:root{--bg:#FFFFFF;--bg-soft:#F4F8F6;--ink:#0C1A14;--ink-soft:#5C6E66;--line:#E4ECE8;--green:#12B886;--green-d:#0E9E74;--green-ink:#0A7553;--mint:#E7F7F0;--blue:#EAF3FF;--blue-d:#2c5f99;
/* escala de formas y sombras (elegante, no juguete) */
--r:13px;--r-sm:10px;--r-xs:8px;--pill:99px;
--sh:0 1px 2px rgba(12,26,20,.04),0 10px 26px -20px rgba(12,26,20,.2);
--sh-pop:0 12px 34px -18px rgba(12,26,20,.26);}
*{box-sizing:border-box;}
body{margin:0;font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--bg-soft);-webkit-font-smoothing:antialiased;}
button{font-family:inherit}
.top{background:#0C1A14;color:#fff;padding:0 20px;display:flex;align-items:center;gap:14px;height:58px}
.top .mk{width:28px;height:28px;border-radius:8px;background:var(--green);display:flex;align-items:center;justify-content:center;font-weight:900}
.top b{font-weight:800;letter-spacing:-.02em}
.top .back{background:transparent;border:1px solid #2a3a33;color:#9DB4AB;font-size:.82rem;border-radius:8px;padding:6px 12px;cursor:pointer}
.top .back:hover{border-color:#46584f;color:#fff}
.bizswitch{display:none;align-items:center;gap:10px}
.bizswitch select{background:#15241d;color:#fff;border:1px solid #2a3a33;border-radius:9px;padding:7px 10px;font-weight:600;font-size:.88rem}
.subtabs{display:none;gap:4px}
.subtabs button{background:transparent;border:none;color:#9DB4AB;font-weight:600;font-size:.88rem;padding:8px 13px;border-radius:9px;cursor:pointer}
.subtabs button:hover{color:#fff}
.subtabs button.on{background:rgba(18,184,134,.16);color:#7FE3C0}
.top .sp{margin-left:auto}
.top .env{font-size:.72rem;color:#5C7A6E;border:1px solid #223029;border-radius:7px;padding:4px 9px}

.view{display:none}.view.on{display:block}
.wrap{max-width:720px;margin:0 auto;padding:26px 20px 64px}
.wrapW{max-width:1160px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh)}
.btn{font-weight:650;font-size:.92rem;border-radius:var(--r-sm);padding:11px 19px;cursor:pointer;border:none;transition:.18s;letter-spacing:-.005em}
.btn:active{transform:translateY(1px)}
.btn-primary{background:linear-gradient(180deg,#17C191,var(--green-d));color:#fff;box-shadow:0 1px 2px rgba(12,26,20,.06),0 8px 18px -12px rgba(14,158,116,.5)}
.btn-primary:hover{background:linear-gradient(180deg,#14B488,#0C9069);box-shadow:0 1px 2px rgba(12,26,20,.08),0 10px 22px -12px rgba(14,158,116,.55)}
.btn-ghost{background:#fff;border:1px solid var(--line);color:var(--ink-soft)}
.btn-ghost:hover{border-color:var(--ink-soft);background:#fbfdfc}
.btn-del{background:#FEECEC;color:#C0392B;border:1px solid #f3c4be}
label{display:block;font-weight:600;font-size:.9rem;margin:14px 0 6px}
label .opt{font-weight:400;color:var(--ink-soft)}
label .req{font-weight:600;color:#C0392B;font-size:.78rem}
input,select,textarea{width:100%;font-family:inherit;font-size:.95rem;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:11px 13px;transition:.18s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(18,184,134,.13)}
textarea{resize:vertical;min-height:70px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.chk{display:flex;align-items:center;gap:9px;font-weight:500;font-size:.95rem;margin:10px 0;cursor:pointer}
.chk input{width:auto;margin:0}

/* dashboard */
.dash-head{text-align:center;margin-bottom:22px}
.dash-head h1{font-size:1.6rem;letter-spacing:-.025em;margin:0 0 6px}
.dash-head p{color:var(--ink-soft);margin:0}
.biz-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.biz-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:18px;cursor:pointer;transition:.18s;box-shadow:var(--sh)}
.biz-card:hover{transform:translateY(-2px);border-color:var(--green);box-shadow:var(--sh-pop)}
.biz-card .ic{width:44px;height:44px;border-radius:var(--r-sm);background:var(--mint);display:flex;align-items:center;justify-content:center;font-size:1.35rem;margin-bottom:12px}
.biz-card h3{margin:0 0 3px;font-size:1.08rem}
.biz-card .sec{color:var(--ink-soft);font-size:.85rem}
.biz-card .meta{margin-top:12px;padding-top:12px;border-top:1px solid var(--line);font-size:.8rem;color:var(--ink-soft);display:flex;gap:14px}
.biz-card .meta b{color:var(--green-d)}
.add-card{border:2px dashed rgba(18,184,134,.4);background:var(--bg-soft);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:170px;color:var(--green-d);font-weight:700}
.add-card:hover{background:#eef8f3}
.add-card .plus{font-size:2rem;line-height:1}

/* onboarding */
.ob{max-width:540px;margin:0 auto}
.paste-cfg{margin-top:8px;text-align:center}
.paste-toggle{background:none;border:none;color:var(--green-ink);font-size:.82rem;font-weight:700;cursor:pointer;padding:6px}
.paste-toggle:hover{text-decoration:underline}
#pasteCfgBox{margin-top:8px}
#pasteCfgBox textarea{width:100%;min-height:96px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.8rem;margin-bottom:8px}
.health-card{background:linear-gradient(135deg,#F2FBF7,#fff);border:1px solid var(--line);margin-bottom:16px}
.health-top{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:12px}
.health-top h3{margin:0;font-size:1.05rem}
.health-pct{font-size:1.5rem;font-weight:900;color:var(--green-ink);font-variant-numeric:tabular-nums;flex:none;line-height:1}
.health-pct.full{color:var(--green)}
.health-bar{height:9px;border-radius:99px;background:#E3EFE9;overflow:hidden}
.health-bar i{display:block;height:100%;background:linear-gradient(90deg,#1ECB9A,#0E9E74);border-radius:99px;transition:width .6s cubic-bezier(.2,.8,.25,1)}
.health-items{display:flex;flex-wrap:wrap;gap:7px;margin-top:13px;align-items:center}
.health-lbl{font-size:.78rem;font-weight:700;color:var(--ink-soft)}
.health-todo{font-size:.78rem;color:var(--ink-soft);background:var(--bg-soft);padding:5px 11px;border-radius:99px}
.chat-welcome{position:relative;overflow:hidden;border-radius:24px;padding:32px 28px;margin-bottom:18px;text-align:center;color:#fff;background:radial-gradient(circle at 86% 4%,rgba(255,255,255,.22),transparent 34%),linear-gradient(140deg,#13B98A,#0A6E50);box-shadow:0 26px 54px -24px rgba(8,110,80,.72);animation:cwIn .55s cubic-bezier(.2,.8,.25,1.02) both}
.cw-mark{position:absolute;right:-12px;bottom:-26px;opacity:.10;color:#fff;pointer-events:none}
.cw-mark svg{width:165px;height:165px}
.cw-ic{position:relative;width:60px;height:60px;border-radius:19px;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto 15px;box-shadow:0 8px 22px rgba(0,0,0,.14),inset 0 0 0 1px rgba(255,255,255,.25)}
.cw-title{position:relative;font-family:'Newsreader',Georgia,serif;font-weight:400;font-size:1.9rem;letter-spacing:-.01em;margin:0 0 9px}
.cw-sub{position:relative;font-size:.95rem;line-height:1.55;color:rgba(255,255,255,.93);max-width:460px;margin:0 auto 20px}
.cw-sub b{color:#fff}
.cw-pills{position:relative;display:flex;flex-wrap:wrap;gap:9px;justify-content:center;margin-bottom:24px}
.cw-pill{font-size:.82rem;font-weight:600;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.24);padding:8px 15px;border-radius:99px}
.cw-btn{position:relative;background:#fff;color:#0B8E66;font-weight:800;font-size:.95rem;border:none;padding:13px 28px;border-radius:99px;cursor:pointer;box-shadow:0 10px 24px -10px rgba(0,0,0,.32);transition:transform .15s,box-shadow .15s}
.cw-btn:hover{transform:translateY(-2px);box-shadow:0 16px 32px -12px rgba(0,0,0,.38)}
@keyframes cwIn{from{opacity:0;transform:translateY(18px) scale(.97)}to{opacity:1;transform:none}}
.cross-rule{border:1px solid var(--line);border-radius:12px;padding:12px 13px;margin-bottom:10px;background:var(--bg-soft)}
.cross-line{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cross-line+.cross-line{margin-top:9px}
.cross-lbl{font-size:.84rem;color:var(--ink-soft);font-weight:600;white-space:nowrap}
.cross-rule select{flex:1;min-width:150px}
.cr-hook{flex:1;min-width:200px}
.cr-min{width:90px;flex:none}
.cross-rule .del{flex:none;border:none;background:#fff;color:#C4574A;width:30px;height:30px;border-radius:8px;cursor:pointer;font-size:.9rem}
.cross-rule .del:hover{background:#FBEBE9}
.aj-card h2{display:flex;align-items:center;gap:9px}
.hi{width:20px;height:20px;flex:none;color:var(--green)}
.bi{width:15px;height:15px;vertical-align:-2px;margin-right:4px;flex:none}
.cw-ic svg{width:26px;height:26px}
.dots{display:flex;gap:7px;justify-content:center;margin-bottom:26px}
.dots .d{width:9px;height:9px;border-radius:50%;background:var(--line);transition:.2s}
.dots .d.on{background:var(--green);transform:scale(1.15)}
.obstep{display:none;text-align:center;animation:fade .3s ease}
.obstep.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.obstep .q{font-size:1.6rem;font-weight:800;letter-spacing:-.02em;margin:6px 0 8px;line-height:1.25}
.obstep .help{color:var(--ink-soft);font-size:.98rem;margin:0 auto 22px;max-width:400px}
.obstep .ex{display:inline-block;background:var(--mint);color:var(--green-ink);font-size:.82rem;font-weight:600;border-radius:99px;padding:6px 13px;margin-top:4px}
.obstep .field{text-align:left;max-width:420px;margin:0 auto}
.obstep input,.obstep select,.obstep textarea{font-size:1.05rem;padding:14px 16px}
.obnav{display:flex;justify-content:center;gap:12px;margin-top:30px}
.obnav .btn{min-width:130px}
.obback{background:none;border:none;color:var(--ink-soft);font-weight:600;cursor:pointer;margin-top:14px;font-size:.88rem}
.svc{display:grid;grid-template-columns:1fr 80px 76px 32px;gap:8px;margin-bottom:8px;align-items:center}
.svc input{padding:11px;font-size:.95rem}
.svc .del{border:1px solid var(--line);background:#fff;border-radius:9px;height:44px;cursor:pointer;color:#C0392B;font-weight:700}
.svc-head{display:grid;grid-template-columns:1fr 80px 76px 32px;gap:8px;font-size:.7rem;color:var(--ink-soft);font-weight:700;text-transform:uppercase;margin-bottom:6px;text-align:left}
.addbtn{font-weight:700;font-size:.86rem;color:var(--green-d);background:var(--mint);border:1px dashed rgba(18,184,134,.4);border-radius:10px;padding:11px 14px;cursor:pointer;width:100%;margin-top:4px}
.toneopt{display:grid;gap:10px;text-align:left;max-width:420px;margin:0 auto}
.toneopt label{display:flex;align-items:center;gap:11px;border:1px solid var(--line);border-radius:12px;padding:13px 15px;cursor:pointer;margin:0;font-weight:600}
.toneopt label:hover{border-color:var(--green)}
.toneopt input{width:auto}
.toneopt label.sel{border-color:var(--green);background:var(--mint)}
.drop{border:2px dashed rgba(18,184,134,.4);border-radius:14px;padding:18px 16px;text-align:center;cursor:pointer;background:var(--bg-soft);transition:.2s}
.drop:hover{background:#eef8f3;border-color:var(--green)}
.drop .ic{font-size:1.6rem}
.drop p{margin:6px 0 2px;font-weight:600;font-size:.93rem}
.drop small{color:var(--ink-soft)}
.docok{display:none;margin-top:10px;font-size:.86rem;font-weight:600;border-radius:10px;padding:10px 12px;text-align:left}
.docok.show{display:block}
.docok.ok{background:var(--mint);color:var(--green-ink)}
.docok.info{background:#FFF4E0;color:#B5730B}
.docok.err{background:#FEECEC;color:#C0392B}
.success{text-align:center;padding:20px 10px}
.success .big{width:76px;height:76px;border-radius:50%;background:linear-gradient(150deg,#36C8C2,#16C2B0 48%,#0E9E70);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2.3rem;margin:0 auto 16px;box-shadow:0 14px 30px -12px rgba(14,158,112,.6);animation:pop .5s cubic-bezier(.2,.9,.3,1.4)}

/* calendario */
.cal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line);gap:12px;flex-wrap:wrap}
.cal-head h1{font-size:1.12rem;margin:0}.cal-head .wk{font-size:.9rem;color:var(--ink);font-weight:700;text-transform:capitalize}
.cal-nav{display:flex;align-items:center;gap:6px}
.cal-nav button{height:34px;min-width:34px;padding:0 10px;border-radius:9px;border:1px solid var(--line);background:#fff;color:var(--green-d);font-weight:800;cursor:pointer;font-size:.85rem}
.cal-nav button:hover{background:var(--mint)}
.cal-nav .cal-today{background:var(--mint)}
.callayout{display:grid;grid-template-columns:minmax(0,1fr) 312px;gap:20px;align-items:start}
.cal{display:grid;grid-template-columns:62px repeat(7,minmax(0,1fr));grid-auto-rows:58px;padding:0 8px 6px;position:relative}
.ch{font-size:.76rem;font-weight:700;text-align:center;padding:10px 2px 8px;color:var(--ink-soft)}
.ch.today{color:var(--green-d)}.ch small{display:block;font-weight:500;font-size:.68rem}
.ch .occ{display:block;font-weight:600;font-size:.6rem;color:var(--ink-soft);margin-top:2px}
.ch.closed{color:#c2cbc7}
.hr{font-size:.68rem;color:var(--ink-soft);text-align:right;padding-right:8px;transform:translateY(-7px);font-variant-numeric:tabular-nums}
.cell{border-top:1px solid #EFF3F1;border-left:1px solid #F3F6F4;cursor:pointer;position:relative}
.cell:hover{background:rgba(18,184,134,.07)}
.cell.past{background:repeating-linear-gradient(135deg,#fafbfb,#fafbfb 6px,#f3f5f4 6px,#f3f5f4 12px);cursor:default}
.cell.past:hover{background:repeating-linear-gradient(135deg,#fafbfb,#fafbfb 6px,#f3f5f4 6px,#f3f5f4 12px)}
.cell.closed{background:#fbfcfc;cursor:default}.cell.closed:hover{background:#fbfcfc}
.cell.dragover{background:rgba(18,184,134,.16);box-shadow:inset 0 0 0 2px var(--green)}
.col-today{background:rgba(18,184,134,.04)}
.nowline{position:absolute;left:0;right:0;height:2px;background:#FF5A5F;z-index:5;pointer-events:none}
.nowline::before{content:'';position:absolute;left:-4px;top:-3px;width:8px;height:8px;border-radius:50%;background:#FF5A5F}
.appt{margin:2px;border-radius:9px;padding:4px 7px;font-size:.71rem;line-height:1.12;overflow:hidden;cursor:grab;background:var(--mint);border:1px solid rgba(18,184,134,.35);color:var(--green-ink);z-index:3}
.appt b{display:block;font-weight:700;color:var(--ink);font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.appt .t{font-size:.64rem;opacity:.85;font-weight:600;font-variant-numeric:tabular-nums}
.appt .stf{display:block;font-size:.62rem;font-weight:700;opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#calStaff{height:34px;border-radius:9px;border:1px solid var(--line);padding:0 8px;font-weight:600;color:var(--ink);max-width:170px}
.appt.dragging{opacity:.4}
.appt.bot{background:var(--blue);border-color:#bcd8fb;color:var(--blue-d)}.appt.bot b{color:#173a5e}
.appt.pend{background:#FFF6E5;border-color:#F4D58A;color:#8a6400}.appt.pend b{color:#6b4e00}
.appt.done{background:#EFF1F0;border-color:#d8dedb;color:#6b7a73;opacity:.85}.appt.done b{color:#56625c}
.appt.no{background:#FDECEC;border-color:#F3B6B6;color:#9c2b2b;text-decoration:line-through}.appt.no b{color:#7d1f1f}
.appt.new{animation:pop .5s cubic-bezier(.2,.9,.3,1.4);box-shadow:0 0 0 3px rgba(18,184,134,.3)}
.appt{position:relative}
.appt-flags{position:absolute;top:2px;right:3px;display:flex;gap:2px}
.af{width:14px;height:14px;border-radius:4px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 2px rgba(0,0,0,.15)}
.af svg{width:10px;height:10px;color:#fff}
.af-new{background:#12B886}
.af-pay{background:#E1A53D}
.af-risk{background:#E5484D}
.ch-bar{height:4px;border-radius:3px;background:#E3EFE9;margin:5px 10px 2px;overflow:hidden}
.ch-bar i{display:block;height:100%;border-radius:3px;background:linear-gradient(90deg,#1ECB9A,#0E9E74);transition:width .4s}
.ch-bar i.full{background:linear-gradient(90deg,#F0A93C,#E1772D)}
/* --- pulido premium del calendario --- */
.appt{border-left-width:3px;border-left-color:rgba(14,158,116,.85);box-shadow:0 1px 3px rgba(20,45,35,.08);padding:5px 8px}
.appt.bot{border-left-color:var(--blue-d)}
.appt.pend{border-left-color:#E1A53D}
.appt.done{border-left-color:#aab6b0}
.appt.no{border-left-color:#E5484D}
.appt b{font-size:.76rem}
.appt .t{opacity:.72}
.cell:not(.past):not(.closed):hover{background:rgba(18,184,134,.07)}
.col-today{background:rgba(18,184,134,.05)}
.ch.today small{display:inline-flex;align-items:center;justify-content:center;width:23px;height:23px;border-radius:50%;background:var(--green);color:#fff;font-weight:700;margin-top:3px;box-shadow:0 2px 6px -2px rgba(14,158,116,.7)}
.mchip{padding:2px 6px;font-weight:600}
.mcell.today{background:rgba(18,184,134,.05)}
.cal-viewsel{display:flex;gap:3px;background:var(--bg-soft);padding:3px;border-radius:99px;flex:none}
.cal-viewsel button{border:none;background:transparent;color:var(--ink-soft);font-weight:700;font-size:.8rem;padding:6px 14px;border-radius:99px;cursor:pointer;transition:.12s}
.cal-viewsel button.on{background:#fff;color:var(--green-ink);box-shadow:0 1px 3px rgba(12,26,20,.12)}
.cal.cal-day{grid-template-columns:64px 1fr}
.cal-month{display:grid;grid-template-columns:repeat(7,1fr);padding:0 10px 10px}
.cal-month .mh{text-align:center;font-size:.7rem;font-weight:800;color:var(--ink-soft);padding:9px 0 7px;text-transform:uppercase;letter-spacing:.03em}
.mcell{min-height:98px;border-top:1px solid #EFF3F1;border-left:1px solid #F3F6F4;padding:5px;cursor:pointer;overflow:hidden;display:flex;flex-direction:column;gap:2px;transition:background .12s}
.mcell:nth-child(7n+8){border-left:none}
.mcell:hover{background:#F4FBF8}
.mcell.other{background:#FAFBFB}.mcell.other .mnum{color:#C3CDC8}
.mcell.closed{background:#F5F7F6}
.mnum{font-size:.78rem;font-weight:700;color:var(--ink);align-self:flex-start;line-height:1.4}
.mcell.today .mnum{background:var(--green);color:#fff;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:.74rem}
.mchip{font-size:.66rem;padding:2px 5px;border-radius:5px;background:var(--mint);color:var(--green-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border:1px solid rgba(18,184,134,.3);font-weight:600}
.mchip.bot{background:var(--blue);color:var(--blue-d);border-color:#bcd8fb}
.mchip.pend{background:#FFF6E5;color:#8a6400;border-color:#F4D58A}
.mchip.done{background:#EFF1F0;color:#6b7a73;border-color:#d8dedb}
.mchip.no{background:#FDECEC;color:#9c2b2b;border-color:#F3B6B6;text-decoration:line-through}
.mmore{font-size:.64rem;color:var(--ink-soft);font-weight:700;padding-left:3px}
.cal-list{display:block;padding:4px 14px 14px}
.lst-day{font-weight:800;font-size:.82rem;color:var(--ink-soft);text-transform:capitalize;padding:16px 4px 7px;border-bottom:1px solid var(--line);margin-bottom:4px}
.lst-day.today{color:var(--green-ink)}
.lst-row{display:flex;align-items:center;gap:11px;padding:10px 6px;border-radius:10px;cursor:pointer;transition:background .12s}
.lst-row:hover{background:var(--bg-soft)}
.lst-time{font-weight:700;font-variant-numeric:tabular-nums;font-size:.86rem;width:50px;flex:none}
.lst-dot{width:9px;height:9px;border-radius:50%;background:var(--green);flex:none}
.lst-dot.bot{background:var(--blue-d)}.lst-dot.pend{background:#E1A53D}.lst-dot.done{background:#9DB4AB}.lst-dot.no{background:#E5484D}
.lst-name{font-weight:700;font-size:.89rem}
.lst-svc{color:var(--ink-soft);font-size:.85rem}
.lst-stf{margin-left:auto;font-size:.78rem;color:var(--ink-soft);font-weight:600}
.lst-svc+.lst-stf{margin-left:auto}
.lst-row .lst-svc{margin-left:8px}
.lst-empty{text-align:center;color:var(--ink-soft);padding:40px}
@media(max-width:900px){.mcell{min-height:72px}.cal-month .mh{font-size:.62rem}}
/* --- panel lateral rediseñado --- */
.occ-hero{background:linear-gradient(155deg,#10241B,#0A1711);border-radius:18px;padding:18px;color:#fff;box-shadow:0 18px 40px -22px rgba(8,30,20,.8);position:relative;overflow:hidden}
.occ-hero::before{content:'';position:absolute;top:-30%;right:-20%;width:60%;height:120%;background:radial-gradient(circle,rgba(18,184,134,.22),transparent 65%);pointer-events:none}
.occ-hero-lbl{font-size:.66rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:14px;position:relative}
.occ-hero-row{display:flex;align-items:center;gap:16px;position:relative}
.occ-ring{width:80px;height:80px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;background:conic-gradient(var(--green) 0 0%,rgba(255,255,255,.13) 0 100%);transition:background .6s}
.occ-ring-in{width:62px;height:62px;border-radius:50%;background:#0A1711;display:flex;align-items:center;justify-content:center}
.occ-ring-in span{font-size:1.15rem;font-weight:900;font-variant-numeric:tabular-nums;color:#fff}
.occ-hero-stats{font-size:.87rem;line-height:1.7;color:rgba(255,255,255,.82)}
.occ-hero-stats b{color:#fff;font-weight:800;font-variant-numeric:tabular-nums}
.mini-kpis{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.mini-kpi{background:#fff;border:1px solid var(--line);border-radius:14px;padding:13px 14px;box-shadow:var(--sh)}
.mini-kpi b{display:block;font-size:1.3rem;font-weight:900;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.mini-kpi b.g{color:var(--green-d)}
.mini-kpi span{font-size:.72rem;color:var(--ink-soft);font-weight:600}
/* --- bloques de cita (handoff) --- */
.appt-meta{display:block;font-size:.64rem;opacity:.92;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.appt-meta .t{font-weight:700;opacity:.85}
.appt-ia{font-size:.5rem;font-weight:800;color:#2c5f99;background:#DCE9FB;padding:1px 4px;border-radius:4px;letter-spacing:.03em;line-height:1.4}
.appt-tick{color:var(--green-d);font-weight:900}
/* --- heatmap mes --- */
.hcell{height:clamp(50px,calc((100vh - 320px)/6),104px);border-radius:10px;margin:3px;padding:6px 8px;cursor:pointer;display:flex;flex-direction:column;justify-content:flex-start;gap:2px;background:#EFF4F1;transition:transform .12s,box-shadow .12s}
.hcell:hover{transform:scale(1.04)}
.hcell.other{opacity:.35;cursor:default;background:transparent}
.hcell.other:hover{transform:none}
.hcell.closed{background:repeating-linear-gradient(135deg,#FBFCFC,#FBFCFC 5px,#F2F5F4 5px,#F2F5F4 10px)!important;cursor:default}
.hcell.closed:hover{transform:none}
.hcell.today{box-shadow:0 0 0 2.5px #0C1B15}
.hnum{font-size:.82rem;font-weight:800;color:var(--ink)}
.hcnt{font-size:.66rem;font-weight:700;color:var(--ink-soft)}
.hcell.dark .hnum,.hcell.dark .hcnt{color:#fff}
/* --- agenda del día --- */
.cal-agenda{display:block;padding:8px 18px 16px}
.ag-row{display:grid;grid-template-columns:54px 22px 1fr;align-items:stretch;cursor:pointer}
.ag-time{font-size:.82rem;font-weight:800;text-align:right;padding:14px 10px 0 0;color:var(--ink);font-variant-numeric:tabular-nums}
.ag-rail{position:relative;display:flex;justify-content:center}
.ag-rail::before{content:'';position:absolute;top:0;bottom:0;width:2px;background:#EEF2F0}
.ag-dot{width:11px;height:11px;border-radius:50%;background:var(--green);margin-top:16px;z-index:1;box-shadow:0 0 0 3px #fff}
.ag-dot.bot{background:var(--blue-d)}.ag-dot.pend{background:#E1A53D}.ag-dot.done{background:#9DB4AB}.ag-dot.no{background:#E5484D}
.ag-card{margin:8px 0 8px 12px;padding:10px 13px;border-radius:11px;background:var(--mint);border-left:3px solid var(--green);box-shadow:0 2px 5px -2px rgba(12,26,20,.14);flex:1;min-width:0}
.ag-card.bot{background:var(--blue);border-left-color:var(--blue-d)}
.ag-card.pend{background:#FFF6E5;border-left-color:#E1A53D}
.ag-card.done{background:#EFF1F0;border-left-color:#9aa8a1;opacity:.92}
.ag-card.no{background:#FDECEC;border-left-color:#E5484D}
.ag-card b{display:flex;align-items:center;gap:6px;font-size:.9rem}
.ag-card.no b{text-decoration:line-through}
.ag-meta{display:block;font-size:.78rem;color:var(--ink-soft);margin-top:2px}
.ag-now{display:flex;align-items:center;gap:8px;margin:4px 0 4px 54px}
.ag-now span{background:#FF5A5F;color:#fff;font-size:.68rem;font-weight:800;padding:1px 7px;border-radius:6px;font-variant-numeric:tabular-nums}
.ag-now::after{content:'';flex:1;height:2px;background:#FF5A5F;border-radius:2px}
/* --- día por empleados --- */
.cal-dstaff{display:grid;grid-auto-rows:48px;padding:0 8px 6px;position:relative}
.ds-head{display:flex;align-items:center;gap:8px;padding:8px 6px;border-left:1px solid #F3F6F4;overflow:hidden}
.ds-av{width:28px;height:28px;border-radius:50%;background:linear-gradient(160deg,#16C194,#0C9069);color:#fff;font-weight:800;font-size:.74rem;display:flex;align-items:center;justify-content:center;flex:none}
.ds-name{font-weight:800;font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ds-cnt{font-size:.68rem;color:var(--ink-soft)}
/* ===== Rediseño Claude Design: cabecera + barra + citas exactas ===== */
.cal-titlerow{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;margin:0 4px 18px}
.cal-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#0A7553;background:#E2F4EC;padding:6px 12px;border-radius:99px}
.cal-eyebrow-dot{width:7px;height:7px;border-radius:50%;background:#12B886}
.cal-title{font-family:'Newsreader',Georgia,serif;font-weight:400;font-size:2.1rem;letter-spacing:-.01em;margin:12px 0 0;color:var(--ink)}
.cal-weekstat{text-align:right}
.cal-weekstat-lbl{font-size:.74rem;color:#7C9A8C;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.cal-weekstat-row{display:flex;align-items:baseline;gap:8px;justify-content:flex-end;margin-top:3px}
.cal-weekstat-row .n{font-size:1.7rem;font-weight:800;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.cal-weekstat-row .u{font-size:.9rem;color:#51635B;font-weight:600}
.cal-wklabel{line-height:1.1}
.cal-wklabel .wk{font-size:1.06rem;font-weight:800;letter-spacing:-.01em;color:var(--ink)}
.cal-wksub{font-size:.74rem;color:#9DB4AB;font-weight:600}
.cal-toolright{margin-left:auto;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.cal-staffpills{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.staffpill{display:inline-flex;align-items:center;gap:7px;height:34px;padding:0 12px 0 6px;border-radius:99px;border:1.5px solid #E5ECE8;background:#fff;cursor:pointer;font-size:.82rem;font-weight:700;color:#51635B;transition:.12s}
.staffpill:hover{border-color:#9ED9C2}
.staffpill.on{border-color:#12B886;background:#E8F7F0;color:#0A7553}
.sp-av{width:22px;height:22px;border-radius:50%;font-size:.66rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex:none}
.sp-av.sp-all{background:#12B886;color:#fff}
.ch{font-size:.72rem;font-weight:700;text-align:center;padding:12px 4px 8px;color:#9DB4AB;text-transform:uppercase;letter-spacing:.04em}
.ch small{display:block;font-weight:800;font-size:1.18rem;color:#46584F;line-height:1.05;text-transform:none;letter-spacing:0;font-variant-numeric:tabular-nums}
.ch.today{color:#0A7553;font-weight:800}
.ch.today small{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:#12B886;color:#fff;font-size:1.04rem;margin-top:1px;box-shadow:none}
.ch.closed{color:#C2CDC8}.ch.closed small{color:#C2CDC8}
.ch .occ{display:block;font-size:.58rem;font-weight:700;color:#9DB4AB;margin-top:3px;text-transform:none;letter-spacing:0}
.ch-bar{height:4px;border-radius:99px;background:#EDF2EF;margin:6px 8px 0;overflow:hidden}
.ch-bar i{display:block;height:100%;background:#7FD8B8}
.ch-bar i.full{background:#12B886}
.ch.today .ch-bar{background:#D6F0E5}.ch.today .ch-bar i{background:#12B886}
.appt{margin:3px;border-radius:11px;padding:6px 9px;background:#E7F7F0;border:none;border-left:3px solid #12B886;box-shadow:0 2px 5px -2px rgba(12,26,20,.18);overflow:hidden;cursor:grab;position:relative}
.appt b{font-weight:800;font-size:.76rem;color:#0B1A13;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.appt-meta{display:block;font-size:.64rem;font-weight:700;color:#0A7553;font-variant-numeric:tabular-nums;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:1}
.appt.bot{background:#EAF3FF;border-left-color:#2c5f99}
.appt.bot b{color:#173a5e}.appt.bot .appt-meta{color:#2c5f99}
.appt.pend{background:#FFF6E5;border-left-color:#F0B429}
.appt.pend b{color:#6b4e00}.appt.pend .appt-meta{color:#9a7400}
.appt.done{background:#EFF1F0;border-left-color:#9aa8a1;opacity:.92}
.appt.done b{color:#56625c}.appt.done .appt-meta{color:#7b8780}
.appt.no{background:#FDECEC;border-left-color:#E05656}
.appt.no b{color:#7d1f1f;text-decoration:line-through}.appt.no .appt-meta{color:#9c2b2b}
.appt-flags{position:absolute;top:6px;right:7px;display:flex;gap:3px;align-items:center}
.appt-ia{font-size:.5rem;font-weight:800;color:#2c5f99;background:#DCE9FB;padding:2px 5px;border-radius:6px;letter-spacing:.02em;line-height:1.3}
.appt:hover{transform:translateY(-2px);box-shadow:0 10px 22px -10px rgba(12,26,20,.4);z-index:9}
.cal-head{align-items:flex-start}
.cal-legend{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;padding:10px 16px 4px;font-size:.72rem;color:var(--ink-soft)}
.cal-legend span{display:flex;align-items:center;gap:5px}
.lg{width:11px;height:11px;border-radius:4px;display:inline-block;border:1px solid}
.lg-conf{background:var(--mint);border-color:rgba(18,184,134,.4)}
.lg-pend{background:#FFF6E5;border-color:#F4D58A}
.lg-bot{background:var(--blue);border-color:#bcd8fb}
.lg-done{background:#EFF1F0;border-color:#d8dedb}
.lg-no{background:#FDECEC;border-color:#F3B6B6}
@keyframes pop{from{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}
.side{display:flex;flex-direction:column;gap:16px}
.kpis{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:13px}
.kpi .n{font-size:1.4rem;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.kpi .n.g{color:var(--green-d)}.kpi .l{font-size:.72rem;color:var(--ink-soft);font-weight:600}
.sbox{padding:15px}.sbox h3{font-size:.72rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--green-ink);margin:0 0 10px}
.item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid #F0F4F2}.item:last-child{border-bottom:0}
.item .av{width:30px;height:30px;border-radius:50%;background:var(--mint);color:var(--green-d);font-weight:800;font-size:.74rem;display:flex;align-items:center;justify-content:center;flex:none}
.item .nm{font-weight:600;font-size:.84rem;line-height:1.1}.item .mt{font-size:.74rem;color:var(--ink-soft)}
.item .when{margin-left:auto;font-size:.76rem;font-weight:700;color:var(--green-d)}

/* chat */
.chatwrap{max-width:430px;margin:0 auto}
.phone{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--sh-pop)}
.chead{background:#0C1A14;color:#fff;padding:13px 16px;display:flex;align-items:center;gap:11px}
.chead .av{width:36px;height:36px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;font-weight:800}
.chead .nm{font-weight:700;font-size:.92rem}.chead .st{font-size:.74rem;color:#7FE3C0}
.cbody{height:450px;overflow-y:auto;padding:16px;background:var(--bg-soft);display:flex;flex-direction:column;gap:8px}
.b{max-width:80%;padding:9px 13px;border-radius:15px;font-size:.9rem;line-height:1.35;white-space:pre-wrap}
.b.bot{align-self:flex-start;background:#fff;border:1px solid var(--line);border-bottom-left-radius:5px}
.b.me{align-self:flex-end;background:var(--green);color:#fff;border-bottom-right-radius:5px}
.chips{display:flex;flex-wrap:wrap;gap:7px;align-self:flex-start;max-width:90%}
.chip{background:#fff;border:1px solid rgba(18,184,134,.4);color:var(--green-d);font-weight:600;font-size:.82rem;border-radius:99px;padding:7px 13px;cursor:pointer}
.chip:hover{background:var(--mint)}
.typ{align-self:flex-start;background:#fff;border:1px solid var(--line);border-radius:15px;padding:11px 14px;display:flex;gap:4px}
.typ span{width:7px;height:7px;border-radius:50%;background:#C4D2CC;animation:tb 1.2s infinite}
.typ span:nth-child(2){animation-delay:.15s}.typ span:nth-child(3){animation-delay:.3s}
@keyframes tb{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}
.cfoot{display:flex;gap:8px;padding:11px;border-top:1px solid var(--line);background:#fff}
.cfoot input{flex:1;border-radius:99px}
.cfoot button{background:var(--green);border:none;color:#fff;width:42px;height:42px;border-radius:50%;cursor:pointer;font-size:1.1rem;flex:none}
.cfoot button.cvoice{background:#eef0f3;color:#5b6470}
.cfoot button.cvoice.on{background:#e5484d;color:#fff;animation:cvpulse 1.2s ease-in-out infinite}
@keyframes cvpulse{0%,100%{box-shadow:0 0 0 0 rgba(229,72,77,.45)}50%{box-shadow:0 0 0 7px rgba(229,72,77,0)}}
/* Asistente: selector de servicio (chat / voz) */
.svc-toggle{display:flex;gap:5px;justify-content:center;margin:0 auto 20px;background:#E6F1EB;padding:5px;border-radius:99px;max-width:400px;box-shadow:inset 0 0 0 1px rgba(18,184,134,.08)}
.svc-toggle .svc{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;border:none;background:transparent;padding:10px 14px;border-radius:99px;cursor:pointer;font-size:.88rem;font-weight:600;color:#5A6E65;transition:color .18s,background .18s,box-shadow .18s}
.svc-toggle .svc:hover{color:var(--green-ink)}
.svc-toggle .svc.on{background:#fff;color:var(--green-ink);box-shadow:0 2px 8px -2px rgba(12,26,20,.18)}
.voicecard{position:relative;max-width:380px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:36px 26px 28px;text-align:center;box-shadow:var(--sh);overflow:hidden}
.voicecard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--green),rgba(18,184,134,0))}
.voiceorb{width:88px;height:88px;border-radius:50%;background:linear-gradient(150deg,#1ED39E,#0C9069);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto 18px;box-shadow:0 12px 28px -10px rgba(14,158,116,.6);animation:voicePulse 2.6s ease-in-out infinite}
@keyframes voicePulse{0%,100%{box-shadow:0 12px 28px -10px rgba(14,158,116,.6),0 0 0 0 rgba(18,184,134,.40)}50%{box-shadow:0 12px 28px -10px rgba(14,158,116,.6),0 0 0 13px rgba(18,184,134,0)}}
.voicetitle{font-weight:700;font-size:1.15rem;color:var(--ink)}
.voicesub{color:var(--ink-soft);font-size:.85rem;margin-top:4px}
.voicehint{margin-top:18px;font-size:.8rem;color:var(--ink-soft);background:#F1F7F4;border:1px solid #E1EEE8;border-radius:var(--r-sm);padding:12px 14px;line-height:1.5}
.voiceorb{cursor:pointer;user-select:none;transition:transform .15s}
.voiceorb:hover{transform:scale(1.05)}
.voiceorb.calling{animation:voiceCalling 1.4s ease-in-out infinite}
.voiceorb.speaking{background:linear-gradient(150deg,#1ED39E,#0C9069)}
@keyframes voiceCalling{0%,100%{box-shadow:0 12px 28px -10px rgba(14,158,116,.6),0 0 0 0 rgba(18,184,134,.5)}50%{box-shadow:0 12px 28px -10px rgba(14,158,116,.6),0 0 0 16px rgba(18,184,134,0)}}
.voicecard .btn-danger{background:#e5484d;box-shadow:0 8px 18px -8px rgba(229,72,77,.55)}
.voicecard .btn-danger:hover{background:#d23b40}
/* Iconos SVG de la sección Asistente (coordinados con el ecosistema) */
.svc-toggle .svc svg{width:17px;height:17px;flex:none}
.voiceorb svg{width:34px;height:34px}
.cfoot button svg{width:18px;height:18px}
.btn.mini{display:inline-flex;align-items:center;gap:5px}
.btn.mini svg{width:13px;height:13px;flex:none}
/* ===== Reputación (reseñas de Google) ===== */
.rep-connect{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;box-shadow:var(--sh);margin-bottom:16px}
.rep-gic{width:42px;height:42px;border-radius:12px;background:linear-gradient(150deg,#E9F8F1,#CBEEDD);color:var(--green-ink);display:flex;align-items:center;justify-content:center;flex:none}
.rep-gic svg{width:22px;height:22px}
.rep-tools{padding:18px;margin-bottom:18px}
.rep-lbl{display:block;font-weight:600;font-size:.85rem;color:var(--ink);margin-bottom:6px}
.rep-sep{border-top:1px solid var(--line);margin:16px 0}
.rep-add{display:grid;grid-template-columns:1fr 110px;gap:8px}
.rep-add textarea{grid-column:1/-1;min-height:64px;resize:vertical}
.rep-add button{grid-column:1/-1;justify-self:start}
.rev-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;box-shadow:var(--sh);margin-bottom:12px}
.rev-top{display:flex;align-items:center;gap:11px;margin-bottom:8px}
.rev-av{width:36px;height:36px;border-radius:50%;background:linear-gradient(150deg,#E9F8F1,#CBEEDD);color:var(--green-ink);display:flex;align-items:center;justify-content:center;font-weight:800;flex:none}
.rev-name{font-weight:700;font-size:.92rem}
.rev-stars{color:#F5A623;font-size:.9rem;letter-spacing:1px}
.rev-badge{margin-left:auto;font-size:.7rem;font-weight:700;padding:3px 9px;border-radius:99px;background:#EEF2F0;color:#5A6E65}
.rev-badge.ok{background:#E7F7F0;color:var(--green-ink)}
.rev-badge.draft{background:#FFF4E0;color:#9A6A12}
.rev-text{font-size:.9rem;color:#46584F;background:#F7FBF9;border-radius:10px;padding:10px 12px;margin-bottom:10px}
.rev-reply{width:100%;min-height:70px;resize:vertical}
.rev-actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap;align-items:center}
.btn.mini{font-size:.82rem;padding:7px 12px}
.rev-del{margin-left:auto;color:#C0392B}
/* Dashboard de reputación */
.rep-dash{display:grid;grid-template-columns:230px 1fr;grid-template-rows:auto auto;gap:14px;margin-bottom:20px}
.rep-empty{grid-column:1/-1;background:#fff;border:1px dashed var(--line);border-radius:var(--r);padding:22px;text-align:center;color:var(--ink-soft);font-size:.9rem}
.rep-hero{grid-row:1/3;background:linear-gradient(140deg,#13B98A,#0C8E66);color:#fff;border-radius:var(--r);padding:22px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;box-shadow:0 20px 44px -24px rgba(14,158,116,.65)}
.rep-hero-num{font-size:3rem;font-weight:800;line-height:1;font-family:'Newsreader',Georgia,serif}
.rep-hero-stars{color:#FFE08A;font-size:1.15rem;letter-spacing:2px;margin-top:6px}
.rep-hero-sub{font-size:.82rem;color:#DAF4EA;margin-top:9px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:center}
.rep-dist{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:15px 18px;box-shadow:var(--sh);display:flex;flex-direction:column;justify-content:center;gap:7px}
.rep-bar{display:flex;align-items:center;gap:9px;font-size:.8rem}
.rb-lbl{width:26px;color:#5A6E65;font-weight:600;font-variant-numeric:tabular-nums}
.rb-track{flex:1;height:8px;background:#EEF2F0;border-radius:99px;overflow:hidden}
.rb-track i{display:block;height:100%;background:linear-gradient(90deg,#34D3A0,#0E9E74);border-radius:99px;transition:width .5s cubic-bezier(.2,.7,.2,1)}
.rb-n{width:22px;text-align:right;color:#46584F;font-variant-numeric:tabular-nums}
.rep-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.rep-kpi{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:13px;text-align:center;box-shadow:var(--sh)}
.rep-kpi b{display:block;font-size:1.55rem;font-weight:800;color:var(--ink);line-height:1.1}
.rep-kpi span{font-size:.74rem;color:var(--ink-soft)}
.rep-kpi.warn b{color:#C0392B}
.rep-trend{font-size:.72rem;font-weight:700;padding:1px 8px;border-radius:99px}
.rep-trend.up{color:#093;background:rgba(255,255,255,.9)}
.rep-trend.down{color:#C0392B;background:rgba(255,255,255,.9)}
.rep-trend.flat{color:#0A7553;background:rgba(255,255,255,.85)}
@media(max-width:760px){.rep-dash{grid-template-columns:1fr}.rep-hero{grid-row:auto}}
/* Pestañas internas de Reputación */
.rep-tabs{display:flex;gap:5px;justify-content:center;margin:0 auto 20px;background:#E6F1EB;padding:5px;border-radius:99px;max-width:360px;box-shadow:inset 0 0 0 1px rgba(18,184,134,.08)}
.rep-tabs .rt{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;border:none;background:transparent;padding:10px 14px;border-radius:99px;cursor:pointer;font-size:.88rem;font-weight:600;color:#5A6E65;transition:color .18s,background .18s,box-shadow .18s}
.rep-tabs .rt svg{width:16px;height:16px;flex:none}
.rep-tabs .rt:hover{color:var(--green-ink)}
.rep-tabs .rt.on{background:#fff;color:var(--green-ink);box-shadow:0 2px 8px -2px rgba(12,26,20,.18)}
/* Gráficas */
.rep-charts{display:grid;grid-template-columns:250px 1fr;gap:14px;margin-bottom:8px}
@media(max-width:760px){.rep-charts{grid-template-columns:1fr}}
.chart-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;box-shadow:var(--sh)}
.chart-card h3{font-size:.74rem;font-weight:800;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;margin:0 0 12px}
.donut{width:140px;height:140px;display:block;margin:2px auto 0}
.donut-num{font-size:24px;font-weight:800;fill:var(--ink)}
.donut-lbl{font-size:10px;fill:var(--ink-soft)}
.donut-legend{display:flex;flex-direction:column;gap:5px;margin-top:12px;font-size:.78rem;color:#46584F}
.donut-legend span{display:flex;align-items:center;gap:8px}
.donut-legend i{width:10px;height:10px;border-radius:3px;display:inline-block;flex:none}
.linechart{width:100%;height:auto;display:block}
.linechart .ax{font-size:9px;fill:#9DB4AB}
.chart-empty{color:var(--ink-soft);font-size:.85rem;text-align:center;padding:34px 12px}
.chart-legend{display:flex;gap:16px;margin-top:10px;font-size:.76rem;color:#46584F}
.chart-legend span{display:flex;align-items:center;gap:6px}
.chart-legend i{display:inline-block;flex:none}
.chart-legend .lg-bar{width:12px;height:10px;border-radius:2px;background:#CDEBDD}
.chart-legend .lg-line{width:14px;height:0;border-top:2.5px solid #0E9E74}
/* Filtros del informe */
.rep-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px;align-items:center}
.rep-filters select,.rep-filters input{padding:8px 11px;font-size:.84rem;border-radius:10px;border:1px solid #DFE8E3;background:#fff}
.rep-filters #fSearch{flex:1;min-width:150px}
.rep-inf-head{display:flex;align-items:center;margin:6px 2px 12px;font-size:.82rem;color:var(--ink-soft);font-weight:600}
.rep-pager{display:flex;align-items:center;justify-content:center;gap:14px;margin:6px 0 4px}
.rep-pg{font-size:.84rem;color:var(--ink-soft);font-weight:600;font-variant-numeric:tabular-nums}
.btn.mini[disabled]{opacity:.4;cursor:default}
/* Tarjeta de reseña: meta + nota interna */
.rev-meta{display:flex;align-items:center;gap:9px;margin-top:2px}
.rev-date{font-size:.74rem;color:var(--ink-soft)}
.rev-note{width:100%;margin-top:8px;padding:8px 11px;font-size:.82rem;border:1px dashed var(--line);border-radius:9px;background:#FBFDFC;color:#46584F}
.rev-note:focus{border-style:solid;border-color:var(--green)}
/* ===== Dashboard profesional de reputación ===== */
#repDash{display:block;margin-bottom:16px}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(158px,1fr));gap:13px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:15px 16px;box-shadow:var(--sh);position:relative;overflow:hidden;animation:lxPop .45s cubic-bezier(.2,.8,.25,1.02) both}
.kpi:nth-child(2){animation-delay:.05s}.kpi:nth-child(3){animation-delay:.1s}.kpi:nth-child(4){animation-delay:.15s}.kpi:nth-child(5){animation-delay:.2s}
.kpi-top{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:30px}
.kpi-top b{font-size:1.7rem;font-weight:800;color:var(--ink);line-height:1;font-variant-numeric:tabular-nums}
.kpi-lbl{display:block;font-size:.76rem;color:var(--ink-soft);margin-top:4px}
.kpi .spark{width:100%;height:24px;margin-top:10px;display:block}
.spark-empty{height:24px;margin-top:10px}
.kdelta{font-size:.72rem;font-weight:800;padding:2px 7px;border-radius:99px;white-space:nowrap}
.kdelta.up{color:#0A7553;background:#E7F7F0}
.kdelta.down{color:#C0392B;background:#FEECEC}
.kdelta.flat{color:#7C9A8C;background:#F1F5F3}
.kpi-hero{background:linear-gradient(140deg,#13B98A,#0C8E66);color:#fff;border:none;box-shadow:0 20px 44px -24px rgba(14,158,116,.65)}
.kpi-h-row{display:flex;align-items:center;justify-content:space-between}
.kpi-h-num{font-size:2.5rem;font-weight:800;line-height:1;font-family:'Newsreader',Georgia,serif;font-variant-numeric:tabular-nums}
.kpi-hero .kpi-lbl{color:#DAF4EA}
.kpi-h-stars{color:#FFE08A;font-size:1rem;letter-spacing:2px;margin-top:5px}
.kpi-hero .kdelta{background:rgba(255,255,255,.22);color:#fff}
#repCharts{grid-template-columns:1fr 1fr;margin-bottom:18px}
.chart-wide{grid-column:1/-1}
.rep-bar.clk,.donut-legend .clk{cursor:pointer}
.rep-bar.clk:hover .rb-track{box-shadow:0 0 0 2px rgba(18,184,134,.3)}
.donut-legend .clk:hover{color:var(--green-ink)}
.donut-seg{cursor:pointer;transition:opacity .15s}
.donut-seg:hover{opacity:.82}
.chart-bar{transform-box:fill-box;transform-origin:center bottom;animation:barGrow .55s cubic-bezier(.2,.8,.25,1) both}
@keyframes barGrow{from{transform:scaleY(0)}to{transform:scaleY(1)}}
.chart-line{stroke-dasharray:1;stroke-dashoffset:1;animation:lineDraw .9s ease .15s forwards}
@keyframes lineDraw{to{stroke-dashoffset:0}}
.rep-tip{position:fixed;z-index:9999;display:none;background:#0C1A14;color:#fff;font-size:.76rem;font-weight:600;padding:6px 10px;border-radius:8px;pointer-events:none;box-shadow:0 6px 18px -6px rgba(0,0,0,.4);white-space:nowrap}
/* Análisis por temas */
.rep-themes{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;box-shadow:var(--sh);margin-bottom:18px}
.rep-themes:empty{display:none}
.rep-themes h3{font-size:.74rem;font-weight:800;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.05em;margin:0 0 12px}
.theme-row{padding:9px 10px;border-radius:10px;cursor:pointer;transition:background .15s}
.theme-row:hover{background:#F4F8F6}
.theme-head{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.theme-name{font-weight:600;font-size:.9rem;color:var(--ink);flex:1}
.theme-cnt{font-size:.74rem;color:var(--ink-soft)}
.theme-avg{font-size:.82rem;font-weight:800;color:var(--green-ink);font-variant-numeric:tabular-nums}
.theme-bar{display:flex;height:9px;border-radius:99px;overflow:hidden;background:#EEF2F0}
.theme-bar i{display:block;height:100%;transition:width .5s cubic-bezier(.2,.7,.2,1)}
.theme-bar .tb-pos{background:#12B886}.theme-bar .tb-neu{background:#E4ECE8}.theme-bar .tb-neg{background:#E5484D}
.theme-legend{display:flex;gap:16px;margin-top:12px;font-size:.74rem;color:#46584F}
.theme-legend span{display:flex;align-items:center;gap:6px}
.theme-legend i{width:10px;height:10px;border-radius:3px;display:inline-block}
/* Predicción / proyección */
.kpi-fc{border-color:#BFE3D2;background:linear-gradient(180deg,#F3FAF6,#fff)}
.proj-lbl{font-size:11px;font-weight:800;fill:#0A7553}
.ax.proj{fill:#B7C9C0}
.chart-legend .lg-proj{width:16px;height:0;border-top:2.5px dashed #0E9E74}
.trendchart{width:100%;height:auto}
/* Animación de creación de negocio */
.lx-cel{position:fixed;inset:0;z-index:99998;background:linear-gradient(157deg,#10433A,#0A2A22 64%,#072019);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:#fff;overflow:hidden}
.lx-cel.cel-out{animation:lxFade .45s ease forwards}
.cel-glow{position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(54,200,194,.34),rgba(154,209,90,.12) 44%,transparent 68%);animation:celGlow 1.2s ease both}
@keyframes celGlow{from{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}
.cel-ring{position:relative;z-index:2;animation:lxMarkPop .5s cubic-bezier(.2,1.4,.4,1) .1s both}
.cel-ring svg{width:98px;height:98px}
.cel-c{fill:none;stroke:#36C8C2;stroke-width:3;stroke-dasharray:160;stroke-dashoffset:160;animation:celDraw .6s ease .15s forwards}
.cel-ck{fill:none;stroke:#fff;stroke-width:4;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:60;stroke-dashoffset:60;animation:celDraw .45s ease .55s forwards}
@keyframes celDraw{to{stroke-dashoffset:0}}
.cel-title{z-index:2;font-family:'Newsreader',Georgia,serif;font-size:1.9rem;margin-top:16px;opacity:0;animation:celUp .5s ease .7s forwards}
.cel-name{z-index:2;font-weight:800;font-size:1.15rem;color:#9AD15A;opacity:0;animation:celUp .5s ease .85s forwards}
.cel-sub{z-index:2;font-size:.85rem;color:#9DB4AB;margin-top:2px;opacity:0;animation:celUp .5s ease 1s forwards}
@keyframes celUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
/* Plano de fondo de la sala (claridad ajustable) */
.floor-bg{position:absolute;inset:0;background-size:100% 100%;background-position:center;background-repeat:no-repeat;z-index:0;pointer-events:none}
.plan-ctl{display:inline-flex;align-items:center;gap:10px;margin-left:6px}
.plan-op{display:inline-flex;align-items:center;gap:7px;font-size:.8rem;color:var(--ink-soft)}
.plan-op input[type=range]{width:110px;accent-color:var(--green)}
/* ===== Mesas estilo "Madera cálida" (suave, no marrón fuerte) ===== */
.floor{background:#EFF6F2 !important;background-image:radial-gradient(#D6E7DD 1.2px,transparent 1.2px) !important;background-size:24px 24px !important;box-shadow:inset 0 0 90px rgba(18,184,134,.04) !important}
.floor .mesa.tbl{background:linear-gradient(157deg,#FBF5EC,#F1E6D5) !important;border:none !important;color:#8A7252 !important;box-shadow:0 2px 3px rgba(120,98,66,.12),0 13px 22px -11px rgba(120,98,66,.34),inset 0 1px 0 rgba(255,255,255,.7) !important}
.floor .mesa.tbl .m-num{color:#7E6747 !important}
.floor .mesa.tbl .m-seats{color:#B3A082 !important;font-weight:700;font-size:.6rem}
.floor .mesa.busy{background:linear-gradient(157deg,#D6EEE2,#BCE5D2) !important;color:#0A7553 !important}
.floor .mesa.busy .m-num,.floor .mesa.busy .m-seats,.floor .mesa.busy .m-who{color:#0A7553 !important}
.floor .mesa.sel{background:linear-gradient(157deg,#D6EEE2,#BCE5D2) !important;color:#0A7553 !important;box-shadow:0 0 0 3px rgba(18,184,134,.5),0 13px 24px -10px rgba(120,98,66,.34) !important;z-index:6}
.floor .mesa.sel .m-num,.floor .mesa.sel .m-seats{color:#0A7553 !important}
/* sillas cuadradas (clase NUEVA 'sx', sin herencia del estilo viejo) */
.floor .sx{position:absolute;display:flex;justify-content:space-around;align-items:center;z-index:0}
.floor .sx-top{top:-12px;left:10px;right:10px;height:10px}
.floor .sx-bottom{bottom:-12px;left:10px;right:10px;height:10px}
.floor .sx-left{left:-12px;top:10px;bottom:10px;width:10px;flex-direction:column}
.floor .sx-right{right:-12px;top:10px;bottom:10px;width:10px;flex-direction:column}
.floor .sx i{flex:0 0 auto;display:block;background:#E8DAC0;border:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.6),0 1px 2px rgba(120,98,66,.16)}
.floor .sx-top i,.floor .sx-bottom i{width:18px;height:10px;border-radius:5px}
.floor .sx-left i,.floor .sx-right i{width:10px;height:18px;border-radius:5px}
.floor .mesa.busy .sx i,.floor .mesa.sel .sx i,.floor .mesa.grp .sx i{background:#B6E2CF}
/* ===== Logo del negocio ===== */
.logo-row{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.logo-prev{width:64px;height:64px;border-radius:16px;background:linear-gradient(150deg,#E9F8F1,#CBEEDD);color:var(--green-ink);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.5rem;flex:none;overflow:hidden}
.logo-prev img{width:100%;height:100%;object-fit:cover;display:block}
.logo-actions{flex:1;min-width:0}
.biz-logo{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}
/* ===== Equipo y roles ===== */
/* ===== Equipo y permisos ===== */
.team-list{display:flex;flex-direction:column;gap:10px;margin:16px 0 4px}
.team-row{display:flex;align-items:center;gap:12px;padding:11px 13px;border:1px solid var(--line);border-radius:var(--r-sm);background:#fff;transition:border-color .15s}
.team-row:hover{border-color:#D4E2DB}
.tm-av{width:38px;height:38px;border-radius:50%;background:var(--mint);color:var(--green-ink);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.95rem;flex:none}
.tm-info{flex:1;min-width:0;display:flex;flex-direction:column;line-height:1.3}
.tm-info b{font-size:.92rem;letter-spacing:-.01em}
.tm-info span{font-size:.78rem;color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.role-badge{font-size:.68rem;font-weight:700;letter-spacing:.04em;padding:5px 11px;border-radius:var(--pill);white-space:nowrap;text-transform:uppercase}
.role-owner{background:var(--mint);color:var(--green-ink)}
.tm-edit{border:1px solid var(--line);background:#fff;color:var(--ink-soft);font-size:.8rem;font-weight:600;padding:7px 14px;border-radius:var(--pill);cursor:pointer;flex:none;transition:.15s}
.tm-edit:hover{border-color:var(--green);color:var(--green-ink);background:var(--mint)}
.tm-edit.on{border-color:var(--green);color:var(--green-ink);background:var(--mint)}
.tm-x{border:none;background:transparent;color:#C4574A;width:32px;height:32px;border-radius:50%;font-size:.9rem;cursor:pointer;flex:none;display:flex;align-items:center;justify-content:center;transition:.15s}
.tm-x:hover{background:#FBEBE9}
.perm-edit{margin:0 0 2px;padding:16px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--bg-soft)}
.perm-grid{display:flex;flex-direction:column;gap:1px;margin:0 0 14px}
.perm-chk{display:flex;align-items:center;gap:11px;font-size:.88rem;color:var(--ink);font-weight:500;cursor:pointer;padding:9px 10px;border-radius:var(--r-xs);transition:background .12s}
.perm-chk:hover{background:#fff}
.perm-chk.sub{margin-left:29px;font-size:.83rem;color:var(--ink-soft);font-weight:400}
.perm-chk input{width:18px;height:18px;accent-color:var(--green);flex:none;cursor:pointer;margin:0}
.perm-chk span{line-height:1.3}
.team-gen{margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}
.team-sub{font-size:1rem;font-weight:700;margin:0 0 3px;letter-spacing:-.01em}
.conv-forget{margin-left:auto;border:1px solid var(--line);background:#fff;color:#C4574A;font-size:.78rem;font-weight:600;padding:7px 12px;border-radius:var(--pill);cursor:pointer;flex:none;white-space:nowrap;transition:.15s}
.conv-forget:hover{border-color:#E0A59E;background:#FBEBE9}
/* ===== Pacientes (fichas) ===== */
.pac-layout{display:grid;grid-template-columns:300px 1fr;gap:18px;align-items:start}
@media(max-width:840px){.pac-layout{grid-template-columns:1fr}}
.pac-side{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);overflow:hidden}
.pac-search{padding:12px;border-bottom:1px solid var(--line)}
.pac-list{max-height:64vh;overflow-y:auto}
.pac-item{display:flex;align-items:center;gap:11px;padding:11px 13px;cursor:pointer;border-bottom:1px solid var(--bg-soft);transition:background .12s}
.pac-item:hover{background:var(--bg-soft)}
.pac-item.on{background:var(--mint)}
.pac-item-av{width:38px;height:38px;border-radius:50%;background:linear-gradient(160deg,#16C194,#0C9069);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.92rem;flex:none;box-shadow:0 4px 10px -5px rgba(14,158,116,.55)}
.pac-item-info{min-width:0;display:flex;flex-direction:column;line-height:1.3}
.pac-item-info b{font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pac-item-info span{font-size:.76rem;color:var(--ink-soft)}
.pac-none{padding:22px 16px;text-align:center;color:var(--ink-soft);font-size:.85rem;line-height:1.5}
.pac-empty{text-align:center;color:var(--ink-soft);padding:64px 20px}
.pac-empty-ic{font-size:2.4rem;margin-bottom:10px}
.pac-empty span{font-size:.84rem;opacity:.85}
.pac-fhead{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.pac-av{width:58px;height:58px;border-radius:50%;background:linear-gradient(160deg,#16C194,#0C9069);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.5rem;flex:none;box-shadow:0 10px 22px -10px rgba(14,158,116,.6)}
.pac-fhead-info{flex:1;min-width:0}
.pac-fhead-info h2{margin:0;font-size:1.3rem;letter-spacing:-.02em}
.pac-phone{font-size:.85rem;color:var(--ink-soft)}
.pac-card{padding:20px;margin-bottom:16px}
.pac-card>label:first-of-type,.pac-card .row2:first-child label{margin-top:0}
.pac-save{display:flex;align-items:center;gap:12px;margin-top:16px}
.pac-saved{color:var(--green-ink);font-size:.85rem;font-weight:600}
.pac-hist-title{font-size:1rem;margin:0 0 12px}
.pac-history{display:flex;flex-direction:column;gap:6px}
.pac-hist-row{display:flex;align-items:center;gap:10px;padding:9px 12px;border:1px solid var(--line);border-radius:var(--r-sm);font-size:.85rem}
.pac-hist-date{font-weight:600;white-space:nowrap}
.pac-hist-svc{flex:1;color:var(--ink-soft);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pac-hist-st{font-size:.72rem;font-weight:700;padding:3px 9px;border-radius:var(--pill);background:var(--bg-soft);color:var(--ink-soft);white-space:nowrap}
.pac-hist-st.st-confirmada,.pac-hist-st.st-completada{background:var(--mint);color:var(--green-ink)}
.pac-hist-st.st-cancelada,.pac-hist-st.st-no_show{background:#FBEBE9;color:#C4574A}
.pac-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.pac-head h1{font-size:1.9rem;margin:0}
.pac-head-sub{color:var(--ink-soft);font-size:.92rem;margin:4px 0 0}
.pac-newbtn{flex:none}
.pac-sec{font-size:.95rem;font-weight:700;margin:0 0 12px;display:flex;align-items:center;gap:8px}
.pac-sens{font-size:.64rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;background:#FFF1E8;color:#B5651D;padding:3px 8px;border-radius:var(--pill)}
.pac-clinical{border-color:#F1D9C4}
.pac-hist-row{cursor:pointer}
.pac-hist-row:hover{border-color:var(--green);background:var(--bg-soft)}
.pac-tag{font-size:.64rem;font-weight:700;background:var(--mint);color:var(--green-ink);padding:2px 6px;border-radius:var(--pill);margin-left:4px}
/* modal de cita */
.modal.modal-cita{max-width:720px;width:min(720px,94vw);max-height:90vh;display:flex;flex-direction:column;padding:0}
.cita-head{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 22px 14px;border-bottom:1px solid var(--line)}
.cita-head h3{margin:0;font-size:1.15rem;letter-spacing:-.01em}
.cita-x{border:none;background:transparent;font-size:1.1rem;color:var(--ink-soft);cursor:pointer;padding:4px 9px;border-radius:8px;flex:none}
.cita-x:hover{background:var(--bg-soft)}
.cita-scroll{overflow-y:auto;padding:18px 22px 22px;display:flex;flex-direction:column;gap:16px}
.cita-card{padding:18px}
.cita-docs{display:flex;flex-direction:column;gap:7px;margin-bottom:10px}
.cita-doc{display:flex;align-items:center;gap:10px;padding:9px 12px;border:1px solid var(--line);border-radius:var(--r-sm)}
.cita-doc-name{flex:1;cursor:pointer;font-size:.88rem;color:var(--green-ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cita-doc-name:hover{text-decoration:underline}
.cita-doc-x{border:none;background:transparent;color:#C4574A;cursor:pointer;font-size:.85rem;padding:3px 8px;border-radius:7px;flex:none}
.cita-doc-x:hover{background:#FBEBE9}
.cita-upl{display:flex;align-items:center;gap:12px}
.team-add{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap;align-items:center}
.team-add select{flex:1;min-width:170px}
.team-add .btn{flex:none}
.tm-code{margin-top:16px;padding:22px;border:1.5px dashed var(--green);border-radius:var(--r);background:linear-gradient(180deg,#F3FBF7,#E9F7F0);text-align:center}
.tm-code-big{font-size:2.15rem;font-weight:800;letter-spacing:.3em;color:var(--green-ink);padding-left:.3em;font-variant-numeric:tabular-nums}
.tm-code-info{font-size:.82rem;color:var(--ink-soft);margin-top:9px}
.tm-code-help{font-size:.8rem;color:var(--ink-soft);margin-top:13px;line-height:1.5}
.tm-code-exp{color:#C4574A;font-weight:600}
.join-box{margin-top:14px}
.join-toggle{display:inline-block;font-size:.82rem;color:var(--green-ink);cursor:pointer;text-decoration:underline}
#joinFields input{text-transform:none}
#joinFields #au_code{text-transform:uppercase;letter-spacing:.15em;font-weight:700}

/* ajustes */
.ajwrap{max-width:620px;margin:0 auto}.ajwrap .card{padding:22px}.ajwrap h2{margin:0 0 18px;font-size:1.25rem}

/* modal */
.overlay{position:fixed;inset:0;background:rgba(12,26,20,.45);display:none;align-items:center;justify-content:center;z-index:60;padding:18px}
.overlay.on{display:flex}
.modal{background:#fff;border-radius:var(--r);padding:22px;width:100%;max-width:380px;box-shadow:0 24px 60px -22px rgba(12,26,20,.4)}
.modal h3{margin:0 0 4px;font-size:1.15rem}.modal .msub{color:var(--ink-soft);font-size:.86rem;margin:0 0 14px}
.mrow{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mact{display:flex;gap:10px;margin-top:18px}.mact .btn{flex:1;text-align:center;padding:11px}

.toast{position:fixed;right:20px;bottom:20px;background:#0C1A14;color:#fff;border-radius:13px;padding:13px 16px;display:flex;gap:11px;align-items:center;box-shadow:0 18px 40px rgba(0,0,0,.3);transform:translateY(160%);transition:transform .5s cubic-bezier(.2,.9,.3,1.3);max-width:300px;z-index:70}
.toast.show{transform:translateY(0)}
.toast .ic{width:32px;height:32px;border-radius:9px;background:var(--green);display:flex;align-items:center;justify-content:center;flex:none}
.loading{text-align:center;color:var(--ink-soft);padding:50px}
/* ----- Módulo Sala / mesas (restaurante) ----- */
.sala-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:14px}
.sala-bar .btn{padding:11px 18px;font-size:.95rem}
.sala-hint{font-size:.82rem;color:var(--ink-soft)}
.sala-foot{text-align:center;color:var(--ink-soft);font-size:.8rem;margin:12px 0 0}
.sala-day{display:inline-flex;align-items:center;gap:6px}
.sala-day button{width:34px;height:34px;border:1px solid var(--line);background:#fff;color:var(--green-d);font-weight:800;border-radius:9px;cursor:pointer}
.sala-day button:hover{background:var(--mint)}
.sala-hourlbl{font-weight:800;color:var(--ink);margin-left:6px}
/* línea de tiempo vertical (izquierda de la sala) */
.sala-stage{display:flex;gap:10px;align-items:stretch}
.sala-stage .floor{flex:1;width:auto;min-width:0}
.sala-timeline{flex:none;width:74px;position:relative;user-select:none}
.tl-track{position:relative;height:100%;min-height:280px;cursor:ns-resize;touch-action:none;padding:6px 0}
.tl-track::before{content:'';position:absolute;left:50px;top:6px;bottom:6px;width:3px;border-radius:3px;background:#E2EAE6}
.tl-fill{position:absolute;left:50px;top:6px;width:3px;border-radius:3px;background:linear-gradient(var(--green-bright,#34D3A0),var(--green));pointer-events:none;box-shadow:0 0 8px rgba(18,184,134,.4)}
.tl-mark{position:absolute;left:0;transform:translateY(-50%);display:flex;align-items:center;gap:6px;font-size:.6rem;color:var(--ink-soft);pointer-events:none}
.tl-mark span{width:40px;text-align:right;font-weight:700;font-variant-numeric:tabular-nums}
.tl-mark::after{content:'';width:7px;height:2px;border-radius:2px;background:#D6E0DB}
.tl-mark.half span{font-weight:500;font-size:.52rem;opacity:.55}
.tl-mark.half::after{opacity:.5}
.tl-handle{position:absolute;left:30px;transform:translateY(-50%);display:flex;align-items:center;gap:0;background:#fff;color:var(--green-ink);border:1.5px solid var(--green);border-radius:99px;padding:3px 10px;font-size:.62rem;font-weight:800;box-shadow:0 5px 14px -4px rgba(18,184,134,.55);white-space:nowrap;cursor:grab;z-index:4;font-variant-numeric:tabular-nums}
.tl-handle::before{content:'';position:absolute;left:-9px;top:50%;transform:translateY(-50%);width:13px;height:13px;border-radius:50%;background:var(--green);border:2.5px solid #fff;box-shadow:0 2px 6px rgba(18,184,134,.6)}
.tl-handle:active{cursor:grabbing}
@media(max-width:900px){.sala-timeline{width:66px}.tl-track::before,.tl-fill{left:44px}.tl-handle{left:26px}}
/* lista de reservas del día */
.resday{margin-top:14px;padding:14px 16px}
.resday-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px;flex-wrap:wrap}
.resday-head h3{font-size:.98rem;margin:0}
.resday-sum{font-size:.8rem;color:var(--ink-soft);font-weight:600}
.resday-empty{color:var(--ink-soft);font-size:.85rem;padding:8px 0}
.resday-item{display:flex;align-items:center;gap:12px;padding:9px 4px;border-bottom:1px solid var(--line);cursor:pointer}
.resday-item:last-child{border-bottom:none}
.resday-item:hover{background:var(--bg-soft)}
.resday-item .rd-hour{font-weight:800;color:var(--green-d);min-width:48px}
.resday-item .rd-info{flex:1;min-width:0;display:flex;flex-direction:column;line-height:1.22}
.resday-item .rd-info small{color:var(--ink-soft);font-size:.78rem}
.rd-st{font-size:.68rem;font-weight:800;border-radius:99px;padding:3px 9px;white-space:nowrap}
.rd-st.conf{background:var(--mint);color:var(--green-ink)}
.rd-st.pend{background:#FFF6E5;color:#8a6400}
.rd-st.done{background:#EAF3FF;color:var(--blue-d)}
.rd-st.no{background:#FDECEC;color:#9c2b2b}
.rd-acts{display:flex;gap:5px;flex:none}
.rd-acts button{width:30px;height:30px;border:none;border-radius:8px;cursor:pointer;font-weight:800;font-size:.82rem}
.rd-acts button:first-child{background:var(--mint);color:var(--green-d)}
.rd-acts button:last-child{background:#FDECEC;color:#c23b3f}
.floor{position:relative;width:100%;height:560px;background:#fff;background-image:radial-gradient(var(--line) 1px,transparent 1px);background-size:26px 26px;border:1px solid var(--line);border-radius:16px;overflow:hidden;touch-action:none}
.noselect,.noselect *{user-select:none!important;-webkit-user-select:none!important;-webkit-touch-callout:none!important}
/* ---- Mesas estilo madera con sillas ---- */
.mesa{position:absolute;min-width:48px;min-height:48px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:grab;user-select:none;font-weight:800;transition:box-shadow .15s ease,transform .12s ease,left .14s ease,top .14s ease}
.mesa.tbl{background:linear-gradient(160deg,#fff,#F4F8F6);border:1.5px solid var(--line);color:var(--ink);border-radius:14px;box-shadow:0 8px 20px -12px rgba(12,26,20,.3)}
.mesa.round{border-radius:50%}
.mesa.square{border-radius:14px}
.mesa:hover{box-shadow:0 12px 26px -12px rgba(12,26,20,.4)}
.mesa.dragging{opacity:.9;cursor:grabbing;z-index:30}
.mesa .m-top{display:flex;flex-direction:column;align-items:center;line-height:1.06;z-index:2}
.mesa .m-num{font-size:1.05rem;letter-spacing:-.01em}
.mesa .m-seats{font-size:.62rem;font-weight:600;color:var(--ink-soft)}
.mesa .m-who{font-size:.58rem;font-weight:700;max-width:92%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;z-index:2;margin-top:1px;color:var(--green-ink)}
/* estado: libre = blanco con borde verde; ocupada = mint rojizo suave + nombre */
.mesa.free{border-color:rgba(18,184,134,.5);box-shadow:0 0 0 1.5px rgba(18,184,134,.16),0 8px 20px -12px rgba(12,26,20,.3)}
.mesa.busy{background:linear-gradient(160deg,#FFF3F2,#FCE7E6);border-color:#EBA29E;color:#9c2b2b}
.mesa.busy .m-num,.mesa.busy .m-seats,.mesa.busy .m-who{color:#9c2b2b}
/* sillas: limpias, a juego con la app (no madera) */
.chairs{position:absolute;display:flex;z-index:0}
.chairs.top{top:-11px;left:9px;right:9px;height:7px;justify-content:space-around}
.chairs.bottom{bottom:-11px;left:9px;right:9px;height:7px;justify-content:space-around}
.chairs.left{left:-11px;top:9px;bottom:9px;width:7px;flex-direction:column;justify-content:space-around}
.chairs.right{right:-11px;top:9px;bottom:9px;width:7px;flex-direction:column;justify-content:space-around}
.chairs i{display:block;background:#CFE6DC;border:1px solid #B4D2C7}
.chairs.top i,.chairs.bottom i{width:16px;height:8px;border-radius:6px 6px 3px 3px}
.chairs.left i,.chairs.right i{width:8px;height:16px;border-radius:6px 3px 3px 6px}
.mesa.busy .chairs i{background:#F3D2D0;border-color:#E2ABA8}
.mesa.sel .chairs i,.mesa.grp .chairs i{background:#BDEAD7;border-color:#8FDcBE}
.mesa.joined{outline:3px dashed #F59F00;outline-offset:2px}
.mesa.fixed{cursor:default}
.mesa.fixed::after{content:'🔒';position:absolute;top:-6px;right:-6px;font-size:.7rem;background:#fff;border-radius:50%;padding:1px 2px;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.mesa.movable-on{cursor:grab}
.floor-empty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);font-size:.9rem;text-align:center;padding:20px;pointer-events:none}
.sala-modes{display:inline-flex;gap:4px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:4px;margin-bottom:14px}
.sala-modes button{border:none;background:transparent;color:var(--ink-soft);font-weight:700;font-size:.9rem;padding:9px 16px;border-radius:9px;cursor:pointer}
.sala-modes button.on{background:var(--green);color:#fff}
.sala-time{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.sala-time input[type=date]{padding:9px 10px}
.sala-hour{display:flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--line);border-radius:11px;padding:4px}
.sala-hour button{width:32px;height:32px;border:none;background:var(--mint);color:var(--green-d);font-weight:800;border-radius:8px;cursor:pointer}
.sala-hour .h{min-width:64px;text-align:center;font-weight:800}
.sala-leg{display:flex;gap:12px;font-size:.74rem;color:var(--ink-soft);align-items:center}
.sala-leg i{display:inline-block;width:11px;height:11px;border-radius:3px;margin-right:4px;vertical-align:-1px}
.mesa.sel{border-color:var(--green-d);box-shadow:0 0 0 3px rgba(18,184,134,.5),0 10px 22px -8px rgba(74,46,18,.5);z-index:6}
.mesa.bookmode{cursor:pointer}
/* contenedor visual de mesas unidas */
.mesa-group{position:absolute;border-radius:18px;z-index:2;pointer-events:none}
.mesa-group.sel-group{background:rgba(18,184,134,.16);border:2.5px solid var(--green-d);box-shadow:0 10px 26px -10px rgba(18,184,134,.65)}
.mesa-group.busy-group{background:rgba(229,115,111,.14);border:2px dashed #E5736F}
.mesa-group .grp-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);color:#fff;font-weight:800;font-size:.78rem;border-radius:99px;padding:3px 12px;white-space:nowrap}
.mesa-group.sel-group .grp-badge{background:var(--green-d);box-shadow:0 6px 14px -6px rgba(18,184,134,.9)}
.mesa-group.busy-group .grp-badge{background:#c23b3f}
/* mesas unidas: mantienen la madera pero con aro verde marcado y número subrayado */
.mesa.grp{border:2.5px solid var(--green-d);box-shadow:0 0 0 4px rgba(18,184,134,.55),0 10px 22px -8px rgba(74,46,18,.5);z-index:6}
.mesa.grp .m-num{text-decoration:underline;text-decoration-thickness:2px}
.stchips-4 button{font-size:.8rem;padding:9px 6px}
.mesa .m-who{font-size:.58rem;font-weight:700;max-width:90%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sala-join{position:sticky;bottom:10px;background:#0C1A14;color:#fff;border-radius:14px;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;box-shadow:0 16px 40px -16px rgba(0,0,0,.5);margin-top:12px}
.sala-join .cap{font-weight:800}
.sala-join .cap small{font-weight:500;color:#9DB4AB}
.sala-join .btn{padding:10px 16px}
/* ----- Login / registro ----- */
.acct{font-size:.85rem;color:var(--ink-soft);font-weight:600;margin-right:10px}
.authwrap{min-height:calc(100vh - 120px);display:flex;align-items:center;justify-content:center;padding:30px 18px}
.authcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px 28px;width:100%;max-width:400px;box-shadow:var(--sh-pop)}
.authlogo{display:flex;align-items:center;gap:8px;font-weight:800;font-size:1.15rem;justify-content:center;margin-bottom:18px}
.authlogo .mk{width:30px;height:30px;border-radius:9px;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900}
.authcard h1{font-size:1.4rem;text-align:center;margin:0 0 4px;letter-spacing:-.02em}
.authsub{text-align:center;color:var(--ink-soft);font-size:.9rem;margin:0 0 20px}
.authcard label{display:block;font-size:.82rem;font-weight:600;color:var(--ink-soft);margin:12px 0 5px}
.authcard input{width:100%}
.autherr{background:#FDECEC;color:#9c2b2b;border:1px solid #F3B6B6;border-radius:10px;padding:10px 12px;font-size:.85rem;margin-bottom:6px}
.authswitch{text-align:center;font-size:.88rem;color:var(--ink-soft);margin:16px 0 0}
.authswitch a{color:var(--green-d);font-weight:700;cursor:pointer}
.authswitch a:hover{text-decoration:underline}
/* ----- Ajustes ----- */
.ajwrap{display:flex;flex-direction:column;gap:16px}
.aj-card h2{font-size:1.05rem;margin:0 0 14px;display:flex;align-items:center;gap:8px}
.aj-help{font-size:.76rem;color:var(--ink-soft);margin:4px 0 0}
.opt{color:var(--ink-soft);font-weight:500;font-size:.8rem}
.daysel{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.daysel label{display:flex;flex-direction:column;align-items:center;gap:4px;border:1.5px solid var(--line);border-radius:10px;padding:8px 0;font-size:.78rem;font-weight:700;color:var(--ink-soft);cursor:pointer}
.daysel label.on{border-color:var(--green);background:var(--mint);color:var(--green-ink)}
.daysel input{display:none}
.staff-card{border:1px solid var(--line);border-radius:12px;padding:10px;margin-bottom:10px;background:#fff}
.staff-head{display:flex;gap:8px;align-items:center}
.staff-head .st-name{flex:1}
.st-cfg-btn{flex:none;background:var(--mint);border:1px solid rgba(18,184,134,.3);color:var(--green-d);border-radius:9px;width:40px;height:40px;cursor:pointer;font-size:1rem}
.st-cfg-btn:hover{background:var(--green);color:#fff}
.staff-cfg{margin-top:12px;padding-top:12px;border-top:1px dashed var(--line)}
.st-svcs{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.chk-mini{display:inline-flex;align-items:center;gap:5px;font-size:.84rem;font-weight:600;color:var(--ink-soft);background:var(--bg-soft);border:1px solid var(--line);border-radius:8px;padding:5px 10px;cursor:pointer}
.chk-mini input{width:auto;margin:0}
.st-hours{margin-top:10px}
.block-row{display:grid;grid-template-columns:1.1fr 1.1fr .8fr .8fr 1.4fr auto;gap:6px;align-items:center;margin-bottom:8px}
.block-row select,.block-row input{padding:8px;font-size:.84rem}
.block-row .del{flex:none}
@media(max-width:720px){.block-row{grid-template-columns:1fr 1fr;gap:6px}}
.daysel-ob{max-width:380px;margin:8px auto 0}
.daysel-ob label{padding:14px 0;font-size:.9rem}
.afinar{background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;padding:16px 18px;margin:18px 0;text-align:left}
.afinar b{color:var(--green-ink)}
.afinar p{margin:6px 0 0;font-size:.85rem;color:var(--ink-soft)}
/* ----- Estados de cita (modal) ----- */
.stchips{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:4px 0 6px}
.stchips button{border:1.5px solid var(--line);background:#fff;border-radius:10px;padding:10px 8px;font-size:.82rem;font-weight:600;cursor:pointer;color:var(--ink-soft);transition:.12s}
.stchips button:hover{border-color:var(--green)}
.stchips button.on{border-color:var(--green);background:var(--mint);color:var(--green-ink)}
.stchips button.on[data-st="pendiente"]{background:#FFF6E5;border-color:#F4D58A;color:#8a6400}
.stchips button.on[data-st="confirmada"]{background:var(--mint);border-color:var(--green);color:var(--green-ink)}
.stchips button.on[data-st="completada"]{background:#EFF1F0;border-color:#aeb8b3;color:#56625c}
.stchips button.on[data-st="no_show"]{background:#FDECEC;border-color:#F3B6B6;color:#9c2b2b}
/* ----- Bandeja "Por revisar" (no-shows) ----- */
.review{border-color:rgba(255,90,95,.4)!important}
.review h3{color:#c23b3f!important}
.rev-sec{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-soft);margin:10px 0 6px}
.rev-item{display:flex;gap:9px;align-items:center;padding:8px 0;border-bottom:1px solid var(--line)}
.rev-item:last-child{border-bottom:none}
.rev-item .av{width:30px;height:30px;border-radius:50%;background:var(--mint);color:var(--green-d);font-weight:800;font-size:.72rem;display:flex;align-items:center;justify-content:center;flex:none}
.rev-item .info{flex:1;min-width:0}
.rev-item .nm{font-weight:700;font-size:.84rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rev-item .mt{font-size:.72rem;color:var(--ink-soft)}
.rev-acts{display:flex;gap:5px;flex:none}
.rev-b{border:none;border-radius:8px;width:30px;height:30px;cursor:pointer;font-size:.82rem;font-weight:800}
.rev-b.yes{background:var(--mint);color:var(--green-d)}.rev-b.yes:hover{background:var(--green);color:#fff}
.rev-b.no{background:#FDECEC;color:#c23b3f}.rev-b.no:hover{background:#c23b3f;color:#fff}
.rev-b.ok{background:#EAF3FF;color:var(--blue-d);width:auto;padding:0 10px;font-size:.76rem}.rev-b.ok:hover{background:var(--blue-d);color:#fff}
.rev-empty{font-size:.82rem;color:var(--ink-soft);padding:4px 0}
/* ----- Bandeja de conversaciones ----- */
.conv-layout{display:grid;grid-template-columns:340px 1fr;gap:18px;align-items:start}
.conv-list{padding:0;overflow:hidden;max-height:72vh;display:flex;flex-direction:column}
.conv-search{padding:12px;border-bottom:1px solid var(--line)}
.conv-search input{width:100%}
#convItems{overflow-y:auto}
.conv-item{display:flex;gap:11px;align-items:center;padding:12px 14px;border-bottom:1px solid var(--line);cursor:pointer}
.conv-item:hover{background:var(--bg-soft)}
.conv-item.on{background:var(--mint)}
.conv-item .av{width:40px;height:40px;border-radius:50%;background:var(--green);color:#fff;font-weight:800;font-size:.85rem;display:flex;align-items:center;justify-content:center;flex:none}
.conv-item .mid{flex:1;min-width:0}
.conv-item .nm{font-weight:700;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.conv-item .last{font-size:.78rem;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.conv-item .last .who{font-weight:700;color:var(--green-d)}
.conv-item .meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex:none}
.conv-item .tm{font-size:.68rem;color:var(--ink-soft)}
.conv-item .badge{background:var(--green);color:#fff;font-size:.66rem;font-weight:800;border-radius:99px;min-width:18px;height:18px;padding:0 5px;display:flex;align-items:center;justify-content:center}
.conv-empty-list{padding:30px 16px;text-align:center;color:var(--ink-soft);font-size:.85rem}
.conv-thread{padding:0;min-height:420px;max-height:72vh;display:flex;flex-direction:column}
.conv-empty{margin:auto;text-align:center;color:var(--ink-soft);padding:40px;max-width:320px}
.conv-empty .big{font-size:2.4rem;margin-bottom:10px}
.conv-thread-head{display:flex;gap:12px;align-items:center;padding:14px 18px;border-bottom:1px solid var(--line)}
.conv-thread-head .av{width:42px;height:42px;border-radius:50%;background:var(--green);color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;flex:none}
.conv-thread-head .nm{font-weight:800}
.conv-thread-head .ph{font-size:.8rem;color:var(--ink-soft)}
.conv-msgs{flex:1;overflow-y:auto;padding:18px;background:var(--bg-soft);display:flex;flex-direction:column;gap:9px}
.cm{max-width:78%;padding:9px 13px;border-radius:14px;font-size:.88rem;line-height:1.35;white-space:pre-wrap;word-break:break-word}
.cm.client{align-self:flex-start;background:#fff;border:1px solid var(--line);border-bottom-left-radius:5px}
.cm.assistant{align-self:flex-end;background:var(--green);color:#fff;border-bottom-right-radius:5px}
.cm .cm-ts{display:block;font-size:.64rem;opacity:.6;margin-top:3px}
.cm.assistant .cm-ts{color:#eafff7}
.cm-day{align-self:center;background:rgba(12,26,20,.08);color:var(--ink-soft);font-size:.7rem;font-weight:700;border-radius:99px;padding:3px 11px;margin:4px 0}
@media(max-width:900px){.conv-layout{grid-template-columns:1fr}.conv-list{max-height:none}}
.res-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.res-kpi{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:18px}
.res-kpi.hero{background:linear-gradient(135deg,var(--green),var(--green-d));border:none;color:#fff;box-shadow:0 12px 30px -18px rgba(14,158,116,.5)}
.res-kpi .n{font-size:1.9rem;font-weight:900;letter-spacing:-.03em;line-height:1;font-variant-numeric:tabular-nums}
.res-kpi .l{font-size:.78rem;color:var(--ink-soft);font-weight:600;margin-top:7px}
.res-kpi.hero .l{color:rgba(255,255,255,.85)}
.res-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.res-line{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--line);font-size:.9rem}
.res-line:last-child{border-bottom:none}
.res-line b{color:var(--green-ink);font-weight:800}
.res-note{color:var(--ink-soft);font-size:.78rem;margin-top:18px;text-align:center}
.res-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;gap:16px;flex-wrap:wrap}
.res-head h1{font-size:1.5rem;letter-spacing:-.02em;margin:0 0 4px}.res-head p{color:var(--ink-soft);margin:0;font-size:.9rem}
.res-nav{display:flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:4px}
.res-nav button{width:34px;height:34px;border-radius:9px;border:none;background:var(--mint);color:var(--green-d);font-weight:800;cursor:pointer;font-size:.85rem}
.res-nav button:hover:not(:disabled){background:var(--green);color:#fff}
.res-nav button:disabled{opacity:.35;cursor:not-allowed}
.res-month{min-width:128px;text-align:center;font-weight:800;font-size:.92rem;text-transform:capitalize}
.res-empty{color:var(--ink-soft);font-size:.85rem;padding:6px 0}
.res-bar{height:6px;border-radius:99px;background:var(--mint);overflow:hidden;margin-top:4px}
.res-bar span{display:block;height:100%;background:var(--green)}
.res-rank{display:flex;justify-content:space-between;font-size:.88rem;margin-bottom:2px}.res-rank b{color:var(--green-ink)}
.res-rank-row{padding:7px 0;border-bottom:1px solid var(--line)}.res-rank-row:last-child{border-bottom:none}
@media(max-width:900px){.res-kpis{grid-template-columns:1fr 1fr}.res-cols{grid-template-columns:1fr}}
/* ===== Panel operativo "Cómo va tu negocio" ===== */
.res-kpis{grid-template-columns:repeat(3,1fr)}
.rk-top{display:flex;align-items:baseline;justify-content:space-between;gap:8px}
.rk-n{font-size:1.9rem;font-weight:900;letter-spacing:-.03em;line-height:1;font-variant-numeric:tabular-nums}
.rk-l{font-size:.78rem;color:var(--ink-soft);font-weight:600;margin-top:7px}
.res-kpi.hero .rk-l{color:rgba(255,255,255,.85)}.res-kpi.hero .rk-n{color:#fff}
.kd{font-size:.7rem;font-weight:800;padding:2px 7px;border-radius:99px;white-space:nowrap}
.kdup{background:#E7F7F0;color:#0A7553}.kddn{background:#FBEBE9;color:#C4574A}.kd0{background:var(--bg-soft);color:var(--ink-soft)}
.res-kpi.hero .kd{background:rgba(255,255,255,.22);color:#fff}
.res-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.res-periodsel{display:flex;gap:3px;background:#E6F1EB;padding:4px;border-radius:99px}
.res-periodsel button{border:none;background:transparent;color:var(--ink-soft);font-weight:700;font-size:.82rem;padding:7px 14px;border-radius:99px;cursor:pointer;transition:.15s}
.res-periodsel button.on{background:#fff;color:var(--green-ink);box-shadow:0 1px 3px rgba(12,26,20,.1)}
.res-grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
@media(max-width:820px){.res-grid2{grid-template-columns:1fr}.res-kpis{grid-template-columns:1fr 1fr}}
.sbox-sub{font-weight:600;font-size:.62rem;color:var(--ink-soft);text-transform:none;letter-spacing:0}
.res-bars{display:flex;align-items:flex-end;gap:10px;height:130px;padding-top:8px}
.res-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}
.res-bar-v{width:100%;max-width:40px;background:linear-gradient(180deg,#1ECB9A,#0E9E74);border-radius:6px 6px 0 0;min-height:3px;transition:height .3s}
.res-bar-col span{font-size:.68rem;color:var(--ink-soft);font-weight:600}
.bar-blue{background:var(--blue-d) !important}
.res-list-row{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--r-xs);cursor:pointer;transition:background .12s}
.res-list-row:hover{background:var(--bg-soft)}
.res-list-row span{font-size:.86rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.res-list-row small{font-size:.76rem;color:var(--ink-soft);white-space:nowrap;flex:none}
.res-list-foot{font-size:.84rem;color:var(--ink-soft);padding:10px 10px 2px;border-top:1px solid var(--line);margin-top:6px}
.res-loalai{position:relative;overflow:hidden;display:flex;align-items:center;gap:16px;padding:20px 24px;background:linear-gradient(135deg,#0E443A,#0A2A22 70%);color:#EAF6F0;border:none;border-radius:18px;margin-bottom:16px;box-shadow:0 22px 50px -28px rgba(8,36,29,.85)}
.res-loalai::before{content:'';position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--au-grad);background-size:100% 320%;animation:auFlow 9s linear infinite}
.res-loalai::after{content:'';position:absolute;right:-90px;top:-130px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(54,200,194,.28),transparent 68%);pointer-events:none}
.res-loalai b{color:#9AD15A;font-weight:800}
.res-loalai-ic{position:relative;z-index:1;width:48px;height:48px;border-radius:14px;background:var(--au-grad);background-size:320% 100%;color:#06231C;display:flex;align-items:center;justify-content:center;flex:none;box-shadow:0 10px 22px -8px rgba(25,166,176,.85)}
.res-loalai-txt{position:relative;z-index:1;color:#EAF6F0}
.res-loalai-eye{font-size:.66rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#8FE6CE;margin-bottom:3px}
.res-loalai-main{font-size:1.12rem;font-weight:700;color:#fff;line-height:1.3}
.res-loalai-main b{color:#9AD15A;font-weight:900}
.res-loalai-sub{font-size:.82rem;font-weight:600;color:#9FCFC0;margin-top:3px}
/* gana al mixin de vidrio (.card{background:var(--glass)!important}) para que el footer sea OSCURO de verdad */
#resLoalai.res-loalai{background:linear-gradient(135deg,#0E443A,#0A2A22 70%) !important;border:none !important;box-shadow:0 22px 50px -28px rgba(8,36,29,.85) !important;-webkit-backdrop-filter:none !important;backdrop-filter:none !important}
.res-title{position:relative;padding-left:16px}
.res-title::before{content:'';position:absolute;left:0;top:5px;bottom:7px;width:4px;border-radius:4px;background:linear-gradient(180deg,#1ECB9A,#0E9E74)}
.res-head h1{font-size:1.9rem}
.res-charts{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:16px}
.sbox-wide{grid-column:span 2}
@media(max-width:900px){.res-charts{grid-template-columns:1fr}.sbox-wide{grid-column:auto}}
.sbox{padding:18px 20px;border-radius:16px}
.sbox-h{display:flex;align-items:center;gap:11px;margin-bottom:14px}
.sbox-h h3{font-size:1rem;font-weight:700;letter-spacing:-.01em;color:var(--ink);margin:0;text-transform:none}
.sbox-h .sbox-sub{display:block;font-size:.74rem;color:var(--ink-soft);font-weight:500;margin-top:1px;text-transform:none;letter-spacing:0}
.sbox-ic{width:36px;height:36px;border-radius:11px;background:linear-gradient(160deg,#EAF8F1,#D7F0E4);display:flex;align-items:center;justify-content:center;font-size:1.05rem;flex:none}
.chart-box{position:relative;height:200px}
.chart-tall{height:244px}
.res-list{display:flex;flex-direction:column;gap:2px}
.res-actions{display:flex;gap:8px;flex:none}
.res-filterbar{padding:14px 16px;margin-bottom:16px}
.res-presets{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.res-presets button{border:1px solid var(--line);background:#fff;color:var(--ink-soft);font-weight:600;font-size:.8rem;padding:7px 13px;border-radius:99px;cursor:pointer;transition:.15s}
.res-presets button:hover{border-color:var(--green);color:var(--green-ink)}
.res-presets button.on{background:linear-gradient(180deg,#1ECB9A,#0E9E74);color:#fff;border-color:transparent;box-shadow:0 4px 12px -6px rgba(14,158,116,.6)}
.res-daterange{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap;margin-bottom:10px;padding:10px 0;border-top:1px solid var(--line)}
.res-daterange label{font-size:.78rem;font-weight:600;display:flex;flex-direction:column;gap:4px;margin:0}
.res-daterange input{padding:8px 10px;width:auto}
.res-filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.res-filters select{width:auto;min-width:128px;padding:8px 12px;font-size:.82rem;border-radius:99px;background:var(--bg-soft);border-color:transparent}
.res-clear{border:1px solid var(--line);background:#fff;color:#C4574A;font-size:.8rem;font-weight:600;padding:7px 13px;border-radius:99px;cursor:pointer}
.res-clear:hover{background:#FBEBE9}
.res-rangelbl{font-size:.8rem;color:var(--ink-soft);margin-left:auto;white-space:nowrap}
.res-spansel{margin-left:auto;display:flex;gap:2px;background:var(--bg-soft);padding:3px;border-radius:99px;flex:none}
.res-spansel button{border:none;background:transparent;color:var(--ink-soft);font-weight:700;font-size:.72rem;padding:5px 11px;border-radius:99px;cursor:pointer;transition:.12s}
.res-spansel button.on{background:#fff;color:var(--green-ink);box-shadow:0 1px 2px rgba(12,26,20,.12)}
.res-charts3{grid-template-columns:repeat(3,1fr)}
.res-charts2{grid-template-columns:1fr 1fr}
@media(max-width:900px){.res-charts3,.res-charts2{grid-template-columns:1fr}}
.heat-grid{display:grid;gap:3px;align-items:center}
.heat-hl{text-align:center;font-size:.6rem;color:var(--ink-soft);font-weight:600}
.heat-dl{font-size:.72rem;color:var(--ink-soft);font-weight:600}
.heat-c{height:26px;border-radius:5px;transition:transform .1s}
.heat-c:hover{transform:scale(1.14);outline:2px solid var(--green);position:relative;z-index:2}
.sbox-h .res-search{margin-left:auto;width:240px;max-width:46%;padding:9px 13px;font-size:.85rem;border-radius:99px}
.res-table-wrap{overflow-x:auto;margin-top:2px}
.res-table{width:100%;border-collapse:collapse;font-size:.85rem}
.res-table th{text-align:left;padding:9px 10px;color:var(--ink-soft);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--line);cursor:pointer;white-space:nowrap;user-select:none}
.res-table th:hover,.res-table th.th-on{color:var(--green-ink)}
.res-table td{padding:9px 10px;border-bottom:1px solid var(--bg-soft);white-space:nowrap}
.res-table tbody tr{cursor:pointer;transition:background .1s}
.res-table tbody tr:hover{background:var(--bg-soft)}
.res-table tfoot td{color:var(--ink-soft);font-size:.78rem;text-align:center;border:none;padding-top:10px;white-space:normal}
.pac-hist-st.st-pendiente{background:var(--blue);color:var(--blue-d)}
@media print{.top{display:none!important}body{display:block!important;background:#fff!important}.res-actions,.res-filterbar,.res-loalai,.subtabs,.bizswitch,.res-search,.rep-tabs,#rep-contestar,.rep-pager,.rep-tip,.res-spansel{display:none!important}.subview{display:block!important}.wrap{max-width:none;padding:0}.card{break-inside:avoid;box-shadow:none}}
.rev-hl{box-shadow:0 0 0 3px rgba(18,184,134,.55)!important;transition:box-shadow .3s}
@media(max-width:900px){.callayout{grid-template-columns:1fr}.cal{grid-template-columns:42px repeat(7,minmax(76px,1fr));overflow-x:auto}.subtabs button{padding:8px 9px;font-size:.82rem}.bizswitch select{max-width:120px}}


/* ===== REDISENO (Claude Design) - capas overlay lx-* ===== */

html{background:#0C1A14;overflow-y:scroll;scrollbar-gutter:stable}
#lx-intro{position:fixed;inset:0;z-index:99999;background:linear-gradient(157deg,#10433A,#0A2A22 64%,#072019);display:flex;align-items:center;justify-content:center;overflow:hidden;opacity:1;visibility:visible;animation:lxFade .55s ease 2.55s forwards}
#lx-intro .grid{position:absolute;inset:0;background:radial-gradient(circle at 30% 38%,rgba(54,200,194,.20),transparent 52%),radial-gradient(circle at 74% 66%,rgba(154,209,90,.15),transparent 52%),radial-gradient(circle at 52% 88%,rgba(95,182,222,.14),transparent 50%);opacity:0;animation:lxGridIn .6s ease both}
#lx-intro .stage{position:relative;display:flex;align-items:center;gap:clamp(12px,2.4vw,24px);z-index:2;animation:lxMarkPop .42s cubic-bezier(.2,1.4,.4,1) .82s both}
#lx-intro svg.mark{width:clamp(74px,11vw,124px);height:auto;overflow:visible;animation:lxMarkGlow 1.3s ease .85s forwards}
#lx-intro svg.mark path{fill:none;stroke:#fff;stroke-width:2.1;stroke-linecap:round;stroke-linejoin:round}
#lx-intro svg.mark .bk{stroke-dasharray:100;stroke-dashoffset:100;animation:lxDraw .8s cubic-bezier(.65,0,.35,1) .15s forwards}
#lx-intro svg.mark .hd{stroke-dasharray:100;stroke-dashoffset:100;animation:lxDraw .42s cubic-bezier(.65,0,.35,1) .82s forwards}
#lx-intro .word{font-family:Inter,system-ui,sans-serif;font-weight:800;letter-spacing:-.045em;font-size:clamp(2.3rem,6.5vw,4rem);color:#fff;opacity:0;animation:lxWord .7s cubic-bezier(.2,.7,.2,1) 1.02s forwards}
#lx-intro .word b{color:#9AD15A;font-weight:800}
#lx-intro .tag{position:absolute;left:50%;top:calc(50% + clamp(58px,8vw,86px));transform:translateX(-50%);font-family:Inter,system-ui,sans-serif;font-weight:700;font-size:clamp(.8rem,1.5vw,1rem);color:#fff;text-shadow:0 1px 10px rgba(8,20,15,.45),0 0 1px rgba(8,20,15,.3);white-space:nowrap;opacity:0;z-index:4;animation:lxTag .6s ease 1.45s forwards}
#lx-intro .flood{position:absolute;left:50%;top:50%;width:44px;height:44px;border-radius:50%;background:radial-gradient(circle,#9AD15A,#36C8C2 42%,#16C2B0 74%);transform:translate(-50%,-50%) scale(0);z-index:1;animation:lxFlood 1.05s cubic-bezier(.7,0,.25,1) 1.55s forwards}
#lx-intro .shot{position:absolute;left:calc(50% - 30px);top:50%;width:140px;height:3px;border-radius:3px;background:linear-gradient(90deg,transparent,#EAFFF7);opacity:0;z-index:3;filter:drop-shadow(0 0 8px rgba(54,200,194,.95));animation:lxShot .55s ease 1.95s both}
#lx-intro .skipbtn{position:absolute;right:20px;bottom:18px;z-index:5;color:rgba(255,255,255,.55);font:600 .82rem Inter,system-ui,sans-serif;background:transparent;border:0;cursor:pointer;letter-spacing:.02em}
#lx-intro .skipbtn:hover{color:#fff}
@keyframes lxDraw{to{stroke-dashoffset:0}}
@keyframes lxWord{from{opacity:0;transform:translateX(-16px)}to{opacity:1;transform:none}}
@keyframes lxTag{from{opacity:0;transform:translate(-50%,6px)}to{opacity:1;transform:translate(-50%,0)}}
@keyframes lxMarkPop{0%{transform:scale(.88)}60%{transform:scale(1.06)}100%{transform:scale(1)}}
@keyframes lxMarkGlow{0%{filter:drop-shadow(0 0 0 rgba(127,227,192,0))}45%{filter:drop-shadow(0 0 26px rgba(127,227,192,.9))}100%{filter:drop-shadow(0 0 12px rgba(127,227,192,.45))}}
@keyframes lxGridIn{to{opacity:1}}
@keyframes lxFlood{to{transform:translate(-50%,-50%) scale(62)}}
@keyframes lxShot{0%{opacity:0;transform:translate(-12%,-50%) scaleX(.3)}28%{opacity:1}100%{opacity:0;transform:translate(880%,-50%) scaleX(1)}}
@keyframes lxFade{from{opacity:1;visibility:visible}to{opacity:0;visibility:hidden}}
#lx-intro.lx-skip{display:none}

@media (prefers-reduced-motion: no-preference){
  .view.on{animation:lxViewIn .55s cubic-bezier(.2,.7,.2,1) both}
  .subview{animation:lxSubIn .42s cubic-bezier(.2,.7,.2,1) both}
  .biz-card{animation:lxPop .55s cubic-bezier(.2,.8,.25,1.02) both}
  .biz-card:nth-child(1){animation-delay:.04s}
  .biz-card:nth-child(2){animation-delay:.10s}
  .biz-card:nth-child(3){animation-delay:.16s}
  .biz-card:nth-child(4){animation-delay:.22s}
  .biz-card:nth-child(5){animation-delay:.28s}
  .biz-card:nth-child(6){animation-delay:.34s}
  .top .mk{transition:transform .35s cubic-bezier(.2,1.4,.4,1)}
  .top .mk:hover{transform:rotate(-8deg) scale(1.08)}
}
@keyframes lxViewIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes lxSubIn{from{opacity:0;transform:translateY(7px)}to{opacity:1;transform:none}}
@keyframes lxPop{from{opacity:0;transform:translateY(15px) scale(.97)}to{opacity:1;transform:none}}

:root{
  --green:#12B886;--green-d:#0E9E74;--green-ink:#0A7553;--mint:#E8F7F0;
  --ink:#0B1A13;--ink-soft:#5A6E65;--line:#E5ECE8;
  --r:18px;--r-sm:12px;--r-xs:9px;
  --sh:0 1px 2px rgba(12,26,20,.05),0 14px 32px -24px rgba(12,26,20,.30);
  --sh-pop:0 18px 48px -22px rgba(12,26,20,.30);
  --side1:#0C1B15;--side2:#091310;
}
body{background:#ECF2EE;background-image:radial-gradient(1200px 600px at 78% -8%,rgba(18,184,134,.06),transparent 60%);}
h1,h2,h3{letter-spacing:-.02em}
.dash-head h1,.res-head h1,.cal-head h1,.pac-head h1{font-family:'Newsreader',Georgia,serif;font-weight:400;letter-spacing:-.005em}


.card{border-radius:var(--r);box-shadow:var(--sh);border-color:var(--line)}
.btn{border-radius:var(--r-sm);font-weight:650}
.btn-primary{background:linear-gradient(180deg,#1ECB9A,#0E9E74);box-shadow:0 1px 2px rgba(12,26,20,.07),0 12px 24px -14px rgba(14,158,116,.6)}
.btn-primary:hover{background:linear-gradient(180deg,#15BE8E,#0C9069)}
input,select,textarea{border-radius:var(--r-sm);border-color:#DFE8E3;padding:12px 14px}
input:focus,select:focus,textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(18,184,134,.15)}


.biz-card{border-radius:var(--r);padding:20px}
.biz-card:hover{transform:translateY(-3px);box-shadow:var(--sh-pop)}
.biz-card .ic{width:48px;height:48px;border-radius:14px;background:linear-gradient(160deg,#EAF8F1,#D7F0E4)}
.biz-card .meta b{color:var(--ink)}
.add-card{border-radius:var(--r);border-color:rgba(18,184,134,.45)}


.phone{border-radius:24px;box-shadow:var(--sh-pop)}
.chead{padding:15px 18px}
.b.me{background:linear-gradient(180deg,#16C194,#0E9E74)}
.cfoot button{background:linear-gradient(180deg,#16C194,#0E9E74)}


.res-kpi{border-radius:var(--r);padding:20px}
.res-kpi.hero{background:linear-gradient(140deg,#13B98A,#0C8E66);box-shadow:0 20px 44px -24px rgba(14,158,116,.65)}
.res-kpi .n{font-size:2rem}


.conv-item .av,.conv-thread-head .av{background:linear-gradient(160deg,#16C194,#0C9069)}
.cm.assistant{background:linear-gradient(180deg,#16C194,#0E9E74)}


.aj-card{border-radius:var(--r)}
.aj-ic{background:linear-gradient(160deg,#EAF8F1,#D7F0E4)}


.toast{border-radius:16px}
.modal{border-radius:18px}


/* ---- Móvil: la barra superior scrollea DENTRO de sí misma; la página nunca se mueve en horizontal ---- */
@media(max-width:760px){
  html,body{ max-width:100%; overflow-x:hidden; }
  .top{ max-width:100%; overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .top::-webkit-scrollbar{ height:0; }
}

@media(min-width:761px){
  body{display:grid;grid-template-columns:256px 1fr;align-items:start;min-height:100vh}
  body{padding-bottom:0}

  .top{
    grid-column:1;grid-row:1;position:sticky;top:0;height:100vh;
    flex-direction:column;align-items:stretch;gap:3px;
    padding:20px 14px 16px;
    background:linear-gradient(180deg,#F7FBF9,#EFF5F1);
    border-right:1px solid #E1EAE5;color:var(--ink);
  }
  .top .brand{display:flex;align-items:center;gap:11px;padding:6px 8px 18px}
  .top .brand .mk{width:34px;height:34px;border-radius:10px;font-size:1.02rem;box-shadow:0 8px 18px -8px rgba(18,184,134,.55)}
  .top .brand b{font-size:1.22rem;letter-spacing:-.03em}

  .top .back{ text-align:left;border:none;background:transparent;color:#5A6E65;
    padding:10px 12px;border-radius:10px;font-size:.9rem;font-weight:600 }
  #backToDash{ margin-bottom:6px;border:1px solid var(--line);background:#fff }
  .top .back:hover{background:#E9F2ED;color:var(--ink)}

  .bizswitch{align-items:stretch;margin:2px 0 10px}
  .bizswitch select{width:100%;background:#fff;border:1px solid var(--line);border-radius:11px;padding:11px 12px;color:var(--ink)}

  .subtabs{flex-direction:column;gap:3px;align-items:stretch}
  .subtabs::before{content:"Tu negocio";display:block;font-size:.66rem;font-weight:800;
    letter-spacing:.12em;text-transform:uppercase;color:#90A39A;padding:4px 12px 8px}
  .subtabs button{display:flex;align-items:center;justify-content:flex-start;gap:12px;padding:11px 12px;border-radius:11px;
    font-size:.93rem;font-weight:600;color:#46584F;width:100%;text-align:left}
  .subtabs button svg{width:19px;height:19px;flex:none}
  .subtabs button:hover{background:#E9F2ED;color:var(--ink)}
  .subtabs button.on{background:linear-gradient(90deg,rgba(18,184,134,.15),rgba(18,184,134,.04));
    color:var(--green-ink);box-shadow:inset 2px 0 0 var(--green)}

  .top .sp{margin:auto 0 0}
  .top .env{align-self:flex-start;margin:8px 0 8px;color:#0A7553;border-color:#D7E4DD;background:#fff}
  .acct{margin:0;padding:8px 12px 2px;color:#46584F;font-weight:700;font-size:.86rem}
  #logoutBtn{text-align:left;display:block;margin-top:2px}

  
  .view{grid-column:2;grid-row:1}
  .view.on{grid-column:2;grid-row:1}
  .wrap{padding:34px 36px 72px}
  .wrapW{max-width:1180px}

  
  .dash-head{text-align:left;margin-bottom:26px}
  .dash-head h1{font-size:2.1rem;margin:0 0 6px}
  .dash-head p{font-size:1rem}
  .biz-grid{grid-template-columns:repeat(auto-fill,minmax(252px,1fr));gap:18px}
}


@media(min-width:1280px){
  .wrap{padding:40px 48px 80px}
}




body{background:#ECF2EE;background-image:
  radial-gradient(900px 520px at 84% -8%,rgba(18,184,134,.11),transparent 58%),
  radial-gradient(700px 480px at -8% 10%,rgba(18,184,134,.06),transparent 55%);
  background-attachment:fixed}


.brand{display:flex;align-items:center;gap:10px}
.brand .bx{display:flex;flex-direction:column;gap:2px;line-height:1.05}
.top .brand .mk{background:linear-gradient(150deg,#1ED39E,#0C9069)}
.top .brand .mk svg{width:18px;height:18px}
.brand .presence{display:flex;align-items:center;gap:6px;font-size:.66rem;font-weight:800;color:var(--green-ink);letter-spacing:.02em;white-space:nowrap}
.brand .presence i{width:7px;height:7px;border-radius:50%;background:#12B886;animation:lxPulse 2.2s infinite}
@keyframes lxPulse{0%{box-shadow:0 0 0 0 rgba(18,184,134,.55)}70%{box-shadow:0 0 0 7px rgba(18,184,134,0)}100%{box-shadow:0 0 0 0 rgba(18,184,134,0)}}


.side-sign{display:none}


.biz-card{position:relative;overflow:hidden}
.biz-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--green),rgba(18,184,134,0))}
.biz-card::after{content:'';position:absolute;right:-12px;bottom:-14px;width:104px;height:104px;opacity:.06;pointer-events:none;
  background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2312B886' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 5v10a4 4 0 0 0 4 4h10'/%3E%3Cpath d='M14 15l4 4-4 4'/%3E%3C/svg%3E")}
.biz-card.add-card::before,.biz-card.add-card::after{display:none}
.biz-card .ic{background:linear-gradient(150deg,#E9F8F1,#CBEEDD);box-shadow:inset 0 0 0 1px rgba(18,184,134,.18)}


.item .av,.rev-item .av{background:linear-gradient(150deg,#E9F8F1,#CBEEDD);color:var(--green-ink)}


.dash-head h1{font-size:2.25rem}

@media(min-width:761px){
  .dash-head{position:relative;padding-left:16px}
  .dash-head::before{content:'';position:absolute;left:0;top:5px;bottom:9px;width:3px;border-radius:3px;background:linear-gradient(180deg,var(--green),rgba(18,184,134,.18))}
  .subtabs button{transition:transform .16s ease,background .16s,color .16s}
  .subtabs button:hover{transform:translateX(3px)}
  .side-sign{display:flex;align-items:center;gap:8px;margin:14px 8px 2px;padding-top:14px;border-top:1px solid #E1EAE5;
    font-family:'Newsreader',Georgia,serif;font-style:italic;font-size:.83rem;color:#7C9A8C}
  .side-sign svg{width:15px;height:15px;flex:none;color:var(--green)}
}

@media(max-width:760px){
  .brand .presence{display:none}
  .top .brand .mk svg{width:15px;height:15px}
  .side-sign{display:none}
}


.floor{background:#E7EEE9;background-image:radial-gradient(#D2DED7 1.3px,transparent 1.3px);background-size:24px 24px;box-shadow:inset 0 0 80px rgba(12,26,20,.07)}
.mesa.tbl{background:#fff;border:none;color:#0B1A13;box-shadow:0 2px 4px rgba(12,26,20,.10),0 12px 22px -10px rgba(12,26,20,.34)}
.mesa.tbl .m-num{color:#0B1A13}
.mesa.tbl .m-seats{color:#8FA89B;font-weight:700;font-size:.6rem}
.mesa.free{border:none;box-shadow:0 2px 4px rgba(12,26,20,.10),0 12px 22px -10px rgba(12,26,20,.34)}
.mesa.busy{background:#E4F4ED;border:none;box-shadow:0 2px 4px rgba(14,158,116,.20),0 12px 22px -10px rgba(14,158,116,.45)}
.mesa.busy .m-num,.mesa.busy .m-seats,.mesa.busy .m-who{color:#0A7553}

.chairs{position:absolute;display:flex;align-items:center;justify-content:space-around;z-index:0}
.chairs.ch-top{top:-16px;left:6px;right:6px;height:14px}
.chairs.ch-bottom{bottom:-16px;left:6px;right:6px;height:14px}
.chairs.ch-left{left:-16px;top:6px;bottom:6px;width:14px;flex-direction:column}
.chairs.ch-right{right:-16px;top:6px;bottom:6px;width:14px;flex-direction:column}
.chairs.ch-top i,.chairs.ch-bottom i,.chairs.ch-left i,.chairs.ch-right i{position:relative;display:block;flex:0 0 auto;width:14px;height:14px;background:transparent;border:none;box-shadow:none}
.chairs i::before,.chairs i::after{content:"";position:absolute;width:14px;height:14px;border-radius:50%}
.chairs i::after{top:0;left:0;background:#E6EDE8}
.chairs i::before{background:#C9D7CF}
.chairs.ch-top i::before{top:-3.5px;left:0}
.chairs.ch-bottom i::before{top:3.5px;left:0}
.chairs.ch-left i::before{top:0;left:-3.5px}
.chairs.ch-right i::before{top:0;left:3.5px}
.mesa.busy .chairs i::after{background:#C7EAD8}
.mesa.busy .chairs i::before{background:#8FCBAF}

.mesa.sel{border-color:#0E9E74;box-shadow:0 0 0 3px rgba(18,184,134,.5),0 12px 24px -10px rgba(12,26,20,.4);z-index:6}
.mesa.grp{border-color:#0E9E74;box-shadow:0 0 0 4px rgba(18,184,134,.55),0 12px 24px -10px rgba(12,26,20,.4);z-index:6}


.sala-timeline{width:94px}
.tl-track{padding:0;min-height:300px}
.tl-track::before{left:54px;top:0;bottom:0;width:5px;border-radius:99px;background:#DCE6E0;box-shadow:none}
.tl-fill{left:54px;top:0;width:5px;border-radius:99px;background:linear-gradient(180deg,#34D3A0,#0E9E74);box-shadow:0 0 12px rgba(18,184,134,.5)}
.tl-mark{left:0;width:72px;transform:translateY(-50%);display:block}
.tl-mark span{position:absolute;left:0;top:50%;transform:translateY(-50%);width:42px;text-align:right;font-size:.66rem;font-weight:700;color:#7C9A8C;font-variant-numeric:tabular-nums;opacity:1}
.tl-mark::after{content:'';position:absolute;left:56.5px;top:50%;transform:translate(-50%,-50%);width:8px;height:8px;border-radius:50%;background:#fff;border:2px solid #C6D5CD}
.tl-mark.half span{display:none}
.tl-mark.half::after{width:4px;height:4px;border:none;background:#D3DFD8;opacity:1}
.tl-handle{left:56.5px;top:0;transform:translate(-50%,-50%);display:inline-flex;align-items:center;gap:0;background:linear-gradient(180deg,#18C796,#0E9E74);color:#fff;border:none;border-radius:99px;padding:5px 11px;font-weight:800;font-size:.72rem;box-shadow:0 7px 16px -5px rgba(14,158,116,.7),0 0 0 4px rgba(18,184,134,.16);cursor:grab;white-space:nowrap;z-index:6;font-variant-numeric:tabular-nums}
.tl-handle::before{display:none}
.tl-handle:active{cursor:grabbing;box-shadow:0 4px 10px -4px rgba(14,158,116,.7),0 0 0 5px rgba(18,184,134,.22)}
@media(max-width:900px){.sala-timeline{width:82px}.tl-track::before,.tl-fill{left:46px}.tl-mark::after,.tl-handle{left:48.5px}.tl-mark{width:64px}.tl-mark span{width:36px}}

.sala-timeline{width:104px}
.tl-wheel{position:relative;height:100%;min-height:300px;width:100%;overflow:hidden;cursor:grab;touch-action:none;user-select:none}
.tl-wheel:active{cursor:grabbing}
.tl-list{position:absolute;left:0;right:0;top:0;transition:transform .14s cubic-bezier(.2,.7,.2,1);will-change:transform}
.tl-item{position:relative;z-index:1;height:34px;display:flex;align-items:center;justify-content:center;font-size:.76rem;font-weight:600;color:#A9BFB5;font-variant-numeric:tabular-nums;transition:color .12s,font-size .12s}
.tl-item.whole{color:#7C9A8C;font-weight:700}
.tl-item.sel{color:#0A7553;font-weight:800;font-size:1.12rem}
.tl-lens{position:absolute;left:8px;right:8px;top:50%;transform:translateY(-50%);height:40px;border-radius:13px;background:#EAF6F0;border:1.5px solid #BFE3D2;box-shadow:0 6px 16px -8px rgba(14,158,116,.4);pointer-events:none;z-index:0}
.tl-fade{position:absolute;left:0;right:0;height:70px;pointer-events:none;z-index:2}
.tl-fade-top{top:0;background:linear-gradient(#ECF2EE,rgba(236,242,238,0))}
.tl-fade-bot{bottom:0;background:linear-gradient(rgba(236,242,238,0),#ECF2EE)}
@media(max-width:900px){.sala-timeline{width:88px}}

.tl-wheel{cursor:grab}
.tl-wheel:active{cursor:grabbing}
.tl-list{transition:none}
.tl-item{cursor:pointer;border-radius:10px;transition:color .12s,font-size .12s,background .12s}
.tl-item:hover:not(.sel){color:#0A7553;background:rgba(18,184,134,.07)}
.tl-nav{position:absolute;left:50%;transform:translateX(-50%);z-index:3;width:40px;height:22px;border:none;background:transparent;color:#A4BAB0;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}
.tl-nav:hover{color:#0E9E74}
.tl-up{top:0}
.tl-down{bottom:0}

.tl-mark.half span{display:none}
.tl-mark.half::after{width:6px;height:6px;border:2px solid #CBD9D1;background:#fff;opacity:1}
.tl-mark.q span{display:none}
.tl-mark.q::after{width:4px;height:4px;border:none;background:#D9E2DC;opacity:1}

/* ============================================================================
   ====  LIQUID GLASS · MENTA  — capa de tema (override, máxima prioridad)  ====
   Aplica el lenguaje "relieve menta + vidrio + degradado" a TODA la app.
   Reutiliza las clases existentes; no cambia el DOM ni la lógica.
   ============================================================================ */
:root{
  --glass: rgba(255,255,255,.55);
  --glass-soft: rgba(255,255,255,.4);
  --glass-strong: rgba(255,255,255,.7);
  --glass-border: rgba(255,255,255,.6);
  --glass-hi: inset 0 1px 0 rgba(255,255,255,.72);
  --glass-sh: 0 12px 32px -18px rgba(10,60,44,.35);
  --glass-blur: blur(20px) saturate(170%);
  --ink-glass: #16352A;
  --line: rgba(255,255,255,.5);   /* bordes claros sobre vidrio */
}

/* ---- fondo: malla menta suave, fija ---- */
body{
  background:
    radial-gradient(820px 640px at 8% 2%,#CFF1E2,transparent 62%),
    radial-gradient(880px 700px at 94% 6%,#BCEAD6,transparent 62%),
    radial-gradient(820px 720px at 82% 104%,#C3E6EF,transparent 62%),
    radial-gradient(760px 700px at -2% 102%,#DCECC6,transparent 62%),
    linear-gradient(152deg,#E2F2EB,#CBE4D9) !important;
  background-attachment: fixed !important;
  color: var(--ink-glass);
}

/* ---- superficie de vidrio (mixin aplicado a todas las tarjetas) ---- */
.card,.biz-card,.add-card,.mini-kpi,.sbox,.aj-card,.health-card,
.pac-side,.pac-main,.conv-list,.conv-thread,.phone,
#repDash .kpi,.kpi,.rep-card,.res-card,.modal,.cal-agenda .ag-card,.authcard{
  background: var(--glass) !important;
  -webkit-backdrop-filter: var(--glass-blur);
  backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border) !important;
  box-shadow: var(--glass-hi), var(--glass-sh) !important;
}
.card{ border-radius: var(--r-lg,18px); }

/* hover de tarjetas interactivas */
.biz-card:hover{ transform: translateY(-3px); border-color: rgba(18,184,134,.55) !important;
  box-shadow: var(--glass-hi), 0 20px 44px -18px rgba(10,60,44,.45) !important; }

/* el "add negocio" en vidrio punteado */
.add-card{ background: rgba(255,255,255,.32) !important; border:1.5px dashed rgba(18,184,134,.5) !important; }
.add-card:hover{ background: rgba(255,255,255,.5) !important; }

/* ---- barra lateral / top: vidrio CLARO (coherente, sin verde oscuro) ---- */
@media(min-width:761px){
  .top{
    background: linear-gradient(180deg, rgba(247,251,249,.82), rgba(232,243,237,.82)) !important;
    -webkit-backdrop-filter: blur(16px) saturate(150%);
    backdrop-filter: blur(16px) saturate(150%);
    border-right: 1px solid rgba(255,255,255,.75) !important;
    box-shadow: 1px 0 0 rgba(18,80,58,.04);
  }
}

/* ---- botones ---- */
.btn-primary{
  background: linear-gradient(180deg,#19C896,#0E9E74) !important;
  box-shadow: var(--glass-hi), 0 10px 22px -10px rgba(14,158,116,.6) !important;
}
.btn-ghost{
  background: rgba(255,255,255,.42) !important;
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  border: 1px solid var(--glass-border) !important; color: var(--green-ink) !important;
}
.btn-ghost:hover{ background: rgba(255,255,255,.7) !important; }

/* ---- inputs: SÓLIDOS y con borde claro para que se identifiquen bien ---- */
input,select,textarea{
  background-color: #fff !important;
  border: 1.5px solid rgba(13,79,58,.22) !important;
}
input::placeholder,textarea::placeholder{ color:#9DB4AB; opacity:1; }
input:hover:not(:focus),select:hover:not(:focus),textarea:hover:not(:focus){ border-color: rgba(13,79,58,.38) !important; }
input:focus,select:focus,textarea:focus{
  background-color: #fff !important;
  border-color: var(--green) !important; box-shadow: 0 0 0 3px rgba(18,184,134,.22) !important;
}

/* ---- Desplegables (select) con estética Loalai: chevron aurora propio, sin la flecha del sistema ---- */
select{
  -webkit-appearance:none; -moz-appearance:none; appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='14'%20height='14'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%230E9E70'%20stroke-width='3'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M6%209l6%206%206-6'/%3E%3C/svg%3E") !important;
  background-repeat:no-repeat !important;
  background-position:right 13px center !important;
  background-size:13px !important;
  padding-right:38px !important;
  cursor:pointer;
}
select::-ms-expand{ display:none; }
select:hover:not(:focus){ background-color:#FAFFFD !important; }

/* ---- titulares de sección en serif (eyebrow + título) ---- */
.dash-head h1,.res-title,.rep-title,.obstep .q,.pac-fhead h2{
  font-family:'Newsreader',Georgia,serif; font-weight:400; letter-spacing:-.01em;
}

/* ---- pastillas / eyebrows en vidrio ---- */
.cal-eyebrow,.health-todo,.obstep .ex{
  background: rgba(255,255,255,.5) !important;
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  border: 1px solid var(--glass-border);
}

/* ---- calendario: superficie y citas en vidrio tintado ---- */
.cal,.cal-month,.cal-dstaff{ background: transparent; }
.ch{ background: transparent; }
.cell{ border-color: rgba(255,255,255,.4) !important; }
.cell:hover{ background: rgba(255,255,255,.3) !important; }
.col-today,.ch.today{ background: rgba(255,255,255,.22) !important; }

.appt{
  -webkit-backdrop-filter: blur(8px) saturate(160%); backdrop-filter: blur(8px) saturate(160%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.55), 0 4px 12px -6px rgba(10,60,44,.4) !important;
}
.appt{ background: linear-gradient(135deg,rgba(18,184,134,.30),rgba(18,184,134,.14)) !important;
  border-left-color: var(--green) !important; }
.appt b{ color:#08402F !important; } .appt-meta,.appt .t{ color:#0A6B4E !important; }
.appt.bot{ background: linear-gradient(135deg,rgba(44,95,153,.30),rgba(44,95,153,.14)) !important; border-left-color:#2c5f99 !important; }
.appt.bot b{ color:#143456 !important; } .appt.bot .appt-meta,.appt.bot .t{ color:#2c5f99 !important; }
.appt.pend{ background: linear-gradient(135deg,rgba(240,180,41,.32),rgba(240,180,41,.14)) !important; border-left-color:#E1A53D !important; }
.appt.pend b{ color:#6B4E00 !important; } .appt.pend .appt-meta,.appt.pend .t{ color:#8A6400 !important; }
.appt.done{ background: linear-gradient(135deg,rgba(150,168,161,.3),rgba(150,168,161,.14)) !important; border-left-color:#9aa8a1 !important; }
.appt.no{ background: linear-gradient(135deg,rgba(224,86,86,.3),rgba(224,86,86,.14)) !important; border-left-color:#E05656 !important; }

/* día por empleados / agenda: columnas como surco de vidrio */
.cal-dstaff .ds-col,.cal-agenda{ background: rgba(255,255,255,.26) !important;
  -webkit-backdrop-filter: var(--glass-blur); backdrop-filter: var(--glass-blur);
  border:1px solid var(--glass-border) !important; border-radius:16px; }

/* ---- KPI hero / occ-hero: vidrio oscuro ---- */
.occ-hero,.kpi.hero,.res-kpi.hero{
  background: linear-gradient(135deg,rgba(8,40,30,.62),rgba(10,60,44,.5)) !important;
  -webkit-backdrop-filter: blur(22px) saturate(180%); backdrop-filter: blur(22px) saturate(180%);
  border: 1px solid rgba(255,255,255,.22) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.3), 0 14px 36px -14px rgba(8,40,30,.5) !important;
}

/* ---- toast en vidrio oscuro ---- */
.toast{
  background: linear-gradient(135deg,rgba(10,42,32,.9),rgba(8,28,21,.9)) !important;
  -webkit-backdrop-filter: blur(18px); backdrop-filter: blur(18px);
  border: 1px solid rgba(255,255,255,.16);
}

/* ---- modal: vidrio claro elevado ---- */
.modal{
  background: rgba(255,255,255,.72) !important;
  -webkit-backdrop-filter: blur(26px) saturate(180%); backdrop-filter: blur(26px) saturate(180%);
  border: 1px solid rgba(255,255,255,.7) !important;
  box-shadow: 0 30px 70px -26px rgba(8,40,30,.5), inset 0 1px 0 rgba(255,255,255,.8) !important;
}
.overlay{ background: rgba(10,40,30,.42) !important; -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px); }

/* ---- chat: hero y burbujas ---- */
.b.bot{ background: rgba(255,255,255,.62) !important; -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px); border:1px solid var(--glass-border) !important; }
.cbody{ background: transparent !important; }

/* ---- separadores y bordes internos a tono claro ---- */
.item,.list-row,.biz-card .meta{ border-color: rgba(255,255,255,.5) !important; }

/* ---- avatares ---- */
.av,.item .av{ background: rgba(18,184,134,.22) !important; border:1px solid rgba(255,255,255,.5); color: var(--green-ink) !important; }

/* ---- tabs internas (reputación, etc.) en vidrio ---- */
.rep-tabs{ background: rgba(255,255,255,.4) !important; -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px); }
.rep-tabs .rt.on{ background: rgba(255,255,255,.85) !important; }

/* ---- Calendario · vista Semana en TIRA menta (surcos + hoy elevado) ---- */
/* a ancho completo: el panel lateral baja debajo (como el mockup) */
/* panel lateral (ocupación, ingresos…) SIEMPRE a la derecha, en todas las vistas */
.cal-strip{ display:grid !important; grid-template-columns:repeat(7,minmax(0,1fr)) !important; gap:14px; align-items:start; padding:8px 2px 16px; background:transparent !important; width:100%; }
.cs-col{ display:flex; flex-direction:column; min-width:0; }
.cal-strip .dh{ text-align:center; margin-bottom:4px; }
.cal-strip .dh .dn{ font-size:.66rem; font-weight:800; text-transform:uppercase; letter-spacing:.05em; color:#7FA294; }
.cal-strip .dh .dd{ font-size:1.18rem; font-weight:800; color:#16352A; font-variant-numeric:tabular-nums; line-height:1.1; }
.cal-strip .dh.today{ margin-bottom:12px; } .cal-strip .dh.today .dn,.cal-strip .dh.today .dd{ color:#0A6B4E; }
.cal-strip .tbadge{ display:inline-block; margin-top:3px; position:relative; z-index:3; font-size:.54rem; font-weight:800; text-transform:uppercase; letter-spacing:.06em; color:#0A6B4E; background:rgba(18,184,134,.18); padding:2px 8px; border-radius:99px; }
.day-well{ background:rgba(255,255,255,.3); -webkit-backdrop-filter:blur(18px) saturate(165%); backdrop-filter:blur(18px) saturate(165%); border:1px solid rgba(255,255,255,.55); box-shadow:inset 0 1px 0 rgba(255,255,255,.6),0 12px 32px -16px rgba(10,60,44,.4); border-radius:18px; padding:9px; display:flex; flex-direction:column; gap:8px; min-height:330px; }
.day-up{ background:linear-gradient(170deg,rgba(255,255,255,.68),rgba(204,240,224,.52)); -webkit-backdrop-filter:blur(24px) saturate(185%); backdrop-filter:blur(24px) saturate(185%); border:1px solid rgba(255,255,255,.82); box-shadow:0 22px 46px -12px rgba(16,140,100,.5),inset 0 1px 0 rgba(255,255,255,.85); border-radius:18px; padding:9px; display:flex; flex-direction:column; gap:8px; min-height:330px; transform:translateY(-12px); position:relative; z-index:2; }
.day-well.dragover,.day-up.dragover{ outline:2px solid rgba(18,184,134,.65); outline-offset:-2px; background:rgba(255,255,255,.5); }
.day-closed{ border-radius:18px; min-height:330px; background:repeating-linear-gradient(135deg,rgba(214,231,224,.7),rgba(214,231,224,.7) 8px,rgba(207,226,218,.7) 8px,rgba(207,226,218,.7) 16px); box-shadow:inset 0 1px 0 rgba(255,255,255,.5); display:flex; align-items:center; justify-content:center; }
.day-closed span{ font-size:.66rem; font-weight:800; color:#9DB4AB; text-transform:uppercase; letter-spacing:.06em; transform:rotate(-90deg); }
.cal-strip .chip{ flex:none; min-height:40px; min-width:0; border-radius:11px; padding:7px 9px; overflow:hidden; -webkit-backdrop-filter:blur(8px) saturate(160%); backdrop-filter:blur(8px) saturate(160%); box-shadow:inset 0 1px 0 rgba(255,255,255,.55),0 4px 12px -6px rgba(10,60,44,.4); cursor:grab; transition:transform .14s ease; }
.cal-strip .chip:hover{ transform:translateY(-1px); }
.cal-strip .chip.onup{ box-shadow:0 6px 16px -7px rgba(16,120,86,.5),inset 0 1px 0 rgba(255,255,255,.7); }
.cal-strip .chip b{ display:block; font-size:.72rem; font-weight:800; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; line-height:1.18; }
.cal-strip .chip i{ display:block; font-size:.6rem; font-weight:700; font-style:normal; font-variant-numeric:tabular-nums; opacity:.95; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cal-strip .chip.dragging{ opacity:.4; }
.cal-strip .cgreen{ background:linear-gradient(135deg,rgba(18,184,134,.32),rgba(18,184,134,.15)); border:1px solid rgba(18,184,134,.42); } .cal-strip .cgreen b{ color:#08402F; } .cal-strip .cgreen i{ color:#0A6B4E; }
.cal-strip .cblue{ background:linear-gradient(135deg,rgba(44,95,153,.3),rgba(44,95,153,.14)); border:1px solid rgba(44,95,153,.42); } .cal-strip .cblue b{ color:#143456; } .cal-strip .cblue i{ color:#2c5f99; }
.cal-strip .camber{ background:linear-gradient(135deg,rgba(240,180,41,.34),rgba(240,180,41,.15)); border:1px solid rgba(212,150,20,.46); } .cal-strip .camber b{ color:#5c4300; } .cal-strip .camber i{ color:#8a6400; }
.cal-strip .cgrey{ background:linear-gradient(135deg,rgba(150,168,161,.3),rgba(150,168,161,.14)); border:1px solid rgba(150,168,161,.42); } .cal-strip .cgrey b{ color:#41504a; } .cal-strip .cgrey i{ color:#6b7a73; }
.cal-strip .cred{ background:linear-gradient(135deg,rgba(224,86,86,.28),rgba(224,86,86,.13)); border:1px solid rgba(224,86,86,.4); } .cal-strip .cred b{ color:#7d1f1f; text-decoration:line-through; } .cal-strip .cred i{ color:#9c2b2b; }
.cal-strip .occ{ margin-top:auto; height:6px; border-radius:99px; background:rgba(18,80,58,.1); overflow:hidden; }
.cal-strip .occ span{ display:block; height:100%; background:#7FD8B8; border-radius:99px; }
.cal-strip .occ span.full{ background:#12B886; }
.cal-strip .occlbl{ font-size:.58rem; font-weight:800; color:#7FA294; text-align:center; margin-top:5px; font-variant-numeric:tabular-nums; }
.cal-strip .occlbl.today{ color:#0A6B4E; }
.cal-strip .appt-ia{ position:static !important; font-size:.5rem; font-weight:800; color:#fff; background:rgba(44,95,153,.85); padding:1px 5px; border-radius:5px; vertical-align:1px; margin-left:5px; }
@media(max-width:900px){ .cal-strip{ grid-template-columns:repeat(7,minmax(132px,1fr)); overflow-x:auto; } }

/* ---- Cabecera de calendario: zonas fijas (el selector NO se mueve) ---- */
.callayout .cal-head{ display:grid !important; grid-template-columns:auto 1fr auto; grid-template-areas:'nav label view' 'tools tools tools'; align-items:center !important; column-gap:14px; row-gap:10px; }
.callayout .cal-nav{ grid-area:nav; }
.callayout .cal-wklabel{ grid-area:label; min-width:0; }
.callayout .cal-wklabel .wk{ white-space:nowrap; }
.callayout #calViewSel{ grid-area:view; justify-self:end; }
.callayout .cal-toolright{ grid-area:tools; justify-self:start; margin-left:0 !important; display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.callayout .cal-toolright:empty{ display:none; }
.cal-occ-chip{ display:inline-flex; align-items:center; gap:10px; padding:7px 8px 7px 14px; border-radius:99px;
  background:linear-gradient(135deg,rgba(8,40,30,.72),rgba(12,70,52,.66)); color:#fff;
  -webkit-backdrop-filter:blur(14px) saturate(170%); backdrop-filter:blur(14px) saturate(170%);
  border:1px solid rgba(255,255,255,.18); box-shadow:0 8px 22px -12px rgba(8,40,30,.6); white-space:nowrap; }
.cal-occ-chip .lbl{ font-size:.62rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:#8FE9CC; }
.cal-occ-chip .stats{ font-size:.72rem; font-weight:700; color:rgba(255,255,255,.82); }
.cal-occ-chip .stats b{ color:#fff; }
.cal-occ-ring{ --p:0; width:42px; height:42px; border-radius:50%; flex:none; display:flex; align-items:center; justify-content:center; position:relative;
  background:conic-gradient(#2BE0A6 calc(var(--p)*1%), rgba(255,255,255,.16) 0); }
.cal-occ-ring::before{ content:''; position:absolute; inset:4px; border-radius:50%; background:#0A2A1E; }
.cal-occ-ring span{ position:relative; font-size:.66rem; font-weight:800; font-variant-numeric:tabular-nums; }

/* ---- Días con MUCHAS citas: scroll interno, columnas siempre alineadas ---- */
.day-well,.day-up{ max-height:430px; }
.cs-chips{ display:flex; flex-direction:column; gap:8px; overflow-y:auto; min-height:0; flex:1; margin:-2px; padding:2px; scrollbar-width:thin; scrollbar-color:rgba(18,140,100,.4) transparent; }
.cs-chips::-webkit-scrollbar{ width:5px; } .cs-chips::-webkit-scrollbar-thumb{ background:rgba(18,140,100,.35); border-radius:99px; }
.cs-more{ font-size:.6rem; font-weight:800; color:#0A6B4E; text-align:center; padding:3px; opacity:.8; }

/* ---- Vista AÑO: 12 meses en vidrio con tinte verde por ocupación ---- */
.cal-year{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; padding:18px; }
.ycell{ position:relative; overflow:hidden; border-radius:18px; padding:15px 17px; min-height:90px; cursor:pointer; display:flex; flex-direction:column; justify-content:space-between;
  background:rgba(255,255,255,.5); -webkit-backdrop-filter:blur(16px) saturate(170%); backdrop-filter:blur(16px) saturate(170%);
  border:1px solid rgba(255,255,255,.6); box-shadow:inset 0 1px 0 rgba(255,255,255,.6), 0 10px 26px -18px rgba(10,60,44,.3);
  transition:transform .13s, box-shadow .13s; }
.ycell::before{ content:''; position:absolute; inset:0; background:var(--ytint, transparent); pointer-events:none; transition:background .2s; }
.ycell > *{ position:relative; z-index:1; }
.ycell:hover{ transform:translateY(-3px); box-shadow:0 16px 32px -16px rgba(10,60,44,.45); }
.ycell.today{ box-shadow:0 0 0 2px var(--green), 0 12px 28px -18px rgba(10,60,44,.4); }
.ytop{ display:flex; align-items:baseline; justify-content:space-between; gap:8px; }
.ynum{ font-family:'Newsreader',Georgia,serif; font-weight:400; font-size:1.2rem; color:var(--ink); text-transform:capitalize; letter-spacing:-.01em; }
.ycount{ font-size:1.1rem; font-weight:800; color:var(--green-ink); font-variant-numeric:tabular-nums; }
.yocc{ font-size:.74rem; font-weight:700; color:var(--ink-soft); }
.ycell.empty .ycount{ color:var(--ink-soft); opacity:.45; }
.ycell.empty .yocc{ opacity:.6; }
/* ---- CRM: consentimiento de marketing en la ficha ---- */
.pac-consent-note{ font-size:.78rem; color:var(--ink-soft); margin:0 0 10px; line-height:1.45; }
.pac-consent{ display:flex; align-items:flex-start; gap:10px; padding:9px 0; font-size:.9rem; cursor:pointer; }
.pac-consent input{ width:18px; height:18px; margin-top:1px; accent-color:var(--green); flex:none; cursor:pointer; }
.pac-consent b{ font-weight:700; }
.pac-consent-at{ font-size:.74rem; color:var(--ink-soft); margin:7px 0 0; font-style:italic; }
/* ---- Crecimiento: bonos y promociones (tiles glass) ---- */
.grow-block{ margin-bottom:26px; }
.grow-bhead{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin:0 2px 13px; flex-wrap:wrap; }
.grow-btitle{ display:flex; align-items:center; gap:9px; font-size:1.08rem; font-weight:800; margin:0; letter-spacing:-.01em; }
.grow-btitle .hi{ color:var(--green); width:20px; height:20px; flex:none; }
.grow-add{ display:inline-flex; align-items:center; gap:7px; height:38px; padding:0 16px; border-radius:99px; border:1.5px solid #BFE6D4; background:#E8F7F0; color:var(--green-ink); font-weight:800; font-size:.86rem; cursor:pointer; transition:.12s; }
.grow-add svg{ width:16px; height:16px; }
.grow-add:hover{ background:#dff3ea; border-color:#9ED9C2; }
.grow-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(212px,1fr)); gap:14px; }
.grow-tile{ position:relative; border-radius:16px; padding:15px 16px; background:rgba(255,255,255,.55); -webkit-backdrop-filter:blur(16px) saturate(165%); backdrop-filter:blur(16px) saturate(165%); border:1px solid rgba(255,255,255,.6); box-shadow:inset 0 1px 0 rgba(255,255,255,.6), 0 10px 24px -18px rgba(10,60,44,.3); display:flex; flex-direction:column; gap:5px; }
.gt-top{ display:flex; align-items:center; justify-content:space-between; }
.gt-badge{ font-size:.72rem; font-weight:800; color:var(--green-ink); background:var(--mint); padding:3px 10px; border-radius:99px; }
.gt-badge.promo{ color:#0A7553; background:#D8F1E6; }
.gt-del{ background:transparent; border:none; color:#9aa8a1; cursor:pointer; padding:4px; border-radius:7px; display:flex; }
.gt-del:hover{ color:#b5454a; background:rgba(229,72,77,.1); }
.gt-name{ font-weight:800; font-size:.98rem; letter-spacing:-.01em; margin-top:2px; }
.gt-sub{ font-size:.8rem; color:var(--ink-soft); }
.gt-foot{ display:flex; align-items:center; justify-content:space-between; gap:8px; margin-top:7px; padding-top:9px; border-top:1px solid rgba(12,26,20,.07); }
.gt-price{ font-size:1.12rem; font-weight:900; color:var(--green-d); font-variant-numeric:tabular-nums; }
.gt-chip{ font-size:.66rem; font-weight:800; color:var(--blue-d); background:var(--blue); padding:2px 8px; border-radius:6px; letter-spacing:.04em; }
.gt-meta{ font-size:.72rem; color:var(--ink-soft); }
.grow-empty{ font-size:.88rem; color:var(--ink-soft); padding:22px; text-align:center; background:rgba(255,255,255,.4); border-radius:14px; border:1px dashed var(--line); }
/* segmentado dentro de modales */
.seg{ display:flex; gap:4px; background:var(--bg-soft); padding:4px; border-radius:12px; margin:2px 0 8px; }
.seg button{ flex:1; border:none; background:transparent; color:var(--ink-soft); font-weight:700; font-size:.83rem; padding:9px 6px; border-radius:9px; cursor:pointer; transition:.12s; }
.seg button.on{ background:#fff; color:var(--green-ink); box-shadow:0 1px 3px rgba(12,26,20,.12); }
/* ---- Buzón de sugerencias ---- */
.fb-card{ border:1.5px dashed #BFE6D4 !important; background:rgba(232,247,240,.45) !important; }
.fb-card:hover{ border-color:var(--green) !important; background:rgba(232,247,240,.7) !important; }
.fb-bizlist{ display:flex; flex-direction:column; gap:6px; margin:4px 0; max-height:180px; overflow:auto; }
.fb-bizopt{ display:flex; align-items:center; gap:9px; font-size:.9rem; cursor:pointer; padding:8px 11px; border:1px solid var(--line); border-radius:10px; background:rgba(255,255,255,.5); }
.fb-bizopt input{ width:17px; height:17px; accent-color:var(--green); cursor:pointer; flex:none; }
.fb-sentas{ font-size:.76rem; color:var(--ink-soft); margin:9px 0 2px; font-style:italic; }
/* ---- Comunicaciones (audiencia consent-gated) ---- */
.grow-comm{ padding:18px; }
.comm-filters{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin:8px 0 4px; }
.comm-tags{ display:flex; flex-wrap:wrap; gap:7px; margin:4px 0 10px; }
.comm-tag{ border:1.5px solid var(--line); background:#fff; color:var(--ink-soft); font-weight:700; font-size:.8rem; padding:6px 13px; border-radius:99px; cursor:pointer; transition:.12s; }
.comm-tag.on{ border-color:var(--green); background:var(--mint); color:var(--green-ink); }
.comm-result{ margin:14px 0; }
.comm-result:empty{ display:none; }
.comm-count{ font-size:1rem; font-weight:700; }
.comm-count b{ font-size:1.5rem; font-weight:900; color:var(--green-d); }
.comm-break{ font-size:.82rem; color:var(--ink-soft); margin-top:3px; }
.comm-list{ display:flex; flex-wrap:wrap; gap:6px; margin-top:12px; }
.comm-list span{ font-size:.78rem; background:rgba(255,255,255,.6); border:1px solid var(--line); border-radius:8px; padding:4px 10px; }
.comm-none{ margin-top:10px; font-size:.86rem; color:#9a7400; background:#FFF6E5; border:1px solid #F4D58A; border-radius:10px; padding:10px 12px; }
.comm-send{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-top:6px; }
.comm-note{ font-size:.76rem; color:var(--ink-soft); }
@media(max-width:760px){ .comm-filters{ grid-template-columns:1fr; } }
@media(max-width:760px){ .cal-year{ grid-template-columns:repeat(2,1fr); padding:12px; gap:10px; } }

/* respeta accesibilidad: reduce desenfoque si el usuario lo pide */
@media (prefers-reduced-transparency: reduce){
  .card,.biz-card,.mini-kpi,.sbox,.aj-card,.modal,.kpi,.pac-side,.pac-main,
  .conv-list,.conv-thread,.phone,input,select,textarea,.btn-ghost{
    -webkit-backdrop-filter:none !important; backdrop-filter:none !important;
    background: rgba(255,255,255,.92) !important;
  }
}

/* ===========================================================================
   ====  PACIENTES · rediseño glass-menta (estructura conservada)          ====
   =========================================================================== */
#sub-pac .pac-head h1{ font-family:'Newsreader',Georgia,serif; font-weight:400; font-size:2rem; letter-spacing:-.01em; }
#sub-pac .pac-head-sub{ color:#5C7A6E; }

/* lista en vidrio */
.pac-side{ background:rgba(255,255,255,.55) !important; -webkit-backdrop-filter:blur(18px) saturate(165%); backdrop-filter:blur(18px) saturate(165%);
  border:1px solid rgba(255,255,255,.6) !important; border-radius:18px !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6),0 12px 32px -18px rgba(10,60,44,.35) !important; }
.pac-search input{ background:rgba(255,255,255,.7) !important; }
/* el panel derecho NO es una tarjeta: contenedor transparente (era un vidrio SIN esquinas redondeadas → cuadrado/picos detrás de la ficha) */
#sub-pac .pac-main{ background:transparent !important; border:0 !important; box-shadow:none !important; -webkit-backdrop-filter:none !important; backdrop-filter:none !important; padding:0 !important; }
/* el estado vacío sí lleva su propia tarjeta redondeada */
#sub-pac .pac-empty{ background:rgba(255,255,255,.92) !important; border:1px solid rgba(255,255,255,.7); border-radius:20px; box-shadow:inset 0 1px 0 rgba(255,255,255,.6),0 12px 32px -20px rgba(10,60,44,.3); }
.pac-item{ border-bottom:none !important; border-radius:13px; margin:5px 7px; padding:10px 11px; }
.pac-item:hover{ background:rgba(18,184,134,.07) !important; }
.pac-item.on{ background:linear-gradient(135deg,rgba(18,184,134,.18),rgba(18,184,134,.05)) !important; box-shadow:inset 2px 0 0 var(--green); }
.pac-item-av{ background:linear-gradient(160deg,#1ED39E,#0C9069); }

/* cabecera "hero" con stats */
.pac-fhead{ display:grid !important; grid-template-columns:auto 1fr auto; grid-template-areas:'av info forget' 'stats stats stats';
  align-items:center; gap:8px 18px; padding:22px; margin-bottom:18px; border-radius:22px; color:#fff; overflow:hidden; position:relative;
  background:linear-gradient(135deg,#103A2B,#0A2519); box-shadow:0 20px 44px -22px rgba(8,40,30,.65); }
.pac-fhead{ background-clip:padding-box; }
.pac-fhead::after{ content:''; position:absolute; inset:0; border-radius:inherit; background:radial-gradient(460px 220px at 92% -30%,rgba(18,184,134,.42),transparent 60%); pointer-events:none; }
.pac-av{ grid-area:av; width:66px; height:66px; font-size:1.7rem; background:linear-gradient(160deg,#1ED39E,#0C9069); box-shadow:0 0 0 4px rgba(255,255,255,.12),0 12px 24px -10px rgba(0,0,0,.45); position:relative; z-index:2; }
.pac-fhead-info{ grid-area:info; position:relative; z-index:2; }
.pac-fhead-info h2{ font-family:'Newsreader',serif; font-weight:400; color:#fff; font-size:1.55rem; }
.pac-phone{ color:#9FE3C8 !important; font-weight:600; }
.pac-fhead #pacForget{ grid-area:forget; align-self:start; background:rgba(255,255,255,.1) !important; color:#fff !important; border:1px solid rgba(255,255,255,.2) !important; position:relative; z-index:2; }
.pac-fhead #pacForget:hover{ background:rgba(224,86,86,.3) !important; border-color:rgba(224,86,86,.5) !important; }
.pac-stats{ grid-area:stats; display:flex; gap:9px; margin-top:6px; position:relative; z-index:2; flex-wrap:wrap; }
.pac-stat{ flex:1; min-width:90px; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.16); border-radius:14px; padding:10px 13px; -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px); }
.pac-stat b{ display:block; font-size:1.1rem; font-weight:800; font-variant-numeric:tabular-nums; letter-spacing:-.01em; line-height:1.2; }
.pac-stat span{ font-size:.62rem; font-weight:800; text-transform:uppercase; letter-spacing:.07em; color:#9FE3C8; }

/* tarjetas de la ficha en vidrio */
#sub-pac .pac-card{ background:rgba(255,255,255,.92) !important; background-clip:padding-box;
  -webkit-backdrop-filter:none !important; backdrop-filter:none !important;
  border:1px solid rgba(255,255,255,.7) !important; border-radius:18px !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6),0 12px 32px -20px rgba(10,60,44,.32) !important; }
#sub-pac .pac-card input,#sub-pac .pac-card select,#sub-pac .pac-card textarea{ background:#fff !important; border:1.5px solid rgba(13,79,58,.18) !important; box-shadow:inset 0 1px 2px rgba(10,60,44,.05) !important; }
#sub-pac .pac-card input:focus,#sub-pac .pac-card select:focus,#sub-pac .pac-card textarea:focus{ border-color:var(--green) !important; box-shadow:0 0 0 3px rgba(18,184,134,.16) !important; }
#sub-pac .pac-card label{ color:var(--green-d); font-weight:700; }
.pac-sec{ font-family:'Newsreader',serif; font-weight:500; font-size:1.08rem; }
.pac-clinical{ border-color:rgba(212,150,20,.4) !important; }
.pac-hist-title{ font-family:'Newsreader',serif; font-weight:500; font-size:1.08rem; }
/* ficha con pestañas */
.pac-tabcard{ padding:0 !important; overflow:hidden; }
.pac-tabs{ display:flex; gap:2px; padding:8px 10px 0; flex-wrap:wrap; border-bottom:1px solid rgba(10,60,44,.1); }
.pac-tabs button{ border:none; background:transparent; color:var(--ink-soft); font-family:'Newsreader',serif; font-weight:500; font-size:1.02rem; padding:11px 18px; border-radius:12px 12px 0 0; cursor:pointer; position:relative; transition:.14s; }
.pac-tabs button:hover{ color:var(--ink); background:rgba(255,255,255,.4); }
.pac-tabs button.on{ color:var(--green-ink); }
.pac-tabs button.on::after{ content:''; position:absolute; left:16px; right:16px; bottom:-1px; height:2.5px; background:var(--green); border-radius:3px; }
.pac-panel{ display:none; padding:22px; }
.pac-panel.on{ display:block; animation:pacFade .18s ease; }
.pac-panel>label:first-child,.pac-panel .row2:first-child label{ margin-top:0; }
@keyframes pacFade{ from{ opacity:0; transform:translateY(3px); } to{ opacity:1; transform:none; } }
.pac-sens-note{ display:flex; align-items:center; gap:8px; font-size:.8rem; color:#9a6a1d; background:rgba(255,241,232,.7); border:1px solid rgba(212,150,20,.3); border-radius:11px; padding:9px 12px; margin-bottom:14px; }

/* historial como línea de tiempo */
.pac-history{ position:relative; padding-left:18px; }
.pac-history::before{ content:''; position:absolute; left:5px; top:8px; bottom:8px; width:2px; background:linear-gradient(#BFE3D2,rgba(191,227,210,.2)); border-radius:2px; }
.pac-hist-row{ position:relative; background:rgba(255,255,255,.5) !important; border:1px solid rgba(255,255,255,.6) !important; border-radius:13px !important; }
.pac-hist-row::before{ content:''; position:absolute; left:-16px; top:50%; transform:translateY(-50%); width:9px; height:9px; border-radius:50%; background:var(--green); box-shadow:0 0 0 3px rgba(18,184,134,.18); }
.pac-hist-row:hover{ border-color:var(--green) !important; background:rgba(255,255,255,.78) !important; }

/* estado vacío con más calidez */
.pac-empty-ic{ width:74px; height:74px; margin:0 auto 14px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(160deg,rgba(18,184,134,.16),rgba(18,184,134,.05)); border:1px solid rgba(18,184,134,.2); }
.pac-empty p{ font-size:1rem; }

@media(max-width:560px){ .pac-fhead{ grid-template-columns:auto 1fr; grid-template-areas:'av info' 'forget forget' 'stats stats'; } }

/* ===========================================================================
   ====  AVATARES de iniciales · mismo estilo en TODA la app               ====
   (Pacientes, Conversaciones, próximas citas, equipo…)
   =========================================================================== */
.av,.item .av,.conv-item .av,.conv-thread-head .av,.pac-item-av,.list-row .av,.tm-av{
  background:linear-gradient(160deg,#1ED39E,#0C9069) !important;
  color:#fff !important; border:none !important;
  box-shadow:0 4px 10px -5px rgba(14,158,116,.55) !important;
  font-weight:800 !important;
}

/* =======================================================================
   ====  AURORA · rebrand global (capa de tema — NO toca estructura ni JS) ==
   ====  Hanken Grotesk · fondo aurora animado · gradiente de marca       ==
   ======================================================================= */
@keyframes auFlow{0%{background-position:0% 50%}100%{background-position:300% 50%}}
@keyframes auD1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(60px,40px) scale(1.18)}}
@keyframes auD2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-50px,30px) scale(1.12)}}
@keyframes auD3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(40px,-44px) scale(1.22)}}
:root{
  --font-sans:'Hanken Grotesk',system-ui,-apple-system,sans-serif;
  --font-serif:'Hanken Grotesk',system-ui,sans-serif;
  --brand:#16C2B0; --brand-strong:#0E9E70; --brand-ink:#0E8A66; --brand-tint:rgba(31,181,138,.10);
  --green:#16C2B0; --green-d:#0E9E70; --green-ink:#0E8A66;
  --au-grad:linear-gradient(110deg,#1FB58A,#16C2B0,#36C8C2,#7FD08A,#9AD15A,#5FB6DE,#1FB58A);
}
html{ background:#EAF1EC !important; }
body{ background:transparent !important; font-family:'Hanken Grotesk',system-ui,sans-serif !important; color:#1E2A28 !important; }
.aurora-mesh{ position:fixed; inset:0; z-index:-1; pointer-events:none; overflow:hidden; }
.aurora-mesh i{ position:absolute; display:block; border-radius:50%; filter:blur(48px); }
.aurora-mesh .b1{ top:-160px; right:-60px; width:560px; height:560px; background:radial-gradient(circle,rgba(31,181,138,.40),transparent 66%); animation:auD1 18s ease-in-out infinite; }
.aurora-mesh .b2{ top:160px; left:-80px; width:440px; height:440px; background:radial-gradient(circle,rgba(63,200,194,.32),transparent 66%); animation:auD2 22s ease-in-out infinite; }
.aurora-mesh .b3{ bottom:-180px; right:18%; width:480px; height:480px; background:radial-gradient(circle,rgba(95,182,222,.26),transparent 66%); animation:auD3 26s ease-in-out infinite; }
.aurora-mesh .b4{ bottom:40px; left:36%; width:340px; height:340px; background:radial-gradient(circle,rgba(154,209,90,.22),transparent 66%); animation:auD1 30s ease-in-out infinite; }
h1,h2,h3,.dash-head h1,.res-title,.rep-title,#sub-pac .pac-head h1,.pac-fhead-info h2,.pac-sec,.pac-hist-title{
  font-family:'Hanken Grotesk',system-ui,sans-serif !important; font-weight:800 !important; letter-spacing:-.03em !important;
}
/* gradiente de marca: QUIETO por defecto, fluye SOLO al pasar el ratón.
   Vía ::before para que la animación no choque con el !important del tema base. */
.btn-primary{
  position:relative; overflow:hidden; isolation:isolate;
  color:#06231C !important; border:none !important; font-weight:800 !important;
  box-shadow:0 12px 26px -10px rgba(25,166,176,.6) !important;
}
.btn-primary::before{ content:''; position:absolute; inset:0; z-index:-1; border-radius:inherit;
  background:var(--au-grad); background-size:320% 100%; background-position:0% 50%; }
.btn-primary:hover::before{ animation:auFlow 3s linear infinite; }
.btn-primary:hover{ filter:brightness(1.03); }
.av,.item .av,.conv-item .av,.conv-thread-head .av,.pac-item-av,.list-row .av,.tm-av,.pac-av{
  background:var(--au-grad) !important; background-size:320% 100% !important; background-position:0% 50% !important; color:#06231C !important;
}
.gtext{ background:linear-gradient(110deg,#0E9E70,#16C2B0,#19A6C0,#5FB55A,#0E9E70); background-size:300% 100%; background-position:0% 50%; -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }

/* --- Aurora · Login --- */
.authcard{ position:relative; overflow:hidden; border-radius:24px !important; }
.authcard::before{ content:''; position:absolute; top:0; left:0; right:0; height:5px; background:var(--au-grad); background-size:320% 100%; animation:auFlow 8s linear infinite; z-index:3; }
.authlogo .mk{ position:relative; overflow:hidden; isolation:isolate; color:#06231C !important; }
.authlogo .mk::before{ content:''; position:absolute; inset:0; z-index:-1; background:var(--au-grad); background-size:320% 100%; background-position:0% 50%; }
.authlogo:hover .mk::before{ animation:auFlow 3s linear infinite; }

/* --- Aurora · Dashboard --- */
.dash-eyebrow{ font-size:.74rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:#7B9488; margin-bottom:6px; }
.dash-head h1{ font-size:2.4rem; }
.biz-card{ border-radius:20px !important; padding:18px 18px 16px !important; }
.biz-card:hover{ transform:translateY(-4px); border-color:rgba(31,181,138,.45) !important; box-shadow:0 28px 56px -30px rgba(20,120,110,.6) !important; }
.bizc-top{ display:flex; align-items:center; gap:12px; }
.bizc-av{ width:46px; height:46px; flex:none; border-radius:13px; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; isolation:isolate;
  background:var(--au-grad); background-size:320% 100%; background-position:0% 50%; color:#06231C; font-weight:800; font-size:.94rem; }
.biz-card:hover .bizc-av{ animation:auFlow 3s linear infinite; }
.bizc-av img{ width:100%; height:100%; object-fit:cover; border-radius:13px; }
.bizc-id{ flex:1; min-width:0; }
.bizc-name{ font-weight:800; font-size:1.04rem; letter-spacing:-.01em; color:#1E2A28; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.biz-card .sec{ font-size:.8rem; color:#7B9488; }
.bizc-dot{ width:9px; height:9px; flex:none; border-radius:50%; background:#16C2B0; box-shadow:0 0 8px #16C2B0; }
.biz-card .meta{ display:flex; gap:8px; margin-top:16px; }
.biz-card .meta span{ flex:1; background:rgba(31,181,138,.08); border-radius:11px; padding:9px 12px; display:flex; flex-direction:column; gap:1px; font-size:.68rem; font-weight:700; color:#7B9488; }
.biz-card .meta b{ font-size:1.3rem; font-weight:900; color:#1E2A28; letter-spacing:-.02em; line-height:1.15; }
.bizc-status{ display:flex; align-items:center; gap:7px; margin-top:14px; font-size:.8rem; font-weight:700; color:#0E8A66; }
.bizc-status span{ width:6px; height:6px; border-radius:50%; background:#16C2B0; flex:none; }
.addc-sub{ font-size:.78rem; color:#7B9488 !important; font-weight:400 !important; }
/* la tarjeta de buzón mantiene su icono en tinte */
.biz-card.fb-card .ic{ background:rgba(31,181,138,.10) !important; border-radius:13px !important; }

/* --- Aurora · Barra lateral (nav compartida en todas las pantallas) --- */
/* ítem de menú ACTIVO = gradiente de marca (quieto, fluye SOLO en hover) */
.subtabs button.on{ position:relative; overflow:hidden; isolation:isolate; color:#06231C !important; box-shadow:none !important; font-weight:700 !important; }
.subtabs button.on::before{ content:''; position:absolute; inset:0; z-index:-1; background:var(--au-grad); background-size:320% 100%; background-position:0% 50%; }
.subtabs button.on:hover::before{ animation:auFlow 3s linear infinite; }
.subtabs button.on svg{ stroke:#06231C !important; }
/* logo de la barra en gradiente (fluye en hover) */
.top .brand .mk{ position:relative; overflow:hidden; isolation:isolate; background:transparent !important; }
.top .brand .mk::before{ content:''; position:absolute; inset:0; z-index:-1; background:var(--au-grad); background-size:320% 100%; background-position:0% 50%; }
.top .brand:hover .mk::before{ animation:auFlow 3s linear infinite; }
/* fondo de la barra (solo escritorio; en móvil sigue siendo barra superior) */
@media(min-width:761px){ .top{ background:linear-gradient(180deg,#E7F1EB,#DAE8DF) !important; border-right:1px solid #D3E0D8 !important; } }

/* --- Aurora · citas PLANAS + barra de color a la izquierda (como el mockup) --- */
/* vistas día / mes (.appt) */
.appt{ background:#E2F3EB !important; border:none !important; border-left:3px solid #15A877 !important;
  -webkit-backdrop-filter:none !important; backdrop-filter:none !important; box-shadow:0 2px 6px -3px rgba(20,120,110,.32) !important; }
.appt b{ color:#0B3D2C !important; } .appt-meta,.appt .t{ color:#0A7553 !important; }
.appt.bot{ background:#E2EFF8 !important; border-left-color:#2E89C4 !important; }
.appt.bot b{ color:#143456 !important; } .appt.bot .appt-meta,.appt.bot .t{ color:#2c5f99 !important; }
.appt.pend{ background:#FFF3DC !important; border-left-color:#E1A53D !important; }
.appt.pend b{ color:#6B4E00 !important; } .appt.pend .appt-meta,.appt.pend .t{ color:#8A6400 !important; }
.appt.done{ background:#EEF1F0 !important; border-left-color:#9AA8A1 !important; opacity:.95 !important; }
.appt.done b{ color:#56625C !important; } .appt.done .appt-meta,.appt.done .t{ color:#7B8780 !important; }
.appt.no{ background:#FDECEC !important; border-left-color:#E05656 !important; }
.appt.no b{ color:#7D1F1F !important; } .appt.no .appt-meta,.appt.no .t{ color:#9C2B2B !important; }
/* vista semana (.cal-strip .chip · cgreen/cblue/camber/cgrey/cred) */
.cal-strip .chip{ -webkit-backdrop-filter:none !important; backdrop-filter:none !important; box-shadow:0 2px 6px -3px rgba(20,120,110,.3) !important; }
.cal-strip .cgreen{ background:#E2F3EB !important; border:none !important; border-left:3px solid #15A877 !important; }
.cal-strip .cblue{ background:#E2EFF8 !important; border:none !important; border-left:3px solid #2E89C4 !important; }
.cal-strip .camber{ background:#FFF3DC !important; border:none !important; border-left:3px solid #E1A53D !important; }
.cal-strip .cgrey{ background:#EEF1F0 !important; border:none !important; border-left:3px solid #9AA8A1 !important; }
.cal-strip .cred{ background:#FDECEC !important; border:none !important; border-left:3px solid #E05656 !important; }

/* --- Aurora · Vista Año (tarjetas de mes con barra de ocupación) --- */
.cal-year{ display:grid !important; grid-template-columns:repeat(4,1fr) !important; gap:14px !important; align-content:start; background:transparent !important; }
.ycard{ background:rgba(255,255,255,.72); border:1px solid #DCE8E1; border-radius:16px; padding:16px 16px 18px; cursor:pointer; transition:transform .15s,box-shadow .15s,border-color .15s; box-shadow:0 10px 28px -22px rgba(20,120,110,.5); }
.ycard:hover{ transform:translateY(-3px); border-color:rgba(31,181,138,.45); box-shadow:0 22px 44px -26px rgba(20,120,110,.55); }
.ycard-top{ display:flex; align-items:center; justify-content:space-between; }
.ymonth{ font-weight:800; font-size:1rem; color:#1E2A28; }
.ybadge{ font-size:.58rem; font-weight:800; letter-spacing:.07em; text-transform:uppercase; color:#7E9A8E; background:#E8F0EC; padding:3px 8px; border-radius:7px; white-space:nowrap; flex:none; }
.ycard-top{ gap:8px; }
.ynum{ font-size:1.9rem; font-weight:900; letter-spacing:-.03em; line-height:1.1; margin-top:8px; color:#0E9E70; }
.ysub{ font-size:.74rem; font-weight:600; color:#7B9488; margin-top:1px; }
.ybar{ height:6px; border-radius:99px; background:rgba(18,120,90,.10); margin-top:12px; overflow:hidden; }
.ybar i{ display:block; height:100%; border-radius:99px; background:linear-gradient(90deg,#16C2B0,#1FB58A); }
.ycard.today{ border:1.5px solid #16C2B0; box-shadow:0 0 0 3px rgba(31,181,138,.12),0 14px 34px -24px rgba(20,120,110,.5); }
.ycard.empty .ynum{ -webkit-text-fill-color:#9DB3A8; color:#9DB3A8; }
@media(max-width:900px){ .cal-year{ grid-template-columns:repeat(2,1fr) !important; } }

/* --- Aurora · Calendario a pantalla completa + panel plegable (Resumen) --- */
.callayout{ display:block !important; }
.cal-headright{ display:flex; align-items:center; gap:12px; flex:none; }
.cal-occpill{ display:inline-flex; align-items:center; gap:8px; cursor:pointer;
  background:rgba(255,255,255,.72) !important; color:#1E2A28 !important; border:1px solid #D3E0D8; font-family:inherit; font-weight:700; font-size:.84rem;
  padding:7px 15px 7px 8px; border-radius:99px; box-shadow:0 6px 16px -12px rgba(20,120,110,.45); white-space:nowrap; transition:border-color .15s,box-shadow .15s; }
.cal-occpill:hover{ border-color:#9FD3C2; box-shadow:0 10px 22px -12px rgba(20,120,110,.5); }
.cal-occpill b{ font-weight:900; color:#0E8A66; }
.cal-occpill .occ-mini{ width:24px; height:24px; border-radius:50%; flex:none; display:flex; align-items:center; justify-content:center; }
.cal-occpill .occ-mini i{ width:15px; height:15px; border-radius:50%; background:rgba(255,255,255,.96); display:block; }
.cal-newbtn{ padding:10px 16px !important; white-space:nowrap; }
#calSidePanel{ position:fixed; top:0; right:0; height:100vh; width:344px; max-width:90vw; z-index:120; overflow-y:auto;
  padding:18px 18px 32px; background:linear-gradient(180deg,#F4FAF7,#EAF2EC); border-left:1px solid #D3E0D8;
  box-shadow:-24px 0 60px -34px rgba(8,40,30,.45); transform:translateX(106%); transition:transform .3s cubic-bezier(.2,.8,.25,1); }
#calSidePanel.open{ transform:none; }
.cal-panel-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.cal-panel-head span{ font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:1.12rem; }
.cal-panel-x{ width:32px; height:32px; border-radius:9px; border:1px solid #D3E0D8; background:#fff; color:#5C7167; cursor:pointer; display:flex; align-items:center; justify-content:center; }
.cal-panel-x:hover{ background:#E9F2ED; color:#1E2A28; }

/* --- Aurora · Vista Mes (celdas limpias con "X citas" + hoy enmarcado, sin heatmap) --- */
.cal-month{ background:rgba(255,255,255,.5) !important; border:1px solid #DCE8E1 !important; border-radius:16px !important; overflow:hidden; }
.cal-month .mh{ color:#8AA89B !important; font-weight:800 !important; text-transform:uppercase; letter-spacing:.06em; background:transparent !important; }
.cal-month .hcell{ background:#fff !important; border:1px solid #EAF1EC !important; border-radius:0 !important; box-shadow:none !important; padding:8px 10px !important; }
.cal-month .hcell .hnum{ font-weight:700; color:#1E2A28; font-size:.86rem; background:none; }
.cal-month .hcell .hcnt{ color:#0E8A66 !important; font-weight:700 !important; font-size:.74rem !important; background:none !important; padding:0 !important; }
.cal-month .hcell.other{ background:#F6FAF8 !important; }
.cal-month .hcell.other .hnum{ color:#B6C7BE; }
.cal-month .hcell.closed{ background:repeating-linear-gradient(45deg,#F4F8F5,#F4F8F5 6px,#EAF1EC 6px,#EAF1EC 12px) !important; }
.cal-month .hcell.closed .hnum{ color:#A9BDB3; }
.cal-month .hcell.today{ box-shadow:inset 0 0 0 2px #16C2B0 !important; border-radius:10px !important; background:#F1FBF7 !important; position:relative; z-index:2; }
.cal-month .hcell.today .hnum{ background:#16C2B0; color:#06231C; min-width:24px; height:24px; padding:0 6px; border-radius:99px; display:inline-flex; align-items:center; justify-content:center; font-weight:800; }

/* --- Aurora · Vista Día: superficie clara para que las horas se distingan del fondo --- */
.cal-dstaff{ background:rgba(255,255,255,.66) !important; border:1px solid #DCE8E1 !important; border-radius:16px !important; overflow:hidden; box-shadow:0 12px 32px -24px rgba(20,120,110,.4); }
.cal-dstaff .cell{ border-top:1px solid #E3EDE8 !important; border-left:1px solid #EDF4F0 !important; background:transparent !important; }
.cal-dstaff .cell:hover{ background:rgba(31,181,138,.09) !important; }
.cal-dstaff .cell.past{ background:repeating-linear-gradient(135deg,#F6F9F7,#F6F9F7 6px,#EDF3F0 6px,#EDF3F0 12px) !important; }
.cal-dstaff .cell.closed{ background:#F4F8F6 !important; }
.cal-dstaff .ds-head{ border-left:1px solid #E8F0EC !important; }
.cal-dstaff .hr{ color:#8AA89B !important; }
/* --- Aurora · Vista Semana (rejilla horaria · cabeceras de día) --- */
.cal-week{ overflow-x:auto; }
.cal-week .dhw{ display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2px; padding:8px 4px 6px; border-left:1px solid #E8F0EC; }
.cal-week .dhw-dow{ font-size:.62rem; font-weight:800; text-transform:uppercase; letter-spacing:.05em; color:#8AA89B; }
.cal-week .dhw-num{ font-size:1.05rem; font-weight:800; color:#1E2A28; line-height:1; }
.cal-week .dhw.today .dhw-num{ background:#16C2B0; color:#06231C; width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; }
.cal-week .dhw.today .dhw-dow{ color:#0E8A66; }
.cal-week .dhw.closed{ background:repeating-linear-gradient(45deg,#F4F8F5,#F4F8F5 6px,#EAF1EC 6px,#EAF1EC 12px); }
.cal-week .dhw.closed .dhw-num,.cal-week .dhw.closed .dhw-dow{ color:#B6C7BE; }
.cal-week .appt{ margin:1px 2px !important; }

/* --- Aurora · Asistente (chat + orbe del asistente) --- */
@keyframes auFloat{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-4px); } }
@keyframes auOrbPulse{ 0%,100%{ box-shadow:0 0 0 0 rgba(31,181,138,.4),0 16px 36px -12px rgba(25,166,176,.55); } 50%{ box-shadow:0 0 0 16px rgba(31,181,138,0),0 16px 36px -12px rgba(25,166,176,.55); } }
/* burbujas: cliente = gradiente, asistente = blanco */
.b.me{ background:linear-gradient(120deg,#1FB58A,#16C2B0) !important; color:#06231C !important; font-weight:500; }
.b.bot{ background:#fff !important; border:1px solid #E4EDE8 !important; color:#1E2A28 !important; -webkit-backdrop-filter:none !important; backdrop-filter:none !important; }
.cbody{ background:linear-gradient(180deg,rgba(234,241,236,.45),transparent) !important; }
/* cabecera del chat: clara + avatar (orbe) en gradiente que flota */
.chead{ background:rgba(247,251,249,.9) !important; color:#1E2A28 !important; border-bottom:1px solid #E4EDE8; }
.chead .nm{ color:#1E2A28; } .chead .st{ color:#0E8A66 !important; }
.chead .av{ background-image:var(--au-grad) !important; background-size:320% 100% !important; background-position:0% 50%; color:#06231C !important; animation:auFloat 4.5s ease-in-out infinite; }
.phone .chead:hover .av{ animation:auFlow 3s linear infinite; }
/* botón enviar en gradiente (fluye en hover) */
.cfoot button{ background-image:var(--au-grad) !important; background-size:320% 100% !important; background-position:0% 50%; color:#06231C !important;
  width:40px !important; height:40px !important; border-radius:11px !important; display:flex !important; align-items:center; justify-content:center; }
.cfoot button:hover{ animation:auFlow 3s linear infinite; }
.cfoot button svg{ stroke:#06231C !important; width:18px !important; height:18px !important; }
/* EL ORBE del asistente (modo voz): gradiente + pulso, FLUYE en hover (background-image, no atajo) */
.voiceorb{ width:104px; height:104px; background-image:var(--au-grad) !important; background-size:320% 100% !important; background-position:0% 50%; color:#06231C !important;
  box-shadow:0 16px 36px -12px rgba(25,166,176,.55); animation:auOrbPulse 2.4s ease-in-out infinite; }
.voiceorb:hover{ transform:scale(1.05); animation:auFlow 3s linear infinite; }
.voiceorb svg{ stroke:#06231C !important; }

/* --- Aurora · Asistente: 3 pestañas (WhatsApp/Teléfono/Conversaciones) --- */
.asist-tabs{ display:flex !important; width:-moz-fit-content; width:fit-content; margin:0 auto 18px !important; gap:3px !important;
  background:rgba(255,255,255,.62) !important; border:1px solid #D3E0D8 !important; border-radius:13px !important; padding:3px !important; box-shadow:none !important; }
.asist-tabs .svc{ display:inline-flex; align-items:center; gap:7px; background:transparent !important; border:none !important; color:#7B9488 !important;
  font-weight:700; font-size:.86rem; padding:8px 16px !important; border-radius:9px !important; cursor:pointer; box-shadow:none !important; transition:.15s; }
.asist-tabs .svc svg{ width:16px !important; height:16px !important; }
.asist-tabs .svc:hover{ color:#0E8A66 !important; }
.asist-tabs .svc.on{ background:#fff !important; color:#0E8A66 !important; box-shadow:0 1px 3px rgba(20,120,110,.15) !important; }
/* la pestaña Conversaciones, a ancho cómodo dentro del asistente */
#asist-conv .conv-layout{ height:calc(100vh - 230px); min-height:440px; }

/* --- Aurora · Resultados: 4 tarjetas KPI estilo mockup ("X en números") --- */
.res-kpis-mk{ display:grid !important; grid-template-columns:repeat(4,1fr) !important; gap:16px !important; }
.rk2{ background:rgba(255,255,255,.66); border:1px solid rgba(255,255,255,.85); border-radius:18px; padding:18px 20px; box-shadow:0 14px 34px -28px rgba(20,120,110,.5); transition:transform .16s,box-shadow .16s; }
.rk2:hover{ transform:translateY(-3px); box-shadow:0 24px 50px -28px rgba(20,120,110,.5); }
.rk2-eye{ font-size:.72rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:#7B9488; }
.rk2-n{ font-size:2.1rem; font-weight:900; letter-spacing:-.04em; line-height:1; margin-top:10px; color:#1E2A28; }
.rk2-sub{ font-size:.78rem; font-weight:600; color:#5C7167; margin-top:6px; }
.rk2-sub b{ color:#0E8A66; font-weight:800; }
.rk2-up{ color:#0E8A66; font-weight:800; } .rk2-up.dn{ color:#C4574A; }
.rk2-dark{ background:linear-gradient(160deg,#0E3A30,#08241D) !important; border:1px solid rgba(255,255,255,.1); color:#fff; box-shadow:0 20px 40px -26px rgba(8,36,29,.7); }
.rk2-dark .rk2-eye{ color:#7FE3C0; } .rk2-dark .rk2-n{ color:#fff !important; -webkit-text-fill-color:#fff; } .rk2-dark .rk2-sub{ color:#9FE3C8; }
@media(max-width:900px){ .res-kpis-mk{ grid-template-columns:1fr 1fr !important; } }
/* la analítica detallada se oculta por defecto; el botón "Detalle" la muestra (sin perder nada) */
/* (v8 PRO) Las gráficas ya NO se esconden: el mural está siempre visible. */
/* === Todo clicable: afordancia + panel lateral de detalle === */
.rk2-click, .sv-click{ cursor:pointer; }
.rk2-click{ position:relative; transition:transform .15s, box-shadow .15s; }
.rk2-click::after{ content:''; position:absolute; top:18px; right:18px; width:7px; height:7px; border-right:2px solid #B6C7BE; border-top:2px solid #B6C7BE; transform:rotate(45deg); transition:.15s; }
.rk2-click:hover{ transform:translateY(-3px); box-shadow:0 24px 50px -26px rgba(20,120,110,.55); }
.rk2-click:hover::after{ border-color:#16C2B0; right:14px; }
.rk2-dark.rk2-click::after{ border-color:rgba(255,255,255,.4); }
.sv-click{ border-radius:10px; margin:0 -8px; padding:6px 8px; transition:background .14s; }
.sv-click:hover{ background:rgba(31,181,138,.06); }
.res-drawer{ position:fixed; inset:0; z-index:120; background:rgba(8,36,29,.34); backdrop-filter:blur(2px); opacity:0; visibility:hidden; transition:opacity .2s; display:block !important; }
.res-drawer.open{ opacity:1; visibility:visible; }
.dw-panel{ position:absolute; top:0; right:0; bottom:0; width:min(440px,92vw); background:#F6FAF8; box-shadow:-30px 0 60px -30px rgba(8,36,29,.5); display:flex; flex-direction:column; transform:translateX(100%); transition:transform .26s cubic-bezier(.2,.8,.25,1); }
.res-drawer.open .dw-panel{ transform:translateX(0); }
.dw-head{ display:flex; align-items:flex-start; justify-content:space-between; gap:12px; padding:22px 22px 16px; border-bottom:1px solid #E4EDE8; }
.dw-eye{ font-size:.66rem; font-weight:800; letter-spacing:.13em; text-transform:uppercase; color:#9DB3A8; margin-bottom:5px; }
.dw-head h3{ font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:1.2rem; margin:0; letter-spacing:-.02em; color:#1E2A28; }
.dw-head p{ margin:3px 0 0; font-size:.82rem; color:#7B9488; font-weight:600; }
.dw-x{ flex:none; width:36px; height:36px; border-radius:10px; border:1px solid #E0EAE5; background:#fff; color:#5C7167; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:.14s; }
.dw-x:hover{ background:#0E8A66; color:#fff; border-color:#0E8A66; }
.dw-x .hi{ width:17px; height:17px; }
.dw-body{ flex:1; overflow-y:auto; padding:16px 22px 26px; }
.dw-sec, .dw-hint{ font-size:.84rem; color:#5C7167; font-weight:600; margin-bottom:12px; }
.dw-hint{ background:rgba(225,165,61,.1); border:1px solid rgba(225,165,61,.25); border-radius:11px; padding:11px 13px; color:#7a5a12; }
.dw-row{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:11px 2px; border-bottom:1px solid #EAF1EC; }
.dw-row .dw-n{ display:flex; flex-direction:column; font-weight:700; color:#1E2A28; font-size:.9rem; }
.dw-row .dw-n small{ font-weight:600; color:#9DB3A8; font-size:.74rem; margin-top:2px; }
.dw-row b{ font-weight:800; color:#0E8A66; font-variant-numeric:tabular-nums; white-space:nowrap; }
.dw-bar-row{ display:grid; grid-template-columns:42px 1fr auto; align-items:center; gap:10px; padding:9px 2px; font-size:.84rem; font-weight:700; color:#5C7167; }
.dw-bar-row b{ color:#1E2A28; font-variant-numeric:tabular-nums; }
.dw-bar{ height:8px; border-radius:99px; background:#E4EDE8; overflow:hidden; }
.dw-bar > div{ height:100%; border-radius:99px; background:linear-gradient(90deg,#16C2B0,#1FB58A); }
.dw-cta{ width:100%; margin-top:18px; border:none; background:#0E8A66; color:#fff; font-family:inherit; font-weight:800; font-size:.9rem; padding:13px; border-radius:12px; cursor:pointer; transition:.15s; }
.dw-cta:hover{ background:#0b7355; transform:translateY(-1px); }
.dw-empty{ color:#9DB3A8; font-size:.88rem; padding:20px 0; text-align:center; }
/* Barra de control SIEMPRE visible: negocio + rango de fechas + filtros */
.res-toolbar{ display:flex !important; flex-wrap:wrap; align-items:center; gap:10px 14px; padding:12px 14px !important; margin-bottom:18px; background:rgba(255,255,255,.7) !important; border:1px solid rgba(255,255,255,.85) !important; border-radius:16px !important; backdrop-filter:none !important; box-shadow:0 10px 30px -24px rgba(20,120,110,.5) !important; }
.res-toolbar .res-bizpick{ display:flex; align-items:center; gap:7px; padding-right:14px; border-right:1px solid #E0EAE5; }
.res-toolbar .res-cl{ font-size:.72rem; font-weight:800; text-transform:uppercase; letter-spacing:.04em; color:#7B9488; }
.res-toolbar select{ font-family:inherit; font-weight:700; font-size:.82rem; color:#1E2A28; border:1px solid #D3E0D8; background:#fff; border-radius:10px; padding:7px 10px; cursor:pointer; transition:.14s; }
.res-toolbar select:hover{ border-color:#9FD3C2; }
.res-toolbar #resBizSel{ font-weight:800; color:#0E8A66; border-color:rgba(31,181,138,.35); }
.res-toolbar .res-presets{ display:flex; flex-wrap:wrap; gap:3px; background:rgba(244,249,246,.8); border:1px solid #E0EAE5; border-radius:11px; padding:3px; }
.res-toolbar .res-presets button{ border:none; background:transparent; color:#7B9488; font-family:inherit; font-weight:700; font-size:.78rem; padding:6px 11px; border-radius:8px; cursor:pointer; transition:.14s; }
.res-toolbar .res-presets button:hover{ color:#0E8A66; }
.res-toolbar .res-presets button.on{ background:#fff; color:#0E8A66; font-weight:800; box-shadow:0 1px 2px rgba(20,120,110,.15); }
.res-toolbar .res-daterange{ display:flex; align-items:center; gap:8px; }
.res-toolbar .res-daterange label{ font-size:.74rem; font-weight:700; color:#5C7167; display:flex; align-items:center; gap:5px; }
.res-toolbar .res-daterange input{ font-family:inherit; font-size:.8rem; border:1px solid #D3E0D8; border-radius:9px; padding:6px 8px; }
.res-toolbar .res-filters{ display:flex; flex-wrap:wrap; gap:8px; align-items:center; }
.res-toolbar .res-rangelbl{ font-size:.76rem; font-weight:700; color:#0E8A66; }
.res-toolbar .res-clear{ border:1px solid #E0CFCF; background:#fff; color:#C4574A; font-weight:700; font-size:.76rem; border-radius:9px; padding:6px 10px; cursor:pointer; }
.res-period{ display:flex; gap:3px; background:rgba(255,255,255,.6); border:1px solid #D3E0D8; border-radius:11px; padding:3px; align-items:center; flex:none; }
.res-period button{ border:none; background:transparent; color:#7B9488; font-family:inherit; font-weight:700; font-size:.82rem; padding:7px 14px; border-radius:8px; cursor:pointer; transition:.15s; }
.res-period button:hover{ color:#0E8A66; }
.res-period button.on{ background:#fff; color:#0E8A66; font-weight:800; box-shadow:0 1px 2px rgba(20,120,110,.15); }
.res-detail-btn{ color:#9DB3A8 !important; font-weight:700 !important; font-size:.78rem !important; }
.res-detail-btn:hover{ color:#0E8A66 !important; }
.res-detail-on .res-detail-btn{ background:#E8F0EC !important; color:#0E8A66 !important; }
#resMk{ margin-top:18px; }
.rmk-grid{ display:grid; grid-template-columns:1.7fr 1fr; gap:18px; align-items:stretch; }
.rmk-card{ background:rgba(255,255,255,.66); border:1px solid rgba(255,255,255,.85); border-radius:20px; padding:20px 22px; box-shadow:0 16px 40px -30px rgba(20,120,110,.5); }
.rmk-card h2{ font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:1.05rem; margin:0; }
.rmk-h{ display:flex; align-items:baseline; justify-content:space-between; }
.rmk-h span{ font-size:.78rem; font-weight:700; color:#7B9488; }
.rbars{ display:flex; align-items:flex-end; gap:14px; height:200px; margin-top:22px; }
.rbar-col{ flex:1; display:flex; flex-direction:column; align-items:center; justify-content:flex-end; height:100%; gap:8px; }
.rbar-v{ font-size:.72rem; font-weight:800; color:#7B9488; }
.rbar-v.on{ color:#0E8A66; font-weight:900; }
.rbar{ width:100%; max-width:46px; border-radius:9px 9px 0 0; background:#A9E0CC; }
.rbar.grad{ background:linear-gradient(180deg,#16C2B0,#1FB58A); }
.rbar-l{ font-size:.72rem; font-weight:700; color:#9DB3A8; }
.rbar-l.on{ color:#0E8A66; font-weight:800; }
.rch-row{ display:flex; justify-content:space-between; font-size:.84rem; font-weight:700; margin-bottom:5px; }
.rch-lbl{ display:flex; align-items:center; gap:7px; }
.rch-lbl i{ width:10px; height:10px; border-radius:3px; display:inline-block; }
.rch-bar{ height:8px; border-radius:99px; background:#E4EDE8; overflow:hidden; }
.rch-bar div{ height:100%; border-radius:99px; }
.rch-donut{ margin-top:18px; padding-top:16px; border-top:1px solid #E4EDE8; display:flex; align-items:center; gap:12px; }
.rdonut{ position:relative; width:58px; height:58px; flex:none; border-radius:50%; display:flex; align-items:center; justify-content:center; }
.rdonut::after{ content:''; position:absolute; inset:9px; border-radius:50%; background:rgba(255,255,255,.96); }
.rdonut span{ position:relative; z-index:1; font-weight:800; font-size:.92rem; color:#0E8A66; }
.rch-donut b{ font-size:.84rem; font-weight:800; display:block; }
.rch-donut small{ font-size:.78rem; color:#7B9488; }
.rmk-banner{ margin-top:18px; background:linear-gradient(135deg,#0E3A30,#08241D); border-radius:20px; padding:22px 24px; color:#fff; box-shadow:0 20px 44px -26px rgba(8,36,29,.7); position:relative; overflow:hidden; }
.rmk-bglow{ position:absolute; top:-40px; right:-30px; width:180px; height:180px; border-radius:50%; background:var(--au-grad); opacity:.3; filter:blur(24px); }
.rmk-bcontent{ position:relative; display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.rmk-beye{ font-size:.72rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:#7FE3C0; }
.rmk-bbig{ font-size:1.5rem; font-weight:800; letter-spacing:-.02em; margin-top:4px; }
.rmk-bstats{ margin-left:auto; display:flex; gap:24px; }
.rmk-bstats b{ font-size:1.7rem; font-weight:900; letter-spacing:-.03em; color:#9FE3C8; display:block; line-height:1; }
.rmk-bstats span{ font-size:.72rem; color:#9FE3C8; }
/* === Evolución de ingresos: historial + PREVISIÓN (punteada) + IA (toggle) === */
.ev-card .rmk-h{ display:flex; align-items:center; justify-content:space-between; }
.ev-toggle{ display:inline-flex; align-items:center; gap:7px; background:#fff; border:1px solid #D3E0D8; color:#5C7167; font-family:inherit; font-weight:700; font-size:.78rem; padding:6px 12px; border-radius:99px; cursor:pointer; transition:.14s; }
.ev-toggle:hover{ border-color:#9FD3C2; color:#0E8A66; transform:translateY(-1px); }
.ev-toggle .ev-dot{ width:9px; height:9px; border-radius:50%; background:#CDE7DC; }
.ev-toggle.on{ background:rgba(31,181,138,.1); border-color:rgba(31,181,138,.4); color:#0E8A66; }
.ev-toggle.on .ev-dot{ background:#16C2B0; }
.ev-bars{ display:flex; align-items:flex-end; gap:8px; height:172px; margin-top:18px; }
.ev-col{ flex:1; display:flex; flex-direction:column; align-items:center; justify-content:flex-end; height:100%; gap:6px; min-width:0; }
.ev-v{ font-size:.64rem; font-weight:800; color:#7B9488; font-variant-numeric:tabular-nums; }
.ev-v.fc{ color:#9DB3A8; }
.ev-bar{ position:relative; width:100%; max-width:32px; border-radius:7px 7px 0 0; background:#CDE7DC; overflow:hidden; transition:height .35s cubic-bezier(.2,.8,.25,1); }
.ev-bar.fc{ background:repeating-linear-gradient(135deg,#E4F0EA,#E4F0EA 4px,#EEF5F1 4px,#EEF5F1 8px); border:1.5px dashed #B6D8C9; }
.ev-ia{ position:absolute; left:0; right:0; bottom:0; background:linear-gradient(180deg,#16C2B0,#1FB58A); }
.ev-l{ font-size:.66rem; font-weight:700; color:#9DB3A8; white-space:nowrap; }
.ev-l.fc{ color:#B6C7BE; font-style:italic; }
.ev-fc-note{ margin-top:14px; padding-top:12px; border-top:1px solid #E4EDE8; font-size:.82rem; color:#5C7167; font-weight:600; }
.ev-fc-note b{ color:#0E8A66; font-weight:900; font-size:.95rem; }
.ev-range{ color:#7B9488; font-weight:600; }
.ev-warn{ color:#9a7400; font-weight:600; }
.ev-leg i{ display:inline-block; width:9px; height:9px; border-radius:3px; margin:0 3px; }
.ev-leg .lg-tot{ background:#CDE7DC; } .ev-leg .lg-ia{ background:#16C2B0; }
/* === Resultados reimaginado: bloques de valor === */
.rmk-grid-eq{ grid-template-columns:1fr 1fr; }
@media(max-width:900px){ .rmk-grid-eq{ grid-template-columns:1fr; } }
.rmk-card h2{ font-family:'Hanken Grotesk',sans-serif; font-weight:800; font-size:1.05rem; margin:0; letter-spacing:-.01em; }
/* ¿Vuelven tus clientes? */
.vb-big{ display:flex; align-items:baseline; gap:10px; margin:8px 0 16px; }
.vb-pct{ font-family:'Hanken Grotesk',sans-serif; font-size:2.4rem; font-weight:800; letter-spacing:-.03em; line-height:1; }
.vb-lbl{ font-size:.9rem; color:#5C7167; font-weight:600; }
.vb-stats{ display:flex; gap:10px; }
.vb-stats > div{ flex:1; background:rgba(244,249,246,.7); border:1px solid #E4EDE8; border-radius:12px; padding:11px 10px; text-align:center; }
.vb-stats b{ display:block; font-size:1.05rem; font-weight:800; color:#1E2A28; }
.vb-stats span{ font-size:.68rem; color:#7B9488; font-weight:600; }
.vb-action{ margin-top:14px; padding:11px 14px; border-radius:12px; background:rgba(225,165,61,.1); border:1px solid rgba(225,165,61,.3); font-size:.84rem; color:#7a5a12; font-weight:600; line-height:1.4; }
.vb-action b{ color:#946a10; font-weight:900; }
.vb-action.ok{ background:rgba(31,181,138,.08); border-color:rgba(31,181,138,.25); color:#0E8A66; }
/* Servicios + carga (barras horizontales) */
.sv-list{ display:flex; flex-direction:column; gap:13px; margin-top:8px; }
.sv-row .sv-top{ display:flex; justify-content:space-between; gap:8px; font-size:.84rem; margin-bottom:5px; }
.sv-n{ font-weight:700; color:#1E2A28; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.sv-rev{ font-weight:800; color:#0E8A66; flex:none; }
.sv-bar{ height:8px; border-radius:99px; background:#EAF1EC; overflow:hidden; }
.sv-bar > div{ height:100%; border-radius:99px; background:#CDE7DC; }
.sv-bar > div.sv-first{ background:linear-gradient(90deg,#16C2B0,#1FB58A); }
.sv-empty{ color:#9DB3A8; font-size:.86rem; padding:12px 0; }
/* Operativa */
.op-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:10px; }
.op-stat{ display:flex; align-items:center; gap:12px; background:rgba(244,249,246,.7); border:1px solid #E4EDE8; border-radius:14px; padding:14px; }
.op-ring{ position:relative; width:52px; height:52px; flex:none; border-radius:50%; display:flex; align-items:center; justify-content:center; }
.op-ring::after{ content:''; position:absolute; inset:8px; border-radius:50%; background:#fff; }
.op-ring i{ position:relative; z-index:1; font-style:normal; font-weight:800; font-size:.78rem; color:#0E8A66; }
.op-num{ font-size:1.4rem; font-weight:800; color:#1E2A28; letter-spacing:-.02em; }
.op-stat b{ display:block; font-size:.9rem; font-weight:800; color:#1E2A28; }
.op-stat span{ font-size:.7rem; color:#7B9488; font-weight:600; }
.op-staff{ margin-top:16px; padding-top:14px; border-top:1px solid #E4EDE8; }
.op-staff-t{ font-size:.76rem; font-weight:700; color:#7B9488; text-transform:uppercase; letter-spacing:.04em; margin-bottom:12px; }
@media(max-width:760px){ .op-grid{ grid-template-columns:1fr; } }
/* contexto + claridad + dinamismo */
.rmk-h .rmk-sub{ font-size:.74rem; font-weight:700; color:#9DB3A8; }
.op-word{ font-size:1.15rem; font-weight:800; color:#0E8A66; letter-spacing:-.01em; }
.vb-empty{ background:rgba(244,249,246,.7); border:1px dashed #C9DDD3; border-radius:12px; padding:16px; font-size:.86rem; color:#5C7167; line-height:1.5; margin-top:4px; }
@keyframes rmkIn{ from{ opacity:0; transform:translateY(8px); } to{ opacity:1; transform:translateY(0); } }
.rmk-card{ animation:rmkIn .34s cubic-bezier(.2,.8,.25,1) both; }
/* === Titular inteligente === */
.res-titular{ position:relative; overflow:hidden; display:flex; gap:0; align-items:stretch; background:linear-gradient(150deg,#0E3A30,#08241D); color:#fff; border-radius:20px; padding:20px 24px 20px 0; margin-bottom:18px; box-shadow:0 22px 50px -28px rgba(8,36,29,.85); animation:rmkIn .34s ease both; }
.res-titular:empty{ display:none; }
.res-titular::after{ content:''; position:absolute; top:-60%; right:-6%; width:260px; height:220%; background:radial-gradient(circle, rgba(31,181,138,.22), transparent 62%); pointer-events:none; }
.res-titular .rt-rail{ flex:none; width:4px; border-radius:0 4px 4px 0; background:var(--au-grad); background-size:300% 100%; background-position:0% 50%; }
.res-titular:hover .rt-rail{ animation:auFlow 4s linear infinite; }
.res-titular .rt-body{ position:relative; padding-left:22px; }
.res-titular .rt-eye{ font-size:.67rem; font-weight:800; letter-spacing:.16em; text-transform:uppercase; color:#6FD9B8; margin-bottom:8px; }
.res-titular .rt-text{ margin:0; font-size:1.12rem; font-weight:600; line-height:1.5; letter-spacing:-.011em; color:#EAF6F1; max-width:64ch; }
.res-titular .rt-text b{ color:#8DE8C6; font-weight:800; }
/* === KPI: sparkline + chips de comparación/benchmark === */
.rk-spark{ display:flex; align-items:flex-end; gap:3px; height:26px; margin-top:10px; }
.rk-spark i{ flex:1; background:linear-gradient(180deg,#9AD15A,#16C2B0); border-radius:2px 2px 0 0; min-height:2px; opacity:.8; }
.rk-cmp{ font-weight:800; font-size:.78rem; }
.rk-cmp.up{ color:#0E8A66; } .rk-cmp.dn{ color:#C4574A; }
.rk-bench{ font-weight:700; font-size:.76rem; }
.rk-bench.ok{ color:#0E8A66; } .rk-bench.bad{ color:#C98A2B; }
.rk-bench::before{ content:'\25CF'; font-size:.58em; vertical-align:1px; margin-right:5px; }
.rk-bench.ok::before{ color:#16C2B0; } .rk-bench.bad::before{ color:#E1A53D; }
.rk2-n, .vb-pct, .sv-rev, .op-num, .ev-v, .bmk-lbls, .rk-cmp{ font-variant-numeric:tabular-nums; }
/* === Barra de benchmark (¿Vuelven?) === */
.bmk{ margin:6px 0 16px; }
.bmk-bar{ position:relative; height:10px; border-radius:99px; background:#E4EDE8; }
.bmk-fill{ position:absolute; left:0; top:0; bottom:0; border-radius:99px; background:linear-gradient(90deg,#E1A53D,#E8B85A); }
.bmk-fill.ok{ background:linear-gradient(90deg,#16C2B0,#1FB58A); }
.bmk-tick{ position:absolute; top:-3px; width:2px; height:16px; background:#5C7167; border-radius:2px; transform:translateX(-1px); }
.bmk-tick.top{ background:#0E8A66; }
.bmk-lbls{ display:flex; justify-content:space-between; margin-top:7px; font-size:.72rem; font-weight:700; color:#7B9488; }
/* === Necesita tu atención === */
.at-list{ display:flex; flex-direction:column; gap:9px; margin-top:12px; }
.at-row{ display:flex; align-items:center; gap:13px; background:#fff; border:1px solid #ECEFEC; border-left:3px solid #C9D6CF; border-radius:13px; padding:10px 12px 10px 13px; transition:transform .14s, box-shadow .14s; }
.at-row:hover{ transform:translateY(-1px); box-shadow:0 12px 26px -18px rgba(20,120,110,.5); }
.at-row.sev-warn{ border-left-color:#E1A53D; } .at-row.sev-bad{ border-left-color:#C4574A; } .at-row.sev-info{ border-left-color:#16C2B0; }
.at-ic{ flex:none; width:34px; height:34px; border-radius:10px; display:flex; align-items:center; justify-content:center; background:#F2F6F3; color:#0E8A66; }
.at-row.sev-warn .at-ic{ background:rgba(225,165,61,.13); color:#B5821F; } .at-row.sev-bad .at-ic{ background:rgba(196,87,74,.12); color:#C4574A; } .at-row.sev-info .at-ic{ background:rgba(22,194,176,.13); color:#0E8A66; }
.at-ic .hi{ width:18px; height:18px; }
.at-t{ flex:1; font-size:.88rem; font-weight:600; color:#2A3633; }
.at-t b{ color:#1E2A28; font-weight:900; }
.at-a{ flex:none; border:1px solid #D3E0D8; background:#fff; color:#0E8A66; font-family:inherit; font-weight:800; font-size:.77rem; padding:7px 13px; border-radius:9px; cursor:pointer; transition:.14s; white-space:nowrap; }
.at-a:hover{ background:#0E8A66; color:#fff; border-color:#0E8A66; transform:translateY(-1px); }
.at-ok{ display:flex; align-items:center; gap:9px; margin-top:8px; padding:14px; border-radius:12px; background:rgba(31,181,138,.08); border:1px solid rgba(31,181,138,.25); color:#0E8A66; font-weight:700; }
.at-ok .hi{ width:18px; height:18px; flex:none; }
@media(max-width:900px){ .rmk-grid{ grid-template-columns:1fr; } .rmk-bstats{ margin-left:0; } }
/* pulido fino Resultados */
#sub-res .res-title{ padding-left:0 !important; }
#sub-res .res-title::before{ display:none !important; }
#sub-res .res-head{ align-items:flex-start !important; }
#sub-res .res-title h1{ font-size:1.9rem; }
.rch-donut small{ display:block; margin-top:1px; }
.rch-donut > div:last-child{ min-width:0; }
.rbar{ transition:height .2s; }
.rmk-banner{ align-items:center; }
/* espaciado de tarjetas consistente (18px en todo Resultados) */
.res-kpis-mk{ gap:18px !important; margin-bottom:0 !important; }

/* === Aurora · más presencia del HOVER en botones (se mueven, con criterio) === */
.btn-primary{ transition:transform .15s cubic-bezier(.2,.8,.25,1), filter .15s, box-shadow .15s; }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 16px 30px -12px rgba(25,166,176,.65) !important; }
.btn-primary:active{ transform:translateY(0); }
.btn-ghost{ transition:transform .14s cubic-bezier(.2,.8,.25,1), border-color .14s, background .14s, color .14s; }
.btn-ghost:hover{ transform:translateY(-1px); border-color:rgba(31,181,138,.5) !important; color:#0E8A66 !important; }
.btn-ghost:active{ transform:translateY(0); }
.res-detail-btn:hover{ transform:translateY(-1px); }
/* Resultados (detalle): espaciado consistente entre secciones (arregla tarjetas pegadas) */
#sub-res .wrap > .res-charts, #sub-res .wrap > .card.sbox, #sub-res .wrap > .res-grid2, #sub-res .wrap > .res-loalai, #sub-res .wrap > .res-filterbar{ margin-bottom:18px !important; }
/* Heatmap "Cuándo tienes más trabajo" · 4 modos (Día/Semana/Mes/Año) */
.res-heat-card .sbox-h{ display:flex; align-items:center; gap:12px; }
.heat-modes{ margin-left:auto; display:flex; gap:3px; background:rgba(255,255,255,.6); border:1px solid #D3E0D8; border-radius:10px; padding:3px; flex:none; }
.heat-modes button{ border:none; background:transparent; color:#7B9488; font-family:inherit; font-weight:700; font-size:.78rem; padding:6px 12px; border-radius:7px; cursor:pointer; transition:.14s; }
.heat-modes button:hover{ color:#0E8A66; }
.heat-modes button.on{ background:#fff; color:#0E8A66; font-weight:800; box-shadow:0 1px 2px rgba(20,120,110,.15); }
/* "Cuándo tienes más trabajo": titular en claro + barras (punta resaltada) */
.wt-headline{ display:flex; align-items:baseline; gap:8px; margin:8px 0 2px; flex-wrap:wrap; }
.wt-h-eye{ font-size:.82rem; font-weight:700; color:#7B9488; }
.wt-h-peak{ font-family:'Hanken Grotesk',sans-serif; font-size:1.3rem; font-weight:800; color:#0E8A66; letter-spacing:-.02em; text-transform:capitalize; }
.wt-bars{ display:flex; align-items:flex-end; gap:8px; height:150px; margin-top:16px; }
.wt-col{ flex:1; display:flex; flex-direction:column; align-items:center; justify-content:flex-end; height:100%; gap:6px; min-width:0; }
.wt-v{ font-size:.7rem; font-weight:800; color:#9DB3A8; font-variant-numeric:tabular-nums; }
.wt-v.on{ color:#0E8A66; }
.wt-bar{ width:100%; max-width:36px; border-radius:8px 8px 0 0; background:#CDE7DC; transition:height .35s cubic-bezier(.2,.8,.25,1); }
.wt-bar.on{ background:linear-gradient(180deg,#16C2B0,#1FB58A); box-shadow:0 8px 16px -7px rgba(25,166,176,.5); }
.wt-l{ font-size:.7rem; font-weight:700; color:#9DB3A8; white-space:nowrap; }
.wt-l.on{ color:#0E8A66; font-weight:800; }
.biz-card.add-card{ border:1.5px dashed rgba(31,181,138,.5) !important; background:rgba(255,255,255,.32) !important; }
.biz-card.add-card{ gap:10px; }
.biz-card.add-card .plus{ position:relative; overflow:hidden; isolation:isolate;
  width:48px; height:48px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:1.6rem; line-height:1; color:#06231C !important; margin-bottom:2px; }
.biz-card.add-card .plus::before{ content:''; position:absolute; inset:0; z-index:-1; background:var(--au-grad); background-size:320% 100%; background-position:0% 50%; }
.biz-card.add-card:hover .plus::before{ animation:auFlow 3s linear infinite; }

/* ============================================================
   Resultados · HÉROE "trayectoria de ingresos + previsión" (v8 · A)
   ============================================================ */
.res-titular{ background:none !important; border:none !important; padding:0 !important; margin:0 0 14px !important; box-shadow:none !important; display:block !important; overflow:visible !important; }
.res-titular::after{ display:none !important; }
.rhero{ position:relative; overflow:hidden; background:linear-gradient(157deg,#10433A,#0A2A22 64%,#072019); border-radius:24px; padding:26px 28px 12px; color:#EAF6F0; box-shadow:0 34px 70px -34px rgba(7,40,32,.85); animation:rmkIn .34s ease both; }
.rhero::after{ content:''; position:absolute; width:460px; height:460px; right:-150px; top:-190px; border-radius:50%; background:radial-gradient(circle,rgba(54,200,194,.30),transparent 68%); pointer-events:none; }
.rhero .rh-rail{ position:absolute; left:0; top:0; bottom:0; width:6px; background:var(--au-grad); background-size:100% 320%; animation:auFlow 9s linear infinite; }
.rh-top{ position:relative; z-index:2; display:flex; align-items:flex-end; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.rh-eye{ font-size:.7rem; font-weight:800; letter-spacing:.15em; text-transform:uppercase; color:#8FE6CE; }
.rh-big{ font-size:3.1rem; font-weight:900; line-height:.9; letter-spacing:-.03em; margin-top:9px; color:#fff; font-variant-numeric:tabular-nums; }
.rh-sub{ font-size:.92rem; color:#9FCFC0; font-weight:600; margin-top:9px; }
.rh-sub b{ color:#fff; }
.rh-right{ display:flex; flex-direction:column; align-items:flex-end; gap:13px; }
.rh-proj{ text-align:right; }
.rh-pe{ font-size:.68rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:#7FB8A8; }
.rh-pv{ font-size:1.8rem; font-weight:800; color:#9AD15A; letter-spacing:-.02em; font-variant-numeric:tabular-nums; }
.rh-pr{ font-size:.73rem; color:#7FB8A8; font-weight:600; }
.rh-cta{ position:relative; overflow:hidden; isolation:isolate; border:none; cursor:pointer; color:#06231C; font-family:inherit; font-weight:800; font-size:.85rem; padding:11px 17px; border-radius:12px; display:inline-flex; align-items:center; gap:8px; box-shadow:0 14px 28px -12px rgba(25,166,176,.7); }
.rh-cta::before{ content:''; position:absolute; inset:0; z-index:-1; background:var(--au-grad); background-size:320% 100%; }
.rh-cta:hover::before{ animation:auFlow 3s linear infinite; }
.rh-cta:hover{ filter:brightness(1.04); }
.rh-cta svg{ width:16px; height:16px; }
.rh-chart{ position:relative; z-index:2; margin-top:6px; }
.rh-chart svg{ width:100%; height:188px; display:block; overflow:visible; }
.rh-xlab{ display:flex; justify-content:space-between; margin-top:2px; padding:0 2px; }
.rh-xlab span{ font-size:.67rem; font-weight:700; color:#7FB8A8; }
.rh-xlab span.fc{ color:#9AD15A; }
/* héroe · gráfica Chart.js interactiva + toggle de granularidad */
.rh-chartwrap{ position:relative; z-index:2; margin-top:14px; }
.rh-grantabs{ display:flex; justify-content:flex-end; gap:3px; margin-bottom:8px; }
.rh-grantabs button{ border:none; background:rgba(255,255,255,.08); color:#9FCFC0; font-family:inherit; font-weight:700; font-size:.7rem; padding:5px 11px; border-radius:8px; cursor:pointer; transition:.14s; }
.rh-grantabs button:hover{ background:rgba(255,255,255,.16); color:#EAF6F0; }
.rh-grantabs button.on{ background:#9AD15A; color:#06231C; }
.rh-chart2{ position:relative; height:150px; }

/* ============================================================
   Resultados · COMPARATIVAS (periodos · equipo · servicios)
   ============================================================ */
.res-compara{ margin:6px 0 18px; }
.cmp-head{ display:flex; align-items:center; gap:12px; margin:26px 0 14px; }
.cmp-head h2{ font-size:1.35rem; font-weight:800; letter-spacing:-.02em; margin:0; }
.cmp-head .cmp-sub{ display:block; font-size:.78rem; font-weight:600; color:#86998F; margin-top:1px; }
.cmp-card{ margin-bottom:14px; }
.cmp-bar{ display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; }
.cmp-views{ display:inline-flex; flex-wrap:wrap; background:#EAF2EE; border:1px solid rgba(20,70,58,.10); border-radius:12px; padding:4px; gap:3px; }
.cmp-views button{ border:none; background:transparent; font-family:inherit; font-weight:800; font-size:.86rem; color:#5C726A; padding:9px 18px; border-radius:9px; cursor:pointer; transition:.15s; }
.cmp-views button:hover{ color:#15302A; }
.cmp-views button.on{ color:#06231C; position:relative; overflow:hidden; isolation:isolate; box-shadow:0 6px 16px -10px rgba(20,120,110,.5); }
.cmp-views button.on::before{ content:''; position:absolute; inset:0; z-index:-1; background:var(--au-grad); background-size:320% 100%; }
.cmp-views button.on:hover::before{ animation:auFlow 3s linear infinite; }
.cmp-filters{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.cmp-mode{ display:inline-flex; background:#0E3A30; border-radius:10px; padding:3px; gap:2px; }
.cmp-mode button{ border:none; background:transparent; font-family:inherit; font-weight:700; font-size:.76rem; color:#9FCFC0; padding:6px 13px; border-radius:7px; cursor:pointer; transition:.14s; }
.cmp-mode button.on{ background:#9AD15A; color:#06231C; }
.cmp-daterange{ display:flex; align-items:center; gap:7px; flex-wrap:wrap; }
.cmp-daterange input[type=date]{ width:auto; font-size:.8rem; font-weight:600; padding:7px 10px; border-radius:9px; border:1px solid rgba(20,70,58,.14); background:#fff; }
.cmp-daterange .cmp-arrow{ color:#86998F; font-weight:800; }
.cmp-daterange .btn.mini{ padding:7px 14px; font-size:.78rem; }
.cmp-rowlink{ cursor:pointer; transition:background .14s; }
.cmp-rowlink:hover td{ background:rgba(31,181,138,.06); }
.cmp-rowlink:hover td.best{ background:rgba(31,181,138,.14); }
.cmp-ctrl{ display:flex; align-items:center; gap:8px; }
.cmp-lbl{ font-size:.68rem; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:#86998F; }
.cmp-ctrl select{ width:auto; min-width:0; font-weight:700; font-size:.82rem; padding:8px 12px; border-radius:10px; background:#F4F9F6; border:1px solid rgba(20,70,58,.12); color:#15302A; cursor:pointer; }
.cmp-tabs{ display:inline-flex; background:#F4F9F6; border:1px solid rgba(20,70,58,.10); border-radius:10px; padding:3px; gap:2px; flex-wrap:wrap; }
.cmp-tabs button{ border:none; background:transparent; font-family:inherit; font-weight:700; font-size:.76rem; color:#5C726A; padding:6px 11px; border-radius:7px; cursor:pointer; transition:.14s; }
.cmp-tabs button.on{ background:#0E9E70; color:#fff; }
.cmp-legend{ display:flex; gap:16px; margin-top:12px; flex-wrap:wrap; }
.cmp-legend span{ display:inline-flex; align-items:center; gap:7px; font-size:.8rem; font-weight:700; color:#5C726A; }
.cmp-legend i{ width:16px; height:4px; border-radius:2px; }
.cmp-legend i.dash{ background:repeating-linear-gradient(90deg,#9DB3A8,#9DB3A8 4px,transparent 4px,transparent 7px); height:3px; }
.cmp-delta{ display:flex; gap:12px; flex-wrap:wrap; margin-top:14px; }
.cmp-delta .d{ flex:1; min-width:130px; background:#F4F9F6; border-radius:13px; padding:12px 14px; }
.cmp-delta .de{ font-size:.66rem; font-weight:800; text-transform:uppercase; letter-spacing:.06em; color:#86998F; }
.cmp-delta .dv{ font-size:1.32rem; font-weight:800; font-variant-numeric:tabular-nums; margin-top:2px; }
.cmp-delta .dc{ font-size:.74rem; font-weight:800; margin-top:1px; }
.cmp-delta .up,.cmp-table .up{ color:#0B7A53; } .cmp-delta .dn,.cmp-table .dn{ color:#B24B3E; }
.cmp-chips{ display:flex; gap:8px; flex-wrap:wrap; }
.cmp-chips .wchip{ border:1.5px solid rgba(20,70,58,.14); background:#F4F9F6; font-family:inherit; font-weight:700; font-size:.82rem; color:#5C726A; padding:7px 14px 7px 11px; border-radius:999px; cursor:pointer; display:inline-flex; align-items:center; gap:8px; transition:.15s; }
.cmp-chips .wchip .wd{ width:10px; height:10px; border-radius:50%; background:var(--c); }
.cmp-chips .wchip.on{ border-color:var(--c); background:#fff; color:#15302A; box-shadow:0 6px 16px -10px var(--c); }
.cmp-chips .wchip.off{ opacity:.45; }
.cmp-table{ width:100%; border-collapse:collapse; margin-top:18px; font-size:.88rem; }
.cmp-table th{ text-align:right; font-size:.66rem; font-weight:800; letter-spacing:.05em; text-transform:uppercase; color:#86998F; padding:9px 12px; border-bottom:2px solid rgba(20,70,58,.12); }
.cmp-table th:first-child{ text-align:left; }
.cmp-table td{ padding:11px 12px; border-bottom:1px solid rgba(20,70,58,.08); text-align:right; font-weight:700; font-variant-numeric:tabular-nums; color:#15302A; }
.cmp-table td:first-child{ text-align:left; }
.cmp-table .wcell{ display:inline-flex; align-items:center; gap:9px; }
.cmp-table .wdot{ width:11px; height:11px; border-radius:50%; flex:none; }
.cmp-table td.best{ color:#0B7A53; background:rgba(31,181,138,.08); }
.cmp-table td.best::after{ content:' ★'; font-size:.7rem; }
.cmp-empty{ color:#86998F; font-weight:600; padding:16px 0; text-align:center; }
@media(max-width:760px){ .rh-big{ font-size:2.4rem; } .rh-right{ align-items:flex-start; } }
/* drawer · barra de benchmark (retención) */
.dw-bmk{ margin:4px 0 16px; }
.dw-bmkbar{ position:relative; height:11px; border-radius:6px; background:rgba(20,70,58,.1); }
.dw-bmkbar .f{ display:block; height:100%; border-radius:6px; background:linear-gradient(90deg,#36C8C2,#0E9E70); }
.dw-bmkbar .t{ position:absolute; top:-4px; width:2px; height:19px; background:#86998F; border-radius:2px; }
.dw-bmkbar .t.top{ background:#C8A23D; }
.dw-bmkl{ display:flex; justify-content:space-between; margin-top:9px; font-size:.7rem; font-weight:700; color:#86998F; }

/* ============================================================
   Resultados · PRO · cabecera con periodo arriba-izquierda + mural de gráficas
   ============================================================ */
.res-head2{ display:flex; align-items:flex-start; justify-content:space-between; gap:18px; flex-wrap:wrap; margin-bottom:14px; }
.res-eyebrow2{ font-size:.7rem; font-weight:800; letter-spacing:.13em; text-transform:uppercase; color:#86998F; }
.res-head2 h1{ font-size:2.1rem; font-weight:800; letter-spacing:-.035em; margin:3px 0 4px; }
.res-sub2{ font-size:.9rem; color:#5C726A; font-weight:500; margin:0 0 13px; }
.res-period2{ display:inline-flex; flex-wrap:wrap; gap:4px; background:#fff; border:1px solid rgba(20,70,58,.10); border-radius:14px; padding:5px; box-shadow:0 18px 40px -26px rgba(16,80,66,.45); }
.res-period2 button{ border:none; background:transparent; font-family:inherit; font-weight:700; font-size:.81rem; color:#5C726A; padding:8px 14px; border-radius:10px; cursor:pointer; transition:.15s; }
.res-period2 button:hover{ background:#F4F9F6; color:#15302A; }
.res-period2 button.on{ color:#06231C; position:relative; overflow:hidden; isolation:isolate; }
.res-period2 button.on::before{ content:''; position:absolute; inset:0; z-index:-1; background:var(--au-grad); background-size:320% 100%; }
.res-period2 button.on:hover::before{ animation:auFlow 3s linear infinite; }
.res-daterange{ margin-top:10px; display:flex; gap:10px; align-items:flex-end; flex-wrap:wrap; }
.res-hright{ display:flex; flex-direction:column; align-items:flex-end; gap:10px; }
.res-hright .res-bizpick{ display:inline-flex; align-items:center; gap:8px; background:#fff; border:1px solid rgba(20,70,58,.10); border-radius:999px; padding:7px 10px 7px 14px; box-shadow:0 18px 40px -26px rgba(16,80,66,.45); }
.res-hright .res-bizpick .res-cl{ font-size:.7rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:#86998F; }
.res-hright .res-bizpick select{ border:none; background:transparent; font-family:inherit; font-weight:700; font-size:.86rem; color:#15302A; cursor:pointer; }
.res-live{ display:inline-flex; align-items:center; gap:7px; font-size:.7rem; font-weight:800; letter-spacing:.05em; color:#0E9E70; }
.res-livepulse{ width:7px; height:7px; border-radius:50%; background:#16C2B0; box-shadow:0 0 0 0 rgba(31,181,138,.5); animation:resPulse 2s infinite; }
@keyframes resPulse{ 0%,100%{ box-shadow:0 0 0 0 rgba(31,181,138,.5); } 50%{ box-shadow:0 0 0 6px rgba(31,181,138,0); } }
.res-filters2{ display:flex; align-items:center; gap:9px; flex-wrap:wrap; margin-bottom:16px; padding:4px 2px; }
.res-filters2 .res-f2ic{ width:18px; height:18px; stroke:#86998F; flex:none; }
.res-filters2 select{ width:auto; min-width:0; font-size:.82rem; font-weight:600; padding:8px 12px; border-radius:10px; background:#fff; border:1px solid rgba(20,70,58,.12); color:#15302A; box-shadow:0 10px 26px -22px rgba(16,80,66,.5); cursor:pointer; }
.res-filters2 .res-clear{ border:none; background:#15302A; color:#fff; font-weight:700; font-size:.76rem; padding:8px 13px; border-radius:9px; cursor:pointer; }
.res-filters2 .res-rangelbl{ font-size:.74rem; font-weight:600; color:#86998F; margin-left:auto; }
/* MURAL */
.res-evocard{ margin-top:16px; }
.res-evocard .chart-tall{ height:300px; }
.res-mural{ display:grid; grid-template-columns:repeat(6,1fr); gap:16px; margin:16px 0 18px; }
.res-mural .sbox{ min-width:0; margin:0 !important; }
.mu-wide{ grid-column:span 4; }
.mu-half{ grid-column:span 3; }
.mu-third{ grid-column:span 2; }
.mu-full{ grid-column:span 6; }
@media(max-width:980px){ .res-mural{ grid-template-columns:repeat(2,1fr); } .mu-wide,.mu-half,.mu-third,.mu-full{ grid-column:span 2; } }
@media(max-width:620px){ .res-mural{ grid-template-columns:1fr; } .mu-wide,.mu-half,.mu-third,.mu-full{ grid-column:auto; } }
/* tooltip flotante (hover muestra info) */
.res-tip{ position:fixed; z-index:9999; pointer-events:none; background:#0A2A22; color:#EAF6F0; border-radius:11px; padding:10px 13px; font-size:.78rem; font-weight:600; line-height:1.45; box-shadow:0 16px 34px -14px rgba(7,40,32,.7); opacity:0; transform:translateY(4px); transition:opacity .12s, transform .12s; max-width:240px; border:1px solid rgba(255,255,255,.1); }
.res-tip.on{ opacity:1; transform:none; }
.res-tip b{ color:#9AD15A; font-weight:800; }
.res-tip .rtt-e{ font-size:.64rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:#8FE6CE; margin-bottom:3px; }
.biz-card.add-card>div:last-child{ font-weight:700; font-size:.94rem; color:#0E8A66; }