@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=Sora:wght@500;600;700&display=swap";:root{--bg: #f3f6fc;--surface: #ffffff;--surface-soft: #f7faff;--text: #0e1b30;--muted: #54617a;--brand: #1d4ed8;--brand-strong: #1e3a8a;--brand-soft: #dbe7ff;--accent: #f59e0b;--accent-strong: #d97706;--positive: #059669;--danger: #dc2626;--warning-bg: #fff3dd;--warning-text: #9a3412;--border: #d8e0ef;--shadow: 0 8px 24px rgba(15, 23, 42, .07);--radius: 16px;--radius-sm: 10px;--radius-full: 999px}*{box-sizing:border-box}body{margin:0;font-family:IBM Plex Sans,sans-serif;color:var(--text);background:radial-gradient(circle at 12% -5%,#2563eb26,#2563eb00 42%),radial-gradient(circle at 90% 5%,#0f766e1f,#0f766e00 38%),linear-gradient(180deg,#f8faff,#eef3fb);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}.auth-shell{min-height:100vh;min-height:100dvh;display:grid;place-items:center;padding:1.25rem;background:radial-gradient(circle at 30% 20%,rgba(37,99,235,.12) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(15,118,110,.1) 0%,transparent 50%),linear-gradient(180deg,#f0f4ff,#e8eef8)}.auth-card{width:min(100%,400px);padding:2rem 1.75rem;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(216,224,239,.6);border-radius:20px;box-shadow:0 20px 60px #0c17311f,0 1px 3px #0c17310f}.auth-kicker{margin:0 0 .5rem;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--brand)}.auth-card h1{margin:0;font-family:Sora,sans-serif;font-size:1.6rem;letter-spacing:-.02em}.auth-copy{margin:.45rem 0 1.25rem;color:var(--muted);font-size:.92rem;line-height:1.5}.auth-form{display:grid;gap:1rem}.auth-form label{display:grid;gap:.4rem;font-size:.88rem;font-weight:600;color:#20304d}.auth-form input{padding:.65rem .75rem;font-size:.95rem}.auth-form button{margin-top:.25rem;padding:.7rem;font-size:.95rem}.app-shell{max-width:1320px;margin:0 auto;padding:.75rem .75rem 5.5rem}.topbar{background:linear-gradient(135deg,#0c1731,#132347 56%,#1a3266);color:#f8fbff;border-radius:var(--radius);padding:1rem 1.15rem;display:flex;justify-content:space-between;align-items:end;gap:1rem;border:1px solid rgba(191,219,254,.2);box-shadow:0 12px 32px #0c173138;animation:rise-in .26s ease-out}.topbar-main{display:grid;gap:.6rem;min-width:0}.topbar-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.topbar h1{margin:0;font-family:Sora,sans-serif;font-size:clamp(1.15rem,3vw,1.75rem);letter-spacing:-.01em;white-space:nowrap}.topbar-subtitle{margin:.2rem 0 0;color:#b4c8e8;font-weight:500;font-size:.82rem}.topbar p{margin:0}.topbar-meta{display:flex;gap:.45rem;flex-wrap:wrap}.status-badge,.meta-pill{display:inline-flex;align-items:center;border-radius:var(--radius-full);padding:.18rem .6rem;font-size:.75rem;font-weight:600;border:1px solid transparent}.status-badge-open{color:#bbf7d0;background:#16a34a2e;border-color:#86efac8c}.status-badge-closed{color:#fde68a;background:#ca8a0429;border-color:#fcd34d85}.meta-pill{color:#d8e7ff;background:#94a3b829;border-color:#bfdbfe57}.privacy-toggle{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;padding:0;border-radius:12px;background:#ffffff1f;border:1px solid rgba(191,219,254,.25);color:#d2e2ff;cursor:pointer;transition:background .15s ease,transform .15s ease}.privacy-toggle:hover:not(:disabled){background:#fff3;transform:translateY(-1px);box-shadow:0 4px 12px #0003}.privacy-mask{display:inline-block;letter-spacing:.15em;color:var(--muted);font-weight:600;-webkit-user-select:none;user-select:none}.topbar-actions{display:flex;gap:.5rem;align-items:center;flex-shrink:0}.month-selector{display:flex;gap:.4rem;align-items:center;font-weight:600;font-size:.85rem;color:#e2e8f0}.month-selector select{min-width:180px;background:#fffffff5;border:1px solid rgba(148,163,184,.48)}.month-kpis{margin-top:.75rem;display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem;animation:rise-in .3s ease-out}.kpi-card{background:linear-gradient(160deg,#fff,#f4f8ff 70%);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem .85rem;box-shadow:0 4px 16px #0f172a0d;transition:transform .15s ease,box-shadow .15s ease}.kpi-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0f172a1a}.kpi-label{margin:0;color:var(--muted);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.kpi-value{margin:.25rem 0 .1rem;font-size:1.2rem;font-family:Sora,sans-serif;font-weight:700;letter-spacing:-.01em}.kpi-note{margin:0;color:#60708b;font-size:.72rem}.kpi-card-positive{border-color:#0596694d}.kpi-card-positive .kpi-value{color:var(--positive)}.kpi-card-danger{border-color:#dc26264d}.kpi-card-danger .kpi-value{color:var(--danger)}.main-nav{display:flex;gap:.4rem;margin:.75rem 0;flex-wrap:wrap;animation:rise-in .34s ease-out}.main-nav a{text-decoration:none;color:#1d2d4a;background:#ffffffe6;border:1px solid #ced9ee;border-radius:var(--radius-full);padding:.45rem .85rem;font-weight:600;font-size:.88rem;display:inline-flex;align-items:center;gap:.4rem;transition:transform .15s ease,box-shadow .15s ease,background-color .15s ease}.main-nav a svg{flex-shrink:0;opacity:.65}.main-nav a:hover{transform:translateY(-1px);background:#f0f5ff;box-shadow:0 6px 14px #1e3a8a1a}.main-nav a.active{background:linear-gradient(120deg,#1d4ed8,#1e3a8a);color:#fff;border-color:#1e40af;box-shadow:0 8px 20px #1e40af47}.main-nav a.active svg{opacity:1}main{animation:rise-in .42s ease-out}.page-stack{display:grid;gap:.75rem}.panel,.chart-card,.summary-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.panel{padding:.85rem;overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.85rem}.panel-header h2,.panel-header h3{margin:0;font-family:Sora,sans-serif;letter-spacing:-.01em;font-size:1.1rem}.panel-header p{margin:0;font-weight:600;font-size:.92rem;color:var(--muted)}button{background:linear-gradient(115deg,var(--brand),var(--brand-strong));color:#fff;border:1px solid rgba(37,99,235,.64);border-radius:var(--radius-sm);padding:.45rem .75rem;cursor:pointer;font-family:inherit;font-weight:600;font-size:.85rem;transition:transform .15s ease,box-shadow .15s ease,filter .15s ease;white-space:nowrap}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 14px #1d4ed833}button:focus-visible{outline:3px solid rgba(56,189,248,.45);outline-offset:2px}button:disabled{opacity:.56;cursor:not-allowed}.button-secondary{background:#eef3ff;color:#1f2d48;border-color:#cad5ec}.button-secondary:hover:not(:disabled){box-shadow:0 6px 14px #64748b26}.cta-new-month{background:linear-gradient(115deg,var(--accent),var(--accent-strong));border:1px solid rgba(217,119,6,.7);color:#fffbeb;box-shadow:0 6px 16px #d9770640}.cta-new-month:hover:not(:disabled){box-shadow:0 10px 20px #d9770652}.inline-form{display:flex;gap:.45rem;align-items:center;flex-wrap:wrap;margin-top:.75rem}.inline-form h3{margin:0;font-family:Sora,sans-serif;font-size:.95rem}input,select{border:1px solid var(--border);border-radius:var(--radius-sm);padding:.45rem .55rem;font:inherit;font-size:.88rem;color:var(--text);background:#fff;transition:border-color .15s ease,box-shadow .15s ease}input:focus,select:focus{outline:2px solid rgba(37,99,235,.2);border-color:#3b82f6}.data-table{width:100%;border-collapse:collapse;border-radius:12px;overflow:hidden}.data-table th,.data-table td{border-bottom:1px solid #edf2fb;padding:.55rem .6rem;text-align:left;vertical-align:top;font-size:.88rem}.data-table thead th{background:var(--surface-soft);font-family:Sora,sans-serif;font-size:.78rem;font-weight:600;color:#3e4c67}.data-table tbody tr:hover{background:#f8fbff}.sort-header{background:transparent;border:none;color:inherit;border-radius:0;padding:0;box-shadow:none;display:inline-flex;gap:.3rem;align-items:center;font:inherit;white-space:nowrap}.sort-header:hover:not(:disabled){transform:none;box-shadow:none;color:#2563eb}.row-actions{display:flex;gap:.35rem;flex-wrap:wrap}.inline-error{margin:.35rem 0 0;color:var(--danger);font-size:.78rem;font-weight:600}.totals-row{font-weight:700}.negative{color:var(--danger)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.6rem}.summary-card{padding:.75rem;background:linear-gradient(165deg,#fff,#f7faff 78%);transition:transform .15s ease}.summary-card:hover{transform:translateY(-2px)}.summary-card h3{margin:0;color:var(--muted);font-family:Sora,sans-serif;font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.summary-card p{margin:.2rem 0 0;font-size:1.15rem;font-family:Sora,sans-serif;font-weight:700}.summary-card small{display:block;margin-top:.2rem;color:#60708b;font-size:.75rem}.summary-card-income{border-color:#2563eb47}.summary-card-positive p{color:var(--positive)}.summary-card-negative p{color:var(--danger)}.summary-card.warning{background:var(--warning-bg);color:var(--warning-text);border-color:#f59e0b57}.summary-card.warning small{color:#9a3412}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:.75rem}.chart-card{padding:.85rem;background:linear-gradient(180deg,#fff,#f8faff)}.chart-card h3{margin-top:0;margin-bottom:.6rem;font-family:Sora,sans-serif;font-size:1rem}.chart-container{width:100%;min-height:280px}.chart-empty{min-height:280px;display:grid;place-items:center;margin:0;text-align:center;color:var(--muted);font-weight:600}.center-message{text-align:center;margin-top:3rem}@keyframes rise-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:860px){.app-shell{padding:.6rem .6rem 5rem}.topbar{flex-direction:column;align-items:stretch;padding:.85rem 1rem;border-radius:14px}.topbar-actions{width:100%;justify-content:space-between;flex-wrap:wrap;gap:.4rem}.month-selector select{min-width:140px}.month-kpis{grid-template-columns:repeat(2,1fr)}.panel-header{flex-direction:column;align-items:flex-start;gap:.5rem}.data-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.charts-grid{grid-template-columns:1fr}}@media(max-width:600px){.app-shell{padding:.5rem .5rem 4.5rem}.topbar{border-radius:12px;padding:.75rem;box-shadow:0 8px 20px #0c17312e}.topbar h1{font-size:1.1rem}.topbar-subtitle{display:none}.topbar-actions{flex-direction:column;align-items:stretch}.topbar-actions>*{width:100%}.month-selector{flex-direction:column;align-items:stretch}.month-selector select{min-width:0;width:100%}.button-secondary{text-align:center;padding:.5rem}.month-kpis{grid-template-columns:repeat(2,1fr);gap:.45rem}.kpi-card{padding:.6rem .7rem}.kpi-value{font-size:1rem}.kpi-label,.kpi-note{font-size:.68rem}.main-nav{position:fixed;bottom:0;left:0;right:0;z-index:100;margin:0;padding:.35rem .3rem;padding-bottom:calc(.35rem + env(safe-area-inset-bottom,0px));background:#ffffffeb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--border);box-shadow:0 -4px 20px #0f172a14;display:flex;justify-content:space-around;flex-wrap:nowrap;gap:0;animation:none}.main-nav a{flex:1;flex-direction:column;justify-content:center;align-items:center;gap:.15rem;padding:.35rem .15rem;border:none;border-radius:10px;background:transparent;font-size:.65rem;font-weight:600;color:#64748b;min-width:0}.main-nav a svg{width:20px;height:20px;opacity:.7}.main-nav a span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.main-nav a:hover{transform:none;box-shadow:none;background:#1d4ed80f}.main-nav a.active{background:#1d4ed81a;color:var(--brand);border:none;box-shadow:none}.main-nav a.active svg{opacity:1;color:var(--brand)}.panel{padding:.7rem;border-radius:12px}.panel-header h2{font-size:.95rem}.inline-form{flex-direction:column;align-items:stretch}.inline-form input,.inline-form select,.inline-form button{width:100%}.summary-grid{grid-template-columns:repeat(2,1fr);gap:.45rem}.summary-card{padding:.6rem;border-radius:12px}.summary-card p{font-size:1rem}.chart-card{padding:.65rem;border-radius:12px}.chart-container{min-height:240px}.data-table th,.data-table td{padding:.45rem .4rem;font-size:.82rem}.row-actions{flex-direction:column;gap:.25rem}.row-actions button{font-size:.78rem;padding:.35rem .5rem}}@media(max-width:380px){.month-kpis,.summary-grid{grid-template-columns:1fr}.main-nav a{font-size:.6rem}.main-nav a svg{width:18px;height:18px}}
