/* =========================================================
   Worthy — design tokens
   ========================================================= */
:root {
  /* Surfaces */
  --bg:                #FCFCF9;
  --surface:           #FFFFFF;

  /* Brand greens */
  --green-900:         #0E3F1C;   /* primary brand / headings */
  --green-800:         #1A3D1F;   /* solid button bg */
  --green-700:         #25592E;   /* hover for solid button */
  --green-200:         #C8DBCB;   /* light secondary fill */
  --green-100:         #D9E8DA;   /* dot inactive / light hover */
  --green-50:          #E9F1E8;   /* very light tint */

  /* Text */
  --ink:               #0E3F1C;
  --ink-soft:          #2A4B30;
  --muted:             #5A5A5A;
  --muted-2:           #9A9A9A;

  /* Status */
  --red-500:           #ED5050;
  --red-600:           #D63E3E;

  /* Chip tints (stat cards) — bg + matching icon color */
  --chip-blue:         #DCE9F8;
  --chip-blue-fg:      #2962E2;
  --chip-green:        #DCEAD4;
  --chip-green-fg:     #1A6B2D;
  --chip-orange:       #FCE2D2;
  --chip-orange-fg:    #E47126;
  --chip-pink:         #F6DCEE;
  --chip-pink-fg:      #B43D87;
  --chip-red:          #FCE3E3;

  /* Neutral */
  --border:            #E0E0E0;
  --disabled-bg:       #EFEFEF;
  --disabled-fg:       #BFBFBF;

  /* Radii */
  --radius-sm: 8px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-pill: 999px;

  /* Control height — buttons, inputs, selects share the same height */
  --control-h: 48px;
  --control-h-lg: 48px;
  --control-h-sm: 36px;

  /* Container — main content max width */
  --container-max: 1320px;
  --container-pad-x: clamp(20px, 5vw, 56px);

  /* Spacing scale */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;

  /* Shadows */
  --shadow-sm: 0 1px 2px rgba(14, 63, 28, 0.06);
  --shadow-md: 0 4px 12px rgba(14, 63, 28, 0.10);

  /* Typography */
  --font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --fs-display: clamp(40px, 5vw, 64px);
  --fs-h2: 32px;
  --fs-body-lg: 18px;
  --fs-body: 16px;
  --fs-sm: 14px;
  --fs-xs: 12px;
}

/* =========================================================
   Base
   ========================================================= */
*,
*::before,
*::after { box-sizing: border-box; }

[hidden] { display: none !important; }

html, body { height: 100%; }

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: 1.5;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img { max-width: 100%; display: block; }
button { font-family: inherit; }

/* =========================================================
   Layout — onboarding shell
   ========================================================= */
.app {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  padding: clamp(20px, 3vw, 40px) clamp(20px, 6vw, 80px);
  max-width: 1440px;
  margin: 0 auto;
  width: 100%;
}

.app__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-shrink: 0;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  text-decoration: none;
  flex-shrink: 0;
}

.brand img {
  height: clamp(28px, 2.4vw, 36px);
  width: auto;
}

