:root{
  --ink:#17120E; --ink-2:#1F1813; --ink-3:#2A2018;
  --ember:#EA4E1B; --ember-soft:#F2734A; --ember-deep:#B83410;
  --bone:#F4F0E7; --bone-dim:#C9C1B2; --umber:#5A2C16;
  --line:rgba(244,240,231,.10);
  --display:'Chakra Petch',sans-serif; --ui:'Outfit',sans-serif; --body:'Work Sans',sans-serif;
  --maxw:1200px;
}
*{margin:0;padding:0;box-sizing:border-box;min-width:0}
html,body{overflow-x:hidden;max-width:100%}
html{scroll-behavior:smooth}
body{background:var(--ink);color:var(--bone);font-family:var(--body);line-height:1.6;-webkit-font-smoothing:antialiased}
img,video,canvas,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,p,span,a,b{overflow-wrap:break-word}
h1,h2,h3{font-family:var(--display);font-weight:700;line-height:1.05;letter-spacing:-.01em}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--ui);font-weight:600;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ember-soft);margin-bottom:18px;display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--ember)}
.ember-text{color:var(--ember)}

/* buttons */
.btn{font-family:var(--ui);font-weight:600;font-size:.98rem;padding:15px 26px;border-radius:999px;display:inline-flex;align-items:center;gap:9px;cursor:pointer;border:1px solid transparent;transition:transform .25s ease, box-shadow .25s ease, background .25s ease;will-change:transform}
.btn-primary{background:var(--ember);color:#fff;box-shadow:0 8px 28px -8px rgba(234,78,27,.6)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 36px -8px rgba(234,78,27,.75)}
.btn-ghost{background:transparent;color:var(--bone);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ember);color:var(--ember-soft);transform:translateY(-2px)}

/* nav */
header{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .3s ease, backdrop-filter .3s ease, border-color .3s ease;border-bottom:1px solid transparent}
header.scrolled{background:rgba(23,18,14,.78);backdrop-filter:blur(14px);border-bottom-color:var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.nav .logo{display:flex;align-items:center;height:100%}
.nav .logo img{height:48px;width:auto;position:relative;top:7px}
.nav-links{display:flex;align-items:center;gap:34px;font-family:var(--ui);font-weight:500;font-size:.95rem}
.nav-links a{color:var(--bone-dim);transition:color .2s}
.nav-links a:hover{color:var(--bone)}
.nav .btn{padding:11px 20px;font-size:.9rem}
.nav-toggle{display:none;background:none;border:0;color:var(--bone);font-size:1.6rem;cursor:pointer}
@media(max-width:860px){
  .nav-links{position:fixed;inset:76px 0 auto 0;flex-direction:column;background:rgba(23,18,14,.97);backdrop-filter:blur(14px);padding:28px 24px 34px;gap:22px;border-bottom:1px solid var(--line);transform:translateY(-120%);transition:transform .35s ease;align-items:flex-start}
  .nav-links.open{transform:translateY(0)}
  .nav-toggle{display:block}
}
@media(max-width:520px){.nav .logo img{height:44px}}

/* hero */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;padding:98px 0 56px}
#fox-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:1}
.hero-glow{position:absolute;z-index:0;width:60vw;height:60vw;max-width:760px;max-height:760px;right:-10%;top:8%;background:radial-gradient(circle,rgba(234,78,27,.22),transparent 62%);filter:blur(20px);pointer-events:none}
.hero-glow.b{left:-15%;top:auto;bottom:-10%;width:50vw;height:50vw;background:radial-gradient(circle,rgba(90,44,22,.5),transparent 65%)}
.hero-inner{position:relative;z-index:2;width:100%}
.hero h1{font-size:clamp(2.6rem,7vw,5.4rem);max-width:14ch;margin:18px 0 0}
.hero h1 .ember-text{display:inline-block}
.hero p.sub{font-family:var(--ui);font-size:clamp(1.02rem,2vw,1.28rem);color:var(--bone-dim);max-width:46ch;margin:26px 0 0;line-height:1.55}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px}
.hero-trust{margin-top:30px;font-family:var(--ui);font-size:.9rem;color:var(--bone-dim);letter-spacing:.02em;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.hero-trust .dot{width:5px;height:5px;border-radius:50%;background:var(--ember)}
.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;font-family:var(--ui);font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:var(--bone-dim);display:flex;flex-direction:column;align-items:center;gap:8px;opacity:.8}
.scroll-hint span.line{width:1px;height:34px;background:linear-gradient(var(--ember),transparent);animation:scrollpulse 2s ease-in-out infinite}
@keyframes scrollpulse{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}
@media(max-height:820px){.hero{align-items:flex-start}.hero h1{font-size:clamp(2.2rem,5vw,4.1rem)}.hero p.sub{margin-top:16px}.hero-cta{margin-top:26px}.hero-trust{margin-top:18px}}

