@font-face {
  font-family: "Sora";
  src: url("/assets/fonts/Sora-VariableFont_wght.ttf") format("truetype");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Cairo";
  src: url("/assets/fonts/Cairo-VariableFont_slnt,wght.ttf") format("truetype");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

:root {
  --page-bg-gradient: #f9fafb;
  --bg: #f5f7fb;
  --card: #ffffff;
  --text: #1f2937;
  --muted: #6b7280;
  --accent: #14803c;
  --accent-hover: #166534;
  --danger: #ef4444;
  --trash-red: #ef4444;
  --trash-icon-filter: invert(17%) sepia(92%) saturate(4325%) hue-rotate(351deg) brightness(92%) contrast(93%);
  --success: #22c55e;
  --border: #d1d5db;
  --app-content-max-width: 760px;
  --app-nav-expanded-width: 280px;
  --sidebar-logo-width: 143px;
  --sidebar-inline-pad: 25px;
  --sidebar-width: 300px;
  --app-header-top: 25px;
  --profile-control-size: 66px;
  --header-logo-height: 128px;
  --app-header-content-height: max(var(--profile-control-size), var(--header-logo-height));
  --app-header-height: calc(var(--app-header-content-height) + (var(--app-header-top) * 2));
  --font-ui: "Sora", "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  --font-amount: "Cairo", "Sora", "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: var(--font-ui);
  color: var(--text);
  background: var(--page-bg-gradient);
  min-height: 100vh;
}

button,
input,
select,
textarea {
  font-family: inherit;
}

html[data-paycheck-restoring-scroll="true"] body {
  visibility: hidden;
}

.auth-page {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 1rem;
}

.auth-card {
  width: 100%;
  max-width: 420px;
  background: var(--card);
  border-radius: 14px;
  padding: 2rem;
  box-shadow: 0 20px 40px rgba(15, 23, 42, 0.08);
}

.auth-two-factor-card {
  max-width: 480px;
}

.two-factor-info-card {
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #f8fafc;
  padding: 0.85rem 0.95rem;
  margin-bottom: 1rem;
}

.two-factor-qr-wrap {
  display: grid;
  place-items: center;
  margin: 0 0 0.55rem;
}

.two-factor-qr-styled {
  display: none;
}

.two-factor-qr-styled.active {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.two-factor-qr-image.qr-fallback-hidden {
  display: none;
}

.two-factor-qr-image {
  width: 220px;
  height: 220px;
  border-radius: 10px;
  border: 1px solid #dbe2ea;
  background: #ffffff;
  object-fit: contain;
}

.two-factor-otp-link {
  display: inline-flex;
  margin: 0 0 0.65rem;
  color: var(--text);
  font-size: 0.88rem;
  font-weight: 600;
  text-decoration: none;
}

.two-factor-otp-link:hover {
  color: var(--text);
  text-decoration: underline;
}

.two-factor-label {
  margin: 0 0 0.35rem;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.two-factor-key {
  margin: 0;
  font-family: var(--font-ui);
  font-size: 1.1rem;
  font-weight: 700;
  word-break: break-word;
  letter-spacing: 0.04em;
}

.two-factor-help {
  margin: 0.4rem 0 0.6rem;
  color: var(--muted);
  font-size: 0.88rem;
}

.two-factor-meta-row {
  display: grid;
  grid-template-columns: 70px 1fr;
  gap: 0.5rem;
  align-items: baseline;
  margin-top: 0.3rem;
}

.two-factor-meta-label {
  font-size: 0.75rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  font-weight: 700;
}

.two-factor-meta-value {
  font-size: 0.95rem;
  font-weight: 700;
  word-break: break-word;
}

.auth-secondary-button {
  margin-top: 0.1rem;
}

#twoFactorSetupCode,
#twoFactorVerifyCode {
  text-align: center;
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  font-family: var(--font-amount);
}

h1 {
  margin: 0 0 0.5rem;
}

.subtitle {
  margin: 0 0 1.5rem;
  color: var(--muted);
}

.auth-form {
  display: grid;
  gap: 0.65rem;
}

label {
  font-size: 0.9rem;
  font-weight: 600;
}

input {
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0.7rem 0.8rem;
  font-size: 1rem;
}

input:focus {
  outline: 2px solid #99f6e4;
  border-color: var(--accent);
}

button {
  margin-top: 0.5rem;
  border: none;
  border-radius: 10px;
  background: var(--accent);
  color: #fff;
  padding: 0.8rem;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
}

button:hover {
  background: var(--accent-hover);
}

.meta {
  margin: 1rem 0 0;
  color: var(--muted);
}

.meta a {
  color: var(--text);
}

.message {
  min-height: 1.4rem;
  margin-top: 0.9rem;
  font-weight: 600;
}

.message.error {
  color: var(--danger);
}

.message.success {
  color: var(--success);
}

.app-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: var(--sidebar-width) 1fr;
}

.app-shell[data-auth-page] {
  display: block;
  position: relative;
}

.app-sidebar {
  background: #e5e7eb;
  color: #1f2937;
  padding: 0 var(--sidebar-inline-pad);
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex;
  flex-direction: column;
  align-self: start;
  min-height: 0;
  overflow-y: auto;
}

.app-shell[data-auth-page] .app-sidebar {
  background: transparent;
  padding: 0;
  position: fixed;
  inset: 0;
  height: auto;
  overflow: visible;
  pointer-events: none;
  z-index: 40;
}

.app-brand {
  margin: 0;
  display: flex;
  justify-content: center;
  width: 100%;
  position: absolute;
  left: 0;
  top: var(--app-header-top);
  line-height: 0;
}

.app-brand-logo {
  display: block;
  width: var(--sidebar-logo-width);
  max-width: 100%;
  height: auto;
}

.app-nav {
  display: grid;
  gap: 0.7rem;
  width: calc(100% - (var(--sidebar-inline-pad) * 2));
  position: absolute;
  top: 50%;
  left: var(--sidebar-inline-pad);
  transform: translateY(-50%);
  justify-items: start;
}

.app-shell[data-auth-page] .app-nav {
  position: fixed;
  top: 50%;
  left: max(
    66px,
    calc(max(25px, ((100vw - var(--app-content-max-width)) / 2)) - 25px)
  );
  transform: translate(-100%, -50%);
  width: var(--app-nav-expanded-width);
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-items: initial;
  pointer-events: auto;
}

.app-shell[data-auth-page] .app-nav a {
  transform-origin: right center;
}

.app-nav a {
  text-decoration: none;
  width: 66px;
  height: 66px;
  padding: 0;
  border-radius: 999px;
  background: #22c55e;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  transition:
    width 0.28s cubic-bezier(0.22, 1, 0.36, 1),
    background 0.2s ease,
    box-shadow 0.2s ease;
}

.app-nav a[data-label="Budget"] {
  --app-nav-item-expanded-width: 150px;
}

.app-nav a[data-label="Transactions"] {
  --app-nav-item-expanded-width: 220px;
}

.app-nav a[data-label="Paycheck Planning"] {
  --app-nav-item-expanded-width: 270px;
}

.app-nav a[data-label="Timeline"] {
  --app-nav-item-expanded-width: 160px;
  overflow: visible;
}

.app-nav a[data-label="Accounts"] {
  --app-nav-item-expanded-width: 170px;
}

.app-nav a:hover {
  width: var(--app-nav-item-expanded-width, var(--app-nav-expanded-width));
  background: var(--accent);
  box-shadow: 0 6px 14px rgba(20, 128, 60, 0.28);
}

.app-nav a:focus-visible {
  width: var(--app-nav-item-expanded-width, var(--app-nav-expanded-width));
  outline: 2px solid #0f172a;
  outline-offset: 2px;
  box-shadow: 0 6px 14px rgba(20, 128, 60, 0.28);
}

.app-nav a.active {
  background: var(--accent);
  box-shadow: 0 6px 14px rgba(20, 128, 60, 0.28);
}

.app-nav-icon {
  width: 34px;
  height: 34px;
  display: block;
  filter: brightness(0) invert(1);
  opacity: 1;
  transform: scale(1);
  transition: opacity 0.16s ease, transform 0.22s ease;
}

.app-nav a::after {
  content: attr(data-label);
  position: absolute;
  width: 100%;
  box-sizing: border-box;
  padding: 0 10px;
  text-align: center;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) scale(0.95);
  opacity: 0;
  pointer-events: none;
  color: #ffffff;
  font-size: 1.45rem;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
  transition: opacity 0.16s ease, transform 0.22s ease;
  z-index: 2;
}

