/* =========================================================
   Heinrichs Genetics — editorial scientific (v2)
   X-factor: keep the brand DNA (Exo 2 + Montserrat, deep #116699
   blue, friendly logo) but reimagine through a magazine-grade
   lens — oversized type, asymmetric grid, generous warm bone
   paper, full-bleed photography, scientific gravitas.
   ========================================================= */

:root{
  /* brand */
  --brand:        #116699;
  --brand-deep:   #0A4D73;
  --brand-light:  #25ABE4;
  --brand-glow:   #3FBFE8;
  --brand-fade:   #DDEAF2;

  --ink:          #0E1F30;
  --ink-2:        #142C42;
  --text:         #2C3A4A;
  --muted:        #5C6B7A;
  --muted-2:      #8194A4;
  --hairline:     #E2DDD4;
  --hairline-2:   #1A2D40;

  /* surfaces */
  --bone:         #F4F1EA;
  --bone-2:       #ECE7DC;
  --bone-deep:    #E5DFD0;
  --paper:        #FFFFFF;
  --night:        #0E1F30;

  --display: "Exo 2", system-ui, sans-serif;
  --body:    "Montserrat", system-ui, sans-serif;

  --r: 0px;
  --ease: cubic-bezier(.2,.7,.2,1);
  --ease-2: cubic-bezier(.83,0,.17,1);

  --gutter: clamp(20px, 4vw, 64px);
  --maxw: 1380px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
  overflow-x:hidden;
  width:100%;
}
body{
  margin:0;
  font-family:var(--body);
  font-weight:400;
  font-size:16px;
  line-height:1.65;
  color:var(--text);
  background:var(--bone);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  position:relative;
  overflow-x:clip;
  width:100%;
  max-width:100vw;
}
/* subtle paper grain across whole site */
body::before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.5;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.4' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .055 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;
}
body > *{ position:relative; z-index:2; }

img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; border:0; background:transparent; color:inherit; }
::selection{ background:var(--brand); color:#fff; }

/* ---------- Type system ---------- */
.eyebrow{
  font-family:var(--body);
  font-weight:500;
  font-size:11px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--brand);
  display:inline-flex; align-items:center; gap:14px;
}
.eyebrow::before{
  content:""; width:24px; height:1px; background:currentColor;
  display:inline-block;
}
.eyebrow .num{
  font-variant-numeric:tabular-nums;
  color:var(--ink); opacity:.45;
}
.kicker{
  font-family:var(--body);
  font-weight:500;
  font-size:12px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--muted);
}
h1,h2,h3,h4{
  font-family:var(--display);
  color:var(--ink);
  margin:0;
  letter-spacing:-0.018em;
  line-height:1.02;
}
h1{
  font-weight:600;
  font-size: clamp(48px, 7.2vw, 108px);
  letter-spacing:-0.03em;
  hyphens:auto;
  -webkit-hyphens:auto;
  overflow-wrap:break-word;
  word-break:normal;
}
h2{ font-weight:600; font-size: clamp(36px, 5.4vw, 88px); letter-spacing:-0.022em; line-height:1.04; }
h3{ font-weight:600; font-size: clamp(22px, 2.4vw, 36px); line-height:1.12; letter-spacing:-0.012em; }
.lead{
  font-family:var(--body); font-weight:300;
  font-size: clamp(17px, 1.45vw, 23px); line-height:1.55; color:var(--text);
}
p{ margin:0 0 1em; }
em{ font-style:italic; color:var(--brand); }
.italic-blue{ font-style:italic; color:var(--brand); font-weight:500; }

/* ---------- Layout primitives ---------- */
.container{
  width:100%;
  max-width:var(--maxw);
  margin:0 auto;
  padding-left:var(--gutter);
  padding-right:var(--gutter);
}
.container.wide{ max-width: 100%; padding-left:var(--gutter); padding-right:0; }

