:root{--background:#08090b;--background-strong:#0f1115;--surface:#14161b;--surface-strong:#1a1d23;--surface-soft:#ffffff06;--border:#ffffff12;--text:#f3f4f6;--muted:#969ca8;--muted-strong:#c4cad4;--positive:#9ca3af;--negative:#e5e7eb;--accent:#c7ccd6;--shadow:0 16px 40px #0000004d;--radius-xl:32px;--radius-lg:24px;--radius-md:18px;--radius-sm:14px;--font-sans:"SF Pro Display", "Avenir Next", "Helvetica Neue", "Segoe UI", sans-serif}*{box-sizing:border-box}html{background:var(--background)}body{min-height:100vh;color:var(--text);font-family:var(--font-sans);background:linear-gradient(#07080a 0%,#0c0e12 100%);margin:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{color:inherit}code{background:#ffffff0f;border-radius:999px;padding:.15rem .35rem}.background-orb{display:none}.background-orb--one{background:#f4c14f29;width:18rem;height:18rem;top:-6rem;left:-4rem}.background-orb--two{background:#36d1c41f;width:20rem;height:20rem;bottom:8rem;right:-6rem}.app-shell{min-height:100vh;display:flex}.desktop-rail{display:none}.app-shell__content{flex:1;min-width:0}.app-shell__inner{width:min(1180px,100%);margin:0 auto;padding:1.5rem 1rem 6.5rem}.page{gap:1rem;min-width:0;animation:.35s ease-out rise-in;display:grid;overflow-x:hidden}.page-header,.section-heading,.hero-card__values,.metric-inline,.profile-card,.wallet-row,.settings-row,.category-row,.taxonomy-card__header,.transaction-card__header,.transaction-card,.brand-lockup,.desktop-nav__item,.mobile-nav__item,.amount-field,.color-field{align-items:center;display:flex}.page-header,.section-heading,.hero-card__values,.brand-lockup,.transaction-card__header,.wallet-row,.settings-row,.category-row,.taxonomy-card__header{justify-content:space-between}.page-header{gap:1rem}.settings-btn{width:2.25rem;height:2.25rem;color:var(--muted);border-radius:50%;justify-content:center;align-items:center;transition:color .15s,background .15s;display:flex}.settings-btn:hover{color:var(--text);background:#ffffff14}.settings-btn__icon{width:1.25rem;height:1.25rem}.page-eyebrow,.section-label,.brand-lockup__eyebrow{color:var(--muted);letter-spacing:.02em;text-transform:uppercase;margin:0 0 .35rem;font-size:.85rem;font-weight:600}.page-title,.brand-lockup__title{margin:0;font-size:clamp(2rem,6vw,3.2rem);line-height:.96}.page-subtitle,.helper-text,.desktop-note__body,.transaction-card__meta,.category-row p,.wallet-row p,.empty-card__body,.taxonomy-card p{color:var(--muted);margin:0;line-height:1.45}.page-pill,.pill-button,.range-chip,.input-pill,.mini-chip{border:1px solid var(--border);color:var(--muted-strong);background:#ffffff0d;border-radius:999px;justify-content:center;align-items:center;display:inline-flex}.page-pill{min-height:2.3rem;padding:0 1rem;font-size:.92rem}.pill-row,.range-row,.wallet-switcher,.chip-row{z-index:1;flex-wrap:wrap;gap:.5rem;min-width:0;max-width:100%;display:flex;position:relative}.month-picker{position:relative}.month-picker__dropdown{background:var(--surface-strong);border:1px solid var(--border);border-radius:var(--radius-md);min-width:9rem;box-shadow:var(--shadow);z-index:20;animation:.15s ease-out both rise-in;position:absolute;top:calc(100% + .5rem);left:0;overflow:hidden}.month-picker__option{border:none;border-bottom:1px solid var(--border);text-align:left;width:100%;color:var(--muted-strong);cursor:pointer;background:0 0;padding:.65rem 1rem;font-size:.92rem;display:block}.month-picker__option:last-child{border-bottom:none}.month-picker__option:hover{color:var(--text);background:#ffffff0f}.month-picker__option--active{color:var(--text);background:#ffffff1a}.month-picker__empty{color:var(--muted);margin:0;padding:.75rem 1rem;font-size:.9rem}.search-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:.5rem;padding:.6rem .85rem;transition:border-color .15s;display:flex}.search-bar:focus-within{border-color:#ffffff2e}.search-bar__icon{color:var(--muted);flex-shrink:0;align-items:center;display:flex}.search-bar__input{color:var(--text);font-size:.9rem;font-family:var(--font-sans);background:0 0;border:none;outline:none;flex:1;min-width:0}.search-bar__input::placeholder{color:var(--muted)}.search-bar__clear{color:var(--muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0;font-size:1.3rem;line-height:1}.search-bar__clear:hover{color:var(--text)}.filter-stack{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-lg);gap:.75rem;padding:1rem 1.25rem;display:grid}.filter-group{gap:.5rem;display:grid}.filter-group__label{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-size:.78rem;font-weight:700}.filter-divider{background:var(--border);height:1px;margin:.1rem 0}.pill-button,.range-chip,.wallet-chip,.mini-chip{min-height:2.4rem;padding:0 1rem;font-size:.92rem}.pill-button--active,.range-chip--active{border-color:var(--border);color:var(--text);background:#ffffff21}.hero-card,.side-card,.form-card,.stats-panel,.auth-card,.auth-preview,.empty-card,.banner,.desktop-note,.taxonomy-card{border:1px solid var(--border);background:var(--surface);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow)}.hero-card,.side-card,.form-card,.stats-panel,.auth-card,.auth-preview,.empty-card,.desktop-note,.taxonomy-card{border-radius:var(--radius-lg);padding:1.25rem}.banner{border-radius:var(--radius-md);color:var(--muted-strong);padding:.95rem 1rem}.hero-card{gap:1rem;display:grid}.headline-balance{margin:0;font-size:clamp(2rem,7vw,3.8rem);line-height:.95}.hero-totals{flex-wrap:wrap;align-items:flex-end;gap:1.5rem;display:flex}.hero-subtotal{border-left:2px solid var(--border);padding-left:1.5rem}.hero-subtotal__amount{letter-spacing:-.02em;color:var(--muted-strong);font-size:1.4rem;font-weight:700}.month-filter-row{align-items:center;gap:.4rem;display:flex}.positive{color:var(--positive)}.negative{color:var(--negative)}.metric-inline{flex-wrap:wrap;gap:1.35rem}.metric-inline__label{color:var(--muted);margin-bottom:.3rem;font-size:.8rem;display:block}.balance-track{background:#ffffff12;border-radius:999px;height:.85rem;position:relative;overflow:hidden}.balance-track__fill{border-radius:inherit;background:linear-gradient(90deg,#ffffff2e,#ffffff61);position:absolute;inset:0 auto 0 0}.dashboard-grid{gap:1rem;display:grid}.stack,.transaction-list,.category-list,.wallet-list,.settings-list,.taxonomy-list{gap:.85rem;display:grid}.day-section{gap:.7rem;display:grid}.transaction-card{border-radius:var(--radius-md);background:var(--surface-strong);border:1px solid var(--border);gap:.85rem;padding:.95rem 1rem}.transaction-card__icon,.category-row__emoji{border-radius:999px;flex-shrink:0;place-items:center;width:3rem;height:3rem;font-size:1.25rem;display:grid}.transaction-card__icon{color:var(--text);background:#ffffff1f}.transaction-card__content{flex:1;min-width:0}.transaction-card__header strong,.category-row strong,.wallet-row strong,.taxonomy-card strong{font-size:1rem}.transaction-card__meta{margin-top:.2rem;font-size:.88rem}.section-link,.text-link{color:#aab2bf}.category-row__main,.profile-card,.auth-provider,.auth-provider--light,.wallet-chip,.secondary-button,.primary-button{align-items:center;gap:.8rem;display:flex}.category-row__main{min-width:0}.category-row__summary{color:var(--muted);justify-items:end;gap:.15rem;display:grid}.side-card,.stats-panel{gap:1rem;display:grid}.stats-kind-toggle{width:100%}.stats-kind-toggle .segmented-control__button{flex:1}.stats-total{gap:.25rem;display:grid}.monthly-breakdown{gap:.9rem;padding-top:.25rem;display:grid}.monthly-row{gap:.45rem;display:grid}.monthly-row__meta{justify-content:space-between;align-items:baseline;gap:.5rem;display:flex}.monthly-row__label{color:var(--muted-strong);font-size:.9rem;font-weight:600}.monthly-row__amount{color:var(--text);white-space:nowrap;font-size:.92rem;font-weight:700}.monthly-row__track{background:#ffffff12;border-radius:999px;height:.45rem;overflow:hidden}.monthly-row__fill{border-radius:inherit;background:linear-gradient(90deg,#fff3,#ffffff73);height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.wallet-row,.settings-row{border-bottom:1px solid #ffffff0f;padding:.9rem 0}.wallet-row:last-child,.settings-row:last-child{border-bottom:none;padding-bottom:0}.settings-row:first-child,.wallet-row:first-child{padding-top:0}.segmented-control{border:1px solid var(--border);background:#ffffff0d;border-radius:999px;flex-wrap:wrap;gap:.35rem;min-width:0;max-width:100%;padding:.25rem;display:inline-flex}.segmented-control--icon{margin-left:auto}.segmented-control__button{color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:999px;min-height:2.35rem;padding:0 1rem}.segmented-control__button--active{color:var(--text);background:#ffffff1a}.toolbar-icon,.desktop-nav__icon,.mobile-nav__icon,.button-icon,.auth-provider__icon{width:1.15rem;height:1.15rem}.sankey-wrap{width:100%;min-width:0;padding:.5rem 0;position:relative;overflow:visible}.sankey-svg{width:100%;height:auto;display:block}.sankey-labels{pointer-events:none;position:absolute;inset:0}.sankey-link{transition:opacity .2s}.sankey-node--interactive{cursor:pointer;transition:fill-opacity .2s}.sankey-label{gap:.15rem;max-width:9rem;display:grid;position:absolute;transform:translateY(-50%)}.sankey-label--left{text-align:right;justify-items:end;transform:translate(-100%)translateY(-50%)}.sankey-label--right{text-align:left;justify-items:start;transform:translateY(-50%)}.sankey-label--center{text-align:center;justify-items:center;transform:translate(-50%)translateY(-50%)}.sankey-label__name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:.82rem;font-weight:600;overflow:hidden}.sankey-label__value{color:var(--muted-strong);white-space:nowrap;font-variant-numeric:tabular-nums;font-size:.75rem}.sankey-label--interactive{pointer-events:auto;cursor:pointer;transition:opacity .2s}.chart-empty{border-radius:var(--radius-md);text-align:center;color:var(--muted);border:1px dashed #ffffff1f;padding:2.5rem 1rem}.field,.auth-actions{gap:.55rem;min-width:0;max-width:100%;display:grid;overflow:hidden}.field__label{color:var(--muted-strong);font-size:.92rem;font-weight:600}.input,.textarea{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;min-width:0;min-height:3.25rem;color:var(--text);box-sizing:border-box;background:#ffffff0f;padding:.9rem 1rem}select.input{text-overflow:ellipsis;max-width:100%}.input:focus,.textarea:focus{outline-offset:1px;outline:2px solid #b8c0cc59}.input--large{min-height:4rem;font-size:1.8rem;font-weight:600}.textarea{resize:vertical;min-height:7.5rem}.amount-field{gap:.75rem}.amount-field .input{flex:1}.input-pill{min-width:3.25rem;min-height:4rem;font-size:1.1rem}.split-fields{gap:1rem;display:grid}.split-fields--add .segmented-control{width:100%}.split-fields--add .segmented-control__button{flex:1;min-width:0;padding-inline:.75rem}.add-section{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-lg);gap:1rem;min-width:0;padding:1rem;display:grid;overflow:hidden}.add-section__label{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-size:.78rem;font-weight:700}.add-amount-row{align-items:baseline;gap:.5rem;padding:.5rem 0;display:flex}.add-amount-input{width:100%;min-width:0;color:var(--text);caret-color:var(--accent);background:0 0;border:none;outline:none;flex:1;font-size:clamp(2rem,8vw,3.5rem);font-weight:700;line-height:1}.add-amount-input::placeholder{color:#ffffff26}.add-amount-currency{color:var(--muted);flex-shrink:0;font-size:1.5rem;font-weight:600}.add-link-button{color:var(--muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:.3rem;padding:0;font-size:.88rem;display:inline-flex}.add-link-button:hover{color:var(--muted-strong)}.add-submit{min-height:3.5rem;font-size:1rem}.inline-create{gap:.65rem;margin-top:.35rem;display:grid}.inline-create__actions{flex-wrap:wrap;gap:.5rem;display:flex}.inline-create__actions .secondary-button{min-height:2.6rem}.emoji-field{gap:.5rem;min-width:0;display:grid}.emoji-field__input{text-align:center;min-height:3rem;font-size:1.35rem;line-height:1.2}.emoji-field__grid{-webkit-overflow-scrolling:touch;flex-wrap:wrap;gap:.35rem;min-width:0;max-width:100%;max-height:9rem;display:flex;overflow-y:auto}.emoji-field__choice{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;width:2.35rem;height:2.35rem;color:inherit;background:#ffffff0a;place-items:center;padding:0;font-size:1.15rem;line-height:1;display:grid}.emoji-field__choice--active{background:#ffffff24;border-color:#ffffff38}.helper-card{border-radius:var(--radius-md);background:#ffffff08;padding:1rem}.primary-button,.secondary-button,.auth-provider{cursor:pointer;border:1px solid #0000;border-radius:999px;justify-content:center;min-height:3.2rem;padding:0 1.1rem}.primary-button{color:#111318;background:#e5e7eb;font-weight:700}.secondary-button,.auth-provider{border-color:var(--border);background:#ffffff0f}.auth-provider--light{color:#141416;background:#f4f1ea}.status{margin:0;font-size:.92rem}.status--error{color:#d4d4d8}.status--success{color:#e5e7eb}.wallet-chip{border:1px solid var(--border);cursor:pointer;min-height:3rem;color:var(--muted);background:#ffffff0d;border-radius:999px;padding:0 1rem;transition:background .15s,border-color .15s,color .15s}.wallet-chip--active{color:var(--text);background:#ffffff26;border-color:#ffffff40;font-weight:600;box-shadow:0 0 0 1px #ffffff14}.color-field{border-radius:var(--radius-sm);border:1px solid var(--border);background:#ffffff0d;gap:.8rem;padding:.65rem .85rem}.color-field input{appearance:none;background:0 0;border:none;width:2.4rem;height:2.4rem;padding:0}.taxonomy-card{box-shadow:none}.mini-chip{min-height:2rem;padding:0 .8rem;font-size:.85rem}.profile-card{gap:1rem}.profile-card__avatar{color:#111318;background:linear-gradient(135deg,#717784,#9aa3b0);border-radius:999px;place-items:center;width:4.25rem;height:4.25rem;font-size:1.15rem;font-weight:800;display:grid;overflow:hidden}.profile-card__avatar img{object-fit:cover;width:100%;height:100%}.auth-shell{align-items:center;width:min(1120px,100%);min-height:100vh;margin:0 auto;padding:1.5rem 1rem 2rem;display:grid}.auth-grid{gap:1rem;display:grid}.auth-grid--single{grid-template-columns:minmax(0,28rem);justify-content:center}.auth-confirm-banner{border-radius:var(--radius-md);border:1px solid var(--border);color:var(--muted-strong);background:#ffffff0a;gap:.3rem;padding:1.1rem 1.2rem;line-height:1.6;display:grid}.auth-confirm-banner strong{color:var(--text);font-size:1rem}.auth-confirm-banner p{margin:0;font-size:.9rem}.login-form{gap:1.5rem;display:grid}.login-form__tabs{border-bottom:1px solid var(--border);grid-template-columns:1fr 1fr;display:grid}.login-form__tab{color:var(--muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.75rem 0;font-size:.95rem;font-weight:600;transition:color .15s,border-color .15s}.login-form__tab--active{color:var(--text);border-bottom-color:var(--text)}.login-form__body{gap:1rem;display:grid}.auth-card{gap:1rem}.auth-hero{gap:1rem;display:grid}.auth-preview__list{gap:.75rem;display:grid}.auth-preview__item{border-bottom:1px solid #ffffff0f;align-items:center;gap:.75rem;padding:.9rem 0;display:flex}.auth-preview__item:last-child{border-bottom:none;padding-bottom:0}.auth-preview__dot{background:#ffffff14;border-radius:999px;place-items:center;width:2.75rem;height:2.75rem;font-size:1.2rem;display:grid}.desktop-note{margin-top:auto}.desktop-note__title{margin:0 0 .4rem;font-weight:700}.brand-lockup{gap:1rem;margin-bottom:2rem}.brand-lockup__badge{background:linear-gradient(135deg,#6f7481,#9aa3b0);border-radius:1.3rem;place-items:center;width:3.5rem;height:3.5rem;font-size:1.5rem;display:grid}.desktop-nav{gap:.45rem;display:grid}.desktop-nav__item{min-height:3.1rem;color:var(--muted-strong);border-radius:999px;gap:.85rem;padding:0 1rem}.desktop-nav__item--active{color:var(--text);background:#ffffff1f}.mobile-nav{border:1px solid var(--border);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);z-index:10;background:#0d0e11f0;border-radius:999px;grid-template-columns:repeat(5,minmax(0,1fr));gap:.3rem;padding:.45rem;display:grid;position:fixed;bottom:1rem;left:1rem;right:1rem}.mobile-nav__item{min-height:3.5rem;color:var(--muted);border-radius:999px;flex-direction:column;justify-content:center;gap:.2rem;font-size:.72rem}.mobile-nav__item--active{color:var(--text);background:#ffffff24}@keyframes rise-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.transaction-card--tappable{cursor:pointer;transition:background .12s}.transaction-card--tappable:hover{background:var(--surface-soft)}.transaction-card--tappable:active{background:#ffffff0f}.transaction-card__chevron{color:var(--muted);flex-shrink:0;margin-left:auto;padding-left:.25rem;font-size:1.2rem;line-height:1}.sheet-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:40;background:#0000008c;animation:.2s both fade-in;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.sheet{z-index:50;-webkit-overflow-scrolling:touch;background:var(--background-strong);border:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;border-bottom:none;gap:1rem;max-height:88dvh;padding:.65rem 1.25rem 2.5rem;animation:.28s cubic-bezier(.4,0,.2,1) both sheet-rise;display:grid;position:fixed;bottom:0;left:0;right:0;overflow-y:auto}@keyframes sheet-rise{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet__handle{background:#ffffff2e;border-radius:999px;width:2.5rem;height:.28rem;margin:0 auto}.sheet__header{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.sheet__title{align-items:center;gap:.75rem;display:flex}.sheet__emoji{background:#ffffff1a;border-radius:999px;flex-shrink:0;place-items:center;width:2.8rem;height:2.8rem;font-size:1.2rem;display:grid}.sheet__subtitle{color:var(--muted);margin:.1rem 0 0;font-size:.85rem}.sheet__close{border:1px solid var(--border);width:2.2rem;height:2.2rem;color:var(--muted);cursor:pointer;background:#ffffff0d;border-radius:999px;flex-shrink:0;place-items:center;font-size:.8rem;display:grid}.sheet__body{gap:1rem;display:grid}.sheet__confirm-delete{border-radius:var(--radius-sm);background:#f871710f;border:1px solid #f8717133;gap:.75rem;padding:1rem;display:grid}.sheet__confirm-delete p{color:var(--muted-strong);margin:0;font-size:.92rem}.sheet__confirm-actions{flex-wrap:wrap;gap:.5rem;display:flex}.sheet__delete-trigger{color:var(--muted)}.sheet__delete-btn{color:#f87171;border-color:#f8717159}@media (min-width:560px){.sheet{border-left:1px solid var(--border);border-right:1px solid var(--border);width:min(30rem,100vw);animation:.28s cubic-bezier(.4,0,.2,1) both sheet-rise-centered;left:50%;right:auto;transform:translate(-50%)}@keyframes sheet-rise-centered{0%{transform:translate(-50%)translateY(100%)}to{transform:translate(-50%)translateY(0)}}}@media (min-width:760px){.app-shell__inner,.auth-shell{padding-left:1.5rem;padding-right:1.5rem}.dashboard-grid,.auth-grid:not(.auth-grid--single){grid-template-columns:minmax(0,1.3fr) minmax(20rem,.9fr);align-items:start}.split-fields{grid-template-columns:repeat(2,minmax(0,1fr))}}.chart-section-label{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:.35rem 0 -.2rem;font-size:.73rem;font-weight:700}.donut-wrap{gap:1rem;display:grid}.donut-chart-area{width:min(180px,72%);margin:0 auto;position:relative}.donut-svg{width:100%;height:auto;display:block}.donut-center{pointer-events:none;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.15rem;padding:0 .85rem;display:flex;position:absolute;inset:0}.donut-center__amount{color:var(--text);font-size:clamp(.72rem,2.4vw,1rem);font-weight:700;line-height:1.1}.donut-center__label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:.62rem;font-weight:600}.donut-legend{gap:.55rem;margin:0;padding:0;list-style:none;display:grid}.donut-legend__item{align-items:center;gap:.6rem;font-size:.88rem;display:flex}.donut-legend__dot,.bar-legend__dot{border-radius:999px;flex-shrink:0;width:.55rem;height:.55rem}.donut-legend__name{color:var(--muted-strong);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.donut-legend__pct{color:var(--text);font-variant-numeric:tabular-nums;font-size:.85rem;font-weight:700}.bar-chart-wrap{gap:.75rem;display:grid}.bar-chart-svg{width:100%;height:auto;display:block}.bar-legend{flex-wrap:wrap;gap:.4rem .85rem;margin:0;padding:0;list-style:none;display:flex}.bar-legend__item{color:var(--muted-strong);align-items:center;gap:.45rem;font-size:.82rem;display:flex}@media (min-width:540px){.donut-wrap{grid-template-columns:160px 1fr;align-items:center;gap:1.25rem}.donut-chart-area{width:160px;margin:0}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{border-radius:var(--radius-sm);background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14 50%,#ffffff0a 75%) 0 0/200% 100%;animation:1.5s ease-in-out infinite shimmer}.skeleton--text{border-radius:6px;height:.85rem}.skeleton--sm{width:5rem}.skeleton--lg{width:8rem;height:1.4rem;margin-top:.4rem}.skeleton--card{border-radius:var(--radius-lg);border:1px solid var(--border)}.skeleton--hero{height:7rem}.skeleton--row{height:3.8rem}.skeleton-page{gap:1rem;display:grid}.skeleton-stack{gap:.5rem;display:grid}.toggle-row{cursor:pointer;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.toggle-row__label{color:var(--text);font-size:.9rem}.toggle-input{opacity:0;pointer-events:none;width:0;height:0;position:absolute}.toggle-track{background:var(--surface-strong);border:1px solid var(--border);border-radius:12px;flex-shrink:0;width:42px;height:24px;transition:background .2s;display:inline-block;position:relative}.toggle-track--on{background:#4ade80;border-color:#4ade80}.toggle-thumb{background:var(--text);border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:2px;left:2px}.toggle-track--on .toggle-thumb{transform:translate(18px)}.recurring-list{gap:.5rem;display:grid}.recurring-card{border-radius:var(--radius-sm);background:var(--surface-strong);border:1px solid var(--border);align-items:flex-start;gap:.75rem;padding:.85rem;display:flex}.recurring-card__icon{flex-shrink:0;padding-top:.05rem;font-size:1.4rem}.recurring-card__body{flex:1;gap:.15rem;min-width:0;display:grid}.recurring-card__name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;overflow:hidden}.recurring-card__meta{color:var(--muted-strong);font-variant-numeric:tabular-nums;font-size:.8rem}.recurring-card__next{color:var(--muted);font-size:.75rem}.recurring-card__note{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;font-style:italic;overflow:hidden}.recurring-card__delete{color:var(--muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:.2rem;font-size:1rem;line-height:1;transition:color .15s}.recurring-card__delete:hover{color:#f87171}.empty-hint{color:var(--muted);padding:.5rem 0;font-size:.85rem}.section-heading__badge{color:var(--muted);background:var(--surface-strong);font-variant-numeric:tabular-nums;border-radius:10px;padding:.15rem .55rem;font-size:.75rem}@media (min-width:1040px){.desktop-rail{-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#0c0c0eb8;border-right:1px solid #ffffff0f;flex-direction:column;width:18rem;min-height:100vh;padding:2rem 1.2rem;display:flex;position:sticky;top:0}.app-shell__inner{padding:2rem}.mobile-nav{display:none}}.nw-hero{background:var(--surface);border:1px solid var(--border);border-radius:1rem;flex-direction:column;align-items:center;gap:.25rem;margin-bottom:.75rem;padding:1.5rem 1rem;display:flex}.nw-hero__label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:.8rem}.nw-hero__amount{letter-spacing:-.02em;font-size:2rem;font-weight:700}.nw-hero__delta{font-size:.85rem;font-weight:600}.nw-hero__delta.positive{color:var(--green)}.nw-hero__delta.negative{color:var(--red)}.nw-chart-section{background:var(--surface);border:1px solid var(--border);border-radius:1rem;margin-bottom:.75rem;padding:1rem}.nw-chart-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.nw-chart-header h2{font-size:1rem;font-weight:600}.nw-chart-toggle{color:var(--accent);border:1px solid var(--accent);cursor:pointer;background:0 0;border-radius:999px;padding:.25rem .75rem;font-size:.75rem}.nw-chart{width:100%}.nw-chart svg{aspect-ratio:320/140;width:100%;height:auto}.nw-chart-labels{justify-content:space-between;padding-top:.25rem;display:flex}.nw-chart-label{color:var(--muted);font-size:.65rem}.nw-chart-legend{color:var(--muted);flex-wrap:wrap;gap:.5rem 1rem;margin-top:.5rem;font-size:.7rem;display:flex}.nw-chart-legend-item{align-items:center;gap:.3rem;display:flex}.nw-chart-legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.nw-input-section{background:var(--surface);border:1px solid var(--border);border-radius:1rem;margin-bottom:.75rem;padding:1rem}.nw-month-nav{justify-content:center;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.nw-month-btn{border:1px solid var(--border);background:var(--surface);width:2rem;height:2rem;color:var(--text);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;display:flex}.nw-month-label{text-align:center;min-width:6rem;font-size:1rem;font-weight:600}.nw-input-grid{flex-direction:column;gap:.5rem;display:flex}.nw-input-row{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.nw-input-row__label{flex:1 1 0;align-items:center;gap:.4rem;min-width:0;display:flex}.nw-input-row__emoji{flex-shrink:0}.nw-input-row__name{text-overflow:ellipsis;white-space:nowrap;font-size:.85rem;overflow:hidden}.nw-input-row__field{flex-shrink:0;align-items:center;gap:.3rem;display:flex}.nw-input-row__input{border:1px solid var(--border);border-left:3px solid var(--accent);background:var(--surface-strong);width:7rem;color:var(--text);text-align:right;font-variant-numeric:tabular-nums;border-radius:.5rem;padding:.4rem .5rem;font-size:.9rem}.nw-input-row__currency{color:var(--muted);font-size:.75rem}.nw-save-btn{width:100%;margin-top:1rem}.nw-history{background:var(--surface);border:1px solid var(--border);border-radius:1rem;margin-bottom:.75rem;padding:1rem}.nw-history h2{margin-bottom:.75rem;font-size:1rem;font-weight:600}.nw-history-list{flex-direction:column;gap:.35rem;display:flex}.nw-history-item{border:1px solid var(--border);border-radius:.75rem;overflow:hidden}.nw-history-summary{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:.6rem .75rem;font-size:.85rem;display:flex}.nw-history-summary::-webkit-details-marker{display:none}.nw-history-month{font-weight:600}.nw-history-total{font-variant-numeric:tabular-nums;color:var(--muted)}.nw-history-breakdown{color:var(--muted);flex-direction:column;gap:.25rem;padding:.25rem .75rem .6rem;font-size:.8rem;display:flex}.nw-history-row{justify-content:space-between;display:flex}.nw-accounts{background:var(--surface);border:1px solid var(--border);border-radius:1rem;margin-bottom:5rem;padding:1rem}.nw-accounts h2{margin-bottom:.75rem;font-size:1rem;font-weight:600}.nw-account-list{flex-direction:column;gap:.35rem;display:flex}.nw-account-card{border:1px solid var(--border);border-radius:.75rem;justify-content:space-between;align-items:center;padding:.5rem .75rem;font-size:.85rem;display:flex}.nw-account-card__left{align-items:center;gap:.5rem;display:flex}.nw-account-card__dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.nw-account-card__delete{color:var(--muted);cursor:pointer;opacity:.5;background:0 0;border:none;padding:.25rem;font-size:.9rem;transition:opacity .15s}.nw-account-card__delete:hover{opacity:1;color:var(--red)}.nw-add-btn{width:100%;margin-top:.75rem}.nw-add-account-form{flex-direction:column;gap:.5rem;margin-top:.75rem;display:flex}.nw-add-account-row{gap:.5rem;display:flex}.nw-add-account-input{border:1px solid var(--border);background:var(--surface-strong);color:var(--text);border-radius:.5rem;padding:.5rem .6rem;font-size:.85rem}.nw-add-account-input--emoji{text-align:center;width:3rem}.nw-add-account-input--name{flex:1}.nw-color-picker{flex-wrap:wrap;gap:.4rem;display:flex}.nw-color-dot{cursor:pointer;border:2px solid #0000;border-radius:50%;width:1.5rem;height:1.5rem;transition:border-color .15s,transform .15s}.nw-color-dot--active{border-color:var(--text);transform:scale(1.15)}.nw-add-account-actions{justify-content:flex-end;gap:.5rem;display:flex}.form-error-message{color:var(--red);margin:0;font-size:.8rem}.subs-hero{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);flex-direction:column;gap:1rem;padding:1.25rem;display:flex}.subs-hero__main{gap:.15rem;display:grid}.subs-hero__amount{letter-spacing:-.02em;font-size:clamp(1.8rem,6vw,2.8rem);font-weight:700;line-height:1}.subs-hero__meta{color:var(--muted);font-size:.85rem}.subs-month-nav{border:1px solid var(--border);background:#ffffff0a;border-radius:999px;justify-content:space-between;align-items:center;gap:.75rem;padding:.4rem .55rem;display:flex}.subs-month-btn{width:2rem;height:2rem;color:var(--text);cursor:pointer;background:#ffffff0f;border:none;border-radius:999px;place-items:center;font-size:1.1rem;line-height:1;transition:background .15s;display:grid}.subs-month-btn:hover{background:#ffffff1f}.subs-month-label{text-align:center;color:var(--muted-strong);letter-spacing:.01em;flex:1;font-size:.95rem;font-weight:600}.subs-calendar{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);gap:.6rem;padding:.9rem;display:grid}.subs-calendar__weekdays{grid-template-columns:repeat(7,minmax(0,1fr));gap:.25rem;padding:0 .1rem;display:grid}.subs-calendar__weekday{text-align:center;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:.7rem;font-weight:700}.subs-calendar__grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:.3rem;display:grid}.subs-calendar__cell{border:1px solid var(--border);background:var(--surface-strong);min-height:4.5rem;color:var(--text);font:inherit;text-align:left;cursor:pointer;border-radius:.75rem;flex-direction:column;gap:.2rem;padding:.35rem .3rem .3rem;transition:background .15s,border-color .15s,transform .1s;display:flex;position:relative;overflow:hidden}.subs-calendar__cell:hover:not(.subs-calendar__cell--empty){background:#ffffff12;border-color:#ffffff2e}.subs-calendar__cell:active:not(.subs-calendar__cell--empty){transform:scale(.98)}.subs-calendar__cell--empty{cursor:default;background:0 0;border-color:#0000}.subs-calendar__cell--active{background:#ffffff0d;border-color:#ffffff29}.subs-calendar__cell--today{outline:1px solid var(--accent);outline-offset:-1px}.subs-calendar__day-number{color:var(--muted-strong);font-size:.8rem;font-weight:600}.subs-calendar__cell--today .subs-calendar__day-number{color:var(--text)}.subs-calendar__emojis{flex-wrap:wrap;gap:.1rem;font-size:.75rem;line-height:1;display:flex}.subs-calendar__emoji{background:#ffffff14;border-radius:999px;place-items:center;width:1.1rem;height:1.1rem;display:inline-grid}.subs-calendar__more{color:var(--muted);padding:0 .25rem;font-size:.65rem;line-height:1.1rem}.subs-calendar__amount{color:var(--muted);font-variant-numeric:tabular-nums;text-overflow:ellipsis;white-space:nowrap;margin-top:auto;font-size:.65rem;overflow:hidden}.subs-upcoming-list{gap:.5rem;display:grid}.subs-upcoming-row{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-strong);align-items:center;gap:.85rem;padding:.7rem .85rem;display:flex}.subs-upcoming-row__date{background:#ffffff0d;border-radius:.5rem;justify-items:center;gap:.1rem;min-width:2.4rem;padding:.2rem 0;display:grid}.subs-upcoming-row__weekday{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-size:.65rem;font-weight:700}.subs-upcoming-row__day{font-variant-numeric:tabular-nums;color:var(--text);font-size:1rem;font-weight:700}.subs-upcoming-row__body{flex:1;align-items:center;gap:.65rem;min-width:0;display:flex}.subs-upcoming-row__icon{flex-shrink:0;font-size:1.2rem}.subs-upcoming-row__info{gap:.1rem;min-width:0;display:grid}.subs-upcoming-row__info strong{text-overflow:ellipsis;white-space:nowrap;font-size:.92rem;overflow:hidden}.subs-upcoming-row__info p{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:.75rem;overflow:hidden}.subs-form{border-radius:var(--radius-md);border:1px solid var(--border);background:#ffffff08;gap:.9rem;padding:1rem;display:grid}@media (min-width:520px){.subs-calendar__cell{min-height:5.25rem}.subs-calendar__amount{font-size:.7rem}}@media (max-width:380px){.subs-calendar{padding:.65rem}.subs-calendar__cell{min-height:4rem;padding:.25rem .2rem}.subs-calendar__day-number{font-size:.72rem}.subs-calendar__emoji{width:.95rem;height:.95rem;font-size:.65rem}}