.app-nav a[data-label="Timeline"]::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 16px;
  height: 16px;
  border-radius: 999px;
  background: var(--trash-red);
  border: 3px solid #f9fafb;
  opacity: 0;
  transform: scale(0.7);
  transition: opacity 0.16s ease, transform 0.16s ease;
  z-index: 3;
}

.app-nav a[data-label="Timeline"].app-nav-has-todo::before {
  opacity: 1;
  transform: scale(1);
}

.app-nav a:hover::after,
.app-nav a:focus-visible::after {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.app-nav a:hover .app-nav-icon,
.app-nav a:focus-visible .app-nav-icon {
  opacity: 0;
  transform: scale(0.72);
}

.app-main {
  background: #f9fafb;
  padding: var(--app-header-height) 25px 25px;
  position: relative;
  --app-main-header-band-width: min(var(--app-content-max-width), calc(100% - 50px));
  --app-main-content-width: min(var(--app-content-max-width), 100%);
}

.app-shell[data-auth-page] .app-sidebar .app-brand {
  display: none;
}

.app-shell[data-auth-page] .app-main::before {
  content: "";
  position: absolute;
  top: var(--app-header-top);
  left: 50%;
  width: var(--app-main-header-band-width);
  height: var(--app-header-content-height);
  background-image: url("/assets/logo/mindlessbudget_logo.svg?v=20260225");
  background-repeat: no-repeat;
  background-position: center;
  background-size: auto var(--header-logo-height);
  transform: translateX(-50%);
  pointer-events: none;
  z-index: 20;
}

.app-shell[data-auth-page] .app-main > * {
  width: var(--app-main-content-width);
  margin-left: auto;
  margin-right: auto;
}

.app-main h2 {
  margin: 0;
  font-size: 2rem;
  line-height: 1.15;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.planning-month-heading {
  display: flex;
  align-items: center;
}

.planning-month-inline-picker {
  display: inline-flex;
  align-items: baseline;
  gap: 0.35rem;
}

.planning-month-inline-slot {
  position: relative;
  display: inline-flex;
  align-items: baseline;
}

.planning-month-inline-button {
  margin: 0;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--text);
  font: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  letter-spacing: inherit;
  cursor: pointer;
}

.planning-month-inline-button:hover,
.planning-month-inline-button:focus,
.planning-month-inline-button:focus-visible {
  background: transparent;
  color: var(--text);
  text-decoration: none;
  outline: none;
}

.planning-month-inline-menu {
  position: absolute;
  top: calc(100% + 0.35rem);
  left: 0;
  min-width: max-content;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #ffffff;
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.12);
  padding: 0.25rem;
  display: grid;
  gap: 0.1rem;
  z-index: 120;
}

.planning-month-inline-slot-month .planning-month-inline-menu {
  min-width: max(100%, var(--planning-month-menu-min-width-px, 0px));
}

.planning-month-inline-slot-year .planning-month-inline-menu-year {
  width: 100%;
  min-width: 100%;
  max-width: 100%;
  padding: 0.25rem 0;
}

.planning-month-inline-menu[hidden] {
  display: none;
}

.planning-month-inline-option {
  margin: 0;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: var(--text);
  font-size: 0.9rem;
  font-weight: 600;
  line-height: 1.2;
  text-align: left;
  white-space: nowrap;
  padding: 0.45rem 0.6rem;
  cursor: pointer;
}

.planning-month-inline-option:hover,
.planning-month-inline-option:focus,
.planning-month-inline-option:focus-visible {
  background: #f1f5f9;
  color: var(--text);
  outline: none;
}

.planning-month-inline-option.is-active {
  background: #ecfeff;
  color: var(--text);
}

.planning-month-inline-option-year {
  text-align: center;
  padding: 0.45rem 0;
}

.budget-header,
.paycheck-header,
.accounts-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  width: 100%;
}

.budget-header {
  margin-bottom: 0;
}

.budget-header-main,
.paycheck-header-main {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex: 1;
  width: 100%;
  max-width: 760px;
  min-width: 0;
  justify-content: space-between;
}

.budget-header-main {
  align-items: flex-start;
  justify-content: flex-start;
}

.paycheck-header-main {
  align-items: flex-start;
  justify-content: flex-start;
}

.budget-month-nav,
.paycheck-month-nav {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-left: auto;
}

.budget-month-nav {
  align-items: center;
  /* Center arrow controls against the month heading while keeping heading top-aligned. */
  margin-top: calc((3rem * 1.05 - 42px) / 2);
  margin-left: 0;
}

.paycheck-month-nav {
  align-items: center;
  margin-top: calc((3rem * 1.05 - 42px) / 2);
  margin-left: 0;
}

.budget-month-nav-button,
.paycheck-month-nav-button {
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--text);
}

.budget-month-nav-button:hover,
.budget-month-nav-button:focus,
.budget-month-nav-button:focus-visible,
.paycheck-month-nav-button:hover,
.paycheck-month-nav-button:focus,
.paycheck-month-nav-button:focus-visible {
  background: transparent;
  outline: none;
}

.budget-month-nav-button:disabled,
.paycheck-month-nav-button:disabled {
  color: var(--text);
  opacity: 1;
  cursor: default;
}

.budget-month-nav-button:disabled:hover,
.budget-month-nav-button:disabled:focus,
.budget-month-nav-button:disabled:focus-visible,
.paycheck-month-nav-button:disabled:hover,
.paycheck-month-nav-button:disabled:focus,
.paycheck-month-nav-button:disabled:focus-visible {
  background: transparent;
}

.budget-month-nav-icon,
.paycheck-month-nav-icon {
  width: 42px;
  height: 42px;
  display: block;
  background-color: var(--accent);
  -webkit-mask: url("/assets/icons/arrow_back_2.svg") center / contain no-repeat;
  mask: url("/assets/icons/arrow_back_2.svg") center / contain no-repeat;
}

.budget-month-nav-button:disabled .budget-month-nav-icon,
.paycheck-month-nav-button:disabled .paycheck-month-nav-icon {
  background-color: #22c55e;
  opacity: 1;
}

.budget-month-nav-icon-forward,
.paycheck-month-nav-icon-forward {
  transform: scaleX(-1);
}

.budget-month-net {
  margin: 0;
  text-align: right;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  font-size: 4rem;
  line-height: 1.05;
}

.budget-month-net-row {
  max-width: 760px;
  margin: 0.6rem 0 0.75rem;
  display: flex;
  justify-content: center;
}

.budget-month-net-row .budget-month-net {
  width: 100%;
  text-align: center;
}

#budgetMonthNet {
  font-size: 4rem !important;
  line-height: 1.05;
  align-self: flex-start;
  margin-left: auto;
  text-align: right;
}

#budgetMonth {
  font-size: 3rem !important;
  line-height: 1.05;
}

#budgetMonth .planning-month-inline-picker {
  gap: 0.65rem;
}

#transactionsMonth,
#paycheckMonth,
#timelineTitle,
#accountsTitle {
  font-size: 3rem !important;
  line-height: 1.05;
}

#transactionsMonth .planning-month-inline-picker,
#paycheckMonth .planning-month-inline-picker,
#timelineTitle .planning-month-inline-picker {
  gap: 0.65rem;
}

.budget-actions-footer {
  max-width: 760px;
  margin: 0.7rem 0 0;
  display: flex;
  justify-content: center;
}

.budget-month-net-positive {
  color: var(--accent);
}

.budget-month-net-negative {
  color: var(--trash-red);
}

.budget-month-net-neutral {
  color: var(--accent);
}

.paycheck-items-card {
  --paycheck-card-side-padding: 1rem;
  max-width: 760px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: var(--paycheck-card-side-padding);
  margin-bottom: 1rem;
}

.paycheck-items-card h3 {
  margin: 0 0 0.35rem;
}

.timeline-items-card {
  max-width: 760px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 1rem;
  margin: 0.7rem 0 1rem;
  display: grid;
  gap: 0.7rem;
}

.timeline-items-card h3 {
  margin: 0;
}

.timeline-items-subtitle {
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
  font-weight: 600;
}

.transactions-card {
  max-width: 760px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 1rem;
  margin-bottom: 1rem;
}

.transactions-card h3 {
  margin: 0 0 0.45rem;
}

