:root{--font-sans: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: .95rem;--font-size-lg: 1.125rem;--font-size-xl: 1.5rem;--line-height-tight: 1.25;--line-height-normal: 1.5;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-pill: 999px;--shadow-soft: 0 10px 30px rgba(15, 23, 42, .35);--shadow-subtle: 0 6px 18px rgba(15, 23, 42, .25);--color-bg: #020617;--color-surface: #020617;--color-surface-alt: #0b1220;--color-surface-card: #020617;--color-surface-card-soft: rgba(15, 23, 42, .9);--color-border-subtle: rgba(148, 163, 184, .25);--color-border-strong: rgba(148, 163, 184, .4);--color-text-main: #f9fafb;--color-text-muted: #94a3b8;--color-text-soft: #64748b;--color-primary: #38bdf8;--color-primary-strong: #0ea5e9;--color-primary-soft: rgba(56, 189, 248, .14);--color-accent: #6366f1;--color-success: #22c55e;--color-danger: #ef4444;--color-warning: #eab308;--color-chip-income-bg: rgba(34, 197, 94, .2);--color-chip-income-fg: #4ade80;--color-chip-expense-bg: rgba(239, 68, 68, .2);--color-chip-expense-fg: #f87171;--color-chip-neutral-bg: rgba(148, 163, 184, .2);--color-chip-neutral-fg: #cbd5e1;font-family:var(--font-sans);line-height:var(--line-height-normal);color:var(--color-text-main);background-color:var(--color-bg)}body{margin:0;min-height:100vh;background:radial-gradient(circle at top,#020617 0 40%,#020617);color:var(--color-text-main)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}.onboarding-overlay{position:fixed;inset:0;background:#0f172af2;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;overflow-y:auto}.onboarding-card{background:#1e293bfa;border:1px solid rgba(148,163,184,.25);border-radius:16px;max-width:440px;width:100%;padding:1.75rem;box-shadow:0 20px 40px #0000004d}.onboarding-progress{margin-bottom:1.5rem}.onboarding-step-indicator{display:block;font-size:.8rem;color:#94a3b8;margin-bottom:.75rem}.onboarding-dots{display:flex;gap:.5rem}.onboarding-dot{flex:1;height:4px;border-radius:2px;background:#94a3b84d;transition:background .2s}.onboarding-dot.active{background:#0ea5e9}.onboarding-dot.done{background:#38bdf880}.onboarding-content{min-height:140px}.onboarding-title{font-size:1.25rem;margin:0 0 .75rem;color:#f8fafc;line-height:1.3}.onboarding-body{font-size:.95rem;color:#cbd5e1;line-height:1.55;margin:0 0 1rem}.onboarding-cta-link{display:inline-block;color:#38bdf8;font-size:.9rem;font-weight:500;text-decoration:none}.onboarding-cta-link:hover{text-decoration:underline}.onboarding-dont-show{display:flex;align-items:center;gap:.5rem;margin-top:1rem;font-size:.85rem;color:#94a3b8;cursor:pointer}.onboarding-dont-show input{accent-color:#0ea5e9}.onboarding-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid rgba(148,163,184,.2)}.onboarding-actions-right{display:flex;gap:.5rem;align-items:center;margin-left:auto}.onboarding-btn{padding:.5rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;border:none}.onboarding-btn.primary{background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff}.onboarding-btn.primary:hover{opacity:.95}.onboarding-btn.secondary{background:transparent;border:1px solid rgba(148,163,184,.4);color:#94a3b8}.onboarding-btn.secondary:hover{border-color:#64748b;color:#cbd5e1}.onboarding-btn.skip{background:transparent;color:#94a3b8;font-weight:400}.onboarding-btn.skip:hover{color:#cbd5e1}@media(max-width:768px){.onboarding-card{padding:1.25rem}.onboarding-title{font-size:1.1rem}.onboarding-body{font-size:.9rem}.onboarding-actions{flex-direction:column;align-items:stretch}.onboarding-actions-right{margin-left:0;justify-content:flex-end}}.transaction-form-page h1{font-size:1.5rem;margin-bottom:.25rem}.transaction-form-page .page-intro{color:#94a3b8;font-size:.9rem;margin:0 0 1rem}.transaction-form-page .type-hint{margin-bottom:.25rem}.tx-form{max-width:480px;display:flex;flex-direction:column;gap:1rem}.form-row{display:flex;flex-direction:column;gap:.35rem}.form-row label{font-size:.85rem;color:#94a3b8}.form-row input,.form-row select{background:#1e293bcc;border:1px solid rgba(148,163,184,.3);border-radius:8px;padding:.6rem .75rem;color:#f8fafc}.form-row .mt-1{margin-top:.35rem}.tx-form .btn-primary{margin-top:.5rem;padding:.75rem}.tx-form .btn-primary:disabled{opacity:.5;cursor:not-allowed}.form-error{background:#ef444426;border:1px solid rgba(239,68,68,.4);border-radius:8px;padding:.75rem;color:#f87171;margin-bottom:1rem}.form-hint{color:#94a3b8;font-size:.9rem;margin:0}.layout{min-height:100vh;background:radial-gradient(circle at top,#020617 0 40%,#020617);color:var(--color-text-main);display:flex;flex-direction:column}.layout-top-nav{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.75rem;background:linear-gradient(135deg,#0f172afa,#0f172aeb);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0}.layout-brand{display:flex;align-items:center;text-decoration:none}.layout-brand-logo{height:36px;width:auto;display:block}.layout-user{display:flex;align-items:center;gap:.75rem;font-size:var(--font-size-sm)}.layout-user span{color:var(--color-text-muted)}.layout-user button{background:transparent;border:1px solid var(--color-border-subtle);color:var(--color-text-soft);padding:.3rem .8rem;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-xs);transition:background .15s ease,color .15s ease,border-color .15s ease,transform .1s ease}.layout-user button:hover{background:#ef444424;border-color:var(--color-danger);color:#fecaca;transform:translateY(-.5px)}.layout-main{flex:1;max-width:960px;width:100%;margin:0 auto;padding:var(--space-4) var(--space-3) calc(64px + env(safe-area-inset-bottom,0))}.layout-bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:58px;padding-bottom:env(safe-area-inset-bottom,0);background:#0f172af5;border-top:1px solid var(--color-border-subtle);align-items:center;justify-content:space-around;z-index:100;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.layout-bottom-link{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;color:var(--color-text-soft);text-decoration:none;font-size:.68rem;padding:.3rem .25rem;transition:color .15s ease,transform .1s ease}.layout-bottom-link:hover{color:var(--color-text-muted);text-decoration:none;transform:translateY(-1px)}.layout-bottom-link.active{color:var(--color-primary)}.layout-bottom-link svg{flex-shrink:0}.layout-add-fab{position:fixed;right:1.25rem;bottom:calc(58px + env(safe-area-inset-bottom,0) + .75rem);width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;cursor:pointer;box-shadow:0 6px 20px #ef444473;z-index:200;display:flex;align-items:center;justify-content:center;line-height:1;transition:transform .15s ease,box-shadow .15s ease}.layout-add-fab:hover{transform:scale(1.06);box-shadow:0 8px 24px #ef444480}.layout-onboarding-fab{position:fixed;right:1.25rem;bottom:calc(118px + env(safe-area-inset-bottom,0) + .75rem);width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary-strong),#0284c7);color:#fff;border:none;font-size:1.25rem;font-weight:700;cursor:pointer;box-shadow:0 8px 22px #0ea5e973;z-index:200;display:flex;align-items:center;justify-content:center;line-height:1}.layout-onboarding-fab:hover{opacity:.95;transform:scale(1.05)}.layout-add-modal-overlay{position:fixed;inset:0;z-index:300;display:flex;align-items:flex-end;justify-content:center;padding:0;pointer-events:auto}.layout-add-modal-backdrop{position:absolute;inset:0;background:#0009}.layout-add-modal{position:relative;width:100%;max-width:520px;max-height:90vh;background:var(--color-surface-alt);border-radius:var(--radius-lg) var(--radius-lg) 0 0;border:1px solid var(--color-border-subtle);border-bottom:none;box-shadow:0 -10px 40px #0006;display:flex;flex-direction:column;overflow:hidden}.layout-add-modal-header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--color-border-subtle);background:var(--color-surface-alt)}.layout-add-modal-header h2{margin:0;font-size:var(--font-size-lg);font-weight:600}.layout-add-modal-close{width:36px;height:36px;border:none;background:transparent;color:var(--color-text-muted);font-size:1.5rem;line-height:1;cursor:pointer;border-radius:var(--radius-md)}.layout-add-modal-close:hover{background:#94a3b826;color:var(--color-text-main)}.layout-add-modal-body{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:0 var(--space-4) var(--space-4) calc(var(--space-4) + env(safe-area-inset-bottom,0))}.layout-add-modal-body .transaction-form-page{padding-top:var(--space-3)}.layout-add-modal-body .transaction-form-page h1{display:none}.layout-add-modal-body .transaction-form-page .page-intro{margin-top:0;margin-bottom:var(--space-3);font-size:var(--font-size-sm)}@media(min-width:769px){.layout-main{max-width:1040px;padding:var(--space-5) var(--space-4) calc(72px + .5rem)}}@media(max-width:768px){.layout-top-nav{padding:.55rem 1.1rem}.layout-main{padding:var(--space-3) var(--space-3) calc(58px + env(safe-area-inset-bottom,0))}}.ui-card{background:var(--color-surface-alt);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);padding:var(--space-4);box-shadow:var(--shadow-subtle)}.ui-card-primary{border-color:var(--color-primary-strong);background:radial-gradient(circle at top left,#38bdf838,#0f172ae6)}.ui-card-soft{background:#0f172ae6;border-radius:var(--radius-lg)}.ui-card-ghost{background:transparent;border-color:transparent;box-shadow:none}.ui-card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);margin-bottom:var(--space-3)}.ui-card-title{font-size:var(--font-size-md);font-weight:600}.ui-card-subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted)}.ui-card-footer{margin-top:var(--space-3);font-size:var(--font-size-xs);color:var(--color-text-soft)}.ui-button{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem 1rem;border-radius:var(--radius-md);border:1px solid transparent;font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease,box-shadow .15s ease,transform .08s ease}.ui-button-primary{background:linear-gradient(135deg,var(--color-primary-strong),var(--color-accent));color:#f9fafb;border-color:#38bdf8cc;box-shadow:0 10px 25px #38bdf859}.ui-button-primary:hover{box-shadow:0 14px 30px #38bdf873;transform:translateY(-1px)}.ui-button-secondary{background:#0f172ae6;color:var(--color-text-main);border-color:var(--color-border-subtle)}.ui-button-secondary:hover{background:#0f172afa}.ui-button-ghost{background:transparent;color:var(--color-text-muted);border-color:transparent}.ui-button-ghost:hover{background:#0f172a99}.ui-button-full{width:100%}.ui-button-icon{width:1.1rem;height:1.1rem;display:inline-flex;align-items:center;justify-content:center}.ui-button:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.ui-textfield{display:flex;flex-direction:column;gap:.35rem}.ui-textfield-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.ui-textfield-input{padding:.75rem .9rem;border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);background:#0f172acc;color:var(--color-text-main);font-size:var(--font-size-md);outline:none;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.ui-textfield-input::placeholder{color:var(--color-text-soft)}.ui-textfield-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 1px #38bdf880;background:#0f172af2}.ui-textfield-helper{font-size:var(--font-size-xs);color:var(--color-text-soft)}.ui-textfield-error-text{font-size:var(--font-size-xs);color:#fecaca}.ui-textfield-error .ui-textfield-input{border-color:var(--color-danger);box-shadow:0 0 0 1px #ef44448c}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top,#020617 0% 45%,#020617);padding:var(--space-5) var(--space-3)}.auth-card{background:radial-gradient(circle at top,#38bdf829,#0f172af5);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-5);width:100%;max-width:400px;box-shadow:var(--shadow-soft)}.auth-logo{width:100%;max-width:220px;height:auto;margin:0 auto 1rem;display:block}.auth-header h1{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-main);margin:0 0 .3rem}.auth-subtitle{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-bottom:1.5rem}.auth-error{background:#ef444433;border:1px solid rgba(239,68,68,.4);color:#fca5a5;padding:.5rem .75rem;border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:1rem}.auth-form{display:flex;flex-direction:column;gap:.875rem}.auth-google-button{margin-top:.75rem;width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;background:#fff;color:#374151;border-radius:999px;border:1px solid #e5e7eb;padding:.6rem 1rem;font-weight:500;font-size:.9rem;box-shadow:0 1px 2px #0f172a40}.auth-google-button:hover{background:#f9fafb}.auth-google-icon{width:20px;height:20px;border-radius:999px;background:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:#4285f4}.auth-footer{margin-top:1.25rem;color:var(--color-text-muted);font-size:var(--font-size-sm);text-align:center}.auth-footer a{color:var(--color-primary);text-decoration:none}.auth-footer a:hover{text-decoration:underline}.auth-spinner{margin-top:1.25rem;width:28px;height:28px;border-radius:999px;border:3px solid rgba(148,163,184,.4);border-top-color:var(--color-primary);animation:auth-spinner .8s linear infinite}@keyframes auth-spinner{to{transform:rotate(360deg)}}@media(max-width:480px){.auth-card{padding:var(--space-4)}}.ui-chip{display:inline-flex;align-items:center;justify-content:center;padding:.15rem .5rem;border-radius:999px;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.04em;border:1px solid transparent}.ui-chip-income{background:var(--color-chip-income-bg);color:var(--color-chip-income-fg);border-color:#22c55e80}.ui-chip-expense{background:var(--color-chip-expense-bg);color:var(--color-chip-expense-fg);border-color:#ef444499}.ui-chip-neutral{background:var(--color-chip-neutral-bg);color:var(--color-chip-neutral-fg);border-color:#94a3b899}.ui-chip-info{background:#38bdf833;color:#7dd3fc;border-color:#38bdf8b3}.ui-emptystate{text-align:center;padding:var(--space-5) var(--space-4);border-radius:var(--radius-lg);background:radial-gradient(circle at top,#38bdf81f,#0f172ae6);border:1px dashed rgba(148,163,184,.5)}.ui-emptystate-icon{width:40px;height:40px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#0f172ae6;box-shadow:0 8px 18px #0f172a99;margin-bottom:var(--space-3)}.ui-emptystate-title{margin:0 0 var(--space-2);font-size:var(--font-size-lg)}.ui-emptystate-description{margin:0 0 var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-muted)}.ui-emptystate-button{margin-top:var(--space-1)}.dashboard{margin-top:var(--space-4)}.dashboard h1{font-size:var(--font-size-xl);margin-bottom:.35rem}.page-intro{color:var(--color-text-muted);font-size:var(--font-size-sm);margin:0 0 1.25rem}.getting-started-card{border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:1.5rem}.getting-started-card h2{font-size:var(--font-size-md);margin:0 0 .75rem;color:var(--color-text-main)}.getting-started-card ol{margin:0 0 1rem;padding-left:1.25rem;color:var(--color-text-muted);font-size:var(--font-size-sm);line-height:1.6}.getting-started-card a{color:var(--color-primary);text-decoration:none;font-weight:500}.getting-started-card a:hover{text-decoration:underline}.getting-started-dismiss{background:#38bdf840;border:1px solid rgba(56,189,248,.5);color:#38bdf8;padding:.4rem .85rem;border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm)}.getting-started-dismiss:hover{background:#38bdf859}.empty-state{margin-top:.5rem}.empty-state .muted{margin-bottom:.75rem}.empty-state-cta{display:inline-block;text-decoration:none}.dashboard-loading{text-align:center;padding:2rem;color:var(--color-text-muted)}.dashboard-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.05rem;margin-bottom:2rem}.stat-card{border-radius:var(--radius-md);padding:var(--space-3) var(--space-4)}.stat-card.net-worth{grid-column:1 / -1;border-color:var(--color-primary-strong)}.stat-card.balance{border-color:#22c55e66;background:#22c55e14}.link-button{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:var(--font-size-xs);margin-top:.5rem;padding:0}.link-button:hover{text-decoration:underline}.net-worth-breakdown{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border-subtle);font-size:var(--font-size-sm);color:var(--color-text-muted)}.net-worth-breakdown p{margin:.25rem 0}.stat-card span{display:block;font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:.25rem}.stat-card strong{font-size:1.3rem}.stat-card .positive{color:#4ade80}.stat-card .negative{color:#f87171}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.dashboard-section+.dashboard-grid{margin-top:var(--space-4)}@media(max-width:900px){.dashboard-grid{grid-template-columns:1fr}}@media(max-width:768px){.dashboard-cards{grid-template-columns:1fr 1fr;gap:.75rem}.stat-card strong{font-size:1.1rem}.stat-card{padding:.75rem 1rem}}.dashboard-section{border-radius:var(--radius-md);padding:var(--space-4)}.dashboard-section h2{font-size:var(--font-size-md);margin:0 0 2rem;color:var(--color-text-main)}.category-list,.tx-list{list-style:none;padding:0;margin:0}.category-list li,.tx-list li{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid rgba(148,163,184,.1);font-size:var(--font-size-sm)}.category-list li:last-child,.tx-list li:last-child{border-bottom:none}.tx-desc{flex:1;margin:0 .5rem;color:var(--color-text-muted)}.due-hint{font-size:.85em;color:var(--color-text-muted);font-weight:400}.muted{color:var(--color-text-soft);font-size:var(--font-size-sm)}.link-more{display:inline-block;margin-top:.75rem;color:var(--color-primary);font-size:var(--font-size-sm);text-decoration:none}.link-more:hover{text-decoration:underline}.accounts-page{padding:0}.accounts-header{display:flex;align-items:center;justify-content:center;position:relative;padding:1rem 1.25rem .75rem}.accounts-header-title{font-size:1.1rem;font-weight:600;color:#f8fafc;letter-spacing:.01em}.accounts-header-actions{position:absolute;right:1.25rem;display:flex;gap:.5rem;align-items:center}.accounts-icon-btn{background:none;border:none;color:#94a3b8;cursor:pointer;padding:.35rem;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:color .15s}.accounts-icon-btn:hover,.accounts-icon-btn.active{color:#f8fafc}.accounts-summary{display:flex;align-items:center;padding:.75rem 1.25rem 1rem;border-bottom:1px solid rgba(148,163,184,.12)}.accounts-summary-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:.2rem}.accounts-summary-divider{width:1px;height:2rem;background:#94a3b833}.accounts-summary-label{font-size:.75rem;color:#94a3b8}.accounts-summary-value{font-size:.95rem;font-weight:600}.accounts-summary-value.asset{color:#3b82f6}.accounts-summary-value.liability{color:#ef4444}.accounts-summary-value.total{color:#f8fafc}.accounts-groups{padding:0 0 1rem}.accounts-group{margin-bottom:.25rem}.accounts-group-header{display:flex;align-items:center;justify-content:space-between;padding:.55rem 1.25rem .35rem;background:#94a3b80f}.accounts-group-header.card-header{align-items:flex-end}.accounts-group-name{font-size:.78rem;color:#94a3b8;font-weight:500;letter-spacing:.02em}.accounts-group-total{font-size:.85rem;font-weight:600}.accounts-group-total.asset{color:#3b82f6}.accounts-group-total.liability{color:#ef4444}.accounts-card-col-headers{display:flex;gap:2rem;font-size:.72rem;color:#94a3b8}.accounts-row{display:flex;align-items:center;justify-content:space-between;padding:.7rem 1.25rem;border-bottom:1px solid rgba(148,163,184,.08)}.accounts-row:last-child{border-bottom:none}.accounts-row-name{font-size:.9rem;color:#f8fafc;font-weight:400}.accounts-row-balance{font-size:.9rem;font-weight:500}.accounts-row-balance.asset{color:#f8fafc}.accounts-row-balance.liability{color:#ef4444}.accounts-card-values{display:flex;gap:2rem;align-items:center}.accounts-card-payable,.accounts-card-outstanding{font-size:.9rem;font-weight:500;min-width:5rem;text-align:right}.accounts-card-payable.liability,.accounts-card-outstanding.liability{color:#ef4444}.accounts-row-actions{display:flex;gap:.4rem;margin-left:.75rem}.accounts-empty{text-align:center;padding:3rem 1.5rem;color:#64748b;font-size:.9rem}.account-form-overlay{position:fixed;inset:0;background:#00000080;z-index:300;display:flex;align-items:flex-end;justify-content:center}@media(min-width:640px){.account-form-overlay{align-items:center}}.account-form-sheet{background:#0f172a;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;border-radius:16px 16px 0 0;padding-bottom:env(safe-area-inset-bottom,0)}@media(min-width:640px){.account-form-sheet{border-radius:16px;max-height:85vh}}.account-form-header{display:flex;align-items:center;justify-content:center;position:relative;padding:1rem 1.25rem .75rem;border-bottom:1px solid rgba(148,163,184,.15)}.account-form-back{position:absolute;left:1rem;display:flex;align-items:center;gap:.2rem;background:none;border:none;color:#94a3b8;font-size:.85rem;cursor:pointer;padding:.25rem}.account-form-back:hover{color:#f8fafc}.account-form-heading{font-size:1rem;font-weight:600;color:#f8fafc}.account-form-body{padding:.5rem 0 1.5rem}.account-form-row{display:flex;align-items:center;padding:.75rem 1.25rem;border-bottom:1px solid rgba(148,163,184,.1);gap:1rem}.account-form-row label{font-size:.875rem;color:#94a3b8;min-width:7.5rem;flex-shrink:0}.account-form-row input,.account-form-row select{flex:1;background:transparent;border:none;border-bottom:1px solid rgba(148,163,184,.3);color:#f8fafc;font-size:.9rem;padding:.25rem 0;outline:none}.account-form-row input:focus,.account-form-row select:focus{border-bottom-color:#ef4444}.account-form-row select option{background:#1e293b;color:#f8fafc}.account-form-toggle-row{justify-content:space-between}.account-form-note{color:#64748b;font-size:.78rem;line-height:1.4;margin-top:-.2rem}.toggle-btn{width:44px;height:26px;border-radius:13px;background:#94a3b84d;border:none;cursor:pointer;position:relative;transition:background .2s;flex-shrink:0}.toggle-btn:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s}.toggle-btn.on{background:#ef4444}.toggle-btn.on:after{transform:translate(18px)}.account-form-cycle-info{padding:0 1.25rem}.billing-cycle-info{background:#1e293bcc;border-radius:8px;padding:.75rem 1rem;font-size:.8rem;display:flex;flex-direction:column;gap:.35rem}.billing-cycle-info>div{display:flex;justify-content:space-between;color:#94a3b8}.billing-cycle-info>div span:first-child{color:#64748b}.account-form-save-btn{display:block;width:calc(100% - 2.5rem);margin:1.5rem 1.25rem 0;padding:.9rem;background:#ef4444;border:none;border-radius:10px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .15s}.account-form-save-btn:hover{opacity:.9}.btn-sm{background:#38bdf826;border:1px solid rgba(56,189,248,.3);color:#38bdf8;padding:.3rem .6rem;border-radius:6px;font-size:.75rem;cursor:pointer}.btn-sm.danger{background:#ef444426;border-color:#ef44444d;color:#f87171}@media(max-width:480px){.accounts-card-col-headers{gap:1rem;font-size:.68rem}.accounts-card-values{gap:1rem}.accounts-card-payable,.accounts-card-outstanding{min-width:4rem;font-size:.82rem}}.reports-tabs{display:flex;gap:.75rem;margin-bottom:1rem;overflow-x:auto;padding-bottom:.25rem}.reports-tab{border:none;background:transparent;color:var(--color-text-muted);padding:.3rem .1rem;font-size:var(--font-size-sm);cursor:pointer;position:relative;white-space:nowrap}.reports-tab-active{color:var(--color-primary);font-weight:600}.reports-tab-active:after{content:"";position:absolute;left:0;right:0;bottom:-.25rem;height:2px;border-radius:999px;background:linear-gradient(90deg,var(--color-primary-strong),var(--color-accent))}.react-calendar{width:350px;max-width:100%;background:#fff;border:1px solid #a0a096;font-family:Arial,Helvetica,sans-serif;line-height:1.125em}.react-calendar--doubleView{width:700px}.react-calendar--doubleView .react-calendar__viewContainer{display:flex;margin:-.5em}.react-calendar--doubleView .react-calendar__viewContainer>*{width:50%;margin:.5em}.react-calendar,.react-calendar *,.react-calendar *:before,.react-calendar *:after{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}.react-calendar button{margin:0;border:0;outline:none}.react-calendar button:enabled:hover{cursor:pointer}.react-calendar__navigation{display:flex;height:44px;margin-bottom:1em}.react-calendar__navigation button{min-width:44px;background:none}.react-calendar__navigation button:disabled{background-color:#f0f0f0}.react-calendar__navigation button:enabled:hover,.react-calendar__navigation button:enabled:focus{background-color:#e6e6e6}.react-calendar__month-view__weekdays{text-align:center;text-transform:uppercase;font:inherit;font-size:.75em;font-weight:700}.react-calendar__month-view__weekdays__weekday{padding:.5em}.react-calendar__month-view__weekNumbers .react-calendar__tile{display:flex;align-items:center;justify-content:center;font:inherit;font-size:.75em;font-weight:700}.react-calendar__month-view__days__day--weekend{color:#d10000}.react-calendar__month-view__days__day--neighboringMonth,.react-calendar__decade-view__years__year--neighboringDecade,.react-calendar__century-view__decades__decade--neighboringCentury{color:#757575}.react-calendar__year-view .react-calendar__tile,.react-calendar__decade-view .react-calendar__tile,.react-calendar__century-view .react-calendar__tile{padding:2em .5em}.react-calendar__tile{max-width:100%;padding:10px 6.6667px;background:none;text-align:center;font:inherit;font-size:.833em}.react-calendar__tile:disabled{background-color:#f0f0f0;color:#ababab}.react-calendar__month-view__days__day--neighboringMonth:disabled,.react-calendar__decade-view__years__year--neighboringDecade:disabled,.react-calendar__century-view__decades__decade--neighboringCentury:disabled{color:#cdcdcd}.react-calendar__tile:enabled:hover,.react-calendar__tile:enabled:focus{background-color:#e6e6e6}.react-calendar__tile--now{background:#ffff76}.react-calendar__tile--now:enabled:hover,.react-calendar__tile--now:enabled:focus{background:#ffffa9}.react-calendar__tile--hasActive{background:#76baff}.react-calendar__tile--hasActive:enabled:hover,.react-calendar__tile--hasActive:enabled:focus{background:#a9d4ff}.react-calendar__tile--active{background:#006edc;color:#fff}.react-calendar__tile--active:enabled:hover,.react-calendar__tile--active:enabled:focus{background:#1087ff}.react-calendar--selectRange .react-calendar__tile--hover{background-color:#e6e6e6}.transactions-page h1{font-size:1.4rem;margin-bottom:.1rem}.transactions-page .empty-state .muted{margin-bottom:.75rem}.transactions-page .empty-state-cta{display:inline-block;text-decoration:none}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.reports-header{margin-bottom:1rem}.reports-header-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.reports-header-center{flex:1}.reports-header-month{font-size:var(--font-size-md);font-weight:600;margin-bottom:.25rem}.reports-header-totals{display:flex;gap:.75rem;font-size:var(--font-size-xs);color:var(--color-text-soft)}.reports-header-income{color:#60a5fa}.reports-header-expense{color:#f97373}.reports-header-total{color:var(--color-text-main)}.reports-header-nav{border:none;background:transparent;color:var(--color-text-muted);font-size:1.1rem;cursor:pointer}.reports-header-nav:disabled{opacity:.6;cursor:not-allowed}.reports-header-updating{color:var(--color-text-soft);font-size:var(--font-size-xs)}.reports-content-loading{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:2rem;color:var(--color-text-soft);font-size:var(--font-size-sm)}.reports-content-loading-spinner{width:1.25rem;height:1.25rem;border:2px solid var(--color-border-subtle);border-top-color:var(--color-primary);border-radius:50%;animation:reports-spin .7s linear infinite}@keyframes reports-spin{to{transform:rotate(360deg)}}.filters{display:flex;gap:.75rem;margin:.5rem 0 1.25rem}.filters select,.filters input{background:#1e293bcc;border:1px solid rgba(148,163,184,.3);border-radius:8px;padding:.5rem .75rem;color:#f8fafc}.reports-daily-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.75rem}.reports-daily-date{display:flex;align-items:center;gap:.6rem}.reports-daily-date-main{font-size:var(--font-size-md);font-weight:600}.reports-daily-date-sub{font-size:var(--font-size-xs);color:var(--color-text-soft)}.reports-day-nav{border:none;background:#0f172ae6;color:var(--color-text-muted);border-radius:999px;width:26px;height:26px;display:flex;align-items:center;justify-content:center;cursor:pointer}.reports-daily-totals{display:flex;flex-direction:column;align-items:flex-end;gap:.1rem;font-size:var(--font-size-xs)}.reports-calendar-section{margin-top:.5rem;display:flex;flex-direction:column;gap:1rem}.reports-calendar{padding:var(--space-4);border-radius:var(--radius-lg)}.reports-calendar-section .react-calendar{width:100%;background:transparent;border:none;font-family:var(--font-sans);line-height:1.3}.reports-calendar-section .react-calendar__navigation{display:flex;align-items:center;justify-content:space-between;height:48px;margin-bottom:var(--space-3);padding:0 var(--space-1)}.reports-calendar-section .react-calendar__navigation button{color:var(--color-text-main);min-width:40px;height:40px;padding:0;background:#0f172acc;border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);font-size:var(--font-size-md);font-weight:600}.reports-calendar-section .react-calendar__navigation button:enabled:hover{background:#38bdf826;border-color:var(--color-primary);color:var(--color-primary)}.reports-calendar-section .react-calendar__navigation__label{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-main)}.reports-calendar-section .react-calendar__month-view__weekdays{text-align:center;text-transform:none;font-size:var(--font-size-xs);font-weight:600;margin-bottom:var(--space-2)}.reports-calendar-section .react-calendar__month-view__weekdays__weekday{padding:.4em 0;color:var(--color-text-muted)}.reports-calendar-section .react-calendar__month-view__weekdays__weekday abbr{text-decoration:none}.reports-calendar-section .react-calendar__month-view__weekdays__weekday:nth-child(1){color:#f87171}.reports-calendar-section .react-calendar__month-view__weekdays__weekday:nth-child(7){color:#60a5fa}.reports-calendar-section .react-calendar__month-view__days{display:grid!important;grid-template-columns:repeat(7,1fr);gap:4px}.reports-calendar-section .react-calendar__month-view__days__day{max-width:none}.reports-calendar-section .react-calendar__tile{min-height:56px;border-radius:var(--radius-md);background:#0f172ab3;border:1px solid var(--color-border-subtle);padding:.35rem .4rem;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:.2rem;color:var(--color-text-main);font-size:var(--font-size-sm);font-weight:500;transition:background .15s ease,border-color .15s ease}@media(max-width:480px){.reports-calendar-section .react-calendar__tile{min-height:48px;padding:.25rem .3rem;font-size:.8rem}.reports-calendar-section .react-calendar__navigation__label{font-size:var(--font-size-md)}.reports-calendar-section .react-calendar__navigation button{min-width:32px;height:32px;font-size:var(--font-size-sm)}.reports-calendar-section .react-calendar__month-view__weekdays__weekday abbr{font-size:.65rem}}.reports-calendar-section .react-calendar__tile:enabled:hover{background:#38bdf81f;border-color:#38bdf880}.reports-calendar-section .react-calendar__month-view__days__day--neighboringMonth{color:var(--color-text-soft);opacity:.6}.reports-calendar-section .react-calendar__month-view__days__day--weekend{color:var(--color-text-main)}.reports-calendar-section .react-calendar__month-view__days__day--weekend:nth-child(7n){color:#93c5fd}.reports-calendar-section .react-calendar__month-view__days__day--weekend:nth-child(7n+1){color:#fca5a5}.reports-calendar-section .react-calendar__tile--now{background:#38bdf81f;border-color:var(--color-primary);font-weight:600}.reports-calendar-section .react-calendar__tile--active{background:#38bdf833;border-color:var(--color-primary);box-shadow:0 0 0 2px #38bdf859;font-weight:600}.reports-calendar-section .reports-calendar-cell{display:flex;flex-direction:column;align-items:center;gap:.15rem;width:100%}.reports-calendar-section .reports-calendar-dots{display:flex;align-items:center;justify-content:center;gap:.2rem;flex-wrap:nowrap}.reports-calendar-section .reports-calendar-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.reports-calendar-section .reports-calendar-dot--income{background:#60a5fa}.reports-calendar-section .reports-calendar-dot--expense{background:#f97373}.reports-calendar-section .reports-calendar-dot--transfer{background:#94a3b8}.reports-calendar-section .reports-calendar-dot--payment{background:#a78bfa}.reports-calendar-section .reports-calendar-dot--neutral{background:var(--color-text-muted)}.reports-calendar-section .reports-calendar-more{font-size:.55rem;font-weight:600;color:var(--color-text-muted);line-height:1}.reports-calendar-section .reports-calendar-total{font-size:.65rem;font-weight:500;color:var(--color-text-muted);line-height:1.2;text-align:center}.reports-calendar-section .reports-calendar-total .positive{color:#60a5fa}.reports-calendar-section .reports-calendar-total .negative{color:#f97373}@media(max-width:480px){.reports-calendar-section .reports-calendar-dot{width:4px;height:4px}.reports-calendar-section .reports-calendar-more{font-size:.5rem}.reports-calendar-section .reports-calendar-total{font-size:.55rem}}.reports-calendar-daily{margin-top:.25rem}.reports-monthly-section{margin-top:.5rem;display:flex;flex-direction:column;gap:1rem}.reports-monthly-summary{padding:var(--space-4)}.reports-monthly-summary-title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:.5rem;color:var(--color-text-main)}.reports-monthly-summary-row{display:flex;gap:1rem;font-size:var(--font-size-sm)}.reports-monthly-summary-row .reports-header-income{color:#60a5fa}.reports-monthly-summary-row .reports-header-expense{color:#f97373}.reports-monthly-summary-row .reports-header-total{color:var(--color-text-main);font-weight:600}.reports-monthly-actions{display:flex;gap:.5rem}.reports-monthly-actions .btn-secondary{padding:.4rem .75rem;font-size:var(--font-size-sm);background:#94a3b826;border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);color:var(--color-text-main);cursor:pointer}.reports-monthly-actions .btn-secondary:hover{background:#94a3b840;border-color:var(--color-border-strong)}.reports-monthly-list{display:flex;flex-direction:column;gap:1.25rem}.reports-monthly-day-block{border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);overflow:hidden;background:#0f172a80}.reports-monthly-day-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem var(--space-3);background:#0f172acc;border-bottom:1px solid var(--color-border-subtle);font-size:var(--font-size-sm)}.reports-monthly-day-date{font-weight:600;color:var(--color-text-main)}.reports-monthly-day-totals{display:flex;gap:.5rem;font-size:var(--font-size-xs)}.reports-monthly-day-totals .positive{color:#60a5fa}.reports-monthly-day-totals .negative{color:#f97373}.reports-monthly-day-block .tx-table{margin:0;border:none}.reports-monthly-day-block .tx-row{border-bottom:1px solid var(--color-border-subtle)}.reports-monthly-day-block .tx-row:last-child{border-bottom:none}.reports-day-modal{position:fixed;inset:0;z-index:300;pointer-events:none;visibility:hidden;transition:visibility .25s ease}.reports-day-modal--open{pointer-events:auto;visibility:visible}.reports-day-modal-backdrop{position:absolute;inset:0;background:#00000080;opacity:0;transition:opacity .25s ease}.reports-day-modal--open .reports-day-modal-backdrop{opacity:1}.reports-day-modal-sheet{position:absolute;left:0;right:0;bottom:0;max-height:85vh;background:var(--color-surface-alt);border-radius:var(--radius-lg) var(--radius-lg) 0 0;border:1px solid var(--color-border-subtle);border-bottom:none;box-shadow:0 -10px 40px #0006;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1)}.reports-day-modal--open .reports-day-modal-sheet{transform:translateY(0)}.reports-day-modal-handle{width:36px;height:4px;margin:.5rem auto;background:var(--color-text-soft);border-radius:2px;opacity:.6}.reports-day-modal-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:0 var(--space-4) var(--space-3);border-bottom:1px solid var(--color-border-subtle);flex-wrap:wrap}.reports-day-modal-header .reports-daily-date{flex:1;min-width:0}.reports-day-modal-header .reports-daily-totals{margin-left:auto}.reports-day-modal-close{flex-shrink:0;width:36px;height:36px;border:none;background:transparent;color:var(--color-text-muted);font-size:1.5rem;line-height:1;cursor:pointer;border-radius:var(--radius-md)}.reports-day-modal-close:hover{background:#94a3b826;color:var(--color-text-main)}.reports-day-modal-body{flex:1;overflow-y:auto;padding:var(--space-3) var(--space-4) calc(var(--space-4) + env(safe-area-inset-bottom,0))}.tx-table{display:flex;flex-direction:column;gap:.5rem}.tx-row{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#1e293bcc;border:1px solid rgba(148,163,184,.2);border-radius:8px;font-size:.9rem}.tx-date{width:100px;color:#94a3b8}.tx-detail{flex:1;color:#cbd5e1}.positive{color:#4ade80}.negative{color:#f87171}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start;gap:.75rem}.filters{flex-wrap:wrap;gap:.5rem}.filters select,.filters input{min-width:0}.tx-row{flex-wrap:wrap;gap:.5rem}.tx-date,.tx-type-badge{width:auto;min-width:0}.tx-detail{flex:1 1 100%;order:3}}.reminders-page{padding:0}.reminders-header{display:flex;align-items:center;justify-content:center;position:relative;padding:1rem 1.25rem .75rem}.reminders-header-title{font-size:1.1rem;font-weight:600;color:#f8fafc;letter-spacing:.01em}.reminders-header-actions{position:absolute;right:1.25rem;display:flex;gap:.5rem;align-items:center}.reminders-icon-btn{background:none;border:none;color:#94a3b8;cursor:pointer;padding:.35rem;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:color .15s}.reminders-icon-btn:hover{color:#f8fafc}.reminders-summary{display:flex;align-items:center;padding:.75rem 1.25rem 1rem;border-bottom:1px solid rgba(148,163,184,.12)}.reminders-summary-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:.2rem}.reminders-summary-divider{width:1px;height:2rem;background:#94a3b833}.reminders-summary-label{font-size:.75rem;color:#94a3b8}.reminders-summary-value{font-size:.95rem;font-weight:600;color:#f8fafc}.reminders-summary-value.overdue{color:#ef4444}.reminders-groups{padding:0 0 1rem}.reminders-group{margin-bottom:.25rem}.reminders-group-header{display:flex;align-items:center;justify-content:space-between;padding:.55rem 1.25rem .35rem;background:#94a3b80f}.reminders-group-name{font-size:.78rem;color:#94a3b8;font-weight:500;letter-spacing:.02em}.reminders-group-header.overdue .reminders-group-name{color:#ef4444}.reminders-group-header.thisWeek .reminders-group-name{color:#f59e0b}.reminders-group-count{font-size:.75rem;color:#64748b;background:#94a3b81a;padding:.1rem .45rem;border-radius:10px}.reminder-row{border-bottom:1px solid rgba(148,163,184,.08)}.reminder-row:last-child{border-bottom:none}.reminder-row-main{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;cursor:pointer;gap:.75rem}.reminder-row-main:hover{background:#94a3b80a}.reminder-row-left{flex:1;min-width:0}.reminder-row-title-line{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.reminder-type-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.reminder-type-dot.credit{background:#22c55e}.reminder-type-dot.debit{background:#ef4444}.reminder-row-title{font-size:.9rem;color:#f8fafc;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reminder-kind-badge{font-size:.65rem;color:#64748b;background:#94a3b81a;padding:.1rem .4rem;border-radius:4px;flex-shrink:0}.reminder-kind-badge.loan{color:#38bdf8;border:1px solid rgba(56,189,248,.35)}.reminder-row-meta{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}.reminder-due{font-size:.78rem;color:#64748b}.reminder-ends,.reminder-person{font-size:.72rem;color:#475569}.reminder-row-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.reminder-amount{font-size:.9rem;font-weight:600}.reminder-amount.credit{color:#22c55e}.reminder-amount.debit{color:#ef4444}.reminder-row-actions{display:flex;gap:.5rem;padding:.5rem 1.25rem .75rem;background:#94a3b80a}.reminder-action-btn{padding:.4rem .9rem;border-radius:8px;font-size:.8rem;font-weight:500;cursor:pointer;border:none;transition:opacity .15s}.reminder-action-btn:hover{opacity:.85}.reminder-action-btn.confirm{background:#22c55e33;color:#4ade80;border:1px solid rgba(34,197,94,.3)}.reminder-action-btn.stop{background:#f59e0b26;color:#fbbf24;border:1px solid rgba(245,158,11,.3)}.reminder-action-btn.delete{background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.3)}.reminder-managed-note{color:#94a3b8;font-size:.75rem;align-self:center}.reminders-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:3rem 1.5rem;color:#475569;gap:.4rem}.reminders-empty svg{color:#334155;margin-bottom:.5rem}.reminders-empty p{margin:0;font-size:.9rem}.reminder-form-overlay{position:fixed;inset:0;background:#00000080;z-index:300;display:flex;align-items:flex-end;justify-content:center}@media(min-width:640px){.reminder-form-overlay{align-items:center}}.reminder-form-sheet{background:#0f172a;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;border-radius:16px 16px 0 0;padding-bottom:env(safe-area-inset-bottom,0)}@media(min-width:640px){.reminder-form-sheet{border-radius:16px;max-height:85vh}}.reminder-form-header{display:flex;align-items:center;justify-content:center;position:relative;padding:1rem 1.25rem .75rem;border-bottom:1px solid rgba(148,163,184,.15)}.reminder-form-back{position:absolute;left:1rem;display:flex;align-items:center;gap:.2rem;background:none;border:none;color:#94a3b8;font-size:.85rem;cursor:pointer;padding:.25rem}.reminder-form-back:hover{color:#f8fafc}.reminder-form-heading{font-size:1rem;font-weight:600;color:#f8fafc}.reminder-form-body{padding:.5rem 0 1.5rem}.reminder-form-row{display:flex;align-items:center;padding:.75rem 1.25rem;border-bottom:1px solid rgba(148,163,184,.1);gap:1rem}.reminder-form-row label{font-size:.875rem;color:#94a3b8;min-width:7.5rem;flex-shrink:0}.reminder-form-row input,.reminder-form-row select{flex:1;background:transparent;border:none;border-bottom:1px solid rgba(148,163,184,.3);color:#f8fafc;font-size:.9rem;padding:.25rem 0;outline:none}.reminder-form-row input:focus,.reminder-form-row select:focus{border-bottom-color:#ef4444}.reminder-form-row select option{background:#1e293b;color:#f8fafc}.reminder-form-save-btn{display:block;width:calc(100% - 2.5rem);margin:1.5rem 1.25rem 0;padding:.9rem;background:#ef4444;border:none;border-radius:10px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .15s}.reminder-form-save-btn:hover{opacity:.9}.page-loading{text-align:center;padding:3rem;color:#94a3b8}.form-error{background:#ef444426;color:#fca5a5;padding:.5rem 1.25rem;font-size:.85rem;margin:.5rem 1.25rem;border-radius:8px}.settings-page h1{font-size:1.5rem;margin-bottom:.5rem}.settings-desc{color:#94a3b8;font-size:.9rem;margin-bottom:1.5rem}.settings-form{max-width:400px;display:flex;flex-direction:column;gap:1rem}.settings-form .form-row label{display:block;font-size:.85rem;color:#94a3b8;margin-bottom:.35rem}.settings-form select{width:100%;background:#1e293bcc;border:1px solid rgba(148,163,184,.3);border-radius:8px;padding:.6rem .75rem;color:#f8fafc}.settings-form .message{font-size:.9rem}.settings-form .message.success{color:#4ade80}.settings-form .message.error{color:#f87171}.onboarding-again-section{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid rgba(148,163,184,.2);max-width:480px}.onboarding-again-section h2{font-size:1rem;margin:0 0 .5rem;color:#e2e8f0}.onboarding-again-desc{color:#94a3b8;font-size:.9rem;margin:0 0 .75rem}.btn-secondary-outline{background:transparent;border:1px solid rgba(148,163,184,.4);color:#94a3b8;padding:.5rem 1rem;border-radius:8px;font-size:.9rem;cursor:pointer}.btn-secondary-outline:hover{border-color:#64748b;color:#cbd5e1}.pwa-install-section{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid rgba(148,163,184,.2);max-width:480px}.pwa-install-section h2{font-size:1rem;margin:0 0 .5rem;color:#e2e8f0}.pwa-install-desc{color:#94a3b8;font-size:.9rem;margin:0 0 .75rem}.pwa-install-steps{margin:0;padding-left:1.25rem;color:#cbd5e1;font-size:.9rem;line-height:1.6}.pwa-install-steps li{margin-bottom:.5rem}.pwa-install-steps strong{color:#e2e8f0}*{box-sizing:border-box}body{margin:0;font-family:var(--font-sans);-webkit-font-smoothing:antialiased}.app-loading,.auth-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top,#020617 0 45%,#020617);color:var(--color-text-muted)}