.screen {
  flex: 1;
  display: none;
  align-items: center;
  justify-content: space-between;
  gap: clamp(24px, 5vw, 80px);
  padding: clamp(24px, 4vw, 48px) 0;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

.screen.is-active { display: flex; }

.screen__copy {
  flex: 1 1 0;
  min-width: 0;
  max-width: 520px;
}

.screen__media {
  flex: 0 1 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 0;
}

.screen__media img {
  width: clamp(260px, 32vw, 440px);
  height: auto;
  max-width: 100%;
  object-fit: contain;
}

.screen__title {
  font-size: clamp(36px, 5vw, 60px);
  line-height: 1.05;
  font-weight: 800;
  color: var(--green-900);
  margin: 0 0 var(--space-5);
  letter-spacing: -0.01em;
}

.screen__subtitle {
  font-size: clamp(14px, 1.1vw, 16px);
  color: var(--ink-soft);
  margin: 0 0 var(--space-8);
  max-width: 42ch;
}

.screen__actions {
  display: flex;
  gap: var(--space-3);
  align-items: center;
  margin-bottom: var(--space-8);
  flex-wrap: wrap;
}

/* footer text on step 4 */
.app__footer {
  margin-top: auto;
  padding-top: var(--space-6);
  font-size: var(--fs-sm);
  color: var(--ink);
  font-weight: 500;
}

/* =========================================================
   Buttons
   ========================================================= */
.btn {
  --btn-bg: var(--green-800);
  --btn-fg: #FFFFFF;
  --btn-border: var(--green-800);
  --btn-bg-hover: var(--green-700);

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0 18px;
  min-height: var(--control-h);
  border: 1px solid var(--btn-border);
  border-radius: var(--radius-md);
  background: var(--btn-bg);
  color: var(--btn-fg);
  font-size: var(--fs-sm);
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0;
  cursor: pointer;
  text-decoration: none;
  transition: background-color .15s ease, color .15s ease, border-color .15s ease, transform .05s ease;
  white-space: nowrap;
}

.btn:hover  { background: var(--btn-bg-hover); border-color: var(--btn-bg-hover); }
.btn:active { transform: translateY(1px); }
.btn:focus-visible {
  outline: 2px solid var(--green-700);
  outline-offset: 2px;
}

.btn[disabled],
.btn.is-disabled {
  background: var(--disabled-bg);
  color: var(--disabled-fg);
  border-color: var(--disabled-bg);
  cursor: not-allowed;
}

/* Variant: outline (white bg, green border + text) */
.btn--outline {
  --btn-bg: transparent;
  --btn-fg: var(--green-900);
  --btn-border: var(--green-900);
  --btn-bg-hover: var(--green-50);
}
.btn--outline:hover { color: var(--green-900); }

/* Variant: light (light green fill, dark text) */
.btn--light {
  --btn-bg: var(--green-200);
  --btn-fg: var(--green-900);
  --btn-border: var(--green-200);
  --btn-bg-hover: #B8CFBC;
}

/* Variant: ghost (no border, no fill, just text) */
.btn--ghost {
  --btn-bg: transparent;
  --btn-fg: var(--green-900);
  --btn-border: transparent;
  --btn-bg-hover: var(--green-50);
}

/* Variant: danger (red) */
.btn--danger {
  --btn-bg: var(--red-500);
  --btn-fg: #FFFFFF;
  --btn-border: var(--red-500);
  --btn-bg-hover: var(--red-600);
}

/* Sizes */
.btn--sm { min-height: var(--control-h-sm); padding: 0 14px; font-size: var(--fs-sm); }
.btn--lg { min-height: var(--control-h-lg); padding: 0 22px; font-size: var(--fs-body); }
.btn--xl { min-height: 56px; padding: 0 28px; font-size: var(--fs-body-lg); }

/* Icon-only square */
.btn--icon {
  padding: 0;
  width: var(--control-h);
  min-height: var(--control-h);
}

.btn .icon {
  width: 16px;
  height: 16px;
  display: inline-block;
  flex-shrink: 0;
}

/* Skip link styling */
.skip-link {
  background: none;
  border: 0;
  padding: 6px 8px;
  color: var(--muted-2);
  font-size: var(--fs-sm);
  font-weight: 500;
  cursor: pointer;
}
.skip-link:hover { color: var(--ink); }

/* =========================================================
   Step indicator (dots)
   ========================================================= */
.steps {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
}

.steps__dots {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.dot {
  width: 10px;
  height: 10px;
  border-radius: var(--radius-pill);
  background: var(--green-100);
  transition: background-color .2s ease, width .2s ease;
}

.dot.is-active {
  background: var(--green-900);
  width: 22px;
}

.steps__count {
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--green-900);
  margin-left: var(--space-2);
}

/* =========================================================
   Inputs
   ========================================================= */
.field {
  display: block;
  margin-bottom: var(--space-4);
}

.field__label {
  display: block;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 6px;
}

.input-wrap {
  position: relative;
  display: flex;
  align-items: center;
  min-height: var(--control-h);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  transition: border-color .15s ease, box-shadow .15s ease;
}

.input-wrap:hover { border-color: var(--green-700); }

.input-wrap:focus-within {
  border-color: var(--green-700);
  box-shadow: 0 0 0 3px rgba(14, 63, 28, 0.08);
}

.input-wrap__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  padding: 0 4px;
  flex-shrink: 0;
  color: var(--green-900);
  font-weight: 600;
  font-size: var(--fs-sm);
}
.input-wrap__icon svg { width: 16px; height: 16px; }

.input {
  flex: 1;
  min-width: 0;
  border: 0;
  outline: 0;
  background: transparent;
  padding: 0 14px;
  font: inherit;
  color: var(--ink);
  align-self: stretch;
}
.input-wrap__icon + .input { padding-left: 0; }

.input::placeholder { color: var(--muted-2); }

.input-wrap.is-error,
.input-wrap.is-error:focus-within {
  border-color: var(--red-500);
  box-shadow: 0 0 0 3px rgba(237, 80, 80, 0.10);
}

.input-wrap.is-disabled {
  background: var(--disabled-bg);
  border-color: var(--border);
  cursor: not-allowed;
}
.input-wrap.is-disabled .input,
.input-wrap.is-disabled .input::placeholder { color: var(--disabled-fg); }