.transactions-card #transactionsStatus {
  margin: 0 0 0.65rem;
  min-height: 1.2rem;
}

.transactions-card #transactionsStatus:empty {
  margin: 0;
  min-height: 0;
}

.transactions-list {
  display: grid;
  gap: 5px;
}

.transactions-table-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 124px 108px;
  gap: 0.4rem;
  padding: 0.68rem 0.95rem;
  background: #f8fafc;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.transactions-table-header span:nth-child(2),
.transactions-table-header span:nth-child(3) {
  text-align: right;
}

.transactions-row {
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #ffffff;
  padding: 0.82rem 0.95rem;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 124px 108px;
  gap: 0.55rem;
  align-items: center;
}

.transactions-row:hover {
  background: #f9fbfe;
}

.transactions-row-pending {
  background: #fffbeb;
  border-color: #fde68a;
}

.transactions-row-pending:hover {
  background: #fef3c7;
}

.transactions-title-cell {
  min-width: 0;
}

.transactions-name {
  margin: 0;
  font-size: 1.04rem;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.transactions-meta {
  margin: 0.2rem 0 0;
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.transactions-date {
  color: var(--muted);
  font-size: 0.96rem;
  font-weight: 600;
  text-align: right;
  white-space: nowrap;
}

.transactions-amount {
  font-size: 1.06rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  text-align: right;
  white-space: nowrap;
}

.transactions-amount-positive {
  color: var(--success);
}

.transactions-amount-negative {
  color: var(--trash-red);
}

.transactions-empty {
  margin: 0;
  border: 1px solid #dbe2ea;
  border-radius: 12px;
  background: #f8fafc;
  padding: 0.75rem 0.8rem;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--muted);
}

.paycheck-items-list {
  --paycheck-thermo-width: 16px;
  --paycheck-thermo-side-gap: 0.85rem;
  --paycheck-thermo-lane: calc(var(--paycheck-thermo-width) + (var(--paycheck-thermo-side-gap) * 2));
  display: grid;
  gap: 5px;
  padding-right: 0;
  width: calc(100% + var(--paycheck-card-side-padding));
  margin-right: calc(-1 * var(--paycheck-card-side-padding));
  border: none;
  border-radius: 0;
  overflow: visible;
  position: relative;
  background: transparent;
}

.paycheck-item-modal-card {
  max-width: 460px;
}

.paycheck-table-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 124px 108px;
  gap: 0.4rem;
  width: calc(100% - var(--paycheck-thermo-lane));
  padding: 0.68rem 0.95rem;
  background: #f8fafc;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.paycheck-table-header span:nth-child(2),
.paycheck-table-header span:nth-child(3) {
  text-align: right;
}

.paycheck-table-row {
  margin: 0;
  width: calc(100% - var(--paycheck-thermo-lane));
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #ffffff;
  color: var(--text);
  padding: 0.9rem 0.95rem;
  min-height: 58px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 124px 108px;
  gap: 0.55rem;
  align-items: center;
  text-align: left;
  position: relative;
  overflow: visible;
}

.paycheck-table-row:hover {
  background: #f9fbfe;
}

.paycheck-table-row-income {
  background: #ecfdf3;
  border-color: #b7ebcf;
}

.paycheck-table-row-income:hover {
  background: #e1f8eb;
}

.paycheck-table-row-overdrawn {
  border-color: #fecaca;
}

.paycheck-table-row:focus,
.paycheck-table-row:focus-visible {
  outline: 2px solid #99f6e4;
  outline-offset: -2px;
}

.paycheck-table-date {
  font-size: 0.96rem;
  color: var(--muted);
  font-weight: 600;
  text-align: right;
  white-space: nowrap;
}

.paycheck-table-name {
  font-size: 1.1rem;
  font-weight: 600;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.paycheck-table-amount {
  font-size: 1.08rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  text-align: right;
  white-space: nowrap;
}

.paycheck-table-row:not(.paycheck-table-row-income):not(.paycheck-table-row-buffer) .paycheck-table-amount {
  color: var(--trash-red);
}

.paycheck-table-row-income .paycheck-table-amount,
.paycheck-table-row-buffer .paycheck-table-amount {
  color: var(--success);
}

.paycheck-thermometer-overlay {
  position: absolute;
  left: calc(100% - var(--paycheck-thermo-width) - var(--paycheck-thermo-side-gap));
  width: var(--paycheck-thermo-width);
  border-radius: 999px;
  pointer-events: none;
  z-index: 5;
}

.paycheck-today-row {
  position: relative;
  display: flex;
  align-items: center;
  margin: 0.55rem 0;
  width: calc(100% - var(--paycheck-thermo-lane));
  padding: 14px 0.95rem;
  background: transparent;
  z-index: 95;
}

.paycheck-today-sweep-row {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 95;
  pointer-events: none;
  will-change: transform;
}

.paycheck-today-sweep-row .paycheck-today-label {
  text-transform: none;
  letter-spacing: 0.02em;
}

.paycheck-income-confetti {
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  pointer-events: none;
  user-select: none;
  z-index: 95;
  background-color: currentColor;
  -webkit-mask-image: var(--paycheck-confetti-icon);
  mask-image: var(--paycheck-confetti-icon);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
  will-change: transform, opacity;
  transform: translate(-50%, -50%) scale(1) rotate(0deg);
  opacity: 0;
  animation-name: paycheckIncomeConfettiBurst;
  animation-timing-function: cubic-bezier(0.1, 0.86, 0.28, 1);
  animation-fill-mode: forwards;
}

.paycheck-income-confetti-dollar {
  color: #22c55e;
}

.paycheck-income-confetti-moneybag {
  color: #d4af37;
}

@keyframes paycheckIncomeConfettiBurst {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%)
      scale(var(--confetti-start-scale, 0.9))
      rotate(var(--confetti-rotate-start, 0deg));
  }
  12% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    transform: translate(
        calc(-50% + var(--confetti-tx, 0px)),
        calc(-50% + var(--confetti-ty, 0px))
      )
      scale(var(--confetti-end-scale, 0.85))
      rotate(var(--confetti-rotate-end, 0deg));
  }
}

.paycheck-today-line {
  position: absolute;
  inset: 0;
  top: 50%;
  transform: translateY(-50%);
  height: 4px;
  background: transparent;
  pointer-events: none;
}

.paycheck-today-line::before,
.paycheck-today-line::after {
  content: "";
  position: absolute;
  top: 0;
  height: 100%;
  border-radius: 999px;
  background: var(--accent);
}

.paycheck-today-line::before {
  left: 0;
  right: calc(50% + (var(--paycheck-today-center-gap, 120px) / 2));
}

.paycheck-today-line::after {
  left: calc(50% + (var(--paycheck-today-center-gap, 120px) / 2));
  right: var(--paycheck-today-line-end-gap, 0px);
}

.paycheck-today-label {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  border-radius: 999px;
  background: var(--accent);
  color: #ffffff;
  padding: 0.28rem 0.88rem;
  font-size: 1.12rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
}

.paycheck-today-remaining {
  position: absolute;
  right: 0.95rem;
  top: 50%;
  transform: translateY(-50%);
  padding: 0.36rem 0;
  border-radius: 0;
  background: transparent;
  font-size: 1.48rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  white-space: nowrap;
}

.paycheck-today-remaining-positive {
  color: var(--success);
}

.paycheck-today-remaining-negative {
  color: var(--trash-red);
}

.paycheck-today-remaining.paycheck-today-remaining-primary {
  color: #14803c;
}

.paycheck-calendar {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 0.35rem;
  margin-top: 0.4rem;
}

.paycheck-calendar-weekday {
  text-align: center;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  padding: 0.1rem 0;
}

.paycheck-calendar-spacer {
  min-height: 40px;
}

.paycheck-day-button {
  margin: 0;
  width: 40px;
  height: 40px;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: #ffffff;
  color: var(--text);
  font-size: 0.9rem;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  justify-self: center;
}

.paycheck-day-button:hover {
  background: #f8fafc;
}

.paycheck-day-button.selected {
  border-color: var(--accent);
  background: var(--accent);
  color: #ffffff;
}

.paycheck-day-button.selected:hover {
  background: var(--accent);
}

.paycheck-selected-summary {
  margin: 0.65rem 0 0;
  color: var(--muted);
  font-size: 0.9rem;
  min-height: 1.3rem;
}

.paycheck-empty {
  margin: 0;
  color: var(--muted);
  font-size: 0.95rem;
}

