/* ============================================================
   galaxyweb.agency v2 — shared stylesheet
   Design system per DESIGN.md. Three adjectives: stellar, honest, sharp.
   Dark cosmic bands (hero + footer only) · light body everywhere else.
   Boldness spent in ONE place: the hero node graph.
   ============================================================ */

/* ---------- 1. Tokens (DESIGN.md §3) ---------- */
:root{
  --ink:        #0B0C10;   /* dark bands, text on light */
  --ink-2:      #15171E;   /* raised dark surfaces */
  --ink-3:      #1E212B;   /* darker card on dark */
  --paper:      #FFFFFF;
  --wash:       #F5F7FA;   /* alt light band */
  --line:       #E4E8EF;   /* hairline on light */
  --line-dark:  rgba(255,255,255,.10); /* hairline on dark */

  --cyan:       #30BFD9;   /* primary accent */
  --cyan-bright:#62FFFF;   /* glow cores — hero only */
  --cyan-ink:   #147A8C;   /* AA-safe cyan for text on light */
  --magenta:    #D353AD;   /* gradient partner, sparing */
  --magenta-ink:#B23A8E;   /* AA-safe magenta for text on light */
  --peach:      #FFBC7D;   /* rare warm highlight */
  --grad:       linear-gradient(90deg, var(--cyan), var(--magenta));

  /* Text tones */
  --t-1:  #0B0C10;         /* strongest ink */
  --t-2:  #3B404C;         /* body on light */
  --t-3:  #626879;         /* muted / captions */
  --on-dark-1: #FFFFFF;
  --on-dark-2: rgba(255,255,255,.74);
  --on-dark-3: rgba(255,255,255,.52);

  /* Type families (DESIGN.md §2) */
  --display: "Unbounded", "Sora", "Trebuchet MS", system-ui, sans-serif;
  --body:    "DM Sans", "Helvetica Neue", Arial, sans-serif;
  --mono:    "DM Mono", ui-monospace, "SF Mono", Menlo, monospace;

  /* Fluid modular scale (Paul Daffey clamp pattern). Body base 17–18px. */
  --step--1: clamp(0.82rem, 0.80rem + 0.10vw, 0.88rem);
  --step-0:  clamp(1.0625rem, 1.02rem + 0.20vw, 1.125rem);  /* body 17–18 */
  --step-1:  clamp(1.2rem, 1.10rem + 0.45vw, 1.5rem);
  --step-2:  clamp(1.55rem, 1.30rem + 1.10vw, 2.3rem);
  --step-3:  clamp(2rem, 1.55rem + 2.0vw, 3.2rem);
  --step-4:  clamp(2.5rem, 1.85rem + 3.2vw, 4.6rem);
  --step-5:  clamp(2.9rem, 1.9rem + 5.0vw, 6rem);

  /* Spacing (4/8) */
  --s-1: 4px;  --s-2: 8px;  --s-3: 12px; --s-4: 16px;
  --s-5: 24px; --s-6: 32px; --s-7: 48px; --s-8: 64px;
  --s-9: 96px; --s-10: 128px;

  /* Layout */
  --wrap: 1200px;
  --measure: 62ch;
  --radius:   12px;
  --radius-sm: 10px;
  --radius-lg: 16px;

  /* Motion */
  --ease:      cubic-bezier(.22,.61,.36,1);
  --ease-soft: cubic-bezier(.33,.86,.45,1);
  --dur: .55s;
}

/* ---------- 2. Reset / base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--paper);
  color:var(--t-2);
  font-family:var(--body);
  font-size:var(--step-0);
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{ max-width:100%; display:block; }

::selection{ background:var(--cyan); color:var(--ink); }

:focus-visible{
  outline:2.5px solid var(--cyan-ink);
  outline-offset:3px;
  border-radius:3px;
}
/* focus on dark bands */
.band-dark :focus-visible{ outline-color:var(--cyan-bright); }

/* ---------- 3. Typography ---------- */
h1,h2,h3,h4{
  font-family:var(--display);
  font-weight:600;
  line-height:1.05;
  margin:0;
  color:var(--t-1);
  letter-spacing:-0.01em;
  text-wrap:balance;
}
.band-dark h1,.band-dark h2,.band-dark h3,.band-dark h4{ color:var(--on-dark-1); }
h2{ font-size:var(--step-3); }
h3{ font-size:var(--step-1); }

p{ margin:0 0 1.1em; }
p:last-child{ margin-bottom:0; }

a{ color:var(--cyan-ink); text-decoration:none; }
strong,b{ font-weight:600; color:inherit; }

/* Eyebrow — uppercase mono-ish label, .14em tracking (DESIGN.md §2) */
.eyebrow{
  font-family:var(--mono);
  font-size:var(--step--1);
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--cyan-ink);
  margin:0 0 var(--s-5);
  display:inline-flex; align-items:center; gap:.8em;
}
.eyebrow::before{
  content:""; width:26px; height:2px; border-radius:2px;
  background:var(--grad); display:inline-block;
}
.band-dark .eyebrow{ color:var(--cyan); }

/* Inline animated-underline link */
.link{
  color:var(--cyan-ink);
  background-image:linear-gradient(var(--cyan),var(--cyan));
  background-size:0% 1.5px; background-repeat:no-repeat; background-position:0 100%;
  transition:background-size .4s var(--ease);
  padding-bottom:1px;
}
.link:hover,.link:focus-visible{ background-size:100% 1.5px; }
.band-dark .link{ color:var(--cyan); background-image:linear-gradient(var(--cyan),var(--cyan)); }

