/* ============================================================
   Flying Turtle UK — design system
   ============================================================ */
:root{
  --green-900:#0E3B2E;
  --green-800:#11483A;
  --green-700:#1B5A48;
  --green-500:#3A7F69;
  --green-100:#D8E5DE;
  --amber-600:#C8853E;
  --amber-500:#D89B58;
  --amber-300:#E8C994;
  --amber-100:#F4E5C8;
  --cream:#FAF6EE;
  --cream-2:#F4EEE1;
  --paper:#FFFFFF;
  --ink:#1A1A1A;
  --ink-2:#3B3B3B;
  --ink-3:#6A6A6A;
  --line:#E6DFCF;
  --line-dark:#234638;
  --shadow-1:0 1px 2px rgba(14,59,46,.06), 0 8px 24px rgba(14,59,46,.06);
  --shadow-2:0 2px 4px rgba(14,59,46,.08), 0 24px 48px rgba(14,59,46,.10);
  --radius:18px;
  --radius-sm:10px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  font-size:16.5px;
}

img,svg{display:block;max-width:100%}
a{color:inherit}
em{font-style:italic}

/* ----- typography ----- */
h1,h2,h3,h4{
  font-family:'Fraunces',Georgia,serif;
  font-weight:500;
  letter-spacing:-0.01em;
  line-height:1.08;
  margin:0 0 .4em;
  color:var(--green-900);
}
h1{ font-size:clamp(2.6rem, 5.4vw, 4.6rem); font-weight:400; letter-spacing:-0.022em; line-height:1.04;}
h2{ font-size:clamp(2rem, 3.4vw, 3rem); }
h3{ font-size:1.45rem; }
h4{ font-size:1.1rem; }
.light{color:#fff !important}
.muted{color:var(--ink-3)}
.small{font-size:.85rem}

p{margin:0 0 1em}

/* ----- container ----- */
.container{
  width:min(1180px, 92vw);
  margin:0 auto;
}

/* ----- nav ----- */
.nav{
  position:sticky;
  top:0; z-index:30;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px clamp(16px, 4vw, 36px);
  background:rgba(250,246,238,0.85);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid rgba(14,59,46,.06);
}
.nav__brand{
  display:flex; align-items:center; gap:10px;
  font-family:'Fraunces',serif;
  font-size:1.15rem;
  text-decoration:none;
  color:var(--green-900);
  font-weight:500;
}
.nav__brand em{ color:var(--amber-600); font-style:normal; }
.nav__logo{ width:30px; height:30px; color:var(--green-900); }
.nav__links{
  display:flex; gap:22px;
}
.nav__links a{
  text-decoration:none;
  font-size:.9rem;
  color:var(--ink-2);
  transition:color .2s;
}
.nav__links a:hover{ color:var(--green-900); }
.nav__cta{
  text-decoration:none;
  font-size:.9rem;
  padding:10px 16px;
  background:var(--green-900);
  color:#fff;
  border-radius:999px;
  font-weight:500;
  transition:background .2s, transform .2s;
}
.nav__cta:hover{ background:var(--green-800); transform:translateY(-1px); }
@media (max-width:880px){
  .nav__links{display:none}
}

/* ----- buttons ----- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:14px 24px;
  border-radius:999px;
  font-weight:500;
  text-decoration:none;
  font-size:.98rem;
  transition:transform .2s, background .2s, color .2s, box-shadow .2s;
  border:0; cursor:pointer;
  font-family:inherit;
}
.btn--primary{ background:var(--amber-600); color:#fff; box-shadow:var(--shadow-1); }
.btn--primary:hover{ background:var(--amber-500); transform:translateY(-2px); box-shadow:var(--shadow-2); }
.btn--ghost{ background:transparent; color:#fff; border:1px solid rgba(255,255,255,0.4); }
.btn--ghost:hover{ background:rgba(255,255,255,0.08); }
.section--cream .btn--ghost,
.section .btn--ghost{ color:var(--green-900); border-color:rgba(14,59,46,.25); }
.section--cream .btn--ghost:hover,
.section .btn--ghost:hover{ background:rgba(14,59,46,.04); }
.btn--small{ padding:9px 16px; font-size:.85rem; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  overflow:hidden;
  background:radial-gradient(1200px 800px at 80% 0%, #14523F 0%, #0E3B2E 50%, #0A2D24 100%);
  color:#fff;
  min-height:100vh;
  display:flex; align-items:center;
  padding:120px 0 80px;
}
.hero__bg{ position:absolute; inset:0; pointer-events:none; }
.hero__halo{
  position:absolute;
  width:900px; height:900px;
  right:-200px; top:-300px;
  background:radial-gradient(closest-side, rgba(232,201,148,.28), transparent 70%);
  filter:blur(20px);
}
.hero__grain{
  position:absolute; inset:0; opacity:.06;
  background-image: radial-gradient(rgba(255,255,255,.7) 1px, transparent 1px);
  background-size: 3px 3px;
  mix-blend-mode:overlay;
}
.hero__inner{ position:relative; width:min(1180px, 92vw); margin:0 auto; z-index:1; }
.kicker{
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 14px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  font-size:.78rem;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:#E8C994;
  margin-bottom:30px;
  backdrop-filter:blur(10px);
}
.kicker__dot{ width:8px; height:8px; border-radius:50%; background:#E8C994; box-shadow:0 0 12px #E8C994; }

.hero__title{
  color:#fff;
  margin-bottom:.6em;
  max-width:18ch;
}
.hero__title em{
  color:var(--amber-300);
  font-style:italic;
}
.hero__lede{
  max-width:62ch;
  font-size:clamp(1.05rem, 1.4vw, 1.25rem);
  color:#E8E2D4;
  margin-bottom:36px;
}
.hero__lede strong{ color:#fff; font-weight:600; }
.hero__ctas{ display:flex; gap:14px; flex-wrap:wrap; margin-bottom:80px; }
.hero__ctas .btn--ghost{ color:#fff; }

.hero__stats{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1px;
  background:rgba(255,255,255,.12);
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
}
.hero__stat{
  background:rgba(14,59,46,.6);
  padding:28px 24px;
  backdrop-filter:blur(8px);
}
.hero__num{
  font-family:'Fraunces',serif;
  font-size:clamp(2rem, 3.6vw, 3rem);
  color:var(--amber-300);
  font-weight:400;
  line-height:1;
  margin-bottom:10px;
  letter-spacing:-.02em;
}
.hero__lbl{
  font-size:.92rem;
  color:#E8E2D4;
  line-height:1.4;
}
.hero__lbl span{
  display:block;
  margin-top:6px;
  font-size:.74rem;
  color:rgba(255,255,255,.55);
  letter-spacing:.02em;
}
@media (max-width:920px){
  .hero__stats{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:520px){
  .hero__stats{grid-template-columns:1fr}
}

.hero__scroll{
  position:absolute;
  bottom:24px; left:50%;
  transform:translateX(-50%);
  font-size:.75rem;
  color:rgba(255,255,255,.5);
  letter-spacing:.2em;
  text-transform:uppercase;
  animation:bob 2.6s ease-in-out infinite;
}
@keyframes bob{
  0%,100%{ transform:translate(-50%,0); opacity:.6 }
  50%{ transform:translate(-50%,8px); opacity:1 }
}

/* ============================================================
   SECTIONS
   ============================================================ */
.section{
  padding:clamp(70px, 10vw, 130px) 0;
  position:relative;
}
.section--cream{ background:var(--cream); }
.section--dark{
  background:linear-gradient(180deg, #0E3B2E 0%, #0B2E25 100%);
  color:#fff;
}
.section--dark h2,
.section--dark h3,
.section--dark h4{ color:#fff; }
.section--dark .section__lede,
.section--dark p{ color:#D8E5DE; }

.section__head{ max-width:780px; margin-bottom:50px; }
.section__head--center{ text-align:center; margin-left:auto; margin-right:auto; }
.section__lede{
  font-size:clamp(1rem, 1.3vw, 1.18rem);
  color:var(--ink-2);
  max-width:60ch;
}
.section__head--center .section__lede{ margin-left:auto; margin-right:auto; }

.eyebrow{
  display:inline-block;
  font-size:.74rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--amber-600);
  margin-bottom:18px;
  font-weight:500;
}
.eyebrow--light{ color:var(--amber-300); }

.m-top{ margin-top:32px; }

/* ----- grids ----- */
.grid{ display:grid; gap:24px; }
.grid--2{ grid-template-columns:repeat(2, 1fr); }
.grid--3{ grid-template-columns:repeat(3, 1fr); }
.grid--4{ grid-template-columns:repeat(4, 1fr); }
@media (max-width:980px){
  .grid--2,.grid--3,.grid--4{ grid-template-columns:1fr 1fr; }
}
@media (max-width:680px){
  .grid--2,.grid--3,.grid--4{ grid-template-columns:1fr; }
}

/* ----- cards ----- */
.card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:32px;
  box-shadow:var(--shadow-1);
}
.card--quote{
  background:linear-gradient(160deg, var(--green-900), var(--green-800));
  color:#fff;
  border-color:transparent;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.card--quote .quote{
  font-family:'Fraunces',serif;
  font-size:clamp(1.15rem, 1.6vw, 1.4rem);
  line-height:1.4;
  font-weight:400;
  margin:0 0 18px;
  color:#F4EEE1;
}
.card--quote .quote::before{
  content:"\201C";
  font-size:5rem;
  color:var(--amber-300);
  display:block;
  line-height:.6;
  margin-bottom:8px;
}
.card--quote .quote__cite{
  font-size:.82rem;
  color:rgba(255,255,255,.6);
  letter-spacing:.04em;
}
.card--chart .card__head{ margin-bottom:18px; }
.card__head h3{ margin-bottom:4px; }
.card__head .muted{ font-size:.85rem; }
.card--wide{ padding:36px; }

.chart-wrap{ position:relative; height:280px; }
.chart-wrap--tall{ height:380px; }

/* ----- stat cards ----- */
.stat-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px;
  transition:transform .25s, box-shadow .25s, border-color .25s;
}
.stat-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-2);
  border-color:rgba(200,133,62,.4);
}
.stat-card__num{
  font-family:'Fraunces',serif;
  font-size:2.4rem;
  color:var(--green-900);
  font-weight:500;
  line-height:1;
  margin-bottom:14px;
  letter-spacing:-.02em;
}
.stat-card__lbl{
  font-size:.95rem;
  color:var(--ink-2);
  line-height:1.5;
  margin-bottom:14px;
}
.stat-card__src{
  font-size:.74rem;
  color:var(--ink-3);
  letter-spacing:.04em;
  text-transform:uppercase;
  border-top:1px solid var(--line);
  padding-top:12px;
}