.budget-header button,
.paycheck-header button,
.accounts-header button {
  margin-top: 0;
  white-space: nowrap;
}

.header-action-buttons {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  position: absolute;
  top: var(--app-header-top);
  right: 25px;
  z-index: 30;
}

.list-bottom-actions {
  max-width: 760px;
  margin: 0.6rem 0;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.6rem;
}

.list-bottom-actions .header-nav-icon-button {
  margin-top: 0;
}

.plaid-status-message {
  max-width: 760px;
  margin: 0 0 0.75rem;
  min-height: 1.2rem;
}

.accounts-header + .plaid-status-message:empty {
  margin: 0;
  min-height: 0;
}

.accounts-bottom-actions {
  justify-content: center;
  margin: 0.7rem 0 0;
}

.plaid-connections-card {
  max-width: 760px;
  border: none;
  background: transparent;
  padding: 0;
  margin-bottom: 0.8rem;
}

.plaid-connections-card h3 {
  margin: 0 0 0.6rem;
  font-size: 1rem;
}

.plaid-connections-empty {
  margin: 0 0 0.25rem;
  color: var(--muted);
  font-size: 0.92rem;
}

.plaid-connections-list {
  display: grid;
  gap: 0.8rem;
}

.plaid-linked-account-card {
  padding: 0.9rem 0.95rem;
}

.plaid-linked-account-row {
  grid-template-columns: minmax(0, 1fr) 108px auto;
}

.plaid-linked-account-name {
  margin: 0;
  color: var(--text);
  font-size: 1.1rem;
  font-weight: 600;
}

.plaid-linked-account-meta {
  margin: 0.2rem 0 0;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--muted);
}

.plaid-linked-account-balance {
  white-space: nowrap;
}

.remove-plaid-account-button:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.budget-actions-row {
  justify-content: space-between;
  align-items: center;
}

.budget-actions-left {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.budget-resync-icon {
  filter: invert(33%) sepia(69%) saturate(636%) hue-rotate(126deg) brightness(92%) contrast(96%);
}

.header-user-menu {
  position: relative;
  display: inline-flex;
}

.header-user-menu-panel {
  position: absolute;
  top: calc(100% + 0.25rem);
  right: 0;
  min-width: 170px;
  padding: 0.3rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #ffffff;
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.12);
  display: grid;
  gap: 0.2rem;
  z-index: 90;
}

.header-user-menu-panel[hidden] {
  display: none;
}

.header-user-menu-item {
  margin-top: 0;
  padding: 0.55rem 0.65rem;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: var(--text);
  font-size: 0.92rem;
  font-weight: 600;
  text-align: left;
}

.header-user-menu-item:hover,
.header-user-menu-item:focus,
.header-user-menu-item:focus-visible {
  background: #f1f5f9;
  color: var(--text);
  outline: none;
}

.header-user-menu-item-logout {
  color: var(--trash-red);
}

.header-user-menu-item-logout:hover,
.header-user-menu-item-logout:focus,
.header-user-menu-item-logout:focus-visible {
  background: #fef2f2;
  color: var(--trash-red);
}

.header-nav-icon-button {
  padding: 0;
  width: 56px;
  height: 56px;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 0;
  background: transparent;
}

.header-nav-icon-button[hidden] {
  display: none;
}

.header-nav-icon-button:hover,
.header-nav-icon-button:focus,
.header-nav-icon-button:focus-visible {
  background: transparent;
  box-shadow: none;
  outline: none;
}

.header-nav-icon {
  width: 48px;
  height: 48px;
  display: block;
}

.header-user-menu .header-nav-icon-button {
  width: var(--profile-control-size);
  height: var(--profile-control-size);
}

html[data-cached-user-photo="true"] .header-user-menu .header-nav-icon-button {
  background-image: var(--cached-user-photo);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  border-radius: 999px;
}

.header-user-menu .header-nav-icon {
  width: var(--profile-control-size);
  height: var(--profile-control-size);
}

html[data-cached-user-photo="true"] .header-user-menu .user-settings-icon {
  opacity: 0;
}

.add-group-icon {
  filter: none;
}

.user-settings-icon {
  filter: invert(20%) sepia(9%) saturate(888%) hue-rotate(178deg) brightness(93%) contrast(90%);
}

.user-settings-icon.user-photo {
  filter: none;
  object-fit: cover;
  border-radius: 999px;
}

.header-todo-icon {
  filter: invert(33%) sepia(69%) saturate(636%) hue-rotate(126deg) brightness(92%) contrast(96%);
  transform: scaleX(-1);
}

.header-todo-badge {
  position: absolute;
  top: 3px;
  right: 1px;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  background: var(--trash-red);
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.68rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0;
  pointer-events: none;
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.15);
}

.header-todo-badge[hidden] {
  display: none;
}

.todo-panel-overlay {
  position: fixed;
  inset: 0;
  padding: 1rem;
  background: rgba(15, 23, 42, 0.35);
  display: flex;
  justify-content: flex-end;
  z-index: 1100;
}

.todo-panel-overlay[hidden] {
  display: none;
}

.todo-panel {
  width: min(390px, 100%);
  max-height: 100%;
  overflow: auto;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: #ffffff;
  box-shadow: 0 24px 52px rgba(15, 23, 42, 0.22);
  padding: 1rem;
  display: grid;
  align-content: start;
  gap: 0.7rem;
}

.todo-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
}

.todo-panel-header h3 {
  margin: 0;
  font-size: 1.2rem;
}

.todo-panel-close {
  margin-top: 0;
  background: #e2e8f0;
  color: #0f172a;
  font-size: 0.92rem;
  padding: 0.5rem 0.75rem;
}

.todo-panel-close:hover {
  background: #cbd5e1;
}

.todo-panel-subtitle {
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
  font-weight: 600;
}

.todo-card-list {
  display: grid;
  gap: 0.55rem;
}

.todo-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.6rem;
  align-items: center;
  border: 1px solid #dbe2ea;
  border-radius: 12px;
  background: #f8fafc;
  padding: 0.75rem 0.8rem;
  cursor: pointer;
}

.todo-card-checkbox {
  -webkit-appearance: none;
  appearance: none;
  width: 30px;
  height: 30px;
  margin: 0;
  border: none;
  border-radius: 0;
  background-color: var(--success);
  -webkit-mask-image: url("/assets/icons/check_box_unchecked.svg");
  mask-image: url("/assets/icons/check_box_unchecked.svg");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
  cursor: pointer;
  flex-shrink: 0;
}

.todo-card-checkbox:checked {
  background-color: var(--success);
  -webkit-mask-image: url("/assets/icons/checkbox.svg");
  mask-image: url("/assets/icons/checkbox.svg");
}

.todo-card-checkbox:focus-visible {
  outline: 2px solid var(--success);
  outline-offset: 2px;
}

.todo-card-content {
  display: grid;
  gap: 0.2rem;
}

.todo-card-title {
  margin: 0;
  font-size: 0.94rem;
  font-weight: 700;
  color: var(--text);
  position: relative;
  display: block;
  line-height: 1.35;
}

.todo-card-subtitle {
  margin: 0;
  font-size: 0.82rem;
  color: var(--muted);
  line-height: 1.4;
}

.todo-card-completed .todo-card-subtitle {
  opacity: 0.85;
}

.todo-card-striking {
  pointer-events: none;
}

.todo-card-strike-layer {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
}

.todo-card-strike-segment {
  position: absolute;
  height: 3px;
  border-radius: 999px;
  background: #14803c;
  transform: scaleX(0);
  transform-origin: left center;
  animation: todoCardStrikeIn 0.24s ease-out forwards;
}

.todo-card-strike-segment-static {
  animation: none;
  transform: scaleX(1);
}

.todo-card-swooshing {
  animation: todoCardSwooshOut 0.34s cubic-bezier(0.22, 0.78, 0.16, 1) forwards;
}

.todo-card-swooshing .todo-card-subtitle {
  opacity: 0.85;
}

@keyframes todoCardStrikeIn {
  to {
    transform: scaleX(1);
  }
}

@keyframes todoCardSwooshOut {
  to {
    opacity: 0;
    transform: translateX(68px) scale(0.95);
  }
}

.todo-card-empty {
  margin: 0;
  border: 1px solid #dbe2ea;
  border-radius: 12px;
  background: #f8fafc;
  padding: 0.75rem 0.8rem;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--muted);
}