/* gradient text accent, used very sparingly */
.grad-text{
  background:var(--grad);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* ---------- 4. Layout primitives ---------- */
.wrap{ width:min(100% - 2*var(--s-5), var(--wrap)); margin-inline:auto; }
@media (max-width:600px){ .wrap{ width:min(100% - 2*var(--s-4), var(--wrap)); } }
.section{ padding-block:clamp(var(--s-8), 9vw, var(--s-10)); }
.measure{ max-width:var(--measure); }
.wash{ background:var(--wash); }
.rule{ border:0; border-top:1px solid var(--line); margin:0; }

/* dark band scaffold */
.band-dark{
  background:var(--ink);
  color:var(--on-dark-2);
  position:relative;
  overflow:hidden;
}
.band-dark p{ color:var(--on-dark-2); }
/* faint starfield + nebula wash on dark bands */
.band-dark::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(60% 50% at 78% 12%, rgba(211,83,173,.10), transparent 60%),
    radial-gradient(70% 60% at 12% 92%, rgba(48,191,217,.12), transparent 62%);
}
.band-dark > *{ position:relative; z-index:1; }

/* skip link */
.skip-link{
  position:absolute; left:-999px; top:0; z-index:200;
  background:var(--ink); color:#fff;
  padding:.7em 1.1em; border-radius:0 0 var(--radius-sm) 0;
  font-family:var(--mono); font-size:.9rem;
}
.skip-link:focus{ left:0; }

/* ---------- 5. Buttons ---------- */
.btn{
  --btn-bg:var(--cyan); --btn-fg:var(--ink);
  display:inline-flex; align-items:center; gap:.55em;
  font-family:var(--display);
  font-weight:600; font-size:var(--step--1);
  letter-spacing:.01em; line-height:1;
  padding:1em 1.5em;
  border-radius:999px;
  border:1px solid transparent;
  background:var(--btn-bg); color:var(--btn-fg);
  cursor:pointer;
  transition:transform .25s var(--ease), box-shadow .3s var(--ease),
             background-color .3s var(--ease), border-color .3s var(--ease), color .3s var(--ease);
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 12px 30px -10px rgba(48,191,217,.55); }
.btn:active{ transform:translateY(0); }
.btn .ic{ width:1.05em; height:1.05em; }
.btn-lg{ font-size:var(--step-0); padding:1.1em 1.9em; }

