/* ═══════════════════════════════════════════════════════════════
   OneQR Events — Stylesheet
   Niagara Edit type system: Cormorant Garamond + DM Sans
   Editorial-luxury aesthetic, accessible-pricing posture
   ═══════════════════════════════════════════════════════════════ */

/* ── Design Tokens ──────────────────────────────────────────── */
:root {
  /* Warm editorial neutrals */
  --oneqr-bg:           #F8F4EE;
  --oneqr-bg-alt:       #F1ECE3;
  --oneqr-ink:          #1A1612;
  --oneqr-ink-soft:     #4A413A;
  --oneqr-ink-muted:    #8A7F75;
  --oneqr-line:         #E0D8CB;
  --oneqr-paper:        #FFFFFF;

  /* Single accent — terracotta, warmer than coral, more editorial */
  --oneqr-accent:       #C4593A;
  --oneqr-accent-hover: #A8472C;
  --oneqr-accent-soft:  #F5DDD0;

  /* Gold for "Best value" tier emphasis */
  --oneqr-gold:         #B8945A;
  --oneqr-gold-soft:    #EFE2C7;

  /* Dark mode for contrast sections */
  --oneqr-dark:         #1F1B17;
  --oneqr-dark-alt:     #2C2622;

  /* Type */
  --oneqr-font-display: 'Cormorant Garamond', 'Times New Roman', Georgia, serif;
  --oneqr-font-body:    'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  --oneqr-text-xs:    clamp(0.75rem,  0.7rem  + 0.2vw,  0.8125rem);
  --oneqr-text-sm:    clamp(0.875rem, 0.83rem + 0.25vw, 0.9375rem);
  --oneqr-text-base:  clamp(1rem,     0.95rem + 0.25vw, 1.0625rem);
  --oneqr-text-lg:    clamp(1.125rem, 1.05rem + 0.4vw,  1.25rem);
  --oneqr-text-xl:    clamp(1.375rem, 1.2rem  + 0.85vw, 1.625rem);
  --oneqr-text-2xl:   clamp(1.75rem,  1.4rem  + 1.6vw,  2.5rem);
  --oneqr-text-3xl:   clamp(2.25rem,  1.5rem  + 3vw,    3.75rem);
  --oneqr-text-4xl:   clamp(2.75rem,  1.6rem  + 4.5vw,  5rem);

  /* Spacing */
  --oneqr-space-1: 0.25rem;
  --oneqr-space-2: 0.5rem;
  --oneqr-space-3: 0.75rem;
  --oneqr-space-4: 1rem;
  --oneqr-space-5: 1.5rem;
  --oneqr-space-6: 2rem;
  --oneqr-space-7: 3rem;
  --oneqr-space-8: 4rem;
  --oneqr-space-9: 6rem;
  --oneqr-space-10: 8rem;

  /* Layout */
  --oneqr-container: 1200px;
  --oneqr-container-narrow: 760px;

  /* Radius */
  --oneqr-radius-sm: 4px;
  --oneqr-radius-md: 8px;
  --oneqr-radius-lg: 16px;
  --oneqr-radius-pill: 999px;

  /* Motion */
  --oneqr-ease: cubic-bezier(0.16, 1, 0.3, 1);
  --oneqr-fast: 180ms;
  --oneqr-slow: 360ms;

  /* Shadows */
  --oneqr-shadow-sm: 0 1px 2px rgba(26, 22, 18, 0.04);
  --oneqr-shadow-md: 0 8px 24px rgba(26, 22, 18, 0.06);
  --oneqr-shadow-lg: 0 16px 48px rgba(26, 22, 18, 0.10);
}

