/* ============================================================
   Variant 1 — ELEVATED EDITORIAL
   Mirrors the pitch deck: linen, serif headlines, botanical calm.
   Brand/story forward, investor section integrated near the end.
   ============================================================ */

body { background: var(--linen); }
section { scroll-margin-top: 78px; }

/* ---------- section heads ---------- */
.sec-head { max-width: 720px; margin-bottom: 54px; }
.sec-head.center { margin-left: auto; margin-right: auto; text-align: center; }
.sec-head h2 {
  font-family: var(--font-head); font-weight: 500;
  font-size: clamp(2rem, 4.2vw, 3.1rem); letter-spacing: .005em; margin: .35em 0 .5em;
}
.sec-head .sec-sub { color: var(--muted); font-size: 1.06rem; max-width: 64ch; }
.sec-head.center .sec-sub { margin-left: auto; margin-right: auto; }
.coral { color: var(--coral); }

/* ---------- header ---------- */
.site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  transition: background .4s var(--ease), box-shadow .4s var(--ease), padding .4s var(--ease);
  padding: 22px 0;
}
.site-header.scrolled {
  background: rgba(251,248,242,.92); backdrop-filter: blur(8px);
  box-shadow: 0 1px 0 var(--line); padding: 13px 0;
}
.header-inner { display: flex; align-items: center; justify-content: space-between; }
.brand { font-size: 1.85rem; color: var(--ink); text-decoration: none; line-height: 1; }
/* At the top of the homepage the big hero wordmark is already on screen, so
   the header logo would double up — fade it in only once the user scrolls. */
.site-header[data-hero-logo] .brand { transition: opacity .35s var(--ease); }
.site-header[data-hero-logo]:not(.scrolled) .brand { opacity: 0; pointer-events: none; }
.nav { display: flex; align-items: center; gap: 30px; }
.nav a {
  font-family: var(--font-label); font-size: .82rem; letter-spacing: .08em;
  text-transform: uppercase; text-decoration: none; color: var(--ink); opacity: .82;
  transition: opacity .2s;
}
.nav a:hover { opacity: 1; }
.nav .nav-cta {
  background: var(--forest); color: #fff; opacity: 1; padding: 9px 18px; border-radius: 4px;
}
.nav .nav-cta:hover { background: var(--forest-soft); }
.nav-toggle { display: none; background: none; border: 0; width: 34px; height: 30px; padding: 5px; }
.nav-toggle span { display: block; height: 2px; background: var(--ink); margin: 5px 0; transition: .3s; }

/* ---------- hero ---------- */
.hero {
  padding: 150px 0 80px;
  background:
    radial-gradient(circle at 80% 0%, rgba(216,225,212,.55), transparent 45%),
    var(--linen);
}
.hero-grid { display: grid; grid-template-columns: 1fr 1fr; column-gap: 50px; align-items: center; }
/* desktop: hero-copy is the left column (normal block); the lockup floats
   between the eyebrow and the lede via its own margins. */
.hero-word { font-size: 1em; color: var(--ink); line-height: .8; margin: 0; }
.hero-lockup {   /* the genny size lives here; width = logo width = the centering frame */
  display: inline-block; font-size: clamp(3.57rem, 10.2vw, 7.65rem);   /* 15% smaller than 9rem */
  width: 2.7em; margin: 1.6rem 0 1.6rem;   /* balanced margins → floats between eyebrow and lede */
}
.hero-tag {
  font-family: var(--font-label); text-transform: uppercase;
  letter-spacing: .34em; text-indent: .34em;   /* indent compensates the trailing track so it centers */
  font-size: .19em; line-height: 1; color: var(--taupe);   /* fixed fraction of the logo → always fits + centers */
  font-weight: 600; text-align: center; margin: .45em 0 0;
}
.hero-lede { font-size: 1.16rem; color: #4a4842; max-width: 46ch; margin-bottom: 1.8em; }
.hero-cta { display: flex; gap: 14px; flex-wrap: wrap; }
.hero-foot { margin-top: 1.6em; font-family: var(--font-label); font-size: .78rem;
  letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }
.hero-figure {
  margin: 0; border-radius: 8px; overflow: hidden;
  box-shadow: 0 40px 80px -30px rgba(70,66,55,.45); transform: rotate(.6deg);
}
.hero-figure img { width: 100%; height: 100%; object-fit: cover; }

/* ---------- why genny ---------- */
.why { padding: 96px 0; background: var(--cream); }
.prop-grid { list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(3,1fr); gap: 36px 40px; }
.prop { border-top: 1px solid var(--line); padding-top: 22px; }
.prop-ico {
  display: inline-flex; align-items: center; justify-content: center;
  width: 46px; height: 46px; border-radius: 50%; background: var(--sage-soft);
  color: var(--forest); font-size: 1.3rem; margin-bottom: 14px;
}
.prop h3 { font-family: var(--font-display); font-weight: 600; font-size: 1.28rem; margin-bottom: .3em; }
.prop p { color: var(--muted); margin: 0; font-size: .98rem; }

/* ---------- flavors ---------- */
.flavors { padding: 96px 0; background: var(--linen); }
.flavor-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 30px; }
.flavor {
  background: var(--cream); border-radius: 10px; padding: 30px 28px 34px; text-align: center;
  border-bottom: 4px solid var(--accent);
  box-shadow: 0 18px 40px -28px rgba(70,66,55,.5); transition: transform .35s var(--ease);
}
.flavor:hover { transform: translateY(-7px); }
.flavor-can { height: 290px; display: flex; align-items: flex-end; justify-content: center; margin-bottom: 18px; }
.flavor-can img { height: 100%; width: auto; filter: drop-shadow(0 16px 18px rgba(70,66,55,.22)); }
.flavor h3 { font-family: var(--font-display); font-size: 1.5rem; font-weight: 600; }
.flavor h3::after { content: ""; display: block; width: 30px; height: 3px; background: var(--accent);
  margin: 10px auto 12px; border-radius: 2px; }