.help-text,
.field-error {
  display: block;
  margin-top: 6px;
  font-size: var(--fs-xs);
}
.help-text  { color: var(--muted); }
.field-error { color: var(--red-500); }

/* =========================================================
   Onboarding inline questionnaire
   ========================================================= */
.question-form {
  margin: 0 0 var(--space-6);
  max-width: 440px;
}

.field-row {
  display: flex;
  gap: var(--space-3);
}
.field-row .field { flex: 1; min-width: 0; }
.field-row .field--currency { flex: 0 0 130px; }

@media (max-width: 480px) {
  .field-row { flex-direction: column; gap: 0; }
  .field-row .field--currency { flex: 1 1 auto; }
}

/* Select (native, restyled) */
.select-wrap {
  position: relative;
  display: flex;
  align-items: center;
  min-height: var(--control-h);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  transition: border-color .15s ease, box-shadow .15s ease;
}
.select-wrap:hover { border-color: var(--green-700); }
.select-wrap:focus-within {
  border-color: var(--green-700);
  box-shadow: 0 0 0 3px rgba(14, 63, 28, 0.08);
}
.select-wrap.is-error {
  border-color: var(--red-500);
  box-shadow: 0 0 0 3px rgba(237, 80, 80, 0.10);
}
.select-wrap::after {
  content: "";
  position: absolute;
  right: 14px;
  top: 50%;
  width: 8px;
  height: 8px;
  border-right: 2px solid var(--muted);
  border-bottom: 2px solid var(--muted);
  transform: translateY(-70%) rotate(45deg);
  pointer-events: none;
}

.select-wrap__icon {
  display: inline-flex;
  align-items: center;
  padding-left: 14px;
  color: var(--green-900);
  flex-shrink: 0;
}
.select-wrap__icon svg { width: 16px; height: 16px; }

.select {
  width: 100%;
  -webkit-appearance: none;
  appearance: none;
  background: transparent;
  border: 0;
  outline: 0;
  padding: 0 36px 0 14px;
  font: inherit;
  color: var(--ink);
  cursor: pointer;
  align-self: stretch;
}
.select-wrap__icon + .select { padding-left: 8px; }

/* =========================================================
   Links
   ========================================================= */
.link {
  color: var(--green-900);
  text-decoration: none;
  font-weight: 600;
  border-bottom: 1px solid transparent;
  transition: border-color .15s ease, color .15s ease;
}
.link:hover { border-bottom-color: currentColor; }
.link--muted {
  color: var(--muted);
  font-weight: 500;
}
.link--muted:hover { color: var(--ink); }

/* =========================================================
   Auth modal-card layout (Login / Registration)
   ========================================================= */
.auth {
  min-height: 100vh;
  position: relative;
}

/* gray overlay sits between the page (with logo) and the modal card */
.auth::after {
  content: "";
  position: fixed;
  inset: 0;
  background: rgba(60, 60, 60, 0.45);
  z-index: 1;
  pointer-events: none;
}

.auth__topbar {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 0; /* under the overlay */
  padding: clamp(20px, 3vw, 32px) clamp(20px, 6vw, 80px);
  display: flex;
  align-items: center;
}

.auth__container {
  position: relative;
  z-index: 2; /* above the overlay */
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(96px, 14vh, 140px) clamp(20px, 4vw, 48px) clamp(40px, 6vh, 72px);
}

.card {
  position: relative;
  width: 100%;
  max-width: 980px;
  min-height: 560px;
  background: var(--surface);
  border-radius: 18px;
  box-shadow: var(--shadow-md);
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.card__close {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: transparent;
  border: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--ink);
  z-index: 2;
}
.card__close:hover { background: var(--green-50); }

.card__mock {
  position: absolute;
  top: 18px;
  left: 18px;
  z-index: 2;
  padding: 6px 10px;
  font: 500 12px/1 var(--font-sans);
  color: var(--muted);
  background: #ECECEC;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background-color .15s ease, color .15s ease;
}
.card__mock:hover { background: #E0E0E0; color: var(--ink); }

.card__form {
  padding: clamp(28px, 4vw, 56px) clamp(24px, 4vw, 56px);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.card__form-inner { max-width: 360px; width: 100%; margin: 0 auto; }

.card__title {
  font-size: clamp(22px, 2vw, 28px);
  font-weight: 800;
  color: var(--green-900);
  margin: 0 0 6px;
  letter-spacing: -0.01em;
}

.card__subtitle {
  font-size: var(--fs-sm);
  color: var(--muted);
  margin: 0 0 var(--space-6);
}

.btn--block { width: 100%; }

.divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: var(--space-5) 0;
  color: var(--muted-2);
  font-size: var(--fs-sm);
}
.divider::before,
.divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--border);
}

