/* ===========================================================================
   B2BLY — Production site styles  ·  Direction B
   One stylesheet for all pages. Brand: "Make AI make sense."
   =========================================================================== */

/* ----- Tokens ----- */
:root{
  --persimmon:#E45C3A; --persimmon-d:#C8492B; --persimmon-l:#F4A98C;
  --violet:#6F57C9; --violet-d:#5B45B0;
  --ink:#1A1714; --ink-soft:#4A433C; --muted:#897E70;
  --paper:#FBF8F3; --card:#FFFFFF; --line:#EBE3D6; --line-strong:#DDD3C3;
  --n100:#F2ECE2; --n200:#E5DCCD; --n300:#CFC4B2;
  --sweep:linear-gradient(135deg,#E45C3A 0%,#C8497B 48%,#6F57C9 100%);
  --sweep-soft:linear-gradient(135deg,#F4A98C 0%,#C98FB8 50%,#9C8BDD 100%);
  --display:"Space Grotesk",system-ui,sans-serif;
  --sans:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
  --shadow-sm:0 1px 2px rgba(26,23,20,.04),0 6px 18px -12px rgba(26,23,20,.20);
  --shadow:0 1px 2px rgba(26,23,20,.05),0 18px 40px -24px rgba(26,23,20,.26);
  --shadow-lg:0 2px 6px rgba(26,23,20,.06),0 44px 90px -44px rgba(26,23,20,.34);
  --r:16px; --r-lg:24px;
  --container:1200px;
  --nav-h:72px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; background:var(--paper); }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0; font-family:var(--sans); color:var(--ink); background:transparent;
  line-height:1.6; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* ----- Animated background wash -----
   Fixed, behind all content (z-index:-1). Opaque sections (white cards, ink
   bands, gradient CTA) cover it; the transparent paper sections let it glow
   through, so the middle of the page picks up gentle, drifting brand colour. */
.bg-aurora{ position:fixed; inset:0; z-index:-1; overflow:hidden; pointer-events:none; }
.bg-aurora .orb-p{ position:absolute; inset:0; will-change:transform; }
.bg-aurora .orb{ position:absolute; border-radius:50%; filter:blur(70px); opacity:.5;
  will-change:transform; }
.bg-aurora .orb-1{ width:46vw; height:46vw; left:-8vw; top:24%;
  background:radial-gradient(circle at 50% 50%, rgba(228,92,58,.32), rgba(228,92,58,0) 70%);
  animation:orbDrift1 26s ease-in-out infinite; }
.bg-aurora .orb-2{ width:42vw; height:42vw; right:-10vw; top:42%;
  background:radial-gradient(circle at 50% 50%, rgba(111,87,201,.30), rgba(111,87,201,0) 70%);
  animation:orbDrift2 32s ease-in-out infinite; }
.bg-aurora .orb-3{ width:38vw; height:38vw; left:28%; top:62%;
  background:radial-gradient(circle at 50% 50%, rgba(200,73,123,.24), rgba(200,73,123,0) 70%);
  animation:orbDrift3 29s ease-in-out infinite; }
@keyframes orbDrift1{ 0%,100%{ transform:translate(0,0) scale(1); } 50%{ transform:translate(6vw,-3vw) scale(1.12); } }
@keyframes orbDrift2{ 0%,100%{ transform:translate(0,0) scale(1); } 50%{ transform:translate(-5vw,4vw) scale(1.1); } }
@keyframes orbDrift3{ 0%,100%{ transform:translate(0,0) scale(1.05); } 50%{ transform:translate(4vw,5vw) scale(.95); } }
@media (prefers-reduced-motion: reduce){ .bg-aurora .orb{ animation:none; } }
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--persimmon); color:#fff; }
h1,h2,h3,h4{ font-family:var(--display); font-weight:600; letter-spacing:-.025em; margin:0; line-height:1.05; text-wrap:balance; }
p{ margin:0; }

/* ----- Layout ----- */
.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 24px; }
.container-wide{ max-width:1340px; }
.section{ padding:96px 0; }
.section-sm{ padding:64px 0; }
.center{ text-align:center; }
.eyebrow{ font-family:var(--mono); font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.eyebrow.accent{ color:var(--persimmon); }
.sec-head{ max-width:42ch; }
.sec-head.center{ margin:0 auto; }
.sec-title{ font-size:clamp(30px,4.4vw,46px); margin:14px 0 16px; }
.sec-sub{ font-size:18px; color:var(--ink-soft); }
.lede{ color:var(--ink-soft); }
.accent{ color:var(--persimmon); }

/* ----- Buttons ----- */
.btn{ font-family:var(--sans); font-weight:600; border-radius:999px; display:inline-flex; align-items:center;
  gap:9px; cursor:pointer; white-space:nowrap; border:1px solid transparent; transition:transform .15s ease, background .2s, box-shadow .2s, color .2s; line-height:1; }
.btn:active{ transform:translateY(1px); }
.btn .arw{ transition:transform .2s ease; }
.btn:hover .arw{ transform:translateX(3px); }
.btn-pri{ background:var(--persimmon); color:#fff; box-shadow:0 8px 22px -10px rgba(228,92,58,.7); }
.btn-pri:hover{ background:var(--persimmon-d); box-shadow:0 12px 26px -10px rgba(228,92,58,.85); }
.btn-dark{ background:var(--ink); color:var(--paper); }
.btn-dark:hover{ background:#000; }
.btn-ghost{ background:var(--card); color:var(--ink); border-color:var(--line-strong); }
.btn-ghost:hover{ border-color:var(--ink); }
.btn-light{ background:#fff; color:var(--ink); }
.btn-light:hover{ background:var(--paper); }
.btn-lg{ font-size:16px; padding:15px 28px; }
.btn-md{ font-size:14.5px; padding:12px 22px; }
.btn-sm{ font-size:13.5px; padding:9px 17px; }

/* ----- Header ----- */
.site-header{ position:sticky; top:0; z-index:100; transition:background .3s, box-shadow .3s, border-color .3s; border-bottom:1px solid transparent; }
.site-header.scrolled{ background:color-mix(in srgb, var(--paper) 86%, transparent); backdrop-filter:saturate(1.5) blur(16px); border-bottom-color:var(--line); }
.nav{ height:var(--nav-h); display:flex; align-items:center; justify-content:space-between; gap:20px; }
.brand{ display:flex; align-items:center; gap:10px; font-family:var(--display); font-weight:700; letter-spacing:-.02em; font-size:19px; }
.brand .two{ color:var(--persimmon); }
.brand svg{ width:28px; height:28px; }
.nav-links{ display:flex; align-items:center; gap:30px; }
.nav-links a{ font-size:14.5px; font-weight:500; color:var(--ink-soft); transition:color .18s; position:relative; }
.nav-links a:hover, .nav-links a[aria-current="page"]{ color:var(--ink); }
.nav-links a[aria-current="page"]::after{ content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px; background:var(--persimmon); border-radius:2px; }
.nav-cta{ display:flex; align-items:center; gap:12px; }
.nav-toggle{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; }
.nav-toggle span{ width:24px; height:2px; background:var(--ink); border-radius:2px; transition:transform .25s, opacity .2s; }
.nav-open .nav-toggle span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-open .nav-toggle span:nth-child(2){ opacity:0; }
.nav-open .nav-toggle span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ----- Hero ----- */
.hero{ position:relative; overflow:hidden; padding:84px 0 72px; text-align:center; }
.hero-blob{ position:absolute; top:-160px; left:50%; transform:translateX(-50%); width:min(760px,120vw); height:480px;
  background:var(--sweep-soft); filter:blur(28px); opacity:.40; border-radius:50%; z-index:0; pointer-events:none; }
.hero > .container{ position:relative; z-index:1; }
.hero h1{ font-size:clamp(38px,6.4vw,72px); margin:18px auto 20px; max-width:16ch; }
.hero h1 .grad{ background:var(--sweep); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero h1 .accent{ color:var(--persimmon); }
.hero-sub{ font-size:clamp(17px,2.2vw,21px); color:var(--ink-soft); max-width:54ch; margin:0 auto 30px; }
.hero-cta{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.hero-trust{ margin-top:22px; font-family:var(--mono); font-size:12.5px; letter-spacing:.04em; color:var(--muted); }
.hero-visual{ margin-top:48px; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-lg); border:1px solid var(--line); background:var(--card); }

/* generic media placeholder */
.ph{ background:repeating-linear-gradient(135deg,transparent 0 13px,rgba(137,126,112,.08) 13px 14px),var(--n100);
  display:flex; align-items:center; justify-content:center; color:var(--muted); font-family:var(--mono); font-size:12px;
  letter-spacing:.05em; text-align:center; }
.ph-tall{ aspect-ratio:16/8; }
.ph-wide{ aspect-ratio:16/6; }
.ph-sq{ aspect-ratio:1; }

/* ----- Logo marquee / trust ----- */
.trust{ background:var(--ink); color:#C9C0B4; padding:30px 0; overflow:hidden; }
.trust-label{ text-align:center; font-family:var(--mono); font-size:11.5px; letter-spacing:.18em; text-transform:uppercase; color:#897E70; margin-bottom:18px; }
.marquee{ display:flex; gap:64px; width:max-content; animation:marq 32s linear infinite; }
.marquee:hover{ animation-play-state:paused; }
.marquee .logo{ font-family:var(--display); font-weight:600; font-size:22px; color:#E5DCCD; opacity:.7; white-space:nowrap; }
@keyframes marq{ to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion: reduce){ .marquee{ animation:none; flex-wrap:wrap; justify-content:center; } }

/* ----- Stats ----- */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.stat{ text-align:center; }
.stat .num{ font-family:var(--display); font-weight:600; font-size:clamp(34px,5vw,52px); letter-spacing:-.03em; line-height:1; }
.stat .num.accent{ color:var(--persimmon); }
.stat .lbl{ font-size:14px; color:var(--muted); margin-top:8px; }
.stats.on-ink .stat .num{ color:var(--paper); }
.stats.on-ink .stat .lbl{ color:#C9C0B4; }

/* ----- Cards / grids ----- */
.grid{ display:grid; gap:22px; }
.cols-2{ grid-template-columns:repeat(2,1fr); }
.cols-3{ grid-template-columns:repeat(3,1fr); }
.cols-4{ grid-template-columns:repeat(4,1fr); }
.card{ background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:30px; transition:transform .2s ease, box-shadow .25s ease, border-color .2s; }
.card-hover:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:var(--line-strong); }
.card .ico{ width:50px; height:50px; border-radius:13px; background:var(--n100); display:grid; place-items:center; color:var(--persimmon); margin-bottom:18px; }
.card .ico svg{ width:26px; height:26px; }
.card h3{ font-size:22px; margin-bottom:9px; }
.card p{ color:var(--ink-soft); font-size:15.5px; }
.card .more{ margin-top:16px; font-family:var(--mono); font-size:12px; letter-spacing:.08em; color:var(--persimmon); display:inline-flex; gap:7px; align-items:center; }
.card .more .arw{ transition:transform .2s; }
.card-hover:hover .more .arw{ transform:translateX(3px); }

/* feature/case cards */
.case{ background:var(--card); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; transition:transform .2s, box-shadow .25s; }
.case-hover:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.case .media{ aspect-ratio:16/10; }
.media img{ display:block; width:100%; height:100%; object-fit:cover; }
.svc-media img{ display:block; width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:var(--r); }
/* Branded gradient cover for slots without a photo */
.media-brand{ position:relative; background:var(--sweep-soft); overflow:hidden; }
.media-brand::after{ content:""; position:absolute; inset:0; background:radial-gradient(120% 90% at 78% 16%, rgba(255,255,255,.28), transparent 55%); }
.media-brand::before{ content:""; position:absolute; inset:0; z-index:1; opacity:.92;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cpath d='M50 27.5 A 25.5 25.5 0 0 0 50 72.5 A 25.5 25.5 0 0 0 50 27.5 Z' fill='%23ffffff'/%3E%3Ccircle cx='38' cy='50' r='25.5' fill='none' stroke='%23ffffff' stroke-width='10.5'/%3E%3Ccircle cx='62' cy='50' r='25.5' fill='none' stroke='%23ffffff' stroke-width='10.5'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:center; background-size:54px; }
.mb1{ background:linear-gradient(135deg,#F4A98C,#C98FB8); }
.mb2{ background:linear-gradient(135deg,#C98FB8,#9C8BDD); }
.mb3{ background:var(--sweep); }
.mb4{ background:linear-gradient(135deg,#9C8BDD,#6F57C9); }
.mb5{ background:linear-gradient(135deg,#F4A98C,#E45C3A); }
.mb6{ background:linear-gradient(135deg,#6F57C9,#C8497B); }
.case .body{ padding:24px; }
.case .tag{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }
.case .metric{ font-family:var(--display); font-weight:600; font-size:34px; color:var(--persimmon); letter-spacing:-.02em; margin:8px 0 4px; }
.case .desc{ color:var(--ink-soft); font-size:15px; }

/* ----- Testimonial ----- */
.quote{ text-align:center; max-width:24ch; margin:0 auto; font-family:var(--display); font-weight:600; font-size:clamp(24px,3.4vw,36px); line-height:1.3; letter-spacing:-.01em; }
.quote .accent{ color:var(--persimmon); }
.quote-by{ display:flex; align-items:center; justify-content:center; gap:12px; margin-top:24px; }
.quote-by .av{ width:48px; height:48px; border-radius:50%; background:var(--n200); }
.quote-by .meta{ font-family:var(--mono); font-size:12px; letter-spacing:.04em; color:var(--muted); text-align:left; }

/* ----- CTA band ----- */
.cta-band{ background:var(--sweep); color:#fff; text-align:center; padding:84px 0; position:relative; overflow:hidden; }
.cta-band h2{ font-size:clamp(30px,4.6vw,48px); color:#fff; max-width:20ch; margin:0 auto 14px; }
.cta-band p{ font-size:18px; opacity:.94; max-width:46ch; margin:0 auto 28px; }
.cta-band.ink{ background:var(--ink); }
.cta-band.ink h2{ color:var(--paper); }

/* ----- Inner page hero ----- */
.page-hero{ padding:72px 0 40px; text-align:center; position:relative; overflow:hidden; }
.page-hero .hero-blob{ height:360px; opacity:.30; }
.page-hero h1{ font-size:clamp(34px,5.4vw,58px); margin:14px auto 16px; max-width:18ch; }
.page-hero p{ font-size:19px; color:var(--ink-soft); max-width:56ch; margin:0 auto; }
.breadcrumb{ font-family:var(--mono); font-size:12px; letter-spacing:.06em; color:var(--muted); }
.breadcrumb a:hover{ color:var(--persimmon); }

/* ----- Services detail rows ----- */
.svc-row{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
.svc-row + .svc-row{ margin-top:64px; }
.svc-row .num{ font-family:var(--mono); font-size:13px; color:var(--persimmon); letter-spacing:.1em; }
.svc-row h2{ font-size:32px; margin:12px 0 14px; }
.svc-row ul{ margin:18px 0 0; padding:0; list-style:none; }
.svc-row li{ display:flex; gap:11px; align-items:flex-start; padding:7px 0; font-size:15.5px; color:var(--ink-soft); }
.svc-row li::before{ content:""; flex:none; width:18px; height:18px; margin-top:2px; border-radius:50%; background:var(--n100);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2.5 6.2l2 2 5-5.4' fill='none' stroke='%23E45C3A' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:center; }

/* ----- Process steps ----- */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; counter-reset:step; }
.step{ position:relative; }
.step .n{ font-family:var(--mono); font-size:12px; color:var(--persimmon); letter-spacing:.1em; }
.step h3{ font-size:20px; margin:10px 0 8px; }
.step p{ font-size:14.5px; color:var(--ink-soft); }

/* ----- Pricing ----- */
.price-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; align-items:start; }
.price{ background:var(--card); border:1px solid var(--line); border-radius:var(--r-lg); padding:32px; position:relative; transition:transform .2s ease, box-shadow .25s ease, border-color .2s ease; }
.price:hover{ border-color:var(--persimmon); box-shadow:var(--shadow); transform:translateY(-5px); }
.price .plan{ font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.price .amt{ font-family:var(--display); font-weight:600; font-size:44px; letter-spacing:-.03em; margin:14px 0 4px; }
.price .amt small{ font-family:var(--sans); font-size:15px; font-weight:500; color:var(--muted); letter-spacing:0; }
.price .pdesc{ color:var(--ink-soft); font-size:15px; min-height:48px; }
.price ul{ list-style:none; margin:22px 0; padding:0; }
.price li{ display:flex; gap:10px; align-items:flex-start; padding:8px 0; font-size:14.5px; border-top:1px solid var(--line); }
.price li:first-child{ border-top:0; }
.price li .ck{ flex:none; color:var(--persimmon); margin-top:2px; }
.price .btn{ width:100%; justify-content:center; }

/* ----- FAQ accordion ----- */
.faq{ max-width:760px; margin:0 auto; }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{ width:100%; background:none; border:0; text-align:left; cursor:pointer; padding:22px 0; display:flex;
  justify-content:space-between; align-items:center; gap:20px; font-family:var(--display); font-weight:600; font-size:19px; color:var(--ink); }
.faq-q .ic{ flex:none; width:22px; height:22px; position:relative; transition:transform .25s; }
.faq-q .ic::before, .faq-q .ic::after{ content:""; position:absolute; background:var(--persimmon); border-radius:2px; }
.faq-q .ic::before{ left:0; right:0; top:10px; height:2px; }
.faq-q .ic::after{ top:0; bottom:0; left:10px; width:2px; transition:transform .25s; }
.faq-item.open .faq-q .ic::after{ transform:scaleY(0); }
.faq-a{ overflow:hidden; max-height:0; transition:max-height .3s ease; }
.faq-a p{ padding:0 0 22px; color:var(--ink-soft); font-size:16px; max-width:64ch; }

/* ----- Blog / insights ----- */
.post-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.post{ border-radius:var(--r); overflow:hidden; border:1px solid var(--line); background:var(--card); transition:transform .2s, box-shadow .25s; }
.post-hover:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.post .media{ aspect-ratio:16/9; }
.post .body{ padding:22px; }
.post .cat{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--persimmon); }
.post h3{ font-size:20px; margin:10px 0 8px; line-height:1.2; }
.post p{ color:var(--ink-soft); font-size:14.5px; }
.post .meta{ margin-top:14px; font-family:var(--mono); font-size:11.5px; color:var(--muted); }
.featured-post{ display:grid; grid-template-columns:1.1fr .9fr; gap:0; border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; background:var(--card); margin-bottom:32px; }
.featured-post .media{ min-height:320px; }
.featured-post .body{ padding:40px; align-self:center; }
.featured-post h2{ font-size:30px; margin:12px 0 12px; }

/* ----- About ----- */
.about-lead{ font-family:var(--display); font-weight:500; font-size:clamp(22px,3vw,30px); line-height:1.35; letter-spacing:-.01em; max-width:24ch; }
.values{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.value h3{ font-size:20px; margin:14px 0 8px; }
.value p{ color:var(--ink-soft); font-size:15px; }
.team{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.member .av{ aspect-ratio:1; border-radius:var(--r); margin-bottom:14px; }
.member .nm{ font-family:var(--display); font-weight:600; font-size:17px; }
.member .role{ font-family:var(--mono); font-size:12px; color:var(--muted); margin-top:3px; }

/* ----- Contact ----- */
.contact-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:48px; align-items:start; }
.contact-info h2{ font-size:34px; margin-bottom:16px; }
.contact-info .row{ display:flex; gap:14px; align-items:flex-start; padding:16px 0; border-top:1px solid var(--line); }
.contact-info .row .ic{ flex:none; width:40px; height:40px; border-radius:11px; background:var(--n100); display:grid; place-items:center; color:var(--persimmon); }
.contact-info .row .t{ font-weight:600; font-size:15.5px; }
.contact-info .row .d{ font-size:14.5px; color:var(--ink-soft); }
.embed-slot{ background:var(--card); border:1px dashed var(--line-strong); border-radius:var(--r-lg); padding:40px; min-height:520px;
  display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; gap:14px; }
.embed-slot .badge{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:#fff; background:var(--ink); padding:6px 12px; border-radius:999px; }
.embed-slot h3{ font-size:22px; }
.embed-slot p{ color:var(--ink-soft); font-size:15px; max-width:42ch; }
.embed-slot code{ font-family:var(--mono); font-size:12.5px; background:var(--n100); padding:3px 8px; border-radius:6px; color:var(--persimmon-d); }

/* ----- Footer ----- */
.site-footer{ background:var(--ink); color:#C9C0B4; padding:64px 0 30px; }
.foot-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; }
.foot-brand .brand{ color:var(--paper); }
.foot-brand p{ font-size:14px; margin:14px 0 18px; max-width:30ch; line-height:1.7; }
.foot-col h4{ font-family:var(--mono); font-weight:500; font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; color:#897E70; margin-bottom:14px; }
.foot-col a{ display:block; font-size:14px; padding:6px 0; color:#C9C0B4; transition:color .18s; }
.foot-col a:hover{ color:#fff; }
.foot-bottom{ border-top:1px solid rgba(255,255,255,.1); margin-top:48px; padding-top:22px; display:flex;
  justify-content:space-between; gap:14px; flex-wrap:wrap; font-family:var(--mono); font-size:11.5px; color:#897E70; }

/* ----- Reveal animation -----
   Content is visible by default (crawler-safe, no-JS-safe). Only when the
   <html> element gets .js-reveal (added by an inline head script, and only
   when motion is allowed) do we hide-then-animate. */
.js-reveal .reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1); }
.js-reveal .reveal.in{ opacity:1; transform:none; }
.js-reveal .reveal[data-d="1"]{ transition-delay:.08s; } .js-reveal .reveal[data-d="2"]{ transition-delay:.16s; }
.js-reveal .reveal[data-d="3"]{ transition-delay:.24s; } .js-reveal .reveal[data-d="4"]{ transition-delay:.32s; }

/* ----- Utilities ----- */
.mt-0{margin-top:0}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mt-8{margin-top:32px}.mt-12{margin-top:48px}
.mb-6{margin-bottom:24px}.mb-8{margin-bottom:32px}.mb-12{margin-bottom:48px}
.maxw-sm{max-width:48ch}.divider{height:1px;background:var(--line);border:0;margin:0}

/* ===========================================================================
   Responsive
   =========================================================================== */
@media (max-width:980px){
  .cols-4{ grid-template-columns:repeat(2,1fr); }
  .stats{ grid-template-columns:repeat(2,1fr); row-gap:32px; }
  .steps{ grid-template-columns:repeat(2,1fr); }
  .team{ grid-template-columns:repeat(2,1fr); }
  .price-grid{ grid-template-columns:1fr; max-width:460px; margin:0 auto; }
  .svc-row{ grid-template-columns:1fr; gap:28px; }
  .svc-row.flip .svc-media{ order:-1; }
  .featured-post{ grid-template-columns:1fr; }
  .featured-post .media{ min-height:220px; }
  .post-grid{ grid-template-columns:repeat(2,1fr); }
  .contact-grid{ grid-template-columns:1fr; gap:32px; }
}
@media (max-width:760px){
  .section{ padding:64px 0; }
  .nav-links, .nav-cta .btn-book-desktop{ display:none; }
  .nav-toggle{ display:flex; }
  .mobile-menu{ display:block; }
  .cols-2,.cols-3,.cols-4,.values{ grid-template-columns:1fr; }
  .post-grid{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:repeat(2,1fr); }
  .team{ grid-template-columns:repeat(2,1fr); }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:28px; }
  .foot-brand{ grid-column:1/-1; }
  .hero-cta .btn{ flex:1; justify-content:center; }
}

/* ----- Mobile menu ----- */
.mobile-menu{ display:none; position:fixed; inset:var(--nav-h) 0 0; z-index:99; background:var(--paper);
  padding:24px; transform:translateX(100%); transition:transform .3s cubic-bezier(.16,1,.3,1); }
.nav-open .mobile-menu{ transform:none; }
.mobile-menu a{ display:block; font-family:var(--display); font-weight:600; font-size:26px; padding:14px 0; border-bottom:1px solid var(--line); }
.mobile-menu .btn{ width:100%; justify-content:center; margin-top:24px; }
body.nav-open{ overflow:hidden; }