/* ── Reset + Base ───────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }

html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  font-family: var(--oneqr-font-body);
  font-size: var(--oneqr-text-base);
  line-height: 1.6;
  color: var(--oneqr-ink);
  background: var(--oneqr-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img, picture { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; transition: color var(--oneqr-fast) var(--oneqr-ease); }
button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; }
input, textarea, select { font: inherit; color: inherit; }
::selection { background: var(--oneqr-accent); color: var(--oneqr-paper); }

/* ── Typography ─────────────────────────────────────────────── */
h1, h2, h3, h4 {
  font-family: var(--oneqr-font-display);
  font-weight: 500;
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: var(--oneqr-ink);
}
h1 { font-size: var(--oneqr-text-4xl); font-weight: 400; letter-spacing: -0.02em; }
h2 { font-size: var(--oneqr-text-3xl); font-weight: 400; }
h3 { font-size: var(--oneqr-text-xl); }
h4 { font-size: var(--oneqr-text-lg); font-family: var(--oneqr-font-body); font-weight: 500; letter-spacing: 0; }

em { font-style: italic; color: var(--oneqr-accent); }
p { color: var(--oneqr-ink-soft); }

.eyebrow {
  font-family: var(--oneqr-font-body);
  font-size: var(--oneqr-text-xs);
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--oneqr-accent);
  display: inline-block;
}

.lead {
  font-size: var(--oneqr-text-lg);
  line-height: 1.55;
  color: var(--oneqr-ink-soft);
  max-width: 60ch;
}

/* ── Layout ─────────────────────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--oneqr-container);
  margin-inline: auto;
  padding-inline: var(--oneqr-space-5);
}

.container-narrow {
  width: 100%;
  max-width: var(--oneqr-container-narrow);
  margin-inline: auto;
  padding-inline: var(--oneqr-space-5);
}

.section { padding-block: clamp(var(--oneqr-space-8), 8vw, var(--oneqr-space-10)); }
.section-tight { padding-block: clamp(var(--oneqr-space-7), 6vw, var(--oneqr-space-9)); }
.section-alt { background: var(--oneqr-bg-alt); }
.section-dark { background: var(--oneqr-dark); color: var(--oneqr-bg); }
.section-dark h1, .section-dark h2, .section-dark h3 { color: var(--oneqr-bg); }
.section-dark p { color: rgba(248, 244, 238, 0.75); }
.section-dark .eyebrow { color: var(--oneqr-gold); }

/* ── Buttons ────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--oneqr-space-2);
  padding: 0.875rem 1.75rem;
  font-family: var(--oneqr-font-body);
  font-size: var(--oneqr-text-sm);
  font-weight: 500;
  letter-spacing: 0.01em;
  border-radius: var(--oneqr-radius-pill);
  border: 1px solid transparent;
  cursor: pointer;
  transition: all var(--oneqr-fast) var(--oneqr-ease);
  white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }

.btn-primary { background: var(--oneqr-accent); color: var(--oneqr-paper); }
.btn-primary:hover { background: var(--oneqr-accent-hover); box-shadow: var(--oneqr-shadow-md); }

.btn-ghost { background: transparent; color: var(--oneqr-ink); border-color: var(--oneqr-ink); }
.btn-ghost:hover { background: var(--oneqr-ink); color: var(--oneqr-paper); }

.btn-light { background: var(--oneqr-paper); color: var(--oneqr-ink); border-color: var(--oneqr-line); }
.btn-light:hover { border-color: var(--oneqr-ink); }

.btn-arrow::after {
  content: '→';
  font-family: var(--oneqr-font-body);
  font-weight: 400;
  transition: transform var(--oneqr-fast) var(--oneqr-ease);
}
.btn-arrow:hover::after { transform: translateX(3px); }

.text-link {
  color: var(--oneqr-accent);
  font-weight: 500;
  border-bottom: 1px solid var(--oneqr-accent-soft);
  padding-bottom: 1px;
  transition: border-color var(--oneqr-fast) var(--oneqr-ease);
}
.text-link:hover { border-color: var(--oneqr-accent); }

/* ── Header / Nav ───────────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(248, 244, 238, 0.85);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--oneqr-line);
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--oneqr-space-5);
  padding-block: var(--oneqr-space-4);
}

.nav-brand {
  font-family: var(--oneqr-font-display);
  font-size: var(--oneqr-text-xl);
  font-weight: 500;
  color: var(--oneqr-ink);
  display: flex;
  align-items: baseline;
  gap: 0.4rem;
}
.nav-brand-mark { color: var(--oneqr-accent); font-style: italic; }

.nav-menu {
  display: none;
  align-items: center;
  gap: var(--oneqr-space-6);
  list-style: none;
}
.nav-menu a { font-size: var(--oneqr-text-sm); color: var(--oneqr-ink-soft); }
.nav-menu a:hover { color: var(--oneqr-ink); }
.nav-menu a.is-current { color: var(--oneqr-ink); font-weight: 500; }

.nav-cta { display: none; }

@media (min-width: 768px) {
  .nav-menu { display: flex; }
  .nav-cta { display: inline-flex; }
}

.nav-toggle {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: var(--oneqr-space-2);
}
.nav-toggle span { display: block; width: 22px; height: 1.5px; background: var(--oneqr-ink); }
@media (min-width: 768px) { .nav-toggle { display: none; } }

.nav-drawer {
  display: none;
  border-top: 1px solid var(--oneqr-line);
  padding-block: var(--oneqr-space-4);
}
.nav-drawer.is-open { display: block; }
.nav-drawer ul { list-style: none; display: flex; flex-direction: column; gap: var(--oneqr-space-4); }
.nav-drawer a {
  display: block;
  font-size: var(--oneqr-text-base);
  color: var(--oneqr-ink-soft);
  padding-block: var(--oneqr-space-2);
}

/* ── Hero ───────────────────────────────────────────────────── */
.hero {
  padding-block: clamp(var(--oneqr-space-7), 7vw, var(--oneqr-space-9)) clamp(var(--oneqr-space-8), 8vw, var(--oneqr-space-10));
  position: relative;
  overflow: hidden;
}