/* sections */
section{position:relative}
.section-pad{padding:clamp(80px,12vh,140px) 0}
.sec-head{max-width:62ch}
.sec-head h2{font-size:clamp(2rem,4.6vw,3.4rem);margin-top:6px}
.sec-head p.lead{font-family:var(--ui);color:var(--bone-dim);font-size:clamp(1.02rem,1.6vw,1.18rem);margin-top:20px;line-height:1.6}

/* journey foxes — the fox guides you down the page */
.journey-fox{width:clamp(125px,15vw,190px);height:auto;pointer-events:none;filter:drop-shadow(0 16px 28px rgba(0,0,0,.55));animation:foxbob 4.6s ease-in-out infinite;transform-origin:bottom center}
@keyframes foxbob{0%,100%{transform:translateY(0) rotate(-1.6deg)}50%{transform:translateY(-12px) rotate(1.6deg)}}
.journey-fox.flip{animation-name:foxbobflip}
@keyframes foxbobflip{0%,100%{transform:scaleX(-1) translateY(0) rotate(1.6deg)}50%{transform:scaleX(-1) translateY(-12px) rotate(-1.6deg)}}
.fox-slot{flex:0 0 auto;display:flex;justify-content:center}
.fox-slot.center{justify-content:center;margin-bottom:24px}
.head-fox{display:flex;align-items:center;gap:clamp(24px,4vw,56px)}
.head-fox.right{flex-direction:row-reverse}
.head-fox .sec-head{flex:1;margin:0}
.foot-fox{position:absolute;right:8%;top:-44px;z-index:2}
.foot-fox .journey-fox{width:clamp(110px,11vw,150px)}
@media(max-width:760px){
  .head-fox,.head-fox.right{flex-direction:column;align-items:flex-start;gap:18px}
  .head-fox .fox-slot{align-self:center}
  .journey-fox{width:clamp(130px,34vw,170px)}
  .foot-fox{position:static;justify-content:center;margin:0 auto 26px}
}

/* stats celebrate fox — glows behind the numbers */
.stats-wrap{position:relative}
.stats-fox{position:absolute;left:50%;top:50%;transform:translate(-50%,-52%);height:clamp(250px,46vw,400px);width:auto;opacity:.15;z-index:0;pointer-events:none;animation:statsfoxfloat 6s ease-in-out infinite}
@keyframes statsfoxfloat{0%,100%{transform:translate(-50%,-52%)}50%{transform:translate(-50%,-57%)}}
.stats-grid{position:relative;z-index:1}

/* ladder */
.ladder{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:54px}
.ladder .step{background:linear-gradient(160deg,var(--ink-2),var(--ink));border:1px solid var(--line);border-radius:18px;padding:32px 28px;position:relative;overflow:hidden;transition:transform .3s ease,border-color .3s ease}
.ladder .step:hover{transform:translateY(-5px);border-color:rgba(234,78,27,.4)}
.ladder .step .num{font-family:var(--display);font-weight:700;font-size:2.4rem;color:var(--ember);opacity:.9}
.ladder .step h3{font-size:1.32rem;margin:14px 0 10px}
.ladder .step p{font-family:var(--ui);color:var(--bone-dim);font-size:.98rem}
.ladder .step::after{content:"";position:absolute;right:-30px;bottom:-30px;width:120px;height:120px;background:radial-gradient(circle,rgba(234,78,27,.14),transparent 70%)}
@media(max-width:820px){.ladder{grid-template-columns:1fr}}

