.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-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-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:32px}.records-quick-actions{display:flex;gap:12px}.records-summary{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;background:var(--bg2);border:1px solid var(--border);border-radius:24px;padding:24px}.records-summary .summary-item{display:flex;flex-direction:column;gap:6px}.records-summary .label{font-size:11px;font-weight:850;color:var(--text3);text-transform:uppercase}.records-summary .value{font-size:18px;font-weight:900}.records-summary .value.green{color:var(--green)}.records-summary .value.red{color:var(--red)}.records-summary .value.blue{color:var(--blue)}.records-view-tabs{display:flex;gap:8px;background:var(--bg3);padding:4px;border-radius:16px;width:-moz-fit-content;width:fit-content}.records-view-tabs button{padding:10px 24px;font-size:14px;font-weight:750;color:var(--text2);border-radius:12px;border:none;background:transparent;cursor:pointer;transition:all .2s}.records-view-tabs button.active{background:var(--bg);color:var(--blue);box-shadow:var(--shadow)}.records-month-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:24px}.records-month-card{background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:20px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:16px}.records-month-card:hover{transform:translateY(-4px);border-color:var(--blue)}.records-month-card.selected{border-color:var(--blue);border-width:2px;box-shadow:0 12px 30px #3b82f61a}.records-month-card .card-header{display:flex;justify-content:space-between;align-items:center}.records-month-card .month-name{font-size:16px;font-weight:900}.records-month-card .card-body{display:flex;flex-direction:column;gap:6px}.records-month-card .row{display:flex;justify-content:space-between;font-size:13px;font-weight:600}.records-month-card .row.footer{border-top:1px solid var(--border);padding-top:8px;margin-top:4px}.records-month-card .lbl{color:var(--text3)}.records-month-card .val.green{color:var(--green)}.records-month-card .val.red{color:var(--red)}.records-month-detail{margin-top:40px;background:var(--bg);border:1px solid var(--border);border-radius:32px;padding:40px;box-shadow:var(--shadow);animation:slideUp .3s ease}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.detail-header h3{font-size:22px;font-weight:950;margin:0}.close-btn{background:var(--bg3);border:none;padding:8px 16px;border-radius:99px;font-size:12px;font-weight:800;color:var(--text2);cursor:pointer}.detail-grid{display:grid;grid-template-columns:280px 1fr;gap:32px;margin-bottom:40px}.detail-summary-card{background:var(--bg2);border:1px solid var(--border);border-radius:24px;padding:24px;display:flex;flex-direction:column;gap:24px}.detail-summary-card .metrics{display:flex;flex-direction:column;gap:16px}.detail-summary-card .metric{display:flex;flex-direction:column;gap:4px}.detail-summary-card .lbl{font-size:11px;font-weight:850;color:var(--text3);text-transform:uppercase}.detail-summary-card .val{font-size:20px;font-weight:950}.detail-summary-card .ai-summary{padding-top:16px;border-top:1px dashed var(--border)}.detail-summary-card .ai-label{font-size:12px;font-weight:900;color:var(--blue);margin-bottom:8px}.detail-summary-card p{font-size:13px;color:var(--text2);line-height:1.6;margin:0;font-weight:600}.records-type-toggle{display:flex;background:var(--bg3);padding:4px;border-radius:12px;margin-bottom:24px;width:-moz-fit-content;width:fit-content}.records-type-toggle button{padding:8px 24px;font-size:13px;font-weight:800;border:none;background:transparent;border-radius:9px;cursor:pointer;transition:all .2s}.records-type-toggle button.active{background:var(--bg);color:var(--blue);box-shadow:var(--shadow)}.amount-input-wrap{display:flex;align-items:center;gap:12px;background:var(--bg3);padding:12px 20px;border-radius:16px;border:2px solid transparent;transition:all .2s}.amount-input-wrap:focus-within{border-color:var(--blue);background:var(--bg)}.amount-input-wrap .currency{font-size:24px;font-weight:900;color:var(--blue)}.amount-input-wrap input{border:none!important;background:transparent!important;font-size:28px!important;font-weight:950!important;width:100%;color:var(--text)}.records-category-chips{display:flex;flex-direction:column;gap:12px}.level1-scroll,.level2-scroll{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.level1-scroll::-webkit-scrollbar{display:none}.chip{padding:6px 16px;border-radius:99px;font-size:12px;font-weight:750;border:1.5px solid var(--border);background:var(--bg);color:var(--text2);cursor:pointer;white-space:nowrap;transition:all .2s}.chip.active{background:var(--blue);color:#fff;border-color:var(--blue)}.chip.level2.active{background:var(--text);border-color:var(--text)}.records-entry-list h4{font-size:16px;font-weight:900;margin-bottom:20px}.entry-scroll-area{display:flex;flex-direction:column;max-height:400px;overflow-y:auto;padding-right:12px}.entry-item{display:flex;align-items:center;gap:16px;padding:16px 0;border-bottom:1px solid var(--border)}.entry-item .date{font-size:12px;font-weight:850;color:var(--text3);min-width:40px}.entry-item .info{flex:1}.entry-item .cat{font-size:14px;font-weight:850;color:var(--text)}.entry-item .note{font-size:12px;color:var(--text3);font-weight:500}.entry-item .amt{font-size:16px;font-weight:900}.entry-item .green{color:var(--green)}.entry-item .red{color:var(--red)}.timeline-view{display:flex;flex-direction:column;padding:20px 0}.timeline-event-card{display:flex;gap:24px;position:relative}.timeline-event-marker{display:flex;flex-direction:column;align-items:center;min-width:32px}.marker-line{width:2px;flex:1;background:var(--border)}.marker-dot{width:14px;height:14px;border-radius:50%;background:var(--border2);border:3px solid var(--bg);z-index:2;position:relative}.marker-dot.positive{background:var(--green);border-color:#10b98133}.marker-dot.danger{background:var(--red);border-color:#ef444433}.marker-dot.ai{background:var(--blue);border-color:#3b82f633}.marker-dot.warning{background:var(--amber);border-color:#f59e0b33}.marker-pulse{position:absolute;top:-4px;left:-4px;width:22px;height:22px;border-radius:50%;background:var(--blue-soft);animation:pulse 2s infinite;z-index:1}@keyframes pulse{0%{transform:scale(.9);opacity:.8}70%{transform:scale(2);opacity:0}to{transform:scale(.9);opacity:0}}.timeline-event-content{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:24px;padding:24px;margin-bottom:32px;transition:transform .2s;position:relative}.timeline-event-card:hover .timeline-event-content{transform:translate(8px);border-color:var(--blue)}.event-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.event-date{font-size:12px;font-weight:850;color:var(--text3)}.event-tag{font-size:10px;font-weight:900;padding:4px 10px;border-radius:6px;text-transform:uppercase}.event-tag.positive{background:#dcfce7;color:#166534}.event-tag.danger{background:#fee2e2;color:#991b1b}.event-tag.ai{background:#e0f2fe;color:#0369a1}.event-body{display:flex;gap:16px;align-items:flex-start}.event-icon-wrap{font-size:24px;background:var(--bg2);width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center}.event-title{font-size:16px;font-weight:900;margin:0 0 4px;color:var(--text)}.event-desc{font-size:13px;color:var(--text2);margin:0;line-height:1.5;font-weight:600}.event-example-badge{position:absolute;top:-10px;right:20px;background:var(--text2);color:#fff;font-size:10px;font-weight:900;padding:2px 8px;border-radius:4px}.timeline-filter-tabs{display:flex;gap:8px;margin-bottom:32px;overflow-x:auto;padding-bottom:8px;scrollbar-width:none}.timeline-filter-tabs::-webkit-scrollbar{display:none}.timeline-filter-tabs button{padding:8px 18px;font-size:13px;font-weight:750;color:var(--text3);background:var(--bg3);border-radius:99px;border:none;cursor:pointer;white-space:nowrap;transition:all .2s}.timeline-filter-tabs button.active{background:var(--text);color:var(--bg)}.timeline-empty{text-align:center;padding:60px;color:var(--text3)}@media (max-width: 1024px){.records-summary{grid-template-columns:repeat(3,1fr)}.records-month-grid{grid-template-columns:repeat(2,1fr)}.detail-grid{grid-template-columns:1fr}}@media (max-width: 700px){.records-summary{grid-template-columns:repeat(2,1fr)}.records-month-grid{grid-template-columns:1fr}.records-month-detail{padding:24px 16px 140px!important;margin-top:24px;width:100%!important;max-width:100%!important;border-radius:24px}.detail-grid{grid-template-columns:1fr!important;gap:24px!important}.detail-summary-card{width:100%!important}.amount-input-wrap{width:100%!important;padding:10px 16px}.amount-input-wrap input{font-size:24px!important}.records-category-chips{width:100%!important}.level1-scroll,.level2-scroll{flex-wrap:wrap!important;overflow-x:visible!important;gap:8px!important;padding-bottom:0}.chip{flex:0 1 auto!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}}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}@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}}.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}}.dashboard-page{display:flex;flex-direction:column;gap:32px}.dashboard-hero{background:linear-gradient(135deg,#0d0d0d,#1a1a1a);color:#fff;border-radius:32px;padding:40px;border:1px solid rgba(255,255,255,.08);box-shadow:0 20px 60px #0000004d;position:relative;overflow:hidden}.dashboard-hero:before{content:"";position:absolute;top:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(59,130,246,.15) 0%,transparent 70%);pointer-events:none}.dashboard-hero-header{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;margin-bottom:48px}.dashboard-hero-title{font-size:32px;font-weight:900;letter-spacing:-.03em;margin-bottom:8px}.dashboard-hero-status{font-size:15px;opacity:.6;font-weight:600;line-height:1.6}.dashboard-health-card{background:#ffffff0f;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:24px;min-width:240px}.dashboard-health-card.green{border-color:#10b9814d;background:#10b9811a}.dashboard-health-card.warn{border-color:#f59e0b4d;background:#f59e0b1a}.dashboard-health-card.risk{border-color:#ef44444d;background:#ef44441a}.health-score-wrap{display:flex;align-items:center;gap:16px;margin-bottom:12px}.health-score{font-size:40px;font-weight:950;color:#fff;line-height:1}.health-level{font-size:14px;font-weight:800;text-transform:uppercase;color:var(--blue)}.green .health-level{color:var(--green)}.risk .health-level{color:var(--red)}.health-score-title{font-size:11px;font-weight:700;opacity:.6}.health-desc{font-size:13px;font-weight:600;opacity:.8;line-height:1.5}.dashboard-hero-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.dashboard-hero-kpi{background:#ffffff0a;border-radius:20px;padding:20px;border:1px solid rgba(255,255,255,.04)}.dashboard-hero-kpi .label{font-size:11px;font-weight:700;opacity:.5;margin-bottom:8px;text-transform:uppercase}.dashboard-hero-kpi .value{font-size:20px;font-weight:850}.dashboard-hero-kpi .value.green{color:#34d399}.dashboard-hero-kpi .value.red{color:#f87171}.dashboard-hero-footer{margin-top:40px;padding-top:32px;border-top:1px solid rgba(255,255,255,.1)}.footer-label{font-size:12px;font-weight:900;color:var(--blue);margin-bottom:16px}.next-steps-list{display:flex;flex-wrap:wrap;gap:12px}.dashboard-next-step-btn{background:#3b82f626;color:#93c5fd;border:1px solid rgba(59,130,246,.2);padding:8px 18px;border-radius:99px;font-size:13px;font-weight:750;cursor:pointer;transition:all .2s}.dashboard-next-step-btn:hover{background:#3b82f640;transform:translateY(-1px)}.dashboard-quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.dashboard-metric-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}.dashboard-metric-card{background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:24px;position:relative}.metric-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.metric-label{font-size:12px;font-weight:800;color:var(--text3);text-transform:uppercase}.metric-status-badge{font-size:10px;font-weight:850;padding:2px 8px;border-radius:6px}.metric-status-badge.green{background:#dcfce7;color:#166534}.metric-status-badge.red{background:#fee2e2;color:#991b1b}.metric-status-badge.blue{background:#e0f2fe;color:#0369a1}.metric-status-badge.neutral{background:var(--bg3);color:var(--text3)}.metric-value{font-size:22px;font-weight:900;margin-bottom:12px;color:var(--text)}.tone-green .metric-value{color:var(--green)}.tone-red .metric-value{color:var(--red)}.metric-desc{font-size:12px;font-weight:600;color:var(--text3);line-height:1.4}.dashboard-main-content{display:grid;grid-template-columns:320px 1fr;gap:24px;align-items:flex-start}.dashboard-side-col{display:flex;flex-direction:column;gap:24px}.goal-risk-content{display:flex;flex-direction:column;gap:20px}.goal-risk-header{display:flex;justify-content:space-between;align-items:center}.goal-name{font-size:16px;font-weight:900}.goal-status-label{font-size:20px;font-weight:950}.goal-status-label.on-track{color:var(--green)}.goal-status-label.near{color:var(--amber)}.goal-status-label.off-track{color:var(--red)}.goal-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:16px;background:var(--bg2);border-radius:16px}.stat-item .lbl{font-size:11px;font-weight:800;color:var(--text3);margin-bottom:4px}.stat-item .val{font-size:14px;font-weight:850;color:var(--text)}.goal-risk-alert{font-size:13px;font-weight:800;padding:12px;border-radius:12px;text-align:center}.goal-risk-alert.low{background:#dcfce7;color:#166534}.goal-risk-alert.medium{background:#fef3c7;color:#92400e}.goal-risk-alert.high{background:#fee2e2;color:#991b1b}.forecast-content{text-align:center;padding:10px 0}.forecast-value{font-size:32px;font-weight:950;color:var(--blue);margin-bottom:8px}.forecast-desc{font-size:13px;font-weight:600;color:var(--text3);margin-bottom:20px}.dashboard-insights-list{display:flex;flex-direction:column;gap:16px}.dashboard-insight-item{background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:24px;border-left:5px solid transparent;transition:all .2s}.dashboard-insight-item.risk{border-left-color:var(--red);background:#ef44440a}.dashboard-insight-item.suggestion{border-left-color:var(--blue);background:#3b82f60a}.dashboard-insight-item.opportunity{border-left-color:var(--green);background:#10b9810a}.dashboard-insight-item.summary{border-left-color:var(--text)}.insight-header{display:flex;justify-content:space-between;margin-bottom:12px}.insight-tag{font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.05em}.insight-title{font-size:16px;font-weight:900;margin-bottom:8px}.insight-desc{font-size:14px;color:var(--text2);line-height:1.6;font-weight:600}.insight-empty,.forecast-empty,.goal-risk-empty{text-align:center;padding:40px 20px;color:var(--text3)}.empty-icon{font-size:32px;margin-bottom:16px;opacity:.5}.empty-title{font-size:16px;font-weight:900;color:var(--text);margin-bottom:8px}@media (max-width: 1024px){.dashboard-main-content{grid-template-columns:1fr}.dashboard-metric-grid{grid-template-columns:repeat(3,1fr)}.dashboard-hero-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.dashboard-quick-actions{grid-template-columns:repeat(2,1fr)}.dashboard-metric-grid{grid-template-columns:1fr}.dashboard-hero{padding:32px 24px}.dashboard-hero-header{flex-direction:column;gap:24px}.dashboard-health-card{min-width:0;width:100%}}@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)}}