.hero-grid {
  display: grid;
  gap: var(--oneqr-space-7);
  align-items: center;
}

@media (min-width: 900px) {
  .hero-grid {
    grid-template-columns: 1.05fr 1fr;
    gap: var(--oneqr-space-9);
  }
}

.hero-eyebrow { margin-bottom: var(--oneqr-space-4); }

.hero-headline {
  font-size: clamp(2.5rem, 1.4rem + 4.5vw, 4.75rem);
  line-height: 1.04;
  font-weight: 400;
  margin-bottom: var(--oneqr-space-5);
  max-width: 14ch;
  letter-spacing: -0.02em;
}
.hero-headline em { font-weight: 400; }

.hero-sub {
  font-size: var(--oneqr-text-lg);
  line-height: 1.55;
  color: var(--oneqr-ink-soft);
  max-width: 50ch;
  margin-bottom: var(--oneqr-space-6);
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--oneqr-space-3);
  margin-bottom: var(--oneqr-space-7);
}

.hero-image {
  position: relative;
  border-radius: var(--oneqr-radius-lg);
  overflow: hidden;
  box-shadow: var(--oneqr-shadow-lg);
  aspect-ratio: 4/5;
}
.hero-image img { width: 100%; height: 100%; object-fit: cover; }

@media (min-width: 900px) {
  .hero-image { aspect-ratio: 5/6; }
}

/* Trust strip below hero */
.trust-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--oneqr-space-4) var(--oneqr-space-6);
  padding-top: var(--oneqr-space-5);
  border-top: 1px solid var(--oneqr-line);
  font-size: var(--oneqr-text-sm);
  color: var(--oneqr-ink-muted);
}
.trust-strip strong { color: var(--oneqr-ink); font-weight: 500; }
.trust-strip-divider { color: var(--oneqr-line); }

/* ── Section header ─────────────────────────────────────────── */
.section-head {
  text-align: center;
  margin-bottom: var(--oneqr-space-8);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--oneqr-space-3);
}
.section-head h2 { max-width: 22ch; }
.section-head p { max-width: 56ch; }

.section-head-left {
  text-align: left;
  align-items: flex-start;
  margin-bottom: var(--oneqr-space-7);
}

/* ── Feature grid (3-up integration thesis) ─────────────────── */
.feature-grid {
  display: grid;
  gap: var(--oneqr-space-5);
}
@media (min-width: 700px) { .feature-grid { grid-template-columns: repeat(3, 1fr); } }