/* ---------- Top utility bar ---------- */
.utility{
  background:var(--ink);
  color:#cdd6df;
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.utility .container{
  display:flex; align-items:center; justify-content:space-between;
  height:38px; gap:24px;
  white-space:nowrap;
}
.utility a{ color:#cdd6df; }
.utility .pill{ display:inline-flex; align-items:center; gap:10px; white-space:nowrap; }
.utility .pill::before{
  content:""; width:6px; height:6px; border-radius:50%;
  background:var(--brand-glow);
  box-shadow:0 0 0 4px rgba(63,191,232,.18);
  animation: pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{ box-shadow:0 0 0 4px rgba(63,191,232,.18); }
  50%   { box-shadow:0 0 0 7px rgba(63,191,232,.06); }
}
.utility .right{ display:flex; gap:24px; align-items:center; }
.utility .right a:hover{ color:#fff; }

/* ---------- Header / nav ---------- */
.header{
  position:sticky; top:0; z-index:50;
  background:rgba(244,241,234,.86);
  backdrop-filter: saturate(140%) blur(10px);
  border-bottom:1px solid rgba(14,31,48,.08);
}
.nav{
  display:grid;
  grid-template-columns: auto 1fr auto;
  align-items:center;
  gap:32px;
  height:88px;
}
.brandmark{ display:inline-flex; align-items:center; gap:14px; }
.brandmark img{ height:44px; width:auto; }
.nav ul{
  list-style:none; padding:0; margin:0;
  display:flex; gap:28px; justify-content:center;
  font-family:var(--body); font-weight:500;
  font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink);
  white-space:nowrap;
}
.nav ul a{ position:relative; padding:6px 0; display:inline-flex; gap:8px; align-items:baseline; white-space:nowrap; }
.nav ul a .num{ font-variant-numeric:tabular-nums; opacity:.5; }
.nav ul a::after{
  content:""; position:absolute; left:0; right:100%; bottom:0;
  height:1px; background:var(--brand);
  transition:right .35s var(--ease);
}
.nav ul a:hover::after{ right:0; }
.nav .cta{
  display:inline-flex; align-items:center; gap:10px;
  font-size:12px; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase;
  color:#fff; background:var(--ink);
  padding:14px 22px;
  border:1px solid var(--ink);
  transition: background .3s var(--ease), border-color .3s var(--ease);
}
.nav .cta:hover{ background:var(--brand); border-color:var(--brand); }
.nav .menu-toggle{ display:none; }

/* ---------- HERO ---------- */
.hero{
  position:relative;
  padding: clamp(40px, 6vw, 110px) 0 0;
  background:var(--bone);
  overflow:hidden;
}
.hero .container{ position:relative; }

.hero-meta{
  display:flex; align-items:center; gap:18px;
  margin-bottom: clamp(24px, 3vw, 48px);
}
.hero-meta .dot{
  width:8px; height:8px; border-radius:50%;
  background:var(--brand-glow);
  box-shadow:0 0 0 6px rgba(63,191,232,.15);
}
.hero h1{
  color:var(--ink);
  text-wrap: balance;
}
.hero h1 .em{ color:var(--brand); font-style:italic; font-weight:500; }
.hero h1 .ampersand{
  color:var(--brand);
  font-style:italic;
  font-weight:400;
  margin: 0 0.05em;
}

.hero-grid{
  display:grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr);
  gap: clamp(32px, 5vw, 80px);
  align-items:end;
}
.hero-image{
  position:relative;
  aspect-ratio: 4/5;
  background:var(--bone-2);
  overflow:hidden;
  /* full-bleed to the right edge */
  margin-right: calc(var(--gutter) * -1);
}
.hero-image img{
  width:100%; height:100%; object-fit:cover; object-position:center;
  transition: transform 1.2s var(--ease-2);
}
.hero-image--dark{
  background: #0a1828;
}
.hero-image--dark img{
  object-fit: cover !important;
  object-position: center;
}
.hero-image:hover img{ transform: scale(1.02); }
.hero-image .stamp-tl{
  position:absolute; top:24px; left:24px;
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--body);
  font-size:10px; letter-spacing:.24em; text-transform:uppercase;
  color:#0E1F30;
  background:rgba(244,241,234,.94);
  padding:8px 12px;
  font-variant-numeric:tabular-nums;
}
.hero-image .stamp-bl{
  position:absolute; bottom:0; left:0; right:0;
  display:flex; justify-content:space-between; align-items:flex-end;
  font-family:var(--body);
  font-size:10px; letter-spacing:.24em; text-transform:uppercase;
  color:#0E1F30;
  background:rgba(244,241,234,.94);
  padding:14px 18px;
  backdrop-filter: blur(4px);
  border-top:1px solid rgba(14,31,48,.08);
}
.hero-image .stamp-bl .v{
  font-family:var(--display); font-weight:500; font-size:14px;
  letter-spacing:0; color:#0E1F30;
  text-transform:none;
  font-variant-numeric:tabular-nums;
  margin-top:4px;
}