/* gradient primary (the one loud button per view) */
.btn-grad{ background:var(--grad); color:#fff; }
.btn-grad:hover{ box-shadow:0 14px 34px -10px rgba(211,83,173,.5); }

/* ghost — outline */
.btn-ghost{ background:transparent; color:var(--t-1); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--cyan-ink); color:var(--cyan-ink); box-shadow:none; }
.band-dark .btn-ghost{ color:#fff; border-color:var(--line-dark); }
.band-dark .btn-ghost:hover{ border-color:var(--cyan); color:var(--cyan); }

/* ---------- 6. Header ---------- */
.site-header{
  position:sticky; top:0; z-index:60;
  background:color-mix(in srgb, var(--ink) 80%, transparent);
  -webkit-backdrop-filter:blur(12px) saturate(1.2);
  backdrop-filter:blur(12px) saturate(1.2);
  border-bottom:1px solid transparent;
  transition:border-color .4s var(--ease), background-color .4s var(--ease);
}
.site-header.is-stuck{
  border-bottom-color:var(--line-dark);
  background:color-mix(in srgb, var(--ink) 92%, transparent);
}
.site-header .wrap{
  display:flex; align-items:center; justify-content:space-between;
  gap:var(--s-5); padding-block:var(--s-4);
}
.brand{ display:inline-flex; align-items:center; gap:.6em; color:#fff; text-decoration:none; }
.brand img{ width:34px; height:34px; flex:0 0 auto; }
.brand .bn{
  font-family:var(--display); font-weight:700;
  font-size:1.06rem; letter-spacing:-0.01em; color:#fff;
}
.brand .bn b{ font-weight:700; }
.brand .bn span{ color:var(--cyan); }

.nav{ display:flex; align-items:center; gap:var(--s-6); }
.nav a{
  font-family:var(--body); font-size:.98rem; font-weight:500;
  color:var(--on-dark-2); position:relative;
  transition:color .3s var(--ease);
}
.nav a::after{
  content:""; position:absolute; left:0; right:100%; bottom:-6px;
  height:2px; border-radius:2px; background:var(--grad);
  transition:right .35s var(--ease);
}
.nav a:hover{ color:#fff; }
.nav a:hover::after,.nav a[aria-current="page"]::after{ right:0; }
.nav a[aria-current="page"]{ color:#fff; }
.nav .cta{
  font-family:var(--display); font-weight:600; font-size:.92rem;
  color:var(--ink); background:var(--cyan);
  padding:.62em 1.15em; border-radius:999px;
  transition:transform .25s var(--ease), box-shadow .3s var(--ease);
}
.nav .cta::after{ display:none; }
.nav .cta:hover{ color:var(--ink); transform:translateY(-2px); box-shadow:0 10px 24px -8px rgba(48,191,217,.6); }

.menu-btn{
  display:none;
  font-family:var(--mono); font-size:.82rem; letter-spacing:.08em; text-transform:uppercase;
  background:transparent; border:1px solid var(--line-dark);
  border-radius:999px; padding:.55em 1.1em; color:#fff; cursor:pointer;
}
@media (max-width:900px){
  .menu-btn{ display:inline-block; }
  .nav{
    position:fixed; inset:0 0 0 auto; width:min(84vw,340px);
    flex-direction:column; align-items:flex-start; justify-content:flex-start;
    gap:var(--s-5);
    background:var(--ink-2);
    border-left:1px solid var(--line-dark);
    padding:92px var(--s-6) var(--s-6);
    transform:translateX(100%);
    transition:transform .45s var(--ease);
    box-shadow:-30px 0 60px rgba(0,0,0,.5);
  }
  .nav.open{ transform:translateX(0); }
  .nav a{ font-size:1.3rem; font-family:var(--display); font-weight:600; }
  .nav .cta{ font-size:1.05rem; margin-top:var(--s-3); }
  body.nav-open{ overflow:hidden; }
}

/* ---------- 7. Footer ---------- */
.site-footer{
  background:var(--ink); color:var(--on-dark-2);
  padding-block:var(--s-9) var(--s-6);
  position:relative; overflow:hidden;
}
.site-footer::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(70% 60% at 85% 0%, rgba(48,191,217,.10), transparent 60%);
}
.site-footer .wrap{ position:relative; z-index:1; }
.site-footer a{ color:var(--on-dark-2); }
.site-footer .cols{
  display:grid; grid-template-columns:1.5fr 1fr 1.3fr;
  gap:var(--s-7); padding-bottom:var(--s-8);
  border-bottom:1px solid var(--line-dark);
}
.site-footer .brand{ margin-bottom:var(--s-4); }
.site-footer .blurb{ color:var(--on-dark-3); max-width:34ch; font-size:.98rem; line-height:1.6; }
.site-footer h4{
  font-family:var(--mono); font-size:.78rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--cyan); margin:0 0 var(--s-4);
}
.site-footer .fnav{ display:flex; flex-direction:column; gap:.7em; }
.site-footer .fnav a{ color:var(--on-dark-2); font-size:1rem; width:max-content; transition:color .3s var(--ease); }
.site-footer .fnav a:hover{ color:var(--cyan); }
.site-footer .legal{
  padding-top:var(--s-6); color:var(--on-dark-3); font-size:.85rem;
  display:flex; flex-wrap:wrap; gap:.4em 1.2em; align-items:center;
}
.site-footer .legal a{ color:var(--on-dark-3); }
.site-footer .legal a:hover{ color:var(--cyan); }
@media (max-width:760px){ .site-footer .cols{ grid-template-columns:1fr; gap:var(--s-6); } }

/* ---------- 8. Scroll reveal ---------- */
.reveal{
  opacity:0; transform:translateY(22px);
  transition:opacity var(--dur) var(--ease-soft), transform var(--dur) var(--ease-soft);
}
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }
.reveal[data-d="4"]{ transition-delay:.32s; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1 !important; transform:none !important; transition:none; }
}

/* ============================================================
   9. HERO (dark) + the signature node graph
   ============================================================ */
.hero{
  background:var(--ink);
  color:var(--on-dark-2);
  position:relative; overflow:hidden;
  padding-block:clamp(var(--s-8), 10vw, 140px) clamp(var(--s-8), 9vw, 120px);
}
/* deep-space atmosphere */
.hero::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(50% 45% at 72% 30%, rgba(211,83,173,.14), transparent 62%),
    radial-gradient(55% 55% at 20% 78%, rgba(48,191,217,.16), transparent 60%),
    radial-gradient(120% 120% at 50% 0%, rgba(21,23,30,.0), var(--ink) 70%);
}
.hero .wrap{ position:relative; z-index:2; }
.hero__grid{
  display:grid; grid-template-columns:1.05fr .95fr;
  gap:clamp(var(--s-6), 5vw, 72px); align-items:center;
}
.hero__title{
  font-size:var(--step-5);
  font-weight:700; line-height:1.0;
  letter-spacing:-0.02em;
  color:#fff; margin:0 0 var(--s-5);
}
.hero__title .grad-text{ font-weight:700; }
.hero__sub{
  font-size:var(--step-1); line-height:1.5;
  color:var(--on-dark-2); margin:0 0 var(--s-6); max-width:46ch;
}
.hero__proof{
  font-family:var(--mono); font-size:var(--step--1); letter-spacing:.04em;
  color:var(--on-dark-3); margin:var(--s-6) 0 0;
  padding-top:var(--s-5); border-top:1px solid var(--line-dark);
}
.hero__proof b{ color:var(--cyan); font-weight:500; }

/* rotating engine pill sentence */
.pill-line{
  font-family:var(--display); font-weight:600;
  font-size:var(--step-1); line-height:1.35; color:#fff;
  margin:0 0 var(--s-6); display:flex; flex-wrap:wrap; align-items:center; gap:.4em .1em;
}
.engine-pill{
  display:inline-flex; align-items:center; gap:.5em;
  height:1.9em; padding:0 .85em; border-radius:999px;
  background:var(--ink-2); border:1px solid var(--line-dark);
  vertical-align:middle; position:relative; overflow:hidden;
  min-width:8.4em; justify-content:center;
  box-shadow:inset 0 0 0 1px rgba(48,191,217,.08);
}
.engine-pill__item{
  display:inline-flex; align-items:center; gap:.5em;
  position:absolute; inset:0; justify-content:center;
  opacity:0; transform:translateY(60%);
  transition:opacity .5s var(--ease), transform .5s var(--ease);
  font-family:var(--display); font-weight:600; font-size:.86em; color:#fff;
  white-space:nowrap;
}
.engine-pill__item.is-active{ opacity:1; transform:translateY(0); }
.engine-pill__item.is-leave{ opacity:0; transform:translateY(-60%); }
.engine-pill__item svg,.engine-pill__item img{ width:1.15em; height:1.15em; flex:0 0 auto; }
.engine-pill__item svg{ display:block; }
@media (prefers-reduced-motion: reduce){
  .engine-pill__item{ transition:none; }
}

