:root{--bg-primary:#eef1f8;--panel-bg:transparent;--panel-border:transparent;--save-btn:black;--card-bg:#fff;--card-tint:#fff;--card-secondary:#f3f4f8;--card-inset:#f8f9fc;--card-inset-border:#e8ebf2;--card-border:#e3e6ef;--card-shadow:0 1px 2px #0f172a0a, 0 8px 24px #0f172a0f;--radius-sm:10px;--radius-md:16px;--radius-lg:20px;--radius-xl:24px;--text-primary:#0f172a;--text-secondary:#334155;--text-muted:#64748b;--text-btn:#0f172a;--button-bg:#f1f3f9;--button-hover:#e8ebf3;--accent:#4f6ef7;--accent-soft:#4f6ef71a;--accent-hover:#4563e0;--success:#059669;--success-soft:#0596691a;--danger:#dc2626;--danger-soft:#dc262614;--warning:#d97706;--chart-income:#4f6ef7;--chart-expense:#64748b;--sidebar-bg:#fff;--glass-bg:#ffffffb8;--glass-border:#ffffff80;--scrollbar:#cbd5e1;--shadow:var(--card-shadow)}html[data-theme=dark]{--bg-primary:#0b0f14;--save-btn:white;--panel-bg:transparent;--panel-border:transparent;--card-bg:#1e2636;--card-tint:#141a22;--card-secondary:#1a222d;--card-inset:#111820;--card-inset-border:#232d3b;--card-border:#334155;--card-shadow:0 0 0 1px #ffffff0d, 0 4px 6px #0003, 0 16px 40px #00000059;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--text-btn:#f1f5f9;--button-bg:#1a222d;--button-hover:#232d3b;--accent:#6b8cff;--accent-soft:#6b8cff24;--accent-hover:#8ba3ff;--success:#34d399;--success-soft:#34d3991f;--danger:#f87171;--danger-soft:#f871711a;--chart-income:#6b8cff;--chart-expense:#64748b;--sidebar-bg:#141a22;--glass-bg:#141a22d9;--glass-border:#ffffff0f;--scrollbar:#334155;--shadow:var(--card-shadow)}html{overflow-x:hidden}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;margin:0;font-family:Inter,system-ui,-apple-system,sans-serif;transition:background .2s,color .2s;overflow-x:hidden}button,input,textarea{font-family:inherit}button{cursor:pointer}.dashboard-layout{box-sizing:border-box;background-color:var(--bg-primary);background-image:linear-gradient(#eef1f8c7,#eef1f8e0),url(/assets/auth-bgc-BQh1Y5C1.png);background-position:top;background-size:cover;background-attachment:scroll;align-items:stretch;gap:16px;width:100%;max-width:100%;min-height:100dvh;padding:16px;display:flex;overflow-x:hidden}html[data-theme=dark] .dashboard-layout{background-color:var(--bg-primary);background-image:linear-gradient(#0b0f14ad,#0b0f14c7),url(/assets/auth-bgc-BQh1Y5C1.png)}.dashboard-content{box-sizing:border-box;flex:1;width:100%;min-width:0}@media (width<=1200px){.dashboard-layout{gap:14px;padding:14px}}@media (width<=1024px){.dashboard-layout{flex-direction:column;gap:12px;min-height:auto;padding:72px 12px 12px}.dashboard-content{overflow-x:hidden;border-radius:0!important;padding:18px!important}.page-header-text h1{font-size:26px!important}}@media (width<=768px){.dashboard-layout{padding-top:68px}.dashboard-content{padding:16px!important}.page-header-text h1{font-size:24px!important}}@media (width<=480px){.dashboard-layout{padding:64px 8px 8px}.dashboard-content{padding:14px!important}.page-header-text h1{font-size:22px!important}}.dashboard-content.app-page-panel{box-sizing:border-box;width:100%;min-width:0;box-shadow:none;background:0 0;border:none;border-radius:0;flex:1;padding:32px 36px;overflow:hidden visible}.app-page-panel .page-header-text h1{color:var(--text-primary);letter-spacing:-.03em}.app-page-panel .page-header-text p,.app-page-panel .analytics-loading,.app-page-panel .recommendations-loading,.app-page-panel .settings-loading,.app-page-panel .admin-loading-text,.app-page-panel .dashboard-loading{color:var(--text-secondary)}@media (width<=1024px){.dashboard-content.app-page-panel{padding:20px 18px}}@media (width<=480px){.dashboard-content.app-page-panel{padding:16px 14px}}.dashboard-layout{contain:layout}.dashboard-content.app-page-panel{-webkit-backdrop-filter:none;background:var(--panel-bg);contain:layout}.sidebar{-webkit-backdrop-filter:none;background:var(--sidebar-bg)}.analytics-grid>*,.recommendations-grid>*,.admin-grid>*,.admin-ai-layout>*,.help-articles-grid>*,.wallet-main-grid>*,.settings-sections>*{content-visibility:auto;contain-intrinsic-size:auto 280px}.dashboard-widget-fallback{border-radius:var(--radius-lg);background:var(--card-bg);border:1px solid var(--card-border);opacity:.6;min-height:200px}.modal-overlay{z-index:999;overscroll-behavior:contain;background:#0f172a73;justify-content:center;align-items:center;padding:24px 16px;display:flex;position:fixed;inset:0;overflow-y:auto}.modal-overlay>.modal-content,.modal-overlay>.all-transactions-modal,.modal-overlay>.transaction-modal,.modal-overlay>.import-modal,.modal-overlay>.success-modal{flex-shrink:0;max-height:calc(100dvh - 48px);margin:auto;overflow-y:auto}@media (width<=768px){.modal-overlay{align-items:center;padding:16px 12px}}@media (width<=480px){.modal-overlay{align-items:center;padding:12px 8px}}.surface-inset,.forecast-item,.recommendation-item,.goal-item{background:var(--card-inset);border:1px solid var(--card-inset-border);border-radius:var(--radius-md)}html[data-theme=dark] .surface-inset,html[data-theme=dark] .forecast-item,html[data-theme=dark] .recommendation-item,html[data-theme=dark] .goal-item{background:#ffffff0a}.surface-inset--danger,.recommendation-item.priority-high{background:var(--danger-soft);border-color:#dc262633}.surface-section-title{letter-spacing:-.02em;color:var(--text-primary);margin:0 0 4px;font-size:17px;font-weight:600}.surface-section-subtitle{color:var(--text-secondary);margin:0 0 20px;font-size:13px}.wallet-insights,.recommendations-card,.forecast-card,.goals-panel,.analytics-card,.balance-card,.top-categories-widget,.transactions-block,.chart-block,.dashboard-empty-state,.family-hero-card,.family-card,.settings-card,.admin-card,.admin-panel,.wallet-metrics-bar,.summary-stat-card{border-radius:var(--radius-lg);background:linear-gradient(145deg, var(--card-bg) 0%, color-mix(in srgb, var(--accent) 6%, var(--card-bg)) 100%);border:1px solid color-mix(in srgb, var(--accent) 28%, var(--card-border));box-shadow:0 0 0 1px color-mix(in srgb, var(--accent) 8%, transparent), 0 10px 40px #4f6ef71f;position:relative;overflow:hidden}.wallet-insights:before,.recommendations-card:before,.forecast-card:before,.goals-panel:before,.analytics-card:before,.balance-card:before,.top-categories-widget:before,.transactions-block:before,.chart-block:before,.dashboard-empty-state:before,.family-hero-card:before,.family-card:before,.settings-card:before,.admin-card:before,.admin-panel:before,.wallet-metrics-bar:before,.summary-stat-card:before{content:"";background:linear-gradient(90deg, var(--accent) 0%, color-mix(in srgb, var(--accent) 60%, #34d399) 100%);pointer-events:none;height:3px;position:absolute;top:0;left:0;right:0}html[data-theme=dark] .wallet-insights,html[data-theme=dark] .recommendations-card,html[data-theme=dark] .forecast-card,html[data-theme=dark] .goals-panel,html[data-theme=dark] .analytics-card,html[data-theme=dark] .balance-card,html[data-theme=dark] .top-categories-widget,html[data-theme=dark] .transactions-block,html[data-theme=dark] .chart-block,html[data-theme=dark] .dashboard-empty-state,html[data-theme=dark] .family-hero-card,html[data-theme=dark] .family-card,html[data-theme=dark] .settings-card,html[data-theme=dark] .admin-card,html[data-theme=dark] .admin-panel,html[data-theme=dark] .wallet-metrics-bar,html[data-theme=dark] .summary-stat-card{background:linear-gradient(145deg,#1a2438 0%,#151d2e 55%,#121824 100%);border-color:#6b8cff59;box-shadow:0 0 0 1px #6b8cff26,0 16px 48px #00000073,inset 0 1px #ffffff0a}.balance-card.balance-card--hero{background:linear-gradient(160deg, color-mix(in srgb, var(--accent) 10%, var(--card-bg)) 0%, color-mix(in srgb, var(--accent) 4%, var(--card-inset)) 100%)}html[data-theme=dark] .balance-card.balance-card--hero{background:linear-gradient(160deg,#1e2a42 0%,#151d2e 60%,#121824 100%)}.featured-card-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.featured-card-header--wrap{flex-wrap:wrap;align-items:flex-start}.featured-card-heading{align-items:center;gap:12px;min-width:0;display:flex}.featured-card-icon-badge{background:var(--accent);color:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex;box-shadow:0 6px 18px #4f6ef773}.featured-card-icon-badge svg{font-size:22px}.featured-card-heading h2,.featured-card-heading h3{letter-spacing:-.02em;color:var(--text-primary);margin:0;font-size:18px;font-weight:700;line-height:1.2}.featured-card-heading h3{font-size:17px}.featured-card-heading p{color:var(--text-secondary);margin:2px 0 0;font-size:12px;line-height:1.4}.featured-card-action{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:999px;flex-shrink:0;align-items:center;gap:6px;height:36px;padding:0 14px;font-size:13px;font-weight:600;text-decoration:none;transition:background .15s,transform .15s;display:inline-flex;box-shadow:0 4px 14px #4f6ef759}.featured-card-action:hover{background:var(--accent-hover);color:#fff;transform:translateY(-1px)}.featured-card-action--soft{background:var(--accent-soft);color:var(--accent);box-shadow:none;border:1px solid color-mix(in srgb, var(--accent) 30%, transparent)}.featured-card-action--soft:hover{background:color-mix(in srgb, var(--accent) 18%, transparent);color:var(--accent)}.featured-inset-panel{border-radius:var(--radius-md);background:linear-gradient(160deg,#4f6ef72e 0%,#4f6ef70f 100%);border:1px solid #4f6ef740;padding:18px}html[data-theme=dark] .featured-inset-panel{background:linear-gradient(160deg,#6b8cff38 0%,#6b8cff14 100%);border-color:#6b8cff59}.featured-inset-panel--danger{background:linear-gradient(160deg,#f8717129 0%,#f871710d 100%);border-color:#f8717159}@media (width<=640px){.featured-card-header{flex-direction:column;align-items:stretch}.featured-card-action{justify-content:center}}.chart-block{overflow:visible}.brand-logo-root{align-items:center;line-height:0;display:inline-flex}.brand-logo{object-fit:contain;flex-shrink:0;display:block}.brand-logo--full{width:auto;max-width:100%;height:auto}.brand-logo-root--hero{box-sizing:border-box;background:#ffffff1f;border:1px solid #ffffff26;border-radius:30px;justify-content:center;align-items:center;width:fit-content;max-width:100%;margin:0 0 16px;padding:12px 20px;line-height:0;display:inline-flex}.brand-logo-root--hero .brand-logo--full{width:min(300px,100vw - 120px);max-width:100%;height:auto}.brand-logo-root--auth{width:100%;max-width:420px}.brand-logo-root--auth .brand-logo--full{width:min(320px,80vw)}.brand-logo-root--badge{justify-content:center;width:100%}.brand-logo-badge{background:#fff;border-radius:50%;justify-content:center;align-items:center;width:76px;height:76px;display:flex;box-shadow:0 8px 24px #4a89c72e,0 2px 8px #0000000f}.brand-logo--short{width:42px;height:auto}.brand-logo-root--auth-panel{margin-bottom:28px}.hero-carousel{contain:layout paint;width:52%;max-width:760px;position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000,#000 8% 92%,#0000);mask-image:linear-gradient(90deg,#0000,#000 8% 92%,#0000)}.hero-carousel-track{will-change:transform;gap:24px;width:max-content;animation:28s linear infinite hero-carousel-scroll;display:flex}.hero-carousel-card{aspect-ratio:16/10;background:#0f172a8c;border:1px solid #ffffff2e;border-radius:22px;flex-shrink:0;width:min(580px,44vw);overflow:hidden;box-shadow:0 16px 40px #00000047}.hero-carousel-card img{object-fit:contain;object-position:top center;width:100%;height:100%;display:block}@keyframes hero-carousel-scroll{0%{transform:translate(0,0)}to{transform:translate(-50%)}}@media (width<=1200px){.hero-carousel{width:100%;max-width:none;-webkit-mask-image:none;mask-image:none}.hero-carousel-card{width:min(480px,84vw)}}@media (width<=768px){.hero-carousel-card{aspect-ratio:16/11;border-radius:16px;width:min(300px,82vw)}.hero-carousel-track{gap:16px;animation-duration:22s}}@media (prefers-reduced-motion:reduce){.hero-carousel-track{flex-wrap:wrap;justify-content:center;width:100%;animation:none}.hero-carousel{overflow:visible}.hero-carousel-card:nth-child(n+4){display:none}}.home-page{background-position:50%;background-size:cover;min-height:100vh;overflow:hidden}.home-overlay{min-height:100vh;padding:40px 80px}.home-header{justify-content:flex-end;align-items:center;margin-bottom:40px;display:flex}.login-btn{color:#fff;cursor:pointer;background:#ffffff1f;border:1px solid #ffffff2e;border-radius:18px;width:140px;height:52px;font-size:16px;transition:all .3s}.home-header-btn{color:#fff;cursor:pointer;background:#ffffff1f;border:1px solid #ffffff2e;border-radius:18px;width:auto;min-width:112px;height:52px;padding:0 22px;font-size:16px;font-weight:600;transition:all .3s}.home-header-btn:hover,.login-btn:hover{background:#ffffff29;transform:translateY(-2px)}.home-header-btn:disabled,.login-btn:disabled{opacity:.7;cursor:wait;transform:none}.hero-section{justify-content:space-between;align-items:center;gap:60px;display:flex}.hero-content{flex-direction:column;align-items:flex-start;width:50%;display:flex}.hero-badge{color:#ffffffd9;background:#ffffff1f;border:1px solid #ffffff26;border-radius:30px;margin-bottom:30px;padding:12px 20px;display:inline-block}.hero-content h1{color:#fff;margin:0 0 30px;font-size:88px;line-height:1}.hero-content p{color:#ffffffb8;max-width:650px;margin-bottom:40px;font-size:22px;line-height:1.7}.hero-buttons{gap:20px;display:flex}.join-btn,.secondary-btn{cursor:pointer;border:none;border-radius:22px;height:62px;padding:0 35px;font-size:17px;font-weight:700;transition:all .3s}.join-btn{color:#fff;background:linear-gradient(135deg,#ffffff47,#ffffff1f);border:1px solid #fff3}.join-btn:hover{background:linear-gradient(135deg,#ffffff59,#ffffff26);transform:translateY(-3px)}.secondary-btn{color:#ffffffeb;background:#ffffff14;border:1px solid #ffffff2e}.secondary-btn:hover{background:#ffffff24;transform:translateY(-3px)}.hero-section--auth{padding-top:12px}@media (width<=1400px){.hero-content h1{font-size:70px}}@media (width<=1200px){.hero-section{flex-direction:column}.hero-content{width:100%}}@media (width<=768px){.home-header{z-index:20;margin-bottom:20px;padding-top:4px;display:flex;position:sticky;top:0}.home-header-btn{border-radius:14px;height:44px;padding:0 18px;font-size:15px}.home-overlay{padding:20px 20px 30px}.hero-content .brand-logo-root--hero{padding:10px 16px}.hero-content .brand-logo-root--hero .brand-logo--full{width:min(240px,100vw - 92px)}.hero-content h1{font-size:52px}.hero-content p{font-size:18px}.hero-buttons{flex-direction:column;width:100%}.join-btn,.secondary-btn{width:100%}}.forgot-modal-backdrop{z-index:1200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172a85;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.forgot-modal{background:linear-gradient(160deg, var(--card-bg,#fff) 0%, color-mix(in srgb, var(--accent,#4f6ef7) 7%, var(--card-bg,#fff)) 100%);border:1px solid color-mix(in srgb, var(--accent,#4f6ef7) 22%, var(--card-border,#e3e6ef));text-align:center;border-radius:24px;width:min(440px,100%);padding:32px 28px 28px;position:relative;box-shadow:0 24px 60px #0f172a2e,inset 0 0 0 1px #fff6}.forgot-modal-close{background:var(--card-inset,#f3f4f8);width:36px;height:36px;color:var(--text-secondary,#64748b);cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:16px;right:16px}.forgot-modal-icon{background:color-mix(in srgb, var(--accent,#4f6ef7) 14%, transparent);width:56px;height:56px;color:var(--accent,#4f6ef7);border-radius:18px;justify-content:center;align-items:center;margin:0 auto 18px;font-size:24px;display:flex}.forgot-modal h3{color:var(--text-primary,#0f172a);margin:0 0 8px;font-size:24px}.forgot-modal-subtitle{color:var(--text-secondary,#64748b);margin:0 0 22px;font-size:15px;line-height:1.5}.forgot-modal form{flex-direction:column;gap:14px;display:flex}.forgot-modal input{border:1px solid var(--card-inset-border,#e8ebf2);background:var(--card-inset,#f8f9fc);border-radius:14px;outline:none;height:52px;padding:0 16px;font-size:16px}.forgot-modal input:focus{border-color:var(--accent,#4f6ef7);box-shadow:0 0 0 4px color-mix(in srgb, var(--accent,#4f6ef7) 15%, transparent)}.forgot-modal button[type=submit]{background:var(--accent,#4f6ef7);color:#fff;cursor:pointer;border:none;border-radius:16px;justify-content:center;align-items:center;gap:10px;height:52px;font-size:16px;font-weight:600;display:inline-flex}.forgot-modal button[type=submit]:disabled{opacity:.7;cursor:wait}.forgot-modal-error{color:#dc2626;margin:0;font-size:14px}.forgot-modal-success{background:color-mix(in srgb, var(--accent,#4f6ef7) 12%, transparent);color:var(--text-primary,#0f172a);border-radius:14px;margin:0;padding:14px 16px;font-size:14px;line-height:1.5}.forgot-modal .inline-spinner{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.75s linear infinite forgot-inline-spin}@keyframes forgot-inline-spin{to{transform:rotate(360deg)}}@media (width<=480px){.forgot-modal-backdrop{align-items:flex-end;padding:16px}.forgot-modal{border-bottom-right-radius:0;border-bottom-left-radius:0}}*{box-sizing:border-box}body{margin:0;font-family:Arial,sans-serif}.auth-page{min-height:100vh;display:flex}.auth-left{flex:1;justify-content:center;align-items:center;display:flex}.auth-overlay{color:#fff;padding:40px}.brand{flex-direction:column;align-items:flex-start;gap:28px;display:flex}.brand p{max-width:420px;margin:0;font-size:20px;line-height:1.6}.auth-right{background:#fff;justify-content:center;align-items:center;width:500px;padding:40px 40px 48px;display:flex}.auth-panel{flex-direction:column;align-items:center;width:100%;max-width:380px;display:flex}.auth-card{width:100%}.auth-card h2{margin-bottom:10px;font-size:36px}.auth-subtitle{color:#666;margin-bottom:35px}.auth-card form{flex-direction:column;gap:18px;display:flex}.auth-card input{border:1px solid #ddd;border-radius:14px;height:55px;padding:0 18px;font-size:16px}.auth-options{color:#666;justify-content:space-between;align-items:center;font-size:14px;display:flex}.auth-options span{cursor:pointer}.auth-forgot-link{color:#666;cursor:pointer;text-underline-offset:3px;white-space:nowrap;background:0 0;border:none;border-radius:0;flex-shrink:0;height:auto;min-height:0;margin:0;padding:0;font-size:14px;font-weight:500;line-height:1.4;text-decoration:underline}.auth-forgot-link:hover{color:#0f172a;opacity:1;background:0 0}.remember{align-items:center;display:flex}.auth-card button[type=submit],.auth-card .auth-submit-btn{color:#fff;cursor:pointer;background:#000;border:none;border-radius:14px;height:55px;font-size:16px;font-weight:700;transition:all .2s}.auth-submit-btn{justify-content:center;align-items:center;gap:10px;display:inline-flex}.auth-submit-btn:disabled{opacity:.75;cursor:wait}@keyframes auth-inline-spin{to{transform:rotate(360deg)}}.auth-card button[type=submit]:hover,.auth-card .auth-submit-btn:hover{opacity:.9}.bottom-link{text-align:center;color:#666;margin-top:25px}.bottom-link span{color:#000;cursor:pointer;margin-left:8px;font-weight:700}.auth-error{color:#dc2626;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:14px;width:100%;padding:1px 16px;font-size:14px;font-weight:500}@media (width<=900px){.auth-left{display:none}.auth-right{width:100%}}.otp-input{justify-content:center;gap:10px;width:100%;display:flex}.otp-cell{flex-direction:column;flex:1;align-items:center;gap:10px;max-width:52px;display:flex;position:relative}.otp-cell input{background:var(--card-inset,#f3f4f8);width:100%;height:54px;color:var(--text-primary,#0f172a);text-align:center;border:none;border-radius:14px;outline:none;font-size:28px;font-weight:700;transition:background .2s,box-shadow .2s,transform .2s}.otp-cell input:focus{background:var(--card-bg,#fff)}.otp-cell.is-active input{background:var(--card-bg,#fff);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent,#4f6ef7) 18%, transparent);transform:translateY(-1px)}.otp-cell.is-filled input{background:color-mix(in srgb, var(--accent,#4f6ef7) 8%, var(--card-bg,#fff))}.otp-bar{background:var(--card-inset-border,#e8ebf2);border-radius:999px;width:100%;height:3px;transition:background .2s,transform .2s,box-shadow .2s}.otp-cell.is-active .otp-bar{background:var(--accent,#4f6ef7);box-shadow:0 0 12px color-mix(in srgb, var(--accent,#4f6ef7) 45%, transparent);transform:scaleX(1.04)}.otp-cell.is-filled .otp-bar{background:color-mix(in srgb, var(--accent,#4f6ef7) 55%, var(--card-inset-border,#e8ebf2))}.otp-cell input:disabled{opacity:.65;cursor:not-allowed}@media (width<=480px){.otp-input{gap:8px}.otp-cell{max-width:46px}.otp-cell input{border-radius:12px;height:48px;font-size:24px}}.verification-modal-backdrop{z-index:1200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172a85;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.verification-modal{background:linear-gradient(160deg, var(--card-bg,#fff) 0%, color-mix(in srgb, var(--accent,#4f6ef7) 7%, var(--card-bg,#fff)) 100%);border:1px solid color-mix(in srgb, var(--accent,#4f6ef7) 22%, var(--card-border,#e3e6ef));text-align:center;border-radius:24px;width:min(440px,100%);padding:32px 28px 28px;position:relative;box-shadow:0 24px 60px #0f172a2e,inset 0 0 0 1px #fff6}.verification-modal-close{background:var(--card-inset,#f3f4f8);width:36px;height:36px;color:var(--text-secondary,#64748b);cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;transition:all .15s;display:inline-flex;position:absolute;top:16px;right:16px}.verification-modal-close:hover:not(:disabled){background:var(--button-hover,#e8ebf3);color:var(--text-primary,#0f172a)}.verification-modal-icon{background:color-mix(in srgb, var(--accent,#4f6ef7) 14%, transparent);width:56px;height:56px;color:var(--accent,#4f6ef7);border-radius:18px;justify-content:center;align-items:center;margin:0 auto 18px;font-size:24px;display:flex}.verification-modal h3{color:var(--text-primary,#0f172a);margin:0 0 8px;font-size:24px;line-height:1.2}.verification-modal-subtitle{color:var(--text-secondary,#64748b);margin:0 0 10px;font-size:15px;line-height:1.5}.verification-modal-email{color:var(--text-primary,#0f172a);word-break:break-word;margin:0 0 24px;font-size:15px;font-weight:700}.verification-modal-error{color:#dc2626;margin:14px 0 0;font-size:14px;line-height:1.4}.verification-modal-submit{background:var(--accent,#4f6ef7);color:#fff;cursor:pointer;border:none;border-radius:16px;justify-content:center;align-items:center;gap:10px;width:100%;height:52px;margin-top:22px;font-size:16px;font-weight:600;transition:all .15s;display:inline-flex}.verification-modal-submit:hover:not(:disabled){background:var(--accent-hover,#4563e0);transform:translateY(-1px)}.verification-modal-submit:disabled{opacity:.65;cursor:not-allowed;transform:none}.verification-modal-submit .inline-spinner{border-color:#fff #ffffff59 #ffffff59}.verification-modal-resend{width:100%;color:var(--accent,#4f6ef7);cursor:pointer;background:0 0;border:none;margin-top:12px;padding:8px 0;font-size:14px;font-weight:600}.verification-modal-resend:disabled{color:var(--text-muted,#94a3b8);cursor:not-allowed}.verification-modal-hint{color:var(--text-muted,#94a3b8);margin:16px 0 0;font-size:13px;line-height:1.45}.inline-spinner{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.75s linear infinite verification-inline-spin}@keyframes verification-inline-spin{to{transform:rotate(360deg)}}@media (width<=480px){.verification-modal-backdrop{align-items:flex-end;padding:16px}.verification-modal{border-bottom-right-radius:0;border-bottom-left-radius:0;padding:28px 22px 24px}}.reset-password-page{background-position:50%;background-size:cover;min-height:100vh}.reset-password-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a6b;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.reset-password-modal{text-align:center;background:linear-gradient(160deg,#fff 0%,#f3f5fe 100%);border:1px solid #c2ccf1;border-radius:24px;width:min(440px,100%);padding:32px 28px 28px;box-shadow:0 24px 60px #0f172a38}.reset-password-modal .brand-logo-root{margin:0 auto 20px}.reset-password-icon{color:#4f6ef7;background:#4f6ef724;border-radius:18px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;font-size:24px;display:flex}.reset-password-modal h1{color:#0f172a;margin:0 0 10px;font-size:28px}.reset-password-subtitle{color:#64748b;margin:0 0 24px;font-size:15px;line-height:1.5}.reset-password-status{color:#64748b;margin:24px 0 0;font-size:15px}.reset-password-modal form{flex-direction:column;gap:14px;display:flex}.reset-password-modal input{background:#f8f9fc;border:1px solid #e8ebf2;border-radius:14px;outline:none;height:52px;padding:0 16px;font-size:16px}.reset-password-modal input:focus{border-color:#4f6ef7;box-shadow:0 0 0 4px #4f6ef726}.reset-password-error{color:#dc2626;text-align:left;margin:0;font-size:14px}.reset-password-btn{color:#fff;cursor:pointer;background:#4f6ef7;border:none;border-radius:16px;justify-content:center;align-items:center;gap:10px;height:52px;font-size:16px;font-weight:600;display:inline-flex}.reset-password-btn.secondary{color:#0f172a;background:#f1f3f9;width:100%;margin-top:8px}.reset-password-btn:disabled{opacity:.7;cursor:wait}.reset-password-modal .inline-spinner{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.75s linear infinite reset-inline-spin}@keyframes reset-inline-spin{to{transform:rotate(360deg)}}@media (width<=480px){.reset-password-overlay{align-items:flex-end;padding:0}.reset-password-modal{border-bottom-right-radius:0;border-bottom-left-radius:0}}.sidebar{border-radius:var(--radius-xl);box-sizing:border-box;background:var(--sidebar-bg);border:1px solid var(--card-border);width:260px;box-shadow:var(--card-shadow);flex-direction:column;flex-shrink:0;justify-content:space-between;gap:16px;padding:24px 16px;transition:background .2s,border-color .2s;display:flex}.sidebar--desktop{overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:var(--scrollbar) transparent;align-self:stretch;height:calc(100dvh - 32px);min-height:calc(100dvh - 32px);max-height:calc(100dvh - 32px);position:sticky;top:16px;overflow-y:auto}.sidebar-profile{border-radius:var(--radius-md);background:var(--card-inset);text-align:center;flex-direction:column;align-items:center;gap:12px;margin-bottom:32px;padding:16px 12px;display:flex}.profile-icon{background:var(--accent-soft);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:76px;height:76px;margin:0;display:flex}.profile-icon svg{color:var(--accent);font-size:28px}.sidebar-profile-info{width:100%;min-width:0}.sidebar-profile-info h3{color:var(--text-primary);-webkit-line-clamp:2;word-break:break-word;-webkit-box-orient:vertical;margin:0;font-size:14px;font-weight:600;line-height:1.35;display:-webkit-box;overflow:hidden}.sidebar-top{position:relative}.profile-avatar{object-fit:cover;border-radius:50%;width:100%;height:100%}.sidebar-menu,.sidebar-bottom{flex-direction:column;gap:4px;display:flex}.menu-item{border-radius:var(--radius-sm);height:44px;color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:0 14px;font-size:14px;font-weight:500;transition:background .15s,color .15s;display:flex}.menu-item svg{opacity:.85;flex-shrink:0;font-size:18px}.menu-item:hover{background:var(--button-bg);color:var(--text-primary)}.menu-item.active{background:var(--accent-soft);color:var(--accent);font-weight:600}.menu-item.active svg{opacity:1}.logout{color:var(--danger)}.logout:hover{background:var(--danger-soft);color:var(--danger)}.burger-btn{border:1px solid var(--card-border);border-radius:var(--radius-sm);background:var(--card-bg);width:44px;height:44px;box-shadow:var(--card-shadow);z-index:2000;cursor:pointer;justify-content:center;align-items:center;display:none;position:fixed;top:16px;right:16px}.burger-btn svg{color:var(--text-primary);font-size:22px}.close-sidebar{border-radius:var(--radius-sm);background:var(--button-bg);cursor:pointer;border:none;justify-content:center;align-items:center;width:40px;height:40px;display:none;position:absolute;top:0;right:0}.close-sidebar svg{color:var(--text-primary);font-size:20px}.sidebar-mobile-shell{z-index:2100;box-sizing:border-box;pointer-events:auto;justify-content:center;align-items:center;padding:20px 16px;display:flex;position:fixed;inset:0}.sidebar-mobile-overlay{-webkit-backdrop-filter:blur(6px);cursor:pointer;background:#0f172a85;border:none;margin:0;padding:0;animation:.2s sidebar-overlay-in;position:absolute;inset:0}html[data-theme=dark] .sidebar-mobile-overlay{background:#02060eb8}.sidebar--mobile{z-index:1;overscroll-behavior:contain;width:min(420px,100%);height:auto;max-height:min(88dvh,760px);margin:0;animation:.24s sidebar-panel-in;position:relative;overflow-y:auto}@keyframes sidebar-overlay-in{0%{opacity:0}to{opacity:1}}@keyframes sidebar-panel-in{0%{opacity:0;transform:translateY(12px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=1200px){.sidebar--desktop{width:240px;padding:20px 14px}.profile-icon{width:56px;height:56px}.sidebar-profile{margin-bottom:24px}}@media (width<=1024px){.burger-btn{display:flex}.sidebar--desktop{display:none}.close-sidebar{display:flex}.sidebar--mobile .sidebar-profile{margin-bottom:24px;padding-top:44px;padding-right:10px}}@media (width<=480px){.burger-btn{width:42px;height:42px;top:12px;right:12px}.sidebar-mobile-shell{align-items:center;padding:12px}.sidebar--mobile{border-radius:var(--radius-lg);width:100%;max-height:calc(100dvh - 24px);padding:20px 14px}.menu-item{height:42px;font-size:13px}}@media (prefers-reduced-motion:reduce){.sidebar-mobile-overlay,.sidebar--mobile{animation:none}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.page-header-main{flex:1;align-items:flex-start;gap:14px;min-width:0;display:flex}.page-header-icon{border-radius:var(--radius-md);background:var(--accent-soft);width:44px;height:44px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.page-header-icon svg{font-size:22px}.page-header-text h1{letter-spacing:-.03em;color:var(--text-primary);margin:0;font-size:26px;font-weight:700;line-height:1.15}.page-header-text p{color:var(--text-secondary);margin:6px 0 0;font-size:14px;line-height:1.45}.page-header-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}@media (width<=768px){.page-header-text h1{font-size:22px}.page-header-icon{width:40px;height:40px}.page-header-icon svg{font-size:20px}}@media (width<=480px){.page-header{margin-bottom:18px}.page-header-text h1{font-size:20px}}.recommendations-card,.forecast-card,.goals-panel{padding:22px 24px 24px}.recommendations-empty,.goals-empty{color:var(--text-secondary);font-size:14px;line-height:1.5}.recommendations-items,.goals-list{flex-direction:column;gap:10px;display:flex}.recommendation-item{gap:12px;padding:14px 16px;display:flex;box-shadow:0 2px 8px #0f172a0f}html[data-theme=dark] .recommendation-item{box-shadow:none}.recommendation-item.priority-high.type-deficit_recovery,.recommendation-item.priority-high{background:#f871711a;border-color:#f8717173}.recommendation-item.priority-medium.type-save_opportunity,.recommendation-item.priority-medium.type-goal_boost,.recommendation-item.priority-medium.type-create_goal{background:#34d3991a;border-color:#34d39966}.recommendation-item.priority-medium:not(.type-save_opportunity):not(.type-goal_boost):not(.type-create_goal){background:#6b8cff1a;border-color:#6b8cff59}.recommendation-icon{background:var(--accent-soft);width:38px;height:38px;color:var(--accent);border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.recommendation-item.priority-high .recommendation-icon{color:var(--danger);background:#f871712e}.recommendation-item.priority-medium.type-save_opportunity .recommendation-icon,.recommendation-item.priority-medium.type-goal_boost .recommendation-icon,.recommendation-item.priority-medium.type-create_goal .recommendation-icon{color:var(--success);background:#34d3992e}.recommendation-content h3{color:var(--text-primary);margin:0 0 5px;font-size:14px;font-weight:700;line-height:1.3}.recommendation-content p{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.45}html:not([data-theme=dark]) .recommendation-content p,html:not([data-theme=dark]) .wallet-insight-content p,html:not([data-theme=dark]) .wallet-insights-forecast-note,html:not([data-theme=dark]) .forecast-summary,html:not([data-theme=dark]) .forecast-item span{color:#334155}html:not([data-theme=dark]) .featured-card-heading p,html:not([data-theme=dark]) .page-header-text p{color:#475569}html[data-theme=dark] .recommendation-content p{color:#cbd5e1}.recommendation-action{color:var(--accent);margin-top:6px;font-size:12px;font-weight:500;display:inline-block}.forecast-card{padding:22px 24px 24px}.forecast-confidence{background:var(--card-inset);color:var(--text-secondary);border:1px solid var(--card-inset-border);border-radius:999px;flex-shrink:0;padding:6px 12px;font-size:11px;font-weight:600}.forecast-confidence.confidence-high{background:var(--success-soft);color:var(--success);border-color:#05966933}.forecast-confidence.confidence-medium{background:var(--accent-soft);color:var(--accent);border-color:#4f6ef733}.forecast-summary{color:var(--text-secondary);margin:0 0 16px;font-size:14px;line-height:1.5}.forecast-grid{grid-template-columns:repeat(auto-fit,minmax(168px,1fr));gap:10px;display:grid}.forecast-item{text-align:left;padding:14px 16px}.forecast-item span{letter-spacing:.04em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:6px;font-size:11px;font-weight:600;display:block}.forecast-item strong{letter-spacing:-.02em;color:var(--text-primary);font-size:20px;font-weight:700;display:block}.forecast-item.highlight{background:linear-gradient(160deg,#4f6ef72e 0%,#4f6ef70f 100%);border-color:#4f6ef740}.forecast-item.highlight strong{color:var(--accent);font-size:24px}html[data-theme=dark] .forecast-item.highlight{background:linear-gradient(160deg,#6b8cff38 0%,#6b8cff14 100%)}.forecast-trend{color:var(--text-muted);margin-top:4px;font-size:11px;display:block}.forecast-trend.trend-up{color:var(--success)}.forecast-trend.trend-down{color:var(--danger)}.forecast-monthly-pair{flex-direction:column;gap:2px;display:flex;font-size:16px!important}.forecast-income{color:var(--success)}.forecast-expense{color:var(--text-secondary);font-weight:500}@media (width<=640px){.forecast-confidence{align-self:flex-start}}.dashboard-empty-state{padding:22px 24px 24px}.dashboard-empty-state>p{max-width:520px;color:var(--text-secondary);margin:0 0 20px;font-size:14px;line-height:1.55}.dashboard-empty-actions{flex-wrap:wrap;gap:10px;margin-bottom:24px;display:flex}.dashboard-empty-btn{border:1px solid var(--card-inset-border);background:var(--card-inset);height:42px;color:var(--text-primary);cursor:pointer;border-radius:999px;align-items:center;gap:8px;padding:0 18px;font-size:14px;font-weight:500;transition:background .15s;display:inline-flex}.dashboard-empty-btn:hover{background:var(--button-hover)}.dashboard-empty-btn.primary{background:var(--accent);color:#fff;border-color:#0000;box-shadow:0 4px 14px #4f6ef759}.dashboard-empty-btn.primary:hover{background:var(--accent-hover)}.dashboard-empty-steps{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.dashboard-empty-steps li{border-radius:var(--radius-md);border:1px solid var(--card-inset-border);color:var(--text-primary);background:#ffffff0a;align-items:center;gap:12px;padding:12px 14px;font-size:13px;display:flex}html:not([data-theme=dark]) .dashboard-empty-steps li{background:var(--card-inset)}.dashboard-empty-steps svg{color:var(--accent);flex-shrink:0;font-size:16px}@media (width<=768px){.dashboard-empty-actions{flex-direction:column}.dashboard-empty-btn{justify-content:center;width:100%}}.dashboard-widgets{gap:16px;display:grid}.dashboard-more-link{justify-content:flex-end;display:flex}.dashboard-more-link button{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;font-weight:500}.summary-stats-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;display:grid}.summary-stat-card{align-items:flex-start;gap:16px;padding:22px;display:flex}.summary-stat-icon{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.summary-stat-icon svg{font-size:20px}.summary-stat-card.positive .summary-stat-icon{color:#16a34a;background:#22c55e1f}.summary-stat-card.negative .summary-stat-icon{color:#dc2626;background:#ef44441f}.summary-stat-card.neutral .summary-stat-icon{color:var(--accent);background:#8ea7ff2e}.summary-stat-content span{color:var(--text-secondary);margin-bottom:6px;font-size:13px;display:block}.summary-stat-content strong{color:var(--text-primary);font-size:22px;line-height:1.2;display:block}.summary-stat-content p{color:var(--text-secondary);margin:6px 0 0;font-size:12px}@media (width<=1200px){.summary-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=600px){.summary-stats-grid{grid-template-columns:1fr}.summary-stat-content strong{font-size:20px}}.period-filter{position:relative}.period-filter-group{border-radius:var(--radius-sm);background:var(--card-inset);border:1px solid var(--card-inset-border);flex-wrap:wrap;gap:2px;padding:3px;display:inline-flex}.period-filter-btn{color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:8px;padding:7px 12px;font-size:12px;font-weight:500;transition:all .15s}.period-filter-btn:hover{color:var(--text-primary)}.period-filter-btn.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px #4f6ef747}.period-range-picker{border-radius:var(--radius-md);border:1px solid var(--card-border);background:var(--card-bg);box-shadow:var(--card-shadow);padding:16px}.period-range-picker-header{color:var(--text-primary);align-items:center;gap:8px;margin-bottom:14px;font-size:14px;font-weight:600;display:flex}.period-range-picker-header svg{color:var(--accent)}.period-range-fields{grid-template-columns:1fr 1fr;gap:10px;display:grid}.period-range-fields label{flex-direction:column;gap:6px;display:flex}.period-range-fields span{letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);font-size:11px;font-weight:600}.period-range-fields input[type=date]{border:1px solid var(--card-inset-border);border-radius:var(--radius-sm);background:var(--card-inset);width:100%;height:40px;color:var(--text-primary);padding:0 10px;font-family:inherit;font-size:13px}.period-range-fields input[type=date]:focus{border-color:color-mix(in srgb, var(--accent) 45%, var(--card-inset-border));box-shadow:0 0 0 3px var(--accent-soft);outline:none}.period-range-actions{justify-content:flex-end;gap:8px;margin-top:14px;display:flex}.period-range-btn{border:1px solid var(--card-inset-border);background:var(--card-inset);height:36px;color:var(--text-primary);cursor:pointer;border-radius:999px;padding:0 14px;font-size:13px;font-weight:500}.period-range-btn--primary{background:var(--accent);color:#fff;border-color:#0000}.period-range-btn--primary:disabled{opacity:.5;cursor:not-allowed}.period-range-btn--ghost:hover{background:var(--button-hover)}.period-range-modal-overlay{z-index:2100;box-sizing:border-box;-webkit-backdrop-filter:blur(4px);background:#0f172a73;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}html[data-theme=dark] .period-range-modal-overlay{background:#02060eb8}.period-range-modal{width:min(420px,100%);max-height:calc(100dvh - 32px);overflow-y:auto}.period-range-modal .period-range-picker{box-shadow:var(--card-shadow)}@media (width<=640px){.period-filter-group{justify-content:stretch;width:100%}.period-filter-btn{flex:auto;min-width:0;padding:7px 8px;font-size:11px}.period-range-modal-overlay{padding:12px}.period-range-fields{grid-template-columns:1fr}.period-range-actions{flex-direction:column-reverse}.period-range-btn{width:100%}}.analytics-card{padding:22px 24px 24px}.analytics-empty{color:var(--text-secondary);text-align:center;padding:20px 0;font-size:14px}@media (width<=768px){.analytics-card{padding:20px}}.income-expense-trend .chart-filters{flex-wrap:wrap;gap:10px;display:flex}.income-expense-trend .chart-filters button{background:var(--button-bg);height:38px;color:var(--text-primary);cursor:pointer;border:none;border-radius:12px;padding:0 14px;transition:all .2s}.income-expense-trend .chart-filters button:hover{background:var(--button-hover)}.income-expense-trend .active-filter{background:var(--accent)!important;color:#fff!important}.trend-chart-wrapper{width:100%}.income-expense-trend .recharts-legend-item-text{font-size:13px;color:var(--text-secondary)!important}.income-expense-trend .recharts-default-legend .recharts-legend-item:first-child .recharts-legend-item-text{color:var(--chart-income)!important}.income-expense-trend .recharts-default-legend .recharts-legend-item:nth-child(2) .recharts-legend-item-text{color:var(--chart-expense)!important}.category-bars{flex-direction:column;gap:16px;display:flex}.category-bar-row{flex-direction:column;gap:8px;display:flex}.category-bar-meta{justify-content:space-between;align-items:center;gap:12px;display:flex}.category-bar-meta span{color:var(--text-primary);font-size:14px}.category-bar-meta strong{color:var(--text-primary);white-space:nowrap;font-size:14px}.category-bar-track{background:var(--button-bg);border-radius:999px;height:10px;overflow:hidden}.category-bar-fill{border-radius:999px;height:100%;transition:width .3s}.top-expenses-items{flex-direction:column;gap:12px;display:flex}.top-expense-item{background:var(--card-secondary);border:1px solid var(--button-bg);border-radius:18px;align-items:center;gap:14px;padding:14px 16px;display:flex}.top-expense-rank{width:32px;height:32px;color:var(--accent);background:#8ea7ff2e;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.top-expense-info{flex:1;min-width:0}.top-expense-info strong{color:var(--text-primary);font-size:14px;display:block}.top-expense-info span{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:13px;display:block;overflow:hidden}.top-expense-info small{color:var(--text-secondary);margin-top:4px;font-size:12px;display:block}.top-expense-amount{color:#dc2626;white-space:nowrap;font-size:15px;font-weight:700}.monthly-overview-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.month-card,.month-change{background:var(--card-secondary);border:1px solid var(--button-bg);border-radius:20px;padding:18px}.month-card span,.month-change span{color:var(--text-secondary);font-size:13px;display:block}.month-card strong,.month-change strong{color:var(--text-primary);margin-top:8px;font-size:22px;display:block}.month-card p{color:var(--text-secondary);margin:6px 0 0;font-size:13px}.month-card small{color:var(--text-secondary);margin-top:8px;font-size:12px;display:block}.month-change{flex-direction:column;justify-content:center;display:flex}.month-change-icon{border-radius:12px;justify-content:center;align-items:center;width:36px;height:36px;margin-bottom:10px;display:flex}.month-change.up .month-change-icon{color:#dc2626;background:#ef44441f}.month-change.down .month-change-icon{color:#16a34a;background:#22c55e1f}.month-change.up strong{color:#dc2626}.month-change.down strong{color:#16a34a}@media (width<=900px){.monthly-overview-grid{grid-template-columns:1fr}}.weekday-chart-wrapper{width:100%}.analytics-loading{color:var(--text-secondary);font-size:16px}.analytics-grid{flex-direction:column;gap:22px;display:flex}.analytics-row{gap:22px;display:grid}.analytics-row.two-cols{grid-template-columns:repeat(2,minmax(0,1fr))}@media (width<=1200px){.analytics-row.two-cols{grid-template-columns:1fr}}.recommendations-grid{gap:16px;display:grid}.category-picker{flex-direction:column;gap:10px;display:flex}.category-picker-label{color:var(--text-secondary);font-size:14px;font-weight:600}.category-picker-hint{color:var(--text-secondary);margin:0;font-size:13px}.categories-dropdown{flex-wrap:wrap;gap:10px;display:flex}.category-option{background:var(--button-bg);color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:14px;padding:10px 16px;font-size:14px;font-weight:500;transition:all .2s}.category-option:hover{background:var(--button-hover)}.category-option.active-category,.category-option-other.active-category{background:var(--accent);color:#fff}.category-other-input{border:1px solid var(--glass-border);background:var(--card-secondary);height:52px;color:var(--text-primary);border-radius:16px;outline:none;padding:0 18px;font-size:15px;transition:all .2s}.category-other-input:focus{border-color:var(--accent);box-shadow:0 0 0 4px #8ea7ff26}.category-other-input::placeholder{color:var(--text-secondary)}@media (width<=768px){.categories-dropdown{gap:8px}.category-option{border-radius:12px;padding:9px 14px;font-size:13px}.category-other-input{border-radius:14px;height:48px;font-size:14px}}@media (width<=480px){.category-option{text-align:center;border-radius:12px;width:100%;padding:10px 12px}}.modal-overlay.transaction-details-overlay{z-index:1300}.transaction-modal{background:var(--card-bg);border-radius:20px;width:min(400px,100%);max-height:calc(100dvh - 48px);padding:22px 22px 20px;overflow-y:auto;box-shadow:0 20px 56px #0f172a2e}.transaction-modal-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.transaction-modal-header h2{color:var(--text-primary);letter-spacing:-.02em;margin:0;font-size:18px;font-weight:700}.transaction-modal-actions{gap:6px;display:flex}.transaction-icon-btn{border:1px solid var(--card-inset-border);background:var(--card-inset);width:36px;height:36px;color:var(--text-primary);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;transition:background .15s;display:flex}.transaction-icon-btn:hover:not(:disabled){background:var(--button-hover)}.transaction-icon-btn.primary{background:var(--accent);color:#fff;border-color:#0000}.transaction-icon-btn.primary:hover:not(:disabled){background:var(--accent-hover)}.transaction-icon-btn:disabled{opacity:.5;cursor:not-allowed}.transaction-hero{background:var(--card-inset);border:1px solid var(--card-inset-border);border-radius:14px;flex-direction:column;align-items:center;gap:8px;margin-bottom:18px;padding:18px 16px;display:flex}.transaction-hero.income{background:color-mix(in srgb, #22c55e 8%, var(--card-inset));border-color:color-mix(in srgb, #22c55e 18%, var(--card-inset-border))}.transaction-hero.expense{background:color-mix(in srgb, #ef4444 7%, var(--card-inset));border-color:color-mix(in srgb, #ef4444 16%, var(--card-inset-border))}.transaction-hero-amount{letter-spacing:-.03em;font-size:clamp(26px,5vw,32px);font-weight:800;line-height:1}.transaction-hero.income .transaction-hero-amount{color:#16a34a}.transaction-hero.expense .transaction-hero-amount{color:#dc2626}html[data-theme=dark] .transaction-hero.income .transaction-hero-amount{color:#4ade80}html[data-theme=dark] .transaction-hero.expense .transaction-hero-amount{color:#f87171}.transaction-hero-type{color:var(--text-secondary);background:color-mix(in srgb, var(--card-bg) 70%, transparent);border-radius:999px;padding:4px 10px;font-size:12px;font-weight:600}.transaction-modal-body{flex-direction:column;display:flex}.transaction-details{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:0;display:grid}.transaction-detail{background:var(--card-inset);border:1px solid var(--card-inset-border);border-radius:12px;margin:0;padding:12px 14px}.transaction-detail--full{grid-column:1/-1}.transaction-detail dt{letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);margin:0 0 4px;font-size:11px;font-weight:600}.transaction-detail dd{color:var(--text-primary);word-break:break-word;margin:0;font-size:14px;font-weight:600;line-height:1.4}.transaction-edit-form{flex-direction:column;gap:14px;display:flex}.transaction-field{flex-direction:column;gap:8px;display:flex}.transaction-field span{color:var(--text-secondary);font-size:12px;font-weight:600}.transaction-field input,.transaction-field textarea{border:1px solid var(--card-inset-border);background:var(--card-inset);width:100%;color:var(--text-primary);border-radius:12px;outline:none;padding:12px 14px;font-family:inherit;font-size:15px}.transaction-field input:focus,.transaction-field textarea:focus{border-color:color-mix(in srgb, var(--accent) 40%, var(--card-inset-border));box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 10%, transparent)}.transaction-field textarea{resize:vertical;min-height:88px}@media (width<=480px){.transaction-modal{border-radius:18px;padding:18px 16px 16px}.transaction-details{grid-template-columns:1fr}}.user-avatar{background:var(--button-bg);border:2px solid #ffffff59;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex;overflow:hidden}.user-avatar img{object-fit:cover;width:100%;height:100%}.user-avatar-fallback{width:100%;height:100%;color:var(--text-primary);background:linear-gradient(135deg,#c7d2fe,#8ea7ff);justify-content:center;align-items:center;font-size:.95em;font-weight:700;display:flex}.user-avatar-fallback svg{font-size:1.1em}.all-transactions-overlay{z-index:1200}.all-transactions-modal{background:var(--card-bg);box-sizing:border-box;border-radius:32px;flex-direction:column;width:min(920px,100%);max-height:calc(100dvh - 48px);padding:28px 32px 32px;display:flex;box-shadow:0 20px 60px #0000001f}.all-transactions-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.all-transactions-header h2{color:var(--text-primary);margin:0;font-size:30px;font-weight:700;line-height:1.1}.all-transactions-subtitle{color:var(--text-secondary);margin:8px 0 0;font-size:14px}.all-transactions-close{background:var(--button-bg);width:44px;height:44px;color:var(--text-primary);cursor:pointer;border:none;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;transition:background .2s;display:flex}.all-transactions-close:hover{background:var(--button-hover)}.all-transactions-close svg{font-size:22px}.all-transactions-filters{flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:16px;display:flex}.all-transactions-category-filter{flex-direction:column;flex:1;gap:6px;min-width:200px;max-width:280px;display:flex}.all-transactions-category-filter span{color:var(--text-secondary);font-size:12px;font-weight:600}.all-transactions-category-filter select{border:1px solid var(--button-bg);background:var(--card-secondary);height:42px;color:var(--text-primary);cursor:pointer;border-radius:12px;padding:0 14px;font-family:inherit;font-size:14px}.all-transactions-list{flex-direction:column;flex:1;gap:12px;min-height:0;padding-right:6px;display:flex;overflow-y:auto}.all-transactions-list::-webkit-scrollbar{width:6px}.all-transactions-list::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:999px}.all-transactions-list .empty-text{text-align:center;color:var(--text-secondary);padding:40px 16px}.all-transactions-load-more{border:1px dashed var(--button-bg);width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:14px;margin-top:4px;padding:12px 16px;font-family:inherit;font-size:14px;font-weight:600;transition:background .2s}.all-transactions-load-more:hover{background:var(--button-bg);color:var(--text-primary)}@media (width<=768px){.all-transactions-modal{border-radius:24px;max-height:92vh;padding:22px 20px 24px}.all-transactions-header h2{font-size:24px}.all-transactions-category-filter{min-width:100%;max-width:none}.all-transactions-filters{flex-direction:column;align-items:stretch}}.transactions-block--compact{flex-direction:column;padding:20px;display:flex}.transactions-block--compact .transactions-featured-header{flex-shrink:0;margin-bottom:12px}.transactions-filters{margin-bottom:14px}.transactions-block--compact .transactions-list-preview{flex:1;min-height:0;max-height:none;overflow-y:auto}.transactions-block--compact .show-all-transactions-btn{flex-shrink:0;margin-top:auto;padding:10px 14px}.transactions-block{box-sizing:border-box;flex:1;width:100%;min-width:0;padding:22px 24px 24px}.transactions-list{flex-direction:column;gap:8px;padding-right:4px;display:flex;overflow-y:auto}.transactions-list-preview{max-height:none;overflow:visible}.show-all-transactions-btn{border:1px solid var(--card-inset-border);border-radius:var(--radius-sm);background:var(--card-inset);width:100%;color:var(--text-primary);cursor:pointer;margin-top:14px;padding:12px 16px;font-family:inherit;font-size:14px;font-weight:500;transition:background .15s}.show-all-transactions-btn:hover{background:var(--button-hover)}.transactions-list::-webkit-scrollbar{width:5px}.transactions-list::-webkit-scrollbar-track{background:0 0}.transactions-list::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:999px}.transaction-item{border-radius:var(--radius-md);background:var(--card-inset);border:1px solid var(--card-inset-border);flex-shrink:0;padding:12px 14px;transition:background .15s}.transaction-item:hover{background:var(--button-bg)}.transaction-main{flex-direction:column;gap:6px;min-width:0;display:flex}.transaction-row{justify-content:space-between;align-items:center;gap:12px;min-width:0;display:flex}.transaction-category{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;margin:0;font-size:14px;font-weight:600;overflow:hidden}.transaction-meta{flex-wrap:wrap;flex:1;align-items:center;gap:8px;min-width:0;display:flex}.transaction-participant{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.transaction-participant--with-avatar{align-items:center;gap:8px;min-width:0;max-width:100%;display:inline-flex}.transaction-participant-avatar.user-avatar{border-width:1px}.transaction-participant-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.transaction-date{color:var(--text-muted);white-space:nowrap;text-align:right;flex-shrink:0;font-size:12px}.amount{white-space:nowrap;flex-shrink:0;font-size:15px;font-weight:600;line-height:1.2}.income{color:var(--success)}.expense{color:var(--text-primary)}.empty-text{color:var(--text-secondary);font-size:14px}.transactions-notice{border-radius:var(--radius-sm);background:var(--accent-soft);color:var(--accent);margin:0 0 12px;padding:10px 14px;font-size:13px;font-weight:500}.transaction-actions{gap:8px;display:flex}.transaction-actions button{border:1px solid var(--card-inset-border);border-radius:var(--radius-sm);background:var(--card-bg);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;transition:background .15s;display:flex}.transaction-actions button:hover{background:var(--button-hover)}.transaction-actions button svg{color:var(--text-secondary);font-size:17px}.clickable{cursor:pointer}.ai-badge{background:var(--accent-soft);color:var(--accent);border-radius:999px;flex-shrink:0;align-items:center;padding:2px 7px;font-size:10px;font-weight:600;line-height:1.2;display:inline-flex}.needs-review{border-color:#dc262640}.transactions-filters{flex-wrap:wrap;align-items:center;gap:8px;margin-top:10px;display:flex}.type-filter-group{border-radius:var(--radius-sm);background:var(--card-inset);border:1px solid var(--card-inset-border);gap:2px;padding:3px;display:inline-flex}.type-filter-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:7px 12px;font-size:12px;font-weight:500;transition:all .15s}.type-filter-btn:hover{color:var(--text-primary)}.type-filter-btn.active{background:var(--card-bg);color:var(--text-primary);box-shadow:0 1px 3px #0f172a14}.review-filter-btn{background:var(--danger-soft);color:var(--danger);cursor:pointer;border:none;border-radius:999px;align-items:center;gap:6px;padding:7px 12px;font-size:12px;font-weight:500;display:inline-flex}.review-filter-btn.active{background:#dc262629}@media (width<=768px){.transactions-block{padding:20px}.transactions-list{max-height:420px}}@media (width<=480px){.transactions-block{padding:16px}.transactions-header{flex-direction:column;align-items:flex-start}.transaction-actions{width:100%}.transaction-actions button{flex:1}.transaction-row-bottom{flex-direction:column;align-items:flex-start;gap:4px}.transaction-date{text-align:left}.transaction-category{white-space:normal}}.balance-card{padding:22px 24px 24px}.balance-card-top{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;display:flex}.balance-label{color:var(--text-secondary);margin:0;font-size:14px;font-weight:500;line-height:1.4}.balance-period-hint{color:var(--text-muted);margin-top:2px;font-size:12px;font-weight:400;display:block}.balance-period-group{border-radius:var(--radius-sm);background:var(--card-inset);border:1px solid var(--card-inset-border);flex-shrink:0;gap:2px;padding:3px;display:inline-flex}.balance-period-btn{height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:0 12px;font-size:12px;font-weight:500;transition:background .15s,color .15s}.balance-period-btn:hover{color:var(--text-primary)}.balance-period-btn.active{background:var(--card-bg);color:var(--text-primary);box-shadow:0 1px 3px #0f172a14}.balance-value{letter-spacing:-.03em;color:var(--text-primary);margin:0 0 20px;font-size:36px;font-weight:700;line-height:1.1}.balance-bottom{border-top:1px solid var(--card-inset-border);justify-content:space-between;align-items:flex-end;gap:16px;padding-top:20px;display:flex}.balance-stats{flex-wrap:wrap;flex:1;gap:20px 28px;min-width:0;display:flex}.stat-item{align-items:center;gap:10px;display:flex}.stat-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.income-stat .stat-icon{background:var(--success-soft);color:var(--success)}.expense-stat .stat-icon{background:var(--card-inset);color:var(--text-secondary);border:1px solid var(--card-inset-border)}.stat-item strong{letter-spacing:-.02em;color:var(--text-primary);font-size:16px;font-weight:600;line-height:1.2;display:block}.income-stat strong{color:var(--success)}.stat-item span{color:var(--text-muted);margin-top:2px;font-size:12px;display:block}.balance-percent{border-radius:var(--radius-sm);flex-shrink:0;padding:8px 12px;font-size:14px;font-weight:600}.positive-balance{background:var(--success-soft);color:var(--success)}.negative-balance{background:var(--danger-soft);color:var(--danger)}.balance-card--hero{background:linear-gradient(160deg, var(--card-bg) 0%, var(--card-inset) 100%);flex-direction:column;justify-content:space-between;min-height:100%;padding:28px;display:flex}.balance-card--hero .balance-value{flex:1;align-items:center;margin-bottom:0;font-size:42px;display:flex}.balance-card--hero .balance-bottom{margin-top:24px}@media (width<=640px){.balance-card--hero .balance-value{font-size:34px}.balance-card-top{flex-direction:column;align-items:stretch}.balance-period-group{justify-content:stretch;width:100%}.balance-period-btn{text-align:center;flex:1}.balance-value{font-size:30px}.balance-bottom{flex-direction:column;align-items:stretch}.balance-percent{align-self:flex-start}}.wallet-metrics-bar{grid-template-columns:repeat(4,minmax(0,1fr));gap:0;margin-bottom:16px;padding:4px;display:grid;overflow:hidden}.wallet-metrics-bar .wallet-stat-card{border:none;border-right:1px solid var(--card-inset-border);min-width:0;box-shadow:none;background:0 0;border-radius:0;align-items:center;gap:12px;padding:14px 16px;display:flex}.wallet-metrics-bar .wallet-stat-card:last-child{border-right:none}.wallet-stat-icon{border-radius:var(--radius-sm);background:var(--card-inset);width:36px;height:36px;color:var(--text-secondary);flex-shrink:0;justify-content:center;align-items:center;font-size:16px;display:flex}.wallet-stat-content{flex:1;min-width:0}.wallet-stat-content span{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:11px;font-weight:500;display:block;overflow:hidden}.wallet-stat-content strong{letter-spacing:-.02em;color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:17px;font-weight:600;display:block;overflow:hidden}.wallet-stat-card.expense .wallet-stat-icon{color:var(--danger);background:var(--danger-soft)}.wallet-stat-card.income .wallet-stat-icon{color:var(--success);background:var(--success-soft)}.wallet-stat-card.warning .wallet-stat-icon{color:var(--warning);background:#d977061f}@media (width<=900px){.wallet-metrics-bar{grid-template-columns:repeat(2,minmax(0,1fr))}.wallet-metrics-bar .wallet-stat-card:nth-child(2){border-right:none}.wallet-metrics-bar .wallet-stat-card:first-child,.wallet-metrics-bar .wallet-stat-card:nth-child(2){border-bottom:1px solid var(--card-inset-border)}}@media (width<=480px){.wallet-metrics-bar{grid-template-columns:1fr}.wallet-metrics-bar .wallet-stat-card{border-right:none;border-bottom:1px solid var(--card-inset-border)}.wallet-metrics-bar .wallet-stat-card:last-child{border-bottom:none}}.top-categories-widget{flex-direction:column;width:100%;padding:22px 24px 24px;display:flex}.top-categories-body{flex-direction:column;flex:1;min-height:0;display:flex}.top-categories-empty{color:var(--text-secondary);text-align:center;margin:auto 0;font-size:14px}.top-categories-list{flex-direction:column;flex:1;gap:14px;margin:26px 0;padding:0;list-style:none;display:flex}.top-category-meta{justify-content:space-between;align-items:center;gap:10px;margin-bottom:6px;display:flex}.top-category-meta span{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:13px;overflow:hidden}.top-category-meta strong{color:var(--text-primary);white-space:nowrap;font-size:13px;font-weight:600}.top-category-track{background:var(--card-inset);border:1px solid var(--card-inset-border);border-radius:999px;height:12px;overflow:hidden}.top-category-fill{border-radius:999px;height:100%}.goals-panel{padding:22px 24px 24px}.goals-hint{color:var(--text-secondary);margin:4px 0 0;font-size:13px;line-height:1.5}.goals-hint--short{color:var(--text-muted);font-size:12px}.goal-form{grid-template-columns:1fr 140px 48px;gap:10px;margin-bottom:18px;display:grid}.goal-form input{border-radius:var(--radius-sm);border:1px solid var(--card-inset-border);background:var(--card-inset);height:44px;color:var(--text-primary);padding:0 14px;font-size:14px}.goal-form input:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}.goal-form button,.goal-form-submit{border-radius:var(--radius-sm);background:var(--accent);color:#fff;cursor:pointer;border:none;justify-content:center;align-items:center;height:44px;font-size:18px;display:flex}.goal-form button:hover,.goal-form-submit:hover{background:var(--accent-hover)}.goal-item{border-radius:var(--radius-md);background:var(--card-inset);border:1px solid var(--card-inset-border);padding:14px 16px}.goal-item--wallet{align-items:flex-start;gap:14px;padding:14px;display:flex}.goal-item-body{flex:1;min-width:0}.goal-top{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.goal-title-block{flex-direction:column;gap:6px;min-width:0;display:flex}.goal-author{color:var(--text-secondary);align-items:center;gap:8px;font-size:12px;font-weight:500;display:flex}.goal-top strong{color:var(--text-primary);font-size:14px;font-weight:600}.goal-delete-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px;transition:color .15s,background .15s}.goal-delete-btn:hover{color:var(--danger);background:var(--danger-soft)}.goal-amounts{color:var(--text-secondary);margin:6px 0 0;font-size:13px}.goal-current{color:var(--text-primary);font-weight:600}.goal-sep{color:var(--text-muted)}.goal-progress{background:var(--button-bg);border-radius:999px;height:6px;margin-top:10px;overflow:hidden}.goal-progress-fill{background:var(--accent);border-radius:999px;height:100%;transition:width .3s}.goal-item--done{background:var(--success-soft);border-color:#34d39940}.goal-done-badge{background:var(--success-soft);color:var(--success);vertical-align:middle;border-radius:999px;margin-left:8px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.goal-deposit-form{gap:8px;margin-top:12px;display:flex}.goal-deposit-form input{border:1px solid var(--card-inset-border);border-radius:var(--radius-sm);background:var(--card-inset);min-width:0;height:38px;color:var(--text-primary);flex:1;padding:0 12px;font-size:13px}.goal-deposit-form input:focus{border-color:color-mix(in srgb, var(--accent) 45%, var(--card-inset-border));box-shadow:0 0 0 3px var(--accent-soft);outline:none}.goal-deposit-submit{border-radius:var(--radius-sm);background:var(--accent);color:#fff;cursor:pointer;border:none;flex-shrink:0;height:38px;padding:0 14px;font-size:13px;font-weight:600}.goal-deposit-submit:hover{background:var(--accent-hover)}.goal-deposit-row{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.goal-deposit-btn{border:1px solid var(--card-inset-border);background:var(--card-bg);height:30px;color:var(--text-secondary);cursor:pointer;border-radius:8px;padding:0 10px;font-size:11px;font-weight:600;transition:background .15s}.goal-deposit-btn:hover{background:var(--button-hover);color:var(--text-primary)}.goal-deposit-btn--accent{background:var(--accent-soft);color:var(--accent);border-color:#4f6ef733}.goals-panel--wallet{flex-direction:column;min-height:100%;display:flex}.goals-carousel{flex-direction:column;flex:1;justify-content:flex-end;gap:10px;min-height:0;display:flex}.goals-carousel-nav{justify-content:center;align-items:center;gap:12px;display:flex}.goals-carousel-btn{border:1px solid var(--card-inset-border);border-radius:var(--radius-sm);background:var(--card-inset);width:34px;height:34px;color:var(--text-primary);cursor:pointer;justify-content:center;align-items:center;transition:background .15s,opacity .15s;display:inline-flex}.goals-carousel-btn:hover:not(:disabled){background:var(--button-hover)}.goals-carousel-btn:disabled{opacity:.35;cursor:default}.goals-carousel-counter{text-align:center;min-width:52px;color:var(--text-secondary);font-size:12px;font-weight:500}.goals-carousel .goal-item--wallet{flex:1;min-height:0}.goals-carousel .goals-empty{text-align:center;margin:auto 0}.goal-form-wallet{margin-bottom:12px}.goal-add-trigger{border:1px dashed var(--card-inset-border);border-radius:var(--radius-sm);width:100%;height:40px;color:var(--text-secondary);cursor:pointer;background:0 0;justify-content:center;align-items:center;gap:8px;font-size:13px;font-weight:500;transition:border-color .15s,color .15s,background .15s;display:flex}.goal-add-trigger:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.goal-form--wallet{grid-template-columns:1fr 100px 40px;margin-bottom:0}.goal-form--wallet input{height:40px;font-size:13px}.goal-form--wallet .goal-form-submit{height:40px}.goals-more-link{color:var(--accent);align-items:center;gap:4px;margin-top:12px;font-size:13px;font-weight:500;text-decoration:none;display:inline-flex}.goals-more-link:hover{color:var(--accent-hover)}.goal-ring{flex-shrink:0;width:44px;height:44px;position:relative}.goal-ring svg{width:100%;height:100%}.goal-ring-track{stroke:var(--card-inset-border)}.goal-ring-fill{stroke:var(--accent);stroke-linecap:round;transition:stroke-dasharray .3s}.goal-ring--done .goal-ring-fill{stroke:var(--success)}.goal-ring span{color:var(--text-secondary);justify-content:center;align-items:center;font-size:10px;font-weight:700;display:flex;position:absolute;inset:0}.goal-ring--done span{color:var(--success);font-size:14px}@media (width<=700px){.goal-form,.goal-form--wallet{grid-template-columns:1fr}}.wallet-content{flex-direction:column;gap:0;display:flex}.wallet-action-btn{border:1px solid var(--card-inset-border);border-radius:var(--radius-sm);background:var(--card-bg);height:40px;color:var(--text-primary);cursor:pointer;justify-content:center;align-items:center;gap:8px;padding:0 16px;font-size:13px;font-weight:500;transition:background .15s;display:inline-flex}.wallet-action-btn:hover{background:var(--button-hover)}.wallet-action-btn.primary{background:var(--accent);color:#fff;border-color:#0000}.wallet-action-btn.primary:hover{background:var(--accent-hover)}.wallet-action-btn span{white-space:nowrap}.wallet-hero{grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);align-items:stretch;gap:16px;margin-bottom:16px;display:grid}.wallet-hero .balance-card,.wallet-hero .goals-panel{box-shadow:var(--card-shadow)}html[data-theme=dark] .wallet-hero .balance-card,html[data-theme=dark] .wallet-hero .goals-panel{box-shadow:0 0 0 1px #4f6ef71f,0 8px 32px #0006}.wallet-body{flex-direction:column;gap:16px;display:flex}.wallet-split{grid-template-columns:minmax(0,1.15fr) minmax(260px,.85fr);align-items:stretch;gap:16px;display:grid}.wallet-split>.transactions-block,.wallet-split>.top-categories-widget{flex-direction:column;height:100%;min-height:420px;display:flex}@media (width<=1100px){.wallet-hero,.wallet-split{grid-template-columns:1fr}}@media (width<=768px){.page-header-actions{width:100%}.wallet-action-btn{flex:1;min-width:0}.wallet-hero,.wallet-body,.wallet-split{gap:14px}}@media (width<=480px){.wallet-action-btn{height:40px;padding:0 12px}.wallet-action-btn span{display:none}.wallet-action-btn svg{font-size:18px}}.admin-content{flex-direction:column;gap:20px;display:flex}.admin-notice{color:var(--accent);background:#8ea7ff26;border-radius:14px;padding:14px 18px;font-size:14px;font-weight:600}.admin-notice.error{color:#dc2626;background:#ef44441f}.admin-tabs{flex-wrap:wrap;gap:8px;display:flex}.admin-tab{background:var(--button-bg);color:var(--text-secondary);cursor:pointer;border:none;border-radius:12px;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.admin-tab:hover{color:var(--text-primary)}.admin-tab.active{background:var(--accent);color:#fff}.admin-loading-text,.admin-loading{color:var(--text-secondary)}.admin-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;display:grid}.admin-card{flex-direction:column;gap:8px;padding:20px;display:flex}.admin-card span{color:var(--text-secondary);font-size:13px}.admin-card strong{color:var(--text-primary);font-size:28px}.admin-card svg{color:var(--accent);font-size:20px}.admin-card.highlight-warn strong{color:#dc2626}.admin-card.highlight-info strong{color:var(--accent)}.admin-ai-layout{grid-template-columns:1fr 1fr;gap:16px;display:grid}.admin-panel{padding:22px 24px 24px}.admin-panel-wide{grid-column:1/-1}.admin-panel h2{color:var(--text-primary);margin:0 0 16px;font-size:20px}.admin-meta-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.admin-meta-list li{color:var(--text-secondary);font-size:14px}.admin-hint{color:var(--text-secondary);margin:16px 0 0;font-size:13px;line-height:1.5}.admin-actions{flex-direction:column;gap:10px;display:flex}.admin-action-btn{background:var(--button-bg);color:var(--text-primary);cursor:pointer;border:none;border-radius:14px;justify-content:center;align-items:center;gap:8px;padding:12px 16px;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.admin-action-btn:hover:not(:disabled){background:var(--button-hover)}.admin-action-btn.primary{background:var(--accent);color:#fff}.admin-action-btn:disabled{opacity:.6;cursor:not-allowed}.admin-empty{color:var(--text-secondary);font-size:14px}.admin-feedback-table-wrap{overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--glass-border);padding:10px 12px}.admin-table th{color:var(--text-secondary);font-weight:600}.admin-table td{color:var(--text-primary)}.admin-table .cell-desc{word-break:break-word;max-width:280px}.admin-role-select{border:1px solid var(--glass-border);background:var(--card-secondary);color:var(--text-primary);border-radius:10px;padding:8px 10px;font-size:13px}@media (width<=900px){.admin-ai-layout{grid-template-columns:1fr}}.avatar-crop-overlay{z-index:1100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a73;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.avatar-crop-modal{background:var(--card-bg);width:100%;max-width:400px;box-shadow:var(--shadow);border-radius:24px;padding:24px}.avatar-crop-modal h3{color:var(--text-primary);margin:0 0 6px;font-size:22px}.avatar-crop-modal>p{color:var(--text-secondary);margin:0 0 18px;font-size:13px}.avatar-crop-viewport{cursor:grab;touch-action:none;background:#0f172a;border-radius:50%;margin:0 auto 16px;position:relative;overflow:hidden}.avatar-crop-viewport:active{cursor:grabbing}.avatar-crop-image{transform-origin:50%;-webkit-user-select:none;user-select:none;pointer-events:none;max-width:none;position:absolute;top:50%;left:50%}.avatar-crop-ring{pointer-events:none;border-radius:50%;position:absolute;inset:0;box-shadow:0 0 0 9999px #0f172a73,inset 0 0 0 2px #ffffffd9}.avatar-crop-zoom{color:var(--text-secondary);align-items:center;gap:12px;margin-bottom:18px;display:flex}.avatar-crop-zoom input{accent-color:var(--accent);flex:1}.avatar-crop-actions{gap:10px;display:flex}.avatar-crop-btn{cursor:pointer;border:none;border-radius:14px;flex:1;justify-content:center;align-items:center;gap:8px;height:48px;font-size:14px;font-weight:600;display:inline-flex}.avatar-crop-btn.cancel{background:var(--button-bg);color:var(--text-primary)}.avatar-crop-btn.save{background:var(--accent);color:#fff}.avatar-crop-btn:disabled{opacity:.65;cursor:not-allowed}.settings-content{flex-direction:column;gap:20px;width:100%;max-width:none;display:flex}.settings-toast{z-index:30;background:color-mix(in srgb, var(--accent) 14%, var(--card-bg));border:1px solid color-mix(in srgb, var(--accent) 28%, transparent);color:var(--accent);box-shadow:var(--card-shadow);border-radius:14px;padding:12px 16px;font-size:14px;font-weight:600;position:sticky;top:12px}.settings-toast.error{background:color-mix(in srgb, #dc2626 10%, var(--card-bg));color:#dc2626;border-color:#dc26263d}.settings-stack{flex-direction:column;gap:16px;display:flex}.settings-layout{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch;gap:16px;display:grid}.settings-column-main{flex-direction:column;gap:16px;min-width:0;display:flex}.settings-column-security{flex-direction:column;min-height:100%;display:flex}.settings-column-security.settings-panel,.settings-column-security .settings-password-form{flex-direction:column;flex:1;display:flex}.settings-column-security .settings-password-fields{flex:1}.settings-column-security .settings-panel-footer{margin-top:auto}.settings-column-security .settings-password-fields{grid-template-columns:1fr}.settings-card{padding:0;overflow:hidden}.settings-hero{flex-direction:column;gap:20px;padding:24px;display:flex}.settings-hero-body{align-items:center;gap:20px;display:flex}.settings-avatar-button{cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0;position:relative}.settings-avatar-button:disabled{cursor:wait;opacity:.75}.settings-avatar-preview{background:var(--card-inset);border:3px solid color-mix(in srgb, var(--accent) 24%, var(--card-border));border-radius:50%;justify-content:center;align-items:center;width:96px;height:96px;display:flex;overflow:hidden;box-shadow:0 8px 24px #4f6ef729}.settings-avatar-preview img{object-fit:cover;width:100%;height:100%}.settings-avatar-preview svg{color:var(--text-secondary);font-size:36px}.settings-avatar-badge{background:var(--accent);color:#fff;border:3px solid var(--card-bg);border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:15px;display:flex;position:absolute;bottom:-2px;right:-2px;box-shadow:0 4px 12px #4f6ef759}.settings-hero-info{flex:1;min-width:0}.settings-hero-info h2{letter-spacing:-.02em;color:var(--text-primary);word-break:break-word;margin:0 0 10px;font-size:clamp(22px,3vw,28px);line-height:1.2}.settings-hero-meta{flex-direction:column;gap:6px;display:flex}.settings-hero-meta span{color:var(--text-secondary);word-break:break-all;align-items:center;gap:8px;font-size:14px;line-height:1.4;display:inline-flex}.settings-hero-meta svg{color:var(--accent);flex-shrink:0}.settings-hero-actions{flex-wrap:wrap;gap:10px;display:flex}.settings-hero-actions .settings-btn{width:auto;min-width:140px}.settings-panel{padding:24px}.settings-panel-head{align-items:flex-start;gap:14px;margin-bottom:22px;display:flex}.settings-panel-icon{background:color-mix(in srgb, var(--accent) 12%, transparent);width:44px;height:44px;color:var(--accent);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;font-size:20px;display:flex}.settings-panel-icon.security{color:#059669;background:#0596691f}.settings-panel-head h3{color:var(--text-primary);margin:0 0 4px;font-size:18px;font-weight:700}.settings-panel-head p{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.45}.settings-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 16px;display:grid}.settings-form-grid.single-col{grid-template-columns:1fr}.settings-password-fields{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 16px;display:grid}.settings-field-full{grid-column:1/-1}.settings-field{flex-direction:column;gap:8px;display:flex}.settings-field span{color:var(--text-secondary);font-size:13px;font-weight:600}.settings-field input{border:1px solid var(--card-inset-border);background:var(--card-inset);height:48px;color:var(--text-primary);border-radius:12px;outline:none;padding:0 14px;font-size:15px;transition:border-color .15s,box-shadow .15s}.settings-field input:focus{border-color:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 14%, transparent)}.settings-panel-footer{border-top:1px solid var(--card-inset-border);justify-content:flex-end;margin-top:22px;padding-top:18px;display:flex}.settings-readonly-row{flex-direction:column;gap:8px;display:flex}.settings-readonly-label{color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;font-weight:600;display:inline-flex}.settings-readonly-label svg{color:var(--accent)}.settings-readonly-value{background:var(--card-inset);border:1px solid var(--card-inset-border);color:var(--text-primary);word-break:break-all;border-radius:12px;padding:12px 14px;font-size:15px}.settings-readonly-hint{color:var(--text-muted);margin:0;font-size:12px}.settings-divider{background:var(--card-inset-border);height:1px;margin:22px 0}.settings-password-head{color:var(--text-primary);align-items:center;gap:8px;margin-bottom:14px;font-size:14px;font-weight:700;display:inline-flex}.settings-password-head svg{color:var(--accent)}.settings-password-form .settings-form-grid{margin-bottom:0}.settings-btn{border:1px solid var(--card-inset-border);background:var(--card-inset);height:44px;color:var(--text-primary);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:0 18px;font-size:14px;font-weight:600;transition:background .15s,border-color .15s,transform .15s;display:inline-flex}.settings-btn:hover:not(:disabled){background:var(--button-hover)}.settings-btn.primary{background:var(--accent);color:#fff;border-color:#0000}.settings-btn.primary:hover:not(:disabled){background:var(--accent-hover)}.settings-btn.danger{color:#dc2626;border-color:color-mix(in srgb, #dc2626 20%, var(--card-inset-border));background:color-mix(in srgb, #dc2626 6%, var(--card-inset))}.settings-btn.danger:hover:not(:disabled){background:color-mix(in srgb, #dc2626 12%, var(--card-inset))}.settings-btn:disabled{opacity:.65;cursor:not-allowed}.settings-skeleton{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch;gap:16px;display:grid}.settings-skeleton-main{flex-direction:column;gap:16px;display:flex}.settings-skeleton-hero,.settings-skeleton-block{border-radius:var(--radius-lg);background:linear-gradient(90deg, var(--card-inset) 0%, var(--button-hover) 50%, var(--card-inset) 100%);background-size:200% 100%;animation:1.2s ease-in-out infinite settings-shimmer}.settings-skeleton-hero{height:160px}.settings-skeleton-block{height:220px}@keyframes settings-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}@media (width<=768px){.settings-content{max-width:none}.settings-layout,.settings-skeleton{grid-template-columns:1fr}.settings-column-security{min-height:0}.settings-hero{padding:18px}.settings-hero-body{text-align:center;flex-direction:column;align-items:center}.settings-hero-meta{align-items:center}.settings-hero-actions{width:100%}.settings-hero-actions .settings-btn{flex:1;min-width:0}.settings-panel{padding:18px}.settings-form-grid,.settings-password-fields{grid-template-columns:1fr}.settings-panel-footer{justify-content:stretch}.settings-panel-footer .settings-btn.primary{width:100%}}@media (width<=480px){.settings-avatar-preview{width:88px;height:88px}}.help-modal-overlay{z-index:2100;box-sizing:border-box;-webkit-backdrop-filter:blur(4px);overscroll-behavior:contain;background:#0f172a73;justify-content:center;align-items:center;padding:20px 16px;display:flex;position:fixed;inset:0;overflow-y:auto}html[data-theme=dark] .help-modal-overlay{background:#02060eb8}.help-modal{background:var(--card-bg);width:100%;max-width:560px;max-height:min(85dvh,720px);box-shadow:var(--shadow);border-radius:24px;flex-direction:column;flex-shrink:0;margin:auto;display:flex}.help-modal-header{flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:16px;padding:24px 24px 12px;display:flex}.help-modal-header h2{color:var(--text-primary);margin:0;font-size:22px;line-height:1.3}.help-modal-close{background:var(--button-bg);width:40px;height:40px;color:var(--text-primary);cursor:pointer;border:none;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex}.help-modal-close:hover{background:var(--button-hover)}.help-modal-body{overscroll-behavior:contain;padding:8px 24px 28px;overflow-y:auto}.help-modal-body section{margin-bottom:22px}.help-modal-body section:last-child{margin-bottom:0}.help-modal-body h3{color:var(--text-primary);margin:0 0 10px;font-size:16px}.help-modal-body p{color:var(--text-secondary);margin:0 0 10px;font-size:15px;line-height:1.6}.help-modal-body p:last-child{margin-bottom:0}@media (width<=768px){.help-modal-overlay{align-items:center;padding:12px}.help-modal{border-radius:20px;max-height:calc(100dvh - 24px)}.help-modal-header{padding:20px 18px 10px}.help-modal-header h2{font-size:20px}.help-modal-body{padding:8px 18px 24px}}@media (width<=480px){.help-modal{border-radius:18px}.help-modal-header h2{font-size:18px}.help-modal-body p{font-size:14px}}.help-content{flex-direction:column;gap:24px;display:flex}.help-sections{flex-direction:column;gap:28px;display:flex}.help-category-block h2{color:var(--text-primary);margin:0 0 12px;font-size:18px;font-weight:700}.help-article-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.help-article-item{border:1px solid var(--glass-border);background:var(--card-secondary);cursor:pointer;text-align:left;border-radius:16px;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:16px 18px;transition:all .2s;display:flex}.help-article-item span{color:var(--text-primary);font-size:15px;font-weight:600;line-height:1.35}.help-article-item svg{color:var(--text-secondary);flex-shrink:0;font-size:18px;transition:all .2s}.help-article-item:hover{border-color:var(--accent);transform:translateY(-1px)}.help-article-item:hover svg{color:var(--accent);transform:translate(2px)}@media (width<=768px){.help-article-item{padding:14px 16px}.help-article-item span{font-size:14px}}.family-content{flex-direction:column;gap:16px;width:100%;display:flex}.family-toast{z-index:30;background:color-mix(in srgb, var(--accent) 12%, var(--card-bg));border:1px solid color-mix(in srgb, var(--accent) 24%, transparent);color:var(--accent);box-shadow:var(--card-shadow);border-radius:12px;padding:11px 16px;font-size:13px;font-weight:600;position:sticky;top:12px}.family-toast.error{background:color-mix(in srgb, #dc2626 8%, var(--card-bg));color:#dc2626;border-color:#dc262633}.family-header-btn{border:1px solid var(--card-inset-border);background:var(--card-bg);height:38px;color:var(--text-primary);cursor:pointer;border-radius:10px;align-items:center;gap:7px;padding:0 14px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s;display:inline-flex}.family-header-btn:hover:not(:disabled){background:var(--button-hover)}.family-header-btn.primary{background:var(--accent);color:#fff;border-color:#0000;box-shadow:0 4px 12px #4f6ef747}.family-header-btn.primary:hover:not(:disabled){background:var(--accent-hover)}.family-header-btn:disabled{opacity:.6;cursor:wait}.family-banner{border-radius:var(--radius-lg);background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 14%, var(--card-bg)) 0%, var(--card-bg) 55%, color-mix(in srgb, var(--accent) 6%, var(--card-bg)) 100%);border:1px solid color-mix(in srgb, var(--accent) 22%, var(--card-border));box-shadow:var(--card-shadow);padding:20px 22px}html[data-theme=dark] .family-banner{background:linear-gradient(135deg,#1e2a42 0%,#171f30 50%,#151d2e 100%);border-color:#6b8cff47}.family-banner-main{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.family-banner-text h2{letter-spacing:-.03em;color:var(--text-primary);margin:0 0 4px;font-size:clamp(20px,2.5vw,26px);font-weight:700;line-height:1.2}.family-banner-text p{color:var(--text-secondary);max-width:480px;margin:0;font-size:14px;line-height:1.5}.family-banner-avatars{flex-shrink:0;align-items:center;display:flex}.family-banner-avatars .user-avatar{border:2px solid var(--card-bg);box-shadow:0 2px 8px #0000001a}.family-banner-avatar-offset{margin-left:-10px}.family-metrics{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.family-chip{background:color-mix(in srgb, var(--card-bg) 80%, transparent);border:1px solid color-mix(in srgb, var(--accent) 14%, var(--card-inset-border));color:var(--text-secondary);white-space:nowrap;border-radius:999px;align-items:center;gap:6px;padding:7px 12px;font-size:13px;display:inline-flex}.family-chip svg{color:var(--accent);flex-shrink:0;font-size:14px}.family-chip strong{color:var(--text-primary);font-weight:700}.family-chip-muted{color:var(--text-muted);font-size:12px}.family-body{grid-template-columns:minmax(0,1fr) 280px;align-items:start;gap:16px;display:grid}.family-panel{border-radius:var(--radius-lg);background:var(--card-bg);border:1px solid var(--card-border);box-shadow:var(--card-shadow);padding:20px}.family-panel-head{justify-content:space-between;align-items:center;gap:8px;margin-bottom:16px;display:flex}.family-panel-head h3{color:var(--text-primary);margin:0;font-size:15px;font-weight:700}.family-panel-head span{background:var(--accent-soft);min-width:26px;height:26px;color:var(--accent);border-radius:999px;justify-content:center;align-items:center;padding:0 8px;font-size:12px;font-weight:700;display:inline-flex}.family-members-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;display:grid}.family-member-card{background:var(--card-inset);border:1px solid var(--card-inset-border);text-align:center;border-radius:14px;flex-direction:column;align-items:center;gap:10px;padding:18px 14px 14px;transition:border-color .15s,transform .15s;display:flex}.family-member-card:hover{border-color:color-mix(in srgb, var(--accent) 20%, var(--card-inset-border))}.family-member-card.is-me{border-color:color-mix(in srgb, var(--accent) 32%, var(--card-inset-border));background:linear-gradient(180deg, color-mix(in srgb, var(--accent) 7%, var(--card-inset)) 0%, var(--card-inset) 100%)}.family-member-card-body{width:100%;min-width:0}.family-member-card-body strong{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;display:block;overflow:hidden}.family-member-nickname{color:var(--accent);margin-top:2px;font-size:13px;font-weight:500;display:block}.family-member-card-badges{flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;margin-top:8px;display:flex}.family-badge{border-radius:999px;align-items:center;gap:4px;padding:3px 9px;font-size:11px;font-weight:600;display:inline-flex}.family-badge--you{background:var(--accent-soft);color:var(--accent)}.family-badge--owner{background:color-mix(in srgb, var(--accent) 14%, transparent);color:var(--accent)}.family-badge--participant{color:#16a34a;background:#22c55e1f}.family-badge--observer{background:var(--card-bg);color:var(--text-muted);border:1px solid var(--card-inset-border)}html[data-theme=dark] .family-badge--participant{color:#4ade80}.family-member-card-actions{border-top:1px solid var(--card-inset-border);align-items:center;gap:6px;width:100%;margin-top:2px;padding-top:4px;display:flex}.family-select{border:1px solid var(--card-inset-border);background:var(--card-bg);height:34px;color:var(--text-primary);cursor:pointer;border-radius:8px;flex:1;padding:0 10px;font-family:inherit;font-size:12px}.family-aside{flex-direction:column;gap:12px;display:flex}.family-aside-hint{color:var(--text-muted);margin:0;font-size:12px;line-height:1.45}.family-role-field{gap:8px;display:flex}.family-role-field input{border:1px solid var(--card-inset-border);background:var(--card-inset);min-width:0;height:40px;color:var(--text-primary);border-radius:10px;flex:1;padding:0 12px;font-family:inherit;font-size:14px}.family-role-field input:focus{border-color:color-mix(in srgb, var(--accent) 40%, var(--card-inset-border));box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 10%, transparent);outline:none}.family-panel--danger{padding:16px 20px}.family-leave-link{color:#dc2626;cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:0;font-family:inherit;font-size:13px;font-weight:600;display:inline-flex}.family-leave-link:hover:not(:disabled){text-decoration:underline}.family-leave-link:disabled{opacity:.45;cursor:not-allowed}.family-icon-btn{border:1px solid var(--card-inset-border);background:var(--card-inset);width:40px;height:40px;color:var(--text-primary);cursor:pointer;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s;display:inline-flex}.family-icon-btn:hover:not(:disabled){background:var(--button-hover)}.family-icon-btn.primary{background:var(--accent);color:#fff;border-color:#0000}.family-icon-btn.primary:hover:not(:disabled){background:var(--accent-hover)}.family-icon-btn.danger{color:#dc2626;border-color:color-mix(in srgb, #dc2626 18%, var(--card-inset-border))}.family-icon-btn:disabled{opacity:.55;cursor:wait}.family-btn{border:1px solid var(--card-inset-border);background:var(--card-inset);height:42px;color:var(--text-primary);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:0 18px;font-family:inherit;font-size:14px;font-weight:600;transition:background .15s;display:inline-flex}.family-btn:hover:not(:disabled){background:var(--button-hover)}.family-btn.primary{background:var(--accent);color:#fff;border-color:#0000}.family-btn.primary:hover:not(:disabled){background:var(--accent-hover)}.family-btn.full{width:100%}.family-btn:disabled{opacity:.55;cursor:not-allowed}.family-form{flex-direction:column;gap:12px;display:flex}.family-form-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.family-field{flex-direction:column;gap:6px;display:flex}.family-field span{color:var(--text-secondary);font-size:12px;font-weight:600}.family-field input,.family-field textarea{border:1px solid var(--card-inset-border);background:var(--card-inset);width:100%;color:var(--text-primary);border-radius:10px;padding:11px 13px;font-family:inherit;font-size:14px}.family-field textarea{resize:vertical;min-height:80px}.family-field input:focus,.family-field textarea:focus{border-color:color-mix(in srgb, var(--accent) 40%, var(--card-inset-border));box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 10%, transparent);outline:none}.family-empty{grid-template-columns:minmax(0,1.3fr) minmax(260px,.7fr);align-items:start;gap:16px;display:grid}.family-panel--create{padding:24px}.family-empty-head{align-items:flex-start;gap:14px;margin-bottom:20px;display:flex}.family-empty-icon{background:var(--accent);color:#fff;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;display:flex;box-shadow:0 6px 16px #4f6ef759}.family-empty-head h2{color:var(--text-primary);margin:0 0 4px;font-size:20px;font-weight:700}.family-empty-head p{color:var(--text-secondary);margin:0;font-size:14px}.family-features{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:20px;display:grid}.family-feature{background:var(--card-inset);border:1px solid var(--card-inset-border);border-radius:12px;flex-direction:column;gap:8px;padding:14px;display:flex}.family-feature svg{color:var(--accent);font-size:18px}.family-feature strong{color:var(--text-primary);font-size:13px;display:block}.family-feature span{color:var(--text-muted);font-size:12px;line-height:1.4}.family-panel--join{background:linear-gradient(160deg, color-mix(in srgb, var(--accent) 10%, var(--card-bg)) 0%, var(--card-bg) 100%);border-color:color-mix(in srgb, var(--accent) 22%, var(--card-border));padding:24px}.family-panel--join h3{color:var(--text-primary);margin:0 0 6px;font-size:17px;font-weight:700}.family-panel--join>p{color:var(--text-secondary);margin:0 0 16px;font-size:13px}.family-join-form{flex-direction:column;gap:10px;display:flex}.family-join-form input{border:1px solid var(--card-inset-border);background:var(--card-bg);letter-spacing:.3em;text-align:center;text-transform:uppercase;width:100%;height:52px;color:var(--text-primary);border-radius:12px;padding:0 16px;font-family:ui-monospace,Cascadia Code,SF Mono,monospace;font-size:24px;font-weight:700}.family-join-form input:focus{border-color:color-mix(in srgb, var(--accent) 40%, var(--card-inset-border));box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 10%, transparent);outline:none}.family-join-form input::placeholder{letter-spacing:.1em;color:var(--text-muted);font-family:inherit;font-size:14px;font-weight:500}.family-modal{background:var(--card-bg);border-radius:20px;width:min(440px,100%);padding:24px;position:relative;box-shadow:0 24px 64px #0003}.family-modal-wide{width:min(480px,100%)}.family-modal-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.family-modal-head h2{color:var(--text-primary);margin:0;font-size:18px;font-weight:700}.family-modal-close{background:var(--card-inset);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;display:flex}.family-modal-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.family-share{flex-direction:column;gap:16px;display:flex}.family-share-lead{color:var(--text-secondary);margin:0;font-size:14px;line-height:1.5}.family-share-code,.family-share-link{background:var(--card-inset);border:1px solid var(--card-inset-border);border-radius:14px;padding:16px}.family-share-code span,.family-share-link span{letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px;font-size:11px;font-weight:700;display:block}.family-share-code strong{letter-spacing:.24em;color:var(--accent);text-align:center;margin-bottom:12px;font-family:ui-monospace,Cascadia Code,SF Mono,monospace;font-size:32px;font-weight:800;display:block}.family-share-link p{background:var(--card-bg);word-break:break-all;color:var(--text-secondary);border-radius:8px;margin:0 0 12px;padding:10px;font-size:12px;line-height:1.45}.family-share-copy{border:1px solid var(--card-inset-border);background:var(--card-bg);height:36px;color:var(--text-primary);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:0 14px;font-family:inherit;font-size:13px;font-weight:600;display:inline-flex}.family-share-copy:hover{background:var(--button-hover)}.family-skeleton{flex-direction:column;gap:16px;display:flex}.family-skeleton-banner,.family-skeleton-block{border-radius:var(--radius-lg);background:linear-gradient(90deg, var(--card-inset) 0%, var(--button-hover) 50%, var(--card-inset) 100%);background-size:200% 100%;animation:1.2s ease-in-out infinite family-shimmer}.family-skeleton-banner{height:140px}.family-skeleton-grid{grid-template-columns:minmax(0,1fr) 280px;gap:16px;display:grid}.family-skeleton-block{height:260px}@keyframes family-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}@media (width<=960px){.family-body,.family-empty,.family-skeleton-grid,.family-features{grid-template-columns:1fr}}@media (width<=640px){.family-form-row{grid-template-columns:1fr}.family-banner-main{flex-direction:column}.family-members-grid{grid-template-columns:1fr}.family-header-btn span{display:none}.family-header-btn{justify-content:center;width:38px;padding:0}}.family-join-page{min-height:100dvh}.family-invite-overlay{z-index:1100;overscroll-behavior:contain;background-position:50%;background-repeat:no-repeat;background-size:cover;justify-content:center;align-items:center;padding:24px 16px;display:flex;position:fixed;inset:0;overflow-y:auto}.family-invite-overlay>.family-invite-modal{flex-shrink:0;max-height:calc(100dvh - 48px);margin:auto;overflow-y:auto}.family-invite-modal{background:var(--card-bg);text-align:center;border-radius:28px;width:min(480px,100%);padding:32px 28px 28px;position:relative;box-shadow:0 20px 60px #00000026}.family-invite-close{background:var(--button-bg);cursor:pointer;border:none;border-radius:12px;width:40px;height:40px;position:absolute;top:16px;right:16px}.family-invite-icon{width:64px;height:64px;color:var(--accent);background:#8ea7ff33;border-radius:20px;justify-content:center;align-items:center;margin:0 auto 16px;font-size:28px;display:flex}.family-invite-modal h2{color:var(--text-primary);margin:0 0 8px;font-size:24px}.family-invite-description{color:var(--text-secondary);margin:0 0 16px;font-size:14px;line-height:1.5}.family-invite-family-name{color:var(--accent);margin:0 0 20px;font-size:18px;font-weight:600}.family-invite-inviter{text-align:left;background:var(--card-secondary);border-radius:18px;align-items:center;gap:14px;margin-bottom:12px;padding:16px;display:flex}.family-invite-inviter strong{color:var(--text-primary);font-size:16px;display:block}.family-invite-inviter span{color:var(--text-secondary);margin-top:2px;font-size:13px;display:block}.family-invite-date{margin-top:6px!important;font-size:12px!important}.family-invite-meta{color:var(--text-secondary);margin:0 0 20px;font-size:14px}.family-invite-label{text-align:left;color:var(--text-secondary);flex-direction:column;gap:8px;margin-bottom:12px;font-size:13px;font-weight:600;display:flex}.family-invite-label input{border:1px solid var(--button-bg);border-radius:14px;height:48px;padding:0 14px;font-family:inherit;font-size:15px}.family-invite-accept{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:14px;width:100%;height:50px;font-size:16px;font-weight:600}.family-invite-accept:disabled{opacity:.7;cursor:wait}.family-invite-error{color:#dc2626;margin-bottom:12px;font-size:14px}.family-invite-login-hint{color:var(--text-secondary);margin-bottom:16px;font-size:14px}.family-invite-loading{color:var(--text-secondary);padding:40px 0}