/* services */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:20px;overflow:hidden;margin-top:54px}
.service{background:var(--ink);padding:38px 32px;transition:background .3s ease;position:relative}
.service:hover{background:var(--ink-2)}
.service .ico{width:42px;height:42px;border-radius:11px;background:rgba(234,78,27,.12);display:flex;align-items:center;justify-content:center;margin-bottom:22px}
.service .ico svg{width:22px;height:22px;stroke:var(--ember);fill:none;stroke-width:1.8}
.service h3{font-size:1.28rem;margin-bottom:11px}
.service p{font-family:var(--ui);color:var(--bone-dim);font-size:.96rem}
@media(max-width:820px){.services-grid{grid-template-columns:1fr}}

/* why us — fox struts in: behind text -> right of it (desktop), band above text (mobile) */
.why-section{position:relative;overflow:hidden;min-height:500px;display:flex;align-items:center}
.fox-stage{position:absolute;inset:0;z-index:0;pointer-events:none}
#foxWalkSrc{display:none}
.fox-key{position:absolute;right:-1%;top:50%;transform:translateY(-50%);width:64%;height:auto;aspect-ratio:16/9;max-width:none}
.fox-stance-fallback{display:none;position:absolute;right:3%;top:50%;transform:translateY(-50%);height:84%;width:auto;max-width:44%}
.fox-stage .flakes{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none}
.why{position:relative;z-index:2}
.why-text{max-width:560px}
.why-points{margin-top:40px;display:grid;gap:22px}
.why-point{display:flex;gap:16px;align-items:flex-start}
.why-point .tick{flex:0 0 auto;width:26px;height:26px;border-radius:7px;background:rgba(234,78,27,.14);display:flex;align-items:center;justify-content:center;margin-top:2px}
.why-point .tick svg{width:14px;height:14px;stroke:var(--ember);fill:none;stroke-width:2.4}
.why-point h4{font-family:var(--ui);font-weight:700;font-size:1.05rem;margin-bottom:3px}
.why-point p{font-family:var(--ui);color:var(--bone-dim);font-size:.95rem}
@media(max-width:860px){
  .why-section{display:block;min-height:0}
  .fox-stage{position:relative;inset:auto;width:100%;aspect-ratio:16/9;height:auto;margin-bottom:6px}
  .fox-key{position:absolute;inset:0;width:100%;height:100%;transform:none;right:auto;top:auto;aspect-ratio:auto}
  .fox-stance-fallback{position:absolute;inset:0;width:100%;height:100%;max-width:none;transform:none;right:auto;top:auto;object-fit:contain}
  .why-text{max-width:none}
}

/* stats */
.stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:linear-gradient(180deg,var(--ink-2),var(--ink))}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stat .n{font-family:var(--display);font-weight:700;font-size:clamp(2.2rem,5vw,3.6rem);color:var(--bone);line-height:1}
.stat .n .ember-text{color:var(--ember)}
.stat .l{font-family:var(--ui);font-size:.92rem;color:var(--bone-dim);margin-top:10px;letter-spacing:.03em}
@media(max-width:880px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:34px 16px}}