.hero-actions{
  margin-top: clamp(28px, 3vw, 48px);
  display:flex; gap:16px; flex-wrap:wrap; align-items:center;
}
.btn{
  display:inline-flex; align-items:center; gap:14px;
  padding:18px 30px;
  font-family:var(--body);
  font-weight:600; font-size:12px;
  letter-spacing:.2em; text-transform:uppercase;
  border:1px solid currentColor;
  transition:background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease), transform .25s var(--ease);
  cursor:pointer; white-space:nowrap;
}
.btn .arr{ display:inline-block; transition:transform .35s var(--ease); }
.btn:hover .arr{ transform:translateX(4px); }
.btn-primary{
  background:var(--brand); color:#fff; border-color:var(--brand);
}
.btn-primary:hover{ background:var(--brand-deep); border-color:var(--brand-deep); }
.btn-ghost{ color:var(--ink); border-color:rgba(14,31,48,.35); }
.btn-ghost:hover{ color:var(--brand); border-color:var(--brand); }

.hero-aside{
  margin-top: clamp(24px, 3vw, 40px);
  max-width: 32ch;
}

/* scroll cue */
.scroll-cue{
  position:absolute; right:32px; bottom:24px;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  font-family:var(--body); font-size:10px; letter-spacing:.28em; text-transform:uppercase;
  color:var(--ink); opacity:.6;
}
.scroll-cue::after{
  content:""; width:1px; height:48px; background:var(--ink); opacity:.45;
  animation: drop 2.4s ease-in-out infinite;
  transform-origin:top;
}
@keyframes drop{
  0%   { transform:scaleY(0); }
  50%  { transform:scaleY(1); }
  100% { transform:scaleY(0); transform-origin:bottom; }
}

/* ---------- Breed index strip ---------- */
.breed-index{
  background:var(--bone);
  border-top:1px solid rgba(14,31,48,.12);
  border-bottom:1px solid rgba(14,31,48,.12);
}
.breed-index .container{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:0;
}
.breed-index .bx-item{
  display:grid;
  grid-template-columns: auto 1fr;
  grid-template-areas:
    "num name"
    "num meta";
  column-gap: 18px;
  row-gap: 4px;
  padding: 28px 32px;
  border-right:1px solid rgba(14,31,48,.12);
  transition: background .35s var(--ease);
  align-items:center;
}
.breed-index .bx-item:last-child{ border-right:0; }
.breed-index .bx-item:hover{ background: var(--bone-2); }

@media (max-width: 920px){
  .breed-index .container{ grid-template-columns: 1fr; }
  .breed-index .bx-item{
    border-right:0;
    border-bottom:1px solid rgba(14,31,48,.12);
    padding: 22px var(--gutter);
    column-gap:20px;
  }
  .breed-index .bx-item:last-child{ border-bottom:0; }
  .breed-index .bx-num{ font-size: 24px; }
  .breed-index .bx-name{ font-size: 18px; }
}
.breed-index .bx-num{
  grid-area: num;
  font-family: var(--display); font-weight:500;
  font-size: 28px;
  color: var(--brand);
  letter-spacing:-0.01em;
  font-variant-numeric:tabular-nums;
  align-self:center;
}
.breed-index .bx-name{
  grid-area: name;
  font-family: var(--display); font-weight:600;
  font-size: clamp(18px, 1.6vw, 22px);
  color: var(--ink);
  letter-spacing: -0.01em;
  line-height: 1.1;
}
.breed-index .bx-name em{
  color: var(--brand);
  font-style: italic;
  font-weight: 500;
}
.breed-index .bx-meta{
  grid-area: meta;
  font-size: 11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color: var(--muted);
  line-height: 1.4;
}

