/* ============================================================
   FLOGAL — FIELD DOSSIER
   Light technical system: bone paper, ink, safety orange.
   Archivo (variable: weight + width) display & body.
   IBM Plex Mono for spec labels, codes and data readouts.
   ============================================================ */

/* ---------- fonts ---------- */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 100 900;
  font-stretch: 62.5% 125%;
  font-display: swap;
  src: url("../fonts/archivo-var.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 100 900;
  font-stretch: 62.5% 125%;
  font-display: swap;
  src: url("../fonts/archivo-var-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/plexmono-400.woff2") format('woff2');
}
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/plexmono-500.woff2") format('woff2');
}
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/plexmono-600.woff2") format('woff2');
}

/* ---------- tokens ---------- */
:root{
  --bone:#F1EDE4;
  --bone-2:#E9E4D8;
  --bone-3:#DFD9CB;
  --ink:#16181D;
  --ink-2:#1D2026;
  --ink-3:#272B33;
  --orange:#F2581C;
  --orange-deep:#CE4413;
  --gold:#E8AE3C;
  --mut:#5E6066;
  --mut-2:#8B8D92;
  --line:rgba(22,24,29,.18);
  --line-soft:rgba(22,24,29,.10);
  --line-hard:#16181D;
  --line-inv:rgba(241,237,228,.18);
  --line-inv-soft:rgba(241,237,228,.10);
  --grid:rgba(22,24,29,.055);

  --f-sans:"Archivo", "Helvetica Neue", Arial, sans-serif;
  --f-mono:"IBM Plex Mono", ui-monospace, "Cascadia Mono", monospace;

  --container:1380px;
  --pad-x:clamp(20px, 4.5vw, 72px);
  --specbar-h:34px;
  --header-h:72px;

  --ease:cubic-bezier(.22,.68,.16,1);
}

/* ---------- base ---------- */
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--bone);
  color:var(--ink);
  font-family:var(--f-sans);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
p{margin:0;}
h1,h2,h3,h4{margin:0;}
.container{max-width:var(--container);margin:0 auto;padding-inline:var(--pad-x);}

::selection{background:var(--orange);color:var(--bone);}

/* drafting grid backdrop */
.blueprint{
  background-image:
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px);
  background-size:88px 88px;
}

/* ---------- type ---------- */
.disp{
  font-weight:840;
  font-stretch:116%;
  text-transform:uppercase;
  line-height:.94;
  letter-spacing:-.018em;
  text-wrap:balance;
}
.disp .o{
  color:transparent;
  -webkit-text-stroke:1.6px currentColor;
}
.disp .hl{color:var(--orange);}
.mono{
  font-family:var(--f-mono);
  font-weight:500;
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.kicker{
  font-family:var(--f-mono);
  font-weight:600;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--orange);
  display:inline-block;
}
.kicker::before{content:"+";font-weight:400;font-size:15px;line-height:1;margin-right:12px;}
.lead{
  font-size:clamp(18px, 1.6vw, 22px);
  line-height:1.55;
  font-weight:420;
  color:var(--mut);
  max-width:58ch;
}
.inv{color:var(--bone);}
.inv .lead{color:var(--mut-2);}
.inv .kicker{color:var(--orange);}

/* ---------- reveal ---------- */
html.js .reveal{opacity:0;transform:translateY(26px);}
html.js .reveal.is-in{
  opacity:1;transform:none;
  transition:opacity .85s var(--ease), transform .85s var(--ease);
}

/* ---------- scroll progress ---------- */
.progress{
  position:fixed;top:0;left:0;height:3px;width:0;
  background:var(--orange);z-index:200;
}

/* ---------- spec bar ---------- */
.specbar{
  background:var(--ink);
  color:var(--bone);
  height:var(--specbar-h);
  display:flex;align-items:center;
  font-family:var(--f-mono);
  font-size:10.5px;
  letter-spacing:.12em;
  text-transform:uppercase;
  position:relative;z-index:60;
}
.specbar .container{
  display:flex;justify-content:space-between;align-items:center;gap:18px;width:100%;
}
.specbar span b{color:var(--orange);font-weight:500;}
.specbar .mid{color:var(--mut-2);}
.specbar .lc{text-transform:none;letter-spacing:.08em;}
.specbar a:hover{color:var(--orange);}
@media (max-width:760px){ .specbar .mid{display:none;} }

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:var(--bone);
  border-bottom:1px solid var(--line-hard);
  height:var(--header-h);
  transition:box-shadow .3s var(--ease);
}
.site-header.scrolled{box-shadow:0 1px 0 var(--line-hard), 0 14px 34px -18px rgba(22,24,29,.28);}
.site-header .container{
  display:flex;align-items:center;justify-content:space-between;gap:28px;height:100%;
}
.logo{display:flex;align-items:center;}
.logo-img{width:auto;height:46px;}
.nav{display:flex;align-items:center;gap:34px;}
.nav a{
  font-family:var(--f-mono);
  font-weight:500;
  font-size:12.5px;
  letter-spacing:.14em;
  text-transform:uppercase;
  position:relative;
  padding:6px 0;
}
.nav a::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--orange);transition:width .3s var(--ease);
}
.nav a:hover::after, .nav a.active::after{width:100%;}
.nav a.nav-cta{
  background:var(--ink);color:var(--bone);
  padding:13px 22px;border:1px solid var(--ink);
  transition:background .25s var(--ease), color .25s var(--ease);
}
.nav a.nav-cta::after{display:none;}
.nav a.nav-cta:hover{background:var(--orange);border-color:var(--orange);color:var(--ink);}

