.app-shell{display:grid;grid-template-columns:var(--sidebar-width) 1fr;min-height:100vh}.sidebar{position:sticky;top:0;align-self:start;height:100vh;display:flex;flex-direction:column;gap:var(--space-6);padding:var(--space-6) var(--space-4);background-color:var(--color-surface);border-right:1px solid var(--color-border)}.sidebar__brand{display:flex;flex-direction:column;gap:var(--space-1);padding:0 var(--space-2)}.sidebar__brand-mark{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;color:var(--color-ink);letter-spacing:-.015em}.sidebar__brand-sub{font-size:var(--text-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--color-muted)}.sidebar__nav{display:flex;flex-direction:column;gap:var(--space-1)}.sidebar__link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);color:var(--color-muted);font-weight:500;font-size:var(--text-sm);transition:background-color var(--duration-fast) var(--ease-standard),color var(--duration-fast) var(--ease-standard)}.sidebar__link:hover{background-color:var(--color-surface-sunk);color:var(--color-ink)}.sidebar__link.is-active{background-color:var(--color-accent-soft);color:var(--color-accent-strong);font-weight:700;box-shadow:inset 3px 0 0 0 var(--color-accent-strong)}.sidebar__link:focus-visible{outline:2px solid var(--color-accent-strong);outline-offset:2px}.sidebar__link-dot{width:7px;height:7px;border-radius:var(--radius-pill);background-color:currentColor;opacity:.55;flex:none}.sidebar__account{margin-top:auto;display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-3) var(--space-2) 0;border-top:1px solid var(--color-border)}.sidebar__account-id{display:flex;flex-direction:column;gap:var(--space-1);min-width:0}.sidebar__account-name{font-size:var(--text-sm);font-weight:600;color:var(--color-ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__account-email{font-size:var(--text-xs);color:var(--color-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__signout{align-self:flex-start;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid var(--color-border-strong);color:var(--color-ink);font-size:var(--text-sm);font-weight:500;transition:border-color var(--duration-fast) var(--ease-standard),color var(--duration-fast) var(--ease-standard)}.sidebar__signout:hover{border-color:var(--color-accent);color:var(--color-accent-strong)}.sidebar__signout:focus-visible{outline:2px solid var(--color-accent-strong);outline-offset:2px}.app-content{display:flex;flex-direction:column;min-width:0}.app-topbar{display:flex;align-items:baseline;gap:var(--space-3);padding:var(--space-4) var(--space-8);border-bottom:1px solid var(--color-border);background-color:var(--color-surface)}.app-topbar__title{font-family:var(--font-display);font-size:var(--text-base);font-weight:600;letter-spacing:-.015em;color:var(--color-ink)}.app-topbar__tagline{font-size:var(--text-xs);letter-spacing:.06em;text-transform:uppercase;color:var(--color-muted)}.app-main{flex:1;padding:var(--space-section) var(--space-8);padding-bottom:calc(var(--footer-height) + var(--space-7))}.period-footer{position:fixed;bottom:0;left:var(--sidebar-width);right:0;height:var(--footer-height);z-index:10;display:flex;align-items:center;gap:var(--space-5);padding:0 var(--space-8);background-color:var(--color-surface-sunk);border-top:1px solid var(--color-border);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.period-footer__label{font-size:var(--text-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--color-muted)}.period-footer__controls{display:flex;align-items:center;gap:var(--space-3)}.period-select{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background-color:var(--color-surface);color:var(--color-ink);font-size:var(--text-sm);font-variant-numeric:tabular-nums;cursor:pointer;transition:border-color var(--duration-fast) var(--ease-standard)}.period-select:hover{border-color:var(--color-accent)}.period-select:focus-visible{border-color:var(--color-accent-strong);outline:2px solid var(--color-accent-strong);outline-offset:2px}.period-footer__current{margin-left:auto;font-family:var(--font-display);font-size:var(--text-base);color:var(--color-ink);text-transform:capitalize}@media (max-width: 720px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto;flex-direction:row;align-items:center;justify-content:space-between;border-right:none;border-bottom:1px solid var(--color-border)}.sidebar__nav{flex-direction:row}.sidebar__account{margin-top:0;flex-direction:row;align-items:center;gap:var(--space-3);padding:0;border-top:none}.sidebar__account-email{display:none}.period-footer{left:0}}.auth-state{min-height:100vh;display:grid;place-items:center;padding:var(--space-6) var(--space-4);background-color:var(--color-paper)}.auth-state__panel{width:100%;max-width:28rem;display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-7) var(--space-6);text-align:center;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.auth-state__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600;color:var(--color-ink)}.auth-state__text{font-size:var(--text-base);line-height:1.5;color:var(--color-muted)}.auth-state__panel--warning{border-color:var(--color-border-strong)}.auth-state__panel--warning .auth-state__title{color:var(--color-negative)}.auth-state__spinner{width:28px;height:28px;margin:0 auto;border-radius:var(--radius-pill);border:3px solid var(--color-border);border-top-color:var(--color-accent-strong);animation:auth-spin .8s linear infinite}.auth-state__retry{align-self:center;padding:var(--space-2) var(--space-5);border-radius:var(--radius-md);border:1px solid transparent;background-color:var(--color-accent-strong);color:var(--color-paper);font-size:var(--text-sm);font-weight:600;transition:background-color var(--duration-fast) var(--ease-standard),filter var(--duration-fast) var(--ease-standard)}.auth-state__retry:hover{filter:brightness(1.05)}.auth-state__retry:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.auth-state__signout{align-self:center;margin-top:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);border:1px solid var(--color-border-strong);color:var(--color-ink);font-size:var(--text-sm);font-weight:500;transition:border-color var(--duration-fast) var(--ease-standard)}.auth-state__signout:hover{border-color:var(--color-accent)}.auth-state__signout:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@keyframes auth-spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.auth-state__spinner{animation:none}}.summary{display:flex;flex-direction:column;gap:var(--space-4)}.summary__header{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--space-4)}.summary__title{font-family:var(--font-display);font-size:var(--text-xl);color:var(--color-ink)}.summary__period{margin-top:var(--space-1);font-size:var(--text-sm);color:var(--color-muted);text-transform:capitalize}.summary__table-wrap{overflow-x:auto;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.summary-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.summary-table thead th{position:sticky;top:0;padding:var(--space-3) var(--space-4);background-color:var(--color-surface-sunk);color:var(--color-muted);font-size:var(--text-xs);font-weight:600;letter-spacing:.08em;text-transform:uppercase;text-align:left;border-bottom:1px solid var(--color-border)}.summary-table tbody td,.summary-table tbody th{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);vertical-align:middle}.summary-table tbody tr:last-child td,.summary-table tbody tr:last-child th{border-bottom:none}.summary-table tbody tr{transition:background-color var(--duration-fast) var(--ease-standard)}.summary-table tbody tr:hover{background-color:var(--color-accent-soft)}.cell-category{font-weight:600;color:var(--color-ink);text-align:left;white-space:nowrap}.cell-money,.cell-planned,.summary-table thead th.cell-money,.summary-table thead th.cell-planned{text-align:right}.cell-money .money{color:var(--color-text)}.cell-saldo{font-weight:600}.saldo{display:inline-flex;align-items:baseline;gap:var(--space-2);justify-content:flex-end}.saldo__cue{font-size:.72em;line-height:1}.saldo--positive{color:var(--color-accent-strong)}.saldo--negative{color:var(--color-negative)}.saldo--neutral{color:var(--color-muted)}.summary-table tfoot th,.summary-table tfoot td{padding:var(--space-3) var(--space-4);border-top:2px solid var(--color-border-strong);background-color:var(--color-surface-sunk);font-weight:700;color:var(--color-ink)}.summary-table tfoot .cell-money .money{color:var(--color-ink)}.planned-cell{display:inline-flex;align-items:center;gap:var(--space-2);justify-content:flex-end}.planned-cell__value{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);color:var(--color-text);transition:background-color var(--duration-fast) var(--ease-standard),box-shadow var(--duration-fast) var(--ease-standard)}.planned-cell__value:hover{background-color:var(--color-surface-sunk);box-shadow:inset 0 0 0 1px var(--color-border-strong)}.planned-cell__value:focus-visible{outline:2px solid var(--color-accent-strong);outline-offset:2px}.planned-cell__badge{padding:0 var(--space-2);border-radius:var(--radius-pill);background-color:var(--color-accent-soft);color:var(--color-accent-strong);font-size:var(--text-xs);font-weight:600;letter-spacing:.02em}.planned-cell__reset{padding:0 var(--space-2);border-radius:var(--radius-pill);border:1px solid var(--color-border-strong);color:var(--color-muted);font-size:var(--text-xs);font-weight:600;transition:color var(--duration-fast) var(--ease-standard)}.planned-cell__reset:hover{color:var(--color-ink);border-color:var(--color-ink)}.planned-cell__reset:focus-visible{outline:2px solid var(--color-accent-strong);outline-offset:2px}.planned-cell__na{color:var(--color-faint)}.planned-cell__error{display:block;margin-top:var(--space-1);color:var(--color-negative);font-size:var(--text-xs)}.planned-edit{display:inline-flex;align-items:center;gap:var(--space-2);justify-content:flex-end;flex-wrap:wrap}.planned-edit__prefix{color:var(--color-muted);font-size:var(--text-sm)}.planned-edit__input{width:7rem;padding:var(--space-1) var(--space-2);border:1px solid var(--color-accent-strong);border-radius:var(--radius-sm);background-color:var(--color-surface);color:var(--color-ink);font-size:var(--text-sm);font-variant-numeric:tabular-nums;text-align:right}.planned-edit__input:focus-visible{outline:2px solid var(--color-accent-strong);outline-offset:1px}.planned-edit__input:disabled{background-color:var(--color-surface-sunk);color:var(--color-faint)}.planned-edit__status{color:var(--color-muted);font-size:var(--text-xs)}.summary__state{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-7) var(--space-5);text-align:center;background-color:var(--color-surface);border:1px dashed var(--color-border-strong);border-radius:var(--radius-lg)}.summary__state--error{border-style:solid;border-color:var(--color-negative);color:var(--color-negative)}.summary__state-note{margin:0 auto;color:var(--color-muted);font-size:var(--text-sm)}.summary__retry{align-self:center;margin-top:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-pill);background-color:var(--color-negative);color:var(--color-surface);font-size:var(--text-sm);font-weight:600;transition:filter var(--duration-fast) var(--ease-standard)}.summary__retry:hover{filter:brightness(.92)}.summary__retry:focus-visible{outline:2px solid var(--color-accent-strong);outline-offset:2px}.skeleton{display:inline-block;height:.9em;border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--color-surface-sunk) 25%,var(--color-border) 37%,var(--color-surface-sunk) 63%);background-size:400% 100%;animation:summary-shimmer 1.4s ease infinite}.skeleton--text{width:8rem}.skeleton--money{width:4.5rem}@keyframes summary-shimmer{0%{background-position:100% 50%}to{background-position:0 50%}}@media (prefers-reduced-motion: reduce){.skeleton{animation:none}.summary-table tbody tr,.planned-cell__value,.planned-cell__reset,.summary__retry{transition:none}}.member-filter{display:flex;flex-direction:column;gap:var(--space-2);border:none;padding:0;margin:0;min-width:0}.member-filter__legend{padding:0;font-size:var(--text-xs);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-muted)}.member-filter__options{display:inline-flex;flex-wrap:wrap;gap:var(--space-1);padding:var(--space-1);background-color:var(--color-surface-sunk);border:1px solid var(--color-border);border-radius:var(--radius-pill)}.member-filter__option{position:relative;display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-pill);color:var(--color-muted);font-size:var(--text-sm);font-weight:600;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--duration-fast) var(--ease-standard),background-color var(--duration-fast) var(--ease-standard),box-shadow var(--duration-fast) var(--ease-standard)}.member-filter__option:hover{color:var(--color-ink)}.member-filter__option--selected{color:var(--color-surface);background-color:var(--color-accent-strong);box-shadow:var(--shadow-sm)}.member-filter__cue{width:.5rem;height:.5rem;border-radius:var(--radius-pill);border:1.5px solid currentColor;flex:none;transition:background-color var(--duration-fast) var(--ease-standard)}.member-filter__option--selected .member-filter__cue{background-color:currentColor}.member-filter__input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.member-filter__input:focus-visible+.member-filter__cue{outline:2px solid var(--color-accent-strong);outline-offset:3px}.member-filter__option:has(.member-filter__input:focus-visible){box-shadow:0 0 0 2px var(--color-accent-soft)}.member-filter__error{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-negative)}.member-filter__retry{padding:var(--space-1) var(--space-3);border-radius:var(--radius-pill);background-color:var(--color-negative);color:var(--color-surface);font-size:var(--text-sm);font-weight:600;transition:filter var(--duration-fast) var(--ease-standard)}.member-filter__retry:hover{filter:brightness(.92)}.member-filter__retry:focus-visible{outline:2px solid var(--color-accent-strong);outline-offset:2px}@media (prefers-reduced-motion: reduce){.member-filter__option,.member-filter__cue,.member-filter__retry{transition:none}}.key-numbers{display:flex;flex-direction:column;gap:var(--space-3)}.key-numbers__grid{display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(min(100%,200px),1fr))}.key-number{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-5);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.key-number--feature{box-shadow:var(--shadow-md);border-color:var(--color-border-strong);background-image:linear-gradient(180deg,var(--color-surface) 0%,var(--color-surface-sunk) 100%)}.key-number__label{font-size:var(--text-xs);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-muted)}.key-number__value{display:inline-flex;align-items:baseline;gap:var(--space-2)}.key-number__amount{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600;color:var(--color-ink)}.key-number--feature .key-number__amount{font-size:var(--text-2xl)}.money{font-variant-numeric:tabular-nums;font-feature-settings:"tnum";letter-spacing:.01em}.key-number__cue{font-size:.7em;line-height:1}.key-number__hint{font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--color-muted)}.key-number--positive .key-number__amount,.key-number--positive .key-number__cue,.key-number--positive .key-number__hint{color:var(--color-accent-strong)}.key-number--negative .key-number__amount,.key-number--negative .key-number__cue,.key-number--negative .key-number__hint{color:var(--color-negative)}.key-number--negative.key-number--feature{background-image:linear-gradient(180deg,var(--color-surface) 0%,var(--color-negative-soft) 100%)}.key-number--positive.key-number--feature{background-image:linear-gradient(180deg,var(--color-surface) 0%,var(--color-positive-soft) 100%)}.key-numbers__note{font-size:var(--text-sm);color:var(--color-muted)}.key-numbers__state{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-6) var(--space-5);text-align:center;background-color:var(--color-surface);border:1px solid var(--color-negative);border-radius:var(--radius-lg);color:var(--color-negative)}.key-numbers__retry{align-self:center;margin-top:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-pill);background-color:var(--color-negative);color:var(--color-surface);font-size:var(--text-sm);font-weight:600;transition:filter var(--duration-fast) var(--ease-standard)}.key-numbers__retry:hover{filter:brightness(.92)}.key-numbers__retry:focus-visible{outline:2px solid var(--color-accent-strong);outline-offset:2px}.skeleton{display:inline-block;height:.9em;border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--color-surface-sunk) 25%,var(--color-border) 37%,var(--color-surface-sunk) 63%);background-size:400% 100%;animation:key-number-shimmer 1.4s ease infinite}.skeleton--number{width:7rem;height:1.6em}@keyframes key-number-shimmer{0%{background-position:100% 50%}to{background-position:0 50%}}@media (prefers-reduced-motion: reduce){.skeleton{animation:none}.key-numbers__retry{transition:none}}.chart{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-5);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.chart__header{display:flex;flex-direction:column;gap:var(--space-1)}.chart__title{font-family:var(--font-display);font-size:var(--text-lg);color:var(--color-ink)}.chart__subtitle{font-size:var(--text-sm);color:var(--color-muted)}.chart__rows{display:flex;flex-direction:column;gap:var(--space-5)}.chart-row{display:flex;flex-direction:column;gap:var(--space-2)}.chart-row__head{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-3)}.chart-row__name{font-size:var(--text-sm);font-weight:600;color:var(--color-ink)}.chart-row__flag{font-size:var(--text-xs);font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--color-negative)}.chart-row__track{display:flex;flex-direction:column;gap:var(--space-1)}.chart-bar{position:relative;display:flex;align-items:center;height:1.4rem;border-radius:var(--radius-pill);overflow:hidden}.chart-bar__fill{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;transform:scaleX(var(--bar-pct, 0));transform-origin:left center;transition:transform var(--duration-normal) var(--ease-out-expo)}.chart-bar--gasto .chart-bar__fill{background-color:var(--color-accent)}.chart-row--over .chart-bar--gasto .chart-bar__fill{background-color:var(--color-negative)}.chart-bar--planned .chart-bar__fill{background-color:var(--color-surface-sunk);box-shadow:inset 0 0 0 1.5px var(--color-border-strong)}.chart-bar__legend{position:relative;padding:0 var(--space-3);font-size:var(--text-xs);font-weight:600;letter-spacing:.02em;white-space:nowrap}.chart-bar--gasto .chart-bar__legend{color:var(--color-surface)}.chart-bar--planned .chart-bar__legend{color:var(--color-muted)}.chart-row__values{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-5)}.chart-row__value{display:inline-flex;align-items:baseline;gap:var(--space-2);font-size:var(--text-sm)}.chart-row__value .money{color:var(--color-text);text-align:right}.chart-row__value-key{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--color-muted)}.chart-row__value-key:before{content:"";width:.6rem;height:.6rem;border-radius:2px}.chart-row__value-key--gasto:before{background-color:var(--color-accent)}.chart-row--over .chart-row__value-key--gasto:before{background-color:var(--color-negative)}.chart-row__value-key--planned:before{border-radius:50%;background-color:var(--color-surface-sunk);box-shadow:inset 0 0 0 1.5px var(--color-border-strong)}.chart__state{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-6) var(--space-5);text-align:center;border:1px dashed var(--color-border-strong);border-radius:var(--radius-lg)}.chart__state--error{border-style:solid;border-color:var(--color-negative);color:var(--color-negative)}.chart__state-note{color:var(--color-muted);font-size:var(--text-sm)}.chart__retry{align-self:center;margin-top:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-pill);background-color:var(--color-negative);color:var(--color-surface);font-size:var(--text-sm);font-weight:600;transition:filter var(--duration-fast) var(--ease-standard)}.chart__retry:hover{filter:brightness(.92)}.chart__retry:focus-visible{outline:2px solid var(--color-accent-strong);outline-offset:2px}.skeleton{display:inline-block;border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--color-surface-sunk) 25%,var(--color-border) 37%,var(--color-surface-sunk) 63%);background-size:400% 100%;animation:chart-shimmer 1.4s ease infinite}.skeleton--text{width:8rem;height:.9em}.skeleton--bar{width:100%;height:1.4rem;border-radius:var(--radius-pill)}@keyframes chart-shimmer{0%{background-position:100% 50%}to{background-position:0 50%}}@media (prefers-reduced-motion: reduce){.chart-bar__fill{transition:none}.skeleton{animation:none}.chart__retry{transition:none}}.page-header{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-7)}.page-eyebrow{font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent-strong);font-weight:600}.page-period{font-size:var(--text-sm);color:var(--color-muted);text-transform:capitalize}.dashboard__toolbar{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:flex-end;gap:var(--space-4);margin-bottom:var(--space-6)}.dashboard__stack{display:flex;flex-direction:column;gap:var(--space-6)}.placeholder-grid{display:grid;gap:var(--space-5)}.placeholder-grid--dashboard{grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr))}.placeholder-card{position:relative;display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-5);background-color:var(--color-surface);border:1px dashed var(--color-border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.placeholder-card--wide{grid-column:1 / -1}.placeholder-card__tag{align-self:flex-start;font-size:var(--text-xs);letter-spacing:.06em;text-transform:uppercase;color:var(--color-faint);font-weight:600}.placeholder-card__title{font-family:var(--font-display);font-size:var(--text-lg);color:var(--color-ink)}.placeholder-card__note{font-size:var(--text-sm);color:var(--color-muted)}.placeholder-card__slice{margin-top:var(--space-2);align-self:flex-start;padding:var(--space-1) var(--space-3);border-radius:var(--radius-pill);background-color:var(--color-accent-soft);color:var(--color-accent-strong);font-size:var(--text-xs);font-weight:600}.entry-layout{display:grid;grid-template-columns:minmax(20rem,34rem) minmax(0,1fr);gap:var(--space-6);align-items:start}@media (max-width: 60rem){.entry-layout{grid-template-columns:1fr}}.entry-layout__form,.entry-layout__table{min-width:0}.entry-card{max-width:34rem;display:flex;flex-direction:column;gap:var(--space-5);padding:var(--space-6);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.entry-form{display:flex;flex-direction:column;gap:var(--space-4)}.entry-field{display:flex;flex-direction:column;gap:var(--space-2)}.entry-row{display:grid;grid-template-columns:1.4fr 1fr;gap:var(--space-4)}@media (max-width: 30rem){.entry-row{grid-template-columns:1fr}}.entry-label{font-size:var(--text-sm);font-weight:500;color:var(--color-text)}.entry-input,.entry-select{padding:var(--space-3);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background-color:var(--color-surface);color:var(--color-ink);font-size:var(--text-base);transition:border-color var(--duration-fast) var(--ease-standard)}.entry-input--amount{font-size:var(--text-lg);font-variant-numeric:tabular-nums;letter-spacing:.01em}.entry-input::placeholder{color:var(--color-faint)}.entry-input:hover,.entry-select:hover{border-color:var(--color-accent)}.entry-input:focus-visible,.entry-select:focus-visible{border-color:var(--color-accent-strong);outline:2px solid var(--color-accent-strong);outline-offset:1px}.entry-input--invalid,.entry-input--invalid:hover{border-color:var(--color-negative)}.entry-field-error{font-size:var(--text-xs);color:var(--color-negative)}.entry-segmented{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-1);padding:var(--space-1);background-color:var(--color-surface-sunk);border-radius:var(--radius-md)}.entry-segmented__option{position:relative;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;color:var(--color-muted);cursor:pointer;transition:background-color var(--duration-fast) var(--ease-standard),color var(--duration-fast) var(--ease-standard),box-shadow var(--duration-fast) var(--ease-standard)}.entry-segmented__option:hover{color:var(--color-ink)}.entry-segmented__input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.entry-segmented__input:checked+.entry-segmented__label{color:var(--color-ink);font-weight:700}.entry-segmented__option:has(.entry-segmented__input:checked){background-color:var(--color-surface);font-weight:700;box-shadow:var(--shadow-sm),inset 0 0 0 2px var(--color-border-strong)}.entry-segmented__option:has(.entry-segmented__input--gasto:checked){color:var(--color-negative)}.entry-segmented__option:has(.entry-segmented__input--receita:checked){color:var(--color-accent-strong)}.entry-segmented__option:has(.entry-segmented__input:focus-visible){outline:2px solid var(--color-accent-strong);outline-offset:2px}.entry-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}@media (max-width: 30rem){.entry-grid{grid-template-columns:1fr}}.entry-message{font-size:var(--text-sm);padding:var(--space-3);border-radius:var(--radius-md);line-height:1.4}.entry-message--error{color:var(--color-negative);background-color:var(--color-negative-soft)}.entry-message--success{color:var(--color-accent-strong);background-color:var(--color-accent-soft)}.entry-submit{margin-top:var(--space-1);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background-color:var(--color-accent-strong);color:var(--color-surface);font-size:var(--text-base);font-weight:600;cursor:pointer;transition:background-color var(--duration-fast) var(--ease-standard),opacity var(--duration-fast) var(--ease-standard)}.entry-submit:hover:not(:disabled){background-color:var(--color-accent)}.entry-submit:disabled{opacity:.6;cursor:not-allowed}.entry-hint{font-size:var(--text-xs);color:var(--color-muted)}.entry-empty{font-size:var(--text-sm);padding:var(--space-4);border-radius:var(--radius-md);background-color:var(--color-surface-sunk);color:var(--color-muted);line-height:1.5}.editable-cell{display:inline-flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.editable-cell--money,.editable-cell--editing.editable-cell--money{justify-content:flex-end}.editable-cell__trigger{display:inline-flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);color:var(--color-text);text-align:left;transition:background-color var(--duration-fast) var(--ease-standard),box-shadow var(--duration-fast) var(--ease-standard)}.editable-cell__trigger--money{justify-content:flex-end;text-align:right}.editable-cell__trigger:hover{background-color:var(--color-surface-sunk);box-shadow:inset 0 0 0 1px var(--color-border-strong)}.editable-cell__trigger:focus-visible{outline:2px solid var(--color-accent-strong);outline-offset:2px}.editable-cell__placeholder{color:var(--color-faint)}.editable-cell__prefix{color:var(--color-muted);font-size:var(--text-sm)}.editable-cell__input{padding:var(--space-1) var(--space-2);border:1px solid var(--color-accent-strong);border-radius:var(--radius-sm);background-color:var(--color-surface);color:var(--color-ink);font-size:var(--text-sm)}.editable-cell__input--money{width:7rem;font-variant-numeric:tabular-nums;font-feature-settings:"tnum";text-align:right}.editable-cell__input--date{width:9.5rem}.editable-cell__input--select{min-width:8rem}.editable-cell__input:focus-visible{outline:2px solid var(--color-accent-strong);outline-offset:1px}.editable-cell__input[aria-invalid=true]{border-color:var(--color-negative)}.editable-cell__input:disabled{background-color:var(--color-surface-sunk);color:var(--color-faint)}.editable-cell__status{color:var(--color-muted);font-size:var(--text-xs)}.editable-cell__error{display:block;flex-basis:100%;margin-top:var(--space-1);color:var(--color-negative);font-size:var(--text-xs)}@media (prefers-reduced-motion: reduce){.editable-cell__trigger{transition:none}}.tx-table-section{display:flex;flex-direction:column;gap:var(--space-4);min-width:0}.tx-table-section__header{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--space-4)}.tx-table-section__title{font-family:var(--font-display);font-size:var(--text-xl);color:var(--color-ink)}.tx-table-section__period{margin-top:var(--space-1);font-size:var(--text-sm);color:var(--color-muted);text-transform:capitalize}.tx-table-wrap{overflow-x:auto;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.tx-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.tx-table thead th{position:sticky;top:0;padding:var(--space-3) var(--space-4);background-color:var(--color-surface-sunk);color:var(--color-muted);font-size:var(--text-xs);font-weight:600;letter-spacing:.08em;text-transform:uppercase;text-align:left;white-space:nowrap;border-bottom:1px solid var(--color-border)}.tx-table tbody td,.tx-table tbody th{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border);vertical-align:middle}.tx-table tbody tr:last-child td,.tx-table tbody tr:last-child th{border-bottom:none}.tx-table tbody tr{transition:background-color var(--duration-fast) var(--ease-standard)}.tx-table tbody tr:hover{background-color:var(--color-accent-soft)}.tx-cell--date{white-space:nowrap}.tx-cell--money,.tx-table thead th.tx-cell--money{text-align:right}.tx-cell--money .money{font-variant-numeric:tabular-nums;font-feature-settings:"tnum";letter-spacing:.01em;color:var(--color-text)}.tx-cell--actions,.tx-table thead th.tx-cell--actions{text-align:right;white-space:nowrap}.tx-delete{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border-radius:var(--radius-pill);border:1px solid var(--color-border-strong);color:var(--color-muted);font-size:var(--text-xs);font-weight:600;cursor:pointer;transition:color var(--duration-fast) var(--ease-standard),border-color var(--duration-fast) var(--ease-standard),background-color var(--duration-fast) var(--ease-standard)}.tx-delete:hover{color:var(--color-negative);border-color:var(--color-negative);background-color:var(--color-negative-soft)}.tx-delete:focus-visible{outline:2px solid var(--color-accent-strong);outline-offset:2px}.tx-row-error{display:block;margin-top:var(--space-1);color:var(--color-negative);font-size:var(--text-xs)}.tx-confirm{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-3);padding:var(--space-4);background-color:var(--color-surface);border:1px solid var(--color-negative);border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.tx-confirm__text{color:var(--color-ink);font-size:var(--text-sm);line-height:1.4}.tx-confirm__actions{display:flex;gap:var(--space-2);flex-wrap:wrap}.tx-btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);border:1px solid var(--color-border-strong);background-color:var(--color-surface);color:var(--color-ink);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background-color var(--duration-fast) var(--ease-standard),filter var(--duration-fast) var(--ease-standard)}.tx-btn:hover:not(:disabled){background-color:var(--color-surface-sunk)}.tx-btn:focus-visible{outline:2px solid var(--color-accent-strong);outline-offset:2px}.tx-btn:disabled{opacity:.6;cursor:not-allowed}.tx-btn--danger{border-color:var(--color-negative);background-color:var(--color-negative);color:var(--color-surface)}.tx-btn--danger:hover:not(:disabled){background-color:var(--color-negative);filter:brightness(.92)}.tx-table-state{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-7) var(--space-5);text-align:center;background-color:var(--color-surface);border:1px dashed var(--color-border-strong);border-radius:var(--radius-lg);color:var(--color-muted)}.tx-table-state--error{border-style:solid;border-color:var(--color-negative);color:var(--color-negative)}.tx-retry{align-self:center;margin-top:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-pill);background-color:var(--color-negative);color:var(--color-surface);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:filter var(--duration-fast) var(--ease-standard)}.tx-retry:hover{filter:brightness(.92)}.tx-retry:focus-visible{outline:2px solid var(--color-accent-strong);outline-offset:2px}.tx-table .skeleton{display:inline-block;height:.9em;border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--color-surface-sunk) 25%,var(--color-border) 37%,var(--color-surface-sunk) 63%);background-size:400% 100%;animation:tx-shimmer 1.4s ease infinite}.tx-table .skeleton--text{width:6rem}.tx-table .skeleton--money{width:4.5rem}@keyframes tx-shimmer{0%{background-position:100% 50%}to{background-position:0 50%}}@media (prefers-reduced-motion: reduce){.tx-table .skeleton{animation:none}.tx-table tbody tr,.tx-delete,.tx-btn,.tx-retry{transition:none}}.manage-stack{display:flex;flex-direction:column;gap:var(--space-7);max-width:46rem}.manage-section{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-6);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.manage-section__head{display:flex;flex-direction:column;gap:var(--space-1)}.manage-section__sub{font-size:var(--text-sm);color:var(--color-muted)}.manage-list{display:flex;flex-direction:column;gap:var(--space-3)}.manage-item{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-4);background-color:var(--color-surface-sunk);border:1px solid var(--color-border);border-radius:var(--radius-md)}.manage-item--editing{display:block;background-color:var(--color-surface);border-color:var(--color-border-strong);box-shadow:inset 3px 0 0 0 var(--color-accent-strong)}.manage-item__main{display:flex;flex-direction:column;gap:var(--space-1);min-width:0}.manage-item__name{font-family:var(--font-display);font-size:var(--text-lg);color:var(--color-ink)}.manage-item__meta{font-size:var(--text-sm);color:var(--color-muted)}.manage-actions{display:flex;flex-wrap:wrap;gap:var(--space-2)}.manage-btn{padding:var(--space-2) var(--space-4);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background-color:var(--color-surface);color:var(--color-ink);font-size:var(--text-sm);font-weight:600;transition:background-color var(--duration-fast) var(--ease-standard),border-color var(--duration-fast) var(--ease-standard),color var(--duration-fast) var(--ease-standard)}.manage-btn:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent-strong)}.manage-btn:focus-visible{outline:2px solid var(--color-accent-strong);outline-offset:2px}.manage-btn:disabled{opacity:.6;cursor:not-allowed}.manage-btn--primary{align-self:flex-start;border-color:var(--color-accent-strong);background-color:var(--color-accent-strong);color:var(--color-surface)}.manage-btn--primary:hover:not(:disabled){background-color:var(--color-accent);color:var(--color-surface)}.manage-btn--danger-ghost:hover:not(:disabled){border-color:var(--color-negative);color:var(--color-negative)}.manage-btn--danger{border-color:var(--color-negative);background-color:var(--color-negative);color:var(--color-surface)}.manage-btn--danger:hover:not(:disabled){filter:brightness(1.08)}.manage-edit{display:flex;flex-direction:column;gap:var(--space-3)}.manage-edit__fields,.manage-add__fields{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}@media (max-width: 34rem){.manage-edit__fields,.manage-add__fields{grid-template-columns:1fr}}.manage-field{display:flex;flex-direction:column;gap:var(--space-2)}.manage-label{font-size:var(--text-sm);font-weight:500;color:var(--color-text)}.manage-input{padding:var(--space-3);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background-color:var(--color-surface);color:var(--color-ink);font-size:var(--text-base);transition:border-color var(--duration-fast) var(--ease-standard)}.manage-input--money{font-variant-numeric:tabular-nums;letter-spacing:.01em}.manage-input::placeholder{color:var(--color-faint)}.manage-input:hover{border-color:var(--color-accent)}.manage-input:focus-visible{border-color:var(--color-accent-strong);outline:2px solid var(--color-accent-strong);outline-offset:1px}.manage-confirm{display:flex;flex-direction:column;gap:var(--space-3);flex-basis:100%;padding:var(--space-4);border:1px solid var(--color-negative);border-radius:var(--radius-md);background-color:var(--color-negative-soft)}.manage-confirm__text{font-size:var(--text-sm);color:var(--color-text);line-height:1.5}.manage-add{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-2);padding-top:var(--space-5);border-top:1px solid var(--color-border)}.manage-add__title{font-family:var(--font-display);font-size:var(--text-lg);color:var(--color-ink)}.manage-state{font-size:var(--text-sm);padding:var(--space-4);border-radius:var(--radius-md);background-color:var(--color-surface-sunk);color:var(--color-muted);line-height:1.5}.manage-message{font-size:var(--text-sm);padding:var(--space-3);border-radius:var(--radius-md);line-height:1.4}.manage-message--error{color:var(--color-negative);background-color:var(--color-negative-soft)}.manage-message--success{color:var(--color-accent-strong);background-color:var(--color-accent-soft)}@media (prefers-reduced-motion: reduce){.manage-btn,.manage-input{transition:none}}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:var(--space-6) var(--space-4);background:radial-gradient(120% 80% at 50% -10%,var(--color-accent-soft) 0%,transparent 55%),var(--color-paper)}.auth-card{width:100%;max-width:26rem;display:flex;flex-direction:column;gap:var(--space-5);padding:var(--space-7) var(--space-6);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.auth-card__brand{display:flex;flex-direction:column;gap:var(--space-1)}.auth-card__brand-mark{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600;letter-spacing:-.015em;color:var(--color-ink)}.auth-card__brand-sub{font-size:var(--text-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--color-muted)}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-1);padding:var(--space-1);background-color:var(--color-surface-sunk);border-radius:var(--radius-md)}.auth-tab{padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;color:var(--color-muted);transition:background-color var(--duration-fast) var(--ease-standard),color var(--duration-fast) var(--ease-standard)}.auth-tab:hover{color:var(--color-ink)}.auth-tab.is-active{background-color:var(--color-surface);color:var(--color-accent-strong);font-weight:700;box-shadow:var(--shadow-sm)}.auth-card__title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:600;letter-spacing:-.02em;color:var(--color-ink);line-height:1.1}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.auth-field{display:flex;flex-direction:column;gap:var(--space-2)}.auth-label{font-size:var(--text-sm);font-weight:500;color:var(--color-text)}.auth-input{padding:var(--space-3) var(--space-3);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background-color:var(--color-surface);color:var(--color-ink);font-size:var(--text-base);transition:border-color var(--duration-fast) var(--ease-standard)}.auth-input::placeholder{color:var(--color-faint)}.auth-input:hover{border-color:var(--color-accent)}.auth-input:focus-visible{border-color:var(--color-accent-strong);outline:2px solid var(--color-accent-strong);outline-offset:1px}.auth-message{font-size:var(--text-sm);padding:var(--space-3);border-radius:var(--radius-md);line-height:1.4}.auth-message--error{color:var(--color-negative);background-color:var(--color-negative-soft)}.auth-message--notice{color:var(--color-accent-strong);background-color:var(--color-accent-soft)}.auth-submit{margin-top:var(--space-1);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background-color:var(--color-accent-strong);color:var(--color-surface);font-size:var(--text-base);font-weight:600;transition:background-color var(--duration-fast) var(--ease-standard),opacity var(--duration-fast) var(--ease-standard)}.auth-submit:hover:not(:disabled){background-color:var(--color-accent)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-switch{font-size:var(--text-sm);color:var(--color-muted);text-align:center}.auth-switch__link{color:var(--color-accent-strong);font-weight:600;text-decoration:underline;text-underline-offset:2px}.auth-switch__link:hover{color:var(--color-accent)}:root{--color-paper: oklch(98.6% .006 85);--color-surface: oklch(99.4% .004 85);--color-surface-sunk: oklch(96.5% .008 85);--color-ink: oklch(23% .012 70);--color-text: oklch(30% .012 70);--color-muted: oklch(55% .012 70);--color-faint: oklch(70% .01 70);--color-border: oklch(89% .008 75);--color-border-strong: oklch(82% .01 75);--color-accent: oklch(58% .13 162);--color-accent-strong: oklch(50% .14 162);--color-accent-soft: oklch(94% .04 162);--color-positive: var(--color-accent);--color-positive-soft: var(--color-accent-soft);--color-negative: oklch(55% .17 25);--color-negative-soft: oklch(94% .04 25);--font-display: "Iowan Old Style", "Palatino Linotype", Palatino, "Source Serif 4", Georgia, "Times New Roman", serif;--font-sans: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono: ui-monospace, "SF Mono", "Cascadia Code", Menlo, Consolas, monospace;--text-xs: clamp(.72rem, .7rem + .1vw, .78rem);--text-sm: clamp(.82rem, .79rem + .14vw, .9rem);--text-base: clamp(.95rem, .91rem + .2vw, 1.05rem);--text-lg: clamp(1.12rem, 1.05rem + .34vw, 1.3rem);--text-xl: clamp(1.45rem, 1.28rem + .8vw, 1.95rem);--text-2xl: clamp(2rem, 1.6rem + 1.8vw, 3rem);--text-display: clamp(2.6rem, 1.8rem + 3.4vw, 4.4rem);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--space-7: 3rem;--space-8: clamp(3rem, 2rem + 4vw, 6rem);--space-section: clamp(2.5rem, 1.8rem + 3vw, 5rem);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-pill: 999px;--shadow-sm: 0 1px 2px oklch(20% .02 70 / .05);--shadow-md: 0 4px 16px oklch(20% .02 70 / .07);--duration-fast: .14s;--duration-normal: .26s;--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-standard: cubic-bezier(.4, 0, .2, 1);--sidebar-width: 232px;--footer-height: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;text-size-adjust:100%}body{min-height:100vh;font-family:var(--font-sans);font-size:var(--text-base);line-height:1.55;color:var(--color-text);background-color:var(--color-paper);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}#root{min-height:100vh}h1,h2,h3{font-family:var(--font-display);color:var(--color-ink);line-height:1.08;font-weight:600;letter-spacing:-.01em}h1{font-size:var(--text-display)}h2{font-size:var(--text-xl)}h3{font-size:var(--text-lg)}p{max-width:65ch}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}input,select{font:inherit;color:inherit}ul{list-style:none}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-sm)}.tabular{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.money-positive{color:var(--color-positive)}.money-negative{color:var(--color-negative)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