/* ---------- Stats strip ---------- */
.stats{
  padding: clamp(40px, 4vw, 64px) 0;
  background:var(--bone);
  border-bottom:1px solid rgba(14,31,48,.10);
}
.stats .container{
  display:grid;
  grid-template-columns: repeat(4,1fr);
  gap: clamp(16px, 3vw, 56px);
  align-items:start;
}
.stats .stat{ position:relative; padding-right:24px; }
.stats .stat:not(:last-child)::after{
  content:""; position:absolute; right:0; top:6px; bottom:6px; width:1px;
  background:rgba(14,31,48,.12);
}
.stats .num{
  font-family:var(--display); font-weight:500;
  font-size: clamp(36px, 3.4vw, 56px);
  color:var(--ink); letter-spacing:-0.025em; line-height:1;
}
.stats .num em{ font-style:italic; color:var(--brand); font-weight:500; }
.stats .label{
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--muted); margin-top:14px; max-width: 22ch;
}

/* ---------- Section base ---------- */
section{ padding: clamp(56px, 6vw, 96px) 0; }
.section-head{
  display:grid;
  grid-template-columns: 1fr 1.6fr;
  gap: clamp(20px, 5vw, 80px);
  align-items:end;
  margin-bottom: clamp(40px, 4vw, 64px);
}
.section-head .right p{ max-width: 56ch; }

/* ---------- About ---------- */
.about{ background:var(--bone); }
.about-grid{
  display:grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(40px, 6vw, 96px);
  align-items:start;
}
.about-image{
  position:relative;
  aspect-ratio: 5/3;
  overflow:hidden;
  background:var(--bone-2);
  position:sticky;
  top: 100px;
}
.about-image img{ width:100%; height:100%; object-fit:cover; object-position:center center; }
.about-image .caption{
  position:absolute; left:24px; bottom:24px; right:24px;
  background:rgba(244,241,234,.94);
  padding:14px 18px;
  font-size:12px; color:var(--ink); letter-spacing:.04em;
  border-left:2px solid var(--brand);
}
.about-copy h2 .em{ color:var(--brand); font-style:italic; font-weight:500; }
.about-copy p{ font-size:17px; line-height:1.7; color:var(--text); margin-top:24px; }
.about-copy .pillars{
  margin-top: clamp(32px, 4vw, 56px);
  display:grid; gap:0;
}
.about-copy .pillar{
  padding:22px 0; border-top:1px solid rgba(14,31,48,.12);
  position:relative;
  padding-left:24px;
}
.about-copy .pillar::before{
  content:""; position:absolute; left:0; top:30px;
  width:8px; height:8px; background:var(--brand);
}
.about-copy .pillar:last-child{ border-bottom:1px solid rgba(14,31,48,.12); }
.about-copy .pillar h4{
  font-family:var(--display); font-size:18px; color:var(--ink);
  margin-bottom:6px; font-weight:600;
}
.about-copy .pillar p{
  font-family:var(--body); font-size:14px; line-height:1.6;
  color:var(--muted); margin:0;
}

/* ---------- Breeds ---------- */
.breeds{ background:var(--paper); border-top:1px solid var(--hairline); }
.breeds .section-head{ margin-bottom: clamp(40px,5vw,72px); }

