/* ===========================================================
   PharWise Research — FINAL (synthesis)
   Base: variant-1 (Clinical Minimal) palette + accessibility + robust reveal
   Grafts: v3 gradient bio-tech hero shell + service media wells (dialed down)
           v2 alternating editorial feature rows
   Robustness: content visible by default; reveal is progressive enhancement
   only (gated behind .js-reveal + prefers-reduced-motion). Self-contained.
   =========================================================== */

:root{
  /* brand */
  --blue:#0a5ca8;
  --blue-700:#073e72;
  --blue-900:#073357;
  --blue-300:#1a86d8;
  --teal:#10a9b8;
  --green:#5bb04a;
  --green-700:#357a2a;

  /* neutral ramp (warm) */
  --n-0:#ffffff;
  --n-50:#f8fafc;
  --n-100:#f1f5f9;
  --n-200:#e6ecf2;
  --n-300:#d3dce5;
  --n-500:#7a8794;
  --n-600:#5d6b79;
  --n-700:#3a4654;
  --n-900:#16212d;

  --ink:#16212d;
  --muted:#5d6b79;
  --line:#e6ecf2;
  --bg:#ffffff;
  --bg-alt:#f8fafc;

  /* light-hero ink: near-black, not true black (vibrates on off-white) */
  --hero-ink:#101a24;

  /* gradients (full-width bands + accents only) */
  --grad-ink:linear-gradient(155deg,#06182f 0%,#0c2a4a 45%,#0a3357 100%);
  --grad-bio:linear-gradient(110deg,var(--blue-300),var(--teal) 58%,var(--green));
  --grad-text:linear-gradient(100deg,var(--blue-300),var(--teal) 60%,var(--green));

  --radius:14px;
  --radius-sm:10px;
  --shadow:0 4px 18px rgba(7,51,87,.07);
  --shadow-lg:0 18px 48px rgba(7,51,87,.16);
  --ring:0 0 0 3px rgba(26,134,216,.35);

  --maxw:1160px;
  --measure:66ch;

  --space-section:clamp(64px,9vw,118px);

  --font:"Segoe UI",ui-sans-serif,system-ui,-apple-system,Roboto,Helvetica,Arial,"Helvetica Neue",sans-serif;
  --mono:ui-monospace,"Cascadia Mono","SF Mono",Menlo,Consolas,monospace;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;color:var(--ink);background:var(--bg);
  font-family:var(--font);
  font-size:clamp(1rem,.96rem + .2vw,1.075rem);
  line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--blue);text-decoration:none}
svg{display:block}

h1,h2,h3{line-height:1.12;color:var(--ink);margin:0 0 .5em;letter-spacing:-.02em}
h1{font-size:clamp(2.1rem,1.4rem + 3.2vw,3.6rem);font-weight:800}
h2{font-size:clamp(1.7rem,1.3rem + 1.7vw,2.5rem);font-weight:700}
h3{font-size:1.18rem;font-weight:700;letter-spacing:-.01em}
p{margin:0 0 1rem}
strong{font-weight:700;color:inherit}

.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;width:100%}
.narrow{max-width:820px}
.center{text-align:center}
.accent{color:var(--green-700)}
.lead{font-size:clamp(1.05rem,1rem + .35vw,1.22rem);color:var(--muted);max-width:var(--measure)}
.section .lead{margin-left:auto;margin-right:auto}

/* gradient text with solid-color fallback (background-clip:text not universal) */
.grad-text{color:var(--blue-300)}
@supports ((-webkit-background-clip:text) or (background-clip:text)){
  .grad-text{
    background:var(--grad-text);
    -webkit-background-clip:text;background-clip:text;
    -webkit-text-fill-color:transparent;color:transparent;
  }
}
/* On the LIGHT hero, use a richer (darker) accent gradient + darker fallback
   so the accent word stays high-contrast on off-white (AA large-text safe).
   Set background-image ONLY (the `background` shorthand would reset
   background-clip back to border-box and turn the text into a colored box). */
