/* =========================================================
   IT'S JUST A NERD — neon nerd-cave, rebuilt
   Dark violet canvas · single accent · terminal/code motif
   Coherence device: window-chrome bar reused across sections
   ========================================================= */

:root{
  --bg:#0b0814;
  --bg-2:#0f0a1c;
  --surf:#16112a;
  --surf-2:#1d1638;
  --tint:#0e0a1d;
  --ink:#f1edff;
  --ink-2:#c5bde2;
  --muted:#8b82ad;
  --line:#271f44;
  --line-2:#392d60;
  --accent:#7c5cf5;
  --accent-d:#8d6ffb;
  --accent-ink:#ffffff;
  --hl:#a78bff;
  --cyan:#46e3d6;
  --pink:#f26fc8;
  --add:#46d98a;
  --del:#f2607f;
  --accent-soft:rgba(124,92,245,.16);
  --ring:rgba(124,92,245,.40);
  --disp:"Space Grotesk",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
  --maxw:1240px;
  --r:20px;
  --r-sm:12px;
  --h1:clamp(33px,5vw,58px);
  --h2:clamp(28px,3.6vw,44px);
  --h3:clamp(21px,2.2vw,27px);
  --shadow:0 30px 70px -34px rgba(74,40,150,.7);
  --shadow-sm:0 16px 40px -24px rgba(74,40,150,.66);
  --z-nav:50;
  --z-chat:80;
  --z-grain:120;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--disp);
  font-size:17px;
  line-height:1.62;
  color:var(--ink-2);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:clip;
}
/* global film grain — breaks digital flatness, one cave */
body::after{
  content:"";position:fixed;inset:0;z-index:var(--z-grain);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='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:150px;
}
img{max-width:100%;display:block}
main{overflow-x:clip}
a{color:inherit;text-decoration:none}
b,strong{font-weight:700;color:var(--ink)}
i{font-style:italic}

h1,h2,h3,h4{
  font-family:var(--disp);color:var(--ink);font-weight:600;
  letter-spacing:-.025em;line-height:1.04;margin:0;text-wrap:balance;
}
::selection{background:var(--accent);color:var(--accent-ink)}
::placeholder{color:var(--muted);opacity:1}
:focus-visible{outline:2px solid var(--accent-d);outline-offset:3px;border-radius:4px}

.skip{
  position:fixed;top:-60px;left:14px;z-index:200;background:var(--accent);color:#fff;
  font-family:var(--mono);font-size:15px;font-weight:600;padding:10px 16px;border-radius:0 0 12px 12px;
  transition:top .2s ease;
}
.skip:focus{top:0}

/* shared coherence: mono kicker label */
.kick{
  display:inline-block;font-family:var(--mono);font-size:15px;font-weight:600;
  letter-spacing:.02em;color:var(--accent);margin-bottom:18px;
}

/* shared coherence: window-chrome bar (hero figure, about, diff, compose) */
.win{
  position:relative;border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;
  background:var(--surf);box-shadow:var(--shadow);
}
.winbar{
  display:flex;align-items:center;gap:11px;padding:12px 15px;
  background:linear-gradient(180deg,var(--surf-2),var(--surf));
  border-bottom:1px solid var(--line);
}
.dots{display:inline-flex;gap:7px}
.dots i{width:11px;height:11px;border-radius:50%}
.dots i:nth-child(1){background:#f2607f}
.dots i:nth-child(2){background:#f5b945}
.dots i:nth-child(3){background:#46d98a}
.winbar .name{font-family:var(--mono);font-size:15px;color:var(--muted);letter-spacing:.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--disp);font-weight:700;font-size:16px;
  color:var(--accent-ink);background:var(--accent);
  padding:14px 24px;border-radius:100px;border:0;cursor:pointer;
  transition:transform .15s ease,background .15s ease,box-shadow .2s ease;
  box-shadow:0 12px 30px -14px var(--ring);white-space:nowrap;
}
.btn:hover{background:var(--accent-d);transform:translateY(-2px);box-shadow:0 18px 36px -14px var(--ring)}
.btn:active{transform:translateY(0)}
.btn .arrow{transition:transform .2s ease}
.btn:hover .arrow{transform:translateX(4px)}
.btn.ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--line-2)}
.btn.ghost:hover{background:var(--surf);box-shadow:inset 0 0 0 1.5px var(--accent)}
.btn.btn-sm{padding:10px 18px;font-size:15px}
.arrow{font-style:normal}

/* ---------- top nav ---------- */
.nav{
  position:sticky;top:0;z-index:var(--z-nav);
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:16px 4vw;
  background:rgba(11,8,20,0);
  transition:background .25s ease,box-shadow .25s ease,backdrop-filter .25s ease;
}
.nav.scrolled{
  background:rgba(11,8,20,.8);
  backdrop-filter:saturate(140%) blur(12px);
  box-shadow:0 1px 0 var(--line);
}
.logo{font-weight:700;font-size:20px;letter-spacing:-.02em;color:var(--ink);display:inline-block;white-space:nowrap}
.logo b{font-weight:800}
.logo .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block;margin-left:4px;vertical-align:1px;box-shadow:0 0 12px var(--accent)}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links>a:not(.btn){font-weight:500;font-size:16px;color:var(--ink-2);position:relative;padding:4px 0;transition:color .15s ease}
.nav-links>a:not(.btn):hover{color:var(--ink)}
.nav-links>a.on{color:var(--ink)}
.nav-links>a.on::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--accent);border-radius:2px}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-cta-work{display:none}
.burger{display:none;flex-direction:column;gap:5px;background:0;border:0;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.2s}
.burger.open span:first-child{transform:translateY(7px) rotate(45deg)}
.burger.open span:last-child{transform:translateY(-7px) rotate(-45deg)}

/* =========================================================
   HERO — asymmetric editorial, oversized type, framed figure
   ========================================================= */
