/* ============================================================
   WIS — Strona WWW  ·  Premium: Navy / Cream / Silver
   Cormorant Garamond (display) · Jost (text) · IBM Plex Mono (data)
   ============================================================ */

:root{
  --navy:#0C1A30;
  --navy2:#11233C;
  --navy3:#16273F;
  --navy-line:#26405F;
  --navy-line-soft:#1E3756;
  --ink:#16243A;
  --ink-soft:#46566C;
  --cream:#F4F0E7;
  --cream2:#FAF7F0;
  --cream-line:#E2DCCF;
  --silver-txt:#7E8794;
  --silver-c:#AEB6C2;
  --silver-b:#E9ECF1;
  --mute:#6A7686;
  --mute-l:#9AA3B0;

  --maxw:1280px;
  --pad:clamp(20px,5vw,90px);
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Jost', system-ui, sans-serif;
  --mono:'IBM Plex Mono', ui-monospace, monospace;
  --metal:linear-gradient(90deg,#7E8694 0%,#E9ECF1 38%,#9AA3B1 62%,#D7DBE2 100%);
  --nav-h:74px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:var(--nav-h)}
body{
  font-family:var(--sans);background:var(--cream);color:var(--ink);
  font-weight:300;line-height:1.62;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:16px;top:16px;background:var(--cream);color:var(--ink);padding:10px 16px;z-index:200}

.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad);width:100%}
.section{padding:clamp(72px,11vw,150px) 0}
.section--white{background:var(--cream2)}
.section--paper{background:var(--cream)}
.section--deep{background:var(--navy);color:var(--cream)}

/* ---------- type ---------- */
.kicker{font-family:var(--mono);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--silver-txt);font-weight:400;display:flex;align-items:center;gap:15px}
.kicker__line{width:50px;height:1px;background:var(--metal);flex:none}
.kicker__idx{margin-left:auto;color:var(--mute-l)}
.section--deep .kicker{color:var(--silver-c)}
.section--deep .kicker__idx{color:#5E6E83}

.display{font-family:var(--serif);font-weight:400;line-height:1.0;letter-spacing:.004em;text-wrap:balance}
.h2{font-family:var(--serif);font-weight:400;font-size:clamp(34px,5.2vw,64px);line-height:1.02;letter-spacing:.004em;margin:18px 0 0;text-wrap:balance}
.h3{font-family:var(--serif);font-weight:500;font-size:clamp(19px,2vw,24px);line-height:1.1}
.lead{font-size:clamp(15.5px,1.45vw,19px);line-height:1.64;color:var(--mute);max-width:60ch;font-weight:300;letter-spacing:.005em}
.section--deep .lead{color:#A9B4C4}
p{font-weight:300}
.em{font-style:italic;font-weight:500}
.silver{background:var(--metal);-webkit-background-clip:text;background-clip:text;color:transparent}

.shead{max-width:760px;margin-bottom:clamp(40px,6vw,72px)}
.shead .lead{margin-top:20px}
.cols-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px)}
@media(max-width:820px){.cols-2{grid-template-columns:1fr}}

