:root{--color-primary: #10b981;--color-primary-dark: #059669;--color-primary-light: #d1fae5;--color-danger: #ef4444;--color-danger-dark: #dc2626;--color-text: #111827;--color-text-muted: #6b7280;--color-border: #e5e7eb;--color-bg: #f9fafb;--color-surface: #ffffff;--color-surface-2: #f3f4f6;--color-shadow: 0 4px 6px -1px rgba(0, 0, 0, .08), 0 2px 4px -1px rgba(0, 0, 0, .04);--color-shadow-lg: 0 10px 25px -5px rgba(0, 0, 0, .1), 0 4px 10px -2px rgba(0, 0, 0, .04);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--transition: .18s ease;--font-ar: "Cairo", "Tajawal", system-ui, sans-serif;--font-en: "Inter", system-ui, -apple-system, sans-serif;--font-family: var(--font-ar)}html[data-theme=dark]{--color-text: #f1f5f9;--color-text-muted: #94a3b8;--color-bg: #0f172a;--color-surface: #1e293b;--color-surface-2: #334155;--color-border: #334155;--color-primary-light: rgba(16, 185, 129, .15)}html[dir=ltr]{--font-family: var(--font-en)}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{font-family:var(--font-family);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;transition:background-color .25s ease,color .25s ease}#app{min-height:100%;display:flex;justify-content:center;padding:16px}.app{width:100%;max-width:560px;display:flex;flex-direction:column;gap:16px;padding:20px 0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:8px 4px}.header-titles h1{margin:0 0 4px;font-size:26px;font-weight:700;letter-spacing:-.02em}.subtitle{margin:0;color:var(--color-text-muted);font-size:13px}.header-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.icon-btn,.lang-toggle{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-family:inherit;transition:all var(--transition);display:inline-flex;align-items:center;justify-content:center}.icon-btn{width:36px;height:36px;color:var(--color-text-muted);padding:0}.icon-btn:hover{color:var(--color-primary-dark);border-color:var(--color-primary);transform:translateY(-1px)}.icon-btn-sm{background:transparent;border:1px solid var(--color-border);width:24px;height:24px;border-radius:4px;color:var(--color-text-muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:14px;line-height:1}.icon-btn-sm:hover{color:var(--color-danger);border-color:var(--color-danger)}.lang-toggle{color:var(--color-primary-dark);padding:8px 12px;font-size:13px;font-weight:600;min-width:52px;height:36px}.lang-toggle:hover{border-color:var(--color-primary);transform:translateY(-1px)}.user-bar{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--color-surface-2);border-radius:var(--radius-md);font-size:13px}.user-icon{color:var(--color-primary)}.user-name{flex:1;font-weight:600;color:var(--color-text)}.link-btn{background:transparent;border:none;color:var(--color-text-muted);font-size:12px;font-family:inherit;cursor:pointer;font-weight:600;padding:4px 8px;border-radius:4px}.link-btn:hover{color:var(--color-danger);background:#ef444414}.auth-screen{padding:32px 0}.auth-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:28px 24px;box-shadow:var(--color-shadow-lg);display:flex;flex-direction:column;gap:18px}.auth-brand{text-align:center}.auth-logo{font-size:48px;display:block;margin-bottom:8px}.auth-brand h1{margin:0 0 4px;font-size:24px}.auth-tabs{display:flex;gap:4px;background:var(--color-surface-2);padding:4px;border-radius:var(--radius-md)}.auth-tab{flex:1;background:transparent;border:none;padding:10px;border-radius:7px;font-family:inherit;font-size:14px;font-weight:600;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition)}.auth-tab.is-active{background:var(--color-surface);color:var(--color-primary-dark);box-shadow:0 1px 2px #00000014}html[data-theme=dark] .auth-tab.is-active{background:var(--color-bg)}.auth-actions{display:flex;gap:6px;justify-content:center;padding-top:8px;border-top:1px solid var(--color-border)}.expense-form{background:var(--color-surface);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--color-shadow);display:grid;gap:12px}.field-row{display:grid;grid-template-columns:1fr 110px;gap:10px}.field{display:flex;flex-direction:column;gap:6px}.field-grow{min-width:0}.field label{font-size:12px;font-weight:600;color:var(--color-text-muted)}.field input{width:100%;padding:11px 13px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;font-family:inherit;background:var(--color-surface);color:var(--color-text);transition:all var(--transition);-webkit-appearance:none}.field input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.field input.has-error{border-color:var(--color-danger);background:#ef44440f}.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(72px,1fr));gap:6px}.cat-chip{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 4px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);cursor:pointer;font-family:inherit;font-size:11px;font-weight:500;color:var(--color-text-muted);transition:all var(--transition);--cat-color: var(--color-text-muted)}.cat-chip:hover{border-color:var(--cat-color);color:var(--color-text);transform:translateY(-2px)}.cat-chip.is-active{border-color:var(--cat-color);background:color-mix(in srgb,var(--cat-color) 12%,transparent);color:var(--cat-color);font-weight:600;box-shadow:0 0 0 3px color-mix(in srgb,var(--cat-color) 18%,transparent)}.cat-icon{font-size:20px;line-height:1}.cat-name{font-size:10px}.btn-primary{background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);padding:12px 18px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:all var(--transition);min-height:44px}.btn-primary:hover{background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-tiny{background:var(--color-primary);color:#fff;border:none;border-radius:6px;padding:6px 10px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:4px;transition:all var(--transition)}.btn-tiny:hover{background:var(--color-primary-dark)}.btn-tiny.ghost{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border)}.btn-tiny.ghost:hover{color:var(--color-text);border-color:var(--color-text-muted);background:transparent}.error-msg{margin:0;padding:10px 14px;background:#ef444414;color:var(--color-danger-dark);border-radius:var(--radius-md);font-size:13px;font-weight:600;border:1px solid rgba(239,68,68,.2)}.info-msg{margin:0;padding:8px 12px;background:var(--color-primary-light);color:var(--color-primary-dark);border-radius:var(--radius-md);font-size:13px;font-weight:600}html[data-theme=dark] .error-msg{color:#fca5a5}.quick-add{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#422006;border:none;border-radius:var(--radius-md);padding:12px 16px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:6px;justify-content:center;transition:all var(--transition);box-shadow:0 2px 8px #f59e0b40}.quick-add:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b59}.quick-add .currency{color:#422006b3;font-size:11px}.search-bar{position:relative;background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:0 12px;display:flex;align-items:center;gap:8px;transition:all var(--transition)}.search-bar:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.search-icon{color:var(--color-text-muted);display:flex}.search-bar input{flex:1;border:none;outline:none;background:transparent;padding:11px 0;font-size:14px;font-family:inherit;color:var(--color-text)}.stats-panel{background:var(--color-surface);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--color-shadow);display:grid;gap:14px}.filter-bar{display:flex;gap:4px;background:var(--color-surface-2);padding:4px;border-radius:var(--radius-md)}.filter-chip{flex:1;background:transparent;border:none;padding:8px;border-radius:7px;font-size:12px;font-weight:600;font-family:inherit;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition)}.filter-chip:hover{color:var(--color-text)}.filter-chip.is-active{background:var(--color-surface);color:var(--color-primary-dark);box-shadow:0 1px 2px #00000014}html[data-theme=dark] .filter-chip.is-active{background:var(--color-bg)}.limit-bar{position:relative;height:32px;background:var(--color-surface-2);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-border)}.limit-fill{position:absolute;top:0;right:0;bottom:0;background:var(--color-primary);transition:width .4s ease,background .3s ease;opacity:.4}html[dir=ltr] .limit-fill{right:auto;left:0}.limit-warn .limit-fill{background:#f59e0b;opacity:.5}.limit-over .limit-fill{background:var(--color-danger);opacity:.6}.limit-text{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;height:100%;padding:0 12px;font-size:12px;font-weight:700;color:var(--color-text);font-variant-numeric:tabular-nums}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.stat{display:flex;flex-direction:column;gap:4px;padding:10px 12px;background:var(--color-surface-2);border-radius:var(--radius-md)}.stat-label{font-size:10px;color:var(--color-text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.stat-value{font-size:15px;font-weight:700;color:var(--color-text);font-variant-numeric:tabular-nums;display:flex;align-items:baseline;gap:3px;flex-wrap:wrap}.insights{display:flex;flex-direction:column;gap:6px}.insight{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-md);font-size:13px;font-weight:500;border:1px solid}.insight-icon{font-size:18px;flex-shrink:0}.insight-warning{background:#f59e0b14;color:#92400e;border-color:#f59e0b33}.insight-positive{background:#10b98114;color:#065f46;border-color:#10b98133}.insight-info{background:#3b82f614;color:#1e40af;border-color:#3b82f633}.insight-danger{background:#ef444414;color:#991b1b;border-color:#ef444440;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.01)}}html[data-theme=dark] .insight-warning{color:#fbbf24}html[data-theme=dark] .insight-positive{color:#6ee7b7}html[data-theme=dark] .insight-info{color:#93c5fd}html[data-theme=dark] .insight-danger{color:#fca5a5}.breakdown-title{margin:0 0 8px;font-size:12px;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.breakdown-list{list-style:none;margin:0;padding:0;display:grid;gap:10px}.bd-row{display:grid;grid-template-columns:22px 1fr auto auto;align-items:center;gap:8px;font-size:13px}.bd-icon{font-size:16px;line-height:1}.bd-name{color:var(--color-text);font-weight:500}.bd-pct{color:var(--color-text-muted);font-size:11px;font-variant-numeric:tabular-nums}.bd-value{font-weight:700;color:var(--color-text);font-variant-numeric:tabular-nums}.bd-bar{height:5px;background:var(--color-surface-2);border-radius:3px;overflow:hidden;margin-top:4px}.bd-bar>span{display:block;height:100%;border-radius:3px;transition:width .35s ease}.chart-wrap{position:relative;height:150px;width:100%}.recurring-section,.recurring-suggest{display:flex;flex-direction:column;gap:8px}.recurring-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.recurring-item{display:grid;grid-template-columns:1fr auto auto auto;align-items:center;gap:10px;padding:8px 10px;background:var(--color-surface-2);border-radius:var(--radius-md);font-size:13px}.rec-name{font-weight:500}.rec-freq{color:var(--color-text-muted);font-size:11px;padding:2px 6px;background:var(--color-surface);border-radius:4px}.rec-amount{font-weight:700;font-variant-numeric:tabular-nums}.rec-amount .currency{color:var(--color-text-muted);font-size:10px}.suggest-row{display:grid;grid-template-columns:1fr auto auto auto auto;align-items:center;gap:8px;padding:8px 10px;background:var(--color-surface-2);border-radius:var(--radius-md);font-size:12px}.suggest-amount{font-weight:700;font-variant-numeric:tabular-nums}.suggest-freq{color:var(--color-text-muted);font-size:11px}.expense-list{background:var(--color-surface);border-radius:var(--radius-lg);padding:6px;box-shadow:var(--color-shadow);min-height:100px}.expense-list ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:3px}.empty{text-align:center;color:var(--color-text-muted);padding:36px 20px;font-size:14px;margin:0}.expense-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px;border-radius:var(--radius-md);transition:background var(--transition);animation:slideIn .22s ease}.expense-item:hover{background:var(--color-surface-2)}@keyframes slideIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.item-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.item-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:9px;font-size:17px;flex-shrink:0}.item-main{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.item-name{font-weight:600;font-size:13px;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-meta{font-size:10px;color:var(--color-text-muted);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-end{display:flex;flex-direction:column;align-items:flex-end;gap:1px;flex-shrink:0}.item-amount{font-variant-numeric:tabular-nums;font-weight:700;font-size:13px;color:var(--color-primary-dark);white-space:nowrap}html[data-theme=dark] .item-amount{color:var(--color-primary)}.item-date{font-size:10px;color:var(--color-text-muted)}.currency{font-size:10px;color:var(--color-text-muted);font-weight:500}.btn-delete{background:transparent;border:1px solid transparent;color:var(--color-text-muted);padding:6px;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);flex-shrink:0}.btn-delete:hover{color:var(--color-danger);background:#ef444414;border-color:#ef444433}.action-row{display:flex;gap:8px}.action-btn{flex:1;background:var(--color-surface);color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:10px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:6px;transition:all var(--transition)}.action-btn:hover{color:var(--color-primary-dark);border-color:var(--color-primary)}.total-bar{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;border-radius:var(--radius-lg);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--color-shadow-lg)}.total-label{font-size:15px;font-weight:600;opacity:.95}.total-value{font-size:20px;font-weight:700;font-variant-numeric:tabular-nums}.total-value .currency{color:#ffffffd9;font-size:12px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:16px;z-index:100;animation:fadeIn .18s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-surface);border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:85vh;overflow-y:auto;box-shadow:var(--color-shadow-lg);animation:slideUp .22s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-border);position:sticky;top:0;background:var(--color-surface);z-index:1}.modal-header h2{margin:0;font-size:16px}.modal-section{padding:16px 20px;border-bottom:1px solid var(--color-border)}.modal-section:last-child{border-bottom:none}.modal-section h3{margin:0 0 10px;font-size:13px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.recurring-form,.limits-form{display:grid;gap:8px;grid-template-columns:1fr}.recurring-form{grid-template-columns:2fr 1fr 1fr auto}.limits-form label{display:grid;grid-template-columns:80px 1fr;align-items:center;gap:8px;font-size:13px}.recurring-form input,.recurring-form select,.limits-form input{padding:8px 10px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-family:inherit;font-size:13px;background:var(--color-surface);color:var(--color-text)}.recurring-form input:focus,.recurring-form select:focus,.limits-form input:focus{outline:none;border-color:var(--color-primary)}.data-actions{display:flex;flex-wrap:wrap;gap:6px}.data-actions .btn-tiny{cursor:pointer}.receipt-input{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:6px;padding:16px 20px;border-bottom:1px solid var(--color-border)}.receipt-input input,.receipt-input select{padding:8px 10px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-family:inherit;font-size:13px;background:var(--color-surface);color:var(--color-text)}.receipt-items{list-style:none;margin:0;padding:0}.receipt-items li{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:10px;padding:10px 20px;border-bottom:1px solid var(--color-border);font-size:13px}.receipt-total{padding:14px 20px;font-size:14px;font-weight:600;border-top:2px solid var(--color-border);display:flex;justify-content:space-between}.receipt-total strong{color:var(--color-primary-dark);font-size:18px}.modal .btn-primary{margin:14px 20px 20px;width:calc(100% - 40px)}@media (max-width: 480px){.app{padding:8px 0;gap:12px}.header-titles h1{font-size:22px}.expense-form,.total-bar,.stats-panel{border-radius:var(--radius-md)}.field-row,.stats-grid{grid-template-columns:1fr}.stat{flex-direction:row;justify-content:space-between;align-items:center}.recurring-form,.receipt-input{grid-template-columns:1fr}.suggest-row{grid-template-columns:1fr;gap:4px}.bd-row{grid-template-columns:20px 1fr auto auto;font-size:12px}}.home-header{padding:20px 16px;display:flex;justify-content:space-between;align-items:flex-start}.total-display{font-size:32px;font-weight:700;color:var(--color-primary);margin-top:4px}.total-label{color:var(--color-text-muted);font-size:13px;margin-top:2px}.quick-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:0 16px 12px}.qa-btn{background:var(--color-surface-2);border:none;padding:12px 8px;border-radius:var(--radius-md);font-size:12px;cursor:pointer;color:var(--color-text);font-family:inherit}.qa-voice{background:linear-gradient(135deg,#ec4899,#f43f5e);color:#fff}.home-section,.stats-section{padding:16px}.home-section h2,.stats-section h2{font-size:16px;margin-bottom:12px;font-weight:700}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:8px}.section-header h2{margin:0}.filter-pills{display:flex;gap:6px;flex-wrap:wrap}.filter-pill{background:var(--color-surface-2);border:none;padding:6px 12px;border-radius:999px;font-size:12px;cursor:pointer;color:var(--color-text);font-family:inherit}.filter-pill.active{background:var(--color-primary);color:#fff}.search-input{width:100%;padding:10px 14px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);font-size:14px;margin-bottom:12px;font-family:inherit;box-sizing:border-box}.template-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}.tpl-chip{background:var(--color-surface-2);border:1px solid var(--color-border);padding:8px 14px;border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;display:flex;flex-direction:column;align-items:center;font-family:inherit;color:var(--color-text)}.tpl-amt{color:var(--color-primary);font-weight:600;font-size:13px}.split-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.split-stat{background:var(--color-surface-2);padding:12px;border-radius:var(--radius-md);text-align:center}.split-label{font-size:11px;color:var(--color-text-muted);margin-bottom:4px}.split-val{font-weight:700;font-size:16px}.split-val.positive{color:var(--color-primary)}.split-val.negative{color:var(--color-danger)}.insight-list{display:flex;flex-direction:column;gap:8px}.insight{padding:10px 14px;border-radius:var(--radius-md);display:flex;align-items:center;gap:10px;font-size:14px}.insight-good{background:#22c55e1a;color:#16a34a}.insight-warn{background:#f59e0b1a;color:#d97706}.insight-info{background:#3b82f61a;color:#2563eb}html[data-theme=dark] .insight-good{color:#4ade80}html[data-theme=dark] .insight-warn{color:#fbbf24}html[data-theme=dark] .insight-info{color:#60a5fa}.insight-icon{font-size:20px}.recurring-list{display:flex;flex-direction:column;gap:8px}.recurring-item{display:flex;justify-content:space-between;padding:10px 12px;background:var(--color-surface-2);border-radius:var(--radius-md);font-size:13px}.expense-row{display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid var(--color-border)}.expense-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.expense-body{flex:1;min-width:0}.expense-name{font-weight:600;font-size:14px}.expense-note{color:var(--color-text-muted);font-size:12px;margin-inline-start:6px}.expense-meta{font-size:11px;color:var(--color-text-muted);display:flex;gap:6px;margin-top:2px;align-items:center;flex-wrap:wrap}.expense-amount{font-weight:700;color:var(--color-primary);font-size:15px}.expense-actions{display:flex;gap:4px}.expense-actions button{background:none;border:none;font-size:16px;cursor:pointer;padding:4px;opacity:.6}.expense-actions button:hover{opacity:1}.tag-pill{background:var(--color-primary-light);color:var(--color-primary-dark);padding:2px 8px;border-radius:999px;font-size:10px}html[data-theme=dark] .tag-pill{background:#10b98133;color:#4ade80}.empty-state{text-align:center;padding:40px 16px;color:var(--color-text-muted)}.empty-icon{font-size:48px;margin-bottom:8px}.empty-hint{font-size:12px;margin-top:4px}.add-form{padding:16px;display:flex;flex-direction:column;gap:12px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:12px;color:var(--color-text-muted);font-weight:600}.form-group input,.form-group select,.form-group textarea{padding:12px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);font-size:14px;font-family:inherit}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary)}.form-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.btn-primary,.btn-secondary,.btn-ghost,.btn-danger{padding:10px 16px;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;border:none}.btn-primary{background:var(--color-primary);color:#fff;flex:1}.btn-secondary{background:var(--color-surface-2);color:var(--color-text)}.btn-ghost{background:transparent;color:var(--color-text-muted)}.btn-danger{background:var(--color-danger);color:#fff}.btn-sm{padding:6px 12px;font-size:12px}.cat-chips{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.cat-chip{background:var(--color-surface-2);border:2px solid transparent;padding:10px 4px;border-radius:var(--radius-md);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;font-family:inherit;color:var(--color-text)}.cat-chip.active{border-color:var(--color-primary);background:var(--color-primary-light)}.cat-icon{font-size:24px}.cat-label{font-size:11px}.tag-chips{display:flex;flex-wrap:wrap;gap:6px}.tag-chip{cursor:pointer}.tag-chip input{display:none}.tag-chip span{padding:4px 12px;border-radius:999px;color:#fff;font-size:12px;display:inline-block}.tag-chip input:checked+span{box-shadow:0 0 0 2px var(--color-primary)}.location-pill{background:var(--color-surface-2);padding:6px 12px;border-radius:999px;font-size:12px;display:inline-block;margin-top:6px}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:0 16px 16px}.stat-card{background:var(--color-surface-2);padding:14px;border-radius:var(--radius-md)}.stat-card.stat-primary{background:var(--color-primary);color:#fff}.stat-card.stat-warn{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.stat-label{font-size:11px;opacity:.8;margin-bottom:4px}.stat-value{font-size:22px;font-weight:700}.compare-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.compare-card{background:var(--color-surface-2);padding:12px;border-radius:var(--radius-md)}.compare-label{font-size:11px;color:var(--color-text-muted);margin-bottom:4px}.compare-value{font-size:16px;font-weight:700}.compare-value.up{color:var(--color-danger)}.compare-value.down{color:var(--color-primary)}.compare-value small{font-size:11px;opacity:.8;margin-inline-start:4px}.bar-chart{display:flex;align-items:flex-end;justify-content:space-between;gap:4px;height:120px;padding:8px 0}.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}.bar-fill{width:100%;background:var(--color-primary);border-radius:4px 4px 0 0;min-height:2px}.bar-label{font-size:10px;color:var(--color-text-muted);margin-top:4px}.bar-val{font-size:9px;color:var(--color-text-muted)}.trends-svg{width:100%;height:auto}.trends-grid{stroke:var(--color-border);stroke-dasharray:2 2}.trends-label{font-size:10px;fill:var(--color-text-muted)}.cat-donut{display:flex;flex-direction:column;align-items:center;gap:12px}.donut-svg{width:180px;height:180px}.donut-center{font-size:22px;font-weight:700;fill:var(--color-text)}.donut-label{font-size:11px;fill:var(--color-text-muted)}.donut-empty{padding:40px;color:var(--color-text-muted)}.cat-legend{width:100%;display:flex;flex-direction:column;gap:6px}.legend-item{display:flex;align-items:center;gap:8px;font-size:13px;padding:4px 0}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-icon{font-size:16px}.legend-label{flex:1}.legend-val{font-weight:600}.heatmap{display:flex;gap:2px;overflow-x:auto;padding:8px 0}.hm-week{display:flex;flex-direction:column;gap:2px}.hm-cell{width:10px;height:10px;border-radius:2px;background:var(--color-surface-2)}.hm-l1{background:#c6f6d5}.hm-l2{background:#68d391}.hm-l3{background:#38a169}.hm-l4{background:#22543d}html[data-theme=dark] .hm-l1{background:#1e3a2e}html[data-theme=dark] .hm-l2{background:#2d5a3d}html[data-theme=dark] .hm-l3{background:#4ade80}html[data-theme=dark] .hm-l4{background:#86efac}.heatmap-legend{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--color-text-muted);margin-top:8px}.heatmap-legend .hm-cell{width:12px;height:12px}.goal-mini{margin-bottom:10px}.goal-mini-head{display:flex;justify-content:space-between;font-size:13px;margin-bottom:4px}.goal-progress{height:8px;background:var(--color-surface-2);border-radius:4px;overflow:hidden}.goal-fill{height:100%;transition:width .3s}.goal-card{background:var(--color-surface-2);padding:14px;border-radius:var(--radius-md);margin-bottom:10px}.goal-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}.goal-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.goal-info{flex:1}.goal-name{font-weight:600;font-size:15px}.goal-amount{font-size:13px;color:var(--color-text-muted)}.goal-days{font-size:11px;color:var(--color-text-muted)}.goal-status{padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600}.goal-status-done{background:var(--color-primary);color:#fff}.goal-status-good{background:#22c55e33;color:#16a34a}.goal-status-mid{background:#f59e0b33;color:#d97706}.goal-status-low{background:var(--color-surface);color:var(--color-text-muted)}.goal-actions{display:flex;gap:6px;margin-top:8px}.settings-list{display:flex;flex-direction:column;gap:1px;background:var(--color-border)}.settings-item{background:var(--color-surface);padding:14px 16px;display:flex;flex-direction:column;gap:8px}.settings-item label{font-size:13px;font-weight:600}.settings-item select{padding:8px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-family:inherit}.theme-toggle,.ws-pills{display:flex;gap:6px;flex-wrap:wrap}.theme-pill{background:var(--color-surface-2);border:1px solid var(--color-border);padding:6px 12px;border-radius:999px;font-size:12px;cursor:pointer;font-family:inherit;color:var(--color-text)}.theme-pill.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-row{display:flex;gap:6px;flex-wrap:wrap}.panel-header{padding:16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--color-border)}.panel-header h1{font-size:20px;font-weight:700;flex:1}.back-btn{background:none;border:none;font-size:14px;color:var(--color-primary);cursor:pointer;font-family:inherit;padding:4px 8px}.ws-list,.tag-list,.people-list{padding:16px;display:flex;flex-direction:column;gap:8px}.ws-row,.tag-row,.person-row,.tpl-row,.asset-row,.debt-row,.limit-row,.recurring-card,.balance-row{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--color-surface-2);border-radius:var(--radius-md);font-size:13px;gap:8px}.recurring-card strong{font-size:14px}.networth-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:16px}.nw-card{padding:14px;border-radius:var(--radius-md);text-align:center}.nw-assets{background:#22c55e1a;color:#16a34a}.nw-debts{background:#ef44441a;color:#dc2626}.nw-net{background:var(--color-primary);color:#fff}.nw-label{font-size:11px;opacity:.8;margin-bottom:4px}.nw-val{font-size:16px;font-weight:700}.receipt-upload{padding:20px;text-align:center}.receipt-upload .hint{font-size:12px;color:var(--color-text-muted);margin-top:8px}.receipt-result{padding:16px}.receipt-progress{padding:20px;text-align:center}.receipt-item{display:flex;justify-content:space-between;padding:10px;background:var(--color-surface-2);border-radius:var(--radius-md);margin-bottom:6px;font-size:14px}.news-list{padding:16px;display:flex;flex-direction:column;gap:8px}.news-empty{padding:40px;text-align:center;color:var(--color-text-muted)}.news-item{display:block;padding:12px;background:var(--color-surface-2);border-radius:var(--radius-md);text-decoration:none;color:var(--color-text)}.news-title{font-weight:600;font-size:14px;margin-bottom:4px;line-height:1.4}.news-meta{font-size:11px;color:var(--color-text-muted)}.ai-suggest-row{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--color-surface-2);border-radius:var(--radius-md);margin-bottom:6px;font-size:13px}.ai-cat{color:var(--color-primary);font-weight:600}.forecast{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.forecast-month{background:var(--color-surface-2);padding:14px;border-radius:var(--radius-md);text-align:center}.fc-val{font-size:18px;font-weight:700;color:var(--color-primary)}.fc-label{font-size:11px;color:var(--color-text-muted);margin-top:4px}.hint{font-size:12px;color:var(--color-text-muted);padding:8px 16px}.share-preview{padding:20px;background:var(--color-surface-2);margin:16px;border-radius:var(--radius-md)}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#10b981,#059669)}.auth-card{background:var(--color-surface);padding:32px 24px;border-radius:20px;width:100%;max-width:400px;box-shadow:0 20px 60px #0003}.auth-logo{font-size:48px;text-align:center;margin-bottom:12px}.auth-card h1{text-align:center;font-size:24px;margin-bottom:4px}.auth-tag{text-align:center;color:var(--color-text-muted);font-size:13px;margin-bottom:24px}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-form input{padding:14px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:15px;font-family:inherit;background:var(--color-bg);color:var(--color-text)}.auth-submit{padding:14px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:16px;font-weight:700;cursor:pointer;font-family:inherit}.auth-error{color:var(--color-danger);font-size:13px;text-align:center;min-height:18px}.auth-switch{background:none;border:none;color:var(--color-primary);font-size:13px;cursor:pointer;margin-top:16px;display:block;width:100%;font-family:inherit}.auth-hint{text-align:center;color:var(--color-text-muted);font-size:11px;margin-top:12px}.app-header{position:sticky;top:0;background:var(--color-surface);padding:12px 16px;display:flex;justify-content:space-between;align-items:center;z-index:10;border-bottom:1px solid var(--color-border)}.app-title{font-weight:700;font-size:16px}.header-actions{display:flex;gap:4px}.icon-btn{background:var(--color-surface-2);border:none;width:36px;height:36px;border-radius:50%;font-size:14px;cursor:pointer;font-family:inherit;color:var(--color-text)}#main{padding:0 0 80px;min-height:calc(100vh - 60px)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--color-surface);border-top:1px solid var(--color-border);display:flex;justify-content:space-around;padding:8px 0;z-index:10}.nav-item{background:none;border:none;padding:6px;font-size:11px;cursor:pointer;color:var(--color-text-muted);font-family:inherit;flex:1;line-height:1.4}.nav-item.active{color:var(--color-primary);font-weight:700}
