/* ═══════════════════════════════════════════════════════
   AMCO — Admin Panel v3
   Design: Refined dark sidebar · Clean light content
   Inspired by Vercel + Stripe dashboard aesthetics
═══════════════════════════════════════════════════════ */

:root {
  /* ── Brand ─────────────────────────────── */
  --adm-gold:          #C9A96E;
  --adm-gold-light:    #F0E4C8;
  --adm-gold-dark:     #A87C42;
  --adm-gold-dim:      rgba(201,169,110,0.14);
  --adm-gold-dim2:     rgba(201,169,110,0.07);

  /* ── Sidebar (dark) ────────────────────── */
  --adm-navy:          #0E0E13;
  --adm-navy-2:        #17171E;
  --adm-navy-3:        #222229;
  --sidebar-hover:     rgba(255,255,255,0.055);
  --sidebar-active:    rgba(255,255,255,0.09);
  --sidebar-border:    rgba(255,255,255,0.07);
  --sidebar-text:      rgba(255,255,255,0.42);
  --sidebar-text-h:    rgba(255,255,255,0.82);

  /* ── Content (light) ───────────────────── */
  --adm-bg:            #F4F4F7;
  --adm-white:         #FFFFFF;
  --adm-surface:       #FFFFFF;
  --adm-surface-2:     #FAFAFA;
  --adm-border:        #E6E6EB;
  --adm-border-2:      #D2D2D9;

  /* ── Text ───────────────────────────────── */
  --adm-text:          #1A1A1E;
  --adm-text-2:        #3C3C43;
  --adm-muted:         #6C6C73;
  --adm-subtle:        #A0A0A8;
  --adm-text-muted:    #6C6C73;

  /* ── Accent colours ────────────────────── */
  --adm-sage:          #22C55E;
  --adm-warning:       #F59E0B;
  --adm-blue:          #3B82F6;
  --adm-red:           #EF4444;

  /* ── Status ─────────────────────────────── */
  --status-pendiente:  #D97706;
  --status-confirmado: #16A34A;
  --status-completado: #2563EB;
  --status-cancelado:  #DC2626;

  /* ── Layout ─────────────────────────────── */
  --sidebar-w:   252px;
  --topbar-h:    60px;
  --radius:      8px;
  --radius-lg:   12px;
  --radius-xl:   16px;

  /* ── Typography ─────────────────────────── */
  --font-serif: 'Playfair Display', Georgia, serif;
  --font-sans:  'Outfit', 'DM Sans', system-ui, sans-serif;

  /* ── Shadows ────────────────────────────── */
  --shadow-xs:  0 1px 2px rgba(0,0,0,0.05);
  --shadow-sm:  0 1px 3px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md:  0 4px 16px rgba(0,0,0,0.08), 0 2px 4px rgba(0,0,0,0.04);
  --shadow-lg:  0 16px 40px rgba(0,0,0,0.13), 0 4px 16px rgba(0,0,0,0.07);
  --shadow-xl:  0 28px 56px rgba(0,0,0,0.18), 0 8px 24px rgba(0,0,0,0.09);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;-webkit-text-size-adjust:100%}