.breed{
  display:grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: clamp(40px, 6vw, 96px);
  align-items:center;
  padding: clamp(48px, 5vw, 80px) 0;
  border-top:1px solid rgba(14,31,48,.10);
  position:relative;
}
.breed:first-of-type{ border-top:0; padding-top: 0; }
.breed.reverse .breed-media{ order:2; }
.breed-media{
  aspect-ratio: 5/3;
  background:var(--bone-2);
  overflow:hidden;
  position:relative;
}
.breed-media img{
  width:100%; height:100%; object-fit:cover; object-position:center center;
  transition: transform 1.2s var(--ease-2);
}
.breed:hover .breed-media img{ transform: scale(1.025); }
.breed-media .index{
  position:absolute; top:24px; left:24px;
  font-family:var(--body); font-weight:500;
  font-size:10px; color:#fff;
  letter-spacing:.24em; text-transform:uppercase;
  background:rgba(14,31,48,.78);
  padding:9px 14px;
  font-variant-numeric:tabular-nums;
  backdrop-filter: blur(4px);
}
.breed-media .index em{ color:var(--brand-glow); font-style:italic; }
.breed-text{ position:relative; }
.breed-text .breed-num{
  font-family:var(--display);
  font-size: clamp(80px, 12vw, 200px);
  font-weight:500; line-height:1; letter-spacing:-0.05em;
  color:var(--bone-2);
  position:absolute;
  top: -40px; left:-12px;
  z-index:0;
  font-variant-numeric:tabular-nums;
  pointer-events:none;
  user-select:none;
}
.breed-text > *{ position:relative; z-index:1; }
.breed-text .breed-name{
  font-family:var(--display); font-weight:600;
  font-size: clamp(36px, 4.4vw, 64px);
  color:var(--ink); letter-spacing:-0.02em; line-height:1.05;
  margin-top:14px;
}
.breed-text .breed-name em{ color:var(--brand); font-style:italic; font-weight:500; }
.breed-text .breed-desc{
  margin-top: clamp(20px, 2vw, 32px);
  font-size: 16px; line-height:1.7; color:var(--text);
  max-width: 50ch;
}
.breed-text .specs{
  margin-top: clamp(28px, 3vw, 40px);
  display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:0;
  border-top:1px solid rgba(14,31,48,.12);
}
.breed-text .specs > div{
  padding:16px 0;
  border-bottom:1px solid rgba(14,31,48,.12);
}
.breed-text .specs > div:nth-child(odd){ padding-right:16px; border-right:1px solid rgba(14,31,48,.12); }
.breed-text .specs > div:nth-child(even){ padding-left:16px; }
@media (max-width: 720px){
  .breed-text .specs{ grid-template-columns: 1fr; }
  .breed-text .specs > div:nth-child(odd){ padding-right:0; border-right:0; }
  .breed-text .specs > div:nth-child(even){ padding-left:0; }
}
.breed-text .specs .k{
  font-size:10px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--muted); margin-bottom:6px;
}
.breed-text .specs .v{
  font-family:var(--display); font-weight:500; font-size:18px; color:var(--ink);
}
.breed-text .more{
  display:inline-flex; align-items:center; gap:12px;
  margin-top: clamp(28px, 3vw, 40px);
  font-size:12px; font-weight:600;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--brand);
  border-bottom:1px solid var(--brand);
  padding-bottom:8px;
}
.breed-text .more .arr{ transition:transform .35s var(--ease); }
.breed-text .more:hover .arr{ transform:translateX(6px); }

/* ---------- Process ---------- */
.process{
  background:var(--bone-deep);
  position:relative;
}
.process .section-head h2 em{ color:var(--brand); font-style:italic; font-weight:500; }
.process-steps{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:0;
  border-top:1px solid rgba(14,31,48,.18);
}
.process-step{
  padding: 56px 36px 64px 36px;
  border-right:1px solid rgba(14,31,48,.18);
  position:relative;
}
.process-step:first-child{ padding-left:0; }
.process-step:last-child{ border-right:0; padding-right:0; }
.process-step .step-num{
  font-family:var(--display); font-weight:500;
  font-size:11px; letter-spacing:.24em; color:var(--brand);
  font-variant-numeric:tabular-nums;
  margin-bottom:32px; display:block;
}
.process-step h4{
  font-family:var(--display); font-weight:600;
  font-size: clamp(20px,1.8vw,26px);
  color:var(--ink);
  line-height:1.25;
  margin-bottom:18px;
  letter-spacing:-0.008em;
}
.process-step h4 em{ color:var(--brand); font-style:italic; font-weight:500; }
.process-step p{
  font-size:15px; line-height:1.7; color:var(--muted); margin:0;
}
.process-step::before{
  content:""; position:absolute;
  top:-1px; left:36px; height:3px; width:36px;
  background:var(--brand);
}
.process-step:first-child::before{ left:0; }

