:root{--bg:#f5f6f8;--surface:#fff;--text:#141518;--muted:#8a8f98;--brand-start:#0f172a;--brand-end:#3b82f6;--brand-gradient:linear-gradient(135deg,var(--brand-start),var(--brand-end));--primary:var(--brand-start);--primary-text:#fff;--secondary:#e6e8ec;--accent:var(--brand-start);--danger:#e11d48;--dash-ink:#141518;--dash-muted:#8a8f98;--dash-border:#e5e7eb;--dash-surface:#fff;--dash-soft:#f8f9fb;--dash-income:#22c55e;--dash-expense:#f97316;--dash-neutral:var(--brand-start);--safe-top:env(safe-area-inset-top);--safe-bottom:env(safe-area-inset-bottom)}:root[data-theme=light]{--bg:#f5f6f8;--surface:#fff;--text:#141518;--muted:#8a8f98;--primary:var(--brand-start);--primary-text:#fff;--secondary:#e6e8ec;--accent:var(--brand-start);--danger:#e11d48}:root[data-theme=dark]{--bg:#0e1116;--surface:#171b22;--text:#f1f5f9;--muted:#9ca3af;--primary:var(--brand-start);--primary-text:#111827;--secondary:#27303b;--accent:var(--brand-start);--danger:#fb7185}@media (prefers-color-scheme:dark){:root{--bg:#0e1116;--surface:#171b22;--text:#f1f5f9;--muted:#9ca3af;--primary:var(--brand-start);--primary-text:#111827;--secondary:#27303b;--accent:var(--brand-start);--danger:#fb7185}}*{box-sizing:border-box}body{margin:0;font-family:var(--font-manrope),system-ui,sans-serif;background:var(--bg);color:var(--text);padding-top:var(--safe-top);padding-bottom:var(--safe-bottom)}a{color:inherit;text-decoration:none}main{min-height:100vh}.container{max-width:1200px;margin:0 auto;padding:32px 20px 56px}.card{background:var(--surface);border-radius:20px;padding:20px;box-shadow:0 20px 40px rgba(15,20,22,.08)}.grid{display:grid;grid-gap:24px;gap:24px}.badge{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:var(--secondary);color:var(--text);font-size:12px;text-transform:uppercase;letter-spacing:.12em}.primary-button{background:transparent;color:var(--primary);border:1px solid var(--primary);padding:12px 18px;border-radius:12px;font-weight:600;cursor:pointer}.primary-button:disabled{opacity:.5;cursor:not-allowed}.input{width:100%;padding:12px 14px;border-radius:12px;border:1px solid rgba(0,0,0,.08);background:var(--surface);color:var(--text)}.input-label{font-size:12px;color:#8a8f98;text-transform:uppercase;letter-spacing:.08em;font-weight:600}.add-amount{font-size:18px;font-weight:600;max-width:360px}.add-presets{margin:0}.add-layout{display:grid;grid-gap:20px;gap:20px}.add-toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.add-footer{display:flex;justify-content:flex-start;margin-top:4px}.add-counter{margin-left:auto;color:#8a8f98;font-size:12px;font-weight:600}.operations-list{display:grid;grid-gap:12px;gap:12px}.op-row{border:1px solid #eef1f4;border-radius:16px;background:#fff;text-align:left;cursor:pointer;animation:fadeInUp .2s ease;grid-template-columns:52px minmax(0,1fr) auto 32px}.op-row .tx-amount{white-space:nowrap;text-align:right}.op-form{border:1px solid #eef1f4;border-radius:20px;background:#f8f9fb;padding:16px;display:grid;grid-gap:16px;gap:16px;animation:fadeInUp .2s ease}.op-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.op-title{font-size:16px;font-weight:700}.op-subtitle{color:var(--muted);font-size:12px}.voice-debug{background:#f8fafc;display:grid;grid-gap:10px;gap:10px}.voice-debug,.voice-preview{border:1px solid #eef1f4;border-radius:16px;padding:12px 14px}.voice-preview{background:#fff}.voice-preview audio{width:100%;margin-top:6px}.voice-meta{margin-top:6px;color:#8a8f98;font-size:12px}.voice-step span{font-size:12px;color:#8a8f98;text-transform:uppercase;letter-spacing:.08em;font-weight:600}.voice-step p{margin:6px 0 0;color:#1c1e22}.voice-step pre{margin:6px 0 0;background:#fff;border-radius:12px;padding:10px;font-size:12px;color:#111827;overflow-x:auto}.voice-panel{border:1px solid #eef1f4;background:#f8fafc;border-radius:16px;padding:12px 14px}.voice-panel summary{font-size:12px;color:#8a8f98;text-transform:uppercase;letter-spacing:.08em;font-weight:600;cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between}.voice-panel summary::-webkit-details-marker{display:none}.voice-panel summary:after{content:"▾";font-size:12px;color:#64748b;transition:transform .2s ease}.voice-panel[open] summary:after{transform:rotate(180deg)}.voice-panel p{margin:8px 0 0;color:#1c1e22}.op-actions{gap:8px}.op-action,.op-actions{display:inline-flex;align-items:center}.op-action{width:32px;height:32px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;color:#6b7280;justify-content:center;cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease}.op-action:hover:not(:disabled){background:var(--primary);color:#fff;border-color:var(--primary)}.op-action.danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626}.op-action:disabled{opacity:.4;cursor:not-allowed}.op-expand{background:transparent;border:none;padding:0;text-align:left;cursor:pointer}.op-main{width:100%}.op-expand-icon{width:32px;height:32px;border-radius:999px;border:1px solid #eef1f4;background:#f8fafc;color:#6b7280;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease,color .2s ease}.op-expand-icon:hover{background:var(--primary);color:#fff}@keyframes fadeInUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.add-content{display:grid;grid-gap:24px;gap:24px}@media (min-width:1024px){.add-content{grid-template-columns:minmax(0,1fr) 320px;align-items:start}}.add-card{background:var(--surface);border-radius:24px;padding:24px;box-shadow:0 12px 30px rgba(17,24,39,.08);display:grid;grid-gap:20px;gap:20px}.add-field{display:grid;grid-gap:8px;gap:8px}.add-date-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.add-date-row .chip,.add-date-row .period-pill{height:40px;padding:0 18px;display:inline-flex;align-items:center}.add-section{display:grid;grid-gap:12px;gap:12px}.add-section-title{font-weight:700;font-size:14px;color:#1c1e22}.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:12px;gap:12px}.category-tile{border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:12px 16px;display:grid;grid-template-columns:46px 1fr;grid-gap:12px;gap:12px;align-items:center;background:#f8fafc;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.category-tile:hover{border-color:rgba(17,24,39,.2);box-shadow:0 10px 20px rgba(17,24,39,.08);transform:translateY(-1px)}.category-tile.is-active{border-color:var(--primary);background:#fff;box-shadow:0 12px 24px rgba(17,24,39,.12)}.category-title{color:#1c1e22}.comment-input{min-height:96px;resize:vertical}.nav{display:flex;gap:16px;align-items:center;padding:16px 24px;border-bottom:1px solid rgba(0,0,0,.06);background:var(--surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);position:-webkit-sticky;position:sticky;top:0;z-index:10}.snow-nav{padding:14px 20px;gap:20px;border-radius:16px;margin:12px 20px 0;box-shadow:0 12px 30px rgba(15,23,42,.08)}.nav-left,.nav-right{display:inline-flex;align-items:center;gap:14px}.nav-left{flex:1 1;min-width:0}.nav-links{display:inline-flex;align-items:center;gap:8px;padding:6px;background:#f1f3f5;border-radius:999px}.nav-link{padding:8px 14px;border-radius:999px;font-weight:600;color:#5b616a}.nav-link:hover{background:#e7eaee}.nav-link.is-active{background:var(--brand-gradient);color:#fff;box-shadow:0 8px 18px rgba(17,24,39,.2)}.brand-pill{display:inline-flex;align-items:center;gap:10px;padding:6px;border-radius:999px;background:transparent;color:#111827}.brand-name{font-weight:700;letter-spacing:.02em;color:#111827}.brand-avatar{width:30px;height:30px;border-radius:999px;background:transparent;display:inline-flex;align-items:center;justify-content:center;font-weight:700;position:relative;overflow:hidden}.logo-mark{width:24px;height:24px;position:relative;z-index:2;display:block}.logo-ring,.logo-spark{display:none}.snow-add{background:#1f2937;color:#fff;padding:10px 18px;border-radius:12px}.budget-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;background:#f8f9fb;border-radius:14px}.budget-select{width:180px;border:none;background:transparent;padding:6px 10px}.user-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:#f8f9fb}.profile-menu{position:relative}.profile-menu .user-pill{cursor:pointer;border:none}.profile-dropdown{position:absolute;right:0;top:44px;background:#fff;border-radius:14px;border:1px solid #e5e7eb;padding:10px;min-width:160px;box-shadow:0 12px 30px rgba(15,23,42,.12);display:grid;grid-gap:8px;gap:8px;z-index:20}.profile-dropdown a{color:#111827;font-weight:600;text-decoration:none;padding:8px 10px;border-radius:10px}.profile-dropdown a:hover{background:#f3f4f6}.user-avatar{width:30px;height:30px;border-radius:999px;background:#1f2937;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700}.user-email{color:#4b5563;font-weight:600}.burger-button{display:none;border:none;background:var(--brand-gradient);width:44px;height:44px;border-radius:12px;align-items:center;justify-content:center;flex-direction:column;gap:4px;padding:10px;margin-left:auto}.burger-button span{display:block;height:2px;width:18px;background:#fff;border-radius:999px}.mobile-menu{position:fixed;inset:0;z-index:40;display:flex;justify-content:flex-end}.mobile-menu-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.4);border:none}.mobile-menu-panel{position:relative;width:min(88vw,360px);height:100%;background:#fff;padding:20px;display:flex;flex-direction:column;gap:20px;box-shadow:-20px 0 40px rgba(15,23,42,.2);animation:slideIn .18s ease-out}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between}.mobile-menu-close{width:36px;height:36px;border-radius:10px;border:none;background:#f3f4f6;font-weight:700}.mobile-menu-links{display:grid;grid-gap:8px;gap:8px}.mobile-menu-links .nav-link{display:block;text-align:left;padding:12px 16px;background:#f3f4f6}.mobile-menu-links .nav-link.is-active{background:var(--brand-gradient)}.mobile-menu-section{display:grid;grid-gap:8px;gap:8px}.menu-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8}.nav a{color:var(--muted);font-weight:600}.add-button,.nav .snow-add,.nav a.active{color:var(--primary)}.add-button{background:transparent;border:1px solid var(--primary);padding:10px 16px;border-radius:999px;font-weight:600}.add-button:hover{background:rgba(59,130,246,.12)}.sidebar{display:none}@media (min-width:960px){.layout{display:grid;grid-template-columns:240px 1fr;grid-gap:32px;gap:32px}.sidebar{display:flex;flex-direction:column;gap:12px;padding:32px 0}}@media (max-width:960px){.snow-nav{margin:0;border-radius:0;padding:14px 16px}.nav{justify-content:space-between}.nav-left{flex:1 1}.nav-links,.nav-right{display:none}.brand-pill{padding:6px 10px}.burger-button{display:inline-flex}.container{padding:20px 16px 60px}}.transactions-layout{display:grid;grid-gap:32px;gap:32px}.toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:16px}.budget-list{gap:16px}.budget-card{padding:16px 18px}.budget-card.is-dragging{opacity:.5;border-style:dashed}.budget-row{display:grid;grid-template-columns:auto 1fr 220px auto;grid-gap:16px;gap:16px;align-items:center}.budget-order{display:grid;grid-gap:6px;gap:6px}.budget-main{display:grid;grid-gap:8px;gap:8px}.budget-title{font-weight:700;font-size:18px;gap:8px}.budget-link,.budget-title{display:inline-flex;align-items:center}.budget-link{justify-content:center;width:28px;height:28px;border-radius:8px;background:#eef2f7;color:#475569}.budget-link:hover{background:var(--primary);color:#fff}.modal{position:fixed;inset:0;z-index:90;display:flex;align-items:center;justify-content:center}.modal-backdrop{position:absolute;inset:0;border:none;background:rgba(15,23,42,.5)}.modal-card{position:relative;width:min(92vw,420px);background:#fff;border-radius:20px;padding:20px 22px;box-shadow:0 20px 50px rgba(15,23,42,.25);display:grid;grid-gap:12px;gap:12px}.modal-actions{display:flex;justify-content:flex-end;gap:10px}.section-tabs{display:flex;gap:12px;flex-wrap:wrap}.categories-grid{display:grid;grid-gap:16px;gap:16px}.category-card{padding:16px}.category-card.is-dragover{outline:2px dashed rgba(15,23,42,.35);outline-offset:2px;background:rgba(15,23,42,.03)}.category-card.is-dragging{opacity:.65}.category-row{display:flex;gap:16px;align-items:center}.category-icon{width:44px;height:44px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;font-size:20px}.category-main{flex:1 1;display:grid;grid-gap:6px;gap:6px}.category-title{font-weight:600}.category-meta{font-size:13px;color:var(--muted)}.category-actions{display:inline-flex;gap:8px;align-items:center}.category-actions .drag-handle{cursor:-webkit-grab;cursor:grab}.category-actions .drag-handle:active{cursor:-webkit-grabbing;cursor:grabbing}.category-edit{margin-top:16px;display:grid;grid-gap:16px;gap:16px}.category-picker{display:grid;grid-gap:8px;gap:8px}.picker-label{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(44px,1fr));grid-gap:8px;gap:8px}.icon-option{width:44px;height:44px;border-radius:12px;border:1px solid rgba(0,0,0,.08);background:#fff;display:inline-flex;align-items:center;justify-content:center}.icon-option.is-active{border-color:var(--primary);box-shadow:0 0 0 2px rgba(17,24,39,.1)}.color-grid{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.color-option{width:28px;height:28px;border-radius:999px;border:2px solid transparent}.color-option.is-active{border-color:var(--primary)}.color-input{width:36px;height:36px;border-radius:10px;border:1px solid rgba(0,0,0,.12);padding:0;background:transparent}.category-create{margin-top:16px}.category-create-form,.category-create-row{display:grid;grid-gap:16px;gap:16px}.category-delete-select{margin:16px 0}.budget-description,.budget-meta{color:#6b7280}.budget-meta{display:grid;grid-gap:6px;gap:6px;font-size:13px}.budget-actions{display:inline-flex;gap:8px;align-items:center;justify-content:flex-end}.members-grid{gap:16px}.member-card{display:grid;grid-gap:12px;gap:12px}.member-header{display:flex;align-items:center;gap:12px;justify-content:space-between}.member-header .member-info{flex:1 1}.member-avatar{width:44px;height:44px;border-radius:16px;background:#f1f5f9;color:#111827;display:inline-flex;align-items:center;justify-content:center}.member-avatar,.member-name{font-weight:700}.member-email{color:#6b7280;font-size:13px}.member-role{color:#94a3b8;font-size:12px;margin-top:2px}.member-permissions{display:grid;grid-gap:8px;gap:8px}.member-cap{display:flex;align-items:center;gap:10px;font-weight:600;color:#1f2937}.member-cap-admin{border-bottom:1px solid #e5e7eb;padding-bottom:6px;margin-bottom:6px}.perm-label{gap:6px}.perm-help,.perm-label{display:inline-flex;align-items:center}.perm-help{position:relative;color:#94a3b8;cursor:help}.perm-help:after{content:attr(data-tooltip);position:absolute;left:50%;bottom:calc(100% + 10px);transform:translateX(-50%);background:#0f172a;color:#fff;padding:10px 12px;border-radius:12px;width:240px;font-size:12px;line-height:1.4;opacity:0;pointer-events:none;transition:opacity .15s ease;box-shadow:0 10px 30px rgba(15,23,42,.18);z-index:10}.perm-help:hover:after{opacity:1}.member-cap input{width:16px;height:16px}.member-tag{display:inline-flex;align-items:center;font-size:11px;font-weight:700;color:#0f172a;background:#e2e8f0;border-radius:999px;padding:4px 8px;margin-top:6px;width:-moz-fit-content;width:fit-content}.member-tag-pending{background:rgba(59,130,246,.15);color:var(--primary)}.invite-card .member-avatar{background:#f8fafc;color:#1f2937;font-size:18px}.member-cap-readonly{color:#64748b}.invite-permissions{background:#f8fafc;border-radius:16px;padding:12px;border:1px solid #e5e7eb}.budget-readonly{color:#9aa1a9;font-weight:600;font-size:12px}.icon-button{width:34px;height:34px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;color:#6b7280;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease}.icon-button:hover:not(:disabled){background:var(--primary);color:#fff;border-color:var(--primary)}.icon-button.danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626}@media (min-width:960px){.transactions-layout{grid-template-columns:minmax(0,1fr) 320px;align-items:start}}@media (max-width:960px){.budget-row{grid-template-columns:auto 1fr;grid-template-areas:"order main" "meta meta" "actions actions"}.budget-order{grid-area:order}.budget-main{grid-area:main}.budget-meta{grid-area:meta}.budget-actions{grid-area:actions;justify-content:flex-start}}.section-header h1,.section-header h2{margin:0 0 6px;font-size:36px;font-weight:700}.budget-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.chips{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0 24px;position:relative}.chips.add-presets{margin:0;align-items:center}.chip{background:#f5f6f8;border:1px solid #e5e7eb;padding:8px 16px;border-radius:999px;font-weight:600;color:#202124;cursor:pointer}.filters-panel{display:grid;grid-gap:10px;gap:10px;margin:12px 0 24px}.filters-title{font-weight:700;color:#111827}.filters-row{position:relative;width:-moz-fit-content;width:fit-content}.filters-row-inline{display:flex;flex-wrap:wrap;gap:8px}.filter-pill{display:inline-flex;align-items:center;gap:10px;background:#f5f6f8;color:#111827;border-radius:999px;padding:10px 16px;border:1px solid #e5e7eb;cursor:pointer;font-weight:600}.filter-pill-value{color:#6b7280}.filter-caret{display:inline-flex;align-items:center;transition:transform .2s ease}.filter-caret.is-open{transform:rotate(180deg)}.filter-dropdown{position:absolute;top:calc(100% + 10px);left:0;width:max-content;min-width:260px;background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:12px;display:grid;grid-gap:10px;gap:10px;max-height:300px;overflow-y:auto;box-shadow:0 18px 40px rgba(15,23,42,.12);z-index:20}.filter-option{display:grid;grid-template-columns:24px 26px 1fr;align-items:center;grid-gap:10px;gap:10px;font-size:13px;color:#1f2937;font-weight:600;cursor:pointer}.filter-option input{position:absolute;opacity:0;pointer-events:none}.filter-check{width:22px;height:22px;border-radius:8px;border:1.5px solid #d7dbe4;background:#fff;display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:inset 0 0 0 1px rgba(15,23,42,.02)}.filter-option input:checked+.filter-check{background:#111827;border-color:#111827}.filter-option input:checked+.filter-check:after{content:"✓";font-size:12px;color:#fff;line-height:1}.filter-option-avatar{width:22px;height:22px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#e2e8f0;font-size:12px}.filter-option-label{white-space:nowrap}.chip-loading{position:relative;padding-right:36px}.chip-loading:after{content:"";position:absolute;right:12px;top:50%;width:12px;height:12px;margin-top:-6px;border-radius:999px;border:2px solid rgba(0,0,0,.2);border-top-color:#111827;animation:spin .8s linear infinite}.chip-active{background:#111827;color:#fff}.chip:disabled{opacity:.5;cursor:not-allowed}.select-chip{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none}.period-picker{display:grid;grid-gap:12px;gap:12px;padding:16px;background:var(--surface);border-radius:16px;border:1px solid rgba(0,0,0,.06);margin-bottom:16px}.period-actions{gap:8px;justify-content:flex-end}.period-actions,.period-header{display:flex;align-items:center}.period-header{justify-content:space-between;gap:16px;padding:6px 8px}.period-nav-button{border:none;background:transparent;font-size:18px;cursor:pointer;padding:6px 10px;border-radius:12px;color:var(--text)}.period-nav-button:hover{background:var(--secondary)}.period-pill{padding:8px 16px;font-weight:600;gap:8px}.period-clear,.period-pill{background:#f5f6f8;color:#111827;border-radius:999px;border:1px solid #e5e7eb;display:inline-flex;align-items:center;cursor:pointer}.period-clear{width:32px;height:32px;font-size:18px;justify-content:center}.period-caret{font-size:12px;opacity:.7}.calendar-panel{box-shadow:0 18px 40px rgba(17,24,39,.12);width:420px;max-width:90vw;padding:16px 18px 18px;border-radius:20px}.calendar-popover{position:absolute;top:48px;left:0;z-index:20}.period-anchor{position:relative;display:inline-flex;align-items:center;gap:8px}.period-month{font-weight:600;text-transform:capitalize;font-size:18px}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-gap:0;gap:0;margin-top:8px}.calendar-weekday{font-size:13px;color:var(--muted);text-align:center;padding:6px 0 10px}.calendar-day{border:none;background:transparent;padding:6px 0;height:42px;cursor:pointer;position:relative;color:var(--text)}.calendar-day,.calendar-day-label{display:inline-flex;align-items:center;justify-content:center}.calendar-day-label{width:34px;height:34px;border-radius:999px;font-weight:600;font-size:15px}.calendar-day.is-muted{color:var(--muted)}.calendar-day.is-range{background:#dbeafe}.calendar-day.is-range.is-start{border-top-left-radius:999px;border-bottom-left-radius:999px}.calendar-day.is-range.is-end{border-top-right-radius:999px;border-bottom-right-radius:999px}.calendar-day.is-start.is-end{background:transparent}.calendar-day.is-range:not(.is-start):not(.is-end){border-radius:0}.calendar-day.is-selected .calendar-day-label,.calendar-day.is-selected.is-muted .calendar-day-label{background:var(--primary);color:#fff}.calendar-day.is-today .calendar-day-label{border:1px solid var(--primary)}.calendar-day.is-range .calendar-day-label{color:#111827}.calendar-day.is-selected.is-range{background:#dbeafe}.calendar-day.is-end .calendar-day-label,.calendar-day.is-start .calendar-day-label{box-shadow:0 8px 20px rgba(17,24,39,.2);color:#fff;background:var(--primary)}.period-pill{padding:10px 18px;gap:10px;font-size:14px}.period-clear{width:34px;height:34px}.period-actions .chip{padding:8px 14px}.transactions-list{display:grid;grid-gap:12px;gap:12px;position:relative}.transactions-list.is-loading{opacity:.6}.tx-group{animation:fadeSlideIn .3s ease both}.tx-animate{animation:fadeSlideIn .35s ease both}.list-loading{position:absolute;top:8px;right:0;display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background:var(--surface);border-radius:999px;border:1px solid rgba(0,0,0,.06);color:var(--muted);font-size:12px;box-shadow:0 10px 20px rgba(17,24,39,.08)}.list-loading.list-loading-center{left:50%;transform:translateX(-50%);right:auto}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.spinner{width:14px;height:14px;border-radius:999px;border:2px solid rgba(0,0,0,.12);border-top:2px solid var(--text);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.date-label{font-weight:700;color:#8a8f98;margin:16px 0 8px}.tx-row{display:grid;grid-template-columns:52px 1fr auto;grid-gap:16px;gap:16px;padding:12px 8px;border-bottom:1px solid #eceff2;cursor:pointer}.tx-icon,.tx-row{align-items:center;border-radius:16px}.tx-icon{width:46px;height:46px;display:flex;justify-content:center;font-weight:700}.tx-icon svg{width:22px;height:22px}.tx-main{display:grid;grid-gap:4px;gap:4px}.tx-subrow{display:flex;align-items:center}.tx-title{font-weight:600;color:#1c1e22}.tx-subtitle{color:#8a8f98;font-size:14px;display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap}.tx-author{gap:6px;padding:2px 8px 2px 2px;background:#f1f5f9;color:#0f172a;font-weight:600}.tx-author,.tx-author-avatar{display:inline-flex;align-items:center;border-radius:999px;font-size:12px}.tx-author-avatar{width:22px;height:22px;justify-content:center;background:#e2e8f0}.tx-author-name{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tx-amount{font-weight:700;font-size:16px;color:#1c1e22}.tx-amount-positive{color:#1f7a46}.tx-actions{display:flex;align-items:center;gap:12px}.tx-delete{width:34px;height:34px;border-radius:999px;border:none;background:#f1f5f9;color:#64748b;display:inline-flex;align-items:center;justify-content:center;opacity:0;transform:scale(.95);transition:opacity .2s ease,transform .2s ease}.tx-delete svg{width:16px;height:16px}.tx-row:hover{background:#f8fafc}.tx-row:hover .tx-delete{opacity:1;transform:scale(1)}.tx-delete:hover{background:#fee2e2;color:#b91c1c}.tx-drawer-overlay{position:fixed;inset:0;background:rgba(15,23,42,.3);display:flex;z-index:60}.tx-drawer-backdrop{position:absolute;inset:0;border:none;background:transparent}.tx-drawer{position:relative;margin-left:auto;width:min(520px,92vw);height:100%;background:#fff;box-shadow:-30px 0 60px rgba(15,23,42,.2);display:flex;flex-direction:column;animation:slideIn .2s ease}@keyframes slideIn{0%{transform:translateX(40px);opacity:0}to{transform:translateX(0);opacity:1}}.tx-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #eef2f6;font-weight:700}.tx-drawer-header-actions{display:inline-flex;align-items:center;gap:8px}.tx-drawer-icon{width:36px;height:36px;border-radius:999px;border:none;background:#f1f5f9;color:#0f172a;display:inline-flex;align-items:center;justify-content:center;font-size:16px}.tx-drawer-icon svg{width:16px;height:16px}.tx-drawer-icon:disabled{opacity:.6}.tx-drawer-icon.is-active{background:#0f172a;color:#fff}.tx-drawer-icon-danger{color:#b91c1c}.tx-drawer-icon-danger:hover{background:#fee2e2}.tx-drawer-close{width:36px;height:36px;border-radius:999px;border:none;background:#f1f5f9;color:#0f172a;display:inline-flex;align-items:center;justify-content:center}.tx-drawer-body{padding:24px;position:relative;overflow:visible}.tx-drawer-scroll{max-height:calc(100vh - 160px);overflow-y:auto;padding-right:6px}.tx-drawer-hero{display:grid;grid-template-columns:72px 1fr;grid-gap:16px;gap:16px;align-items:center;margin-bottom:20px}.tx-icon-large{width:64px;height:64px;border-radius:24px}.tx-drawer-amount{font-size:30px;font-weight:700}.tx-drawer-title{font-weight:600;margin-top:6px}.tx-drawer-date{color:#8a8f98;margin-top:6px}.tx-drawer-grid{display:grid;grid-gap:12px;gap:12px}.tx-detail-card{background:#f8fafc;border-radius:16px;padding:14px 16px;display:flex;flex-direction:column;gap:6px;font-size:14px;color:#64748b}.tx-detail-card strong{color:#0f172a;font-size:16px}.tx-detail-full{grid-column:1/-1}.tx-drawer-actions{margin-top:18px}.tx-drawer-actions-row{display:flex;align-items:center;justify-content:flex-end;gap:12px}.tx-inline-input,.tx-inline-select{min-width:180px;height:40px}.tx-inline-input{max-width:220px}.tx-inline-select{max-width:240px}.tx-select,.tx-select-with-icon{display:inline-flex;align-items:center;gap:10px;padding:6px 12px;border-radius:16px;background:#fff;border:1px solid #e5e7eb;width:100%}.tx-select .tx-inline-select,.tx-select-with-icon .tx-inline-select{border:none;background:transparent;height:auto;flex:1 1;min-width:0;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%230f172a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 4px center;padding:0 22px 0 0}.tx-select-icon{width:32px;height:32px;border-radius:12px;justify-content:center}.tx-date-field,.tx-select-icon{display:inline-flex;align-items:center}.tx-date-field{position:relative}.period-popover-inline{position:absolute;top:calc(100% + 12px);left:0;z-index:80}.period-popover-inline .period-popover{width:360px;max-width:min(90vw,420px)}.tx-author-inline{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:#0f172a}.tx-drawer-actions-row .chip,.tx-drawer-actions-row .primary-button{min-height:44px;min-width:140px;border-radius:16px}.period-popover{background:#fff;border-radius:20px;border:1px solid #e5e7eb;box-shadow:0 24px 50px rgba(15,23,42,.18)}.tx-delete-action{color:#b91c1c}.tx-edit{margin-top:20px;padding:16px;border-radius:16px;background:#f8fafc;display:grid;grid-gap:16px;gap:16px}.tx-edit-grid{display:grid;grid-gap:12px;gap:12px}.tx-edit-field{display:grid;grid-gap:6px;gap:6px;color:#64748b;font-size:13px}.tx-edit-field .input{font-size:15px}.tx-date-button{justify-content:flex-start;text-align:left}.tx-edit-actions{display:flex;justify-content:flex-end;gap:12px}@media (max-width:860px){.tx-delete{opacity:1;transform:scale(1)}.tx-drawer{width:100%;border-radius:0}}.add-aside .tx-row{position:relative;grid-template-columns:52px minmax(60px,230px) auto 32px;gap:16px;border-bottom:1px solid #eef1f4;border-radius:0;padding:14px 8px}.add-aside .tx-main{min-width:0}.add-aside .tx-subtitle,.add-aside .tx-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.add-aside .tx-title{font-size:14px;white-space:normal}.add-aside .tx-amount{white-space:nowrap;text-align:right}.add-aside .tx-meta{display:inline-flex;align-items:center;justify-content:flex-end}.add-aside .tx-copy{align-self:center;opacity:1;pointer-events:auto;background:#eef1f4;color:#9aa1ab;border:none;width:32px;height:32px;border-radius:999px;font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease}.add-aside .tx-row:hover .tx-copy{background:var(--primary);color:#fff}.analytics-panel{display:grid;grid-gap:16px;gap:16px}.analytics-card{background:#fff;border-radius:20px;padding:16px;box-shadow:0 12px 30px rgba(15,20,22,.08)}.add-aside .analytics-card{background:#fff;padding:18px}.add-aside .category-list{gap:0}.add-aside .tx-row:last-child{border-bottom:none}.analytics-title{color:#8a8f98;margin-bottom:6px}.analytics-amount{font-size:24px;font-weight:700;margin-bottom:12px}.analytics-bar{display:flex;gap:6px}.analytics-bar span{display:block;height:10px;border-radius:999px}.export-button{background:transparent;border:1px solid #e5e7eb;padding:12px 16px;border-radius:12px;font-weight:600;cursor:pointer}.dashboard-shell{--dash-ink:#0f172a;--dash-muted:#98a2b3;--dash-border:#e6eaf0;--dash-surface:#fff;--dash-soft:#f8fafc;--dash-income:#4cc38a;--dash-expense:#f16463;--dash-neutral:var(--brand-start);background:radial-gradient(circle at 20% 0,rgba(76,195,138,.08),transparent 45%),radial-gradient(circle at 80% 20%,hsla(0,84%,67%,.08),transparent 45%),var(--bg);border-radius:28px;padding:18px}.dashboard-content,.dashboard-shell{display:grid;grid-gap:20px;gap:20px}.dashboard-menu{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--dash-surface);border-radius:18px;padding:12px 16px;border:1px solid var(--dash-border);box-shadow:0 12px 24px rgba(15,23,42,.06);flex-wrap:wrap}.dashboard-menu-title{font-weight:700;font-size:14px;color:var(--dash-ink)}.dashboard-menu-links{display:flex;gap:8px;flex-wrap:wrap}.dashboard-menu-link{text-decoration:none;padding:8px 14px;border-radius:999px;background:#f1f5f9;color:var(--dash-ink);font-weight:600;font-size:12px;border:1px solid transparent}.dashboard-menu-link.is-active{background:var(--dash-ink);color:#fff}.dashboard-filters{background:var(--dash-surface);border-radius:20px;padding:16px;display:grid;grid-gap:16px;gap:16px;border:1px solid var(--dash-border);box-shadow:0 12px 24px rgba(15,23,42,.06)}.filter-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:12px;gap:12px;align-items:end}.filter-group{display:grid;grid-gap:6px;gap:6px}.filter-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--dash-muted)}.filter-toggle{display:flex;gap:6px;flex-wrap:wrap}.filter-chip{border:1px solid #e5e7eb;background:#fff;padding:6px 12px;border-radius:999px;font-weight:600;font-size:12px;cursor:pointer}.filter-chip.is-active{background:#111827;color:#fff;border-color:#111827}.filter-range-inputs{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;grid-gap:8px;gap:8px}.filter-range-separator{color:var(--dash-muted)}.filter-multi{min-height:120px}.filter-actions{align-self:end}.filter-reset{border:none;background:var(--dash-ink);color:#fff;padding:10px 14px;border-radius:12px;font-weight:600;cursor:pointer}.date-picker,.date-picker-input{width:100%}.react-datepicker-popper{z-index:40}.react-datepicker{border:none;border-radius:16px;box-shadow:0 24px 40px rgba(15,23,42,.16);font-family:var(--font-manrope);overflow:hidden}.react-datepicker__header{background:var(--dash-soft);border-bottom:none;padding-top:12px}.react-datepicker__current-month,.react-datepicker__day,.react-datepicker__day-name,.react-datepicker__month-text{color:var(--dash-ink)}.react-datepicker__day--keyboard-selected,.react-datepicker__day--selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__month-text--selected{background:var(--dash-ink);color:#fff;border-radius:10px}.react-datepicker__day--in-range,.react-datepicker__day--in-selecting-range{background:rgba(15,23,42,.12);color:var(--dash-ink);border-radius:10px}.react-datepicker__navigation-icon:before{border-color:var(--dash-ink)}@media (max-width:720px){.dashboard-menu{flex-direction:column;align-items:flex-start}.filter-row{grid-template-columns:1fr}.filter-multi{min-height:160px}}@media (max-width:900px){.panel.is-half,.panel.is-third,.panel.is-two-thirds{grid-column:span 12}}.dashboard-grid{display:grid;grid-gap:20px;gap:20px;grid-template-columns:repeat(12,minmax(0,1fr))}.dashboard-header{display:grid;grid-gap:16px;gap:16px;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid var(--dash-border);padding:24px;border-radius:20px;box-shadow:0 14px 30px rgba(15,23,42,.08);grid-column:1/-1}.dashboard-header h1{margin:8px 0 0;font-size:34px;color:var(--dash-ink)}.dashboard-muted{color:var(--dash-muted);margin:6px 0 0}.summary-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:16px;gap:16px;margin-top:18px}.summary-card{background:#fff;border-radius:16px;padding:14px 18px;display:grid;grid-gap:4px;gap:4px;border:1px solid var(--dash-border);position:relative;overflow:hidden}.summary-card span{color:var(--dash-muted);font-weight:600;font-size:12px;padding-left:10px}.summary-card strong{font-size:22px;color:var(--dash-ink);padding-left:10px}.summary-delta{font-style:normal;color:var(--dash-muted);font-size:12px;padding-left:10px}.summary-delta.is-up{color:var(--dash-income)}.summary-delta.is-down{color:var(--dash-expense)}.summary-delta.is-flat{color:var(--dash-muted)}.summary-spark{margin-top:8px;width:100%;padding-left:10px}.summary-card:before{content:"";position:absolute;inset:12px auto 12px 12px;width:4px;border-radius:999px;background:var(--dash-border)}.summary-card.is-income:before{background:var(--dash-income)}.summary-card.is-expense:before{background:var(--dash-expense)}.summary-card.is-neutral:before{background:var(--dash-ink)}.summary-card.is-muted:before{background:var(--dash-border)}.summary-card.is-income{background:linear-gradient(135deg,rgba(76,195,138,.24),rgba(76,195,138,.06));border-color:rgba(76,195,138,.45)}.summary-card.is-expense{background:linear-gradient(135deg,hsla(0,84%,67%,.22),hsla(0,84%,67%,.06));border-color:hsla(0,84%,67%,.45)}.panel{background:var(--dash-surface);border-radius:20px;padding:20px;border:1px solid var(--dash-border);box-shadow:0 12px 24px rgba(15,23,42,.06);grid-column:span 12}.panel.is-half{grid-column:span 6}.panel.is-two-thirds{grid-column:span 8}.panel.is-third{grid-column:span 4}.panel-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:12px}.panel-header h2{margin:0;font-size:20px;color:var(--dash-ink)}.panel-subtitle{color:var(--dash-muted);font-size:12px}.chart{background:var(--dash-soft);border-radius:16px;padding:12px;border:1px solid rgba(230,234,240,.8)}.chart-container{height:280px}.chart.pie .chart-container{height:320px}.category-list{display:grid;grid-gap:12px;gap:12px}.category-row{display:grid;grid-gap:8px;gap:8px}.category-row strong{font-size:14px}.category-row span{color:var(--dash-muted);font-size:13px}.category-bar{height:8px;background:#eef2f7;border-radius:999px;overflow:hidden}.category-bar span{display:block;height:100%;background:var(--dash-ink);border-radius:999px}.insight-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:12px;gap:12px}.insight-card{background:var(--dash-soft);border-radius:16px;padding:14px 16px;display:grid;grid-gap:6px;gap:6px;border:1px solid rgba(230,234,240,.8)}.insight-card span{color:var(--dash-muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em}.insight-card strong{font-size:18px}.compare-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:12px;gap:12px;margin-bottom:16px}.compare-card{background:var(--dash-soft);border-radius:16px;padding:14px 16px;display:grid;grid-gap:6px;gap:6px;border:1px solid rgba(230,234,240,.8)}.compare-card span{color:var(--dash-muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em}.compare-card strong{font-size:18px}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:48px 24px;background:radial-gradient(circle at 20% 20%,rgba(15,23,42,.08),transparent 50%),radial-gradient(circle at 80% 0,rgba(59,130,246,.12),transparent 45%),#f5f6f8}.auth-card{width:min(920px,100%);background:#fff;border-radius:28px;padding:32px 40px;box-shadow:0 40px 80px rgba(15,23,42,.08);display:grid;grid-gap:24px;gap:24px;justify-items:center}.auth-brand{display:flex;align-items:center;gap:14px;width:100%;justify-content:center}.auth-brand-title{font-size:20px;font-weight:700;color:#0f172a}.auth-brand-subtitle{font-size:12px;color:#94a3b8}.auth-stepper{display:flex;gap:20px;flex-wrap:wrap;width:100%;justify-content:center}.auth-step{display:flex;align-items:center;gap:10px;color:#9ca3af;font-weight:600;font-size:14px}.auth-step-dot{width:28px;height:28px;border-radius:999px;display:grid;place-items:center;background:#e5e7eb;color:#6b7280;font-size:12px}.auth-step.is-active .auth-step-dot,.auth-step.is-done .auth-step-dot{background:var(--primary);color:#fff}.auth-step.is-active{color:var(--primary)}.auth-panel{width:100%;display:flex;justify-content:center;animation:authFade .35s ease}.auth-form{display:grid;grid-gap:16px;gap:16px;max-width:520px;width:100%;margin:0 auto}.auth-muted{color:#6b7280;margin:0}.auth-info{color:var(--primary)}.auth-error,.auth-info{font-size:14px;margin:0}.auth-error{color:#dc2626}.auth-check{display:flex;align-items:center;gap:8px;color:#6b7280;font-size:14px}.auth-legal{display:grid;grid-gap:8px;gap:8px}.auth-check a{color:#111827;text-decoration:underline}.auth-strength{display:flex;align-items:center;gap:12px}.auth-strength-bar{flex:1 1;height:6px;border-radius:999px;background:#e5e7eb;position:relative;overflow:hidden}.auth-strength-bar:after{content:"";position:absolute;inset:0;transform-origin:left;transform:scaleX(.2);background:#dc2626;transition:transform .3s ease,background .3s ease}.auth-strength-bar.level-2:after{transform:scaleX(.45);background:var(--brand-end)}.auth-strength-bar.level-3:after,.auth-strength-bar.level-4:after{transform:scaleX(.85);background:#16a34a}.auth-hint{color:#9ca3af;font-size:13px;margin:0}.profile-header{display:flex;align-items:center;gap:16px}.profile-avatar{width:64px;height:64px;border-radius:18px;background:var(--primary);color:#fff;display:grid;place-items:center;font-size:26px;font-weight:700}.profile-name{font-size:20px;font-weight:700;color:#111827}.profile-email{color:#6b7280}.auth-section{display:grid;grid-gap:12px;gap:12px}.auth-section-title{font-weight:600;color:#111827}.avatar-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(64px,1fr));grid-gap:12px;gap:12px}.avatar-item{border:none;background:transparent;padding:0;cursor:pointer}.avatar-circle{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;font-weight:600;color:#111827;background:#f3f4f6;border:2px solid transparent}.avatar-item.is-active .avatar-circle{border-color:var(--primary)}.goal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));grid-gap:12px;gap:12px}.goal-card{padding:14px 16px;border-radius:16px;border:1px solid #e5e7eb;background:#f8fafc;cursor:pointer;font-weight:600;color:#111827;text-align:left}.goal-card.is-active{border-color:var(--primary);background:var(--brand-gradient);color:#fff}.ghost-button{background:transparent;border:none;color:#6b7280;font-weight:600;cursor:pointer;text-align:left}.avatar-avatar_01{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.avatar-avatar_02{background:linear-gradient(135deg,#fee2e2,#fecaca)}.avatar-avatar_03{background:linear-gradient(135deg,#dcfce7,#bbf7d0)}.avatar-avatar_04{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.avatar-avatar_05{background:linear-gradient(135deg,#ede9fe,#ddd6fe)}.avatar-avatar_06{background:linear-gradient(135deg,#cffafe,#a5f3fc)}.avatar-avatar_07{background:linear-gradient(135deg,#ffe4e6,#fecdd3)}.avatar-avatar_08{background:linear-gradient(135deg,#e0f2fe,#bae6fd)}.avatar-avatar_09{background:linear-gradient(135deg,#ecfccb,#d9f99d)}.avatar-avatar_10{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.avatar-avatar_11{background:linear-gradient(135deg,#f3e8ff,#e9d5ff)}.avatar-avatar_12{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}@keyframes authFade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}