/* ═══════════════════════════════════════════════════════════
   AUREUS · App de Cliente · reservar.css (rediseño v2)
   Old money: negro, dorado, crema. Mobile-first, instalable.
   ═══════════════════════════════════════════════════════════ */
@font-face{font-family:'Cormorant';src:url('../fonts/cormorant-300.woff2') format('woff2');font-weight:300;font-style:normal;font-display:swap;}
@font-face{font-family:'Cormorant';src:url('../fonts/cormorant-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:'Cormorant';src:url('../fonts/cormorant-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap;}
@font-face{font-family:'Cormorant';src:url('../fonts/cormorant-400-italic.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap;}
@font-face{font-family:'Jost';src:url('../fonts/jost-300.woff2') format('woff2');font-weight:300;font-style:normal;font-display:swap;}
@font-face{font-family:'Jost';src:url('../fonts/jost-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:'Jost';src:url('../fonts/jost-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap;}
:root{
  --gold:#B3935A; --gold-l:#D8B878; --gold-d:#8F7240;
  --bg:#0B0C0B; --bg-2:#101109; --bg-3:#17180F; --card:#14150F;
  --cream:#ECE3D2; --cream-d:#C8C0B0;
  --border:rgba(179,147,90,.15); --border-2:rgba(179,147,90,.35);
  --ok:#4CAF7D; --err:#E07070;
  --ui:'Jost',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --display:'Cormorant',Georgia,serif;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
[hidden]{display:none!important;}
html,body{height:100%;}
body{background:var(--bg);color:var(--cream-d);font-family:var(--ui);font-size:15px;overflow-x:hidden;}
button{cursor:pointer;font-family:var(--ui);color:inherit;}
input,textarea{font-family:var(--ui);}
::-webkit-scrollbar{width:3px;} ::-webkit-scrollbar-thumb{background:var(--gold-d);}
em{font-style:italic;color:var(--gold);}
.muted{font-size:.78rem;color:var(--cream-d);opacity:.5;text-align:center;padding:14px;}

/* Splash */
#splash{position:fixed;inset:0;background:var(--bg);z-index:900;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:14px;transition:opacity .6s;}
#splash.out{opacity:0;pointer-events:none;}
.sp-mark{width:220px;max-width:62%;height:auto;display:block;}

/* App shell */
#app{max-width:440px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;
  background:var(--bg);position:relative;}
.topbar{height:54px;flex-shrink:0;background:rgba(10,10,8,.97);border-bottom:1px solid var(--border);
  display:flex;align-items:center;padding:0 16px;position:sticky;top:0;z-index:50;backdrop-filter:blur(8px);}
.tb-logo{font-family:var(--display);font-size:1.1rem;font-weight:600;color:var(--gold);letter-spacing:.3em;
  flex:1;text-align:center;}
.tb-side{font-size:.74rem;color:var(--gold);background:none;border:none;min-width:64px;}
.tb-side.l{text-align:left;} .tb-side.r{text-align:right;color:var(--cream-d);opacity:.6;}

/* Screens */
.screen{display:none;flex:1;flex-direction:column;min-height:0;}
.screen.on{display:flex;}
.scrl{flex:1;overflow-y:auto;padding-bottom:24px;}

/* ─── AUTH ─── */
#s-auth{align-items:center;justify-content:flex-start;overflow-y:auto;
  background:radial-gradient(ellipse 60% 50% at 50% 38%,rgba(179,147,90,.05),transparent 70%);}
.auth-wrap{padding:38px 20px 30px;width:100%;}
.au-mark{display:block;width:260px;max-width:78%;height:auto;margin:0 auto 26px;}
.au-card{background:var(--card);border:1px solid var(--border);border-top:2px solid var(--gold);
  padding:22px 18px;width:100%;max-width:390px;margin:0 auto;}
.au-tabs{display:flex;margin-bottom:18px;border:1px solid var(--border);}
.au-tab{flex:1;background:none;border:none;color:var(--cream-d);font-size:.7rem;letter-spacing:.1em;
  text-transform:uppercase;padding:11px 4px;}
.au-tab.on{background:var(--gold);color:var(--bg);}
.au-form{display:none;} .au-form.on{display:block;}
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;}
.fl{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);}
.fi{background:var(--bg-3);border:1px solid var(--border);color:var(--cream);padding:11px 12px;
  font-size:.88rem;outline:none;width:100%;border-radius:0;}
.fi:focus{border-color:var(--gold-d);}
.fi::placeholder{color:var(--cream-d);opacity:.45;}
textarea.fi{resize:vertical;min-height:64px;}
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.phone-group{display:flex;align-items:stretch;}
.phone-prefix{display:flex;align-items:center;padding:0 10px;background:var(--bg-2);border:1px solid var(--border);
  border-right:none;color:var(--gold);font-size:.84rem;}
.phone-group .fi{border-left:none;}
.pass-group{position:relative;display:flex;}
.pass-toggle{position:absolute;right:0;top:0;bottom:0;border:none;background:none;color:var(--gold);
  font-size:.7rem;padding:0 12px;}
.btn-au{width:100%;background:var(--gold);color:var(--bg);border:none;padding:13px;font-size:.72rem;
  letter-spacing:.18em;text-transform:uppercase;margin-top:4px;font-weight:500;}
.btn-au:disabled{opacity:.6;}
.au-err{background:rgba(224,112,112,.08);border:1px solid rgba(224,112,112,.25);color:var(--err);
  font-size:.7rem;padding:9px 12px;margin-top:10px;text-align:center;line-height:1.5;}
.au-link{display:block;width:100%;text-align:center;background:none;border:none;color:var(--cream-d);
  opacity:.6;font-size:.74rem;margin-top:12px;text-decoration:underline;}
.au-div{height:1px;background:var(--border);margin:14px 0;}
.au-rl{font-size:.78rem;color:var(--cream);margin-bottom:4px;}
.au-rn{font-size:.72rem;color:var(--cream-d);opacity:.6;margin-bottom:10px;line-height:1.5;}

/* Botón dorado genérico */
.btn-gold{background:var(--gold);color:var(--bg);border:none;font-size:.72rem;letter-spacing:.18em;
  text-transform:uppercase;padding:14px 28px;width:100%;max-width:260px;font-weight:500;}
.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--cream-d);padding:9px 16px;
  font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;}
