/* ==========================================================================
   IBARNELLI AUTOPARTES · Sistema de gestión
   styles.css
   ========================================================================== */

:root{
  --primary:#14283C; --primary-dark:#0E1C2A; --primary-light:#1F3754; --primary-soft:rgba(20,40,60,0.08);
  --accent:#B41428; --accent-dark:#8F0F1F; --accent-light:#D32F3F; --accent-soft:rgba(180,20,40,0.10);
  --bg:#FAF7F0; --bg-2:#F5F1E8; --bg-3:#EDE7D6; --surface:#FFFFFF; --surface-2:#FBF9F2;
  --border:#E5DFD0; --border-strong:#D4CCB8; --text:#14283C; --text-2:#5D6B7A; --text-3:#8E9AAB;
  --ok:#0E8A4A; --ok-soft:rgba(14,138,74,0.12); --warn:#D97706; --warn-soft:rgba(217,119,6,0.12);
  --danger:var(--accent); --danger-soft:var(--accent-soft); --info:#1F6FB5; --info-soft:rgba(31,111,181,0.12);
  --gold:#A37E2C; --gold-soft:rgba(163,126,44,0.12);
  --radius:12px; --radius-sm:8px; --radius-lg:16px;
  --shadow-sm:0 1px 2px rgba(20,40,60,0.04);
  --shadow:0 1px 3px rgba(20,40,60,0.05), 0 1px 2px rgba(20,40,60,0.03);
  --shadow-md:0 4px 12px rgba(20,40,60,0.06), 0 2px 4px rgba(20,40,60,0.04);
  --shadow-lg:0 10px 30px rgba(20,40,60,0.08);
  --font-sans:'Manrope',system-ui,-apple-system,sans-serif;
  --font-display:'Plus Jakarta Sans',sans-serif;
  --font-mono:'JetBrains Mono','SF Mono',Menlo,monospace;
  --sidebar-w:216px; --sidebar-w-collapsed:64px;
}

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:14px;line-height:1.5;overflow-x:hidden;-webkit-font-smoothing:antialiased}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
a{color:inherit;text-decoration:none}
input,select,textarea{font:inherit;color:inherit}

/* === LAYOUT === */
.app{display:flex;min-height:100vh}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.content{padding:24px;flex:1;background:var(--bg)}

/* === SIDEBAR PREMIUM === */
.sidebar{width:var(--sidebar-w);flex-shrink:0;background:linear-gradient(180deg,var(--surface) 0%,var(--surface-2) 100%);border-right:1px solid var(--border);padding:16px 10px 14px;display:flex;flex-direction:column;gap:2px;position:sticky;top:0;height:100vh;overflow-y:auto;overflow-x:hidden;transition:width .28s cubic-bezier(0.4,0,0.2,1);box-shadow:1px 0 0 rgba(20,40,60,0.02)}
.sidebar.collapsed{width:var(--sidebar-w-collapsed);padding:16px 8px 14px}
.sidebar.collapsed .nav-section,.sidebar.collapsed .brand-text,.sidebar.collapsed .user-info,.sidebar.collapsed .nav-item span:not(.nav-badge),.sidebar.collapsed .nav-badge{display:none}
.sidebar.collapsed .nav-item{justify-content:center;padding:11px 0;position:relative}
.sidebar.collapsed .nav-item:hover::after{content:attr(data-label);position:absolute;left:calc(100% + 14px);top:50%;transform:translateY(-50%);background:var(--primary);color:#fff;padding:7px 13px;border-radius:8px;font-size:12px;white-space:nowrap;z-index:50;box-shadow:var(--shadow-md);font-weight:600;pointer-events:none;letter-spacing:0.01em}
.sidebar.collapsed .nav-item:hover::before{content:"";position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%) rotate(45deg);width:8px;height:8px;background:var(--primary);z-index:50}
.sidebar.collapsed .brand{justify-content:center;padding:2px 0 14px}
.sidebar.collapsed .brand-logo{width:40px;height:40px}
.sidebar.collapsed .sidebar-foot{justify-content:center;flex-direction:column;gap:8px}
.sidebar.collapsed .sidebar-foot .avatar{width:34px;height:34px}
.sidebar.collapsed .sidebar-foot .user-info{display:none}
.sidebar.collapsed .nav-divider{margin:8px 6px}