/* testimonials */
.tcard{background:linear-gradient(160deg,var(--ink-2),var(--ink));border:1px solid var(--line);border-radius:18px;padding:28px 26px;display:flex;flex-direction:column;gap:18px}
.tcard p.quote{font-family:var(--ui);font-size:1.02rem;color:var(--bone);line-height:1.55}
.tcard .who{display:flex;align-items:center;gap:13px}
.avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(140deg,var(--ember),var(--umber));display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;color:#fff;font-size:1rem;flex:0 0 auto}
.who .meta b{font-family:var(--ui);font-weight:600;font-size:.96rem;display:block}
.who .meta span{font-family:var(--ui);font-size:.84rem;color:var(--bone-dim)}
.stars{color:var(--ember);letter-spacing:2px;font-size:.9rem}
.tfeatured{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:50px}
.tfeatured .tcard:nth-child(1),.tfeatured .tcard:nth-child(6){grid-column:span 2}
@media(max-width:980px){.tfeatured{grid-template-columns:repeat(2,1fr)}.tfeatured .tcard:nth-child(1),.tfeatured .tcard:nth-child(6){grid-column:span 2}}
@media(max-width:620px){.tfeatured{grid-template-columns:1fr}.tfeatured .tcard{grid-column:span 1!important}}
.wall{margin-top:24px;overflow:hidden;position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.wall-track{display:flex;gap:16px;width:max-content;animation:marquee 38s linear infinite}
.wall:hover .wall-track{animation-play-state:paused}
.chip{background:var(--ink-2);border:1px solid var(--line);border-radius:999px;padding:13px 22px;font-family:var(--ui);font-size:.92rem;color:var(--bone-dim);white-space:nowrap;display:flex;align-items:center;gap:10px}
.chip b{color:var(--bone);font-weight:600}
@keyframes marquee{to{transform:translateX(-50%)}}

/* showcase: websites we build */
.showcase{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:54px}
.shot{position:relative;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--ink-2);transition:transform .35s ease,border-color .35s ease}
.shot:hover{transform:translateY(-5px);border-color:rgba(234,78,27,.45)}
.shot .frame{position:relative;overflow:hidden;aspect-ratio:16/10;background:#0d0a08}
.shot .frame img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.shot:hover .frame img{transform:scale(1.05)}
.shot .meta{padding:18px 20px 20px}
.shot .meta .tag{font-family:var(--ui);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ember-soft)}
.shot .meta h3{font-size:1.18rem;margin-top:5px}
.shot .meta p{font-family:var(--ui);font-size:.92rem;color:var(--bone-dim);margin-top:6px}
@media(max-width:760px){.showcase{grid-template-columns:1fr}}

/* capabilities */
.caps{margin-top:60px;display:grid;gap:26px}
.cap{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center;background:linear-gradient(160deg,var(--ink-2),var(--ink));border:1px solid var(--line);border-radius:22px;padding:34px;overflow:hidden}
.cap:nth-child(even) .cap-media{order:2}
.cap-media{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3;background:#0d0a08}
.cap-media.phone{aspect-ratio:3/4;max-width:300px;margin:0 auto}
.cap-media img{width:100%;height:100%;object-fit:cover}
.cap-media .haze{position:absolute;inset:0;background:radial-gradient(circle at 70% 20%,rgba(234,78,27,.16),transparent 60%);pointer-events:none}
.cap-body .num{font-family:var(--display);font-weight:700;color:var(--ember);font-size:1.1rem;letter-spacing:.04em}
.cap-body h3{font-size:clamp(1.4rem,2.6vw,1.9rem);margin:8px 0 12px}
.cap-body p{font-family:var(--ui);color:var(--bone-dim);font-size:1rem;line-height:1.6}
.cap-body ul{list-style:none;margin-top:16px;display:grid;gap:9px}
.cap-body li{font-family:var(--ui);font-size:.95rem;color:var(--bone);display:flex;gap:10px;align-items:flex-start}
.cap-body li::before{content:"";flex:0 0 auto;width:7px;height:7px;border-radius:50%;background:var(--ember);margin-top:8px}
@media(max-width:760px){.cap{grid-template-columns:1fr;gap:24px;padding:24px}.cap:nth-child(even) .cap-media{order:0}.cap-media.phone{max-width:260px;aspect-ratio:3/4;margin:0 auto}}

/* niches */
.demos{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:54px}
.demo{position:relative;border-radius:22px;overflow:hidden;border:1px solid var(--line);background:var(--ink-2);aspect-ratio:9/16;display:flex;flex-direction:column;justify-content:flex-end;transition:transform .35s ease,border-color .35s ease}
.demo:hover{transform:translateY(-6px);border-color:rgba(234,78,27,.45)}
.demo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:transform .5s ease}
.demo:hover img{transform:scale(1.06)}
.demo .veil{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,transparent 35%,rgba(23,18,14,.45) 60%,rgba(23,18,14,.95))}
.demo .label{position:relative;z-index:2;padding:22px 22px 24px}
.demo .label .tag{font-family:var(--ui);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ember-soft)}
.demo .label h3{font-size:1.32rem;margin-top:6px}
.demo .label .view{font-family:var(--ui);font-size:.86rem;color:var(--bone-dim);margin-top:8px;display:inline-flex;gap:6px;align-items:center}
@media(max-width:880px){.demos{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.demos{grid-template-columns:1fr}.demo{aspect-ratio:4/3}}

/* CTA */
.cta{position:relative;overflow:hidden;background:linear-gradient(150deg,var(--ink-2),var(--ink));border:1px solid var(--line);border-radius:28px;padding:clamp(40px,7vw,80px);display:grid;grid-template-columns:1.4fr .6fr;align-items:center;gap:30px}
.cta .glow{position:absolute;right:-5%;top:-30%;width:50%;height:160%;background:radial-gradient(circle,rgba(234,78,27,.22),transparent 60%);filter:blur(10px)}
.cta-content{position:relative;z-index:2}
.cta h2{font-size:clamp(2rem,4.4vw,3.2rem)}
.cta p{font-family:var(--ui);color:var(--bone-dim);font-size:1.1rem;margin-top:18px;max-width:42ch}
.cta-btns{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px}
.cta-fox{position:relative;z-index:2;display:flex;justify-content:center}
.cta-fox img{max-height:310px;width:auto;filter:drop-shadow(0 24px 40px rgba(0,0,0,.5));animation:foxbob 4.6s ease-in-out infinite;transform-origin:bottom center}
@media(max-width:820px){.cta{grid-template-columns:1fr}.cta-fox{margin-top:8px}.cta-fox img{max-height:210px}}

/* footer */
footer{position:relative;padding:70px 0 40px;border-top:1px solid var(--line);margin-top:20px}
.foot-grid{display:flex;justify-content:space-between;flex-wrap:wrap;gap:34px}
.foot-brand img{height:52px;margin-bottom:18px}
.foot-brand p{font-family:var(--ui);color:var(--bone-dim);max-width:34ch;font-size:.95rem}
.foot-cols{display:flex;gap:64px;flex-wrap:wrap}
.foot-col h5{font-family:var(--ui);font-weight:600;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--bone-dim);margin-bottom:16px}
.foot-col a{display:block;font-family:var(--ui);color:var(--bone);font-size:.96rem;margin-bottom:11px;transition:color .2s}
.foot-col a:hover{color:var(--ember)}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;margin-top:54px;padding-top:26px;border-top:1px solid var(--line);font-family:var(--ui);font-size:.86rem;color:var(--bone-dim)}