.btn-ghost.wide{width:100%;padding:12px;}

/* ─── HOME ─── */
.hm-badge{display:flex;align-items:center;gap:10px;padding:10px 20px;border-bottom:1px solid var(--border);background:var(--bg-2);}
.hm-lvl{font-size:.52rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bg);background:var(--gold);padding:3px 9px;}
.hm-lbl{font-size:.74rem;color:var(--cream-d);opacity:.6;}
.hm-hero{padding:30px 22px 18px;text-align:center;}
.hm-seal{display:block;width:84px;height:auto;margin:0 auto 16px;opacity:.95;}
.hm-greet{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);opacity:.8;margin-bottom:10px;}
.hm-title{font-family:var(--display);font-size:2.1rem;font-weight:300;color:var(--cream);line-height:1.2;margin-bottom:12px;}
.hm-sub{font-size:.74rem;color:var(--cream-d);opacity:.6;margin-bottom:22px;line-height:1.7;}
.hm-div{height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:22px auto;width:46px;}
.sec-label{display:block;font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);
  opacity:.7;padding:0 22px;margin-bottom:10px;}
.hm-svcs{padding:0 22px;margin-bottom:24px;}
.sv-row{display:flex;align-items:center;width:100%;text-align:left;padding:12px 16px;background:var(--card);
  border:1px solid var(--border);border-left:2px solid transparent;margin-bottom:3px;}
.sv-row:hover,.sv-row:active{border-left-color:var(--gold);}
.sv-n{font-size:.74rem;color:var(--cream);}
.sv-d{font-size:.7rem;color:var(--cream-d);opacity:.5;margin-top:2px;}
.sv-p{font-size:1.05rem;color:var(--gold);margin-left:auto;font-family:var(--display);}
.hm-brbs{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:0 22px 30px;}
.bb-chip{background:var(--card);border:1px solid var(--border);padding:14px 6px;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:8px;}
.bb-av{width:42px;height:42px;border-radius:50%;background:var(--bg-3);border:1px solid var(--border-2);
  display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:1.1rem;color:var(--gold);}
.bb-nm{font-size:.62rem;letter-spacing:.06em;color:var(--cream);}