.hero .grad-text{color:var(--blue-700)}
@supports ((-webkit-background-clip:text) or (background-clip:text)){
  .hero .grad-text{background-image:linear-gradient(100deg,var(--blue),var(--teal) 70%,var(--green-700))}
}

/* skip link */
.skip-link{
  position:absolute;left:12px;top:-60px;z-index:2000;
  background:var(--blue-900);color:#fff;padding:10px 16px;border-radius:8px;font-weight:600;
  transition:top .2s ease;
}
.skip-link:focus{top:12px}

/* focus visibility */
:focus-visible{outline:2px solid var(--blue-300);outline-offset:2px;border-radius:4px}
a:focus-visible,.btn:focus-visible,button:focus-visible{box-shadow:var(--ring);outline:none}

/* eyebrow / section heads */
.eyebrow{
  font-family:var(--mono);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--blue-300);margin:0 0 .9rem;font-weight:600;
}
.eyebrow-ink{color:var(--blue)}
.eyebrow.on-ink{color:var(--teal)}
.section-head{max-width:760px;margin:0 0 clamp(2rem,4vw,3.2rem)}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head .lead{margin-top:.4rem}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  min-height:48px;padding:13px 28px;border-radius:10px;font-weight:600;
  font-size:.95rem;letter-spacing:.01em;cursor:pointer;border:1px solid transparent;
  transition:transform .18s ease,box-shadow .22s ease,background .2s ease,border-color .2s ease,color .2s ease;
}
.btn-ico{width:18px;height:18px;transition:transform .25s ease}
.btn:hover .btn-ico{transform:translateX(3px)}
.btn-primary{background:var(--blue);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{background:var(--blue-700);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-ghost{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.45)}
.btn-ghost:hover{background:rgba(255,255,255,.14);transform:translateY(-2px);border-color:#fff}
.btn-light{background:#fff;color:var(--blue-700);box-shadow:var(--shadow)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);background:var(--n-50)}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:1000;
  background:#fff;
  border-bottom:1px solid transparent;transition:border-color .25s ease,box-shadow .25s ease,background .25s ease;
}
/* progressive blur only where supported (legibility-safe fallback above) */
@supports ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  .site-header{background:rgba(255,255,255,.82);-webkit-backdrop-filter:saturate(160%) blur(12px);backdrop-filter:saturate(160%) blur(12px)}
  .site-header.scrolled{background:rgba(255,255,255,.9)}
}
.site-header.scrolled{border-bottom-color:var(--line);box-shadow:0 6px 24px rgba(7,51,87,.06)}
.header-inner{
  max-width:var(--maxw);margin:0 auto;padding:12px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
}
.brand{display:flex;align-items:center}
.brand-logo{height:46px;width:auto}
.primary-nav{display:flex;align-items:center;gap:8px}
.primary-nav a{
  color:var(--ink);font-weight:600;font-size:.92rem;
  padding:9px 14px;border-radius:8px;position:relative;transition:color .2s ease;
}
.primary-nav a:not(.nav-cta)::after{
  content:"";position:absolute;left:14px;right:14px;bottom:5px;height:2px;
  background:var(--grad-bio);border-radius:2px;transform:scaleX(0);transform-origin:left;
  transition:transform .25s ease;
}
.primary-nav a:not(.nav-cta):hover{color:var(--blue)}
.primary-nav a:not(.nav-cta):hover::after{transform:scaleX(1)}
.primary-nav .nav-cta{
  background:var(--blue);color:#fff;border-radius:8px;padding:11px 20px;margin-left:6px;min-height:44px;
  display:inline-flex;align-items:center;box-shadow:var(--shadow);
}
.primary-nav .nav-cta:hover{background:var(--blue-700);color:#fff;transform:translateY(-1px)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:10px;
  min-width:44px;min-height:44px;align-items:center;justify-content:center;border-radius:8px}
.nav-toggle span{width:24px;height:2.5px;background:var(--ink);border-radius:2px;transition:transform .3s ease,opacity .3s ease}
.nav-toggle.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ---------- hex pattern (data-uri) ---------- */
.hex-field,.hex-overlay{
  position:absolute;inset:0;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='56' height='96' viewBox='0 0 56 96'%3E%3Cg fill='none' stroke='%23ffffff' stroke-width='1'%3E%3Cpath d='M28 0 L56 16 L56 48 L28 64 L0 48 L0 16 Z'/%3E%3Cpath d='M28 32 L56 48 L56 80 L28 96 L0 80 L0 48 Z'/%3E%3C/g%3E%3C/svg%3E");
  background-size:56px 96px;opacity:.06;
}

/* ---------- hero — SOFT LIGHT GRADIENT ---------- */
/* Warm off-white base, sub-perceptual luminance shift + a single off-center
   brand glow behind the headline. Dark ink text (AA verified). The page base
   color is this off-white, so subsequent light sections step gently, not slam. */
.hero{
  position:relative;overflow:hidden;isolation:isolate;color:var(--hero-ink);
  background:
    radial-gradient(115% 90% at 78% -10%,rgba(16,169,184,.10),transparent 55%),
    radial-gradient(90% 80% at 8% 5%,rgba(10,92,168,.07),transparent 55%),
    linear-gradient(176deg,#fbfcfb 0%,#f4f8f7 52%,#eef3f2 100%);
  padding:clamp(64px,8vw,108px) 0 clamp(72px,10vw,116px);
}
.hero-bg{position:absolute;inset:0;overflow:hidden;z-index:-1}
.hero .glow{position:absolute;border-radius:50%;filter:blur(96px)}
/* light-on-light glows: low opacity so they read as depth, not blobs */
.glow-a{width:520px;height:520px;top:-180px;left:-120px;
  background:radial-gradient(circle,rgba(26,134,216,.18),transparent 70%);opacity:.7}
.glow-b{width:560px;height:560px;bottom:-220px;right:-150px;
  background:radial-gradient(circle,rgba(16,169,184,.18),transparent 68%);opacity:.6}
/* faint molecular mesh texture on the off-white (dark strokes, very low opacity) */
.hero .hex-field{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='56' height='96' viewBox='0 0 56 96'%3E%3Cg fill='none' stroke='%230a3357' stroke-width='1'%3E%3Cpath d='M28 0 L56 16 L56 48 L28 64 L0 48 L0 16 Z'/%3E%3Cpath d='M28 32 L56 48 L56 80 L28 96 L0 80 L0 48 Z'/%3E%3C/g%3E%3C/svg%3E");
  opacity:.04;
}
.hero-inner{
  position:relative;
  display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);
  gap:clamp(2rem,4vw,4rem);align-items:center;
}
.hero .eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;color:var(--blue);
  background:rgba(10,92,168,.06);border:1px solid rgba(10,92,168,.16);
  padding:7px 14px;border-radius:999px;margin:0 0 1.3rem;
}
.hero .eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--green-700);box-shadow:0 0 0 4px rgba(53,122,42,.18)}
.hero h1{color:var(--hero-ink);max-width:18ch;margin-bottom:.55em}
.hero-sub{font-size:clamp(1.08rem,1rem + .5vw,1.32rem);color:var(--n-700);max-width:50ch;margin:0 0 2rem;line-height:1.6}
.hero-sub strong{color:var(--blue-700);font-weight:700}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px}
/* on a light hero, the secondary button needs an ink outline, not a white one */
.hero .btn-ghost{background:#fff;color:var(--blue-700);border-color:var(--n-300);box-shadow:var(--shadow)}
.hero .btn-ghost:hover{border-color:var(--blue);color:var(--blue);background:#fff;transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.hero-stats{
  display:flex;flex-wrap:wrap;gap:clamp(1.4rem,3vw,2.6rem);margin:2.6rem 0 0;padding-top:1.7rem;
  border-top:1px solid var(--n-200);
}
.hero-stats div{display:flex;flex-direction:column}
.hero-stats dt{font-size:1.5rem;font-weight:800;color:var(--blue-700);letter-spacing:-.02em;line-height:1.1}
.hero-stats dd{margin:.25rem 0 0;font-size:.82rem;color:var(--n-600);max-width:18ch}

/* hero media card — BRIGHT contained panel (not a dark glass card) */
.hero-media{position:relative}
/* ambient brand glow behind the card so the hero's right side feels designed */
.hero-media::before{
  content:"";position:absolute;z-index:0;inset:4% 0 -7% 8%;border-radius:40px;pointer-events:none;
  background:radial-gradient(55% 55% at 72% 28%,rgba(16,169,184,.5),transparent 70%),
             radial-gradient(55% 55% at 18% 88%,rgba(10,92,168,.42),transparent 72%);
  filter:blur(46px);opacity:.6;
}
.media-card{
  position:relative;z-index:1;border-radius:20px;overflow:hidden;aspect-ratio:4/3;
  /* the dark network render sits inside a bright matte frame (framed-print feel) */
  background:#fff;padding:10px;
  box-shadow:0 0 0 1px rgba(10,92,168,.12),0 30px 64px rgba(7,51,87,.22),0 8px 20px rgba(7,51,87,.10);
}
/* the photo gets its own inner rounding so the white frame reads as a panel */
.media-card picture{display:block;position:absolute;inset:10px;border-radius:12px;overflow:hidden}
.media-card img{width:100%;height:100%;object-fit:cover;opacity:1}
/* keep the render legible + on-brand inside its bright frame (treat the photo) */
.media-card::after{content:"";position:absolute;inset:10px;border-radius:12px;pointer-events:none;
  background:linear-gradient(150deg,rgba(10,92,168,.22),rgba(16,169,184,.10) 55%,transparent)}
.media-badge{
  position:absolute;left:24px;bottom:24px;z-index:2;
  width:84px;height:84px;border-radius:18px;color:#bff0ff;
  background:rgba(6,24,47,.55);border:1px solid rgba(255,255,255,.22);
  display:grid;place-items:center;animation:drift 9s ease-in-out infinite;
}
@supports ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  .media-badge{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
}
.media-badge .mol{width:54px;height:54px}
@keyframes drift{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* ---------- proof strip — LIGHT (carries the airy top down, no dark seam) ---------- */
.strip{
  position:relative;overflow:hidden;
  padding:clamp(54px,7vw,80px) 0 clamp(40px,5vw,58px);
  /* one tiny luminance step down from the hero's bottom, still off-white */
  background:linear-gradient(180deg,#eef3f2 0%,#f4f7f6 100%);
  color:var(--ink);text-align:center;
  border-top:1px solid rgba(10,92,168,.06);
}
.strip::before{
  content:"";position:absolute;inset:0;opacity:.05;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='56' height='64' viewBox='0 0 56 64'%3E%3Cpath d='M28 1 54 16v32L28 63 2 48V16Z' fill='none' stroke='%230a3357' stroke-width='1.5'/%3E%3C/svg%3E");
  background-size:56px 64px;
}
.strip h2{color:var(--hero-ink);position:relative}
.strip .accent{color:var(--green-700)}
.strip .lead{color:var(--n-700);margin-left:auto;margin-right:auto;position:relative}
.capabilities{
  position:relative;list-style:none;margin:2.2rem auto 0;padding:0;max-width:660px;
  display:flex;flex-wrap:wrap;justify-content:center;gap:12px;
}
.capabilities li{
  font-family:var(--mono);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;
  padding:8px 16px;border:1px solid rgba(10,92,168,.18);border-radius:999px;
  color:var(--blue-700);background:#fff;
  box-shadow:0 2px 8px rgba(7,51,87,.05);
  transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease;
}
.capabilities li:hover{border-color:rgba(10,92,168,.45);box-shadow:0 4px 14px rgba(7,51,87,.1);transform:translateY(-1px)}

/* ---------- sections ---------- */
.section{padding:var(--space-section) 0;position:relative}
.dotgrid{position:relative}
.dotgrid::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:radial-gradient(rgba(10,92,168,.10) 1px,transparent 1.4px);
  background-size:26px 26px;
  -webkit-mask-image:linear-gradient(180deg,#000,transparent 38%);
  mask-image:linear-gradient(180deg,#000,transparent 38%);
}
.dotgrid>.container{position:relative}

/* ---------- feature rows (Why PharWise) — grafted from v2 ---------- */
.feature-row{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);
  align-items:center;margin-bottom:clamp(34px,4.5vw,56px);
}
.feature-row:last-child{margin-bottom:0}
.feature-row.reverse .feature-media{order:2}
.feature-media{
  position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);
  aspect-ratio:16/10;
  /* guaranteed non-empty backdrop so the well can never read blank */
  background:
    radial-gradient(120% 120% at 80% 0%,rgba(16,169,184,.18),transparent 60%),
    radial-gradient(120% 120% at 0% 100%,rgba(10,92,168,.2),transparent 60%),
    #eef4fa;
}
.feature-media img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;padding:0;
  filter:saturate(1.06) contrast(1.02);
  transition:transform .5s ease;
}
.feature-row:hover .feature-media img{transform:scale(1.04)}
/* brand duotone wash — unifies mixed photos + keeps pale images from reading blank */
.feature-overlay{position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(135deg,rgba(10,92,168,.30),rgba(16,169,184,.16) 60%,rgba(91,176,74,.14));
  mix-blend-mode:multiply}
.feature-badge{
  position:absolute;left:16px;top:16px;z-index:2;
  font-family:var(--mono);font-size:1.02rem;font-weight:700;color:#fff;
  width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(6,24,47,.5);border:1px solid rgba(255,255,255,.32);box-shadow:0 6px 16px rgba(7,51,87,.28);
}
@supports ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  .feature-badge{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
}
.feature-icon{
  display:inline-grid;place-items:center;width:52px;height:52px;border-radius:14px;margin-bottom:16px;
  background:var(--grad-bio);color:#fff;box-shadow:0 10px 22px rgba(16,135,184,.26);
}
.feature-icon svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.feature-copy h3{color:var(--blue-700);font-size:clamp(1.3rem,1.1rem + .8vw,1.7rem)}
.feature-copy h3::after{content:"";display:block;width:54px;height:3px;border-radius:3px;
  background:var(--grad-bio);margin:.7rem 0 1.1rem}
.feature-copy p{color:var(--muted);font-size:1.05rem;margin:0;max-width:52ch}

/* ---------- band-ink (steps) — from v3 ---------- */
.band-ink{background:var(--grad-ink);color:#dfeaf6;overflow:hidden}
.band-ink h2{color:#fff}
.band-ink .hex-overlay{opacity:.06}
.band-ink .container{position:relative}

/* ---------- steps ---------- */
.steps{
  list-style:none;margin:0;padding:0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.5vw,28px);
  counter-reset:step;position:relative;
}
.steps::before{
  content:"";position:absolute;top:56px;left:16%;right:16%;height:2px;z-index:0;
  background:repeating-linear-gradient(90deg,rgba(255,255,255,.4) 0 8px,transparent 8px 16px);
}
.step{
  position:relative;z-index:1;text-align:center;padding:32px 24px 28px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);
  transition:transform .25s ease,border-color .25s ease,background .25s ease;
}
@supports ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  .step{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}
}
.step:hover{transform:translateY(-5px);border-color:rgba(16,169,184,.55);background:rgba(255,255,255,.08)}
.step-num{
  display:inline-grid;place-items:center;width:56px;height:56px;border-radius:50%;
  background:var(--grad-bio);color:#fff;font-size:1.45rem;font-weight:800;font-family:var(--mono);margin-bottom:14px;
  box-shadow:0 8px 22px rgba(16,135,184,.36);border:3px solid rgba(6,24,47,.7);
}
.step-icon{display:block;margin:0 auto 4px;color:var(--teal);opacity:.9}
.step-icon svg{width:28px;height:28px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.step h3{color:#fff;margin-top:.6rem}
.step p{color:#aec6e0;margin:0}

/* ---------- services grid — media wells from v3 ---------- */
.services-grid{
  display:grid;gap:clamp(20px,2.6vw,28px);
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
}
.svc-card{
  display:flex;flex-direction:column;background:#fff;
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);transition:transform .22s ease,box-shadow .25s ease,border-color .22s ease;
}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--n-300)}
/* uniform media well — guaranteed non-empty gradient backdrop (fixes v2 blank wells) */
.svc-media{
  position:relative;aspect-ratio:16/9;overflow:hidden;
  background:
    radial-gradient(120% 120% at 80% 0%,rgba(16,169,184,.16),transparent 60%),
    radial-gradient(120% 120% at 0% 100%,rgba(10,92,168,.18),transparent 60%),
    #eef4fa;
}
.svc-media img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;padding:0;
  filter:saturate(1.06) contrast(1.02);
  transition:transform .4s ease;
}
.svc-card:hover .svc-media img{transform:scale(1.05)}
.svc-overlay{position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(135deg,rgba(10,92,168,.28),rgba(16,169,184,.15) 60%,rgba(91,176,74,.12));
  mix-blend-mode:multiply}
