.auth-screen{min-height:100dvh;width:100%;display:grid;place-items:center;padding:24px;position:relative;overflow:hidden;background:radial-gradient(1100px 600px at -10% -10%,color-mix(in oklab,var(--brand, #ff7a00) 12%,transparent),transparent 60%),radial-gradient(1100px 600px at 110% -20%,color-mix(in oklab,var(--brand, #ff7a00) 8%,transparent),transparent 55%),linear-gradient(180deg,var(--bg, #fff),var(--bg-2, #fbfbfb));color:var(--text, #0f172a)}.auth-bg{display:none}.auth-card{z-index:1;width:min(440px,92vw);border-radius:16px;border:1px solid var(--panel-border, #e5e7eb);background:#fff;color:var(--text, #0f172a);box-shadow:var(--shadow-2, 0 14px 38px rgba(15,23,42,.1));padding:22px;min-width:0}.auth-brand{display:flex;align-items:center;gap:10px;margin-bottom:12px}.auth-logo{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;font-size:18px;color:#fff;background:linear-gradient(135deg,color-mix(in oklab,var(--brand, #ff7a00) 88%,#ffd19f),var(--brand, #ff7a00));box-shadow:0 8px 22px color-mix(in oklab,var(--brand, #ff7a00) 35%,transparent)}.auth-name{font-weight:900;letter-spacing:.2px}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;background:#fff7f0;border:1px solid #ffe2cc;border-radius:12px;padding:6px;margin:12px 0 16px}.auth-tab{border:0;cursor:pointer;border-radius:8px;padding:10px 8px;background:transparent;color:#7a3a00;font-weight:800}.auth-tab.is-active{color:#fff;background:linear-gradient(180deg,var(--brand, #ff7a00),color-mix(in oklab,var(--brand, #ff7a00) 86%,#cc6200));box-shadow:0 10px 22px #ff7a0040}.auth-form{display:grid;gap:12px;min-width:0}.auth-field{display:grid;gap:6px;font-size:14px;min-width:0}.auth-field>span{color:#475569;font-weight:600}.auth-input,.auth-input input{width:100%;border-radius:12px;border:1px solid var(--panel-border, #e5e7eb);background:#fff;color:var(--text, #0f172a);padding:12px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.auth-input::placeholder,.auth-input input::placeholder{color:#94a3b8}.auth-input:focus-within,.auth-input input:focus{border-color:var(--brand, #ff7a00);box-shadow:0 0 0 3px color-mix(in oklab,var(--brand, #ff7a00) 35%,transparent)}.auth-input.has-icon{position:relative;padding:0}.auth-input.has-icon input{padding-right:44px;border:none;background:transparent}.auth-eye{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:34px;height:34px;border-radius:10px;border:1px solid var(--panel-border, #e5e7eb);background:#fff;color:#0f172a;cursor:pointer}.auth-error{padding:10px 12px;border-radius:12px;background:#fff1f1;border:1px solid #fcdada;color:#7f1d1d;font-size:13px}.auth-info{padding:10px 12px;border-radius:12px;background:#3b82f61f;border:1px solid rgba(59,130,246,.35);color:#0f172a;font-size:13px}.wrap-any{overflow-wrap:anywhere;word-break:break-word;white-space:normal}.truncate-one{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.dev-link{display:flex;align-items:center;gap:8px;border:1px solid var(--panel-border, #e5e7eb);background:#f8fafc;border-radius:12px;padding:10px 12px;min-width:0}.dev-link code{flex:1;min-width:0;display:block;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.auth-btn{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--panel-border, #e5e7eb);background:linear-gradient(180deg,#fff,#f8fafc);color:var(--text, #0f172a);font-weight:800;cursor:pointer;transition:transform .05s ease,background .15s ease,box-shadow .15s ease,border-color .15s ease}.auth-btn:hover{background:linear-gradient(180deg,#fff,#f1f5f9)}.auth-btn:active{transform:translateY(1px)}.auth-btn.primary{color:#fff;border-color:color-mix(in oklab,var(--brand, #ff7a00) 75%,#0000);background:linear-gradient(180deg,var(--brand, #ff7a00),color-mix(in oklab,var(--brand, #ff7a00) 86%,#cc6200));box-shadow:0 12px 28px #ff7a0040}.auth-btn.primary:hover{background:linear-gradient(180deg,color-mix(in oklab,var(--brand, #ff7a00) 80%,#ffb15c),var(--brand, #ff7a00))}.auth-minor a,.auth-form a{color:var(--brand, #ff7a00);text-underline-offset:2px}.auth-footer{margin-top:14px;font-size:12px;color:#475569;text-align:center}.auth-footer a{color:var(--brand, #ff7a00)}@media (min-width: 860px){.auth-card{padding:24px;width:440px}}:root{--bg: #ffffff;--bg-2: #fbfbfb;--panel: #ffffff;--panel-2: #f9fafb;--text: #0f172a;--muted: #475569;--muted-3: #64748b;--brand: #ff7a00;--brand-600: #e66e00;--brand-700: #cc6200;--brand-300: #ffb15c;--accent: var(--brand);--accent-2: #ef4444;--info: #2563eb;--border: #e5e7eb;--panel-border: var(--border);--ring: rgba(255, 122, 0, .35);--shadow-1: 0 8px 24px rgba(15, 23, 42, .06);--shadow-2: 0 14px 38px rgba(15, 23, 42, .1);--sidebar-w: 260px}*{box-sizing:border-box}html,body,#root{height:100%;width:100%;max-width:100%}html,body,#root{overflow-x:hidden}body{margin:0;background:radial-gradient(1100px 600px at -10% -10%,rgba(255,122,0,.08),transparent 60%),radial-gradient(1100px 600px at 110% -20%,rgba(255,122,0,.06),transparent 55%),linear-gradient(180deg,var(--bg),var(--bg-2));color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-shell,.app-content,.page{overflow-x:clip}.container{max-width:1080px;margin:24px auto;padding:0 16px}.header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.title{font-size:28px;font-weight:800;letter-spacing:.2px}.page .title{font-size:24px;font-weight:800}.header-actions{display:flex;gap:8px;align-items:center}.filters,.form,.table-wrap,.summary{background:var(--panel);border:1px solid var(--panel-border);border-radius:16px;padding:16px;margin-bottom:16px;box-shadow:var(--shadow-1)}.filters-grid,.form-grid{display:grid;gap:12px}.filters-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.form-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.full{grid-column:1 / -1}@media (max-width: 900px){.filters-grid{grid-template-columns:repeat(2,1fr)}.form-grid{grid-template-columns:1fr}}.input,.select,.button,textarea.input{width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--panel-border);background:#fff;color:var(--text);transition:border-color .15s ease,box-shadow .15s ease,transform .05s ease,background .15s ease}textarea.input{min-height:90px}.input,.select{min-height:40px}.input::placeholder,.select::placeholder,textarea.input::placeholder{color:#94a3b8}.input:focus,.select:focus,textarea.input:focus{outline:0;border-color:var(--brand);box-shadow:0 0 0 3px var(--ring)}input[type=date]::-webkit-calendar-picker-indicator{filter:opacity(.75)}.button{cursor:pointer;font-weight:700;letter-spacing:.2px;color:#111827;background:linear-gradient(180deg,#fff,#f8fafc)}.button:hover{background:linear-gradient(180deg,#fff,#f1f5f9)}.button:active{transform:translateY(1px)}.button-success{color:#fff;background:linear-gradient(180deg,var(--brand),var(--brand-600));border-color:#e66e00e6;text-shadow:0 0 0 transparent}.button-success:hover{background:linear-gradient(180deg,var(--brand-300),var(--brand));box-shadow:0 10px 24px #ff7a0040}.button-success:focus{outline:0;box-shadow:0 0 0 3px var(--ring)}.button-danger{background:linear-gradient(180deg,#fee2e2,#fecaca);border-color:#fca5a5;color:#7f1d1d}.button-danger:hover{background:linear-gradient(180deg,#fecaca,#fca5a5)}.summary-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.card{background:#fff;border:1px solid var(--panel-border);border-radius:14px;padding:14px;box-shadow:var(--shadow-1);transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-2);border-color:#dbe1e8}.card h3{margin:0 0 8px;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}.card .value{font-size:22px;font-weight:800}.card.income .value{color:var(--accent)}.card.expense .value{color:var(--accent-2)}.card.balance .value{color:var(--info)}.table-wrap{overflow-x:auto;background:#fff}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:10px 8px;border-bottom:1px solid var(--panel-border);text-align:left}.table th{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}.row-actions{display:flex;gap:8px;justify-content:flex-end}.badge{padding:2px 10px;border-radius:999px;font-size:12px;border:1px solid #e6e6e6;background:#fff7f0;color:#7a3a00}.badge.income{color:#7a3a00;border-color:#ffd6b0;background:#fff3e6}.badge.expense{color:#7f1d1d;border-color:#fcdada;background:#fff1f1}.helper{color:var(--muted);font-size:12px}.category-dot{display:inline-block;width:10px;height:10px;border-radius:999px;margin-right:6px;border:1px solid #d1d5db;vertical-align:middle}.modal-overlay{position:fixed;inset:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{width:100%;max-width:520px;background:#fff;color:var(--text);border:1px solid var(--panel-border);border-radius:16px;padding:16px;box-shadow:var(--shadow-2);animation:modalIn .12s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.modal-header h3{margin:0;font-size:18px;font-weight:800}.modal-close{width:36px;height:36px;border-radius:12px;background:#fff;color:var(--text);border:1px solid var(--panel-border);cursor:pointer}.modal-close:hover{border-color:var(--brand-600)}.modal-body{margin-top:8px}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}@keyframes modalIn{0%{transform:translateY(4px);opacity:0}to{transform:translateY(0);opacity:1}}.app-shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;overflow:auto;background:#fff;border-right:1px solid var(--panel-border);display:flex;flex-direction:column;padding:16px;z-index:1200}.sidebar-header{position:sticky;top:0;z-index:2;background:#fff;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 0 10px;margin:0;border-bottom:1px solid var(--panel-border)}.sidebar-brand{display:flex;align-items:center;gap:6px;line-height:1;white-space:nowrap}.sidebar-close{display:none!important}.nav{display:flex;flex-direction:column;gap:6px}.sidebar-brand span{font-size:clamp(1.1rem,.4vw + .9rem,1.6rem);font-weight:700}.brand-logo{height:1.2em;width:auto;object-fit:contain;display:block}@media (max-width: 768px){.sidebar-brand{gap:6px}.sidebar-brand span{font-size:clamp(1rem,1.2vw + .85rem,1.4rem)}.brand-logo{height:1.1em}}@media (max-width: 480px){.sidebar-brand{gap:4px}.sidebar-brand span{font-size:clamp(1rem,2vw + .7rem,1.2rem)}.brand-logo{height:1em}}.nav{margin-top:10px}.nav .nav-item:first-child{margin-top:2px}.nav-item{display:block;width:100%;text-align:left;padding:10px 12px;border-radius:12px;text-decoration:none;color:var(--text);border:1px solid transparent;background:transparent;appearance:none;-webkit-appearance:none;font:inherit;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .05s ease;position:relative}.nav-item:hover{background:#fff6ee;border-color:#ffe2cc}.nav-item.active{background:#fff2e6;border-color:#ffddb8}.nav-item.active:before{content:"";position:absolute;left:-1px;top:10px;bottom:10px;width:3px;border-radius:3px;background:linear-gradient(180deg,var(--brand-300),var(--brand))}.logout-btn{margin-top:8px;background:#fff1f2;border:1px solid #fecdd3;color:#7f1d1d}.logout-btn:hover{background:#ffe4e6;border-color:#fda4af;transform:translateY(-1px)}.logout-btn:active{transform:translateY(0)}.sidebar-footer{margin-top:auto;color:var(--muted);font-size:12px}.app-content{padding:24px}.sidebar-toggle{position:fixed;top:max(12px,env(safe-area-inset-top));left:max(12px,env(safe-area-inset-left));z-index:2001;display:none;width:44px;height:44px;padding:0;border-radius:12px;border:1px solid var(--panel-border);background:#fff;color:var(--text);box-shadow:var(--shadow-1);align-items:center;justify-content:center}.sidebar-toggle:focus{outline:0;box-shadow:0 0 0 3px var(--ring)}.sidebar-backdrop{position:fixed;inset:0;background:#00000040;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);z-index:1200;display:none}.grid-2{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}@media (max-width: 1000px){.grid-2{grid-template-columns:1fr}}.cards-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.goal-card{display:grid;gap:8px}.goal-head{display:flex;align-items:center;gap:8px}.goal-title{flex:1;font-weight:900;color:var(--text)}.goal-status{margin-left:auto;color:var(--muted);font-size:12px}.goal-line{display:flex;justify-content:space-between;align-items:center}.progress{background:#f1f5f9;border-radius:8px;height:10px;overflow:hidden;border:1px solid #e2e8f0}.progress-bar{height:100%;border-radius:8px;transition:width .25s ease;background:linear-gradient(90deg,var(--brand-300),var(--brand))}.modal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.checkbox-line{display:flex;align-items:center;gap:8px}.swatches{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px;align-items:center}.swatch{width:22px;height:22px;border-radius:6px;border:2px solid #e5e7eb;cursor:pointer;background:#fff}.swatch-active{border-color:var(--brand);outline:2px solid rgba(255,122,0,.25);outline-offset:0}.goal-timeline{margin-top:8px;padding:8px;border:1px solid var(--panel-border);border-radius:12px;background:var(--panel-2);max-width:100%;overflow:hidden}.goal-card svg{width:100%!important;height:auto!important}.goal-card .card{overflow:hidden}.heatgrid{display:grid;grid-template-columns:repeat(7,minmax(60px,1fr));gap:8px}.heatcell{border:1px solid var(--panel-border);border-radius:10px;padding:10px 6px;text-align:center;color:var(--text);background:#fff}.heatlabel{font-size:12px;color:var(--muted)}.heatvalue{font-size:12px;color:#111827}.categories-panel{max-width:100%;width:min(420px,100%);box-sizing:border-box;overflow-x:hidden}.categories-backdrop{position:fixed;inset:0;background:#00000040;z-index:1399;display:none}.categories-panel.drawer{position:fixed;top:0;right:0;bottom:0;background:var(--panel-2);border-left:1px solid var(--panel-border);overflow:auto;z-index:1400}@media (max-width: 1024px){.summary-cards{grid-template-columns:1fr 1fr}.grid-2,.cards-grid{grid-template-columns:1fr}.filters-grid,.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 900px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;inset:0 auto 0 0;width:min(var(--sidebar-w),86vw);max-width:320px;min-width:240px;height:100dvh;transform:translate(-100%);box-shadow:2px 0 24px #0f172a1f;background:#fff;transition:transform .2s ease;padding:12px;overflow-y:auto;-webkit-overflow-scrolling:touch}.sidebar.open{transform:translate(0)}.sidebar-backdrop.show{display:block}.sidebar-toggle{display:inline-flex}.app-content{padding:16px}.header{flex-wrap:wrap;gap:8px}.header .helper{margin-top:4px}.sidebar-brand{margin:0;padding:0;gap:6px}.sidebar-brand span{font-size:clamp(1rem,2vw + .75rem,1.2rem)}.brand-logo{height:1.1em}.nav-item{padding:9px 10px}.sidebar.open~.sidebar-toggle{display:none!important}}@media (max-width: 720px){.summary-cards,.filters-grid,.form-grid,.form-grid.modal-grid{grid-template-columns:1fr}.table{border:0}.table thead{display:none}.table tbody tr{display:grid;grid-template-columns:1fr;gap:6px;margin-bottom:10px;border:1px solid var(--panel-border);border-radius:10px;padding:8px 10px;background:#fff;box-shadow:var(--shadow-1)}.table td{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.table td:before{content:attr(data-label);font-weight:700;color:var(--muted-3);margin-right:12px}.row-actions{justify-content:flex-end}.value{font-size:1.1rem}.heatgrid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 900px){.header .title{padding-left:56px}}