/* ----- callout ----- */
.callout{
  margin-top:40px;
  padding:32px;
  border-radius:var(--radius);
  background:linear-gradient(120deg, var(--amber-100), var(--cream-2));
  border:1px solid rgba(200,133,62,.25);
  position:relative;
  overflow:hidden;
}
.callout::before{
  content:"";
  position:absolute;
  left:0; top:0; bottom:0;
  width:5px;
  background:var(--amber-600);
}
.callout__title{
  font-family:'Fraunces',serif;
  font-size:1.1rem;
  color:var(--green-900);
  margin-bottom:6px;
}
.callout p{
  margin:0;
  color:var(--ink-2);
  font-size:1.02rem;
}

/* ============================================================
   PRODUCT
   ============================================================ */
.product{
  display:grid;
  grid-template-columns:0.9fr 1.1fr;
  gap:60px;
  align-items:center;
}
@media (max-width:900px){
  .product{ grid-template-columns:1fr; gap:40px; }
}
.product__diagram{
  position:relative;
  aspect-ratio:1/1;
  display:flex; align-items:center; justify-content:center;
}
.machine{
  position:relative;
  width:280px;
  height:430px;
  margin:0 auto;
}
.machine__screen{
  position:relative;
  background:linear-gradient(180deg, #15493B, #0F3D2E);
  border:2px solid var(--amber-300);
  border-radius:14px 14px 4px 4px;
  height:170px;
  padding:18px;
  box-shadow: inset 0 0 30px rgba(232,201,148,.15), 0 0 30px rgba(232,201,148,.15);
}
.machine__screen-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:8px;
}
.machine__screen-grid span{
  background:rgba(232,201,148,.12);
  border:1px solid rgba(232,201,148,.3);
  color:var(--amber-300);
  padding:6px 4px;
  border-radius:6px;
  font-size:.7rem;
  text-align:center;
  font-family:'Inter',sans-serif;
  font-weight:500;
}
.machine__menu-tag{
  position:absolute;
  bottom:14px;
  left:50%;
  transform:translateX(-50%);
  font-size:.68rem;
  color:rgba(232,201,148,.7);
  letter-spacing:.18em;
  text-transform:uppercase;
}
.machine__body{
  background:linear-gradient(180deg, #E8C994 0%, #D89B58 100%);
  height:200px;
  border:2px solid var(--green-900);
  border-top:0;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:14px;
}
.machine__strip{
  position:absolute; left:0; right:0; top:30px;
  height:8px;
  background:repeating-linear-gradient(90deg, var(--green-900) 0 14px, transparent 14px 22px);
  opacity:.5;
}
.machine__nozzle{
  width:38px; height:18px;
  background:#1F1F1F;
  border-radius:0 0 6px 6px;
  margin-top:18px;
}
.machine__cup{
  width:50px; height:50px;
  background:#fff;
  border:2px solid var(--green-900);
  border-radius:4px 4px 12px 12px;
  position:relative;
}
.machine__cup::after{
  content:"";
  position:absolute; inset:4px 4px 30%;
  background:linear-gradient(180deg, #6B3A1F, #3A1E0E);
  border-radius:2px 2px 0 0;
}
.machine__pad{
  font-size:.72rem;
  color:var(--green-900);
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:600;
}
.machine__base{
  height:30px;
  background:var(--green-900);
  border-radius:0 0 14px 14px;
}
.machine__dim{
  position:absolute;
  font-size:.7rem;
  color:var(--ink-3);
  letter-spacing:.1em;
  text-transform:uppercase;
}
.machine__dim--w{ bottom:-26px; left:50%; transform:translateX(-50%); }
.machine__dim--h{ top:50%; right:-60px; transform:translateY(-50%) rotate(90deg); transform-origin:center; }

.section--dark .machine__cup{ background:#FAF6EE; }
.section--dark .machine__dim{ color:rgba(255,255,255,.55); }

.product__features{
  list-style:none;
  margin:0; padding:0;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:28px;
}
@media (max-width:600px){ .product__features{ grid-template-columns:1fr; } }
.product__features li{
  display:flex; gap:18px;
  padding:6px 0;
}
.feature__num{
  flex-shrink:0;
  width:64px;
  font-family:'Fraunces',serif;
  font-size:1.4rem;
  font-weight:500;
  color:var(--amber-300);
  letter-spacing:-.01em;
  border-right:1px solid rgba(255,255,255,.18);
  padding-right:14px;
  line-height:1.1;
}
.product__features h4{ margin:0 0 4px; color:#fff; font-size:1.05rem; }
.product__features p{ margin:0; color:rgba(255,255,255,.7); font-size:.9rem; line-height:1.5; }

/* ============================================================
   PROOF
   ============================================================ */
.proof-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px;
  text-align:center;
  transition:transform .25s, box-shadow .25s;
}
.proof-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow-2); }
.proof-card__num{
  font-family:'Fraunces',serif;
  font-size:2.6rem;
  color:var(--amber-600);
  font-weight:500;
  line-height:1;
  margin-bottom:12px;
  letter-spacing:-.02em;
}
.proof-card__lbl{ color:var(--ink-2); margin-bottom:14px; font-size:.95rem; }
.proof-card__src{
  border-top:1px solid var(--line);
  padding-top:12px;
  font-size:.74rem;
  color:var(--ink-3);
  letter-spacing:.04em;
  text-transform:uppercase;
}

/* ============================================================
   STRATEGY · site cards
   ============================================================ */
.site-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px;
  transition:transform .25s, box-shadow .25s, border-color .25s, background .25s;
}
.site-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-2);
  border-color:var(--green-500);
  background:linear-gradient(180deg, var(--paper), var(--cream-2));
}
.site-card__icon{
  width:52px; height:52px;
  border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  background:var(--green-100);
  color:var(--green-900);
  margin-bottom:18px;
}
.site-card h4{ margin-bottom:8px; font-size:1.05rem; }
.site-card p{ margin:0; font-size:.92rem; color:var(--ink-2); line-height:1.5; }