.brand{display:flex;align-items:center;gap:10px;padding:2px 6px 14px;border-bottom:1px solid var(--border);margin-bottom:10px;transition:padding .28s}
.brand-logo{width:42px;height:42px;background-image:url('../assets/logo/ibarnelli-transparente.png');background-size:contain;background-repeat:no-repeat;background-position:center;flex-shrink:0;transition:all .28s}
.brand-text{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--primary);letter-spacing:-0.01em;line-height:1.15;white-space:nowrap;overflow:hidden}
.brand-text small{display:block;font-size:9.5px;color:var(--accent);font-weight:700;font-family:var(--font-sans);letter-spacing:0.08em;text-transform:uppercase;margin-top:2px}

.nav-section{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:0.1em;padding:14px 12px 6px;font-weight:700;white-space:nowrap}
.nav-divider{height:1px;background:var(--border);margin:8px 6px;opacity:0.6}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:9px;color:var(--text-2);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease;position:relative;white-space:nowrap;letter-spacing:-0.005em}
.nav-item i{font-size:18px;flex-shrink:0;transition:transform .15s ease}
.nav-item:hover{background:var(--bg-2);color:var(--primary)}
.nav-item:hover i{transform:scale(1.08)}
.nav-item.active{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;font-weight:600;box-shadow:0 2px 8px rgba(20,40,60,0.18)}
.nav-item.active i{color:#fff}
.nav-item.active::before{content:"";position:absolute;left:-10px;top:50%;transform:translateY(-50%);width:3px;height:18px;background:var(--accent);border-radius:0 3px 3px 0}
.sidebar.collapsed .nav-item.active::before{left:-8px;height:22px}
.nav-badge{margin-left:auto;background:var(--bg-2);color:var(--text-2);font-size:10px;padding:2px 7px;border-radius:999px;font-weight:700;min-width:20px;text-align:center}
.nav-item.active .nav-badge{background:rgba(255,255,255,0.18);color:#fff}

.sidebar-foot{margin-top:auto;padding-top:12px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px;transition:all .28s}
.avatar{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);display:grid;place-items:center;font-weight:700;font-size:12.5px;color:#fff;font-family:var(--font-display);flex-shrink:0;box-shadow:0 2px 6px rgba(20,40,60,0.18)}
.user-info{flex:1;min-width:0}
.user-info b{font-size:12.5px;font-weight:700;display:block;color:var(--primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-0.005em}
.user-info span{font-size:10.5px;color:var(--text-3);font-weight:500}

.collapse-btn{width:30px;height:30px;border-radius:8px;background:var(--bg-2);display:grid;place-items:center;font-size:14px;color:var(--text-2);border:1px solid var(--border);transition:all .18s;cursor:pointer;flex-shrink:0}
.collapse-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:scale(1.05)}
.collapse-btn i{transition:transform .28s cubic-bezier(0.4,0,0.2,1)}
.sidebar.collapsed .collapse-btn i{transform:rotate(180deg)}

/* === TOPBAR === */
.topbar{display:flex;align-items:center;gap:14px;padding:14px 24px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:10;backdrop-filter:blur(8px)}
.mobile-menu{display:none;width:38px;height:38px;border-radius:10px;background:var(--bg-2);align-items:center;justify-content:center;font-size:20px;color:var(--primary);border:1px solid var(--border);transition:all .15s;cursor:pointer}
.mobile-menu:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.topbar h1{font-family:var(--font-display);font-weight:700;font-size:19px;color:var(--primary);letter-spacing:-0.02em;min-width:0;flex:1}
.topbar h1 small{display:block;font-size:11.5px;color:var(--text-3);font-weight:500;font-family:var(--font-sans);letter-spacing:0;margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.topbar-actions{margin-left:auto;display:flex;gap:8px;align-items:center;flex-shrink:0}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:10px;font-size:13.5px;font-weight:600;background:var(--surface);border:1px solid var(--border);color:var(--text);transition:all .15s;cursor:pointer}
.btn:hover{border-color:var(--primary);background:var(--bg-2)}
.btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn.primary:hover{background:var(--primary-dark);border-color:var(--primary-dark)}
.btn.accent{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn.accent:hover{background:var(--accent-dark);border-color:var(--accent-dark)}
.btn.ok{background:var(--ok);color:#fff;border-color:var(--ok)}
.btn.ok:hover{background:#0a6e3a;border-color:#0a6e3a}
.btn.ghost{background:transparent;border:none}
.btn.ghost:hover{background:var(--bg-2)}
.btn i{font-size:17px}

.icon-btn{width:40px;height:40px;border-radius:10px;background:var(--surface);display:grid;place-items:center;font-size:18px;color:var(--text-2);border:1px solid var(--border);transition:all .15s;cursor:pointer}
.icon-btn:hover{color:var(--primary);border-color:var(--primary);background:var(--bg-2)}

/* === PILLS === */
.pill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;background:var(--bg-2);color:var(--text-2)}
.pill.ok{background:var(--ok-soft);color:var(--ok)}
.pill.warn{background:var(--warn-soft);color:var(--warn)}
.pill.danger{background:var(--danger-soft);color:var(--danger)}
.pill.info{background:var(--info-soft);color:var(--info)}
.pill.accent{background:var(--accent-soft);color:var(--accent)}
.pill.primary{background:var(--primary-soft);color:var(--primary)}
.pill.gold{background:var(--gold-soft);color:var(--gold)}

/* === CARDS === */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-sm)}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:10px;flex-wrap:wrap}
.card-title{font-size:14.5px;font-weight:700;color:var(--primary);font-family:var(--font-display)}
.card-title small{display:block;font-size:12px;color:var(--text-3);font-weight:500;font-family:var(--font-sans);margin-top:2px}

/* === KPI === */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.kpi{position:relative;overflow:hidden}
.kpi-label{font-size:12px;color:var(--text-3);font-weight:600;display:flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:0.04em}
.kpi-label i{font-size:15px;color:var(--text-2)}
.kpi-value{font-family:var(--font-display);font-size:30px;font-weight:700;letter-spacing:-0.02em;margin:10px 0 4px;line-height:1;color:var(--primary)}
.kpi-value .unit{font-size:14px;color:var(--text-3);font-weight:500;margin-left:4px;font-family:var(--font-sans)}
.kpi-delta{font-size:12px;display:inline-flex;align-items:center;gap:4px;color:var(--text-2);font-weight:500}
.kpi-delta.up{color:var(--ok)}
.kpi-delta.down{color:var(--danger)}

.hero-card{grid-column:span 2;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);border:1px solid var(--primary);position:relative;overflow:hidden;color:#fff}
.hero-card .kpi-label{color:rgba(255,255,255,0.7)}
.hero-card .kpi-label i{color:rgba(255,255,255,0.8)}
.hero-card .kpi-value{font-size:38px;color:#fff}
.hero-card .kpi-value .unit{color:rgba(255,255,255,0.6)}
.hero-card .kpi-delta{color:#fff}
.hero-card::after{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;background:radial-gradient(circle,rgba(180,20,40,0.3) 0%,transparent 70%);pointer-events:none}

/* === GRID HELPERS === */
.row{display:grid;gap:16px}
.row.cols-2{grid-template-columns:2fr 1fr}
.row.cols-3{grid-template-columns:1fr 1fr 1fr}
.row.cols-4{grid-template-columns:repeat(4,1fr)}
.row.cols-half{grid-template-columns:1fr 1fr}

/* === TABLE === */
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;font-weight:600;color:var(--text-3);font-size:11px;text-transform:uppercase;letter-spacing:0.06em;padding:10px 12px;border-bottom:1px solid var(--border)}
td{padding:13px 12px;border-bottom:1px solid var(--border);color:var(--text)}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--bg-2)}
.mono{font-family:var(--font-mono);font-size:12px;font-weight:500}
.num{text-align:right;font-variant-numeric:tabular-nums}