.nav-toggle{
  display:none;background:none;border:1px solid var(--line-hard);
  width:46px;height:46px;cursor:pointer;padding:12px 10px;
  flex-direction:column;justify-content:space-between;
}
.nav-toggle span{display:block;height:2px;background:var(--ink);transition:transform .3s var(--ease), opacity .3s;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--f-mono);font-weight:600;font-size:12.5px;
  letter-spacing:.16em;text-transform:uppercase;
  padding:18px 30px;border:1px solid var(--ink);
  cursor:pointer;line-height:1;
  transition:transform .22s var(--ease), box-shadow .22s var(--ease),
             background .22s var(--ease), color .22s var(--ease);
}
.btn .arr{font-family:var(--f-sans);font-weight:600;transition:transform .25s var(--ease);}
.btn:hover .arr{transform:translateX(5px);}
.btn-solid{background:var(--ink);color:var(--bone);}
.btn-solid:hover{
  transform:translate(-3px,-3px);
  box-shadow:5px 5px 0 var(--orange);
}
.btn-line{background:transparent;color:var(--ink);}
.btn-line:hover{
  transform:translate(-3px,-3px);
  box-shadow:5px 5px 0 var(--orange);
  background:var(--bone);
}
.inv .btn-line, .btn-line.on-ink{border-color:var(--bone);color:var(--bone);}
.inv .btn-line:hover, .btn-line.on-ink:hover{background:transparent;}
.btn-orange{background:var(--orange);color:var(--ink);border-color:var(--orange);}
.btn-orange:hover{
  transform:translate(-3px,-3px);
  box-shadow:5px 5px 0 var(--ink);
}

/* ---------- photo plate ---------- */
.plate{position:relative;border:1px solid var(--line-hard);background:var(--ink);
  display:flex;flex-direction:column;}
.plate picture, .plate .ph{display:block;overflow:hidden;flex:1;min-height:0;}
.plate img{width:100%;height:100%;object-fit:cover;}
.plate .cap{
  display:flex;justify-content:space-between;gap:14px;align-items:center;
  background:var(--bone);border-top:1px solid var(--line-hard);
  font-family:var(--f-mono);font-size:10.5px;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;
  padding:11px 14px;color:var(--ink);
}
.plate .cap b{color:var(--orange);font-weight:600;}
.tick{position:absolute;width:14px;height:14px;pointer-events:none;z-index:2;}
.tick::before,.tick::after{content:"";position:absolute;background:var(--orange);}
.tick::before{width:14px;height:2px;top:6px;}
.tick::after{width:2px;height:14px;left:6px;}
.tick.tl{top:-7px;left:-7px;}
.tick.tr{top:-7px;right:-7px;}
.tick.bl{bottom:-7px;left:-7px;}
.tick.br{bottom:-7px;right:-7px;}

/* ---------- sections ---------- */
.band{padding-block:clamp(72px, 11vh, 140px);position:relative;}
.band.ink-band{background:var(--ink);color:var(--bone);}
.band.ink-band ::selection{background:var(--bone);color:var(--ink);}
.band.bone-2{background:var(--bone-2);}
.band.hairline-top{border-top:1px solid var(--line-hard);}

.sec-head{max-width:880px;}
.sec-head h2{
  font-weight:840;font-stretch:116%;text-transform:uppercase;
  line-height:.95;letter-spacing:-.015em;
  font-size:clamp(38px, 5.2vw, 76px);
  margin-top:22px;text-wrap:balance;
}
.sec-head .lead{margin-top:24px;}
.sec-head.row{
  max-width:none;display:flex;justify-content:space-between;
  align-items:flex-end;gap:28px;flex-wrap:wrap;
}
.sec-head.row > div{min-width:0;max-width:100%;}
.sec-head .lead{max-width:min(58ch, 100%);}
.sec-index{
  font-family:var(--f-mono);font-weight:400;
  font-size:clamp(60px, 8vw, 120px);
  line-height:1;color:transparent;
  -webkit-text-stroke:1px var(--line);
  user-select:none;
}
.ink-band .sec-index{-webkit-text-stroke:1px var(--line-inv);}

