/* =========================================================
   Caring Bio Pharmaceuticals — Design System
   A luminous, champagne-and-ivory identity
   ========================================================= */

:root{
  /* Palette — light, luxurious */
  --alabaster:   #FBFAF6;
  --linen:       #F4F0E7;
  --pearl:       #FFFFFF;
  --mist:        #ECEDE7;
  --ink:         #1E2A2B;
  --slate:       #43514F;
  --muted:       #6E7B78;
  --gold:        #B58A3E;
  --gold-soft:   #CDA85E;
  --gold-pale:   #EBDDBE;
  --sage:        #7E9B90;
  --sage-pale:   #DCE7E1;
  --blush:       #E7C6BD;
  --blush-pale:  #F6E7E2;
  --line:        rgba(30,42,43,.12);
  --line-soft:   rgba(30,42,43,.07);

  /* Type */
  --serif: "Cormorant Garamond", Georgia, serif;
  --sans:  "Manrope", system-ui, -apple-system, sans-serif;

  /* Motion */
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);

  --maxw: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }

body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--alabaster);
  line-height:1.65;
  font-weight:400;
  overflow-x:hidden;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }

/* ---------- Typography ---------- */
.display{
  font-family:var(--serif);
  font-weight:500;
  line-height:1.02;
  letter-spacing:-.01em;
  font-size:clamp(2.8rem, 8vw, 6.6rem);
}
h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; line-height:1.08; letter-spacing:-.01em; }
h2{ font-size:clamp(2rem, 4.6vw, 3.6rem); }
h3{ font-size:clamp(1.4rem, 2.4vw, 2rem); }
.lede{ font-size:clamp(1.05rem,1.6vw,1.35rem); color:var(--slate); font-weight:300; }

.eyebrow{
  font-family:var(--sans);
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold);
  display:inline-flex;
  align-items:center;
  gap:.85em;
}
.eyebrow::before{
  content:"";
  width:34px; height:1px;
  background:linear-gradient(90deg,var(--gold),transparent);
}
.serif-accent{ font-family:var(--serif); font-style:italic; color:var(--gold); font-weight:500; }

/* ---------- Layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
section{ position:relative; }
.section-pad{ padding-block:clamp(72px, 11vw, 160px); }
.center{ text-align:center; }
.muted{ color:var(--muted); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.7em;
  font-size:.82rem; font-weight:600; letter-spacing:.06em;
  padding:1.05em 1.9em; border-radius:100px;
  position:relative; overflow:hidden;
  transition:transform .5s var(--ease-out), box-shadow .5s var(--ease), color .4s ease;
  will-change:transform;
}
.btn .arw{ transition:transform .45s var(--ease-out); }
.btn:hover .arw{ transform:translateX(5px); }
.btn-primary{
  background:linear-gradient(120deg,var(--ink),#2c3b3a);
  color:var(--alabaster);
  box-shadow:0 14px 30px -14px rgba(30,42,43,.6);
}
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 22px 40px -16px rgba(30,42,43,.55); }
.btn-gold{
  background:linear-gradient(120deg,var(--gold),var(--gold-soft));
  color:#fff;
  box-shadow:0 14px 30px -14px rgba(181,138,62,.7);
}
.btn-gold:hover{ transform:translateY(-3px); box-shadow:0 22px 44px -16px rgba(181,138,62,.6); }
.btn-ghost{ border:1px solid var(--line); color:var(--ink); background:rgba(255,255,255,.4); }
.btn-ghost:hover{ border-color:var(--gold); color:var(--gold); transform:translateY(-3px); }

/* ---------- Navigation ---------- */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:100;
  transition:background .5s var(--ease), backdrop-filter .5s, box-shadow .5s, padding .5s;
  padding-block:1.4rem;
}
.nav.scrolled{
  background:rgba(251,250,246,.82);
  backdrop-filter:saturate(140%) blur(18px);
  -webkit-backdrop-filter:saturate(140%) blur(18px);
  box-shadow:0 1px 0 var(--line-soft);
  padding-block:.85rem;
}
.nav-inner{ display:flex; align-items:center; justify-content:space-between; gap:2rem; }
.brand{ display:flex; align-items:center; gap:.7rem; z-index:2; }
.brand .mark{ width:34px; height:34px; flex:none; }
.brand .name{ font-family:var(--serif); font-size:1.32rem; font-weight:600; letter-spacing:-.01em; line-height:1; }
.brand .name small{ display:block; font-family:var(--sans); font-size:.56rem; letter-spacing:.34em; text-transform:uppercase; color:var(--gold); font-weight:600; margin-top:.32em; }