.feature-card {
  background: var(--oneqr-paper);
  border-radius: var(--oneqr-radius-lg);
  overflow: hidden;
  border: 1px solid var(--oneqr-line);
  display: flex;
  flex-direction: column;
  transition: transform var(--oneqr-slow) var(--oneqr-ease), box-shadow var(--oneqr-slow) var(--oneqr-ease);
}
.feature-card:hover { transform: translateY(-2px); box-shadow: var(--oneqr-shadow-md); }

.feature-card-image {
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--oneqr-bg-alt);
}
.feature-card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--oneqr-slow) var(--oneqr-ease); }
.feature-card:hover .feature-card-image img { transform: scale(1.03); }

.feature-card-body {
  padding: var(--oneqr-space-5) var(--oneqr-space-5) var(--oneqr-space-6);
  display: flex;
  flex-direction: column;
  gap: var(--oneqr-space-3);
}

.feature-card-num {
  font-family: var(--oneqr-font-display);
  font-style: italic;
  font-size: var(--oneqr-text-base);
  color: var(--oneqr-accent);
}

.feature-card h3 { font-size: var(--oneqr-text-lg); line-height: 1.25; }
.feature-card p { font-size: var(--oneqr-text-sm); line-height: 1.6; }

/* ── Pull quote (built-not-promised) ────────────────────────── */
.pull-quote {
  text-align: center;
  font-family: var(--oneqr-font-display);
  font-style: italic;
  font-size: clamp(1.5rem, 1rem + 2vw, 2.25rem);
  line-height: 1.3;
  color: var(--oneqr-ink);
  max-width: 28ch;
  margin-inline: auto;
  letter-spacing: -0.01em;
}
.pull-quote-link { color: var(--oneqr-accent); border-bottom: 1px solid var(--oneqr-accent-soft); }
.pull-quote-link:hover { border-color: var(--oneqr-accent); }

/* ── Pricing teaser cards (homepage) ────────────────────────── */
.tier-row {
  display: grid;
  gap: var(--oneqr-space-4);
}
@media (min-width: 800px) { .tier-row { grid-template-columns: repeat(3, 1fr); } }

.tier-card-mini {
  background: var(--oneqr-paper);
  border: 1px solid var(--oneqr-line);
  border-radius: var(--oneqr-radius-lg);
  padding: var(--oneqr-space-6) var(--oneqr-space-5);
  display: flex;
  flex-direction: column;
  gap: var(--oneqr-space-3);
}
.tier-card-mini-name {
  font-family: var(--oneqr-font-body);
  font-size: var(--oneqr-text-sm);
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--oneqr-ink-muted);
}
.tier-card-mini-price {
  font-family: var(--oneqr-font-display);
  font-size: var(--oneqr-text-3xl);
  font-weight: 400;
  line-height: 1;
  color: var(--oneqr-ink);
}
.tier-card-mini-price-detail { font-size: var(--oneqr-text-sm); color: var(--oneqr-ink-muted); margin-left: var(--oneqr-space-1); }
.tier-card-mini-tag {
  font-size: var(--oneqr-text-sm);
  color: var(--oneqr-ink-soft);
  line-height: 1.5;
}
.tier-card-mini.is-featured {
  border-color: var(--oneqr-gold);
  background: linear-gradient(180deg, var(--oneqr-gold-soft) 0%, var(--oneqr-paper) 30%);
  position: relative;
}
.tier-card-mini.is-featured::before {
  content: 'Best value';
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--oneqr-gold);
  color: var(--oneqr-paper);
  font-size: var(--oneqr-text-xs);
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 4px 14px;
  border-radius: var(--oneqr-radius-pill);
}

/* ── Closing CTA ────────────────────────────────────────────── */
.closing {
  text-align: center;
  padding-block: clamp(var(--oneqr-space-8), 8vw, var(--oneqr-space-10));
}
.closing h2 { max-width: 18ch; margin-inline: auto; margin-bottom: var(--oneqr-space-5); }
.closing p { max-width: 50ch; margin-inline: auto; margin-bottom: var(--oneqr-space-6); }
.closing-actions { display: flex; flex-wrap: wrap; gap: var(--oneqr-space-3); justify-content: center; }