.alt-action {
  text-align: center;
  font-size: var(--fs-sm);
  color: var(--muted);
}

.field__row {
  display: flex;
  justify-content: flex-end;
  margin-top: 6px;
}

.secure-note {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: var(--space-8);
  font-size: var(--fs-xs);
  color: var(--muted);
  align-self: center;
}
.secure-note svg { color: var(--green-900); }

/* hero (right side of the card) */
.card__hero {
  background: var(--bg);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: clamp(28px, 4vw, 48px);
  text-align: center;
}

.card__hero img {
  width: clamp(180px, 22vw, 260px);
  height: auto;
  margin-bottom: var(--space-4);
}

.card__hero-title {
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 800;
  color: var(--green-900);
  margin: 0 0 6px;
  letter-spacing: -0.01em;
}

.card__hero-tag {
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  margin: 0;
}

@media (max-width: 760px) {
  .card { grid-template-columns: 1fr; min-height: 0; }
  .card__hero { order: -1; padding: 24px; }
  .card__hero img { width: 140px; margin-bottom: 8px; }
  .card__hero-title { font-size: 22px; }
  .card__form { padding: 24px; }
}

/* =========================================================
   Site footer (minimalist)
   ========================================================= */
.site-footer {
  border-top: 1px solid var(--border);
  font-size: var(--fs-xs);
  color: var(--muted-2);
}

.site-footer__inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 14px var(--container-pad-x);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}

.site-footer__nav {
  display: inline-flex;
  gap: var(--space-4);
}

.site-footer .link {
  font-weight: 500;
  font-size: var(--fs-xs);
}

@media (max-width: 480px) {
  .site-footer__inner {
    flex-direction: column;
    gap: 6px;
    text-align: center;
  }
}

/* =========================================================
   App shell — topbar + page layout (dashboard, add-new-item)
   ========================================================= */
.shell {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
}

.topbar__inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 14px var(--container-pad-x);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}

.topbar__user {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: var(--ink);
  font-size: var(--fs-sm);
}

.topbar__user-email { color: var(--ink); }

.icon-btn {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 0;
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--ink);
}
.icon-btn:hover { background: var(--green-50); }

.page {
  flex: 1;
  padding: clamp(20px, 3vw, 40px) var(--container-pad-x) clamp(40px, 6vw, 72px);
  max-width: var(--container-max);
  width: 100%;
  margin: 0 auto;
}

.section {
  margin-bottom: clamp(20px, 3vw, 32px);
}

.section__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-3);
}

.section__title {
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted-2);
  margin: 0;
}

/* =========================================================
   Breadcrumb
   ========================================================= */
.breadcrumb {
  font-size: var(--fs-sm);
  color: var(--muted);
  margin-bottom: var(--space-2);
}
.breadcrumb__sep { margin: 0 6px; color: var(--muted-2); }
.breadcrumb__link {
  color: inherit;
  text-decoration: none;
}
.breadcrumb__link:hover { color: var(--ink); }
.breadcrumb__current { color: var(--muted); }

/* =========================================================
   Page hero (H1 + subtitle area on inner pages)
   ========================================================= */
.page-hero { margin-bottom: clamp(20px, 3vw, 32px); }
.page-hero__title {
  font-size: clamp(28px, 3vw, 36px);
  font-weight: 800;
  color: var(--ink);
  margin: 0 0 6px;
  letter-spacing: -0.01em;
}
.page-hero__subtitle {
  font-size: var(--fs-body);
  color: var(--muted);
  margin: 0;
}

/* =========================================================
   Form card (used on add-new-item / settings)
   ========================================================= */
.form-card {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: clamp(20px, 3vw, 28px);
}
.form-card__title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: var(--fs-body-lg);
  font-weight: 700;
  color: var(--ink);
  margin: 0 0 var(--space-5);
}
.chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: var(--chip-green);
  color: var(--chip-green-fg);
  flex-shrink: 0;
}
.chip svg { width: 18px; height: 18px; }
.chip--blue   { background: var(--chip-blue);   color: var(--chip-blue-fg); }
.chip--orange { background: var(--chip-orange); color: var(--chip-orange-fg); }
.chip--pink   { background: var(--chip-pink);   color: var(--chip-pink-fg); }

/* mock-data button positioned in form-card too (in addition to .card) */
.form-card > .card__mock { top: 16px; right: 16px; left: auto; }

/* 2-column page layout — main form left, side card right */
.layout-2col {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
  gap: clamp(16px, 2vw, 24px);
  align-items: start;
}
@media (max-width: 900px) {
  .layout-2col { grid-template-columns: 1fr; }
}

/* Inner form grid for paired fields (Category + Priority) */
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}
@media (max-width: 520px) { .form-grid { grid-template-columns: 1fr; } }

