/* ═══════════════════════════════════════════════════════════════════
   styles.css — Estilos del portal
   Portal Cliente · Estudio Los Lagos · v1
   ───────────────────────────────────────────────────────────────────
   Sistema de diseño:
     Tipografías: DM Serif Display (títulos), Inter (UI), JetBrains Mono (cifras)
     Colores marca: --ink #0D1B2A · --ocean #1B4F7E · --teal #0E7C7B · --gold #C9A84C
   Todas las variables CSS están en :root (primer bloque).
   Responsive: breakpoints en 1200px, 1024px, 768px (móvil), 480px.
   ═══════════════════════════════════════════════════════════════════ */

:root{--ink:#0D1B2A;--deep:#1A2E45;--ocean:#1B4F7E;--ocean-dim:rgba(27,79,126,0.08);--teal:#0E7C7B;--teal-dim:rgba(14,124,123,0.1);--teal-glow:rgba(14,124,123,0.15);--gold:#C9A84C;--gold-dim:rgba(201,168,76,0.12);--gold-lt:#E8C97A;--red:#E53E3E;--red-dim:rgba(229,62,62,0.1);--amber:#D97706;--amber-dim:rgba(217,119,6,0.1);--green:#059669;--green-dim:rgba(5,150,105,0.1);--purple:#7C3AED;--purple-dim:rgba(124,58,237,0.1);--slate:#4A5568;--mist:#8FA3B1;--border:#D8E3ED;--surface:#F7F9FC;--cloud:#EEF2F7;--white:#FFFFFF;--sidebar-w:240px;--topbar-h:60px;--r:10px;--shadow:0 2px 12px rgba(13,27,42,0.07);--shadow-md:0 8px 28px rgba(13,27,42,0.11);--shadow-lg:0 20px 56px rgba(13,27,42,0.16);--mono:'JetBrains Mono',monospace;--sans:'Inter',sans-serif;--serif:'DM Serif Display',serif}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;height:100%;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:var(--surface);color:var(--ink);-webkit-font-smoothing:antialiased;height:100%;overflow:hidden}

/* ── Foco de teclado (a11y) ──
   Anillo de foco visible y consistente SOLO para navegación por teclado
   (:focus-visible no se dispara con el mouse, así que no afecta a quien
   hace clic — anti-regresión). Cubre los elementos interactivos que no
   son campos de formulario (botones, enlaces, ítems de menú, tabs,
   tarjetas clicables y cualquier [data-action]/[tabindex]). Los inputs
   conservan su glow propio en :focus. El outline transparente garantiza
   visibilidad en modo de alto contraste / forced-colors. */
a:focus-visible,button:focus-visible,summary:focus-visible,
[role=button]:focus-visible,[role=tab]:focus-visible,
[role=link]:focus-visible,[role=menuitem]:focus-visible,
[data-action]:focus-visible,[tabindex]:focus-visible,
.nav-item:focus-visible,.dash-tab:focus-visible,.bn-item:focus-visible{
  outline:2px solid transparent;outline-offset:2px;
  box-shadow:0 0 0 2px var(--white),0 0 0 4px var(--teal);
}
/* En superficies oscuras (sidebar/login) el halo blanco no contrasta:
   se usa el halo dorado de marca para que el foco sea siempre visible. */
.sidebar a:focus-visible,.sidebar button:focus-visible,
.sidebar .nav-item:focus-visible,.sidebar [data-action]:focus-visible,
#login-screen a:focus-visible,#login-screen button:focus-visible,
#login-screen [data-action]:focus-visible{
  box-shadow:0 0 0 2px var(--ink),0 0 0 4px var(--gold-lt);
}
/* El contenedor de contenido recibe foco programático desde el "saltar al
   contenido"; no debe mostrar el halo grande de los controles. */
#main-content:focus,#main-content:focus-visible{outline:none;box-shadow:none}

/* ── Saltar al contenido (a11y) ──
   Enlace oculto que aparece al tabular: deja a quien navega por teclado o
   con lector de pantalla brincar la barra lateral y el topbar para ir
   directo al contenido. Fuera de pantalla hasta enfocarse. */
.skip-link{position:fixed;top:0;left:0;z-index:2000;
  transform:translateY(-130%);transition:transform .18s ease;
  background:var(--ink);color:#fff;font-family:var(--sans);font-size:13px;
  font-weight:600;padding:10px 16px;border-radius:0 0 10px 0;text-decoration:none;
  box-shadow:var(--shadow-md)}
.skip-link:focus{transform:translateY(0)}
@media (prefers-reduced-motion: reduce){.skip-link{transition:none}}

/* ── LOGIN ── */
#login-screen{position:fixed;inset:0;z-index:1000;background:linear-gradient(160deg,var(--ink) 0%,#162840 45%,#0A3052 100%);display:flex;align-items:center;justify-content:center;padding:24px}
#login-screen::before{content:'';position:absolute;inset:0;background-image:radial-gradient(ellipse at 70% 20%,rgba(14,124,123,.12) 0%,transparent 60%),radial-gradient(ellipse at 20% 80%,rgba(27,79,126,.1) 0%,transparent 60%)}
.login-card{background:white;border-radius:20px;padding:44px 40px;width:100%;max-width:420px;position:relative;z-index:1;box-shadow:0 40px 80px rgba(0,0,0,.4)}
.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:32px}
.login-logo-mark{width:38px;height:38px;border-radius:9px;background:linear-gradient(135deg,var(--ocean),var(--teal));display:flex;align-items:center;justify-content:center;font-family:var(--serif);color:white;font-size:18px;flex-shrink:0}
.ln{font-size:15px;font-weight:700;color:var(--ink);line-height:1.2}.ls{font-size:11px;color:var(--mist)}
.login-title{font-family:var(--serif);font-size:26px;color:var(--ink);margin-bottom:6px}
.login-sub{font-size:13px;color:var(--slate);margin-bottom:28px;line-height:1.5}
.fld{margin-bottom:14px}
.fld label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--slate);margin-bottom:6px}
.fld input{width:100%;padding:12px 14px;border-radius:8px;border:1.5px solid var(--border);font-size:16px;color:var(--ink);font-family:var(--sans);outline:none;transition:border-color .15s;background:var(--surface);-webkit-appearance:none}
.fld input:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-glow)}
.btn-login{width:100%;padding:14px;border-radius:9px;border:none;cursor:pointer;background:linear-gradient(135deg,var(--ocean),var(--teal));color:white;font-size:15px;font-weight:700;font-family:var(--sans);box-shadow:0 4px 16px rgba(27,79,126,.35);transition:all .2s;-webkit-tap-highlight-color:transparent}
.btn-login:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(27,79,126,.4)}
.login-footer{text-align:center;margin-top:20px;font-size:12px;color:var(--mist)}
.login-footer a{color:var(--teal);text-decoration:none;font-weight:600}
.login-demo{background:var(--teal-dim);border:1px solid rgba(14,124,123,.2);border-radius:8px;padding:10px 14px;margin-bottom:20px;font-size:12px;color:var(--slate);display:flex;align-items:center;gap:8px}
.login-demo strong{color:var(--teal)}
.login-trust{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:16px;font-size:11px;color:var(--mist)}