/* ─── Carteles PWA (instalar / notificaciones) ─── */
.pwa-banner{display:flex;align-items:center;gap:12px;margin:10px 16px 0;padding:12px 14px;
  background:var(--card);border:1px solid var(--border-2);border-left:2px solid var(--gold);}
.pwa-text{flex:1;display:flex;flex-direction:column;gap:2px;}
.pwa-text strong{font-size:.78rem;color:var(--cream);font-weight:500;}
.pwa-text span{font-size:.68rem;color:var(--cream-d);opacity:.6;}
.btn-gold.sm{width:auto;padding:9px 16px;font-size:.66rem;flex-shrink:0;}
.pwa-hint{margin:10px 16px 0;font-size:.7rem;color:var(--cream-d);opacity:.65;line-height:1.5;
  background:var(--card);border:1px solid var(--border);padding:10px 14px;}

/* ─── HOME · próxima cita + CTA ─── */
.next-card{margin:4px 22px 0;background:var(--card);border:1px solid var(--border-2);border-top:2px solid var(--gold);padding:16px;}
.next-tag{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);opacity:.8;margin-bottom:8px;}
.next-svc{font-family:var(--display);font-size:1.3rem;color:var(--cream);margin-bottom:4px;}
.next-meta{font-size:.76rem;color:var(--cream-d);opacity:.7;margin-bottom:14px;}
.next-actions{display:flex;gap:8px;}
.next-actions .btn-ghost{flex:1;text-align:center;}
.btn-ghost.danger{color:var(--err);border-color:rgba(224,112,112,.3);}
.hm-cta{padding:22px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;}
.hm-cta .btn-ghost.wide{max-width:300px;}
.surcharge-note{margin:0 22px 22px;background:rgba(224,112,112,.07);border:1px solid rgba(224,112,112,.25);
  color:var(--err);font-size:.72rem;padding:10px 14px;line-height:1.5;}

/* ─── MODAL DE RESERVA (hoja) ─── */
.sheet-modal{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:700;display:flex;align-items:flex-end;justify-content:center;}
.sheet-modal[hidden]{display:none;}
.sheet{background:var(--bg);width:100%;max-width:440px;height:92dvh;display:flex;flex-direction:column;
  border-top:2px solid var(--gold);box-shadow:0 -8px 30px rgba(0,0,0,.5);}
.sheet-head{height:52px;flex-shrink:0;display:flex;align-items:center;padding:0 16px;border-bottom:1px solid var(--border);}
.sheet-title{flex:1;font-family:var(--display);font-size:1.2rem;color:var(--gold);letter-spacing:.06em;}
.sheet-x{background:none;border:none;color:var(--cream-d);font-size:1.1rem;width:36px;height:36px;}
#book-flow{flex:1;display:flex;flex-direction:column;min-height:0;}
.book-success{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:34px 26px;text-align:center;}
.book-success .sum-card{width:100%;max-width:300px;}
.book-success .btn-gold{margin-top:8px;}

/* ─── BOOKING ─── */
.reschedule-banner{flex:1;font-size:.72rem;letter-spacing:.08em;color:var(--gold);text-align:center;text-transform:uppercase;}
.sum-warn{background:rgba(224,112,112,.07);border:1px solid rgba(224,112,112,.25);color:var(--err);
  font-size:.72rem;padding:10px 12px;margin-top:10px;line-height:1.5;}
.stepbar{display:flex;align-items:center;padding:12px 22px;border-bottom:1px solid var(--border);background:var(--bg-2);flex-shrink:0;}
.sd{width:26px;height:26px;border:1px solid var(--border);flex-shrink:0;display:flex;align-items:center;
  justify-content:center;font-size:.74rem;color:var(--cream-d);}
.sd.act{border-color:var(--gold);color:var(--gold);background:rgba(179,147,90,.08);}
.sd.done{background:var(--gold);color:var(--bg);border-color:var(--gold);}
.sline{flex:1;height:1px;background:var(--border);}
.sline.done{background:var(--gold-d);}
.book-body{flex:1;overflow-y:auto;}
.book-step{display:none;padding:22px;} .book-step.on{display:block;}
.step-title{font-family:var(--display);font-size:1.5rem;font-weight:300;color:var(--cream);margin-bottom:16px;}
.opt{display:flex;align-items:center;width:100%;text-align:left;gap:12px;padding:13px 15px;background:var(--card);
  border:1px solid var(--border);border-left:2px solid transparent;margin-bottom:3px;}