/* ---------- hero (home) ---------- */
.hero{
  position:relative;
  border-bottom:1px solid var(--line-hard);
  overflow:hidden;
}
.hero .container{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);
  gap:clamp(32px, 4vw, 72px);
  align-items:end;
  padding-block:clamp(56px, 9vh, 110px) clamp(46px, 7vh, 80px);
}
.hero h1{
  font-weight:860;font-stretch:118%;text-transform:uppercase;
  line-height:.92;letter-spacing:-.02em;
  font-size:clamp(48px, 7.6vw, 122px);
}
.hero h1 .o{color:transparent;-webkit-text-stroke:1.8px var(--ink);}
.hero h1 .hl{color:var(--orange);}
.hero .lead{margin-top:30px;}
.hero-cta{display:flex;gap:16px;margin-top:40px;flex-wrap:wrap;}
.hero-code{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--mut);
  display:flex;gap:26px;flex-wrap:wrap;margin-top:46px;
  padding-top:20px;border-top:1px solid var(--line);
}
.hero-code b{color:var(--orange);font-weight:600;}
.hero-plate{align-self:stretch;display:flex;flex-direction:column;justify-content:flex-end;}
.hero-plate .plate{aspect-ratio:4/3.4;}
.hero-plate .plate img{height:100%;}

/* hero entrance */
html.js .rise{opacity:0;transform:translateY(34px);animation:rise .9s var(--ease) forwards;animation-delay:calc(var(--r,0) * 110ms);}
@keyframes rise{to{opacity:1;transform:none;}}

/* ---------- marquee ---------- */
.marquee{
  background:var(--ink);color:var(--bone);
  border-block:1px solid var(--ink);
  overflow:hidden;padding-block:16px;
  position:relative;z-index:2;
}
.marquee .track{
  display:flex;width:max-content;
  animation:mq 30s linear infinite;
}
.marquee:hover .track{animation-play-state:paused;}
.marquee .seg{
  display:flex;align-items:center;gap:0;
  font-family:var(--f-mono);font-weight:500;font-size:13px;
  letter-spacing:.22em;text-transform:uppercase;white-space:nowrap;
}
.marquee .seg span{padding-inline:28px;}
.marquee .seg i{font-style:normal;color:var(--orange);}
@keyframes mq{to{transform:translateX(-50%);}}

/* ---------- stats ---------- */
.stats{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));
  border:1px solid var(--line-hard);
  background:var(--bone);
}
.ink-band .stats{border-color:var(--line-inv);background:transparent;}
.stat{
  padding:34px 30px 30px;
  border-right:1px solid var(--line-hard);
  position:relative;
}
.ink-band .stat{border-color:var(--line-inv);}
.stat:last-child{border-right:0;}
.stat .n{
  font-family:var(--f-mono);font-weight:600;
  font-size:clamp(38px, 4vw, 58px);line-height:1;
  letter-spacing:-.04em;
}
.stat .n .u{font-size:.38em;color:var(--orange);letter-spacing:.06em;margin-left:4px;}
.stat .l{
  margin-top:14px;font-family:var(--f-mono);font-size:11px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;color:var(--mut);
}
.ink-band .stat .l{color:var(--mut-2);}
.stat::before{
  content:attr(data-idx);
  position:absolute;top:12px;right:14px;
  font-family:var(--f-mono);font-size:10px;color:var(--mut-2);letter-spacing:.1em;
}

/* ---------- service index (home) ---------- */
.svc-list{border-top:1px solid var(--line-hard);margin-top:64px;}
.svc-row{
  display:grid;
  grid-template-columns:120px minmax(0,1fr) minmax(0,1.2fr) 60px;
  gap:clamp(18px, 3vw, 48px);
  align-items:center;
  padding:34px 0;
  border-bottom:1px solid var(--line-hard);
  position:relative;
  transition:background .25s var(--ease), padding-left .3s var(--ease);
}
.svc-row::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:0;
  background:var(--orange);transition:width .3s var(--ease);
}
.svc-row:hover{background:var(--bone-2);padding-left:22px;}
.svc-row:hover::before{width:6px;}
.svc-row .code{
  font-family:var(--f-mono);font-size:11.5px;font-weight:500;
  letter-spacing:.12em;color:var(--mut);
}
.svc-row h3{
  font-weight:800;font-stretch:112%;text-transform:uppercase;
  font-size:clamp(20px, 2.2vw, 30px);line-height:1;letter-spacing:-.01em;
}
.svc-row p{color:var(--mut);font-size:15.5px;max-width:52ch;}
.svc-row .go{
  font-family:var(--f-sans);font-size:24px;font-weight:600;
  justify-self:end;color:var(--ink);
  transition:transform .25s var(--ease), color .25s var(--ease);
}
.svc-row:hover .go{transform:translateX(6px);color:var(--orange);}