/* ---------- NAV ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);display:flex;align-items:center;
  background:rgba(12,26,48,.0);transition:background .4s,backdrop-filter .4s,border-color .4s;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(11,21,38,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--navy-line-soft)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;width:100%}
.brand{display:flex;align-items:center;gap:13px;text-decoration:none}
.brand__mark{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--silver-c);
  font-family:var(--serif);font-weight:600;font-size:16px;letter-spacing:.06em;color:var(--cream);
  background:radial-gradient(120% 120% at 30% 20%,#1A3052,#0C1A30);flex:none;position:relative;overflow:hidden}
.brand__mark::after{content:'';position:absolute;inset:0;border-radius:50%;border:1px solid transparent;
  background:var(--metal) border-box;-webkit-mask:linear-gradient(#000 0 0) padding-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.5}
.brand__txt{display:flex;flex-direction:column;line-height:1.05}
.brand__name{font-family:var(--mono);font-size:13px;letter-spacing:.28em;font-weight:500;color:var(--cream)}
.brand__sub{font-family:var(--mono);font-size:8.5px;letter-spacing:.26em;color:var(--silver-c);margin-top:3px;text-transform:uppercase}
.nav__links{display:flex;gap:clamp(14px,1.8vw,30px);margin-left:auto}
.nav__links a{font-family:var(--sans);font-size:13.5px;font-weight:400;letter-spacing:.02em;color:#C3CDDB;text-decoration:none;transition:color .25s;position:relative}
.nav__links a:hover{color:var(--cream)}
.nav__links a::after{content:'';position:absolute;left:0;right:100%;bottom:-6px;height:1px;background:var(--metal);transition:right .3s}
.nav__links a:hover::after{right:0}
.nav__right{display:flex;align-items:center;gap:16px}
.lang{display:flex;gap:2px;border:1px solid var(--navy-line);padding:2px}
.lang button{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;color:var(--silver-c);background:none;border:0;padding:5px 8px;cursor:pointer;transition:.2s}
.lang button.active{background:var(--metal);color:var(--navy)}
.nav__cta{font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.02em;color:var(--navy);background:var(--metal);padding:10px 18px;text-decoration:none;transition:.25s;white-space:nowrap}
.nav__cta:hover{filter:brightness(1.06)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:24px;height:1.5px;background:var(--cream);display:block;transition:.3s}
@media(max-width:1000px){.nav__links{display:none}.nav__cta{display:none}.burger{display:flex}}

.mmenu{position:fixed;inset:var(--nav-h) 0 auto 0;background:rgba(11,21,38,.97);backdrop-filter:blur(14px);z-index:99;
  display:flex;flex-direction:column;padding:20px var(--pad) 30px;gap:4px;transform:translateY(-120%);transition:transform .4s;border-bottom:1px solid var(--navy-line)}
.mmenu.open{transform:none}
.mmenu a{font-family:var(--serif);font-size:22px;color:var(--cream);text-decoration:none;padding:12px 0;border-bottom:1px solid var(--navy-line-soft)}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;background:var(--navy);overflow:hidden;color:var(--cream)}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__video{width:100%;height:100%;object-fit:cover;filter:grayscale(.5) brightness(.78) contrast(1.05)}
.media__fallback{position:absolute;inset:0;background:var(--navy)}
.hero__media::after{content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(12,26,48,.78) 0%,rgba(12,26,48,.4) 32%,rgba(12,26,48,.62) 70%,rgba(12,26,48,.95) 100%),
  linear-gradient(90deg,rgba(12,26,48,.88) 0%,rgba(12,26,48,.15) 62%,transparent 100%)}
.hero__media::before{content:'';position:absolute;inset:0;z-index:1;mix-blend-mode:color;background:#16345E;opacity:.45}
.hero__sweep{position:absolute;inset:0;z-index:2;width:100%;height:100%;pointer-events:none}
.hero__grid{position:absolute;inset:0;z-index:2;background-image:linear-gradient(rgba(120,140,180,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(120,140,180,.05) 1px,transparent 1px);background-size:70px 70px;mask-image:radial-gradient(120% 80% at 70% 30%,#000 30%,transparent 80%)}
.hero__inner{position:relative;z-index:5;padding-bottom:clamp(40px,6vw,70px)}
.hero__spine{display:grid;grid-template-columns:auto 1fr;gap:clamp(20px,3vw,40px)}
.hero__rule{width:1px;background:var(--metal);opacity:.6;margin-top:6px}
.media__tick{position:absolute;z-index:6;font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;color:var(--silver-c);opacity:.7}
.hero .kicker{color:var(--silver-c)}
.hero .display{font-size:clamp(40px,7.6vw,104px);margin-top:24px;color:var(--cream);font-weight:300}
.hero .display .em{color:var(--silver-b)}
.hero__lead{margin-top:26px;max-width:52ch;color:#BAC5D4;font-size:clamp(15.5px,1.55vw,19px)}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.btn{display:inline-flex;align-items:center;gap:12px;font-family:var(--sans);font-size:14px;font-weight:500;letter-spacing:.02em;padding:15px 26px;text-decoration:none;transition:.28s;border:1px solid transparent;cursor:pointer;white-space:nowrap}
.btn--gold{background:var(--metal);color:var(--navy)}
.btn--gold:hover{filter:brightness(1.07);gap:16px}
.btn--ghost{background:transparent;color:var(--cream);border-color:var(--navy-line)}
.btn--ghost:hover{border-color:var(--silver-c);background:rgba(255,255,255,.04)}
.btn__arrow{transition:transform .28s}
.btn:hover .btn__arrow{transform:translateX(4px)}
.hero__meta{position:relative;z-index:5;border-top:1px solid var(--navy-line-soft);background:rgba(8,17,32,.4)}
.hero__metainner{display:flex;align-items:center;gap:clamp(14px,2.5vw,32px);padding-top:18px;padding-bottom:18px;flex-wrap:wrap}
.hero__metaitem{display:flex;flex-direction:column;gap:3px}
.hero__metaitem span{font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:#6E7E93}
.hero__metaitem b{font-size:14px;font-weight:400;color:var(--cream)}
.hero__scroll{margin-left:auto;display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--silver-c)}
.hero__scrollline{width:40px;height:1px;background:var(--metal);position:relative;overflow:hidden}
.hero__scrollline::after{content:'';position:absolute;top:0;left:-40px;width:20px;height:100%;background:var(--cream);animation:scrollln 2.4s infinite}
@keyframes scrollln{to{left:40px}}
@media(max-width:560px){.hero__scroll{display:none}}

/* ---------- anim ---------- */
.anim{opacity:0;transform:translateY(22px);animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards}
.a1{animation-delay:.1s}.a2{animation-delay:.24s}.a3{animation-delay:.4s}.a4{animation-delay:.54s}.a5{animation-delay:.7s}
@keyframes rise{to{opacity:1;transform:none}}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.anim,.reveal{opacity:1;transform:none;animation:none}}