.hero{
  position:relative;min-height:100dvh;display:flex;align-items:center;overflow:hidden;
  padding:clamp(96px,12vh,150px) 4vw clamp(64px,8vh,104px);
  background:
    radial-gradient(120% 95% at 78% -8%,rgba(140,104,255,.40),transparent 55%),
    radial-gradient(72% 105% at -4% 34%,rgba(124,84,244,.32),transparent 56%),
    radial-gradient(80% 80% at 24% 112%,rgba(70,227,214,.09),transparent 58%),
    linear-gradient(165deg,#1b1338 0%,#130d28 58%,#0b0814 100%);
}
.cave{position:absolute;inset:0;z-index:0;pointer-events:none;transform:translate(var(--px,0),var(--py,0));transition:transform .5s ease-out}
.cave span{position:absolute;display:block;will-change:transform}
.cave-violet{width:84%;height:104%;right:-16%;top:-24%;border-radius:50%;filter:blur(64px);
  background:radial-gradient(closest-side,rgba(140,104,255,.66),rgba(108,72,236,.26) 55%,transparent 74%)}
.cave-cyan{width:50%;height:58%;right:2%;bottom:-18%;border-radius:50%;filter:blur(78px);
  background:radial-gradient(closest-side,rgba(70,227,214,.30),transparent 72%)}
.cave-pink{width:48%;height:56%;left:-14%;bottom:-12%;border-radius:50%;filter:blur(88px);
  background:radial-gradient(closest-side,rgba(242,111,200,.20),transparent 72%)}
.cave-grid{inset:0;width:100%;height:100%;opacity:.65;will-change:background-position;
  background-image:linear-gradient(rgba(167,139,255,.14) 1px,transparent 1px),linear-gradient(90deg,rgba(167,139,255,.14) 1px,transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:radial-gradient(150% 130% at 50% 0%,#000 45%,transparent 95%);
          mask-image:radial-gradient(150% 130% at 50% 0%,#000 45%,transparent 95%)}
.cave-vignette{inset:0;width:100%;height:100%;background:radial-gradient(130% 115% at 58% 24%,transparent 50%,rgba(5,3,10,.7) 100%)}
/* scroll-parallax background layer for non-hero sections */
.sec-has-fx{position:relative;overflow:hidden}
.sec-has-fx>.sec-head,.sec-has-fx>.contact-grid{position:relative;z-index:1}
.sec-fx{position:absolute;left:-10%;right:-10%;top:-32%;height:168%;z-index:0;pointer-events:none;will-change:transform;
  background:radial-gradient(40% 36% at 26% 30%,rgba(124,92,245,.28),transparent 68%),radial-gradient(36% 32% at 82% 70%,rgba(56,189,248,.20),transparent 70%);
  filter:blur(16px)}

.hero-inner{
  position:relative;z-index:1;width:100%;max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(20px,3vw,56px);align-items:center;
}
.hero-copy{display:flex;flex-direction:column;align-items:flex-start}
.hero-kick{
  display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:15px;
  letter-spacing:.04em;text-transform:uppercase;color:var(--ink);
  background:rgba(255,255,255,.05);border:1px solid var(--line-2);padding:8px 15px;border-radius:100px;
  margin-bottom:28px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
}
.hero-kick i{width:8px;height:8px;border-radius:50%;background:#46d98a;box-shadow:0 0 0 4px rgba(70,217,138,.2)}
.hero-copy h1{font-size:clamp(44px,7vw,104px);font-weight:600;line-height:.94;letter-spacing:-.045em;margin:0}
.hero-copy h1 .hl{color:var(--accent);text-shadow:0 0 40px rgba(124,92,246,.7)}
.lead{font-size:clamp(17px,1.4vw,20px);color:var(--ink-2);max-width:42ch;margin:30px 0 34px;line-height:1.6}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-fine{margin:26px 0 0;font-family:var(--mono);font-size:15px;letter-spacing:.01em;color:var(--muted)}

/* framed figure + floating neon chips */
.hero-figure{position:relative;justify-self:end;width:100%;max-width:520px}
.hero-figure::before{content:"";position:absolute;inset:-12% -8% -8%;z-index:0;border-radius:50%;filter:blur(58px);
  background:radial-gradient(52% 56% at 50% 42%,rgba(124,92,246,.6),transparent 70%)}
.hero-figure .win{position:relative;z-index:1;animation:floatY 5.5s ease-in-out infinite;will-change:transform}
.win-shot{position:relative;overflow:hidden}
.win-shot img{width:100%;display:block}
.hero-figure .win-shot img{aspect-ratio:16/11;object-fit:cover;object-position:center 22%}
.float-chip{
  position:absolute;z-index:3;font-family:var(--mono);font-size:15px;font-weight:600;color:var(--ink);
  background:rgba(22,17,42,.82);border:1px solid var(--line-2);padding:9px 14px;border-radius:100px;
  box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);white-space:nowrap;
}
.float-chip::before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--accent);margin-right:8px;vertical-align:1px;box-shadow:0 0 10px var(--accent)}
.hero-figure .chip-1{top:14%;left:-10%}
.hero-figure .chip-2{top:54%;right:-8%}
.hero-figure .chip-3{bottom:-4%;left:8%}

.hero-scroll{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:1;
  display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:15px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.hero-scroll>span{width:20px;height:32px;border:1.5px solid var(--line-2);border-radius:100px;position:relative}
.hero-scroll>span::after{content:"";position:absolute;left:50%;top:7px;width:3px;height:6px;border-radius:2px;
  background:var(--accent);transform:translateX(-50%);animation:scrollDot 1.8s ease-in-out infinite}
@keyframes scrollDot{0%{opacity:0;transform:translate(-50%,0)}30%{opacity:1}60%{opacity:1;transform:translate(-50%,10px)}100%{opacity:0;transform:translate(-50%,12px)}}

/* =========================================================
   SECTIONS — left-aligned editorial heads, indexed kickers
   ========================================================= */
.sec{padding:clamp(64px,9vw,128px) 4vw;position:relative}
.sec-inner,.sec>.sec-head,.sec>*{max-width:var(--maxw);margin-left:auto;margin-right:auto}
.sec-tint{background:var(--tint);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sec-head{margin-bottom:clamp(44px,5vw,72px);max-width:var(--maxw)}
.sec-head .kick{color:var(--accent)}
.sec-head h2{font-size:var(--h2);font-weight:600;letter-spacing:-.035em}
.sec-head p{font-size:clamp(16px,1.3vw,19px);color:var(--ink-2);margin:18px 0 0;max-width:52ch}

/* =========================================================
   SERVICES — numbered zig-zag rows + ghost numerals
   ========================================================= */
/* ----- services: same numbered accordion as the FAQ ----- */
.svc-acc .faq-a{display:flex;flex-direction:column;gap:18px;align-items:flex-start}
.svc-hook{margin:0;font-family:var(--disp);font-size:clamp(18px,2vw,21px);font-weight:600;color:var(--ink);line-height:1.32;max-width:60ch}
.svc-acc .faq-a>p:not(.svc-hook){margin:0;max-width:62ch;color:var(--ink-2);font-size:16px;line-height:1.72}
.svc-checks{list-style:none;margin:0;padding:0;display:grid;gap:10px;width:100%;max-width:640px}
.svc-checks li{position:relative;padding-left:26px;font-size:16px;color:var(--ink-2);line-height:1.5}
.svc-checks li::before{content:"+";position:absolute;left:0;top:0;color:var(--accent);font-family:var(--mono);font-weight:700}
.svc-label{display:inline-block;font-family:var(--mono);font-size:15px;text-transform:uppercase;letter-spacing:.07em;color:var(--accent);font-weight:600;margin-bottom:14px}

/* =========================================================
   WORK — asymmetric gallery: 1 featured + 2 stacked
   ========================================================= */
.work-gallery{
  display:grid;grid-template-columns:1fr 1fr;
  gap:24px;align-items:stretch;
}
.proj{
  position:relative;border-radius:22px;overflow:hidden;display:flex;flex-direction:column;
  border:1px solid var(--line);background:#0a0713;
  transition:transform .25s ease,box-shadow .3s ease,border-color .25s ease;
}
.proj-lead{grid-row:1 / span 2}
.proj:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--line-2)}
.proj-shot{position:relative;flex:1;min-height:200px;overflow:hidden;background:#0a0713}
.proj-shot img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.proj:hover .proj-shot img{transform:scale(1.04)}
.proj-shot::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,5,16,.05) 0%,rgba(8,5,16,0) 32%,rgba(8,5,16,.78) 100%)}
.proj-tag{position:absolute;top:16px;left:16px;z-index:2;font-family:var(--mono);font-size:15px;text-transform:uppercase;letter-spacing:.06em;color:#fff;
  background:rgba(8,5,16,.46);padding:6px 11px;border-radius:100px;border:1px solid rgba(255,255,255,.18);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.proj-wm{position:absolute;left:20px;bottom:18px;z-index:2;font-family:var(--disp);font-weight:700;color:#fff;
  font-size:clamp(28px,3.6vw,46px);line-height:.92;letter-spacing:-.03em;text-shadow:0 6px 28px rgba(0,0,0,.55)}
.proj-lead .proj-wm{font-size:clamp(34px,4.4vw,60px)}
.proj-foot{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#0a0713;border-top:1px solid var(--line)}
.proj-av{width:38px;height:38px;border-radius:11px;object-fit:cover;flex-shrink:0;border:1px solid var(--line-2)}
.proj-meta{display:flex;flex-direction:column;min-width:0}
.proj-meta b{font-size:15px;color:var(--ink);font-weight:600;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.proj-meta span{font-size:15px;color:var(--muted);margin-top:1px}
.proj-cta{margin-left:auto;flex-shrink:0;display:inline-flex;align-items:center;gap:.4em;font-size:15px;font-weight:600;color:var(--ink);
  padding:8px 15px;border-radius:100px;border:1px solid var(--line-2);transition:background .18s ease,border-color .18s ease,color .18s ease}
.proj-cta .arrow{transition:transform .2s ease}
.proj:hover .proj-cta{background:var(--accent);border-color:var(--accent);color:#fff}
.proj:hover .proj-cta .arrow{transform:translateX(3px)}
.work-note{text-align:center;font-size:15px;color:var(--muted);margin-top:28px;font-style:italic}

/* =========================================================
   ABOUT — framed portrait + floating chips
   ========================================================= */
.about-cols{display:grid;grid-template-columns:.84fr 1.16fr;gap:clamp(44px,6vw,88px);align-items:center}
.about-pic{position:relative;max-width:460px;justify-self:center;width:100%}
.about-glow{position:absolute;inset:-14% -12% -18%;z-index:0;border-radius:50%;filter:blur(48px);
  background:radial-gradient(52% 52% at 38% 28%,rgba(124,92,245,.5),transparent 70%),radial-gradient(50% 50% at 84% 92%,rgba(70,227,214,.22),transparent 72%)}
.about-frame{position:relative;z-index:1;animation:floatY 6.8s ease-in-out .6s infinite;will-change:transform}
.about-frame .win-shot img{aspect-ratio:4/5;object-fit:cover}
.about-pic .float-chip{z-index:3}
.about-pic .chip-a{top:18%;right:-12%}
.about-pic .chip-b{bottom:8%;left:-12%}
.about-text .kick{color:var(--accent)}
.about-text h2{font-size:var(--h2);margin-bottom:22px}
.about-lead{font-size:clamp(17px,1.4vw,20px);color:var(--ink);margin:0 0 18px;line-height:1.5}
.about-text p{margin:0 0 16px;color:var(--ink-2);max-width:60ch}
.facts{display:flex;flex-wrap:wrap;gap:9px;margin-top:26px}
.fact{font-size:15px;font-weight:500;color:var(--ink);background:var(--surf);border:1px solid var(--line);padding:8px 15px;border-radius:100px}

/* WHY — reimagined as a git diff (the nerd signature) */
.why{margin-top:clamp(64px,8vw,116px)}
.why-head{text-align:center;margin-bottom:clamp(32px,4vw,52px)}
.why-head .kick{color:var(--accent)}
.why-head h3{font-size:var(--h2);font-weight:600}
.diff{border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;background:#0a0714;box-shadow:var(--shadow)}
.diff-body{display:grid;grid-template-columns:1fr 1fr;font-family:var(--mono)}
.diff-col{padding:clamp(20px,2.4vw,34px)}
.diff-col ul{list-style:none;margin:0;padding:0;display:grid;gap:14px}
.diff-col li{position:relative;padding-left:26px;font-size:15px;line-height:1.5}
.diff-col li::before{position:absolute;left:0;top:0;font-weight:700}
.diff-tag{display:inline-block;font-size:15px;font-weight:700;letter-spacing:.02em;margin-bottom:22px;padding:5px 12px;border-radius:8px}
.diff-del{background:rgba(242,96,127,.05);border-right:1px solid var(--line)}
.diff-del .diff-tag{color:var(--del);background:rgba(242,96,127,.12)}
.diff-del li{color:var(--muted)}
.diff-del li::before{content:"−";color:var(--del)}
.diff-add{background:rgba(70,217,138,.05)}
.diff-add .diff-tag{color:var(--add);background:rgba(70,217,138,.12)}
.diff-add li{color:var(--ink)}
.diff-add li::before{content:"+";color:var(--add)}

/* =========================================================
   CONTACT — note card + email-composer form
   ========================================================= */
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(28px,4vw,56px);align-items:stretch}
.formnote{display:flex;flex-direction:column;background:var(--surf);border:1px solid var(--line);border-radius:var(--r);padding:clamp(26px,3vw,42px)}
.formnote h3{font-size:var(--h3);margin-bottom:18px}
.formnote p{margin:0 0 16px;color:var(--ink-2)}
.formnote ul{margin:0 0 18px;padding:0;list-style:none;display:grid;gap:12px}
.formnote li{position:relative;padding-left:28px;font-size:16px;color:var(--ink-2)}
.formnote li::before{content:"✓";position:absolute;left:0;top:0;color:var(--accent);font-weight:700}
.kick-note{font-weight:600;color:var(--ink) !important}
.sig{display:flex;align-items:center;gap:14px;margin-top:auto;padding-top:30px;border-top:1px solid var(--line)}
.sig img{width:54px;height:54px;border-radius:14px;object-fit:cover;border:1px solid var(--line-2);flex-shrink:0}
.sig-t b{display:block;color:var(--ink);font-size:16px;line-height:1.25}
.sig-t span{font-size:15px;color:var(--muted)}

.formwrap{position:relative;overflow:hidden;background:var(--surf);border:1px solid var(--line-2);border-radius:var(--r);box-shadow:var(--shadow);display:flex;flex-direction:column}
.compose-bar .name{color:var(--ink-2)}
.formbody{padding:clamp(24px,3vw,38px)}
.formfoot{text-align:center;font-size:15px;color:var(--muted);margin:14px 0 0}
.hp{position:absolute !important;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.field{margin-bottom:20px}
.field label{display:block;font-family:var(--mono);font-weight:600;font-size:15px;color:var(--muted);margin-bottom:8px;text-transform:lowercase;letter-spacing:.02em}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--disp);font-size:16px;color:var(--ink);
  background:var(--bg);border:1.5px solid var(--line);border-radius:var(--r-sm);
  padding:13px 15px;transition:border .15s ease,box-shadow .15s ease;
}
.field textarea{min-height:124px;resize:vertical;line-height:1.55}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 4px var(--ring)}
.field .err{display:none;color:var(--del);font-size:15px;margin-top:7px}
.field.invalid input,.field.invalid textarea{border-color:var(--del)}
.field.invalid .err{display:block}
.formbody .btn{width:100%;justify-content:center;margin-top:4px}
.form-success{display:none;text-align:center;padding:48px 24px}
.form-success.show{display:block;animation:fade .4s ease both}
.form-success h4{font-size:26px;margin-bottom:10px}
.form-success p{color:var(--ink-2);margin:0}

/* ---------- footer ---------- */
.foot{max-width:var(--maxw);margin:0 auto;padding:48px 4vw 56px}
.foot-top{display:flex;flex-wrap:wrap;gap:16px 28px;align-items:center;justify-content:space-between;padding-bottom:24px;border-bottom:1px solid var(--line)}
.foot .logo{font-size:18px}
.foot-links{display:flex;flex-wrap:wrap;gap:22px;font-size:15px;color:var(--ink-2)}
.foot-links a{transition:color .15s ease}
.foot-links a:hover{color:var(--ink)}
.foot-bot{display:flex;flex-wrap:wrap;gap:8px 20px;align-items:center;justify-content:space-between;padding-top:22px;font-size:15px;color:var(--muted)}
.foot-legal a:hover{color:var(--ink)}

/* ---------- chatbot ---------- */
.chatbot{position:fixed;right:22px;bottom:22px;z-index:var(--z-chat);display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.chat-fab{width:62px;height:62px;border-radius:50%;border:3px solid var(--surf);cursor:pointer;overflow:hidden;padding:0;box-shadow:var(--shadow);position:relative;background:var(--surf-2);transition:transform .2s ease}
.chat-fab:hover{transform:scale(1.06)}
.chat-fab img{width:100%;height:100%;object-fit:cover}
.fab-dot{position:absolute;top:2px;right:2px;width:14px;height:14px;border-radius:50%;background:#46d98a;border:2px solid var(--surf);z-index:2}
.chat-teaser{display:none;background:var(--surf-2);color:var(--ink);font-size:15px;font-weight:500;padding:9px 15px;border-radius:14px 14px 4px 14px;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.chat-teaser.show{display:block;animation:pop .3s ease both}
.chat-panel{display:none;width:min(360px,calc(100vw - 44px));background:var(--surf);border:1px solid var(--line-2);border-radius:20px;overflow:hidden;box-shadow:var(--shadow)}
.chat-panel.open{display:block;animation:pop .28s ease both}
.chat-head{display:flex;align-items:center;gap:11px;padding:15px 16px;background:var(--tint);border-bottom:1px solid var(--line)}
.chat-head .ava{width:42px;height:42px;border-radius:50%;overflow:hidden;flex-shrink:0}
.chat-head .ava img{width:100%;height:100%;object-fit:cover}
.chat-head .nm{font-weight:700;color:var(--ink);font-size:16px}
.chat-head .st{font-size:15px;color:var(--muted);display:flex;align-items:center;gap:6px}
.chat-head .st .d{width:8px;height:8px;border-radius:50%;background:#46d98a}
.chat-head .x{margin-left:auto;background:0;border:0;font-size:24px;color:var(--muted);cursor:pointer;line-height:1}
.chat-body{padding:18px 16px;display:flex;flex-direction:column;gap:10px;max-height:300px;overflow-y:auto}
.bubble{font-size:15px;line-height:1.5;padding:11px 14px;border-radius:14px;max-width:85%}
.bubble.bot{background:var(--tint);color:var(--ink);border-bottom-left-radius:4px;align-self:flex-start}
.bubble.user{background:var(--accent);color:var(--accent-ink);border-bottom-right-radius:4px;align-self:flex-end}
.chat-fields{padding:0 16px 16px;display:flex;flex-direction:column;gap:9px}
.chat-fields .row{display:flex;gap:9px}
.chat-fields input,.chat-fields textarea{width:100%;font-family:var(--disp);font-size:15px;color:var(--ink);background:var(--bg);border:1.5px solid var(--line-2);border-radius:10px;padding:10px 12px}
.chat-fields textarea{min-height:64px;resize:vertical}
.chat-fields input:focus,.chat-fields textarea:focus{outline:0;border-color:var(--accent)}
.cerr{display:none;color:var(--del);font-size:15px}
.chat-fields.err .cerr{display:block}
.chat-fields .send{font-family:var(--disp);font-weight:700;font-size:15px;color:var(--accent-ink);background:var(--accent);border:0;border-radius:100px;padding:12px;cursor:pointer;transition:background .15s ease}
.chat-fields .send:hover{background:var(--accent-d)}

/* ---------- motion ---------- */
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:none}}
@keyframes rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

html.go .hero-copy>*{animation:rise .8s cubic-bezier(.2,.8,.2,1) both}
html.go .hero-copy>*:nth-child(1){animation-delay:.14s}
html.go .hero-copy>*:nth-child(2){animation-delay:.24s}
html.go .hero-copy>*:nth-child(3){animation-delay:.36s}
html.go .hero-copy>*:nth-child(4){animation-delay:.48s}
html.go .hero-copy>*:nth-child(5){animation-delay:.6s}
html.go .cave>*{animation:caveIgnite 1.2s ease both}
html.go .cave-violet{animation:caveIgnite 1.2s ease both, glowPulse 7s ease-in-out 1.4s infinite}
html.go .hero-figure{animation:figIn 1.1s .3s cubic-bezier(.2,.8,.2,1) both}
@keyframes caveIgnite{from{opacity:0}to{opacity:1}}
@keyframes glowPulse{0%,100%{opacity:.95;transform:scale(1)}50%{opacity:1;transform:scale(1.07)}}
@keyframes figIn{from{opacity:0;transform:translateY(26px) scale(.98);filter:blur(10px)}to{opacity:1;transform:none;filter:blur(0)}}
@keyframes floatY{0%,100%{transform:translateY(0) rotate(-.6deg)}50%{transform:translateY(-24px) rotate(.6deg)}}
@keyframes floatYm{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}

html.go .onscroll{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s cubic-bezier(.2,.8,.2,1)}
html.go .onscroll.in{opacity:1;transform:none}

@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto}
  html.go .onscroll{opacity:1;transform:none}
}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .hero-inner{grid-template-columns:1fr;text-align:center;gap:8px}
  .hero-copy{align-items:center}
  .lead{margin-inline:auto}
  .hero-figure{order:-1;justify-self:center;max-width:380px;margin:0 auto 14px}
  .hero-figure .chip-1,.hero-figure .chip-2,.hero-figure .chip-3{display:none}
  .hero-scroll{display:none}
  .work-gallery{grid-template-columns:1fr 1fr;grid-template-rows:none}
  .proj-lead{grid-row:auto;grid-column:1 / span 2}
  .proj-shot{min-height:240px}
  .about-cols{grid-template-columns:1fr;gap:clamp(40px,7vw,64px)}
  .about-pic{order:-1;max-width:400px}
  .about-pic .chip-a{right:-6%}
  .about-pic .chip-b{left:-6%}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width:680px){
  body{font-size:16px}
  body.nav-open,body.chat-open{overflow:hidden}

  /* ---- fullscreen menu (cartoon bg, full-width buttons pinned bottom) ---- */
  .burger{display:flex;position:relative;z-index:70}
  /* nav's backdrop-filter makes it the containing block for the fixed menu → menu offsets when scrolled. Drop it while open. */
  body.nav-open .nav{background:transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}
  /* iOS Safari repaint bug: a sticky nav with backdrop-filter vanishes on scroll-down and only repaints on scroll-up. Use a solid bg on mobile instead of blur. */
  .nav.scrolled{background:rgba(11,8,20,.96);-webkit-backdrop-filter:none;backdrop-filter:none}
  .nav-links{
    position:fixed;inset:0;z-index:60;display:none;overflow:hidden;
    flex-direction:column;justify-content:flex-end;align-items:stretch;gap:10px;
    padding:0 5vw calc(24px + env(safe-area-inset-bottom));
    background:var(--bg);
  }
  .nav-links::before{
    content:"";position:absolute;left:0;right:0;top:0;height:58%;z-index:0;pointer-events:none;
    background:url("/assets/img/about.jpg") center 24%/cover no-repeat;
    -webkit-mask-image:linear-gradient(180deg,#000 0%,#000 58%,transparent 100%);
            mask-image:linear-gradient(180deg,#000 0%,#000 58%,transparent 100%);
  }
  .nav-links>*{position:relative;z-index:1}
  .nav-links.open{display:flex;animation:fade .3s ease both}
  .nav-links>a:not(.btn){
    display:block;width:100%;font-family:var(--disp);font-size:21px;font-weight:600;color:var(--ink);text-align:left;
    padding:16px 18px;border-radius:14px;background:rgba(15,10,28,.74);border:1px solid var(--line-2);
    -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  }
  .nav-links>a.on::after{display:none}
  .nav-cta{display:flex;flex-direction:column;gap:10px;margin-top:14px}
  .nav-cta-work{display:none}
  .nav-cta .btn{width:100%;justify-content:center;font-size:16px;padding:16px}

  /* ---- hero ---- */
  .hero{padding:44px 5vw 34px;min-height:auto}
  .hero-copy h1{font-size:clamp(31px,8vw,50px);line-height:1.02;letter-spacing:-.03em}
  .hero-kick{margin-bottom:14px;flex-wrap:wrap;justify-content:center;text-align:center;line-height:1.4;max-width:100%;font-size:12px;letter-spacing:.02em;padding:6px 12px}
  .lead{font-size:16px;margin:14px auto 20px;line-height:1.5}
  .hero-cta{width:100%;flex-direction:column;align-items:stretch}
  .hero-cta .btn{width:100%;justify-content:center}
  .hero-figure{order:-1;max-width:none;width:auto;margin:0 -4vw 8px}
  .hero-figure .win{animation:floatYm 5.5s ease-in-out infinite}
  .hero-figure .win-shot img{aspect-ratio:16/9;object-position:center 24%}

  /* ---- services accordion (mobile) ---- */
  .svc-acc .faq-a .btn{width:100%;justify-content:center}
  .svc-hook{font-size:17px}

  /* ---- work / diff ---- */
  .work-gallery{grid-template-columns:1fr}
  .proj-lead{grid-column:auto}
  .diff-body{grid-template-columns:1fr}
  .diff-del{border-right:0;border-bottom:1px solid var(--line)}
  .about-pic .chip-a,.about-pic .chip-b{display:none}

  /* ---- chatbot: fullscreen ---- */
  .chatbot{right:16px;bottom:20px}
  .chat-fab{display:none}
  .chat-teaser{display:none !important}
  .chat-panel{position:fixed;inset:0;width:100%;height:100dvh;border:0;border-radius:0;z-index:90;flex-direction:column}
  .chat-panel.open{display:flex}
  .chat-head{padding:16px}
  .chat-body{flex:1;max-height:none}
}

/* =========================================================
   INNER PAGES — shared (work, blog, articles, case studies)
   ========================================================= */
.text-link{display:inline-flex;align-items:center;gap:.4em;color:var(--accent);font-weight:600;font-style:normal}
.text-link .arrow{transition:transform .2s ease}
.text-link:hover{color:var(--accent-d)}
.text-link:hover .arrow{transform:translateX(3px)}

/* page hero band for inner pages */
.page-hero{position:relative;overflow:hidden;padding:clamp(112px,14vh,176px) 4vw clamp(36px,5vw,60px);
  background:radial-gradient(90% 130% at 82% -20%,rgba(124,92,245,.30),transparent 60%),linear-gradient(180deg,#150f2c,var(--bg))}
.page-hero::after{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(167,139,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(167,139,255,.045) 1px,transparent 1px);
  background-size:46px 46px;-webkit-mask-image:radial-gradient(120% 100% at 50% 0%,#000 20%,transparent 75%);mask-image:radial-gradient(120% 100% at 50% 0%,#000 20%,transparent 75%)}
.page-hero-inner{position:relative;max-width:var(--maxw);margin-inline:auto}
.page-hero .kick{color:var(--accent)}
.page-hero h1{font-size:var(--h1);font-weight:600;letter-spacing:-.04em;line-height:1.04;max-width:20ch}
.page-hero .lead{margin:20px 0 0;font-size:clamp(17px,1.4vw,20px);color:var(--ink-2);max-width:60ch}

/* breadcrumb */
.breadcrumb{display:flex;flex-wrap:wrap;gap:8px;font-family:var(--mono);font-size:15px;color:var(--muted);margin-bottom:20px}
.breadcrumb a{transition:color .15s ease}
.breadcrumb a:hover{color:var(--ink)}
.breadcrumb .sep{color:var(--line-2)}
.breadcrumb [aria-current]{color:var(--ink-2)}

/* =========================================================
   FAQ — editorial numbered list, headings that expand.
   <details>/<summary>, no JS, content stays in the DOM (schema).
   ========================================================= */
html{interpolate-size:allow-keywords}
.faq{max-width:820px;margin-inline:auto;border-top:1px solid var(--line)}
.faq--wide{max-width:none}
.faq-title{font-size:var(--h3);margin-top:2.4em;margin-bottom:.2em}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:baseline;gap:22px;padding:30px 4px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-no{flex:none;width:38px;font-family:var(--mono);font-size:16px;font-weight:600;color:var(--accent);letter-spacing:.02em}
.faq-q{flex:1;font-family:var(--disp);font-size:clamp(23px,3vw,34px);font-weight:600;color:var(--ink);
  letter-spacing:-.025em;line-height:1.14;transition:color .15s ease}
.faq-item summary:hover .faq-q,.faq-item[open] .faq-q{color:var(--hl)}
.faq-chev{flex:none;align-self:center;width:13px;height:13px;
  border-right:2.5px solid var(--muted);border-bottom:2.5px solid var(--muted);
  transform:rotate(45deg);transition:transform .35s cubic-bezier(.22,.61,.36,1),border-color .2s ease}
.faq-item summary:hover .faq-chev,.faq-item[open] .faq-chev{border-color:var(--accent)}
.faq-item[open] .faq-chev{transform:rotate(225deg)}
/* smooth expand / collapse (animated height + fade), no JS */
.faq-item::details-content{
  height:0;overflow:clip;opacity:0;
  transition:height .38s cubic-bezier(.22,.61,.36,1),opacity .32s ease,content-visibility .38s allow-discrete;
}
.faq-item[open]::details-content{height:auto;opacity:1}
.faq-a{padding:0 4px 30px 60px}
.faq-a p{margin:0;max-width:62ch;color:var(--ink-2);font-size:16px;line-height:1.72}

@media (max-width:760px){
  .faq{max-width:none}
  .faq-item summary{gap:14px;padding:24px 2px}
  .faq-no{width:28px;font-size:15px}
  .faq-q{font-size:clamp(21px,6vw,26px)}
  .faq-a{padding:0 2px 24px 42px}
  .faq-a p{font-size:16px}
}

/* =========================================================
   BLOG — editorial index: hairline-separated entries, no boxes
   ========================================================= */
/* category chip + mono meta line (kept for related cards) */
.post-cat{position:absolute;top:14px;left:14px;font-family:var(--mono);font-size:15px;text-transform:uppercase;letter-spacing:.06em;
  color:#fff;background:rgba(8,5,16,.5);border:1px solid rgba(255,255,255,.18);padding:6px 12px;border-radius:100px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.post-meta{font-family:var(--mono);font-size:15px;color:var(--muted);display:flex;flex-wrap:wrap;align-items:center;gap:10px 16px}

/* the index */
.journal{max-width:var(--maxw);margin-inline:auto;border-top:1px solid var(--line)}
.entry{display:grid;grid-template-columns:300px 1fr;gap:clamp(24px,3.6vw,60px);align-items:center;
  padding:clamp(26px,3.4vw,46px) 0;border-bottom:1px solid var(--line)}
.entry-thumb{position:relative;display:block;border-radius:14px;overflow:hidden;background:#0a0713;aspect-ratio:16/11;border:1px solid var(--line)}
.entry-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .55s cubic-bezier(.22,.61,.36,1)}
.entry:hover .entry-thumb img{transform:scale(1.05)}
.entry-head{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px 16px;margin-bottom:15px;font-family:var(--mono);font-size:15px}
.entry-cat{font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}
.entry-date{color:var(--muted)}
.entry-title{font-size:var(--h3);font-weight:600;line-height:1.12;letter-spacing:-.02em;margin:0 0 12px}
.entry-title a{transition:color .15s ease}
.entry:hover .entry-title a{color:var(--hl)}
.entry-dek{font-size:16px;color:var(--ink-2);line-height:1.62;margin:0 0 18px;max-width:58ch}
.entry .text-link{font-size:16px}
.entry:hover .text-link .arrow{transform:translateX(4px)}

/* newest post leads: bigger image + bigger title, same hairline rhythm */
.entry--lead{grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,64px);padding-top:clamp(18px,2vw,28px)}
.entry--lead .entry-thumb{aspect-ratio:16/10}
.entry--lead .entry-title{font-size:var(--h2);line-height:1.06;letter-spacing:-.03em}
.entry--lead .entry-dek{font-size:clamp(16px,1.3vw,18px);max-width:50ch}

/* inline CTA that breaks the long list every few entries */
.entry-cta{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:18px 36px;
  margin:clamp(10px,1.4vw,18px) 0;padding:clamp(28px,3.2vw,42px) clamp(24px,3vw,40px);
  border:1px solid var(--line-2);border-radius:var(--r);
  background:radial-gradient(130% 150% at 100% 0%,var(--accent-soft),transparent 58%),var(--surf)}
.entry-cta .kick{margin-bottom:10px}
.entry-cta-line{margin:0;font-size:clamp(17px,1.4vw,20px);line-height:1.4;color:var(--ink);max-width:48ch}
.entry-cta .btn{flex:none}
@media (max-width:680px){
  .entry-cta{flex-direction:column;align-items:flex-start}
  .entry-cta .btn{width:100%;justify-content:center}
}

@media (max-width:820px){
  .entry,.entry--lead{grid-template-columns:1fr;gap:18px;align-items:start}
  .entry-thumb,.entry--lead .entry-thumb{aspect-ratio:16/9}
  .entry--lead .entry-title{font-size:var(--h3)}
}

/* related-posts grid cards (reused in article + case templates) */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;max-width:var(--maxw);margin-inline:auto}
.post-card{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--surf);
  transition:transform .25s ease,box-shadow .3s ease,border-color .25s ease}
.post-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--line-2)}
.post-card .ph{position:relative;aspect-ratio:16/9;overflow:hidden;background:#0a0713}
.post-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.post-card:hover .ph img{transform:scale(1.04)}
.post-body{padding:20px 20px 22px;display:flex;flex-direction:column;flex:1}
.post-body .post-meta{margin-bottom:11px}
.post-body h3{font-size:19px;line-height:1.22;margin:0 0 10px;letter-spacing:-.01em}
.post-body h3 a:hover{color:var(--hl)}
.post-body p{margin:0 0 16px;font-size:15px;color:var(--ink-2);line-height:1.55}
.post-body .text-link{margin-top:auto;font-size:15px}

/* =========================================================
   ARTICLE — prose typography
   ========================================================= */
.article{padding:clamp(10px,2vw,24px) 4vw clamp(56px,8vw,96px)}
.article-hero{max-width:940px;margin:0 auto clamp(28px,4vw,46px);border-radius:18px;overflow:hidden;border:1px solid var(--line);aspect-ratio:16/8}
.article-hero img{width:100%;height:100%;object-fit:cover}
.article-wrap{max-width:740px;margin-inline:auto}
.article-meta{display:flex;flex-wrap:wrap;gap:14px;align-items:center;font-family:var(--mono);font-size:15px;color:var(--muted);margin:0 0 30px}
.article-meta .author{display:inline-flex;align-items:center;gap:8px;color:var(--ink-2)}
.article-meta .author img{width:26px;height:26px;border-radius:50%;object-fit:cover;border:1px solid var(--line-2)}

.prose{font-size:18px;line-height:1.75;color:var(--ink-2)}
.prose>*+*{margin-top:1.15em}
.prose h2{font-size:clamp(24px,3vw,33px);color:var(--ink);margin-top:1.85em;line-height:1.14;letter-spacing:-.02em}
.prose h3{font-size:clamp(19px,2.3vw,23px);color:var(--ink);margin-top:1.5em}
.prose h2:first-child,.prose h3:first-child{margin-top:0}
.prose p{margin:0}
.prose a{color:var(--hl);text-decoration:underline;text-decoration-color:var(--line-2);text-underline-offset:3px;transition:text-decoration-color .15s ease}
.prose a:hover{text-decoration-color:var(--accent)}
.prose strong{color:var(--ink);font-weight:700}
.prose ul,.prose ol{margin:0;padding-left:1.3em;display:grid;gap:.5em}
.prose li{padding-left:.2em}
.prose li::marker{color:var(--accent)}
.prose blockquote{margin:1.6em 0;padding:18px 22px;border-left:3px solid var(--accent);background:var(--surf);border-radius:0 12px 12px 0;color:var(--ink);font-size:17px}
.prose blockquote p{margin:0}
.prose img{border-radius:14px;border:1px solid var(--line)}

/* in-article callout (mini case studies) */
.callout{margin:1.8em 0;padding:22px 24px;border:1px solid var(--line-2);border-radius:16px;background:var(--surf);position:relative;overflow:hidden}
.callout::before{content:"";position:absolute;top:-30%;right:-12%;width:46%;height:80%;pointer-events:none;background:radial-gradient(closest-side,var(--accent-soft),transparent)}
.callout>*{position:relative}
.callout .kick{margin-bottom:10px}
.callout :last-child{margin-bottom:0}

/* article footer CTA */
.article-cta{max-width:740px;margin:clamp(40px,6vw,72px) auto 0;padding:clamp(28px,3vw,42px);border:1px solid var(--accent);border-radius:var(--r);
  background:var(--surf);position:relative;overflow:hidden;text-align:center}
.article-cta::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(80% 70% at 50% 0%,var(--accent-soft),transparent 70%)}
.article-cta>*{position:relative}
.article-cta h3{font-size:var(--h3);margin-bottom:12px}
.article-cta p{margin:0 auto 22px;color:var(--ink-2);max-width:48ch}

/* related posts band */
.related{padding:clamp(48px,7vw,88px) 4vw;border-top:1px solid var(--line);background:var(--tint)}
.related-head{max-width:var(--maxw);margin:0 auto clamp(24px,3vw,36px)}
.related-head h2{font-size:var(--h2)}

/* =========================================================
   CASE STUDY
   ========================================================= */
.case{padding:clamp(8px,2vw,20px) 4vw clamp(56px,8vw,96px)}
.case-wrap{max-width:940px;margin-inline:auto}
.case-shot{border-radius:18px;overflow:hidden;border:1px solid var(--line);margin-bottom:clamp(28px,4vw,44px);aspect-ratio:16/9}
.case-shot img{width:100%;height:100%;object-fit:cover}
.case-meta{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:clamp(28px,3vw,40px)}
.case-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:clamp(30px,4vw,48px) auto;max-width:940px}
.case-stat{padding:26px 22px;border:1px solid var(--line);border-radius:16px;background:var(--surf);text-align:center}
.case-stat b{display:block;font-size:clamp(28px,4.4vw,44px);color:var(--accent);font-weight:700;letter-spacing:-.03em;line-height:1}
.case-stat span{display:block;margin-top:9px;font-size:15px;color:var(--muted);line-height:1.4}
.case-body{max-width:720px;margin-inline:auto}
/* before / after compare slider for redesign case studies */
.ba{position:relative;border-radius:18px;overflow:hidden;background:#0a0713;aspect-ratio:16/10;margin-bottom:14px;box-shadow:var(--shadow);--pos:42%;touch-action:none}
.ba-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top;user-select:none;-webkit-user-drag:none}
.ba-top{clip-path:inset(0 calc(100% - var(--pos)) 0 0)}
.ba-tag{position:absolute;top:14px;z-index:3;font-family:var(--mono);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:5px 11px;border-radius:100px;pointer-events:none}
.ba-before{left:14px;background:rgba(8,5,16,.66);color:#fff;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.ba-after{right:14px;background:rgba(8,5,16,.66);color:#fff;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.ba-divider{position:absolute;top:0;bottom:0;left:var(--pos);width:2px;background:rgba(255,255,255,.7);z-index:4;pointer-events:none;transform:translateX(-1px)}
.ba-knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;border-radius:50%;background:rgba(13,10,24,.82);border:1px solid rgba(255,255,255,.38);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 8px 22px rgba(0,0,0,.55);display:grid;place-items:center}
.ba-knob::after{content:"\21C4";color:#fff;font-size:17px;font-weight:700;line-height:1}
.ba-range{position:absolute;inset:0;z-index:5;width:100%;height:100%;margin:0;padding:0;cursor:ew-resize;opacity:0;-webkit-appearance:none;appearance:none;background:transparent}
.ba-range::-webkit-slider-thumb{-webkit-appearance:none;width:50px;height:100%}
.ba-range::-moz-range-thumb{width:50px;height:100%;border:0;background:transparent}
.ba-range:focus-visible{outline:none}
.ba-range:focus-visible+.ba-tag,.ba:focus-within .ba-knob{box-shadow:0 0 0 4px rgba(124,92,245,.4),0 8px 22px rgba(0,0,0,.55)}
.ba-hint{text-align:center;font-family:var(--mono);font-size:13px;color:var(--muted);margin:0 0 18px}
.ba-live{text-align:center;margin:0 0 clamp(30px,4vw,46px)}

@media (max-width:980px){
  .post-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .faq{grid-template-columns:1fr;gap:14px}
}
@media (max-width:680px){
  .post-grid{grid-template-columns:1fr}
  .case-stats{grid-template-columns:1fr}
  .prose{font-size:17px}
}

/* =========================================================
   WORK LISTING — editorial horizontal case rows (alternating)
   ========================================================= */
/* /work listing reuses the blog .journal / .entry index styles */