/* === LOGIN === */
.login{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 20% 30%,rgba(180,20,40,0.06) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(20,40,60,0.06) 0%,transparent 50%),var(--bg)}
.login-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:40px 36px;box-shadow:var(--shadow-lg)}
.login-logo{width:280px;max-width:100%;height:auto;margin:0 auto 24px;display:block}
.login h2{font-family:var(--font-display);font-size:24px;font-weight:700;letter-spacing:-0.02em;margin-bottom:6px;color:var(--primary);text-align:center}
.login p.sub{color:var(--text-3);font-size:13.5px;margin-bottom:28px;text-align:center}
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;color:var(--text-2);margin-bottom:6px;font-weight:600}
.field input{width:100%;padding:12px 14px;border-radius:10px;background:var(--bg-2);border:1px solid var(--border);font-size:14px;outline:none;transition:all .15s;color:var(--text)}
.field input:focus{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 3px var(--primary-soft)}
.login .btn.primary{width:100%;justify-content:center;padding:13px;margin-top:8px;font-size:14px}

/* === VIEWS === */
.view{display:none;animation:fadeIn .25s ease}
.view.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* === PROGRESS === */
.progress{height:8px;background:var(--bg-3);border-radius:999px;overflow:hidden;margin-top:8px}
.progress-fill{height:100%;background:var(--primary);border-radius:999px;transition:width .4s}