/* ── LANDING (split hero + login) ── */
.landing{position:relative;z-index:1;display:flex;align-items:center;gap:56px;width:100%;max-width:1040px;margin:0 auto}
.landing-hero{flex:1 1 0;min-width:0;color:#fff;animation:lh-in .7s ease both}
.lh-brand{display:flex;align-items:center;gap:11px;margin-bottom:34px}
.lh-brand-mark{width:44px;height:44px;border-radius:11px;background:linear-gradient(135deg,var(--ocean),var(--teal));display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:20px;color:#fff;box-shadow:0 6px 20px rgba(14,124,123,.4);flex-shrink:0}
.lh-brand-name{font-family:var(--serif);font-size:18px;font-weight:600;letter-spacing:.2px}
.lh-brand-sub{font-size:11px;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.1em;margin-top:2px}
.lh-title{font-family:var(--serif);font-size:38px;line-height:1.14;font-weight:500;letter-spacing:-.4px;margin-bottom:18px;color:#fff}
.lh-title-accent{background:linear-gradient(100deg,var(--teal),#5ec9c8);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.lh-lead{font-size:15px;line-height:1.6;color:rgba(255,255,255,.72);max-width:460px;margin-bottom:30px}
.lh-features{display:grid;grid-template-columns:1fr 1fr;gap:16px 22px;margin-bottom:30px}
.lh-feat{display:flex;gap:11px;align-items:flex-start}
.lh-feat-ic{font-size:19px;line-height:1;flex-shrink:0;width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center}
.lh-feat-t{font-size:13.5px;font-weight:600;color:#fff;margin-bottom:2px}
.lh-feat-d{font-size:12px;line-height:1.45;color:rgba(255,255,255,.6)}
.lh-trust{display:flex;align-items:center;gap:9px;flex-wrap:wrap;font-size:11.5px;color:rgba(255,255,255,.5)}
.lh-trust-dot{color:rgba(255,255,255,.3)}
.landing .login-card{flex:0 0 420px}
@keyframes lh-in{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@media(max-width:900px){.landing{flex-direction:column;gap:30px;max-width:440px}.landing-hero{text-align:center}.lh-brand{justify-content:center}.lh-title{font-size:30px}.lh-lead{margin-left:auto;margin-right:auto}.lh-features{text-align:left;max-width:420px;margin-left:auto;margin-right:auto}.lh-trust{justify-content:center}.landing .login-card{flex:1 1 auto;width:100%}}
@media(max-width:560px){.lh-features{grid-template-columns:1fr;gap:13px}.lh-title{font-size:25px}.landing-hero .lh-lead{font-size:14px}}

/* ── APP SHELL ── */
#app{display:none;height:100vh;flex-direction:row}
#app.visible{display:flex}
.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--ink);display:flex;flex-direction:column;height:100vh;overflow:hidden;border-right:1px solid rgba(255,255,255,.05)}
.sidebar-brand{padding:18px 18px 14px;border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:10px;text-decoration:none}
.sb-mark{width:32px;height:32px;border-radius:7px;background:linear-gradient(135deg,var(--ocean),var(--teal));display:flex;align-items:center;justify-content:center;font-family:var(--serif);color:white;font-size:15px;flex-shrink:0}
.sb-name{font-size:13px;font-weight:700;color:white;line-height:1.3}.sb-sub{font-size:10px;color:rgba(255,255,255,.3)}
.sidebar-nav{flex:1;overflow-y:auto;padding:10px 10px;-webkit-overflow-scrolling:touch;position:relative}
.nav-slide-ind{position:absolute;left:0;width:3px;height:20px;background:var(--teal);border-radius:0 3px 3px 0;opacity:0;pointer-events:none;transition:top .3s cubic-bezier(.16,1,.3,1),opacity .2s;z-index:1}
.nav-group-label{font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.22);padding:14px 10px 5px}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:8px;cursor:pointer;font-size:13px;color:rgba(255,255,255,.48);transition:background .15s,color .15s;margin-bottom:2px;text-decoration:none;position:relative;-webkit-tap-highlight-color:transparent}
.nav-item:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.85)}
.nav-item:hover .nav-item-icon,.nav-item:hover>span:not(.nav-item-icon){transform:translateX(2px)}
.nav-item.active{background:rgba(255,255,255,.09);color:white}
.nav-item.active .nav-item-icon{color:var(--teal)}
.nav-item-icon{width:20px;height:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:inherit;transition:transform .18s,color .15s}
.nav-item-icon svg{width:18px;height:18px;display:block}
.nav-item>span:not(.nav-item-icon){transition:transform .18s}
.nav-badge{margin-left:auto;color:white;font-size:10px;font-weight:700;padding:2px 7px;border-radius:100px;font-family:var(--mono)}
.nb-red{background:var(--red)}.nb-amber{background:var(--amber)}.nb-teal{background:var(--teal)}.nb-gold{background:var(--gold);color:var(--ink)}.nb-purple{background:var(--purple)}
.sidebar-user{padding:12px 16px;border-top:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:10px}
.user-av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--ocean),var(--teal));display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:white;flex-shrink:0}
.user-name{font-size:12px;font-weight:600;color:white;line-height:1.3}.user-plan{font-size:10px;color:rgba(255,255,255,.32)}
.logout-btn{margin-left:auto;background:none;border:none;cursor:pointer;color:rgba(255,255,255,.28);font-size:16px;padding:8px;-webkit-tap-highlight-color:transparent;border-radius:6px;transition:color .15s ease,background .15s ease,transform .12s ease}
.logout-btn:hover{color:rgba(255,255,255,.85);background:rgba(255,255,255,.06)}
.logout-btn:active{transform:scale(.9)}

/* ── TOPBAR ── */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden}
.topbar{height:var(--topbar-h);flex-shrink:0;background:white;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:12px}
.topbar-title{font-size:16px;font-weight:700;color:var(--ink)}.topbar-sub{font-size:12px;color:var(--mist)}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.topbar-alert-btn{position:relative;background:none;border:none;cursor:pointer;font-size:19px;padding:6px;color:var(--slate);-webkit-tap-highlight-color:transparent;border-radius:7px;transition:color .15s ease,background .15s ease,transform .12s ease}
.topbar-alert-btn:hover{color:var(--ocean);background:var(--ocean-dim)}
.topbar-alert-btn:active{transform:scale(.9)}
.alert-dot{position:absolute;top:2px;right:2px;width:8px;height:8px;background:var(--red);border-radius:50%;border:2px solid white}
.topbar-date{font-size:12px;color:var(--mist);font-family:var(--mono)}
.topbar-confidential{font-size:10px;color:var(--mist);display:flex;align-items:center;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:100px;padding:4px 10px}
.content{flex:1;overflow-y:auto;padding:28px;-webkit-overflow-scrolling:touch}