/* ── Pricing page — full tier grid ──────────────────────────── */
.tier-grid {
  display: grid;
  gap: var(--oneqr-space-5);
}
@media (min-width: 800px) { .tier-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .tier-grid { grid-template-columns: repeat(4, 1fr); gap: var(--oneqr-space-4); } }

.tier-card {
  background: var(--oneqr-paper);
  border: 1px solid var(--oneqr-line);
  border-radius: var(--oneqr-radius-lg);
  padding: var(--oneqr-space-6) var(--oneqr-space-5) var(--oneqr-space-7);
  display: flex;
  flex-direction: column;
  gap: var(--oneqr-space-4);
  position: relative;
}

.tier-card.is-featured {
  border-color: var(--oneqr-gold);
  border-width: 2px;
  background: linear-gradient(180deg, var(--oneqr-gold-soft) 0%, var(--oneqr-paper) 25%);
}
.tier-card.is-featured::before {
  content: 'Best value';
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--oneqr-gold);
  color: var(--oneqr-paper);
  font-size: var(--oneqr-text-xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 5px 16px;
  border-radius: var(--oneqr-radius-pill);
}

.tier-name {
  font-family: var(--oneqr-font-body);
  font-size: var(--oneqr-text-sm);
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--oneqr-ink-muted);
}
.tier-price {
  font-family: var(--oneqr-font-display);
  font-size: clamp(2.5rem, 1.5rem + 3vw, 3.5rem);
  font-weight: 400;
  line-height: 1;
  color: var(--oneqr-ink);
  display: flex;
  align-items: baseline;
  gap: var(--oneqr-space-2);
}
.tier-price small {
  font-family: var(--oneqr-font-body);
  font-size: var(--oneqr-text-sm);
  font-weight: 400;
  color: var(--oneqr-ink-muted);
}
.tier-tagline { font-size: var(--oneqr-text-sm); color: var(--oneqr-ink-soft); line-height: 1.55; }

.tier-features {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--oneqr-space-2);
  margin-block: var(--oneqr-space-4);
  padding-block: var(--oneqr-space-4) 0;
  border-top: 1px solid var(--oneqr-line);
  flex: 1;
}
.tier-features li {
  font-size: var(--oneqr-text-sm);
  color: var(--oneqr-ink-soft);
  padding-left: var(--oneqr-space-5);
  position: relative;
  line-height: 1.5;
}
.tier-features li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 12px;
  height: 6px;
  border-left: 1.5px solid var(--oneqr-accent);
  border-bottom: 1.5px solid var(--oneqr-accent);
  transform: rotate(-45deg);
}

.tier-foot { font-size: var(--oneqr-text-xs); color: var(--oneqr-ink-muted); font-style: italic; margin-top: auto; }

/* ── FAQ accordion ──────────────────────────────────────────── */
.faq-list {
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--oneqr-line);
}
.faq-item { border-bottom: 1px solid var(--oneqr-line); }

.faq-item summary {
  list-style: none;
  cursor: pointer;
  padding-block: var(--oneqr-space-5);
  display: flex;
  justify-content: space-between;
  gap: var(--oneqr-space-4);
  align-items: flex-start;
  font-family: var(--oneqr-font-display);
  font-size: var(--oneqr-text-lg);
  font-weight: 500;
  color: var(--oneqr-ink);
  letter-spacing: -0.01em;
  transition: color var(--oneqr-fast) var(--oneqr-ease);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary:hover { color: var(--oneqr-accent); }

.faq-icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid var(--oneqr-line);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  transition: transform var(--oneqr-slow) var(--oneqr-ease), border-color var(--oneqr-fast) var(--oneqr-ease);
}
.faq-icon::before, .faq-icon::after {
  content: '';
  position: absolute;
  background: var(--oneqr-ink);
  transition: opacity var(--oneqr-fast) var(--oneqr-ease);
}
.faq-icon::before { width: 10px; height: 1.5px; }
.faq-icon::after { width: 1.5px; height: 10px; }
.faq-item[open] .faq-icon { transform: rotate(135deg); border-color: var(--oneqr-accent); }
.faq-item[open] .faq-icon::before { background: var(--oneqr-accent); }
.faq-item[open] .faq-icon::after { background: var(--oneqr-accent); }

