@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--bg: #f5f5f5;--surface: #ffffff;--surface-raised: #fafafa;--text: #111827;--text-secondary: #6b7280;--brand: #2563eb;--brand-hover: #1d4ed8;--brand-soft: #eff6ff;--brand-muted: #bfdbfe;--positive: #16a34a;--positive-soft: #f0fdf4;--danger: #dc2626;--danger-soft: #fef2f2;--warning: #d97706;--warning-soft: #fffbeb;--border: #e5e7eb;--border-strong: #d1d5db;--radius: 12px;--radius-sm: 8px;--radius-full: 999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow: 0 4px 12px rgba(0,0,0,.06)}[data-theme=dark]{--bg: #0f172a;--surface: #1e293b;--surface-raised: #263348;--text: #f1f5f9;--text-secondary: #94a3b8;--brand: #3b82f6;--brand-hover: #2563eb;--brand-soft: #1e3a5f;--brand-muted: #1e40af;--positive: #22c55e;--positive-soft: #052e16;--danger: #f87171;--danger-soft: #3b0f0f;--warning: #fbbf24;--warning-soft: #3b2200;--border: #2d3f57;--border-strong: #3f546e;--shadow-sm: 0 1px 3px rgba(0,0,0,.3);--shadow: 0 4px 12px rgba(0,0,0,.3)}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,sans-serif;font-size:15px;line-height:1.5;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background .2s ease,color .2s ease;overflow-x:hidden}#root{min-height:100vh}.auth-shell{min-height:100vh;min-height:100dvh;display:grid;place-items:center;padding:1.5rem;background:var(--bg)}.auth-card{width:min(100%,380px);padding:2rem 1.75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.auth-logo{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem}.auth-logo-icon{width:32px;height:32px;background:var(--brand);border-radius:8px;display:grid;place-items:center;color:#fff;flex-shrink:0}.auth-logo-name{font-weight:700;font-size:1rem;color:var(--text)}.auth-card h1{margin:0 0 .35rem;font-size:1.4rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.auth-copy{margin:0 0 1.5rem;color:var(--text-secondary);font-size:.875rem}.auth-form{display:grid;gap:1rem}.auth-form label{display:grid;gap:.35rem;font-size:.875rem;font-weight:500;color:var(--text)}.auth-form input{padding:.6rem .75rem;font-size:.9rem}.auth-form button[type=submit]{margin-top:.25rem;padding:.65rem;font-size:.9rem;width:100%;justify-content:center}.app-shell{max-width:1280px;margin:0 auto;padding:1rem 1rem 1.5rem}.topbar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.875rem 1rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;box-shadow:var(--shadow-sm)}.topbar-main{display:flex;align-items:center;gap:.75rem;min-width:0}.topbar-brand{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.topbar-brand-icon{width:28px;height:28px;background:var(--brand);border-radius:7px;display:grid;place-items:center;color:#fff;flex-shrink:0}.topbar-brand-name{font-weight:700;font-size:.95rem;color:var(--text);white-space:nowrap}.topbar-divider{width:1px;height:20px;background:var(--border);flex-shrink:0}.topbar-meta{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}.topbar-actions{display:flex;gap:.5rem;align-items:center;flex-shrink:0}.status-badge,.meta-pill{display:inline-flex;align-items:center;border-radius:var(--radius-full);padding:.2rem .55rem;font-size:.72rem;font-weight:600;border:1px solid transparent}.status-badge-open{color:var(--positive);background:var(--positive-soft);border-color:#16a34a33}[data-theme=dark] .status-badge-open{border-color:#22c55e33}.status-badge-closed{color:var(--warning);background:var(--warning-soft);border-color:#d9770633}.meta-pill{color:var(--text-secondary);background:var(--surface-raised);border-color:var(--border);font-size:.72rem}.icon-btn{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border-radius:var(--radius-sm);background:var(--surface-raised);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s,border-color .15s;font-family:inherit}.icon-btn:hover:not(:disabled){background:var(--brand-soft);color:var(--brand);border-color:var(--brand-muted);transform:none;box-shadow:none}.icon-btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.privacy-mask{display:inline-block;letter-spacing:.1em;color:var(--text-secondary);font-weight:600;-webkit-user-select:none;user-select:none}.month-selector{display:flex;gap:.4rem;align-items:center}.month-selector select{min-width:160px;background:var(--surface)}.month-kpis{margin-top:.75rem;display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.875rem 1rem;transition:border-color .15s}.kpi-label{margin:0;color:var(--text-secondary);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.kpi-value{margin:.2rem 0 .15rem;font-size:1.2rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.kpi-note{margin:0;color:var(--text-secondary);font-size:.72rem}.kpi-card-positive{border-left:3px solid var(--positive)}.kpi-card-positive .kpi-value{color:var(--positive)}.kpi-card-danger{border-left:3px solid var(--danger)}.kpi-card-danger .kpi-value{color:var(--danger)}.main-nav{display:flex;gap:.25rem;margin:.75rem 0;flex-wrap:wrap;padding:.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.main-nav a{text-decoration:none;color:var(--text-secondary);border-radius:var(--radius-sm);padding:.45rem .75rem;font-weight:500;font-size:.875rem;display:inline-flex;align-items:center;gap:.4rem;transition:background .15s,color .15s;white-space:nowrap}.main-nav a svg{flex-shrink:0}.main-nav a:hover{background:var(--surface-raised);color:var(--text)}.main-nav a.active{background:var(--brand-soft);color:var(--brand);font-weight:600}[data-theme=dark] .main-nav a.active{background:var(--brand-soft);color:var(--brand)}main{animation:fade-in .18s 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)}.panel{padding:1rem;overflow:clip}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -1rem;padding:0 1rem}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.panel-header h2,.panel-header h3{margin:0;font-size:1rem;font-weight:600;letter-spacing:-.01em}.panel-header p{margin:0;font-size:.875rem;color:var(--text-secondary)}button{background:var(--brand);color:#fff;border:1px solid var(--brand);border-radius:var(--radius-sm);padding:.5rem .875rem;cursor:pointer;font-family:inherit;font-weight:500;font-size:.875rem;transition:background .15s,border-color .15s,box-shadow .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:.4rem}button:hover:not(:disabled){background:var(--brand-hover);border-color:var(--brand-hover);box-shadow:0 2px 8px #2563eb40}button:focus-visible{outline:2px solid var(--brand);outline-offset:2px}button:disabled{opacity:.5;cursor:not-allowed}.button-secondary{background:var(--surface-raised);color:var(--text);border-color:var(--border)}.button-secondary:hover:not(:disabled){background:var(--surface);border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.button-danger{background:var(--danger-soft);color:var(--danger);border-color:#dc262633}.button-danger:hover:not(:disabled){background:var(--danger);color:#fff;border-color:var(--danger);box-shadow:0 2px 8px #dc262640}.cta-new-month{background:var(--surface-raised);color:var(--warning);border-color:#d977064d}.cta-new-month:hover:not(:disabled){background:var(--warning-soft);border-color:#d9770680;box-shadow:none}.inline-form{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;margin-top:.75rem}.inline-form h3{margin:0;font-size:.95rem;font-weight:600}input,select{border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem .65rem;font:inherit;font-size:.875rem;color:var(--text);background:var(--surface);transition:border-color .15s,box-shadow .15s}input:focus,select:focus{outline:2px solid var(--brand);outline-offset:-1px;border-color:var(--brand)}input::placeholder{color:var(--text-secondary)}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{border-bottom:1px solid var(--border);padding:.6rem .75rem;text-align:left;vertical-align:middle;font-size:.875rem}.data-table th:first-child,.data-table td:first-child{padding-left:1rem}.data-table th:last-child,.data-table td:last-child{padding-right:1rem}.data-table thead th{background:var(--surface-raised);font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--surface-raised)}.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;font-size:inherit;white-space:nowrap}.sort-header:hover:not(:disabled){transform:none;box-shadow:none;color:var(--brand);background:transparent;border-color:transparent}.row-actions{display:flex;gap:.3rem;flex-wrap:wrap}.inline-error{margin:.35rem 0 0;color:var(--danger);font-size:.78rem;font-weight:500}.totals-row td{font-weight:700;border-top:2px solid var(--border-strong);border-bottom:none}.negative{color:var(--danger)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.5rem}.summary-card{padding:.875rem 1rem;border-radius:var(--radius)}.summary-card h3{margin:0;color:var(--text-secondary);font-size:.72rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.summary-card p{margin:.25rem 0 0;font-size:1.1rem;font-weight:700;letter-spacing:-.02em}.summary-card small{display:block;margin-top:.2rem;color:var(--text-secondary);font-size:.75rem}.summary-card-income{border-left:3px solid var(--brand)}.summary-card-positive p{color:var(--positive)}.summary-card-negative p{color:var(--danger)}.summary-card.warning{background:var(--warning-soft);border-color:#d9770640;border-left:3px solid var(--warning)}.summary-card.warning small{color:var(--warning)}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:.75rem}.chart-card{padding:1rem}.chart-card h3{margin:0 0 .75rem;font-size:.9rem;font-weight:600}.chart-container{width:100%;min-height:260px}.chart-empty{min-height:260px;display:grid;place-items:center;margin:0;text-align:center;color:var(--text-secondary);font-size:.875rem}.center-message{text-align:center;margin-top:3rem;color:var(--text-secondary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#00000073;display:grid;place-items:center;padding:1rem;animation:fade-in .12s ease-out}.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem;width:min(100%,360px);animation:fade-in .15s ease-out}.modal-title{margin:0 0 .4rem;font-size:1rem;font-weight:600;color:var(--text)}.modal-description{margin:0 0 1.25rem;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.25rem}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@media(max-width:860px){.app-shell{padding:.75rem .75rem 1.5rem}.month-kpis{grid-template-columns:repeat(2,1fr)}.panel-header{flex-direction:column;align-items:flex-start;gap:.5rem}.data-table{min-width:480px}.charts-grid{grid-template-columns:1fr}}@media(max-width:600px){body{font-size:14px}.app-shell{padding:.5rem .5rem 5rem}.topbar{flex-direction:column;align-items:stretch;gap:.75rem;padding:.75rem;border-radius:var(--radius-sm)}.topbar-main{flex-wrap:wrap}.topbar-divider{display:none}.topbar-actions{width:100%;flex-direction:row;flex-wrap:wrap;gap:.4rem}.topbar-actions>*{flex:1 1 auto}.month-selector{flex:1 1 100%}.month-selector select{min-width:0;width:100%}.month-kpis{grid-template-columns:repeat(2,1fr);gap:.4rem}.kpi-card{padding:.75rem}.kpi-value{font-size:1rem}.icon-btn{width:44px;height:44px}select,input[type=date],input[type=number],input[type=text],input:not([type]){min-height:44px}.main-nav{position:fixed;bottom:0;left:0;right:0;z-index:100;margin:0;padding:.35rem .5rem;padding-bottom:calc(.35rem + env(safe-area-inset-bottom,0px));border-radius:0;border-top:1px solid var(--border);border-bottom:none;border-left:none;border-right:none;display:flex;justify-content:space-around;gap:0}.main-nav a{flex:1;flex-direction:column;justify-content:center;align-items:center;gap:.15rem;padding:.4rem .25rem;border-radius:var(--radius-sm);font-size:.65rem;font-weight:600;min-width:0}.main-nav a svg{width:20px;height:20px}.main-nav a span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.main-nav a:hover{background:var(--surface-raised)}.main-nav a.active{background:var(--brand-soft);color:var(--brand)}.panel{padding:.75rem;border-radius:var(--radius-sm)}.panel-header h2{font-size:.9rem}.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:.4rem}.summary-card{padding:.65rem .75rem;border-radius:var(--radius-sm)}.summary-card p{font-size:1rem}.chart-card{padding:.75rem;border-radius:var(--radius-sm)}.chart-container{min-height:220px}.data-table th,.data-table td{padding:.5rem;font-size:.8rem}.data-table th:first-child,.data-table td:first-child{padding-left:.5rem}.row-actions{flex-direction:column;gap:.2rem}.row-actions button{font-size:.78rem;padding:.35rem .5rem;min-height:44px}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%;justify-content:center;min-height:44px}}@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}}