/* ── BASE COMPONENTS ── */
.card{background:white;border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--shadow)}
.card-header{padding:18px 22px 0;display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:8px}
.card-title{font-size:14px;font-weight:700;color:var(--ink)}.card-sub{font-size:12px;color:var(--mist);margin-top:2px}
.card-body{padding:0 22px 20px}
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none;text-decoration:none;transition:all .15s;font-family:var(--sans);-webkit-tap-highlight-color:transparent}
.btn-sm{padding:6px 12px;font-size:12px;border-radius:6px}
.btn-xs{padding:4px 9px;font-size:11px;border-radius:5px}
.btn-primary{background:linear-gradient(135deg,var(--ocean),var(--teal));color:white;box-shadow:0 2px 8px rgba(27,79,126,.22)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(27,79,126,.32)}
.btn-ghost{background:transparent;color:var(--ocean);border:1.5px solid var(--border)}
.btn-ghost:hover{border-color:var(--ocean);background:var(--ocean-dim)}
.btn-danger{background:var(--red-dim);color:var(--red);border:1.5px solid rgba(229,62,62,.2)}
.btn-gold{background:linear-gradient(135deg,#9B7320,var(--gold));color:white;box-shadow:0 2px 8px rgba(201,168,76,.25)}
.btn-gold:hover{transform:translateY(-1px)}
.btn-purple{background:linear-gradient(135deg,#5B21B6,var(--purple));color:white;box-shadow:0 2px 8px rgba(124,58,237,.22)}
.btn-teal{background:var(--teal);color:white;box-shadow:0 2px 8px rgba(14,124,123,.22)}
.pill{display:inline-flex;align-items:center;font-size:11px;font-weight:700;padding:3px 9px;border-radius:100px;white-space:nowrap}
.pill-green{background:var(--green-dim);color:var(--green)}.pill-amber{background:var(--amber-dim);color:var(--amber)}
.pill-red{background:var(--red-dim);color:var(--red)}.pill-ocean{background:var(--ocean-dim);color:var(--ocean)}
.pill-teal{background:var(--teal-dim);color:var(--teal)}.pill-mist{background:var(--cloud);color:var(--slate)}
.pill-gold{background:var(--gold-dim);color:#7A5A10}.pill-purple{background:var(--purple-dim);color:var(--purple)}
.view{display:none}.view.active{display:block}

/* ── DASHBOARD TABS ── */
.dash-tabs{display:flex;gap:3px;margin-bottom:20px;background:var(--cloud);border-radius:12px;padding:4px;border:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.dash-tabs::-webkit-scrollbar{display:none}
.dash-tab{flex:1;padding:10px 14px;border-radius:9px;text-align:center;cursor:pointer;font-size:13px;font-weight:600;color:var(--slate);transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap;min-width:110px;-webkit-tap-highlight-color:transparent}
.dash-tab.active{background:white;color:var(--ink);box-shadow:var(--shadow)}
.dash-tab:not(.active):hover{background:rgba(255,255,255,.55);color:var(--ink)}
.tab-icon{font-size:15px}
.dash-sub-view{display:none}.dash-sub-view.active{display:block}

/* ── WELCOME BANNERS ── */
.dash-welcome{border-radius:14px;padding:24px 28px;color:white;display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;position:relative;overflow:hidden}
.dash-welcome.ocean-w{background:linear-gradient(135deg,#0F3460,var(--ocean) 60%,var(--teal))}
.dash-welcome.gold-w{background:linear-gradient(135deg,#5C3A0A,#8B6914 50%,#A07820)}
.dash-welcome.purple-w{background:linear-gradient(135deg,#3B0F8C,#5B21B6 50%,var(--purple))}
.dash-welcome::before{content:'';position:absolute;right:-60px;top:-60px;width:240px;height:240px;border-radius:50%;background:rgba(255,255,255,.05);pointer-events:none}
.dash-welcome::after{content:'';position:absolute;right:60px;bottom:-80px;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.04);pointer-events:none}
.dw-text{position:relative;z-index:1}
.dw-text h2{font-family:var(--serif);font-size:22px;margin-bottom:4px}
.dw-text p{font-size:13px;color:rgba(255,255,255,.7);max-width:420px;line-height:1.55}
.dw-actions{display:flex;gap:9px;margin-top:16px;flex-wrap:wrap}
.dw-btn{padding:7px 14px;border-radius:7px;font-size:12px;font-weight:700;font-family:var(--sans);cursor:pointer;border:none;-webkit-tap-highlight-color:transparent}
.dw-btn-light{background:rgba(255,255,255,.15);color:white;border:1px solid rgba(255,255,255,.25)}
.dw-btn-light:hover{background:rgba(255,255,255,.22)}
.dw-stat{text-align:right;position:relative;z-index:1;flex-shrink:0}
.dw-stat-val{font-family:var(--mono);font-size:32px;font-weight:600;color:white;line-height:1}
.dw-stat-lbl{font-size:11px;color:rgba(255,255,255,.5);margin-top:4px}
.dw-stat-del{font-size:11px;color:rgba(255,255,255,.75);margin-top:3px;font-weight:600}

/* ── KPI GRID ── */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.kpi-card{background:white;border:1px solid var(--border);border-radius:var(--r);padding:18px 20px;box-shadow:var(--shadow);transition:all .2s}
.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
/* Microinteracciones premium */
.btn:active{transform:scale(.97)}
.card{transition:box-shadow .2s ease,transform .2s ease}
.card:hover{box-shadow:var(--shadow-md)}
.dtbl-row:hover,.inv-row:hover,.ptbl-row:hover{background:var(--surface)}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}
.kpi-icon{font-size:20px;margin-bottom:10px;display:block}
.kpi-label{font-size:11px;color:var(--mist);margin-bottom:6px;font-weight:500;line-height:1.3}
.kpi-value{font-family:var(--mono);font-size:22px;font-weight:600;color:var(--ink);line-height:1}
.kpi-delta{font-size:11px;margin-top:5px;font-weight:600}
.delta-up{color:var(--green)}.delta-down{color:var(--red)}.delta-neutral{color:var(--mist)}
.kpi-row-6{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:22px}

/* ── DASH GRID ── */
.dash-grid{display:grid;grid-template-columns:1fr 320px;gap:18px;margin-bottom:22px}
.dash-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:22px}
.mini-chart{display:flex;align-items:flex-end;gap:4px;height:60px;padding:0 2px}
.mc-bar{flex:1;border-radius:3px 3px 0 0;background:var(--teal-dim);cursor:pointer;position:relative;transition:background .15s}
.mc-bar:hover,.mc-bar.cur{background:var(--teal)}
.mc-bar.gold-bar{background:var(--gold-dim)}.mc-bar.gold-bar:hover,.mc-bar.gold-bar.cur{background:var(--gold)}
.mc-bar.purple-bar{background:var(--purple-dim)}.mc-bar.purple-bar:hover,.mc-bar.purple-bar.cur{background:var(--purple)}
.mc-bar.ocean-bar{background:var(--ocean-dim)}.mc-bar.ocean-bar:hover,.mc-bar.ocean-bar.cur{background:var(--ocean)}
.mc-tooltip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--ink);color:white;font-size:10px;padding:4px 8px;border-radius:5px;white-space:nowrap;display:none;font-family:var(--mono);z-index:10}
.mc-bar:hover .mc-tooltip{display:block}
.mc-labels{display:flex;gap:4px;margin-top:6px}
.mc-label{flex:1;text-align:center;font-size:9px;color:var(--mist);font-family:var(--mono)}

/* ── GROUPED BARS (income comparison) ── */
.grouped-chart{display:flex;align-items:flex-end;gap:12px;height:80px;padding:0 4px;margin-bottom:8px}
.gc-group{flex:1;display:flex;align-items:flex-end;gap:2px}
.gc-bar{flex:1;border-radius:2px 2px 0 0;min-width:8px}
.gc-labels{display:flex;gap:12px;margin-top:6px}
.gc-label{flex:1;text-align:center;font-size:9px;color:var(--mist);font-family:var(--mono)}
.chart-legend{display:flex;gap:14px;flex-wrap:wrap;margin-top:10px}
.cl-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--slate)}
.cl-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}

/* ── ALLOCATION RING ── */
.alloc-ring-wrap{display:flex;align-items:center;gap:24px;padding:8px 0}
.alloc-ring{width:120px;height:120px;border-radius:50%;background:conic-gradient(var(--teal) 0% 35%,var(--gold) 35% 58%,var(--ocean) 58% 78%,var(--purple) 78% 92%,var(--mist) 92% 100%);position:relative;flex-shrink:0}
.alloc-ring::after{content:'';position:absolute;inset:22px;border-radius:50%;background:white}
.alloc-ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1}
.alloc-ring-center .val{font-family:var(--mono);font-size:15px;font-weight:700}
.alloc-ring-center .lbl{font-size:9px;color:var(--mist)}
.alloc-legend{display:flex;flex-direction:column;gap:8px;flex:1}
.alloc-leg-item{display:flex;align-items:center;gap:8px;font-size:12px}
.alloc-leg-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}
.alloc-leg-pct{font-family:var(--mono);font-size:11px;font-weight:600;margin-left:auto}

/* ── VENCIMIENTOS ── */
.venc-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.venc-item:last-child{border-bottom:none}
.venc-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.venc-name{font-size:13px;font-weight:600;flex:1;line-height:1.3}
.venc-date{font-family:var(--mono);font-size:11px;color:var(--mist);flex-shrink:0}
.venc-days{font-size:10px;font-weight:700;flex-shrink:0;padding:2px 7px;border-radius:100px}
.days-red{background:var(--red-dim);color:var(--red)}.days-amber{background:var(--amber-dim);color:var(--amber)}.days-green{background:var(--green-dim);color:var(--green)}

/* ── PREMIUM TIMELINE (activity) ── */
.tl-wrap{position:relative;padding-left:24px}
.tl-wrap::before{content:'';position:absolute;left:11px;top:8px;bottom:8px;width:2px;background:linear-gradient(to bottom,var(--teal-dim),var(--border))}
.tl-item{position:relative;padding:0 0 20px 24px}
.tl-item:last-child{padding-bottom:0}
.tl-dot{position:absolute;left:-24px;top:2px;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;border:2px solid white;box-shadow:0 0 0 2px var(--border)}
.tl-dot.tl-done{background:var(--green-dim);box-shadow:0 0 0 2px rgba(5,150,105,.2)}
.tl-dot.tl-review{background:var(--ocean-dim);box-shadow:0 0 0 2px rgba(27,79,126,.2)}
.tl-dot.tl-pending{background:var(--amber-dim);box-shadow:0 0 0 2px rgba(217,119,6,.2)}
.tl-dot.tl-available{background:var(--teal-dim);box-shadow:0 0 0 2px rgba(14,124,123,.2)}
.tl-dot.tl-urgent{background:var(--red-dim);box-shadow:0 0 0 2px rgba(229,62,62,.2)}
.tl-content{background:white;border:1px solid var(--border);border-radius:var(--r);padding:14px 16px;box-shadow:0 1px 4px rgba(13,27,42,.05)}
.tl-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:4px}
.tl-title{font-size:13px;font-weight:700;color:var(--ink);line-height:1.4}
.tl-meta{font-size:11px;color:var(--mist);margin-bottom:8px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.tl-meta-sep{color:var(--border)}
.tl-footer{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

/* ── DOCUMENTS ── */
.doc-toolbar{display:flex;align-items:center;gap:10px;background:white;border:1px solid var(--border);border-radius:var(--r);padding:14px 18px;margin-bottom:18px;box-shadow:var(--shadow);flex-wrap:wrap}
.doc-search{flex:1;min-width:160px;display:flex;align-items:center;gap:8px;background:var(--surface);border:1.5px solid var(--border);border-radius:7px;padding:8px 12px}
.doc-search input{background:none;border:none;outline:none;font-size:13px;color:var(--ink);font-family:var(--sans);width:100%}
.doc-filter{padding:8px 12px;border-radius:7px;border:1.5px solid var(--border);font-size:12px;color:var(--slate);background:white;cursor:pointer;font-family:var(--sans);outline:none}
.upload-zone{border:2px dashed var(--border);border-radius:12px;padding:28px;text-align:center;cursor:pointer;transition:all .2s;background:var(--surface);-webkit-tap-highlight-color:transparent}
.upload-zone:hover{border-color:var(--teal);background:var(--teal-dim)}
.upload-zone.gold-zone{border-color:rgba(201,168,76,.35);background:rgba(201,168,76,.04)}
.upload-zone.gold-zone:hover{border-color:var(--gold);background:var(--gold-dim)}
.upload-icon{font-size:28px;margin-bottom:8px;display:block}
.upload-title{font-size:14px;font-weight:700;color:var(--ink);margin-bottom:3px}
.upload-sub{font-size:12px;color:var(--mist)}
.upload-badge{display:inline-flex;align-items:center;gap:5px;background:var(--teal-dim);border:1px solid rgba(14,124,123,.2);border-radius:6px;padding:5px 10px;font-size:11px;font-weight:700;color:var(--teal);margin-top:8px}
.doc-table{background:white;border:1px solid var(--border);border-radius:var(--r);overflow-x:auto;box-shadow:var(--shadow);-webkit-overflow-scrolling:touch}
.dtbl-head{display:grid;grid-template-columns:2.5fr 1fr 1fr 1fr 80px;padding:10px 18px;background:var(--surface);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--mist);border-bottom:1px solid var(--border);min-width:500px}
.dtbl-row{display:grid;grid-template-columns:2.5fr 1fr 1fr 1fr 80px;padding:13px 18px;border-bottom:1px solid var(--border);align-items:center;cursor:pointer;min-width:500px;transition:background .15s}
.dtbl-row:last-child{border-bottom:none}.dtbl-row:hover{background:var(--surface)}
.dtbl-name{font-size:13px;font-weight:600;display:flex;align-items:center;gap:9px}
.dtbl-icon{font-size:16px;flex-shrink:0}.dtbl-meta{font-size:12px;color:var(--mist)}.dtbl-actions{display:flex;gap:6px;justify-content:flex-end}

/* ── INVERSIONES TABLE ── */
.inv-table{background:white;border:1px solid var(--border);border-radius:var(--r);overflow-x:auto;box-shadow:var(--shadow);-webkit-overflow-scrolling:touch}
.inv-head{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 80px;padding:10px 18px;background:var(--surface);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--mist);border-bottom:1px solid var(--border);min-width:560px}
.inv-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 80px;padding:13px 18px;border-bottom:1px solid var(--border);align-items:center;min-width:560px;transition:background .15s}
.inv-row:last-child{border-bottom:none}.inv-row:hover{background:var(--surface)}

