/* Amed'or — Panel Maestro (Jennifer) · dark + gold */
:root{
  --bg:#0e0a07; --bg-2:#16100b; --panel:#1c150e; --panel-2:#241a10;
  --ivory:#F6EFE3; --muted:#b7a892; --gold:#C9A24B; --gold-bright:#E4C77A; --gold-deep:#A9762B;
  --line:rgba(228,199,122,.16); --ok:#5fbf8a; --warn:#e0a14b; --danger:#e0556a;
  --shadow:0 24px 60px -30px rgba(0,0,0,.8);
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{font-family:'Jost',system-ui,sans-serif;background:var(--bg);color:var(--ivory);font-weight:300;line-height:1.6;-webkit-font-smoothing:antialiased;overscroll-behavior-y:none}
.serif{font-family:'Fraunces',Georgia,serif}
img{display:block;max-width:100%}
button{font-family:inherit}
.app{max-width:560px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;position:relative;background:var(--bg)}

.btn{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;border:none;cursor:pointer;font-weight:500;letter-spacing:.03em;font-size:1rem;padding:15px 22px;border-radius:14px;transition:transform .2s,opacity .2s}
.btn:active{transform:scale(.98)}
.btn-gold{background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));color:#1a1206;box-shadow:0 14px 30px -14px rgba(201,162,75,.6)}
.btn[disabled]{opacity:.5;pointer-events:none}
.input{width:100%;background:var(--panel);border:1px solid var(--line);color:var(--ivory);font-size:1.05rem;padding:14px 16px;border-radius:14px;outline:none;transition:border-color .25s;font-family:inherit}
.input:focus{border-color:var(--gold)}
textarea.input{resize:vertical;line-height:1.5}
.label{font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:0 0 8px 2px}
.muted{color:var(--muted)}
.eyebrow{font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold)}
.pill{display:inline-flex;align-items:center;gap:7px;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;border-radius:30px;border:1px solid var(--line);color:var(--gold-bright);margin-top:8px}
.pill.ok{color:var(--ok);border-color:rgba(95,191,138,.4)}
.pill.warn{color:var(--warn);border-color:rgba(224,161,75,.4)}
.toast{position:fixed;left:50%;bottom:30px;transform:translateX(-50%) translateY(20px);z-index:200;opacity:0;background:var(--panel-2);border:1px solid var(--line);color:var(--ivory);padding:13px 20px;border-radius:30px;font-size:.92rem;box-shadow:var(--shadow);transition:opacity .3s,transform .3s;pointer-events:none;max-width:90%}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.err{border-color:rgba(224,85,106,.5)}
.spin{width:22px;height:22px;border:2px solid var(--line);border-top-color:var(--gold);border-radius:50%;animation:sp .7s linear infinite;margin:30px auto}
.spin.sm{width:16px;height:16px;margin:auto}
@keyframes sp{to{transform:rotate(360deg)}}
.empty{text-align:center;color:var(--muted);padding:34px 16px}
.empty .e{font-size:2.2rem;opacity:.6;margin-bottom:8px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:18px;margin-bottom:14px}
.section{margin-bottom:24px}
.row{display:flex;align-items:center;gap:10px}

.screen{display:none;flex:1;flex-direction:column}
.screen.active{display:flex;animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* LOGIN */
#auth{justify-content:center;align-items:center;text-align:center;padding:40px 26px;background:radial-gradient(120% 70% at 50% 0%,rgba(201,162,75,.12),transparent 60%)}
#auth .logo{height:90px;margin:0 auto 18px;filter:drop-shadow(0 6px 24px rgba(201,162,75,.35))}
#auth>div{width:100%;max-width:380px}
#auth h1{font-size:1.8rem;font-weight:400;margin:10px 0 8px}
#auth p.sub{color:var(--muted);margin-bottom:28px}
#auth .form{text-align:left;display:flex;flex-direction:column;gap:14px}
#auth .legal{font-size:.78rem;color:var(--muted);margin-top:18px}
.otp{display:flex;gap:9px;justify-content:center}
.otp input{width:46px;height:56px;text-align:center;font-size:1.5rem;background:var(--panel);border:1px solid var(--line);border-radius:12px;color:var(--ivory);outline:none}
.otp input:focus{border-color:var(--gold)}
.linkbtn{background:none;border:none;color:var(--gold-bright);cursor:pointer;font-size:.92rem;text-decoration:underline;padding:6px}

/* HEADER */
.hdr{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line);position:sticky;top:0;background:rgba(14,10,7,.9);backdrop-filter:blur(12px);z-index:20}
.hdr .brand{display:flex;align-items:center;gap:9px}
.hdr .brand img{height:28px}
.hdr .brand b{font-size:1rem;font-weight:500;color:var(--gold-bright)}
.hdr .out{background:none;border:1px solid var(--line);border-radius:30px;color:var(--muted);cursor:pointer;font-size:.82rem;padding:6px 12px}
.hdr #refreshBtn{font-size:1.05rem;padding:6px 11px}

