/* ===========================================================
   J&O DIGITAL CREATIONS — "Liquid Cobalt" shared stylesheet
   =========================================================== */
:root{
  --white:#ffffff;
  --paper:#eef2fe;
  --paper2:#e3ebff;
  --ink:#05091c;
  --ink-soft:#3a4366;
  --cobalt:#1452ff;
  --cobalt-deep:#0a36c9;
  --azure:#4d86ff;
  --sky:#9cc0ff;
  --line:rgba(8,28,90,.12);
  --glass:rgba(255,255,255,.6);
  --shadow:0 30px 80px -30px rgba(11,52,201,.45);
  --maxw:1480px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
body{background:var(--white);color:var(--ink);font-family:"Satoshi",system-ui,sans-serif;font-size:18px;line-height:1.55;overflow-x:hidden;cursor:none}
@media (max-width:760px){body{cursor:auto}}
::selection{background:var(--cobalt);color:#fff}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
h1,h2,h3{font-family:"Clash Display",sans-serif;font-weight:600;line-height:.96;letter-spacing:-.02em}
.mono{font-family:"Martian Mono",monospace;text-transform:uppercase;letter-spacing:.18em;font-size:11px;font-weight:500}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,72px)}
section{position:relative}
.cobalt{color:var(--cobalt)}

