/* ============================================================
   SUGARHILL RECORDING STUDIOS — shared stylesheet
   Branding: the live SPLASH look. Warm near-black field, gold +
   cream, Fraunces serif with Space Mono labels, gold hairlines,
   soft grain + vignette, the gold script logo with a glow.
   Quiet, editorial, minimal. One file skins the whole site.
   ============================================================ */

:root{
  --bg:#0b0907;
  --surface:#15110c;
  --surface-2:#1d1710;
  --gold:#c9a24e;
  --gold-bright:#dcb45f;
  --cream:#f4ecda;
  --dim:#8a7d67;
  --dimmer:#6a5f4d;

  --line:rgba(201,162,78,0.20);
  --line-soft:rgba(244,236,218,0.10);

  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --mono:"Space Mono",ui-monospace,monospace;

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

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; background:var(--bg); color:var(--cream);
  font-family:var(--serif); font-size:clamp(16px,1.05vw,18px);
  line-height:1.66; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden; position:relative;
}
/* grain + vignette overlays (from the splash) */
body::before{ content:""; 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='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
body::after{ content:""; position:fixed; inset:0; z-index:1; pointer-events:none;
  background:radial-gradient(125% 100% at 50% 0%,transparent 60%,rgba(0,0,0,0.55) 100%); }
body > *{ position:relative; z-index:2; }

a{ color:inherit; }
img{ display:block; max-width:100%; }
::selection{ background:var(--gold); color:var(--bg); }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding-left:var(--gutter); padding-right:var(--gutter); }
.wrap-narrow{ max-width:780px; }

/* ---- type atoms ---- */
.serif{ font-family:var(--serif); }
.mono{ font-family:var(--mono); text-transform:uppercase; letter-spacing:0.28em; font-size:0.7rem; color:var(--gold); }
.mono-sm{ font-family:var(--mono); text-transform:uppercase; letter-spacing:0.24em; font-size:0.62rem; color:var(--dim); }
.eyebrow{ font-family:var(--mono); text-transform:uppercase; letter-spacing:0.34em; font-size:0.7rem; color:var(--gold); display:block; }
em.gd{ font-style:italic; color:var(--gold); }
em.it{ font-style:italic; color:var(--cream); }
.rule{ width:58px; height:1px; background:var(--gold); opacity:.55; border:0; margin:0; }
.rule-wide{ width:100%; height:1px; background:var(--line); border:0; margin:0; }

h1,h2,h3,h4{ font-weight:400; font-family:var(--serif); letter-spacing:-0.01em; }
.h1{ font-size:clamp(2.4rem,6vw,4.6rem); line-height:1.04; font-weight:400; }
.h2{ font-size:clamp(1.9rem,4vw,3.1rem); line-height:1.08; font-weight:400; }
.h3{ font-size:clamp(1.3rem,2.2vw,1.8rem); line-height:1.2; font-weight:600; }
.lede{ font-size:clamp(1.1rem,1.5vw,1.32rem); line-height:1.55; color:var(--cream); font-weight:400; max-width:60ch; }
.lede em{ font-style:italic; color:var(--gold); }

.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0; }
.skip{ position:absolute; left:-9999px; top:0; background:var(--gold); color:var(--bg); padding:12px 18px; z-index:200; font-family:var(--mono); font-size:0.7rem; letter-spacing:0.12em; }
.skip:focus{ left:12px; top:12px; }
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{ outline:2px solid var(--gold); outline-offset:3px; }

/* ============================================================
   NAV
   ============================================================ */
header.nav{ position:sticky; top:0; z-index:100; background:rgba(11,9,7,0.86); -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px); border-bottom:1px solid var(--line); }
.nav-inner{ display:flex; align-items:center; justify-content:space-between; gap:24px; padding-top:16px; padding-bottom:16px; }
.nav-mark{ display:flex; align-items:center; gap:12px; text-decoration:none; }
.nav-mark img{ height:30px; width:auto; filter:drop-shadow(0 0 16px rgba(201,162,78,0.28)); }
.nav-mark .nm-text{ font-family:var(--mono); font-size:0.58rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--dim); }
.nav-links{ display:flex; gap:clamp(14px,2vw,30px); align-items:center; font-family:var(--mono); text-transform:uppercase; letter-spacing:0.16em; font-size:0.66rem; }
.nav-links > a, .has-sub > a{ text-decoration:none; color:var(--cream); opacity:0.74; transition:opacity .15s,color .15s; white-space:nowrap; }
.nav-links > a:hover, .has-sub > a:hover, .nav-links a[aria-current="page"]{ opacity:1; color:var(--gold); }
.nav-cta{ border:1px solid var(--gold); color:var(--gold) !important; border-radius:999px; padding:9px 18px; opacity:1 !important; transition:background .15s,color .15s; }
.nav-cta:hover{ background:var(--gold); color:var(--bg) !important; }
.nav-toggle{ display:none; font-family:var(--mono); text-transform:uppercase; letter-spacing:0.16em; font-size:0.66rem; background:transparent; border:1px solid var(--line); color:var(--cream); padding:9px 14px; border-radius:999px; cursor:pointer; }

