@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--page-bg:#f7f9fc;--bg:#f7f9fc;--surface:#fff;--text:#1e293b;--text-muted:#64748b;--border:#e2e8f0;--blue:#3b82f6;--blue-dark:#2563eb;--purple:#8b5cf6;--purple-dark:#7c3aed;--gradient:linear-gradient(135deg, var(--blue) 0%, var(--purple) 100%);--shadow:0 4px 24px #3b82f614;--shadow-lg:0 12px 40px #7c3aed1f;--radius:14px;--radius-sm:10px;--transition:.25s cubic-bezier(.4, 0, .2, 1);--danger:#ef4444;--success:#10b981}[data-theme=dark]{--page-bg:radial-gradient(1200px 700px at 18% -5%, #2b2660 0%, #18142f 55%, #110e24 100%);--bg:#191636;--surface:#232048;--text:#ece9fb;--text-muted:#a39ecb;--border:#a096dc29;--blue:#5b9dff;--blue-dark:#8ab4ff;--purple:#b072ff;--purple-dark:#c79bff;--gradient:linear-gradient(135deg, #4f7cff 0%, #b072ff 100%);--shadow:0 8px 30px #00000059;--shadow-lg:0 16px 50px #00000080;--danger:#f87171;--success:#34d399}[data-theme=dark] .status-pill--good{color:#6ee7b7}[data-theme=dark] .status-pill--caution,[data-theme=dark] .insight--caution{color:#fcd34d}[data-theme=dark] .status-pill--warn,[data-theme=dark] .insight--warn{color:#fca5a5}[data-theme=dark] .insight--good,[data-theme=dark] .info-message{color:#6ee7b7}*,:before,:after{box-sizing:border-box}html,body,#root{min-height:100%}body{background:var(--page-bg);color:var(--text);-webkit-font-smoothing:antialiased;background-attachment:fixed;margin:0;font-family:Inter,system-ui,-apple-system,sans-serif;transition:background .3s,color .3s}button,input,select{font:inherit;color:inherit}[data-theme=dark] select option{background:var(--surface);color:var(--text)}.app-shell{min-height:100vh}.app-loading{min-height:100vh;color:var(--text-muted,#64748b);justify-content:center;align-items:center;font-size:1rem;display:flex}.landing__links{flex-wrap:wrap;justify-content:space-between;gap:12px;margin-top:16px;display:flex}.link-btn{color:var(--blue-dark);cursor:pointer;background:0 0;border:none;padding:4px 0;font-size:.9rem;font-weight:600}.link-btn:hover{text-decoration:underline}.info-message{color:#047857;border-radius:var(--radius-sm);background:#10b9811a;margin:0 0 16px;padding:10px 14px;font-size:.9rem}.recovery-key{letter-spacing:2px;text-align:center;border:2px dashed var(--purple);border-radius:var(--radius-sm);cursor:pointer;-webkit-user-select:all;user-select:all;background:#8b5cf60f;margin:8px 0;padding:18px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:1.35rem}.recovery-confirm{color:var(--text-muted);align-items:center;gap:8px;margin:18px 0;font-size:.9rem;display:flex}.budget-header__actions{align-items:center;gap:10px;display:flex}.tabs{border-bottom:1px solid var(--border);gap:4px;margin:0 0 24px;display:flex}.tab{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:12px 18px;font-weight:600}.tab--active{color:var(--blue-dark);border-bottom-color:var(--blue)}.tab-body{animation:fadeIn .3s var(--transition) both}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}.empty-hint{color:var(--text-muted);text-align:center;margin:12px 0}.section-title{margin:0 0 6px;font-size:1.2rem}.section-hint{color:var(--text-muted);margin:0 0 20px;font-size:.92rem}.add-row{gap:10px;margin-bottom:20px;display:flex}.add-row .input{flex:1}.user-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.user-row{align-items:center;gap:12px;display:flex}.user-row__name{flex:1}.user-row__meta{color:var(--text-muted);white-space:nowrap;font-size:.85rem}.btn--danger{color:var(--danger)}.budgets-tab,.dashboard-tab{flex-direction:column;gap:16px;display:flex}.period-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.period-row{align-items:stretch;gap:10px;display:flex}.period-row__open{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;text-align:left;flex-direction:column;flex:1;align-items:flex-start;gap:4px;padding:12px 16px;display:flex}.period-row__open:hover{border-color:var(--blue)}.period-row__meta{color:var(--text-muted);font-size:.85rem}.budget-row__head{justify-content:space-between;align-items:center;gap:12px;width:100%;display:flex}.budget-row__ccy{color:var(--text-muted);letter-spacing:.04em;font-size:.8rem;font-weight:700}.budget-row__type{color:var(--blue-dark);white-space:nowrap;background:#3b82f61a;border-radius:999px;margin-right:auto;padding:2px 10px;font-size:.75rem;font-weight:600}.budget-row__group{max-width:150px;font-size:.85rem}.type-picker{gap:10px;margin-bottom:14px;display:flex}.type-option{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;transition:var(--transition);flex-direction:column;flex:1;align-items:center;gap:4px;padding:12px;display:flex}.type-option:hover{border-color:var(--blue)}.type-option--active{border-color:var(--blue);background:#3b82f614}.type-option__icon{font-size:1.4rem}.type-option__label{font-size:.85rem;font-weight:600}.month-nav{align-items:center;gap:8px;display:inline-flex}.month-nav__arrow{border:1.5px solid var(--border);background:var(--surface);width:26px;height:26px;color:var(--text);cursor:pointer;transition:var(--transition);border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;line-height:1;display:inline-flex}.month-nav__arrow:hover{border-color:var(--blue);color:var(--blue-dark);background:#3b82f614}.create-row{flex-wrap:wrap;gap:12px;display:flex}.create-btn{border-radius:var(--radius-sm);cursor:pointer;min-width:180px;transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);flex:1;justify-content:center;align-items:center;gap:8px;padding:12px 18px;font-size:.95rem;font-weight:700;display:flex}.create-btn--monthly{background:var(--gradient);color:#fff;border:none;box-shadow:0 4px 14px #3b82f64d}.create-btn--monthly:hover{transform:translateY(-1px);box-shadow:0 6px 20px #7c3aed66}.create-btn--goal{color:#fff;background:linear-gradient(135deg,#8b5cf6 0%,#ec4899 100%);border:none;box-shadow:0 4px 14px #ec48994d}.create-btn--goal:hover{transform:translateY(-1px);box-shadow:0 6px 20px #ec489966}.create-btn__icon{font-size:1.15rem;line-height:1}.perf-actions{justify-content:space-between;align-items:center;gap:12px;margin-top:14px;display:flex}.perf-actions .perf-toggle{margin-top:0}.perf-empty{flex-direction:column;align-items:center;gap:14px;padding:8px 0 4px;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:50;background:#0f0c238c;justify-content:center;align-items:flex-start;padding:7vh 1.5rem 1.5rem;animation:.2s both fadeIn;display:flex;position:fixed;inset:0;overflow-y:auto}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:420px;box-shadow:var(--shadow-lg);flex-direction:column;gap:12px;padding:24px;display:flex}.modal-row{gap:10px;display:flex}.modal-row .input:first-child{flex:1}.modal-actions{justify-content:flex-end;gap:10px;margin-top:6px;display:flex}.dash-divider{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:8px 2px -4px;font-size:.9rem;font-weight:700}.dash-section{flex-direction:column;gap:16px;display:flex}.dash-section__head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:8px;display:flex}.dash-section__toggle{cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:4px 2px;display:inline-flex}.dash-section__toggle .dash-divider{margin:0}.dash-chevron{color:var(--text-muted);width:.9em;font-size:.8rem;display:inline-block}.dash-period{align-items:center;gap:8px;display:flex}.dash-period__select{width:auto;padding:.4rem .6rem;font-size:.85rem}.dash-section__body{flex-direction:column;gap:16px;display:flex}.welcome-guide{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px}.welcome-guide__title{background:var(--gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 10px;font-size:1.4rem}.welcome-guide__lead{color:var(--text-muted);max-width:68ch;margin:0 0 22px;line-height:1.6}.welcome-guide__grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=640px){.welcome-guide__grid{grid-template-columns:1fr}}.welcome-card{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);padding:18px}.welcome-card--monthly{border-top:3px solid var(--blue)}.welcome-card--goal{border-top:3px solid var(--purple)}.welcome-card__icon{margin-bottom:6px;font-size:1.5rem;display:block}.welcome-card__title{margin:0 0 6px;font-size:1.05rem}.welcome-card p{color:var(--text-muted);margin:0;font-size:.92rem;line-height:1.55}.welcome-guide__note{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);border-left:3px solid var(--purple-dark);gap:14px;margin-top:16px;padding:18px;display:flex}.welcome-guide__note .welcome-card__icon{margin-bottom:0}.welcome-guide__footer{color:var(--text-muted);margin:20px 0 0;font-size:.88rem;font-style:italic}.perf-card__head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.perf-card__title{flex-direction:column;gap:2px;display:flex}.perf-card__name{margin:0;font-size:1.1rem;font-weight:700}.perf-card__sub{color:var(--text-muted);font-size:.8rem;font-weight:600}.status-pill{text-transform:uppercase;letter-spacing:.03em;border-radius:999px;flex-shrink:0;padding:5px 12px;font-size:.72rem;font-weight:700}.status-pill--good{color:#047857;background:#10b9811f}.status-pill--caution{color:#b45309;background:#f59e0b29}.status-pill--warn{color:#b91c1c;background:#ef44441f}.status-pill--info{background:var(--bg);color:var(--text-muted)}.perf-overview{flex-wrap:wrap;align-items:center;gap:18px;display:flex}.ring{flex-shrink:0;width:100px;height:100px;position:relative}.ring svg{width:100%;height:100%}.ring__track{fill:none;stroke:var(--bg);stroke-width:9px}.ring__val{fill:none;stroke-width:9px;stroke-linecap:round;transition:stroke-dashoffset .6s}.ring__val--good{stroke:var(--success)}.ring__val--caution{stroke:#f59e0b}.ring__val--warn{stroke:var(--danger)}.ring__val--info{stroke:var(--border)}.ring__center{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.ring__pct{font-size:1.45rem;font-weight:800;line-height:1}.ring__cap{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-top:2px;font-size:.62rem}.perf-kpis{flex:1;grid-template-columns:repeat(auto-fit,minmax(96px,1fr));gap:10px;min-width:200px;display:grid}.kpi{background:var(--bg);border-radius:var(--radius-sm);flex-direction:column;gap:2px;padding:10px 12px;display:flex}.kpi__label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-size:.68rem;font-weight:700}.kpi__val{font-variant-numeric:tabular-nums;font-size:1.15rem;font-weight:700}.kpi__val.pos{color:var(--success)}.kpi__val.neg{color:var(--danger)}.kpi__sub{color:var(--text-muted);font-size:.72rem}.perf-toggle{color:var(--blue-dark);cursor:pointer;background:0 0;border:none;margin-top:14px;padding:4px 0;font-size:.85rem;font-weight:600}.perf-toggle:hover{text-decoration:underline}.insights{border-top:1px solid var(--border);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:14px;padding-top:16px;display:grid}.insight-panel{flex-direction:column;gap:8px;display:flex}.insight-panel__title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.72rem;font-weight:700}.insight{border-radius:var(--radius-sm);padding:9px 12px;font-size:.85rem}.insight strong{font-weight:800}.insight--warn{color:#b91c1c;background:#ef44441a}.insight--caution{color:#b45309;background:#f59e0b24}.insight--good{color:#047857;background:#10b9811f}.insight--info{background:var(--bg);color:var(--text-muted)}.perf-headline{margin-top:14px;line-height:1.45}.spend-row{flex-direction:column;gap:4px;display:flex}.spend-row__head{justify-content:space-between;font-size:.83rem;font-weight:600;display:flex}.spend-row__track{background:var(--bg);border-radius:999px;height:6px;overflow:hidden}.spend-row__fill{background:var(--gradient);border-radius:999px;height:100%;transition:width .4s}.stat-line{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:7px 0;font-size:.85rem;display:flex}.stat-line:last-child{border-bottom:none}.stat-line__val{font-weight:700}.card--group{border:1.5px solid var(--blue);background:#3b82f60a}.group-currency{margin-top:10px}.period-status{color:var(--text-muted);font-size:.8rem;font-weight:600}.period-status--locked{color:var(--danger)}.period-status--open{color:var(--success)}.period-header{flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:20px;display:flex}.view-toggle{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);margin-left:auto;padding:3px;display:inline-flex}.toggle{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:7px;padding:7px 16px;font-weight:600}.toggle--active{background:var(--surface);color:var(--blue-dark);box-shadow:var(--shadow)}.crumbs-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.crumbs{flex-wrap:wrap;align-items:center;gap:8px;font-size:.95rem;display:flex}.crumb{cursor:pointer;color:var(--blue-dark);background:0 0;border:none;padding:0;font-weight:600}.crumb:hover{text-decoration:underline}.crumb--current{color:var(--text);cursor:default}.crumb--current:hover{text-decoration:none}.crumb__sep{color:var(--text-muted)}.editor-actions{align-items:center;gap:10px;display:flex}.lock-badge{color:var(--text-muted);font-weight:600}.summary-blocks{grid-template-columns:repeat(5,1fr);gap:12px;display:grid}@media (width<=760px){.summary-blocks{grid-template-columns:1fr 1fr}}.summary-block{border-radius:var(--radius-sm);color:#fff;flex-direction:column;gap:6px;padding:16px;display:flex}.summary-block__label{text-transform:uppercase;letter-spacing:.04em;opacity:.9;font-size:.78rem;font-weight:600}.summary-block__value{font-size:1.35rem;font-weight:700}.summary-block--expense{background:linear-gradient(135deg,#f97316,#ea580c)}.summary-block--actual{background:linear-gradient(135deg,#ef4444,#dc2626)}.summary-block--income{background:linear-gradient(135deg,#10b981,#059669)}.summary-block--pos{background:linear-gradient(135deg,#3b82f6,#2563eb)}.summary-block--neg{background:linear-gradient(135deg,#ef4444,#b91c1c)}.panels{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (width<=760px){.panels{grid-template-columns:1fr}}.panel__title{margin:0}.budget-stack{flex-direction:column;gap:24px;display:flex}.budget-stack .panel+.panel,.budget-stack .report{border-top:1px solid var(--border);padding-top:20px}.panel__toggle{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:0 0 12px;display:flex}.report__head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.report__heading{margin:0}.report__cols{grid-template-columns:1fr 1fr;gap:28px;display:grid}@media (width<=640px){.report__cols{grid-template-columns:1fr}}.report__title{color:var(--text);margin:0 0 8px;font-size:.95rem}.report-row{color:var(--text);font-variant-numeric:tabular-nums;grid-template-columns:1fr auto auto;gap:16px;padding:3px 0;font-size:.9rem;display:grid}.report-row span:not(.report-row__name){text-align:right;min-width:90px}.report-row--head{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);margin-bottom:3px;padding-bottom:5px;font-size:.78rem}.report-row--total{border-top:1px solid var(--border);margin-top:4px;padding-top:6px;font-weight:700}.report-row__name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.cat-row{grid-template-columns:1fr 100px 100px 56px 72px 32px;align-items:center;gap:8px;margin-bottom:8px;display:grid}.cat-row__check{cursor:pointer;justify-self:center;width:18px;height:18px}.cat-row--head,.cat-row--total{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.8rem}.cat-row--total{color:var(--text);text-transform:none;border-top:1px solid var(--border);margin-top:4px;padding-top:8px;font-weight:700}.cat-row__actual{text-align:right;font-variant-numeric:tabular-nums}.transactions__bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.transactions__total{color:var(--text-muted);font-size:.9rem}.tx-table{flex-direction:column;gap:8px;display:flex}.tx-row{grid-template-columns:150px 1fr 110px 1fr 32px;align-items:center;gap:8px;display:grid}.tx-row--head{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.8rem}@media (width<=760px){.tx-row{grid-template-columns:1fr 1fr}.tx-row--head{display:none}}.fade-in{animation:fadeIn .5s var(--transition) both}.slide-up{animation:slideUp .35s var(--transition) both}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:transform var(--transition), box-shadow var(--transition), background var(--transition), color var(--transition);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-weight:600;display:inline-flex}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--primary{background:var(--gradient);color:#fff;box-shadow:0 4px 14px #3b82f659}.btn--primary:hover:not(:disabled){box-shadow:0 6px 20px #7c3aed66}.btn--secondary{background:var(--surface);color:var(--blue-dark);border:1.5px solid var(--border)}.btn--secondary:hover:not(:disabled){border-color:var(--blue);color:var(--purple-dark)}.btn--ghost{color:var(--text-muted);background:0 0;padding:.5rem .75rem}.btn--ghost:hover:not(:disabled){color:var(--blue-dark);background:#3b82f60f}.btn--sm{padding:.4rem .75rem;font-size:.875rem}.input{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);width:100%;color:var(--text);transition:border-color var(--transition), box-shadow var(--transition);padding:.75rem 1rem}.input:focus{border-color:var(--blue);outline:none;box-shadow:0 0 0 3px #3b82f626}.input--calc{background:var(--bg);color:var(--text-muted);cursor:default}.input--calc:focus{border-color:var(--border);box-shadow:none}.file-input{clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.error-message{border-radius:var(--radius-sm);color:var(--danger);background:#ef444414;margin:1rem 0 0;padding:.75rem 1rem;font-size:.9rem}.landing{justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex;position:relative;overflow:hidden}.landing__glow{filter:blur(80px);opacity:.35;pointer-events:none;border-radius:50%;animation:8s ease-in-out infinite pulse;position:absolute}.landing__glow--blue{background:var(--blue);width:400px;height:400px;top:-100px;left:-100px}.landing__glow--purple{background:var(--purple);width:350px;height:350px;animation-delay:-4s;bottom:-80px;right:-80px}@keyframes pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.45;transform:scale(1.1)}}.landing__card{background:var(--surface);border-radius:var(--radius);width:100%;max-width:480px;box-shadow:var(--shadow-lg);border:1px solid var(--border);padding:2.5rem;position:relative}.landing__brand{margin-bottom:1.5rem}.landing__logo{letter-spacing:.04em;text-transform:uppercase;background:var(--gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:.85rem;font-weight:700;display:inline-block}.landing__title{margin:0 0 .5rem;font-size:1.75rem;font-weight:700;line-height:1.2}.landing__subtitle{color:var(--text-muted);margin:0 0 2rem;font-size:.95rem;line-height:1.5}.landing__section{flex-direction:column;gap:.75rem;display:flex}.landing__label{color:var(--text);margin:0;font-size:.9rem;font-weight:500}.landing__divider{color:var(--text-muted);align-items:center;gap:1rem;margin:1.75rem 0;font-size:.85rem;display:flex}.landing__divider:before,.landing__divider:after{content:"";background:var(--border);flex:1;height:1px}.budget-app{max-width:1200px;margin:0 auto;padding:1.5rem}.budget-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.budget-header__left{align-items:flex-start;gap:1rem;display:flex}.budget-header__title{background:var(--gradient);color:#0000;-webkit-background-clip:text;background-clip:text;margin:0;font-size:1.5rem;font-weight:700}.theme-switch{cursor:pointer;background:0 0;border:none;padding:0}.theme-switch__track{background:var(--bg);border:1px solid var(--border);width:56px;height:30px;transition:background var(--transition);border-radius:999px;justify-content:space-between;align-items:center;padding:0 7px;display:flex;position:relative}.theme-switch.is-dark .theme-switch__track{background:var(--gradient);border-color:#0000}.theme-switch__icon{z-index:3;color:var(--text-muted);font-size:.8rem;line-height:1;position:relative}.theme-switch.is-dark .theme-switch__icon{color:#ffffffe6}.theme-switch__knob{width:24px;height:24px;transition:left var(--transition);z-index:2;background:#fff;border-radius:50%;position:absolute;top:50%;left:3px;transform:translateY(-50%);box-shadow:0 1px 4px #0000004d}.theme-switch.is-dark .theme-switch__knob{left:29px}.budget-header__meta{margin:.25rem 0 0;font-size:.85rem}.unsaved-badge{color:var(--purple-dark);font-weight:500}.saved-badge{color:var(--success);font-weight:500}.autosave{color:var(--text-muted);font-size:.85rem;font-weight:500}.autosave--saved{color:var(--success)}.autosave--error{color:var(--danger)}.download-wrapper{position:relative}.download-menu{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:160px;box-shadow:var(--shadow-lg);z-index:10;position:absolute;top:calc(100% + .5rem);right:0;overflow:hidden}.download-menu button{text-align:left;cursor:pointer;width:100%;transition:background var(--transition);background:0 0;border:none;padding:.75rem 1rem;display:block}.download-menu button:hover{color:var(--blue-dark);background:#3b82f614}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.summary-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);transition:transform var(--transition), box-shadow var(--transition);padding:1.25rem}.summary-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.summary-card__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.35rem;font-size:.8rem;font-weight:500;display:block}.summary-card__value{font-size:1.35rem;font-weight:700}.summary-card--income .summary-card__value{color:var(--success)}.summary-card--expense .summary-card__value{color:var(--danger)}.summary-card--balance .summary-card__value{background:var(--gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.summary-card--budgeted .summary-card__value{color:var(--blue-dark)}.budget-layout{grid-template-columns:1fr 1.2fr;gap:1.5rem;display:grid}@media (width<=900px){.budget-layout{grid-template-columns:1fr}}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem}.panel__header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.panel__header h2{margin:0;font-size:1.1rem;font-weight:600}.panel h2{margin:0 0 1rem;font-size:1.1rem;font-weight:600}.create-period{margin-bottom:1.5rem}.create-period__row{grid-template-columns:1fr 120px auto;gap:.75rem;display:grid}.copy-checkbox{color:var(--text-muted);cursor:pointer;align-items:center;gap:.5rem;margin-top:1rem;font-size:.9rem;display:flex}.copy-checkbox input{width:16px;height:16px;accent-color:var(--blue)}.currency-panel{margin-bottom:1.5rem}.currency-picker{max-width:420px;position:relative}.currency-picker__label{margin-bottom:.5rem;font-size:.9rem;font-weight:500;display:block}.currency-picker__list{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:20;max-height:240px;margin:0;padding:.35rem;list-style:none;position:absolute;top:calc(100% + .35rem);left:0;right:0;overflow-y:auto}.currency-picker__list button{cursor:pointer;text-align:left;width:100%;transition:background var(--transition);background:0 0;border:none;border-radius:6px;justify-content:space-between;align-items:center;gap:1rem;padding:.6rem .75rem;display:flex}.currency-picker__list button:hover,.currency-picker__list button.active{background:#3b82f614}.currency-picker__code{color:var(--text-muted);font-size:.8rem;font-weight:600}@media (width<=600px){.create-period__row{grid-template-columns:1fr}}.period-list{flex-direction:column;gap:.5rem;display:flex}.period-card{border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--transition), box-shadow var(--transition);align-items:center;gap:.5rem;display:flex}.period-card:hover{box-shadow:var(--shadow);border-color:#3b82f659}.period-card__open{cursor:pointer;text-align:left;background:0 0;border:none;flex-direction:column;flex:1;align-items:flex-start;gap:.25rem;padding:1rem;display:flex}.period-card__title{color:var(--text);font-size:1rem;font-weight:600}.period-card__meta{color:var(--text-muted);font-size:.85rem}.entry-table--expenses{--entry-cols:minmax(140px, 1.4fr) 112px 112px 32px}.entry-table--income{--entry-cols:minmax(140px, 1.4fr) 112px 32px}.entry-table{flex-direction:column;gap:.25rem;display:flex}.entry-table__head,.entry-row--expenses,.entry-row--income{grid-template-columns:var(--entry-cols);align-items:center;gap:.75rem;display:grid}.entry-table__head{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:0 .5rem .5rem;font-size:.75rem;font-weight:600}.entry-table__head span:nth-child(2),.entry-table__head span:nth-child(3){text-align:right}.entry-block{border-radius:var(--radius-sm);transition:background var(--transition);padding:.35rem .5rem .5rem}.entry-block:hover{background:#3b82f60a}.entry-row__name{color:var(--text);background:0 0;border:none;min-width:0;padding:.5rem .25rem;font-weight:500}.entry-row__name:focus{border-bottom:2px solid var(--blue);outline:none}.entry-row__amount{border:1px solid var(--border);text-align:right;border-radius:6px;width:100%;padding:.5rem .6rem}.entry-row__diff{color:var(--text-muted);margin:.15rem 0 0;padding-left:.25rem;font-size:.8rem}.text-danger{color:var(--danger);font-weight:500}.empty-state{text-align:center;color:var(--text-muted);padding:2rem 1rem;font-size:.9rem}.icon-btn{width:28px;height:28px;color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.25rem;display:flex}.icon-btn:hover{color:var(--danger);background:#ef44441a}.btn--danger-solid{background:var(--danger);color:#fff;box-shadow:0 4px 14px #ef44444d}.admin-panel{flex-direction:column;gap:16px;display:flex}.admin-toolbar{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.admin-toolbar .input{flex:1;min-width:180px}.admin-toolbar__num{flex:0 0 150px;min-width:130px}.admin-toolbar .btn{flex:none}.admin-table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:.9rem}.admin-table th,.admin-table td{text-align:left;white-space:nowrap;padding:12px 14px}.admin-table thead th{border-bottom:1px solid var(--border);color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:.8rem;font-weight:600}.admin-table tbody tr{border-bottom:1px solid var(--border)}.admin-table tbody tr:last-child{border-bottom:none}.admin-table tbody tr.is-selected{background:#3b82f612}.admin-table tbody tr:hover{background:#7c3aed0d}.admin-table__name{color:var(--text);font-weight:600}.admin-table__muted{color:var(--text-muted)}.admin-table__check{text-align:center;width:36px}.admin-table__actions{text-align:right}.admin-table input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--blue)}.admin-sort{font:inherit;color:inherit;text-transform:inherit;letter-spacing:inherit;cursor:pointer;background:0 0;border:none;padding:0}.admin-sort:hover{color:var(--blue-dark)}