/* ---------- feature plates (home projects) ---------- */
.feat{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:clamp(16px, 1.6vw, 24px);
  margin-top:56px;
}
.feat .plate{transition:transform .3s var(--ease), box-shadow .3s var(--ease);}
.feat .plate:hover{transform:translate(-5px,-5px);box-shadow:8px 8px 0 var(--orange);}
.feat .plate img{transition:transform .8s var(--ease);}
.feat .plate:hover img{transform:scale(1.04);}
.feat .plate{overflow:visible;display:flex;flex-direction:column;}
.feat .plate .ph{overflow:hidden;aspect-ratio:4/3;flex:1;min-height:0;}
.feat .plate.wide .ph{aspect-ratio:16/8.4;}
.feat .f1{grid-column:span 4;}
.feat .f2{grid-column:span 2;}
.feat .f3{grid-column:span 2;}
.feat .f4{grid-column:span 2;}
.feat .f5{grid-column:span 2;}

/* ---------- crew (ink band) ---------- */
.crew{
  display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);
  gap:clamp(36px, 5vw, 90px);align-items:center;
}
.crew-art{position:relative;}
.crew-art .plate .ph{aspect-ratio:4/3;overflow:hidden;}
.crew-art .badge{
  position:absolute;z-index:3;top:-26px;right:-14px;
  background:var(--orange);color:var(--ink);
  font-family:var(--f-mono);text-align:center;
  padding:18px 22px;border:1px solid var(--ink);
}
.crew-art .badge b{display:block;font-size:30px;font-weight:600;letter-spacing:-.03em;line-height:1;}
.crew-art .badge small{display:block;margin-top:7px;font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;}
.crew h2{
  font-weight:840;font-stretch:116%;text-transform:uppercase;
  font-size:clamp(34px, 4.4vw, 64px);line-height:.95;letter-spacing:-.015em;
  margin-top:22px;
}
.crew p{margin-top:22px;color:var(--mut-2);max-width:54ch;}
.crew p strong{color:var(--bone);}
.micro{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px;}
.micro span{
  font-family:var(--f-mono);font-size:10.5px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  border:1px solid var(--line-inv);padding:9px 14px;color:var(--bone);
}

/* ---------- clients ---------- */
.clients{
  display:grid;grid-template-columns:repeat(5,minmax(0,1fr));
  border:1px solid var(--line-hard);margin-top:56px;
}
.client{
  border-right:1px solid var(--line-hard);
  padding:34px 26px;min-height:150px;
  display:flex;flex-direction:column;justify-content:space-between;gap:18px;
  transition:background .25s var(--ease);
  position:relative;
}
.client:last-child{border-right:0;}
.client:hover{background:var(--bone-2);}
.client .cn{
  font-weight:800;font-stretch:112%;text-transform:uppercase;
  font-size:21px;line-height:1.04;letter-spacing:-.01em;
}
.client .cs{
  font-family:var(--f-mono);font-size:10px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;color:var(--mut);
}
.client img{height:62px;width:auto;object-fit:contain;}
.client.logo{justify-content:center;align-items:flex-start;}

/* ---------- CTA band ---------- */
.cta-band{
  background:var(--orange);color:var(--ink);
  padding-block:clamp(80px, 12vh, 150px);
  position:relative;overflow:hidden;
  border-top:1px solid var(--ink);
}
.cta-band::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(22,24,29,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(22,24,29,.07) 1px, transparent 1px);
  background-size:88px 88px;
}
.cta-band .container{position:relative;z-index:2;text-align:center;}
.cta-band .mono-top{
  font-family:var(--f-mono);font-size:11px;font-weight:600;
  letter-spacing:.24em;text-transform:uppercase;
}
.cta-band h2{
  font-weight:860;font-stretch:118%;text-transform:uppercase;
  font-size:clamp(40px, 6.4vw, 96px);line-height:.93;letter-spacing:-.02em;
  max-width:18ch;margin:26px auto 0;
}
.cta-band .sub{margin:24px auto 0;font-size:clamp(17px,1.6vw,21px);max-width:52ch;}
.cta-btns{display:flex;gap:16px;justify-content:center;margin-top:44px;flex-wrap:wrap;}

/* ---------- footer ---------- */
.site-footer{
  background:var(--ink);color:var(--bone);
  padding-top:clamp(70px, 9vh, 110px);
  position:relative;overflow:hidden;
}
.foot-grid{
  display:grid;
  grid-template-columns:minmax(0,1.4fr) repeat(3,minmax(0,1fr));
  gap:clamp(30px, 4vw, 70px);
  position:relative;z-index:2;
}
.foot-brand img{height:52px;width:auto;}
.foot-brand p{margin-top:22px;color:var(--mut-2);font-size:15px;max-width:34ch;}
.foot-col h4{
  font-family:var(--f-mono);font-weight:600;font-size:11px;
  letter-spacing:.2em;text-transform:uppercase;color:var(--orange);
  margin-bottom:20px;
}
.foot-col a, .foot-col .fitem{
  display:block;font-size:15px;color:var(--bone);
  padding-block:6px;
}
.foot-col a{transition:color .2s, transform .25s var(--ease);}
.foot-col a:hover{color:var(--orange);transform:translateX(4px);}
.fitem{color:var(--mut-2);}
.fitem b{
  display:block;font-family:var(--f-mono);font-weight:500;font-size:10px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--mut-2);
  margin-bottom:2px;
}
.fitem a{display:inline;padding:0;}
.foot-coords{
  margin-top:clamp(48px, 7vh, 80px);
  border-top:1px solid var(--line-inv-soft);
  padding-block:18px;
  display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;
  font-family:var(--f-mono);font-size:10.5px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--mut-2);
  position:relative;z-index:2;
}
.foot-coords b{color:var(--orange);font-weight:500;}
.foot-mark{
  font-weight:880;font-stretch:122%;text-transform:uppercase;
  font-size:clamp(90px, 17vw, 280px);line-height:.78;
  letter-spacing:-.02em;text-align:center;
  color:transparent;-webkit-text-stroke:1px rgba(241,237,228,.14);
  user-select:none;pointer-events:none;
  transform:translateY(14%);
}