/* Input with wide text prefix (https://, etc.) */
.input-wrap__icon--text {
  padding: 0 12px;
  color: var(--muted);
  font-weight: 500;
}
.input-wrap__icon--divider {
  border-right: 1px solid var(--border);
}

/* =========================================================
   Quantity stepper
   ========================================================= */
.stepper {
  display: flex;
  align-items: stretch;
  height: var(--control-h);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.stepper:hover { border-color: var(--green-700); }
.stepper:focus-within {
  border-color: var(--green-700);
  box-shadow: 0 0 0 3px rgba(14, 63, 28, 0.08);
}
.stepper__btn {
  width: 44px;
  border: 0;
  background: transparent;
  font: inherit;
  font-size: 18px;
  color: var(--muted);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.stepper__btn:hover { background: var(--green-50); color: var(--ink); }
.stepper__btn:disabled { color: var(--disabled-fg); cursor: not-allowed; background: transparent; }
.stepper__input {
  flex: 1;
  min-width: 0;
  border: 0;
  outline: 0;
  background: transparent;
  font: inherit;
  text-align: center;
  -moz-appearance: textfield;
}
.stepper__input::-webkit-outer-spin-button,
.stepper__input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* =========================================================
   Form actions row
   ========================================================= */
.form-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
  margin-top: var(--space-6);
}
.form-actions .btn { width: 100%; }
@media (max-width: 480px) {
  .form-actions:not(.form-actions--end) { grid-template-columns: 1fr; }
}

.form-actions--end {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-3);
}
.form-actions--end .btn { width: auto; }

.form-stack {
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 2vw, 24px);
}

.page-back { margin-bottom: var(--space-4); }

.toast-inline {
  font-size: var(--fs-sm);
  color: var(--green-900);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  opacity: 0;
  transition: opacity .2s ease;
}
.toast-inline.is-visible { opacity: 1; }
.toast-inline svg { color: var(--green-700); }

.danger-zone__text {
  font-size: var(--fs-sm);
  color: var(--muted);
  margin: 0 0 var(--space-4);
  max-width: 60ch;
}

/* =========================================================
   Purchase analysis (right side of add-new-item)
   ========================================================= */
.analysis-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  min-height: 280px;
  padding: var(--space-6);
}
.analysis-empty img {
  width: clamp(180px, 22vw, 240px);
  height: auto;
}
.analysis-empty__hint {
  text-align: center;
  font-size: var(--fs-sm);
  color: var(--muted);
  margin: 0;
  max-width: 26ch;
}

/* populated state */
.analysis-result {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

/* hero metric */
.analysis-headline { display: flex; flex-direction: column; gap: 4px; }
.analysis-percent {
  font-size: clamp(24px, 2.6vw, 30px);
  font-weight: 800;
  color: var(--ink);
  line-height: 1.05;
  margin: 0;
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
}
.analysis-percent--mid  { color: #C7910A; }
.analysis-percent--high { color: var(--chip-orange-fg); }
.analysis-percent--bad  { color: var(--red-500); }
.analysis-percent__sym  { font-size: 0.55em; font-weight: 700; opacity: .85; margin-left: 1px; }

.analysis-label {
  font-size: var(--fs-sm);
  color: var(--muted);
  margin: 0;
}

/* insights — list of secondary metrics */
.analysis-insights {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding-top: var(--space-4);
  border-top: 1px solid var(--border);
}
.analysis-line {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 15px;
  color: var(--ink);
  line-height: 1.4;
  font-weight: 500;
}
.analysis-line svg {
  width: 18px;
  height: 18px;
  color: var(--green-700);
  flex-shrink: 0;
}

/* verdict — summary panel at the bottom of analysis */
.verdict {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: var(--radius-md);
  background: var(--green-50);
  color: var(--green-700);
  font-size: var(--fs-body);
  font-weight: 700;
  margin: 0;
}
.verdict svg {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  stroke-width: 1.8;
}
.verdict--bad {
  background: var(--chip-red);
  color: var(--red-500);
}

/* horizontal bar chart — refined */
.budget-chart { margin-top: 4px; }
.budget-chart__track {
  position: relative;
  height: 12px;
  background: var(--green-50);
  border-radius: var(--radius-pill);
  overflow: visible;
}
.budget-chart__fill {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 0;
  background: var(--green-700);
  border-radius: var(--radius-pill);
  transition: width .3s ease, background-color .3s ease;
}
/* tiered colors — match the percent of monthly budget */
.budget-chart__fill--low  { background: var(--green-700); }   /* < 20% */
.budget-chart__fill--mid  { background: #C7910A; }            /* 20–50% — amber */
.budget-chart__fill--high { background: var(--chip-orange-fg); } /* 50–100% */
.budget-chart__fill--bad  { background: var(--red-500); }     /* > 100% */

.budget-chart__marker {
  position: absolute;
  top: -4px;
  bottom: -4px;
  width: 2px;
  background: var(--ink);
  border-radius: 1px;
  transform: translateX(-1px);
  opacity: .55;
}
.budget-chart__marker::after {
  content: attr(data-label);
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  margin-bottom: 4px;
  font-size: 10px;
  color: var(--muted);
  white-space: nowrap;
}

.budget-chart__legend {
  display: flex;
  justify-content: space-between;
  margin-top: 10px;
  font-size: 12px;
  color: var(--ink-soft);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}

/* =========================================================
   Stat card
   ========================================================= */
.stat-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-3);
}
@media (max-width: 1024px) { .stat-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px)  { .stat-grid { grid-template-columns: 1fr; } }

.stat-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 18px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 130px;
}