.opt:hover,.opt.on{border-color:var(--border-2);border-left-color:var(--gold);}
.opt.on{background:rgba(179,147,90,.05);}
.opt-main{flex:1;min-width:0;}
.opt-n{font-size:.78rem;color:var(--cream);}
.opt-d{font-size:.68rem;color:var(--cream-d);opacity:.5;margin-top:2px;}
.opt-side{text-align:right;}
.opt-p{font-size:1rem;color:var(--gold);font-family:var(--display);}
.opt-t{font-size:.64rem;color:var(--cream-d);opacity:.55;}
.opt-av{width:42px;height:42px;border-radius:50%;background:var(--bg-3);border:1px solid var(--border-2);
  display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:1.1rem;color:var(--gold);flex-shrink:0;}
.opt-ck{color:var(--gold);font-size:.8rem;opacity:0;}
.opt.on .opt-ck{opacity:1;}
/* Categorías de servicio */
.svc-cat-tile{display:flex;align-items:center;width:100%;text-align:left;gap:12px;padding:16px 15px;background:var(--card);
  border:1px solid var(--border-1);border-left:3px solid var(--gold);border-radius:8px;margin-bottom:8px;cursor:pointer;}
.svc-cat-tile:active{opacity:.8;}
.svc-cat-name{flex:1;font-size:.85rem;color:var(--cream);font-family:var(--display);letter-spacing:.05em;}
.svc-cat-count{font-size:.68rem;color:var(--cream-d);opacity:.55;}
.svc-cat-arrow{color:var(--gold);font-size:.9rem;opacity:.7;}
.svc-cat-back{display:flex;align-items:center;gap:8px;width:100%;text-align:left;padding:8px 0 12px;background:none;
  border:none;border-bottom:1px solid var(--border-1);margin-bottom:12px;cursor:pointer;
  font-size:.72rem;color:var(--gold);letter-spacing:.08em;text-transform:uppercase;}
/* Calendario */
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.cal-month{font-size:.78rem;letter-spacing:.1em;color:var(--cream);text-transform:capitalize;}
.cal-nav{background:none;border:1px solid var(--border);color:var(--gold);width:30px;height:30px;font-size:.9rem;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:16px;}
.cal-wd{text-align:center;font-size:.62rem;letter-spacing:.06em;color:var(--gold);opacity:.5;padding:6px 0;text-transform:uppercase;}
.cd{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.74rem;color:var(--cream-d);border:1px solid transparent;}
.cd.av{cursor:pointer;} .cd.av:hover,.cd.sel{border-color:var(--gold);}
.cd.sel{background:var(--gold);color:var(--bg);}
.cd.dis{opacity:.2;}
.slots-label{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);opacity:.7;margin-bottom:10px;}
.slots-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;}
.slot{background:var(--card);border:1px solid var(--border);padding:11px 5px;text-align:center;font-size:.78rem;color:var(--cream-d);}
.slot:hover,.slot.sel{border-color:var(--gold);color:var(--gold);}
.slot.sel{background:rgba(179,147,90,.1);}
/* Resumen */
.sum-card{background:var(--card);border:1px solid var(--border-2);border-top:2px solid var(--gold);padding:16px;margin-bottom:14px;}
.sum-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);}
.sum-row:last-child{border-bottom:none;}
.sum-row span{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cream-d);opacity:.55;}
.sum-row strong{font-size:.86rem;color:var(--cream);font-weight:400;}
.sum-row strong.gold{color:var(--gold);font-family:var(--display);font-size:1.05rem;}
.book-nav{padding:12px 18px;border-top:1px solid var(--border);background:var(--bg-2);display:flex;gap:8px;flex-shrink:0;}
.btn-next{flex:1;background:var(--gold);color:var(--bg);border:none;padding:13px;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;}
.btn-next:disabled{opacity:.6;}
.btn-prev{background:transparent;border:1px solid var(--border);color:var(--cream-d);padding:13px 16px;font-size:.85rem;}