/* ---------- page hero (sub-pages) ---------- */
.page-hero{
  border-bottom:1px solid var(--line-hard);
  position:relative;overflow:hidden;
}
.page-hero .container{
  display:grid;
  grid-template-columns:minmax(0,1.25fr) minmax(0,.75fr);
  gap:clamp(32px, 4vw, 72px);
  align-items:end;
  padding-block:clamp(48px, 8vh, 96px) clamp(40px, 6vh, 70px);
}
.crumb{
  font-family:var(--f-mono);font-size:11px;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;color:var(--mut);
  display:flex;gap:12px;align-items:center;
}
.crumb a:hover{color:var(--orange);}
.crumb .sep{color:var(--orange);}
.page-hero h1{
  font-weight:860;font-stretch:118%;text-transform:uppercase;
  line-height:.92;letter-spacing:-.02em;
  font-size:clamp(40px, 6.6vw, 100px);
  margin-top:24px;
}
.page-hero h1 .o{color:transparent;-webkit-text-stroke:1.6px var(--ink);}
.page-hero h1 .hl{color:var(--orange);}
.page-hero .lead{margin-top:26px;}
.page-hero .plate{aspect-ratio:4/3;}
.page-hero .hero-plate .plate{aspect-ratio:4/3;}

/* ---------- capability rows (services) ---------- */
.cap-list{border-top:1px solid var(--line-hard);margin-top:64px;counter-reset:cap;}
.cap-row{
  display:grid;
  grid-template-columns:140px minmax(0,.9fr) minmax(0,1.1fr);
  gap:clamp(20px, 3vw, 56px);
  padding:clamp(36px, 5vh, 56px) 0;
  border-bottom:1px solid var(--line-hard);
  position:relative;
}
.cap-row .code{
  font-family:var(--f-mono);font-size:12px;font-weight:500;
  letter-spacing:.12em;color:var(--mut);
  display:flex;flex-direction:column;gap:8px;
}
.cap-row .code b{
  font-size:clamp(34px, 3.4vw, 52px);font-weight:400;letter-spacing:-.03em;
  color:transparent;-webkit-text-stroke:1px var(--ink);line-height:1;
}
.cap-row h3{
  font-weight:820;font-stretch:114%;text-transform:uppercase;
  font-size:clamp(26px, 3vw, 42px);line-height:.98;letter-spacing:-.012em;
}
.cap-row .cd p{color:var(--mut);max-width:58ch;}
.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px;}
.tags span{
  font-family:var(--f-mono);font-size:10px;font-weight:500;
  letter-spacing:.13em;text-transform:uppercase;
  border:1px solid var(--line);padding:7px 12px;color:var(--ink);
  transition:border-color .2s, color .2s;
}
.cap-row:hover .tags span{border-color:var(--orange);}

/* ---------- process (services) ---------- */
.process{
  display:grid;grid-template-columns:repeat(5,minmax(0,1fr));
  border:1px solid var(--line-inv);
  margin-top:60px;
}
.pstep{
  border-right:1px solid var(--line-inv);
  padding:32px 24px 38px;position:relative;
  transition:background .25s var(--ease);
}
.pstep:last-child{border-right:0;}
.pstep:hover{background:var(--ink-2);}
.pstep .node{
  font-family:var(--f-mono);font-weight:600;font-size:12px;
  width:38px;height:38px;border:1px solid var(--orange);color:var(--orange);
  display:flex;align-items:center;justify-content:center;
}
.pstep h4{
  font-weight:800;font-stretch:112%;text-transform:uppercase;
  font-size:21px;letter-spacing:.01em;margin-top:22px;
}
.pstep p{margin-top:12px;font-size:14px;color:var(--mut-2);line-height:1.55;}
.one-line{
  margin-top:54px;
  font-weight:800;font-stretch:114%;text-transform:uppercase;
  font-size:clamp(22px, 2.6vw, 36px);line-height:1.1;letter-spacing:-.01em;
}
.one-line i{font-style:normal;color:var(--orange);}

