:root{--accent: #34508e;--accent-2: #223560;--muted: #a99ebe;--text: #223560;--bg: #f6f8fb;--panel: #ffffff;--border: #e7e9f0;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--radius-lg: 14px;--radius-md: 12px;--radius-sm: 10px;--shadow-sm: 0 1px 2px rgba(16,24,40,.06), 0 1px 1px rgba(16,24,40,.04);--shadow-md: 0 6px 24px rgba(17,24,39,.06), 0 2px 8px rgba(17,24,39,.08);--shadow-lg: 0 14px 40px rgba(17,24,39,.08), 0 6px 18px rgba(17,24,39,.06);--fs-hero: clamp(28px, 3.2vw, 54px);--fs-h1: clamp(24px, 2.4vw, 40px);--fs-h2: clamp(20px, 1.8vw, 28px);--fs-h3: clamp(18px, 1.6vw, 22px);--fs-body: 16px;--fs-small: 14px;--fw-regular: 500;--fw-medium: 600;--fw-bold: 800;--container-w: 1180px;--focus: 0 0 0 3px rgba(52,80,142,.2)}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Inter,Helvetica Neue,Arial,Noto Sans,"Apple Color Emoji","Segoe UI Emoji";font-size:var(--fs-body);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{max-width:100%;display:block}.container{width:min(100%,var(--container-w));margin-inline:auto;padding-inline:20px}h1,.h1{font-size:var(--fs-h1);line-height:1.1;margin:0 0 12px;font-weight:var(--fw-bold);color:var(--text)}h2,.h2{font-size:var(--fs-h2);line-height:1.2;margin:0 0 12px;font-weight:var(--fw-medium);color:var(--text)}h3,.h3{font-size:var(--fs-h3);line-height:1.25;margin:0 0 8px;font-weight:var(--fw-medium);color:var(--text)}p{margin:0 0 12px;color:#41507b}.muted{color:var(--muted)}.section{padding:28px 0}.section-lg{padding:36px 0}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.navbar{position:sticky;top:0;z-index:20;background:#fffc;-webkit-backdrop-filter:saturate(180%) blur(10px);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--border)}.navbar .bar{display:flex;align-items:center;justify-content:space-between;height:64px}.nav-brand{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--text)}.nav-brand .logo{width:34px;height:34px;border-radius:10px;background:var(--accent);color:#fff;display:grid;place-items:center;box-shadow:var(--shadow-sm)}.nav{display:flex;align-items:center;gap:24px}.nav a{text-decoration:none;color:#3a4e86;font-weight:600;padding:8px 10px;border-radius:8px}.nav a:hover{color:var(--accent);background:#34508e14}.nav a.active{color:var(--accent);background:#34508e1f}.nav-actions{display:flex;align-items:center;gap:10px}.button{--btn-bg: var(--accent);--btn-fg: #fff;--btn-bg-hover: var(--accent-2);display:inline-flex;align-items:center;justify-content:center;gap:10px;height:44px;padding:0 18px;border-radius:14px;border:1px solid transparent;background:var(--btn-bg);color:var(--btn-fg);font-weight:700;text-decoration:none;cursor:pointer;box-shadow:var(--shadow-sm);transition:background .15s ease,transform .05s ease,box-shadow .15s ease}.button:hover{background:var(--btn-bg-hover);box-shadow:var(--shadow-md)}.button:active{transform:translateY(1px)}.button:focus-visible{outline:none;box-shadow:var(--focus)}.button.secondary{--btn-bg: #fff;--btn-fg: var(--accent-2);--btn-bg-hover: #fff;border-color:var(--border)}.button.ghost{--btn-bg: rgba(52,80,142,.08);--btn-fg: var(--accent-2);--btn-bg-hover: rgba(52,80,142,.14);border:1px solid rgba(52,80,142,.18)}.pill{display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 14px;border-radius:999px;border:1px dashed rgba(52,80,142,.25);color:var(--accent-2);background:#fff}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card.pad{padding:18px}.card.pad-lg{padding:22px}.kpis{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.kpi{background:linear-gradient(180deg,color-mix(in oklab,var(--card) 98%,transparent),color-mix(in oklab,var(--card) 90%,transparent));border:1px solid var(--border);border-radius:14px;padding:16px;box-shadow:var(--shadow)}.kpi-label{color:var(--muted);font-weight:600;font-size:13px}.kpi-value.is-negative{color:#ef4444;opacity:.95}.tile{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-sm)}.tag{display:inline-flex;align-items:center;gap:8px;height:26px;padding:0 10px;border-radius:999px;font-size:12px;font-weight:700;background:#34508e14;color:var(--accent-2);border:1px solid rgba(52,80,142,.18)}.status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;border:1px solid transparent}.status.paid{color:#0f5132;background:#d1fae5;border-color:#a7f3d0}.status.pending{color:#92400e;background:#fef3c7;border-color:#fde68a}.status.overdue{color:#7f1d1d;background:#fee2e2;border-color:#fecaca}.label{display:block;font-size:13px;color:#5b6485;margin-bottom:6px;font-weight:600}.input,.select,.textarea{width:100%;height:42px;padding:0 12px;background:#fff;color:var(--text);border:1px solid var(--border);border-radius:var(--radius-md);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.textarea{min-height:110px;padding:10px 12px;resize:vertical}.input:focus,.select:focus,.textarea:focus{border-color:var(--accent);box-shadow:var(--focus)}.form-row{display:grid;gap:14px;grid-template-columns:repeat(12,1fr)}.col-6{grid-column:span 6}.col-4{grid-column:span 4}.col-3{grid-column:span 3}.col-12{grid-column:span 12}.form-actions{display:flex;gap:10px;justify-content:flex-end}.help{font-size:12px;color:var(--muted)}.error{color:var(--danger)}.table-wrap{overflow:auto;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}.table thead th{position:sticky;top:0;z-index:1;background:#fff;color:#3a4e86;text-align:left;font-weight:800;letter-spacing:.01em;padding:12px 14px;border-bottom:1px solid var(--border)}.table tbody td{padding:12px 14px;border-bottom:1px solid var(--border)}.table tbody tr:nth-child(2n) td{background:#fafbff}.table .row-actions{display:inline-flex;align-items:center;gap:8px}.table .link{color:var(--accent);text-decoration:none;font-weight:700}.table .link:hover{color:var(--accent-2);text-decoration:underline}.pagination{display:flex;align-items:center;gap:8px;justify-content:flex-end;padding:12px}.pagination .page{height:36px;min-width:36px;padding:0 10px;display:grid;place-items:center;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:700;cursor:pointer}.pagination .page.active,.pagination .page:hover{border-color:#34508e40;background:#34508e0f;color:var(--accent-2)}.dialog{background:#14161e59;position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:20px;z-index:50}.dialog .panel{width:min(520px,100%);background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:20px}.dialog .title{font-weight:800;margin-bottom:8px}.dialog .text{color:#41507b;margin-bottom:16px}.dialog .actions{display:flex;justify-content:flex-end;gap:10px}.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center}.hero .lead{font-size:var(--fs-hero);font-weight:var(--fw-bold);letter-spacing:-.02em}.hero .sub{color:#41507b;font-size:17px}.mock{min-height:240px;border-radius:var(--radius-lg);border:2px dashed rgba(52,80,142,.25);background:#fff;color:#6c79a8;display:grid;place-items:center;box-shadow:var(--shadow-sm)}.chart-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-sm)}.upload{display:grid;gap:8px;background:var(--panel);border:1px dashed rgba(52,80,142,.25);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-sm)}.upload .hint{color:var(--muted);font-size:13px}.hr{height:1px;background:var(--border);border:0}.hidden{display:none!important}@media (max-width: 980px){.hero{grid-template-columns:1fr}.kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.form-row{grid-template-columns:1fr}.col-6,.col-4,.col-3,.col-12{grid-column:auto}}@media (max-width: 640px){.kpis{grid-template-columns:1fr}.navbar .bar{height:60px}.button{height:42px;border-radius:12px}}.card form.row{gap:10px;flex-wrap:wrap;align-items:center}.card form.row>.input,.card form.row>.select{min-height:36px}.form-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}.form-grid .col-1{grid-column:span 1}.form-grid .col-2{grid-column:span 2}.form-grid .col-3{grid-column:span 3}.form-grid .col-4{grid-column:span 4}.form-grid .col-6{grid-column:span 6}.form-grid .input,.form-grid .select{width:100%;height:40px;padding:8px 10px}.form-grid .actions{grid-column:1 / -1;display:flex;justify-content:flex-end;gap:10px}@media (max-width: 980px){.form-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 640px){.form-grid{grid-template-columns:1fr}}.form-grid .input,.form-grid .select{height:40px}.form-grid .checkbox-field{display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 2px;border-radius:8px}.form-grid .checkbox-field input{width:18px;height:18px}.form-grid .checkbox-field .checkbox-label{font-size:13px;color:var(--text);font-weight:600;line-height:1}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.toolbar .left,.toolbar .right{display:flex;align-items:center;gap:10px}.filters{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.filters .spacer{flex:1}.chip{display:inline-flex;align-items:center;justify-content:center;height:32px;padding:0 10px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:700;font-size:13px}.filters .input,.filters .select{height:36px}.meta-note{color:var(--muted);font-size:13px}.header,.controls{display:flex;align-items:center;gap:10px;flex-wrap:nowrap}.header>*,.controls>*{height:40px}.filters-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:6px 0 10px}.filters-row .row-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.filters-row .row-right{margin-left:auto;display:flex;align-items:center}.label-inline{display:inline-flex;align-items:center;height:32px;line-height:32px;font-size:13px;font-weight:600;color:var(--muted);margin:0;white-space:nowrap}.filters-row .input,.filters-row select,.filters-row .button,.filters-row .chip{height:32px}.header{display:flex;align-items:center;justify-content:space-between;gap:16px}.header .brand{display:flex;align-items:center;gap:14px}.header .brand .logo{width:40px;height:40px;border-radius:12px;display:grid;place-items:center}.header .brand h2{margin:0;line-height:40px;font-weight:800}.header .brand .muted{margin:0;line-height:16px}.nav,.tabs{display:flex;align-items:center;gap:12px}.nav .tab,.tabs .tab{display:inline-flex;align-items:center;justify-content:center;height:40px;padding:0 14px;border-radius:999px}.controls{display:flex;align-items:center;gap:10px;flex-wrap:nowrap}.controls>*{height:40px}@media (max-width:980px){.controls{flex-wrap:wrap}}.upload{display:grid;gap:12px;background:var(--panel);border:1px dashed rgba(52,80,142,.25);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-sm)}.upload input[type=file]{display:none}.upload .file-label{display:flex;align-items:center;justify-content:center;gap:10px;height:44px;border-radius:var(--radius-md);border:1px solid var(--border);background:#fff;color:var(--text);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s ease,box-shadow .15s ease}.upload .file-label:hover{background:#34508e0f;box-shadow:var(--shadow-sm)}.upload .file-name{margin-top:6px;font-size:13px;color:var(--muted)}:root{--bg: #f8fafc;--card: #ffffff;--text: #0f172a;--muted: #475569;--border: #e2e8f0;--accent: #0ea5e9;--ring: rgba(14,165,233,.35);--shadow: 0 10px 30px rgba(2,6,23,.06)}.dark{--bg: #0b1220;--card: #0f172a;--text: #e5e7eb;--muted: #94a3b8;--border: #1e293b;--accent: #38bdf8;--ring: rgba(56,189,248,.35);--shadow: 0 12px 36px rgba(2,6,23,.35)}html,body,#root{height:100%}body{background:var(--bg);color:var(--text)}.app-header{position:sticky;top:0;z-index:40;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:color-mix(in oklab,var(--bg) 80%,transparent);border-bottom:1px solid var(--border)}.card{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:16px}input,select,textarea{background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:8px 10px}button{color:var(--text)}table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden}thead th{background:color-mix(in oklab,var(--card) 92%,transparent);color:var(--muted)}td,th{border-bottom:1px solid var(--border);padding:10px 12px}.theme-toggle{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:999px;padding:4px;background:color-mix(in oklab,var(--card) 92%,transparent);box-shadow:var(--shadow)}.theme-toggle button{display:flex;align-items:center;gap:6px;border:0;background:transparent;color:var(--text);padding:6px 12px;border-radius:999px;cursor:pointer;transition:box-shadow .12s,opacity .12s,transform .12s}.theme-toggle button.active{box-shadow:0 0 0 3px var(--ring)}.theme-toggle button:not(.active):hover{opacity:.9;transform:translateY(-1px)}.theme-toggle .divider{width:1px;height:20px;background:var(--border)}.kpi{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-bottom:16px}.kpi-card{background:linear-gradient(180deg,color-mix(in oklab,var(--card) 98%,transparent),color-mix(in oklab,var(--card) 90%,transparent));border:1px solid var(--border);border-radius:14px;padding:16px;box-shadow:var(--shadow)}.kpi-title{color:var(--muted);font-weight:600;font-size:13px}.kpi-value{margin-top:8px;font-weight:800;font-size:22px;letter-spacing:.3px;color:var(--text);opacity:.95}.kpi-sub{margin-top:6px;font-size:12px;color:var(--muted)}.file-wrap{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:8px}.file-input-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.file-btn{display:inline-flex;align-items:center;justify-content:center;height:36px;padding:0 14px;border-radius:10px;cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--accent);color:#fff;font-weight:700;border:none;box-shadow:0 4px 12px #22356040;transition:background .15s ease,transform .1s ease,box-shadow .15s ease}.file-btn:hover{background:var(--accent-2);transform:translateY(-1px)}.file-btn:active{transform:translateY(0)}.file-name{color:var(--text);padding:0 6px;opacity:.9;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dark .file-name{opacity:.85}.theme-toggle button.active,input:focus,select:focus,textarea:focus,.file-btn:focus{outline:none;box-shadow:0 0 0 3px var(--ring)}