/* reveal + per-section unfolds */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s cubic-bezier(.16,.84,.44,1),transform .8s cubic-bezier(.16,.84,.44,1),filter .8s ease;will-change:transform,opacity}
.shot.reveal{transform:translateY(48px) scale(.95)}
.demo.reveal{transform:translateY(42px) scale(.96)}
.service.reveal{transform:translateY(30px) scale(.97)}
.cap.reveal{transform:translateY(40px)}
.cap:nth-child(odd).reveal{transform:translateX(-46px)}
.cap:nth-child(even).reveal{transform:translateX(46px)}
.tcard.reveal{transform:translateY(30px) scale(.97)}
.ladder .step.reveal{transform:translateY(38px)}
.reveal.in{opacity:1!important;transform:none!important;filter:none!important}

/* ember hairline divider at the top of each content section */
.section-pad::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:clamp(80px,18vw,170px);height:1px;background:linear-gradient(90deg,transparent,rgba(234,78,27,.6),transparent);opacity:.7}
.stats.section-pad::before{content:none}

/* subtle alternating section atmosphere so each passes distinctly */
#services{background:radial-gradient(120% 80% at 100% 0,rgba(234,78,27,.05),transparent 60%)}
#capabilities{background:radial-gradient(120% 80% at 0 0,rgba(90,44,22,.20),transparent 55%)}
#why{background:radial-gradient(100% 90% at 82% 50%,rgba(234,78,27,.06),transparent 60%)}
#niches{background:radial-gradient(120% 80% at 100% 100%,rgba(234,78,27,.05),transparent 60%)}

@media(max-width:560px){.hero-trust{font-size:.82rem;gap:8px}.btn{padding:13px 20px;font-size:.92rem}.section-pad{padding:62px 0}}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;filter:none!important;transition:none}.wall-track{animation:none}.scroll-hint span.line{animation:none}.journey-fox,.cta-fox img,.stats-fox{animation:none}.fox-key{display:none}.fox-stance-fallback{display:block}}
