/* ============================================================
   REGARDEN — Landing page  ·  Herbarium identity
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400..700;1,9..144,400..600&family=Hanken+Grotesk:wght@400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root{
  --bone:#F3ECDD; --bone-2:#EADFC9; --bone-3:#E4D7BD;
  --ink:#20251E; --ink-soft:#54584B;
  --clay:#BC6044; --clay-deep:#97462F;
  --orchid:#7B5670; --orchid-deep:#59384F;
  --honey:#C2913B; --honey-deep:#8A6420;
  --sage:#94A07E; --petrol:#15302B;
  --line:rgba(32,37,30,0.14);
  --f-display:"Fraunces",Georgia,serif;
  --f-serif:"Fraunces",Georgia,serif;
  --f-sans:"Hanken Grotesk",system-ui,sans-serif;
  --f-mono:"IBM Plex Mono",ui-monospace,monospace;
  --wm-track:0.06em;
  --maxw:1240px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0; background:var(--bone); color:var(--ink);
  font-family:var(--f-sans); font-size:17px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit; text-decoration:none;}
img{display:block; max-width:100%;}
section{position:relative;}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 40px;}

/* ---------- type atoms ---------- */
.kicker{font-family:var(--f-mono); font-size:12px; letter-spacing:.32em; text-transform:uppercase; color:var(--ink-soft);}
.wordmark{font-family:var(--f-sans); font-weight:800; letter-spacing:var(--wm-track); text-transform:uppercase; line-height:.9;}
.wordmark .tm{font-size:.42em; font-weight:700; vertical-align:super;}
.serif-it{font-family:var(--f-serif); font-style:italic;}
.display{font-family:var(--f-display); font-weight:600;}
/* Fraunces reads sturdier than Bodoni; nudge optical sizing for legibility */
.display,.hero h1,.sec-head h2,.card .name,.pd-name,.waitlist h2,.orchid h2{font-optical-sizing:auto;}

/* ---------- rosette mark (built by inline script) ---------- */
.rosette{position:relative; display:inline-block; color:var(--clay); vertical-align:middle;}
.rosette .petal{position:absolute; top:50%; left:50%; background:currentColor;
  border-radius:50% 50% 50% 50% / 64% 64% 36% 36%;}
.rosette .core{position:absolute; top:50%; left:50%; border-radius:50%; background:var(--bone); transform:translate(-50%,-50%); z-index:2;}
.seal{position:relative; border-radius:50%; border:1.5px solid currentColor; display:inline-flex; align-items:center; justify-content:center;}
.seal::after{content:""; position:absolute; inset:5px; border-radius:50%; border:1px solid currentColor; opacity:.4;}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:sticky; top:0; z-index:50; background:rgba(243,236,221,.82);
  backdrop-filter:blur(14px); border-bottom:1px solid var(--line);}
.nav-in{display:flex; align-items:center; justify-content:space-between; height:74px;}
.brand{display:flex; align-items:center; gap:14px;}
.brand .wordmark{font-size:22px;}
.brand .endorse{font-family:var(--f-mono); font-size:8.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); line-height:1.3; border-left:1px solid var(--line); padding-left:12px;}
.nav-links{display:flex; align-items:center; gap:34px;}
.nav-links a{font-size:14px; font-weight:500; color:var(--ink-soft); transition:color .2s;}
.nav-links a:hover{color:var(--ink);}
.btn{display:inline-flex; align-items:center; gap:9px; font-family:var(--f-sans); font-weight:700;
  font-size:14px; letter-spacing:.01em; padding:12px 22px; border-radius:100px; cursor:pointer;
  white-space:nowrap; flex-shrink:0;
  border:1px solid var(--ink); background:var(--ink); color:var(--bone); transition:all .2s;}
