/* ═══════════════════════════════════════════════════════
   IBSALA v3 — design system
   ═══════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* surfaces */
  --bg:#f7faff;
  --bg2:#eef3fb;
  --bg3:#e3ebf6;
  --surface:#ffffff;
  --border:#d6deec;
  --border-soft:#e9eef7;

  /* brand */
  --blue:#002555;
  --blue-2:#0a3570;
  --blue-dim:#003a80;
  --blue-glow:rgba(0,37,85,.08);
  --gold:#F5AC00;
  --gold-dim:#d89700;
  --gold-soft:#fff4d0;

  /* legacy aliases (usados inline no HTML) */
  --cyan:#F5AC00;
  --yellow:#F5AC00;

  /* semantic */
  --green:#16a34a;
  --green-soft:#ddf5e4;
  --red:#dc2626;
  --red-soft:#fde8e8;

  /* text */
  --text:#0b1220;
  --text-dim:#475168;
  --text-muted:#8894ab;

  /* elevation */
  --shadow-sm:0 1px 2px rgba(0,37,85,.05);
  --shadow-md:0 4px 16px rgba(0,37,85,.08),0 1px 3px rgba(0,37,85,.05);
  --shadow-lg:0 12px 36px rgba(0,37,85,.14),0 2px 6px rgba(0,37,85,.06);

  /* radius scale */
  --r-sm:6px;
  --r-md:10px;
  --r-lg:14px;
  --r-xl:20px;

  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}

html{height:100%;scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}
body{min-height:100%;display:flex;flex-direction:column;background:var(--bg);color:var(--text);font-family:var(--font);font-size:15px;line-height:1.65;font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}

/* ── app shell ───────────────────────────── */
#app{max-width:980px;margin:0 auto;padding:calc(32px + env(safe-area-inset-top)) 22px 32px;flex:1;width:100%;border-top:3px solid var(--gold)}

/* ── header ──────────────────────────────── */
.site-header{position:relative;background:linear-gradient(135deg,var(--surface) 0%,var(--bg2) 100%);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px 14px;margin-bottom:24px;box-shadow:var(--shadow-sm);overflow:hidden}
.site-header::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--blue) 0%,var(--gold) 100%)}
.hdr-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.hdr-brand{display:flex;align-items:center;gap:12px;text-decoration:none;cursor:pointer;-webkit-tap-highlight-color:transparent;flex-shrink:1;min-width:0}
.hdr-mark{width:28px;height:28px;border-radius:7px;background:linear-gradient(135deg,var(--blue) 0%,var(--blue-2) 100%);position:relative;flex-shrink:0;box-shadow:0 2px 8px rgba(0,37,85,.18)}
.hdr-mark::after{content:"";position:absolute;right:-3px;bottom:-3px;width:10px;height:10px;border-radius:50%;background:var(--gold);box-shadow:0 1px 4px rgba(245,172,0,.5);border:2px solid var(--surface)}
.hdr-brand-text{display:flex;flex-direction:column;line-height:1.1;min-width:0}
.hdr-name{font-family:var(--font-display,var(--font));font-size:20px;font-weight:900;color:var(--blue);letter-spacing:1.2px}
.hdr-tag{font-size:11px;color:var(--text-muted);font-weight:600;letter-spacing:.4px;margin-top:3px;text-transform:lowercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hdr-stats{display:flex;flex-wrap:wrap;gap:6px;animation:fadeIn .4s ease both}
.hdr-stat{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:var(--text-dim);padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:var(--bg);letter-spacing:.2px;white-space:nowrap}
.hdr-stat .hs-ico{font-size:11px;line-height:1;opacity:.75}
.hdr-stat-day{background:linear-gradient(135deg,var(--blue) 0%,var(--blue-2) 100%);color:#fff;border-color:var(--blue);font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:4px 11px}
.hdr-stat-day .hs-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 3px rgba(245,172,0,.3);animation:agoraPulse 2s ease-in-out infinite;flex-shrink:0}
.hdr-stat-cap{color:var(--text-muted);background:transparent;border-style:dashed}
.hdr-loading{font-size:12px;color:var(--text-dim)}

/* ── splash v3 ───────────────────────────── */
#splash{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#f7faff 0%,#e8eef8 100%);opacity:1;transition:opacity .45s ease}
#splash.hide{opacity:0;pointer-events:none}
.spl-grid{position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:48px 48px;opacity:.4;pointer-events:none;mask-image:radial-gradient(circle at center,#000 35%,transparent 80%);-webkit-mask-image:radial-gradient(circle at center,#000 35%,transparent 80%)}
.spl-corner{position:absolute;width:22px;height:22px;border-color:var(--gold);border-style:solid;opacity:.6}
.spl-corner.tl{top:28px;left:28px;border-width:2px 0 0 2px}
.spl-corner.tr{top:28px;right:28px;border-width:2px 2px 0 0}
.spl-corner.bl{bottom:28px;left:28px;border-width:0 0 2px 2px}
.spl-corner.br{bottom:28px;right:28px;border-width:0 2px 2px 0}
.spl-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center}
.spl-logo{font-size:40px;font-weight:800;color:var(--blue);letter-spacing:4px;line-height:1;margin-bottom:12px;display:inline-flex;align-items:center;gap:4px}
.spl-slash{color:var(--gold);font-weight:800}
.spl-version{font-size:12px;font-weight:800;letter-spacing:1.5px;color:var(--blue);background:var(--gold);padding:4px 10px;border-radius:999px;margin-left:10px;position:relative;top:-12px;box-shadow:0 3px 12px rgba(245,172,0,.4);text-transform:uppercase}
.spl-sub{font-size:11px;letter-spacing:3px;color:var(--text-muted);text-transform:uppercase;margin-bottom:28px;font-weight:600}
.spl-track{width:160px;height:3px;background:var(--border);border-radius:2px;overflow:hidden;margin-bottom:14px}
@keyframes spl-fill{0%{transform:translateX(-100%)}100%{transform:translateX(0)}}
.spl-fill{height:100%;width:100%;background:linear-gradient(90deg,var(--gold) 0%,var(--gold-dim) 100%);transform:translateX(-100%);animation:spl-fill 1.4s cubic-bezier(.4,0,.2,1) forwards}
.spl-txt{font-size:11px;color:var(--text-dim);letter-spacing:2px;text-transform:uppercase;font-weight:600}
@keyframes spl-blink{0%,100%{opacity:1}50%{opacity:0}}
.spl-cur{display:inline-block;width:6px;height:11px;background:var(--gold);vertical-align:middle;margin-left:4px;animation:spl-blink .9s step-end infinite}

@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.cursor{display:inline-block;width:7px;height:14px;background:var(--gold);animation:blink 1s step-end infinite;vertical-align:middle;margin-left:2px}

/* ── screens ─────────────────────────────── */
.screen{display:none;opacity:0;pointer-events:none;transition:opacity .15s}
.screen.active{display:block;opacity:1;pointer-events:auto;animation:fadeUp .25s ease both}

/* ── section titles ──────────────────────── */
.stitle{color:var(--blue);font-size:11px;letter-spacing:2px;text-transform:uppercase;margin-bottom:22px;padding-bottom:10px;border-bottom:2px solid var(--blue);font-weight:700}
.stitle::before{content:'//';color:var(--gold);margin-right:8px;font-weight:800;font-size:13px;letter-spacing:0}

/* ── menu ────────────────────────────────── */
.menu{list-style:none;display:flex;flex-direction:column;gap:8px}
.menu-item{display:flex;align-items:center;gap:14px;padding:16px 20px;border:1px solid var(--border);background:var(--surface);cursor:pointer;min-height:56px;border-radius:var(--r-md);box-shadow:var(--shadow-sm);transition:border-color .2s,background .2s,transform .15s,box-shadow .2s}
.menu-item:hover{border-color:var(--blue);background:var(--bg);transform:translateX(3px);box-shadow:var(--shadow-md)}
.menu-item:active{transform:translateX(2px) scale(.99)}
.menu-item.hl{border-color:var(--blue);border-left:4px solid var(--blue);background:linear-gradient(90deg,rgba(0,37,85,.05) 0%,var(--surface) 60%)}
.menu-key{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;border-radius:var(--r-sm);color:var(--blue);background:var(--bg2);font-weight:800;font-size:14px;flex-shrink:0}
.menu-item.hl .menu-key{background:var(--gold);color:var(--blue)}
.menu-label{color:var(--text);flex:1;font-size:15px;font-weight:600}
.menu-item.hl .menu-label{color:var(--blue)}
.menu-badge{color:var(--text-muted);font-size:12px;font-weight:500}

/* ── back button ─────────────────────────── */
.btn-back{background:var(--surface);border:1px solid var(--border);color:var(--text-dim);font-family:var(--font);font-size:13px;padding:9px 18px;cursor:pointer;margin-bottom:22px;min-height:40px;border-radius:var(--r-md);font-weight:500;box-shadow:var(--shadow-sm);transition:border-color .18s,color .18s,transform .15s}
.btn-back:hover{border-color:var(--blue);color:var(--blue);transform:translateX(-3px)}
.btn-back:active{transform:translateX(-1px)}

/* ── inputs ──────────────────────────────── */
.igroup{display:flex;gap:0;margin-bottom:16px;border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm)}
.iprefix{background:var(--bg2);border:1px solid var(--border);border-right:none;padding:11px 14px;color:var(--blue);font-family:var(--font);font-size:14px;font-weight:700;display:flex;align-items:center}
input[type=text],input[type=email],input[type=password]{flex:1;background:var(--surface);border:1px solid var(--border);color:var(--text);font-family:var(--font);font-size:15px;padding:11px 14px;outline:none;font-weight:400;transition:border-color .18s,box-shadow .18s}
input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,37,85,.12)}
.igroup input{border-radius:0}
select{background:var(--surface);border:1px solid var(--border);color:var(--text);font-family:var(--font);font-size:14px;padding:11px 12px;outline:none;cursor:pointer;min-height:44px;font-weight:500;border-radius:var(--r-md);transition:border-color .18s,box-shadow .18s}
select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,37,85,.12)}