.svc-body{display:flex;flex-direction:column;padding:26px 26px 28px;flex:1}
.icon-badge{
  display:inline-grid;place-items:center;width:56px;height:56px;border-radius:14px;margin:-52px 0 16px;
  background:var(--grad-ink);color:#fff;box-shadow:0 10px 22px rgba(7,51,87,.28);
  border:3px solid #fff;position:relative;
}
.icon-badge svg{width:28px;height:28px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.svc-card h3{color:var(--blue-700);font-size:1.22rem;margin-bottom:.25em}
.svc-tag{color:var(--green-700);font-weight:600;font-size:.92rem;margin-bottom:.85rem}
.svc-intro{color:var(--muted);font-size:.96rem;margin-bottom:1.1rem;max-width:46ch}
.checks{list-style:none;margin:auto 0 0;padding:1.05rem 0 0;border-top:1px solid var(--line)}
.checks li{position:relative;padding-left:1.85rem;margin-bottom:.72rem;color:var(--muted);font-size:.92rem;line-height:1.5}
.checks li:last-child{margin-bottom:0}
.checks li strong{color:var(--ink);font-weight:600}
.checks li::before{content:"";position:absolute;left:0;top:.1em;width:1.15rem;height:1.15rem;border-radius:50%;
  background:rgba(91,176,74,.16)}
.checks li::after{content:"";position:absolute;left:.4rem;top:.34em;width:.34rem;height:.62rem;
  border:solid var(--green-700);border-width:0 2px 2px 0;transform:rotate(45deg)}

/* ---------- cta band ---------- */
.cta-band{
  position:relative;overflow:hidden;isolation:isolate;
  padding:clamp(72px,10vw,118px) 0;text-align:center;color:#fff;background:var(--grad-ink);
}
.cta-band .hex-overlay{opacity:.06}
.cta-band .glow-c{
  position:absolute;width:600px;height:600px;left:50%;top:50%;transform:translate(-50%,-50%);
  border-radius:50%;filter:blur(110px);opacity:.34;
  background:radial-gradient(circle,#10a9b8,transparent 65%);z-index:0;
}
.cta-inner{position:relative;max-width:760px;z-index:1}
.cta-band h2{color:#fff;font-weight:700}
.cta-lead{color:#bcd2e8;margin:0 auto 1.6rem;max-width:54ch}
.cta-mail{margin:0 0 1.8rem}
.cta-mail a{
  display:inline-flex;align-items:center;gap:.55rem;color:#fff;font-family:var(--mono);font-size:1.05rem;font-weight:600;
  padding-bottom:3px;border-bottom:1px solid rgba(255,255,255,.4);transition:border-color .2s ease,color .2s ease;
}
.cta-mail a:hover{border-bottom-color:var(--teal);color:#bff0ff}
.mail-ico{width:22px;height:22px;color:var(--teal);fill:none;stroke:currentColor}

/* ---------- footer ---------- */
.site-footer{background:var(--n-900);color:#aebac6;position:relative}
.foot-divider{display:block;width:100%;height:46px;color:var(--blue-900);margin-top:-1px;position:relative;top:1px}
.foot-inner{
  display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:24px;
  padding-top:38px;padding-bottom:30px;
}
.foot-brand{max-width:360px}
.foot-brand img{height:54px;width:auto;margin-bottom:14px}
.foot-tag{color:#8b99a7;font-size:.9rem;margin:0;max-width:34ch}
.foot-nav{display:flex;flex-wrap:wrap;gap:8px 26px}
.foot-nav a{color:#c2cdd8;font-size:.92rem;font-weight:500}
.foot-nav a:hover{color:#fff}
.foot-base{border-top:1px solid rgba(255,255,255,.08);padding:18px 24px}
.foot-base p{margin:0;font-size:.85rem;color:#7f8d9b}

/* ===========================================================
   SCROLL REVEAL — progressive enhancement only.
   Content is visible by default. Hidden state applies ONLY when
   <html> carries .js-reveal (added by JS when JS + motion present).
   No JS / IO failure / reduced-motion => nothing is ever hidden.
   =========================================================== */
.js-reveal .reveal{opacity:0;transform:translateY(22px);
  transition:opacity .6s ease var(--d,0s),transform .6s ease var(--d,0s)}
.js-reveal .reveal.in-view{opacity:1;transform:none}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media(max-width:1000px){
  .hero-inner{grid-template-columns:1fr;gap:2.4rem}
  .hero-copy{max-width:none}
  .hero-media{order:-1;max-width:520px;margin:0 auto}
  .hero h1{max-width:20ch}
}
@media(max-width:900px){
  .feature-row{grid-template-columns:1fr;gap:24px}
  .feature-row.reverse .feature-media{order:0}
  .feature-copy p{max-width:none}
}
@media(max-width:860px){
  .steps{grid-template-columns:1fr;gap:0}
  .steps::before{display:none}
  .step{margin-bottom:24px}
  .step:not(:last-child)::after{
    content:"";position:absolute;left:50%;bottom:-24px;width:2px;height:24px;
    background:repeating-linear-gradient(180deg,rgba(255,255,255,.4) 0 6px,transparent 6px 12px);
    transform:translateX(-50%);
  }
  .step:last-child{margin-bottom:0}
  .nav-toggle{display:flex}
  .primary-nav{
    position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;align-items:stretch;
    background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow-lg);
    max-height:0;overflow:hidden;transition:max-height .32s ease;
  }
  .primary-nav.open{max-height:460px}
  .primary-nav a{width:100%;padding:16px 24px;border-bottom:1px solid var(--line);border-radius:0}
  .primary-nav a:not(.nav-cta)::after{display:none}
  .primary-nav .nav-cta{border-radius:0;justify-content:center;margin:0;box-shadow:none}
  .header-inner{flex-wrap:wrap}
}
@media(max-width:560px){
  .hero-stats{gap:20px}
  .hero-stats li,.hero-stats div{flex:1 1 40%}
  .hero-stats dt{font-size:1.25rem}
  .foot-inner{flex-direction:column;align-items:flex-start}
  .btn{width:100%}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{width:100%}
}

/* safe areas for any fixed/bottom UI (defensive) */
@supports(padding:max(0px)){
  .foot-base{padding-bottom:max(18px,calc(18px + env(safe-area-inset-bottom)))}
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .js-reveal .reveal{opacity:1!important;transform:none!important}
}