.strategy-bottom{
  margin-top:60px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  padding-top:50px;
  border-top:1px solid var(--line);
}
@media (max-width:820px){ .strategy-bottom{ grid-template-columns:1fr; gap:32px; } }
.strategy-bottom h3{ margin-bottom:18px; font-size:1.35rem; }

.ticks, .crosses{
  list-style:none;
  margin:0; padding:0;
  display:grid; gap:12px;
}
.ticks li, .crosses li{
  position:relative;
  padding-left:30px;
  font-size:.98rem;
  color:var(--ink-2);
  line-height:1.55;
}
.ticks li::before{
  content:"";
  position:absolute; left:0; top:8px;
  width:18px; height:18px;
  border-radius:50%;
  background:var(--green-100);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230E3B2E' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
  background-size:12px; background-repeat:no-repeat; background-position:center;
}
.crosses li::before{
  content:"";
  position:absolute; left:0; top:8px;
  width:18px; height:18px;
  border-radius:50%;
  background:#F4DCD0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23A03A1A' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><line x1='18' y1='6' x2='6' y2='18'/><line x1='6' y1='6' x2='18' y2='18'/></svg>");
  background-size:12px; background-repeat:no-repeat; background-position:center;
}
.ticks--light li{ color:rgba(255,255,255,.85); }
.ticks--light li::before{
  background:rgba(232,201,148,.2);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23E8C994' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
}