body{font-family:var(--font-sans);background:var(--adm-bg);color:var(--adm-text);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
a{color:inherit;text-decoration:none}
button{font-family:var(--font-sans);cursor:pointer}
input,select,textarea{font-family:var(--font-sans)}
svg{stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}

/* ═══ LOGIN ═══ */
.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;overflow:hidden;background:var(--adm-navy)}
.login-screen::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 20% 50%,rgba(201,169,110,.10) 0%,transparent 65%),radial-gradient(ellipse 60% 80% at 80% 20%,rgba(62,62,80,.5) 0%,transparent 70%);pointer-events:none}
.login-screen::after{content:'';position:absolute;bottom:-20%;left:-10%;width:60%;height:60%;border-radius:50%;background:radial-gradient(circle,rgba(201,169,110,.06) 0%,transparent 70%);pointer-events:none}
.login-box{background:var(--adm-white);border-radius:20px;padding:52px 44px 44px;width:100%;max-width:400px;box-shadow:var(--shadow-xl);text-align:center;position:relative;z-index:1;border:1px solid rgba(255,255,255,.06)}
.login-logo{font-family:var(--font-serif);font-size:28px;font-weight:700;color:var(--adm-navy);letter-spacing:8px;margin-bottom:6px}
.login-logo-bar{width:28px;height:2.5px;background:var(--adm-gold);margin:10px auto 0;border-radius:2px}
.login-sub{font-size:11px;color:var(--adm-muted);letter-spacing:1.5px;text-transform:uppercase;margin-top:14px;margin-bottom:36px;font-weight:500}
.login-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;text-align:left}
.login-group label{font-size:11px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--adm-muted)}
.login-group input{width:100%;padding:12px 14px;border:1.5px solid var(--adm-border);border-radius:10px;font-size:14px;color:var(--adm-text);background:var(--adm-bg);outline:none;transition:border-color .2s,box-shadow .2s,background .2s;font-family:var(--font-sans)}
.login-group input:focus{border-color:var(--adm-gold);background:var(--adm-white);box-shadow:0 0 0 3px rgba(201,169,110,.16)}
.login-error{background:#FEF2F2;color:#991B1B;font-size:13px;padding:10px 14px;border-radius:8px;border:1px solid rgba(153,27,27,.15);margin-bottom:14px;display:none;text-align:left;line-height:1.4}
.login-error.visible{display:block}
.login-btn{width:100%;padding:13px;background:var(--adm-navy);color:#fff;border:none;border-radius:10px;font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s;display:flex;align-items:center;justify-content:center;gap:10px;margin-top:10px;box-shadow:0 2px 10px rgba(14,14,19,.3)}
.login-btn:hover{background:var(--adm-navy-3);transform:translateY(-1px);box-shadow:0 4px 16px rgba(14,14,19,.35)}
.login-btn:active{transform:translateY(0)}
.login-btn:disabled{opacity:.65;cursor:not-allowed;transform:none;box-shadow:none}
.login-btn__spinner{width:15px;height:15px;border:2px solid rgba(255,255,255,.28);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:none}
.login-btn.loading .login-btn__spinner{display:block}
.login-btn.loading .login-btn__text{opacity:.5}
.login-back{display:inline-block;margin-top:22px;font-size:13px;color:var(--adm-subtle);transition:color .2s}
.login-back:hover{color:var(--adm-navy)}
@keyframes spin{to{transform:rotate(360deg)}}

/* ═══ LAYOUT ═══ */
.admin-panel{display:flex;min-height:100vh}

/* ═══ SIDEBAR ═══ */
.sidebar{width:var(--sidebar-w);background:var(--adm-navy);display:flex;flex-direction:column;flex-shrink:0;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform .3s cubic-bezier(.25,.46,.45,.94)}
.sidebar__brand{padding:24px 20px 20px;border-bottom:1px solid var(--sidebar-border)}
.sidebar__logo{font-family:var(--font-serif);font-size:20px;font-weight:700;color:#fff;letter-spacing:6px;display:block}
.sidebar__sub{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--adm-gold);display:block;margin-top:4px;opacity:.8;font-weight:500}
.sidebar__nav{flex:1;padding:10px;overflow-y:auto;scrollbar-width:none}
.sidebar__nav::-webkit-scrollbar{display:none}
.sidebar__link{display:flex;align-items:center;gap:10px;padding:9px 12px;font-size:13px;font-weight:400;color:var(--sidebar-text);transition:color .18s,background .18s;position:relative;border-radius:var(--radius);margin-bottom:1px;letter-spacing:.1px}
.sidebar__link svg{width:16px;height:16px;flex-shrink:0;opacity:.55;transition:opacity .18s}
.sidebar__link:hover{color:var(--sidebar-text-h);background:var(--sidebar-hover)}
.sidebar__link:hover svg{opacity:.85}
.sidebar__link.active{color:#fff;background:var(--sidebar-active);font-weight:500}
.sidebar__link.active svg{opacity:1}
.sidebar__link.active::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);height:18px;width:3px;background:var(--adm-gold);border-radius:0 3px 3px 0}
.sidebar__divider{height:1px;background:var(--sidebar-border);margin:6px 0}
.sidebar__footer{padding:12px 14px;border-top:1px solid var(--sidebar-border);display:flex;align-items:center;justify-content:space-between;gap:8px}
.sidebar__user{display:flex;align-items:center;gap:9px;overflow:hidden;flex:1}
.sidebar__avatar{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--adm-gold) 0%,var(--adm-gold-dark) 100%);color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sidebar__user-info{overflow:hidden;flex:1}
.sidebar__user-name{font-size:13px;font-weight:500;color:rgba(255,255,255,.82);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}
.sidebar__user-role{font-size:10px;color:rgba(255,255,255,.3);display:block;margin-top:1px;text-transform:uppercase;letter-spacing:.5px}
.sidebar__logout{background:none;border:none;color:rgba(255,255,255,.28);cursor:pointer;padding:7px;border-radius:8px;transition:color .18s,background .18s;display:flex;align-items:center;flex-shrink:0}
.sidebar__logout:hover{color:rgba(255,255,255,.8);background:rgba(255,255,255,.07)}
.sidebar__logout svg{width:16px;height:16px}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:99;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}

/* ═══ MAIN ═══ */
.admin-main{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-height:100vh;min-width:0}

/* ═══ TOPBAR ═══ */
.admin-topbar{height:var(--topbar-h);background:var(--adm-white);border-bottom:1px solid var(--adm-border);display:flex;align-items:center;padding:0 24px;gap:14px;position:sticky;top:0;z-index:50}
.topbar__menu-btn{display:none;background:none;border:none;color:var(--adm-muted);padding:7px;border-radius:var(--radius);cursor:pointer;transition:background .18s,color .18s}
.topbar__menu-btn svg{width:20px;height:20px}
.topbar__menu-btn:hover{background:var(--adm-bg);color:var(--adm-text)}
.topbar__title{font-size:14px;font-weight:500;color:var(--adm-text);flex:1;letter-spacing:-.1px}
.topbar__actions{display:flex;align-items:center;gap:8px}
.topbar__refresh,.topbar__site-link{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:var(--radius);font-size:12px;font-weight:500;border:1px solid var(--adm-border);color:var(--adm-muted);background:var(--adm-white);cursor:pointer;transition:all .18s;font-family:var(--font-sans)}
.topbar__refresh svg,.topbar__site-link svg{width:13px;height:13px}
.topbar__refresh:hover{border-color:var(--adm-border-2);color:var(--adm-text);background:var(--adm-bg)}
.topbar__site-link:hover{border-color:var(--adm-gold);color:var(--adm-gold);background:var(--adm-gold-dim2)}
.topbar__refresh.spinning svg{animation:spin .8s linear infinite}