.has-sub{ position:relative; }
.has-sub > a::after{ content:" ▾"; opacity:0.55; }
.subnav{ position:absolute; top:100%; left:0; min-width:220px; background:var(--surface); border:1px solid var(--line); border-radius:10px; padding:8px 0; display:flex; flex-direction:column; opacity:0; visibility:hidden; transform:translateY(6px); transition:opacity .15s,transform .15s,visibility .15s; z-index:120; }
.has-sub:hover .subnav, .has-sub:focus-within .subnav{ opacity:1; visibility:visible; transform:none; }
.subnav a{ text-decoration:none; color:var(--cream); opacity:0.8; padding:9px 20px; letter-spacing:0.14em; }
.subnav a:hover, .subnav a[aria-current="page"]{ opacity:1; color:var(--gold); }

@media (max-width:980px){
  .nav-toggle{ display:inline-block; }
  .nav-links{ position:absolute; top:100%; left:0; right:0; background:var(--bg); border-bottom:1px solid var(--line); flex-direction:column; align-items:stretch; gap:0; padding:6px 0; display:none; }
  .nav-links.open{ display:flex; }
  .nav-links > a, .has-sub > a{ padding:13px var(--gutter); opacity:0.9; border-top:1px solid var(--line-soft); }
  .nav-cta{ border:0; border-radius:0; border-top:1px solid var(--line-soft) !important; }
  .has-sub{ display:flex; flex-direction:column; }
  .subnav{ position:static; opacity:1; visibility:visible; transform:none; border:0; border-radius:0; padding:0 0 6px; background:transparent; }
  .subnav a{ padding:10px var(--gutter) 10px calc(var(--gutter) + 18px); font-size:0.62rem; }
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{ display:inline-flex; align-items:center; gap:9px; font-family:var(--mono); text-transform:uppercase; letter-spacing:0.18em; font-size:0.7rem; padding:13px 26px; text-decoration:none; border:1px solid var(--gold); color:var(--gold); background:transparent; border-radius:999px; cursor:pointer; transition:background .18s,color .18s,transform .12s; }
.btn:hover{ transform:translateY(-2px); }
.btn-solid{ background:var(--gold); color:var(--bg); }
.btn-solid:hover{ background:var(--gold-bright); color:var(--bg); }
.btn-ghost{ border-color:var(--line); color:var(--cream); }
.btn-ghost:hover{ border-color:var(--gold); color:var(--gold); }

/* ============================================================
   PAGE HERO + breadcrumb
   ============================================================ */
.page-hero{ border-bottom:1px solid var(--line); }
.page-hero .wrap{ padding-top:clamp(40px,6vw,84px); padding-bottom:clamp(40px,6vw,80px); }
.crumb{ display:flex; gap:10px; align-items:center; font-family:var(--mono); text-transform:uppercase; letter-spacing:0.18em; font-size:0.6rem; color:var(--dimmer); margin-bottom:clamp(22px,3vw,34px); }
.crumb a{ color:var(--dim); text-decoration:none; }
.crumb a:hover{ color:var(--gold); }
.crumb .sep{ color:var(--gold); opacity:.6; }
.page-hero h1{ font-family:var(--serif); font-weight:400; font-size:clamp(2.4rem,6.5vw,5rem); line-height:1.03; margin:14px 0 0; max-width:18ch; }
.page-hero .lede{ margin-top:clamp(20px,2.5vw,30px); }
.page-hero .rule{ margin:clamp(22px,3vw,30px) 0; }
.page-hero .hero-actions{ margin-top:clamp(22px,3vw,30px); display:flex; gap:14px; flex-wrap:wrap; }

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
section{ position:relative; }
.sec-pad{ padding-top:clamp(58px,8vw,116px); padding-bottom:clamp(58px,8vw,116px); }
.sec-pad-sm{ padding-top:clamp(40px,5vw,70px); padding-bottom:clamp(40px,5vw,70px); }
.on-ink{ background:var(--surface); }      /* subtle banding; whole site is dark */
.tint{ background:linear-gradient(180deg,var(--surface),var(--bg)); }
.sec-head{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:8px 24px; align-items:baseline; border-bottom:1px solid var(--line); padding-bottom:14px; margin-bottom:clamp(34px,5vw,58px); font-family:var(--mono); text-transform:uppercase; letter-spacing:0.22em; font-size:0.62rem; color:var(--dim); }
.sec-head .idx{ color:var(--gold); }
.sec-head .ref{ color:var(--dimmer); }

.prose p{ color:var(--cream); opacity:0.86; font-size:1.06rem; line-height:1.74; max-width:62ch; margin:0; }
.prose p + p{ margin-top:1.15em; }
.prose strong{ color:var(--cream); opacity:1; font-weight:600; }
.prose em{ font-style:italic; color:var(--gold); }
.lead-2{ display:grid; grid-template-columns:6fr 5fr; gap:clamp(28px,5vw,80px); align-items:start; margin-bottom:clamp(34px,5vw,56px); }
.lead-2 h2{ margin:0; }
@media (max-width:760px){ .lead-2{ grid-template-columns:1fr; gap:18px; } }

/* scroll reveal */
.js [data-reveal]{ opacity:0; transform:translateY(16px); transition:opacity .7s ease var(--d,0s),transform .7s ease var(--d,0s); }
.js [data-reveal].in{ opacity:1; transform:none; }

/* ============================================================
   CARD GRID (services hub, home teasers, related)
   ============================================================ */
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(14px,1.6vw,20px); }
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(14px,1.6vw,20px); }
@media (max-width:900px){ .grid-3{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .grid-3,.grid-2{ grid-template-columns:1fr; } }

.card{ display:flex; flex-direction:column; text-decoration:none; color:var(--cream); background:var(--surface); border:1px solid var(--line); border-radius:12px; padding:clamp(22px,2.6vw,32px); min-height:196px; transition:transform .2s,border-color .2s,background .2s; }
.card:hover{ transform:translateY(-4px); border-color:var(--gold); background:var(--surface-2); }
.card .num{ font-family:var(--mono); font-size:0.6rem; letter-spacing:0.18em; color:var(--gold); }
.card h3{ font-family:var(--serif); font-weight:600; font-size:clamp(1.3rem,2vw,1.7rem); line-height:1.1; margin:.55rem 0 .45rem; }
.card p{ margin:0; font-size:0.98rem; line-height:1.6; color:var(--cream); opacity:0.78; flex:1; }
.card .go{ margin-top:1.2rem; font-family:var(--mono); font-size:0.62rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--gold); }
.card .go::after{ content:" →"; }

