.ui-preview-page{min-height:100vh;background:#f7f7f4;color:#171a1f;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;padding:24px}.ui-preview-page *{box-sizing:border-box}.ui-preview-header{position:sticky;top:16px;z-index:10;max-width:1180px;min-height:64px;margin:0 auto 44px;padding:10px 12px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:18px;background:#fffffcdb;border:1px solid #e5e1d8;border-radius:18px;box-shadow:0 16px 40px #2c261c14;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.ui-preview-logo{display:inline-flex;align-items:center;gap:10px;color:inherit;text-decoration:none;font-size:15px}.ui-preview-logo span,.ui-preview-empty-mark{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;background:#1f2937;color:#fffdfa;font-size:11px;font-weight:800}.ui-preview-logo strong{font-weight:760}.ui-preview-plan-picker{min-height:40px;padding:0 16px;border:1px solid #d9d3c8;border-radius:999px;background:#fffdfa;color:#2b3139;font:inherit;font-size:13px;font-weight:650}.ui-preview-nav{display:flex;justify-content:flex-end;gap:6px}.ui-preview-nav a{color:#68707a;text-decoration:none;font-size:13px;font-weight:650;padding:9px 12px;border-radius:10px}.ui-preview-nav a:hover{background:#f0eee8;color:#171a1f}.ui-preview-hero,.ui-preview-section{max-width:1180px;margin:0 auto}.ui-preview-hero{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:32px;align-items:end;padding:24px 0 36px}.ui-preview-hero-copy{max-width:760px}.ui-preview-eyebrow,.ui-preview-section-title span,.ui-preview-muted,.ui-preview-field span,.ui-preview-advice-card span,.ui-preview-metric-card span{color:#747a82;font-size:12px;font-weight:720}.ui-preview-eyebrow,.ui-preview-section-title span{text-transform:uppercase;letter-spacing:.08em}.ui-preview-hero h1{margin:0 0 16px;max-width:720px;color:#171a1f;font-size:clamp(38px,6vw,72px);line-height:.98;letter-spacing:-.045em;font-weight:780}.ui-preview-hero p{margin:0;max-width:680px;color:#59616b;font-size:17px;line-height:1.65}.ui-preview-hero-panel{display:flex;align-items:flex-start;gap:12px;padding:18px;background:#fffdfa;border:1px solid #e5e1d8;border-radius:16px;box-shadow:0 14px 32px #2c261c12}.ui-preview-hero-panel strong,.ui-preview-hero-panel span{display:block}.ui-preview-hero-panel strong{font-size:14px;margin-bottom:4px}.ui-preview-hero-panel span{color:#747a82;font-size:13px;line-height:1.45}.ui-preview-status-dot{width:10px;height:10px;margin-top:5px;border-radius:99px;background:#2e7d5f;box-shadow:0 0 0 4px #2e7d5f1f}.ui-preview-section{padding:28px 0}.ui-preview-section-title{margin-bottom:14px}.ui-preview-section-title h2{margin:5px 0 0;color:#171a1f;font-size:22px;line-height:1.2;letter-spacing:-.02em}.ui-preview-surface,.ui-preview-card,.ui-preview-dashboard,.ui-preview-dream-card,.ui-preview-advice-card,.ui-preview-mobile-screen{background:#fffdfa;border:1px solid #e5e1d8;border-radius:18px;box-shadow:0 1px 2px #1f29370a,0 18px 44px #2c261c0f}.ui-preview-button-row{display:flex;flex-wrap:wrap;gap:10px;padding:18px}.ui-preview-btn{min-height:40px;padding:0 16px;border-radius:10px;border:1px solid transparent;font:inherit;font-size:13px;font-weight:720;cursor:pointer}.ui-preview-btn-primary{background:#1f2937;color:#fffdfa}.ui-preview-btn-secondary{background:#fffdfa;color:#1f2937;border-color:#d9d3c8}.ui-preview-btn-ghost{background:transparent;color:#4f5965}.ui-preview-btn-danger{background:#fff7f5;color:#b42318;border-color:#f2c8c1}.ui-preview-btn:disabled{cursor:not-allowed;background:#ede9e0;color:#a19a8f}.ui-preview-card-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}.ui-preview-card{min-height:168px;padding:18px}.ui-preview-card p,.ui-preview-empty-card p,.ui-preview-advice-card p,.ui-preview-mobile-card p{margin:0;color:#59616b;font-size:13px;line-height:1.55}.ui-preview-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.ui-preview-card-title{font-size:14px;font-weight:760}.ui-preview-pill{display:inline-flex;align-items:center;min-height:24px;padding:0 9px;border-radius:999px;background:#f0eee8;color:#59616b;font-size:11px;font-weight:720;white-space:nowrap}.ui-preview-pill-blue{background:#edf4f7;color:#226172}.ui-preview-pill-amber{background:#fff3d8;color:#946200}.ui-preview-pill-green{background:#e9f5ee;color:#2e7d5f}.ui-preview-data-card strong,.ui-preview-metric-card strong,.ui-preview-mobile-card strong{display:block;color:#171a1f;font-size:30px;line-height:1;letter-spacing:-.03em;margin:12px 0}.ui-preview-progress{height:8px;overflow:hidden;border-radius:999px;background:#ece8df}.ui-preview-progress span{display:block;height:100%;border-radius:inherit;background:#2e7d5f}.ui-preview-insight-card{border-left:3px solid #226172}.ui-preview-risk-card{border-left:3px solid #d59b2d}.ui-preview-empty-card{display:flex;flex-direction:column;align-items:flex-start;gap:12px;background:#fbfaf6}.ui-preview-two-column{display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);gap:20px}.ui-preview-form{display:grid;gap:14px;padding:18px}.ui-preview-field{display:grid;gap:7px}.ui-preview-field input,.ui-preview-field select,.ui-preview-field textarea,.ui-preview-amount-input{width:100%;border:1px solid #d9d3c8;border-radius:12px;background:#fffdfa;color:#171a1f;font:inherit;font-size:14px}.ui-preview-field input,.ui-preview-field select,.ui-preview-field textarea{padding:11px 12px}.ui-preview-field textarea{resize:vertical}.ui-preview-field input:focus,.ui-preview-field select:focus,.ui-preview-field textarea:focus,.ui-preview-amount-input:focus-within{outline:none;border-color:#587082;box-shadow:0 0 0 3px #5870821f}.ui-preview-check,.ui-preview-switch-row{min-height:44px;display:flex;align-items:center;justify-content:space-between;gap:12px;color:#2b3139;font-size:14px;font-weight:650}.ui-preview-check{justify-content:flex-start}.ui-preview-check input{width:17px;height:17px;accent-color:#1f2937}.ui-preview-switch{width:44px;height:24px;padding:3px;border-radius:999px;background:#1f2937}.ui-preview-switch span{display:block;width:18px;height:18px;margin-left:auto;border-radius:50%;background:#fffdfa}.ui-preview-amount-input{min-height:44px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;padding:0 12px}.ui-preview-amount-input input{border:0;padding:0;background:transparent;font-weight:720}.ui-preview-amount-input input:focus{outline:none}.ui-preview-amount-input span,.ui-preview-amount-input em{color:#747a82;font-size:13px;font-style:normal;font-weight:720}.ui-preview-metric-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.ui-preview-metric-card{min-height:122px;padding:16px;border:1px solid #e5e1d8;border-radius:16px;background:#fffdfa}.ui-preview-metric-card:last-child{grid-column:1 / -1}.ui-preview-trend-positive,.ui-preview-trend-neutral{font-style:normal;font-size:12px;font-weight:720}.ui-preview-trend-positive{color:#2e7d5f}.ui-preview-trend-neutral{color:#68707a}.ui-preview-dashboard{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:0;overflow:hidden}.ui-preview-dashboard-main{padding:24px}.ui-preview-dashboard-top{display:flex;justify-content:space-between;gap:18px;margin-bottom:28px}.ui-preview-dashboard h2{margin:6px 0 0;font-size:clamp(28px,4vw,46px);line-height:1;letter-spacing:-.04em}.ui-preview-dashboard-chart{height:190px;display:flex;align-items:end;gap:12px;padding:14px;border-radius:14px;background:#f5f2eb}.ui-preview-dashboard-chart span{flex:1;min-width:24px;border-radius:8px 8px 3px 3px;background:#6f8793}.ui-preview-dashboard-side{display:grid;border-left:1px solid #e5e1d8;background:#fbfaf6}.ui-preview-dashboard-side div{padding:22px;border-bottom:1px solid #e5e1d8}.ui-preview-dashboard-side div:last-child{border-bottom:0}.ui-preview-dashboard-side span{display:block;color:#747a82;font-size:12px;font-weight:720;margin-bottom:8px}.ui-preview-dashboard-side strong{font-size:22px;letter-spacing:-.02em}.ui-preview-dream-list{display:grid;gap:12px}.ui-preview-dream-card{padding:18px}.ui-preview-dream-card dl{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:0}.ui-preview-dream-card div{min-width:0}.ui-preview-dream-card dt{color:#747a82;font-size:12px;font-weight:720;margin-bottom:4px}.ui-preview-dream-card dd{margin:0;color:#171a1f;font-size:14px;font-weight:760}.ui-preview-advice-card{padding:20px;display:grid;gap:18px;border-left:3px solid #226172}.ui-preview-advice-card div{padding-bottom:18px;border-bottom:1px solid #eeeae2}.ui-preview-advice-card div:last-child{padding-bottom:0;border-bottom:0}.ui-preview-advice-card p{margin-top:6px}.ui-preview-mobile-shell{display:flex;justify-content:center;padding:24px;border:1px solid #e5e1d8;border-radius:22px;background:#ebe7de}.ui-preview-mobile-screen{position:relative;width:360px;min-height:640px;padding:18px 16px 86px;border-radius:34px;overflow:hidden}.ui-preview-mobile-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;font-weight:780}.ui-preview-icon-button{width:34px;height:34px;border:1px solid #e5e1d8;border-radius:10px;background:#fffdfa;color:#59616b}.ui-preview-mobile-card{padding:16px;margin-bottom:12px;border:1px solid #e5e1d8;border-radius:16px;background:#fbfaf6}.ui-preview-mobile-card strong{font-size:26px}.ui-preview-mobile-nav{position:absolute;left:16px;right:16px;bottom:16px;display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:8px;border:1px solid #e5e1d8;border-radius:18px;background:#fffdfae6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.ui-preview-mobile-nav a{color:#68707a;text-decoration:none;text-align:center;font-size:11px;font-weight:720;padding:9px 4px;border-radius:11px}.ui-preview-mobile-nav a:first-child{background:#1f2937;color:#fffdfa}@media (max-width: 980px){.ui-preview-header{grid-template-columns:1fr;position:static}.ui-preview-nav{justify-content:flex-start;overflow-x:auto}.ui-preview-hero,.ui-preview-two-column,.ui-preview-dashboard{grid-template-columns:1fr}.ui-preview-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.ui-preview-dashboard-side{grid-template-columns:repeat(3,1fr);border-left:0;border-top:1px solid #e5e1d8}.ui-preview-dashboard-side div{border-bottom:0;border-right:1px solid #e5e1d8}}@media (max-width: 640px){.ui-preview-page{padding:14px}.ui-preview-hero{padding-top:10px}.ui-preview-hero h1{font-size:40px}.ui-preview-card-grid,.ui-preview-metric-grid,.ui-preview-dream-card dl,.ui-preview-dashboard-side{grid-template-columns:1fr}.ui-preview-button-row{display:grid;grid-template-columns:1fr}.ui-preview-dashboard-top{flex-direction:column}.ui-preview-mobile-shell{padding:12px}.ui-preview-mobile-screen{width:100%;min-height:620px}}:root{--bg: #ffffff;--fg: #111827;--card: #ffffff;--border: #e5e7eb;--border2: #d1d5db;--primary: #111827;--primary-hover: #000000;--muted: #6b7280;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--ai-accent: #4f46e5;--blue: #3b82f6;--blue-soft: rgba(59, 130, 246, .1);--radius: 10px;--radius-lg: 20px;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06)}body[data-theme=default]{--bg: #ffffff;--fg: #111827;--card: #ffffff;--border: #e5e7eb;--border2: #d1d5db;--primary: #111827;--primary-hover: #000000;--muted: #6b7280;--ai-accent: #4f46e5}body[data-theme=blue]{--bg: #ffffff;--fg: #0f172a;--card: #ffffff;--border: #e2e8f0;--border2: #cbd5e1;--primary: #2563eb;--primary-hover: #1d4ed8;--muted: #64748b;--ai-accent: #3b82f6}body[data-theme=linear]{--bg: #ffffff;--fg: #000000;--card: #ffffff;--border: #e2e2e3;--border2: #cfcfd0;--primary: #000000;--primary-hover: #1a1a1a;--muted: #8a8a8a;--ai-accent: #5e5e5e}body[data-theme=supabase]{--bg: #1c1c1c;--fg: #ededed;--card: #2e2e2e;--border: #3e3e3e;--border2: #4e4e4e;--primary: #3ecf8e;--primary-hover: #34b27b;--muted: #888888;--success: #3ecf8e;--ai-accent: #3ecf8e}body[data-theme=vercel]{--bg: #000000;--fg: #ffffff;--card: #111111;--border: #333333;--border2: #444444;--primary: #ffffff;--primary-hover: #eaeaea;--muted: #888888;--ai-accent: #ffffff}body[data-theme=modern]{--bg: #fafafa;--fg: #171717;--card: #ffffff;--border: #e4e4e7;--border2: #d4d4d8;--primary: #171717;--primary-hover: #000000;--muted: #71717a;--ai-accent: #a1a1aa}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,sans-serif;background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;line-height:1.5}.theme-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:12px}.theme-card-option{background:var(--bg);border:2px solid var(--border);border-radius:16px;padding:16px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:12px;text-align:left}.theme-card-option:hover{border-color:var(--primary);transform:translateY(-2px)}.theme-card-option.active{border-color:var(--primary);background:var(--bg2);box-shadow:0 4px 12px #0000000d}.theme-card-info .name{display:block;font-size:14px;font-weight:800;color:var(--fg);margin-bottom:2px}.theme-card-info .desc{display:block;font-size:11px;color:var(--muted);font-weight:500}.theme-preview-dots{display:flex;gap:6px}.theme-dot{width:14px;height:14px;border-radius:50%;border:1px solid rgba(0,0,0,.05)}@media (max-width: 768px){.theme-grid{grid-template-columns:1fr}}.app input,.app select,.app textarea,.modal input,.modal select,.settings-auth-box input{font-family:inherit;outline:none;border:1px solid var(--border2);background:var(--bg);color:var(--text);border-radius:var(--radius);padding:10px 14px;transition:all .2s;font-size:14px}.app input:focus,.app select:focus,.modal input:focus,.modal select:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft)}.app button,.modal button{font-family:inherit;transition:all .2s;cursor:pointer;border:none;outline:none}.landing-page{min-height:100vh;overflow-x:hidden;background:#f8fafc;color:#0f172a;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.landing-page *{box-sizing:border-box}.landing-nav{position:sticky;top:0;z-index:1000;display:flex;justify-content:center;padding:14px 20px;background:#f8fafcdb;border-bottom:1px solid rgba(229,231,235,.9);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.landing-nav-inner{width:100%;max-width:1180px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:24px}.landing-logo{display:inline-flex;align-items:center;gap:10px;color:#0f172a;font-size:16px;font-weight:820;letter-spacing:-.01em;text-decoration:none;white-space:nowrap}.landing-logo-mark{width:34px;height:34px;border-radius:11px;display:inline-flex;align-items:center;justify-content:center;background:#0f172a;color:#fff;font-size:11px;font-weight:850;letter-spacing:.04em}.landing-nav-menu{display:flex;justify-content:center;align-items:center;gap:8px;min-width:0}.landing-nav-menu a,.landing-link{color:#64748b;text-decoration:none;font-size:13px;font-weight:650;padding:9px 11px;border-radius:10px;transition:color .18s,background .18s;white-space:nowrap}.landing-nav-menu a:hover,.landing-link:hover{color:#0f172a;background:#eef2f7}.landing-nav-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px}.landing-btn-primary,.landing-btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:12px;text-decoration:none;font-weight:760;transition:transform .18s,background .18s,border-color .18s,box-shadow .18s;white-space:nowrap}.landing-btn-primary{background:#2563eb;color:#fff;border:1px solid #2563eb;box-shadow:0 10px 24px #2563eb33}.landing-btn-primary:hover{background:#1d4ed8;border-color:#1d4ed8;transform:translateY(-1px);box-shadow:0 14px 30px #2563eb3d}.landing-btn-ghost{background:#ffffff14;color:#dbeafe;border:1px solid rgba(219,234,254,.24)}.landing-btn-ghost:hover{background:#ffffff24;color:#fff;border-color:#ffffff5c;transform:translateY(-1px)}.landing-btn-small{min-height:38px;padding:0 14px;font-size:13px}.landing-btn-large{min-height:50px;padding:0 22px;font-size:15px}.landing-hero{max-width:1180px;min-height:calc(100vh - 118px);margin:24px auto 0;padding:72px 26px 72px 48px;display:grid;grid-template-columns:minmax(0,.88fr) minmax(500px,1.12fr);align-items:center;gap:48px;border-radius:36px;background:radial-gradient(circle at 80% 16%,rgba(37,99,235,.18),transparent 32%),linear-gradient(135deg,#07111f,#0f172a 58%,#182235);color:#fff;box-shadow:0 30px 90px #0f172a3d}.landing-hero-content{text-align:left;min-width:0}.landing-hero-badge,.landing-section-kicker,.landing-section-head span{display:inline-flex;align-items:center;width:-moz-fit-content;width:fit-content;min-height:28px;padding:0 10px;border-radius:999px;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.landing-hero-badge{margin-bottom:18px;color:#bfdbfe;background:#2563eb29;border:1px solid rgba(147,197,253,.24)}.landing-hero-title{max-width:650px;margin:0 0 20px;font-size:clamp(48px,6vw,76px);line-height:.98;letter-spacing:-.055em;font-weight:850;color:#fff}.landing-hero-subtitle{max-width:620px;margin:0 0 34px;color:#cbd5e1;font-size:18px;line-height:1.65;font-weight:450}.landing-hero-actions{display:flex;align-items:center;gap:12px}.landing-product-frame{min-width:0;padding:14px;border-radius:28px;background:#ffffff14;border:1px solid rgba(255,255,255,.16);box-shadow:inset 0 1px #ffffff14,0 30px 80px #00000040}.landing-product-window{overflow:hidden;border-radius:22px;background:#fff;color:#0f172a;border:1px solid rgba(226,232,240,.92);box-shadow:0 18px 46px #0000002e}.landing-product-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 20px;border-bottom:1px solid #e5e7eb;background:#f8fafc}.landing-product-topbar span,.landing-product-label{display:block;color:#64748b;font-size:11px;font-weight:780;text-transform:uppercase;letter-spacing:.06em}.landing-product-topbar strong{display:block;margin-top:4px;color:#0f172a;font-size:18px;letter-spacing:-.02em}.landing-product-plan{min-height:26px;padding:6px 10px;border-radius:999px;background:#eff6ff;color:#1d4ed8!important;border:1px solid #dbeafe;white-space:nowrap}.landing-product-layout{display:grid;grid-template-columns:124px minmax(0,1fr);min-height:430px}.landing-product-sidebar{display:flex;flex-direction:column;gap:8px;padding:18px 14px;border-right:1px solid #e5e7eb;background:#f8fafc;color:#64748b;font-size:12px;font-weight:720}.landing-product-sidebar span{padding:9px 10px;border-radius:10px}.landing-product-nav-active{color:#0f172a;background:#fff;border:1px solid #e5e7eb;box-shadow:0 1px 2px #0f172a0a}.landing-product-main{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(0,.92fr);gap:12px;padding:14px;background:#fff}.landing-product-score,.landing-product-balance,.landing-product-goal,.landing-product-ai{min-width:0;padding:18px;border:1px solid #e5e7eb;border-radius:18px;background:#fff;box-shadow:0 1px 2px #0f172a0a,0 14px 30px #0f172a0a}.landing-product-score{grid-column:1 / -1;display:grid;grid-template-columns:minmax(0,1fr) 122px;align-items:center;gap:18px}.landing-product-score strong{display:block;margin:10px 0 8px;color:#0f172a;font-size:56px;line-height:.95;letter-spacing:-.06em}.landing-product-score p,.landing-product-goal p,.landing-product-ai p{margin:0;color:#64748b;font-size:13px;line-height:1.55;font-weight:540}.landing-score-ring{width:112px;height:112px;display:grid;place-items:center;border-radius:999px;background:conic-gradient(#2563eb 0,#2563eb 82%,#e5e7eb 82%,#e5e7eb);position:relative}.landing-score-ring:before{content:"";position:absolute;top:10px;right:10px;bottom:10px;left:10px;border-radius:inherit;background:#fff}.landing-score-ring span{position:relative;color:#0f172a;font-size:24px;font-weight:820;letter-spacing:-.04em}.landing-product-balance strong{display:block;margin-top:8px;color:#0f172a;font-size:30px;letter-spacing:-.04em}.landing-balance-bars{height:110px;display:flex;align-items:end;gap:8px;margin-top:18px;padding:12px;border-radius:14px;background:#f8fafc}.landing-balance-bars span,.landing-value-bars i{flex:1;min-width:9px;border-radius:8px 8px 3px 3px;background:#2563eb;opacity:.82}.landing-product-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}.landing-product-row strong,.landing-product-ai strong{display:block;margin-top:7px;color:#0f172a;font-size:20px;letter-spacing:-.02em}.landing-status-pill{display:inline-flex;align-items:center;min-height:24px;padding:0 9px;border-radius:999px;background:#ecfdf5;color:#047857;font-size:11px;font-weight:800;white-space:nowrap}.landing-progress-bg{height:8px;overflow:hidden;border-radius:999px;background:#e2e8f0;margin-bottom:10px}.landing-progress-fill{display:block;height:100%;border-radius:inherit;background:#2563eb}.landing-product-ai{border-left:3px solid #2563eb;background:#f8fafc}.landing-product-ai strong{margin-bottom:8px}.landing-section-head{max-width:760px;margin-bottom:34px}.landing-section-head-centered{margin-left:auto;margin-right:auto;text-align:center}.landing-section-head span,.landing-section-kicker{color:#2563eb;background:#eff6ff;border:1px solid #dbeafe}.landing-section-head h2,.landing-how-copy h2,.landing-dream-copy h2,.landing-coach-header h2,.landing-cta-title{margin:12px 0 0;color:#0f172a;font-size:clamp(32px,4vw,48px);line-height:1.08;letter-spacing:-.04em;font-weight:850}.landing-values{max-width:1180px;margin:0 auto;padding:106px 20px 84px}.landing-value-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.landing-value-card{min-width:0;padding:26px;border-radius:24px;background:#fff;border:1px solid #e5e7eb;box-shadow:0 1px 2px #0f172a0a,0 18px 42px #0f172a0a}.landing-value-index{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;background:#f1f5f9;color:#475569;font-size:12px;font-weight:850}.landing-value-card h3{margin:24px 0 10px;color:#0f172a;font-size:24px;line-height:1.15;letter-spacing:-.03em}.landing-value-card p{margin:0;color:#64748b;font-size:15px;line-height:1.65}.landing-value-mini{margin-top:28px;padding:16px;border-radius:18px;background:#f8fafc;border:1px solid #e5e7eb}.landing-value-mini span{display:block;color:#64748b;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.landing-value-mini strong{display:block;margin:8px 0 14px;color:#0f172a;font-size:27px;line-height:1;letter-spacing:-.04em}.landing-value-bars{height:74px;display:flex;align-items:end;gap:8px}.landing-how{max-width:1180px;margin:0 auto;padding:86px 20px;display:grid;grid-template-columns:minmax(0,.78fr) minmax(0,1.22fr);align-items:center;gap:42px}.landing-step-track{position:relative;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.landing-step-track:before{content:"";position:absolute;left:9%;right:9%;top:29px;height:1px;background:#e5e7eb}.landing-step{position:relative;min-width:0;padding:16px;border-radius:20px;background:#fff;border:1px solid #e5e7eb;box-shadow:0 1px 2px #0f172a0a}.landing-step-dot{width:28px;height:28px;display:grid;place-items:center;margin-bottom:24px;border-radius:999px;background:#0f172a;color:#fff;font-size:12px;font-weight:820}.landing-step span{display:block;color:#64748b;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.landing-step strong{display:block;margin-top:8px;color:#0f172a;font-size:15px;line-height:1.35;letter-spacing:-.01em}.landing-dream-spotlight{max-width:1180px;margin:0 auto;padding:48px 20px 106px;display:grid;grid-template-columns:minmax(0,.76fr) minmax(0,1.24fr);align-items:center;gap:42px}.landing-dream-copy p,.landing-cta-desc{margin:16px 0 0;color:#64748b;font-size:16px;line-height:1.7}.landing-dream-board{overflow:hidden;border:1px solid #e5e7eb;border-radius:24px;background:#fff;box-shadow:0 20px 52px #0f172a12}.landing-dream-head,.landing-dream-row{display:grid;grid-template-columns:1.05fr 1fr .78fr .64fr 1fr;gap:12px;align-items:center;padding:16px 18px}.landing-dream-head{background:#f8fafc;color:#64748b;font-size:11px;font-weight:850;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid #e5e7eb}.landing-dream-row{color:#475569;font-size:13px;font-weight:650}.landing-dream-row+.landing-dream-row{border-top:1px solid #e5e7eb}.landing-dream-row strong{color:#0f172a;font-size:14px}.landing-recommendation{display:inline-flex;justify-content:center;width:-moz-fit-content;width:fit-content;min-height:26px;padding:0 10px;border-radius:999px;align-items:center;font-size:11px;font-weight:850;white-space:nowrap}.landing-recommendation-buy-soon{background:#ecfdf5;color:#047857}.landing-recommendation-wait{background:#eff6ff;color:#1d4ed8}.landing-recommendation-delay{background:#fff7ed;color:#c2410c}.landing-coach{max-width:1180px;margin:0 auto;padding:96px 20px}.landing-coach-header{max-width:760px;margin-bottom:26px}.landing-coach-card{display:grid;grid-template-columns:minmax(0,.72fr) minmax(0,1fr);gap:16px;padding:18px;border-radius:28px;background:#0f172a;color:#fff;box-shadow:0 24px 70px #0f172a33}.landing-coach-question,.landing-coach-answer,.landing-coach-grid section{min-width:0;padding:20px;border-radius:20px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12)}.landing-coach-answer{background:#fff;color:#0f172a}.landing-coach-question span,.landing-coach-answer span,.landing-coach-grid span{display:block;margin-bottom:10px;color:#93c5fd;font-size:11px;font-weight:850;text-transform:uppercase;letter-spacing:.06em}.landing-coach-answer span{color:#2563eb}.landing-coach-question strong{display:block;color:#fff;font-size:30px;line-height:1.1;letter-spacing:-.04em}.landing-coach-answer p{margin:0;color:#0f172a;font-size:18px;line-height:1.5;font-weight:760}.landing-coach-grid{grid-column:1 / -1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.landing-coach-grid section{background:#ffffff0d}.landing-coach-grid p{margin:0;color:#cbd5e1;font-size:13px;line-height:1.58}.landing-trust{max-width:1180px;margin:0 auto;padding:92px 20px 70px}.landing-trust-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.landing-trust-item{min-height:74px;display:flex;align-items:center;gap:12px;padding:16px 18px;border:1px solid #e5e7eb;border-radius:18px;background:#fff;box-shadow:0 1px 2px #0f172a0a}.landing-trust-item span{width:10px;height:10px;flex:0 0 auto;border-radius:999px;background:#2563eb;box-shadow:0 0 0 5px #eff6ff}.landing-trust-item strong{color:#0f172a;font-size:14px;font-weight:780;letter-spacing:-.01em}.landing-final-cta{max-width:1180px;margin:0 auto;padding:56px 20px 20px}.landing-cta-box{padding:58px 32px;border-radius:30px;text-align:center;background:#0f172a;color:#fff;box-shadow:0 24px 70px #0f172a33}.landing-cta-title{color:#fff}.landing-cta-desc{color:#cbd5e1;margin-bottom:28px}.landing-footer{padding:42px 20px 56px}.landing-footer-bottom{max-width:1180px;margin:0 auto;padding-top:24px;border-top:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;gap:24px}.landing-footer-logo{color:#0f172a;font-size:15px;font-weight:850;text-decoration:none}.landing-footer-links{display:flex;align-items:center;flex-wrap:wrap;justify-content:flex-end;gap:18px}.landing-footer-links a{color:#64748b;text-decoration:none;font-size:13px;font-weight:650}.landing-footer-links a:hover{color:#0f172a}@media (max-width: 1040px){.landing-hero{min-height:auto;grid-template-columns:1fr;padding:58px 28px 28px;gap:40px}.landing-product-frame{width:100%;max-width:760px;margin:0 auto}.landing-how,.landing-dream-spotlight{grid-template-columns:1fr}.landing-step-track,.landing-trust-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.landing-step-track:before{display:none}}@media (max-width: 760px){.landing-nav{padding:10px 12px}.landing-nav-inner{grid-template-columns:auto 1fr;gap:12px}.landing-nav-menu{display:none}.landing-nav-actions{gap:6px}.landing-link,.landing-btn-small{min-height:38px;padding-left:11px;padding-right:11px;justify-content:center}.landing-hero{margin:0;padding:42px 16px 18px;border-radius:0 0 28px 28px}.landing-hero-title{font-size:42px;line-height:1.03;letter-spacing:-.045em}.landing-hero-subtitle{font-size:16px;margin-bottom:26px}.landing-hero-actions{display:grid;grid-template-columns:1fr;width:100%}.landing-btn-large{width:100%;min-height:52px}.landing-product-frame{padding:8px;border-radius:22px}.landing-product-window{border-radius:18px}.landing-product-topbar{padding:14px}.landing-product-layout{grid-template-columns:1fr;min-height:auto}.landing-product-sidebar{display:none}.landing-product-main{grid-template-columns:1fr;padding:10px}.landing-product-score{grid-template-columns:1fr}.landing-score-ring{width:92px;height:92px}.landing-values,.landing-how,.landing-dream-spotlight,.landing-coach,.landing-trust{padding:66px 16px}.landing-section-head h2,.landing-how-copy h2,.landing-dream-copy h2,.landing-coach-header h2,.landing-cta-title{font-size:30px;line-height:1.12}.landing-value-grid,.landing-step-track,.landing-coach-card,.landing-coach-grid,.landing-trust-grid{grid-template-columns:1fr}.landing-value-card{padding:22px;border-radius:22px}.landing-dream-board{border-radius:22px}.landing-dream-head{display:none}.landing-dream-row{grid-template-columns:1fr;gap:8px;padding:18px}.landing-dream-row strong{font-size:16px}.landing-dream-row span[data-label]{display:flex;align-items:center;justify-content:space-between;gap:16px}.landing-dream-row span[data-label]:before{content:attr(data-label);color:#64748b;font-size:11px;font-weight:850;text-transform:uppercase;letter-spacing:.04em}.landing-coach-card{padding:12px;border-radius:24px}.landing-coach-question strong{font-size:24px}.landing-final-cta{padding:42px 16px 16px}.landing-cta-box{padding:40px 20px;border-radius:24px}.landing-footer-bottom{flex-direction:column;align-items:flex-start}.landing-footer-links{justify-content:flex-start;flex-direction:column;align-items:flex-start;gap:12px}}.auth-page{min-height:100dvh;background:#f8fafc;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px;box-sizing:border-box;overflow-x:hidden}.auth-logo-center{margin-bottom:32px;display:flex;align-items:center;gap:10px;text-decoration:none;color:#0f172a;font-size:20px;font-weight:850;letter-spacing:-.02em}.auth-logo-icon{width:32px;height:32px;background:#0f172a;color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:900}.auth-card{width:100%;max-width:460px;background:#fff;border:1px solid #e5e7eb;border-radius:24px;padding:40px;box-shadow:0 16px 40px #0f172a0f;box-sizing:border-box;overflow:hidden}.auth-header{text-align:center;margin-bottom:32px}.auth-header h2{font-size:26px;font-weight:850;letter-spacing:-.03em;margin-bottom:8px;color:#0f172a}.auth-header p{font-size:15px;color:#64748b;font-weight:500;line-height:1.5}.auth-segmented-control{display:flex;background:#f1f5f9;padding:4px;border-radius:14px;margin-bottom:32px;border:1px solid #e2e8f0;height:48px;width:100%;box-sizing:border-box}.auth-segment-btn{flex:1;display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:14px;font-weight:700;color:#64748b;text-decoration:none;transition:all .2s}.auth-segment-btn.active{background:#fff;color:#0f172a;box-shadow:0 1px 2px #0000000d}.auth-form{display:flex;flex-direction:column;gap:20px;width:100%;max-width:100%;box-sizing:border-box}.auth-field{display:flex;flex-direction:column;gap:8px;width:100%;max-width:100%;box-sizing:border-box}.auth-field label{font-size:14px;font-weight:700;color:#334155}.auth-label-row{display:flex;justify-content:space-between;align-items:center}.auth-label-row a{font-size:13px;color:#2563eb;text-decoration:none;font-weight:600}.auth-label-row a:hover{text-decoration:underline}.auth-input-wrapper{position:relative;width:100%;max-width:100%;box-sizing:border-box;overflow:hidden}.auth-input{width:100%;max-width:100%;height:48px;border-radius:12px;font-size:16px;border:1px solid #d1d5db;background:#fff;color:#0f172a;padding:0 16px;outline:none;transition:all .2s;font-family:inherit;box-sizing:border-box}.auth-input:focus{border-color:#2563eb;box-shadow:0 0 0 1px #2563eb}.auth-input-wrapper .auth-input{padding-right:48px}.auth-eye-btn{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:transparent;border:none;padding:10px;cursor:pointer;color:#94a3b8;display:flex;align-items:center;justify-content:center;transition:color .2s;z-index:10;border-radius:8px}.auth-eye-btn:hover{color:#64748b}.auth-submit-btn{width:100%;max-width:100%;height:48px;background:#2563eb;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;box-sizing:border-box}.auth-submit-btn:hover{background:#1d4ed8}.auth-submit-btn:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:16px;margin:24px 0;font-size:13px;color:#64748b;font-weight:600;width:100%}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#e5e7eb}.auth-google-btn{width:100%;max-width:100%;height:48px;border-radius:12px;border:1px solid #d1d5db;background:#fff;font-weight:600;font-size:15px;display:flex;align-items:center;justify-content:center;gap:12px;cursor:pointer;color:#0f172a;transition:all .2s;box-sizing:border-box}.auth-google-btn:hover{background:#f8fafc;border-color:#94a3b8}.auth-google-btn img{width:18px}.auth-footer{margin-top:32px;text-align:center;font-size:14px;color:#64748b;font-weight:600}.auth-footer a{color:#2563eb;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.auth-aux-links{margin-top:40px;display:flex;justify-content:center;gap:12px;font-size:12px;color:#94a3b8;font-weight:500;width:100%;box-sizing:border-box}.auth-aux-links a{color:inherit;text-decoration:none;transition:color .2s}.auth-aux-links a:hover{color:#64748b}.auth-error-box{background:#fef2f2;color:#b91c1c;padding:12px 16px;border-radius:12px;font-size:14px;font-weight:600;line-height:1.5;border:1px solid #fee2e2;width:100%;box-sizing:border-box}.auth-success-box{background:#f0fdf4;color:#15803d;padding:12px 16px;border-radius:12px;font-size:14px;font-weight:600;line-height:1.5;border:1px solid #dcfce7;width:100%;box-sizing:border-box}.auth-success-state{text-align:center}.auth-success-icon{font-size:48px;margin-bottom:24px}.auth-terms-text{margin-top:20px;font-size:12px;color:#64748b;text-align:center;line-height:1.6}.auth-terms-text a{color:#475569;text-decoration:underline}@media (max-width: 600px){.auth-page{padding:24px 16px;justify-content:center}.auth-card{max-width:calc(100% + -0px);padding:24px;border-radius:20px}.auth-logo-center,.auth-header{margin-bottom:24px}.auth-aux-links{flex-wrap:wrap;gap:8px 16px}}.legal-page{background:var(--bg);min-height:100vh;color:var(--text);padding:80px 20px}.legal-container{max-width:900px;margin:0 auto}.legal-header{margin-bottom:60px;border-bottom:1px solid var(--border);padding-bottom:40px}.legal-title{font-size:48px;font-weight:900;margin:0 0 12px;letter-spacing:-.04em}.legal-subtitle{font-size:20px;color:var(--text2);margin:0}.legal-section{margin-bottom:48px}.legal-section-title{font-size:24px;font-weight:800;margin-bottom:20px;color:var(--text)}.legal-text{font-size:16px;line-height:1.8;color:var(--text2);margin-bottom:16px}.legal-list{margin-bottom:24px;padding-left:20px}.legal-list li{font-size:16px;line-height:1.8;color:var(--text2);margin-bottom:12px}.legal-footer{margin-top:80px;padding-top:40px;border-top:1px solid var(--border)}@media (max-width: 700px){.legal-page{padding:40px 20px}.legal-title{font-size:32px}.legal-subtitle{font-size:18px}}.support-page{background:var(--bg);min-height:100vh;color:var(--text);padding:80px 20px}.support-container{max-width:900px;margin:0 auto}.support-header{margin-bottom:60px;text-align:center}.support-title{font-size:48px;font-weight:900;margin-bottom:12px;letter-spacing:-.04em}.support-subtitle{font-size:18px;color:var(--text2);margin:0}.support-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:40px;align-items:start;margin-bottom:60px}.support-card{background:var(--bg2);border:1px solid var(--border);border-radius:24px;padding:40px;text-align:center}.support-icon{font-size:48px;margin-bottom:24px}.support-section-title{font-size:24px;font-weight:800;margin-bottom:20px;color:var(--text)}.support-text{font-size:15px;line-height:1.7;color:var(--text2);margin-bottom:24px}.support-btn-primary{background:var(--blue);color:#fff;font-weight:700;border-radius:12px;padding:12px 32px;display:inline-block;text-decoration:none;transition:all .2s}.support-btn-primary:hover{background:#2563eb;transform:translateY(-1px)}.support-email{font-size:13px;color:var(--text3);margin-top:16px;font-weight:600}.support-faq-section{background:var(--bg)}.support-faq-list{display:flex;flex-direction:column;gap:24px}.support-faq-item{border-bottom:1px solid var(--border);padding-bottom:24px}.support-faq-item:last-child{border-bottom:none}.support-faq-q{font-size:17px;font-weight:750;color:var(--text);margin-bottom:12px}.support-faq-a{font-size:15px;color:var(--text2);line-height:1.6;margin:0}.support-footer{margin-top:80px;padding-top:40px;border-top:1px solid var(--border);text-align:center}@media (max-width: 800px){.support-grid{grid-template-columns:1fr}.support-page{padding:40px 20px}.support-title{font-size:36px}}.header{display:flex;justify-content:space-between;align-items:center;min-height:80px;margin-bottom:32px;position:sticky;top:0;background:#ffffffd9;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:100;border-bottom:.5px solid var(--border);padding:0 20px}body[data-theme=dark] .header{background:#030712d9}.header-left{display:flex;align-items:center;gap:24px}.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit}.brand-mark{width:32px;color:var(--blue)}.brand-name{font-size:18px;font-weight:900;letter-spacing:-.02em}.brand h1{font-size:11px;color:var(--text3);margin:0;font-weight:600}.page-tabs{display:flex;gap:6px;background:var(--bg3);padding:4px;border-radius:14px}.tab-btn{padding:8px 18px;font-size:13px;font-weight:700;color:var(--text2);border-radius:10px;text-decoration:none;transition:all .2s;border:none;background:transparent}.tab-btn:hover:not(.active){background:var(--bg);color:var(--blue);opacity:.8}.tab-btn.active{background:var(--bg);color:var(--blue);box-shadow:var(--shadow)}.header-plan-picker{position:relative}.header-plan-button{background:var(--bg3);border-radius:99px;padding:8px 18px;font-size:13px;font-weight:750;color:var(--text);border:none}.header-plan-menu{position:absolute;top:100%;right:0;margin-top:10px;background:var(--bg);border:1px solid var(--border);border-radius:18px;width:260px;box-shadow:0 15px 40px #00000026;padding:10px;display:none;z-index:1000}.header-plan-menu.open{display:block}.header-plan-option{width:100%;text-align:left;padding:12px 16px;border-radius:12px;font-size:13.5px;font-weight:600;display:flex;justify-content:space-between;align-items:center;background:transparent;border:none}.header-plan-option:hover{background:var(--bg2)}.header-plan-option.active{color:var(--blue);background:var(--blue-soft)}.section-head{display:flex;justify-content:space-between;align-items:flex-end;margin:40px 0 28px}.section-head h2{font-size:28px;font-weight:900;margin:0 0 6px;letter-spacing:-.03em}.section-head p{font-size:14px;color:var(--text3);margin:0;font-weight:500}.card,.panel-card,.settings-panel{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;margin-bottom:24px;box-shadow:0 1px 3px #00000005}.card-title{font-size:16px;font-weight:850;margin-bottom:24px;color:var(--text);display:flex;align-items:center;justify-content:space-between}.muted-note{font-size:13px;color:var(--text3);font-weight:500}.hero-cockpit{background:linear-gradient(135deg,#0d0d0d,#1a1a1a);color:#fff;border-radius:28px;padding:40px;margin-bottom:32px;position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.08);box-shadow:0 20px 50px #0003}.hero-cockpit:before{content:"";position:absolute;top:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(79,70,229,.12) 0%,transparent 70%);pointer-events:none}.hero-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:40px}.hero-title{font-size:32px;font-weight:900;letter-spacing:-.02em;margin-bottom:8px}.hero-subtitle{font-size:15px;opacity:.6;font-weight:500}.hero-health-badge{background:#ffffff14;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:18px;padding:14px 24px;min-width:120px;text-align:center;border:1px solid rgba(255,255,255,.12)}.hero-health-badge.good{background:#10b98133;border-color:#10b9814d}.hero-health-badge.warn{background:#f59e0b33;border-color:#f59e0b4d}.hero-health-badge.risk{background:#ef444433;border-color:#ef44444d}.health-score{font-size:36px;font-weight:950;line-height:1;margin-bottom:4px}.health-label{font-size:11px;font-weight:800;opacity:.9}.hero-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.hero-kpi{background:#ffffff0a;border-radius:20px;padding:20px;border:1px solid rgba(255,255,255,.04)}.hero-kpi-label{font-size:11px;font-weight:700;opacity:.5;margin-bottom:10px;text-transform:uppercase}.hero-kpi-value{font-size:24px;font-weight:850}.hero-kpi-value.green{color:#34d399}.hero-kpi-value.red{color:#f87171}.hero-ai-footer{display:grid;grid-template-columns:1.2fr 1fr;gap:40px;margin-top:40px;padding-top:32px;border-top:1px solid rgba(255,255,255,.1)}.hero-ai-label{font-size:11px;font-weight:900;color:var(--blue);margin-bottom:8px}.hero-ai-text{font-size:14px;font-weight:600;line-height:1.6}.hero-step-pill{background:#3b82f626;color:#93c5fd;font-size:12px;font-weight:750;padding:6px 14px;border-radius:99px;margin-right:10px;border:1px solid rgba(59,130,246,.2)}.overview-forecast{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:32px}.summary-grid,.analysis-kpi-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:32px}.metric-card,.mini-card{background:var(--bg);border:1px solid var(--border);border-radius:18px;padding:20px;text-align:left}.metric-label,.mini-card .title{font-size:12px;color:var(--text3);font-weight:700;margin-bottom:8px}.metric-value,.mini-card .value{font-size:18px;font-weight:850}.tone-green .metric-value{color:var(--green)}.tone-red .metric-value{color:var(--red)}.tone-blue .metric-value{color:var(--blue)}.plan-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:10px}.plan-detail-item{display:flex;flex-direction:column;gap:6px}.plan-detail-label{font-size:11px;color:var(--text3);font-weight:750}.plan-detail-value{font-size:16px;font-weight:800}.goal-section{background:var(--bg3);border-radius:24px;padding:32px;margin-bottom:32px}.goal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.goal-title{font-size:15px;font-weight:850}.goal-pct{font-size:24px;font-weight:950}.goal-bar-bg,.progress-bg{height:12px;background:var(--bg);border-radius:99px;overflow:hidden;margin-bottom:16px}.goal-bar-fill,.progress-fill{height:100%;background:var(--blue);transition:width 1s cubic-bezier(.34,1.56,.64,1)}.goal-bar-fill.positive{background:var(--green)}.goal-bar-fill.warning{background:var(--amber)}.goal-meta{display:flex;gap:24px;font-size:12px;color:var(--text3);font-weight:700}.progress-wrap{margin-top:32px;margin-bottom:32px}.progress-head{margin-bottom:12px}.progress-label{display:flex;justify-content:space-between;font-size:13px;font-weight:800;color:var(--text2)}.insight-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px;margin-bottom:32px}.insight-card{background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:24px}.insight-title{font-size:14px;font-weight:900;margin-bottom:12px}.insight-body{font-size:13px;color:var(--text2);line-height:1.6}.plan-switcher{display:flex;justify-content:space-between;align-items:center;background:var(--bg);padding:32px 40px;border-radius:24px;border:1px solid var(--border);margin-bottom:24px;box-shadow:0 1px 3px #00000005}.plan-label{font-size:11px;color:var(--text3);font-weight:800;margin-bottom:8px;text-transform:uppercase;letter-spacing:.1em}.plan-switcher-main{flex:1}.plan-title-row{display:flex;align-items:center;gap:16px;margin-top:4px}.custom-dropdown{position:relative;display:inline-block}.custom-dropdown-trigger{background:transparent;border:none;padding:0;font-size:24px;font-weight:900;color:var(--text);cursor:pointer;display:flex;align-items:center;gap:12px;letter-spacing:-.03em;transition:color .2s}.custom-dropdown-trigger:hover{color:var(--blue)}.dropdown-arrow{font-size:10px;opacity:.3;transition:transform .3s ease}.custom-dropdown-trigger.active .dropdown-arrow{transform:rotate(180deg);opacity:.6}.custom-dropdown-menu{position:absolute;top:100%;left:0;margin-top:12px;background:var(--bg);border:1px solid var(--border);border-radius:16px;width:280px;box-shadow:0 15px 40px #00000026;padding:8px;display:none;z-index:1000;animation:dropdownFade .2s ease-out}.custom-dropdown-menu.open{display:block}@keyframes dropdownFade{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.custom-dropdown-item{width:100%;text-align:left;padding:12px 16px;border-radius:12px;font-size:14px;font-weight:650;color:var(--text2);display:flex;justify-content:space-between;align-items:center;background:transparent;border:none}.custom-dropdown-item:hover{background:var(--bg2);color:var(--text)}.custom-dropdown-item.active{color:var(--blue);background:var(--blue-soft)}.active-indicator{color:var(--blue);font-weight:900}.plan-chip{background:var(--bg3);font-size:11px;font-weight:800;padding:4px 14px;border-radius:99px;color:var(--text3)}.plan-actions{display:flex;gap:12px;align-items:center}.risk-card{background:#fffbeb;border-color:#fde68a;border-left:5px solid #f59e0b}body[data-theme=dark] .risk-card{background:#f59e0b0d;border-color:#f59e0b33}.plans-list{display:flex;flex-direction:column;gap:16px;margin-top:32px}.plan-row-card{display:flex;justify-content:space-between;align-items:center;background:var(--bg);padding:24px 40px;border-radius:20px;border:1px solid var(--border);transition:all .2s;cursor:pointer}.plan-row-card.active{border-left:4px solid var(--blue);padding-left:28px;background:var(--bg2)}.records-view-switch{display:flex;gap:4px;background:var(--bg3);padding:4px;border-radius:14px;margin-bottom:32px;width:-moz-fit-content;width:fit-content;border:1px solid var(--border)}.records-view-btn{padding:8px 24px;font-size:13px;font-weight:750;color:var(--text2);border-radius:11px;background:transparent;cursor:pointer;transition:all .2s;border:none}.records-view-btn.active{background:var(--bg);color:var(--blue);box-shadow:var(--shadow)}.year-tabs{display:flex;gap:8px;margin-bottom:28px;border-bottom:1px solid var(--border);padding-bottom:12px;overflow-x:auto;scrollbar-width:none}.year-tabs::-webkit-scrollbar{display:none}.year-tab{background:transparent;font-size:15px;font-weight:800;color:var(--text3);padding:8px 20px;border-radius:10px;transition:all .2s;cursor:pointer;white-space:nowrap;border:none}.year-tab:hover{background:var(--bg3)}.year-tab.active{color:var(--blue);background:var(--blue-soft)}.month-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:20px}.month-card{background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:24px 20px;cursor:pointer;transition:all .2s;position:relative;aspect-ratio:1 / 1;display:flex;flex-direction:column;justify-content:space-between}.month-card.selected{border-color:var(--blue);border-width:2.5px;box-shadow:0 10px 25px #3b82f61a}.month-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000000a}.month-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.month-name{font-size:17px;font-weight:900}.month-nums{display:flex;flex-direction:column;gap:6px;margin-top:12px}.detail-panel{margin-top:40px;background:var(--bg);border-radius:28px;border:1px solid var(--border);padding:36px;box-shadow:var(--shadow)}.detail-title{font-size:22px;font-weight:900;margin-bottom:32px;display:flex;justify-content:space-between;align-items:center}.detail-close{background:var(--bg3);padding:8px 18px;border-radius:99px;font-size:13px;font-weight:750;color:var(--text2);border:none;cursor:pointer;display:flex;align-items:center;gap:8px}.month-row{display:flex;justify-content:space-between;font-size:14px}.month-row .lbl{color:var(--text3);font-weight:650}.month-row .val-green{color:var(--green);font-weight:850}.month-row .val-red{color:var(--red);font-weight:850}.month-badge{font-size:10px;font-weight:800;padding:2px 8px;border-radius:6px;text-transform:uppercase}.badge-pos{background:#dcfce7;color:#166534}.badge-neg{background:#fee2e2;color:#991b1b}.badge-zero{background:var(--bg3);color:var(--text3)}.timeline-container{padding:10px 0;margin-top:20px}.timeline-row{display:grid;grid-template-columns:110px 1fr;gap:24px;margin-bottom:40px;position:relative}.timeline-row.is-example{opacity:.5}.timeline-left{display:flex;flex-direction:column;align-items:flex-end}.timeline-date-label{font-size:11px;font-weight:850;color:var(--text3);margin-bottom:8px}.timeline-line{position:relative;width:24px;display:flex;justify-content:center;height:100%}.timeline-dot-outer{width:22px;height:22px;border-radius:50%;background:var(--bg);border:2.5px solid var(--border);z-index:2;display:flex;align-items:center;justify-content:center}.timeline-dot-outer.sev-positive{border-color:var(--green)}.timeline-dot-outer.sev-danger{border-color:var(--red)}.timeline-dot-outer.sev-warning{border-color:var(--amber)}.timeline-dot-outer.sev-ai{border-color:var(--blue)}.timeline-dot-inner{width:8px;height:8px;border-radius:50%;background:var(--text3)}.sev-positive .timeline-dot-inner{background:var(--green)}.sev-danger .timeline-dot-inner{background:var(--red)}.sev-warning .timeline-dot-inner{background:var(--amber)}.sev-ai .timeline-dot-inner{background:var(--blue)}.timeline-connector{position:absolute;top:22px;bottom:-40px;width:2.5px;background:var(--border);left:50%;transform:translate(-50%);z-index:1}.timeline-card-v2{background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:20px 24px;box-shadow:0 1px 3px #00000005;transition:all .2s ease;position:relative}.timeline-card-v2.sev-positive{background:#f0fdf4;border-color:#bbf7d0}.timeline-card-v2.sev-danger{background:#fef2f2;border-color:#fecaca}.timeline-card-v2.sev-ai{border-left:4px solid var(--blue)}.timeline-card-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.timeline-title-v2{font-size:15px;font-weight:850;color:var(--text)}.timeline-desc-v2{font-size:13.5px;color:var(--text2);line-height:1.6;margin-bottom:12px;font-weight:600}.timeline-footer{display:flex;gap:12px;align-items:center}.timeline-source{font-size:10px;font-weight:900;background:var(--bg3);padding:2px 8px;border-radius:4px;color:var(--text3)}.timeline-tag-v2{font-size:10px;font-weight:800;color:var(--blue)}.example-badge{position:absolute;top:-10px;right:20px;background:var(--text2);color:var(--bg);font-size:9px;font-weight:900;padding:2px 8px;border-radius:4px}.btn-primary{background:var(--blue);color:#fff;font-weight:700;padding:10px 24px;border-radius:var(--radius);font-size:14px;border:none;cursor:pointer}.btn-ghost{background:transparent;color:var(--text2);font-weight:600;padding:10px 20px;border-radius:var(--radius);border:none;cursor:pointer}.btn-ghost:hover{background:var(--bg3)}.record-form{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:40px;background:var(--bg2);padding:32px;border-radius:28px;border:1px solid var(--border)}.record-row{display:flex;flex-direction:column;gap:10px}.category-picker{display:flex;flex-direction:column;gap:16px;margin-top:4px}.category-level-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px}.category-card-btn{background:var(--bg);padding:10px;border-radius:12px;font-size:13px;font-weight:700;border:1px solid var(--border);cursor:pointer}.category-card-btn.active{border-color:var(--blue);color:var(--blue);background:var(--blue-soft)}.subcategory-pills{display:flex;flex-wrap:wrap;gap:8px;padding:12px;background:var(--bg);border-radius:12px;border:1px solid var(--border)}.subcat-btn{background:var(--bg3);padding:7px 16px;border-radius:99px;font-size:12px;font-weight:750;color:var(--text3);border:none;cursor:pointer}.subcat-btn.active{background:var(--text);color:var(--bg)}.record-list{display:flex;flex-direction:column;margin-bottom:40px}.record-item{display:flex;align-items:center;gap:20px;padding:20px 0;border-bottom:1px solid var(--border)}.record-main{flex:1;min-width:0}.record-category{font-size:16px;font-weight:850;color:var(--text);margin-bottom:4px}.record-note{font-size:13px;color:var(--text3);font-weight:500}.record-amount{font-size:17px;font-weight:900;text-align:right}.del-btn{width:32px;height:32px;border-radius:50%;background:var(--bg3);color:var(--text3);display:flex;align-items:center;justify-content:center;font-size:14px;border:none;cursor:pointer}.quick-templates{margin-bottom:32px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}.template-list{display:flex;gap:10px;flex-wrap:wrap}.template-btn{background:var(--bg3);padding:8px 18px;border-radius:99px;font-size:13px;font-weight:700;border:1px solid transparent;cursor:pointer}.wants-form{background:var(--bg2);border-radius:24px;padding:36px;margin-bottom:40px;border:2px dashed var(--border2)}.wants-form.inline-edit{border-style:solid;border-color:var(--border);margin-top:-10px;margin-bottom:32px}.is-hidden{display:none!important}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}.form-item{display:flex;flex-direction:column;gap:8px}.form-item label{font-size:12px;font-weight:800;color:var(--text3);text-transform:uppercase;letter-spacing:.05em}.toggle-group{display:flex;gap:32px;margin-top:24px;margin-bottom:32px}.wants-form-actions{display:flex;justify-content:flex-end;gap:16px;border-top:1px solid var(--border);padding-top:28px}.want-item{background:var(--bg);border:1px solid var(--border);border-radius:24px;padding:32px;margin-bottom:20px;transition:all .2s}.want-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;gap:20px}.want-title{font-size:18px;font-weight:900;display:flex;align-items:center;gap:12px;flex:1;min-width:0}.want-actions{display:flex;align-items:center;gap:12px;flex-shrink:0;flex-wrap:nowrap}.wish-edit-btn{background:var(--bg3);color:var(--blue);padding:6px 14px;border-radius:8px;font-size:12px;font-weight:700;border:none;cursor:pointer;flex-shrink:0}.wish-edit-btn:hover{background:var(--blue-soft)}.wish-del-btn{width:32px;height:32px;border-radius:50%;background:var(--bg3);color:var(--text3);display:flex;align-items:center;justify-content:center;font-size:14px;border:none;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;white-space:nowrap;flex-shrink:0}.wish-del-btn:hover{background:#fee2e2;color:var(--red)}.wish-del-btn.confirming{width:auto;padding:0 16px;border-radius:99px;background:var(--red);color:#fff;font-size:12px;font-weight:800;transform:scale(1.02)}.wish-del-btn.confirming:hover{background:#dc2626}.dream-progress-bar{height:10px;background:var(--bg3);border-radius:99px;overflow:hidden;margin:12px 0}.dream-progress-fill{height:100%;background:linear-gradient(90deg,var(--green),#34d399)}.dream-impact-tag{font-size:10px;font-weight:850;padding:4px 12px;border-radius:8px;margin-left:10px}.analysis-tabs{display:flex;gap:10px;margin-bottom:24px;flex-wrap:wrap}.analysis-tab{background:var(--bg3);padding:8px 20px;border-radius:10px;font-size:13px;font-weight:700;color:var(--text2);border:none;cursor:pointer}.analysis-tab.active{background:var(--text);color:var(--bg)}.analysis-section{background:var(--bg);border:1px solid var(--border);border-radius:24px;padding:32px;margin-top:32px}.filter-grid{display:flex;gap:16px;margin-bottom:32px;flex-wrap:wrap}.filter-grid select{background:var(--bg3);border:1px solid var(--border);border-radius:12px;height:44px;padding:0 16px;font-size:13px;font-weight:750;color:var(--text2);min-width:160px;outline:none}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000073;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000}.modal{background:var(--bg);width:100%;max-width:520px;border-radius:32px;padding:48px;box-shadow:0 40px 100px #0000004d}.modal h2{font-size:26px;font-weight:900;margin:0 0 40px}.modal-section{margin-bottom:28px}.modal-label{font-size:12px;font-weight:850;color:var(--text3);text-transform:uppercase;margin-bottom:12px}.modal-row{display:flex;gap:14px;align-items:center;width:100%}.modal-row select{flex:0 0 100px}.modal-footer{display:flex;justify-content:flex-end;gap:16px;margin-top:48px;padding-top:32px;border-top:1px solid var(--border)}.ai-insights-list{display:flex;flex-direction:column;gap:16px}.ai-insight-row{background:var(--bg2);border-radius:16px;padding:20px;border:1px solid transparent}.ai-insight-tag{font-size:11px;font-weight:800;padding:4px 12px;border-radius:99px}.ai-insight-tag.summary{background:#e0f2fe;color:#0369a1}.ai-insight-tag.opportunity{background:#dcfce7;color:#15803d}.ai-insight-tag.risk{background:#fee2e2;color:#b91c1c}.ai-insight-tag.suggestion{background:#fef3c7;color:#92400e}.settings-page{max-width:960px;margin:0 auto 48px}.settings-page .section-head{margin-top:24px;margin-bottom:24px}.settings-page .section-head h2{font-size:30px;letter-spacing:-.025em}.settings-page .section-head p{color:var(--text2);font-weight:550}.settings-panel{background:var(--bg);border:1px solid var(--border);border-radius:16px;padding:0;margin-bottom:20px;box-shadow:0 1px 2px #1018280a,0 8px 24px #1018280a;overflow:hidden}.settings-group-title{min-height:68px;margin:0;padding:18px 24px;display:flex;align-items:center;gap:12px;color:var(--text);border-bottom:1px solid var(--border);background:linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%)}.settings-group-title h3{font-size:15px;font-weight:850;letter-spacing:-.01em;margin:0}.settings-group-icon{width:32px;height:32px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;background:var(--bg);border:1px solid var(--border);color:var(--blue);font-size:10px;font-weight:900;letter-spacing:.04em;box-shadow:0 1px 2px #1018280a}.settings-section-body{padding:6px 24px}.settings-section-desc{margin:14px 0 20px;max-width:680px;font-size:13px;line-height:1.6;color:var(--text2);font-weight:550}.settings-row{display:flex;justify-content:space-between;align-items:center;gap:24px;min-height:74px;padding:18px 0;border-bottom:1px solid var(--border)}.settings-row:last-child{border-bottom:none}.settings-row-stack{flex-direction:column;align-items:flex-start;gap:8px}.settings-row-stack .theme-grid{width:100%;margin-top:8px}.settings-row-main{flex:1;min-width:0;padding-right:20px}.settings-row-title{font-size:14px;line-height:1.35;font-weight:750;color:var(--text);margin-bottom:4px;letter-spacing:-.005em}.settings-row-desc{max-width:640px;font-size:13px;line-height:1.5;color:var(--text3);font-weight:500}.ios-switch{position:relative;display:inline-block;width:44px;height:24px;flex:0 0 auto}.ios-switch input{opacity:0;width:0;height:0}.ios-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--border2);transition:.2s;border-radius:34px;box-shadow:inset 0 0 0 1px #00000008}.ios-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.2s;border-radius:50%;box-shadow:0 1px 3px #00000029}input:checked+.ios-slider{background-color:var(--blue)}input:checked+.ios-slider:before{transform:translate(20px)}.plan-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.theme-select{min-width:220px;height:42px;border-radius:10px!important;border-color:var(--border2)!important;background:var(--bg)!important;color:var(--text)!important;font-weight:650}.theme-select:hover{border-color:var(--text3)!important}.settings-btn{padding:8px 16px;border-radius:8px;font-size:13px;font-weight:700;border:1px solid var(--border2);background:var(--bg2);color:var(--text2);transition:all .2s;cursor:pointer}.import-btn,.export-btn,.settings-page .settings-btn{min-height:38px;padding:8px 14px;border-radius:10px;font-size:13px;font-weight:750;border:1px solid var(--border2);background:var(--bg);color:var(--text2);transition:all .2s;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 1px 2px #1018280a}.import-btn:hover,.export-btn:hover,.settings-page .settings-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-soft);transform:translateY(-1px)}.import-btn{border-color:#3b82f640;color:var(--blue)}.settings-page .settings-btn[href]{background:var(--blue);color:#fff;border-color:var(--blue)}.settings-page .settings-btn[href]:hover{background:#2563eb;border-color:#2563eb;color:#fff}.settings-danger-btn{min-height:40px;padding:9px 16px;border-radius:10px;border:1px solid rgba(239,68,68,.35);background:#ef44440f;color:var(--red);font-size:13px;font-weight:750;cursor:pointer;white-space:nowrap}.settings-danger-btn:hover{background:#ef44441a;border-color:var(--red)}.settings-auth-box{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:18px;margin:18px 0 4px}.auth-form-inline{display:flex;flex-direction:column;gap:12px}.auth-inputs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.auth-inputs input{height:42px;border-radius:10px!important;background:var(--bg)!important}.auth-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.auth-error,.auth-success{padding:10px 12px;border-radius:10px;font-size:12px;line-height:1.45;font-weight:650}.auth-error{color:var(--red);background:#ef444414;border:1px solid rgba(239,68,68,.16)}.auth-success{color:var(--green);background:#10b98114;border:1px solid rgba(16,185,129,.16)}.auth-switch{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-top:14px;color:var(--text3);font-size:13px;font-weight:550}.status-chip.good{background:#dcfce7;color:#166534;font-size:10px;font-weight:800;padding:2px 8px;border-radius:99px;text-transform:uppercase}.plan-chip{background:var(--bg3);border:1px solid var(--border);font-size:12px;padding:3px 10px;border-radius:99px;color:var(--text3);font-weight:700}.ai-assistant-drawer{position:fixed;top:0;right:-420px;width:400px;height:100dvh;background:#f8fafc;border-left:1px solid var(--border);box-shadow:-10px 0 40px #0000000d;z-index:4000;transition:right .4s cubic-bezier(.16,1,.3,1),bottom .4s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;overflow:hidden}.ai-assistant-drawer.open{right:0}.ai-assistant-header{padding:24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:#fff;flex-shrink:0}.ai-title-wrap{display:flex;gap:12px;align-items:center}.ai-icon{font-size:20px;background:var(--bg3);width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--blue)}.ai-assistant-title{font-size:15px;font-weight:800;color:#0f172a}.ai-assistant-subtitle{font-size:11px;color:#64748b;font-weight:600;margin-top:1px}.ai-close-btn{background:var(--bg3);border:none;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#64748b;cursor:pointer;transition:all .2s}.ai-close-btn:hover{background:#e2e8f0;color:#0f172a}.ai-content{flex:1;overflow-y:auto;padding:20px;scrollbar-width:none;-webkit-overflow-scrolling:touch;background:#f8fafc}.ai-content::-webkit-scrollbar{display:none}.ai-quick-grid{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:24px}.ai-question-chip{background:#fff;border:1px solid #E2E8F0;padding:8px 14px;border-radius:8px;font-size:12px;font-weight:650;color:#475569;cursor:pointer;transition:all .2s;white-space:nowrap}.ai-question-chip:hover{border-color:var(--blue);color:var(--blue);background:#eff6ff}.ai-chat-list{display:flex;flex-direction:column;gap:20px;padding-bottom:20px}.ai-message{display:flex;flex-direction:column;width:100%}.ai-message.user{align-items:flex-end}.user-text-bubble{background:#1e293b;color:#fff;padding:10px 16px;border-radius:16px 16px 2px;font-size:13px;font-weight:550;max-width:80%}.ai-answer-card{background:#fff;border:1px solid #E2E8F0;border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:16px;width:100%;border-left:3px solid var(--blue)}.ai-answer-section{display:flex;flex-direction:column;gap:4px;padding-bottom:12px;border-bottom:1px dashed #F1F5F9}.ai-answer-section.no-border{border-bottom:none;padding-bottom:0}.ai-answer-title{font-size:11px;font-weight:800;color:#64748b;text-transform:uppercase;letter-spacing:.02em}.ai-answer-text{font-size:13px;color:#1e293b;font-weight:550;line-height:1.5}.ai-answer-actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.ai-answer-action-btn{background:#f1f5f9;border:1px solid #E2E8F0;padding:5px 12px;border-radius:6px;font-size:11px;font-weight:700;color:var(--blue);cursor:pointer;transition:all .2s}.ai-answer-action-btn:hover{background:#dbeafe;border-color:var(--blue)}.ai-typing{display:flex;gap:3px;padding:10px 16px;background:#fff;border:1px solid #E2E8F0;width:-moz-fit-content;width:fit-content;border-radius:12px;margin-top:6px}.ai-typing span{width:4px;height:4px;background:#94a3b8;border-radius:50%;animation:aiTyping 1.4s infinite ease-in-out}.ai-typing span:nth-child(2){animation-delay:.2s}.ai-typing span:nth-child(3){animation-delay:.4s}@keyframes aiTyping{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.ai-footer{padding:16px 20px;border-top:1px solid var(--border);background:#fff;flex-shrink:0}.ai-input-wrap{display:flex;align-items:center;gap:8px;background:#f1f5f9;padding:6px 12px;border-radius:12px;border:1px solid transparent;transition:all .2s}.ai-input-wrap:focus-within{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px #3b82f61a}.ai-input{flex:1;border:none!important;background:transparent!important;padding:6px 0!important;font-size:14px!important;font-weight:550!important;color:#0f172a;outline:none}.ai-send-btn{background:var(--blue);color:#fff;border:none;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer}.ai-send-btn:hover{background:#1d4ed8}@media (max-width: 768px){.ai-assistant-drawer{width:100%;height:80dvh;top:auto;bottom:-80dvh;right:0;border-radius:20px 20px 0 0;border-left:none;border-top:1px solid var(--border)}.ai-assistant-drawer.open{bottom:0}.ai-footer{padding-bottom:calc(16px + env(safe-area-inset-bottom))}}.onboarding-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:3000;display:flex;align-items:center;justify-content:center;padding:20px;overflow:hidden}.onboarding-container{width:100%;max-width:500px;max-height:90vh;display:flex;animation:onboardingPop .4s cubic-bezier(.16,1,.3,1)}@keyframes onboardingPop{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.onboarding-card{background:var(--bg);border-radius:32px;box-shadow:0 40px 100px #0003;border:1px solid var(--border);display:flex;flex-direction:column;width:100%;overflow:hidden}.onboarding-header{display:flex;justify-content:space-between;align-items:center;padding:32px 40px 0;flex-shrink:0}.onboarding-body{flex:1;overflow-y:auto;padding:32px 40px;scrollbar-width:thin;scrollbar-color:var(--border2) transparent}.onboarding-body::-webkit-scrollbar{width:6px}.onboarding-body::-webkit-scrollbar-thumb{background-color:var(--border2);border-radius:10px}.onboarding-footer{display:flex;justify-content:space-between;align-items:center;padding:0 40px 32px;flex-shrink:0}.onboarding-progress{flex:1;margin-right:40px}.progress-text{font-size:12px;font-weight:800;color:var(--text3);margin-bottom:8px;text-transform:uppercase}.progress-bar-bg{height:6px;background:var(--bg3);border-radius:99px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--blue);transition:width .4s ease}.onboarding-skip-btn{background:transparent;border:none;color:var(--text3);font-size:13px;font-weight:700;cursor:pointer}.onboarding-skip-btn:hover{color:var(--text2)}.onboarding-step-title{font-size:24px;font-weight:900;margin:0 0 12px;letter-spacing:-.02em}.onboarding-step-desc{font-size:15px;color:var(--text2);margin-bottom:32px;line-height:1.6}.onboarding-form{display:flex;flex-direction:column;gap:20px}.onboarding-field{display:flex;flex-direction:column;gap:8px}.onboarding-field label{font-size:13px;font-weight:800;color:var(--text3)}.onboarding-field input,.onboarding-field select{height:48px;border-radius:12px;border:1.5px solid var(--border);padding:0 16px;font-size:15px;font-weight:600;background:var(--bg);color:var(--text);outline:none;transition:all .2s}.onboarding-field input:focus,.onboarding-field select:focus{border-color:var(--blue);box-shadow:0 0 0 4px var(--blue-soft)}.onboarding-result{text-align:center}.onboarding-success-icon{font-size:56px;margin-bottom:24px}.onboarding-result-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin:32px 0}.onboarding-result-metric{background:var(--bg2);padding:20px;border-radius:20px;text-align:left;border:1px solid var(--border)}.onboarding-result-metric .label{font-size:11px;font-weight:800;color:var(--text3);margin-bottom:8px;text-transform:uppercase}.onboarding-result-metric .value{font-size:18px;font-weight:900}.onboarding-result-actions{display:flex;flex-direction:column;gap:12px;margin-top:8px;width:100%}.onboarding-result-actions-secondary{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%}.onboarding-ai-suggestion{background:var(--blue-soft);border:1px solid rgba(59,130,246,.2);border-radius:20px;padding:24px;text-align:left}.ai-label{font-size:12px;font-weight:900;color:var(--blue);margin-bottom:8px}.onboarding-ai-suggestion p{font-size:14px;font-weight:600;line-height:1.6;color:var(--text);margin:0}@media (max-width: 1024px){.hero-kpi-grid,.summary-grid,.insight-grid{grid-template-columns:repeat(2,1fr)}.month-grid{grid-template-columns:repeat(3,1fr)}}.dream-overview{background:linear-gradient(135deg,var(--bg) 0%,var(--bg2) 100%);border:1px solid var(--border);border-radius:28px;padding:32px;margin-bottom:32px;box-shadow:var(--shadow)}.dream-overview-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:24px}.dream-overview-item{display:flex;flex-direction:column;gap:8px}.dream-overview-item .label{font-size:11px;font-weight:850;color:var(--text3);text-transform:uppercase;letter-spacing:.05em}.dream-overview-item .value{font-size:24px;font-weight:900;color:var(--text)}.dream-overview-footer{font-size:14px;color:var(--text2);font-weight:600;padding-top:20px;border-top:1px solid var(--border)}.dream-filter-tabs{display:flex;gap:8px;margin-bottom:24px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.dream-filter-tabs::-webkit-scrollbar{display:none}.dream-filter-tabs button{background:var(--bg3);border:none;padding:8px 20px;border-radius:99px;font-size:13px;font-weight:750;color:var(--text3);cursor:pointer;transition:all .2s;white-space:nowrap}.dream-filter-tabs button:hover{background:var(--border);color:var(--text2)}.dream-filter-tabs button.active{background:var(--text);color:var(--bg)}.dream-card{background:var(--bg);border:1px solid var(--border);border-radius:24px;padding:32px;margin-bottom:20px;transition:transform .2s,border-color .2s}.dream-card:hover{border-color:var(--blue);transform:translateY(-2px)}.dream-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.dream-card-title{font-size:20px;font-weight:900;margin:0;letter-spacing:-.02em}.dream-status-badge{font-size:10px;font-weight:850;padding:4px 12px;border-radius:8px;text-transform:uppercase}.status-achievable{background:#dcfce7;color:#166534}.status-saving{background:#e0f2fe;color:#0369a1}.status-waiting{background:#fef3c7;color:#92400e}.status-delay{background:#fee2e2;color:#991b1b}.status-planning{background:var(--bg3);color:var(--text3)}.dream-category-tag{font-size:12px;font-weight:700;color:var(--text3);background:var(--bg2);padding:2px 10px;border-radius:6px}.dream-priority-badge{font-size:11px;font-weight:800}.priority-high{color:var(--red)}.priority-medium{color:var(--blue)}.priority-low{color:var(--text3)}.dream-progress-section{margin-bottom:24px}.dream-progress-info{display:flex;justify-content:space-between;margin-bottom:10px;font-size:13px;font-weight:750}.dream-pct-text{font-size:18px;font-weight:900;color:var(--blue)}.dream-progress-bar-bg{height:10px;background:var(--bg3);border-radius:99px;overflow:hidden}.dream-progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--blue) 0%,#60a5fa 100%);transition:width .6s cubic-bezier(.34,1.56,.64,1)}.dream-meta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:24px;padding:20px;background:var(--bg2);border-radius:18px}.dream-meta-label{font-size:11px;font-weight:800;color:var(--text3);margin-bottom:6px;text-transform:uppercase}.dream-meta-value{font-size:15px;font-weight:850;color:var(--text)}.dream-impact-badge{font-size:11px;font-weight:850;padding:2px 10px;border-radius:6px}.dream-impact-badge.impact-high{background:#fee2e2;color:#991b1b}.dream-impact-badge.impact-low{background:#fef3c7;color:#92400e}.dream-impact-badge.impact-none{background:#dcfce7;color:#166534}.dream-ai-suggestion{background:var(--blue-soft);border-left:4px solid var(--blue);padding:20px;border-radius:0 16px 16px 0;margin-bottom:24px}.dream-ai-suggestion .ai-label{font-size:12px;font-weight:900;color:var(--blue);margin-bottom:6px}.dream-ai-suggestion p{font-size:14px;font-weight:600;line-height:1.6;color:var(--text);margin:0}.dream-roadmap-toggle{text-align:center;margin-bottom:20px}.roadmap-btn{background:transparent;border:none;font-size:13px;font-weight:800;color:var(--text3);cursor:pointer}.roadmap-btn:hover{color:var(--blue)}.dream-roadmap{display:flex;flex-direction:column;gap:0;padding:24px;background:var(--bg3);border-radius:20px;margin-bottom:24px;position:relative}.roadmap-step{display:flex;align-items:center;gap:16px;position:relative;padding-bottom:24px}.roadmap-step:last-child{padding-bottom:0}.step-number{width:28px;height:28px;border-radius:50%;background:var(--bg);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:900;z-index:2;flex-shrink:0}.roadmap-step.completed .step-number{background:var(--green);border-color:var(--green);color:#fff}.step-label{font-size:14px;font-weight:700;color:var(--text2)}.roadmap-step.completed .step-label{color:var(--text)}.step-line{position:absolute;top:28px;left:13px;width:2px;height:24px;background:var(--border);z-index:1}.roadmap-step.completed .step-line{background:var(--green)}.dream-note{font-size:13px;color:var(--text3);padding-top:16px;border-top:1px solid var(--border)}.dream-action-btn{background:var(--bg3);color:var(--text2);border:none;padding:6px 16px;border-radius:8px;font-size:12px;font-weight:800;cursor:pointer;transition:all .2s}.dream-action-btn:hover{background:var(--border)}.dream-action-btn.del:hover{background:#fee2e2;color:var(--red)}.dream-action-btn.confirming{background:var(--red);color:#fff}.dream-template-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px;align-items:center}.dream-template-chips.no-margin{margin-bottom:0;justify-content:center}.dream-template-chips .label{font-size:12px;font-weight:800;color:var(--text3)}.template-chip{background:var(--bg3);border:1.5px solid transparent;padding:6px 16px;border-radius:99px;font-size:12px;font-weight:750;color:var(--text2);cursor:pointer;transition:all .2s}.template-chip:hover{border-color:var(--blue);color:var(--blue)}.dream-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:24px 0}.form-field{display:flex;flex-direction:column;gap:8px}.form-field.full-width{grid-column:span 2}.form-field label{font-size:12px;font-weight:850;color:var(--text3);text-transform:uppercase}.dream-form-actions{display:flex;justify-content:flex-end;gap:16px;margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}.dream-no-results{text-align:center;padding:60px;color:var(--text3);font-weight:700;background:var(--bg2);border-radius:24px;border:2px dashed var(--border)}@media (max-width: 768px){.planning-main-content{grid-template-columns:1fr!important}.overview-grid{grid-template-columns:repeat(2,1fr)!important;gap:16px}.planning-overview{padding:24px 20px}.hierarchy-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.wishes-page{padding-bottom:140px!important}.dream-overview-grid{grid-template-columns:repeat(2,1fr)!important;gap:12px}.dream-meta-grid{grid-template-columns:1fr!important;gap:12px}.dream-form-grid{grid-template-columns:1fr!important;gap:16px!important}.form-field.full-width{grid-column:span 1!important}.form-field input,.form-field select{width:100%!important;max-width:100%!important}.dream-template-chips{margin:0 -16px 20px;padding:0 16px 8px;overflow-x:auto;display:flex!important;flex-wrap:nowrap!important;scrollbar-width:none;-webkit-overflow-scrolling:touch}.dream-template-chips::-webkit-scrollbar{display:none}.template-chip{flex:0 0 auto!important;white-space:nowrap!important;min-width:-moz-max-content!important;min-width:max-content!important;padding:10px 18px!important}.dream-money-field{display:flex!important;flex-direction:column!important;gap:8px!important;width:100%!important}.dream-currency-select,.dream-amount-input{width:100%!important}.dream-form-actions{flex-direction:column;gap:12px}.dream-form-actions button{width:100%!important}.dream-filter-tabs{padding-bottom:8px;margin:0 -16px 24px;padding-left:16px;padding-right:16px}}.records-page{display:flex;flex-direction:column;gap:20px;color:#0f172a}.records-page *{min-width:0}.records-page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:24px}.records-kicker{display:block;margin-bottom:8px;color:#64748b;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.records-page-header h1{margin:0;color:#0f172a;font-size:30px;line-height:1.15;letter-spacing:-.04em;font-weight:850}.records-page-header p{margin:8px 0 0;color:#64748b;font-size:14px;line-height:1.6}.records-header-actions,.records-confirm-actions,.records-empty-state div{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.records-header-actions button,.records-quick-entry-input button,.records-confirm-actions button,.records-empty-state button,.records-detail-head button,.records-submit-button{min-height:38px;padding:0 14px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;color:#334155;font-size:13px;font-weight:750;cursor:pointer;box-shadow:0 1px 2px #0f172a0a}.records-header-actions button:first-child,.records-quick-entry-input button,.records-confirm-actions button:first-child,.records-submit-button{background:#2563eb;border-color:#2563eb;color:#fff}.records-confirm-actions button:disabled{opacity:.45;cursor:not-allowed}.records-empty-state,.records-quick-entry,.records-detail-card,.records-recent-list,.records-timeline{background:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 1px 2px #0f172a0a}.records-empty-state{padding:20px}.records-empty-state h2{margin:0 0 8px;font-size:18px;letter-spacing:-.02em}.records-empty-state p{margin:0 0 16px;color:#64748b;font-size:14px;line-height:1.6}.records-quick-entry{padding:20px}.records-quick-entry-head{display:flex;justify-content:space-between;gap:18px;margin-bottom:16px}.records-quick-entry-head h2,.records-recent-head h2,.records-detail-head h2{margin:0;color:#0f172a;font-size:18px;letter-spacing:-.02em}.records-quick-entry-head p{margin:6px 0 0;color:#64748b;font-size:13px;line-height:1.6}.records-quick-entry-head>span{align-self:flex-start;padding:4px 9px;border-radius:999px;background:#f1f5f9;color:#475569;font-size:11px;font-weight:800;white-space:nowrap}.records-quick-entry-input{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px}.records-quick-entry-input input,.records-form-field input,.records-form-field select{width:100%;height:42px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;color:#0f172a;padding:0 12px;font-size:14px;outline:none}.records-quick-entry-input input:focus,.records-form-field input:focus,.records-form-field select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.records-quick-entry-chips,.records-year-tabs,.records-timeline-filters{display:flex;gap:8px;overflow-x:auto;padding:12px 0 2px;scrollbar-width:none}.records-quick-entry-chips::-webkit-scrollbar,.records-year-tabs::-webkit-scrollbar,.records-timeline-filters::-webkit-scrollbar{display:none}.records-quick-entry-chips button,.records-year-tabs button,.records-timeline-filters button{flex:0 0 auto;min-height:32px;padding:0 12px;border-radius:999px;border:1px solid #e5e7eb;background:#f8fafc;color:#475569;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}.records-year-tabs button.active,.records-timeline-filters button.active{background:#0f172a;border-color:#0f172a;color:#fff}.records-confirm-card{margin-top:16px;padding:16px;border:1px solid #e5e7eb;border-left:3px solid #2563eb;border-radius:16px;background:#f8fafc}.records-confirm-head{display:flex;justify-content:space-between;gap:14px;margin-bottom:12px}.records-confirm-head span,.records-detail-head span,.records-recent-head span{display:block;color:#64748b;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.records-confirm-head strong{display:block;margin-top:4px;color:#0f172a;font-size:15px}.records-confirm-head button{min-height:30px;padding:0 10px;border-radius:999px;border:1px solid #e5e7eb;background:#fff;color:#475569;font-size:12px;font-weight:750;cursor:pointer;white-space:nowrap}.records-confirm-warning{margin:0 0 10px;color:#b45309;font-size:12px;font-weight:700}.records-confirm-grid,.records-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.records-form-field{display:flex;flex-direction:column;gap:7px}.records-form-field span{color:#64748b;font-size:12px;font-weight:750}.records-form-wide,.records-form-amount{grid-column:1 / -1}.records-summary-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}.records-summary-card,.records-month-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 1px 2px #0f172a0a}.records-summary-card{padding:16px}.records-summary-card span{display:block;color:#64748b;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}.records-summary-card strong{display:block;margin-top:10px;color:#0f172a;font-size:18px;letter-spacing:-.02em}.records-summary-card strong.income,.records-record-row em.income{color:#047857}.records-summary-card strong.expense,.records-record-row em.expense{color:#b91c1c}.records-view-tabs{display:inline-flex;width:-moz-fit-content;width:fit-content;max-width:100%;gap:4px;padding:4px;border-radius:12px;background:#f1f5f9;overflow-x:auto}.records-view-tabs button{min-height:34px;padding:0 16px;border:0;border-radius:9px;background:transparent;color:#64748b;font-size:13px;font-weight:750;cursor:pointer;white-space:nowrap}.records-view-tabs button.active{background:#fff;color:#0f172a;box-shadow:0 1px 2px #0f172a0f}.records-month-view{display:flex;flex-direction:column;gap:14px}.records-month-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.records-month-card{padding:16px;text-align:left;cursor:pointer;transition:border-color .18s,box-shadow .18s}.records-month-card:hover,.records-month-card.selected{border-color:#2563eb;box-shadow:0 8px 18px #0f172a0f}.records-month-card-head{display:flex;justify-content:space-between;gap:12px;margin-bottom:14px}.records-month-card-head strong{font-size:16px;color:#0f172a}.records-month-card-head span{align-self:flex-start;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:800;white-space:nowrap}.records-month-card-head .good{background:#ecfdf5;color:#047857}.records-month-card-head .risk{background:#fef2f2;color:#b91c1c}.records-month-card-head .neutral{background:#f1f5f9;color:#64748b}.records-month-card-lines{display:flex;flex-direction:column;gap:8px}.records-month-card-lines p{display:flex;justify-content:space-between;gap:12px;margin:0;color:#64748b;font-size:13px}.records-month-card-lines strong{color:#0f172a;font-weight:800}.records-month-card-lines strong.income{color:#047857}.records-month-card-lines strong.expense{color:#b91c1c}.records-detail-card{padding:20px}.records-detail-head{display:flex;justify-content:space-between;gap:16px;margin-bottom:16px}.records-detail-grid{display:grid;grid-template-columns:minmax(240px,.72fr) minmax(0,1.28fr);gap:14px}.records-month-summary-card,.records-entry-form{background:#f8fafc;border:1px solid #e5e7eb;border-radius:16px;padding:16px}.records-month-summary-metrics{display:grid;gap:10px;margin-bottom:14px}.records-month-summary-metrics div{padding:12px;border-radius:12px;background:#fff;border:1px solid #e5e7eb}.records-month-summary-metrics span,.records-month-ai-summary span{display:block;margin-bottom:6px;color:#64748b;font-size:11px;font-weight:800;text-transform:uppercase}.records-month-summary-metrics strong{color:#0f172a;font-size:18px}.records-month-summary-metrics strong.income{color:#047857}.records-month-summary-metrics strong.expense{color:#b91c1c}.records-month-ai-summary p{margin:0;color:#64748b;font-size:13px;line-height:1.6}.records-type-toggle{display:inline-flex;gap:4px;padding:4px;border-radius:12px;background:#e5e7eb;margin-bottom:14px}.records-type-toggle button{min-height:32px;padding:0 14px;border:0;border-radius:9px;background:transparent;color:#64748b;font-size:13px;font-weight:800;cursor:pointer}.records-type-toggle button.active{background:#fff;color:#0f172a}.amount-input-wrap{display:flex;align-items:center;gap:10px;height:56px;padding:0 14px;border:1px solid #e5e7eb;border-radius:14px;background:#fff}.amount-input-wrap:focus-within{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.amount-input-wrap b{color:#2563eb;font-size:20px}.amount-input-wrap input{border:0!important;background:transparent!important;padding:0!important;color:#0f172a;font-size:26px!important;font-weight:850!important;outline:none}.records-category-chips{display:flex;flex-direction:column;gap:8px}.records-category-chips>div{display:flex;flex-wrap:wrap;gap:8px}.chip{min-height:30px;padding:0 11px;border-radius:999px;border:1px solid #e5e7eb;background:#fff;color:#475569;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}.chip.active{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.chip.level2.active{background:#0f172a;border-color:#0f172a;color:#fff}.records-submit-button{width:100%;margin-top:12px}.records-entry-list{margin-top:16px}.records-entry-list h3{margin:0 0 10px;font-size:16px}.records-record-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:12px;padding:12px;border:1px solid #e5e7eb;border-radius:14px;background:#fff;margin-top:8px}.records-record-row strong{display:block;color:#0f172a;font-size:14px}.records-record-row span{display:block;margin-top:4px;color:#64748b;font-size:12px}.records-record-row em{font-style:normal;font-weight:850;white-space:nowrap}.records-record-row button{min-height:30px;padding:0 10px;border:1px solid #fee2e2;border-radius:8px;background:#fef2f2;color:#b91c1c;font-size:12px;font-weight:750;cursor:pointer}.records-empty-hint{margin:0;padding:16px;border-radius:14px;background:#f8fafc;color:#64748b;font-size:13px;line-height:1.6}.records-recent-list{padding:20px}.records-recent-head{margin-bottom:12px}.records-timeline{padding:20px}.records-timeline-filters{padding-top:0;margin-bottom:8px}.records-timeline-empty{padding:30px 16px;border-radius:16px;background:#f8fafc;color:#64748b;font-size:14px;line-height:1.6;text-align:center}.timeline-view{display:flex;flex-direction:column;padding-top:8px}.timeline-event-card{display:flex;gap:16px;position:relative}.timeline-event-marker{display:flex;flex-direction:column;align-items:center;min-width:24px}.marker-line{width:1px;flex:1;background:#e5e7eb}.marker-dot{width:10px;height:10px;border-radius:50%;background:#cbd5e1;border:2px solid #fff;z-index:2}.marker-dot.positive{background:#10b981}.marker-dot.danger{background:#ef4444}.marker-dot.ai{background:#2563eb}.marker-dot.warning{background:#f59e0b}.marker-pulse{display:none}.timeline-event-content{flex:1;background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:16px;margin-bottom:12px}.event-header,.event-body{display:flex;align-items:flex-start;gap:12px}.event-header{justify-content:space-between;margin-bottom:12px}.event-date{color:#64748b;font-size:12px;font-weight:750}.event-tag{padding:3px 8px;border-radius:999px;background:#f1f5f9;color:#475569;font-size:11px;font-weight:800}.event-tag.positive{background:#ecfdf5;color:#047857}.event-tag.danger{background:#fef2f2;color:#b91c1c}.event-tag.ai{background:#eff6ff;color:#1d4ed8}.event-icon-wrap{width:38px;height:38px;flex:0 0 auto;display:grid;place-items:center;border-radius:12px;background:#f8fafc;border:1px solid #e5e7eb;color:#475569;font-size:11px;font-weight:850}.event-info{flex:1}.event-title{margin:0 0 4px;color:#0f172a;font-size:15px;font-weight:820}.event-desc{margin:0;color:#64748b;font-size:13px;line-height:1.55}.event-amount{color:#0f172a;font-size:13px;font-weight:850}.event-example-badge{margin-top:10px;color:#64748b;font-size:11px;font-weight:750}@media (max-width: 1080px){.records-page-header{align-items:flex-start;flex-direction:column}.records-summary-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.records-month-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.records-detail-grid{grid-template-columns:1fr}}@media (max-width: 640px){.records-page{gap:16px}.records-page-header h1{font-size:26px}.records-header-actions,.records-empty-state div,.records-confirm-actions{display:grid;grid-template-columns:1fr 1fr;width:100%}.records-header-actions button,.records-empty-state button,.records-confirm-actions button{width:100%}.records-quick-entry,.records-detail-card,.records-recent-list,.records-timeline,.records-empty-state{padding:16px;border-radius:16px}.records-quick-entry-head,.records-confirm-head,.records-detail-head{flex-direction:column;align-items:flex-start}.records-quick-entry-input,.records-confirm-grid,.records-form-grid,.records-summary-grid,.records-month-grid{grid-template-columns:1fr}.records-view-tabs{width:100%}.records-view-tabs button{flex:1}.records-record-row{grid-template-columns:1fr;align-items:flex-start}.event-body{flex-direction:column}.amount-input-wrap input{font-size:22px!important}}:root{--header-height: 64px;--nav-bar-height: calc(64px + env(safe-area-inset-bottom)) }html,body,#root{min-height:100dvh;margin:0;padding:0;display:flex;flex-direction:column;overflow-x:hidden}body{overflow-x:hidden;overflow-y:auto;background:var(--bg);-webkit-overflow-scrolling:touch}.app{display:flex;flex-direction:column;flex:1;overflow-x:hidden}.app-main{flex:1;position:relative;display:flex;flex-direction:column;overflow-x:hidden}.app-shell-container{display:flex;min-height:100vh;background:var(--bg)}.app-sidebar{display:none}.app-main-view{flex:1;display:flex;flex-direction:column;min-width:0;background:#f8fafc}.app-header-toolbar{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:100}.header-page-title{font-size:16px;font-weight:700;color:#0f172a;margin:0}.header-plan-button{display:flex;align-items:center;gap:8px;padding:6px 14px;border-radius:8px;background:#f1f5f9;border:1px solid #e2e8f0;font-size:13px;font-weight:600;color:#475569;cursor:pointer;transition:all .2s}.header-plan-button:hover{background:#e2e8f0}.plan-label-prefix{opacity:.6;font-weight:500}.picker-arrow{font-size:10px;opacity:.5}.app-page-content{flex:1;padding:24px 24px 40px;width:100%;max-width:1200px;margin:0 auto;box-sizing:border-box}.app-page-content>*:not(.onboarding-overlay):not(.ai-assistant-drawer):not(.ai-assistant-button){width:100%}@media (min-width: 1025px){.app-sidebar{display:flex;flex-direction:column;width:240px;height:100vh;position:fixed;top:0;left:0;background:#fff;border-right:1px solid #e5e7eb;z-index:3900}.app-main-view{margin-left:240px}.sidebar-brand-area{padding:20px 24px}.sidebar-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:#0f172a}.logo-icon{width:28px;height:28px;background:#0f172a;color:#fff;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:850}.logo-text{font-size:16px;font-weight:800;letter-spacing:-.01em}.sidebar-nav-container{flex:1;display:flex;flex-direction:column;padding:12px 16px 24px}.sidebar-nav-group{flex:1;display:flex;flex-direction:column;gap:4px}.sidebar-nav-footer{display:flex;flex-direction:column;gap:4px;padding-top:12px;border-top:1px solid #f1f5f9}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;text-decoration:none;color:#64748b;font-size:14px;font-weight:600;transition:all .2s}.nav-item:hover{background:#f1f5f9;color:#0f172a}.nav-item.active{background:#f1f5f9;color:var(--primary)}.nav-icon{font-size:16px;width:20px;display:flex;justify-content:center}}@media (max-width: 1024px){.app-sidebar{display:none}.app-main-view{margin-left:0;background:#fff}.app-header-toolbar{padding:0 16px}.app-page-content{padding:16px 16px 32px}.mobile-brand-logo img{width:32px;height:32px}}.mobile-capsule-nav{display:none}@media (max-width: 768px){.app-shell-container{padding-bottom:calc(96px + env(safe-area-inset-bottom))}.app-page-content{padding-bottom:calc(100px + env(safe-area-inset-bottom))}.mobile-capsule-nav{display:grid;grid-template-columns:1fr 1fr 64px 1fr 1fr;align-items:center;position:fixed;bottom:calc(16px + env(safe-area-inset-bottom));left:50%;transform:translate(-50%);width:calc(100% - 32px);max-width:480px;height:56px;background:#fffffff5;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(0,0,0,.06);border-radius:999px;box-shadow:0 10px 25px -5px #00000014,0 8px 10px -6px #00000003;z-index:3500;padding:0 4px;overflow:visible}.capsule-item{display:flex;flex-direction:column;align-items:center;justify-content:center;text-decoration:none;color:#475569;height:100%;position:relative;transition:all .2s}.capsule-item.active{color:#2563eb;background:#00000008}.mobile-capsule-nav .capsule-item:first-child.active{border-radius:999px 0 0 999px}.mobile-capsule-nav .capsule-item:last-child.active{border-radius:0 999px 999px 0}.capsule-item .icon{width:20px;height:20px;stroke-width:2.2}.capsule-item .tooltip{position:absolute;bottom:68px;left:50%;transform:translate(-50%) translateY(4px);background:#1e293b;color:#fff;padding:5px 12px;border-radius:10px;font-size:11px;font-weight:700;white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s cubic-bezier(.16,1,.3,1);box-shadow:0 4px 12px #00000026}.capsule-item .tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#1e293b}.capsule-item.active .tooltip{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.capsule-center{display:flex;justify-content:center;align-items:center}.add-main-btn{width:44px;height:44px;background:#2563eb;color:#fff;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #2563eb4d;cursor:pointer;transition:transform .2s}.add-main-btn:active{transform:scale(.92)}.add-main-btn svg{width:24px;height:24px}.ai-assistant-button{bottom:calc(96px + env(safe-area-inset-bottom))!important;right:20px!important;padding:0 16px!important;height:44px!important;border-radius:22px!important}}@media (min-width: 769px){.mobile-capsule-nav{display:none}}.workspace-shell{display:grid;grid-template-columns:96px minmax(0,1fr);width:100%;min-height:100vh;background:#f8fafc;color:#0f172a}.workspace-rail{position:fixed;left:20px;top:16px;bottom:16px;width:52px;height:auto;max-height:none;display:flex;flex-direction:column;align-items:center;gap:0;margin:0;padding:12px 6px;background:#fff;border:1px solid #e5e7eb;border-radius:20px;box-shadow:0 10px 24px #0f172a0d;overflow:hidden;z-index:200}.workspace-rail-logo{width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;background:#f8f8f8;border:1px solid #ededed;box-shadow:0 8px 18px #0f172a14;text-decoration:none;flex:0 0 auto}.workspace-rail-logo img{width:21px;height:21px;display:block;border-radius:9px}.workspace-rail-nav,.workspace-rail-bottom{display:flex;flex-direction:column;align-items:center;gap:9px;width:100%}.workspace-rail-nav{flex:1;min-height:0;padding-top:30px;overflow:hidden}.workspace-rail-bottom{flex:0 0 auto;margin-top:auto;padding-top:16px;border-top:0}.workspace-nav-item{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;color:#a3a3a3;text-decoration:none;transition:background .18s,color .18s,box-shadow .18s}.workspace-nav-item:hover{background:#fafafa;color:#737373}.workspace-nav-item.active{background:#f7f7f7;color:#6b6b6b;box-shadow:inset 0 0 0 1px #e5e5e5b3}.workspace-rail-icon{width:21px;height:21px}.workspace-avatar{position:relative;width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#fff;color:#737373;border:1px solid #e5e5e5;text-decoration:none;box-shadow:0 1px 2px #0f172a0f}.workspace-avatar span{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:inherit;background:#f5f5f5;color:#525252;font-size:13px;font-weight:800}.workspace-avatar:after{content:"";position:absolute;right:2px;bottom:3px;width:11px;height:11px;border-radius:999px;background:#22c55e;border:2px solid #ffffff}.workspace-avatar:hover,.workspace-avatar.active{border-color:#d4d4d4;background:#fafafa;color:#262626}.workspace-sidebar{position:fixed;left:84px;top:16px;bottom:16px;width:260px;height:auto;display:flex;flex-direction:column;padding:22px 14px;background:#fff;border:1px solid #e5e7eb;border-radius:22px;box-shadow:0 18px 40px #0f172a14;opacity:0;visibility:hidden;transform:translate(-8px);pointer-events:none;transition:opacity .16s,visibility .16s,transform .16s;z-index:150}.workspace-sidebar.open{opacity:1;visibility:visible;transform:translate(0);pointer-events:auto}.workspace-sidebar-head{padding:6px 10px 18px}.workspace-sidebar-head span{display:block;color:#94a3b8;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px}.workspace-sidebar-head h2{margin:0;color:#0f172a;font-size:20px;line-height:1.2;letter-spacing:-.03em;font-weight:850}.workspace-sidebar-nav{display:flex;flex-direction:column;gap:4px}.workspace-subnav-item{min-height:38px;display:flex;align-items:center;padding:0 10px;border-radius:10px;color:#64748b;text-decoration:none;font-size:14px;font-weight:650;transition:background .18s,color .18s}.workspace-subnav-item:hover{background:#f8fafc;color:#0f172a}.workspace-subnav-item.active{background:#f1f5f9;color:#0f172a}.workspace-main{grid-column:2 / -1;min-width:0;min-height:100vh;display:flex;flex-direction:column;background:#f8fafc}.workspace-content{flex:1;min-width:0}.workspace-main .app-header-toolbar{height:58px;padding:0 28px;background:#f8fafce6;border-bottom:1px solid #e5e7eb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.workspace-main .header-left-side,.workspace-main .header-right-side{display:flex;align-items:center;min-width:0}.workspace-main .header-page-title{color:#0f172a;font-size:15px;font-weight:780;letter-spacing:-.01em}.workspace-main .header-plan-button{border:1px solid #e5e7eb;background:#fff;color:#475569;border-radius:10px;box-shadow:0 1px 2px #0f172a0a}.workspace-main .app-page-content{max-width:1240px;padding:28px 28px 44px}.workspace-section{width:100%}.workspace-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 1px 2px #0f172a0a}.workspace-page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:22px}.workspace-page-header h1{margin:0;color:#0f172a;font-size:28px;line-height:1.15;letter-spacing:-.035em;font-weight:850}.workspace-page-header p{margin:8px 0 0;color:#64748b;font-size:14px;line-height:1.55}.workspace-page-header-action{flex:0 0 auto}.desktop-hidden{display:none}@media (max-width: 1024px){.workspace-shell{display:block;min-height:100vh;background:#fff}.workspace-rail,.workspace-sidebar{display:none}.workspace-main{min-height:100vh;background:#fff}.workspace-main .app-header-toolbar{height:56px;padding:0 16px;background:#fff}.workspace-main .app-page-content{max-width:1200px;padding:16px 16px 32px}.desktop-hidden{display:inline-flex}}input,select,textarea{font-size:16px!important}.ai-assistant-button{position:fixed;bottom:32px;right:32px;background:var(--text);color:var(--bg);border:none;border-radius:99px;padding:12px 24px;display:flex;align-items:center;gap:10px;font-weight:800;cursor:pointer;box-shadow:0 10px 30px #0003;z-index:3000;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.ai-assistant-button:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 15px 40px #00000040}.ai-btn-icon{font-size:20px}.ai-btn-text{font-size:14px;letter-spacing:.02em}@media (max-width: 768px){:root{--header-height: 60px}.app{padding-bottom:0}.app>*:not(.header):not(.mobile-nav-bar):not(.onboarding-overlay):not(.ai-assistant-drawer):not(.ai-assistant-button){padding:12px 16px calc(var(--nav-bar-height) + 40px)}.section-head{margin-top:0!important;margin-bottom:20px!important}.header{height:var(--header-height);padding:0 16px;position:sticky;top:0;background:#fffc;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);z-index:3800}.header .page-tabs{display:none}.header-plan-button{padding:6px 12px;font-size:13px}.brand-name{font-size:18px}.brand h1{display:none}.mobile-nav-bar{display:block}.ai-assistant-button{bottom:calc(var(--nav-bar-height) + 16px);right:16px;width:auto;max-width:calc(100vw - 32px);height:48px;padding:0 16px;z-index:3800}}.planning-page{display:flex;flex-direction:column;gap:32px}.planning-quick-actions{display:flex;gap:12px}.planning-overview{background:linear-gradient(135deg,var(--bg) 0%,var(--bg2) 100%);border:1px solid var(--border);border-radius:28px;padding:32px;box-shadow:var(--shadow)}.overview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--border)}.overview-header .label{font-size:11px;font-weight:850;color:var(--text3);text-transform:uppercase;margin-bottom:4px}.overview-header .goal-name{font-size:24px;font-weight:900;margin:0;color:var(--text)}.progress-badge{display:flex;flex-direction:column;align-items:flex-end}.progress-badge .pct{font-size:32px;font-weight:950;color:var(--blue);line-height:1}.progress-badge .lbl{font-size:10px;font-weight:800;color:var(--text3);text-transform:uppercase;margin-top:4px}.overview-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:24px}.overview-item .lbl{font-size:11px;font-weight:800;color:var(--text3);margin-bottom:8px}.overview-item .val{font-size:15px;font-weight:850;color:var(--text)}.planning-main-content{display:grid;grid-template-columns:1fr 400px;gap:24px;align-items:flex-start}.planning-left-col,.planning-right-col{display:flex;flex-direction:column;gap:24px}.planning-risk-card{border-left:4px solid var(--border);transition:all .2s}.planning-risk-card.high{border-left-color:var(--red);background:#ef444405}.planning-risk-card.medium{border-left-color:var(--amber);background:#f59e0b05}.planning-risk-card.low{border-left-color:var(--green);background:#10b98105}.risk-header{margin-bottom:12px}.risk-indicator{font-size:13px;font-weight:900;padding:4px 12px;border-radius:8px;text-transform:uppercase}.risk-indicator.high{background:#fee2e2;color:#991b1b}.risk-indicator.medium{background:#fef3c7;color:#92400e}.risk-indicator.low{background:#dcfce7;color:#166534}.risk-desc{font-size:14px;color:var(--text2);line-height:1.6;font-weight:600;margin-bottom:20px}.backcast-stats{display:flex;flex-direction:column;gap:12px;padding-top:16px;border-top:1px dashed var(--border)}.stat-row{display:flex;justify-content:space-between;font-size:13px;font-weight:750;color:var(--text3)}.stat-row .val{color:var(--text);font-weight:850}.stat-row .val.red{color:var(--red)}.stat-row .val.green{color:var(--green)}.roadmap-container{display:flex;flex-direction:column;gap:0;position:relative;padding:10px 0}.roadmap-stage{display:flex;gap:20px;padding-bottom:32px;position:relative}.roadmap-stage:last-child{padding-bottom:0}.stage-marker{display:flex;flex-direction:column;align-items:center;width:32px;flex-shrink:0}.stage-num{width:32px;height:32px;border-radius:50%;background:var(--bg2);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900;color:var(--text3);z-index:2;position:relative;transition:all .3s}.stage-line{width:2px;flex:1;background:var(--border);z-index:1;margin:4px 0}.roadmap-stage.completed .stage-num{background:var(--blue);border-color:var(--blue);color:#fff}.roadmap-stage.completed .stage-line{background:var(--blue)}.stage-content{flex:1}.stage-title{font-size:15px;font-weight:900;color:var(--text);margin-bottom:6px}.stage-desc{font-size:13px;color:var(--text2);line-height:1.5;font-weight:500;margin:0}.planning-selector-card .current-plan-display{background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:20px;margin-bottom:32px}.plan-picker-wrap{position:relative;margin-bottom:16px}.plan-picker-trigger{width:100%;display:flex;justify-content:space-between;align-items:center;background:var(--bg);border:2.5px solid var(--border);border-radius:12px;padding:12px 20px;font-size:15px;font-weight:900;color:var(--text);cursor:pointer;transition:all .2s}.plan-picker-trigger:hover{border-color:var(--blue)}.plan-picker-menu{position:absolute;top:100%;left:0;right:0;background:var(--bg);border:1px solid var(--border);border-radius:16px;margin-top:8px;box-shadow:var(--shadow-lg);z-index:100;max-height:300px;overflow-y:auto;padding:8px}.plan-picker-menu .menu-item{width:100%;text-align:left;background:transparent;border:none;padding:10px 16px;font-size:14px;font-weight:700;color:var(--text2);border-radius:10px;cursor:pointer;transition:all .2s}.plan-picker-menu .menu-item:hover{background:var(--bg3);color:var(--blue)}.plan-picker-menu .menu-item.active{background:var(--blue-soft);color:var(--blue)}.hierarchy-actions{display:flex;gap:8px;flex-wrap:wrap}.subgoal-section h4{font-size:14px;font-weight:900;color:var(--text3);text-transform:uppercase;margin-bottom:16px}.subgoal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.subgoal-grid{display:flex;flex-direction:column;gap:16px}.planning-subgoal-card{background:var(--bg);border:1.5px solid var(--border);border-radius:18px;padding:20px;transition:transform .2s}.planning-subgoal-card:hover{transform:scale(1.01);border-color:var(--blue)}.planning-subgoal-card .card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.planning-subgoal-card .card-title{font-size:15px;font-weight:900;margin:0}.planning-subgoal-card .plan-status-tag{font-size:10px;font-weight:900;padding:2px 8px;border-radius:6px;text-transform:uppercase;background:var(--bg3)}.planning-subgoal-card .plan-status-tag.on-track{background:#dcfce7;color:#166534}.subgoal-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px;padding-top:16px;border-top:1px dashed var(--border)}.subgoal-meta-grid .lbl{font-size:10px;font-weight:800;color:var(--text3);margin-bottom:4px}.subgoal-meta-grid .val{font-size:13px;font-weight:850;color:var(--text)}.planning-ai-advice .advice-list{display:flex;flex-direction:column;gap:16px}.advice-item{display:flex;gap:16px;align-items:flex-start}.advice-item .icon{font-size:18px}.advice-item p{font-size:13px;color:var(--text2);font-weight:600;line-height:1.6;margin:0}.planning-empty-state{border:2px dashed var(--border);padding:60px 40px}@media (max-width: 1024px){.planning-main-content{grid-template-columns:1fr}.overview-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 700px){.overview-grid{grid-template-columns:repeat(2,1fr)}.overview-header{flex-direction:column;align-items:flex-start;gap:24px}.progress-badge{align-items:flex-start}}.analytics-page{display:flex;flex-direction:column;gap:32px}.analytics-range-tabs{display:flex;gap:8px;background:var(--bg3);padding:4px;border-radius:12px}.analytics-range-tabs button{padding:6px 16px;border:none;background:transparent;font-size:13px;font-weight:750;color:var(--text3);border-radius:9px;cursor:pointer;transition:all .2s}.analytics-range-tabs button.active{background:var(--bg);color:var(--blue);box-shadow:var(--shadow)}.analytics-summary-header{background:linear-gradient(135deg,var(--bg) 0%,var(--bg2) 100%);border:1px solid var(--border);border-radius:28px;padding:40px;box-shadow:var(--shadow)}.analytics-summary-header .label{font-size:11px;font-weight:850;color:var(--blue);text-transform:uppercase;margin-bottom:20px;letter-spacing:.1em}.summary-content{display:flex;flex-direction:column;gap:16px}.summary-status-row{display:flex;gap:12px;flex-wrap:wrap}.status-badge{font-size:11px;font-weight:900;padding:4px 12px;border-radius:6px}.status-badge.positive{background:#dcfce7;color:#166534}.status-badge.risk{background:#fee2e2;color:#991b1b}.data-badge{font-size:11px;font-weight:700;color:var(--text3);padding:4px 0}.analytics-summary-header .summary-text{font-size:24px;font-weight:950;line-height:1.4;margin:0;color:var(--text)}.summary-details{display:flex;flex-direction:column;gap:12px;margin-top:8px;padding-top:24px;border-top:1px dashed var(--border)}.summary-details .detail-item{font-size:15px;color:var(--text2);line-height:1.6;font-weight:550}.summary-details strong{color:var(--text);font-weight:800}.analytics-section-title{font-size:14px;font-weight:900;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:-16px}.analytics-finding-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.analytics-finding-card{background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:20px;display:flex;gap:16px;transition:transform .2s}.analytics-finding-card:hover{transform:translateY(-2px);border-color:var(--blue)}.analytics-finding-card.high{border-left:4px solid var(--red);background:#ef444405}.analytics-finding-card.medium{border-left:4px solid var(--amber)}.analytics-finding-card.low{border-left:4px solid var(--blue)}.analytics-finding-card .card-icon{font-size:24px;background:var(--bg2);width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.analytics-finding-card .card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.analytics-finding-card .card-title{font-size:15px;font-weight:900;color:var(--text)}.analytics-finding-card .card-tag{font-size:10px;font-weight:850;padding:2px 8px;background:var(--bg3);border-radius:6px;color:var(--text3)}.analytics-finding-card .card-desc{font-size:13px;color:var(--text2);line-height:1.5;margin:0;font-weight:600}.analytics-suggestion-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.analytics-suggestion-card{background:var(--bg2);border:1px solid var(--border);border-radius:24px;padding:24px;display:flex;flex-direction:column;gap:16px}.analytics-suggestion-card .card-header{display:flex;justify-content:space-between;align-items:center}.analytics-suggestion-card .card-title{font-size:16px;font-weight:950;color:var(--blue)}.analytics-suggestion-card .card-priority{font-size:10px;font-weight:900;padding:4px 10px;border-radius:6px;background:var(--blue-soft);color:var(--blue)}.analytics-suggestion-card .card-priority.高{background:#fee2e2;color:#991b1b}.analytics-suggestion-card .card-desc{font-size:14px;color:var(--text);font-weight:600;line-height:1.6;margin:0}.analytics-suggestion-card .card-footer{display:flex;gap:24px;padding-top:16px;border-top:1px dashed var(--border)}.analytics-suggestion-card .footer-item{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:750}.analytics-suggestion-card .lbl{color:var(--text3)}.analytics-suggestion-card .val{color:var(--text2)}.analytics-kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.analytics-chart-card{background:var(--bg);border:1px solid var(--border);border-radius:32px;padding:32px;box-shadow:var(--shadow);min-height:auto}.chart-tabs{display:flex;gap:8px;overflow-x:auto;margin-bottom:24px;padding-bottom:4px;scrollbar-width:none}.chart-tab{background:var(--bg3);border:none;padding:8px 20px;border-radius:99px;font-size:13px;font-weight:800;color:var(--text3);cursor:pointer;transition:all .2s;white-space:nowrap}.chart-tab.active{background:var(--text);color:var(--bg)}.chart-container{height:360px;max-height:420px;position:relative;margin-bottom:24px}.chart-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:var(--text3)}.fallback-icon{font-size:40px;margin-bottom:16px;opacity:.5}.chart-footer-explanation{display:flex;gap:12px;align-items:flex-start;padding:20px;background:var(--bg2);border-radius:16px}.settings-account-card{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:18px;margin:18px 0 4px;display:flex;justify-content:space-between;align-items:center;gap:20px}.account-info-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;flex:1;min-width:0}.account-meta-item{min-width:0;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:12px}.account-meta-item .lbl{font-size:11px;font-weight:750;color:var(--text3);margin-bottom:6px}.account-meta-item .val{font-size:13px;font-weight:750;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-page{max-width:1040px;margin:0 auto 48px;color:#0f172a}.profile-cover{position:relative;min-height:220px;border:1px solid #e5e7eb;border-radius:20px;overflow:hidden;box-shadow:0 1px 2px #0f172a0a,0 12px 32px #0f172a0a}.profile-cover:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.28) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.28) 1px,transparent 1px);background-size:28px 28px;opacity:.42}.profile-cover-slate{background:linear-gradient(135deg,#e2e8f0,#f8fafc 52%,#dbeafe)}.profile-cover-mist{background:linear-gradient(135deg,#ecfeff,#f8fafc 55%,#eef2ff)}.profile-cover-sand{background:linear-gradient(135deg,#f5f5f4,#fff 52%,#e7e5e4)}.profile-cover button{position:absolute;right:18px;bottom:18px;z-index:1;min-height:36px;padding:0 13px;border:1px solid rgba(148,163,184,.42);border-radius:10px;background:#ffffffc7;color:#64748b;font-size:13px;font-weight:750}.profile-header{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:end;gap:20px;margin:-48px 24px 22px;position:relative;z-index:2}.profile-avatar{display:flex;flex-direction:column;align-items:center;gap:9px}.profile-avatar>img,.profile-avatar>span{width:104px;height:104px;display:inline-flex;align-items:center;justify-content:center;border:4px solid #ffffff;border-radius:999px;background:#f8fafc;color:#0f172a;font-size:34px;font-weight:850;-o-object-fit:cover;object-fit:cover;box-shadow:0 10px 24px #0f172a1f}.profile-avatar button{min-height:32px;padding:0 10px;border:1px solid #e5e7eb;border-radius:9px;background:#fff;color:#64748b;font-size:12px;font-weight:750}.profile-header-main{min-width:0;padding-bottom:10px}.profile-header-main>span,.profile-card-head>span{display:block;margin-bottom:6px;color:#64748b;font-size:11px;font-weight:820;letter-spacing:.07em;text-transform:uppercase}.profile-header-main h1{margin:0;color:#0f172a;font-size:30px;line-height:1.15;letter-spacing:-.035em;font-weight:850}.profile-header-main p{margin:6px 0 0;color:#64748b;font-size:14px;font-weight:650}.profile-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding-bottom:13px;flex-wrap:wrap}.profile-actions a,.profile-actions button,.profile-danger{min-height:38px;display:inline-flex;align-items:center;justify-content:center;padding:0 14px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;color:#334155;font-size:13px;font-weight:760;text-decoration:none;cursor:pointer;box-shadow:0 1px 2px #0f172a0a}.profile-actions button:last-child{background:#2563eb;border-color:#2563eb;color:#fff}.profile-grid{display:grid;grid-template-columns:minmax(280px,.8fr) minmax(0,1.2fr);gap:16px}.profile-card{min-width:0;background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:20px;box-shadow:0 1px 2px #0f172a0a}.profile-card-head{margin-bottom:18px}.profile-card-head h2{margin:0;color:#0f172a;font-size:17px;line-height:1.25;letter-spacing:-.02em;font-weight:820}.profile-info-list{display:flex;flex-direction:column;gap:10px}.profile-info-list div{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px;border:1px solid #e5e7eb;border-radius:14px;background:#f8fafc}.profile-info-list span,.profile-field>span{color:#64748b;font-size:12px;font-weight:740}.profile-info-list strong{min-width:0;overflow:hidden;color:#0f172a;font-size:13px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.profile-status-good{color:#047857!important}.profile-danger{width:100%;margin-top:14px;border-color:#ef44444d;background:#ef44440f;color:#b91c1c}.profile-form{grid-row:span 2}.profile-field{display:grid;grid-template-columns:150px minmax(0,1fr);align-items:center;gap:16px;padding:14px 0;border-bottom:1px solid #e5e7eb}.profile-field:last-child{border-bottom:0}.profile-field input,.profile-field select{width:100%;min-height:42px;border:1px solid #e5e7eb;border-radius:11px;background:#fff;color:#0f172a;padding:0 12px;font:inherit;font-size:14px;font-weight:650;outline:none}.profile-field input:focus,.profile-field select:focus{border-color:#93c5fd;box-shadow:0 0 0 3px #2563eb1f}.profile-field input:disabled,.profile-field select:disabled{background:#f8fafc;color:#64748b;cursor:not-allowed}.profile-avatar-preview{width:54px;height:54px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #e5e7eb;border-radius:999px;background:#f8fafc;color:#0f172a;font-size:18px;font-weight:850;overflow:hidden}.profile-avatar-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.profile-rules p{margin:0 0 10px;color:#64748b;font-size:13px;line-height:1.55}@media (max-width: 768px){.chart-container{height:280px;max-height:320px}.settings-account-card{flex-direction:column;align-items:stretch;gap:20px}.account-info-grid{grid-template-columns:1fr;gap:10px}.profile-page{margin-bottom:32px}.profile-cover{min-height:150px;border-radius:16px}.profile-cover button{right:12px;bottom:12px}.profile-header{grid-template-columns:1fr;align-items:start;gap:12px;margin:-42px 16px 18px}.profile-avatar{align-items:flex-start}.profile-avatar>img,.profile-avatar>span{width:88px;height:88px;font-size:28px}.profile-header-main{padding-bottom:0}.profile-header-main h1{font-size:26px}.profile-actions{width:100%;justify-content:stretch;padding-bottom:0}.profile-actions a,.profile-actions button{flex:1 1 auto}.profile-grid{grid-template-columns:1fr;gap:14px}.profile-form{grid-row:auto}.profile-card{border-radius:16px;padding:16px}.profile-field{grid-template-columns:1fr;gap:8px}.profile-info-list div{align-items:flex-start;flex-direction:column;gap:5px}}.expl-icon{font-size:18px;opacity:.6}.expl-text{font-size:13px;color:var(--text2);line-height:1.5;font-weight:600}.analytics-empty-state{border:2px dashed var(--border);padding:60px 40px}@media (max-width: 768px){.analytics-summary-header{padding:24px 20px!important;border-radius:20px!important;margin-top:-8px}.analytics-summary-header .summary-text{font-size:18px!important}.analytics-finding-grid,.analytics-suggestion-grid,.analytics-kpi-grid{grid-template-columns:1fr!important;gap:16px}.analytics-suggestion-card{padding:20px}.analytics-range-tabs{width:100%;justify-content:center}.analytics-range-tabs button{flex:1;text-align:center;padding:6px 4px}.analytics-chart-card{padding:24px 16px;border-radius:24px}.chart-container{height:320px}.chart-tabs{margin:0 -16px 20px;padding:0 16px 8px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}}.workspace-dashboard{display:flex;flex-direction:column;gap:20px;color:#0f172a}.workspace-dashboard-header{display:flex;justify-content:space-between;align-items:flex-end;gap:24px}.workspace-dashboard-kicker{display:block;margin-bottom:8px;color:#64748b;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.workspace-dashboard-header h1{margin:0;color:#0f172a;font-size:30px;line-height:1.15;letter-spacing:-.04em;font-weight:850}.workspace-dashboard-header p{margin:8px 0 0;color:#64748b;font-size:14px;line-height:1.6}.workspace-dashboard-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.workspace-dashboard-actions button,.workspace-dashboard-primary-action,.workspace-dashboard-empty button{min-height:36px;display:inline-flex;align-items:center;justify-content:center;padding:0 13px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;color:#334155;font-size:13px;font-weight:750;cursor:pointer;box-shadow:0 1px 2px #0f172a0a;transition:background .18s,color .18s,border-color .18s}.workspace-dashboard-actions button:hover,.workspace-dashboard-primary-action:hover,.workspace-dashboard-empty button:hover{background:#f8fafc;border-color:#cbd5e1;color:#0f172a}.workspace-dashboard-actions button:first-child{background:#2563eb;border-color:#2563eb;color:#fff}.workspace-dashboard-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.workspace-dashboard-kpi,.workspace-dashboard-card,.dashboard-insights-card{min-width:0;background:#fff!important;border:1px solid #e5e7eb!important;border-radius:18px!important;box-shadow:0 1px 2px #0f172a0a!important}.workspace-dashboard-kpi{padding:18px}.workspace-dashboard-kpi-head,.workspace-dashboard-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.workspace-dashboard-kpi-head>span,.workspace-dashboard-card-head span{color:#64748b;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.workspace-dashboard-kpi strong{display:block;margin:16px 0 10px;color:#0f172a;font-size:26px;line-height:1;letter-spacing:-.04em;font-weight:850}.workspace-dashboard-kpi p{margin:0;color:#64748b;font-size:12px;line-height:1.5}.workspace-dashboard-kpi.good strong{color:#047857}.workspace-dashboard-kpi.risk strong{color:#b91c1c}.workspace-dashboard-kpi.warning strong{color:#b45309}.workspace-dashboard-badge{display:inline-flex;align-items:center;min-height:22px;padding:0 8px;border-radius:999px;font-style:normal;font-size:11px;font-weight:800;white-space:nowrap}.workspace-dashboard-badge.green{background:#ecfdf5;color:#047857}.workspace-dashboard-badge.red{background:#fef2f2;color:#b91c1c}.workspace-dashboard-badge.blue{background:#eff6ff;color:#1d4ed8}.workspace-dashboard-badge.neutral{background:#f1f5f9;color:#475569}.workspace-dashboard-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(320px,.75fr);gap:16px;align-items:stretch}.workspace-dashboard-lower-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(280px,.8fr);gap:16px;align-items:start}.workspace-dashboard-recent{grid-column:1 / -1}.workspace-dashboard-card{padding:20px}.workspace-dashboard-card-head{margin-bottom:18px}.workspace-dashboard-card-head h2{margin:6px 0 0;color:#0f172a;font-size:17px;line-height:1.25;letter-spacing:-.02em;font-weight:820}.workspace-dashboard-goal-title{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:12px}.workspace-dashboard-goal-title strong{color:#0f172a;font-size:24px;line-height:1.15;letter-spacing:-.04em}.workspace-dashboard-goal-title span{color:#0f172a;font-size:24px;line-height:1;letter-spacing:-.04em;font-weight:850}.workspace-dashboard-progress{height:10px;overflow:hidden;border-radius:999px;background:#e5e7eb;margin-bottom:18px}.workspace-dashboard-progress i{display:block;height:100%;border-radius:inherit;background:#2563eb}.workspace-dashboard-goal-metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.workspace-dashboard-goal-metrics div,.workspace-dashboard-note{min-width:0;padding:13px;border-radius:14px;background:#f8fafc;border:1px solid #e5e7eb}.workspace-dashboard-goal-metrics span,.workspace-dashboard-note span{display:block;margin-bottom:6px;color:#64748b;font-size:11px;font-weight:760}.workspace-dashboard-goal-metrics strong,.workspace-dashboard-note strong{display:block;overflow:hidden;color:#0f172a;font-size:14px;font-weight:820;text-overflow:ellipsis;white-space:nowrap}.workspace-dashboard-note{margin-top:12px}.workspace-dashboard-note p{margin:8px 0 0;color:#64748b;font-size:12px;line-height:1.5}.workspace-dashboard-primary-action{width:100%;margin-top:14px}.workspace-dashboard-empty{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;min-height:214px;padding:20px;border-radius:16px;background:#f8fafc;border:1px dashed #cbd5e1}.workspace-dashboard-empty.compact{min-height:132px}.workspace-dashboard-empty h3{margin:0 0 8px;color:#0f172a;font-size:16px;letter-spacing:-.02em}.workspace-dashboard-empty p{margin:0 0 14px;color:#64748b;font-size:13px;line-height:1.6}.workspace-dashboard-budget-list,.workspace-dashboard-forecast-list,.workspace-dashboard-record-list{display:flex;flex-direction:column;gap:10px}.workspace-dashboard-budget-row,.workspace-dashboard-forecast-row,.workspace-dashboard-record-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px;border-radius:14px;background:#f8fafc;border:1px solid #e5e7eb}.workspace-dashboard-budget-row strong,.workspace-dashboard-record-row strong{display:block;color:#0f172a;font-size:14px;font-weight:800}.workspace-dashboard-budget-row span,.workspace-dashboard-record-row span,.workspace-dashboard-forecast-row span{display:block;margin-top:4px;color:#64748b;font-size:12px;line-height:1.45}.workspace-dashboard-forecast-row strong{color:#0f172a;font-size:14px;font-weight:820;white-space:nowrap}.workspace-dashboard-record-row em{flex:0 0 auto;font-style:normal;font-size:14px;font-weight:820;white-space:nowrap}.workspace-dashboard-record-row em.income{color:#047857}.workspace-dashboard-record-row em.expense{color:#b91c1c}.dashboard-insights-card{padding:20px!important;margin:0!important}.dashboard-insights-card .panel-title{margin-bottom:18px}.dashboard-insights-list{display:flex;flex-direction:column;gap:12px}.dashboard-insight-item{background:#fff;border:1px solid #e5e7eb;border-left:3px solid #2563eb;border-radius:14px;padding:16px}.dashboard-insight-item.risk{border-left-color:#ef4444}.dashboard-insight-item.opportunity{border-left-color:#10b981}.dashboard-insight-item.summary{border-left-color:#64748b}.insight-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.insight-tag,.example-badge{display:inline-flex;align-items:center;min-height:22px;padding:0 8px;border-radius:999px;background:#f1f5f9;color:#475569;font-size:11px;font-weight:800}.insight-title{color:#0f172a;font-size:15px;font-weight:820;margin-bottom:6px}.insight-desc,.insight-basis,.insight-action{color:#64748b;font-size:13px;line-height:1.6}.insight-basis,.insight-action{margin-top:8px}.insight-action{color:#334155;font-weight:650}.insight-desc span,.insight-basis span,.insight-action span{display:block;margin-bottom:2px;color:#94a3b8;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.insight-empty{padding:18px;border-radius:14px;background:#f8fafc;color:#64748b;font-size:13px;line-height:1.6}@media (max-width: 1080px){.workspace-dashboard-header{align-items:flex-start;flex-direction:column}.workspace-dashboard-actions{justify-content:flex-start}.workspace-dashboard-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.workspace-dashboard-grid,.workspace-dashboard-lower-grid{grid-template-columns:1fr}.workspace-dashboard-goal-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 600px){.workspace-dashboard{gap:16px}.workspace-dashboard-header h1{font-size:26px}.workspace-dashboard-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));width:100%}.workspace-dashboard-actions button{width:100%}.workspace-dashboard-kpis,.workspace-dashboard-goal-metrics{grid-template-columns:1fr}.workspace-dashboard-card,.workspace-dashboard-kpi,.dashboard-insights-card{border-radius:16px!important;padding:16px!important}.workspace-dashboard-record-row,.workspace-dashboard-budget-row,.workspace-dashboard-forecast-row{align-items:flex-start;flex-direction:column}}@media (max-width: 768px){.section-head{flex-direction:column!important;align-items:flex-start!important;gap:16px;margin-bottom:24px}.section-head h2{font-size:24px}.settings-page{max-width:none;margin-bottom:32px}.settings-page .section-head{margin-top:12px}.settings-panel{border-radius:16px;margin-bottom:16px}.settings-group-title{min-height:62px;padding:16px 18px}.settings-section-body{padding:4px 18px}.settings-row{flex-direction:column!important;align-items:stretch!important;gap:14px;min-height:0;padding:18px 0}.settings-row-main{padding-right:0}.settings-row .plan-actions{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:8px}.settings-row select{width:100%!important;height:44px}.settings-row>.ios-switch{align-self:flex-start}.settings-account-card{margin-top:14px}.budget-list{grid-template-columns:1fr}.modal{width:92%;padding:24px;border-radius:28px}.modal-row{flex-direction:column!important;gap:12px!important}.modal-row select{width:100%!important}.btn-primary,.btn-ghost,.settings-btn,.landing-btn-primary,.landing-btn-ghost{height:50px;min-height:50px;border-radius:14px;font-size:15px}}.budget-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding-bottom:18px}.budget-row{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:14px;background:var(--bg2);border-radius:14px;border:1px solid var(--border);transition:all .2s}.budget-row:hover{border-color:#3b82f673;background:var(--bg);box-shadow:0 8px 18px #1018280f}.budget-info{display:flex;align-items:center;gap:14px;flex:1;min-width:0}.budget-cat-name{font-size:14px;font-weight:800;min-width:72px;color:var(--text)}.budget-input-wrap{display:flex;align-items:center;gap:8px;background:var(--bg);padding:3px 10px;border-radius:10px;border:1px solid var(--border2);min-width:126px}.budget-input-wrap:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft)}.budget-input-wrap .unit{font-size:12px;font-weight:800;color:var(--text3)}.budget-input{border:none!important;background:transparent!important;padding:5px 0!important;font-size:14px!important;font-weight:750!important;width:78px!important}.budget-actions{display:flex;align-items:center;gap:8px;flex:0 0 auto}.budget-action-label{font-size:12px;color:var(--text3);font-weight:650;white-space:nowrap}.budget-alert-card{display:flex;flex-direction:column;gap:20px}.budget-alert-item{display:flex;flex-direction:column;gap:12px;padding:16px;background:var(--bg2);border-radius:16px;border:1px solid var(--border)}.budget-alert-head{display:flex;justify-content:space-between;align-items:center}.budget-alert-cat{font-size:14px;font-weight:850}.budget-alert-status{font-size:10px;font-weight:900;padding:2px 8px;border-radius:6px;text-transform:uppercase}.budget-alert-status.danger{background:#fee2e2;color:#991b1b}.budget-alert-status.warning{background:#fef3c7;color:#92400e}.budget-alert-status.attention{background:#e0f2fe;color:#0369a1}.budget-progress-bar{height:8px;background:var(--bg3);border-radius:99px;overflow:hidden;position:relative}.budget-progress-fill{height:100%;transition:width .6s cubic-bezier(.34,1.56,.64,1)}.budget-progress-fill.normal{background:var(--green)}.budget-progress-fill.attention{background:var(--blue)}.budget-progress-fill.warning{background:var(--amber)}.budget-progress-fill.danger{background:var(--red)}.budget-alert-msg{font-size:12px;font-weight:600;color:var(--text2);line-height:1.5}@media (max-width: 768px){.budget-list{grid-template-columns:1fr}.budget-row{flex-direction:column;align-items:flex-start;gap:16px}.budget-info{width:100%;justify-content:space-between}.budget-actions{width:100%;justify-content:flex-end;padding-top:12px;border-top:1px dashed var(--border)}}.workspace-main .app-page-content:has(.calendar-page){max-width:none;padding:16px 20px}.workspace-main:has(.calendar-page) .app-header-toolbar{display:none}.calendar-page{width:100%;max-width:none;height:calc(100dvh - 32px);min-height:560px;display:flex;flex-direction:column;margin:0;color:#0f172a}.calendar-page-heading{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin:10px 0 18px}.calendar-page-heading span{display:block;margin-bottom:8px;color:#64748b;font-size:11px;font-weight:820;letter-spacing:.08em;text-transform:uppercase}.calendar-page-heading h2{margin:0;color:#0f172a;font-size:30px;line-height:1.15;letter-spacing:-.04em;font-weight:850}.calendar-page-heading p{margin:8px 0 0;color:#64748b;font-size:14px;line-height:1.6}.calendar-shell-card{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;background:#fff;border:1px solid #e5e7eb;border-radius:20px;box-shadow:0 1px 2px #0f172a0a,0 14px 34px #0f172a0a}.calendar-toolbar{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:14px 18px;border-bottom:1px solid #e5e7eb}.calendar-toolbar-title{display:flex;align-items:center;min-width:0;gap:14px}.calendar-date-badge{width:54px;height:58px;display:flex;flex-direction:column;align-items:center;justify-content:center;flex:0 0 auto;border:1px solid #e5e7eb;border-radius:12px;background:#f8fafc}.calendar-date-badge span{color:#64748b;font-size:12px;font-weight:800}.calendar-date-badge strong{margin-top:4px;color:#2563eb;font-size:22px;font-weight:850;letter-spacing:-.04em}.calendar-toolbar h1{margin:0;color:#0f172a;font-size:23px;line-height:1.15;letter-spacing:-.035em;font-weight:850}.calendar-toolbar p{margin:5px 0 0;color:#64748b;font-size:14px;line-height:1.45}.calendar-toolbar-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:10px}.calendar-icon-button,.calendar-nav-control button,.calendar-view-switch button,.calendar-add-record,.calendar-detail-action{min-height:38px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #e5e7eb;border-radius:10px;background:#fff;color:#334155;font-size:13px;font-weight:760;text-decoration:none;cursor:pointer;box-shadow:0 1px 2px #0f172a0a}.calendar-icon-button{width:38px;padding:0;color:#64748b;font-size:22px}.calendar-nav-control{display:inline-flex;overflow:hidden;border:1px solid #e5e7eb;border-radius:11px;background:#fff}.calendar-nav-control button{border:0;border-right:1px solid #e5e7eb;border-radius:0;min-width:42px;box-shadow:none}.calendar-nav-control button:last-child{border-right:0}.calendar-view-switch{display:inline-flex;gap:4px;padding:4px;border:1px solid #e5e7eb;border-radius:12px;background:#f8fafc}.calendar-view-switch button{min-height:30px;padding:0 10px;border:0;border-radius:8px;background:transparent;box-shadow:none;color:#64748b}.calendar-view-switch button.active{background:#fff;color:#0f172a;box-shadow:0 1px 2px #0f172a0f}.calendar-add-record,.calendar-detail-action{padding:0 14px;background:#2563eb;border-color:#2563eb;color:#fff}.calendar-content{flex:1;min-height:0;display:grid;grid-template-columns:minmax(0,1fr);overflow:hidden}.calendar-content.has-detail{grid-template-columns:minmax(0,1fr) 360px}.calendar-main-view{min-width:0;min-height:0;overflow:hidden}.calendar-month-grid{height:100%;display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-template-rows:42px repeat(6,minmax(0,1fr));min-width:0}.calendar-weekday{height:42px;display:flex;align-items:center;justify-content:center;border-right:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb;background:#f8fafc;color:#64748b;font-size:12px;font-weight:800}.calendar-weekday:nth-child(7){border-right:0}.calendar-day-cell{min-height:0;overflow:hidden;padding:8px;border-right:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb;background:#fff;cursor:pointer;transition:background .16s ease,box-shadow .16s ease}.calendar-day-cell:hover{background:#f8fafc;box-shadow:inset 0 0 0 1px #cbd5e1}.calendar-day-cell:nth-child(7n){border-right:0}.calendar-day-cell.calendar-event-muted{background:#fafafa}.calendar-day-cell.calendar-event-muted .calendar-day-number{color:#a3a3a3}.calendar-day-cell.selected{background:#f8fafc}.calendar-day-number{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;padding:0;border:0;border-radius:999px;background:transparent;color:#334155;font-size:13px;font-weight:820;cursor:pointer}.calendar-today .calendar-day-number,.calendar-week-column.calendar-today .calendar-week-head strong{background:#2563eb;color:#fff}.calendar-day-events{display:flex;flex-direction:column;gap:4px;margin-top:6px;overflow:hidden}.calendar-event{width:100%;min-width:0;min-height:34px;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 9px;border:1px solid #e5e7eb;border-radius:9px;background:#fff;color:#334155;text-align:left;cursor:pointer;transition:background .16s ease,border-color .16s ease,color .16s ease,transform .16s ease,box-shadow .16s ease}.calendar-event.compact{min-height:26px;padding:4px 8px}.calendar-event-title,.calendar-event-amount{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:800}.calendar-event-amount{flex:0 0 auto;font-weight:820}.calendar-event-income{background:#ecfdf3;border-color:#86efac;color:#047857}.calendar-event-expense{background:#fdf2f8;border-color:#f9a8d4;color:#db2777}.calendar-event-food{background:#fff7ed;border-color:#fdba74;color:#ea580c}.calendar-event-transport{background:#eff6ff;border-color:#93c5fd;color:#1d4ed8}.calendar-event-fixed{background:#f8fafc;border-color:#d4d4d8;color:#475569}.calendar-event-growth{background:#faf5ff;border-color:#d8b4fe;color:#7e22ce}.calendar-event:hover{transform:translateY(-1px);box-shadow:0 6px 14px #0f172a14}.calendar-event-income:hover{background:#dcfce7;border-color:#4ade80}.calendar-event-expense:hover{background:#fce7f3;border-color:#f472b6}.calendar-event-food:hover{background:#ffedd5;border-color:#fb923c}.calendar-event-transport:hover{background:#dbeafe;border-color:#60a5fa}.calendar-event-fixed:hover{background:#f4f4f5;border-color:#a1a1aa}.calendar-event-growth:hover{background:#f3e8ff;border-color:#c084fc}.calendar-more,.calendar-no-events{color:#64748b;font-size:12px;font-weight:700}.calendar-week-grid{height:100%;display:grid;grid-template-columns:repeat(7,minmax(150px,1fr));min-width:860px;min-height:0}.calendar-week-column{min-width:0;border-right:1px solid #e5e7eb;background:#fff}.calendar-week-column:last-child{border-right:0}.calendar-week-column.selected{background:#f8fafc}.calendar-week-head{width:100%;height:64px;display:flex;align-items:center;justify-content:center;gap:8px;border:0;border-bottom:1px solid #e5e7eb;background:transparent;color:#64748b;cursor:pointer}.calendar-week-head span{font-size:12px;font-weight:800}.calendar-week-head strong{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;color:#0f172a;font-size:13px;font-weight:850}.calendar-week-events{display:flex;flex-direction:column;gap:8px;padding:12px;overflow:hidden}.calendar-day-view{height:100%;display:flex;flex-direction:column;gap:16px;padding:18px;overflow:auto}.calendar-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.calendar-summary div{min-width:0;padding:16px;border:1px solid #e5e7eb;border-radius:14px;background:#f8fafc}.calendar-summary span{display:block;margin-bottom:8px;color:#64748b;font-size:12px;font-weight:760}.calendar-summary strong{color:#0f172a;font-size:20px;line-height:1.1;letter-spacing:-.03em;font-weight:850}.calendar-summary strong.income,.calendar-detail-list strong.income{color:#047857}.calendar-summary strong.expense,.calendar-detail-list strong.expense{color:#b91c1c}.calendar-day-list{display:flex;flex-direction:column;gap:10px;min-height:0;overflow:auto}.calendar-day-record{display:grid;grid-template-columns:minmax(220px,.36fr) minmax(0,1fr);gap:14px;align-items:start;padding:12px;border:1px solid #e5e7eb;border-radius:14px;background:#fff}.calendar-day-record span{display:block;margin-bottom:4px;color:#64748b;font-size:11px;font-weight:800}.calendar-day-record strong{display:block;color:#0f172a;font-size:14px;font-weight:820}.calendar-day-record p{margin:6px 0 0;color:#64748b;font-size:13px;line-height:1.45}.calendar-detail-panel{min-width:0;overflow:auto;padding:28px 24px;border-left:1px solid #e5e7eb;background:#fff}.calendar-detail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:28px}.calendar-detail-head span{display:block;margin-bottom:10px;color:#64748b;font-size:13px;font-weight:900;letter-spacing:.16em;text-transform:uppercase}.calendar-detail-head h2{margin:0;color:#0f172a;font-size:30px;line-height:1.25;letter-spacing:-.04em;font-weight:900}.calendar-detail-head button{width:56px;height:56px;border:1px solid #e5e7eb;border-radius:16px;background:#fff;color:#64748b;font-size:32px;line-height:1;cursor:pointer}.calendar-detail-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.calendar-detail-form{display:flex;flex-direction:column;gap:18px}.calendar-detail-field{display:flex;flex-direction:column;gap:6px}.calendar-detail-label{display:block;margin:0;color:#344054;font-size:14px;line-height:1.4;font-weight:650;letter-spacing:0}.calendar-detail-label i{color:#7c3aed;font-style:normal}.calendar-detail-control{min-height:44px;display:flex;align-items:center;padding:0 13px;border:1px solid #d0d5dd;border-radius:8px;background:#fff;box-shadow:0 1px 2px #1018280d;transition:border-color .16s ease,box-shadow .16s ease}.calendar-detail-control:focus-within{border-color:#a855f7;box-shadow:0 0 0 3px #a855f724,0 1px 2px #1018280d}.calendar-detail-field input,.calendar-detail-field select,.calendar-detail-field textarea{width:100%;border:0;background:transparent;color:#667085;padding:0;font:inherit;font-size:16px;line-height:1.5;font-weight:400;letter-spacing:0;outline:none;resize:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.calendar-detail-field input:focus,.calendar-detail-field select:focus,.calendar-detail-field textarea:focus{color:#101828}.calendar-detail-field small{color:#667085;font-size:13px;line-height:1.45}.calendar-detail-field textarea{min-height:84px;color:#667085;line-height:1.5}.calendar-detail-input-row,.calendar-money-row{display:flex;align-items:center;gap:10px;min-width:0}.calendar-detail-input-row input,.calendar-detail-input-row select{flex:1;min-width:0}.calendar-date-picker-anchor{position:relative}.calendar-date-picker-anchor input{cursor:pointer}.calendar-date-trigger{width:28px;height:28px;flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;padding:0;border:0;background:transparent;color:#98a2b3;cursor:pointer}.calendar-field-icon{flex:0 0 auto;width:18px;height:18px;position:relative;color:#98a2b3}.calendar-icon-calendar:before{content:"";position:absolute;top:3px;right:2px;bottom:2px;left:2px;border:2px solid currentColor;border-radius:3px}.calendar-icon-calendar:after{content:"";position:absolute;left:6px;right:6px;top:1px;height:6px;border-left:2px solid currentColor;border-right:2px solid currentColor}.calendar-icon-chevron:before{content:"";position:absolute;left:5px;top:5px;width:8px;height:8px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg)}.calendar-money-symbol{flex:0 0 auto;color:#344054;font-size:20px;font-weight:400}.calendar-money-row input{flex:1;min-width:0}.calendar-money-row select{width:92px;flex:0 0 92px;color:#344054;text-align:right;font-size:16px;font-weight:500;letter-spacing:0}.calendar-note-field .calendar-detail-control{min-height:112px;align-items:flex-start;padding-top:10px;padding-bottom:10px}.calendar-date-popover{position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:40;width:100%;overflow:hidden;border:1px solid #d0d5dd;border-radius:16px;background:#fff;box-shadow:0 18px 40px #1018282e}.calendar-date-popover-head{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 16px}.calendar-date-popover-head strong{color:#344054;font-size:16px;font-weight:750}.calendar-date-popover-head button{width:34px;height:34px;border:0;border-radius:9px;background:transparent;color:#667085;font-size:26px;cursor:pointer}.calendar-date-popover-head button:hover{background:#f9fafb}.calendar-date-popover-inputs{display:grid;grid-template-columns:minmax(0,1fr) 82px;gap:10px;padding:0 16px 14px}.calendar-date-popover-inputs input,.calendar-date-popover-inputs button{min-height:40px;display:flex;align-items:center;justify-content:center;border:1px solid #d0d5dd;border-radius:9px;background:#fff;color:#344054;font-size:15px;font-weight:600;box-shadow:0 1px 2px #1018280d}.calendar-date-popover-inputs input{width:100%;min-width:0;padding:0 12px;font:inherit;font-weight:500;outline:none}.calendar-date-popover-inputs input:focus{border-color:#a855f7;box-shadow:0 0 0 3px #a855f724,0 1px 2px #1018280d}.calendar-date-popover-inputs button{width:82px;padding:0;cursor:pointer}.calendar-date-popover-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;padding:0 16px 18px}.calendar-date-popover-grid span{display:flex;align-items:center;justify-content:center;height:28px;color:#344054;font-size:13px;font-weight:700}.calendar-date-popover-grid button{position:relative;height:34px;border:0;border-radius:999px;background:transparent;color:#344054;font-size:14px;font-weight:500;cursor:pointer}.calendar-date-popover-grid button:hover{background:#f4f3ff;color:#7c3aed}.calendar-date-popover-grid button.muted{color:#d0d5dd}.calendar-date-popover-grid button.selected{background:#7c3aed;color:#fff}.calendar-date-popover-grid button.selected:after{content:"";position:absolute;left:50%;bottom:5px;width:4px;height:4px;border-radius:999px;background:#fff;transform:translate(-50%)}.calendar-date-popover-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:16px;border-top:1px solid #eaecf0}.calendar-date-popover-actions button{min-height:42px;border-radius:9px;font-size:15px;font-weight:700;cursor:pointer}.calendar-date-popover-actions button:first-child{border:1px solid #d0d5dd;background:#fff;color:#344054;box-shadow:0 1px 2px #1018280d}.calendar-date-popover-actions button:last-child{border:1px solid #7c3aed;background:#7c3aed;color:#fff;box-shadow:0 1px 2px #10182814}.calendar-detail-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding-top:8px}.calendar-detail-actions.dirty{grid-template-columns:1fr .88fr .7fr}.calendar-detail-actions button,.calendar-detail-actions a{min-height:54px;display:inline-flex;align-items:center;justify-content:center;padding:0 14px;border-radius:16px;font-size:16px;font-weight:850;text-decoration:none;white-space:nowrap}.calendar-detail-actions button[type=submit]{border:1px solid #2563eb;background:#2563eb;color:#fff;cursor:pointer}.calendar-detail-actions a{border:1px solid #e5e7eb;background:#fff;color:#334155}.calendar-detail-delete{border:1px solid rgba(239,68,68,.28);background:#ef44440f;color:#b91c1c;cursor:pointer}.calendar-detail-list div{padding:12px;border:1px solid #e5e7eb;border-radius:12px;background:#f8fafc}.calendar-detail-list span{display:block;margin-bottom:5px;color:#64748b;font-size:11px;font-weight:800}.calendar-detail-list strong{display:block;overflow-wrap:anywhere;color:#0f172a;font-size:13px;line-height:1.45;font-weight:800}.calendar-empty{min-height:420px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:36px;text-align:center}.calendar-empty.compact{min-height:180px;align-items:flex-start;padding:20px;text-align:left;border:1px dashed #cbd5e1;border-radius:14px;background:#f8fafc}.calendar-empty h3{margin:0 0 8px;color:#0f172a;font-size:18px;letter-spacing:-.02em}.calendar-empty p{max-width:420px;margin:0 0 16px;color:#64748b;font-size:14px;line-height:1.6}.calendar-empty a{min-height:38px;display:inline-flex;align-items:center;justify-content:center;padding:0 14px;border-radius:10px;background:#2563eb;color:#fff;font-size:13px;font-weight:760;text-decoration:none}@media (max-width: 1080px){.calendar-toolbar{align-items:flex-start;flex-direction:column}.calendar-toolbar-actions{width:100%;justify-content:flex-start}.calendar-content.has-detail{grid-template-columns:1fr}.calendar-detail-panel{border-top:1px solid #e5e7eb;border-left:0}}@media (max-width: 768px){.workspace-main .app-page-content:has(.calendar-page){padding:12px 12px 86px}.calendar-page{height:calc(100dvh - 110px);min-height:520px;margin:0}.calendar-page-heading h2{font-size:26px}.calendar-shell-card{border-radius:16px}.calendar-toolbar{padding:16px}.calendar-toolbar-title{align-items:flex-start}.calendar-toolbar h1{font-size:21px}.calendar-toolbar-actions{display:grid;grid-template-columns:38px 1fr}.calendar-nav-control,.calendar-view-switch,.calendar-add-record{grid-column:1 / -1;width:100%}.calendar-nav-control button,.calendar-view-switch button,.calendar-add-record{flex:1}.calendar-content,.calendar-content.has-detail{min-height:0;overflow:hidden}.calendar-main-view{overflow-x:auto;-webkit-overflow-scrolling:touch}.calendar-month-grid{min-width:720px}.calendar-week-grid{min-width:0;display:flex;flex-direction:column}.calendar-week-column{border-right:0;border-bottom:1px solid #e5e7eb}.calendar-week-head{justify-content:flex-start;padding:0 16px}.calendar-summary,.calendar-day-record{grid-template-columns:1fr}.calendar-detail-panel{padding:16px}}