.todo-completed-section {
  border-top: 1px solid #e2e8f0;
  padding-top: 0.3rem;
}

.todo-completed-toggle {
  margin-top: 0;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  background: #eef2f7;
  color: #0f172a;
  padding: 0.6rem 0.72rem;
  border-radius: 10px;
  font-size: 0.88rem;
  font-weight: 700;
}

.todo-completed-toggle:hover {
  background: #e2e8f0;
}

.todo-completed-title {
  text-align: left;
}

.todo-completed-meta {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.todo-completed-count {
  min-width: 1.4rem;
  padding: 0.1rem 0.45rem;
  border-radius: 999px;
  background: #dbe2ea;
  font-size: 0.78rem;
  text-align: center;
}

.todo-completed-chevron {
  font-size: 0.82rem;
  transition: transform 0.2s ease;
}

.todo-completed-toggle.is-expanded .todo-completed-chevron {
  transform: rotate(180deg);
}

.todo-completed-body {
  padding-top: 0.55rem;
}

.budget-groups {
  display: grid;
  gap: 0;
  max-width: 760px;
}

.budget-group {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0.9rem 1rem;
}

.group-insert-row {
  height: 14px;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: height 0.15s ease, margin 0.15s ease;
}

.group-insert-row.hover-ready,
.group-insert-row:focus-within {
  height: 63px;
  margin: 0.2rem 0;
}

.between-section-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  opacity: 0;
  transform: translateY(-2px);
  pointer-events: none;
  transition: opacity 0.15s ease, transform 0.15s ease;
}

.group-insert-row.hover-ready .between-section-actions,
.group-insert-row:focus-within .between-section-actions {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.between-section-action {
  margin-top: 0;
  padding: 0;
  width: 33px;
  height: 33px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 0;
  background: transparent;
}

.between-section-action:hover,
.between-section-action:focus,
.between-section-action:focus-visible {
  background: transparent;
  box-shadow: none;
  outline: none;
}

.between-section-icon {
  width: 30px;
  height: 30px;
  display: block;
}

.group-gap-add .group-gap-action-icon {
  filter: none;
}

.group-gap-edit .group-gap-action-icon {
  filter: none;
}

.group-gap-delete .group-gap-action-icon {
  filter: none;
}

.budget-group-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.budget-group-title {
  margin: 0;
  font-size: 1.02rem;
}

.add-item-button {
  margin-top: 0;
  padding: 0;
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 0;
  background: transparent;
  color: var(--text);
}

.add-item-button:hover,
.add-item-button:focus,
.add-item-button:focus-visible {
  background: transparent;
  box-shadow: none;
  outline: none;
}

.add-item-icon {
  width: 22px;
  height: 22px;
  display: block;
  filter: none;
}

.budget-item-list {
  --budget-item-text-size: 0.95rem;
  --budget-item-amount-size: 1rem;
  margin: 0.7rem 0 0;
  padding-left: 0;
  list-style: none;
}

.budget-item {
  margin-bottom: 0.35rem;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.75rem;
  padding: 0.45rem 0;
  border-bottom: 1px solid #e5e7eb;
  cursor: grab;
}

.budget-item.dragging {
  opacity: 0.45;
}

.budget-item.drop-before {
  border-top: 2px solid #9ca3af;
}

.budget-item.drop-after {
  border-bottom: 2px solid #9ca3af;
}

.budget-group.drop-target {
  outline: 1px dashed #94a3b8;
  outline-offset: 3px;
}

.budget-item-columns {
  display: grid;
  grid-template-columns: 1fr 120px;
  gap: 0.75rem;
  padding: 0.2rem 0 0.4rem;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--muted);
  text-transform: uppercase;
}

.budget-item-columns span:nth-child(2) {
  text-align: right;
}

.item-name-cell {
  display: flex;
  align-items: center;
}

.item-name-display {
  appearance: none;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  color: var(--text);
  padding: 0;
  font-weight: 400;
  font-size: var(--budget-item-text-size);
  text-align: left;
}

.item-name-display:hover {
  text-decoration: none;
  background: transparent;
  color: var(--text);
  cursor: pointer;
}

.item-name-display:active {
  background: transparent;
  color: var(--text);
}

.item-name-display:focus,
.item-name-display:focus-visible {
  outline: none;
  box-shadow: none;
}

.unlinked-item-icon {
  width: 1rem;
  height: 1rem;
  flex: 0 0 auto;
  filter: none;
}

.item-name-editor {
  display: flex;
  align-items: center;
  gap: 0;
}

.item-name-editor[hidden] {
  display: none;
}

.item-name-input {
  width: 200px;
  padding: 0.4rem 0.5rem;
  border-radius: 8px;
  border: 1px solid var(--border);
}

.item-name-input:focus,
.item-name-input:focus-visible {
  outline: none;
  border-color: var(--border);
  box-shadow: none;
}

.budgeted-cell {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-end;
  gap: 0.3rem;
}

.budgeted-display {
  margin: 0;
  border: none;
  background: transparent;
  color: var(--text);
  padding: 0;
  display: inline-flex;
  align-items: center;
  line-height: 1;
  font-size: var(--budget-item-amount-size);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

.budgeted-display:hover {
  text-decoration: none;
  background: transparent;
  color: var(--text);
}

.budgeted-display:focus,
.budgeted-display:focus-visible {
  outline: none;
  box-shadow: none;
}

.budget-start-next-indicator {
  margin-top: 0;
  padding: 0;
  width: 24px;
  height: 24px;
  border: none;
  border-radius: 0;
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  flex: 0 0 auto;
}

.budget-start-next-indicator:hover,
.budget-start-next-indicator:focus,
.budget-start-next-indicator:focus-visible {
  background: transparent;
  box-shadow: none;
  outline: none;
}

.budget-start-next-icon {
  width: 21px;
  height: 21px;
  display: block;
  filter: none;
}

.budget-start-next-tooltip {
  position: absolute;
  right: 0;
  bottom: calc(100% + 8px);
  padding: 0.32rem 0.5rem;
  border-radius: 8px;
  border: 1px solid #fcd34d;
  background: #fffbeb;
  color: #111827;
  font-size: 0.74rem;
  font-weight: 700;
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transform: translateY(4px);
  transition: opacity 0.14s ease, transform 0.14s ease, visibility 0.14s ease;
  z-index: 22;
}

.budget-start-next-indicator:hover .budget-start-next-tooltip,
.budget-start-next-indicator:focus .budget-start-next-tooltip,
.budget-start-next-indicator:focus-visible .budget-start-next-tooltip {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.budgeted-editor {
  display: flex;
  align-items: center;
  gap: 0;
}

.budgeted-editor[hidden] {
  display: none;
}

.budgeted-input {
  width: 110px;
  padding: 0.45rem 0.55rem;
  border-radius: 8px;
  border: 1px solid var(--border);
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.budgeted-input:focus,
.budgeted-input:focus-visible {
  outline: none;
  border-color: var(--border);
  box-shadow: none;
}

.budgeted-input::-webkit-outer-spin-button,
.budgeted-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.budgeted-input[type="number"] {
  -moz-appearance: textfield;
  appearance: textfield;
}

.budget-item-empty {
  color: var(--muted);
  margin: 0;
  margin-left: 0;
  border: none;
  background: transparent;
  font-size: inherit;
  font-style: italic;
  text-align: left;
  padding: 0;
  width: auto;
  display: inline;
  cursor: pointer;
}

.budget-item-empty:hover,
.budget-item-empty:focus,
.budget-item-empty:focus-visible,
.budget-item-empty:active {
  background: transparent;
  color: var(--muted);
  box-shadow: none;
  outline: none;
  text-decoration: none;
}

.budget-total-row {
  margin-top: 0.4rem;
  padding-top: 0.55rem;
  border-top: 1px solid #d1d5db;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.75rem;
  font-weight: 700;
}

.budget-total-row span:nth-child(2) {
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.45);
  display: grid;
  place-items: center;
  padding: 1rem;
  z-index: 1000;
}

.modal-overlay[hidden] {
  display: none;
}

.modal-card {
  width: 100%;
  max-width: 460px;
  background: #ffffff;
  border-radius: 14px;
  border: 1px solid #d1d5db;
  box-shadow: 0 25px 60px rgba(15, 23, 42, 0.2);
  padding: 1.25rem;
}

.modal-card h3 {
  margin: 0 0 0.4rem;
}

.modal-subtitle {
  margin: 0 0 1rem;
  color: var(--muted);
}

.account-type-actions {
  display: grid;
  gap: 0.55rem;
}

.account-type-actions button {
  margin-top: 0;
}

.account-confirm-message {
  margin-bottom: 1.05rem;
}

.account-confirm-reassign {
  display: grid;
  gap: 0.4rem;
  margin-bottom: 0.8rem;
}

.account-confirm-reassign[hidden] {
  display: none;
}

.account-confirm-reassign label {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--text);
}

.account-confirm-reassign select {
  margin: 0;
}

.modal-form {
  display: grid;
  gap: 0.55rem;
}

.modal-form input,
.modal-form select {
  margin-bottom: 0.4rem;
}

.modal-form select,
.account-confirm-reassign select {
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0.7rem 2.2rem 0.7rem 0.8rem;
  font-size: 1rem;
  color: var(--text);
  background-color: #fff;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  cursor: pointer;
  background-image:
    linear-gradient(45deg, transparent 50%, #64748b 50%),
    linear-gradient(135deg, #64748b 50%, transparent 50%);
  background-position:
    calc(100% - 16px) calc(50% - 2px),
    calc(100% - 11px) calc(50% - 2px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}

.modal-form select:focus,
.modal-form select:focus-visible,
.account-confirm-reassign select:focus,
.account-confirm-reassign select:focus-visible {
  outline: 2px solid #99f6e4;
  border-color: var(--accent);
}

#accountModalGoalAmountWrap {
  display: grid;
  gap: 0.55rem;
}

#accountModalGoalAmountWrap[hidden] {
  display: none !important;
}

.set-aside-fields {
  display: grid;
  gap: 0.55rem;
  padding-top: 0.1rem;
}

.set-aside-fields[hidden] {
  display: none;
}

.set-aside-amount-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 0.55rem;
  align-items: start;
}

.set-aside-amount-field {
  display: grid;
  gap: 0.1rem;
}

.set-aside-amount-field input {
  width: 100%;
}

.set-aside-date-row {
  display: block;
}

.set-aside-date-row #itemModalTargetDate {
  display: block;
  width: 100%;
  margin-bottom: 0;
}

