:root{color-scheme:light;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#14213d;background:radial-gradient(circle at top left,rgba(249,199,79,.18),transparent 30%),linear-gradient(180deg,#f7f4ea,#fffdf8);--bg-card: rgba(255, 255, 255, .92);--bg-strong: #17324d;--line: #d8deea;--accent: #d97706;--accent-dark: #8a4b08;--success: #16795c;--danger: #a73a30;--text-soft: #6a7486;--shadow: 0 20px 40px rgba(20, 33, 61, .08)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:inherit}button,input,select,small{font:inherit}table{width:100%;border-collapse:collapse}th,td{padding:.85rem .75rem;border-bottom:1px solid var(--line);text-align:left}th{color:var(--text-soft);font-size:.85rem;text-transform:uppercase;letter-spacing:.08em}.app-shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.sidebar{background:linear-gradient(180deg,#17324d,#0f2235);color:#fff8ee;padding:2rem}.sidebar-inner{display:grid;gap:1.5rem}.sidebar h1{margin:.5rem 0 0;font-size:2rem}.sidebar-summary{margin:.75rem 0 0;color:#d8e2ef;line-height:1.45}.sidebar-identity{padding:1rem 1rem .95rem;border-radius:18px;background:#ffffff14;border:1px solid rgba(255,255,255,.08)}.sidebar-identity strong,.sidebar-identity span{display:block}.sidebar-identity span{margin-top:.35rem;color:#d8e2ef;font-size:.92rem}.sidebar-kicker,.eyebrow{margin:0;text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;color:#d3b07a}.sidebar-nav{display:grid;gap:1rem}.sidebar-group{display:grid;gap:.65rem}.sidebar-group-title{margin:0;font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#d3b07a}.sidebar-group-links{display:grid;gap:.6rem}.nav-link{display:grid;gap:.2rem;padding:.95rem 1rem;border-radius:16px;color:#f5eee1;text-decoration:none;background:#ffffff0d;transition:transform .12s ease,background .12s ease}.nav-link:hover{transform:translate(2px)}.nav-link-label{font-weight:600}.nav-link-hint{color:#d8e2ef;font-size:.83rem}.nav-link.active{background:linear-gradient(135deg,#f9c74f33,#f59e0b29);color:#fff;box-shadow:inset 3px 0 #f7c857}.sidebar-group.compact{gap:.55rem}.sidebar-group-links.compact{grid-template-columns:1fr}.mobile-sidebar{padding:0;background:transparent;color:var(--bg-strong)}.mobile-sidebar .sidebar-inner{gap:1rem}.mobile-sidebar .sidebar-kicker,.mobile-sidebar .sidebar-summary{color:var(--text-soft)}.mobile-sidebar h1{font-size:1.5rem;color:#fff8ee}.mobile-sidebar .sidebar-identity{background:#ffffff14;border:1px solid rgba(255,255,255,.08)}.mobile-sidebar .sidebar-identity strong{color:#fff8ee}.mobile-sidebar .sidebar-identity span{color:#d8e2ef}.mobile-sidebar .sidebar-group-title{color:#d3b07a}.mobile-sidebar .nav-link{background:#ffffff0d;color:#f5eee1;border:none}.mobile-sidebar .nav-link-hint{color:#d8e2ef}.mobile-sidebar .nav-link.active{color:#fff;box-shadow:inset 3px 0 #f7c857}.mobile-drawer-backdrop,.mobile-drawer{display:none}.mobile-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f223561;border:none;padding:0;z-index:60}.mobile-drawer{position:fixed;top:0;left:0;height:100vh;width:min(320px,86vw);padding:1rem;background:linear-gradient(180deg,#17324d,#0f2235);box-shadow:24px 0 40px #14213d2e;transform:translate(-100%);transition:transform .18s ease;z-index:70;overflow-y:auto}.mobile-drawer.open{transform:translate(0)}.mobile-drawer .mobile-sidebar{display:block}.mobile-drawer-header{display:flex;justify-content:flex-end;align-items:center;margin-bottom:.5rem}.app-main{padding:2rem}.topbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem}.topbar-mobile-action{display:none}.topbar-main{display:grid;gap:.25rem}.brand-signature{display:flex;align-items:center;gap:.9rem}.brand-signature-mark{display:block;width:64px;height:auto;flex:0 0 auto}.brand-signature-copy,.brand-signature-name{display:grid}.brand-signature-copy{gap:.2rem}.brand-signature-name,.brand-signature-tagline{margin:0}.brand-signature-name{gap:.05rem;font-weight:800;line-height:.92;text-transform:uppercase}.brand-signature-name span{display:block}.brand-signature-tagline{font-size:.76rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase}.brand-signature-login{margin-bottom:1.4rem}.brand-signature-login .brand-signature-mark{width:88px;filter:drop-shadow(0 12px 18px rgba(17,39,74,.12))}.brand-signature-login .brand-signature-name{font-size:2rem;color:var(--bg-strong);letter-spacing:.03em}.brand-signature-login .brand-signature-tagline{color:var(--text-soft);letter-spacing:.18em}.brand-signature-sidebar{display:grid;justify-items:start;gap:.8rem;margin-top:.35rem}.brand-signature-sidebar .brand-signature-mark{width:86px;filter:drop-shadow(0 10px 18px rgba(6,14,31,.32))}.brand-signature-sidebar .brand-signature-name{font-size:1.55rem;letter-spacing:.02em;color:#fff8ee}.brand-signature-sidebar .brand-signature-tagline{color:#ffffffb8;max-width:12ch;line-height:1.25;letter-spacing:.18em}.brand-signature-topbar{gap:.7rem;margin-bottom:.2rem}.brand-signature-topbar .brand-signature-mark{width:36px;filter:drop-shadow(0 8px 12px rgba(17,39,74,.12))}.brand-signature-topbar .brand-signature-copy{gap:0}.brand-signature-topbar .brand-signature-name{font-size:.98rem;line-height:.96;letter-spacing:.04em;color:var(--bg-strong)}.topbar h2{margin:.25rem 0 0}.topbar-subtitle{margin:0;color:var(--text-soft)}.topbar-user{display:flex;align-items:center;gap:1rem;padding:.75rem .9rem;border-radius:18px;background:#ffffff8c;border:1px solid rgba(23,50,77,.08)}.topbar-user-copy strong,.topbar-user-copy span{display:block}.topbar-user-copy span{margin-top:.2rem;color:var(--text-soft);font-size:.9rem}.mobile-menu-button{min-width:112px}.content-stack{display:grid;gap:1.25rem}.card,.hero-card,.stat-card{background:var(--bg-card);border:1px solid rgba(255,255,255,.55);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-radius:24px;box-shadow:var(--shadow)}.card{padding:1.25rem}.hero-card{padding:1.5rem;display:flex;justify-content:space-between;align-items:end;background:linear-gradient(120deg,#17324df2,#1e5378e6),var(--bg-card);color:#fff9ef}.hero-card h3,.hero-balance strong{font-size:2rem;margin:0}.hero-balance{text-align:right}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.stat-card{padding:1.25rem}.stat-card strong{display:block;margin-top:.45rem;font-size:1.5rem}.stat-card.success strong{color:var(--success)}.stat-card.highlight{background:linear-gradient(160deg,#fff8e9,#f6dfad)}.stat-card.highlight strong{color:var(--accent-dark)}.stat-card.danger strong{color:var(--danger)}.balance-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.balance-pill{padding:1rem 1.1rem;border-radius:20px;background:linear-gradient(135deg,#17324d,#204a6c);color:#fff9ef;box-shadow:var(--shadow)}.balance-pill span{display:block;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:#ead8b0}.balance-pill strong{display:block;margin-top:.45rem;font-size:1.5rem}.balance-pill.soft{background:linear-gradient(135deg,#fffaf0,#f4ead2);color:var(--bg-strong)}.balance-pill.soft span{color:#8d6b37}.balance-pill.income{background:linear-gradient(135deg,#e8f7f0,#ccebdd);color:var(--success)}.balance-pill.income span{color:#427867}.balance-pill.expense{background:linear-gradient(135deg,#fff0ed,#f5d6d1);color:var(--danger)}.balance-pill.expense span{color:#8d5a54}.section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.section-head h3,.section-head p,.login-panel h1,.supporting{margin:0}.toolbar,.form-grid{display:grid;gap:1rem}.toolbar{grid-template-columns:repeat(2,minmax(0,180px))}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.field,.field-inline{display:grid;gap:.45rem}.field-full{grid-column:1 / -1}.checkbox-field{align-self:end}input,select{width:100%;padding:.85rem 1rem;border-radius:14px;border:1px solid var(--line);background:#fffdfa}.primary-button,.secondary-button,.link-button{border:none;border-radius:14px;cursor:pointer}.primary-button{background:linear-gradient(120deg,#d97706,#f59e0b);color:#fff;padding:.9rem 1.25rem}.secondary-button{background:#eef2f7;color:#17324d;padding:.8rem 1rem}.link-button{background:transparent;color:var(--accent-dark)}.link-button.danger{color:var(--danger)}.form-actions{display:flex;gap:.75rem;align-items:center}.actions-cell{display:flex;gap:.25rem;flex-wrap:wrap}.attachment-cell{background:#fffcf5}.attachment-list{display:grid;gap:.75rem}.attachment-list-compact{gap:.55rem;min-width:280px}.attachment-item{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.9rem 1rem;border:1px solid var(--line);border-radius:16px;background:#fff}.attachment-item-compact{align-items:center;gap:.75rem;padding:.7rem .85rem}.attachment-thumb{flex:0 0 46px;width:46px;height:46px;display:grid;place-items:center;border-radius:12px;background:linear-gradient(160deg,#eef5fb,#ddeaf6);color:var(--bg-strong);font-size:.76rem;font-weight:800;letter-spacing:.08em}.attachment-copy{min-width:0;flex:1}.attachment-item strong,.attachment-item span{display:block}.attachment-copy strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-item span{margin-top:.25rem;color:var(--text-soft);font-size:.9rem}.attachment-actions{display:flex;gap:.5rem;flex-wrap:wrap}.attachment-actions-compact{gap:.35rem;justify-content:flex-end}.attachment-upload-button{width:100%;text-align:center;border:1px dashed var(--line);background:#f7f9fc}.attachment-empty,.field-hint{margin:0;color:var(--text-soft)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0d19288c;display:grid;place-items:center;padding:1.5rem;z-index:1000}.modal-card{width:min(1000px,100%);max-height:90vh;overflow:auto;background:#fffdfa;border-radius:24px;box-shadow:0 30px 60px #0000002e;padding:1.25rem}.modal-head{display:flex;justify-content:space-between;align-items:start;gap:1rem;margin-bottom:1rem}.modal-head h3,.modal-head p{margin:0}.modal-head p{color:var(--text-soft);margin-top:.35rem}.modal-body{min-height:360px}.attachment-preview-image,.attachment-preview-frame{width:100%;border:1px solid var(--line);border-radius:18px;background:#fff}.attachment-preview-image{max-height:70vh;object-fit:contain}.attachment-preview-frame{min-height:70vh}.attachment-preview-fallback{min-height:280px;display:grid;place-items:center;color:var(--text-soft)}.login-page{min-height:100vh;display:grid;place-items:center;padding:2rem}.login-panel{width:min(980px,100%);display:grid;grid-template-columns:1.1fr .9fr;gap:1.5rem;align-items:center}.login-panel h1{font-size:clamp(2.4rem,4vw,4rem);line-height:1}.supporting{margin-top:1rem;color:var(--text-soft);max-width:45ch}.login-form{display:grid;gap:1rem}.table-card{overflow:auto}.report-preview{display:grid;gap:1rem}.report-period-badge{display:inline-flex;align-items:center;padding:.5rem .85rem;border-radius:999px;background:#eef4fb;color:var(--bg-strong);font-weight:600}.report-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.report-block{padding:1rem;border-radius:20px;background:#fffdfa;border:1px solid var(--line)}.report-block h4{margin:0}.report-block-full{grid-column:1 / -1}.empty-cell,.center-screen,.error-text,.success-text{text-align:center}.error-text{color:var(--danger)}.success-text{color:var(--success)}.status-badge{display:inline-block;margin-top:.45rem;padding:.35rem .7rem;border-radius:999px;font-size:.82rem;font-weight:600}.category-chip-list{display:flex;flex-wrap:wrap;gap:.5rem}.status-badge.success{background:#dff1d8;color:#285f2f}.status-badge.danger{background:#f8dfdc;color:#9f3429}@media (max-width: 900px){.app-shell,.login-panel,.stats-grid,.form-grid,.report-grid{grid-template-columns:1fr}.sidebar{display:none}.topbar-mobile-action,.mobile-drawer,.mobile-drawer-backdrop{display:block}.topbar,.section-head,.hero-card{flex-direction:column;align-items:flex-start}.toolbar{grid-template-columns:1fr 1fr}.app-main{padding:1rem}.topbar-user{width:100%;justify-content:space-between}.brand-signature-login{align-items:flex-start}}@media (max-width: 640px){.toolbar{grid-template-columns:1fr}.topbar-user,.form-actions,.attachment-item{flex-direction:column;align-items:stretch}.topbar-mobile-action,.mobile-menu-button{width:100%}}