.faq-answer {
  padding-bottom: var(--oneqr-space-5);
  padding-right: 44px;
  font-size: var(--oneqr-text-base);
  line-height: 1.65;
  color: var(--oneqr-ink-soft);
}

/* ── Journey steps (How It Works) ───────────────────────────── */
.journey {
  display: grid;
  gap: var(--oneqr-space-7);
}
@media (min-width: 700px) { .journey { grid-template-columns: repeat(2, 1fr); gap: var(--oneqr-space-6); } }
@media (min-width: 1000px) { .journey { grid-template-columns: repeat(4, 1fr); gap: var(--oneqr-space-5); } }

.journey-step { display: flex; flex-direction: column; gap: var(--oneqr-space-4); }
.journey-step-image {
  aspect-ratio: 1/1;
  border-radius: var(--oneqr-radius-lg);
  overflow: hidden;
  background: var(--oneqr-bg-alt);
  position: relative;
}
.journey-step-image img { width: 100%; height: 100%; object-fit: cover; }
.journey-step-num {
  position: absolute;
  top: var(--oneqr-space-4);
  left: var(--oneqr-space-4);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--oneqr-paper);
  color: var(--oneqr-ink);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--oneqr-font-display);
  font-size: var(--oneqr-text-base);
  font-weight: 500;
}
.journey-step h3 { font-size: var(--oneqr-text-lg); }
.journey-step p { font-size: var(--oneqr-text-sm); line-height: 1.6; }

/* ── Setup steps (3-up) ─────────────────────────────────────── */
.setup-grid {
  display: grid;
  gap: var(--oneqr-space-5);
}
@media (min-width: 800px) { .setup-grid { grid-template-columns: repeat(3, 1fr); } }