.set-aside-checkbox-row {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin: 0.05rem 0 0.2rem;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
}

.set-aside-checkbox-row input[type="checkbox"] {
  width: 16px;
  height: 16px;
  margin: 0;
  accent-color: var(--accent);
}

@media (max-width: 560px) {
  .set-aside-amount-row {
    grid-template-columns: 1fr;
  }
}

.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.6rem;
  margin-top: 0.35rem;
}

.modal-actions button {
  margin-top: 0;
}

.item-modal-delete-button {
  margin-right: auto;
  min-width: 0;
  padding: 0;
  border: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  color: var(--trash-red);
  box-shadow: none;
}

.item-modal-delete-button:hover,
.item-modal-delete-button:focus,
.item-modal-delete-button:focus-visible,
.item-modal-delete-button:active {
  background: transparent;
  box-shadow: none;
  outline: none;
}

.item-modal-delete-icon {
  width: 48px;
  height: 48px;
  display: block;
}

.item-modal-delete-button.modal-danger,
.item-modal-delete-button.modal-danger:hover,
.item-modal-delete-button.modal-danger:focus,
.item-modal-delete-button.modal-danger:focus-visible,
.item-modal-delete-button.modal-danger:active {
  background: transparent;
  color: var(--trash-red);
  box-shadow: none;
  outline: none;
}

.modal-secondary {
  background: #e2e8f0;
  color: #0f172a;
}

.modal-secondary:hover {
  background: #cbd5e1;
}

.modal-danger {
  background: var(--trash-red);
}

.modal-danger:hover {
  background: var(--danger);
}

.accounts-grid {
  display: grid;
  gap: 0;
  max-width: 760px;
  --account-drop-gap: 14px;
}

.account-insert-row {
  height: 14px;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: height 0.15s ease, margin 0.15s ease;
}

.account-insert-row.hover-ready,
.account-insert-row:focus-within {
  height: 63px;
  margin: 0.2rem 0;
}

.account-insert-row.hover-ready .between-section-actions,
.account-insert-row:focus-within .between-section-actions {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.account-gap-add .account-gap-action-icon {
  filter: none;
}

.account-gap-edit .account-gap-action-icon {
  filter: none;
}

.account-gap-delete .account-gap-action-icon {
  filter: none;
}

.settings-card {
  max-width: 760px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 1rem;
  margin-bottom: 1rem;
}

.account-settings-card {
  max-width: 760px;
}

.account-settings-form {
  display: grid;
  gap: 0.1rem;
}

#accountSettingsStatus {
  margin-top: 0.5rem;
}

#accountSettingsStatus:empty {
  display: none;
}

.profile-avatar-wrap {
  display: grid;
  place-items: center;
  margin-bottom: 0.5rem;
}

.profile-avatar-button {
  margin-top: 0;
  width: 86px;
  height: 86px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.profile-avatar-button:hover {
  background: #f8fafc;
}

.profile-avatar-button:focus,
.profile-avatar-button:focus-visible {
  outline: 2px solid #99f6e4;
  border-color: var(--accent);
}

.profile-avatar-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.photo-crop-card {
  max-width: 420px;
}

.photo-options-card {
  max-width: 360px;
  text-align: center;
}

.photo-options-preview-wrap {
  display: grid;
  place-items: center;
  margin: 0.1rem 0 0.35rem;
}

.photo-options-preview {
  width: 96px;
  height: 96px;
  border-radius: 999px;
  border: 1px solid var(--border);
  object-fit: cover;
  background: #ffffff;
}

.photo-options-label {
  margin: 0 0 0.85rem;
  color: var(--text);
  font-size: 1.15rem;
  font-weight: 700;
}

.photo-options-actions {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.85rem;
}

.photo-options-icon-button {
  margin-top: 0;
  padding: 0;
  width: 38px;
  height: 38px;
  border-radius: 0;
  border: none;
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.photo-options-icon-button:hover,
.photo-options-icon-button:focus,
.photo-options-icon-button:focus-visible {
  background: transparent;
  box-shadow: none;
  outline: none;
}

.photo-options-icon-button:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.photo-options-icon {
  width: 28px;
  height: 28px;
  display: block;
}

.photo-options-add-icon {
  filter: invert(33%) sepia(69%) saturate(636%) hue-rotate(126deg) brightness(92%) contrast(96%);
}

.photo-options-remove-icon {
  filter: var(--trash-icon-filter);
}

.photo-options-cancel-icon {
  filter: invert(21%) sepia(7%) saturate(874%) hue-rotate(177deg) brightness(90%) contrast(89%);
}

.password-modal-card {
  max-width: 460px;
}

.two-factor-profile-modal {
  max-width: 460px;
}

.two-factor-profile-modal h3,
.two-factor-profile-modal .modal-subtitle {
  text-align: center;
}

.two-factor-profile-modal .modal-subtitle {
  margin-bottom: 0.8rem;
}

.two-factor-profile-modal .two-factor-info-card {
  border: none;
  border-radius: 0;
  background: transparent;
  padding: 0;
  margin-bottom: 0.85rem;
}

.two-factor-profile-modal .two-factor-qr-wrap {
  margin: 0 0 0.6rem;
}

.two-factor-profile-modal .two-factor-qr-image {
  width: 260px;
  height: 260px;
  padding: 10px;
  border-radius: 24px;
  border: 1px solid #99f6e4;
  background: #ffffff;
  box-shadow: 0 10px 24px rgba(15, 118, 110, 0.12);
}

.two-factor-profile-modal .two-factor-qr-styled {
  width: 260px;
  height: 260px;
  padding: 10px;
  border-radius: 24px;
  border: 1px solid #99f6e4;
  background: #ffffff;
  box-shadow: 0 10px 24px rgba(15, 118, 110, 0.12);
}

.two-factor-profile-modal .two-factor-qr-styled canvas,
.two-factor-profile-modal .two-factor-qr-styled svg {
  width: 100% !important;
  height: 100% !important;
  border-radius: 16px;
}

.two-factor-profile-modal .two-factor-otp-link {
  color: var(--text);
  font-weight: 700;
  margin-bottom: 0.75rem;
}

.two-factor-profile-modal .two-factor-otp-link:hover {
  color: var(--text);
}

.two-factor-profile-modal .two-factor-label,
.two-factor-profile-modal .two-factor-meta-label {
  color: var(--text);
}

.two-factor-profile-modal .two-factor-key {
  line-height: 1.28;
}

.two-factor-profile-modal .two-factor-label {
  margin-bottom: 0.2rem;
}

.two-factor-setup-key-actions {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  margin: 0.1rem 0 0.35rem;
}

.two-factor-text-button {
  margin: 0;
  padding: 0.2rem 0.35rem;
  border: none;
  border-radius: 6px;
  background: transparent;
  color: var(--text);
  font-size: 0.83rem;
  font-weight: 700;
}

.two-factor-text-button:hover {
  background: #ecfdf5;
  color: var(--text);
}

.two-factor-key-wrap {
  text-align: center;
}

#twoFactorSetupModalCode,
#twoFactorDisableCode {
  text-align: center;
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  font-family: var(--font-amount);
}

.password-modal-message {
  margin-top: 0.4rem;
}

#photoCropCanvas {
  width: 100%;
  max-width: 320px;
  height: auto;
  aspect-ratio: 1 / 1;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: #0f172a;
  display: block;
  margin: 0 auto 0.8rem;
  cursor: grab;
  touch-action: none;
}