/* ── PAGOS ── */
.pay-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:22px}
.pay-sum-card{background:white;border:1px solid var(--border);border-radius:var(--r);padding:18px 20px;box-shadow:var(--shadow)}
.pay-sum-lbl{font-size:11px;color:var(--mist);margin-bottom:6px}
.pay-sum-val{font-family:var(--mono);font-size:22px;font-weight:700}.pay-sum-sub{font-size:11px;color:var(--mist);margin-top:3px}
.pay-table{background:white;border:1px solid var(--border);border-radius:var(--r);overflow-x:auto;box-shadow:var(--shadow)}
.ptbl-head{display:grid;grid-template-columns:1.5fr 1fr 1fr 100px 100px;padding:10px 18px;background:var(--surface);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--mist);border-bottom:1px solid var(--border);min-width:480px}
.ptbl-row{display:grid;grid-template-columns:1.5fr 1fr 1fr 100px 100px;padding:14px 18px;border-bottom:1px solid var(--border);align-items:center;min-width:480px;transition:background .15s}
.ptbl-row:last-child{border-bottom:none}.ptbl-row:hover{background:var(--surface)}
.ptbl-amount{font-family:var(--mono);font-size:14px;font-weight:600}.ptbl-meta{font-size:12px;color:var(--slate)}
.subs-field-lbl{font-size:11px;color:var(--mist);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.subs-field-val{font-size:14px;font-weight:600;color:var(--ink)}

/* ── OBLIGATIONS CALENDAR ── */
.calendar-header{display:flex;align-items:center;justify-content:space-between;background:white;border:1px solid var(--border);border-radius:var(--r);padding:16px 22px;margin-bottom:18px;box-shadow:var(--shadow)}
.cal-month{font-size:18px;font-weight:700;font-family:var(--serif)}
.cal-nav-btn{width:36px;height:36px;border-radius:7px;border:1.5px solid var(--border);background:white;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.cal-nav-btn:hover{border-color:var(--teal);color:var(--teal)}
.obligations-list{display:flex;flex-direction:column;gap:10px}
.obl-card{background:white;border:1px solid var(--border);border-radius:var(--r);padding:18px 20px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow)}
.obl-card.urgent{border-left:4px solid var(--red);padding-left:16px}
.obl-card.warn{border-left:4px solid var(--amber);padding-left:16px}
.obl-card.ok{border-left:4px solid var(--green);padding-left:16px}
.obl-card.done{border-left:4px solid var(--border);padding-left:16px;opacity:.65}
.obl-date{text-align:center;flex-shrink:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px 14px}
.obl-date-day{font-family:var(--mono);font-size:22px;font-weight:700;line-height:1}
.obl-date-mon{font-size:10px;font-weight:700;text-transform:uppercase;color:var(--mist)}
.obl-info{flex:1;min-width:0}.obl-name{font-size:14px;font-weight:700;margin-bottom:3px}.obl-desc{font-size:12px;color:var(--slate)}
.obl-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0}

/* ── REPORTES ── */
.rep-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:22px}
.rep-card{background:white;border:1px solid var(--border);border-radius:var(--r);padding:22px;box-shadow:var(--shadow);transition:all .2s;cursor:pointer}
.rep-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.rep-icon{font-size:26px;margin-bottom:12px;display:block}.rep-title{font-size:14px;font-weight:700;margin-bottom:4px}
.rep-desc{font-size:12px;color:var(--slate);line-height:1.5;margin-bottom:14px}
.rep-foot{display:flex;align-items:center;justify-content:space-between}.rep-date{font-size:11px;color:var(--mist);font-family:var(--mono)}