/* ---------- Trust block ---------- */
.trust{
  background:var(--ink);
  color:#dde6ee;
  position:relative;
  overflow:hidden;
}
.trust::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(800px 500px at 90% 10%, rgba(37,171,228,.10), transparent 60%),
    radial-gradient(600px 400px at 10% 90%, rgba(17,102,153,.18), transparent 60%);
  pointer-events:none;
}
.trust > *{ position:relative; }
.trust h2{ color:#fff; }
.trust h2 .em{ color:var(--brand-glow); font-style:italic; font-weight:500; }
.trust .eyebrow{ color:var(--brand-glow); }
.trust .eyebrow .num{ color:#fff; opacity:.5; }
.trust-grid{
  display:grid;
  grid-template-columns: repeat(3,1fr);
  gap: 0;
  margin-top: clamp(40px, 5vw, 80px);
  border-top:1px solid rgba(255,255,255,.14);
}
.trust-item{
  padding: clamp(34px,3vw,52px) clamp(24px,2.4vw,40px) clamp(40px,4vw,64px);
  border-bottom:1px solid rgba(255,255,255,.14);
  border-right:1px solid rgba(255,255,255,.14);
  position:relative;
}
.trust-item:nth-child(3n){ border-right:0; }
.trust-item h4{
  font-family:var(--display); font-weight:600;
  font-size: clamp(22px,1.9vw,26px); color:#fff;
  margin-bottom:14px; line-height:1.18;
  letter-spacing:-0.005em;
}
.trust-item p{ color:#a8b6c4; font-size:14.5px; line-height:1.65; }
.trust-item .icon{
  width:38px; height:38px; margin-bottom:24px;
  color:var(--brand-glow);
}

/* ---------- Quote / pull ---------- */
.quote{
  background:var(--bone);
  padding: clamp(80px,8vw,140px) 0;
  border-top:1px solid var(--hairline);
}
.quote blockquote{
  margin:0;
  font-family:var(--display);
  font-weight:500;
  font-size: clamp(30px, 4vw, 64px);
  line-height:1.14;
  color:var(--ink);
  letter-spacing:-0.022em;
  max-width: 22ch;
  text-wrap:balance;
}
.quote blockquote em{ color:var(--brand); font-style:italic; }
.quote .attribution{
  margin-top: clamp(40px, 4vw, 72px);
  display:flex; gap:18px; align-items:center;
  font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted);
}
.quote .attribution .name{
  font-family:var(--display); font-weight:600; color:var(--ink);
  font-size:14px; letter-spacing:.06em;
}
.quote .attribution::before{
  content:""; width:36px; height:1px; background:var(--ink); opacity:.35;
}

/* ---------- CTA band ---------- */
.cta-band{
  background:var(--brand);
  color:#fff;
  position:relative; overflow:hidden;
}
.cta-band::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(700px 400px at 100% 0%, rgba(63,191,232,.35), transparent 55%),
    radial-gradient(600px 400px at 0% 100%, rgba(10,77,115,.45), transparent 55%);
  pointer-events:none;
}
.cta-band > *{ position:relative; }
.cta-band .container{
  display:grid; grid-template-columns: 1.4fr 1fr; gap: clamp(32px,5vw,80px);
  align-items:center;
  padding-top: clamp(60px,7vw,120px);
  padding-bottom: clamp(60px,7vw,120px);
}
.cta-band h2{
  color:#fff; font-weight:500;
  font-size: clamp(34px, 4.6vw, 72px); line-height:1.06;
  letter-spacing:-0.022em;
  text-wrap:balance;
}
.cta-band h2 em{ color:#cfeaff; font-style:italic; }
.cta-band p{
  margin-top:20px; max-width: 50ch; color:#dff0ff; font-size:16px;
}
.cta-band .actions{
  display:flex; flex-direction:column; gap:14px; align-items:flex-start;
  justify-self:end;
}
.cta-band .btn-primary{
  background:#fff; color:var(--brand); border-color:#fff;
}
.cta-band .btn-primary:hover{
  background:var(--ink); color:#fff; border-color:var(--ink);
}
.cta-band .btn-ghost{
  color:#fff; border-color:rgba(255,255,255,.5);
}
.cta-band .btn-ghost:hover{ color:#fff; border-color:#fff; background:rgba(255,255,255,.08); }

/* ---------- Contact ---------- */
.contact{
  background:var(--paper);
  border-top:1px solid var(--hairline);
}
.contact-grid{
  display:grid; grid-template-columns: 1fr 1.2fr; gap: clamp(40px, 6vw, 96px);
  align-items:start;
}
.contact-info dl{
  display:grid; grid-template-columns: 120px 1fr; gap:14px 24px;
  margin: clamp(24px,3vw,40px) 0 0;
  border-top:1px solid rgba(14,31,48,.12);
  padding-top:24px;
}
.contact-info dt{
  font-size:10px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--muted); padding-top:4px;
}
.contact-info dd{
  margin:0; padding-bottom:18px; border-bottom:1px solid rgba(14,31,48,.08);
  font-family:var(--display); font-weight:500; font-size:18px;
  color:var(--ink); letter-spacing:-0.005em;
}
.contact-info dd a:hover{ color:var(--brand); }
.contact-info dl > div{ display:contents; }

form{
  display:grid; gap:18px;
  background:var(--bone);
  padding: clamp(28px, 3vw, 44px);
  border:1px solid var(--hairline);
}
form .row{ display:grid; grid-template-columns: 1fr 1fr; gap:18px; }
form label{
  display:block;
  font-size:10px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--muted); margin-bottom:8px;
}
form input, form textarea, form select{
  width:100%;
  padding:14px 16px;
  font-family:var(--body); font-size:15px; color:var(--ink);
  background:#fff;
  border:1px solid rgba(14,31,48,.18);
  border-radius:0;
  transition:border-color .25s var(--ease);
}
form input:focus, form textarea:focus, form select:focus{
  outline:none; border-color:var(--brand);
}
form textarea{ min-height:140px; resize:vertical; }
form .submit{ justify-self:start; margin-top:8px; }

/* ---------- Footer ---------- */
.footer{
  background:var(--ink);
  color:#a8b6c4;
  padding: clamp(60px, 6vw, 96px) 0 32px;
  position:relative; overflow:hidden;
}
.footer::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(800px 500px at 50% 100%, rgba(37,171,228,.10), transparent 60%);
  pointer-events:none;
}
.footer > *{ position:relative; }