.setup-step {
  background: var(--oneqr-paper);
  border-radius: var(--oneqr-radius-lg);
  padding: var(--oneqr-space-6) var(--oneqr-space-5);
  border: 1px solid var(--oneqr-line);
  display: flex;
  flex-direction: column;
  gap: var(--oneqr-space-3);
}
.setup-step-num {
  font-family: var(--oneqr-font-display);
  font-style: italic;
  font-size: var(--oneqr-text-2xl);
  color: var(--oneqr-accent);
  line-height: 1;
}
.setup-step h3 { font-size: var(--oneqr-text-lg); }
.setup-step p { font-size: var(--oneqr-text-sm); }
.setup-step-time {
  font-size: var(--oneqr-text-xs);
  color: var(--oneqr-ink-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-top: auto;
  padding-top: var(--oneqr-space-3);
  border-top: 1px solid var(--oneqr-line);
}
.setup-step-time strong { color: var(--oneqr-ink); font-weight: 500; }

/* ── Includes grid (12 pills) ───────────────────────────────── */
.includes-grid {
  display: grid;
  gap: var(--oneqr-space-3);
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 700px) { .includes-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1000px) { .includes-grid { grid-template-columns: repeat(4, 1fr); } }

.include-pill {
  background: var(--oneqr-paper);
  border: 1px solid var(--oneqr-line);
  border-radius: var(--oneqr-radius-pill);
  padding: var(--oneqr-space-3) var(--oneqr-space-4);
  font-size: var(--oneqr-text-sm);
  text-align: center;
  color: var(--oneqr-ink-soft);
}

/* ── About proof stats ──────────────────────────────────────── */
.proof-grid {
  display: grid;
  gap: var(--oneqr-space-5);
  grid-template-columns: repeat(2, 1fr);
  text-align: center;
}
@media (min-width: 700px) { .proof-grid { grid-template-columns: repeat(4, 1fr); } }

.proof-stat-num {
  font-family: var(--oneqr-font-display);
  font-size: var(--oneqr-text-2xl);
  font-weight: 400;
  color: var(--oneqr-ink);
  line-height: 1;
  margin-bottom: var(--oneqr-space-2);
}
.proof-stat-num em { font-style: italic; color: var(--oneqr-accent); }
.proof-stat-label {
  font-size: var(--oneqr-text-xs);
  color: var(--oneqr-ink-muted);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

/* ── About essay ────────────────────────────────────────────── */
.essay {
  max-width: 65ch;
  margin-inline: auto;
  font-size: var(--oneqr-text-lg);
  line-height: 1.7;
  color: var(--oneqr-ink-soft);
}
.essay p { margin-bottom: var(--oneqr-space-5); }
.essay p:last-child { margin-bottom: 0; }
.essay em { display: inline; }
.essay-pull {
  font-family: var(--oneqr-font-display);
  font-style: italic;
  font-size: var(--oneqr-text-xl);
  line-height: 1.4;
  color: var(--oneqr-ink);
  border-left: 2px solid var(--oneqr-accent);
  padding-left: var(--oneqr-space-5);
  margin-block: var(--oneqr-space-7);
}

/* ── Contact form ───────────────────────────────────────────── */
.contact-grid {
  display: grid;
  gap: var(--oneqr-space-7);
}
@media (min-width: 900px) {
  .contact-grid { grid-template-columns: 1fr 1.4fr; gap: var(--oneqr-space-9); }
}

.contact-info { display: flex; flex-direction: column; gap: var(--oneqr-space-5); }
.contact-info-item {
  padding-block: var(--oneqr-space-4);
  border-top: 1px solid var(--oneqr-line);
}
.contact-info-item:last-child { border-bottom: 1px solid var(--oneqr-line); }
.contact-info-label {
  font-size: var(--oneqr-text-xs);
  color: var(--oneqr-ink-muted);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: var(--oneqr-space-2);
}
.contact-info-value { font-size: var(--oneqr-text-base); color: var(--oneqr-ink); }
.contact-info-value a { color: var(--oneqr-accent); }
.contact-info-value a:hover { color: var(--oneqr-accent-hover); }

.form { display: flex; flex-direction: column; gap: var(--oneqr-space-4); }
.form-row { display: grid; gap: var(--oneqr-space-4); }
@media (min-width: 600px) { .form-row.cols-2 { grid-template-columns: 1fr 1fr; } }

.form-field { display: flex; flex-direction: column; gap: var(--oneqr-space-2); }
.form-label {
  font-size: var(--oneqr-text-xs);
  color: var(--oneqr-ink-muted);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 500;
}
.form-input, .form-textarea, .form-select {
  width: 100%;
  padding: 0.875rem 1rem;
  background: var(--oneqr-paper);
  border: 1px solid var(--oneqr-line);
  border-radius: var(--oneqr-radius-md);
  font-size: var(--oneqr-text-base);
  color: var(--oneqr-ink);
  transition: border-color var(--oneqr-fast) var(--oneqr-ease), box-shadow var(--oneqr-fast) var(--oneqr-ease);
}
.form-input:focus, .form-textarea:focus, .form-select:focus {
  outline: none;
  border-color: var(--oneqr-accent);
  box-shadow: 0 0 0 3px var(--oneqr-accent-soft);
}
.form-textarea { resize: vertical; min-height: 120px; font-family: var(--oneqr-font-body); }
.form-radio-group { display: flex; flex-direction: column; gap: var(--oneqr-space-2); }
.form-radio {
  display: flex;
  align-items: center;
  gap: var(--oneqr-space-3);
  padding: var(--oneqr-space-3) var(--oneqr-space-4);
  background: var(--oneqr-paper);
  border: 1px solid var(--oneqr-line);
  border-radius: var(--oneqr-radius-md);
  cursor: pointer;
  transition: border-color var(--oneqr-fast) var(--oneqr-ease);
  font-size: var(--oneqr-text-sm);
}
.form-radio:hover { border-color: var(--oneqr-ink-muted); }
.form-radio input[type="radio"] { accent-color: var(--oneqr-accent); }
.form-radio:has(input:checked) { border-color: var(--oneqr-accent); background: var(--oneqr-accent-soft); }

.form-submit { align-self: flex-start; margin-top: var(--oneqr-space-3); }
.form-success, .form-error {
  padding: var(--oneqr-space-4);
  border-radius: var(--oneqr-radius-md);
  font-size: var(--oneqr-text-sm);
  display: none;
}
.form-success { background: var(--oneqr-gold-soft); color: var(--oneqr-ink); }
.form-error { background: var(--oneqr-accent-soft); color: var(--oneqr-accent-hover); }
.form-success.is-visible, .form-error.is-visible { display: block; }

/* ── Footer ─────────────────────────────────────────────────── */
.site-footer {
  background: var(--oneqr-dark);
  color: var(--oneqr-bg);
  padding-block: var(--oneqr-space-8) var(--oneqr-space-6);
}
.footer-grid {
  display: grid;
  gap: var(--oneqr-space-6);
  margin-bottom: var(--oneqr-space-7);
}
@media (min-width: 700px) { .footer-grid { grid-template-columns: 2fr 1fr 1fr; } }

.footer-brand { display: flex; flex-direction: column; gap: var(--oneqr-space-3); max-width: 36ch; }
.footer-brand-name {
  font-family: var(--oneqr-font-display);
  font-size: var(--oneqr-text-2xl);
  font-weight: 400;
  color: var(--oneqr-bg);
  letter-spacing: -0.01em;
}
.footer-brand-name em { color: var(--oneqr-gold); font-style: italic; }
.footer-tagline { font-size: var(--oneqr-text-sm); color: rgba(248, 244, 238, 0.7); line-height: 1.6; }

.footer-col h4 {
  font-family: var(--oneqr-font-body);
  font-size: var(--oneqr-text-xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--oneqr-gold);
  margin-bottom: var(--oneqr-space-4);
}
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: var(--oneqr-space-3); }
.footer-col a { font-size: var(--oneqr-text-sm); color: rgba(248, 244, 238, 0.7); }
.footer-col a:hover { color: var(--oneqr-bg); }

.footer-bottom {
  padding-top: var(--oneqr-space-5);
  border-top: 1px solid rgba(248, 244, 238, 0.1);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--oneqr-space-4);
  font-size: var(--oneqr-text-xs);
  color: rgba(248, 244, 238, 0.5);
}
.footer-bottom a { color: rgba(248, 244, 238, 0.7); }
.footer-bottom a:hover { color: var(--oneqr-bg); }

