/* ============================================================
   CreaVerum™  —  Brand site stylesheet
   "The verified truth in creatine."
   Palette, type and motion derived from the CreaVerum Brand Book 1.0
   ============================================================ */

/* ---------- Design tokens ---------- */
:root{
  /* Colour — Verum Ink leads (~70%), Bone opens space (~22%), Gold is precious (~8%) */
  --ink:        #102438;   /* primary, grounds the brand            */
  --ink-deep:   #0b1a29;   /* deeper ink for layering               */
  --ink-soft:   #18324b;   /* raised ink surfaces                   */
  --slate:      #34506b;   /* secondary support                     */
  --slate-soft: #46627d;
  --gold:       #c2a24e;   /* accent — truth & proof                */
  --gold-bright:#d8bd6f;
  --gold-deep:  #a4863a;
  --bone:       #f4efe4;   /* light surfaces & type                 */
  --paper:      #fbfaf6;   /* page background (light sections)      */

  /* Text */
  --text-on-ink:        #eef1f4;
  --text-on-ink-dim:    #9fb0c2;
  --text-on-ink-faint:  #6c8198;
  --text-on-paper:      #18324b;
  --text-on-paper-dim:  #5c6f80;

  --line-on-ink:   rgba(194,162,78,.22);
  --line-on-paper: rgba(16,36,56,.12);
  --hairline-ink:  rgba(255,255,255,.08);

  /* Type */
  --serif: "Fraunces", "Times New Roman", serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --mono:  "IBM Plex Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;

  /* Spacing / layout */
  --container: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
  --section-y: clamp(80px, 11vw, 168px);
  --radius: 14px;
  --radius-lg: 22px;

  /* Motion */
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-soft: cubic-bezier(.4,0,.2,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0;
  font-family:var(--sans);
  font-size:17px;
  line-height:1.65;
  color:var(--text-on-ink);
  background:var(--ink);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,canvas,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:0; background:none; color:inherit; }
::selection{ background:var(--gold); color:var(--ink); }

/* ---------- Type primitives ---------- */
.kicker{
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
  margin:0;
}
.kicker--dim{ color:var(--text-on-ink-faint); }
.kicker .dot{ color:var(--gold); opacity:.6; margin:0 .5em; }

h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; line-height:1.04; letter-spacing:-.01em; margin:0; }
.display{
  font-family:var(--serif);
  font-weight:340;
  font-size:clamp(2.7rem, 6.2vw, 5.4rem);
  line-height:1.0;
  letter-spacing:-.02em;
}
h2.title{ font-size:clamp(2rem, 3.8vw, 3.3rem); line-height:1.05; }
h3{ font-size:1.3rem; line-height:1.2; }
.lead{
  font-size:clamp(1.1rem, 1.7vw, 1.45rem);
  line-height:1.55;
  color:var(--text-on-ink-dim);
  font-weight:400;
}
p{ margin:0 0 1.1em; }
em{ font-style:italic; }
.serif-italic{ font-family:var(--serif); font-style:italic; font-weight:340; }
.measure{ max-width:62ch; }
.measure-sm{ max-width:46ch; }

/* The wordmark — "Crea" in ink/bone, "Verum" in gold */
.wordmark{ font-family:var(--serif); font-weight:500; letter-spacing:-.015em; white-space:nowrap; }
.wordmark .crea{ color:var(--bone); }
.wordmark .verum{ color:var(--gold); }
.wordmark .tm{ font-size:.42em; vertical-align:.85em; color:var(--gold); font-family:var(--sans); margin-left:.04em; }
.on-paper .wordmark .crea{ color:var(--ink); }