/* ---------- positioning statement ---------- */
.stmt{padding:clamp(70px,10vw,140px) 0}
.stmt .big{display:grid;grid-template-columns:90px 1fr;gap:clamp(20px,4vw,56px);align-items:start}
.stmt__idx{font-family:var(--mono);font-size:13px;color:var(--silver-txt);letter-spacing:.1em;padding-top:14px}
.stmt__lead{font-family:var(--serif);font-weight:400;font-size:clamp(24px,3.4vw,44px);line-height:1.2;color:var(--ink);text-wrap:balance}
.stmt__side{margin-top:30px;max-width:52ch}
.stmt__side p{font-size:15.5px;color:var(--mute);line-height:1.7}
@media(max-width:680px){.stmt .big{grid-template-columns:1fr}.stmt__idx{padding-top:0}}

/* ---------- trust marquee ---------- */
.trust{background:var(--navy);color:var(--cream);padding:46px 0 54px;overflow:hidden}
.trust__label{font-family:var(--mono);font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--silver-txt);text-align:center;margin-bottom:30px}
.marquee{position:relative;overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee__track{display:flex;gap:0;width:max-content;animation:marq 38s linear infinite}
.marquee__item{font-family:var(--serif);font-weight:400;font-size:clamp(24px,3vw,40px);color:#5E6E83;padding:0 clamp(26px,3.5vw,56px);white-space:nowrap;transition:color .3s}
.marquee__item::after{content:'·';margin-left:clamp(26px,3.5vw,56px);color:var(--navy-line)}
.marquee:hover .marquee__track{animation-play-state:paused}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- services ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--cream-line);border-left:1px solid var(--cream-line)}
.svc{padding:clamp(24px,2.4vw,36px);border-right:1px solid var(--cream-line);border-bottom:1px solid var(--cream-line);position:relative;transition:background .3s}
.svc:hover{background:#fff}
.svc__n{font-family:var(--mono);font-size:11px;color:var(--silver-txt);letter-spacing:.1em}
.svc .h3{margin:18px 0 12px}
.svc p{font-size:13.5px;color:var(--ink-soft);line-height:1.6}
.svc__bar{height:1px;background:var(--cream-line);margin-top:22px;position:relative;overflow:hidden}
.svc__bar::after{content:'';position:absolute;inset:0;background:var(--metal);transform:translateX(-101%);transition:transform .5s}
.svc:hover .svc__bar::after{transform:none}
@media(max-width:980px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.svc-grid{grid-template-columns:1fr}}

/* ---------- industries ---------- */
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,26px)}
.ind{position:relative;overflow:hidden;background:var(--navy);border:1px solid var(--cream-line)}
.media{position:relative;overflow:hidden}
.ind-img{width:100%;aspect-ratio:3/2.1;object-fit:cover;filter:grayscale(.5) brightness(.7) contrast(1.05);transition:transform .7s,filter .5s}
.ind:hover .ind-img{transform:scale(1.05);filter:grayscale(.3) brightness(.78)}
.ind .media::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,26,48,.15),rgba(12,26,48,.86));mix-blend-mode:normal}
.ind .media::before{content:'';position:absolute;inset:0;z-index:1;mix-blend-mode:color;background:#1B3D6B;opacity:.5}
.ind__body{position:absolute;left:0;right:0;bottom:0;z-index:3;padding:clamp(20px,2vw,28px);color:var(--cream)}
.ind__n{font-family:var(--mono);font-size:10.5px;color:var(--silver-c);letter-spacing:.12em;margin-bottom:8px}
.ind__body h3{font-family:var(--serif);font-weight:500;font-size:clamp(20px,2.2vw,27px);line-height:1.05}
.ind__desc{max-height:0;overflow:hidden;opacity:0;transition:max-height .5s,opacity .4s,margin .4s}
.ind:hover .ind__desc{max-height:80px;opacity:1;margin-top:10px}
.ind__desc p{font-size:13.5px;color:#BAC5D4;line-height:1.55}
.ind__line{height:1px;background:var(--metal);margin-top:14px;transform:scaleX(0);transform-origin:left;transition:transform .5s}
.ind:hover .ind__line{transform:none}
@media(max-width:880px){.ind-grid{grid-template-columns:repeat(2,1fr)}.ind__desc{max-height:80px;opacity:1;margin-top:10px}.ind__line{transform:none}}
@media(max-width:520px){.ind-grid{grid-template-columns:1fr}}

/* ---------- stats / process (deep) ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--navy-line);border-left:1px solid var(--navy-line)}
.stat{padding:clamp(26px,3vw,42px) clamp(20px,2vw,30px);border-right:1px solid var(--navy-line);border-bottom:1px solid var(--navy-line)}
.stat__v{font-family:var(--serif);font-weight:400;font-size:clamp(44px,6vw,76px);line-height:1;color:var(--cream)}
.stat__v .silver,.stat__v{background:var(--metal);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat__l{font-size:13px;color:#A9B4C4;margin-top:12px;line-height:1.5;max-width:24ch}
@media(max-width:780px){.stats{grid-template-columns:repeat(2,1fr)}}

.proc{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-top:clamp(34px,4vw,54px);border-top:1px solid var(--navy-line)}
.pstep{padding:30px 22px 30px 0;border-right:1px solid var(--navy-line);position:relative}
.pstep:last-child{border-right:0}
.pstep__dot{width:9px;height:9px;border-radius:50%;background:var(--metal);position:absolute;top:-5px;left:0}
.pstep__n{font-family:var(--mono);font-size:11px;color:var(--silver-txt);letter-spacing:.1em;margin-bottom:14px}
.pstep h4{font-family:var(--serif);font-weight:500;font-size:19px;color:var(--cream);margin-bottom:9px;line-height:1.1}
.pstep p{font-size:13px;color:#A9B4C4;line-height:1.55}
@media(max-width:880px){.proc{grid-template-columns:repeat(2,1fr)}.pstep{border-right:0;border-bottom:1px solid var(--navy-line);padding-right:0}}
@media(max-width:480px){.proc{grid-template-columns:1fr}}

/* ---------- expertise ---------- */
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,28px)}
.exp{background:var(--cream2);border:1px solid var(--cream-line);padding:clamp(26px,2.6vw,36px)}
.exp__tag{font-family:var(--serif);font-style:italic;font-size:26px;background:var(--metal);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:14px}
.exp h4{font-family:var(--serif);font-weight:500;font-size:21px;margin-bottom:14px}
.exp p{font-size:13.5px;color:var(--ink-soft);line-height:1.66}
@media(max-width:820px){.exp-grid{grid-template-columns:1fr}}
.oem{margin-top:clamp(30px,4vw,48px);border-top:1px solid var(--cream-line)}
.oem__row{display:grid;grid-template-columns:230px 1fr;gap:24px;padding:22px 0;border-bottom:1px solid var(--cream-line)}
.oem__label{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--silver-txt);padding-top:3px}
.oem__list{font-family:var(--serif);font-size:clamp(17px,1.8vw,22px);color:var(--ink);line-height:1.4}
@media(max-width:680px){.oem__row{grid-template-columns:1fr;gap:8px}}

