:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{min-height:100svh}.app-shell{min-height:100svh;display:flex}.sidebar{background:var(--bg);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:220px;height:100svh;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-brand{color:var(--accent);letter-spacing:-.4px;border-bottom:1px solid var(--border);padding:1.25rem 1.25rem .75rem;font-size:1.25rem;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:.75rem;display:flex}.nav-item{color:var(--text);border-radius:8px;align-items:center;gap:.65rem;padding:.55rem .75rem;font-size:.875rem;text-decoration:none;transition:background .12s,color .12s;display:flex}.nav-item:hover{background:var(--accent-bg);color:var(--text-h)}.nav-item--active{background:var(--accent-bg);color:var(--accent);font-weight:500}.sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:.5rem;padding:1rem 1.25rem;display:flex}.sidebar-email{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;overflow:hidden}.logout-btn{color:var(--text);border:1px solid var(--border);cursor:pointer;text-align:left;background:0 0;border-radius:6px;padding:.3rem .6rem;font-size:.8rem;transition:color .12s,border-color .12s}.logout-btn:hover{color:#ef4444;border-color:#ef4444}.app-main{background:var(--code-bg);flex:1;min-width:0}.page{max-width:960px;margin:0 auto;padding:2rem 1.5rem}.page-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.page-title{letter-spacing:-.4px!important;margin:0!important;font-size:1.5rem!important}.page-subtitle{color:var(--text);margin-top:2px;font-size:.875rem;display:block}.page-loading{justify-content:center;padding:4rem 0;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:1.5rem;height:1.5rem;animation:.6s linear infinite spin}.card{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:1.25rem}.card-title{color:var(--text-h);margin:0 0 1rem!important;font-size:.9rem!important;font-weight:600!important}.card-title-row{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.card-link{color:var(--accent);font-size:.8rem;text-decoration:none}.card-link:hover{text-decoration:underline}.stats-grid{grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.25rem;display:grid}.stat-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:.25rem;padding:1.1rem 1.25rem;display:flex}.stat-label{color:var(--text);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:500}.stat-value{letter-spacing:-.5px;color:var(--text-h);font-size:1.6rem;font-weight:600}.stat-value--income{color:#22c55e}.stat-value--expense{color:#ef4444}.dashboard-grid{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}.tx-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.tx-list--full{gap:0}.tx-item{justify-content:space-between;align-items:center;gap:1rem;padding:.65rem 0;display:flex}.tx-list--full .tx-item{border-bottom:1px solid var(--border);padding:.75rem 1.25rem}.tx-list--full .tx-item:last-child{border-bottom:none}.tx-item--clickable{cursor:pointer}.tx-item--clickable:hover{background:var(--accent-bg)}.tx-left{align-items:center;gap:.65rem;min-width:0;display:flex}.tx-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.tx-label{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:500;display:block;overflow:hidden}.tx-meta{color:var(--text);margin-top:1px;font-size:.75rem;display:block}.tx-amount{white-space:nowrap;font-size:.9rem;font-weight:600}.tx-amount--income{color:#22c55e}.tx-amount--expense{color:#ef4444}.tx-summary{align-items:center;gap:.75rem;margin-bottom:1rem;font-size:.95rem;font-weight:600;display:flex}.payment-list{flex-direction:column;gap:.625rem;margin:0;padding:0;list-style:none;display:flex}.payment-item{justify-content:space-between;align-items:center;font-size:.875rem;display:flex}.payment-label{color:var(--text-h);font-size:.875rem;font-weight:500;display:block}.payment-date{color:var(--text);margin-top:1px;font-size:.75rem;display:block}.payment-amount{color:#ef4444;font-size:.875rem;font-weight:600}.payment-list--full{gap:0}.payment-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1.25rem;transition:background .12s;display:flex}.payment-row:last-child{border-bottom:none}.payment-row--inactive{opacity:.5}.payment-row-left{cursor:pointer;flex:1;align-items:center;gap:.65rem;min-width:0;display:flex}.categories-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem;display:grid}.category-card{background:var(--bg);border:1px solid var(--border);cursor:pointer;border-radius:12px;align-items:center;gap:.75rem;padding:1rem;transition:border-color .12s,box-shadow .12s;display:flex;position:relative}.category-card:hover{border-color:var(--accent-border);box-shadow:var(--shadow)}.category-color{border-radius:50%;flex-shrink:0;width:14px;height:14px}.category-info{flex:1;align-items:center;gap:.4rem;min-width:0;display:flex}.category-icon{flex-shrink:0;font-size:1rem}.category-name{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:500;overflow:hidden}.filters{flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;display:flex}.filter-input{border:1px solid var(--border);background:var(--bg);color:var(--text-h);font-size:.875rem;font-family:var(--sans);border-radius:8px;outline:none;padding:.45rem .75rem;transition:border-color .15s}.filter-input:focus{border-color:var(--accent)}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:.55rem 1.1rem;font-size:.875rem;font-weight:500;transition:opacity .15s}.btn-primary:hover:not(:disabled){opacity:.88}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{color:var(--text-h);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;padding:.55rem 1.1rem;font-size:.875rem;font-weight:500;transition:border-color .15s}.btn-secondary:hover{border-color:var(--text)}.icon-delete{color:var(--text);cursor:pointer;opacity:.5;background:0 0;border:none;border-radius:4px;padding:.25rem .4rem;font-size:.75rem;transition:opacity .12s,color .12s}.icon-delete:hover{opacity:1;color:#ef4444}.toggle-btn{cursor:pointer;background:0 0;border:none;padding:.2rem;font-size:1.1rem;transition:color .15s}.toggle-btn--on{color:#22c55e}.toggle-btn--off{color:var(--border)}.empty-state{text-align:center;color:var(--text);flex-direction:column;align-items:center;gap:1rem;padding:4rem 1rem;display:flex}.empty-hint{color:var(--text);text-align:center;padding:1.5rem 0;font-size:.875rem}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-box{background:var(--bg);border:1px solid var(--border);width:100%;max-width:440px;box-shadow:var(--shadow);border-radius:14px;max-height:90svh;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;padding:1.25rem 1.5rem 0;display:flex}.modal-title{margin:0!important;font-size:1.05rem!important;font-weight:600!important}.modal-close{color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.25rem .4rem;font-size:.9rem;line-height:1}.modal-close:hover{color:var(--text-h)}.modal-body{padding:1.25rem 1.5rem 1.5rem}.modal-form{flex-direction:column;gap:1rem;display:flex}.modal-actions{justify-content:flex-end;gap:.75rem;margin-top:.5rem;display:flex}.form-error{color:#ef4444;background:#ef444414;border:1px solid #ef444433;border-radius:6px;margin:0;padding:.5rem .75rem;font-size:.85rem}select.field input,select{border:1px solid var(--border);background:var(--bg);color:var(--text-h);font-size:.9rem;font-family:var(--sans);border-radius:8px;outline:none;width:100%;padding:.6rem .75rem;transition:border-color .15s}select:focus{border-color:var(--accent)}.color-grid{flex-wrap:wrap;gap:.5rem;display:flex}.color-swatch{cursor:pointer;border:3px solid #0000;border-radius:50%;width:28px;height:28px;transition:transform .12s,border-color .12s}.color-swatch:hover{transform:scale(1.15)}.color-swatch--active{border-color:var(--text-h)}.icon-grid{flex-wrap:wrap;gap:.4rem;display:flex}.icon-btn{border:1px solid var(--border);background:var(--bg);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;transition:border-color .12s,background .12s;display:flex}.icon-btn:hover{border-color:var(--accent-border)}.icon-btn--active{border-color:var(--accent);background:var(--accent-bg)}.type-toggle{border:1px solid var(--border);border-radius:8px;grid-template-columns:1fr 1fr;display:grid;overflow:hidden}.type-btn{color:var(--text);cursor:pointer;background:0 0;border:none;padding:.55rem;font-size:.875rem;font-weight:500;transition:background .12s,color .12s}.type-btn--expense{color:#ef4444;background:#ef44441f}.type-btn--income{color:#22c55e;background:#22c55e1f}.auth-page{justify-content:center;align-items:center;min-height:100svh;padding:1rem;display:flex}.auth-card{background:var(--bg);border:1px solid var(--border);width:100%;max-width:400px;box-shadow:var(--shadow);border-radius:12px;padding:2rem}.auth-header{text-align:center;margin-bottom:1.75rem}.auth-title{color:var(--accent);letter-spacing:-.5px!important;margin:0 0 .25rem!important;font-size:1.75rem!important}.auth-subtitle{color:var(--text);font-size:.9rem}.auth-form{flex-direction:column;gap:1rem;display:flex}.field{flex-direction:column;gap:.375rem;display:flex}.field label{color:var(--text-h);font-size:.875rem;font-weight:500}.field input{border:1px solid var(--border);background:var(--bg);color:var(--text-h);font-size:.9rem;font-family:var(--sans);border-radius:8px;outline:none;padding:.6rem .75rem;transition:border-color .15s}.field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.field input::placeholder{color:var(--text);opacity:.6}.auth-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;min-height:2.5rem;margin-top:.25rem;padding:.65rem 1rem;font-size:.9rem;font-weight:500;transition:opacity .15s;display:flex}.auth-btn:hover:not(:disabled){opacity:.88}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.btn-spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:1rem;height:1rem;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.auth-error{color:#ef4444;background:#ef444414;border:1px solid #ef444433;border-radius:6px;margin:0;padding:.5rem .75rem;font-size:.85rem}.auth-success{color:#22c55e;background:#22c55e14;border:1px solid #22c55e33;border-radius:6px;margin:0;padding:.5rem .75rem;font-size:.85rem}.auth-switch{text-align:center;color:var(--text);margin:1.25rem 0 0;font-size:.875rem}.auth-switch a{color:var(--accent);font-weight:500;text-decoration:none}.auth-switch a:hover{text-decoration:underline}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.landing{flex-direction:column;max-width:960px;min-height:100svh;margin:0 auto;padding:0 1.5rem;display:flex}.landing-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.25rem 0;display:flex}.landing-logo{color:var(--accent);letter-spacing:-.4px;font-size:1.25rem;font-weight:600}.landing-header-actions{align-items:center;gap:1rem;display:flex}.landing-link{color:var(--text);font-size:.875rem;text-decoration:none;transition:color .15s}.landing-link:hover{color:var(--text-h)}.landing-hero{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:1.25rem;padding:4rem 0 3rem;display:flex}.hero-badge{color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-border);letter-spacing:.02em;border-radius:99px;padding:.3rem .85rem;font-size:.8rem;font-weight:500;display:inline-block}.hero-title{color:var(--text-h);letter-spacing:-2px!important;margin:0!important;font-size:3.5rem!important;font-weight:700!important;line-height:1.1!important}.hero-accent{color:var(--accent)}.hero-desc{color:var(--text);max-width:520px;font-size:1.1rem;line-height:1.6}.hero-actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem;margin-top:.5rem;display:flex}.btn-primary--lg{padding:.75rem 1.5rem!important;font-size:.95rem!important}.btn-ghost{color:var(--text);border-radius:8px;padding:.75rem 1rem;font-size:.875rem;text-decoration:none;transition:color .15s}.btn-ghost:hover{color:var(--text-h)}.landing-features{grid-template-columns:repeat(3,1fr);gap:1rem;padding-bottom:4rem;display:grid}.feature-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:.5rem;padding:1.5rem;display:flex}.feature-icon{font-size:1.75rem}.feature-title{color:var(--text-h);margin:0!important;font-size:1rem!important;font-weight:600!important}.feature-desc{color:var(--text);font-size:.875rem;line-height:1.55}.landing-footer{border-top:1px solid var(--border);color:var(--text);justify-content:space-between;align-items:center;padding:1.25rem 0;font-size:.8rem;display:flex}.landing-footer a{color:var(--text);text-decoration:none}.landing-footer a:hover{color:var(--accent)}@media (width<=768px){.hero-title{letter-spacing:-1px!important;font-size:2.25rem!important}.landing-features{grid-template-columns:1fr}.hero-desc{font-size:1rem}}.topbar,.drawer-overlay{display:none}@media (width<=768px){.sidebar{display:none}.topbar{background:var(--bg);border-bottom:1px solid var(--border);z-index:50;justify-content:space-between;align-items:center;width:100%;height:52px;padding:0 1rem;display:flex;position:sticky;top:0}.topbar-brand{color:var(--accent);letter-spacing:-.4px;font-size:1.15rem;font-weight:600}.hamburger{color:var(--text-h);cursor:pointer;background:0 0;border:none;align-items:center;padding:.25rem;display:flex}.drawer-overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;display:block;position:fixed;inset:0}.drawer{background:var(--bg);border-right:1px solid var(--border);z-index:201;flex-direction:column;width:260px;height:100svh;animation:.2s slideIn;display:flex;position:fixed;top:0;left:0}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}.app-shell{flex-direction:column}.app-main{width:100%}.page{padding:1.25rem 1rem}.page-header{align-items:center}.page-title{font-size:1.2rem!important}.stats-grid{grid-template-columns:1fr;gap:.75rem}.stat-value{font-size:1.3rem}.dashboard-grid{grid-template-columns:1fr}.categories-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.filters{flex-direction:column;gap:.5rem}.filter-input{box-sizing:border-box;width:100%}.tx-summary{flex-wrap:wrap;font-size:.875rem}.modal-overlay{align-items:flex-end;padding:0}.modal-box{border-radius:16px 16px 0 0;width:100%;max-width:100%;max-height:92svh}.auth-card{box-shadow:none;border:none;padding:1.5rem 1rem}}