/* ---------- Layout ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:var(--section-y); position:relative; }
.section--tight{ padding-block:clamp(56px,7vw,96px); }
.eyebrow-row{ display:flex; align-items:center; gap:14px; margin-bottom:26px; }
.eyebrow-row .rule{ height:1px; flex:0 0 42px; background:var(--gold); opacity:.5; }

/* Surfaces */
.on-paper{ background:var(--paper); color:var(--text-on-paper); }
.on-paper .lead{ color:var(--text-on-paper-dim); }
.on-paper .kicker--dim{ color:#9aa7b2; }
.on-ink-deep{ background:var(--ink-deep); }

/* ---------- Grain / powder texture overlay ---------- */
.grain{
  position:fixed; inset:0; z-index:1; pointer-events:none;
  opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--gold); --fg:var(--ink); --bd:var(--gold);
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--sans); font-weight:600; font-size:.94rem; letter-spacing:.005em;
  padding:.85em 1.5em; border-radius:100px;
  background:var(--bg); color:var(--fg); border:1px solid var(--bd);
  transition:transform .35s var(--ease), background .3s var(--ease), color .3s var(--ease), box-shadow .35s var(--ease);
  will-change:transform;
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 12px 30px -12px rgba(194,162,78,.6); }
.btn:active{ transform:translateY(0); }
.btn .arrow{ transition:transform .35s var(--ease); }
.btn:hover .arrow{ transform:translateX(4px); }
.btn--ghost{ --bg:transparent; --fg:var(--bone); --bd:var(--line-on-ink); }
.btn--ghost:hover{ --bd:var(--gold); --fg:var(--gold-bright); box-shadow:none; }
.on-paper .btn--ghost{ --fg:var(--ink); --bd:var(--line-on-paper); }
.on-paper .btn--ghost:hover{ --fg:var(--gold-deep); --bd:var(--gold); }
.btn--lg{ padding:1.02em 1.9em; font-size:1rem; }

.textlink{ color:var(--gold-bright); border-bottom:1px solid var(--line-on-ink); padding-bottom:1px; transition:border-color .3s; }
.textlink:hover{ border-color:var(--gold); }