.content{flex:1;overflow-y:auto;display:flex;flex-direction:column}
.view{display:none;flex:1;flex-direction:column}
.view.active{display:flex;animation:fade .3s ease}

/* LISTA DE CLIENTAS */
.searchwrap{padding:16px 16px 8px;position:sticky;top:0;background:var(--bg);z-index:5}
.input.search{padding:12px 16px;border-radius:30px;font-size:.98rem}
#clientList{padding:4px 12px 24px}
.client-row{display:flex;align-items:center;gap:13px;width:100%;text-align:left;background:none;border:none;border-bottom:1px solid var(--line);padding:14px 8px;cursor:pointer;color:var(--ivory);transition:background .2s}
.client-row:hover{background:var(--panel)}
.avatar{flex:0 0 46px;width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;color:#1a1206;background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep))}
.avatar.lg{flex:0 0 58px;width:58px;height:58px;font-size:1.3rem}
.cr-mid{flex:1;min-width:0}
.cr-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.cr-top b{font-weight:500;font-size:1.02rem}
.cr-time{flex:0 0 auto;font-size:.74rem;color:var(--muted)}
.cr-sub{font-size:.86rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.badge{flex:0 0 auto;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--danger);color:#fff;font-size:.7rem;font-weight:600;display:flex;align-items:center;justify-content:center}
.badge[hidden]{display:none}

/* DETALLE */
#detailView{padding:0}
.backbtn{align-self:flex-start;background:none;border:none;color:var(--gold-bright);cursor:pointer;font-size:.95rem;padding:14px 16px 6px}
.client-hero{display:flex;align-items:center;gap:14px;padding:6px 18px 16px;border-bottom:1px solid var(--line);min-height:70px}
.ch-name{font-size:1.4rem;font-weight:500}
.ch-meta{font-size:.86rem;color:var(--muted)}

.tabs{display:flex;gap:6px;padding:12px 16px 0;position:sticky;top:0;background:rgba(14,10,7,.92);backdrop-filter:blur(10px);z-index:6}
.tabs button{position:relative;flex:1;background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);cursor:pointer;padding:10px 4px;font-size:.95rem;transition:color .2s,border-color .2s}
.tabs button.active{color:var(--gold-bright);border-color:var(--gold)}
.tabs .badge{position:absolute;top:4px;right:18%}
.tabpane{display:none;flex:1;flex-direction:column;padding:16px}
.tabpane.active{display:flex;animation:fade .25s ease}
.hint{font-size:.84rem;margin-bottom:12px}

/* CHAT */
#tab-chat{padding:0;height:calc(100dvh - 210px)}
.chat-log{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding:16px}
.chat-log .empty{margin:auto}
.cb{display:flex;max-width:82%}
.cb.me{align-self:flex-end;justify-content:flex-end}
.cb.her{align-self:flex-start}
.bub{position:relative;padding:10px 14px 18px;border-radius:16px;font-size:.96rem;line-height:1.45;word-break:break-word}
.cb.me .bub{background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));color:#1a1206;border-bottom-right-radius:5px}
.cb.her .bub{background:var(--panel-2);border:1px solid var(--line);color:var(--ivory);border-bottom-left-radius:5px}
.bub .ct{position:absolute;bottom:4px;right:11px;font-size:.62rem;opacity:.6}
.cb.her .bub .ct{color:var(--muted)}
.chat-bar{flex:0 0 auto;display:flex;gap:8px;padding:10px 14px calc(12px + env(safe-area-inset-bottom));border-top:1px solid var(--line);background:var(--bg)}
.chat-input{flex:1;background:var(--panel);border:1px solid var(--line);color:var(--ivory);font-size:1rem;padding:13px 16px;border-radius:24px;outline:none}
.chat-input:focus{border-color:var(--gold)}
.chat-send{flex:0 0 48px;width:48px;height:48px;border:none;border-radius:50%;cursor:pointer;font-size:1.1rem;background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));color:#1a1206}
.chat-send:active{transform:scale(.94)}