.flavor p { color: var(--muted); font-size: .98rem; margin: 0; }

/* ---------- pull quote ---------- */
.pullquote { padding: 100px 0; background: var(--sage-soft);
  border-top: 1px solid var(--sage-line); border-bottom: 1px solid var(--sage-line); }
.pullquote .container { max-width: 980px; text-align: center; }
blockquote {
  margin: 0; font-family: var(--font-head); font-weight: 400;
  font-size: clamp(1.9rem, 5vw, 3.4rem); line-height: 1.28; color: #5d5b53;
}
blockquote em { font-style: italic; color: var(--sage-deep); }
blockquote .q { font-family: var(--font-head); color: var(--sage-deep); font-size: 1.2em; line-height: 0; }
.pq-attr { margin-top: 1.8em; font-style: italic; color: var(--muted); }
.pq-attr .wordmark { font-style: normal; letter-spacing: .12em; }

/* ---------- story ---------- */
.story { padding: 104px 0; background: var(--linen); }
.story-grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: 64px; align-items: center; }
.story-figure { margin: 0; background: #fff; padding: 15px 15px 22px; transform: rotate(-2deg);
  box-shadow: 0 30px 60px -28px rgba(70,66,55,.5); border-radius: 2px; }
.story-figure img { border-radius: 1px; }
.story-copy h2 { font-family: var(--font-head); font-weight: 500;
  font-size: clamp(2rem,4.4vw,3.2rem); margin: .3em 0 .6em; }
.story-copy p { font-size: 1.08rem; color: #4a4842; max-width: 56ch; }
.story-copy em { font-style: italic; }
.story-kicker { font-family: var(--font-head); font-style: italic; font-size: 1.5rem !important;
  color: var(--forest) !important; margin-top: 1.1em !important; }

/* ---------- market ---------- */
.market { padding: 96px 0; background: var(--cream); }
.market-stats { display: grid; grid-template-columns: repeat(4,1fr); gap: 28px; margin-top: 8px; }
.mstat { border-left: 2px solid var(--coral); padding: 6px 0 6px 22px; }
.mstat strong { display: block; font-family: var(--font-head); font-size: 2.6rem; color: var(--forest); line-height: 1; }
.mstat span { color: var(--muted); font-size: .95rem; }

/* ---------- founder ---------- */
.founder { padding: 104px 0; background: var(--linen); }
.founder-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: 64px; align-items: center; }
.founder-figure { margin: 0; border-radius: 8px; overflow: hidden; background: #fff;
  box-shadow: 0 30px 60px -30px rgba(70,66,55,.5); }