/* ── MENSAJERÍA + AGENDA ── */
.msg-tabs{display:flex;gap:4px;background:var(--cloud);border:1px solid var(--border);border-radius:10px;padding:4px;margin-bottom:20px}
.msg-tab{flex:1;padding:9px 16px;border-radius:7px;text-align:center;cursor:pointer;font-size:13px;font-weight:600;color:var(--slate);transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px;-webkit-tap-highlight-color:transparent}
.msg-tab.active{background:white;color:var(--ink);box-shadow:var(--shadow)}
.msg-tab:not(.active):hover{background:rgba(255,255,255,.55);color:var(--ink)}
.msg-sub-view{display:none}.msg-sub-view.active{display:block}
.ico-svg{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;color:inherit;width:18px;height:18px}
.ico-svg svg{width:100%;height:100%;stroke:currentColor;fill:none}
.ico-svg.ico-sm{width:14px;height:14px}.ico-svg.ico-md{width:22px;height:22px}.ico-svg.ico-lg{width:30px;height:30px}
.planes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:16px}
.plan-card{background:white;border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);padding:16px 18px;display:flex;flex-direction:column}
.plan-card-actual{border:2px solid var(--gold);background:var(--gold-dim)}
.plan-name{font-size:14px;font-weight:700;color:var(--ink);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.plan-badge{font-size:10px;font-weight:700;background:var(--gold);color:var(--ink);padding:2px 8px;border-radius:100px}
.plan-price{font-size:18px;font-weight:700;color:var(--teal);margin:6px 0 2px}
.plan-price span{font-size:11px;font-weight:600;color:var(--mist)}
.plan-desc{font-size:12px;color:var(--slate);line-height:1.45;margin-bottom:14px;flex:1}
.asesoria-card{background:white;border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);padding:16px 20px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.asesoria-top{display:flex;align-items:baseline;justify-content:space-between;gap:10px;flex-wrap:wrap}
.asesoria-precio{font-size:16px;font-weight:700;color:var(--teal);white-space:nowrap}
.asesoria-precio span{font-size:11px;font-weight:600;color:var(--mist)}
/* Proceso de contratación */
.proceso-card{background:white;border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);padding:18px 20px;margin-bottom:16px}
.proceso-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.proceso-title{font-size:15px;font-weight:700;color:var(--ink)}
.proceso-sub{font-size:12px;color:var(--slate);margin-top:2px}
.proceso-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px}
.proceso-step{display:flex;gap:11px;align-items:flex-start;background:var(--cloud);border:1px solid var(--border);border-radius:10px;padding:13px 14px}
.ps-num{flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--teal);color:white;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center}
.ps-t{font-size:13px;font-weight:700;color:var(--ink)}
.ps-d{font-size:12px;color:var(--slate);line-height:1.45;margin-top:2px}
.proceso-refund{display:flex;align-items:center;gap:8px;margin-top:14px;padding:11px 14px;background:var(--teal-dim);border:1px solid rgba(14,124,123,.2);border-radius:9px;font-size:12px;color:var(--slate)}
/* Apoyo profesional — campos */
.apoyo-card{background:white;border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);padding:22px 24px;max-width:640px}
.apoyo-card .fld textarea,.apoyo-card .fld select{width:100%;font-family:var(--sans);font-size:14px;color:var(--ink);background:var(--surface);border:1.5px solid var(--border);border-radius:8px;padding:11px 13px;outline:none;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none}
.apoyo-card .fld textarea{resize:vertical;min-height:96px;line-height:1.5}
.apoyo-card .fld textarea::placeholder{font-family:var(--sans);color:var(--mist)}
.apoyo-card .fld textarea:focus,.apoyo-card .fld select:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-glow)}
.apoyo-card .fld select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;padding-right:34px}
/* Agenda adaptativa */
.agenda-loading{padding:24px;text-align:center;color:var(--mist);font-size:13px}
.ag-card{background:white;border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);padding:16px 18px}
.ag-days{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;scrollbar-width:none}
.ag-days::-webkit-scrollbar{display:none}
.ag-day{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:1px;min-width:54px;padding:8px 6px;border:1.5px solid var(--border);border-radius:10px;background:var(--surface);cursor:pointer;transition:all .15s}
.ag-day:hover{border-color:var(--teal)}
.ag-day.on{background:var(--teal);border-color:var(--teal)}
.ag-day.on .ag-dow,.ag-day.on .ag-num,.ag-day.on .ag-mon{color:white}
.ag-dow{font-size:10px;font-weight:700;letter-spacing:.05em;color:var(--mist)}
.ag-num{font-size:17px;font-weight:700;color:var(--ink)}
.ag-mon{font-size:10px;color:var(--slate)}
.ag-slots-head{margin:14px 0 10px;font-size:12px;font-weight:700;color:var(--slate)}
.ag-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(82px,1fr));gap:8px}
.ag-slot{position:relative;padding:10px 6px;border:1.5px solid var(--border);border-radius:8px;background:white;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer;transition:all .15s}
.ag-slot:hover:not(:disabled){border-color:var(--teal);background:var(--teal-dim);color:var(--teal)}
.ag-slot.taken{background:var(--teal-dim);border-color:rgba(14,124,123,.25);color:var(--teal);cursor:default}
.ag-slot.past{opacity:.4;cursor:default;background:var(--cloud)}
.ag-tag{display:block;font-size:9px;font-weight:600;color:var(--teal);margin-top:1px}
.ag-foot{display:flex;align-items:center;gap:6px;margin-top:14px;font-size:11px;color:var(--mist)}
.ag-dot{width:10px;height:10px;border-radius:3px;display:inline-block}
.ag-dot-free{background:white;border:1px solid var(--border)}
.ag-dot-mine{background:var(--teal-dim);border:1px solid rgba(14,124,123,.25)}
/* ── Vista staff (solo lectura) ── */
#staff-bar{position:sticky;top:0;z-index:400;background:#7A5A10;color:#fff;display:flex;align-items:center;gap:10px;padding:7px 16px;font-size:12px;flex-wrap:wrap}
#staff-bar .sb-tag{font-weight:700;letter-spacing:.04em;background:rgba(255,255,255,.18);padding:2px 9px;border-radius:100px}
#staff-bar .sb-lbl{margin-left:auto;opacity:.9}
#staff-bar select{background:#fff;color:var(--ink);border:none;border-radius:6px;padding:4px 10px;font-size:12px;max-width:60vw}
body.staff-view .nav-item[onclick*="'ahorro'"],
body.staff-view .nav-item[onclick*="'metas'"],
body.staff-view .nav-item[onclick*="'deuda'"],
body.staff-view .nav-item[onclick*="'seguros'"],
body.staff-view .nav-item[onclick*="'presupuesto'"],
body.staff-view .nav-item[onclick*="'flujo'"],
body.staff-view .nav-item[onclick*="'cartola'"]{display:none}
body.staff-view .btn-primary[onclick*="om("],
body.staff-view [onclick*="contratarAsesoria"],
body.staff-view [onclick*="abrirAsesoria"],
body.staff-view [onclick*="solicitarApoyo"],
body.staff-view [onclick*="nuevaReunion"],
body.staff-view [onclick*="cancelarReunionPortal"],
body.staff-view #asesoria-btn,
body.staff-view #apoyo-btn{display:none !important}
body.staff-view .ag-slot{pointer-events:none;opacity:.85}
body.staff-view .ag-day{pointer-events:none}
.msg-layout{display:grid;grid-template-columns:280px 1fr;gap:0;background:white;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);height:calc(100vh - 220px)}
.msg-left{border-right:1px solid var(--border);display:flex;flex-direction:column;min-height:0}
.msg-left-head{padding:16px;border-bottom:1px solid var(--border);flex-shrink:0}
.msg-left-title{font-size:14px;font-weight:700;margin-bottom:10px}
.msg-search-w{background:var(--surface);border:1.5px solid var(--border);border-radius:7px;display:flex;align-items:center;gap:7px;padding:7px 11px}
.msg-search-w input{background:none;border:none;outline:none;font-size:12px;font-family:var(--sans);color:var(--ink);width:100%}
.msg-threads{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
.msg-thread{padding:13px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}
.msg-thread:hover{background:var(--surface)}
.msg-thread.active{background:var(--ocean-dim);border-right:3px solid var(--ocean)}
.th-top{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.th-av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--ocean),var(--teal));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:white;flex-shrink:0}
.th-name{font-size:13px;font-weight:700;flex:1}.th-time{font-size:10px;color:var(--mist);font-family:var(--mono)}
.th-preview{font-size:12px;color:var(--mist);line-height:1.4;padding-left:38px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.th-unread{width:8px;height:8px;border-radius:50%;background:var(--teal);flex-shrink:0}
.msg-right{display:flex;flex-direction:column;min-height:0}
.msg-right-head{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;flex-shrink:0}
.mh-av{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--ocean),var(--teal));display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:white;flex-shrink:0}
.mh-name{font-size:14px;font-weight:700}.mh-status{font-size:11px;color:var(--green);display:flex;align-items:center;gap:4px}
.mh-status::before{content:"●";font-size:8px}
.msg-feed{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:14px;background:var(--surface);-webkit-overflow-scrolling:touch}
.bubble-wrap{display:flex;gap:9px;align-items:flex-end}
.bubble-wrap.mine{flex-direction:row-reverse}
.bav{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--ocean),var(--teal));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:white;flex-shrink:0}
.bav.mine{background:var(--cloud);color:var(--slate)}
.bubble{max-width:72%;padding:11px 15px;border-radius:12px;font-size:13px;line-height:1.55}
.bubble.theirs{background:white;border:1px solid var(--border);border-radius:3px 12px 12px 12px}
.bubble.mine{background:linear-gradient(135deg,var(--ocean),var(--teal));color:white;border-radius:12px 3px 12px 12px}
.b-time{font-size:10px;color:var(--mist);margin-top:4px;font-family:var(--mono)}
.bubble-wrap.mine .b-time{text-align:right}
.msg-input-row{padding:12px 16px;border-top:1px solid var(--border);background:white;display:flex;gap:10px;align-items:flex-end;flex-shrink:0}
.msg-ta{flex:1;background:var(--surface);border:1.5px solid var(--border);border-radius:10px;padding:10px 14px;font-size:16px;font-family:var(--sans);resize:none;outline:none;min-height:42px;max-height:120px;-webkit-appearance:none}
.msg-ta:focus{border-color:var(--teal)}
.msg-send{width:42px;height:42px;border-radius:9px;border:none;cursor:pointer;background:linear-gradient(135deg,var(--ocean),var(--teal));color:white;font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* ── AGENDA ── */
.agenda-layout{display:grid;grid-template-columns:1fr 280px;gap:18px}
.agenda-notice{background:var(--teal-dim);border:1px solid rgba(14,124,123,.2);border-radius:8px;padding:12px 16px;font-size:12px;color:var(--slate);margin-bottom:18px;display:flex;align-items:center;gap:8px}
.week-grid{background:white;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.week-header{display:grid;grid-template-columns:56px repeat(5,1fr);border-bottom:1px solid var(--border);background:var(--surface)}
.week-day-head{padding:10px 6px;text-align:center}
.wdh-dow{font-size:10px;font-weight:700;color:var(--mist);text-transform:uppercase}
.wdh-date{font-size:16px;font-weight:700;color:var(--ink);font-family:var(--mono)}
.wdh-date.today{color:var(--teal);background:var(--teal-dim);border-radius:6px;padding:2px 6px}
.week-body{display:grid;grid-template-columns:56px repeat(5,1fr)}
.wt-label{font-size:10px;font-family:var(--mono);color:var(--mist);padding:12px 6px 0;text-align:right;border-right:1px solid var(--border);border-bottom:1px solid var(--border)}
.w-slot{border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:4px 5px;min-height:52px;cursor:pointer;transition:background .15s;position:relative}
.w-slot:hover{background:var(--teal-dim)}
.w-slot.past{background:var(--surface);cursor:default;opacity:.5}
.w-slot.past:hover{background:var(--surface)}
.w-slot.booked{background:var(--ocean-dim);cursor:default}
.w-slot.booked:hover{background:var(--ocean-dim)}
.w-slot.mine{background:var(--teal-dim);cursor:default}
.w-slot.mine:hover{background:var(--teal-dim)}
.slot-event{font-size:10px;font-weight:600;padding:4px 6px;border-radius:5px;line-height:1.3}
.slot-cesar{background:rgba(27,79,126,.12);color:var(--ocean);border:1px solid rgba(27,79,126,.15)}
.slot-mine{background:rgba(14,124,123,.12);color:var(--teal);border:1px solid rgba(14,124,123,.15)}
.next-meetings-card{background:white;border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden}
.nmc-header{padding:14px 18px;border-bottom:1px solid var(--border);font-size:13px;font-weight:700}
.nmi{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;gap:12px;align-items:flex-start}
.nmi:last-child{border-bottom:none}
.nmi-date{text-align:center;flex-shrink:0;background:var(--teal-dim);border:1px solid rgba(14,124,123,.2);border-radius:8px;padding:6px 10px;min-width:44px}
.nmi-day{font-family:var(--mono);font-size:18px;font-weight:700;color:var(--teal);line-height:1}
.nmi-mon{font-size:9px;font-weight:700;text-transform:uppercase;color:var(--mist)}
.nmi-info{flex:1}.nmi-title{font-size:13px;font-weight:700;margin-bottom:2px}.nmi-sub{font-size:11px;color:var(--mist);line-height:1.4}

/* ── MEDICAL VIEW ── */
.med-source-card{background:white;border:1px solid var(--border);border-radius:var(--r);padding:18px 20px;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.med-source-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px}
.med-src-soc::before{background:var(--purple)}
.med-src-hon::before{background:var(--teal)}
.med-src-sue::before{background:var(--ocean)}
.med-src-inv::before{background:var(--gold)}
.med-source-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.med-source-val{font-family:var(--mono);font-size:24px;font-weight:600;color:var(--ink)}
.med-source-pct{font-size:11px;font-weight:600;margin-top:4px}
.med-sources-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.med-pl-row{display:flex;justify-content:space-between;padding:10px 14px;border-radius:7px;border:1px solid var(--border)}
.med-pl-row.highlight{background:var(--purple-dim);border-color:rgba(124,58,237,.2)}
.med-pl-row.positive{background:var(--green-dim);border-color:rgba(5,150,105,.15)}
.med-pl-row.deduction{background:var(--red-dim);border-color:rgba(229,62,62,.15)}
.med-pl-label{font-size:13px;color:var(--slate)}
.med-pl-value{font-family:var(--mono);font-size:13px;font-weight:600}
.accion-item{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:white;border:1px solid var(--border);border-radius:var(--r);box-shadow:0 1px 4px rgba(13,27,42,.05);margin-bottom:10px}
.accion-item:last-child{margin-bottom:0}
.accion-item.accion-alert{border-left:3px solid var(--amber);padding-left:13px}
.accion-item.accion-info{border-left:3px solid var(--ocean);padding-left:13px}
.accion-item.accion-ok{border-left:3px solid var(--green);padding-left:13px}
.accion-icon{font-size:18px;flex-shrink:0;margin-top:1px}
.accion-title{font-size:13px;font-weight:700;margin-bottom:2px}
.accion-desc{font-size:12px;color:var(--slate);line-height:1.45}

/* ── FIRMA DIGITAL ── */
.firma-steps{display:flex;gap:4px;margin-bottom:24px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.firma-steps::-webkit-scrollbar{display:none}
.firma-step{flex:1;text-align:center;padding:11px 8px;border-radius:8px;background:var(--cloud);border:1px solid var(--border);min-width:80px;transition:all .2s}
.firma-step.active{background:linear-gradient(135deg,var(--ocean),var(--teal));color:white;border-color:var(--teal)}
.firma-step.done{background:var(--green-dim);border-color:rgba(5,150,105,.3);color:var(--green)}
.fs-num{font-size:11px;font-weight:700;margin-bottom:2px}.fs-label{font-size:10px;font-weight:600}
.firma-panel{background:white;border:1px solid var(--border);border-radius:var(--r);padding:28px;box-shadow:var(--shadow);min-height:280px}
.firma-doc-preview{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:20px;margin:16px 0;max-height:280px;overflow-y:auto;font-size:12px;line-height:1.7;color:var(--slate);-webkit-overflow-scrolling:touch}
.firma-doc-preview h4{color:var(--ink);font-size:14px;margin-bottom:8px;font-family:var(--serif)}
.firma-doc-preview p{margin-bottom:10px}
.firma-success{text-align:center;padding:24px 16px}
.firma-success-icon{font-size:52px;margin-bottom:14px;display:block}
.firma-log{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:14px;margin-top:16px;font-family:var(--mono);font-size:11px;color:var(--slate);text-align:left}
.firma-log-row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid var(--border);gap:12px;flex-wrap:wrap}
.firma-log-row:last-child{border-bottom:none}

/* ── PERFIL / CUENTA ── */
.profile-header{background:linear-gradient(135deg,var(--ocean),var(--teal));border-radius:14px;padding:28px;color:white;display:flex;align-items:center;gap:20px;margin-bottom:22px}
.profile-av{width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.2);border:3px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:700;color:white;flex-shrink:0}
.profile-name{font-family:var(--serif);font-size:22px;margin-bottom:2px}
.profile-email{font-size:13px;color:rgba(255,255,255,.7)}
.profile-plan-badge{margin-left:auto;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);border-radius:8px;padding:12px 18px;text-align:center}
.profile-plan-name{font-size:15px;font-weight:700}.profile-plan-sub{font-size:11px;color:rgba(255,255,255,.55);margin-top:2px}
.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.profile-card{background:white;border:1px solid var(--border);border-radius:var(--r);padding:22px;box-shadow:var(--shadow)}
.profile-card-title{font-size:13px;font-weight:700;margin-bottom:16px}
.pf-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.pf-field label{display:block;font-size:11px;font-weight:600;color:var(--mist);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px}
.pf-field input{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:7px;font-size:13px;color:var(--ink);font-family:var(--sans);outline:none;background:var(--surface)}
.pf-field input:focus{border-color:var(--teal)}
.contrato-card{background:linear-gradient(135deg,rgba(14,124,123,.04),rgba(27,79,126,.06));border:1.5px solid rgba(14,124,123,.2);border-radius:var(--r);padding:18px 20px;display:flex;align-items:center;gap:16px;margin-bottom:16px;box-shadow:var(--shadow);flex-wrap:wrap}
.contrato-icon{font-size:30px;flex-shrink:0}
.contrato-info{flex:1;min-width:180px}
.contrato-name{font-size:14px;font-weight:700;margin-bottom:2px}
.contrato-detail{font-size:12px;color:var(--slate)}
.danger-zone{background:white;border:1.5px solid rgba(229,62,62,.2);border-radius:var(--r);padding:20px;box-shadow:var(--shadow)}
.danger-title{font-size:13px;font-weight:700;color:var(--red);margin-bottom:6px}
.danger-desc{font-size:13px;color:var(--slate);margin-bottom:14px}