/* ============================================================
   CALCULATOR
   ============================================================ */
.calc{
  display:grid;
  grid-template-columns:340px 1fr;
  gap:36px;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:36px;
  box-shadow:var(--shadow-1);
}
@media (max-width:980px){ .calc{ grid-template-columns:1fr; } }

.calc__controls{ display:flex; flex-direction:column; gap:22px; }
.control label{
  display:flex; justify-content:space-between; align-items:baseline;
  font-size:.88rem;
  color:var(--ink-2);
  margin-bottom:8px;
  font-weight:500;
}
.control output{
  font-family:'Fraunces',serif;
  font-size:1.15rem;
  color:var(--green-900);
  font-weight:600;
}
.control input[type=range]{
  width:100%;
  -webkit-appearance:none;
  background:transparent;
  height:24px;
}
.control input[type=range]::-webkit-slider-runnable-track{
  height:6px;
  background:linear-gradient(90deg, var(--amber-600) var(--p,50%), var(--line) var(--p,50%));
  border-radius:999px;
}
.control input[type=range]::-moz-range-track{
  height:6px;
  background:var(--line);
  border-radius:999px;
}
.control input[type=range]::-moz-range-progress{
  height:6px;
  background:var(--amber-600);
  border-radius:999px;
}
.control input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;
  width:20px; height:20px;
  border-radius:50%;
  background:var(--green-900);
  border:3px solid #fff;
  margin-top:-7px;
  box-shadow:0 2px 6px rgba(14,59,46,.3);
  cursor:pointer;
  transition:transform .15s;
}
.control input[type=range]::-moz-range-thumb{
  width:20px; height:20px;
  border-radius:50%;
  background:var(--green-900);
  border:3px solid #fff;
  box-shadow:0 2px 6px rgba(14,59,46,.3);
  cursor:pointer;
}
.control input[type=range]:hover::-webkit-slider-thumb{ transform:scale(1.1); }
.control__range{
  display:flex; justify-content:space-between;
  font-size:.7rem; color:var(--ink-3);
  margin-top:4px;
}