.stat-card__main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.stat-card__title {
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted-2);
  margin: 0;
}

.stat-card__value {
  font-size: 32px;
  font-weight: 800;
  color: var(--ink);
  line-height: 1;
  margin: 2px 0 0;
}

.stat-card__unit {
  font-size: var(--fs-sm);
  color: var(--muted);
  margin: 0;
}

.stat-card__icon {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 18px;
}

.stat-card__icon svg { width: 22px; height: 22px; }

.stat-card__icon--blue   { background: var(--chip-blue);   color: var(--chip-blue-fg); }
.stat-card__icon--green  { background: var(--chip-green);  color: var(--chip-green-fg); }
.stat-card__icon--orange { background: var(--chip-orange); color: var(--chip-orange-fg); }
.stat-card__icon--pink   { background: var(--chip-pink);   color: var(--chip-pink-fg); }

/* =========================================================
   Items panel + table (dashboard - full state)
   ========================================================= */
.items-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.items-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}

.tabs {
  display: inline-flex;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 3px;
  gap: 2px;
}
.tabs__btn {
  border: 0;
  background: transparent;
  padding: 7px 14px;
  border-radius: 7px;
  font: inherit;
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--muted);
  cursor: pointer;
}
.tabs__btn.is-active {
  background: var(--surface);
  color: var(--ink);
  font-weight: 600;
  box-shadow: 0 1px 2px rgba(0,0,0,0.06);
}

.items-search {
  position: relative;
  flex: 1;
  max-width: 380px;
  min-width: 180px;
}
.items-search input {
  width: 100%;
  padding: 0 12px 0 38px;
  height: 36px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  font: inherit;
  font-size: var(--fs-sm);
  outline: none;
}
.items-search input:focus { border-color: var(--green-700); }
.items-search svg {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  color: var(--muted-2);
}

.items-toolbar__actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.sort-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 36px;
  padding: 0 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  font: inherit;
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--ink);
  cursor: pointer;
}
.sort-btn:hover { border-color: var(--green-700); }
.sort-btn svg { width: 14px; height: 14px; color: var(--muted); }