/* ---------- team ---------- */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,24px)}
.tcard{background:var(--cream2);border:1px solid var(--cream-line);padding:clamp(22px,2.2vw,30px);transition:.3s}
.tcard:hover{border-color:var(--silver-c)}
.tcard__yrs{display:flex;align-items:baseline;gap:6px;margin-bottom:18px}
.tcard__n{font-family:var(--serif);font-weight:400;font-size:46px;line-height:1;background:var(--metal);-webkit-background-clip:text;background-clip:text;color:transparent}
.tcard__u{font-family:var(--mono);font-size:11px;color:var(--silver-txt);letter-spacing:.1em}
.tcard h4{font-family:var(--serif);font-weight:500;font-size:18px;line-height:1.14;margin-bottom:10px}
.tcard p{font-size:12.5px;color:var(--ink-soft);line-height:1.55}
.tlink{display:inline-flex;align-items:center;gap:10px;font-family:var(--sans);font-size:13.5px;font-weight:500;color:var(--silver-b);text-decoration:none}
.tlink span:last-child{transition:transform .25s}
.tlink:hover span:last-child{transform:translateX(4px)}
@media(max-width:920px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.team-grid{grid-template-columns:1fr}}

/* ---------- about / values ---------- */
.vals{display:grid;gap:4px}
.val{display:grid;grid-template-columns:48px 1fr;gap:18px;padding:22px 0;border-bottom:1px solid var(--cream-line);align-items:start}
.val__i{font-family:var(--serif);font-style:italic;font-size:24px;background:var(--metal);-webkit-background-clip:text;background-clip:text;color:transparent}
.val h4{font-family:var(--serif);font-weight:500;font-size:21px;margin-bottom:6px}
.val p{font-size:14px;color:var(--ink-soft);line-height:1.5}