.calc__result{ display:flex; flex-direction:column; gap:24px; }
.calc__readouts{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
}
.readout{
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:18px;
}
.readout--feature{
  background:linear-gradient(160deg, var(--green-900), var(--green-800));
  color:#fff;
  border-color:transparent;
}
.readout__lbl{
  font-size:.78rem;
  color:var(--ink-3);
  margin-bottom:8px;
  line-height:1.35;
}
.readout--feature .readout__lbl{ color:rgba(255,255,255,.7); }
.readout__val{
  font-family:'Fraunces',serif;
  font-size:1.7rem;
  color:var(--green-900);
  font-weight:500;
  line-height:1;
  letter-spacing:-.01em;
}
.readout--feature .readout__val{ color:var(--amber-300); }
.readout__sub{
  margin-top:8px;
  font-size:.7rem;
  color:rgba(255,255,255,.6);
  letter-spacing:.04em;
  text-transform:uppercase;
}
@media (max-width:600px){ .calc__readouts{ grid-template-columns:1fr; } }

/* ============================================================
   PHASES (rollout)
   ============================================================ */
.phases{
  list-style:none;
  margin:0; padding:0;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
  counter-reset:phase;
}
@media (max-width:920px){ .phases{ grid-template-columns:1fr; } }
.phase{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:32px;
  position:relative;
  transition:transform .25s, box-shadow .25s;
}
.phase::before{
  content:"";
  position:absolute;
  top:0; left:0;
  height:4px;
  width:100%;
  background:linear-gradient(90deg, var(--amber-600), var(--amber-300));
  border-radius:var(--radius) var(--radius) 0 0;
}
.phase:hover{ transform:translateY(-4px); box-shadow:var(--shadow-2); }
.phase__hd{ margin-bottom:18px; }
.phase__num{
  display:inline-block;
  font-size:.72rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--amber-600);
  font-weight:500;
  margin-bottom:10px;
}
.phase h3{ margin-bottom:8px; font-size:1.25rem; }
.phase__when{
  font-size:.85rem;
  color:var(--ink-3);
  display:block;
}
.phase ul{
  margin:0; padding:0;
  list-style:none;
  display:grid;
  gap:10px;
}
.phase ul li{
  font-size:.93rem;
  color:var(--ink-2);
  padding-left:18px;
  position:relative;
  line-height:1.5;
}
.phase ul li::before{
  content:"→";
  position:absolute;
  left:0; top:0;
  color:var(--amber-600);
  font-weight:600;
}

