/* ══════════════════════════════════════════
   TOKENS — change hex values here only
══════════════════════════════════════════ */
:root {
  --color-primary:        #84A59D;
  --color-primary-dk:     #5C8078;
  --color-primary-pale:   rgba(132, 165, 157, 0.10);
  --color-primary-border: rgba(132, 165, 157, 0.25);

  --color-danger:         #E8605A;
  --color-danger-dk:      #C94F49;
  --color-danger-pale:    rgba(232, 96, 90, 0.08);

  --color-warning:        #F6BD60;
  --color-warning-pale:   rgba(246, 189, 96, 0.12);

  --color-dark:           #1E1E1E;
  --color-light:          #FDF8F2;
  --color-light-dk:       #F5EFE6;
  --color-white:          #FFFFFF;
  --color-body:           #2C2C2C;
  --color-muted:          #7A7A7A;
  --color-border:         #D9CFC4;
  --color-border-lt:      #EDE7DE;

  --font-sans:            'DM Sans', system-ui, sans-serif;
  --font-display:         'DM Serif Display', Georgia, serif;

  --radius-sm:            8px;
  --radius-md:            14px;
  --radius-lg:            22px;
  --radius-pill:          100px;

  --shadow-sm:            0 1px 4px rgba(0,0,0,0.06);
  --shadow-md:            0 4px 16px rgba(0,0,0,0.08);
  --shadow-lg:            0 12px 40px rgba(0,0,0,0.10);
}

/* ══════════════════════════════════════════
   RESET
══════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html  { scroll-behavior: smooth; }
body  {
  font-family: var(--font-sans);
  background: var(--color-light);
  color: var(--color-body);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img  { display: block; max-width: 100%; }
a    { color: inherit; text-decoration: none; }
ul   { list-style: none; }
h1, h2, h3, h4 { font-family: var(--font-display); line-height: 1.15; }

/* ══════════════════════════════════════════
   LAYOUT
══════════════════════════════════════════ */
.container {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 28px;
}
.section      { padding: 96px 0; }
.section-alt  { padding: 96px 0; background: var(--color-light-dk); }
.section-dark { padding: 96px 0; background: var(--color-dark); color: var(--color-white); }

/* ══════════════════════════════════════════
   PROSE — centered max-width column for long-form content
══════════════════════════════════════════ */
.prose-column {
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}

/* ══════════════════════════════════════════
   SPACING UTILITIES
══════════════════════════════════════════ */
.mt-sm { margin-top: 16px; }
.mt-md { margin-top: 32px; }
.mt-lg { margin-top: 48px; }
.mt-xl { margin-top: 64px; }
.mb-sm { margin-bottom: 16px; }
.mb-md { margin-bottom: 32px; }
.mb-lg { margin-bottom: 48px; }
.mb-xl { margin-bottom: 64px; }

/* ══════════════════════════════════════════
   TYPOGRAPHY
══════════════════════════════════════════ */
.eyebrow {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-primary-dk);
  background: var(--color-primary-pale);
  border: 1px solid var(--color-primary-border);
  padding: 5px 14px;
  border-radius: var(--radius-pill);
  margin-bottom: 20px;
}
.eyebrow-light {
  color: var(--color-primary);
  background: rgba(132,165,157,0.15);
  border-color: rgba(132,165,157,0.2);
}
.display-hero {
  font-family: var(--font-display);
  font-size: clamp(40px, 6vw, 68px);
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: var(--color-body);
}
.display-hero em       { font-style: italic; color: var(--color-danger); }
.display-section {
  font-family: var(--font-display);
  font-size: clamp(30px, 4vw, 44px);
  line-height: 1.15;
  letter-spacing: -0.01em;
}
.display-section-light { color: var(--color-white); }
.lead                  { font-size: clamp(17px, 2vw, 20px); color: var(--color-muted); line-height: 1.65; }
.lead-light            { color: rgba(255,255,255,0.65); }
.body-copy             { font-size: 15px; line-height: 1.75; color: var(--color-muted); }