/* ── MODALS ── */
.overlay{position:fixed;inset:0;z-index:800;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity .2s}
.overlay.open{opacity:1;pointer-events:all}
.mbox{background:white;border-radius:16px;padding:28px;max-width:520px;width:100%;position:relative;transform:translateY(16px);transition:transform .2s;box-shadow:0 32px 64px rgba(0,0,0,.28);max-height:90vh;overflow-y:auto;-webkit-overflow-scrolling:touch}
.overlay.open .mbox{transform:translateY(0)}
.m-title{font-family:var(--serif);font-size:22px;margin-bottom:6px}
.m-sub{font-size:13px;color:var(--slate);margin-bottom:22px;line-height:1.5}
.m-close{position:absolute;top:14px;right:14px;background:var(--surface);border:1px solid var(--border);border-radius:6px;width:30px;height:30px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;color:var(--slate);transition:background .15s ease,color .15s ease,border-color .15s ease,transform .12s ease}
.m-close:hover{background:var(--cloud);color:var(--ink);border-color:var(--mist)}
.m-close:active{transform:scale(.9)}
.mfld{margin-bottom:14px}
.mfld label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--slate);margin-bottom:6px}
.mfld select,.mfld textarea,.mfld input{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:14px;font-family:var(--sans);outline:none;background:var(--surface);-webkit-appearance:none;transition:border-color .15s ease,box-shadow .15s ease}
.mfld select:focus,.mfld textarea:focus,.mfld input:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-glow)}
.mfld textarea{resize:vertical;min-height:80px}
/* Guard de movimiento reducido para las microinteracciones del modal
   (entrada del mbox, fade del overlay, feedback del campo y del cerrar).
   Conserva el cambio de color/glow del foco — solo elimina el movimiento. */