/* grain */
.grain{position:fixed;inset:0;z-index:9000;pointer-events:none;opacity:.04;mix-blend-mode:multiply;
  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='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* cursor */
.cur{position:fixed;top:0;left:0;width:10px;height:10px;border-radius:50%;background:var(--cobalt);z-index:9999;pointer-events:none;transform:translate(-50%,-50%);mix-blend-mode:multiply}
.cur-ring{position:fixed;top:0;left:0;width:42px;height:42px;border:1px solid var(--cobalt);border-radius:50%;z-index:9999;pointer-events:none;transform:translate(-50%,-50%);transition:width .3s,height .3s,background .3s,opacity .3s;opacity:.5}
.cur-ring.hot{width:74px;height:74px;background:rgba(20,82,255,.08);opacity:1}
@media (max-width:760px){.cur,.cur-ring{display:none}}

/* preloader */
#pre{position:fixed;inset:0;z-index:10000;background:var(--white);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:26px}
#pre .pmark{font-family:"Clash Display";font-weight:600;font-size:clamp(60px,12vw,150px);color:var(--ink);letter-spacing:-.03em}
#pre .pmark b{color:var(--cobalt)}
#pre .pbar{width:min(320px,70vw);height:2px;background:var(--line);position:relative;overflow:hidden}
#pre .pbar i{position:absolute;inset:0;width:0;background:var(--cobalt)}
#pre .pcount{font-family:"Martian Mono";font-size:12px;letter-spacing:.3em;color:var(--ink-soft)}

/* nav */
nav{position:fixed;top:0;left:0;right:0;z-index:8000;display:flex;align-items:center;justify-content:space-between;padding:18px clamp(20px,5vw,72px);transition:background .4s,box-shadow .4s,padding .4s}
nav.scrolled{background:rgba(255,255,255,.72);backdrop-filter:blur(18px);box-shadow:0 1px 0 var(--line);padding:12px clamp(20px,5vw,72px)}
nav .logo{font-family:"Clash Display";font-weight:600;font-size:24px;letter-spacing:-.02em}
nav .logo b{color:var(--cobalt)}
nav .nlinks{display:flex;gap:34px;align-items:center}
nav .nlinks a.nl{font-weight:500;font-size:15px;position:relative;padding:4px 0}
nav .nlinks a.nl::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--cobalt);transition:width .35s cubic-bezier(.2,.8,.2,1)}
nav .nlinks a.nl:hover::after,nav .nlinks a.nl.active::after{width:100%}
nav .nlinks a.nl.active{color:var(--cobalt)}
.btn{display:inline-flex;align-items:center;gap:10px;background:var(--cobalt);color:#fff;font-weight:700;font-size:15px;padding:13px 24px;border-radius:100px;position:relative;overflow:hidden;will-change:transform}
.btn span{position:relative;z-index:2}
.btn::before{content:"";position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:transform .45s cubic-bezier(.2,.8,.2,1)}
.btn:hover::before{transform:translateY(0)}
.btn.ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn.ghost::before{background:var(--cobalt)}
.btn.ghost:hover{color:#fff;border-color:var(--cobalt)}
.btn.big{padding:18px 34px;font-size:17px}
.btn.white{background:#fff;color:var(--ink)}
.btn.white::before{background:var(--cobalt)}
.btn.white:hover{color:#fff}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:8500}
.burger span{width:26px;height:2px;background:var(--ink);transition:.3s}
@media (max-width:880px){nav .nlinks{display:none}.burger{display:flex}}
#mmenu{position:fixed;inset:0;z-index:8200;background:var(--cobalt);color:#fff;display:flex;flex-direction:column;justify-content:center;padding:0 32px;gap:8px;transform:translateY(-100%);transition:transform .6s cubic-bezier(.76,0,.24,1)}
#mmenu.open{transform:translateY(0)}
#mmenu a{font-family:"Clash Display";font-size:clamp(38px,11vw,64px);font-weight:600;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.2)}
#mmenu .mcontact{margin-top:30px;font-family:"Martian Mono";font-size:12px;letter-spacing:.2em;opacity:.85;line-height:2.2}

/* hero (home) */
#hero{min-height:100svh;display:flex;align-items:flex-end;padding-bottom:6vh;position:relative;overflow:hidden}
#flow{position:absolute;inset:0;z-index:0}
.hero-glow{position:absolute;z-index:0;width:60vw;height:60vw;right:-15vw;top:-10vw;border-radius:50%;background:radial-gradient(circle,rgba(77,134,255,.30),transparent 65%);filter:blur(20px);pointer-events:none}
.hero-inner{position:relative;z-index:2;width:100%}
.hero-top{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:clamp(20px,4vw,46px);flex-wrap:wrap}
.hero-tag{max-width:340px;color:var(--ink-soft);font-size:16px;line-height:1.5}
.hero-tag .dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--cobalt);margin-right:8px;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(20,82,255,.5)}70%{box-shadow:0 0 0 8px rgba(20,82,255,0)}}
h1.hero-h{font-size:clamp(48px,11.5vw,200px);font-weight:600;letter-spacing:-.03em}
h1.hero-h .ln{display:block;overflow:hidden}
h1.hero-h .ln i{display:inline-block;font-style:normal}
h1.hero-h em{font-style:normal;color:var(--cobalt)}
.hero-video-chip{position:absolute;right:0;bottom:34%;width:clamp(150px,18vw,290px);aspect-ratio:16/10;border-radius:16px;overflow:hidden;box-shadow:var(--shadow);z-index:3;border:5px solid #fff}
.hero-video-chip video{width:100%;height:100%;object-fit:cover}
@media (max-width:980px){.hero-video-chip{position:relative;bottom:auto;right:auto;width:100%;margin-top:26px}}
.hero-bottom{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-top:clamp(24px,4vw,54px);flex-wrap:wrap}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.scroll-hint{font-family:"Martian Mono";font-size:10px;letter-spacing:.25em;color:var(--ink-soft);display:flex;align-items:center;gap:10px}
.scroll-hint .bar{width:40px;height:1px;background:var(--ink);position:relative;overflow:hidden}
.scroll-hint .bar::after{content:"";position:absolute;inset:0;background:var(--cobalt);animation:slide 2s infinite}
@keyframes slide{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

/* page hero (subpages) */
.phero{padding:clamp(140px,18vh,220px) 0 clamp(50px,7vw,90px);position:relative;overflow:hidden}
.phero .hero-glow{top:-20vw}
.phero .crumb{color:var(--cobalt);display:flex;align-items:center;gap:10px;margin-bottom:24px}
.phero .crumb::before{content:"";width:30px;height:1px;background:var(--cobalt)}
.phero h1{font-size:clamp(46px,10vw,150px);font-weight:600;letter-spacing:-.03em;position:relative;z-index:2}
.phero h1 em{font-style:normal;color:var(--cobalt)}
.phero .lead{margin-top:26px;max-width:560px;color:var(--ink-soft);font-size:clamp(18px,2.2vw,22px);position:relative;z-index:2}

/* marquee */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0;overflow:hidden;white-space:nowrap;background:var(--ink)}
.marquee.lite{background:transparent}
.marquee .track{display:inline-flex;gap:44px;will-change:transform}
.marquee .track span{font-family:"Clash Display";font-weight:600;font-size:clamp(22px,3vw,40px);color:#fff;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:44px}
.marquee.lite .track span{color:var(--ink)}
.marquee .track span::before{content:"✦";color:var(--cobalt);font-size:.6em}

/* section heading */
.shead{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:clamp(34px,5vw,64px);flex-wrap:wrap}
.shead .lbl{color:var(--cobalt);margin-bottom:18px;display:flex;align-items:center;gap:10px}
.shead .lbl::before{content:"";width:30px;height:1px;background:var(--cobalt)}
.shead h2{font-size:clamp(34px,6vw,82px)}
.shead p{max-width:380px;color:var(--ink-soft);font-size:16px}

/* services */
.svc-sec{padding:clamp(80px,11vw,170px) 0}
.svc{border-top:1px solid var(--line)}
.svc .row{display:grid;grid-template-columns:90px 1.1fr 1.6fr auto;gap:30px;align-items:center;padding:clamp(26px,4vw,48px) 0;position:relative;cursor:none}
.svc .row .num{font-family:"Martian Mono";font-size:13px;color:var(--cobalt)}
.svc .row h3{font-size:clamp(28px,4.4vw,58px);font-weight:600;transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.svc .row p{color:var(--ink-soft);font-size:16px;max-width:480px}
.svc .row .ico{width:54px;height:54px;color:var(--cobalt);transition:transform .5s}
.svc .row::before{content:"";position:absolute;left:0;bottom:0;width:0;height:100%;background:linear-gradient(90deg,rgba(20,82,255,.06),transparent);transition:width .5s;z-index:-1}
.svc .row:hover::before{width:100%}
.svc .row:hover h3{transform:translateX(18px);color:var(--cobalt)}
.svc .row:hover .ico{transform:rotate(-8deg) scale(1.1)}
@media (max-width:880px){.svc .row{grid-template-columns:50px 1fr;gap:8px 18px}.svc .row p{grid-column:1/-1;grid-row:2}.svc .row .ico{display:none}}
#svc-float{position:fixed;width:300px;height:210px;border-radius:14px;overflow:hidden;pointer-events:none;z-index:7000;opacity:0;transform:translate(-50%,-50%) scale(.8);transition:opacity .35s,transform .35s;box-shadow:var(--shadow);border:4px solid #fff}
#svc-float img{width:100%;height:100%;object-fit:cover}

/* service detail blocks (services page) */
.sdetail{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,4vw,60px);align-items:center;padding:clamp(50px,8vw,110px) 0;border-top:1px solid var(--line)}
.sdetail:nth-child(even) .sd-media{order:2}
.sd-media{border-radius:18px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:16/11}
.sd-media img,.sd-media video{width:100%;height:100%;object-fit:cover}
.sd-body .n{font-family:"Martian Mono";font-size:12px;color:var(--cobalt);letter-spacing:.2em}
.sd-body h2{font-size:clamp(32px,5vw,64px);margin:16px 0 18px}
.sd-body p{color:var(--ink-soft);max-width:480px;font-size:17px}
.sd-body ul{list-style:none;margin-top:26px;display:flex;flex-wrap:wrap;gap:10px}
.sd-body ul li{font-family:"Martian Mono";font-size:11px;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--line);border-radius:100px;padding:8px 16px;color:var(--ink-soft)}
@media (max-width:820px){.sdetail{grid-template-columns:1fr}.sdetail:nth-child(even) .sd-media{order:0}}

/* horizontal work */
#workx{padding:clamp(40px,8vw,90px) 0 0;overflow:hidden}
.hx-viewport{height:100vh;display:flex;align-items:center;overflow:hidden}
.hx-track{display:flex;gap:34px;padding:0 clamp(20px,5vw,72px);will-change:transform}
.hx-card{position:relative;flex:0 0 auto;width:clamp(300px,42vw,640px);height:min(72vh,640px);border-radius:20px;overflow:hidden;background:var(--paper);box-shadow:var(--shadow)}
.hx-card img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.8,.2,1)}
.hx-card:hover img{transform:scale(1.06)}
.hx-card .meta{position:absolute;left:0;right:0;bottom:0;padding:30px;background:linear-gradient(0deg,rgba(5,9,28,.82),transparent);color:#fff}
.hx-card .meta .k{font-family:"Martian Mono";font-size:10px;letter-spacing:.22em;color:var(--sky);margin-bottom:8px}
.hx-card .meta h3{font-size:clamp(24px,3vw,40px);color:#fff}
.hx-card .meta .t{margin-top:8px;font-size:14px;color:rgba(255,255,255,.78);max-width:80%}
.hx-intro{flex:0 0 auto;width:clamp(260px,30vw,440px);align-self:center;padding-right:20px}
.hx-intro .lbl{color:var(--cobalt);margin-bottom:18px;display:flex;align-items:center;gap:10px}
.hx-intro .lbl::before{content:"";width:30px;height:1px;background:var(--cobalt)}
.hx-intro h2{font-size:clamp(36px,5vw,72px)}
.hx-intro p{margin-top:18px;color:var(--ink-soft)}
@media (max-width:880px){.hx-viewport{height:auto;display:block}.hx-track{flex-direction:column;transform:none!important;padding:0 clamp(20px,5vw,72px)}.hx-card{width:100%;height:62vh}.hx-intro{width:100%;padding:0 0 30px}}

/* work grid (work page) */
.wgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,2.4vw,30px);padding:clamp(50px,8vw,100px) 0}
.wgrid .wc{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow);background:var(--paper)}
.wgrid .wc>a,.wgrid .wc>.meta-wrap{position:absolute;inset:0;display:block}
.wgrid .wc:nth-child(3n){grid-column:span 2;aspect-ratio:16/7}
.wgrid .wc img{width:100%;height:100%;object-fit:cover;transition:transform 1s cubic-bezier(.2,.8,.2,1)}
.wgrid .wc:hover img{transform:scale(1.05)}
.wgrid .wc .meta{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:clamp(20px,3vw,38px);background:linear-gradient(0deg,rgba(5,9,28,.85),rgba(5,9,28,.05) 60%,transparent);color:#fff}
.wgrid .wc .meta .k{font-family:"Martian Mono";font-size:10px;letter-spacing:.2em;color:var(--sky);margin-bottom:10px}
.wgrid .wc .meta h3{font-size:clamp(22px,2.6vw,38px);color:#fff}
.wgrid .wc .meta p{margin-top:8px;font-size:14px;color:rgba(255,255,255,.8);max-width:520px}
@media (max-width:760px){.wgrid{grid-template-columns:1fr}.wgrid .wc:nth-child(3n){grid-column:span 1;aspect-ratio:4/3}}

/* why + stats */
#why{padding:clamp(90px,12vw,180px) 0;background:var(--ink);color:#fff;border-radius:40px 40px 0 0;margin-top:60px}
#why ::selection{background:#fff;color:var(--cobalt)}
#why .lbl{color:var(--sky)}
#why h2{color:#fff;font-size:clamp(34px,6vw,82px)}
#why p.lead{color:rgba(255,255,255,.7);max-width:560px;font-size:clamp(18px,2.2vw,26px);margin-top:24px;line-height:1.5}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin-top:clamp(50px,7vw,90px);border-top:1px solid rgba(255,255,255,.16);padding-top:50px}
.stats .st .n{font-family:"Clash Display";font-weight:600;font-size:clamp(46px,7vw,104px);letter-spacing:-.04em;line-height:1}
.stats .st .n b{color:var(--azure);font-weight:600}
.stats .st .c{font-family:"Martian Mono";font-size:11px;letter-spacing:.18em;color:rgba(255,255,255,.6);margin-top:14px}
@media (max-width:760px){.stats{grid-template-columns:1fr 1fr;gap:34px 20px}}

/* dark generic */
.darksec{background:var(--ink);color:#fff}
.darksec .lbl{color:var(--sky)}
.darksec h2{color:#fff}

/* process (simple steps) */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:60px}
.step{border-top:1px solid rgba(255,255,255,.2);padding-top:24px;position:relative}
.step .sn{font-family:"Clash Display";font-size:clamp(34px,4vw,56px);font-weight:600;color:var(--azure)}
.step h3{font-size:22px;color:#fff;margin:14px 0 10px}
.step p{color:rgba(255,255,255,.6);font-size:15px}
@media (max-width:880px){.steps{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.steps{grid-template-columns:1fr}}

/* ============ PROCESS REEL (process.html) ============ */
#reel{position:relative;height:100svh;overflow:hidden;background:var(--ink)}
.phase{position:absolute;inset:0;opacity:0;transition:opacity .8s ease}
.phase.active{opacity:1}
.phase .pv{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.phase::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(5,9,28,.85),rgba(5,9,28,.25) 55%,rgba(5,9,28,.55))}
.phase .pc{position:absolute;left:0;bottom:0;z-index:3;color:#fff;padding:clamp(30px,6vw,90px);max-width:760px}
.phase .pc .pn{font-family:"Clash Display";font-weight:600;font-size:clamp(70px,16vw,260px);line-height:.8;letter-spacing:-.04em;-webkit-text-stroke:1.5px var(--azure);color:transparent;display:block}
.phase .pc h2{font-size:clamp(36px,7vw,96px);color:#fff;margin:6px 0 16px}
.phase .pc p{color:rgba(255,255,255,.82);font-size:clamp(16px,2vw,21px);max-width:540px}
.phase .pc .tag{font-family:"Martian Mono";font-size:11px;letter-spacing:.2em;color:var(--sky);margin-bottom:14px;display:block}
.reel-rail{position:absolute;right:clamp(20px,4vw,60px);top:50%;transform:translateY(-50%);z-index:5;display:flex;flex-direction:column;gap:18px}
.reel-rail .rd{display:flex;align-items:center;gap:12px;justify-content:flex-end;opacity:.5;transition:opacity .4s}
.reel-rail .rd.on{opacity:1}
.reel-rail .rd .lab{font-family:"Martian Mono";font-size:10px;letter-spacing:.16em;color:#fff}
.reel-rail .rd .dotn{width:10px;height:10px;border-radius:50%;border:1px solid rgba(255,255,255,.6);position:relative}
.reel-rail .rd.on .dotn{background:var(--azure);border-color:var(--azure);box-shadow:0 0 0 4px rgba(77,134,255,.3)}
.reel-progress{position:absolute;left:0;top:0;height:3px;background:var(--azure);z-index:6;width:0%}
@media (max-width:880px){
  #reel{height:auto;background:transparent}
  .phase{position:relative;inset:auto;opacity:1;margin-bottom:30px;border-radius:18px;overflow:hidden;background:var(--ink)}
  .phase .pv{position:relative;height:54vh}
  .phase::after{display:none}
  .phase .pc{position:relative;padding:26px}
  .phase .pc .pn{font-size:64px}
  .reel-rail{display:none}
  .reel-progress{display:none}
}

/* reviews */
#reviews{padding:clamp(90px,12vw,170px) 0;overflow:hidden}
.rev-head{display:flex;align-items:center;gap:18px;justify-content:center;margin-bottom:50px;flex-wrap:wrap;text-align:center}
.rev-head .stars{color:var(--cobalt);font-size:24px;letter-spacing:4px}
.rev-head .big{font-family:"Clash Display";font-size:clamp(30px,4vw,52px);font-weight:600}
.rev-track{display:flex;gap:24px;will-change:transform}
.rev{flex:0 0 clamp(290px,32vw,420px);background:var(--white);border:1px solid var(--line);border-radius:18px;padding:32px;box-shadow:0 20px 50px -34px rgba(11,52,201,.4)}
.rev .stars{color:var(--cobalt);font-size:15px;letter-spacing:2px;margin-bottom:16px}
.rev p{font-size:17px;line-height:1.5}
.rev .who{margin-top:20px;font-family:"Martian Mono";font-size:11px;letter-spacing:.16em;color:var(--ink-soft)}

/* CTA */
.cta{padding:clamp(100px,14vw,200px) 0;text-align:center;position:relative;overflow:hidden}
.cta .glow{position:absolute;inset:0;z-index:0;background:radial-gradient(circle at 50% 60%,rgba(77,134,255,.22),transparent 60%)}
.cta .inner{position:relative;z-index:2}
.cta .lbl{color:var(--cobalt);justify-content:center;display:flex;align-items:center;gap:10px;margin-bottom:24px}
.cta .lbl::before,.cta .lbl::after{content:"";width:30px;height:1px;background:var(--cobalt)}
.cta h2{font-size:clamp(40px,9vw,150px);letter-spacing:-.03em}
.cta h2 em{font-style:normal;color:var(--cobalt)}
.cta .sub{color:var(--ink-soft);max-width:480px;margin:26px auto 38px;font-size:18px}
.cta .ctab{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* contact */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,5vw,80px);padding:clamp(40px,6vw,90px) 0 clamp(80px,10vw,140px)}
@media (max-width:860px){.contact-grid{grid-template-columns:1fr}}
.cform{display:flex;flex-direction:column;gap:18px}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-family:"Martian Mono";font-size:11px;letter-spacing:.16em;color:var(--ink-soft)}
.field input,.field textarea,.field select{font-family:"Satoshi";font-size:17px;color:var(--ink);background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:15px 18px;outline:none;transition:border .3s,box-shadow .3s;cursor:none}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--cobalt);box-shadow:0 0 0 4px rgba(20,82,255,.12);background:#fff}
.field textarea{resize:vertical;min-height:130px}
.cinfo .ci{padding:24px 0;border-top:1px solid var(--line)}
.cinfo .ci .k{font-family:"Martian Mono";font-size:11px;letter-spacing:.16em;color:var(--cobalt);margin-bottom:10px}
.cinfo .ci a,.cinfo .ci p{font-family:"Clash Display";font-weight:600;font-size:clamp(22px,3vw,34px)}
.cinfo .ci .sm{font-family:"Satoshi";font-weight:400;font-size:16px;color:var(--ink-soft)}

/* footer */
footer{background:var(--ink);color:#fff;padding:clamp(60px,8vw,110px) 0 40px;overflow:hidden}
footer ::selection{background:#fff;color:var(--cobalt)}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,.14)}
.fgrid h4{font-family:"Martian Mono";font-size:11px;letter-spacing:.2em;color:var(--sky);margin-bottom:20px;font-weight:500}
.fgrid a,.fgrid p{color:rgba(255,255,255,.75);font-size:16px;line-height:2}
.fgrid a:hover{color:#fff}
.flogo{font-family:"Clash Display";font-weight:600;font-size:30px;color:#fff;display:inline-block;margin-bottom:18px}
.flogo b{color:var(--azure)}
.fblurb{color:rgba(255,255,255,.6);max-width:360px;font-size:16px;line-height:1.6}
.fwordmark{font-family:"Clash Display";font-weight:600;font-size:clamp(80px,22vw,360px);line-height:.8;letter-spacing:-.04em;margin-top:50px;-webkit-text-stroke:1.5px rgba(255,255,255,.34);color:transparent;white-space:nowrap}
.fwordmark b{-webkit-text-stroke:1.5px var(--azure)}
.fbottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:36px;font-family:"Martian Mono";font-size:11px;letter-spacing:.14em;color:rgba(255,255,255,.5)}
@media (max-width:760px){.fgrid{grid-template-columns:1fr;gap:34px}}

/* roster (full portfolio lists) */
.roster{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);padding:clamp(50px,8vw,100px) 0}
.roster .col .ch{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:10px}
.roster .col .ch h3{font-size:clamp(24px,3vw,40px)}
.roster .col .ch .ct{font-family:"Martian Mono";font-size:11px;letter-spacing:.16em;color:var(--cobalt)}
.roster ul{list-style:none}
.roster li{border-top:1px solid var(--line)}
.roster li:last-child{border-bottom:1px solid var(--line)}
.roster li a,.roster li .ri{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:18px 2px;transition:padding .35s cubic-bezier(.2,.8,.2,1),color .35s}
.roster li a:hover{color:var(--cobalt);padding-left:14px}
.roster li .nm{font-family:"Clash Display";font-weight:500;font-size:clamp(19px,2.2vw,28px);letter-spacing:-.01em}
.roster li .d{font-family:"Martian Mono";font-size:10px;letter-spacing:.14em;color:var(--ink-soft);white-space:nowrap;text-transform:uppercase}
.roster li a .d::after{content:" ↗";color:var(--cobalt)}
@media (max-width:760px){.roster{grid-template-columns:1fr;gap:40px}}

/* 404 */
.e404{min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:120px 24px 80px;position:relative;overflow:hidden}
.e404 .big{font-family:"Clash Display";font-weight:600;font-size:clamp(110px,30vw,420px);line-height:.82;letter-spacing:-.04em;color:var(--ink)}
.e404 .big em{font-style:normal;color:var(--cobalt)}
.e404 p{margin:22px 0 34px;color:var(--ink-soft);font-size:clamp(17px,2.4vw,22px);max-width:460px}
.e404 .crumb{color:var(--cobalt);margin-bottom:18px}

/* reveal */
.reveal{opacity:0;transform:translateY(40px)}
.is-in{opacity:1;transform:none}