/* ---------- Navigation ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gutter);
  transition:background .4s var(--ease), padding .4s var(--ease), border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.is-scrolled{
  background:rgba(11,26,41,.82);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  padding-top:13px; padding-bottom:13px;
  border-bottom:1px solid var(--hairline-ink);
}
.nav__brand{ font-size:1.5rem; z-index:2; }
.nav__links{ display:flex; align-items:center; gap:34px; }
.nav__links a:not(.btn){
  font-size:.9rem; color:var(--text-on-ink-dim); letter-spacing:.01em;
  position:relative; transition:color .3s;
}
.nav__links a:not(.btn)::after{
  content:""; position:absolute; left:0; bottom:-5px; height:1px; width:0; background:var(--gold);
  transition:width .35s var(--ease);
}
.nav__links a:not(.btn):hover{ color:var(--bone); }
.nav__links a:not(.btn):hover::after{ width:100%; }
.nav__toggle{ display:none; width:30px; height:30px; position:relative; z-index:2; }
.nav__toggle span{ position:absolute; left:3px; right:3px; height:1.5px; background:var(--bone); transition:transform .35s var(--ease), opacity .25s; }
.nav__toggle span:nth-child(1){ top:9px; } .nav__toggle span:nth-child(2){ bottom:9px; }
.nav.is-open .nav__toggle span:nth-child(1){ transform:translateY(5px) rotate(45deg); }
.nav.is-open .nav__toggle span:nth-child(2){ transform:translateY(-5px) rotate(-45deg); }

@media (max-width: 860px){
  .nav__toggle{ display:block; }
  .nav__links{
    position:fixed; inset:0; flex-direction:column; justify-content:center; gap:30px;
    background:rgba(8,20,32,.97); backdrop-filter:blur(8px);
    transform:translateY(-100%); opacity:0; pointer-events:none;
    transition:transform .5s var(--ease), opacity .4s;
  }
  .nav.is-open .nav__links{ transform:translateY(0); opacity:1; pointer-events:auto; }
  .nav__links a:not(.btn){ font-size:1.4rem; font-family:var(--serif); color:var(--bone); }
}

/* ---------- Hero ---------- */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:center;
  padding-top:96px; overflow:hidden;
  background:
    radial-gradient(120% 90% at 78% 18%, rgba(52,80,107,.45), transparent 60%),
    radial-gradient(90% 70% at 12% 90%, rgba(11,26,41,.8), transparent 70%),
    var(--ink);
}
.hero__grid{
  display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center;
  width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter);
  position:relative; z-index:3;
}
.hero__copy{ max-width:620px; }
.hero h1{ margin:18px 0 0; }
.hero .lead{ margin-top:26px; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:38px; }
.hero__stage{ position:relative; height:min(74vh,640px); }
.hero__stage{ display:grid; place-items:center; position:relative; }
.product-glow{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:80%; aspect-ratio:1; border-radius:50%; background:radial-gradient(circle, rgba(194,162,78,.16), transparent 64%); filter:blur(18px); z-index:0; }
/* real product photo + CreaVerum seal badge (swap the <img> src to use your own shot) */
.hero__photo{ position:relative; height:100%; aspect-ratio:4/5; margin-inline:auto; z-index:1; }
.hero__photo-img{ width:100%; height:100%; background-repeat:no-repeat;
  background-image:url('https://images.pexels.com/photos/8789596/pexels-photo-8789596.jpeg?auto=compress&cs=tinysrgb&w=1600');
  background-size:262%; background-position:47% 41%;
  -webkit-mask-image:radial-gradient(ellipse 82% 88% at 50% 50%, #000 58%, transparent 90%);
          mask-image:radial-gradient(ellipse 82% 88% at 50% 50%, #000 58%, transparent 90%); }
.hero__badge{ position:absolute; left:50%; top:55%; transform:translate(-50%,-50%); display:flex; flex-direction:column; align-items:center; gap:9px; pointer-events:none; }
.hero__badge .seal{ width:112px; height:112px; filter:drop-shadow(0 6px 16px rgba(0,0,0,.6)); }
.hero__badge .seal .seal__bezel{ animation:none; }
.hero__badge-txt{ font-family:var(--mono); font-size:.58rem; letter-spacing:.2em; text-transform:uppercase; color:var(--bone); text-align:center; line-height:1.6; text-shadow:0 1px 5px rgba(0,0,0,.85); }
.hero__badge-txt b{ display:inline-block; margin-top:3px; font-family:var(--serif); font-weight:500; letter-spacing:0; font-size:1.06rem; color:var(--gold-bright); text-transform:none; }
@keyframes float{ 0%,100%{ transform:translateY(0) } 50%{ transform:translateY(-14px) } }
@media (prefers-reduced-motion:reduce){ .hero__product{ animation:none } }

.trustrow{ display:flex; flex-wrap:wrap; gap:11px 22px; list-style:none; margin:30px 0 0; padding:0; }
.trustrow li{ font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--text-on-ink-dim); position:relative; padding-left:18px; }
.trustrow li::before{ content:""; position:absolute; left:0; top:50%; width:7px; height:7px; transform:translateY(-50%) rotate(45deg); background:var(--gold); }

/* ---------- Media (photos) ---------- */
.media{ position:relative; overflow:hidden; border-radius:var(--radius-lg); border:1px solid var(--hairline-ink); background:var(--ink-deep); }
.media img,.media video{ display:block; width:100%; height:100%; object-fit:cover; }
.media--duo img{ filter:grayscale(.42) contrast(1.04) brightness(.92); transition:transform 1.2s var(--ease); }
.media--duo::after{ content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(155deg, rgba(16,36,56,.55), rgba(16,36,56,.06) 55%, rgba(194,162,78,.16)); }
.media--tall{ aspect-ratio:4/5; }
.media--wide{ aspect-ratio:16/10; }
.media:hover.media--duo img{ transform:scale(1.04); }
.media__cap{ position:absolute; left:16px; bottom:13px; z-index:2; font-family:var(--mono); font-size:.6rem; letter-spacing:.16em; text-transform:uppercase; color:var(--bone); opacity:.9; }
.media-stack{ display:grid; gap:14px; grid-template-rows:1.55fr 1fr; height:100%; min-height:420px; }

/* ---------- Cinematic sport video band ---------- */
.videoband{ position:relative; min-height:clamp(440px,74vh,720px); display:grid; place-items:center; overflow:hidden; background:var(--ink-deep); }
.videoband__poster,.videoband video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.videoband video{ z-index:1; opacity:0; transition:opacity 1.4s var(--ease); background:transparent; }
.videoband.is-playing video{ opacity:1; }
.videoband__poster{ z-index:0; filter:grayscale(.4) contrast(1.05) brightness(.62); }
.videoband::after{ content:""; position:absolute; inset:0; z-index:2;
  background:linear-gradient(180deg, rgba(8,18,30,.72), rgba(8,18,30,.4) 42%, rgba(8,18,30,.88)); }
.videoband__inner{ position:relative; z-index:3; text-align:center; max-width:780px; padding-inline:var(--gutter); }

/* ---------- Ingredient-inside clarity strip ---------- */
.clarity{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--hairline-ink); border-radius:var(--radius-lg); overflow:hidden; margin-top:clamp(36px,5vw,56px); }
.clarity__cell{ background:var(--ink); padding:clamp(24px,3vw,38px); }
.clarity__cell .ic{ color:var(--gold); font-family:var(--mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; }
.clarity__cell h4{ font-family:var(--sans); font-weight:600; font-size:1.05rem; color:var(--bone); margin:14px 0 8px; letter-spacing:.005em; }
.clarity__cell p{ font-size:.95rem; color:var(--text-on-ink-dim); margin:0; }
@media (max-width:760px){ .clarity{ grid-template-columns:1fr; } }
.scroll-cue{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:4;
  display:flex; flex-direction:column; align-items:center; gap:9px;
  font-family:var(--mono); font-size:.62rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--text-on-ink-faint);
}
.scroll-cue .bar{ width:1px; height:46px; background:linear-gradient(var(--gold),transparent); animation:cue 2.4s var(--ease) infinite; transform-origin:top; }
@keyframes cue{ 0%{ transform:scaleY(0); opacity:0; } 30%{ opacity:1; } 100%{ transform:scaleY(1); opacity:0; } }

@media (max-width: 920px){
  .hero{ min-height:auto; padding-top:130px; padding-bottom:60px; }
  .hero__grid{ grid-template-columns:1fr; gap:8px; }
  .hero__stage{ height:min(56vh,440px); order:-1; }
  .scroll-cue{ display:none; }
}

/* ---------- Verum Seal (SVG) ---------- */
.seal{ width:100%; height:auto; overflow:visible; }
.seal .ring,.seal .tick,.seal .pip{ stroke:var(--gold); fill:none; }
.seal .vcheck{ stroke:var(--gold); fill:none; stroke-linecap:round; stroke-linejoin:round; }
.seal__bezel{ transform-box:fill-box; transform-origin:center; animation:sealspin 80s linear infinite; }
@media (prefers-reduced-motion: reduce){ .seal__bezel{ animation:none; } }
@keyframes sealspin{ to{ transform:rotate(360deg); } }

/* draw-on animation (added via .is-drawn) */
.seal .vcheck{ stroke-dasharray:var(--vlen,200); stroke-dashoffset:var(--vlen,200); }
.seal.is-drawn .vcheck{ transition:stroke-dashoffset 1.1s var(--ease) .25s; stroke-dashoffset:0; }
.seal .ring{ opacity:0; transition:opacity .8s var(--ease); }
.seal.is-drawn .ring{ opacity:1; }
.seal .tick,.seal .pip{ opacity:0; transition:opacity 1s var(--ease) .2s; }
.seal.is-drawn .tick,.seal.is-drawn .pip{ opacity:1; }

/* ---------- Statement / pull quote ---------- */
.statement{ text-align:center; }
.statement .big{
  font-family:var(--serif); font-weight:340;
  font-size:clamp(1.9rem,4.1vw,3.4rem); line-height:1.16; letter-spacing:-.015em;
  max-width:20ch; margin:0 auto;
}
.statement .big .hl{ color:var(--gold); font-style:italic; }

/* ---------- Spec stat strip ---------- */
.stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line-on-paper); border-radius:var(--radius-lg); overflow:hidden; }
.on-ink-deep .stats,.section:not(.on-paper) .stats{ background:var(--hairline-ink); }
.stat{ background:var(--paper); padding:clamp(28px,3.6vw,48px); }
.section:not(.on-paper) .stat{ background:var(--ink); }
.stat__num{ font-family:var(--mono); font-weight:500; font-size:clamp(2rem,4vw,3rem); color:var(--gold); letter-spacing:-.02em; line-height:1; }
.stat__num .unit{ font-size:.42em; color:var(--text-on-ink-dim); margin-left:.35em; letter-spacing:.04em; }
.on-paper .stat__num .unit{ color:var(--text-on-paper-dim); }
.stat__label{ margin-top:14px; font-size:.96rem; color:var(--text-on-ink-dim); }
.on-paper .stat__label{ color:var(--text-on-paper-dim); }
@media (max-width:720px){ .stats{ grid-template-columns:1fr; } }