/* ─── DONE ─── */
.done{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:34px 26px;text-align:center;}
.done-mark{width:64px;height:64px;border-radius:50%;border:1px solid var(--gold);display:flex;align-items:center;
  justify-content:center;margin-bottom:18px;font-size:1.6rem;color:var(--gold);}
.done-title{font-family:var(--display);font-size:1.6rem;font-weight:300;color:var(--cream);margin-bottom:8px;}
.done-sub{font-size:.8rem;color:var(--cream-d);opacity:.65;margin-bottom:20px;line-height:1.6;}
.done .sum-card{width:100%;max-width:300px;}
.done .btn-gold{margin-top:8px;}

/* ─── MIS CITAS / páginas ─── */
.page-head{padding:24px 22px 8px;}
.page-title{font-family:var(--display);font-size:1.5rem;font-weight:300;color:var(--cream);}
.page-sub{font-size:.7rem;color:var(--cream-d);opacity:.6;margin-top:2px;}
.appts-list{padding:8px 22px 20px;}
.appt-it{background:var(--card);border:1px solid var(--border);border-left:2px solid var(--gold);padding:13px 14px;margin-bottom:4px;position:relative;}
.appt-b{position:absolute;top:11px;right:12px;font-size:.5rem;letter-spacing:.08em;border:1px solid var(--border-2);
  padding:2px 7px;text-transform:uppercase;color:var(--gold);}
.appt-it{width:100%;text-align:left;}
.appt-it.past{opacity:.62;}
.appt-s{font-size:.78rem;color:var(--cream);margin-bottom:3px;}
.appt-d{font-size:.7rem;color:var(--cream-d);opacity:.6;line-height:1.5;}
.appt-go{font-size:.66rem;color:var(--gold);margin-top:8px;}
/* Modal de cita */
.appt-card{text-align:left;}
.appt-modal-svc{font-family:var(--display);font-size:1.4rem;color:var(--gold);margin-bottom:6px;}
.appt-modal-meta{font-size:.78rem;color:var(--cream-d);opacity:.7;margin-bottom:6px;}
.appt-modal-status{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cream);margin-bottom:16px;}
.appt-modal-actions{display:flex;flex-direction:column;gap:8px;margin-bottom:8px;}
.appt-modal-actions .btn-ghost{width:100%;padding:12px;}
/* Invitar referido */
.refs-intro{font-size:.72rem;color:var(--cream-d);opacity:.6;line-height:1.5;margin-bottom:10px;}
.invite-form{display:flex;flex-direction:column;gap:8px;margin-bottom:14px;}
.empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:54px 22px;text-align:center;}
.empty-i{font-size:1.8rem;color:var(--gold);opacity:.2;}
.empty-t{font-family:var(--display);font-style:italic;font-size:1.05rem;color:var(--cream);opacity:.65;}
.empty-s{font-size:.7rem;color:var(--cream-d);opacity:.5;}

/* ─── PERFIL ─── */
.pr-head{padding:24px 22px 16px;border-bottom:1px solid var(--border);}
.pr-name{font-family:var(--display);font-size:1.4rem;font-weight:300;color:var(--cream);margin-bottom:8px;}
.pr-level{display:inline-block;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;padding:3px 10px;
  border:1px solid var(--border-2);color:var(--gold);margin-bottom:8px;}
.pr-phone{font-size:.72rem;color:var(--cream-d);opacity:.6;}
.pr-level-hint{font-size:.7rem;color:var(--cream-d);opacity:.55;font-style:italic;margin-bottom:8px;line-height:1.5;}
.refs-empty{font-size:.7rem;color:var(--cream-d);opacity:.55;line-height:1.5;padding:4px 0;}
.rf-it{background:var(--card);border:1px solid var(--border);padding:11px 13px;margin-bottom:4px;}
.rf-head{display:flex;justify-content:space-between;align-items:center;gap:10px;}
.rf-n{font-size:.76rem;color:var(--cream);}
.rf-s{font-size:.62rem;letter-spacing:.04em;text-align:right;}
.rf-s.pend{color:var(--cream-d);opacity:.6;}
.rf-s.ok{color:var(--ok);}
.rf-actions{display:flex;gap:6px;margin-left:auto;}
.rf-btn-edit,.rf-btn-del{background:none;border:1px solid var(--border);border-radius:4px;
  padding:3px 9px;font-size:.62rem;letter-spacing:.04em;cursor:pointer;}