/* FOTOS */
.photogrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.pcell{position:relative;aspect-ratio:3/4;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:var(--panel);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}
.pcell img{width:100%;height:100%;object-fit:cover}
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(4,3,1,.92);display:flex;align-items:center;justify-content:center;padding:20px}
.lightbox[hidden]{display:none}
.lightbox img{max-width:100%;max-height:90vh;border-radius:10px}
.lbx{position:absolute;top:calc(16px + env(safe-area-inset-top));right:18px;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.12);border:none;color:#fff;font-size:1.1rem;cursor:pointer}

/* CITAS */
.appt-head{padding:6px 16px 4px}
.appt-title{font-size:1.5rem;font-weight:500;margin:6px 0 2px}
#apptList{padding:8px 16px 28px;display:flex;flex-direction:column;gap:12px}
.appt-card{background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--line);border-radius:16px;padding:15px 16px;transition:border-color .2s}
.appt-card.req{border-left-color:var(--warn);background:linear-gradient(135deg,rgba(224,161,75,.1),var(--panel))}
.appt-card.ok{border-left-color:var(--ok)}
.appt-card.cancel{border-left-color:var(--muted);opacity:.62}
.appt-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.appt-cli{font-weight:500;font-size:1.08rem;color:var(--ivory)}
.appt-pill{flex:0 0 auto;font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;border-radius:30px;border:1px solid var(--line);color:var(--gold-bright)}
.appt-pill.req{color:var(--warn);border-color:rgba(224,161,75,.45);background:rgba(224,161,75,.1)}
.appt-pill.ok{color:var(--ok);border-color:rgba(95,191,138,.4);background:rgba(95,191,138,.08)}
.appt-pill.cancel{color:var(--muted)}
.appt-when{font-size:.95rem;color:var(--ivory);margin-top:8px}
.appt-meta{font-size:.84rem;color:var(--muted);margin-top:3px}
.appt-notes{font-size:.88rem;color:var(--muted);margin-top:8px;padding-top:8px;border-top:1px solid var(--line);line-height:1.45}
.appt-actions{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.appt-btn{flex:1;min-width:90px;border:1px solid var(--line);background:var(--panel-2);color:var(--ivory);cursor:pointer;font-family:inherit;font-size:.9rem;font-weight:500;padding:10px 12px;border-radius:11px;transition:transform .15s,opacity .2s}
.appt-btn:active{transform:scale(.97)}
.appt-btn[disabled]{opacity:.45;pointer-events:none}
.appt-btn.approve{background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));color:#1a1206;border-color:transparent}
.appt-btn.move{color:var(--gold-bright);border-color:rgba(228,199,122,.35)}
.appt-btn.reject{color:var(--danger);border-color:rgba(224,85,106,.35)}
.appt-btn.ghost{color:var(--muted)}
.appt-reschedule{margin-top:12px;padding-top:12px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:10px}
.appt-reschedule[hidden]{display:none}
.appt-dt{font-size:.95rem;padding:11px 14px;color-scheme:dark}
.appt-rs-actions{display:flex;gap:8px}

/* ============ HOME / COCKPIT ============ */
#homeView{padding:0 16px 36px}
.home-hero{padding:20px 2px 14px}
.home-hero h1{font-size:1.7rem;font-weight:400;margin:4px 0 2px}
.home-hero .muted{font-size:.9rem;text-transform:capitalize}