/* === MODALS === */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(20,40,60,0.6);z-index:100;align-items:flex-start;justify-content:center;padding:24px;overflow-y:auto;backdrop-filter:blur(4px)}
.modal-bg.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:20px;width:100%;max-width:580px;padding:30px;margin:40px auto;box-shadow:var(--shadow-lg)}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.modal-head h3{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--primary)}

/* === FORMS === */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid .full{grid-column:span 2}
.form-grid label{display:block;font-size:12px;color:var(--text-2);margin-bottom:6px;font-weight:600}
.form-grid input,.form-grid select,.form-grid textarea{width:100%;padding:11px 13px;border-radius:10px;background:var(--bg-2);border:1px solid var(--border);outline:none;font-size:13.5px;color:var(--text);transition:all .15s}
.form-grid input:focus,.form-grid select:focus,.form-grid textarea:focus{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 3px var(--primary-soft)}

/* === BANNERS === */
.banner{background:linear-gradient(135deg,var(--accent-soft) 0%,rgba(180,20,40,0.04) 100%);border:1px solid rgba(180,20,40,0.2);border-radius:14px;padding:16px 20px;margin-bottom:22px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.banner i{font-size:22px;color:var(--accent)}
.banner b{color:var(--accent-dark);font-weight:700}
.banner-text{flex:1;font-size:13px;color:var(--text);min-width:200px}
.banner.ok{background:linear-gradient(135deg,var(--ok-soft) 0%,rgba(14,138,74,0.04) 100%);border-color:rgba(14,138,74,0.2)}
.banner.ok i{color:var(--ok)}
.banner.ok b{color:#0a6e3a}
.banner.info{background:linear-gradient(135deg,var(--info-soft) 0%,rgba(31,111,181,0.04) 100%);border-color:rgba(31,111,181,0.2)}
.banner.info i{color:var(--info)}
.banner.info b{color:#155a99}
.banner.warn{background:linear-gradient(135deg,var(--warn-soft) 0%,rgba(217,119,6,0.04) 100%);border-color:rgba(217,119,6,0.2)}
.banner.warn i{color:var(--warn)}
.banner.warn b{color:#a85d05}

/* === TABS === */
.tabs{display:flex;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:5px;margin-bottom:22px;width:fit-content;overflow-x:auto;max-width:100%}
.tab{padding:9px 18px;border-radius:8px;font-size:13px;color:var(--text-2);font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s}
.tab:hover{color:var(--primary)}
.tab.active{background:var(--primary);color:#fff}

/* === BREAKEVEN BARS === */
.breakeven{display:flex;align-items:flex-end;gap:14px;padding:8px 0;height:140px}
.be-bar{flex:1;background:var(--bg-3);border-radius:8px 8px 0 0;position:relative;min-height:30px;transition:height .4s}
.be-bar.target{background:var(--bg-2);border-top:3px dashed var(--accent)}
.be-bar.current{background:linear-gradient(180deg,var(--primary) 0%,var(--primary-light) 100%)}
.be-bar label{position:absolute;top:-22px;left:0;right:0;text-align:center;font-size:11px;color:var(--text-3);font-weight:600}
.be-bar value{position:absolute;bottom:-22px;left:0;right:0;text-align:center;font-size:12px;font-weight:700;color:var(--text);display:block}

/* === POS ITEMS === */
.pos-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.pos-item:last-child{border-bottom:none}
.pos-item-info{flex:1;min-width:0}
.pos-item-info b{font-size:13.5px;font-weight:600;color:var(--text);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pos-item-info span{font-size:11.5px;color:var(--text-3)}
.pos-qty{display:flex;align-items:center;gap:6px;background:var(--bg-2);border-radius:8px;padding:3px;border:1px solid var(--border)}
.pos-qty button{width:28px;height:28px;border-radius:6px;display:grid;place-items:center;font-size:16px;color:var(--text-2)}
.pos-qty button:hover{background:var(--surface);color:var(--primary)}
.pos-qty span{width:28px;text-align:center;font-weight:700;font-size:13px;color:var(--primary)}

/* === LOAN === */
.loan-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}
.sim-result{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;border-radius:14px;padding:18px;margin-top:14px}
.sim-result p{color:rgba(255,255,255,0.85)}
.sim-result b{color:#fff;font-family:var(--font-display);font-size:22px}
.sim-result .accent-num{color:var(--accent-light)}

/* === HEALTH CARD === */
.health-card{background:linear-gradient(135deg,#0E1C2A 0%,#14283C 50%,#1F3754 100%);color:#fff;border:1px solid var(--primary);border-radius:var(--radius-lg);padding:24px;position:relative;overflow:hidden}
.health-card::before{content:"";position:absolute;top:-30%;right:-10%;width:300px;height:300px;background:radial-gradient(circle,rgba(14,138,74,0.25) 0%,transparent 70%);pointer-events:none}
.health-title{font-size:12px;color:rgba(255,255,255,0.6);font-weight:600;text-transform:uppercase;letter-spacing:0.06em;display:flex;align-items:center;gap:6px;position:relative;z-index:1}
.health-status{font-family:var(--font-display);font-size:34px;font-weight:800;color:#fff;margin:8px 0 14px;position:relative;z-index:1;display:flex;align-items:center;gap:10px}
.health-bar{height:10px;background:rgba(255,255,255,0.1);border-radius:999px;position:relative;margin-bottom:8px;overflow:hidden}
.health-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent) 0%,var(--warn) 33%,var(--ok) 66%,#1FB876 100%);border-radius:999px;transition:width .6s}
.health-bar-marker{position:absolute;top:-4px;width:4px;height:18px;background:#fff;border-radius:2px;box-shadow:0 0 8px rgba(0,0,0,0.4);transition:left .6s}
.health-zones{display:flex;font-size:10px;color:rgba(255,255,255,0.5);font-weight:600;letter-spacing:0.04em;text-transform:uppercase;margin-bottom:18px}
.health-zones span{flex:1;text-align:center}
.health-indicators{display:grid;grid-template-columns:1fr 1fr;gap:8px;font-size:12.5px;position:relative;z-index:1}
.health-indicator{display:flex;align-items:center;gap:7px;color:rgba(255,255,255,0.85);padding:6px 10px;background:rgba(255,255,255,0.06);border-radius:8px}
.health-indicator i{color:var(--ok);font-size:14px}
.health-indicator.warn i{color:var(--warn)}
.health-indicator.danger i{color:var(--accent-light)}
.health-action{background:rgba(255,255,255,0.08);border-left:3px solid var(--ok);padding:10px 14px;border-radius:8px;margin-top:14px;font-size:12.5px;position:relative;z-index:1}
.health-action b{color:#fff;display:block;margin-bottom:2px}
.health-action p{color:rgba(255,255,255,0.75)}

/* === RECOVERY === */
.recovery-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;margin-bottom:12px}
.recovery-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px;gap:10px;flex-wrap:wrap}
.recovery-vehicle b{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--primary);display:block;margin-bottom:2px}
.recovery-vehicle span{font-size:12px;color:var(--text-3)}
.recovery-progress{height:18px;background:var(--bg-3);border-radius:999px;overflow:hidden;position:relative;margin:14px 0 8px}
.recovery-progress-fill{height:100%;background:linear-gradient(90deg,var(--warn) 0%,var(--ok) 100%);border-radius:999px;transition:width .5s}
.recovery-progress.completed .recovery-progress-fill{background:linear-gradient(90deg,var(--ok) 0%,#1FB876 100%)}
.recovery-progress.overflow .recovery-progress-fill{background:linear-gradient(90deg,var(--ok) 0%,var(--gold) 100%)}
.recovery-stats{display:flex;justify-content:space-between;font-size:12px;color:var(--text-2);flex-wrap:wrap;gap:8px}
.recovery-stats .mono{font-weight:700;color:var(--text)}

/* === BUCKETS === */
.bucket-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;position:relative;overflow:hidden}
.bucket-card.fixed{border-color:rgba(31,111,181,0.3)}
.bucket-card.salary{border-color:rgba(14,138,74,0.3)}
.bucket-card.reserve{border-color:rgba(217,119,6,0.3)}
.bucket-card.growth{border-color:rgba(163,126,44,0.3)}
.bucket-icon{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:20px;margin-bottom:12px}
.bucket-icon.fixed{background:var(--info-soft);color:var(--info)}
.bucket-icon.salary{background:var(--ok-soft);color:var(--ok)}
.bucket-icon.reserve{background:var(--warn-soft);color:var(--warn)}
.bucket-icon.growth{background:var(--gold-soft);color:var(--gold)}
.bucket-label{font-size:11.5px;color:var(--text-3);text-transform:uppercase;letter-spacing:0.06em;font-weight:600;margin-bottom:4px}
.bucket-percentage{font-size:14px;color:var(--text-2);font-weight:600;margin-bottom:6px}
.bucket-amount{font-family:var(--font-display);font-size:26px;font-weight:700;color:var(--primary);letter-spacing:-0.02em;margin-bottom:6px}
.bucket-detail{font-size:11.5px;color:var(--text-2);line-height:1.5}
.bucket-bar{height:6px;background:var(--bg-3);border-radius:999px;overflow:hidden;margin-top:10px}
.bucket-bar-fill{height:100%;border-radius:999px;transition:width .5s}
.bucket-status{font-size:10.5px;color:var(--text-3);margin-top:6px;font-weight:600;letter-spacing:0.04em;text-transform:uppercase}

/* === SUELDO MODULE (BASE + BONUS) === */
.salary-hero{background:linear-gradient(135deg,#0a6e3a 0%,#0E8A4A 50%,#1FB876 100%);color:#fff;border-radius:var(--radius-lg);padding:28px;position:relative;overflow:hidden;margin-bottom:18px}
.salary-hero::before{content:"";position:absolute;top:-40%;right:-15%;width:340px;height:340px;background:radial-gradient(circle,rgba(255,255,255,0.15) 0%,transparent 70%);pointer-events:none}
.salary-hero-label{font-size:12px;color:rgba(255,255,255,0.75);font-weight:600;text-transform:uppercase;letter-spacing:0.06em;position:relative;z-index:1}
.salary-hero-amount{font-family:var(--font-display);font-size:56px;font-weight:800;color:#fff;letter-spacing:-0.03em;line-height:1;margin:8px 0 4px;position:relative;z-index:1}
.salary-hero-amount .small{font-size:24px;opacity:0.7}
.salary-hero-split{font-size:14px;color:rgba(255,255,255,0.9);position:relative;z-index:1;margin-bottom:18px;display:flex;flex-wrap:wrap;gap:14px}
.salary-hero-split .pill-base{background:rgba(255,255,255,0.18);padding:4px 12px;border-radius:999px;font-weight:700}
.salary-hero-split .pill-bonus{background:#A37E2C;padding:4px 12px;border-radius:999px;font-weight:700;color:#fff}
.salary-hero-bar{height:14px;background:rgba(0,0,0,0.2);border-radius:999px;overflow:hidden;position:relative;z-index:1;margin-bottom:8px}
.salary-hero-bar-base{height:100%;background:rgba(255,255,255,0.6);border-radius:999px;float:left;transition:width .5s}
.salary-hero-bar-bonus{height:100%;background:var(--gold);border-radius:999px;float:left;transition:width .5s}
.salary-hero-marks{font-size:10px;color:rgba(255,255,255,0.6);font-weight:600;letter-spacing:0.04em;text-transform:uppercase;display:flex;justify-content:space-between;position:relative;z-index:1}

.condition-card{display:flex;align-items:flex-start;gap:12px;padding:14px;background:var(--bg-2);border-radius:12px;border-left:4px solid var(--ok);margin-bottom:10px;transition:all .2s}
.condition-card.failed{border-left-color:var(--accent);background:var(--accent-soft)}
.condition-card.pending{border-left-color:var(--warn);background:var(--warn-soft)}
.condition-icon{width:32px;height:32px;border-radius:10px;background:var(--ok);color:#fff;display:grid;place-items:center;font-size:18px;flex-shrink:0}
.condition-card.failed .condition-icon{background:var(--accent)}
.condition-card.pending .condition-icon{background:var(--warn)}
.condition-body{flex:1;min-width:0}
.condition-body b{font-size:13px;color:var(--primary);display:block;margin-bottom:2px}
.condition-body span{font-size:12px;color:var(--text-2)}
.condition-status{font-family:var(--font-mono);font-weight:700;font-size:13px;color:var(--ok);white-space:nowrap}
.condition-card.failed .condition-status{color:var(--accent)}
.condition-card.pending .condition-status{color:var(--warn)}

.lookback-month{flex:1;padding:14px;background:var(--surface);border:2px solid var(--border);border-radius:12px;text-align:center;position:relative;transition:all .2s}
.lookback-month.ok{border-color:var(--ok);background:var(--ok-soft)}
.lookback-month.warn{border-color:var(--warn);background:var(--warn-soft)}
.lookback-month.current{border-color:var(--primary);background:var(--primary-soft)}
.lookback-label{font-size:11px;color:var(--text-3);font-weight:600;text-transform:uppercase;letter-spacing:0.04em;margin-bottom:6px}
.lookback-value{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--primary);margin-bottom:4px}
.lookback-status{font-size:11px;font-weight:600}
.lookback-status.ok{color:var(--ok)}
.lookback-status.warn{color:var(--warn)}
.lookback-arrow{position:absolute;right:-14px;top:50%;transform:translateY(-50%);width:24px;height:24px;background:var(--surface);border-radius:50%;display:grid;place-items:center;color:var(--text-3);font-size:14px;z-index:2;border:1px solid var(--border)}

.salary-slider{position:relative;height:60px;margin:20px 0 30px;padding:0 14px}
.salary-track{position:absolute;top:50%;left:14px;right:14px;height:10px;background:var(--bg-3);border-radius:999px;transform:translateY(-50%);overflow:hidden}
.salary-track-base{height:100%;background:linear-gradient(90deg,var(--ok) 0%,#1FB876 100%);border-radius:999px 0 0 999px;float:left}
.salary-track-bonus{height:100%;background:linear-gradient(90deg,var(--gold) 0%,#C8A04F 100%);float:left}
.salary-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:24px;height:24px;background:var(--surface);border:3px solid var(--primary);border-radius:50%;box-shadow:var(--shadow-md);z-index:2}
.salary-marker::after{content:attr(data-label);position:absolute;top:30px;left:50%;transform:translateX(-50%);font-size:11px;color:var(--text-2);font-weight:700;white-space:nowrap}
.salary-piso,.salary-techo,.salary-techo-bonus{position:absolute;top:0;height:60px;border-left:2px dashed var(--text-3);padding-left:6px;font-size:10px;color:var(--text-3);font-weight:600;text-transform:uppercase;letter-spacing:0.04em;display:flex;flex-direction:column;justify-content:center}
.salary-piso{left:14px}
.salary-techo{left:50%}
.salary-techo-bonus{right:14px;border-left:none;border-right:2px dashed var(--gold);padding-left:0;padding-right:6px;text-align:right;color:var(--gold)}

/* === BANK CONCILIATION === */
.bank-comp-item{display:flex;justify-content:space-between;align-items:center;padding:10px;border-radius:10px}

/* === RESPONSIVE === */
/* Tablet grande / laptop pequeña: auto-colapsar sidebar */
@media (max-width:1180px){
  .sidebar:not(.force-expanded){width:var(--sidebar-w-collapsed);padding:16px 8px 14px}
  .sidebar:not(.force-expanded) .nav-section,
  .sidebar:not(.force-expanded) .brand-text,
  .sidebar:not(.force-expanded) .user-info,
  .sidebar:not(.force-expanded) .nav-item span:not(.nav-badge),
  .sidebar:not(.force-expanded) .nav-badge{display:none}
  .sidebar:not(.force-expanded) .nav-item{justify-content:center;padding:11px 0;position:relative}
  .sidebar:not(.force-expanded) .nav-item:hover::after{content:attr(data-label);position:absolute;left:calc(100% + 14px);top:50%;transform:translateY(-50%);background:var(--primary);color:#fff;padding:7px 13px;border-radius:8px;font-size:12px;white-space:nowrap;z-index:50;box-shadow:var(--shadow-md);font-weight:600;pointer-events:none}
  .sidebar:not(.force-expanded) .brand{justify-content:center;padding:2px 0 14px}
  .sidebar:not(.force-expanded) .brand-logo{width:40px;height:40px}
  .sidebar:not(.force-expanded) .sidebar-foot{justify-content:center;flex-direction:column;gap:8px}
  .sidebar:not(.force-expanded) .sidebar-foot .user-info{display:none}
  .sidebar:not(.force-expanded) .nav-item.active::before{left:-8px;height:22px}
  .sidebar:not(.force-expanded) .collapse-btn i{transform:rotate(180deg)}
}
@media (max-width:980px){
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .row.cols-2,.row.cols-3,.row.cols-4,.row.cols-half{grid-template-columns:1fr}
  .hero-card{grid-column:span 2}
  .content{padding:20px}
  .loan-summary{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  .sidebar{position:fixed;left:-260px;top:0;z-index:30;transition:left .28s cubic-bezier(0.4,0,0.2,1);box-shadow:20px 0 60px rgba(20,40,60,0.25);width:240px!important;padding:16px 10px 14px!important}
  .sidebar.open{left:0}
  .sidebar .nav-section,.sidebar .brand-text,.sidebar .user-info,.sidebar .nav-item span:not(.nav-badge),.sidebar .nav-badge{display:initial!important}
  .sidebar .nav-item{justify-content:flex-start!important;padding:10px 11px!important}
  .sidebar .nav-item:hover::after,.sidebar .nav-item:hover::before{display:none!important;content:none!important}
  .sidebar .brand{justify-content:flex-start!important;padding:2px 6px 14px!important}
  .sidebar .brand-logo{width:42px!important;height:42px!important}
  .sidebar .sidebar-foot{justify-content:flex-start!important;flex-direction:row!important;gap:10px!important}
  .sidebar .sidebar-foot .avatar{width:34px!important;height:34px!important}
  .sidebar .sidebar-foot .user-info{display:block!important}
  .sidebar .nav-item.active::before{left:-10px!important;height:18px!important}
  .collapse-btn{display:none}
  .mobile-menu{display:flex}
  .content{padding:16px}
  .topbar{padding:12px 16px;gap:10px}
  .topbar h1{font-size:16px}
  .topbar h1 small{font-size:11px}
  .topbar-actions .btn-text{display:none}
  .topbar-actions .btn{padding:9px 12px}
  .topbar-actions .icon-btn{width:38px;height:38px}
  .kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .kpi-value{font-size:22px}
  .kpi{padding:16px}
  .hero-card .kpi-value{font-size:26px}
  .card{padding:16px}
  .card-head{margin-bottom:14px}
  table{font-size:12px}
  th,td{padding:9px 10px}
  .hide-mobile{display:none}
  .form-grid{grid-template-columns:1fr}
  .form-grid .full{grid-column:span 1}
  .health-indicators{grid-template-columns:1fr}
  .salary-hero{padding:20px}
  .salary-hero-amount{font-size:36px}
  .loan-summary{grid-template-columns:repeat(2,1fr);gap:10px}
  .modal{padding:22px;border-radius:16px}
  .modal-head h3{font-size:18px}
  .breakeven{height:120px;gap:10px}
}
@media (max-width:480px){
  .content{padding:12px}
  .topbar{padding:10px 12px}
  .topbar h1{font-size:15px}
  .kpi-grid{grid-template-columns:1fr;gap:10px}
  .card{padding:14px;border-radius:12px}
  .modal-bg{padding:12px}
  .modal{padding:18px;margin:20px auto}
  .login-card{padding:28px 22px;border-radius:16px}
}

.scrim{display:none;position:fixed;inset:0;background:rgba(20,40,60,0.4);z-index:25}
.scrim.open{display:block}
@media (min-width:761px){.scrim{display:none!important}}

::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--text-3)}