/* hero form */
.audit-form{
  background:var(--ink-2);
  border:1px solid var(--line-dark);
  border-radius:var(--radius-lg);
  padding:clamp(var(--s-5), 3vw, 34px);
  box-shadow:0 40px 80px -40px rgba(0,0,0,.7), 0 0 0 1px rgba(48,191,217,.06);
}
.audit-form__head{ margin-bottom:var(--s-5); }
.audit-form__title{
  font-family:var(--display); font-weight:600; font-size:var(--step-1);
  color:#fff; margin:0 0 var(--s-2); line-height:1.15;
}
.audit-form__note{ font-size:.92rem; color:var(--on-dark-3); margin:0; }
.audit-form .row{ display:grid; grid-template-columns:1fr 1fr; gap:var(--s-3); }
.field{ margin-bottom:var(--s-3); }
.field label{
  display:block; margin-bottom:6px;
  font-family:var(--mono); font-size:.72rem; letter-spacing:.08em; text-transform:uppercase;
  color:var(--on-dark-2);
}
.field input,.field select,.field textarea{
  width:100%; font-family:var(--body); font-size:1rem; color:#fff;
  background:var(--ink-3);
  border:1px solid var(--line-dark); border-radius:var(--radius-sm);
  padding:.72em .85em; line-height:1.4;
  transition:border-color .3s var(--ease), box-shadow .3s var(--ease);
}
.field select{ appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2362FFFF' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right .9em center; padding-right:2.2em;
}
.field input::placeholder,.field textarea::placeholder{ color:var(--on-dark-3); }
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none; border-color:var(--cyan);
  box-shadow:0 0 0 3px rgba(48,191,217,.22);
}
.audit-form .btn{ width:100%; justify-content:center; margin-top:var(--s-2); }
.audit-form__fine{ margin-top:var(--s-4); font-size:.82rem; color:var(--on-dark-3); text-align:center; }
.hp{ position:absolute; left:-9999px; opacity:0; height:0; width:0; }
.form-status{ margin:var(--s-4) 0 0; font-size:.92rem; color:var(--cyan); text-align:center; min-height:1.2em; }
.form-status.err{ color:var(--peach); }

/* ---- The node graph ---- */
.graph{
  position:relative; width:100%; aspect-ratio:1/1;
  max-width:560px; margin-inline:auto;
}
.graph svg{ width:100%; height:100%; overflow:visible; }
.graph__ring{ fill:none; stroke:var(--line-dark); }
.graph__link{
  fill:none; stroke:url(#gwGrad); stroke-width:1.4;
  opacity:.55;
  stroke-dasharray:4 5;
  animation:linkFlow 3.2s linear infinite;
}
@keyframes linkFlow{ to{ stroke-dashoffset:-18; } }
.graph__node{ cursor:pointer; }
.graph__node circle{
  fill:var(--ink-2); stroke:var(--cyan); stroke-width:1.4;
  transition:transform .3s var(--ease), fill .3s var(--ease);
  transform-box:fill-box; transform-origin:center;
}
.graph__node:hover circle{ fill:var(--ink-3); transform:scale(1.12); }
.graph__node text{
  font-family:var(--display); font-weight:600; font-size:12px;
  fill:#fff; text-anchor:middle; dominant-baseline:middle;
  pointer-events:none;
}
.graph__node .glow{ fill:var(--cyan); opacity:.14; }
.graph__hub circle{ fill:var(--ink-2); stroke:url(#gwGrad); stroke-width:2; }
.graph__hub .hub-glow{ fill:var(--cyan); opacity:.10; }
.graph__sat{ fill:var(--on-dark-3); font-family:var(--mono); font-size:8.5px; opacity:.7; }
.graph__dot{ fill:var(--cyan); opacity:.5; }
/* slow drift on the whole constellation */
.graph__drift{ animation:drift 24s ease-in-out infinite; transform-origin:center; }
@keyframes drift{
  0%,100%{ transform:translate(0,0); }
  50%{ transform:translate(0,-1.4%); }
}
.graph__orbit-a{ animation:orbFloatA 20s ease-in-out infinite; transform-box:fill-box; transform-origin:center; }
.graph__orbit-b{ animation:orbFloatB 26s ease-in-out infinite; transform-box:fill-box; transform-origin:center; }
@keyframes orbFloatA{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-6px); } }
@keyframes orbFloatB{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(6px); } }
.graph__hub-img{ transform-box:fill-box; transform-origin:center; }
@media (prefers-reduced-motion: reduce){
  .graph__link{ animation:none; stroke-dasharray:none; }
  .graph__drift,.graph__orbit-a,.graph__orbit-b{ animation:none; }
}

