/* ---------- tokens ---------- */
:root{
  --paper:#FFFFFF;
  --paper-2:#F5F3EE;
  --cream:#F4F1EA;
  --ink:#0E1116;
  --ink-2:#2A2E36;
  --ink-3:#5B6068;
  --violet:#5B3BFF;
  --solar:#FF6A1F;
  --line:rgba(14,17,22,.10);
  --line-2:rgba(14,17,22,.18);
  --maxw:1280px;
  --pad:clamp(20px, 4vw, 56px);
  --radius:18px;
  --radius-lg:28px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.mono{font-family:'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace; letter-spacing:.02em}
.eyebrow{
  font-family:'JetBrains Mono', ui-monospace, monospace;
  font-size:12px; font-weight:500;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-3);
  display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{content:""; width:24px; height:1px; background:var(--ink-2); display:inline-block}
h1,h2,h3{margin:0; font-weight:600; letter-spacing:-.02em; line-height:1.05; text-wrap:balance}
p{margin:0; text-wrap:pretty}

.container{max-width:var(--maxw); margin:0 auto; padding:0 var(--pad)}
section{padding:clamp(80px, 10vw, 140px) 0; position:relative}

/* ---------- nav ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  padding:18px var(--pad);
  display:flex; align-items:center; justify-content:space-between;
  transition:background .25s ease, backdrop-filter .25s ease, box-shadow .25s ease, padding .25s ease;
}
.nav.scrolled{
  background:rgba(244,241,234,.78);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  box-shadow:0 1px 0 var(--line);
  padding:12px var(--pad);
}
.brand{display:flex; align-items:center; gap:10px}
.brand img{height:40px; width:auto}
@media (max-width: 520px){
  .brand img{height:34px}
}
.nav-links{display:flex; align-items:center; gap:4px}
.nav-links a:not(.cta){
  font-size:14px; font-weight:500; color:var(--ink-2);
  padding:8px 14px; border-radius:8px;
  transition:background .2s ease, color .2s ease;
}
.nav-links a:not(.cta):hover{background:rgba(14,17,22,.06); color:var(--ink)}
/* language selector */
.lang{
  display:inline-flex; align-items:center; gap:2px;
  margin:0 6px; padding:3px; height:36px; box-sizing:border-box;
  border:1px solid rgba(14,17,22,.18); border-radius:10px;
  font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.1em;
}
.lang a, .lang button{
  appearance:none; border:0; background:transparent; cursor:pointer;
  padding:0 12px; height:28px; border-radius:7px;
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--ink-3); font:inherit; letter-spacing:inherit;
  text-decoration:none;
  transition:background .2s ease, color .2s ease;
}
.lang a:hover, .lang button:hover{color:var(--ink)}
.lang a.active, .lang button.active{background:var(--ink); color:#fff}
body.hero-in-view .nav:not(.scrolled) .lang{border-color:rgba(255,255,255,.28)}
body.hero-in-view .nav:not(.scrolled) .lang a, body.hero-in-view .nav:not(.scrolled) .lang button{color:rgba(255,255,255,.7)}
body.hero-in-view .nav:not(.scrolled) .lang a:hover, body.hero-in-view .nav:not(.scrolled) .lang button:hover{color:#fff}
body.hero-in-view .nav:not(.scrolled) .lang a.active, body.hero-in-view .nav:not(.scrolled) .lang button.active{background:#fff; color:var(--ink)}
/* nav inverts over dark hero — direct-child selector skips .lang anchors so the active pill stays readable */
body.hero-in-view .nav:not(.scrolled) .nav-links > a:not(.cta){color:rgba(255,255,255,.78)}
body.hero-in-view .nav:not(.scrolled) .nav-links > a:not(.cta):hover{background:rgba(255,255,255,.08); color:#fff}
body.hero-in-view .nav:not(.scrolled) .cta{background:transparent; color:#fff; border-color:rgba(255,255,255,.28)}
body.hero-in-view .nav:not(.scrolled) .cta:hover{background:#fff; color:var(--ink); border-color:#fff}
body.hero-in-view .nav:not(.scrolled) .nav-toggle{color:#fff}
body.hero-in-view .nav:not(.scrolled) .brand img.logo-dark{display:none}
body.hero-in-view .nav:not(.scrolled) .brand img.logo-light{display:block}

.cta{
  display:inline-flex; align-items:center; gap:8px;
  background:transparent; color:var(--ink);
  padding:0 16px; height:36px; box-sizing:border-box;
  border-radius:10px;
  border:1px solid rgba(14,17,22,.18);
  font-size:13px; font-weight:500;
  transition:transform .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
}
.cta:hover{background:var(--ink); color:#fff; border-color:var(--ink); transform:translateY(-1px)}
.cta .dot{width:6px; height:6px; border-radius:50%; background:var(--solar)}
.nav-toggle{display:none; background:none; border:0; padding:8px; color:var(--ink); cursor:pointer}
.nav-toggle svg{width:24px; height:24px}

@media (max-width: 880px){
  .nav-links{
    position:fixed; inset:64px 16px auto 16px;
    flex-direction:column; align-items:stretch; gap:4px;
    /* FIX: dark, opaque dropdown so text is always readable on mobile */
    background:#0E1116;
    border:1px solid rgba(255,255,255,.08);
    border-radius:18px; padding:12px;
    box-shadow:0 24px 60px rgba(0,0,0,.45);
    transform-origin:top right;
    transform:scale(.95) translateY(-8px); opacity:0; pointer-events:none;
    transition:all .2s ease;
  }
  .nav-links.open{transform:none; opacity:1; pointer-events:auto}
  .nav-links a{padding:12px 14px; border-radius:12px}
  /* FIX: force readable colors regardless of hero state */
  .nav-links a:not(.cta),
  body.hero-in-view .nav:not(.scrolled) .nav-links a:not(.cta){
    color:rgba(255,255,255,.86);
  }
  .nav-links a:not(.cta):hover,
  body.hero-in-view .nav:not(.scrolled) .nav-links a:not(.cta):hover{
    background:rgba(255,255,255,.08); color:#fff;
  }
  .nav-links .lang,
  body.hero-in-view .nav:not(.scrolled) .nav-links .lang{
    align-self:center; margin:8px 0 4px;
    border-color:rgba(255,255,255,.22);
  }
  .nav-links .lang a, .nav-links .lang button,
  body.hero-in-view .nav:not(.scrolled) .nav-links .lang a,
  body.hero-in-view .nav:not(.scrolled) .nav-links .lang button{
    color:rgba(255,255,255,.7);
  }
  .nav-links .lang a.active, .nav-links .lang button.active,
  body.hero-in-view .nav:not(.scrolled) .nav-links .lang a.active,
  body.hero-in-view .nav:not(.scrolled) .nav-links .lang button.active{
    background:#fff; color:var(--ink);
  }
  .nav-links .cta,
  body.hero-in-view .nav:not(.scrolled) .nav-links .cta{
    justify-content:center; margin-top:6px;
    color:#fff; border-color:rgba(255,255,255,.3);
  }
  .nav-links .cta:hover,
  body.hero-in-view .nav:not(.scrolled) .nav-links .cta:hover{
    background:#fff; color:var(--ink); border-color:#fff;
  }
  .nav-toggle{display:inline-flex}
}

/* ---------- hero ---------- */
.hero{
  min-height:100vh;
  padding:120px var(--pad) 80px;
  position:relative;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  background:#0A0A0B;
  color:#fff;
}
/* base gradient — stays even when no video is set */
.hero::before{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse 60% 80% at 50% 100%, rgba(255,106,31,.32) 0%, rgba(255,106,31,.08) 30%, transparent 60%),
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(91,59,255,.18) 0%, transparent 55%),
    repeating-linear-gradient(90deg, rgba(255,255,255,.025) 0 1px, transparent 1px 80px),
    linear-gradient(180deg, #0A0A0B 0%, #0E0E10 60%, #15100C 100%);
}
/* dimming/contrast overlay applied above the video so it isn't too bright */
.hero::after{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:2;
  background:
    radial-gradient(ellipse 70% 60% at 30% 55%, rgba(0,0,0,.45), transparent 75%),
    linear-gradient(180deg, rgba(10,10,11,.35) 0%, rgba(10,10,11,.4) 60%, rgba(10,10,11,.55) 100%);
}
/* fullscreen background video */
.hero-video{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover;
  z-index:1;
  pointer-events:none;
}
.hero-copy{
  text-align:left;
  max-width:1100px; width:100%;
  margin:0; padding-right:clamp(20px,4vw,40px);
  position:relative; z-index:3; /* sits above ::after overlay */
}
.hero h1{
  font-size:clamp(44px, 9vw, 132px);
  font-weight:400;
  letter-spacing:-.04em;
  line-height:1.0;
}
.hero h1 .o{color:#fff}
.hero h1 .dot{color:var(--solar)}
.hero h1 .ital{font-style:italic; font-weight:400}

.hero h1 .w{
  display:inline-block;
  overflow:hidden;
  vertical-align:bottom;
  line-height:1;
}
.hero h1 .w > span{
  display:inline-block;
  transform:translateY(110%);
  opacity:0;
  transition:transform 1.05s cubic-bezier(.2,.7,.15,1), opacity .8s ease;
}
.hero.in h1 .w > span{transform:none; opacity:1}
.hero.in h1 .w:nth-child(1) > span{transition-delay:.05s}
.hero.in h1 .w:nth-child(2) > span{transition-delay:.13s}
.hero.in h1 .w:nth-child(3) > span{transition-delay:.21s}
.hero.in h1 .w:nth-child(4) > span{transition-delay:.29s}
.hero.in h1 .w:nth-child(5) > span{transition-delay:.37s}
.hero.in h1 .w:nth-child(6) > span{transition-delay:.45s}
.hero.in h1 .w:nth-child(7) > span{transition-delay:.53s}
.hero.in h1 .w:nth-child(8) > span{transition-delay:.61s}

.hero-sub{
  margin-top:32px;
  font-size:clamp(16px, 1.4vw, 20px);
  color:rgba(255,255,255,.65);
  max-width:560px;
  opacity:0; transform:translateY(14px);
  transition:opacity .8s ease .65s, transform .8s ease .65s;
}
.hero.in .hero-sub{opacity:1; transform:none}

.hero-meta{
  display:flex; justify-content:flex-start; gap:14px; margin-top:40px; flex-wrap:wrap;
  opacity:0; transform:translateY(14px);
  transition:opacity .8s ease .8s, transform .8s ease .8s;
}
.hero.in .hero-meta{opacity:1; transform:none}
.hero-meta a{
  font-size:15px; padding:14px 24px; border-radius:10px;
  border:1px solid rgba(255,255,255,.18); color:#fff;
  font-weight:500;
  transition:all .2s ease;
}
.hero-meta a:hover{background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.3)}
.hero-meta a.primary{
  background:#fff; color:#0A0A0B; border-color:#fff;
}
.hero-meta a.primary:hover{background:#f5f3ee; transform:translateY(-1px); border-color:#f5f3ee}

.hero-eyebrow{
  display:inline-flex; justify-content:flex-start;
  margin-bottom:32px;
  opacity:0; transform:translateY(8px);
  transition:opacity .6s ease, transform .6s ease;
}
.hero.in .hero-eyebrow{opacity:1; transform:none}

.scroll-cue{
  position:absolute;
  left:50%; bottom:24px;
  transform:translateX(-50%);
  z-index:3; /* keep above the overlay */
  font-family:'JetBrains Mono', monospace;
  font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink-3);
  display:flex; flex-direction:column; align-items:center; gap:8px;
  opacity:0;
  transition:opacity .8s ease 1.2s;
}
.hero.in .scroll-cue{opacity:.7}
.scroll-cue::after{
  content:""; width:1px; height:28px;
  background:linear-gradient(180deg, rgba(255,255,255,.5), transparent);
}
.hero .scroll-cue{color:rgba(255,255,255,.55)}
.nav .brand img.logo-light{display:none}

/* ---------- services ---------- */
.section-head{
  display:flex; justify-content:space-between; align-items:flex-end;
  gap:32px; margin-bottom:48px; flex-wrap:wrap;
}
.section-head h2{
  font-size:clamp(32px, 5vw, 64px);
  font-weight:600; letter-spacing:-.025em;
  max-width:18ch;
}
.section-head .h-meta{max-width:380px; color:var(--ink-3); font-size:15px}

.services-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  border-top:1px solid var(--line-2);
  border-left:1px solid var(--line-2);
}
.service{
  border-right:1px solid var(--line-2);
  border-bottom:1px solid var(--line-2);
  padding:36px 32px 32px;
  display:flex; flex-direction:column; gap:18px;
  background:transparent;
  transition:background .25s ease;
  position:relative;
  min-height:280px;
}
.service:hover{background:rgba(14,17,22,.025)}
.service .num{
  font-family:'JetBrains Mono', monospace;
  font-size:12px; color:var(--ink-3); letter-spacing:.18em;
}
.service h3{font-size:26px; letter-spacing:-.015em}
.service p{color:var(--ink-3); font-size:15px}
.service .tags{display:flex; flex-wrap:wrap; gap:8px; margin-top:auto; padding-top:14px}
.tag{
  font-family:'JetBrains Mono', monospace;
  font-size:11px; letter-spacing:.06em;
  padding:5px 10px; border:1px solid var(--line-2); border-radius:8px;
  color:var(--ink-2);
}
.service .icon{
  width:44px; height:44px; border-radius:12px;
  background:var(--paper-2);
  display:grid; place-items:center;
  color:var(--ink);
}
.service .icon svg{width:22px; height:22px}
.service.accent .icon{background:var(--ink); color:var(--paper)}
@media (max-width: 720px){
  .services-grid{grid-template-columns:1fr}
}

/* ---------- about + metrics ---------- */
.about-grid{
  display:grid; gap:48px;
  grid-template-columns: 1.2fr 1fr;
  align-items:start;
}
.about-grid h2{font-size:clamp(32px, 4.5vw, 56px)}
.about-grid .lede{
  font-size:clamp(20px, 1.8vw, 26px);
  color:var(--ink-2);
  max-width:30ch;
  line-height:1.3;
  letter-spacing:-.01em;
}
.about-grid .lede em{font-style:italic; color:var(--violet); font-weight:400}
.about-body{display:flex; flex-direction:column; gap:18px; color:var(--ink-2); font-size:16px; padding-top:8px}
.about-body p{max-width:52ch}

.metrics{
  margin-top:80px;
  display:grid; grid-template-columns:repeat(4, 1fr);
  border-top:1px solid var(--line-2);
}
.metric{
  padding:32px 24px 28px;
  border-right:1px solid var(--line-2);
  display:flex; flex-direction:column; gap:6px;
}
.metric:last-child{border-right:0}
.metric .num{
  font-size:clamp(40px, 5vw, 64px);
  font-weight:500; letter-spacing:-.03em; line-height:1;
}
.metric .num .unit{color:var(--solar); font-weight:500}
.metric .lbl{
  font-family:'JetBrains Mono', monospace;
  font-size:12px; letter-spacing:.16em; color:var(--ink-3); text-transform:uppercase;
  margin-top:8px;
}
@media (max-width: 880px){
  .about-grid{grid-template-columns:1fr; gap:24px}
  .metrics{grid-template-columns:repeat(2, 1fr)}
  .metric:nth-child(2){border-right:0}
  .metric:nth-child(1), .metric:nth-child(2){border-bottom:1px solid var(--line-2)}
}

/* ---------- CTA strip ---------- */
.cta-strip{
  margin:0 var(--pad);
  background:var(--ink); color:var(--paper);
  border-radius:var(--radius-lg);
  padding:clamp(48px, 7vw, 96px) clamp(28px, 5vw, 72px);
  display:grid; grid-template-columns:1.4fr 1fr; gap:40px; align-items:center;
  position:relative; overflow:hidden;
}
.cta-strip::before{
  content:""; position:absolute; right:-10%; top:-30%;
  width:60%; height:160%;
  background:radial-gradient(circle at 50% 50%, rgba(91,59,255,.55), transparent 60%);
  pointer-events:none;
}
.cta-strip::after{
  content:""; position:absolute; right:8%; bottom:-30%;
  width:36%; height:120%;
  background:radial-gradient(circle, rgba(255,106,31,.45), transparent 60%);
  pointer-events:none;
}
.cta-strip h2{
  font-size:clamp(32px, 4.5vw, 64px);
  font-weight:500; letter-spacing:-.025em;
  position:relative; z-index:1;
}
.cta-strip h2 .ital{font-style:italic; font-weight:300}
.cta-strip .sub{color:rgba(244,241,234,.75); margin-top:18px; max-width:48ch; position:relative; z-index:1}
.cta-strip .actions{display:flex; flex-direction:column; gap:12px; align-items:flex-start; position:relative; z-index:1}
.cta-strip .btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 22px; border-radius:10px;
  background:var(--paper); color:var(--ink);
  font-weight:500; font-size:15px;
  transition:transform .2s ease;
}
.cta-strip .btn:hover{transform:translateY(-2px)}
.cta-strip .ghost{
  background:transparent; color:var(--paper);
  border:1px solid rgba(244,241,234,.3);
}
@media (max-width: 880px){
  .cta-strip{grid-template-columns:1fr; gap:24px}
}

/* ---------- work / portfolio ---------- */
.work-grid{
  display:grid; gap:24px;
  grid-template-columns:repeat(12, 1fr);
}
.project{
  grid-column:span 6;
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--paper-2);
  border:1px solid var(--line);
  display:flex; flex-direction:column;
  transition:transform .25s ease, box-shadow .25s ease;
}
.project:hover{transform:translateY(-4px); box-shadow:0 18px 40px -10px rgba(14,17,22,.12)}
.project.wide{grid-column:span 12}
.project.third{grid-column:span 4}
.project .thumb{
  aspect-ratio: 16/10;
  position:relative;
  overflow:hidden;
  background:#1a1d24;
}
.project.wide .thumb{aspect-ratio: 16/6}
.project.third .thumb{aspect-ratio:4/5}
.project .thumb svg, .project .thumb img{width:100%; height:100%; display:block; object-fit:cover}
.project .meta{
  padding:20px 22px 22px;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  background:var(--paper);
}
.project .meta h3{font-size:18px; font-weight:600; letter-spacing:-.01em}
.project .meta .cat{font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.16em; color:var(--ink-3); text-transform:uppercase}
.project .meta .arrow{
  width:36px; height:36px; border-radius:50%;
  border:1px solid var(--line-2);
  display:grid; place-items:center; color:var(--ink);
  flex:none;
}
@media (max-width: 880px){
  .project, .project.wide, .project.third{grid-column:span 12}
}

/* ---------- value props ---------- */
.values{
  display:grid; gap:0;
  grid-template-columns:repeat(3, 1fr);
  border-top:1px solid var(--line-2);
}
.value{
  padding:36px 28px;
  border-right:1px solid var(--line-2);
  display:flex; flex-direction:column; gap:14px;
}
.value:last-child{border-right:0}
.value .v-num{
  font-family:'JetBrains Mono', monospace;
  font-size:12px; color:var(--ink-3); letter-spacing:.16em;
}
.value h3{font-size:22px; letter-spacing:-.015em; font-weight:600}
.value p{color:var(--ink-3); font-size:15px}
@media (max-width: 880px){
  .values{grid-template-columns:1fr}
  .value{border-right:0; border-bottom:1px solid var(--line-2)}
  .value:last-child{border-bottom:0}
}

/* ---------- contact ---------- */
.contact-grid{
  display:grid; gap:48px;
  grid-template-columns: 1fr 1.1fr;
  align-items:start;
}
.contact-grid h2{font-size:clamp(32px, 4.5vw, 56px); margin-bottom:18px}
.contact-grid .c-sub{color:var(--ink-3); margin-bottom:28px; max-width:38ch}
.contact-info{display:flex; flex-direction:column; gap:18px; padding-top:8px}
.info-row{display:flex; flex-direction:column; gap:4px}
.info-row .lbl{font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.16em; color:var(--ink-3); text-transform:uppercase}
.info-row .val{font-size:18px; color:var(--ink); font-weight:500}

form.contact{
  display:grid; gap:18px;
  background:var(--paper-2);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:32px;
}
form.contact .row{display:grid; grid-template-columns:1fr 1fr; gap:18px}
form.contact .field{display:flex; flex-direction:column; gap:6px}
form.contact label{
  font-family:'JetBrains Mono', monospace;
  font-size:11px; letter-spacing:.16em; color:var(--ink-3); text-transform:uppercase;
}
form.contact input, form.contact textarea, form.contact select{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:12px;
  padding:14px 16px;
  font:inherit; color:var(--ink);
  transition:border-color .2s ease, box-shadow .2s ease;
}
form.contact input:focus, form.contact textarea:focus, form.contact select:focus{
  outline:none;
  border-color:var(--ink);
  box-shadow:0 0 0 4px rgba(91,59,255,.12);
}
form.contact textarea{min-height:120px; resize:vertical}
form.contact button{
  appearance:none; border:0; cursor:pointer;
  background:var(--ink); color:var(--paper);
  padding:16px 22px; border-radius:10px;
  font:inherit; font-weight:500;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  transition:background .2s ease, transform .2s ease;
  justify-self:start;
}
form.contact button:hover{background:var(--violet); transform:translateY(-1px)}
form.contact button[disabled]{opacity:.65; cursor:not-allowed}
form.contact .dot{width:6px; height:6px; border-radius:50%; background:var(--solar)}
form.contact .form-msg{font-size:14px; padding:10px 14px; border-radius:10px; display:none}
form.contact .form-msg.success{display:block; background:rgba(91,59,255,.08); color:var(--violet)}
form.contact .form-msg.error{display:block; background:rgba(220,40,40,.08); color:#b3261e}
.honey{position:absolute !important; left:-9999px !important; width:1px !important; height:1px !important; opacity:0 !important; pointer-events:none !important}
@media (max-width: 880px){
  .contact-grid{grid-template-columns:1fr}
  form.contact .row{grid-template-columns:1fr}
}

/* ---------- footer ---------- */
footer.site-footer{
  background:var(--ink); color:var(--paper);
  padding:64px var(--pad) 32px;
  margin-top:0;
}
.footer-inner{
  max-width:var(--maxw); margin:0 auto;
  display:grid; gap:40px;
  grid-template-columns:1.3fr repeat(3, 1fr);
}
.footer-inner h4{
  font-family:'JetBrains Mono', monospace;
  font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(244,241,234,.5);
  margin:0 0 16px; font-weight:500;
}
.footer-inner ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px}
.footer-inner a{color:rgba(244,241,234,.85); font-size:15px; transition:color .2s ease}
.footer-inner a:hover{color:var(--paper)}
.footer-brand img{height:44px; width:auto; margin-bottom:20px}
.footer-brand p{color:rgba(244,241,234,.6); font-size:14px; max-width:30ch}
.footer-bottom{
  max-width:var(--maxw); margin:48px auto 0;
  border-top:1px solid rgba(244,241,234,.12);
  padding-top:24px;
  display:flex; justify-content:space-between; align-items:center;
  color:rgba(244,241,234,.5); font-size:13px;
  font-family:'JetBrains Mono', monospace; letter-spacing:.06em;
  flex-wrap:wrap; gap:12px;
}
@media (max-width: 880px){
  .footer-inner{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:span 2}
}
@media (max-width: 520px){
  .footer-inner{grid-template-columns:1fr}
  .footer-brand{grid-column:auto}
}

/* reveal-on-scroll */
.reveal{opacity:0; transform:translateY(18px); transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1; transform:none}

@media (prefers-reduced-motion: reduce){
  *{transition:none !important; animation:none !important}
  .hero h1 .w > span{transform:none; opacity:1}
  .hero-sub, .hero-meta, .hero-eyebrow, .scroll-cue{opacity:1; transform:none}
}