/* ---------- Generic two-column ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,96px); align-items:center; }
.split--seal{ grid-template-columns:.85fr 1.15fr; }
@media (max-width:860px){ .split,.split--seal{ grid-template-columns:1fr; gap:48px; } }

/* ---------- Cards / pillars ---------- */
.pillars{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
@media (max-width:760px){ .pillars{ grid-template-columns:1fr; } }
.pillar{
  position:relative; padding:clamp(26px,3vw,40px); border-radius:var(--radius-lg);
  background:linear-gradient(180deg, var(--ink-soft), var(--ink));
  border:1px solid var(--hairline-ink); overflow:hidden;
  transition:transform .5s var(--ease), border-color .5s, box-shadow .5s;
}
.pillar::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:2px; background:var(--gold); transform:scaleY(0); transform-origin:top; transition:transform .55s var(--ease); }
.pillar:hover{ transform:translateY(-4px); border-color:var(--line-on-ink); box-shadow:0 24px 50px -30px #000; }
.pillar:hover::before{ transform:scaleY(1); }
.pillar__no{ font-family:var(--mono); font-size:.78rem; color:var(--gold); letter-spacing:.18em; }
.pillar h3{ margin:16px 0 12px; color:var(--bone); }
.pillar p{ color:var(--text-on-ink-dim); font-size:1rem; margin:0; }

/* ---------- Chain of trust ---------- */
.chain{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; position:relative; }
.chain__step{ position:relative; }
.chain__no{
  width:46px; height:46px; border-radius:50%; display:grid; place-items:center;
  border:1px solid var(--gold); color:var(--gold); font-family:var(--mono); font-size:.95rem;
  margin-bottom:20px; background:var(--ink);
}
.chain__step h4{ font-family:var(--sans); font-weight:600; font-size:1.02rem; color:var(--bone); margin:0 0 8px; letter-spacing:.005em; }
.chain__step p{ font-size:.94rem; color:var(--text-on-ink-dim); margin:0; }
.chain__step:not(:last-child)::after{
  content:""; position:absolute; top:23px; left:58px; right:-14px; height:1px;
  background:linear-gradient(90deg,var(--line-on-ink),transparent);
}
@media (max-width:860px){ .chain{ grid-template-columns:1fr 1fr; gap:34px 22px; } .chain__step:not(:last-child)::after{ display:none; } }
@media (max-width:480px){ .chain{ grid-template-columns:1fr; } }

/* ---------- Endorsement lockups ---------- */
.endorse-pair{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media (max-width:560px){ .endorse-pair{ grid-template-columns:1fr; } }
.endorse{
  border-radius:var(--radius); padding:26px 22px; display:flex; align-items:center; gap:16px;
  border:1px solid var(--gold);
}
.endorse--dark{ background:var(--ink-deep); }
.endorse--light{ background:var(--bone); }
.endorse--light .endorse__txt strong{ color:var(--ink); }
.endorse--light .endorse__code{ color:var(--gold-deep); }
.endorse__seal{ flex:0 0 50px; }
.endorse__txt{ line-height:1.25; }
.endorse__txt small{ display:block; font-size:.62rem; font-family:var(--mono); letter-spacing:.18em; text-transform:uppercase; color:var(--text-on-ink-faint); }
.endorse--light .endorse__txt small{ color:#9aa7b2; }
.endorse__txt strong{ font-family:var(--serif); font-weight:500; font-size:1.18rem; color:var(--bone); }
.endorse__code{ display:block; font-family:var(--mono); font-size:.74rem; letter-spacing:.12em; color:var(--gold); margin-top:5px; }

/* ---------- Verum code teaser / input ---------- */
.codebox{
  display:flex; align-items:stretch; gap:10px; flex-wrap:wrap; max-width:520px;
}
.code-input{
  flex:1 1 280px; display:flex; align-items:center; gap:.5ch;
  font-family:var(--mono); font-size:1.15rem; letter-spacing:.12em; color:var(--bone);
  background:rgba(255,255,255,.04); border:1px solid var(--line-on-ink);
  border-radius:100px; padding:.7em 1.3em; transition:border-color .3s, box-shadow .3s;
}
.code-input:focus-within{ border-color:var(--gold); box-shadow:0 0 0 4px rgba(194,162,78,.12); }
.code-input .prefix{ color:var(--gold); }
.code-input input{
  flex:1; min-width:0; background:none; border:0; outline:none;
  font-family:var(--mono); font-size:1.15rem; letter-spacing:.16em; color:var(--bone); text-transform:uppercase;
}
.code-input input::placeholder{ color:var(--text-on-ink-faint); letter-spacing:.16em; }

/* ---------- Forms ---------- */
.form{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.form .full{ grid-column:1 / -1; }
.field label{ display:block; font-family:var(--mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--text-on-ink-faint); margin-bottom:9px; }
.field input,.field textarea,.field select{
  width:100%; font-family:var(--sans); font-size:1rem; color:var(--bone);
  background:rgba(255,255,255,.03); border:1px solid var(--line-on-ink);
  border-radius:12px; padding:.85em 1em; outline:none; transition:border-color .3s, box-shadow .3s;
}
.field textarea{ resize:vertical; min-height:120px; }
.field input:focus,.field textarea:focus,.field select:focus{ border-color:var(--gold); box-shadow:0 0 0 4px rgba(194,162,78,.1); }
.field input::placeholder,.field textarea::placeholder{ color:var(--text-on-ink-faint); }
@media (max-width:600px){ .form{ grid-template-columns:1fr; } }

/* ---------- CTA panel ---------- */
.cta-panel{
  position:relative; border-radius:var(--radius-lg); padding:clamp(40px,6vw,80px);
  background:
    radial-gradient(100% 140% at 85% 0%, rgba(52,80,107,.5), transparent 55%),
    linear-gradient(160deg, var(--ink-soft), var(--ink-deep));
  border:1px solid var(--hairline-ink); overflow:hidden;
}

/* ---------- Footer ---------- */
.footer{ background:var(--ink-deep); border-top:1px solid var(--hairline-ink); padding-block:clamp(56px,7vw,86px) 40px; }
.footer__top{ display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; align-items:flex-start; }
.footer__brand .wordmark{ font-size:2rem; }
.footer__tag{ font-family:var(--serif); font-style:italic; color:var(--gold); margin-top:6px; }
.footer__cols{ display:flex; gap:64px; flex-wrap:wrap; }
.footer__col h5{ font-family:var(--mono); font-weight:500; font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--text-on-ink-faint); margin:0 0 16px; }
.footer__col a{ display:block; color:var(--text-on-ink-dim); font-size:.95rem; margin-bottom:11px; transition:color .3s; }
.footer__col a:hover{ color:var(--gold-bright); }
.footer__legal{
  margin-top:clamp(44px,6vw,72px); padding-top:26px; border-top:1px solid var(--hairline-ink);
  display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap;
  font-size:.8rem; color:var(--text-on-ink-faint);
}
.footer__legal .mono{ font-family:var(--mono); letter-spacing:.04em; }

/* ---------- Scroll-reveal ---------- */
.js .reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.js .reveal-stagger > *{ opacity:0; transform:translateY(22px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal-stagger.in > *{ opacity:1; transform:none; }
.reveal-stagger.in > *:nth-child(2){ transition-delay:.08s; }
.reveal-stagger.in > *:nth-child(3){ transition-delay:.16s; }
.reveal-stagger.in > *:nth-child(4){ transition-delay:.24s; }
@media (prefers-reduced-motion: reduce){
  .reveal,.reveal-stagger > *{ opacity:1 !important; transform:none !important; transition:none; }
  .scroll-cue .bar{ animation:none; }
}

/* ---------- Verify page ---------- */
.verify-wrap{ min-height:100svh; display:flex; flex-direction:column; }
.verify-hero{ padding-top:140px; }
.verify-seal{ width:96px; margin:0 auto 30px; }
.verify-form{ max-width:520px; margin:36px auto 0; }
.verify-form .codebox{ margin-inline:auto; }
.verify-samples{ margin-top:22px; font-size:.85rem; color:var(--text-on-ink-faint); }
.verify-samples .chip{ margin-left:6px; }
#verify-result{ margin-top:48px; }

.chips{ display:flex; flex-wrap:wrap; gap:10px; margin-top:16px; justify-content:center; }
.chip{
  font-family:var(--mono); font-size:.8rem; letter-spacing:.08em; color:var(--gold-bright);
  border:1px solid var(--line-on-ink); border-radius:100px; padding:.5em 1em; transition:border-color .3s, background .3s;
}
.chip:hover{ border-color:var(--gold); background:rgba(194,162,78,.08); }

.verify-msg{ text-align:center; max-width:540px; margin-inline:auto; }
.verify-msg__title{ font-family:var(--serif); font-size:1.5rem; color:var(--bone); margin-bottom:8px; }

/* Certificate of Analysis card */
.coa{
  max-width:720px; margin:0 auto; border-radius:var(--radius-lg);
  background:linear-gradient(165deg, var(--ink-soft), var(--ink-deep));
  border:1px solid var(--line-on-ink); padding:clamp(26px,4vw,44px);
  box-shadow:0 40px 80px -50px #000;
}
.coa__head{ display:flex; align-items:center; gap:22px; padding-bottom:24px; border-bottom:1px solid var(--hairline-ink); }
.coa__seal{ flex:0 0 64px; }
.coa__title{ font-family:var(--serif); font-weight:500; font-size:1.35rem; color:var(--bone); margin:6px 0 4px; line-height:1.15; }
.coa__batch{ font-size:.82rem; letter-spacing:.1em; color:var(--gold); }
.coa__stamp{
  margin-left:auto; align-self:flex-start; display:inline-flex; align-items:center; gap:8px;
  font-family:var(--mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold);
  border:1px solid var(--gold); border-radius:100px; padding:.5em .9em; white-space:nowrap;
}
.coa__stamp span{ display:grid; place-items:center; width:16px; height:16px; border-radius:50%; background:var(--gold); color:var(--ink); font-size:.7rem; }
.coa__table{ width:100%; border-collapse:collapse; margin-top:18px; }
.coa__table th{
  text-align:left; font-family:var(--mono); font-weight:500; font-size:.62rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--text-on-ink-faint); padding:10px 12px; border-bottom:1px solid var(--hairline-ink);
}
.coa__table th:nth-child(2),.coa__table th:nth-child(3){ text-align:right; }
.coa__table td{ padding:13px 12px; border-bottom:1px solid var(--hairline-ink); font-size:.92rem; vertical-align:top; }
.coa__param{ color:var(--text-on-ink-dim); }
.coa__result{ text-align:right; font-family:var(--mono); color:var(--bone); white-space:nowrap; }
.coa__spec{ text-align:right; font-family:var(--mono); font-size:.74rem; color:var(--text-on-ink-faint); }
.coa__meta{ display:flex; flex-wrap:wrap; gap:8px 26px; margin-top:20px; font-size:.74rem; letter-spacing:.04em; color:var(--text-on-ink-faint); }
.coa__foot{ display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-top:26px; }
.coa__note{ font-size:.76rem; color:var(--text-on-ink-faint); margin:0; max-width:38ch; }
@media (max-width:560px){
  .coa__head{ flex-wrap:wrap; }
  .coa__stamp{ margin-left:0; }
  .coa__table th:nth-child(3),.coa__spec{ display:none; }
}
@media print{
  .nav,.footer,.verify-form,.verify-samples,.verify-intro,.coa__foot,.grain,.scroll-cue{ display:none !important; }
  body{ background:#fff; color:#000; }
  .coa{ background:#fff; border-color:#999; box-shadow:none; color:#000; max-width:100%; }
  .coa__title,.coa__result{ color:#000; } .coa__param{ color:#222; }
}

/* ---------- Utilities ---------- */
.center{ text-align:center; } .mx-auto{ margin-inline:auto; }
.mt-s{ margin-top:14px; } .mt-m{ margin-top:26px; } .mt-l{ margin-top:44px; }
.gold{ color:var(--gold); } .dim{ color:var(--text-on-ink-dim); }
.hr{ height:1px; background:var(--line-on-ink); border:0; margin:0; }