.section-header        { max-width: 600px; }
.section-header .lead  { margin-top: 16px; }
.section-header-centered {
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

/* ══════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-sans);
  font-size: 15px;
  font-weight: 600;
  line-height: 1;
  padding: 13px 28px;
  border-radius: var(--radius-pill);
  border: 2px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.18s, border-color 0.18s, box-shadow 0.18s, transform 0.18s;
}
.btn-lg { font-size: 17px; padding: 16px 36px; }

.btn-danger {
  background: var(--color-danger);
  color: var(--color-white);
  border-color: var(--color-danger);
  box-shadow: 0 2px 12px rgba(232,96,90,0.28);
}
.btn-danger:hover {
  background: var(--color-danger-dk);
  border-color: var(--color-danger-dk);
  box-shadow: 0 4px 20px rgba(232,96,90,0.38);
  transform: translateY(-1px);
}
.btn-primary {
  background: transparent;
  color: var(--color-primary-dk);
  border-color: var(--color-primary);
}
.btn-primary:hover {
  background: var(--color-primary-pale);
  transform: translateY(-1px);
}
.btn-light {
  background: var(--color-white);
  color: var(--color-danger);
  border-color: var(--color-white);
}
.btn-light:hover {
  background: var(--color-light);
  transform: translateY(-1px);
}

/* ══════════════════════════════════════════
   NAV
══════════════════════════════════════════ */
.nav {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(253,248,242,0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--color-border-lt);
}
.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 68px;
}
.nav-logo              { display: flex; align-items: center; gap: 10px; }
.nav-logo img          { height: 32px; width: auto; }
.nav-logo-fallback {
  width: 32px; height: 32px;
  background: var(--color-danger);
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px;
}
.nav-wordmark          { font-size: 18px; font-weight: 700; color: var(--color-body); }
.nav-wordmark span     { color: var(--color-body); }
.nav-links             { display: flex; align-items: center; gap: 32px; }
.nav-links a           { font-size: 14px; font-weight: 500; color: var(--color-muted); transition: color 0.15s; }
.nav-links a:hover     { color: var(--color-danger); }

/* ══════════════════════════════════════════
   FOOTER
══════════════════════════════════════════ */
.footer                { background: var(--color-dark); padding: 40px 0; }
.footer-inner {
  display: flex; align-items: center;
  justify-content: space-between; gap: 24px; flex-wrap: wrap;
}
.footer-wordmark       { font-size: 15px; font-weight: 700; color: rgba(255,255,255,0.7); }
.footer-wordmark span  { color: rgba(255,255,255,0.7); }
.footer-links          { display: flex; gap: 24px; }
.footer-links a        { font-size: 13px; color: rgba(255,255,255,0.4); transition: color 0.15s; }
.footer-links a:hover  { color: rgba(255,255,255,0.8); }
.footer-legal          { font-size: 12px; color: rgba(255,255,255,0.28); }

/* ══════════════════════════════════════════
   HERO
══════════════════════════════════════════ */
.hero {
  padding: 100px 0 96px;
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 60% 40%, rgba(132,165,157,0.10) 0%, transparent 70%),
    radial-gradient(ellipse 50% 50% at 20% 80%, rgba(246,189,96,0.08) 0%, transparent 60%);
  pointer-events: none;
}
.hero-inner {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.hero-text .display-hero { margin-bottom: 24px; }
.hero-text .lead         { margin-bottom: 36px; max-width: 480px; }
.hero-actions            { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.hero-note               { margin-top: 16px; font-size: 13px; color: var(--color-muted); }
.hero-visual             { display: flex; justify-content: center; }

/* ══════════════════════════════════════════
   MOCKUP — shopping list card
══════════════════════════════════════════ */
.mockup-card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 28px 26px;
  width: 100%;
  max-width: 340px;
  box-shadow: var(--shadow-lg);
}
.mockup-card-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 20px; padding-bottom: 16px;
  border-bottom: 1px solid var(--color-border-lt);
}
.mockup-card-title   { font-size: 14px; font-weight: 700; color: var(--color-body); }
.mockup-card-badge {
  font-size: 11px; font-weight: 600;
  color: var(--color-primary-dk);
  background: var(--color-primary-pale);
  border: 1px solid var(--color-primary-border);
  padding: 3px 10px;
  border-radius: var(--radius-pill);
}
.mockup-section-label {
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--color-muted);
  margin: 14px 0 8px;
}
.mockup-item {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 0;
  border-bottom: 1px solid var(--color-border-lt);
  font-size: 14px; color: var(--color-muted);
}
.mockup-item:last-of-type { border-bottom: none; }
.mockup-item.done         { text-decoration: line-through; text-decoration-color: var(--color-primary); opacity: 0.6; }
.mockup-check {
  width: 18px; height: 18px; min-width: 18px;
  border-radius: 5px;
  border: 1.5px solid var(--color-border);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px;
}
.mockup-check.checked     { background: var(--color-primary); border-color: var(--color-primary); color: var(--color-white); }
.mockup-item-qty          { margin-left: auto; font-size: 12px; font-weight: 500; white-space: nowrap; }
.mockup-card-footer {
  margin-top: 16px; padding-top: 14px;
  border-top: 1px solid var(--color-border-lt);
  display: flex; align-items: center; justify-content: space-between;
  font-size: 12px; color: var(--color-muted);
}
.mockup-card-footer strong { color: var(--color-danger); font-weight: 700; }
.mockup-card-confirm       { color: var(--color-primary-dk); font-weight: 600; }
.mockup-pill {
  position: absolute;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  padding: 7px 14px;
  font-size: 12px; font-weight: 600; color: var(--color-muted);
  box-shadow: var(--shadow-md);
  white-space: nowrap;
  display: flex; align-items: center; gap: 6px;
}
.mockup-pill .dot          { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.mockup-pill-top           { top: 6px; right: 20px; }
.mockup-pill-bottom        { bottom: 18px; left: 0; }

/* ══════════════════════════════════════════
   BAND — full-width dark quote strip
══════════════════════════════════════════ */
.band-dark             { background: var(--color-dark); padding: 56px 0; }
.band-dark-inner       { max-width: 740px; margin: 0 auto; text-align: center; }
.band-dark-inner p {
  font-family: var(--font-display);
  font-size: clamp(20px, 3vw, 28px);
  line-height: 1.5;
  color: rgba(255,255,255,0.9);
  letter-spacing: -0.01em;
}
.band-dark-inner em    { font-style: italic; color: var(--color-warning); }

.band-dark-quote {
  font-family: var(--font-display);
  font-size: clamp(19px, 2.5vw, 26px);
  line-height: 1.55;
  color: rgba(255,255,255,0.92);
  letter-spacing: -0.01em;
}

.band-dark-body {
  font-size: 16px;
  line-height: 1.8;
  color: rgba(255,255,255,0.70);
}

.band-dark-body em {
  font-style: italic;
  color: rgba(255,255,255,0.90);
}

/* ══════════════════════════════════════════
   GRID — 2 column card grid
══════════════════════════════════════════ */
.grid-2col {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}

/* ══════════════════════════════════════════
   GRID — 2 column values card grid
══════════════════════════════════════════ */
.values-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-top: 56px;
}