/* ============================================================
   COMPLIANCE
   ============================================================ */
.comp-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px;
  transition:transform .25s, box-shadow .25s;
}
.comp-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow-2); }
.comp-card h4{ margin-bottom:10px; }
.comp-card p{ margin:0; font-size:.95rem; color:var(--ink-2); line-height:1.55; }

/* ============================================================
   TEAM
   ============================================================ */
.team{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:28px;
}
@media (max-width:920px){ .team{ grid-template-columns:1fr; } }

.team-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:32px;
  box-shadow:var(--shadow-1);
  transition:transform .25s, box-shadow .25s, border-color .25s;
  display:flex; flex-direction:column;
  gap:22px;
}
.team-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-2);
  border-color:rgba(200,133,62,.35);
}
.team-card__hd{
  display:flex; gap:18px; align-items:flex-start;
}
.team-card__avatar{
  flex-shrink:0;
  width:64px; height:64px;
  border-radius:50%;
  background:linear-gradient(140deg, var(--green-900), var(--green-700));
  color:var(--amber-300);
  display:flex; align-items:center; justify-content:center;
  font-family:'Fraunces',serif;
  font-weight:500;
  font-size:1.4rem;
  letter-spacing:.02em;
  border:2px solid var(--amber-300);
  box-shadow:0 4px 12px rgba(14,59,46,.18);
}
.team-card__name{
  margin:0 0 4px;
  font-size:1.35rem;
}
.team-card__role{
  font-size:.92rem;
  color:var(--amber-600);
  font-weight:500;
  margin-bottom:6px;
  letter-spacing:.01em;
}
.team-card__loc{
  display:flex; align-items:center; gap:6px;
  font-size:.82rem;
  color:var(--ink-3);
}
.team-card__loc svg{ color:var(--amber-600); }
.team-card__bio{
  margin:0;
  font-size:.98rem;
  color:var(--ink-2);
  line-height:1.6;
}
.team-card__row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  padding:20px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
@media (max-width:520px){ .team-card__row{ grid-template-columns:1fr; gap:16px; } }
.team-card__col h5{
  font-family:'Inter',sans-serif;
  font-size:.7rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-3);
  margin:0 0 10px;
  font-weight:600;
}
.team-card__col ul{
  list-style:none; margin:0; padding:0;
  display:grid; gap:8px;
}
.team-card__col li{
  font-size:.86rem;
  line-height:1.5;
  color:var(--ink-2);
}
.team-card__col li strong{ color:var(--green-900); font-weight:600; }
.team-card__chips{
  list-style:none;
  margin:0; padding:0;
  display:flex; flex-wrap:wrap; gap:8px;
}
.team-card__chips li{
  font-size:.78rem;
  padding:6px 12px;
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:999px;
  color:var(--ink-2);
}