.rf-btn-edit{color:var(--gold);border-color:var(--gold);}
.rf-btn-del{color:var(--error,#e57373);border-color:var(--error,#e57373);}
.rf-edit-form{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);}
.rf-edit-form .field{margin-bottom:8px;}
.field-label-sm{font-size:.65rem;letter-spacing:.06em;text-transform:uppercase;color:var(--cream-d);opacity:.7;display:block;margin-bottom:3px;}
.rf-edit-err{font-size:.7rem;color:var(--error,#e57373);margin:4px 0;}
.rf-edit-btns{display:flex;gap:8px;justify-content:flex-end;margin-top:8px;}
.rf-wa{width:100%;margin-top:9px;background:transparent;border:1px solid #25D366;color:#25D366;
  padding:8px;font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;}
.pr-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin:14px 22px 0;}
.ps{background:var(--card);padding:14px 8px;text-align:center;}
.ps-v{font-family:var(--display);font-size:1.4rem;color:var(--gold);}
.ps-l{font-size:.52rem;letter-spacing:.08em;text-transform:uppercase;color:var(--cream-d);opacity:.5;margin-top:3px;}
.pr-next{margin:14px 22px 0;font-size:.78rem;color:var(--cream);background:var(--card);border:1px solid var(--border);padding:11px 14px;}
.pr-next .muted{display:inline;padding:0;opacity:.5;}
.pr-section{padding:18px 22px 0;}
.pr-section-label{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);opacity:.65;margin-bottom:10px;}
.notif-card{background:var(--card);border:1px solid var(--border);padding:13px 15px;display:flex;align-items:center;gap:12px;}
.notif-text{flex:1;display:flex;flex-direction:column;gap:3px;}
.notif-text strong{font-size:.78rem;color:var(--cream);font-weight:500;}
.notif-text span{font-size:.68rem;color:var(--cream-d);opacity:.55;}
.notif-state{font-size:.7rem;color:var(--cream-d);opacity:.55;padding:4px 0;}
.pr-logout{padding:22px;}

/* ─── Bottom nav ─── */
.botnav{height:62px;flex-shrink:0;background:rgba(10,10,8,.97);border-top:1px solid var(--border);
  display:flex;position:sticky;bottom:0;z-index:50;backdrop-filter:blur(8px);padding-bottom:env(safe-area-inset-bottom);}
.bn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  background:none;border:none;border-top:2px solid transparent;}
.bn.on{border-top-color:var(--gold);}
.bn-i{font-size:.95rem;color:var(--cream-d);opacity:.6;}
.bn-l{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cream-d);opacity:.6;}
.bn.on .bn-i,.bn.on .bn-l{color:var(--gold);opacity:1;}

/* ─── Modal de nivel ─── */
.lvl-modal{position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:800;display:flex;align-items:center;
  justify-content:center;padding:24px;}
.lvl-modal[hidden]{display:none;}
.lvl-card{background:var(--card);border:1px solid var(--border-2);border-top:2px solid var(--gold);
  padding:32px 26px;max-width:340px;width:100%;text-align:center;}
.lvl-mark{font-size:1.6rem;color:var(--gold);display:block;margin-bottom:12px;}
.lvl-name{font-family:var(--display);font-size:1.8rem;font-weight:600;color:var(--gold);letter-spacing:.16em;margin-bottom:10px;}
.lvl-msg{font-size:.88rem;color:var(--cream);margin-bottom:8px;line-height:1.6;}
.lvl-hint{font-size:.72rem;color:var(--cream-d);opacity:.6;margin-bottom:20px;line-height:1.6;font-style:italic;}
.lvl-card .btn-gold{max-width:none;}

/* Toast */
#toast{position:fixed;bottom:78px;left:50%;transform:translateX(-50%);background:var(--bg-3);
  border:1px solid var(--border-2);border-left:2px solid var(--gold);color:var(--cream);font-size:.72rem;
  padding:10px 18px;z-index:200;opacity:0;transition:opacity .25s;pointer-events:none;white-space:nowrap;max-width:90%;}
#toast.on{opacity:1;}