.sort-wrap { position: relative; }
.sort-menu {
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  min-width: 200px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  box-shadow: 0 10px 24px rgba(14, 63, 28, 0.10);
  padding: 6px;
  z-index: 20;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.sort-menu button {
  border: 0;
  background: transparent;
  text-align: left;
  padding: 8px 10px;
  border-radius: var(--radius-sm);
  font: inherit;
  font-size: var(--fs-sm);
  cursor: pointer;
  color: var(--ink);
  width: 100%;
}
.sort-menu button:hover { background: var(--green-50); }
.sort-menu button.is-active { background: var(--green-50); color: var(--green-700); font-weight: 600; }

/* Table grid */
.items-table { width: 100%; }
.items-table__row {
  display: grid;
  grid-template-columns: minmax(180px, 1.6fr) minmax(90px, 0.7fr) minmax(140px, 0.9fr) minmax(180px, 1.4fr) minmax(140px, 0.9fr) minmax(80px, 0.6fr) 32px;
  align-items: center;
  gap: var(--space-3);
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
}

/* Status dropdown — pending row gets a clickable badge with chevron */
.status-dropdown { position: relative; display: inline-block; }
.status-dropdown__trigger {
  border: 0;
  cursor: pointer;
  font: inherit;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px 4px 10px;
  border-radius: var(--radius-pill);
  font-size: 12px;
  font-weight: 600;
}
.status-dropdown__trigger--pending  { background: #FBEEC8; color: #B58400; }
.status-dropdown__trigger--bought   { background: var(--chip-orange); color: var(--chip-orange-fg); }
.status-dropdown__trigger--rejected { background: var(--green-100); color: var(--green-700); }
.status-dropdown__trigger::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.status-dropdown__trigger svg { width: 12px; height: 12px; opacity: .75; }

.status-dropdown__menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 130px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  box-shadow: 0 10px 24px rgba(14, 63, 28, 0.10);
  padding: 6px;
  z-index: 20;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.status-dropdown__option {
  border: 0;
  background: transparent;
  font: inherit;
  text-align: left;
  cursor: pointer;
  border-radius: var(--radius-sm);
  padding: 6px 8px;
  display: flex;
  align-items: center;
}
.status-dropdown__option:hover { background: var(--green-50); }

.cell-price {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.items-table__row:last-child { border-bottom: 0; }
.items-table__row--head {
  font-size: 12px;
  font-weight: 500;
  color: var(--muted-2);
  letter-spacing: 0.02em;
  text-transform: capitalize;
  padding-top: 12px;
  padding-bottom: 12px;
}

/* Item name */
.item-name {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}
.item-name__icon {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-sm);
  background: var(--bg);
  border: 1px solid var(--border);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--muted-2);
}
.item-name__icon svg { width: 16px; height: 16px; }
.item-name__main { min-width: 0; }
.item-name__title {
  font-weight: 600;
  color: var(--ink);
  margin: 0;
  font-size: 14px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.item-name__url {
  margin: 2px 0 0;
  color: var(--muted-2);
  font-size: 12px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Status */
.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  font-size: 12px;
  font-weight: 600;
  white-space: nowrap;
}
.status-badge::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.status-badge--pending  { color: #B58400; background: #FBEEC8; }
.status-badge--rejected { color: var(--green-700); background: var(--green-100); }
.status-badge--bought   { color: var(--chip-orange-fg); background: var(--chip-orange); }

/* Mini bar */
.budget-mini {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.budget-mini__track {
  flex: 1;
  height: 8px;
  background: var(--green-50);
  border-radius: var(--radius-pill);
  position: relative;
  overflow: hidden;
}
.budget-mini__fill {
  position: absolute;
  inset: 0 auto 0 0;
  background: var(--ink);
  border-radius: var(--radius-pill);
}

/* Worthy suggestion inline */
.suggestion {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  color: var(--green-700);
  white-space: nowrap;
}
.suggestion svg { width: 14px; height: 14px; }
.suggestion--bad { color: var(--red-500); }

/* Timer */
.cell-timer {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  color: var(--ink);
  font-size: 13px;
}

/* Row actions */
.row-actions {
  display: inline-flex;
  gap: 6px;
}
.row-actions .btn {
  min-height: 32px;
  padding: 0 10px;
  font-size: 12px;
}

.kebab-wrap { position: relative; justify-self: end; }
.kebab {
  width: 28px;
  height: 28px;
  border: 0;
  background: transparent;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  border-radius: 6px;
}
.kebab:hover { background: var(--green-50); }
.kebab svg { width: 16px; height: 16px; }

.kebab-menu {
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  min-width: 160px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  box-shadow: 0 10px 24px rgba(14, 63, 28, 0.10);
  padding: 6px;
  z-index: 20;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.kebab-menu button {
  border: 0;
  background: transparent;
  text-align: left;
  padding: 8px 10px;
  border-radius: var(--radius-sm);
  font: inherit;
  font-size: var(--fs-sm);
  cursor: pointer;
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
}
.kebab-menu button:hover { background: var(--green-50); }
.kebab-menu button[data-kebab-action="delete"] { color: var(--red-500); }
.kebab-menu button[data-kebab-action="delete"]:hover { background: var(--chip-red); }
.kebab-menu svg { width: 14px; height: 14px; flex-shrink: 0; color: var(--muted); }
.kebab-menu button[data-kebab-action="delete"] svg { color: currentColor; }

/* Pagination */
.items-pagination {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 18px;
  font-size: var(--fs-sm);
  color: var(--muted);
  border-top: 1px solid var(--border);
}
.items-pagination__nav {
  display: inline-flex;
  gap: 8px;
}
.items-pagination__nav .btn { min-height: 32px; padding: 0 12px; font-size: 12px; }

/* Hide head row + table on smaller screens — let it scroll horizontally */
@media (max-width: 1100px) {
  .items-panel { overflow-x: auto; }
  .items-table { min-width: 1000px; }
}

/* =========================================================
   Empty state card
   ========================================================= */
.empty-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: clamp(40px, 6vw, 72px) 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: var(--space-5);
  min-height: 220px;
}

.empty-card__text {
  max-width: 36ch;
  color: var(--muted);
  font-size: var(--fs-body);
  margin: 0;
}

/* =========================================================
   Date Range Picker (component library — not used on onboarding,
   but included as part of the design system per the brief)
   ========================================================= */
.daterange { position: relative; display: inline-block; }

.daterange__trigger {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  min-height: var(--control-h);
  padding: 0 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  color: var(--ink);
  font: inherit;
  font-size: var(--fs-sm);
  cursor: pointer;
  white-space: nowrap;
}
.daterange__trigger:hover,
.daterange.is-open .daterange__trigger {
  border-color: var(--green-700);
}
.daterange__trigger.is-empty { color: var(--muted-2); }

.daterange--block { display: block; }
.daterange--block .daterange__trigger { display: flex; width: 100%; }

.daterange.is-focused,
.daterange:hover {
  border-color: var(--green-700);
}

.daterange.is-disabled {
  background: var(--disabled-bg);
  color: var(--disabled-fg);
  cursor: not-allowed;
  border-color: var(--border);
}

.daterange__icon { color: var(--green-900); flex-shrink: 0; display: inline-flex; }
.daterange--block .daterange__value { flex: 1; }
.daterange__chevron {
  color: var(--muted-2);
  flex-shrink: 0;
  margin-left: 4px;
  transition: transform .15s ease;
}
.daterange.is-open .daterange__chevron { transform: rotate(180deg); }

/* Popover */
.daterange__pop {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 50;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px;
  box-shadow: 0 12px 32px rgba(14, 63, 28, 0.12);
  display: none;
}
.daterange.is-open .daterange__pop { display: block; }

.daterange__months {
  display: flex;
  gap: 32px;
}

.daterange__actions {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.daterange__range-summary {
  font-size: var(--fs-sm);
  color: var(--muted);
}

/* Calendar */
.cal { width: 252px; }

.cal__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
  gap: 8px;
}
.cal__title {
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--ink);
}
.cal__nav {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: var(--surface);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--ink);
  flex-shrink: 0;
}
.cal__nav:hover { background: var(--green-50); border-color: var(--green-700); }
.cal__nav.is-hidden { visibility: hidden; pointer-events: none; }
.cal__nav svg { width: 14px; height: 14px; }

.cal__weekdays,
.cal__grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
}

.cal__weekday {
  text-align: center;
  font-size: var(--fs-xs);
  font-weight: 500;
  color: var(--muted-2);
  padding: 8px 0;
}

.cal__day {
  border: 0;
  background: transparent;
  font: inherit;
  font-size: var(--fs-sm);
  color: var(--ink);
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  border-radius: 6px;
  margin: 1px 0;
}
.cal__day:hover:not(.is-empty):not(.is-start):not(.is-end) {
  background: var(--green-50);
}
.cal__day.is-empty { visibility: hidden; pointer-events: none; }
.cal__day.is-in-range { background: var(--green-100); }
.cal__day.is-start,
.cal__day.is-end {
  background: var(--green-900);
  color: #FFFFFF;
  font-weight: 600;
}

@media (max-width: 720px) {
  .daterange__months { flex-direction: column; gap: 16px; }
  .daterange__pop { left: 0; right: auto; }
  .cal { width: 100%; }
}

/* =========================================================
   Responsive — explicit breakpoints
   - >=1200px : large desktop (default)
   -  900-1199: small desktop / tablet landscape
   -  640-899 : tablet portrait — single column, mascot first
   -  <640    : mobile
   ========================================================= */
@media (max-width: 1199px) {
  .screen { gap: clamp(24px, 4vw, 56px); }
  .screen__media img { width: clamp(240px, 30vw, 380px); }
}

@media (max-width: 899px) {
  .app {
    padding: 24px 32px;
  }
  .screen {
    flex-direction: column-reverse;
    align-items: stretch;
    text-align: left;
    gap: 32px;
    padding: 24px 0;
  }
  .screen__copy {
    max-width: 100%;
  }
  .screen__media {
    width: 100%;
  }
  .screen__media img {
    width: clamp(220px, 50vw, 320px);
    margin: 0 auto;
  }
  .screen__title { font-size: clamp(32px, 6vw, 44px); }
  .screen__subtitle { max-width: 100%; }
}

@media (max-width: 639px) {
  .app {
    padding: 20px 20px 28px;
  }
  .screen {
    gap: 24px;
    padding: 16px 0;
  }
  .screen__title { font-size: clamp(28px, 8vw, 36px); }
  .screen__subtitle { font-size: 14px; margin-bottom: var(--space-6); }
  .screen__actions { gap: 8px; margin-bottom: var(--space-6); }
  .btn { padding: 10px 14px; }
  .btn--lg { padding: 12px 18px; }
  .screen__media img { width: clamp(200px, 60vw, 260px); }
}

@media (max-width: 380px) {
  .screen__actions { width: 100%; }
  .screen__actions .btn { flex: 1 1 auto; }
  .skip-link { margin-left: auto; }
}
