:root{--p-ink: #292929;--p-mist: #f2f2f2;--p-cyan: #01a0c6;--p-cyan-600: #018ba9;--p-cyan-50: #e6f6fa;--surface-0: #ffffff;--surface-1: #f7f7f8;--surface-2: #f2f2f2;--surface-3: #ebebed;--border-subtle: #e7e7ea;--border-strong: #d4d4d8;--text-primary: #18181b;--text-secondary: #5c5c66;--text-muted: #9094a0;--success: #16a34a;--success-50: #ecfdf5;--warning: #d97706;--warning-50: #fff7ed;--danger: #dc2626;--danger-50: #fef2f2;--font-display: "Manrope", ui-sans-serif, system-ui, sans-serif;--font-body: "Inter", ui-sans-serif, system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, monospace;--font-num: "Inter", ui-sans-serif, system-ui, sans-serif;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px;--shadow-sm: 0 1px 2px rgba(24, 24, 27, .04), 0 0 0 1px rgba(24, 24, 27, .04);--shadow-md: 0 2px 8px rgba(24, 24, 27, .06), 0 0 0 1px rgba(24, 24, 27, .05)}html.dark{--surface-0: #0e0f12;--surface-1: #15171b;--surface-2: #1c1e23;--surface-3: #24272d;--border-subtle: #26282e;--border-strong: #34373e;--text-primary: #f4f4f5;--text-secondary: #a1a4ad;--text-muted: #6b6e78;--p-mist: #1c1e23;--success-50: #052e1c;--warning-50: #2a1a05;--danger-50: #2a0c0c;--p-cyan-50: #052830;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4), 0 0 0 1px rgba(255, 255, 255, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .5), 0 0 0 1px rgba(255, 255, 255, .05)}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font-body);background:var(--surface-1);color:var(--text-primary);font-feature-settings:"cv11","ss01","ss03";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.45}.num,td.num,.kpi-value,.currency{font-variant-numeric:tabular-nums;font-feature-settings:"tnum","cv11"}.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{background:var(--surface-0);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:10px;padding:18px 20px;border-bottom:1px solid var(--border-subtle)}.brand .logo{width:26px;height:26px;color:var(--text-primary)}.brand .wordmark{font-family:var(--font-display);font-weight:700;letter-spacing:.04em;font-size:14px;color:var(--text-primary)}.brand .env{margin-left:auto;font-size:10.5px;color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border-subtle);padding:2px 6px;border-radius:999px;letter-spacing:.04em;text-transform:uppercase;font-weight:600}.nav{display:flex;flex-direction:column;gap:2px;padding:12px 10px;flex:1}.nav-section{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:14px 10px 6px;font-weight:600}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r-sm);color:var(--text-secondary);font-weight:500;cursor:pointer;border:none;background:transparent;font-family:inherit;font-size:13.5px;text-align:left;width:100%}.nav-item:hover{background:var(--surface-1);color:var(--text-primary)}.nav-item.active{background:var(--surface-2);color:var(--text-primary)}.nav-item.active .nav-icon{color:var(--p-cyan)}.nav-icon{width:16px;height:16px;color:var(--text-muted);flex-shrink:0}.nav-badge{margin-left:auto;font-size:11px;background:var(--surface-2);border:1px solid var(--border-subtle);padding:1px 6px;border-radius:999px;color:var(--text-secondary);font-variant-numeric:tabular-nums}.nav-badge.danger{background:var(--danger-50);color:var(--danger);border-color:transparent}.user-card{display:flex;align-items:center;gap:10px;padding:12px 14px;border-top:1px solid var(--border-subtle)}.avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--p-cyan),#0270a8);color:#fff;display:grid;place-items:center;font-size:11px;font-weight:700;font-family:var(--font-display);letter-spacing:.02em}.user-card .who{display:flex;flex-direction:column;line-height:1.15}.user-card .who b{font-size:12.5px;font-weight:600}.user-card .who span{font-size:11px;color:var(--text-muted)}.main{display:flex;flex-direction:column;min-width:0}.topbar{position:sticky;top:0;z-index:10;background:color-mix(in srgb,var(--surface-1) 85%,transparent);-webkit-backdrop-filter:saturate(140%) blur(8px);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--border-subtle);padding:12px 28px;display:flex;align-items:center;gap:16px}.topbar h1{font-family:var(--font-display);font-size:17px;font-weight:700;letter-spacing:-.01em;margin:0}.topbar .breadcrumb{color:var(--text-muted);font-size:12.5px;margin-left:2px}.topbar .actions{margin-left:auto;display:flex;align-items:center;gap:8px}.btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--r-sm);border:1px solid var(--border-subtle);background:var(--surface-0);color:var(--text-primary);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .12s ease,border-color .12s ease}.btn:hover{background:var(--surface-2)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn.primary{background:var(--p-cyan);border-color:var(--p-cyan);color:#fff}.btn.primary:hover{background:var(--p-cyan-600);border-color:var(--p-cyan-600)}.btn.ghost{background:transparent;border-color:transparent;color:var(--text-secondary)}.btn.ghost:hover{background:var(--surface-2);color:var(--text-primary)}.btn.icon{padding:6px}.btn .icon-svg{width:14px;height:14px}.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--r-sm);padding:2px}.seg button{border:none;background:transparent;color:var(--text-secondary);padding:4px 10px;font-size:12.5px;font-weight:500;border-radius:4px;cursor:pointer;font-family:inherit;font-variant-numeric:tabular-nums}.seg button.on{background:var(--surface-0);color:var(--text-primary);box-shadow:var(--shadow-sm)}.content{padding:24px 28px 60px;display:flex;flex-direction:column;gap:22px;max-width:1480px;width:100%}.banner{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:var(--r-md);border:1px solid var(--border-subtle);background:var(--surface-0)}.banner.danger{background:var(--danger-50);border-color:color-mix(in srgb,var(--danger) 25%,transparent)}.banner.danger .banner-icon{color:var(--danger)}.banner-icon{width:18px;height:18px;flex-shrink:0;margin-top:1px}.banner-body{flex:1}.banner-title{font-weight:600;font-size:13.5px;margin:0 0 2px}.banner-text{font-size:13px;color:var(--text-secondary);margin:0}.banner.danger .banner-title{color:var(--danger)}.kpi-row{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:14px}.card{background:var(--surface-0);border:1px solid var(--border-subtle);border-radius:var(--r-md);padding:18px}.kpi-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin:0 0 8px;display:flex;align-items:center;gap:6px}.kpi-value{font-family:var(--font-display);font-size:32px;font-weight:700;letter-spacing:-.02em;line-height:1.05;color:var(--text-primary)}.kpi-value.lg{font-size:40px}.kpi-sub{margin-top:10px;font-size:12.5px;color:var(--text-secondary);display:flex;align-items:center;gap:6px}.kpi-sub.success{color:var(--success)}.kpi-sub.danger{color:var(--danger)}.kpi-sub.warning{color:var(--warning)}.kpi-overdue{margin-top:12px;display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:var(--r-sm);background:var(--danger-50);color:var(--danger);font-size:12px;font-weight:600;border:1px solid color-mix(in srgb,var(--danger) 18%,transparent)}.kpi-overdue .icon-svg{width:13px;height:13px}.kpi-overdue .amt{font-family:var(--font-display);font-variant-numeric:tabular-nums}.tl-event.overdue{background:var(--danger-50);border-color:color-mix(in srgb,var(--danger) 25%,transparent)}.tl-date.overdue .marker,.tl-date.overdue .small{color:var(--danger)}.delta{font-variant-numeric:tabular-nums;font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:2px;padding:2px 6px;border-radius:4px}.delta.up{background:var(--success-50);color:var(--success)}.delta.down{background:var(--danger-50);color:var(--danger)}.delta.flat{background:var(--surface-2);color:var(--text-secondary)}.card-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}.card-title{font-family:var(--font-display);font-size:14.5px;font-weight:700;letter-spacing:-.005em;margin:0}.card-sub{color:var(--text-muted);font-size:12.5px}.card-head .right{margin-left:auto;display:flex;gap:6px;align-items:center}.dual{display:grid;grid-template-columns:1.6fr 1fr;gap:14px}.dual-3{display:grid;grid-template-columns:2fr 1fr;gap:14px}.bank-list{display:flex;flex-direction:column;gap:2px}.bank-row{display:grid;grid-template-columns:1fr auto;align-items:center;padding:10px 4px;border-bottom:1px dashed var(--border-subtle)}.bank-row:last-child{border-bottom:none}.bank-row .name{display:flex;align-items:center;gap:10px}.bank-row .pill{font-size:10.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border-subtle);padding:2px 6px;border-radius:4px}.bank-row .amount{font-variant-numeric:tabular-nums;font-weight:600;font-family:var(--font-display);font-size:14.5px}.bank-row .meta{font-size:12px;color:var(--text-muted)}.tbl{width:100%;border-collapse:collapse}.tbl th,.tbl td{text-align:left;padding:10px 12px;font-size:13px;border-bottom:1px solid var(--border-subtle);vertical-align:middle}.tbl th{font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px;background:var(--surface-1);position:sticky;top:0}.tbl tr:last-child td{border-bottom:none}.tbl td.num,.tbl th.num{text-align:right;font-variant-numeric:tabular-nums}.tbl tbody tr{transition:background .12s ease}.tbl tbody tr:hover{background:var(--surface-1);cursor:pointer}.tbl .tight{padding:8px 12px}.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;font-size:11.5px;font-weight:600;border-radius:999px;letter-spacing:.01em}.tag.success{background:var(--success-50);color:var(--success)}.tag.danger{background:var(--danger-50);color:var(--danger)}.tag.warning{background:var(--warning-50);color:var(--warning)}.tag.neutral{background:var(--surface-2);color:var(--text-secondary)}.tag .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.timeline{display:flex;flex-direction:column;gap:0}.tl-day{display:grid;grid-template-columns:90px 1fr;border-top:1px solid var(--border-subtle);padding:14px 0}.tl-day:first-child{border-top:none;padding-top:0}.tl-date{font-family:var(--font-display);font-weight:700;font-size:13px;color:var(--text-primary);display:flex;flex-direction:column;line-height:1.1}.tl-date .small{color:var(--text-muted);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.06em;margin-top:2px}.tl-date.today .marker,.tl-date.today .small{color:var(--p-cyan)}.tl-events{display:flex;flex-direction:column;gap:6px}.tl-event{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;padding:8px 12px;border-radius:var(--r-sm);border:1px solid var(--border-subtle);background:var(--surface-0)}.tl-event:hover{background:var(--surface-1);cursor:pointer}.tl-event .badge{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-size:14px;font-weight:700}.tl-event.cobro .badge{background:var(--success-50);color:var(--success)}.tl-event.pago .badge{background:var(--danger-50);color:var(--danger)}.tl-event .who{font-weight:600;font-size:13px}.tl-event .ref{color:var(--text-muted);font-size:11.5px;margin-left:6px}.tl-event .amount{font-family:var(--font-display);font-weight:700;font-variant-numeric:tabular-nums;font-size:14px}.tl-event.cobro .amount:before{content:"+"}.tl-event.pago .amount:before{content:"−"}.tl-event.cobro .amount{color:var(--success)}.tl-event.pago .amount{color:var(--danger)}.bar-track{background:var(--surface-2);height:6px;border-radius:999px;overflow:hidden}.bar-fill{background:var(--p-cyan);height:100%;border-radius:999px}.pillbar{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.pill{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;background:var(--surface-0);border:1px solid var(--border-subtle);border-radius:999px;font-size:12.5px;color:var(--text-secondary);cursor:pointer;transition:all .12s ease;font-family:inherit}.pill:hover{background:var(--surface-2);color:var(--text-primary)}.pill.on{background:var(--p-cyan-50);color:var(--p-cyan-600);border-color:color-mix(in srgb,var(--p-cyan) 25%,transparent)}html.dark .pill.on{color:#6dd4ec}.cache-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 9px;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:999px;font-size:11.5px;color:var(--text-secondary)}.cache-chip .dot{width:6px;height:6px;border-radius:50%;background:var(--p-cyan);box-shadow:0 0 0 3px var(--p-cyan-50)}.login-screen{min-height:100vh;display:grid;grid-template-columns:1.2fr 1fr;background:var(--surface-0)}.login-left{position:relative;color:#fff;padding:28px 48px 48px;display:flex;flex-direction:column;justify-content:space-between;gap:32px;overflow:hidden;background:radial-gradient(1200px 600px at 110% 20%,rgba(1,160,198,.18),transparent 60%),radial-gradient(800px 400px at -10% 90%,rgba(1,160,198,.1),transparent 60%),var(--p-ink)}.login-left .pattern{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.login-left .pattern:before{content:"";position:absolute;top:-10%;right:-5%;bottom:-10%;left:-5%;background-image:repeating-linear-gradient(90deg,transparent 0px,transparent 38px,rgba(255,255,255,.045) 38px,rgba(255,255,255,.11) 42px,rgba(255,255,255,.18) 46px,rgba(255,255,255,.11) 50px,rgba(255,255,255,.045) 54px,transparent 54px,transparent 92px),radial-gradient(circle at 50% -5%,rgba(255,255,255,.06),transparent 65%);transform:rotate(-8deg);transform-origin:center;mask-image:linear-gradient(180deg,transparent 0%,black 25%,black 75%,transparent 100%);-webkit-mask-image:linear-gradient(180deg,transparent 0%,black 25%,black 75%,transparent 100%)}.login-left .pattern:after{content:"";position:absolute;right:-120px;bottom:-120px;width:520px;height:520px;background-image:radial-gradient(circle 56px at 22% 32%,rgba(255,255,255,.08) 99%,transparent 100%),radial-gradient(circle 56px at 50% 32%,rgba(1,160,198,.55) 99%,transparent 100%),radial-gradient(circle 56px at 78% 32%,rgba(255,255,255,.08) 99%,transparent 100%),radial-gradient(circle 56px at 36% 60%,rgba(255,255,255,.08) 99%,transparent 100%),radial-gradient(circle 56px at 64% 60%,rgba(255,255,255,.08) 99%,transparent 100%);filter:blur(.4px);opacity:.55}.login-left:after{content:"EST. 1976  ·  ALGEMESÍ, VALENCIA  ·  TUBOS Y MANGOS DE ALUMINIO  ·  EST. 1976  ·  ALGEMESÍ, VALENCIA  ·";position:absolute;font-family:var(--font-mono);font-size:9.5px;letter-spacing:.32em;color:#ffffff2e;white-space:nowrap;pointer-events:none;transform:rotate(-90deg) translate(-50%);transform-origin:left center;left:24px;bottom:50%}.login-left h2{font-family:var(--font-display);font-size:32px;letter-spacing:-.02em;font-weight:700;margin:0 0 14px;position:relative;max-width:420px}.login-left p{color:#ffffffa6;max-width:380px;position:relative;font-size:15px;line-height:1.55}.login-left .brand-block{display:flex;align-items:center;gap:12px;position:relative}.login-left .brand-block .logo{width:36px;height:36px;color:#fff}.login-left .brand-block .wm{font-family:var(--font-display);font-weight:700;letter-spacing:.06em;font-size:16px}.login-left .footer{position:relative;font-size:12px;color:#fff6}.login-left .footer span{color:var(--p-cyan)}.login-right{display:grid;place-items:center;padding:48px}.login-form{width:100%;max-width:380px}.login-form h3{font-family:var(--font-display);font-size:22px;letter-spacing:-.01em;margin:0 0 6px;font-weight:700}.login-form p.lead{color:var(--text-secondary);margin:0 0 28px;font-size:13.5px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:12.5px;font-weight:600;color:var(--text-secondary)}.field input{font-family:var(--font-mono);font-size:13px;padding:10px 12px;border-radius:var(--r-sm);border:1px solid var(--border-strong);background:var(--surface-0);color:var(--text-primary);outline:none;transition:border-color .12s ease,box-shadow .12s ease}.field input:focus{border-color:var(--p-cyan);box-shadow:0 0 0 3px var(--p-cyan-50)}.field .hint{font-size:11.5px;color:var(--text-muted)}.field .err{font-size:12px;color:var(--danger)}.checkbox{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-secondary);margin-bottom:22px;cursor:pointer}.checkbox input{accent-color:var(--p-cyan)}.btn-block{width:100%;justify-content:center;padding:10px;font-weight:600}.donut{display:flex;align-items:center;gap:18px}.donut-svg{width:132px;height:132px;flex-shrink:0}.donut-legend{display:flex;flex-direction:column;gap:8px;flex:1}.legend-row{display:grid;grid-template-columns:12px 1fr auto;align-items:center;gap:10px;font-size:12.5px}.legend-row .swatch{width:10px;height:10px;border-radius:2px}.legend-row .name{color:var(--text-secondary)}.legend-row .val{font-weight:600;font-variant-numeric:tabular-nums;color:var(--text-primary)}.rank{display:flex;flex-direction:column}.rank-row{display:grid;grid-template-columns:24px 1fr 90px;align-items:center;gap:12px;padding:10px 0;border-bottom:1px dashed var(--border-subtle)}.rank-row:last-child{border-bottom:none}.rank-row .pos{font-family:var(--font-display);font-weight:700;font-size:12px;color:var(--text-muted);text-align:center}.rank-row .meta{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;margin-bottom:4px}.rank-row .name{font-weight:600;font-size:13px}.rank-row .pct{color:var(--text-muted);font-size:11.5px;font-variant-numeric:tabular-nums}.rank-row .val{font-family:var(--font-display);font-weight:700;font-variant-numeric:tabular-nums;font-size:13.5px;text-align:right}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:200px 0}}.sk{display:inline-block;background:linear-gradient(90deg,var(--surface-2) 0px,var(--surface-3) 40px,var(--surface-2) 80px);background-size:200px 100%;animation:shimmer 1.4s infinite linear;border-radius:4px}.sk-line{height:12px;width:100%}.placeholder{text-align:center;padding:32px 16px;color:var(--text-muted);font-size:13px}.placeholder b{color:var(--text-secondary)}.placeholder .icon-svg{width:22px;height:22px;margin-bottom:6px;opacity:.6}.pnl{width:100%;border-collapse:collapse}.pnl th,.pnl td{padding:8px 12px;font-size:13.5px;border-bottom:1px solid var(--border-subtle);vertical-align:middle}.pnl thead th{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border-strong)}.pnl td.num,.pnl th.num{text-align:right;font-variant-numeric:tabular-nums;font-family:var(--font-display)}.pnl tr.row-hdr td{font-weight:600}.pnl tr.row-total td{border-top:1px solid var(--border-strong);border-bottom:2px solid var(--border-strong);font-family:var(--font-display);font-weight:700;font-size:14px;background:var(--surface-1)}.pnl tr.row-total td.num{font-size:15px}.pnl tr.row-total.positive td.num{color:var(--success)}.pnl tr.row-total.negative td.num{color:var(--danger)}.pnl tr.row-sub{background:var(--surface-1)}.pnl tr.row-sub td{color:var(--text-secondary);padding-left:28px;font-size:12.5px}.pnl .row-cat-sign{display:inline-block;width:14px;color:var(--text-muted)}.pnl .pct{margin-left:6px;font-size:11.5px;color:var(--text-muted);font-weight:500}.compo-row{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;padding:8px 0;border-bottom:1px dashed var(--border-subtle)}.compo-row:last-child{border-bottom:none}.compo-row .nombre{font-weight:500;font-size:13px}.compo-row .meta{font-size:11.5px;color:var(--text-muted)}.compo-row .amount{font-family:var(--font-display);font-weight:700;font-variant-numeric:tabular-nums;font-size:13.5px}.divider{height:1px;background:var(--border-subtle);border:none;margin:0}.muted{color:var(--text-muted)}.tnum{font-variant-numeric:tabular-nums}@media (max-width: 1100px){.kpi-row{grid-template-columns:1fr 1fr}.dual,.dual-3{grid-template-columns:1fr}}@media (max-width: 720px){.app{grid-template-columns:1fr}.sidebar{position:static;height:auto}.nav{flex-direction:row;overflow-x:auto}.nav-section{display:none}.login-screen{grid-template-columns:1fr}.login-left{display:none}}