/* ── Page header (non-home pages) ───────────────────────────── */
.page-header {
  padding-block: clamp(var(--oneqr-space-8), 7vw, var(--oneqr-space-9)) clamp(var(--oneqr-space-7), 5vw, var(--oneqr-space-8));
  text-align: center;
}
.page-header h1 {
  max-width: 18ch;
  margin-inline: auto;
  margin-bottom: var(--oneqr-space-4);
  font-size: clamp(2.25rem, 1.5rem + 3vw, 3.75rem);
}
.page-header p { max-width: 56ch; margin-inline: auto; }

/* ── Comparison table ───────────────────────────────────────── */
.compare-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--oneqr-text-sm);
}
.compare-table th, .compare-table td {
  padding: var(--oneqr-space-4);
  text-align: left;
  border-bottom: 1px solid var(--oneqr-line);
}
.compare-table th {
  font-family: var(--oneqr-font-body);
  font-weight: 500;
  font-size: var(--oneqr-text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--oneqr-ink-muted);
}
.compare-table td:first-child {
  font-weight: 500;
  color: var(--oneqr-ink);
}
.compare-table td.tier-yes { color: var(--oneqr-accent); font-weight: 500; }
.compare-table td.tier-no { color: var(--oneqr-ink-muted); }
@media (max-width: 700px) {
  .compare-table { font-size: var(--oneqr-text-xs); }
  .compare-table th, .compare-table td { padding: var(--oneqr-space-3) var(--oneqr-space-2); }
}

/* ── Utilities ──────────────────────────────────────────────── */
.text-center { text-align: center; }
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