/* ============================================================
   SERVICE PAGE blocks
   ============================================================ */
.svc-split{ display:grid; grid-template-columns:6fr 6fr; gap:clamp(30px,5vw,80px); align-items:start; }
@media (max-width:860px){ .svc-split{ grid-template-columns:1fr; gap:26px; } }
.svc-photo{ border:1px solid var(--line); border-radius:12px; overflow:hidden; }
.svc-photo img{ width:100%; aspect-ratio:4/3.2; object-fit:cover; filter:grayscale(0.25) sepia(0.28) brightness(0.82) contrast(1.02); }
.checklist{ list-style:none; margin:0; padding:0; border-top:1px solid var(--line); }
.checklist li{ padding:15px 0 15px 30px; border-bottom:1px solid var(--line-soft); position:relative; font-size:1.02rem; color:var(--cream); opacity:0.86; }
.checklist li::before{ content:"✦"; position:absolute; left:0; top:15px; color:var(--gold); }
.deflist{ border-top:1px solid var(--line); margin:0; }
.deflist > div{ display:flex; justify-content:space-between; gap:18px; align-items:baseline; padding:15px 0; border-bottom:1px solid var(--line-soft); }
.deflist dt{ font-family:var(--mono); font-size:0.62rem; letter-spacing:0.14em; text-transform:uppercase; color:var(--dim); margin:0; }
.deflist dd{ margin:0; font-family:var(--serif); font-size:1.18rem; text-align:right; color:var(--cream); }