/* ---------- work ---------- */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,28px)}
.case{background:var(--cream2);border:1px solid var(--cream-line);padding:clamp(26px,2.6vw,36px);display:flex;flex-direction:column}
.case__tag{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--silver-txt);margin-bottom:16px}
.case .h3{margin-bottom:20px;min-height:2.2em}
.case__block{margin-bottom:16px}
.case__k{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--mute-l);display:block;margin-bottom:6px}
.case__block p{font-size:13.5px;color:var(--ink-soft);line-height:1.62}
.case__metrics{display:flex;flex-wrap:wrap;gap:18px 26px;margin-top:auto;padding-top:22px;border-top:1px solid var(--cream-line)}
.case__m b{font-family:var(--serif);font-size:24px;font-weight:500;color:var(--ink);display:block}
.case__m span{font-size:11px;color:var(--mute);letter-spacing:.02em}
.work__note{text-align:center;font-size:13px;color:var(--mute);margin-top:clamp(30px,4vw,50px);font-family:var(--mono);letter-spacing:.04em}
@media(max-width:920px){.work-grid{grid-template-columns:1fr}.case .h3{min-height:0}}

/* ---------- contact ---------- */
.contact{position:relative;background:var(--navy);color:var(--cream);overflow:hidden}
.contact .hero__grid{z-index:0}
.contact__inner{position:relative;z-index:2}
.contact .kicker{justify-content:center;color:var(--silver-c)}
.contact .h2{text-align:center;color:var(--cream)}
.contact__lead{text-align:center;margin:18px auto 0;max-width:54ch;color:#A9B4C4}
.contact__grid{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(30px,4vw,60px);margin-top:clamp(46px,6vw,72px);align-items:start}
@media(max-width:880px){.contact__grid{grid-template-columns:1fr}}
.cform{display:grid;gap:18px}
.cform__row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:520px){.cform__row{grid-template-columns:1fr}}
.cfield{display:flex;flex-direction:column;gap:8px}
.cfield__l{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--silver-c)}
.cfield input,.cfield select,.cfield textarea{font-family:var(--sans);font-size:14.5px;font-weight:300;color:var(--cream);background:rgba(255,255,255,.03);border:1px solid var(--navy-line);padding:13px 14px;transition:.25s;width:100%}
.cfield textarea{resize:vertical}
.cfield input:focus,.cfield select:focus,.cfield textarea:focus{outline:none;border-color:var(--silver-c);background:rgba(255,255,255,.06)}
.cfield select{appearance:none;cursor:pointer}
.cfield select option{background:var(--navy2);color:var(--cream)}
.cform__hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.cform__foot{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-top:6px}
.cform__status{font-size:13px;color:var(--silver-c)}
.cinfo{display:grid;gap:24px;align-content:start;padding-left:clamp(0px,2vw,30px)}
.cinfo__item{border-top:1px solid var(--navy-line);padding-top:18px}
.cinfo__k{font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:#6E7E93;margin-bottom:9px}
.cinfo__v{font-size:14.5px;color:var(--cream);line-height:1.5}
.cinfo__v a{color:var(--silver-b);text-decoration:none}
.cinfo__v a:hover{text-decoration:underline}

/* ---------- footer ---------- */
.footer{background:#091221;color:var(--cream);padding:clamp(56px,7vw,90px) 0 30px}
.footer__top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:clamp(28px,3vw,50px);padding-bottom:clamp(40px,5vw,60px);border-bottom:1px solid var(--navy-line)}
.footer__brand .brand{margin-bottom:18px}
.footer__brand p{font-size:13.5px;color:#8C99AC;line-height:1.66;max-width:38ch}
.footer__col h5{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--silver-c);margin-bottom:18px}
.footer__col a,.footer__col p{display:block;font-size:13.5px;color:#9AA6B6;text-decoration:none;margin-bottom:11px;line-height:1.5;transition:color .2s}
.footer__col a:hover{color:var(--cream)}
.footer__bottom{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;padding-top:26px}
.footer__bottom .copy{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;color:#6E7C90}
.footer__bottom .tag{font-family:var(--serif);font-style:italic;font-size:16px;color:var(--silver-c)}
@media(max-width:820px){.footer__top{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer__top{grid-template-columns:1fr}}

/* progress */
.progress{position:fixed;top:0;left:0;height:2px;background:var(--metal);width:0;z-index:101}

/* contact form status colours (merged from technical layer) */
.cform__status.ok{color:var(--accent,#C9D3E2)}
.cform__status.err{color:#E06B6B}
.cform__submit[disabled]{opacity:.55;cursor:progress}

/* accessibility: skip link + visible keyboard focus (merged from technical layer) */
.skip-link{position:absolute;left:-999px;top:0;z-index:2000;background:var(--silver-c,#AEB6C2);color:#0C1A30;
  font-family:var(--mono,monospace);font-size:.8rem;font-weight:600;letter-spacing:.06em;padding:10px 16px;border-radius:0 0 6px 0}
.skip-link:focus{left:0}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--silver-c,#AEB6C2);outline-offset:2px;border-radius:3px}

/* mobile: enlarge tap targets to >=44px (WCAG 2.5.5 / Apple HIG) */
@media(max-width:1000px){
  .lang button{min-height:44px;min-width:42px;padding:6px 11px;display:inline-flex;align-items:center;justify-content:center}
  .burger{min-width:44px;min-height:44px;padding:10px;align-items:center;justify-content:center}
}

/* ============================================================
   SUBPAGE PRIMITIVES  (services/industries/insights/work)
   Token-only, no new fonts/JS. Reuses existing design system.
   ============================================================ */
.page-hero{background:var(--navy);color:var(--cream);padding:calc(var(--nav-h) + clamp(48px,8vw,96px)) 0 clamp(48px,7vw,88px);position:relative;overflow:hidden}
.page-hero .hero__grid{opacity:.5}
.crumbs{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--silver-c);margin-bottom:22px}
.crumbs a{color:var(--silver-c);text-decoration:none;transition:color .25s}
.crumbs a:hover{color:var(--cream)}
.crumbs span[aria-current]{color:var(--cream)}
.crumbs .sep{opacity:.45}
.page-hero h1{font-family:var(--serif);font-weight:400;font-size:clamp(38px,6vw,76px);line-height:1.02;letter-spacing:.004em;margin:0;text-wrap:balance}
.page-hero .lead{color:#A9B4C4;margin-top:22px;max-width:64ch}
.prose{max-width:72ch}
.prose>*+*{margin-top:18px}
.prose p{font-weight:300;font-size:clamp(15.5px,1.4vw,18px);line-height:1.7;color:var(--ink-soft)}
.prose h2{font-family:var(--serif);font-weight:400;font-size:clamp(26px,3.4vw,40px);line-height:1.08;margin:clamp(36px,5vw,56px) 0 4px;color:var(--ink)}
.prose h3{font-family:var(--serif);font-weight:500;font-size:clamp(19px,2vw,24px);line-height:1.15;margin-top:28px;color:var(--ink)}
.prose ul{list-style:none;padding:0;margin:6px 0}
.prose li{position:relative;padding-left:22px;font-weight:300;line-height:1.66;color:var(--ink-soft);margin-top:10px}
.prose li::before{content:"";position:absolute;left:0;top:11px;width:8px;height:1px;background:var(--metal)}
.prose strong{font-weight:500;color:var(--ink)}
.faq{margin-top:14px;border-top:1px solid var(--cream-line)}
.faq__item{border-bottom:1px solid var(--cream-line)}
.faq__item summary{cursor:pointer;list-style:none;padding:20px 0;font-family:var(--serif);font-size:clamp(18px,2vw,22px);color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";font-family:var(--mono);font-size:20px;color:var(--mute-l);transition:transform .3s}
.faq__item[open] summary::after{content:"–"}
.faq__item p{font-weight:300;line-height:1.7;color:var(--ink-soft);padding:0 0 22px;max-width:70ch}
.rel-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin-top:18px}
.rel{display:block;padding:22px 24px;border:1px solid var(--cream-line);background:var(--cream2);text-decoration:none;transition:border-color .3s,transform .3s}
.rel:hover{border-color:var(--mute-l);transform:translateY(-2px)}
.rel__k{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--mute-l)}
.rel__t{font-family:var(--serif);font-size:21px;color:var(--ink);margin-top:6px}
.rel__a{font-family:var(--mono);font-size:12px;color:var(--mute);margin-top:14px}