/* KPIs */
.kpi-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:8px}
.kpi{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:16px 10px 14px;text-align:center;cursor:pointer;transition:transform .15s,border-color .2s;display:flex;flex-direction:column;align-items:center;gap:4px}
.kpi:active{transform:scale(.97)}
.kpi:hover{border-color:var(--gold)}
.kpi .kpi-num{font-family:'Fraunces',Georgia,serif;font-size:2rem;line-height:1;font-weight:500;color:var(--gold-bright)}
.kpi.warn .kpi-num{color:var(--warn)}
.kpi .kpi-label{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);line-height:1.25}
.kpi .badge{position:absolute;top:8px;right:8px}

/* bloques del home */
.home-block{margin-top:26px}
.hb-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.hb-head h2{font-size:1.2rem;font-weight:500}
.hb-count{flex:0 0 auto;min-width:24px;height:24px;padding:0 8px;border-radius:12px;background:rgba(224,161,75,.16);color:var(--warn);border:1px solid rgba(224,161,75,.4);font-size:.8rem;font-weight:600;display:flex;align-items:center;justify-content:center}
.hb-count[hidden]{display:none}
#pendList{display:flex;flex-direction:column;gap:12px}
.home-empty{background:var(--panel);border:1px dashed var(--line);border-radius:16px;text-align:center;color:var(--muted);padding:22px 16px;font-size:.92rem}

/* mini appt card del home (reusa look de .appt-card) */
.pend-card{background:linear-gradient(135deg,rgba(224,161,75,.1),var(--panel));border:1px solid var(--line);border-left:3px solid var(--warn);border-radius:16px;padding:14px 15px}
.pend-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.pend-cli{font-weight:500;font-size:1.05rem}
.pend-when{font-size:.9rem;color:var(--muted);margin-top:4px}
.pend-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.pend-reschedule{margin-top:12px;padding-top:12px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:10px}
.pend-reschedule[hidden]{display:none}

/* ============ CALENDARIO ESTILO VAGARO ============ */
.cal-head{margin-bottom:14px}
.cal-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.cal-title-row h2{font-size:1.2rem;font-weight:500}
.cal-views{display:flex;gap:2px;background:var(--panel);border:1px solid var(--line);border-radius:30px;padding:3px}
.cal-vbtn{background:none;border:none;color:var(--muted);cursor:pointer;font-family:inherit;font-size:.8rem;font-weight:500;padding:7px 14px;border-radius:30px;transition:color .2s,background .2s}
.cal-vbtn.active{background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));color:#1a1206}
.cal-nav{display:flex;align-items:center;gap:8px}
.cal-arrow{flex:0 0 auto;width:34px;height:34px;border-radius:50%;border:1px solid var(--line);background:var(--panel);color:var(--gold-bright);cursor:pointer;font-size:1.2rem;line-height:1;display:flex;align-items:center;justify-content:center}
.cal-arrow:active{transform:scale(.92)}
.cal-period{flex:1;font-size:.95rem;font-weight:500;color:var(--ivory);text-align:center;text-transform:capitalize}
.cal-today{flex:0 0 auto;background:none;border:1px solid var(--line);color:var(--gold-bright);cursor:pointer;font-family:inherit;font-size:.78rem;font-weight:500;padding:7px 13px;border-radius:30px}
.cal-today:active{transform:scale(.95)}