.value-card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-primary);
  border-radius: var(--radius-md);
  padding: 32px 30px;
}

.value-card-title {
  font-family: var(--font-sans);
  font-size: 16px;
  font-weight: 700;
  color: var(--color-body);
  margin-bottom: 10px;
  line-height: 1.3;
}

.value-card-body {
  font-size: 14px;
  color: var(--color-muted);
  line-height: 1.75;
}

/* ══════════════════════════════════════════
   CARD — icon card (used in grid-2col)
══════════════════════════════════════════ */
.card-icon {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 32px 30px;
  transition: box-shadow 0.2s, transform 0.2s;
}
.card-icon:hover       { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.card-icon-figure      { font-size: 26px; margin-bottom: 16px; }
.card-icon-title       { font-family: var(--font-sans); font-size: 17px; font-weight: 700; color: var(--color-body); margin-bottom: 8px; }
.card-icon-body        { font-size: 14px; color: var(--color-muted); line-height: 1.7; }

/* ══════════════════════════════════════════
   CARD — split action (text left, button right)
══════════════════════════════════════════ */
.card-split-action {
  background: var(--color-primary-pale);
  border: 1px solid var(--color-primary-border);
  border-radius: var(--radius-lg);
  padding: 40px 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
}
.card-split-action h3  { font-family: var(--font-display); font-size: 26px; color: var(--color-body); margin-bottom: 6px; }
.card-split-action p   { font-size: 15px; color: var(--color-muted); }

/* ══════════════════════════════════════════
   GRID — 3 column joined block grid
══════════════════════════════════════════ */
.grid-3col-joined {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  background: var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.grid-3col-joined-cell { background: var(--color-white); padding: 40px 36px; }
.decorative-number {
  font-family: var(--font-display);
  font-size: 56px;
  line-height: 1;
  color: var(--color-border);
  margin-bottom: 20px;
  display: block;
}
.cell-icon             { font-size: 24px; margin-bottom: 16px; }
.cell-title            { font-family: var(--font-sans); font-size: 18px; font-weight: 700; color: var(--color-body); margin-bottom: 10px; }
.cell-body             { font-size: 14px; color: var(--color-muted); line-height: 1.7; }

/* ══════════════════════════════════════════
   LIST — label + body rows
══════════════════════════════════════════ */
.list-label-body       { display: flex; flex-direction: column; gap: 3px; }
.row-label-body {
  display: grid;
  grid-template-columns: 200px 1fr;
  background: var(--color-border-lt);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: box-shadow 0.2s;
}
.row-label-body:hover          { box-shadow: var(--shadow-sm); }
.row-label-body-label {
  background: var(--color-white);
  padding: 28px 24px;
  display: flex; align-items: flex-start; gap: 12px;
  border-right: 1px solid var(--color-border-lt);
}
.row-label-body-icon           { font-size: 20px; margin-top: 1px; flex-shrink: 0; }
.row-label-body-name           { font-size: 15px; font-weight: 700; color: var(--color-body); line-height: 1.3; }
.row-label-body-content        { background: var(--color-white); padding: 28px; font-size: 14px; color: var(--color-muted); line-height: 1.75; }

/* ══════════════════════════════════════════
   LAYOUT — 2 column text + aside
══════════════════════════════════════════ */
.layout-2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.layout-2col-primary .display-section { margin-bottom: 20px; }
.layout-2col-primary .body-copy       { margin-bottom: 14px; }

/* ══════════════════════════════════════════
   CARD — pullquote
══════════════════════════════════════════ */
.card-pullquote {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-danger);
  border-radius: var(--radius-md);
  padding: 32px 30px;
}
.card-pullquote blockquote {
  font-family: var(--font-display);
  font-size: 19px;
  font-style: italic;
  line-height: 1.55;
  color: var(--color-body);
  margin-bottom: 16px;
}
.card-pullquote-attr           { font-size: 13px; color: var(--color-muted); }
.card-pullquote-attr strong    { display: block; font-size: 14px; font-weight: 600; color: var(--color-body); margin-bottom: 2px; }

/* ══════════════════════════════════════════
   FINAL CTA
══════════════════════════════════════════ */
.final-cta             { position: relative; overflow: hidden; }
.final-cta::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 70% at 30% 50%, rgba(132,165,157,0.12) 0%, transparent 60%),
    radial-gradient(ellipse 40% 40% at 75% 30%, rgba(232,96,90,0.08) 0%, transparent 50%);
  pointer-events: none;
}
.centered-content      { position: relative; max-width: 680px; margin: 0 auto; text-align: center; }
.cta-note              { margin-top: 18px; font-size: 13px; color: rgba(255,255,255,0.35); }