@media (prefers-reduced-motion: reduce){
  .overlay,.mbox,.m-close,.mfld select,.mfld textarea,.mfld input{transition:none}
  .mbox{transform:none}
  .m-close:active{transform:none}
}

/* ── TOAST ── */
.toast-wrap{position:fixed;bottom:80px;right:16px;z-index:900;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{background:white;border:1px solid var(--border);border-radius:10px;padding:12px 16px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);font-size:13px;animation:tIn .3s ease both;min-width:240px;max-width:320px;pointer-events:all}
@keyframes tIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
.t-close{margin-left:auto;background:none;border:none;cursor:pointer;color:var(--mist);font-size:16px;padding:4px}

/* ── RESPONSIVE ── */
@media(max-width:1200px){.kpi-row{grid-template-columns:repeat(2,1fr)}.dash-grid{grid-template-columns:1fr}.agenda-layout{grid-template-columns:1fr}.next-meetings-card{display:none}}
@media(max-width:1024px){:root{--sidebar-w:64px}.sb-name,.sb-sub,.nav-item>span:not(.nav-item-icon),.nav-group-label,.user-name,.user-plan{display:none}.nav-item{justify-content:center;padding:12px}.nav-badge{position:absolute;top:2px;right:2px;padding:2px 5px;font-size:9px}.sidebar-brand{padding:14px 8px;justify-content:center}.sidebar-user{justify-content:center;padding:14px 8px}.profile-grid{grid-template-columns:1fr}.msg-layout{grid-template-columns:1fr}.msg-left{display:none}.dash-grid{grid-template-columns:1fr}}
@media(max-width:768px){
:root{--sidebar-w:0px;--topbar-h:54px}
#app{flex-direction:column}
.sidebar{position:fixed;left:-260px;top:0;width:250px;height:100vh;z-index:999;transition:left .3s ease;box-shadow:none}
.sidebar.open{left:0;box-shadow:var(--shadow-lg)}
.sb-name,.sb-sub,.nav-item>span:not(.nav-item-icon),.nav-group-label,.user-name,.user-plan{display:initial}
.nav-item{justify-content:flex-start}.nav-badge{position:static}
.sidebar-brand{padding:20px 18px 16px;justify-content:flex-start}
.sidebar-user{justify-content:flex-start;padding:14px 16px}
.sidebar-overlay{display:none}
.sidebar-overlay.open{display:block;position:fixed;inset:0;background:rgba(0,0,0,.48);z-index:998}
.main{width:100%;padding-bottom:66px}
.topbar{position:sticky;top:0;z-index:100;padding:0 14px}
.content{padding:14px}
.kpi-row{grid-template-columns:1fr 1fr}.kpi-card{padding:14px 16px}.kpi-value{font-size:18px}
.kpi-row-6{grid-template-columns:1fr 1fr}.pay-summary{grid-template-columns:1fr}
.rep-grid{grid-template-columns:1fr}.dash-grid{grid-template-columns:1fr}
.profile-grid{grid-template-columns:1fr}
.dash-welcome{flex-direction:column;padding:20px 18px;text-align:center}
.dw-stat{text-align:center;margin-top:14px}.dw-stat-val{font-size:26px}
.dw-text h2{font-size:18px}.dw-actions{justify-content:center}
.alloc-ring-wrap{flex-direction:column;text-align:center}.alloc-ring{margin:0 auto}
.obl-card{flex-direction:column;align-items:flex-start;gap:10px}.obl-right{flex-direction:row;width:100%;justify-content:space-between}
.msg-layout{height:calc(100vh - 230px)}.msg-left{display:none}
.profile-header{flex-direction:column;text-align:center;padding:22px 18px}.profile-plan-badge{margin-left:0;margin-top:10px}
.contrato-card{flex-direction:column;text-align:center}
.topbar-date{display:none}.topbar-confidential{display:none}
.agenda-layout{grid-template-columns:1fr}
.week-grid{overflow-x:auto;-webkit-overflow-scrolling:touch}.week-header{min-width:480px}.week-body{min-width:480px}
.med-sources-grid{grid-template-columns:1fr 1fr}
.dash-grid-3{grid-template-columns:1fr}
.firma-panel{padding:18px}
.mbox{padding:22px;border-radius:14px}
.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:64px;background:white;border-top:1px solid var(--border);display:grid;grid-template-columns:repeat(5,1fr);z-index:1000;box-shadow:0 -2px 12px rgba(0,0,0,.06)}
.bn-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;color:var(--mist);font-size:10px;font-weight:600;text-decoration:none;position:relative;-webkit-tap-highlight-color:transparent;transition:color .15s ease}
.bn-item.active{color:var(--teal)}
.bn-icon{font-size:20px;transition:transform .18s cubic-bezier(.16,1,.3,1)}
.bn-item.active .bn-icon{transform:translateY(-1px) scale(1.08)}
.bn-item:active .bn-icon{transform:scale(.86)}
.bn-badge{position:absolute;top:4px;right:calc(50% - 18px);width:16px;height:16px;border-radius:50%;background:var(--red);color:white;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center}
}
@media(max-width:480px){.kpi-row{grid-template-columns:1fr}.med-sources-grid{grid-template-columns:1fr}.content{padding:10px}.login-card{padding:28px 20px;border-radius:14px}}
@media(min-width:769px){.bottom-nav{display:none}#menu-btn{display:none!important}}

/* ============================================================
   Safe-area insets — app nativa (Capacitor).
   Evita que el notch / barra de estado tape el topbar y que la
   barra de gestos (home indicator) tape la bottom-nav. En navegador
   y desktop env()=0px, así que no afecta a quien entra por planifica.ell.cl
   (anti-regresión). Requiere viewport-fit=cover en el <meta viewport>.
   ============================================================ */
@media(max-width:768px){
.topbar{height:calc(var(--topbar-h) + env(safe-area-inset-top, 0px));padding-top:env(safe-area-inset-top, 0px);padding-left:calc(14px + env(safe-area-inset-left, 0px));padding-right:calc(14px + env(safe-area-inset-right, 0px))}
.sidebar{padding-top:env(safe-area-inset-top, 0px);padding-bottom:env(safe-area-inset-bottom, 0px)}
.bottom-nav{height:calc(64px + env(safe-area-inset-bottom, 0px));padding-bottom:env(safe-area-inset-bottom, 0px)}
.main{padding-bottom:calc(66px + env(safe-area-inset-bottom, 0px))}
}

/* ============================================================
   iOS: evita el auto-zoom al enfocar campos. Safari hace zoom si el
   campo tiene font-size < 16px. En movil forzamos 16px en los campos
   de texto (no toca .code-digit ni radios/checkboxes). Solo aplica a
   <=768px, por lo que desktop queda igual (anti-regresion).
   ============================================================ */
@media(max-width:768px){
input:not([type=radio]):not([type=checkbox]):not(.code-digit),
select,
textarea{font-size:16px !important}
}

/* ============================================================
   Targets táctiles >=44px (mínimo iOS HIG) en los botones de icono
   de alto tráfico (hamburguesa, alertas, logout, cerrar modal).
   Solo en móvil: en desktop conservan su tamaño (anti-regresión).
   El glifo se mantiene centrado con inline-flex.
   ============================================================ */
@media(max-width:768px){
#menu-btn,.topbar-alert-btn,.logout-btn{min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}
.m-close{width:44px;height:44px}
}

/* ============================================================
   Drawer (sidebar) abierto en móvil: bloquea el scroll del fondo para
   que el contenido no se desplace detrás del menú/overlay (bug típico
   en webview). Solo <=768px (el drawer no existe en desktop).
   ============================================================ */
@media(max-width:768px){
body.drawer-open,body.modal-open{overflow:hidden}
body.drawer-open .content,body.modal-open .content{overflow:hidden}
}

/* ============================================================
   CTA cómodos en móvil: los botones (salvo .btn-sm, intencionalmente
   compactos) llegan a ≥44px de alto. Solo <=768px (anti-regresión).
   ============================================================ */
@media(max-width:768px){
.btn:not(.btn-sm){min-height:44px}
}

/* ============================================================
   LOGIN en móvil — bug crítico + jerarquía.
   Problema original: #login-screen es flex fijo con align-items:center
   y overflow visible. Cuando el contenido apilado (hero marketing +
   tarjeta de login) supera el alto del viewport, el centrado recorta la
   parte de arriba (marca/título) Y la de abajo (botón Ingresar, Google,
   "¿Olvidaste tu contraseña?") FUERA de pantalla, sin posibilidad de
   scroll → en un teléfono típico no se puede ni iniciar sesión.
   Fix: el contenedor se vuelve scrollable y alinea arriba; la tarjeta de
   login pasa PRIMERO (el visitante que vuelve llega directo a los campos)
   y el hero de marketing queda debajo para quien baja a conocer el valor.
   Solo <=900px (donde la vista ya apila). Desktop intacto (anti-regresión).
   ============================================================ */
@media(max-width:900px){
  #login-screen{
    align-items:flex-start;
    justify-content:center;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    padding:0;
  }
  .landing{
    width:100%;
    margin:0 auto;
    min-height:100%;
    justify-content:flex-start;
    padding:calc(22px + env(safe-area-inset-top,0px)) 18px calc(30px + env(safe-area-inset-bottom,0px));
    gap:22px;
  }
  /* La tarjeta de login va primero; el hero (por qué Planifica+) debajo. */
  .landing .login-card{order:-1}
  .landing-hero{
    order:1;
    padding-top:24px;
    border-top:1px solid rgba(255,255,255,.12);
  }
  /* La marca ya aparece en la cabecera de la tarjeta de login → evita
     duplicarla en el hero (que ahora está a media página). */
  .landing-hero .lh-brand{display:none}
}

