/* ═══════════════════════════════════════════════════════════════════
   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}

/* ── 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)}

/* ── 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}
.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:10px;padding:9px 12px;border-radius:8px;cursor:pointer;font-size:13px;color:rgba(255,255,255,.48);transition:all .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.active{background:rgba(255,255,255,.09);color:white}
.nav-item.active::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:18px;background:var(--teal);border-radius:0 2px 2px 0}
.nav-item-icon{font-size:16px;width:20px;text-align:center;flex-shrink:0}
.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}

/* ── 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}
.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)}
.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)}
.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-sub-view{display:none}.msg-sub-view.active{display:block}
.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)}
.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}
.mfld select:focus,.mfld textarea:focus,.mfld input:focus{border-color:var(--teal)}
.mfld textarea{resize:vertical;min-height:80px}

/* ── 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}
.bn-item.active{color:var(--teal)}
.bn-icon{font-size:20px}
.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}}