/* ---------- values ---------- */
.values{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));
  border:1px solid var(--line-hard);margin-top:60px;
}
.value{
  border-right:1px solid var(--line-hard);
  padding:34px 28px 40px;
  transition:background .25s var(--ease);
  position:relative;overflow:hidden;
}
.value:last-child{border-right:0;}
.values.svc8 .value:nth-child(-n+4){border-bottom:1px solid var(--line-hard);}
.values.svc8 .value:nth-child(4n){border-right:0;}
.value:hover{background:var(--ink);color:var(--bone);}
.value .vi{
  font-family:var(--f-mono);font-size:11px;font-weight:500;
  letter-spacing:.14em;color:var(--orange);
}
.value h3{
  font-weight:800;font-stretch:112%;text-transform:uppercase;
  font-size:23px;line-height:1.02;margin-top:50px;letter-spacing:-.005em;
}
.value p{margin-top:14px;font-size:14.5px;color:var(--mut);line-height:1.6;}
.value:hover p{color:var(--mut-2);}

/* ---------- case studies (projects) ---------- */
.case{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:clamp(30px, 4.5vw, 80px);
  align-items:center;
  padding-block:clamp(44px, 7vh, 80px);
  border-bottom:1px solid var(--line-hard);
}
.case:last-child{border-bottom:0;}
.case .plate .ph{aspect-ratio:4/3;overflow:hidden;}
.case .plate img{transition:transform .8s var(--ease);}
.case .plate:hover img{transform:scale(1.04);}
.case.alt .cbody{order:-1;}
.case h3{
  font-weight:820;font-stretch:114%;text-transform:uppercase;
  font-size:clamp(26px, 3vw, 44px);line-height:.98;letter-spacing:-.012em;
  margin-top:20px;
}
.car{margin-top:30px;border-top:1px solid var(--line);}
.car .row{
  display:grid;grid-template-columns:120px 1fr;gap:18px;
  padding:16px 0;border-bottom:1px solid var(--line);
}
.car .rl{
  font-family:var(--f-mono);font-size:10.5px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--orange);
  padding-top:4px;
}
.car .rt{font-size:15px;color:var(--mut);line-height:1.6;}
.chip{
  display:inline-flex;flex-wrap:wrap;align-items:center;gap:10px 14px;margin-top:28px;
  max-width:100%;
  border:1px solid var(--line-hard);padding:13px 18px;
  font-family:var(--f-mono);font-size:11.5px;font-weight:500;
  letter-spacing:.1em;text-transform:uppercase;
}
.chip b{font-weight:600;color:var(--orange);}
.chip .v{width:1px;height:16px;background:var(--line);}

/* ---------- gallery ---------- */
.gallery{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
  gap:clamp(14px, 1.5vw, 22px);margin-top:56px;
}
.gtile{position:relative;border:1px solid var(--line-inv);overflow:hidden;aspect-ratio:4/3;}
.gtile img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease);}
.gtile:hover img{transform:scale(1.05);}
.glab{
  position:absolute;left:0;bottom:0;right:0;
  background:linear-gradient(transparent, rgba(16,18,22,.88) 58%);
  color:var(--bone);padding:38px 16px 13px;
  font-family:var(--f-mono);font-size:10.5px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
}
.glab b{color:var(--orange);font-weight:500;}

.regions{
  display:flex;flex-wrap:wrap;gap:10px;margin-top:48px;
}
.regions span{
  font-family:var(--f-mono);font-size:10.5px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  border:1px solid var(--line-inv);padding:9px 15px;color:var(--mut-2);
}
.regions span.hl{border-color:var(--orange);color:var(--orange);}

/* ---------- about: who ---------- */
.who{
  display:grid;grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);
  gap:clamp(36px, 5vw, 90px);align-items:center;
}
.who .plate .ph{aspect-ratio:4/4.6;overflow:hidden;}
.who h2{
  font-weight:840;font-stretch:116%;text-transform:uppercase;
  font-size:clamp(32px, 4.2vw, 60px);line-height:.95;letter-spacing:-.015em;
  margin-top:22px;
}
.who p{margin-top:22px;color:var(--mut);max-width:56ch;}
.who p strong{color:var(--ink);}

.principles{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
  border:1px solid var(--line-hard);
  margin-top:clamp(56px, 8vh, 90px);
}
.principle{
  border-right:1px solid var(--line-hard);
  padding:36px 30px 42px;
  transition:background .25s var(--ease);
}
.principle:last-child{border-right:0;}
.principle:hover{background:var(--bone-2);}
.principle .pi{
  font-family:var(--f-mono);font-size:11px;font-weight:500;
  letter-spacing:.14em;color:var(--orange);
}
.principle h3{
  font-weight:800;font-stretch:112%;text-transform:uppercase;
  font-size:24px;line-height:1;margin-top:46px;letter-spacing:-.005em;
}
.principle p{margin-top:14px;font-size:15px;color:var(--mut);line-height:1.6;}