@media (max-width:940px){
  .hero__grid{ grid-template-columns:1fr; gap:var(--s-7); }
  .hero__media{ order:-1; }
  .graph{ max-width:440px; }
}
@media (max-width:560px){
  .audit-form .row{ grid-template-columns:1fr; }
  .hero__cta .btn{ width:100%; justify-content:center; }
  /* on small screens the graph is static (JS also removes drift) */
  .graph{ max-width:340px; }
}

/* ============================================================
   10. Proof band — client site mockups
   ============================================================ */
.proof__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:var(--s-5); flex-wrap:wrap; margin-bottom:clamp(var(--s-6),5vw,var(--s-8)); }
.proof__head h2{ font-size:var(--step-2); max-width:20ch; }
.proof__grid{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:clamp(var(--s-4), 3vw, var(--s-6));
}
.client{
  border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; background:var(--wash);
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
}
.client:hover{ transform:translateY(-4px); box-shadow:0 24px 50px -26px rgba(11,12,16,.28); border-color:#d6dbe6; }
.client__shot{ aspect-ratio:16/10; overflow:hidden; background:#0e1016; }
.client__shot img{ width:100%; height:100%; object-fit:cover; object-position:top center; }
.client__body{ padding:var(--s-4) var(--s-5) var(--s-5); display:flex; align-items:center; justify-content:space-between; gap:var(--s-3); }
.client__name{ font-family:var(--display); font-weight:600; font-size:1.02rem; color:var(--t-1); }
.client__trade{ display:block; font-family:var(--mono); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase; color:var(--t-3); margin-top:3px; }
.client__arrow{ flex:0 0 auto; width:34px; height:34px; border-radius:50%; border:1px solid var(--line); display:grid; place-items:center; color:var(--cyan-ink); transition:background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease); }
.client:hover .client__arrow{ background:var(--cyan); color:var(--ink); border-color:var(--cyan); }
@media (max-width:860px){ .proof__grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .proof__grid{ grid-template-columns:1fr; } }

/* ============================================================
   11. Services
   ============================================================ */
.svc__head{ max-width:34ch; margin-bottom:clamp(var(--s-7),6vw,var(--s-9)); }
.svc__head h2{ font-size:var(--step-3); }
.svcs{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.svc{
  background:var(--paper); padding:clamp(var(--s-6),4vw,var(--s-8));
  display:flex; flex-direction:column; gap:var(--s-3);
  position:relative; transition:background .35s var(--ease);
}
.svc:hover{ background:var(--wash); }
.svc__n{ font-family:var(--mono); font-size:.78rem; letter-spacing:.12em; color:var(--t-3); }
.svc h3{ font-size:var(--step-1); display:flex; align-items:center; gap:.5em; }
.svc__flag{
  font-family:var(--mono); font-size:.64rem; letter-spacing:.1em; text-transform:uppercase;
  color:#fff; background:var(--grad); padding:.32em .7em; border-radius:999px; font-weight:500;
}
.svc p{ color:var(--t-2); margin:0; font-size:1rem; }
.svc__link{
  margin-top:auto; padding-top:var(--s-4);
  font-family:var(--display); font-weight:600; font-size:.95rem;
  color:var(--cyan-ink); display:inline-flex; align-items:center; gap:.45em;
}
.svc__link .ic{ width:1em; height:1em; transition:transform .3s var(--ease); }
.svc:hover .svc__link .ic{ transform:translateX(4px); }
.svc--flagship{ background:linear-gradient(180deg, rgba(48,191,217,.06), rgba(211,83,173,.05)); }
.svc--flagship:hover{ background:linear-gradient(180deg, rgba(48,191,217,.10), rgba(211,83,173,.08)); }
@media (max-width:720px){ .svcs{ grid-template-columns:1fr; } }

/* ============================================================
   12. Session transcript window (audit report component language)
   ============================================================ */
.session{
  border:1px solid var(--line-dark); border-radius:14px; overflow:hidden;
  background:var(--ink-2);
  box-shadow:0 30px 70px -40px rgba(0,0,0,.8);
  max-width:640px;
}
.band-light .session{ border-color:var(--line); background:var(--paper); box-shadow:0 24px 60px -34px rgba(11,12,16,.22); }
.session__chrome{
  display:flex; align-items:center; gap:12px; padding:12px 16px;
  background:var(--ink-3); color:#fff; border-bottom:1px solid var(--line-dark);
}
.session__dots{ display:flex; gap:6px; }
.session__dots i{ width:11px; height:11px; border-radius:50%; display:block; }
.session__dots i:nth-child(1){ background:#FF5F57; }
.session__dots i:nth-child(2){ background:#FEBC2E; }
.session__dots i:nth-child(3){ background:#28C840; }
.session__who{ display:flex; align-items:center; gap:9px; font-family:var(--display); font-weight:600; font-size:.86rem; color:#fff; }
.session__who svg,.session__who img{ width:18px; height:18px; }
.session__who small{ font-family:var(--mono); font-weight:400; color:var(--on-dark-3); font-size:.7rem; letter-spacing:.04em; }
.session__body{ display:flex; flex-direction:column; gap:12px; padding:18px 16px; }
.bubble{ max-width:88%; padding:12px 15px; border-radius:16px; font-size:.92rem; line-height:1.5; }
.bubble.user{ align-self:flex-end; background:var(--cyan); color:var(--ink); border-bottom-right-radius:4px; font-weight:500; }
.bubble.ai{ align-self:flex-start; background:var(--ink-3); color:var(--on-dark-1); border:1px solid var(--line-dark); border-bottom-left-radius:4px; white-space:pre-wrap; }
.bubble.ai mark{ background:rgba(211,83,173,.24); color:#fff; padding:.05em .3em; border-radius:4px; }
.session__cap{ font-family:var(--mono); font-size:.74rem; color:var(--on-dark-3); margin:0; padding:0 16px 16px; letter-spacing:.02em; }
/* verdict chip */
.verdict-chip{
  display:inline-flex; align-items:center; gap:.5em;
  font-family:var(--mono); font-size:.76rem; letter-spacing:.08em; text-transform:uppercase;
  background:rgba(211,83,173,.14); color:var(--peach);
  border:1px solid rgba(211,83,173,.3); padding:.4em .8em; border-radius:999px;
}
.verdict-chip b{ color:#fff; }

/* AI-gap band layout */
.gap__grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(var(--s-6),5vw,72px); align-items:center; }
.gap__copy h2{ font-size:var(--step-3); margin-bottom:var(--s-5); }
.gap__stat{
  display:flex; align-items:baseline; gap:.4em; margin:var(--s-6) 0;
  font-family:var(--display);
}
.gap__stat b{ font-size:clamp(2.6rem,1.8rem+3vw,4rem); font-weight:700; color:var(--cyan); line-height:1; }
.gap__stat span{ font-size:1rem; color:var(--on-dark-2); font-family:var(--body); max-width:22ch; }
@media (max-width:900px){ .gap__grid{ grid-template-columns:1fr; gap:var(--s-7); } .session{ max-width:100%; } }

/* ============================================================
   13. Testimonials
   ============================================================ */
.testis__head{ text-align:center; max-width:24ch; margin:0 auto clamp(var(--s-7),5vw,var(--s-8)); }
.testis__head h2{ font-size:var(--step-2); }
.testis{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(var(--s-4),3vw,var(--s-6)); }
.testi{
  border:1px solid var(--line); border-radius:var(--radius);
  padding:clamp(var(--s-5),3vw,var(--s-6)); background:var(--paper);
  display:flex; flex-direction:column;
}
.testi__mark{ width:30px; height:24px; margin-bottom:var(--s-4); }
.testi__mark path{ fill:url(#gwGradFlat); }
.testi p{ color:var(--t-2); font-size:1rem; line-height:1.6; margin:0 0 var(--s-5); }
.testi__who{ display:flex; align-items:center; gap:var(--s-3); margin-top:auto; padding-top:var(--s-4); border-top:1px solid var(--line); }
.testi__av{ width:44px; height:44px; border-radius:50%; overflow:hidden; flex:0 0 auto; background:var(--wash); }
.testi__av img{ width:100%; height:100%; object-fit:cover; }
.testi__av--initials{ display:grid; place-items:center; background:var(--ink); color:var(--cyan); font-family:var(--display); font-weight:600; font-size:1rem; }
.testi__name{ font-family:var(--display); font-weight:600; font-size:.98rem; color:var(--t-1); }
.testi__role{ display:block; font-family:var(--mono); font-size:.72rem; letter-spacing:.04em; color:var(--t-3); margin-top:2px; }
@media (max-width:860px){ .testis{ grid-template-columns:1fr; max-width:560px; margin-inline:auto; } }

/* ============================================================
   14. Final CTA band (gradient RULE, not wash)
   ============================================================ */
.endcta{ background:var(--ink); color:var(--on-dark-2); position:relative; overflow:hidden; padding-block:clamp(var(--s-8),8vw,120px); }
.endcta::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(60% 80% at 50% 120%, rgba(48,191,217,.16), transparent 60%),
            radial-gradient(50% 60% at 80% -10%, rgba(211,83,173,.12), transparent 60%);
}
.endcta__rule{ height:3px; background:var(--grad); border:0; margin:0 0 clamp(var(--s-7),5vw,var(--s-8)); border-radius:3px; position:relative; z-index:1; }
.endcta .wrap{ position:relative; z-index:1; }
.endcta__inner{ display:flex; align-items:center; justify-content:space-between; gap:var(--s-6) var(--s-7); flex-wrap:wrap; }
.endcta__lead{ font-family:var(--display); font-weight:600; font-size:var(--step-2); line-height:1.14; color:#fff; max-width:20ch; margin:0; }
.endcta__lead span{ color:var(--cyan); }
.endcta__sub{ font-size:1rem; color:var(--on-dark-2); margin:var(--s-3) 0 0; max-width:40ch; }
@media (max-width:720px){ .endcta__inner{ flex-direction:column; align-items:flex-start; } .endcta .btn{ width:100%; justify-content:center; } }

/* ============================================================
   15. Inner-page hero (GEO / contact / privacy)
   ============================================================ */
.page-hero{ background:var(--ink); color:var(--on-dark-2); position:relative; overflow:hidden; padding-block:clamp(var(--s-8),9vw,130px) clamp(var(--s-7),6vw,84px); }
.page-hero::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(55% 55% at 20% 30%, rgba(48,191,217,.16), transparent 60%),
            radial-gradient(50% 50% at 85% 90%, rgba(211,83,173,.12), transparent 60%);
}
.page-hero .wrap{ position:relative; z-index:2; }
.page-hero__grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(var(--s-6),5vw,72px); align-items:start; }
.page-hero__title{ font-size:var(--step-4); font-weight:700; line-height:1.02; letter-spacing:-0.02em; color:#fff; margin:0 0 var(--s-5); }
.page-hero__intro{ font-size:var(--step-1); line-height:1.5; color:var(--on-dark-2); margin:0; max-width:46ch; }
.page-hero--slim .page-hero__grid{ display:block; }
.page-hero--slim .page-hero__inner{ max-width:40ch; }
@media (max-width:940px){ .page-hero__grid{ grid-template-columns:1fr; gap:var(--s-7); } }

/* ============================================================
   16. GEO — problem / steps / checklist / honesty / FAQ
   ============================================================ */
/* problem */
.problem__grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(var(--s-6),5vw,72px); align-items:center; }
.problem__copy h2{ font-size:var(--step-3); margin-bottom:var(--s-5); }
.problem__list{ list-style:none; margin:var(--s-6) 0 0; padding:0; display:flex; flex-direction:column; gap:var(--s-4); }
.problem__list li{ display:flex; gap:var(--s-3); align-items:flex-start; color:var(--t-2); }
.problem__list .num{ flex:0 0 auto; width:26px; height:26px; border-radius:50%; background:var(--wash); border:1px solid var(--line); display:grid; place-items:center; font-family:var(--mono); font-size:.78rem; color:var(--cyan-ink); }
@media (max-width:900px){ .problem__grid{ grid-template-columns:1fr; gap:var(--s-7); } }

/* pricing steps */
.steps__head{ text-align:center; max-width:32ch; margin:0 auto clamp(var(--s-7),5vw,var(--s-8)); }
.steps__head h2{ font-size:var(--step-3); }
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s-5); align-items:stretch; }
.pcard{
  border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:clamp(var(--s-5),3vw,var(--s-6)); background:var(--paper);
  display:flex; flex-direction:column; position:relative;
}
.pcard--feature{ border-color:transparent; background:var(--ink); color:var(--on-dark-2); box-shadow:0 30px 70px -40px rgba(11,12,16,.5); }
.pcard--feature::before{ content:""; position:absolute; inset:0; border-radius:var(--radius-lg); padding:1.5px; background:var(--grad); -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none; }
.pcard__step{ font-family:var(--mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--t-3); margin-bottom:var(--s-3); }
.pcard--feature .pcard__step{ color:var(--cyan); }
.pcard__name{ font-family:var(--display); font-weight:600; font-size:var(--step-1); color:var(--t-1); margin:0 0 var(--s-2); }
.pcard--feature .pcard__name{ color:#fff; }
.pcard__price{ font-family:var(--display); font-weight:700; font-size:clamp(1.9rem,1.4rem+2vw,2.6rem); color:var(--t-1); line-height:1; margin:var(--s-3) 0 var(--s-2); letter-spacing:-0.01em; }
.pcard--free .pcard__price{ background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.pcard--feature .pcard__price{ color:#fff; }
.pcard__price small{ font-size:.9rem; font-weight:500; color:var(--t-3); font-family:var(--body); }
.pcard--feature .pcard__price small{ color:var(--on-dark-3); }
.pcard__desc{ font-size:.98rem; color:var(--t-2); margin:0 0 var(--s-5); }
.pcard--feature .pcard__desc{ color:var(--on-dark-2); }
.pcard__list{ list-style:none; margin:0 0 var(--s-6); padding:0; display:flex; flex-direction:column; gap:var(--s-3); }
.pcard__list li{ display:flex; gap:.6em; align-items:flex-start; font-size:.94rem; color:var(--t-2); }
.pcard--feature .pcard__list li{ color:var(--on-dark-2); }
.pcard__list .tick{ flex:0 0 auto; color:var(--cyan-ink); font-weight:700; }
.pcard--feature .pcard__list .tick{ color:var(--cyan); }
.pcard__cancel{ font-family:var(--mono); font-size:.74rem; letter-spacing:.04em; color:var(--cyan-ink); margin:0 0 var(--s-5); }
.pcard--feature .pcard__cancel{ color:var(--cyan); }
.pcard .btn{ margin-top:auto; width:100%; justify-content:center; }
.pcard__turnaround{ font-family:var(--mono); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase; color:var(--t-3); margin-top:var(--s-3); text-align:center; }
.pcard--feature .pcard__turnaround{ color:var(--on-dark-3); }
@media (max-width:900px){ .steps{ grid-template-columns:1fr; max-width:460px; margin-inline:auto; } }

/* what we fix — checklist */
.fixes__grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(var(--s-6),5vw,72px); align-items:start; }
.fixes__copy{ position:sticky; top:96px; }
.fixes__copy h2{ font-size:var(--step-3); margin-bottom:var(--s-4); }
.fixlist{ list-style:none; margin:0; padding:0; }
.fixlist li{ display:flex; gap:var(--s-4); padding:var(--s-5) 0; border-top:1px solid var(--line); }
.fixlist li:last-child{ border-bottom:1px solid var(--line); }
.fixlist .tick{ flex:0 0 auto; width:28px; height:28px; border-radius:8px; background:linear-gradient(135deg, rgba(48,191,217,.16), rgba(211,83,173,.14)); display:grid; place-items:center; color:var(--cyan-ink); font-weight:700; font-family:var(--display); }
.fixlist b{ display:block; font-family:var(--display); font-weight:600; font-size:1.05rem; color:var(--t-1); margin-bottom:3px; }
.fixlist span{ font-size:.95rem; color:var(--t-2); }
@media (max-width:900px){ .fixes__grid{ grid-template-columns:1fr; gap:var(--s-6); } .fixes__copy{ position:static; } }

/* honesty block */
.honesty__inner{ max-width:720px; margin-inline:auto; text-align:center; }
.honesty h2{ font-size:var(--step-2); color:#fff; margin-bottom:var(--s-5); }
.honesty p{ font-size:var(--step-1); line-height:1.5; color:var(--on-dark-2); }
.honesty .formula{ font-family:var(--display); font-weight:600; color:#fff; margin-top:var(--s-6); }
.honesty .formula span{ color:var(--cyan); }

/* FAQ accordion */
.faqs__wrap{ max-width:820px; margin-inline:auto; }
.faqs__head{ text-align:center; max-width:26ch; margin:0 auto clamp(var(--s-6),4vw,var(--s-7)); }
.faqs__head h2{ font-size:var(--step-3); }
.faq__item{ border-top:1px solid var(--line); }
.faq__item:last-child{ border-bottom:1px solid var(--line); }
.faq__item summary{ list-style:none; cursor:pointer; display:flex; align-items:flex-start; justify-content:space-between; gap:var(--s-5); padding:var(--s-5) 0; }
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__q{ font-family:var(--display); font-weight:600; font-size:var(--step-1); line-height:1.2; color:var(--t-1); transition:color .3s var(--ease); }
.faq__item:hover .faq__q{ color:var(--cyan-ink); }
.faq__ic{ flex:0 0 auto; position:relative; width:20px; height:20px; margin-top:.4em; }
.faq__ic::before,.faq__ic::after{ content:""; position:absolute; left:50%; top:50%; background:var(--cyan-ink); border-radius:2px; transform:translate(-50%,-50%); transition:transform .35s var(--ease), opacity .35s var(--ease); }
.faq__ic::before{ width:15px; height:2px; }
.faq__ic::after{ width:2px; height:15px; }
.faq__item[open] .faq__ic::after{ transform:translate(-50%,-50%) scaleY(0); opacity:0; }
.faq__a{ padding:0 var(--s-7) var(--s-6) 0; max-width:64ch; color:var(--t-2); }
.faq__a p{ margin:0 0 .8em; }
.faq__a p:last-child{ margin-bottom:0; }
.faq__item[open] .faq__a{ animation:faqIn .4s var(--ease-soft) both; }
@keyframes faqIn{ from{ opacity:0; transform:translateY(-6px); } to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion: reduce){ .faq__item[open] .faq__a{ animation:none; } }
@media (max-width:560px){ .faq__a{ padding-right:0; } }

/* ============================================================
   17. Contact
   ============================================================ */
.contact__grid{ display:grid; grid-template-columns:1.2fr .8fr; gap:clamp(var(--s-6),5vw,72px); align-items:start; }
/* reuse .audit-form but on light surface */
.contact .audit-form{ background:var(--wash); border-color:var(--line); box-shadow:0 24px 60px -40px rgba(11,12,16,.2); }
.contact .audit-form__title{ color:var(--t-1); }
.contact .audit-form__note{ color:var(--t-3); }
.contact .field label{ color:var(--t-2); }
.contact .field input,.contact .field select,.contact .field textarea{ background:var(--paper); color:var(--t-1); border-color:var(--line); }
.contact .field input::placeholder,.contact .field textarea::placeholder{ color:var(--t-3); }
.contact .field select{ background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23147A8C' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right .9em center; }
.contact .audit-form__fine{ color:var(--t-3); }
.contact .form-status{ color:var(--cyan-ink); }
.contact textarea{ resize:vertical; min-height:130px; }
.info-card{ background:var(--ink); color:var(--on-dark-2); border-radius:var(--radius-lg); padding:clamp(var(--s-6),4vw,44px); position:sticky; top:96px; overflow:hidden; }
.info-card::before{ content:""; position:absolute; inset:0; z-index:0; background:radial-gradient(70% 60% at 90% 0%, rgba(48,191,217,.14), transparent 60%); }
.info-card > *{ position:relative; z-index:1; }
.info-card .eyebrow{ color:var(--cyan); margin-bottom:var(--s-5); }
.info-card__big{ display:block; font-family:var(--display); font-weight:600; font-size:var(--step-1); color:#fff; margin-bottom:var(--s-4); word-break:break-word; transition:color .3s var(--ease); }
.info-card__big:hover{ color:var(--cyan); }
.info-card__row{ margin-top:var(--s-5); padding-top:var(--s-5); border-top:1px solid var(--line-dark); }
.info-card__lbl{ display:block; margin-bottom:var(--s-2); font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--cyan); }
.info-card__row p{ margin:0; color:var(--on-dark-2); line-height:1.6; }
@media (max-width:900px){ .contact__grid{ grid-template-columns:1fr; gap:var(--s-6); } .info-card{ position:static; } }

/* ============================================================
   18. Privacy / prose
   ============================================================ */
.prose{ max-width:70ch; }
.prose h2{ font-size:var(--step-1); margin:var(--s-8) 0 var(--s-4); line-height:1.2; }
.prose h2:first-of-type{ margin-top:var(--s-6); }
.prose p{ color:var(--t-2); }
.prose ul{ margin:0 0 1.1em; padding-left:1.3em; color:var(--t-2); }
.prose li{ margin-bottom:.4em; }
.prose li::marker{ color:var(--cyan-ink); }