/* ══════════════════════════════════════════
   PRIVACY PAGE
══════════════════════════════════════════ */
.policy-page           { max-width: 720px; margin: 0 auto; padding: 72px 28px 96px; }
.policy-meta           { font-size: 14px; color: var(--color-muted); margin-bottom: 48px; padding-bottom: 40px; border-bottom: 1px solid var(--color-border); }
.policy-body           { display: flex; flex-direction: column; gap: 3px; }
.policy-section {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 28px 32px;
}
.policy-section h2     { font-family: var(--font-sans); font-size: 11px; font-weight: 600; letter-spacing: 0.09em; text-transform: uppercase; color: var(--color-primary-dk); margin-bottom: 14px; }
.policy-section p      { font-size: 15px; color: var(--color-muted); line-height: 1.75; }
.policy-section p + p  { margin-top: 12px; }
.policy-section a      { color: var(--color-danger); font-weight: 600; text-decoration: underline; text-decoration-color: rgba(232,96,90,0.3); }
.policy-section a:hover { text-decoration-color: var(--color-danger); }
.policy-section strong { font-weight: 600; color: var(--color-body); }

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media (max-width: 900px) {
  .hero-inner            { grid-template-columns: 1fr; gap: 48px; }
  .hero-visual           { order: -1; }
  .layout-2col           { grid-template-columns: 1fr; gap: 40px; }
  .grid-3col-joined      { grid-template-columns: 1fr; }
  .grid-2col             { grid-template-columns: 1fr; }
  .values-grid           { grid-template-columns: 1fr; }
  .row-label-body        { grid-template-columns: 1fr; }
  .row-label-body-label  { border-right: none; border-bottom: 1px solid var(--color-border-lt); }
  .card-split-action     { flex-direction: column; text-align: center; padding: 32px 24px; }
  .nav-links             { display: none; }
}
@media (max-width: 600px) {
  .container             { padding: 0 20px; }
  .section, .section-alt, .section-dark { padding: 72px 0; }
  .hero                  { padding: 72px 0 64px; }
  .hero-actions          { flex-direction: column; align-items: flex-start; }
  .btn-lg                { width: 100%; justify-content: center; }
  .footer-inner          { flex-direction: column; align-items: flex-start; }
  .policy-page           { padding: 48px 20px 72px; }
}

@media print {
  .hero::before,
  .final-cta::before {
    display: none;
  }
}