/* ---------- contact ---------- */
.contact-grid{
  display:grid;grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);
  gap:clamp(36px, 5vw, 90px);align-items:start;
}
.contact-info h2{
  font-weight:830;font-stretch:114%;text-transform:uppercase;
  font-size:clamp(28px, 3vw, 44px);line-height:.98;letter-spacing:-.012em;
  margin:22px 0 38px;
}
.ci-row{
  display:grid;grid-template-columns:90px 1fr;gap:18px;
  padding:18px 0;border-top:1px solid var(--line);
}
.ci-row:last-of-type{border-bottom:1px solid var(--line);}
.cik{
  font-family:var(--f-mono);font-size:10.5px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--orange);
  padding-top:5px;
}
.civ{font-size:17px;line-height:1.6;}
.civ a:hover{color:var(--orange);}
.civ.sm{font-size:15px;color:var(--mut);}

.form{
  border:1px solid var(--line-hard);background:var(--bone);
  padding:clamp(26px, 3vw, 44px);
  position:relative;
}
.form::before{
  content:"ENQUIRY FORM — FLG/REQ";
  position:absolute;top:-1px;left:-1px;
  background:var(--ink);color:var(--bone);
  font-family:var(--f-mono);font-size:9.5px;font-weight:500;
  letter-spacing:.18em;padding:7px 12px;
}
.form .field{margin-top:22px;}
.form .form-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:22px;}
.form label{
  display:block;font-family:var(--f-mono);font-size:10.5px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink);
  margin-bottom:9px;
}
.form input, .form select, .form textarea{
  width:100%;background:transparent;
  border:1px solid var(--line);
  padding:14px 15px;font-family:var(--f-sans);font-size:15.5px;color:var(--ink);
  transition:border-color .2s, box-shadow .2s;
  border-radius:0;-webkit-appearance:none;appearance:none;
}
.form select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23F2581C'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 15px center;
}
.form textarea{min-height:150px;resize:vertical;}
.form input:focus, .form select:focus, .form textarea:focus{
  outline:none;border-color:var(--orange);box-shadow:3px 3px 0 var(--orange);
}
.form input::placeholder, .form textarea::placeholder{color:var(--mut-2);}
.form .btn{width:100%;justify-content:center;margin-top:28px;}
.form-status{
  margin-top:18px;font-family:var(--f-mono);font-size:12px;
  letter-spacing:.08em;padding:13px 16px;border:1px solid var(--line);
}
.form-status.sending{color:var(--mut);}
.form-status.ok{border-color:#2E7D45;color:#2E7D45;}
.form-status.err{border-color:var(--orange-deep);color:var(--orange-deep);}

/* ---------- statement (home) ---------- */
.statement{
  display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);
  gap:clamp(36px, 5vw, 90px);align-items:start;
}
.statement .big{
  font-weight:840;font-stretch:116%;text-transform:uppercase;
  font-size:clamp(34px, 4.6vw, 68px);line-height:.96;letter-spacing:-.016em;
}
.statement .big .hl{color:var(--orange);}
.statement .body p{color:var(--mut-2);margin-top:20px;max-width:56ch;}
.statement .body p:first-child{margin-top:6px;}
.statement .body strong{color:var(--bone);}

/* ---------- mobile nav ---------- */
@media (max-width:980px){
  .nav{
    position:fixed;inset:calc(var(--specbar-h) + var(--header-h)) 0 0 0;
    background:var(--bone);
    flex-direction:column;align-items:flex-start;justify-content:flex-start;
    padding:42px var(--pad-x);gap:8px;
    transform:translateX(102%);
    transition:transform .4s var(--ease);
    border-top:1px solid var(--line-hard);
    z-index:90;overflow-y:auto;
  }
  body.nav-open .nav{transform:none;}
  .nav a{
    font-family:var(--f-sans);
    font-weight:830;font-stretch:116%;
    font-size:clamp(34px, 9vw, 54px);
    letter-spacing:-.015em;line-height:1.05;
    padding:10px 0;width:100%;
    border-bottom:1px solid var(--line-soft);
  }
  .nav a::after{display:none;}
  .nav a.active{color:var(--orange);}
  .nav a.nav-cta{
    margin-top:26px;text-align:center;justify-content:center;display:flex;
    font-size:clamp(22px, 6vw, 30px);padding:20px;border-bottom:0;
  }
  .nav-toggle{display:flex;}
  body.nav-open .nav-toggle span:nth-child(1){transform:translateY(9px) rotate(45deg);}
  body.nav-open .nav-toggle span:nth-child(2){opacity:0;}
  body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-9px) rotate(-45deg);}
  body.nav-open{overflow:hidden;}
}