/* ── buttons ─────────────────────────────── */
.btn{background:var(--blue);border:1px solid var(--blue);color:#fff;font-family:var(--font);font-size:14px;padding:11px 20px;cursor:pointer;white-space:nowrap;min-height:44px;border-radius:var(--r-md);font-weight:600;box-shadow:var(--shadow-sm);transition:background .18s,border-color .18s,transform .12s,box-shadow .18s,filter .18s}
.btn:hover{background:var(--blue-2);border-color:var(--blue-2);box-shadow:var(--shadow-md)}
.btn:active{transform:scale(.97);filter:brightness(.96)}
.btn.primary{background:linear-gradient(180deg,var(--gold) 0%,var(--gold-dim) 100%);border-color:var(--gold-dim);color:#1a0f00;font-weight:700;box-shadow:0 2px 10px rgba(245,172,0,.28),var(--shadow-sm)}
.btn.primary:hover{filter:brightness(1.06);box-shadow:0 4px 16px rgba(245,172,0,.38),var(--shadow-md)}
.btn.success{background:#fff;border:1px solid var(--green);color:var(--green)}
.btn.success:hover{background:var(--green-soft);border-color:var(--green)}
.btn.danger{background:#fff;border:1px solid var(--red);color:var(--red)}
.btn.danger:hover{background:var(--red-soft);border-color:var(--red)}
.btn.sm{padding:8px 14px;font-size:12px;min-height:36px}
.btn-trash{font-size:16px;line-height:1;padding:8px 12px;min-width:40px}
.btn:disabled,.btn[disabled]{opacity:.45;cursor:not-allowed;pointer-events:none;box-shadow:none}

/* ── tables ──────────────────────────────── */
.tbl{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;margin-top:10px;border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm);background:var(--surface)}
.tbl th{background:var(--blue);color:#fff;padding:11px 14px;text-align:left;font-weight:600;font-size:11px;letter-spacing:.5px;text-transform:uppercase}
.tbl td{padding:11px 14px;border-bottom:1px solid var(--border-soft);color:var(--text);vertical-align:top;transition:background .15s}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:var(--bg2)}
.c-sala{color:var(--blue);font-weight:700}
.c-hora{color:var(--blue);font-weight:500}
.c-turma{color:var(--green);font-weight:600}
.c-dim{color:var(--text-muted)}

/* ── categories ──────────────────────────── */
.cat-block{margin-bottom:28px;animation:fadeUp .22s ease both}
.cat-label{display:inline-block;color:var(--blue);font-size:11px;letter-spacing:1px;margin-bottom:12px;padding:5px 14px;border-left:3px solid var(--gold);background:var(--bg2);font-weight:700;text-transform:uppercase;border-radius:0 var(--r-sm) var(--r-sm) 0}

/* ── messages ────────────────────────────── */
.msg{padding:12px 16px;border-left:3px solid;margin-bottom:14px;font-size:14px;border-radius:0 var(--r-md) var(--r-md) 0;animation:slideDown .18s ease both}
.msg.info{border-color:var(--blue);background:#e8f2ff;color:var(--blue)}
.msg.ok{border-color:var(--green);background:var(--green-soft);color:#0f5a24}
.msg.warn{border-color:var(--gold);background:var(--gold-soft);color:#7a5a00}
.msg.error{border-color:var(--red);background:var(--red-soft);color:#9b1c1c}

/* ── push nudge (banner s-hoje pra ativar notificacoes) ───────── */
.push-nudge{background:var(--bg2);border:1px solid var(--gold);border-left:3px solid var(--gold);padding:12px 14px;margin:0 0 14px 0;border-radius:0 var(--r-md) var(--r-md) 0}
.push-nudge-title{color:var(--text);font-weight:600;font-size:13px;margin-bottom:4px}
.push-nudge-text{color:var(--text-dim);font-size:12px;line-height:1.5}
.push-nudge-ios .push-nudge-text strong{color:var(--text)}

/* ── loading / hr ────────────────────────── */
.loading{color:var(--text-muted);font-size:14px;padding:20px 0;font-weight:500;animation:pulse 1.4s ease-in-out infinite}
hr{border:none;border-top:1px solid var(--border-soft);margin:24px 0}

/* ── aula card ───────────────────────────── */
.aula-card{border:1px solid var(--border);border-left:3px solid var(--blue);background:var(--surface);padding:18px 20px;margin-bottom:14px;border-radius:var(--r-md);box-shadow:var(--shadow-md);animation:fadeUp .22s ease both;transition:box-shadow .2s,transform .2s}
.aula-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}
.aula-card-title{color:var(--blue);font-size:15px;margin-bottom:6px;font-weight:700}
.aula-card-meta{color:var(--text-muted);font-size:13px;margin-bottom:12px;font-weight:500}

/* ── pick list ───────────────────────────── */
.pick-list{list-style:none}
.pick-item{padding:12px 14px;border:1px solid var(--border);background:var(--surface);cursor:pointer;margin-bottom:6px;font-size:13px;display:flex;flex-wrap:wrap;gap:8px;align-items:center;min-height:48px;border-radius:var(--r-md);box-shadow:var(--shadow-sm);animation:fadeIn .15s ease both;transition:border-color .15s,background .15s,transform .12s,box-shadow .18s}
.pick-item:hover{border-color:var(--blue);background:var(--bg2);transform:translateX(2px);box-shadow:var(--shadow-md)}
.pick-item:nth-child(1){animation-delay:.00s}
.pick-item:nth-child(2){animation-delay:.03s}
.pick-item:nth-child(3){animation-delay:.06s}
.pick-item:nth-child(4){animation-delay:.09s}
.pick-item:nth-child(n+5){animation-delay:.12s}
.pi-turma{color:var(--green);font-weight:600}
.pi-disc{color:var(--text);flex:1;min-width:160px;font-weight:500}
.pi-prof{color:var(--text-muted);font-size:12px}
.pi-sala{color:var(--blue);font-weight:700}
.pi-hora{color:var(--text-dim);font-size:12px}

/* ── dt list ─────────────────────────────── */
.dt-list{list-style:none;margin-bottom:16px}
.dt-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border:1px solid var(--border);background:var(--surface);margin-bottom:6px;font-size:13px;min-height:48px;border-radius:var(--r-md);box-shadow:var(--shadow-sm)}
.dt-dia{color:var(--blue);min-width:74px;font-weight:600}
.dt-disc{color:var(--text);flex:1}
.dt-rm{background:none;border:none;color:var(--text-muted);cursor:pointer;font-family:var(--font);font-size:16px;padding:4px 8px;min-height:36px;min-width:36px;border-radius:var(--r-sm);transition:color .15s,background .15s}
.dt-rm:hover{color:var(--red);background:var(--red-soft)}

.btn-row{display:flex;gap:12px;flex-wrap:wrap}
.tbl-inp{background:transparent;border:none;border-bottom:1px solid var(--border);color:var(--text);font-family:var(--font);font-size:13px;padding:5px 6px;width:100%;outline:none;transition:border-color .15s}
.tbl-inp:focus{border-bottom-color:var(--blue)}
.add-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.add-row input{flex:1;min-width:160px}

/* ── footer ──────────────────────────────── */
footer{background:linear-gradient(180deg,var(--blue) 0%,#001a3d 100%);border-top:3px solid var(--gold);text-align:center;font-size:12px;color:rgba(255,255,255,.75);letter-spacing:.3px;padding:14px 22px;width:100%;flex-shrink:0;font-weight:500}
footer a{color:var(--gold)!important}

/* ── trava ───────────────────────────────── */
body.travado .menu-item:not(.adm-item){pointer-events:none;border-color:var(--red)!important;background:var(--red-soft)!important}
body.travado .menu-item:not(.adm-item) .menu-label{color:var(--red)!important}
body.travado .menu-item:not(.adm-item) .menu-key{color:var(--red)!important;background:transparent!important}
body.travado .menu-item:not(.adm-item) .menu-badge{color:#c0392b88!important}
body.travado .btn{pointer-events:none;border-color:var(--red)!important;color:var(--red)!important;background:var(--red-soft)!important}
#banner-trava{display:none;background:var(--red-soft);border:1px solid var(--red);color:var(--red);padding:14px 20px;margin-bottom:22px;text-align:center;font-size:15px;border-radius:var(--r-md)}
body.travado #banner-trava{display:block}

/* ── keyframes ───────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ── details ─────────────────────────────── */
.slot-arrow{display:inline-block;transition:transform .25s ease}
details[open] .slot-arrow{transform:rotate(90deg)}
details>summary{transition:background .18s;border-radius:var(--r-sm);padding:4px 8px}
details>summary:hover{background:var(--bg2)!important}
details[open]>div{animation:slideDown .2s ease both}

/* ── switch ──────────────────────────────── */
.sw{display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none;transition:transform .15s}
.sw:hover{transform:scale(1.03)}
.sw-track{width:40px;height:22px;background:var(--border);border-radius:12px;position:relative;transition:background .25s ease;flex-shrink:0;box-shadow:inset 0 1px 2px rgba(0,0,0,.08)}
.sw-track.on{background:var(--gold)}
.sw-thumb{position:absolute;top:3px;left:3px;width:16px;height:16px;background:#fff;border-radius:50%;box-shadow:0 1px 3px rgba(0,0,0,.25);transition:transform .25s cubic-bezier(.4,0,.2,1)}
.sw-track.on .sw-thumb{transform:translateX(18px)}
.sw-label{font-size:12px;color:var(--text-muted);font-weight:500;transition:color .25s}
.sw:hover .sw-label{color:var(--text)}

/* ── badge AGORA ─────────────────────────── */
@keyframes agoraPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.04)}}
.badge-agora{animation:agoraPulse 2s ease-in-out infinite}

/* ── chips ───────────────────────────────── */
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.chip{background:var(--surface);border:1px solid var(--border);color:var(--text-dim);font-family:var(--font);font-size:12px;padding:7px 14px;cursor:pointer;min-height:36px;display:inline-flex;align-items:center;user-select:none;border-radius:var(--r-xl);font-weight:600;box-shadow:var(--shadow-sm);transition:border-color .15s,color .15s,background .15s,transform .12s,box-shadow .18s}
.chip:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.chip.active{border-color:var(--gold);color:#7a5a00;background:var(--gold-soft);font-weight:700;box-shadow:0 2px 10px rgba(245,172,0,.3)}

/* ── stepper ─────────────────────────────── */
.stepper{display:flex;align-items:center;gap:0;margin-bottom:22px}
.step-dot{width:30px;height:30px;border-radius:50%;border:2px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--text-muted);flex-shrink:0;font-weight:800;box-shadow:var(--shadow-sm);transition:border-color .25s,color .25s,background .25s,box-shadow .25s}
.step-dot.active{border-color:var(--blue);color:#fff;background:var(--blue);box-shadow:0 2px 12px rgba(0,37,85,.3)}
.step-dot.done{border-color:var(--green);color:#fff;background:var(--green)}
.step-line{flex:1;height:2px;background:var(--border);transition:background .25s}
.step-line.done{background:var(--green)}
.step-label{font-size:10px;color:var(--text-muted);letter-spacing:.5px;text-align:center;margin-top:5px;font-weight:600}

/* ── disc tags ───────────────────────────── */
.disc-tags{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;min-height:32px}
.disc-tag{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--border);background:var(--surface);font-size:12px;animation:fadeIn .15s ease both;border-radius:var(--r-md);box-shadow:var(--shadow-sm)}
.disc-tag-dia{color:var(--blue);min-width:60px;font-size:11px;letter-spacing:.5px;font-weight:700}
.disc-tag-disc{color:var(--text);flex:1;font-weight:500}
.disc-tag-rm{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;padding:4px 8px;min-height:28px;min-width:28px;font-family:var(--font);border-radius:var(--r-sm);transition:color .15s,background .15s}
.disc-tag-rm:hover{color:var(--red);background:var(--red-soft)}
.disc-count{font-size:11px;color:var(--text-dim);margin-bottom:6px;font-weight:600}
.disc-count span{color:var(--blue);font-weight:800}

/* ── responsive scale ────────────────────── */
@media(min-width:768px){
  body{font-size:16px}
  .hdr-name{font-size:22px}
  .hdr-tag{font-size:12px}
  .hdr-stat{font-size:12px}
  .stitle{font-size:12px}
  .menu-label{font-size:16px}
  .menu-key{font-size:15px}
  .menu-badge{font-size:13px}
  .btn{font-size:15px;padding:12px 22px}
  .btn.sm{font-size:13px;padding:8px 14px}
  .btn-back{font-size:14px}
  input[type=text],input[type=email],input[type=password],.iprefix,select{font-size:15px}
  .tbl{font-size:14px}
  .tbl th{font-size:12px}
  .msg{font-size:15px}
  .pick-item{font-size:14px}
  .dt-item{font-size:14px}
  .aula-card-title{font-size:16px}
  .aula-card-meta{font-size:14px}
  .loading{font-size:15px}
  footer{font-size:13px}
}

/* ── desktop (≥1024px): s-hoje compacto ──── */
@media(min-width:1024px){
  #s-hoje{max-width:720px;margin:0 auto}
  #s-hoje .hoje-cta{padding:10px 14px;margin:0 0 14px 0;gap:12px;font-size:13px}
  #s-hoje .hoje-cta-ico{width:32px;height:32px;font-size:17px}
  #s-hoje .hoje-cta-title{font-size:13px}
  #s-hoje .hoje-cta-sub{font-size:10px;margin-top:2px}
  #s-hoje .hoje-cta-arrow{font-size:18px}
  #s-hoje .hoje-section{margin-bottom:14px}
  #s-hoje .hoje-section-label{font-size:10px;letter-spacing:1px;margin:0 0 6px 2px}
  #s-hoje .aula-card{padding:10px 14px;margin-bottom:8px;border-radius:var(--r-sm)}
  #s-hoje .aula-card:hover{transform:none}
  #s-hoje .aula-head{margin-bottom:6px;gap:8px}
  #s-hoje .aula-badge{font-size:9px;padding:2px 7px}
  #s-hoje .aula-time{font-size:10px}
  #s-hoje .aula-body{gap:12px}
  #s-hoje .aula-sala-wrap{min-width:70px}
  #s-hoje .aula-sala{font-size:16px;letter-spacing:1px}
  #s-hoje .aula-sala-miss{font-size:11px}
  #s-hoje .aula-card-title{font-size:13px;margin-bottom:2px}
  #s-hoje .aula-card-meta{font-size:11px;margin-bottom:0}
  #s-hoje .aula-extra{margin-top:6px;gap:4px}
  #s-hoje .aula-extra-chip{font-size:10px;padding:2px 8px}
  #s-hoje .hoje-footer{margin-top:6px}
  #s-hoje .hoje-actions{margin-top:8px}
  #s-hoje .hoje-empty{padding:16px 14px}
  #s-hoje .hoje-empty-title{font-size:14px}
  #s-hoje .hoje-empty-sub{font-size:12px}
}

/* ── mobile ──────────────────────────────── */
@media(max-width:768px){
  body{font-size:16px}
  input,select,textarea{font-size:16px!important}
  button,.btn{min-height:44px;padding:12px 18px;font-size:15px}
  .btn.sm{min-height:36px;padding:8px 14px;font-size:13px}
  table,.tbl{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r-md)}
  .menu-item{padding:16px 16px;min-height:58px}
  .aula-card{padding:16px 16px}
  .pick-item{min-height:52px;padding:13px 14px}
  .igroup{flex-wrap:nowrap}
  .add-row{flex-direction:column}
  .add-row select,.add-row input,.add-row .btn{width:100%}
  .btn-row{flex-direction:column}
  .chip{min-height:40px;padding:9px 15px}
  #app{padding:calc(20px + env(safe-area-inset-top)) 16px 20px}
  .hdr-row{flex-wrap:nowrap}
  .site-header{padding:14px 14px 12px;border-radius:var(--r-md)}
  .hdr-name{font-size:17px;letter-spacing:.8px}
  .hdr-tag{font-size:10px}
  .hdr-mark{width:24px;height:24px;border-radius:6px}
  .hdr-mark::after{width:8px;height:8px;right:-2px;bottom:-2px}
  .hdr-stats{gap:5px}
  .hdr-stat{font-size:10px;padding:3px 8px}
  .hdr-stat-day{padding:3px 9px}
  .landing-actions{gap:12px}
  .landing-btn{font-size:16px;min-height:54px}
  .aula-card-title{font-size:15px}
  #s-hoje .action-bar{position:sticky;bottom:0;background:var(--bg);padding:8px 0;border-top:1px solid var(--border);margin-top:8px;z-index:50}
  #side-menu{width:85vw;max-width:320px}
  .spl-logo{font-size:32px}
  .spl-version{font-size:10px;padding:3px 8px;top:-10px}
  .stepper{gap:2px}
  .step-dot{width:26px;height:26px;font-size:11px}
}

.step-label,.disc-count,.disc-tag-dia,.menu-badge,.sw-label,.pi-prof,.pi-hora{font-size:12px!important}

@media(hover:none){
  .menu-item:hover{transform:none}
  .pick-item:hover{transform:none}
  .btn:hover{filter:none}
  .chip:hover{transform:none}
}

/* ── header nav ──────────────────────────── */
#hdr-nav{display:none;align-items:center;gap:8px;margin-left:auto}
#hdr-nav.visible{display:flex}
.btn-user-pill{background:var(--surface);border:1px solid var(--border);color:var(--text-dim);font-family:var(--font);font-size:12px;padding:6px 14px;cursor:pointer;border-radius:999px;font-weight:600;white-space:nowrap;box-shadow:var(--shadow-sm);transition:border-color .15s,color .15s,background .15s}
.btn-user-pill:hover{border-color:var(--blue);color:var(--blue);background:var(--bg2)}
.btn-menu-toggle{background:var(--surface);border:1px solid var(--border);color:var(--text-dim);font-family:var(--font);font-size:16px;padding:6px 10px;cursor:pointer;border-radius:var(--r-sm);line-height:1;font-weight:700;min-width:40px;min-height:40px;box-shadow:var(--shadow-sm);transition:border-color .15s,color .15s}
.btn-menu-toggle:hover{border-color:var(--blue);color:var(--blue)}

/* ── side menu ───────────────────────────── */
#side-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}
#side-overlay.open{display:block;animation:fadeIn .2s ease both}
#side-menu{position:fixed;top:0;left:0;bottom:0;width:280px;background:var(--surface);border-right:1px solid var(--border);z-index:201;display:flex;flex-direction:column;transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);box-shadow:8px 0 30px rgba(0,37,85,.15)}
#side-menu.open{transform:translateX(0)}
.side-menu-hdr{display:flex;align-items:center;justify-content:space-between;padding:22px 22px 18px;border-bottom:2px solid var(--blue)}
.side-menu-hdr-title{font-size:15px;letter-spacing:4px;color:var(--blue);font-weight:800;text-transform:uppercase}
.side-menu-close{background:none;border:none;color:var(--text-muted);font-size:24px;cursor:pointer;padding:2px 8px;font-family:var(--font);line-height:1;border-radius:var(--r-sm);transition:color .15s,background .15s}
.side-menu-close:hover{color:var(--red);background:var(--red-soft)}
.side-menu-nav{flex:1;padding:14px 0;overflow-y:auto;display:flex;flex-direction:column}
.side-menu-item{display:block;width:100%;padding:13px 22px;background:none;border:none;border-left:3px solid transparent;color:var(--text);font-family:var(--font);font-size:14px;cursor:pointer;text-align:left;font-weight:500;transition:background .15s,border-color .15s,color .15s}
.side-menu-item:hover{background:var(--bg2);border-left-color:var(--blue);color:var(--blue)}
.side-menu-logout{color:var(--red);font-weight:600;margin-top:auto}
.side-menu-logout:hover{background:var(--red-soft);border-left-color:var(--red);color:var(--red)}
.side-menu-sep{border:none;border-top:1px solid var(--border);margin:8px 22px}

/* ── landing ─────────────────────────────── */
.landing-actions{display:flex;flex-direction:column;gap:12px;margin-bottom:22px}
.landing-btn{width:100%;font-size:15px;padding:14px 20px;text-align:center;min-height:54px}
.btn-link-text{background:none;border:none;color:var(--text-muted);font-family:var(--font);font-size:13px;cursor:pointer;padding:4px 0;text-decoration:underline;text-underline-offset:3px;font-weight:500;transition:color .15s}
.btn-link-text:hover{color:var(--blue)}

/* ── admin ───────────────────────────────── */
[id^="s-adm-"]:not(#s-adm-login) .stitle{border-bottom-color:var(--red);color:var(--red)}
[id^="s-adm-"]:not(#s-adm-login) .stitle::before{color:var(--red)}
#s-adm-main .stitle{border-bottom-color:var(--red);color:var(--red)}
#s-adm-main .stitle::before{color:var(--red)}
.adm-indicator{display:inline-block;font-size:9px;padding:3px 9px;background:var(--red);color:#fff;border-radius:999px;letter-spacing:1px;font-weight:700;vertical-align:middle;margin-left:6px}

/* ── consulta hub ────────────────────────── */
.consulta-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px;min-width:0}
.consulta-head .stitle{margin-bottom:0;border-bottom:none;padding-bottom:0;flex:1;min-width:0}
.consulta-pill{display:inline-flex;align-items:center;gap:7px;background:var(--gold-soft);border:1px solid var(--gold);color:#7a5a00;font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:lowercase;padding:5px 11px;border-radius:999px;white-space:nowrap;flex-shrink:0;max-width:100%}
.consulta-pill .cp-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 3px rgba(245,172,0,.25);animation:agoraPulse 2s ease-in-out infinite;flex-shrink:0}

/* s-hoje: CTA + sections */
.hoje-cta{display:flex;align-items:center;gap:14px;width:100%;padding:13px 16px;margin:0 0 18px 0;background:linear-gradient(135deg,var(--blue) 0%,var(--blue-2) 100%);border:1px solid var(--blue);color:#fff;border-radius:var(--r-md);box-shadow:var(--shadow-md),0 2px 12px rgba(0,37,85,.18);text-align:left;font-family:var(--font);cursor:pointer;transition:transform .15s,box-shadow .18s,filter .18s;white-space:normal;font-size:14px;line-height:1.3}
.hoje-cta:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg),0 4px 18px rgba(0,37,85,.28);filter:brightness(1.06)}
.hoje-cta:active{transform:scale(.99)}
.hoje-cta-ico{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--r-sm);background:var(--gold);color:var(--blue);font-size:20px;font-weight:800;flex-shrink:0;box-shadow:0 2px 8px rgba(245,172,0,.4)}
.hoje-cta-text{display:flex;flex-direction:column;flex:1;min-width:0;white-space:normal}
.hoje-cta-title{color:#fff;font-size:14px;font-weight:700;line-height:1.3;letter-spacing:.2px}
.hoje-cta-sub{color:rgba(255,255,255,.78);font-size:11px;font-weight:500;margin-top:3px;line-height:1.3}
.hoje-cta-arrow{color:var(--gold);font-size:22px;font-weight:800;flex-shrink:0;transition:transform .18s;line-height:1}
.hoje-cta:hover .hoje-cta-arrow{transform:translateX(4px)}

.hoje-section{margin-bottom:18px}
.hoje-section-label{font-size:11px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:1.2px;margin:0 0 8px 4px}
.hoje-section .aula-card{margin-bottom:10px}
.hoje-section .aula-card:last-child{margin-bottom:0}

.aula-head{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.aula-badge{font-size:10px;padding:3px 9px;font-weight:700;letter-spacing:.5px;border-radius:4px;text-transform:uppercase}
.aula-badge-now{background:var(--cyan);color:#003040}
.aula-badge-done{border:1px solid var(--text-dim);color:var(--text-dim)}
.aula-badge-next{border:1px solid var(--border);color:var(--text-muted)}
.aula-time{color:var(--text-dim);font-size:11px;letter-spacing:.5px;text-transform:lowercase;font-weight:600}
.aula-body{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.aula-sala-wrap{min-width:90px;display:flex;align-items:center}
.aula-sala{font-size:22px;font-weight:900;letter-spacing:1.5px;color:var(--text)}
.aula-sala-miss{font-size:12px;color:var(--text-dim);letter-spacing:.3px;font-weight:600;text-transform:lowercase;line-height:1.3}
.aula-info{flex:1;min-width:160px}
.aula-extra{margin-top:10px;display:flex;flex-wrap:wrap;gap:6px}
.aula-extra-chip{padding:3px 10px;border:1px solid var(--border);color:var(--text-dim);font-size:11px;border-radius:4px;background:var(--bg2)}

.aula-agora{border-color:var(--cyan);border-left-width:4px;border-left-color:var(--cyan)}
.aula-concluida{opacity:.55}
.aula-concluida{border-left-style:dashed}

.hoje-empty{padding:22px 18px;background:var(--bg2);border:1px dashed var(--border);border-radius:var(--r-md);text-align:center}
.hoje-empty-title{font-size:15px;font-weight:700;color:var(--text);margin:0 0 6px 0}
.hoje-empty-sub{font-size:13px;color:var(--text-dim);margin:0 0 14px 0;line-height:1.5}

.hoje-footer{margin-top:10px;text-align:center}
.hoje-actions{display:flex;gap:8px;margin-top:12px}
.btn.hoje-secondary{flex:1;background:var(--bg2);color:var(--text);border-color:var(--border);box-shadow:none}
.btn.hoje-secondary:hover{background:var(--surface);border-color:var(--blue);color:var(--blue)}

.btn.outline{background:transparent;border:1px solid var(--border);color:var(--text-dim);box-shadow:none;font-weight:600}
.btn.outline:hover{border-color:var(--blue);color:var(--blue);background:var(--bg2);box-shadow:var(--shadow-sm)}

/* acontecendo agora */
.agora-block{border:1px solid var(--border);background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--shadow-md);margin-bottom:22px;overflow:hidden;border-left:4px solid var(--gold)}
.agora-summary{cursor:pointer;list-style:none;padding:14px 16px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:linear-gradient(180deg,var(--bg2) 0%,var(--surface) 100%);transition:background .18s;user-select:none}
.agora-summary::-webkit-details-marker{display:none}
.agora-summary:hover{background:var(--bg2)}
.ag-arrow{color:var(--gold);font-size:13px;font-weight:800;display:inline-block;transition:transform .25s ease;flex-shrink:0}
.agora-block[open] .ag-arrow{transform:rotate(90deg)}
.ag-title{font-size:11px;font-weight:800;color:var(--blue);letter-spacing:1.5px;text-transform:uppercase;flex-shrink:0}
.ag-meta{font-size:12px;color:var(--text-dim);font-weight:500;margin-left:auto;letter-spacing:.2px}
.ag-meta-num{color:var(--blue);font-weight:800;font-size:13px}
.ag-meta-sep{color:var(--border);margin:0 4px}
.agora-body{padding:14px 16px 18px;border-top:1px solid var(--border-soft);animation:slideDown .22s ease both}
.agora-section{margin-bottom:18px}
.agora-section:last-child{margin-bottom:0}
.agora-section-head{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim);margin-bottom:10px}
.ag-sec-dot{width:8px;height:8px;border-radius:50%;background:var(--blue);flex-shrink:0;box-shadow:0 0 0 3px var(--blue-glow)}
.ag-sec-dot-green{background:var(--green);box-shadow:0 0 0 3px rgba(22,163,74,.15)}
.ag-sec-count{margin-left:4px;background:var(--bg2);color:var(--blue);font-weight:800;padding:2px 8px;border-radius:999px;font-size:10px;letter-spacing:.5px}
.agora-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:8px}
.agora-card{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--bg);border:1px solid var(--border-soft);border-radius:var(--r-md);transition:border-color .15s,background .15s;overflow-x:auto;-webkit-overflow-scrolling:touch}
.agora-card:hover{border-color:var(--blue);background:var(--bg2)}
.agora-card-sala{font-weight:800;color:var(--blue);font-size:14px;min-width:60px;letter-spacing:.3px;flex-shrink:0;white-space:nowrap}
.ag-sala-empty{color:var(--text-muted);font-weight:500;font-size:11px;font-style:italic}
.agora-card-info{flex:1}
.agora-card-disc{color:var(--text);font-size:13px;font-weight:600;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.agora-card-meta{color:var(--text-muted);font-size:11px;font-weight:500;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.agora-card-hora{color:var(--text-dim);font-size:11px;font-weight:600;flex-shrink:0;font-variant-numeric:tabular-nums}
.agora-chips{display:flex;flex-wrap:wrap;gap:6px}
.agora-chip{display:inline-flex;align-items:center;padding:5px 12px;background:var(--green-soft);border:1px solid var(--green);color:#0f5a24;font-size:12px;font-weight:700;border-radius:999px;letter-spacing:.3px}
.agora-empty{color:var(--text-muted);font-size:12px;font-style:italic;padding:6px 0}

/* ── salas livres por turno ──────────────── */
.sl-intro{color:var(--text-dim);font-size:12px;margin-bottom:14px;line-height:1.6}

.sl-hero{display:flex;align-items:center;gap:14px;padding:16px 18px;margin-bottom:20px;background:linear-gradient(135deg,var(--blue) 0%,var(--blue-2) 100%);border-radius:var(--r-lg);box-shadow:var(--shadow-md);color:#fff;position:relative;overflow:hidden}
.sl-hero::after{content:'';position:absolute;top:0;right:0;bottom:0;width:120px;background:radial-gradient(circle at 100% 50%,rgba(245,172,0,.28) 0%,transparent 70%);pointer-events:none}
.sl-hero-num{font-size:36px;font-weight:800;line-height:1;letter-spacing:-1.5px;font-variant-numeric:tabular-nums;color:var(--gold);text-shadow:0 1px 2px rgba(0,0,0,.15);min-width:54px;text-align:center}
.sl-hero-txt{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.sl-hero-lb{font-size:14px;font-weight:700;letter-spacing:.2px;line-height:1.25}
.sl-hero-sub{font-size:11px;font-weight:500;color:rgba(255,255,255,.75);letter-spacing:.3px;line-height:1.3}
.sl-hero-sub b{color:var(--gold);font-weight:700}
.sl-hero-hora{font-size:11px;font-weight:600;color:rgba(255,255,255,.8);font-variant-numeric:tabular-nums;background:rgba(0,0,0,.18);padding:4px 10px;border-radius:999px;flex-shrink:0;letter-spacing:.3px;z-index:1}

.sl-sec{margin-bottom:18px}
.sl-sec:last-child{margin-bottom:0}
.sl-sec-title{font-size:10px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);margin:0 0 8px 4px;display:flex;align-items:center;gap:8px}
.sl-sec-title::before{content:'';display:inline-block;width:10px;height:2px;background:var(--gold);border-radius:1px}
.sl-sec-list{display:flex;flex-direction:column;gap:8px}

.sl-card{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);overflow:hidden;transition:border-color .18s,box-shadow .18s}
.sl-card[open]{box-shadow:var(--shadow-sm)}
.sl-card.sl-is-agora{border-color:var(--gold);box-shadow:0 0 0 3px rgba(245,172,0,.15)}
.sl-card.sl-is-passado{opacity:.68}
.sl-card.sl-is-passado:hover{opacity:.96}

.sl-card-head{display:flex;align-items:center;gap:12px;padding:12px 14px;cursor:pointer;list-style:none;user-select:none;transition:background .15s}
.sl-card-head::-webkit-details-marker{display:none}
.sl-card-head::marker{content:""}
.sl-card-head:hover{background:var(--bg2)}
.sl-card.sl-is-agora>.sl-card-head{background:linear-gradient(90deg,rgba(245,172,0,.10) 0%,transparent 55%)}

.sl-card-main{flex:1 1 0;min-width:0;display:flex;flex-direction:column;gap:3px}
.sl-card-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.sl-card-nome{font-weight:700;font-size:14px;color:var(--text);line-height:1.2;letter-spacing:.1px}
.sl-card-range{font-size:11px;color:var(--text-muted);font-weight:500;font-variant-numeric:tabular-nums;letter-spacing:.3px;line-height:1.2}

.sl-pill{display:inline-flex;align-items:center;font-size:9px;font-weight:800;letter-spacing:1px;text-transform:uppercase;padding:3px 9px;border-radius:999px;white-space:nowrap;line-height:1.3}
.sl-pill-agora{background:var(--gold);color:#3a2800;animation:agoraPulse 2s ease-in-out infinite;box-shadow:0 0 0 2px rgba(245,172,0,.22)}
.sl-pill-passado{background:var(--bg3);color:var(--text-muted)}
.sl-pill-futuro{background:var(--blue-glow);color:var(--blue);border:1px solid var(--border)}

.sl-card-num{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;line-height:1;font-variant-numeric:tabular-nums}
.sl-card-num-n{font-size:20px;font-weight:800;color:var(--blue);letter-spacing:-.5px;line-height:1}
.sl-card-num-lb{font-size:9px;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.6px;margin-top:2px}
.sl-card.sl-is-agora .sl-card-num-n{color:var(--gold-dim)}

.sl-card-caret{flex-shrink:0;color:var(--text-muted);font-size:11px;transition:transform .22s ease;line-height:1;width:12px;text-align:center}
.sl-card[open] .sl-card-caret{transform:rotate(180deg);color:var(--blue)}
.sl-card.sl-is-agora[open] .sl-card-caret{color:var(--gold)}

.sl-card-body{padding:12px 14px 14px;border-top:1px solid var(--border-soft);background:var(--bg);display:flex;flex-wrap:wrap;gap:6px;animation:slideDown .22s ease both}

.sl-chip{display:inline-flex;align-items:center;padding:6px 13px;background:var(--green-soft);border:1px solid var(--green);color:#0f5a24;font-size:12px;font-weight:700;border-radius:999px;letter-spacing:.3px;font-variant-numeric:tabular-nums}
.sl-empty{color:var(--text-muted);font-size:12px;font-style:italic;padding:4px 2px}

@media(max-width:380px){
  .sl-hero{padding:14px;gap:10px}
  .sl-hero-num{font-size:28px;min-width:40px}
  .sl-hero-lb{font-size:13px}
  .sl-hero-sub{font-size:10px}
  .sl-card-head{gap:10px;padding:11px 12px}
  .sl-card-nome{font-size:13px}
  .sl-card-num-n{font-size:18px}
  .sl-chip{padding:5px 11px;font-size:11.5px}
}

body.dark .sl-hero{background:linear-gradient(135deg,var(--bg3) 0%,var(--surface) 100%);border:1px solid var(--border)}
body.dark .sl-card{background:var(--surface)}
body.dark .sl-card-head:hover{background:var(--bg3)}
body.dark .sl-card-body{background:var(--bg2)}
body.dark .sl-pill-passado{background:var(--bg3)}
body.dark .sl-pill-futuro{background:rgba(107,157,255,.12);border-color:var(--border)}
body.dark .sl-chip{background:#0d2b1a;color:#6ddb99;border-color:var(--green)}

/* search hero */
.consulta-search{display:flex;align-items:stretch;gap:0;margin:0 0 14px;border:1px solid var(--border);background:var(--surface);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:border-color .18s,box-shadow .18s}
.consulta-search:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,37,85,.15),var(--shadow-md)}
.consulta-search-icon{display:flex;align-items:center;justify-content:center;width:50px;font-size:22px;color:var(--blue);background:var(--bg2);border-right:1px solid var(--border-soft);font-weight:700;flex-shrink:0}
.consulta-search input{border:none!important;background:transparent;padding:14px 16px;font-size:15px;font-weight:500;flex:1;min-width:0}
.consulta-search input:focus{box-shadow:none!important}
.consulta-search .btn{border-radius:0;border:none;border-left:1px solid rgba(0,0,0,.06);min-height:auto}

/* atalhos */
.consulta-shortcuts{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:24px}
.consulta-shortcut{display:flex;align-items:center;gap:12px;padding:13px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);text-align:left;cursor:pointer;font-family:var(--font);transition:border-color .18s,transform .15s,box-shadow .18s}
.consulta-shortcut:hover{border-color:var(--blue);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.cs-ico{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r-sm);background:var(--bg2);color:var(--blue);font-size:18px;font-weight:700;flex-shrink:0}
.cs-text{display:flex;flex-direction:column;flex:1;min-width:0}
.cs-title{color:var(--text);font-size:13px;font-weight:700;line-height:1.3}
.cs-sub{color:var(--text-muted);font-size:11px;font-weight:500;margin-top:2px}
.cs-arrow{color:var(--text-muted);font-size:18px;font-weight:700;flex-shrink:0}
.consulta-shortcut:hover .cs-arrow{color:var(--blue)}

/* section label + grid de categorias */
.consulta-section-label{font-size:11px;font-weight:700;letter-spacing:1.5px;color:var(--text-dim);text-transform:uppercase;margin:8px 0 12px;display:flex;align-items:center;gap:10px}
.consulta-section-label::before{content:'';width:14px;height:2px;background:var(--gold);display:inline-block}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;margin-bottom:24px}
.cat-card{display:flex;flex-direction:column;align-items:flex-start;gap:6px;padding:16px 16px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);text-align:left;cursor:pointer;font-family:var(--font);position:relative;overflow:hidden;transition:border-color .18s,transform .15s,box-shadow .18s;min-height:88px}
.cat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue) 0%,var(--gold) 100%);opacity:.55;transition:opacity .2s}
.cat-card:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.cat-card:hover::before{opacity:1}
.cat-card-name{color:var(--text);font-size:13px;font-weight:700;letter-spacing:.2px;line-height:1.3;padding-right:18px}
.cat-card-meta{color:var(--text-muted);font-size:11px;font-weight:500;display:flex;align-items:baseline;gap:5px;margin-top:auto}
.cat-card-count{color:var(--blue);font-weight:800;font-size:18px;letter-spacing:-.5px;font-variant-numeric:tabular-nums}
.cat-card-arrow{position:absolute;right:12px;bottom:10px;color:var(--text-muted);font-size:18px;font-weight:700;transition:transform .18s,color .18s;line-height:1}
.cat-card:hover .cat-card-arrow{color:var(--blue);transform:translateX(3px)}

.consulta-foot{font-size:11px;color:var(--text-muted);text-align:center;line-height:1.6;padding:14px 8px 4px;border-top:1px dashed var(--border);margin-top:8px}

@media(max-width:540px){
  .consulta-shortcuts{grid-template-columns:1fr}
  .cat-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
  .agora-grid{grid-template-columns:1fr}
  .ag-meta{margin-left:0;width:100%;flex-basis:100%;font-size:11px}
  .consulta-search input{font-size:16px}
  .consulta-search-icon{width:42px;font-size:18px}
}

/* dark mode tweaks */
body.dark .consulta-pill{background:#2a1f00;color:var(--gold);border-color:var(--gold)}
body.dark .agora-block{background:var(--surface);border-color:var(--border)}
body.dark .agora-summary{background:linear-gradient(180deg,var(--bg3) 0%,var(--surface) 100%)}
body.dark .agora-summary:hover{background:var(--bg3)}
body.dark .agora-card{background:var(--bg2);border-color:var(--border-soft)}
body.dark .agora-card:hover{background:var(--bg3);border-color:var(--blue)}
body.dark .ag-sec-count{background:var(--bg3);color:var(--blue)}
body.dark .agora-chip{background:#0d2b1a;color:#6ddb99;border-color:var(--green)}
body.dark .consulta-search,body.dark .consulta-shortcut,body.dark .cat-card{background:var(--surface);border-color:var(--border)}
body.dark .consulta-search-icon,body.dark .cs-ico{background:var(--bg3)}

/* ── dark mode ───────────────────────────── */
body.dark{
  --bg:#0b0f17;
  --bg2:#141a28;
  --bg3:#1c2436;
  --surface:#161c2c;
  --border:#2a3350;
  --border-soft:#1f2740;
  --blue:#6b9dff;
  --blue-2:#5688e8;
  --blue-dim:#4070e0;
  --blue-glow:rgba(107,157,255,.15);
  --gold:#F5AC00;
  --gold-dim:#d89700;
  --gold-soft:#3a2a00;
  --cyan:#F5AC00;
  --yellow:#F5AC00;
  --green:#2ecc71;
  --green-soft:#0d2b1a;
  --red:#e74c3c;
  --red-soft:#2b0d0d;
  --text:#e8edf8;
  --text-dim:#a8b4d0;
  --text-muted:#6070a0;
  --shadow-sm:0 1px 2px rgba(0,0,0,.35);
  --shadow-md:0 4px 16px rgba(0,0,0,.45),0 1px 3px rgba(0,0,0,.35);
  --shadow-lg:0 12px 36px rgba(0,0,0,.55),0 2px 6px rgba(0,0,0,.35);
}
body.dark #splash{background:linear-gradient(180deg,#0b0f17 0%,#161c2c 100%)}
body.dark .spl-logo{color:#e8edf8}
body.dark .spl-version{background:var(--gold);color:#1a0f00}
body.dark .btn:not(.primary):not(.danger):not(.success){background:var(--bg3);color:var(--text);border-color:var(--border)}
body.dark .btn:not(.primary):not(.danger):not(.success):hover{background:var(--bg2);border-color:var(--blue)}
body.dark .btn.primary{background:linear-gradient(180deg,var(--gold) 0%,var(--gold-dim) 100%);color:#1a0f00}
body.dark input,body.dark select,body.dark textarea{background:var(--bg2);color:var(--text);border-color:var(--border)}
body.dark .menu-item{background:var(--surface);border-color:var(--border)}
body.dark .menu-item:hover{background:var(--bg3);border-color:var(--blue)}
body.dark .menu-item.hl{background:linear-gradient(90deg,rgba(107,157,255,.1) 0%,var(--surface) 60%)}
body.dark .menu-key{background:var(--bg3);color:var(--blue)}
body.dark .menu-item.hl .menu-key{background:var(--gold);color:#1a0f00}
body.dark .pick-item{background:var(--surface);border-color:var(--border)}
body.dark .pick-item:hover{background:var(--bg3)}
body.dark .chip{background:var(--surface);border-color:var(--border);color:var(--text-dim)}
body.dark .chip.active{background:#2a1f00;border-color:var(--gold);color:var(--gold)}
body.dark .iprefix{background:var(--bg3);border-color:var(--border)}
body.dark .tbl{background:var(--surface)}
body.dark .tbl th{background:var(--blue);color:#fff}
body.dark .tbl td{border-color:var(--border-soft)}
body.dark .tbl tr:hover td{background:var(--bg3)}
body.dark .step-dot{background:var(--surface);border-color:var(--border)}
body.dark .site-header{background:linear-gradient(135deg,var(--surface) 0%,var(--bg3) 100%);border-color:var(--border)}
body.dark .hdr-mark::after{border-color:var(--surface)}
body.dark .hdr-stat{background:var(--bg3);border-color:var(--border);color:var(--text-dim)}
body.dark .hdr-stat-day{background:linear-gradient(135deg,var(--blue) 0%,var(--blue-2) 100%);border-color:var(--blue);color:#fff}
body.dark .hdr-stat-cap{background:transparent;border-style:dashed}
body.dark .aula-card{background:var(--surface);box-shadow:var(--shadow-md)}
body.dark .aula-extra-chip{background:var(--bg3);border-color:var(--border)}
body.dark .hoje-empty{background:var(--surface);border-color:var(--border)}
body.dark .btn.hoje-secondary{background:var(--bg3);color:var(--text);border-color:var(--border)}
body.dark .btn.hoje-secondary:hover{background:var(--bg2);border-color:var(--blue);color:var(--blue)}
body.dark .dt-item,body.dark .disc-tag{background:var(--surface)}
body.dark .btn-user-pill,body.dark .btn-menu-toggle,body.dark .btn-back{background:var(--surface);color:var(--text-dim);border-color:var(--border)}
body.dark .msg.ok{background:var(--green-soft);border-color:var(--green);color:#6ddb99}
body.dark .msg.error{background:var(--red-soft);border-color:var(--red);color:#e88}
body.dark .msg.info{background:var(--blue-glow);border-color:var(--blue);color:var(--blue)}
body.dark .msg.warn{background:#2a1f00;border-color:var(--gold);color:var(--gold)}
body.dark #main-trava-aviso{background:var(--red-soft)!important;border-color:var(--red)!important;color:#e88!important}
body.dark footer{background:linear-gradient(180deg,#060a14 0%,#0b1326 100%)}
body.dark #side-menu{background:var(--surface);border-left-color:var(--border)}
body.dark .side-menu-item:hover{background:var(--bg3)}