#photoCropCanvas:active {
  cursor: grabbing;
}

.photo-crop-controls {
  display: grid;
  gap: 0.7rem;
  margin-bottom: 0.85rem;
}

.photo-crop-controls label {
  font-size: 0.95rem;
}

#photoCropZoom {
  --photo-crop-thumb-size: 20px;
  width: 100%;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  appearance: none;
  -webkit-appearance: none;
  background: transparent;
  box-shadow: none;
}

#photoCropZoom::-webkit-slider-runnable-track {
  height: 8px;
  border-radius: 999px;
  background: #e2e8f0;
}

#photoCropZoom::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: var(--photo-crop-thumb-size);
  height: var(--photo-crop-thumb-size);
  margin-top: calc((8px - var(--photo-crop-thumb-size)) / 2);
  border-radius: 999px;
  border: 2px solid #ffffff;
  background: var(--accent);
  box-shadow: none;
}

#photoCropZoom::-moz-range-track {
  height: 8px;
  border-radius: 999px;
  background: #e2e8f0;
}

#photoCropZoom::-moz-range-thumb {
  width: var(--photo-crop-thumb-size);
  height: var(--photo-crop-thumb-size);
  border: 2px solid #ffffff;
  border-radius: 999px;
  background: var(--accent);
  box-shadow: none;
}

#photoCropZoom:focus,
#photoCropZoom:focus-visible {
  outline: none;
}

.photo-crop-card .modal-actions {
  margin-top: 0;
  padding-top: 0.2rem;
}

.settings-form button {
  margin-top: 0.85rem;
}

.member-since-text {
  margin: 0.35rem 0 0;
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 600;
}

.two-factor-settings {
  margin-top: 0.2rem;
  padding: 0.65rem 0.05rem 0.2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
}

.two-factor-settings-copy {
  display: grid;
  gap: 0.2rem;
}

.two-factor-settings-title {
  margin: 0;
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--text);
}

.two-factor-settings-status {
  margin: 0;
  font-size: 0.84rem;
  color: var(--muted);
  font-weight: 600;
}

.two-factor-toggle {
  position: relative;
  display: inline-flex;
  width: 52px;
  height: 30px;
  cursor: pointer;
}

.two-factor-toggle input {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.two-factor-toggle-slider {
  width: 100%;
  height: 100%;
  border-radius: 999px;
  border: 1px solid #cbd5e1;
  background: #e2e8f0;
  transition: background-color 0.18s ease, border-color 0.18s ease;
}

.two-factor-toggle-slider::after {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: #ffffff;
  box-shadow: 0 1px 4px rgba(15, 23, 42, 0.22);
  transition: transform 0.18s ease;
}

.two-factor-toggle input:checked + .two-factor-toggle-slider {
  background: #ccfbf1;
  border-color: #5eead4;
}

.two-factor-toggle input:checked + .two-factor-toggle-slider::after {
  transform: translateX(22px);
}

.two-factor-toggle input:focus + .two-factor-toggle-slider,
.two-factor-toggle input:focus-visible + .two-factor-toggle-slider {
  outline: 2px solid #99f6e4;
  outline-offset: 2px;
}

.change-password-text {
  margin: 0.1rem 0 0.15rem;
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 600;
}

#profilePasswordTrigger {
  cursor: pointer;
  letter-spacing: 0.14em;
  font-family: var(--font-ui);
}

.budget-month-net,
.budgeted-display,
.budgeted-input,
.budget-total-row span:nth-child(2),
.account-amount-input,
.paycheck-table-amount,
.paycheck-today-remaining,
#itemModalAmount,
#itemModalDebtBalance,
#itemModalMinimumPayment,
#itemModalGoalAmount,
#itemModalExistingAmount,
#accountAmountModalAmount,
#emergencyFundModalExistingAmount,
#emergencyFundModalGoalAmount,
#paycheckBufferAmount {
  font-family: var(--font-amount);
}

.account-modal-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  margin-top: 0.35rem;
}

.account-modal-updated-at {
  margin: 0;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--muted);
}

.account-modal-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
}

.account-modal-actions button {
  margin-top: 0;
}

#profilePasswordTrigger:hover {
  background: #ffffff;
}

#profilePasswordTrigger:focus,
#profilePasswordTrigger:focus-visible {
  outline: 2px solid #99f6e4;
  border-color: var(--accent);
}

#profilePasswordTrigger::selection {
  background: transparent;
}

.settings-actions {
  display: flex;
  justify-content: center;
  gap: 0.6rem;
  align-items: center;
  padding-bottom: 0.75rem;
}

.settings-actions button {
  margin-top: 0.85rem;
}

.sign-out-button {
  background: #ef4444;
  min-width: 180px;
}

.sign-out-button:hover {
  background: #ef4444;
}

#profileMessage {
  min-height: 0;
  margin-top: 0;
}

#profileMessage:empty {
  display: none;
}

#profileMessage:not(:empty) {
  display: block;
  margin-top: 0.65rem;
}

.account-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 1rem;
  cursor: grab;
}

.account-card.dragging {
  opacity: 0.45;
}

.account-card.drop-marker-top {
  border-top: 4px solid var(--accent);
}

.account-card.drop-marker-bottom {
  border-bottom: 4px solid var(--accent);
}

.account-card.drop-gap-before {
  margin-top: var(--account-drop-gap);
}

.account-card.drop-gap-after {
  margin-bottom: var(--account-drop-gap);
}

.account-card h3 {
  margin: 0;
  font-size: 1rem;
}

.account-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 108px auto;
  gap: 0.55rem;
  align-items: center;
  min-height: 58px;
}

.account-card + .account-card {
  margin-top: 0;
}

.accounts-grid .account-card {
  padding: 0.9rem 0.95rem;
}

.emergency-fund-progress-wrap {
  margin-top: 0.35rem;
}

.emergency-fund-progress-track {
  position: relative;
  width: 100%;
  height: 12px;
  border-radius: 999px;
  background: #e2e8f0;
  overflow: hidden;
}

.emergency-fund-progress-fill {
  height: 100%;
  border-radius: 999px;
  background: #22c55e;
  transition: width 0.2s ease;
}

.credit-paydown-progress-wrap {
  margin-top: 0.35rem;
}

.credit-paydown-progress-track {
  position: relative;
  width: 100%;
  height: 12px;
  border-radius: 999px;
  background: #e5e7eb;
  overflow: hidden;
}