.btn:hover{background:transparent; color:var(--ink);}
.btn-clay{background:var(--clay-deep); border-color:var(--clay-deep); color:#fff;}
.btn-clay:hover{background:#7d3825; border-color:#7d3825; color:#fff;}
/* Nav CTA: strongest contrast on the bone bar */
.nav .btn-clay{background:var(--ink); border-color:var(--ink); color:var(--bone);}
.nav .btn-clay:hover{background:var(--clay-deep); border-color:var(--clay-deep); color:#fff;}
.btn-ghost{background:transparent; color:var(--ink);}
.btn-ghost:hover{background:var(--ink); color:var(--bone);}

/* ============================================================
   HERO
   ============================================================ */
.hero{padding:64px 0 70px; overflow:hidden;}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center;}
.hero-kicker{display:flex; align-items:center; gap:14px; margin-bottom:26px;}
.hero-kicker .line{height:1px; width:46px; background:var(--clay);}
.hero h1{font-family:var(--f-display); font-weight:600; font-size:clamp(44px,5.4vw,76px);
  line-height:.98; letter-spacing:-.01em; margin:0 0 8px;}
.hero h1 em{font-style:italic; font-weight:600;}
.hero h1 .amp{color:var(--clay);}
.hero-sub{font-family:var(--f-serif); font-style:italic; font-weight:500; font-size:clamp(20px,2.2vw,27px);
  color:var(--ink-soft); line-height:1.25; margin:18px 0 22px; max-width:30ch;}
.hero-body{font-size:17px; color:var(--ink-soft); max-width:46ch; margin-bottom:32px;}
.hero-cta{display:flex; align-items:center; gap:18px; flex-wrap:wrap;}
.hero-note{font-family:var(--f-mono); font-size:11px; letter-spacing:.08em; color:var(--ink-soft); margin-top:22px;}
.hero-note b{color:var(--clay); font-weight:600;}

/* hero art */
.hero-art{position:relative; aspect-ratio:4/5;}
.hero-art .arch{position:absolute; inset:0; border-radius:300px 300px 16px 16px; overflow:hidden;
  box-shadow:0 30px 70px -30px rgba(32,37,30,.5); border:1px solid var(--line);}
.hero-art image-slot{width:100%; height:100%;}
/* branded empty-state for all slots */
image-slot{
  background:
    repeating-linear-gradient(135deg, rgba(32,37,30,.035) 0 9px, rgba(32,37,30,0) 9px 18px),
    var(--bone-2);
}
.hero-art .seal-badge{position:absolute; right:-26px; bottom:42px; width:118px; height:118px;
  background:var(--bone); border-radius:50%; display:flex; flex-direction:column; align-items:center;
  justify-content:center; box-shadow:0 14px 30px -12px rgba(32,37,30,.4); z-index:3; text-align:center; gap:5px;}
.hero-art .seal-badge .t{font-family:var(--f-mono); font-size:8.5px; letter-spacing:.16em; color:var(--clay-deep); line-height:1.4;}
.hero-watermark{position:absolute; left:-120px; top:-60px; color:var(--bone-2); z-index:-1; opacity:.8;}

/* trust strip under hero */
.trust-strip{border-top:1px solid var(--line); border-bottom:1px solid var(--line); margin-top:56px;}
.trust-strip .wrap{display:flex; flex-wrap:wrap; gap:10px 30px; align-items:center; justify-content:center; padding:18px 40px;}
.trust-strip span{font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); white-space:nowrap;}
.trust-strip .dot{color:var(--clay); opacity:.6;}

/* ============================================================
   SECTION SHELL
   ============================================================ */
.sec{padding:96px 0;}
.sec-head{max-width:640px; margin-bottom:54px;}
.sec-head.center{margin-left:auto; margin-right:auto; text-align:center;}
.sec-head .kicker{margin-bottom:18px; display:block;}
.sec-head h2{font-family:var(--f-display); font-weight:600; font-size:clamp(32px,3.6vw,48px); line-height:1.04; letter-spacing:-.01em; margin:0;}
.sec-head p{font-size:18px; color:var(--ink-soft); margin:18px 0 0;}

/* ---------- the wedge ---------- */
.wedge{background:var(--bone-2);}
.wedge-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px; align-items:stretch;}
.wedge-card{background:var(--bone); border:1px solid var(--line); border-radius:14px; padding:34px 30px;}
.wedge-card.bad{background:transparent; border-style:dashed;}
.wedge-card.soft{background:var(--bone); border-color:var(--line);}
.wedge-card.soft .tag{color:var(--clay-deep);}
.wedge-card .mk{display:block; margin-bottom:18px;}
.wedge-card .tag{font-family:var(--f-mono); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:16px;}
.wedge-card h3{font-family:var(--f-serif); font-weight:600; font-size:25px; line-height:1.1; margin:0 0 12px;}
.wedge-card p{font-size:15px; color:var(--ink-soft); margin:0;}
.wedge-card.win{background:var(--clay); color:#fff; border-color:var(--clay);}
.wedge-card.win .tag{color:rgba(255,255,255,.8);}
.wedge-card.win p{color:rgba(255,255,255,.92);}
.wedge-card.win .mk{color:#fff; margin-bottom:18px;}

/* ---------- products ---------- */
.prod-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:26px;}
.card{background:var(--bone); border:1px solid var(--line); border-radius:18px; overflow:hidden;
  display:flex; flex-direction:column; transition:transform .25s, box-shadow .25s;}
.card:hover{transform:translateY(-6px); box-shadow:0 26px 50px -28px rgba(32,37,30,.45);}
.card .top{padding:22px 26px; color:#fff; display:flex; align-items:center; justify-content:space-between;}
.card .top .no{font-family:var(--f-mono); font-size:11px; letter-spacing:.14em;}
.card .shot{aspect-ratio:4/3; position:relative;}
.card .shot image-slot{width:100%; height:100%;}
.card .body{padding:26px 26px 30px; flex:1; display:flex; flex-direction:column;}
.card .cat{font-family:var(--f-mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:10px;}
.card .name{font-family:var(--f-display); font-weight:600; font-size:30px; line-height:1; margin:0 0 12px;}
.card .claim{font-family:var(--f-serif); font-style:italic; font-size:19px; margin:0 0 14px;}
.card .desc{font-size:14.5px; color:var(--ink-soft); margin:0 0 20px;}
.card .chips{display:flex; flex-wrap:wrap; gap:7px; margin-top:auto;}
.card .chip{font-family:var(--f-mono); font-size:9.5px; letter-spacing:.06em; text-transform:uppercase;
  padding:5px 10px; border-radius:100px; background:rgba(32,37,30,.06); color:var(--ink); font-weight:600;}

/* ---------- proof ---------- */
.proof{background:var(--petrol); color:#EFE7D6;}
.proof .kicker{color:rgba(239,231,214,.6);}
.proof .sec-head h2{color:#F3ECDD;}
.proof .sec-head p{color:rgba(239,231,214,.78);}
.stats{display:grid; grid-template-columns:repeat(4,1fr); gap:28px; margin-top:8px;}
.stat{border-top:1px solid rgba(239,231,214,.22); padding-top:22px;}
.stat .n{font-family:var(--f-display); font-weight:600; font-size:clamp(40px,4.4vw,60px); line-height:.9; color:var(--honey);}
.stat .l{font-size:14px; color:rgba(239,231,214,.8); margin-top:12px;}
.proof-note{margin-top:54px; display:flex; gap:18px; align-items:flex-start; max-width:760px;
  font-family:var(--f-serif); font-style:italic; font-size:22px; line-height:1.35; color:#EFE7D6;}
.proof-note .mk{color:var(--honey); flex-shrink:0; margin-top:4px;}

/* ---------- proven / independently tested ---------- */
.tested{background:var(--bone-2);}
.tested-band{margin-top:8px; border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:40px 0; text-align:center;}
.tested-label{display:block; font-family:var(--f-mono); font-size:11px; letter-spacing:.28em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:26px;}
.tested-list{display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:18px 38px;}
.tested-list span{font-family:var(--f-display); font-weight:600; font-size:clamp(18px,2vw,24px); color:var(--ink); line-height:1.1;}

/* ---------- orchid play ---------- */
.orchid{background:var(--orchid-deep); color:#F4ECE9; overflow:hidden;}
.orchid-grid{display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center;}
.orchid .kicker{color:rgba(244,236,233,.65);}
.orchid h2{font-family:var(--f-display); font-weight:600; font-size:clamp(30px,3.4vw,46px); line-height:1.05; margin:18px 0 0;}
.orchid p{color:rgba(244,236,233,.85); font-size:18px; margin:20px 0 0; max-width:46ch;}
.orchid .pquote{font-family:var(--f-serif); font-style:italic; font-size:24px; color:#fff; margin:28px 0 0; line-height:1.3;}
.orchid-art{position:relative; aspect-ratio:1; border-radius:20px; overflow:hidden; box-shadow:0 30px 70px -30px rgba(0,0,0,.6);}
.orchid-art image-slot{width:100%; height:100%;}

/* ---------- waitlist ---------- */
.waitlist{text-align:center; padding:104px 0;}
.waitlist .mk{color:var(--clay); margin-bottom:26px;}
.waitlist h2{font-family:var(--f-display); font-weight:600; font-size:clamp(34px,4.2vw,58px); line-height:1; margin:0 0 14px;}
.waitlist .lead{font-family:var(--f-serif); font-style:italic; font-size:24px; color:var(--ink-soft); margin:0 0 36px;}
.form{display:flex; gap:12px; max-width:480px; margin:0 auto; flex-wrap:wrap; justify-content:center;}
.form input{flex:1; min-width:240px; font-family:var(--f-sans); font-size:16px; padding:15px 20px;
  border:1px solid var(--ink); border-radius:100px; background:transparent; color:var(--ink); outline:none;}
.form input::placeholder{color:var(--ink-soft);}
.form input:focus{border-color:var(--clay);}
.form-note{font-family:var(--f-mono); font-size:11px; letter-spacing:.06em; color:var(--ink-soft); margin-top:18px;}
.form-success{display:none; font-family:var(--f-serif); font-style:italic; font-size:21px; color:var(--clay-deep); margin-top:8px;}

/* ---------- footer ---------- */
.foot{background:var(--ink); color:var(--bone); padding:64px 0 40px;}
.foot-grid{display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; align-items:flex-start;}
.foot .brand .wordmark{font-size:26px; color:var(--bone);}
.foot .endorse{color:rgba(243,236,221,.6); border-color:rgba(243,236,221,.2);}
.foot .tag{font-family:var(--f-serif); font-style:italic; font-size:20px; color:rgba(243,236,221,.8); margin-top:18px;}
.foot-cols{display:flex; gap:64px; flex-wrap:wrap;}
.foot-col h4{font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:rgba(243,236,221,.5); margin:0 0 16px;}
.foot-col a{display:block; font-size:15px; color:rgba(243,236,221,.85); margin-bottom:11px; transition:color .2s;}
.foot-col a:hover{color:var(--clay);}
.foot-bottom{margin-top:54px; padding-top:24px; border-top:1px solid rgba(243,236,221,.15);
  display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap;
  font-family:var(--f-mono); font-size:10.5px; letter-spacing:.08em; color:rgba(243,236,221,.5); text-transform:uppercase;}

/* ---------- in-progress ribbon ---------- */
.wip{background:var(--honey); color:var(--ink); text-align:center; font-family:var(--f-mono);
  font-size:11px; letter-spacing:.18em; text-transform:uppercase; padding:8px 16px; font-weight:500;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1000px){
  .hero-grid{grid-template-columns:1fr; gap:44px;}
  .hero-art{max-width:440px; margin:0 auto; width:100%;}
  .orchid-grid{grid-template-columns:1fr; gap:40px;}
  .wedge-grid{grid-template-columns:1fr;}
  .prod-grid{grid-template-columns:1fr; max-width:460px; margin:0 auto;}
  .stats{grid-template-columns:1fr 1fr; gap:24px 28px;}
  .nav-links{display:none;}
}
@media(max-width:560px){
  .wrap{padding:0 22px;}
  .sec{padding:68px 0;}
  .stats{grid-template-columns:1fr;}
  .foot-grid{flex-direction:column;}
  .brand .endorse{display:none;}
}