/* ============================================================
   STUDIOS detail
   ============================================================ */
.studio{ border-top:1px solid var(--line); padding-top:clamp(30px,4vw,52px); }
.studio + .studio{ margin-top:clamp(50px,7vw,96px); }
.studio-head{ display:flex; flex-wrap:wrap; align-items:baseline; justify-content:space-between; gap:10px 24px; margin-bottom:clamp(22px,3vw,34px); }
.studio-head h2{ font-family:var(--serif); font-weight:400; font-size:clamp(2rem,4.5vw,3.4rem); line-height:1.02; margin:0; }
.studio-head h2 em{ font-style:italic; color:var(--gold); }
.studio-head .tag{ font-family:var(--mono); font-size:0.6rem; letter-spacing:0.16em; text-transform:uppercase; border:1px solid var(--line); border-radius:999px; padding:7px 14px; color:var(--gold); }
.studio-grid{ display:grid; grid-template-columns:7fr 5fr; gap:clamp(26px,4vw,56px); align-items:start; }
@media (max-width:900px){ .studio-grid{ grid-template-columns:1fr; } }
.studio-photo{ border:1px solid var(--line); border-radius:12px; overflow:hidden; }
.studio-photo img{ width:100%; aspect-ratio:16/10; object-fit:cover; filter:grayscale(0.25) sepia(0.28) brightness(0.82) contrast(1.02); }

/* ============================================================
   EQUIPMENT
   ============================================================ */
.eqcat{ border-top:1px solid var(--line); padding:clamp(24px,3vw,38px) 0; display:grid; grid-template-columns:minmax(180px,260px) 1fr; column-gap:clamp(20px,3vw,52px); row-gap:14px; align-items:start; }
.eqcat > h2{ grid-column:1; grid-row:1 / span 99; align-self:start; position:sticky; top:96px; font-family:var(--serif); font-weight:400; font-size:clamp(1.5rem,3vw,2.3rem); line-height:1.05; margin:0; }
.eqcat > h2 em{ font-style:italic; color:var(--gold); }
.eqcat > *:not(h2){ grid-column:2; }
.eqcat .eqcat-note{ font-family:var(--mono); font-size:0.6rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--dim); margin:0; }
.gearlist{ list-style:none; margin:0; padding:0; }
.gearlist li{ display:flex; justify-content:space-between; gap:18px; align-items:baseline; padding:13px 0; border-bottom:1px solid var(--line-soft); font-size:1.04rem; }
.gearlist li .g-name{ color:var(--cream); }
.gearlist li .g-meta{ font-family:var(--mono); font-size:0.6rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--dim); text-align:right; white-space:nowrap; }
@media (max-width:760px){
  .eqcat{ grid-template-columns:1fr; row-gap:12px; }
  .eqcat > h2{ grid-column:1; grid-row:auto; position:static; }
  .eqcat > *:not(h2){ grid-column:1; }
}

/* ============================================================
   ENGINEERS (placeholder cards)
   ============================================================ */
.eng-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(14px,1.6vw,20px); }
@media (max-width:860px){ .eng-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .eng-grid{ grid-template-columns:1fr; } }
.eng-card{ border:1px solid var(--line); border-radius:12px; background:var(--surface); overflow:hidden; }
.eng-photo{ aspect-ratio:1/1; background:radial-gradient(circle at 50% 38%,rgba(201,162,78,0.10),transparent 60%),var(--surface-2); border-bottom:1px solid var(--line); display:flex; align-items:center; justify-content:center; }
.eng-photo span{ font-family:var(--mono); font-size:0.56rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--dimmer); }
.eng-card .eng-body{ padding:20px 22px 24px; }
.eng-card h3{ font-family:var(--serif); font-weight:400; font-size:1.5rem; line-height:1.1; margin:0 0 7px; }
.eng-card .role{ font-family:var(--mono); font-size:0.6rem; letter-spacing:0.14em; text-transform:uppercase; color:var(--gold); }

/* ============================================================
   TIMELINE LEDGER (About)
   ============================================================ */