.credit-paydown-progress-fill {
  position: absolute;
  inset: 0;
  border-radius: 999px;
  background: linear-gradient(90deg, #ef4444 0%, #22c55e 100%);
  clip-path: inset(0 calc(100% - var(--credit-paydown-progress, 0%)) 0 0 round 999px);
  transition: clip-path 0.2s ease;
}

.account-name-cell,
.account-amount-cell {
  align-items: center;
}

.account-name-cell {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.25rem;
}

.account-name-display {
  appearance: none;
  margin: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  color: var(--text);
  padding: 0;
  font-weight: 600;
  font-size: 1.1rem;
  text-align: left;
  flex: 0 0 auto;
}

.account-name-display:hover {
  background: transparent;
  color: var(--text);
  cursor: pointer;
}

.account-name-display:focus,
.account-name-display:focus-visible {
  outline: none;
  box-shadow: none;
}

.account-name-mask-suffix {
  font-family: var(--font-ui);
  font-weight: 350;
  font-size: 0.92rem;
  line-height: 1;
  letter-spacing: 0;
  font-variant-numeric: tabular-nums;
  color: inherit;
}

.account-name-editor {
  display: flex;
  align-items: center;
  flex: 0 0 auto;
}

.account-name-editor[hidden] {
  display: none;
}

.account-name-input {
  width: 210px;
  padding: 0.4rem 0.5rem;
  border-radius: 8px;
  border: 1px solid var(--border);
}

.account-name-input:focus,
.account-name-input:focus-visible {
  outline: none;
  border-color: var(--border);
  box-shadow: none;
}

.account-amount-cell {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 0.35rem;
}

.account-amount-display {
  margin: 0;
  border: none;
  background: transparent;
  color: var(--text);
  padding: 0;
  font-family: var(--font-amount);
  font-size: 1.08rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  line-height: 1;
}

.account-amount-display:hover {
  background: transparent;
  color: var(--text);
  cursor: pointer;
}

.account-amount-display:focus,
.account-amount-display:focus-visible {
  outline: none;
  box-shadow: none;
}

.account-amount-display-linked,
.account-amount-display-linked:hover,
.account-amount-display-linked:focus,
.account-amount-display-linked:focus-visible {
  color: var(--text) !important;
  -webkit-text-fill-color: var(--text);
  opacity: 1;
  cursor: default;
  background: transparent;
  box-shadow: none;
  outline: none;
}

.account-amount-display-linked.account-amount-display-credit,
.account-amount-display-linked.account-amount-display-credit:hover,
.account-amount-display-linked.account-amount-display-credit:focus,
.account-amount-display-linked.account-amount-display-credit:focus-visible {
  color: var(--trash-red) !important;
  -webkit-text-fill-color: var(--trash-red);
}

.account-reconcile-indicator {
  margin-top: 0;
  padding: 0;
  width: 30px;
  height: 30px;
  border: none;
  border-radius: 0;
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  flex: 0 0 auto;
}

.account-reconcile-indicator:hover,
.account-reconcile-indicator:focus,
.account-reconcile-indicator:focus-visible {
  background: transparent;
  box-shadow: none;
  outline: none;
}

.account-reconcile-icon {
  width: 22px;
  height: 22px;
  display: block;
}

.account-reconcile-match .account-reconcile-icon {
  filter: brightness(0) saturate(100%) invert(61%) sepia(79%) saturate(476%) hue-rotate(87deg) brightness(91%) contrast(89%);
}

.account-reconcile-too-much .account-reconcile-icon {
  filter: brightness(0) saturate(100%) invert(68%) sepia(71%) saturate(1599%) hue-rotate(10deg) brightness(96%) contrast(92%);
}

.account-reconcile-too-little .account-reconcile-icon {
  filter: brightness(0) saturate(100%) invert(43%) sepia(88%) saturate(1740%) hue-rotate(330deg) brightness(100%) contrast(88%);
}

.account-reconcile-tooltip {
  position: absolute;
  right: -6px;
  bottom: calc(100% + 8px);
  padding: 0.35rem 0.55rem;
  border-radius: 8px;
  border: 1px solid #fcd34d;
  background: #fffbeb;
  color: #111827;
  font-size: 0.74rem;
  font-weight: 700;
  line-height: 1.2;
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transform: translateY(4px);
  transition: opacity 0.14s ease, transform 0.14s ease, visibility 0.14s ease;
  z-index: 25;
}

.account-reconcile-too-little .account-reconcile-tooltip {
  border-color: #fca5a5;
  background: #fef2f2;
}

.account-reconcile-indicator:hover .account-reconcile-tooltip,
.account-reconcile-indicator:focus .account-reconcile-tooltip,
.account-reconcile-indicator:focus-visible .account-reconcile-tooltip {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.account-amount-editor {
  display: flex;
  align-items: center;
}

.account-amount-editor[hidden] {
  display: none;
}

.account-amount-input {
  width: 110px;
  padding: 0.45rem 0.55rem;
  border-radius: 8px;
  border: 1px solid var(--border);
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.account-amount-input:focus,
.account-amount-input:focus-visible {
  outline: none;
  border-color: var(--border);
  box-shadow: none;
}

.modal-form input:disabled {
  background: #e2e8f0;
  color: #64748b;
  cursor: not-allowed;
}

.modal-form input:disabled.account-modal-linked-amount {
  color: var(--text);
  -webkit-text-fill-color: var(--text);
  opacity: 1;
}

.remove-account-button {
  margin-top: 0;
  padding: 0;
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 0;
  background: transparent;
  color: var(--trash-red);
  justify-self: end;
}

.remove-account-button:hover {
  background: transparent;
}

.remove-account-icon {
  width: 22px;
  height: 22px;
  display: block;
  fill: currentColor;
}

.account-expand-toggle {
  margin-top: 0;
  padding: 0;
  width: 30px;
  height: 30px;
  border: none;
  border-radius: 0;
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}

.account-expand-toggle:hover,
.account-expand-toggle:focus,
.account-expand-toggle:focus-visible {
  background: transparent;
  box-shadow: none;
  outline: none;
}

.account-expand-icon {
  width: 22px;
  height: 22px;
  display: block;
  transition: transform 0.16s ease;
}

.account-card.expanded .account-expand-icon {
  transform: rotate(180deg);
}

.account-breakdown {
  margin-top: 0.65rem;
  padding-top: 0.6rem;
  border-top: 1px solid #e2e8f0;
  display: grid;
  gap: 0;
}

.account-breakdown-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.75rem;
  padding: 0.45rem 0;
  border-bottom: 1px solid #e5e7eb;
}

.account-breakdown-total-row {
  margin-top: 0.2rem;
  padding-top: 0.55rem;
  border-top: 1px solid #d1d5db;
  border-bottom: none;
}

.account-breakdown-total-row .account-breakdown-item,
.account-breakdown-total-row .account-breakdown-amount {
  font-weight: 700;
}

.account-breakdown-item {
  color: var(--text);
  font-size: var(--budget-item-text-size);
  font-weight: 400;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.account-breakdown-category {
  display: none;
}

.account-breakdown-amount {
  color: var(--text);
  font-family: var(--font-amount);
  font-size: var(--budget-item-amount-size);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  text-align: right;
  white-space: nowrap;
}

.account-breakdown-empty {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 500;
}

.account-on-hold-row {
  grid-template-columns: minmax(0, 1fr) auto auto;
}

.account-on-hold-cleared-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  user-select: none;
}

.account-on-hold-cleared-checkbox {
  width: 14px;
  height: 14px;
  margin: 0;
  accent-color: var(--accent);
}

.account-on-hold-total-spacer {
  width: 68px;
}

@media (max-width: 760px) {
  .app-shell {
    grid-template-columns: 1fr;
    height: auto;
  }

  .app-sidebar {
    padding: 1rem;
    position: static;
    top: auto;
    height: auto;
    min-height: auto;
    overflow: visible;
  }

  .app-nav {
    grid-auto-flow: column;
    overflow-x: auto;
    gap: 0.4rem;
  }

  .paycheck-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .paycheck-table-header,
  .paycheck-table-row {
    grid-template-columns: minmax(0, 1fr) 106px 90px;
    gap: 0.45rem;
  }

  .transactions-table-header,
  .transactions-row {
    grid-template-columns: minmax(0, 1fr) 106px 90px;
    gap: 0.45rem;
  }

  .paycheck-today-label {
    font-size: 1rem;
    padding: 0.24rem 0.72rem;
    line-height: 1;
  }

  .paycheck-table-date,
  .paycheck-table-name,
  .paycheck-table-amount {
    font-size: 0.96rem;
  }

  .transactions-date,
  .transactions-name,
  .transactions-amount {
    font-size: 0.96rem;
  }

  .paycheck-today-remaining {
    font-size: 1.2rem;
    padding: 0.28rem 0;
    line-height: 1;
  }

  .budget-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .budget-header-main,
  .paycheck-header-main {
    width: 100%;
  }

  .budget-item,
  .budget-item-columns {
    grid-template-columns: 1fr auto;
    gap: 0.4rem;
  }

  .budgeted-input {
    width: 88px;
  }

  .accounts-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .account-row {
    grid-template-columns: minmax(0, 1fr) 94px auto;
    gap: 0.4rem;
  }

  .account-name-input {
    width: 165px;
  }

  .account-amount-input {
    width: 90px;
  }
}