.nav-links{ display:flex; align-items:center; gap:.35rem; }
.nav-links a{
  font-size:.86rem; font-weight:500; color:var(--slate);
  padding:.55em 1.05em; border-radius:100px; position:relative;
  transition:color .35s ease, background .35s ease;
}
.nav-links a:hover{ color:var(--ink); }
.nav-links a.active{ color:var(--ink); }
.nav-links a.active::after{
  content:""; position:absolute; left:50%; bottom:.15em; transform:translateX(-50%);
  width:5px; height:5px; border-radius:50%; background:var(--gold);
}
.nav-cta{ margin-left:.6rem; }

.burger{ display:none; width:46px; height:46px; border-radius:50%; border:1px solid var(--line); position:relative; z-index:2; background:rgba(255,255,255,.5); }
.burger span{ position:absolute; left:13px; right:13px; height:1.6px; background:var(--ink); transition:transform .4s var(--ease), opacity .3s; }
.burger span:nth-child(1){ top:18px; }
.burger span:nth-child(2){ bottom:18px; }
.burger.open span:nth-child(1){ transform:translateY(4px) rotate(45deg); }
.burger.open span:nth-child(2){ transform:translateY(-4px) rotate(-45deg); }

/* ---------- Footer ---------- */
.footer{ background:var(--ink); color:#cfd6d3; padding-block:clamp(56px,8vw,96px) 2.2rem; position:relative; overflow:hidden; }
.footer::before{ content:""; position:absolute; inset:0; background:radial-gradient(120% 90% at 80% -10%, rgba(181,138,62,.18), transparent 60%); pointer-events:none; }
.footer .wrap{ position:relative; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:3rem; padding-bottom:3.5rem; border-bottom:1px solid rgba(255,255,255,.1); }
.footer h4{ color:#fff; font-size:1.05rem; margin-bottom:1.2rem; font-family:var(--sans); font-weight:600; letter-spacing:.02em; }
.footer .brand .name{ color:#fff; }
.footer p{ color:#9aa6a3; font-size:.92rem; max-width:34ch; }
.footer a{ color:#b6c0bd; font-size:.92rem; display:block; padding:.3em 0; transition:color .3s, transform .3s; width:fit-content; }
.footer a:hover{ color:var(--gold-soft); transform:translateX(4px); }
.footer-base{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem; padding-top:1.8rem; font-size:.8rem; color:#7e8a87; }

/* ---------- Hero ---------- */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden; }
#hero-canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:0; }
.hero-veil{ position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    radial-gradient(70% 60% at 78% 30%, rgba(235,221,190,.5), transparent 60%),
    radial-gradient(60% 70% at 10% 80%, rgba(220,231,225,.6), transparent 55%),
    linear-gradient(180deg, rgba(251,250,246,.2), rgba(251,250,246,.85));
}
.hero .wrap{ position:relative; z-index:2; width:100%; padding-top:7rem; }
.hero-content{ max-width:920px; }
.hero h1{ margin:1.4rem 0 1.6rem; }
.hero h1 .line{ display:block; overflow:hidden; }
.hero h1 .line > span{ display:block; }
.hero-sub{ max-width:46ch; margin-bottom:2.5rem; }
.hero-cta{ display:flex; gap:1rem; flex-wrap:wrap; align-items:center; }
.hero-hint{ position:absolute; bottom:2rem; left:50%; transform:translateX(-50%); z-index:2; font-size:.68rem; letter-spacing:.3em; text-transform:uppercase; color:var(--muted); display:flex; flex-direction:column; align-items:center; gap:.7rem; }
.hero-hint .dot{ width:1px; height:42px; background:linear-gradient(var(--gold),transparent); position:relative; overflow:hidden; }
.hero-hint .dot::after{ content:""; position:absolute; top:-50%; left:0; width:100%; height:50%; background:var(--ink); animation:drip 2.4s var(--ease) infinite; }
@keyframes drip{ 0%{ transform:translateY(-100%);} 60%,100%{ transform:translateY(300%);} }

/* floating stat chips on hero */
.hero-chips{ display:flex; gap:1.4rem; margin-top:3.2rem; flex-wrap:wrap; }
.chip{ background:rgba(255,255,255,.55); backdrop-filter:blur(10px); border:1px solid var(--line-soft); border-radius:18px; padding:1rem 1.4rem; box-shadow:0 18px 40px -28px rgba(30,42,43,.4); }
.chip .n{ font-family:var(--serif); font-size:1.9rem; font-weight:600; line-height:1; color:var(--ink); }
.chip .n .serif-accent{ font-size:1.3rem; }
.chip .l{ font-size:.72rem; letter-spacing:.04em; color:var(--muted); margin-top:.4rem; }

/* ---------- Marquee ---------- */
.marquee{ border-block:1px solid var(--line-soft); background:var(--linen); padding-block:1.5rem; overflow:hidden; }
.marquee-track{ display:flex; gap:4rem; width:max-content; animation:scrollx 32s linear infinite; align-items:center; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-track span{ font-family:var(--serif); font-style:italic; font-size:1.5rem; color:var(--slate); white-space:nowrap; display:inline-flex; align-items:center; gap:4rem; }
.marquee-track span::after{ content:"✦"; color:var(--gold); font-size:.7rem; font-style:normal; }
@keyframes scrollx{ to{ transform:translateX(-50%); } }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity 1s var(--ease-out), transform 1s var(--ease-out); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.1s; }
.reveal[data-d="2"]{ transition-delay:.2s; }
.reveal[data-d="3"]{ transition-delay:.3s; }
.reveal[data-d="4"]{ transition-delay:.4s; }
.reveal[data-d="5"]{ transition-delay:.5s; }

/* ---------- Generic cards ---------- */
.grid{ display:grid; gap:clamp(1.2rem,2.4vw,2rem); }
.g-2{ grid-template-columns:repeat(2,1fr); }
.g-3{ grid-template-columns:repeat(3,1fr); }
.g-4{ grid-template-columns:repeat(4,1fr); }

.card{
  background:var(--pearl);
  border:1px solid var(--line-soft);
  border-radius:22px;
  padding:clamp(1.6rem,2.6vw,2.4rem);
  position:relative; overflow:hidden;
  transition:transform .6s var(--ease-out), box-shadow .6s var(--ease), border-color .6s;
}
.card::after{ content:""; position:absolute; inset:0; border-radius:inherit; background:radial-gradient(120% 100% at 100% 0%, rgba(235,221,190,.4), transparent 55%); opacity:0; transition:opacity .6s; pointer-events:none; }
.card:hover{ transform:translateY(-8px); box-shadow:0 40px 70px -44px rgba(30,42,43,.4); border-color:var(--gold-pale); }
.card:hover::after{ opacity:1; }
.card .ic{ width:54px; height:54px; border-radius:15px; display:grid; place-items:center; background:var(--linen); margin-bottom:1.3rem; color:var(--gold); }
.card h3{ margin-bottom:.6rem; }
.card p{ color:var(--slate); font-size:.96rem; }
.card .idx{ font-family:var(--serif); font-style:italic; color:var(--gold-pale); font-size:1.4rem; position:absolute; top:1.4rem; right:1.6rem; }

/* ---------- Section heading block ---------- */
.head{ max-width:720px; margin-bottom:clamp(2.5rem,5vw,4.5rem); }
.head.center{ margin-inline:auto; }
.head .eyebrow{ margin-bottom:1.4rem; }
.head h2{ margin-bottom:1.1rem; }

/* ---------- Split feature ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
.split.rev .split-media{ order:-1; }
.split-media{ position:relative; border-radius:26px; overflow:hidden; aspect-ratio:4/4.4; background:linear-gradient(160deg,var(--sage-pale),var(--linen)); }

/* figure glass panels */
.glass-panel{ background:rgba(255,255,255,.6); backdrop-filter:blur(12px); border:1px solid rgba(255,255,255,.7); border-radius:20px; box-shadow:0 30px 60px -40px rgba(30,42,43,.45); }

/* ---------- Stats band ---------- */
.stats-band{ background:var(--ink); color:#e8ece9; border-radius:30px; padding:clamp(2.4rem,5vw,4rem); overflow:hidden; position:relative; }
.stats-band::before{ content:""; position:absolute; inset:0; background:radial-gradient(80% 120% at 90% 10%, rgba(181,138,62,.22), transparent 55%); }
.stats-band .grid{ position:relative; }
.stat .n{ font-family:var(--serif); font-size:clamp(2.6rem,5vw,4rem); font-weight:600; line-height:1; background:linear-gradient(120deg,#fff,var(--gold-pale)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.stat .l{ color:#9fb0ab; font-size:.86rem; margin-top:.7rem; max-width:24ch; }
.stat .n .serif-accent{ font-size:.7em; }

/* ---------- Timeline (About) ---------- */
.timeline{ position:relative; margin-top:2rem; }
.timeline::before{ content:""; position:absolute; left:9px; top:8px; bottom:8px; width:1px; background:linear-gradient(var(--gold-pale),var(--line),transparent); }
.tl-item{ position:relative; padding:0 0 clamp(2.4rem,5vw,3.6rem) clamp(2.4rem,5vw,3.4rem); }
.tl-item::before{ content:""; position:absolute; left:3px; top:6px; width:13px; height:13px; border-radius:50%; background:var(--alabaster); border:2px solid var(--gold); box-shadow:0 0 0 5px var(--alabaster); transition:transform .5s var(--ease), background .5s; }
.tl-item.in::before{ background:var(--gold); }
.tl-year{ font-family:var(--serif); font-style:italic; color:var(--gold); font-size:1.5rem; margin-bottom:.3rem; }
.tl-item h3{ font-size:1.35rem; margin-bottom:.6rem; }
.tl-item p{ color:var(--slate); max-width:62ch; }
.tl-item ul{ list-style:none; margin-top:.8rem; display:flex; flex-wrap:wrap; gap:.5rem; }
.tl-item li{ font-size:.82rem; padding:.4em .9em; border:1px solid var(--line); border-radius:100px; color:var(--slate); }

/* ---------- Director cards ---------- */
.director{ display:grid; grid-template-columns:auto 1fr; gap:clamp(1.4rem,3vw,2.6rem); align-items:start; }
.director .portrait{ width:clamp(120px,18vw,220px); aspect-ratio:3/3.7; border-radius:22px; background:linear-gradient(160deg,var(--gold-pale),var(--linen)); position:relative; overflow:hidden; display:grid; place-items:center; }
.director .portrait .mono{ font-family:var(--serif); font-size:clamp(3rem,6vw,5rem); color:var(--gold); opacity:.7; }
.director h3{ font-size:clamp(1.6rem,3vw,2.3rem); }
.director .role{ color:var(--gold); font-weight:600; font-size:.82rem; letter-spacing:.16em; text-transform:uppercase; margin:.4rem 0 1.2rem; }
.director p{ color:var(--slate); margin-bottom:1rem; font-size:.98rem; }
.quote{ border-left:2px solid var(--gold); padding:.4rem 0 .4rem 1.4rem; margin-top:1.4rem; font-family:var(--serif); font-style:italic; font-size:1.25rem; color:var(--ink); line-height:1.4; }
.quote cite{ display:block; font-style:normal; font-family:var(--sans); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-top:1rem; }

/* ---------- Pipeline (Services) ---------- */
.pipe{ display:grid; gap:1.2rem; }
.pipe-row{ background:var(--pearl); border:1px solid var(--line-soft); border-radius:20px; padding:clamp(1.4rem,2.6vw,2rem); transition:box-shadow .5s, border-color .5s, transform .5s var(--ease-out); }
.pipe-row:hover{ box-shadow:0 34px 60px -44px rgba(30,42,43,.4); border-color:var(--gold-pale); transform:translateY(-4px); }
.pipe-top{ display:flex; justify-content:space-between; align-items:baseline; gap:1rem; flex-wrap:wrap; margin-bottom:.3rem; }
.pipe-code{ font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); font-weight:600; }
.pipe-name{ font-family:var(--serif); font-size:1.5rem; font-weight:600; }
.pipe-ind{ color:var(--muted); font-size:.9rem; margin-bottom:1.4rem; }
.pipe-badge{ font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; font-weight:700; padding:.45em 1em; border-radius:100px; white-space:nowrap; }
.badge-rnd{ background:var(--sage-pale); color:#3c5a4f; }
.badge-fda{ background:linear-gradient(120deg,var(--gold),var(--gold-soft)); color:#fff; box-shadow:0 10px 24px -12px rgba(181,138,62,.7); }

.track{ display:grid; grid-template-columns:repeat(5,1fr); gap:.5rem; position:relative; }
.stage{ position:relative; }
.stage .bar{ height:7px; border-radius:100px; background:var(--mist); overflow:hidden; position:relative; }
.stage .bar .fill{ position:absolute; inset:0; width:0; border-radius:inherit; background:linear-gradient(90deg,var(--gold),var(--gold-soft)); transition:width 1.1s var(--ease-out); }
.stage.done .bar .fill{ width:100%; }
.stage.current .bar .fill{ width:60%; background:linear-gradient(90deg,var(--gold),var(--blush)); }
.pipe-row.fda .stage .bar .fill{ background:linear-gradient(90deg,var(--gold),var(--gold-soft)); }
.stage .lbl{ font-size:.66rem; letter-spacing:.04em; color:var(--muted); margin-top:.6rem; text-align:center; }
.stage.done .lbl, .stage.current .lbl{ color:var(--slate); font-weight:600; }
@media(max-width:620px){
  .track{ grid-template-columns:1fr 1fr; }
  .stage .lbl{ font-size:.6rem; }
}

/* legend */
.legend{ display:flex; gap:1.6rem; flex-wrap:wrap; font-size:.8rem; color:var(--muted); margin-top:1.8rem; }
.legend span{ display:inline-flex; align-items:center; gap:.5em; }
.legend i{ width:14px; height:8px; border-radius:4px; display:inline-block; }

/* ---------- White-label / MOQ ---------- */
.spec-list{ list-style:none; display:grid; gap:1px; background:var(--line-soft); border:1px solid var(--line-soft); border-radius:18px; overflow:hidden; }
.spec-list li{ background:var(--pearl); display:flex; justify-content:space-between; gap:1rem; padding:1.05rem 1.4rem; font-size:.94rem; }
.spec-list li span:first-child{ color:var(--muted); }
.spec-list li span:last-child{ font-weight:600; text-align:right; }

/* ---------- Mission / Focus page ---------- */
.focus-hero{ position:relative; min-height:78svh; display:flex; align-items:flex-end; overflow:hidden; background:linear-gradient(180deg,var(--blush-pale),var(--alabaster)); }
.focus-hero .orb{ position:absolute; border-radius:50%; filter:blur(2px); pointer-events:none; }
.value-card{ padding:2rem; border-radius:22px; background:var(--pearl); border:1px solid var(--line-soft); transition:transform .6s var(--ease-out), box-shadow .6s; }
.value-card:hover{ transform:translateY(-6px); box-shadow:0 40px 70px -48px rgba(30,42,43,.4); }
.value-card .k{ font-family:var(--serif); font-style:italic; color:var(--gold); font-size:1.1rem; }
.value-card h3{ margin:.5rem 0 .6rem; font-size:1.35rem; }
.value-card p{ color:var(--slate); font-size:.94rem; }

/* ---------- Contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(2rem,5vw,4.5rem); align-items:start; }
.field{ position:relative; margin-bottom:1.6rem; }
.field input, .field textarea, .field select{
  width:100%; font-family:inherit; font-size:1rem; color:var(--ink);
  background:transparent; border:none; border-bottom:1px solid var(--line);
  padding:.9rem 0; transition:border-color .4s;
}
.field textarea{ resize:vertical; min-height:120px; }
.field label{ position:absolute; left:0; top:.9rem; color:var(--muted); pointer-events:none; transition:.35s var(--ease); font-size:1rem; }
.field input:focus, .field textarea:focus, .field select:focus{ outline:none; border-color:var(--gold); }
.field input:focus + label, .field input:not(:placeholder-shown) + label,
.field textarea:focus + label, .field textarea:not(:placeholder-shown) + label{
  top:-.8rem; font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold);
}
.field select{ border:1px solid var(--line); border-radius:12px; padding:.9rem 1rem; }
.info-card{ padding:2rem; border-radius:22px; }
.info-row{ display:flex; gap:1rem; padding:1.2rem 0; border-bottom:1px solid var(--line-soft); }
.info-row:last-child{ border-bottom:none; }
.info-row .ic{ width:44px; height:44px; border-radius:12px; background:var(--linen); color:var(--gold); display:grid; place-items:center; flex:none; }
.info-row .t{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.info-row .v{ font-size:1.02rem; color:var(--ink); margin-top:.2rem; }
.form-note{ font-size:.8rem; color:var(--muted); margin-top:1rem; }

.map-wrap{ border-radius:22px; overflow:hidden; border:1px solid var(--line-soft); aspect-ratio:16/7; background:var(--linen); position:relative; }
.map-wrap iframe{ width:100%; height:100%; border:0; filter:grayscale(.3) contrast(1.02) brightness(1.03); }

/* ---------- Page hero (interior) ---------- */
.page-hero{ padding-top:clamp(9rem,16vw,12rem); padding-bottom:clamp(2.5rem,5vw,4rem); position:relative; overflow:hidden; }
.page-hero::before{ content:""; position:absolute; inset:0; background:radial-gradient(60% 80% at 85% 0%, rgba(235,221,190,.45), transparent 60%); pointer-events:none; }
.page-hero .wrap{ position:relative; }
.page-hero h1{ font-size:clamp(2.6rem,7vw,5.2rem); margin:1.2rem 0 1.2rem; max-width:16ch; }
.crumb{ font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }

/* ---------- CTA band ---------- */
.cta-band{ position:relative; border-radius:30px; overflow:hidden; padding:clamp(2.6rem,6vw,5rem); text-align:center; background:linear-gradient(140deg,var(--linen),var(--sage-pale)); }
.cta-band::before{ content:""; position:absolute; inset:0; background:radial-gradient(60% 100% at 50% 0%, rgba(235,221,190,.6), transparent 60%); }
.cta-band > *{ position:relative; }
.cta-band h2{ max-width:18ch; margin:0 auto 1.2rem; }

/* ---------- Custom cursor (desktop) ---------- */
.cursor-dot, .cursor-ring{ position:fixed; top:0; left:0; border-radius:50%; pointer-events:none; z-index:9999; mix-blend-mode:multiply; }
.cursor-dot{ width:7px; height:7px; background:var(--gold); transform:translate(-50%,-50%); }
.cursor-ring{ width:38px; height:38px; border:1px solid var(--gold); transform:translate(-50%,-50%); transition:width .3s, height .3s, background .3s, border-color .3s; }
.cursor-ring.hot{ width:60px; height:60px; background:rgba(181,138,62,.08); border-color:transparent; }
@media(hover:none){ .cursor-dot,.cursor-ring{ display:none !important; } }

/* ---------- Responsive ---------- */
@media(max-width:960px){
  .g-4{ grid-template-columns:repeat(2,1fr); }
  .g-3{ grid-template-columns:repeat(2,1fr); }
  .split{ grid-template-columns:1fr; }
  .split.rev .split-media{ order:0; }
  .director{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:2rem; }
}
@media(max-width:760px){
  .nav-links{
    position:fixed; inset:0; flex-direction:column; justify-content:center; gap:1.4rem;
    background:rgba(251,250,246,.97); backdrop-filter:blur(20px);
    transform:translateY(-100%); transition:transform .6s var(--ease); pointer-events:none;
  }
  .nav-links.open{ transform:translateY(0); pointer-events:auto; }
  .nav-links a{ font-size:1.5rem; font-family:var(--serif); color:var(--ink); }
  .nav-links .nav-cta{ margin:1rem 0 0; }
  .burger{ display:block; }
  .g-2,.g-3,.g-4{ grid-template-columns:1fr; }
  .stats-band .grid{ grid-template-columns:1fr 1fr; gap:2rem; }
  .footer-grid{ grid-template-columns:1fr; }
  .hero-chips{ gap:.8rem; }
  .chip{ flex:1 1 40%; }
}
@media(prefers-reduced-motion:reduce){
  *{ animation:none !important; transition-duration:.001s !important; }
  .reveal{ opacity:1; transform:none; }
}