/* ═══ SECTIONS ═══ */
.admin-section{padding:28px 28px 40px;flex:1}

/* ═══ KPI CARDS ═══ */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.kpi-card{background:var(--adm-white);border:1px solid var(--adm-border);border-radius:var(--radius-lg);padding:20px 22px;display:flex;flex-direction:column;gap:14px;transition:box-shadow .22s,transform .22s;position:relative;overflow:hidden}
.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.kpi-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius-lg) var(--radius-lg) 0 0;opacity:0;transition:opacity .22s}
.kpi-card:hover::before{opacity:1}
.kpi-card:nth-child(1)::before{background:var(--adm-gold)}
.kpi-card:nth-child(2)::before{background:var(--adm-blue)}
.kpi-card:nth-child(3)::before{background:var(--adm-sage)}
.kpi-card:nth-child(4)::before{background:var(--adm-warning)}
.kpi-card__ico{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.kpi-card__ico svg{width:19px;height:19px}
.kpi-card__ico--gold{background:rgba(201,169,110,.12);color:var(--adm-gold)}
.kpi-card__ico--navy{background:rgba(59,130,246,.10);color:var(--adm-blue)}
.kpi-card__ico--sage{background:rgba(34,197,94,.10);color:var(--adm-sage)}
.kpi-card__ico--warning{background:rgba(245,158,11,.10);color:var(--adm-warning)}
.kpi-card__ico svg{stroke:currentColor;fill:none}
.kpi-card__body{display:flex;flex-direction:column;gap:4px}
.kpi-card__label{font-size:11px;color:var(--adm-muted);font-weight:500;letter-spacing:.4px;text-transform:uppercase}
.kpi-card__value{font-size:26px;font-weight:600;color:var(--adm-text);line-height:1.1;letter-spacing:-.5px;font-family:var(--font-sans)}

/* ═══ DASH GRID / CARDS ═══ */
.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.dash-card{background:var(--adm-white);border:1px solid var(--adm-border);border-radius:var(--radius-lg);padding:22px 24px;box-shadow:var(--shadow-xs);margin-bottom:14px}
.dash-card h3{font-size:13px;font-weight:600;color:var(--adm-text);margin-bottom:18px;letter-spacing:-.1px}
.dash-card__sub{font-size:12px;color:var(--adm-subtle);font-weight:400;margin-left:5px}

/* ═══ BAR CHART ═══ */
.bar-chart{display:flex;flex-direction:column;gap:9px}
.bar-item{display:flex;align-items:center;gap:10px}
.bar-item__label{font-size:12px;color:var(--adm-muted);width:140px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-item__track{flex:1;height:6px;background:var(--adm-bg);border-radius:3px;overflow:hidden}
.bar-item__fill{height:100%;background:linear-gradient(90deg,var(--adm-gold) 0%,var(--adm-gold-dark) 100%);border-radius:3px;transition:width .7s cubic-bezier(.25,.46,.45,.94)}
.bar-item__val{font-size:12px;font-weight:600;color:var(--adm-text-2);min-width:26px;text-align:right}

/* ═══ ACTIVITY CHART ═══ */
.activity-chart{display:flex;align-items:flex-end;gap:4px;height:88px;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin;scrollbar-color:var(--adm-border) transparent}
.activity-bar{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:default;position:relative}
.activity-bar__fill{width:18px;background:var(--adm-navy);border-radius:3px 3px 0 0;min-height:4px;transition:background .18s,transform .12s}
.activity-bar:hover .activity-bar__fill{background:var(--adm-gold);transform:scaleY(1.05);transform-origin:bottom}
.activity-bar__lbl{font-size:9px;color:var(--adm-subtle);writing-mode:vertical-lr;transform:rotate(180deg);white-space:nowrap;max-height:38px;overflow:hidden}

/* ═══ MINI TABLE ═══ */
.mini-table-wrap{overflow-x:auto}
.mini-table{width:100%;border-collapse:collapse;font-size:13px}
.mini-table th{text-align:left;font-size:10px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--adm-subtle);padding:0 10px 10px;border-bottom:1px solid var(--adm-border)}
.mini-table td{padding:10px;border-bottom:1px solid var(--adm-bg);color:var(--adm-text);vertical-align:middle}
.mini-table tbody tr:last-child td{border-bottom:none}
.mini-table tbody tr:hover td{background:var(--adm-gold-dim2)}

/* ═══ TOOLBAR ═══ */
.section-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.toolbar-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.toolbar-search{padding:8px 14px 8px 36px;border:1.5px solid var(--adm-border);border-radius:var(--radius);font-size:13px;color:var(--adm-text);background:var(--adm-white) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23A0A0A8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E") no-repeat 11px center;width:230px;outline:none;transition:border-color .18s,box-shadow .18s;font-family:var(--font-sans)}
.toolbar-search:focus{border-color:var(--adm-gold);box-shadow:0 0 0 3px rgba(201,169,110,.13)}
.toolbar-date{padding:8px 10px;border:1.5px solid var(--adm-border);border-radius:var(--radius);font-size:12px;color:var(--adm-text);background:var(--adm-white);outline:none;transition:border-color .18s;font-family:var(--font-sans)}
.toolbar-date:focus{border-color:var(--adm-gold)}
.toolbar-btn{padding:8px 16px;background:var(--adm-navy);color:#fff;border:1px solid transparent;border-radius:var(--radius);font-size:12px;font-weight:500;letter-spacing:.2px;cursor:pointer;transition:background .18s,transform .12s,box-shadow .18s;font-family:var(--font-sans)}
.toolbar-btn:hover{background:var(--adm-navy-3);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.toolbar-btn:active{transform:translateY(0)}
.toolbar-btn--ghost{background:var(--adm-white);color:var(--adm-muted);border-color:var(--adm-border)}
.toolbar-btn--ghost:hover{background:var(--adm-bg);color:var(--adm-text);border-color:var(--adm-border-2);box-shadow:none;transform:none}
.total-count{font-size:12px;color:var(--adm-muted);white-space:nowrap;background:var(--adm-bg);padding:5px 12px;border-radius:20px;border:1px solid var(--adm-border);font-weight:500}

/* ═══ DATA TABLE ═══ */
.table-wrap{background:var(--adm-white);border:1px solid var(--adm-border);border-radius:var(--radius-lg);overflow-x:auto;-webkit-overflow-scrolling:touch;box-shadow:var(--shadow-xs)}
.data-table{width:100%;min-width:600px;border-collapse:collapse;font-size:13px}
.data-table thead tr{background:var(--adm-surface-2);border-bottom:1px solid var(--adm-border)}
.data-table th{padding:11px 16px;text-align:left;font-size:10px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--adm-subtle);white-space:nowrap}
.data-table td{padding:13px 16px;border-bottom:1px solid var(--adm-border);color:var(--adm-text);vertical-align:middle}
.data-table tbody tr:last-child td{border-bottom:none}
.data-table tbody tr{transition:background .12s}
.data-table tbody tr:hover td{background:rgba(201,169,110,.04)}
.table-loading{text-align:center!important;padding:52px!important;color:var(--adm-subtle)!important;font-size:13px}

/* ═══ BADGES ═══ */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.2px;text-transform:capitalize;white-space:nowrap}
.badge--pendiente{background:rgba(217,119,6,.10);color:#B45309}
.badge--confirmado{background:rgba(22,163,74,.10);color:#15803D}
.badge--completado{background:rgba(37,99,235,.10);color:#1D4ED8}
.badge--cancelado{background:rgba(220,38,38,.10);color:#B91C1C}

/* ═══ ACTION BUTTONS ═══ */
.action-btn{background:var(--adm-white);border:1px solid var(--adm-border);border-radius:6px;padding:5px 11px;font-size:12px;font-weight:500;color:var(--adm-muted);cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:5px;font-family:var(--font-sans)}
.action-btn:hover{border-color:var(--adm-border-2);color:var(--adm-text);background:var(--adm-bg);box-shadow:var(--shadow-xs)}
.action-btn svg{width:12px;height:12px}
.action-btn--danger{color:var(--status-cancelado);border-color:rgba(220,38,38,.2)}
.action-btn--danger:hover{border-color:rgba(220,38,38,.4);background:rgba(220,38,38,.05);color:var(--status-cancelado);box-shadow:none}

/* ═══ EMPTY INFO ═══ */
.empty-info{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--adm-white);border:1px solid var(--adm-border);border-radius:var(--radius);margin-bottom:18px;color:var(--adm-muted);font-size:13px;box-shadow:var(--shadow-xs)}
.empty-info svg{stroke:var(--adm-subtle);flex-shrink:0}

/* ═══ MODAL ═══ */
.modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}
.modal__backdrop{position:absolute;inset:0;background:rgba(10,10,16,.65);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.modal__box{position:relative;background:var(--adm-white);border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:modalIn .22s cubic-bezier(.34,1.56,.64,1);border:1px solid rgba(0,0,0,.06)}
@keyframes modalIn{from{opacity:0;transform:scale(.93) translateY(14px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--adm-border)}
.modal__header h2{font-size:16px;font-weight:600;color:var(--adm-text);letter-spacing:-.2px}
.modal__close{background:none;border:none;width:28px;height:28px;border-radius:7px;font-size:14px;color:var(--adm-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .18s,background .18s}
.modal__close:hover{color:var(--adm-text);background:var(--adm-bg)}
.modal__body{padding:22px 24px}
.modal-detail{display:flex;flex-direction:column;gap:8px}
.modal-row{display:flex;gap:10px;align-items:flex-start;font-size:13px;padding:9px 12px;border-radius:var(--radius);background:var(--adm-bg);border:1px solid var(--adm-border)}
.modal-row strong{width:100px;flex-shrink:0;font-size:10px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;color:var(--adm-subtle);padding-top:2px}
.modal-row span{color:var(--adm-text);line-height:1.5}
.modal__footer{padding:15px 24px;border-top:1px solid var(--adm-border);display:flex;gap:8px;align-items:center;flex-wrap:wrap;background:var(--adm-surface-2);border-radius:0 0 var(--radius-xl) var(--radius-xl)}
.modal-select{padding:8px 12px;border:1.5px solid var(--adm-border);border-radius:var(--radius);font-size:13px;color:var(--adm-text);background:var(--adm-white);outline:none;cursor:pointer;flex:1;transition:border-color .18s;-webkit-appearance:none;appearance:none;font-family:var(--font-sans)}
.modal-select:focus{border-color:var(--adm-gold)}
.modal-btn{padding:8px 18px;border-radius:var(--radius);font-size:12px;font-weight:600;letter-spacing:.2px;cursor:pointer;border:none;transition:background .18s,transform .12s,box-shadow .18s;font-family:var(--font-sans)}
.modal-btn--save{background:var(--adm-navy);color:#fff}
.modal-btn--save:hover{background:var(--adm-navy-3);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.modal-btn--save:active{transform:translateY(0)}
.modal-btn--delete{background:rgba(220,38,38,.08);color:#B91C1C}
.modal-btn--delete:hover{background:rgba(220,38,38,.15)}

/* ═══ TOAST ═══ */
.toast{position:fixed;bottom:24px;right:24px;padding:11px 18px;border-radius:10px;font-size:13px;font-weight:500;color:#fff;background:var(--adm-navy);box-shadow:var(--shadow-lg);z-index:300;transform:translateY(18px);opacity:0;transition:opacity .3s,transform .3s;pointer-events:none;max-width:320px;border:1px solid rgba(255,255,255,.08)}
.toast.visible{opacity:1;transform:translateY(0)}
.toast.success{background:#166534}
.toast.error{background:#991B1B}

/* ═══ RESPONSIVE ═══ */
@media(max-width:1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.dash-grid{grid-template-columns:1fr}}
@media(max-width:768px){
  .sidebar{transform:translateX(calc(-1 * var(--sidebar-w)))}
  .sidebar.open{transform:translateX(0)}
  .sidebar-overlay.visible{display:block}
  .admin-main{margin-left:0}
  .topbar__menu-btn{display:flex}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .admin-section{padding:16px 16px 32px}
  .toolbar-search{width:100%}
  .data-table{font-size:12px}
  .data-table th,.data-table td{padding:10px 12px}
  .modal{padding:16px}
  .login-box{padding:40px 28px 36px}
}
@media(max-width:480px){
  .kpi-grid{grid-template-columns:1fr}
  .topbar__actions{gap:6px}
  .topbar__site-link span{display:none}
  .login-box{padding:36px 22px 30px}
}

/* ═══ CALENDAR ═══ */
.calendar-wrap{background:var(--adm-white);border:1px solid var(--adm-border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:18px;box-shadow:var(--shadow-xs)}
.calendar-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--adm-border);background:var(--adm-surface-2)}
.cal-header-left{display:flex;align-items:center;gap:10px}
.cal-header-center h3{font-size:15px;color:var(--adm-text);font-weight:600;margin:0;min-width:190px;text-align:center;letter-spacing:-.2px}
.cal-nav-btn{width:30px;height:30px;border-radius:var(--radius);border:1px solid var(--adm-border);background:var(--adm-white);font-size:17px;color:var(--adm-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .16s;line-height:1}
.cal-nav-btn:hover{border-color:var(--adm-border-2);color:var(--adm-text);background:var(--adm-bg)}
.cal-today-btn{font-size:12px;font-weight:500;padding:5px 13px;border-radius:var(--radius);border:1px solid var(--adm-border);background:var(--adm-white);color:var(--adm-muted);cursor:pointer;transition:all .16s;font-family:var(--font-sans)}
.cal-today-btn:hover{border-color:var(--adm-gold);color:var(--adm-gold);background:var(--adm-gold-dim2)}
.cal-header-right{display:flex;align-items:center;gap:8px}
.cal-legend-inline{display:flex;gap:14px;flex-wrap:wrap}
.cal-legend-inline span{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--adm-muted);white-space:nowrap}
.cal-dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0}
.dot--pendiente{background:var(--status-pendiente)}
.dot--confirmado{background:var(--status-confirmado)}
.dot--completado{background:var(--status-completado)}
.dot--cancelado{background:var(--status-cancelado)}
.calendar-dow{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--adm-border);background:var(--adm-surface-2)}
.calendar-dow span{text-align:center;font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--adm-subtle);padding:8px 4px;border-right:1px solid var(--adm-border)}
.calendar-dow span:last-child{border-right:none}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:minmax(110px,auto)}
.cal-day{border-right:1px solid var(--adm-border);border-bottom:1px solid var(--adm-border);padding:7px 6px 5px;cursor:pointer;transition:background .12s;position:relative;display:flex;flex-direction:column;gap:3px;min-height:110px;overflow:hidden}
.cal-day:nth-child(7n){border-right:none}
.cal-day--empty{background:var(--adm-bg);cursor:default;opacity:.5}
.cal-day:not(.cal-day--empty):hover{background:rgba(201,169,110,.04)}
.cal-day--today{background:rgba(14,14,19,.025)}
.cal-day--selected{background:rgba(201,169,110,.08)!important;box-shadow:inset 0 0 0 1.5px var(--adm-gold)}
.cal-day--weekend{background:rgba(0,0,0,.01)}
.cal-day__num{font-size:12px;font-weight:500;color:var(--adm-text-2);line-height:1;display:flex;align-items:center;justify-content:flex-end;margin-bottom:2px}
.cal-day--today .cal-day__num span{background:var(--adm-navy);color:#fff;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600}
.cal-turno{display:flex;align-items:center;gap:4px;padding:2px 5px;border-radius:4px;font-size:10.5px;font-weight:500;line-height:1.3;cursor:pointer;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;transition:opacity .12s;flex-shrink:0}
.cal-turno:hover{opacity:.78}
.cal-turno__hora{font-size:9.5px;font-weight:700;opacity:.75;flex-shrink:0}
.cal-turno__nombre{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal-turno--pendiente{background:rgba(217,119,6,.12);color:#92400E;border-left:2.5px solid var(--status-pendiente)}
.cal-turno--confirmado{background:rgba(22,163,74,.10);color:#14532D;border-left:2.5px solid var(--status-confirmado)}
.cal-turno--completado{background:rgba(37,99,235,.10);color:#1E3A8A;border-left:2.5px solid var(--status-completado)}
.cal-turno--cancelado{background:rgba(220,38,38,.08);color:#7F1D1D;border-left:2.5px solid var(--status-cancelado)}
.cal-turno--mas{background:var(--adm-bg);color:var(--adm-muted);border-left:2.5px solid var(--adm-border-2);font-weight:400;font-size:10px}
.cal-turno--mas:hover{background:var(--adm-border);opacity:1}
.calendar-empty{grid-column:1/-1;text-align:center;padding:48px;color:var(--adm-subtle);font-size:14px}
@media(max-width:768px){.calendar-header{flex-direction:column;gap:12px;align-items:flex-start}.cal-header-right{display:none}.calendar-grid{grid-auto-rows:minmax(80px,auto)}.cal-day{min-height:80px;padding:4px 3px}.cal-turno{font-size:10px;padding:2px 4px}.cal-turno__hora{display:none}}
@media(max-width:480px){.calendar-grid{grid-auto-rows:minmax(60px,auto)}.cal-day{min-height:60px}}

/* ═══ MEDICO / ROLE TAGS ═══ */
.medico-tag{font-size:11px;padding:2px 9px;border-radius:20px;font-weight:600;display:inline-block}
.medico-tag--baccon{background:rgba(59,130,246,.10);color:#1D4ED8}
.medico-tag--cappello{background:rgba(22,163,74,.10);color:#15803D}
.medico-tag--molinari{background:rgba(168,85,247,.10);color:#6D28D9}
.medico-tag--magdalena{background:rgba(236,72,153,.10);color:#BE185D}
.role-tag{font-size:11px;padding:2px 9px;border-radius:20px;font-weight:600;display:inline-block}
.role-tag--admin{background:rgba(245,158,11,.10);color:#92400E}
.role-tag--doctor{background:rgba(59,130,246,.10);color:#1E40AF}

/* ═══ FORM GROUPS ═══ */
.form-group-adm{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.form-group-adm label{font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--adm-muted)}
.form-group-adm input,.form-group-adm select,.form-group-adm textarea{padding:9px 12px;border:1.5px solid var(--adm-border);border-radius:var(--radius);font-family:var(--font-sans);font-size:13px;color:var(--adm-text);background:var(--adm-white);outline:none;transition:border-color .18s,box-shadow .18s;-webkit-appearance:none;appearance:none;width:100%}
.form-group-adm input:focus,.form-group-adm select:focus,.form-group-adm textarea:focus{border-color:var(--adm-gold);box-shadow:0 0 0 3px rgba(201,169,110,.13)}
.form-group-adm input.input-error,.form-group-adm select.input-error{border-color:#F87171!important;box-shadow:0 0 0 3px rgba(248,113,113,.11)!important}

/* ═══ CRED CARDS ═══ */
.cred-card{background:var(--adm-bg);border:1px solid var(--adm-border);border-radius:10px;padding:12px 16px;transition:box-shadow .18s}
.cred-card:hover{box-shadow:var(--shadow-sm)}
.cred-card--doctor{border-left:3px solid var(--adm-gold)}
.cred-card__role{font-size:9.5px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--adm-subtle);margin-bottom:5px}
.cred-card__info{display:flex;gap:8px;font-size:13px;font-weight:600;color:var(--adm-text);font-family:'Courier New',monospace;margin-bottom:4px}
.cred-card__desc{font-size:12px;color:var(--adm-muted)}

/* ═══ FICHA CLÍNICA ═══ */
.ficha-section{border:1px solid var(--adm-border);border-radius:var(--radius-lg);padding:20px;margin-bottom:16px;background:var(--adm-surface-2);box-shadow:0 1px 4px rgba(0,0,0,.04)}
.ficha-section__title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--adm-text-2);margin-bottom:16px;padding-bottom:11px;border-bottom:2px solid var(--adm-border)}
.ficha-grid{display:grid;gap:10px}
.ficha-grid--2{grid-template-columns:1fr 1fr}
.ficha-grid--3{grid-template-columns:1fr 1fr 1fr}
.ficha-col--full{grid-column:1/-1}
@media(max-width:560px){.ficha-grid--2,.ficha-grid--3{grid-template-columns:1fr}}

/* ═══ ODONTOGRAMA ═══ */
.odontograma-wrap{width:100%}

/* Leyenda / selector de estado activo */
.odontograma-legend{display:flex;flex-wrap:wrap;gap:6px 10px;margin-bottom:14px}
.odontograma-legend__item{display:flex;align-items:center;gap:6px;font-size:11.5px;font-weight:500;color:var(--adm-text-2);padding:4px 10px;border-radius:20px;border:1.5px solid transparent;cursor:pointer;transition:all .15s;user-select:none}
.odontograma-legend__item:hover{background:var(--adm-bg);border-color:var(--adm-border)}
.odontograma-legend__item.od-legend--active{border-color:currentColor;font-weight:700}
.odontograma-legend__item.od-legend--active.od-pick--sano{color:#16a34a;background:#f0fdf4}
.odontograma-legend__item.od-legend--active.od-pick--caries{color:#E74C3C;background:#FDE8E8}
.odontograma-legend__item.od-legend--active.od-pick--extraccion{color:#2C3E50;background:#ecf0f1}
.odontograma-legend__item.od-legend--active.od-pick--obturacion{color:#2980B9;background:#D6EAF8}
.odontograma-legend__item.od-legend--active.od-pick--corona{color:#D68910;background:#FEF9E7}
.odontograma-legend__item.od-legend--active.od-pick--implante{color:#1E8449;background:#D5F5E3}
.odontograma-legend__item.od-legend--active.od-pick--ausente{color:#7F8C8D;background:#f4f4f4}

.od-dot{width:11px;height:11px;border-radius:50%;display:inline-block;flex-shrink:0}
.od-dot--caries{background:#E74C3C}
.od-dot--extraccion{background:#2C3E50}
.od-dot--obturacion{background:#3498DB}
.od-dot--corona{background:#F39C12}
.od-dot--implante{background:#27AE60}
.od-dot--ausente{background:#BDC3C7;border:1px solid #999}
.od-dot--sano{background:#16a34a}

/* Contenedor principal */
.odontograma-container{display:flex;flex-direction:column;gap:8px;background:var(--adm-white);border:1.5px solid var(--adm-border);border-radius:12px;padding:16px 10px;overflow-x:auto;box-shadow:inset 0 1px 4px rgba(0,0,0,.03)}
.od-arch{display:flex;flex-direction:column;gap:6px}
.od-arch--top{padding-bottom:10px;border-bottom:1px dashed var(--adm-border)}
.od-arch--bottom{padding-top:10px}
.od-row{display:flex;align-items:center;justify-content:center;gap:3px}
.od-row--nums{font-size:9.5px;color:var(--adm-subtle);font-family:monospace}
.od-row--nums span{width:44px;text-align:center}
.od-row--nums .od-separator{height:12px}
.od-separator{width:1px;background:var(--adm-border);margin:0 8px;align-self:stretch;min-height:16px}

/* Dientes grandes */
.od-tooth{
  width:44px;height:56px;
  border:2px solid var(--adm-border);
  border-radius:7px 7px 10px 10px;
  background:var(--adm-white);
  cursor:pointer;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  position:relative;
  transition:transform .15s cubic-bezier(.34,1.56,.64,1), border-color .15s, box-shadow .18s, background .15s;
  overflow:visible;
}
.od-tooth:hover{
  transform:translateY(-5px) scale(1.1);
  border-color:var(--adm-gold);
  z-index:5;
  box-shadow:0 8px 20px rgba(0,0,0,.16);
}
/* Tooltip al hacer hover */
.od-tooth::after{
  content:attr(data-label);
  position:absolute;
  bottom:calc(100% + 7px);
  left:50%;transform:translateX(-50%);
  background:#1e293b;color:#fff;
  font-size:9px;font-weight:600;font-family:inherit;
  padding:3px 7px;border-radius:5px;
  white-space:nowrap;pointer-events:none;
  opacity:0;transition:opacity .15s;
  letter-spacing:.2px;
  z-index:20;
}
.od-tooth:hover::after{opacity:1}

/* Estado colores */
.od-tooth[data-estado="sano"]{background:#f0fdf4;border-color:#86efac}
.od-tooth[data-estado="caries"]{background:#FDE8E8;border-color:#E74C3C;box-shadow:0 2px 6px rgba(231,76,60,.15)}
.od-tooth[data-estado="extraccion"]{background:#34495e;border-color:#2C3E50}
.od-tooth[data-estado="obturacion"]{background:#D6EAF8;border-color:#3498DB;box-shadow:0 2px 6px rgba(52,152,219,.12)}
.od-tooth[data-estado="corona"]{background:#FEF9E7;border-color:#F39C12;box-shadow:0 2px 6px rgba(243,156,18,.15)}
.od-tooth[data-estado="implante"]{background:#D5F5E3;border-color:#27AE60;box-shadow:0 2px 6px rgba(39,174,96,.12)}
.od-tooth[data-estado="ausente"]{background:#f4f4f4;border-color:#BDC3C7;opacity:.5}

/* Ícono del diente más grande */
.od-tooth__icon{font-size:24px;line-height:1;display:block}

/* Número pequeño debajo del ícono */
.od-tooth__num{font-size:8px;font-weight:700;opacity:.55;margin-top:2px;font-family:monospace}
.od-tooth[data-estado="extraccion"] .od-tooth__num{color:#ecf0f1}

/* ═══ ANAMNESIS ═══ */
.anamnesis-checks{display:flex;flex-direction:column;gap:7px}
.anam-row{display:flex;align-items:center;flex-wrap:wrap;gap:8px;padding:9px 14px;background:var(--adm-white);border-radius:var(--radius);border:1px solid var(--adm-border);transition:border-color .15s,background .15s}
.anam-row:hover{border-color:var(--adm-gold)}
.anam-row--si{background:#fffdf0;border-color:#F39C12}
.anam-label{font-size:13px;font-weight:500;color:var(--adm-text);min-width:130px}
.anam-check{display:flex;align-items:center;gap:5px;font-size:13px;cursor:pointer;color:var(--adm-text)}
.anam-check input[type="checkbox"]{accent-color:var(--adm-gold);width:14px;height:14px}
.anam-input{flex:1;min-width:140px;padding:5px 9px;border:1.5px solid var(--adm-border);border-radius:6px;background:var(--adm-bg);color:var(--adm-text);font-size:12px;font-family:var(--font-sans)}
.anam-input:focus{outline:none;border-color:var(--adm-gold)}

/* ═══ NUEVO TURNO MODAL ═══ */
.nt-modal-box{overflow-y:auto}
.nt-header{gap:0}
.nt-header-inner{display:flex;align-items:center;gap:12px}
.nt-header-icon{font-size:1.5rem;line-height:1}
.nt-header-sub{margin:2px 0 0;font-size:12px;color:var(--adm-muted);font-weight:400}
.nt-body{padding:20px 24px!important}
.nt-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 24px!important;border-top:1px solid var(--adm-border);background:var(--adm-surface-2)}
.nt-section-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--adm-gold);margin-bottom:10px}
.nt-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.nt-full{grid-column:1/-1}
.nt-required{color:#F87171;font-size:13px}
.nt-field-error{display:block;font-size:11px;color:#F87171;margin-top:4px;min-height:14px}
.nt-autocomplete-wrap{position:relative}
.nt-sugg-list{position:absolute;top:calc(100% - 4px);left:0;right:0;z-index:9999;background:var(--adm-white);border:1.5px solid var(--adm-gold);border-top:none;border-radius:0 0 10px 10px;box-shadow:var(--shadow-md);list-style:none;margin:0;padding:4px 0;max-height:200px;overflow-y:auto}
.nt-sugg-item{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;cursor:pointer;transition:background .12s}
.nt-sugg-item:hover{background:var(--adm-gold-dim2)}
.nt-sugg-nombre{font-size:13px;font-weight:600;color:var(--adm-text)}
.nt-sugg-meta{font-size:11px;color:var(--adm-muted)}
.nt-save-btn{background:var(--adm-gold)!important;color:#fff!important;border-color:var(--adm-gold)!important;min-width:130px;font-weight:600}
.nt-save-btn:hover:not(:disabled){filter:brightness(1.07);transform:translateY(-1px)}
.nt-save-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}

/* ═══ HISTORIAL DEL DÍA — card ═══ */
.historial-card{background:var(--adm-white);border:1px solid var(--adm-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xs);transition:box-shadow .2s}
.historial-card:hover{box-shadow:var(--shadow-sm)}

/* ═══ SPINNERS ═══ */
.btn-spinner{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle;margin-right:5px}
.modal--closing .modal__box{animation:modalOut .16s ease forwards}
@keyframes modalOut{to{opacity:0;transform:scale(.95) translateY(8px)}}

/* ═══ SCROLLBAR ═══ */
/* ── 1024×768 and similar tablet/low-height screens ── */
@media(max-width:1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-height:800px){
  .modal{padding:12px;align-items:flex-start;padding-top:56px}
  .modal__box{max-height:calc(100vh - 68px)}
  .nt-body{padding:14px 18px!important}
  .nt-footer{padding:10px 18px!important}
  .form-group-adm{margin-bottom:8px}
}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--adm-border-2);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--adm-muted)}