/* tira de fechas horizontal */
.cal-datestrip{display:flex;gap:7px;overflow-x:auto;padding:2px 2px 8px;margin:0 -2px 14px;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.cal-datestrip::-webkit-scrollbar{display:none}
.cal-datestrip[hidden]{display:none}
.ds-day{flex:0 0 auto;width:50px;display:flex;flex-direction:column;align-items:center;gap:3px;padding:9px 0;border-radius:14px;border:1px solid transparent;background:var(--panel);cursor:pointer;color:var(--ivory);transition:transform .15s,border-color .2s}
.ds-day:active{transform:scale(.95)}
.ds-day .ds-dow{font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.ds-day .ds-num{font-family:'Fraunces',Georgia,serif;font-size:1.25rem;font-weight:500;line-height:1}
.ds-day .ds-dot{width:5px;height:5px;border-radius:50%;background:transparent}
.ds-day.has .ds-dot{background:var(--gold)}
.ds-day.today{border-color:rgba(228,199,122,.4)}
.ds-day.today .ds-dow{color:var(--gold-bright)}
.ds-day.sel{background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));border-color:transparent}
.ds-day.sel .ds-dow,.ds-day.sel .ds-num{color:#1a1206}
.ds-day.sel .ds-dot{background:#1a1206}

/* VISTA DÍA · timeline */
.cal-day-view{position:relative}
.cal-day-view[hidden]{display:none}
.cal-tl{position:relative}
.cal-hour{position:relative;display:flex;min-height:58px;border-top:1px solid var(--line)}
.cal-hour:last-child{border-bottom:1px solid var(--line)}
.cal-hour .ch-label{flex:0 0 52px;font-size:.68rem;color:var(--muted);padding:5px 8px 0 2px;text-align:right;letter-spacing:.02em}
.cal-hour .ch-slot{flex:1;position:relative}
.cal-now-line{position:absolute;left:52px;right:0;height:2px;background:var(--danger);z-index:4;pointer-events:none}
.cal-now-line::before{content:"";position:absolute;left:-4px;top:-3px;width:8px;height:8px;border-radius:50%;background:var(--danger)}
.tl-appt{position:absolute;border-radius:11px;padding:8px 11px;background:var(--panel-2);border:1px solid var(--line);border-left:4px solid var(--gold);cursor:pointer;overflow:hidden;z-index:2;box-shadow:0 6px 18px -12px rgba(0,0,0,.7);transition:transform .12s;text-align:left;display:flex;flex-direction:column;justify-content:center}
.tl-appt:active{transform:scale(.985)}
.tl-appt.req{border-left-color:var(--warn);background:linear-gradient(135deg,rgba(224,161,75,.18),var(--panel-2))}
.tl-appt.ok{border-left-color:var(--ok);background:linear-gradient(135deg,rgba(95,191,138,.16),var(--panel-2))}
.tl-appt.cancel{border-left-color:var(--muted);opacity:.55}
.tl-appt .ta-cli{font-weight:500;font-size:.92rem;color:var(--ivory);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tl-appt .ta-time{font-size:.74rem;color:var(--muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-day-empty{text-align:center;color:var(--muted);font-size:.9rem;padding:30px 16px}

/* VISTA SEMANA · agenda agrupada */
.cal-week-view{display:flex;flex-direction:column;gap:16px}
.cal-week-view[hidden]{display:none}
.wk-group .wk-head{display:flex;align-items:baseline;gap:8px;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--line)}
.wk-group .wk-dow{font-weight:500;color:var(--ivory);text-transform:capitalize}
.wk-group .wk-date{font-size:.8rem;color:var(--muted)}
.wk-group.is-today .wk-dow{color:var(--gold-bright)}
.wk-items{display:flex;flex-direction:column;gap:8px}
.wk-empty{font-size:.82rem;color:var(--muted);padding:2px 0 4px}

/* VISTA MES · grilla (reusa cal) */
.cal-month-view[hidden]{display:none}
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-dow{text-align:center;font-size:.62rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);padding:4px 0}
.cal-day{position:relative;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:.9rem;color:var(--ivory);background:transparent;border:1px solid transparent;cursor:pointer}
.cal-day.empty{cursor:default}
.cal-day.muted-day{color:var(--muted);opacity:.4}
.cal-day.today{border-color:var(--line);font-weight:600}
.cal-day.has{font-weight:500}
.cal-day.sel{background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));color:#1a1206;border-color:transparent}
.cal-dots{position:absolute;bottom:5px;left:0;right:0;display:flex;gap:2px;justify-content:center}
.cal-dot{width:4px;height:4px;border-radius:50%;background:var(--gold)}
.cal-dot.req{background:var(--warn)}
.cal-dot.ok{background:var(--ok)}
.cal-day.sel .cal-dot{background:#1a1206}
.cal-day-list{margin-top:14px;display:flex;flex-direction:column;gap:10px}
.cal-row{display:flex;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:11px 14px;cursor:pointer;text-align:left;width:100%;color:var(--ivory)}
.cal-row:active{transform:scale(.99)}
.cal-row .cr-cli{flex:1;min-width:0;font-weight:500}
.cal-row .cr-cli small{display:block;font-weight:300;color:var(--muted);font-size:.82rem;margin-top:2px}
.cal-day-empty{text-align:center;color:var(--muted);font-size:.88rem;padding:14px}

/* HOJA DE DETALLE DE CITA (bottom sheet estilo Vagaro) */
.sheet-backdrop{position:fixed;inset:0;z-index:140;background:rgba(4,3,1,.6);backdrop-filter:blur(3px);display:flex;align-items:flex-end;justify-content:center;animation:fade .2s ease}
.sheet-backdrop[hidden]{display:none}
.sheet{width:100%;max-width:560px;background:var(--bg-2);border:1px solid var(--line);border-bottom:none;border-radius:24px 24px 0 0;padding:8px 18px calc(22px + env(safe-area-inset-bottom));box-shadow:0 -20px 60px -20px rgba(0,0,0,.8);animation:sheetUp .3s cubic-bezier(.22,1,.36,1);max-height:88dvh;overflow-y:auto}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:none}}
.sheet-grip{width:42px;height:4px;border-radius:4px;background:var(--line);margin:6px auto 14px}
.sheet-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.sheet-cli{font-family:'Fraunces',Georgia,serif;font-size:1.5rem;font-weight:500;line-height:1.15}
.sheet-when{font-size:.95rem;color:var(--ivory);margin-top:12px;display:flex;align-items:center;gap:8px}
.sheet-when .sw-ico{color:var(--gold-bright)}
.sheet-meta{font-size:.86rem;color:var(--muted);margin-top:6px}
.sheet-notes{font-size:.9rem;color:var(--muted);margin-top:12px;padding-top:12px;border-top:1px solid var(--line);line-height:1.5}
.sheet-actions{display:flex;gap:9px;margin-top:20px;flex-wrap:wrap}
.sheet-actions .appt-btn{flex:1 1 30%}
.sheet-reschedule{margin-top:14px;padding-top:14px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:10px}
.sheet-reschedule[hidden]{display:none}
.sheet-reschedule .sr-label{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.sheet-close{flex:0 0 auto;background:none;border:1px solid var(--line);border-radius:50%;width:34px;height:34px;color:var(--muted);cursor:pointer;font-size:1rem}

/* MÓDULOS */
.modgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.modcard{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:18px 16px;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:8px;color:var(--ivory);transition:transform .15s,border-color .2s;min-height:96px}
.modcard:active{transform:scale(.98)}
.modcard:hover{border-color:var(--gold)}
.modcard .mc-ico{font-size:1.6rem;line-height:1}
.modcard .mc-name{font-weight:500;font-size:1rem}
.modcard .mc-sub{font-size:.78rem;color:var(--muted)}
.modcard.disabled{opacity:.5;cursor:default;pointer-events:none}
.modcard .badge{position:absolute;top:12px;right:12px}
.mc-soon{font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);position:absolute;top:14px;right:14px}

/* PAGOS */
#payBody{padding:8px 16px 28px}
.pay-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px}
.pay-stat{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:18px 16px}
.pay-stat .ps-num{font-family:'Fraunces',Georgia,serif;font-size:1.7rem;font-weight:500;color:var(--gold-bright)}
.pay-stat.due .ps-num{color:var(--warn)}
.pay-stat .ps-label{font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:4px}
.pay-stat .ps-sub{font-size:.8rem;color:var(--muted);margin-top:6px}

/* CASO timeline */
.tl{position:relative;padding-left:26px;margin-top:8px}
.tl::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--line)}
.tlrow{position:relative;margin-bottom:18px}
.tlrow::before{content:"";position:absolute;left:-26px;top:4px;width:14px;height:14px;border-radius:50%;background:var(--bg);border:2px solid var(--gold)}
.tlrow .d{font-size:.78rem;color:var(--gold-bright)}
.tlrow h4{font-family:'Fraunces';font-weight:500;font-size:1.05rem;margin:2px 0}
.tlrow p{font-size:.9rem;color:var(--muted)}