/* ============================================================
   TOPBAR en móvil — menos ruido, más claridad.
   El topbar venía apretado: hamburguesa + título + "Contratar asesoría"
   + "+ Subir" + alerta en ~390px. "Contratar asesoría" ya está a un toque
   en la bottom-nav (🛟 Asesoría), así que en móvil se oculta su duplicado
   del topbar para dejar respirar al título y a la acción principal
   (+ Subir). Solo <=768px (desktop conserva ambos botones).
   ============================================================ */
@media(max-width:768px){
  .topbar-right .btn-ghost{display:none}
  .topbar{gap:8px}
  .topbar-right{gap:6px}
}

/* ============================================================
   Feel nativo en móvil — las tiras horizontales (pestañas del dashboard,
   pestañas de Inversiones, chips de Metas) ya scrollean; el scroll-snap
   hace que al deslizar se asienten suave en cada elemento, como en una
   app. proximity (no mandatory) = gesto gentil, no "pegajoso", y no
   fuerza la posición al cargar. Solo <=768px (anti-regresión desktop).
   ============================================================ */
@media(max-width:768px){
  .dash-tabs,.iv-tabs,.mt-strip{scroll-snap-type:x proximity;scroll-padding-left:10px}
  .dash-tab,.iv-tab,.mt-chipcard{scroll-snap-align:start}
}

/* ============================================================
   Impresión / Guardar como PDF. Limpia la vista activa para un
   documento legible: oculta navegación, controles y vistas inactivas;
   evita cortar tarjetas a la mitad. Pensado para estados financieros.
   ============================================================ */
/* Transiciones suaves de navegación (fluidez). Respeta reduced-motion. */
@media (prefers-reduced-motion: no-preference) {
  @keyframes viewFade { from { opacity: 0; transform: translateY(5px); } to { opacity: 1; transform: none; } }
  .view.active { animation: viewFade .26s ease both; }
  .dash-sub-view.active { animation: viewFade .26s ease both; }
  #empresa-content.emp-fade { animation: viewFade .22s ease both; }
}

.print-header { display: none; }
@media print {
  #login-screen, .sidebar, #sidebar, #sb-overlay, .topbar, .bottom-nav,
  .dash-tabs, .empresa-selector-wrap, .dw-actions, button, .btn, .info-badge,
  #toast-wrap, .cmp-here { display: none !important; }
  .print-header { display: block !important; border-bottom: 2px solid #0D1B2A;
    padding-bottom: 8px; margin-bottom: 16px; }
  .print-header .ph-brand { font-family: var(--serif); font-size: 18px; font-weight: 600; color: #0D1B2A; }
  .print-header .ph-meta { font-size: 11px; color: #3d4d5c; margin-top: 2px; }
  #app { display: block !important; height: auto !important; }
  .main { padding: 0 !important; overflow: visible !important; }
  .content { padding: 0 !important; }
  .view { display: none !important; }
  .view.active { display: block !important; }
  .dash-sub-view { display: none !important; }
  .dash-sub-view.active { display: block !important; }
  .dash-grid, .dash-grid-3 { display: block !important; }
  .dash-grid > *, .dash-grid-3 > * { margin-bottom: 14px; }
  .card, .dash-welcome, .fin-score-card, .fin-score-cell, .kpi-card,
  .obl-card, table, tr { break-inside: avoid; page-break-inside: avoid; }
  .card, .dash-welcome, .fin-score-card, .kpi-card {
    box-shadow: none !important; border: 1px solid #d9dee5 !important; }
  .dash-welcome { background: #f4f6f9 !important; color: #0D1B2A !important; }
  .dash-welcome h2, .dash-welcome p, .dw-stat-val, .dw-stat-lbl, .dw-stat-del { color: #0D1B2A !important; }
  body { background: #fff !important; }
  @page { margin: 14mm; }
}