.founder-copy h2 { font-family: var(--font-head); font-weight: 500; font-size: clamp(2rem,4vw,2.9rem); margin: .3em 0 .55em; }
.founder-copy p { color: #4a4842; font-size: 1.05rem; max-width: 56ch; }
.founder-quote { font-family: var(--font-head); font-style: italic; font-size: 1.3rem;
  color: var(--forest); border-left: 3px solid var(--sage-deep); padding-left: 22px; margin: 1.4em 0; max-width: 54ch; }
.brand-strip { list-style: none; display: flex; flex-wrap: wrap; gap: 10px 26px; padding: 22px 0 0; margin: 0;
  border-top: 1px solid var(--line); }
.brand-strip li { font-family: var(--font-head); font-size: .95rem; letter-spacing: .04em;
  color: var(--taupe); text-transform: uppercase; }

/* ---------- investment ---------- */
.invest { padding: 100px 0; background: var(--forest); color: #eef1ea; }
.invest .sec-head h2 { color: #fff; }
.invest .eyebrow { color: var(--sage-deep); }
.invest .sec-sub { color: #c9d2c4; }
.invest .coral { color: #f0a48f; }
.invest-grid { display: grid; grid-template-columns: 1fr 1.15fr; gap: 40px; align-items: stretch; }
.capital-card, .invest-side { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.12);
  border-radius: 10px; padding: 34px; }
.capital-card h3, .why-us h3 { font-family: var(--font-display); font-weight: 600; font-size: 1.3rem;
  color: #fff; margin-bottom: 22px; }
.capital-flex { display: flex; align-items: center; gap: 30px; flex-wrap: wrap; }
.donut { width: 168px; height: 168px; flex: none; }
.capital-legend { list-style: none; margin: 0; padding: 0; display: grid; gap: 13px; }
.capital-legend li { display: flex; align-items: center; gap: 11px; font-size: .98rem; color: #dfe5da; }
.capital-legend .dot { width: 13px; height: 13px; border-radius: 50%; flex: none; }
.capital-legend b { margin-left: auto; color: #fff; font-family: var(--font-display); }
.invest-side { display: flex; flex-direction: column; }
.why-us p { color: #c9d2c4; font-size: 1rem; }
.teaser-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; margin: 22px 0 18px; }
.teaser { background: rgba(255,255,255,.06); border-radius: 7px; padding: 16px 14px; text-align: center; }
.teaser strong { display: block; font-family: var(--font-head); font-size: 1.7rem; color: #f0a48f; }
.teaser span { font-size: .78rem; color: #c2cbbd; line-height: 1.3; display: block; margin-top: 4px; }
.gated-line { font-size: .92rem; color: #aebaa6; font-style: italic; margin: auto 0 16px; }
.invest-side .btn { align-self: flex-start; }

/* roadmap */
.roadmap { margin-top: 56px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.12);
  border-radius: 10px; padding: 36px; }
.roadmap h3 { font-family: var(--font-display); font-weight: 600; color: #fff; font-size: 1.3rem; margin-bottom: 26px; }
/* 1-pager-style icon timeline */
.tl { display: flex; gap: 30px; align-items: stretch; }
.tl-phase { flex: var(--n, 1) 1 0; min-width: 0; }
.tl-phase-label { display: block; text-align: center; font-family: var(--font-label);
  text-transform: uppercase; letter-spacing: .16em; font-size: .68rem; font-weight: 500;
  color: #aebaa6; padding-bottom: 12px; margin-bottom: 22px;
  border-bottom: 1px dashed rgba(255,255,255,.28); }
.tl-nodes { list-style: none; margin: 0; padding: 0; display: flex; gap: 6px; position: relative; }
.tl-nodes::before { content: ""; position: absolute; top: 27px; left: 10%; right: 10%;
  height: 1px; background: rgba(255,255,255,.22); }
.tl-phase[style*="--n:1"] .tl-nodes::before { display: none; }
.tl-nodes li { position: relative; flex: 1; min-width: 0; display: flex; flex-direction: column;
  align-items: center; text-align: center; gap: 10px; }
.tl-ico { position: relative; z-index: 1; width: 54px; height: 54px; border-radius: 50%;
  background: #3c5444; color: #dfe5da; display: flex; align-items: center; justify-content: center;
  border: 1px solid rgba(255,255,255,.14); }
.tl-ico svg { width: 25px; height: 25px; }
.tl-phase.done .tl-ico::after { content: "✓"; position: absolute; top: -3px; right: -3px;
  width: 18px; height: 18px; border-radius: 50%; background: var(--sage-deep); color: #1f3325;
  font-size: 11px; font-weight: 700; display: flex; align-items: center; justify-content: center; }
.tl-phase.prog .tl-ico { border-color: var(--honeysuckle); }
.tl-phase.ahead .tl-ico { background: rgba(255,255,255,.07); color: #b9c4b5; }
.tl-launch .tl-ico { background: var(--coral); border-color: var(--coral); color: #fff; }
.tl-label { font-size: .76rem; line-height: 1.3; color: #cdd6c9; max-width: 110px; }
.tl-launch .tl-label { color: #f0a48f; font-weight: 700; }
.road-goal { margin: 30px 0 0; text-align: center; color: #dfe5da; font-size: 1.05rem; }
.road-goal strong { color: #fff; }

/* ---------- launch list ---------- */
.list { padding: 90px 0; background: var(--sage-soft); }
.list-inner { display: flex; align-items: center; justify-content: space-between; gap: 40px; flex-wrap: wrap; }
.list-copy h2 { font-family: var(--font-head); font-weight: 500; font-size: clamp(1.9rem,3.6vw,2.7rem); margin: .25em 0 .4em; }
.list-copy p { color: var(--muted); margin: 0; }
.list-form { min-width: 340px; flex: 1; max-width: 440px; }
.list-form .form-fields { display: flex; gap: 10px; }
.list-form input { flex: 1; padding: 14px 16px; border: 1px solid var(--sage-line); border-radius: 4px;
  background: #fff; font-size: 1rem; font-family: var(--font-body); }
.list-form input:focus { outline: 2px solid var(--sage-deep); }

/* ---------- footer ---------- */
.site-footer { background: var(--ink); color: #cfccc4; padding: 54px 0; }
.footer-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.foot-word { font-size: 2rem; color: #fff; }
.foot-tag { font-family: var(--font-label); text-transform: uppercase; letter-spacing: .3em;
  font-size: .68rem; color: var(--taupe-light); margin: 4px 0 0; }
.footer-contact { display: flex; flex-direction: column; gap: 4px; }
.footer-contact a { text-decoration: none; color: #e7e4dc; }
.footer-contact a:hover { color: #fff; }
.footer-legal { font-size: .8rem; color: #908d85; max-width: 30ch; margin: 0; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 900px) {
  .nav-toggle { display: block; position: relative; z-index: 210; }
  /* backdrop-filter on the header would trap the fixed menu inside it — drop it on mobile */
  .site-header.scrolled { backdrop-filter: none; -webkit-backdrop-filter: none; background: var(--cream); box-shadow: 0 1px 0 var(--line); }
  .nav {
    position: fixed; inset: 0 0 0 auto; z-index: 200; width: min(82vw, 332px);
    flex-direction: column; align-items: stretch; justify-content: flex-start; gap: 0;
    background: var(--cream); padding: 74px 32px 40px; transform: translateX(100%);
    overflow-y: auto; transition: transform .4s var(--ease); box-shadow: -20px 0 50px rgba(0,0,0,.15);
  }
  .nav.open { transform: none; }
  .nav > a { display: none; }
  .nav-m { display: block; }
  body.nav-open { overflow: hidden; }

  .hero-grid, .story-grid, .founder-grid, .invest-grid { grid-template-columns: 1fr; gap: 40px; }
  .hero-grid { grid-template-areas: "brand" "figure" "eyebrow" "detail"; gap: 18px; }   /* name/tag, photo, then eyebrow + copy; tighter around the photo */
  .hero-copy { display: contents; }   /* unfold the copy so its parts can reorder around the photo */
  .hero-eyebrow { grid-area: eyebrow; }
  .hero-lockup  { grid-area: brand; margin: 0; }   /* drop the desktop float margin on mobile */
  .hero-detail  { grid-area: detail; }
  .hero-figure  { grid-area: figure; }
  .hero { padding: 120px 0 60px; }
  .hero-figure { transform: none; }
  .story-figure { max-width: 360px; }
  .prop-grid { grid-template-columns: repeat(2,1fr); }
  .market-stats { grid-template-columns: repeat(2,1fr); }
  .tl { flex-direction: column; gap: 30px; }
  .tl-nodes { flex-wrap: wrap; row-gap: 20px; }
  .tl-nodes::before { display: none; }
  .tl-nodes li { flex: 1 1 30%; min-width: 96px; }
}
@media (max-width: 620px) {
  /* tighter mobile rhythm + closer landing when jumping to a section */
  section { scroll-margin-top: 54px; }
  .hero { padding-top: 96px; }
  .why, .flavors, .pullquote, .story, .market, .founder, .invest, .list, .cm { padding-top: 40px; padding-bottom: 50px; }
  .flavor-row { grid-template-columns: 1fr; max-width: 360px; margin: 0 auto; }
  .prop-grid { grid-template-columns: 1fr; }
  .market-stats { grid-template-columns: 1fr; }
  .teaser-row { grid-template-columns: 1fr; }
  .list-form { min-width: 0; width: 100%; }
  .list-form .form-fields { flex-direction: column; }
  .footer-inner { flex-direction: column; align-items: flex-start; text-align: left; }
}