/* ---------- responsive ---------- */
@media (max-width:1100px){
  .feat .f1{grid-column:span 6;}
  .feat .f2,.feat .f3{grid-column:span 3;}
  .feat .f4,.feat .f5{grid-column:span 3;}
  .clients{grid-template-columns:repeat(3,minmax(0,1fr));}
  .client:nth-child(3n){border-right:0;}
  .client:nth-child(n+4){border-top:1px solid var(--line-hard);}
  .client:nth-child(3n+1):nth-last-child(-n+3) ~ .client{border-right:1px solid var(--line-hard);}
  .client:nth-child(4),.client:nth-child(5){border-right:1px solid var(--line-hard);}
  .client:last-child{border-right:0;}
  .process{grid-template-columns:repeat(5,minmax(0,1fr));}
}
@media (max-width:980px){
  .hero .container{grid-template-columns:minmax(0,1fr);align-items:start;}
  .hero-plate{order:2;}
  .page-hero .container{grid-template-columns:minmax(0,1fr);}
  .page-hero .hero-plate{display:none;}
  .stats{grid-template-columns:minmax(0,1fr) minmax(0,1fr);}
  .stat:nth-child(2n){border-right:0;}
  .stat:nth-child(n+3){border-top:1px solid var(--line-hard);}
  .ink-band .stat:nth-child(n+3){border-top:1px solid var(--line-inv);}
  .svc-row{grid-template-columns:70px minmax(0,1fr) 40px;grid-template-areas:"code title go" "code body go";}
  .svc-row h3{font-size:19px;font-stretch:106%;}
  .svc-row .code{grid-area:code;}
  .svc-row h3{grid-area:title;}
  .svc-row p{grid-area:body;margin-top:8px;}
  .svc-row .go{grid-area:go;}
  .crew{grid-template-columns:1fr;}
  .crew-art .badge{right:6px;}
  .statement{grid-template-columns:1fr;}
  .case{grid-template-columns:1fr;}
  .case.alt .cbody{order:0;}
  .cap-row{grid-template-columns:1fr;gap:16px;}
  .who{grid-template-columns:1fr;}
  .who .plate .ph{aspect-ratio:4/3;}
  .contact-grid{grid-template-columns:1fr;}
  .process{grid-template-columns:minmax(0,1fr) minmax(0,1fr);}
  .pstep{border-top:1px solid var(--line-inv);}
  .pstep:nth-child(-n+2){border-top:0;}
  .pstep:nth-child(2n){border-right:0;}
  .values{grid-template-columns:minmax(0,1fr) minmax(0,1fr);}
  .value:nth-child(2n){border-right:0;}
  .value:nth-child(n+3){border-top:1px solid var(--line-hard);}
  .principles{grid-template-columns:1fr;}
  .principle{border-right:0;border-bottom:1px solid var(--line-hard);}
  .principle:last-child{border-bottom:0;}
  .foot-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);}
}
@media (max-width:640px){
  .gallery{grid-template-columns:minmax(0,1fr) minmax(0,1fr);}
  .clients{grid-template-columns:minmax(0,1fr) minmax(0,1fr);}
  .client{border-top:1px solid var(--line-hard);border-right:1px solid var(--line-hard);}
  .client:nth-child(-n+2){border-top:0;}
  .client:nth-child(2n){border-right:0;}
  .stats{grid-template-columns:minmax(0,1fr) minmax(0,1fr);}
  .form .form-row{grid-template-columns:1fr;gap:0;}
  .foot-grid{grid-template-columns:1fr;}
  .feat .f2,.feat .f3,.feat .f4,.feat .f5{grid-column:span 6;}
  .process{grid-template-columns:1fr;}
  .pstep{border-right:0;border-top:1px solid var(--line-inv);}
  .pstep:first-child{border-top:0;}
  .values{grid-template-columns:1fr;}
  .value{border-right:0;border-top:1px solid var(--line-hard);}
  .value:first-child{border-top:0;}
  .car .row{grid-template-columns:1fr;gap:6px;}
  .ci-row{grid-template-columns:70px 1fr;}
}

@media (max-width:560px){
  .hero h1{font-size:clamp(28px, 8.6vw, 38px);font-stretch:102%;}
  .hero h1 .o{-webkit-text-stroke-width:1.2px;}
  .page-hero h1{font-size:clamp(28px, 8.6vw, 40px);font-stretch:102%;}
  .page-hero h1 .o{-webkit-text-stroke-width:1.2px;}
  .sec-head h2{font-size:clamp(27px, 7.9vw, 36px);font-stretch:103%;}
  .statement .big{font-size:clamp(27px, 8vw, 36px);font-stretch:106%;}
  .crew h2, .who h2{font-size:clamp(27px, 8vw, 36px);font-stretch:106%;}
  .cta-band h2{font-size:clamp(29px, 9vw, 42px);font-stretch:106%;}
  .case h3, .cap-row h3{font-size:clamp(23px, 6.6vw, 28px);}
  .contact-info h2{font-size:clamp(24px, 7vw, 30px);}
  .hero-code{gap:14px 22px;}
  .stat{padding:24px 18px 22px;}
  .stat .n{font-size:clamp(30px, 8.6vw, 40px);}
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  html.js .reveal, html.js .rise{opacity:1!important;transform:none!important;transition:none!important;animation:none!important;}
  .marquee .track{animation:none;}
  *{transition-duration:.01ms!important;}
}