/* big wordmark in footer */
.footer-wordmark{
  font-family:var(--display);
  font-weight:600;
  font-size: clamp(64px, 12vw, 220px);
  letter-spacing:-0.04em;
  line-height:.85;
  color:transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,.16);
  margin: 0 0 60px;
  text-wrap:balance;
}
.footer-wordmark em{
  color:var(--brand-glow);
  font-style:italic;
  font-weight:500;
  -webkit-text-stroke: 0;
}

.footer-top{
  display:grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: clamp(24px, 4vw, 64px);
}
.footer .brandmark{ color:#fff; align-items:flex-start; }
.footer .brandmark img{ height:48px; opacity:.95; }
.footer h5{
  color:#fff; font-family:var(--display); font-weight:600;
  font-size:11px; letter-spacing:.24em; text-transform:uppercase;
  margin:0 0 18px; padding-bottom:14px;
  border-bottom:1px solid rgba(255,255,255,.18);
}
.footer ul{ list-style:none; padding:0; margin:0; display:grid; gap:10px; font-size:14px; }
.footer ul a:hover{ color:#fff; }
.footer .blurb{
  margin-top:20px; max-width: 36ch; font-size:14px; line-height:1.6;
}
.footer .social{
  display:flex; gap:12px; margin-top:24px;
}
.footer .social a{
  width:40px; height:40px; display:inline-flex; align-items:center; justify-content:center;
  border:1px solid rgba(255,255,255,.18);
  transition: background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
  color:#cdd6df;
}
.footer .social a:hover{ background:var(--brand); border-color:var(--brand); color:#fff; }
.footer-bottom{
  margin-top: clamp(48px, 4vw, 80px);
  padding-top:24px;
  border-top:1px solid rgba(255,255,255,.12);
  display:flex; justify-content:space-between; align-items:center;
  font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:#7c8a98; flex-wrap:wrap; gap:16px;
}
.footer-bottom .links{ display:flex; gap:24px; }
.footer-bottom a:hover{ color:#fff; }

/* ---------- Legal pages ---------- */
.legal-page{
  background:var(--bone);
  padding: clamp(48px, 6vw, 96px) 0 clamp(64px, 7vw, 120px);
}
.legal-body{
  max-width: 70ch;
  font-size: 16px;
  line-height: 1.75;
  color: var(--text);
}
.legal-body h3{
  font-family: var(--display);
  font-size: 20px;
  font-weight: 600;
  color: var(--ink);
  margin: 36px 0 12px;
  letter-spacing: -0.005em;
}
.legal-body h3:first-child{ margin-top: 0; }
.legal-body p{ margin: 0 0 18px; }
.legal-body a{ color: var(--brand); border-bottom: 1px solid currentColor; }
.legal-body a:hover{ color: var(--brand-deep); }

/* ---------- Reveal (subtle) ---------- */
.reveal{ opacity:0; transform: translateY(14px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

/* ---------- Responsive ---------- */
@media (max-width: 1080px){
  .process-steps{ grid-template-columns: repeat(2,1fr); }
  .process-step:nth-child(2){ border-right:0; }
  .process-step:nth-child(3),.process-step:nth-child(4){ border-top:1px solid rgba(14,31,48,.18); }
  .process-step{ padding-right:24px; padding-left:24px; }
  .process-step:first-child{ padding-left:0; }
  .process-step:nth-child(2){ padding-right:0; }
}
@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; }
  .hero-image{ aspect-ratio: 4/3; margin-right:0; }
  .about-image{
    position:relative;
    top:auto;
    aspect-ratio: 3/2;
    min-height: 0;
  }
  .about-image img{ min-height: 0; }
  .about-image .caption{
    left:16px; right:16px; bottom:16px;
    padding:12px 14px;
    font-size:11px;
  }
  .stats .container{ grid-template-columns: repeat(2,1fr); row-gap:32px; }
  .stats .stat:nth-child(2)::after{ display:none; }
  .section-head{ grid-template-columns:1fr; }
  .about-grid{ grid-template-columns:1fr; }
  .breed{ grid-template-columns:1fr; gap:32px; }
  .breed.reverse .breed-media{ order:0; }
  .breed-text .breed-num{ font-size: clamp(120px, 22vw, 200px); top:-30px; }
  .trust-grid{ grid-template-columns:1fr; }
  .trust-item{ border-right:0 !important; }
  .cta-band .container{ grid-template-columns:1fr; }
  .cta-band .actions{ justify-self:start; }
  .contact-grid{ grid-template-columns:1fr; }
  .footer-top{ grid-template-columns: 1fr 1fr; }
  .scroll-cue{ display:none; }
}

@media (max-width: 1024px){
  .utility{ display:none; }
  .nav{ height:72px; gap:16px; grid-template-columns: auto 1fr auto; }
  .brandmark img{ height:40px; }
  .nav ul{ display:none; }
  .nav .cta{ display:none; }
  .nav .menu-toggle{
    display:inline-flex; align-items:center; justify-content:center;
    width:44px; height:44px; border:1px solid rgba(14,31,48,.2);
  }
}
@media (max-width: 720px){
  :root{ --gutter: 18px; }
  .nav{ height:64px; }
  .brandmark img{ height:36px; }
  h1{ font-size: clamp(38px, 11vw, 56px) !important; }
  .btn{ font-size:11px; padding:16px 22px; }
  .lead{ font-size: 16px; }

  h1{ font-size: clamp(46px, 12.5vw, 72px); letter-spacing:-0.025em; }
  h2{ font-size: clamp(32px, 9vw, 48px); }
  .hero{ padding-top: 32px; }
  .hero-image{ aspect-ratio: 3/4; }
  .ticker-inner{ font-size: 18px; gap:32px; padding:14px 0; }
  .stats .container{ grid-template-columns: 1fr 1fr; }
  .stats .stat:nth-child(2)::after{ display:none; }
  .stats .stat:nth-child(odd){ border-right:1px solid rgba(14,31,48,.12); padding-right:16px; }
  .stats .stat:nth-child(even){ padding-left:16px; }
  .stats .stat::after{ display:none !important; }

  .breed-text .breed-num{ font-size: 120px; top:-22px; }

  form .row{ grid-template-columns: 1fr; }
  .contact-info dl{ grid-template-columns: 1fr; gap:0; }
  .contact-info dt{ padding-top:14px; }
  .footer-top{ grid-template-columns: 1fr; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; }
  .footer-wordmark{ -webkit-text-stroke-width: .8px; }
}