.ledger{ border-top:1px solid var(--line); }
.ledger-row{ display:grid; grid-template-columns:54px minmax(110px,170px) 1fr minmax(110px,160px); gap:clamp(14px,2.5vw,40px); align-items:baseline; padding:clamp(20px,2.4vw,30px) 0; border-bottom:1px solid var(--line-soft); transition:background .2s,padding-left .25s; }
.ledger-row:hover{ background:rgba(201,162,78,0.04); padding-left:clamp(6px,1vw,16px); }
.ledger-row .no{ font-family:var(--mono); font-size:0.6rem; letter-spacing:0.14em; color:var(--dimmer); }
.ledger-row .yr{ font-family:var(--serif); font-style:italic; font-size:clamp(1.8rem,3.6vw,2.9rem); line-height:1; color:var(--gold); margin:0; }
.ledger-row .what h3{ font-family:var(--serif); font-weight:600; font-size:1.2rem; line-height:1.1; margin:0 0 8px; }
.ledger-row .what p{ margin:0; font-size:0.97rem; line-height:1.6; color:var(--cream); opacity:0.78; max-width:58ch; }
.ledger-row .tag{ font-family:var(--mono); font-size:0.56rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--dim); justify-self:end; align-self:center; white-space:nowrap; }
@media (max-width:860px){
  .ledger-row{ grid-template-columns:40px 1fr; grid-template-rows:auto auto; row-gap:10px; }
  .ledger-row .what{ grid-column:2; } .ledger-row .tag{ grid-column:2; justify-self:start; }
}

/* ============================================================
   ROSTER (About) — elegant serif, not poster
   ============================================================ */
.roster{ border-top:1px solid var(--line); }
.roster-row{ display:flex; align-items:baseline; gap:clamp(14px,3vw,40px); padding:clamp(14px,1.8vw,20px) 0; border-bottom:1px solid var(--line-soft); flex-wrap:wrap; transition:padding-left .25s,color .2s; }
.roster-row:hover{ padding-left:clamp(8px,1.5vw,22px); }
.roster-no{ font-family:var(--mono); font-size:0.58rem; letter-spacing:0.16em; color:var(--dimmer); flex:0 0 34px; }
.roster-name{ font-family:var(--serif); font-weight:400; font-size:clamp(1.5rem,3.4vw,2.6rem); line-height:1.1; margin:0; flex:1 1 auto; color:var(--cream); }
.roster-row:hover .roster-name{ color:var(--gold); }
.roster-meta{ font-family:var(--mono); text-transform:uppercase; letter-spacing:0.12em; font-size:0.62rem; color:var(--dim); text-align:right; white-space:nowrap; flex:0 0 auto; }

/* ============================================================
   CONTACT + MAP
   ============================================================ */
.contact-grid{ display:grid; grid-template-columns:5fr 6fr; gap:clamp(32px,6vw,80px); align-items:start; }
@media (max-width:900px){ .contact-grid{ grid-template-columns:1fr; } }
.contact-meta{ margin-top:30px; border-top:1px solid var(--line); }
.contact-line{ display:block; border-bottom:1px solid var(--line-soft); padding:17px 0; text-decoration:none; transition:padding-left .2s; }
a.contact-line:hover{ padding-left:10px; }
a.contact-line:hover .big{ color:var(--gold); }
.contact-line .mono-sm{ color:var(--gold); display:block; margin-bottom:7px; }
.contact-line .big{ font-family:var(--serif); font-size:clamp(1.2rem,2.2vw,1.7rem); line-height:1.1; color:var(--cream); transition:color .15s; overflow-wrap:anywhere; }
.map-embed{ border:1px solid var(--line); border-radius:12px; overflow:hidden; }
.map-embed iframe{ display:block; width:100%; height:clamp(300px,42vw,460px); border:0; filter:invert(0.9) hue-rotate(180deg) brightness(0.95) contrast(0.92) saturate(0.7); }

