:root{--color-bg:#f8f7f4;--color-surface:#fff;--color-surface-raised:#fff;--color-surface-overlay:#ffffffd9;--color-border:#e2e0db;--color-border-strong:#c8c5bf;--color-text-primary:#1c1c1e;--color-text-secondary:#6b6966;--color-text-tertiary:#9b9895;--color-text-inverse:#fff;--color-accent:#2563eb;--color-accent-hover:#1d4ed8;--color-accent-active:#1e40af;--color-accent-subtle:#eff6ff;--color-accent-text:#1d4ed8;--color-success:#16a34a;--color-success-subtle:#f0fdf4;--color-success-border:#bbf7d0;--color-warning:#d97706;--color-warning-subtle:#fffbeb;--color-warning-border:#fde68a;--color-danger:#dc2626;--color-danger-subtle:#fef2f2;--color-danger-border:#fecaca;--color-info:#0284c7;--color-info-subtle:#f0f9ff;--color-info-border:#bae6fd;--font-family:"DM Sans", system-ui, -apple-system, sans-serif;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-md:1.125rem;--font-size-lg:1.25rem;--font-size-xl:1.5rem;--font-size-2xl:1.875rem;--font-size-3xl:2.25rem;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-tight:1.2;--line-height-snug:1.4;--line-height-normal:1.6;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-2xl:28px;--radius-full:9999px;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000d;--shadow-md:0 4px 12px #00000014, 0 2px 4px #0000000d;--shadow-lg:0 10px 30px #0000001a, 0 4px 8px #0000000f;--shadow-xl:0 20px 50px #0000001f, 0 8px 16px #00000012;--transition-fast:.12s ease;--transition-base:.2s ease;--transition-slow:.32s ease;--touch-target:48px;--content-max-width:480px}@media (prefers-color-scheme:dark){:root{--color-bg:#0f172a;--color-surface:#1e293b;--color-surface-raised:#273549;--color-surface-overlay:#0f172ae6;--color-border:#2d3f55;--color-border-strong:#3d5470;--color-text-primary:#f1f5f9;--color-text-secondary:#94a3b8;--color-text-tertiary:#64748b;--color-text-inverse:#0f172a;--color-accent:#3b82f6;--color-accent-hover:#60a5fa;--color-accent-active:#93c5fd;--color-accent-subtle:#3b82f626;--color-accent-text:#60a5fa;--color-success:#4ade80;--color-success-subtle:#4ade801f;--color-success-border:#4ade8040;--color-warning:#fbbf24;--color-warning-subtle:#fbbf241f;--color-warning-border:#fbbf2440;--color-danger:#f87171;--color-danger-subtle:#f871711f;--color-danger-border:#f8717140;--color-info:#38bdf8;--color-info-subtle:#38bdf81f;--color-info-border:#38bdf840;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #00000059;--shadow-lg:0 10px 30px #0006;--shadow-xl:0 20px 50px #00000080}}[data-theme=dark]{--color-bg:#0f172a;--color-surface:#1e293b;--color-surface-raised:#273549;--color-surface-overlay:#0f172ae6;--color-border:#2d3f55;--color-border-strong:#3d5470;--color-text-primary:#f1f5f9;--color-text-secondary:#94a3b8;--color-text-tertiary:#64748b;--color-text-inverse:#0f172a;--color-accent:#3b82f6;--color-accent-hover:#60a5fa;--color-accent-active:#93c5fd;--color-accent-subtle:#3b82f626;--color-accent-text:#60a5fa;--color-success:#4ade80;--color-success-subtle:#4ade801f;--color-success-border:#4ade8040;--color-warning:#fbbf24;--color-warning-subtle:#fbbf241f;--color-warning-border:#fbbf2440;--color-danger:#f87171;--color-danger-subtle:#f871711f;--color-danger-border:#f8717140;--color-info:#38bdf8;--color-info-subtle:#38bdf81f;--color-info-border:#38bdf840;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #00000059;--shadow-lg:0 10px 30px #0006;--shadow-xl:0 20px 50px #00000080}[data-theme=light]{--color-bg:#f8f7f4;--color-surface:#fff;--color-surface-raised:#fff;--color-surface-overlay:#ffffffd9;--color-border:#e2e0db;--color-border-strong:#c8c5bf;--color-text-primary:#1c1c1e;--color-text-secondary:#6b6966;--color-text-tertiary:#9b9895;--color-text-inverse:#fff;--color-accent:#2563eb;--color-accent-hover:#1d4ed8;--color-accent-active:#1e40af;--color-accent-subtle:#eff6ff;--color-accent-text:#1d4ed8;--color-success:#16a34a;--color-success-subtle:#f0fdf4;--color-success-border:#bbf7d0;--color-warning:#d97706;--color-warning-subtle:#fffbeb;--color-warning-border:#fde68a;--color-danger:#dc2626;--color-danger-subtle:#fef2f2;--color-danger-border:#fecaca;--color-info:#0284c7;--color-info-subtle:#f0f9ff;--color-info-border:#bae6fd;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000d;--shadow-md:0 4px 12px #00000014, 0 2px 4px #0000000d;--shadow-lg:0 10px 30px #0000001a, 0 4px 8px #0000000f;--shadow-xl:0 20px 50px #0000001f, 0 8px 16px #00000012}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg);-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}body{background-color:var(--color-bg);min-width:320px;min-height:100dvh;color:var(--color-text-primary);transition:background-color var(--transition-base), color var(--transition-base)}img,video{max-width:100%;height:auto;display:block}a{color:var(--color-accent-text);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--color-text-primary)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}h5{font-size:var(--font-size-md)}h6{font-size:var(--font-size-base)}p{color:var(--color-text-secondary);line-height:var(--line-height-normal)}strong,b{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}small{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.mono{font-variant-numeric:tabular-nums;letter-spacing:-.01em}.btn{justify-content:center;align-items:center;gap:var(--space-2);min-height:var(--touch-target);padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:background-color var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;white-space:nowrap;border:none;line-height:1;text-decoration:none;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background-color:var(--color-accent);color:var(--color-text-inverse);box-shadow:var(--shadow-sm)}.btn-primary:hover{background-color:var(--color-accent-hover);box-shadow:var(--shadow-md)}.btn-primary:active{background-color:var(--color-accent-active)}.btn-secondary{background-color:var(--color-surface);color:var(--color-text-primary);border:1.5px solid var(--color-border);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background-color:var(--color-bg);border-color:var(--color-border-strong)}.btn-ghost{color:var(--color-accent-text);padding-left:var(--space-2);padding-right:var(--space-2);background-color:#0000}.btn-ghost:hover{background-color:var(--color-accent-subtle)}.btn-danger{background-color:var(--color-danger);color:#fff;box-shadow:var(--shadow-sm)}.btn-danger:hover{opacity:.88}.btn-sm{min-height:36px;padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);border-radius:var(--radius-md)}.btn-lg{min-height:56px;padding:var(--space-4) var(--space-8);font-size:var(--font-size-md);border-radius:var(--radius-xl)}.btn-block{width:100%}.input,.textarea,.select{width:100%;min-height:var(--touch-target);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);border:1.5px solid var(--color-border);background-color:var(--color-surface);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-regular);line-height:var(--line-height-snug);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);appearance:none;display:block}.input::placeholder,.textarea::placeholder{color:var(--color-text-tertiary)}.input:focus,.textarea:focus,.select:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #2563eb26}.textarea{resize:vertical;min-height:100px}.form-label{margin-bottom:var(--space-2);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);letter-spacing:.01em;display:block}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-hint{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.form-error{font-size:var(--font-size-sm);color:var(--color-danger)}.card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5);box-shadow:var(--shadow-sm)}.card-raised{background-color:var(--color-surface-raised);box-shadow:var(--shadow-md)}.card-header{justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.card-title{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:var(--line-height-tight)}.card-body{gap:var(--space-4);flex-direction:column;display:flex}.badge{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:.03em;text-transform:uppercase;line-height:1;display:inline-flex}.badge-accent{background-color:var(--color-accent-subtle);color:var(--color-accent-text)}.badge-success{background-color:var(--color-success-subtle);color:var(--color-success);border:1px solid var(--color-success-border)}.badge-warning{background-color:var(--color-warning-subtle);color:var(--color-warning);border:1px solid var(--color-warning-border)}.badge-danger{background-color:var(--color-danger-subtle);color:var(--color-danger);border:1px solid var(--color-danger-border)}.badge-info{background-color:var(--color-info-subtle);color:var(--color-info);border:1px solid var(--color-info-border)}.alert{gap:var(--space-1);padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);font-size:var(--font-size-sm);flex-direction:column;display:flex}.alert strong{font-size:var(--font-size-base)}.alert-success{background-color:var(--color-success-subtle);border:1px solid var(--color-success-border);color:var(--color-success)}.alert-warning{background-color:var(--color-warning-subtle);border:1px solid var(--color-warning-border);color:var(--color-warning)}.alert-danger{background-color:var(--color-danger-subtle);border:1px solid var(--color-danger-border);color:var(--color-danger)}.alert-info{background-color:var(--color-info-subtle);border:1px solid var(--color-info-border);color:var(--color-info)}.divider{background-color:var(--color-border);height:1px;margin:var(--space-4) 0;border:none}.skeleton{background-color:var(--color-border);border-radius:var(--radius-md);position:relative;overflow:hidden}.skeleton:after{content:"";background:linear-gradient(90deg, transparent 0%, var(--color-surface-raised) 50%, transparent 100%);animation:1.5s infinite skeleton-shimmer;position:absolute;inset:0;transform:translate(-100%)}@keyframes skeleton-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.container{width:100%;max-width:var(--content-max-width);padding-inline:var(--space-4);margin-inline:auto}@media (width>=768px){.container{max-width:720px;padding-inline:var(--space-6)}}@media (width>=1024px){.container{max-width:960px}}.stack{flex-direction:column;display:flex}.stack-2{gap:var(--space-2)}.stack-3{gap:var(--space-3)}.stack-4{gap:var(--space-4)}.stack-6{gap:var(--space-6)}.stack-8{gap:var(--space-8)}.row{flex-direction:row;align-items:center;display:flex}.row-2{gap:var(--space-2)}.row-3{gap:var(--space-3)}.row-4{gap:var(--space-4)}.row-between{justify-content:space-between}.row-center{justify-content:center}.row-end{justify-content:flex-end}.bottom-nav{height:calc(60px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background-color:var(--color-surface);border-top:1px solid var(--color-border);z-index:100;justify-content:space-around;align-items:flex-start;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #0000000f}.bottom-nav-item{justify-content:center;align-items:center;gap:var(--space-1);min-width:60px;height:60px;padding:var(--space-2);color:var(--color-text-tertiary);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);cursor:pointer;font-family:var(--font-family);transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;display:flex}.bottom-nav-item.active{color:var(--color-accent)}.fab{bottom:calc(72px + env(safe-area-inset-bottom));right:var(--space-5);border-radius:var(--radius-full);background-color:var(--color-accent);color:#fff;width:56px;height:56px;box-shadow:var(--shadow-lg);cursor:pointer;z-index:99;transition:background-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);-webkit-tap-highlight-color:transparent;border:none;justify-content:center;align-items:center;font-size:1.5rem;display:flex;position:fixed}.fab:hover{background-color:var(--color-accent-hover);box-shadow:var(--shadow-xl)}.fab:active{transform:scale(.93)}.page-with-nav{padding-bottom:calc(60px + env(safe-area-inset-bottom) + var(--space-4))}.page-header{padding:var(--space-5) var(--space-4) var(--space-4);background-color:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:50;position:sticky;top:0}.page-header-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:var(--line-height-tight)}.list-item{align-items:center;gap:var(--space-3);padding:var(--space-4);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:background-color var(--transition-fast), border-color var(--transition-fast);-webkit-tap-highlight-color:transparent;color:inherit;text-decoration:none;display:flex}.list-item:hover{background-color:var(--color-accent-subtle);border-color:var(--color-accent)}.list-item-icon{border-radius:var(--radius-md);background-color:var(--color-accent-subtle);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.25rem;display:flex}.list-item-content{flex:1;min-width:0}.list-item-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.list-item-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:2px}.list-item-end{text-align:right;flex-shrink:0}.list-item-amount{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-text-primary);font-variant-numeric:tabular-nums}.stat-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-4) var(--space-5);box-shadow:var(--shadow-sm)}.stat-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em}.stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);font-variant-numeric:tabular-nums;margin-top:var(--space-1);line-height:1.1}.stat-value-accent{color:var(--color-accent)}.stat-value-success{color:var(--color-success)}.stat-value-warning{color:var(--color-warning)}.stat-value-danger{color:var(--color-danger)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.text-accent{color:var(--color-accent-text)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-md{font-size:var(--font-size-md)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.text-center{text-align:center}.text-right{text-align:right}:focus-visible{outline:2.5px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-sm)}.splash-page{min-height:100dvh;padding:var(--space-6) var(--space-4);background-color:var(--color-bg);flex-direction:column;justify-content:center;align-items:center;display:flex}.splash-card{width:100%;max-width:var(--content-max-width);gap:var(--space-5);flex-direction:column;display:flex}.splash-brand{gap:var(--space-3);flex-direction:column;display:flex}.splash-header{align-items:center}.splash-title{font-size:clamp(var(--font-size-3xl), 10vw, 4rem);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--color-text-primary)}.splash-lead{font-size:var(--font-size-md);color:var(--color-text-secondary);line-height:var(--line-height-normal)}.splash-features{gap:var(--space-2);flex-direction:column;list-style:none;display:flex}.splash-feature-item{align-items:center;gap:var(--space-3);font-size:var(--font-size-base);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);display:flex}.splash-feature-dot{border-radius:var(--radius-full);background-color:var(--color-accent);flex-shrink:0;width:8px;height:8px}.theme-toggle{align-items:center;gap:var(--space-2);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-full);-webkit-tap-highlight-color:transparent;transition:background-color var(--transition-fast);background:0 0;border:none;display:inline-flex}.theme-toggle:hover{background-color:var(--color-accent-subtle)}.theme-toggle-track{border-radius:var(--radius-full);background-color:var(--color-border-strong);width:44px;height:26px;transition:background-color var(--transition-base);flex-shrink:0;position:relative}.theme-toggle-thumb{border-radius:var(--radius-full);width:20px;height:20px;box-shadow:var(--shadow-sm);transition:transform var(--transition-base);background-color:#fff;position:absolute;top:3px;left:3px}[data-theme=dark] .theme-toggle-track{background-color:var(--color-accent)}[data-theme=dark] .theme-toggle-thumb{transform:translate(18px)}@media (prefers-color-scheme:dark){:not([data-theme=light]) .theme-toggle-track{background-color:var(--color-accent)}:not([data-theme=light]) .theme-toggle-thumb{transform:translate(18px)}}.theme-toggle-icon{font-size:var(--font-size-md);line-height:1}
