:root{--color-bg: #f8f8f8;--color-surface: #ffffff;--color-text: #111827;--color-muted: #6b7280;--color-border: #e5e7eb;--color-accent: #111827;--color-accent-text: #fff;--color-green: #059669;--color-red: #dc2626;--color-chip-bg: #e0e7ff;--color-chip-text: #3730a3;--color-error-bg: #fef2f2;--color-error-border: #fecaca;--color-row-edit: #f8f9fb;--radius: .5rem;--max-width: 1120px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .06);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .08);--font-heading: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--space-7: 3rem;--space-8: 4rem;color-scheme:light dark}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--color-bg: #0f0f0f;--color-surface: #1a1a1a;--color-text: #e5e5e5;--color-muted: #9ca3af;--color-border: #2e2e2e;--color-accent: #f5f5f5;--color-accent-text: #111;--color-green: #34d399;--color-red: #f87171;--color-chip-bg: #1e1b4b;--color-chip-text: #a5b4fc;--color-error-bg: #1c0a0a;--color-error-border: #7f1d1d;--color-row-edit: #1f1f1f;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 2px 8px rgba(0, 0, 0, .3);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .4)}}[data-theme=dark]{--color-bg: #0f0f0f;--color-surface: #1a1a1a;--color-text: #e5e5e5;--color-muted: #9ca3af;--color-border: #2e2e2e;--color-accent: #e5e5e5;--color-green: #34d399;--color-red: #f87171;--color-chip-bg: #1e1b4b;--color-chip-text: #a5b4fc;--color-error-bg: #1c0a0a;--color-error-border: #7f1d1d;--color-row-edit: #1f1f1f;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 2px 8px rgba(0, 0, 0, .3);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .4)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.stat-value,.data-table td,input[type=number]{font-variant-numeric:tabular-nums}h1{font-family:var(--font-heading);font-size:1.75rem;font-weight:700;letter-spacing:-.025em;line-height:1.2;margin-bottom:var(--space-5)}h2{font-family:var(--font-heading);font-size:1.375rem;font-weight:700;letter-spacing:-.02em;line-height:1.25;margin-bottom:var(--space-4)}h3{font-family:var(--font-heading);font-size:1.0625rem;font-weight:600;letter-spacing:-.01em;line-height:1.3;margin-bottom:var(--space-3)}.landing-page{max-width:720px;margin:0 auto;padding:0 1.5rem}.hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding:6rem 0 4rem}.hero-title{font-family:var(--font-heading);font-size:3.5rem;font-weight:800;letter-spacing:-.04em;margin-bottom:.75rem}.hero-tagline{font-family:var(--font-heading);font-size:1.375rem;color:var(--color-muted);margin-bottom:1.5rem;letter-spacing:-.01em}.hero-body{color:var(--color-muted);max-width:32rem;margin-bottom:2.5rem;line-height:1.7}.features{padding:3rem 0}.features-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:600px){.features-grid{grid-template-columns:1fr}}.feature-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem}.feature-title{font-size:1rem;font-weight:600;margin-bottom:.375rem}.feature-desc{font-size:.875rem;color:var(--color-muted);line-height:1.6}.principles{padding:3rem 0}.section-title{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;text-align:center;margin-bottom:var(--space-6);letter-spacing:-.02em}.principles-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.5rem}@media(max-width:600px){.principles-grid{grid-template-columns:1fr}}.principle h4{font-size:.9375rem;font-weight:600;margin-bottom:.375rem}.principle p{font-size:.8125rem;color:var(--color-muted);line-height:1.6}.landing-footer{padding:3rem 0;text-align:center;border-top:1px solid var(--color-border)}.footer-links{display:flex;justify-content:center;gap:1.5rem;margin-bottom:1rem}.footer-links a{font-size:.8125rem;color:var(--color-muted);text-decoration:none}.footer-links a:hover{color:var(--color-text)}.footer-text{font-size:.8125rem;color:var(--color-muted);font-style:italic}.footer-copyright{font-size:.75rem;color:var(--color-muted);margin-top:.5rem}.legal-page{max-width:640px;margin:0 auto;padding:2rem 1.5rem 4rem;line-height:1.7}.legal-page h1{font-size:2rem;margin-bottom:.25rem}.legal-page h2{font-size:1.125rem;margin-top:2rem;margin-bottom:.5rem}.legal-page p,.legal-page ul{color:var(--color-muted);margin-bottom:1rem}.legal-page ul{padding-left:1.5rem}.legal-page li{margin-bottom:.5rem}.legal-page a{color:var(--color-text)}.legal-updated{font-size:.8125rem;color:var(--color-muted);margin-bottom:2rem}.btn{padding:.5rem 1.25rem;font-family:var(--font-heading);font-size:.875rem;border-radius:var(--radius);border:1px solid transparent;cursor:pointer;font-weight:600;letter-spacing:-.005em;transition:opacity .15s,box-shadow .15s,transform .1s}.btn:hover{opacity:.9}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:default;transform:none}.btn-primary{background:var(--color-accent);color:var(--color-accent-text);box-shadow:var(--shadow-sm)}.btn-primary:hover{box-shadow:var(--shadow-md)}.btn-lg{padding:.875rem 2.5rem;font-size:1.0625rem}.app-layout{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;border-bottom:1px solid var(--color-border);margin-bottom:2rem}.app-header-left{display:flex;align-items:baseline;gap:2rem}.app-logo{font-family:var(--font-heading);font-size:1.25rem;font-weight:800;letter-spacing:-.03em}.app-nav{display:flex;align-items:baseline;gap:.25rem}.nav-link{padding:.375rem .75rem;border-radius:var(--radius);text-decoration:none;color:var(--color-muted);font-size:.875rem;font-weight:500;transition:background .15s,color .15s}.nav-link:hover{background:var(--color-border);color:var(--color-text)}.nav-link-active,.nav-link-active:hover{background:var(--color-accent);color:var(--color-accent-text)}.nav-dropdown-trigger{border:none;background:none;cursor:pointer;font-family:inherit;font-size:inherit;line-height:inherit;vertical-align:baseline}.nav-dropdown{position:absolute;top:calc(100% + .375rem);left:0;z-index:100;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:11rem;padding:.375rem;display:flex;flex-direction:column}.nav-dropdown-item{padding:.375rem .75rem;border-radius:.25rem;text-decoration:none;color:var(--color-text);font-size:.8125rem;font-weight:500;transition:background .1s}.nav-dropdown-item:hover{background:var(--color-bg)}.nav-dropdown-item-active{background:var(--color-accent);color:var(--color-accent-text)}.nav-dropdown-item-active:hover{background:var(--color-accent)}.app-header-right{display:flex;align-items:center;gap:.75rem}.theme-toggle{background:none;border:1px solid var(--color-border);border-radius:var(--radius);width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;color:var(--color-muted);transition:background .15s,color .15s}.theme-toggle:hover{background:var(--color-border);color:var(--color-text)}.app-main{padding-bottom:var(--space-7)}@media(max-width:768px){.app-header{flex-wrap:wrap;gap:var(--space-2);padding:var(--space-3) 0}.app-header-left{width:100%;flex-wrap:wrap;gap:var(--space-3)}.app-nav{flex-wrap:wrap;gap:.125rem}.nav-link{font-size:.8125rem;padding:.25rem .5rem}.app-header-right{width:100%;justify-content:flex-end;padding-top:var(--space-2);border-top:1px solid var(--color-border)}.stat-grid{grid-template-columns:1fr 1fr}}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-4) var(--space-5);box-shadow:var(--shadow-sm);transition:box-shadow .2s,transform .2s}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-label{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em;color:var(--color-muted);margin-bottom:var(--space-1)}.stat-value{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;letter-spacing:-.02em}.data-table{width:100%;border-collapse:collapse;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;font-size:.8125rem;box-shadow:var(--shadow-sm)}.data-table th{text-align:left;padding:.625rem 1rem;font-weight:600;font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted);border-bottom:1px solid var(--color-border);background:var(--color-bg)}.data-table td{padding:.5rem 1rem;border-bottom:1px solid var(--color-border)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background .15s ease}.data-table tbody tr:hover{background:var(--color-bg)}.income{color:var(--color-green)}.expense{color:var(--color-red)}.filter-bar{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem;padding:1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.filter-group{display:flex;flex-direction:column;gap:.25rem;min-width:140px;flex:1}.filter-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted)}.filter-input{padding:.375rem .625rem;border:1px solid var(--color-border);border-radius:var(--radius);font-size:.8125rem;background:var(--color-bg);color:var(--color-text)}.filter-input:focus{outline:2px solid var(--color-accent);outline-offset:-1px}.txn-summary{display:flex;gap:1.5rem;font-size:.8125rem;color:var(--color-muted);margin-bottom:1rem}.month-picker{display:flex;align-items:center;gap:.5rem}.month-picker-btn{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:.25rem .5rem;cursor:pointer;font-size:.875rem;color:var(--color-text);line-height:1}.month-picker-btn:hover{background:var(--color-border)}.month-picker-label{font-size:.8125rem;font-weight:500;min-width:8rem;text-align:center}.category-chip{display:inline-block;padding:.125rem .5rem;border:none;border-radius:1rem;font-size:.75rem;font-weight:500;color:var(--color-text);cursor:pointer;white-space:nowrap;transition:opacity .15s}.category-chip:hover{opacity:.75}.chip-blue{background:#e0e7ff;color:#3730a3}.chip-green{background:#d1fae5;color:#065f46}.chip-amber{background:#fef3c7;color:#92400e}.chip-pink{background:#fce7f3;color:#9d174d}.chip-purple{background:#ede9fe;color:#5b21b6}.chip-red{background:#fee2e2;color:#991b1b}.chip-gray{background:#f3f4f6;color:#374151}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .chip-blue{background:#1e1b4b;color:#a5b4fc}:root:not([data-theme=light]) .chip-green{background:#022c22;color:#6ee7b7}:root:not([data-theme=light]) .chip-amber{background:#451a03;color:#fcd34d}:root:not([data-theme=light]) .chip-pink{background:#500724;color:#f9a8d4}:root:not([data-theme=light]) .chip-purple{background:#2e1065;color:#c4b5fd}:root:not([data-theme=light]) .chip-red{background:#450a0a;color:#fca5a5}:root:not([data-theme=light]) .chip-gray{background:#1f2937;color:#9ca3af}}[data-theme=dark] .chip-blue{background:#1e1b4b;color:#a5b4fc}[data-theme=dark] .chip-green{background:#022c22;color:#6ee7b7}[data-theme=dark] .chip-amber{background:#451a03;color:#fcd34d}[data-theme=dark] .chip-pink{background:#500724;color:#f9a8d4}[data-theme=dark] .chip-purple{background:#2e1065;color:#c4b5fd}[data-theme=dark] .chip-red{background:#450a0a;color:#fca5a5}[data-theme=dark] .chip-gray{background:#1f2937;color:#9ca3af}.td-category{position:relative}.category-editor{display:flex;flex-direction:column;gap:.375rem;padding:.375rem;background:var(--color-surface);border:1px solid var(--color-accent);border-radius:var(--radius);min-width:16rem;box-shadow:0 2px 8px #00000014}.category-editor-row{display:flex;gap:.375rem}@media(max-width:600px){.category-editor-row{flex-direction:column}}.category-editor-select{flex:1;padding:.25rem .375rem;border:1px solid var(--color-border);border-radius:var(--radius);font-size:.75rem;background:var(--color-bg);color:var(--color-text)}.category-editor-select:focus{outline:2px solid var(--color-accent);outline-offset:-1px}.category-editor-actions{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.category-editor-learn{display:flex;align-items:center;gap:.25rem;font-size:.6875rem;color:var(--color-muted);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-editor-learn input{margin:0}.category-editor-buttons{display:flex;gap:.25rem;flex-shrink:0}.category-editor-error{font-size:.6875rem;color:var(--color-red)}.batch-offer{display:flex;flex-direction:column;gap:.5rem}.batch-offer-text{font-size:.75rem;line-height:1.5;color:var(--color-text)}.batch-offer-actions{display:flex;gap:.375rem}.batch-result{font-size:.75rem;color:var(--color-green);font-weight:500;padding:.125rem 0}.row-transfer{opacity:.6}.row-transfer:hover{opacity:.85}.paired-icon{display:inline-block;margin-right:.375rem;color:var(--color-muted);font-size:.875rem;cursor:help}.filter-toggle{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--color-muted);cursor:pointer;white-space:nowrap}.filter-toggle input{margin:0}.row-editing{background:var(--color-row-edit)}.row-editing td{border-bottom-color:transparent}.btn-icon{background:none;border:1px solid var(--color-border);border-radius:var(--radius);padding:.1875rem .5rem;font-size:.6875rem;color:var(--color-muted);cursor:pointer;white-space:nowrap;transition:all .15s ease}.btn-icon:hover{background:var(--color-bg);color:var(--color-text);border-color:var(--color-muted)}.btn-icon:active{transform:scale(.96)}.btn-icon-primary{background:var(--color-accent);color:var(--color-accent-text);border-color:var(--color-accent)}.btn-icon-primary:hover{background:var(--color-accent);color:var(--color-accent-text);opacity:.85}.message-box{margin:1rem 0;padding:.75rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);font-size:.8125rem;white-space:pre-wrap}.td-projects{position:relative}.project-tagger{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}.project-tags{display:flex;gap:.25rem;flex-wrap:wrap}.project-tag{display:inline-block;padding:.0625rem .375rem;border-radius:1rem;font-size:.6875rem;background:var(--color-chip-bg);color:var(--color-chip-text);white-space:nowrap}.project-tag-btn{display:inline-flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;border:1px dashed var(--color-border);border-radius:50%;background:none;color:var(--color-muted);font-size:.75rem;cursor:pointer;flex-shrink:0}.project-tag-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-bg)}.project-tagger-popup{position:absolute;top:100%;left:0;z-index:10;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 4px 12px #0000001a;padding:.5rem;min-width:10rem;display:flex;flex-direction:column;gap:.25rem}.project-tagger-option{display:flex;align-items:center;gap:.375rem;font-size:.75rem;padding:.1875rem .25rem;border-radius:.25rem;cursor:pointer}.project-tagger-option:hover{background:var(--color-bg)}.project-tagger-option input{margin:0}.project-link{color:var(--color-accent);text-decoration:none;font-weight:500}.project-link:hover{text-decoration:underline}.create-project-form{display:flex;gap:.75rem;align-items:flex-end}.create-project-form .filter-input{flex:1}.empty-state{text-align:center;padding:3rem 1rem;color:var(--color-muted)}.empty-hint{font-size:.875rem;margin-top:.5rem}.text-muted{color:var(--color-muted)}.import-steps{display:flex;flex-direction:column;gap:1.5rem}.import-step h3{font-size:.9375rem;margin-bottom:.5rem}.file-input{font-size:.875rem}.import-errors{padding:.75rem 1rem;background:var(--color-error-bg);border:1px solid var(--color-error-border);border-radius:var(--radius);font-size:.8125rem}.month-input{padding:.375rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius);font-size:.875rem;background:var(--color-surface)}.dashboard-charts{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:1.5rem}.dashboard-charts>*{min-width:0;overflow:hidden}@media(max-width:700px){.dashboard-charts{grid-template-columns:1fr}}.dashboard-chart-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.25rem;min-width:0}.dashboard-chart-section h3{font-size:.9375rem;margin-bottom:1rem}.pagination-bar{display:flex;justify-content:space-between;align-items:center;margin-top:.75rem;padding:.5rem 0}.pagination-info{font-size:.8125rem;color:var(--color-muted)}.subcategory-row td{font-size:.75rem;padding-top:.25rem;padding-bottom:.25rem;border-bottom-color:transparent}.budget-bar-track{height:.375rem;background:var(--color-border);border-radius:.1875rem;overflow:hidden}.budget-bar-fill{height:100%;border-radius:.1875rem;background:var(--color-green);transition:width .3s ease}.budget-bar-over{background:var(--color-red)}.budget-input{width:5.5rem;padding:.25rem .5rem;border:1px solid var(--color-border);border-radius:var(--radius);font-size:.875rem;text-align:right;background:var(--color-bg);color:var(--color-text)}.budget-input:focus{outline:2px solid var(--color-accent);outline-offset:-1px}.budget-input::placeholder{color:var(--color-border)}.row-over-budget{background:var(--color-error-bg)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:border-color .2s,box-shadow .2s}input,select,textarea{background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius);padding:.375rem .625rem;font-size:.8125rem;font-family:inherit;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--color-accent) 20%,transparent)}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--color-accent) 20%,transparent)}.recurring-cards{display:none}.recurring-table{display:block}@media(max-width:700px){.recurring-cards{display:block}.recurring-table{display:none}}.chip{display:inline-block;padding:.0625rem .5rem;border-radius:1rem;font-size:.75rem;background:var(--color-chip-bg);color:var(--color-chip-text)}