/* booking sheet form */
form.sheet{ background:var(--surface); border:1px solid var(--line); border-radius:14px; padding:clamp(26px,3vw,42px); }
.sheet-head{ display:flex; justify-content:space-between; align-items:baseline; gap:14px; border-bottom:1px solid var(--line); padding-bottom:16px; margin-bottom:26px; }
.sheet-head .t{ font-family:var(--serif); font-size:1.5rem; }
.sheet-head .n{ font-family:var(--mono); font-size:0.6rem; letter-spacing:0.12em; color:var(--gold); }
.field{ margin-bottom:22px; }
.field label{ display:block; font-family:var(--mono); text-transform:uppercase; letter-spacing:0.12em; font-size:0.6rem; margin-bottom:9px; color:var(--dim); }
.field input,.field textarea,.field select{ width:100%; font-family:var(--serif); font-size:1rem; padding:11px 2px; border:0; border-bottom:1px solid var(--line); background:transparent; color:var(--cream); border-radius:0; transition:border-color .15s; }
.field input:hover,.field textarea:hover,.field select:hover,.field input:focus,.field textarea:focus,.field select:focus{ border-bottom-color:var(--gold); }
.field textarea{ min-height:110px; resize:vertical; }
.field input::placeholder,.field textarea::placeholder{ color:var(--dimmer); }
.field select option{ background:var(--surface); color:var(--cream); }
.sheet-2{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
button.submit{ width:100%; font-family:var(--mono); text-transform:uppercase; letter-spacing:0.16em; font-size:0.78rem; padding:16px; background:var(--gold); color:var(--bg); border:1px solid var(--gold); border-radius:999px; cursor:pointer; transition:background .15s; }
button.submit:hover{ background:var(--gold-bright); }
.sheet-fine{ margin-top:14px; font-family:var(--mono); font-size:0.56rem; letter-spacing:0.06em; color:var(--dimmer); text-align:center; }
@media (max-width:900px){ .sheet-2{ grid-template-columns:1fr; gap:0; } }

/* policy blocks */
.policy{ border-top:1px solid var(--line); }
.policy > div{ padding:clamp(20px,2.4vw,28px) 0; border-bottom:1px solid var(--line-soft); display:grid; grid-template-columns:minmax(160px,230px) 1fr; gap:clamp(18px,3vw,46px); align-items:start; }
@media (max-width:720px){ .policy > div{ grid-template-columns:1fr; gap:8px; } }
.policy h3{ font-family:var(--serif); font-weight:600; font-size:1.25rem; line-height:1.1; margin:0; }
.policy p{ margin:0; font-size:0.99rem; line-height:1.65; color:var(--cream); opacity:0.82; max-width:60ch; }

/* ============================================================
   "NEEDS FROM RICKY" flag
   ============================================================ */
.needs{ display:block; border:1px dashed var(--gold); background:rgba(201,162,78,0.07); color:var(--gold-bright); padding:13px 16px; margin:16px 0; font-family:var(--mono); font-size:0.64rem; letter-spacing:0.04em; line-height:1.6; text-transform:none; border-radius:8px; }
.needs::before{ content:"◆ NEEDS FROM RICKY — "; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; color:var(--gold); }

/* ============================================================
   FOOTER
   ============================================================ */
footer.foot{ border-top:1px solid var(--line); padding-top:clamp(56px,7vw,90px); padding-bottom:44px; background:var(--bg); }
.foot-top{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:36px; align-items:start; }
.foot-logo{ width:190px; max-width:60%; height:auto; margin-bottom:20px; filter:drop-shadow(0 0 22px rgba(201,162,78,0.18)); }
.foot-brand p{ color:var(--dim); max-width:36ch; font-size:0.92rem; line-height:1.6; margin:0; }
.foot-col h4{ font-family:var(--mono); text-transform:uppercase; letter-spacing:0.16em; font-size:0.62rem; color:var(--gold); margin:0 0 16px; }
.foot-col a{ display:block; text-decoration:none; color:var(--cream); opacity:0.78; padding:6px 0; font-size:0.94rem; transition:color .15s,opacity .15s; }
.foot-col a:hover{ color:var(--gold); opacity:1; }
.foot-rule{ height:1px; background:var(--line); margin:clamp(38px,5vw,62px) 0 26px; }
.foot-bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:14px; font-family:var(--mono); font-size:0.6rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--dimmer); }
.foot-bottom a{ color:var(--dim); text-decoration:none; }
.foot-bottom a:hover{ color:var(--gold); }
@media (max-width:860px){ .foot-top{ grid-template-columns:1fr 1fr; } .foot-brand{ grid-column:1 / -1; } }

/* review pills (gated preview only) */
.review-pills{ position:fixed; bottom:18px; left:18px; z-index:9999; display:flex; gap:8px; font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; }
.review-pills a{ color:#f4ecda; background:rgba(11,9,7,.82); border:1px solid var(--line); border-radius:999px; padding:7px 13px; text-decoration:none; -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px); }
.review-pills a:hover{ border-color:var(--gold); color:var(--gold); }

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *{ animation:none !important; transition:none !important; }
  .js [data-reveal]{ opacity:1 !important; transform:none !important; }
}