.team-band{
  margin-top:36px;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:0;
  background:linear-gradient(135deg, var(--green-900), var(--green-800));
  color:#fff;
  border-radius:var(--radius);
  overflow:hidden;
}
@media (max-width:780px){ .team-band{ grid-template-columns:1fr; } }
.team-band > div{
  padding:26px 28px;
  border-right:1px solid rgba(255,255,255,.08);
}
.team-band > div:last-child{ border-right:0; }
@media (max-width:780px){
  .team-band > div{ border-right:0; border-bottom:1px solid rgba(255,255,255,.08); }
  .team-band > div:last-child{ border-bottom:0; }
}
.team-band__lbl{
  display:block;
  font-size:.7rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--amber-300);
  margin-bottom:8px;
}
.team-band strong{
  display:block;
  font-family:'Fraunces',serif;
  font-size:1.5rem;
  font-weight:500;
  color:#fff;
  margin-bottom:6px;
  letter-spacing:-.01em;
}
.team-band p{
  margin:0;
  font-size:.88rem;
  color:rgba(255,255,255,.65);
  line-height:1.5;
}

/* ============================================================
   ASK
   ============================================================ */
.ask-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  margin-bottom:60px;
}
@media (max-width:820px){ .ask-grid{ grid-template-columns:1fr; gap:32px; } }
.ask-col h3{ margin-bottom:20px; font-size:1.3rem; }

.questions{
  border-top:1px solid rgba(255,255,255,.15);
  padding-top:48px;
}
.questions h3{ margin-bottom:24px; }
.q-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:16px;
}
@media (max-width:880px){ .q-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:600px){ .q-grid{ grid-template-columns:1fr; } }
.q{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius-sm);
  padding:20px;
  font-size:.95rem;
  color:rgba(255,255,255,.8);
  line-height:1.5;
  position:relative;
  transition:background .25s, border-color .25s;
}
.q:hover{ background:rgba(255,255,255,.07); border-color:rgba(232,201,148,.4); }
.q::before{
  content:"?";
  position:absolute;
  top:14px; right:18px;
  font-family:'Fraunces',serif;
  font-size:1.4rem;
  color:var(--amber-300);
  opacity:.4;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:#091F18;
  color:rgba(255,255,255,.65);
  padding-top:60px;
}
.footer__inner{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:48px;
  padding-bottom:50px;
}
@media (max-width:760px){ .footer__inner{ grid-template-columns:1fr; gap:30px; } }
.footer__logo{
  font-family:'Fraunces',serif;
  font-size:1.4rem;
  color:#fff;
  margin-bottom:10px;
}
.footer__logo em{ color:var(--amber-300); font-style:normal; }
.footer__brand p{ font-size:.9rem; color:rgba(255,255,255,.55); max-width:36ch; }
.footer__links{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:30px;
}
.footer__links h5{
  font-family:'Inter',sans-serif;
  font-size:.74rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--amber-300);
  margin:0 0 14px;
  font-weight:500;
}
.footer__links ul{
  list-style:none; margin:0; padding:0;
  display:grid; gap:8px;
  font-size:.88rem;
}
.footer__links a{
  color:rgba(255,255,255,.75);
  text-decoration:none;
  border-bottom:1px solid rgba(232,201,148,.3);
  transition:color .2s, border-color .2s;
}
.footer__links a:hover{
  color:var(--amber-300);
  border-color:var(--amber-300);
}
.footer__strip{
  border-top:1px solid rgba(255,255,255,.08);
  padding:18px 0;
  text-align:center;
  font-size:.78rem;
  color:rgba(255,255,255,.4);
  width:min(1180px, 92vw);
  margin:0 auto;
}

/* ============================================================
   reveal animations
   ============================================================ */
[data-reveal]{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .8s ease, transform .8s ease;
}
[data-reveal].is-visible{ opacity:1; transform:none; }

/* small-screen tweaks */
@media (max-width:600px){
  .hero{ padding:100px 0 60px; }
  .hero__ctas{ margin-bottom:50px; }
  .card,.card--wide{ padding:24px; }
  .calc{ padding:24px; }
}
