/* ITW UNIVERSE — Light Paper / Zine-Editorial System · ink on paper · blue + gold */
@import url(/assets/../fonts/oswald.css);
@import url(/assets/../fonts/poppins.css);
@import url(/assets/../fonts/gfont-bebas.css);
@import url(/assets/../fonts/gfont-marker.css);
@import url(/assets/../fonts/gfont-mono.css);

:root{
  --paper:#ffffff; --paper-2:#ffffff; --card:#ffffff;
  --ink:#15181e; --ink-2:#2a2f38; --navy:#0b1b33;
  --blue:#1f5bff; --blue-ink:#123aa8; --gold:#b88600; --gold-fill:#ffba00; --gold-2:#e0a200; --gold-ink:#7a5800;
  --muted:rgba(21,24,30,.82); --muted-2:rgba(21,24,30,.82);
  --line:rgba(20,24,32,.16); --line-2:rgba(20,24,32,.09);
  --maxw:1600px; --pad:clamp(20px,5vw,72px); --r:6px;
  --ease:cubic-bezier(.22,1,.36,1);
  --sans:"Plus Jakarta Sans","Poppins",sans-serif; --serif:"Oswald",sans-serif;
  --mono:"Space Mono",ui-monospace,monospace; --marker:"Permanent Marker",cursive;
  --display:"Big Shoulders Display","Bebas Neue","Oswald",sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:var(--paper);color:var(--ink);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
::selection{background:var(--ink);color:var(--paper)}

.bg-field{position:fixed;inset:0;z-index:-2;pointer-events:none;background:#ffffff}
.bg-field::after{display:none}
.paper-tex{display:none}
.grain{display:none}
@keyframes grain{0%{transform:translate(0,0)}20%{transform:translate(-6%,4%)}40%{transform:translate(4%,-6%)}60%{transform:translate(-3%,3%)}80%{transform:translate(5%,2%)}100%{transform:translate(0,0)}}

.cur,.cur-ring{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:9999}
.cur,.cur-ring{display:none!important}

.preload{position:fixed;inset:0;z-index:10000;background:var(--paper);display:grid;place-items:center;transition:opacity .6s ease,visibility .6s}
.preload.done{opacity:0;visibility:hidden}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad);position:relative;z-index:1}
section{position:relative;padding-block:clamp(72px,11vw,150px)}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.16em;font-size:11px;font-weight:700;color:var(--blue-ink);margin-bottom:22px}
.eyebrow::before{content:"";width:26px;height:11px;background:var(--gold-fill);border-radius:1px}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.02;color:var(--navy)}
.h-display{font-family:var(--display);font-weight:400;font-size:clamp(48px,10vw,160px);text-transform:uppercase;line-height:.82;letter-spacing:.01em;color:var(--ink)}
.h2{font-family:var(--display);font-weight:400;font-size:clamp(36px,5.8vw,86px);text-transform:uppercase;line-height:.88;letter-spacing:.016em;color:var(--ink)}
.lead{font-size:clamp(16px,1.5vw,20px);color:var(--muted);max-width:62ch}
.gold{color:var(--gold)} .blue{color:var(--blue)} .muted{color:var(--muted)}
.stroke{color:transparent;-webkit-text-stroke:1.6px rgba(20,24,32,.5)}
.marker{font-family:var(--marker);color:var(--blue);font-weight:400;display:inline-block;transform:rotate(-3deg)}
.h2 .gold,.h-display .gold,.foot-cta .gold,.hc-title .gold{color:var(--blue-ink)}
a.gold{color:var(--blue-ink)}

.btn{position:relative;display:inline-flex;align-items:center;gap:12px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-weight:700;font-size:13px;padding:16px 28px;border-radius:3px;overflow:hidden;isolation:isolate;border:1px solid var(--ink);color:var(--paper);background:var(--ink)}
.btn::before{content:"";position:absolute;inset:0;z-index:-1;background:var(--gold-fill);transform:translateY(101%);transition:transform .45s var(--ease)}
.btn:hover{color:var(--ink)}
.btn:hover::before{transform:translateY(0)}
.btn .arr{transition:transform .4s var(--ease)}
.btn:hover .arr{transform:translate(5px,-5px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost::before{background:var(--blue)}
.btn-ghost:hover{color:#fff;border-color:var(--blue)}
.link-u{position:relative;display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-weight:700;font-size:12px;color:var(--ink)}
.link-u::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:100%;background:var(--gold-fill);transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease)}
.link-u:hover::after{transform:scaleX(1);transform-origin:left}
.link-u .arr{color:var(--blue);transition:transform .4s var(--ease)}
.link-u:hover .arr{transform:translateX(5px)}

.nav{position:fixed;top:0;left:0;width:100%;z-index:900;padding:9px 0;transition:padding .4s var(--ease),background .4s,box-shadow .4s;background:rgba(245,243,237,.95);backdrop-filter:blur(18px) saturate(130%);border-bottom:1px solid var(--line)}
.nav.scrolled{padding:7px 0;background:rgba(250,248,243,.98);box-shadow:0 8px 30px rgba(20,24,32,.08)}
.nav .row{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:13px}
.brand img{height:44px;width:auto;filter:drop-shadow(.3px 0 0 rgba(20,24,32,.55)) drop-shadow(-.3px 0 0 rgba(20,24,32,.55)) drop-shadow(0 .3px 0 rgba(20,24,32,.55)) drop-shadow(0 -.3px 0 rgba(20,24,32,.55))}
.menu{display:flex;align-items:center;gap:4px}
.menu>a,.menu .has-sub>a{display:inline-flex;align-items:center;line-height:1}
.menu a{position:relative;font-family:var(--mono);text-transform:uppercase;letter-spacing:.05em;font-size:14px;font-weight:700;color:var(--ink-2);padding:10px 12px;border-radius:3px;transition:color .3s}
.menu a::after{content:"";position:absolute;left:12px;right:12px;bottom:6px;height:2px;background:var(--gold-fill);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.menu a:hover,.menu a.active{color:var(--ink)}
.menu a:hover::after,.menu a.active::after{transform:scaleX(1)}
.has-sub{position:relative;display:inline-flex;align-items:center}
.sub{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(10px);min-width:280px;background:var(--card);border:1px solid var(--line);border-radius:6px;padding:12px;opacity:0;visibility:hidden;transition:.35s var(--ease);box-shadow:0 30px 70px rgba(20,24,32,.18)}
.has-sub:hover .sub,.has-sub:focus-within .sub{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.sub a{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:4px;font-size:13px;letter-spacing:.05em;color:var(--muted);font-family:var(--mono);font-weight:700}
.sub a::after{display:none}
.sub a:hover{background:rgba(31,91,255,.08);color:var(--ink)}
.sub a span.n{color:var(--blue);font-size:11px;min-width:24px}
.nav-cta{display:flex;align-items:center;gap:16px}
.burger{display:none;width:46px;height:46px;border:1px solid var(--line);border-radius:4px;background:transparent;position:relative}
.burger i{position:absolute;left:13px;width:20px;height:1.8px;background:var(--ink);transition:.3s var(--ease)}
.burger i:nth-child(1){top:18px}.burger i:nth-child(2){top:24px}.burger i:nth-child(3){top:30px}
.burger.open i:nth-child(1){top:24px;transform:rotate(45deg)}
.burger.open i:nth-child(2){opacity:0}
.burger.open i:nth-child(3){top:24px;transform:rotate(-45deg)}
.mobile{position:fixed;inset:0;z-index:850;background:var(--paper);padding:120px var(--pad) 50px;display:flex;flex-direction:column;gap:6px;transform:translateY(-100%);transition:transform .6s var(--ease);overflow-y:auto}
.mobile.open{transform:translateY(0)}
.mobile a{font-family:var(--display);text-transform:uppercase;font-size:clamp(26px,7vw,40px);letter-spacing:.02em;padding:11px 0;border-bottom:1px solid var(--line-2);color:var(--ink);display:flex;justify-content:space-between;align-items:center}
.mobile a .arr{color:var(--blue)}
.mobile .btn{color:var(--paper)}
.mobile .btn:hover{color:var(--ink)}
@media(max-width:1140px){.menu,.nav-cta .btn{display:none}.burger{display:block}}

/* HERO collage */
.hero-collage{position:relative;min-height:100svh;padding-top:clamp(96px,12vw,150px);padding-bottom:70px;overflow:hidden;display:flex;align-items:center}
.hc-grid{display:grid;grid-template-columns:1.12fr .88fr;gap:clamp(30px,5vw,64px);align-items:center;position:relative;z-index:2;width:100%}
@media(max-width:900px){.hc-grid{grid-template-columns:1fr;gap:40px}}
.hc-tags{display:flex;flex-wrap:wrap;gap:16px;font-family:var(--mono);font-weight:700;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-ink);margin-bottom:20px}
.hc-tags span{display:inline-flex;align-items:center;gap:7px}
.hc-tags span::before{content:"+";color:var(--gold-2);font-size:14px}
.hc-title{font-family:var(--display);font-weight:400;text-transform:uppercase;line-height:.92;font-size:clamp(48px,8.2vw,126px);letter-spacing:.01em;color:var(--ink)}
.hc-title span{display:block}
.hc-title em{font-style:normal;color:var(--blue-ink)}
.hc-title .marker{font-size:.34em;margin-left:.35em;vertical-align:.45em;color:var(--blue)}
.hc-lead{margin-top:24px;max-width:46ch}
.hc-cta{display:flex;align-items:center;gap:22px;margin-top:30px;flex-wrap:wrap}
.hc-barcode{height:34px;margin-top:32px;opacity:.85}
.hc-right{position:relative;display:flex;justify-content:center}
.hc-right.cutout{align-items:flex-end;min-height:clamp(400px,62vh,640px)}
.hc-disc{position:absolute;width:min(440px,92%);aspect-ratio:1;border-radius:50%;background:var(--blue);bottom:6%;left:50%;transform:translateX(-50%);z-index:0}
.hc-disc::after{content:"";position:absolute;inset:0;border-radius:50%;background:radial-gradient(rgba(255,255,255,.2) 1px,transparent 1.4px) 0 0/7px 7px;opacity:.5}
.hc-figure{position:relative;z-index:2;height:clamp(400px,64vh,660px);width:auto;max-width:100%;object-fit:contain;filter:contrast(1.04) drop-shadow(0 22px 34px rgba(20,24,32,.32))}
.hc-photo{position:relative;border:7px solid #fff;box-shadow:0 28px 60px rgba(20,24,32,.28);transform:rotate(3deg);width:min(420px,90%);aspect-ratio:4/5;overflow:hidden;z-index:2}
.hc-photo img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.12) brightness(.96)}
.hc-photo .px-tag{position:absolute;left:10px;bottom:10px;font-family:var(--mono);font-weight:700;font-size:10px;letter-spacing:.1em;color:#fff;background:var(--ink);padding:4px 8px}
.sh{position:absolute;z-index:1;pointer-events:none;user-select:none}
.sh-burst{width:clamp(120px,15vw,210px);top:6%;right:4%;opacity:.92;animation:spin 44s linear infinite}
.sh-blob{width:clamp(180px,24vw,320px);bottom:-50px;right:-40px;opacity:.14;z-index:0}
.sh-tri{width:120px;bottom:14%;left:40%;opacity:.45}
.sh-scatter{width:130px;top:14%;left:36%;opacity:.7}
.sh-burst2{width:84px;left:-26px;bottom:24px;z-index:3}
.sh-stroke{width:230px;left:-10px;top:-28px;opacity:.9;z-index:0}
@keyframes spin{to{transform:rotate(360deg)}}
.hc-mono{position:absolute;bottom:20px;left:0;width:100%;font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted-2);text-align:center;z-index:2}

.ticker{border-block:2px solid var(--ink);padding:22px 0;overflow:hidden;white-space:nowrap;display:flex;background:var(--ink)}
.ticker-track{display:inline-flex;align-items:center;gap:46px;padding-right:46px;animation:slide 32s linear infinite;will-change:transform}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker-track span{font-family:var(--display);text-transform:uppercase;font-size:clamp(24px,3vw,42px);letter-spacing:.02em;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.5)}
.ticker-track span.fill{color:var(--gold-fill);-webkit-text-stroke:0}
.ticker-track .dot{width:9px;height:9px;border-radius:50%;background:var(--blue);-webkit-text-stroke:0}
@keyframes slide{to{transform:translateX(-50%)}}

[data-reveal]{opacity:0;transform:translateY(38px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
[data-reveal].vis{opacity:1;transform:none}
[data-reveal="left"]{transform:translateX(-50px)}
[data-reveal="right"]{transform:translateX(50px)}
[data-delay="1"]{transition-delay:.1s}[data-delay="2"]{transition-delay:.2s}[data-delay="3"]{transition-delay:.3s}[data-delay="4"]{transition-delay:.4s}[data-delay="5"]{transition-delay:.5s}

.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,90px);align-items:center}
@media(max-width:900px){.split{grid-template-columns:1fr}}
.who-figure{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/5;border:1px solid var(--ink);box-shadow:8px 8px 0 rgba(20,24,32,.12)}
.who-figure img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.who-figure:hover img{transform:scale(1.06)}
.who-figure.who-figure-contain{aspect-ratio:1306/807;background:var(--card);display:flex;align-items:center;justify-content:center}
.who-figure.who-figure-contain img{width:100%;height:100%;object-fit:contain;padding:2.5%}
.who-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--ink);border:1px solid var(--ink);border-radius:6px;overflow:hidden;margin-top:18px}
.who-stats>div{background:var(--card);padding:18px 16px;text-align:center}
.who-stats b{font-family:var(--display);font-weight:400;font-size:clamp(28px,3vw,40px);color:var(--blue-ink);line-height:1;display:block}
.who-stats small{display:block;margin-top:6px;text-transform:uppercase;letter-spacing:.14em;font-size:10.5px;color:var(--muted);font-family:var(--mono)}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--ink);border:1px solid var(--ink);border-radius:6px;overflow:hidden}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{background:var(--card);padding:clamp(26px,4vw,46px) clamp(20px,3vw,34px);transition:background .4s}
.stat:hover{background:var(--paper-2)}
.stat .num{font-family:var(--display);font-weight:400;font-size:clamp(48px,6vw,82px);line-height:1;color:var(--blue-ink)}
.stat .lbl{margin-top:12px;text-transform:uppercase;letter-spacing:.14em;font-size:12px;color:var(--muted);font-family:var(--mono)}

.svc-list{border-top:2px solid var(--ink)}
.svc{border-bottom:1px solid var(--line);position:relative}
.svc-head{display:grid;grid-template-columns:90px 1fr auto;align-items:center;gap:24px;padding:clamp(26px,4vw,44px) 6px;transition:padding .4s var(--ease)}
.svc .idx{font-family:var(--mono);color:var(--blue-ink);font-size:14px}
.svc .ti{font-family:var(--display);font-weight:400;font-size:clamp(28px,4.6vw,62px);line-height:1;letter-spacing:.02em;color:var(--ink);transition:transform .5s var(--ease),color .4s}
.svc .ico{width:54px;height:54px;border:1px solid var(--ink);border-radius:50%;display:grid;place-items:center;transition:.4s var(--ease);color:var(--ink)}
.svc:hover .ti{transform:translateX(18px);color:var(--blue-ink)}
.svc:hover .ico{background:var(--gold-fill);color:var(--ink);transform:rotate(45deg);border-color:var(--gold-fill)}
.svc:hover .svc-head{padding-left:22px}
.svc-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .55s var(--ease)}
.svc.open .svc-body{grid-template-rows:1fr}
.svc-body>div{overflow:hidden}
.svc-inner{display:grid;grid-template-columns:1fr 1fr;gap:30px;padding:0 6px 38px 114px;align-items:center}
@media(max-width:820px){.svc-head{grid-template-columns:48px 1fr auto;gap:14px}.svc-inner{grid-template-columns:1fr;padding-left:6px}}
.svc-inner p{color:var(--muted);max-width:54ch}
.svc-img{border-radius:4px;overflow:hidden;aspect-ratio:16/10;border:1px solid var(--ink)}
.svc-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.svc:hover .svc-img img{transform:scale(1.05)}
.svc-units{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.svc-units span{font-family:var(--mono);font-weight:700;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--blue-ink);border:1px solid var(--line);border-radius:2px;padding:6px 13px}
@media (hover:hover) and (pointer:fine){.svc:hover .svc-body{grid-template-rows:1fr}}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
@media(max-width:980px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.grid-3,.grid-2{grid-template-columns:1fr}}
.card{position:relative;border:1px solid var(--ink);border-radius:4px;padding:30px;overflow:hidden;background:var(--card);transition:transform .5s var(--ease),box-shadow .4s;box-shadow:5px 5px 0 rgba(20,24,32,.1)}
.card:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 rgba(31,91,255,.18)}
.card .k{font-family:var(--mono);color:var(--blue-ink);font-size:13px}
.card h3{font-family:var(--display);font-weight:400;font-size:26px;margin:16px 0 12px;text-transform:uppercase;letter-spacing:.01em;color:var(--ink)}
.card p{color:var(--muted);font-size:15px}
.card .ico{width:50px;height:50px;border-radius:6px;background:var(--ink);display:grid;place-items:center;color:var(--gold-fill);margin-bottom:20px}

.cases{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
.case{position:relative;border-radius:var(--r);overflow:hidden;min-height:300px;display:flex;align-items:flex-end;grid-column:span 4;border:1px solid var(--ink);box-shadow:6px 6px 0 rgba(20,24,32,.1)}
.case.wide{grid-column:span 6}.case.tall{min-height:440px}
@media(max-width:900px){.case,.case.wide{grid-column:span 12}}
.case img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 12%;transition:transform 4s var(--ease),filter .5s var(--ease),object-position 4s var(--ease);z-index:-1;filter:grayscale(1) contrast(1.08) brightness(.6)}
.case::after{content:"";position:absolute;inset:0;z-index:-1;background:
  radial-gradient(rgba(255,255,255,.12) 1px,transparent 1.4px) 0 0/5px 5px,
  linear-gradient(180deg,rgba(11,18,30,.5) 0%,rgba(11,18,30,.5) 35%,rgba(11,18,30,.97) 100%);transition:opacity .5s var(--ease)}
.case:hover::after{opacity:0}
.case:hover img{transform:scale(1.12);filter:none;object-position:center 88%}
.case .meta{padding:26px;width:100%}
.case .meta .tag,.case .meta h3,.case .meta p{transition:opacity .45s var(--ease)}
.case:hover .meta .tag,.case:hover .meta h3,.case:hover .meta p{opacity:0}
.case .tag{font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.16em;font-size:11px;color:var(--gold-ink)}
.case h3{font-family:var(--display);font-weight:400;font-size:clamp(20px,2vw,28px);text-transform:uppercase;margin-top:10px;line-height:1.05;letter-spacing:.01em;color:#fff}
.case .meta p{color:rgba(255,255,255,.9)}
.case .meta h3,.case .meta p,.case .tag{text-shadow:0 2px 14px rgba(0,0,0,.85)}
.case .go{margin-top:16px;display:inline-flex;width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.4);align-items:center;justify-content:center;color:#fff;transition:.4s var(--ease)}
.case:hover .go{background:var(--gold-fill);color:var(--ink);transform:rotate(-45deg)}

.logos{display:grid;grid-template-columns:repeat(6,1fr);border:1px solid var(--ink);border-radius:6px;overflow:hidden;background:var(--card)}
@media(max-width:980px){.logos{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.logos{grid-template-columns:repeat(2,1fr)}}
.logos>a,.logos>div{aspect-ratio:3/2;display:grid;place-items:center;padding:22px;border-right:1px solid var(--line-2);border-bottom:1px solid var(--line-2);transition:background .4s}
.logos>a:hover,.logos>div:hover{background:rgba(31,91,255,.06)}
.logos img{max-height:48px;width:auto;object-fit:contain;filter:grayscale(1) opacity(.82);transition:.45s var(--ease)}
.logos>a:hover img,.logos>div:hover img{filter:none;opacity:1;transform:scale(1.08)}

.net{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,70px);align-items:center}
@media(max-width:900px){.net{grid-template-columns:1fr}}
.net-list{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.net-city{padding:18px 4px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px;transition:.4s;font-family:var(--display);text-transform:uppercase;letter-spacing:.04em;font-size:20px;color:var(--ink)}
.net-city .pin{width:8px;height:8px;border-radius:50%;background:var(--blue);box-shadow:0 0 0 0 rgba(31,91,255,.5);animation:pulse 2.4s infinite}
.net-city small{color:var(--muted-2);font-family:var(--mono);letter-spacing:.08em;font-size:11px;text-transform:uppercase}
.net-city:hover{padding-left:14px;color:var(--blue-ink)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(31,91,255,.5)}70%{box-shadow:0 0 0 12px rgba(31,91,255,0)}100%{box-shadow:0 0 0 0 rgba(31,91,255,0)}}
.net-map{position:relative;border:1px solid var(--ink);border-radius:var(--r);overflow:hidden;aspect-ratio:1/1;background:var(--card);display:grid;place-items:center}
.net-map img{width:86%;opacity:.8}

.awards{display:flex;flex-wrap:wrap;justify-content:center;gap:18px}
.award{flex:0 0 calc((100% - 5*18px)/6);aspect-ratio:1;border:1px solid var(--ink);border-radius:6px;display:grid;place-items:center;padding:26px;transition:.4s var(--ease);background:var(--card)}
@media(max-width:980px){.award{flex-basis:calc((100% - 2*18px)/3)}}
@media(max-width:560px){.award{flex-basis:calc((100% - 18px)/2)}}
.award:hover{border-color:var(--blue);transform:translateY(-5px);box-shadow:6px 6px 0 rgba(31,91,255,.15)}
.award img{max-height:92px;max-width:100%;width:auto;object-fit:contain;filter:grayscale(1) brightness(.2) opacity(.8);transition:.4s}
.award:hover img{filter:none;opacity:1}

.news-row{display:flex;align-items:center;gap:24px;padding:24px 4px;border-bottom:1px solid var(--line);transition:.4s var(--ease)}
.news-row:hover{padding-left:16px;background:linear-gradient(90deg,rgba(31,91,255,.06),transparent)}
.news-row .src{font-family:var(--mono);font-weight:700;color:var(--blue-ink);text-transform:uppercase;letter-spacing:.12em;font-size:11px;min-width:130px}
.news-row h3{font-size:clamp(17px,1.7vw,23px);font-family:var(--sans);font-weight:600;line-height:1.3;flex:1;text-transform:none;letter-spacing:0;color:var(--ink)}
.news-row .arr{color:var(--blue);transition:transform .4s var(--ease)}
.news-row:hover .arr{transform:translate(5px,-5px)}

.quote{border:1px solid var(--ink);border-radius:var(--r);padding:clamp(30px,5vw,60px);background:var(--card);position:relative;overflow:hidden;box-shadow:6px 6px 0 rgba(20,24,32,.1)}
.quote .mark{font-family:var(--display);font-size:160px;line-height:.6;color:rgba(31,91,255,.18);position:absolute;top:30px;left:30px}
.quote p{font-family:var(--serif);font-weight:300;font-size:clamp(22px,3vw,40px);line-height:1.25;position:relative;color:var(--ink)}
.quote .who{margin-top:26px;color:var(--blue-ink);font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:13px}
.wearitw{text-align:center;overflow:hidden}
.wearitw .big{font-family:var(--display);font-weight:400;text-transform:uppercase;line-height:.9;font-size:clamp(64px,18vw,260px);letter-spacing:.01em;color:transparent;-webkit-text-stroke:2px rgba(20,24,32,.3)}
.wearitw .big .gold{-webkit-text-stroke:0;color:var(--blue-ink)}

.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:980px){.team-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.team-grid{grid-template-columns:repeat(2,1fr)}}
.member{position:relative;border-radius:6px;overflow:hidden;aspect-ratio:3/4;background:var(--card);border:1px solid var(--ink)}
.member img{width:100%;height:100%;object-fit:cover;filter:contrast(1.02);transition:filter .6s var(--ease),transform 1s var(--ease)}
.member:hover img{transform:scale(1.05)}
.member .cap{position:absolute;left:0;right:0;bottom:0;padding:46px 18px 18px;background:linear-gradient(transparent 0%,rgba(10,23,48,.45) 32%,rgba(13,38,104,.92) 100%);opacity:1;transition:.45s var(--ease)}
.member:hover .cap{background:linear-gradient(transparent 0%,rgba(10,23,48,.55) 28%,rgba(17,49,140,.96) 100%)}
.member .cap b{font-family:var(--display);font-weight:400;font-size:19px;text-transform:uppercase;letter-spacing:.02em;display:block;color:#fff}
.member .cap small{color:var(--gold-ink);font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase}

.cta-band{position:relative;border-radius:10px;overflow:hidden;padding:clamp(48px,8vw,110px) var(--pad);text-align:center;border:1px solid var(--ink);background:var(--ink)}
.cta-band h2{font-size:clamp(36px,6vw,92px);text-transform:uppercase;color:var(--paper)}
.cta-band .lead{margin:22px auto 36px;text-align:center;color:rgba(255,255,255,.7)}
.cta-band .eyebrow{color:var(--gold-fill)}
.cta-band .eyebrow::before{background:var(--blue)}
.cta-band .h2 .gold,.cta-band h2 .gold{color:var(--gold-fill)}

.phero{min-height:60vh;display:flex;align-items:flex-end;padding-top:150px;overflow:hidden;background:var(--paper)}
.phero-bg{position:absolute;inset:0;z-index:-1;opacity:.16}
.phero-bg img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.1)}
.phero-bg::after{content:"";position:absolute;inset:0;background:radial-gradient(rgba(20,24,32,.5) 1px,transparent 1.4px) 0 0/6px 6px;opacity:.4}
.crumb{font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:12px;color:var(--muted);margin-bottom:18px}
.crumb b{color:var(--blue-ink)}
.hero-top{position:absolute;top:clamp(110px,16vw,170px);left:var(--pad);right:var(--pad);display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
.hero-top .tag{font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:12px;color:var(--muted)}

.footer{border-top:2px solid var(--ink);padding-top:clamp(60px,8vw,110px);position:relative;overflow:hidden}
.foot-cta{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:clamp(44px,9vw,150px);line-height:.9;letter-spacing:.01em;color:var(--ink)}
.foot-cta a{display:inline-flex;align-items:center;gap:.2em;transition:color .4s}
.foot-cta a:hover{color:var(--blue-ink)}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.3fr;gap:30px;margin-top:clamp(50px,7vw,90px);padding-bottom:50px}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}
.foot-col h5{font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:12px;color:var(--blue-ink);margin-bottom:20px}
.foot-col a{display:block;color:var(--muted);font-size:14px;padding:7px 0;transition:.3s}
.foot-col a:hover{color:var(--ink);padding-left:6px}
.foot-bot{border-top:1px solid var(--line);padding:26px 0;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:var(--muted-2);font-size:13px;font-family:var(--mono)}
.socials{display:flex;gap:10px}
.socials a{width:40px;height:40px;border:1px solid var(--ink);border-radius:50%;display:grid;place-items:center;color:var(--ink);transition:.4s var(--ease)}
.socials a:hover{background:var(--ink);color:var(--paper);transform:translateY(-4px)}

.form{display:grid;gap:18px}
.field input,.field textarea,.field select{width:100%;background:var(--card);border:1px solid var(--ink);border-radius:4px;padding:17px 18px;color:var(--ink);font-family:var(--sans);font-size:15px;transition:.3s}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--blue);box-shadow:3px 3px 0 rgba(31,91,255,.15)}
.field input::placeholder,.field textarea::placeholder{color:var(--muted-2)}
.note{font-size:12.5px;color:var(--muted);background:rgba(31,91,255,.06);border:1px solid rgba(31,91,255,.2);border-radius:4px;padding:12px 14px}
.cinfo{display:flex;align-items:center;gap:16px;padding:20px 0;border-bottom:1px solid var(--line)}
.cinfo .ic{width:48px;height:48px;border-radius:6px;background:var(--ink);display:grid;place-items:center;color:var(--gold-fill);flex-shrink:0}
.cinfo b{font-family:var(--display);font-weight:400;text-transform:uppercase;letter-spacing:.02em;font-size:18px;display:block;color:var(--ink)}
.cinfo small{color:var(--muted);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;font-size:11px}

.pos-list{border-top:2px solid var(--ink)}
.pos{display:grid;grid-template-columns:1.4fr 1fr auto;gap:24px;align-items:center;padding:26px 6px;border-bottom:1px solid var(--line);transition:.4s var(--ease)}
.pos:hover{padding-left:16px;background:linear-gradient(90deg,rgba(31,91,255,.06),transparent)}
.pos-role{display:flex;align-items:center;gap:18px}
.pos-role .idx{font-family:var(--mono);color:var(--blue-ink);font-size:15px}
.pos-role b{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:clamp(18px,2vw,26px);letter-spacing:.02em;display:block;line-height:1.05;color:var(--ink)}
.pos-role small{color:var(--blue-ink);font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase}
.pos-meta{display:flex;flex-direction:column;gap:6px;color:var(--muted);font-size:13px;font-family:var(--mono)}
.pos-meta span{display:inline-flex;align-items:center;gap:8px}
@media(max-width:760px){.pos{grid-template-columns:1fr;gap:12px}}
.office-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.office-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.office-grid{grid-template-columns:1fr}}
.office{display:flex;gap:14px;border:1px solid var(--ink);border-radius:6px;padding:22px;background:var(--card);transition:.4s var(--ease)}
.office:hover{transform:translateY(-4px);box-shadow:6px 6px 0 rgba(31,91,255,.14)}
.office .ic{width:42px;height:42px;border-radius:6px;background:var(--ink);display:grid;place-items:center;color:var(--gold-fill);flex-shrink:0}
.office b{font-family:var(--display);font-weight:400;text-transform:uppercase;letter-spacing:.02em;font-size:18px;display:block;color:var(--ink)}
.office .ar{display:block;color:var(--blue-ink);font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;margin:2px 0 8px}
.office p{color:var(--muted);font-size:13px;line-height:1.5}
.ir-subnav{position:sticky;top:56px;z-index:80;background:rgba(238,235,227,.96);backdrop-filter:blur(14px);border-block:1px solid var(--line)}
.ir-subnav .wrap{display:flex;gap:8px;overflow-x:auto;padding-block:14px;scrollbar-width:none}
.ir-subnav .wrap::-webkit-scrollbar{display:none}
.ir-subnav a{white-space:nowrap;font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:12px;color:var(--muted);padding:9px 16px;border-radius:3px;border:1px solid transparent;transition:.3s}
.ir-subnav a:hover{color:var(--ink);border-color:var(--ink)}
.note-band{display:flex;gap:14px;align-items:flex-start;border:1px solid var(--ink);background:var(--card);border-radius:6px;padding:18px 22px;color:var(--muted);font-size:14px;line-height:1.6}
.note-band .ic{color:var(--blue-ink);flex-shrink:0;margin-top:2px}
.note-band b{color:var(--ink)}
.ir-anchor{scroll-margin-top:130px}
.fy-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:26px}
.fy-tab{font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:13px;color:var(--muted);padding:10px 18px;border:1px solid var(--ink);border-radius:3px;background:transparent;transition:.3s}
.fy-tab.active{background:var(--ink);color:var(--paper)}
.fy-panel{display:none}.fy-panel.active{display:block}
.doc-list{border-top:2px solid var(--ink)}
.doc-row{display:flex;align-items:center;gap:18px;padding:18px 6px;border-bottom:1px solid var(--line);transition:.3s var(--ease)}
.doc-row:hover{padding-left:12px;background:linear-gradient(90deg,rgba(31,91,255,.05),transparent)}
.doc-row .di{width:42px;height:42px;border-radius:6px;background:var(--ink);display:grid;place-items:center;color:var(--gold-fill);flex-shrink:0}
.doc-row .dt{flex:1;min-width:0}
.doc-row .dt b{font-family:var(--sans);font-weight:600;font-size:15px;display:block;color:var(--ink)}
.doc-row .dt small{color:var(--muted-2);font-family:var(--mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase}
.doc-row .dl{font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:11px;color:var(--blue-ink);border:1px solid var(--ink);border-radius:3px;padding:9px 15px;transition:.3s;white-space:nowrap}
.doc-row .dl:hover{background:var(--ink);color:var(--paper)}
.doc-row .dl.soon{color:var(--muted-2);border-color:var(--line);pointer-events:none}
.gov-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
@media(max-width:760px){.gov-grid{grid-template-columns:1fr}}
.policy-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.policy-chips a{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--ink);border-radius:3px;padding:10px 16px;font-size:13px;color:var(--ink);font-family:var(--mono);transition:.3s}
.policy-chips a:hover{background:var(--ink);color:var(--paper)}
.policy-chips .chip-disabled{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:3px;padding:10px 16px;font-size:13px;color:var(--ink);font-family:var(--mono);background:rgba(251,250,245,.45)}
.policy-chips .chip-disabled svg{color:var(--blue-ink);flex-shrink:0}
.kmp-row{display:flex;justify-content:space-between;gap:16px;padding:16px 0;border-bottom:1px solid var(--line)}
.kmp-row b{font-family:var(--display);font-weight:400;text-transform:uppercase;letter-spacing:.02em;font-size:16px;color:var(--ink)}
.kmp-row small{color:var(--blue-ink);font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase}
.kmp-row .val{color:var(--muted);font-size:14px;text-align:right}
.tbd{color:var(--muted-2);font-style:italic}
.badge-soon{display:inline-block;font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:10px;color:var(--blue-ink);border:1px solid var(--line);border-radius:20px;padding:3px 9px;margin-left:8px;vertical-align:middle}

.center{text-align:center}
.mt-s{margin-top:22px}.mt-m{margin-top:40px}.mt-l{margin-top:64px}
.flex-between{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap}
.divider{height:1px;background:var(--line);margin:0}
.pill{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--ink);border-radius:3px;padding:8px 16px;font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink)}
.tcol{display:flex;flex-direction:column;gap:8px}
.form-ok{font-family:var(--mono);font-weight:700;color:var(--blue-ink)}

/* collage decoration — site-wide shapes (removed) */
section:not(.hero-collage):not(.phero){overflow:hidden}
section:not(.hero-collage):not(.phero)::before,
section:not(.hero-collage):not(.phero)::after{display:none!important}
.phero::before{display:none!important}

/* accessibility */
a:focus-visible,button:focus-visible,.btn:focus-visible,.link-u:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid var(--blue);outline-offset:2px;border-radius:2px}
@media (prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}

/* awards: raw images, single-row marquee (no chips, no filter) */
.award-marquee{overflow:hidden;width:100%;-webkit-mask:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.award-track{display:flex;align-items:center;gap:clamp(48px,6vw,100px);width:max-content;animation:awslide 38s linear infinite}
.award-marquee:hover .award-track{animation-play-state:paused}
.aw-logo{height:clamp(120px,14vw,185px);width:auto;object-fit:contain;flex:none}
@keyframes awslide{to{transform:translateX(-50%)}}

/* B&W treated images reveal original colour on hover */
.m-color{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .55s var(--ease);z-index:1}
.member:hover .m-color,.who-figure:hover .m-color{opacity:1}
.member .cap{z-index:2}

/* hero illustration panel */


.hc-right.illus .sh-burst2{z-index:1;opacity:.85}

/* full-width hero: illustration anchored in the right corner */
.hero-illus .hc-grid{grid-template-columns:1fr}
.hero-illus .hc-left{max-width:760px;position:relative;z-index:2}
.hc-illus{position:absolute;right:0;bottom:0;top:auto;height:clamp(460px,92%,900px);width:auto;max-width:58vw;object-fit:contain;object-position:bottom right;z-index:0;pointer-events:none;
  -webkit-mask:linear-gradient(90deg,transparent 0%,#000 24%);mask:linear-gradient(90deg,transparent 0%,#000 24%)}
@media(max-width:900px){.hc-illus{position:relative;right:auto;bottom:auto;max-width:100%;height:auto;margin-top:24px;-webkit-mask:none;mask:none}.hero-illus .hc-grid{grid-template-columns:1fr}}
/* ===== full-bleed landscape hero banner (responsive) ===== */
.hero-banner{min-height:0;height:clamp(560px,52vw,900px);padding:0;margin-top:clamp(52px,6vw,62px);display:flex;align-items:center;overflow:hidden}
.hero-banner .hb-bg{position:absolute;inset:0;z-index:0}
.hero-banner .hb-bg img{width:100%;height:100%;object-fit:cover;object-position:left center}
.hero-banner .hb-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--paper) 0%,rgba(221,230,242,.72) 22%,rgba(221,230,242,.12) 44%,transparent 56%)}
.hero-banner .hc-grid{grid-template-columns:1fr;position:relative;z-index:2}
.hero-banner .hc-left{max-width:600px;padding-top:0}
.hero-banner .hc-title{font-size:clamp(40px,6.4vw,108px)}
.hero-banner .sh,.hero-banner .hc-barcode{display:none}
.hero-banner .hc-mono{color:var(--navy);bottom:0;padding:16px 0 15px;background:linear-gradient(180deg,transparent,rgba(255,255,255,.92) 60%);text-shadow:none;z-index:3}
.hero-banner .hc-title{color:var(--ink)}
.hero-banner .hc-left .lead,.hero-banner .hc-left p{color:rgba(21,24,30,.82)}
/* tablet & down: full-bleed image, text overlaid on a bottom yellow scrim (like desktop) */
@media(max-width:1024px){
  .hero-banner{height:auto;min-height:calc(100vh - 56px);min-height:calc(100svh - 56px);max-height:none;display:flex;flex-direction:column;padding:0;background:rgb(250,180,1)}
  .hero-banner .hb-bg{position:relative;inset:auto;flex:1 1 auto;min-height:320px;aspect-ratio:auto;width:100%;height:auto;z-index:0;order:1;background:rgb(250,180,1) url(/assets/images/hero-banner-mobile.webp) 50% 20%/cover no-repeat}
  .hero-banner .hb-bg img{display:none}
  .hero-banner .hb-bg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:72% 24%}
  .hero-banner .hb-bg::after{display:block;background:linear-gradient(180deg,transparent 76%,rgba(250,180,1,.55) 90%,rgb(250,180,1) 100%)}
  .hero-banner .hc-grid{position:relative;z-index:2;flex:0 0 auto;order:2}
  .hero-banner .hc-left{max-width:100%;padding:22px 0 16px}
  .hero-banner .hc-title{font-size:clamp(31px,7.8vw,60px);line-height:1}
  .hero-banner .hc-left .lead,.hero-banner .hc-left p{color:rgba(21,24,30,.9)}
  .hero-banner .hb-fx{display:block;position:absolute;left:0;right:0;top:0;bottom:auto;height:62%;width:100%;opacity:.8;pointer-events:none;overflow:hidden;z-index:1;-webkit-mask-image:linear-gradient(180deg,#000 70%,transparent 100%);mask-image:linear-gradient(180deg,#000 70%,transparent 100%)}
  .hero-banner .hb-fx .shard{width:clamp(20px,5vw,34px);opacity:.45}
  .hero-banner .hb-fx .hb-sweep{filter:blur(9px);animation-duration:9s;opacity:.85}
  .hero-banner .hb-fx .ember{box-shadow:0 0 5px 1px rgba(120,170,255,.5)}
  .hero-banner .hc-mono{display:block;position:relative;inset:auto;bottom:auto;order:3;flex:0 0 auto;width:100%;text-align:center;background:var(--paper);color:var(--navy);padding:13px 14px;font-size:12px;letter-spacing:.14em;text-shadow:none;z-index:3}
}
@media(max-width:560px){
  .hero-banner .hb-bg img{object-position:74% 24%}
  .hero-banner .hc-title{font-size:clamp(29px,8.2vw,50px)}
  .hero-banner .hc-lead{font-size:14.5px}
  .hero-banner .hc-mono{font-size:10.5px;letter-spacing:.1em}
}

/* =====================================================================
   BOLD ELECTRIC MOMENTS — light base · saturated blue+gold key-art bands
   Echoes the hero splash: deep electric blue + gold diagonal energy shards
   ===================================================================== */
:root{ --elec-1:#0a1730; --elec-2:#11296f; --elec-3:#2147c8; --shard-gold:#ffba00; }

/* full-bleed electric band: paints edge-to-edge, .wrap keeps content centred */
.electric{position:relative;color:#fff;isolation:isolate;overflow:hidden;
  background:
    radial-gradient(120% 150% at 86% -12%, rgba(255,186,0,.20), transparent 46%),
    radial-gradient(115% 130% at -8% 114%, rgba(31,91,255,.55), transparent 54%),
    linear-gradient(118deg,var(--elec-1) 0%,var(--elec-2) 48%,var(--elec-3) 100%);
  box-shadow:inset 0 2px 0 rgba(255,186,0,.55), inset 0 -1px 0 rgba(255,186,0,.16);}
/* neutralise the light-section collage shapes on electric bands */
section.electric::before, section.electric::after{display:none!important;content:none!important}
.electric>.wrap{position:relative;z-index:2}
.electric .eyebrow{color:var(--shard-gold)}
.electric .eyebrow::before{background:var(--blue)}
.electric h2,.electric .h2,.electric h3{color:#fff}
.electric .gold,.electric .h2 .gold,.electric h2 .gold{color:var(--shard-gold)}
.electric .lead{color:rgba(255,255,255,.78)}

/* diagonal gold + blue energy shards (hero splash echo) — reusable */
.shards{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.shards::before{content:"";position:absolute;inset:-12% -6%;mix-blend-mode:screen;opacity:.9;
  background:
   linear-gradient(116deg,transparent 31.4%,rgba(255,186,0,.95) 32%,rgba(255,186,0,.95) 33%,transparent 33.6%),
   linear-gradient(116deg,transparent 35%,rgba(255,186,0,.42) 35.4%,rgba(255,186,0,.42) 35.9%,transparent 36.3%),
   linear-gradient(116deg,transparent 63.6%,rgba(150,185,255,.62) 64.1%,rgba(150,185,255,.62) 65%,transparent 65.5%),
   linear-gradient(116deg,transparent 70%,rgba(150,185,255,.30) 70.3%,rgba(150,185,255,.30) 70.7%,transparent 71%);}
.shards::after{content:"";position:absolute;width:56%;aspect-ratio:1;right:-8%;top:-34%;
  background:radial-gradient(circle,rgba(255,186,0,.30),transparent 62%);filter:blur(6px)}
@media(prefers-reduced-motion:no-preference){
  .electric .shards::before{animation:shardpulse 6s var(--ease) infinite alternate}
}
@keyframes shardpulse{from{opacity:.7;transform:translateX(-1.2%)}to{opacity:1;transform:translateX(1.2%)}}

/* STATS as a full-bleed electric band */
.band-stats{padding-block:clamp(58px,8vw,108px)}
.band-stats .stats{background:transparent;border:0;border-radius:0;gap:0;box-shadow:none}
.band-stats .stat{background:transparent;border-left:1px solid rgba(255,255,255,.14);padding:clamp(18px,3vw,40px) clamp(18px,2.4vw,34px);transition:background .4s var(--ease)}
.band-stats .stat:first-child{border-left:0}
.band-stats .stat:hover{background:rgba(255,255,255,.06)}
.band-stats .stat .num{color:var(--shard-gold);font-variant-numeric:tabular-nums;text-shadow:0 0 34px rgba(255,186,0,.45)}
.band-stats .stat .lbl{color:rgba(255,255,255,.72)}
@media(max-width:760px){.band-stats .stat:nth-child(odd){border-left:0}.band-stats .stat:nth-child(3),.band-stats .stat:nth-child(4){border-top:1px solid rgba(255,255,255,.14)}}

/* WE ARE ITW — cinematic electric band */
.wearitw.electric{padding-block:clamp(84px,12vw,168px)}
.wearitw.electric .big{color:transparent;-webkit-text-stroke:2px rgba(255,255,255,.82)}
.wearitw.electric .big .gold{-webkit-text-stroke:0;color:var(--shard-gold);text-shadow:0 0 44px rgba(255,186,0,.5)}
.wearitw .kick{margin-top:22px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.22em;font-size:12px;color:rgba(255,255,255,.7)}

/* CTA band → electric gradient + shards + glow */
.cta-band{border:0;background:linear-gradient(118deg,var(--elec-1) 0%,var(--elec-2) 50%,var(--elec-3) 100%);
  box-shadow:0 50px 110px -50px rgba(15,40,120,.8), inset 0 2px 0 rgba(255,186,0,.5);isolation:isolate}
.cta-band>*{position:relative;z-index:2}
.cta-band .shards{border-radius:inherit}
.cta-band h2{color:#fff;text-wrap:balance}
.cta-band .h2 .gold,.cta-band h2 .gold{color:var(--shard-gold)}
.cta-band .foot-cta a{color:#fff}
.cta-band .foot-cta a:hover{color:var(--shard-gold)}

/* INNER-PAGE HERO (phero) → electric so every page opens with a bold moment */
.phero.electric{color:#fff;background:linear-gradient(120deg,var(--elec-1) 0%,var(--elec-2) 56%,var(--elec-3) 100%)}
.phero.electric .phero-bg{opacity:.20;mix-blend-mode:luminosity;z-index:0}
.phero.electric .phero-bg::after{opacity:.18}
.phero.electric>.wrap{position:relative;z-index:2}
.phero.electric .h-display{color:#fff;text-wrap:balance}
.phero.electric .crumb{color:rgba(255,255,255,.7)}
.phero.electric .crumb a{color:rgba(255,255,255,.7)} .phero.electric .crumb b{color:var(--shard-gold)}
.phero.electric .lead{color:rgba(255,255,255,.82)}
.phero.electric .hero-orb{opacity:.5;mix-blend-mode:screen}

/* TICKER → tie into the electric palette */
.ticker{background:linear-gradient(110deg,var(--elec-1),var(--elec-2))}

/* ---- premium polish (per high-end-visual-design + web interface guidelines) ---- */
h1,h2,h3,h4,.h2,.h-display,.hc-title,.foot-cta{text-wrap:balance}
.lead,p{text-wrap:pretty}
.num,.who-stats b,.stat .num,.fy-num{font-variant-numeric:tabular-nums}
[id]{scroll-margin-top:96px}

/* buttons / links sitting on electric bands → gold pop, readable */
.electric .btn,.cta-band .btn{background:var(--shard-gold);border-color:var(--shard-gold);color:#0a1730}
.electric .btn::before,.cta-band .btn::before{background:#fff}
.electric .btn:hover,.cta-band .btn:hover{color:#0a1730}
.electric .link-u{color:#fff}
.electric .link-u .arr{color:var(--shard-gold)}


/* ===== interactive dot globe (blue + gold) ===== */
.net-map.globe-wrap{display:block;position:relative;background:transparent;border:1px solid var(--line);overflow:visible;aspect-ratio:1/1}
.net-map.globe-wrap .globe{display:block;width:100%;height:100%;cursor:grab;touch-action:none}
.net-map.globe-wrap .globe:active{cursor:grabbing}
.globe-hint{position:absolute;left:16px;bottom:14px;font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:10px;color:var(--muted-2);pointer-events:none}
.globe-tip{position:absolute;transform:translate(-50%,calc(-100% - 14px));background:#0a1730;color:#fff;border:1px solid rgba(255,186,0,.5);border-radius:5px;padding:7px 11px;font-family:var(--mono);font-size:11px;line-height:1.25;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s var(--ease);box-shadow:0 14px 34px rgba(10,23,48,.4);z-index:4;pointer-events:none}
.globe-tip.on{opacity:1;visibility:visible}
.globe-tip b{display:block;font-weight:700;letter-spacing:.04em}
.globe-tip span{display:block;color:var(--gold-fill);font-size:9.5px;text-transform:uppercase;letter-spacing:.14em;margin-top:2px}
/* city list → interactive */
.net-city{cursor:pointer;transition:padding-left .3s var(--ease),color .3s}
.net-city:hover,.net-city:focus-visible,.net-city.active{padding-left:8px;outline:none}
.net-city.active .pin,.net-city:hover .pin{background:var(--gold-fill);box-shadow:0 0 0 4px rgba(255,186,0,.22)}
.net-city.active,.net-city:hover{color:var(--ink)}

/* ===== hero banner immersive FX (gold sparks + light sweep) ===== */
.hero-banner .hb-fx{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.hb-fx .hb-sweep{position:absolute;top:-25%;left:-40%;width:38%;height:150%;transform:skewX(-16deg);filter:blur(7px);background:linear-gradient(100deg,transparent,rgba(255,255,255,.14),rgba(255,210,90,.10),transparent);animation:hbSweep 7.5s var(--ease) infinite}
@keyframes hbSweep{0%{left:-40%;opacity:0}12%{opacity:1}55%{left:120%;opacity:0}100%{left:120%;opacity:0}}
.hb-fx .spark{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(255,214,92,.98),rgba(255,186,0,.5) 40%,rgba(255,186,0,0) 70%);opacity:0;will-change:transform,opacity;animation-name:hbSpark;animation-timing-function:ease-in;animation-iteration-count:infinite}
@keyframes hbSpark{0%{opacity:0;transform:translateY(24px) scale(.5)}12%{opacity:1}80%{opacity:.85}100%{opacity:0;transform:translateY(-150px) scale(1.15)}}
.hb-fx .ember{position:absolute;width:2px;height:2px;border-radius:50%;background:rgba(140,180,255,.9);box-shadow:0 0 6px 1px rgba(120,170,255,.6);opacity:.0;animation-name:hbSpark;animation-timing-function:linear;animation-iteration-count:infinite}
.hb-fx .shard{position:absolute;width:clamp(26px,3vw,46px);opacity:.5;filter:drop-shadow(0 0 8px rgba(255,186,0,.4));animation:hbDrift 11s ease-in-out infinite}
@keyframes hbDrift{0%,100%{transform:translate(0,0) rotate(0deg)}50%{transform:translate(10px,-16px) rotate(14deg)}}
@media(prefers-reduced-motion:reduce){.hb-fx{display:none}}
@media(max-width:1024px){.hero-banner .hb-fx{opacity:.7}}

/* ===== hero desktop subtle motion: floating shapes, barcode pulse, mono shimmer ===== */
@media(prefers-reduced-motion:no-preference){
  .hero-collage .sh{will-change:transform}
  .hero-collage .sh-blob{animation:heroFloatA 16s ease-in-out infinite}
  .hero-collage .sh-scatter{animation:heroFloatB 13s ease-in-out infinite;animation-delay:-3s}
  .hero-collage .sh-tri{animation:heroFloatA 18s ease-in-out infinite;animation-delay:-6s}
  .hero-collage .sh-burst{animation:heroFloatB 15s ease-in-out infinite;animation-delay:-2s}
  .hc-barcode{animation:heroBarPulse 4.6s ease-in-out infinite}
}
@keyframes heroFloatA{0%,100%{transform:translate3d(0,0,0) rotate(0deg)}50%{transform:translate3d(0,-14px,0) rotate(2deg)}}
@keyframes heroFloatB{0%,100%{transform:translate3d(0,0,0) rotate(0deg)}50%{transform:translate3d(6px,10px,0) rotate(-3deg)}}
@keyframes heroBarPulse{0%,100%{opacity:.7;filter:drop-shadow(0 0 0 rgba(212,175,55,0))}50%{opacity:1;filter:drop-shadow(0 0 10px rgba(212,175,55,.45))}}


/* ===== premium type: make display headings heroic-heavy (Big Shoulders) ===== */
.h-display,.h2,.hc-title,.foot-cta,.wearitw .big,.ticker-track span,.stat .num,.who-stats b,.cta-band h2{font-weight:800;letter-spacing:.005em}
.hc-title{letter-spacing:0}

/* ===== heroic stats band + icons ===== */
.band-stats .stat{display:flex;flex-direction:column;align-items:flex-start;gap:0}
.band-stats .stat-ic{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:11px;margin-bottom:18px;color:var(--shard-gold);background:rgba(255,186,0,.12);border:1px solid rgba(255,186,0,.32);box-shadow:0 0 26px rgba(255,186,0,.18)}
.band-stats .stat-ic svg{width:24px;height:24px}
.band-stats .stat .num{font-size:clamp(58px,7.4vw,116px);line-height:.92;color:var(--shard-gold);text-shadow:0 0 40px rgba(255,186,0,.5)}
.band-stats .stat .lbl{margin-top:10px;font-size:13px;letter-spacing:.2em;color:rgba(255,255,255,.78)}
@media(prefers-reduced-motion:no-preference){.band-stats .stat-ic{transition:transform .4s var(--ease),box-shadow .4s}.band-stats .stat:hover .stat-ic{transform:translateY(-3px);box-shadow:0 0 34px rgba(255,186,0,.4)}}

/* ===== reusable FX layer for electric cards (CTA etc.) ===== */
.fx-layer{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden;border-radius:inherit}
.fx-layer .spark{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(255,214,92,.98),rgba(255,186,0,.5) 40%,rgba(255,186,0,0) 70%);opacity:0;will-change:transform,opacity;animation-name:hbSpark;animation-timing-function:ease-in;animation-iteration-count:infinite}
.fx-layer .ember{position:absolute;width:2px;height:2px;border-radius:50%;background:rgba(150,185,255,.9);box-shadow:0 0 6px 1px rgba(120,170,255,.55);opacity:0;animation-name:hbSpark;animation-timing-function:linear;animation-iteration-count:infinite}
.fx-layer .hb-sweep{position:absolute;top:-25%;left:-40%;width:34%;height:150%;transform:skewX(-16deg);filter:blur(7px);background:linear-gradient(100deg,transparent,rgba(255,255,255,.12),rgba(255,210,90,.08),transparent);animation:hbSweep 8s var(--ease) infinite}
.cta-band .fx-layer,.cta-band .shards{z-index:1}
.cta-band .shards::before{opacity:1}
.cta-band>.fx-layer,.cta-band>.shards{position:absolute}
@media(prefers-reduced-motion:reduce){.fx-layer{display:none}}

/* pawsome spotlight posters — show full image, never crop */
.paw-img{margin-bottom:20px;border-radius:6px;overflow:hidden;border:1px solid var(--ink);background:var(--card)}
.paw-img img{width:100%;height:auto;display:block;object-fit:contain;transition:transform 1s var(--ease)}
.card:hover .paw-img img{transform:scale(1.03)}

/* ============================================================
   RESPONSIVE AUDIT FIXES — premium mobile parity
   ============================================================ */
/* grid/flex children must be allowed to shrink (kills image overflow) */
.split>*,.net>*,.cases>*,.grid-3>*,.grid-2>*,.who>*,.foot-grid>*,.svc-inner>*{min-width:0}
.who-figure img,.case img,.card img,.svc-img img,.paw-img img{max-width:100%}

@media(max-width:900px){
  .net-list{grid-template-columns:1fr}
}
@media(max-width:560px){
  section{padding-block:clamp(46px,9vw,74px)}
  .who-stats{grid-template-columns:1fr}
  .who-stats>div{padding:16px 14px}
  .stats{grid-template-columns:1fr}
  .band-stats .stat{align-items:center;text-align:center;border-left:0!important;border-top:1px solid rgba(255,255,255,.14);padding:22px 16px}
  .band-stats .stat:first-child{border-top:0}
  .band-stats .stat .num{font-size:clamp(50px,16vw,80px)}
  .wearitw .big{font-size:clamp(40px,15vw,74px);-webkit-text-stroke-width:1.4px}
  .foot-cta{font-size:clamp(32px,11vw,60px)}
  .hc-title{font-size:clamp(34px,11vw,66px)}
  .h-display{font-size:clamp(36px,12vw,74px)}
  .h2{font-size:clamp(32px,9vw,60px)}
  .who-figure{box-shadow:4px 4px 0 rgba(20,24,32,.12)}
  .case{box-shadow:4px 4px 0 rgba(20,24,32,.1)}
  .quote{box-shadow:4px 4px 0 rgba(20,24,32,.1)}
  .foot-col a{padding:11px 0}
  .socials a{width:44px;height:44px}
  .net-map.globe-wrap{overflow:hidden}
  .globe-tip{white-space:normal;max-width:min(64vw,220px)}
  .hc-title,.h-display,.foot-cta,.wearitw .big,.h2{overflow-wrap:anywhere}
  .btn{padding:15px 22px}
  .cta-band{padding-inline:24px}
}

/* mobile menu — expandable submenu (Services) */
.mobile details.mob-sub{border-bottom:1px solid var(--line-2)}
.mobile .mob-sub summary{list-style:none;cursor:pointer;font-family:var(--display);text-transform:uppercase;font-size:clamp(26px,7vw,40px);letter-spacing:.02em;padding:11px 0;color:var(--ink);display:flex;justify-content:space-between;align-items:center}
.mobile .mob-sub summary::-webkit-details-marker{display:none}
.mobile .mob-sub .mob-chev{color:var(--blue);transition:transform .35s var(--ease);flex:none}
.mobile .mob-sub[open] .mob-chev{transform:rotate(180deg)}
.mobile .mob-sublist{display:flex;flex-direction:column;padding:0 0 12px 2px}
.mobile .mob-sublist a{font-family:var(--mono);font-weight:700;text-transform:uppercase;font-size:14px;letter-spacing:.06em;padding:10px 0;border-bottom:none;color:var(--muted);justify-content:flex-start}
.mobile .mob-sublist a::before{content:"—";color:var(--gold-fill);margin-right:10px}
.mobile .mob-sublist a:hover{color:var(--ink)}

/* Lighthouse: respect reduced motion + cap focus visibility */
@media (prefers-reduced-motion: reduce) {
  .hb-fx .spark, .hb-fx .ember, .hb-fx .shard, .hb-sweep,
  .sh, [class*="animate"], [style*="animation"] {
    animation: none !important;
    transition: none !important;
  }
  * { scroll-behavior: auto !important; }
}
/* unified focus ring lives at top of file */

/* Apply modal */
.apply-modal { position: fixed; inset: 0; z-index: 999; display: flex; align-items: center; justify-content: center; padding: 20px; }
.apply-modal[hidden] { display: none; }
.apply-modal__backdrop { position: absolute; inset: 0; background: rgba(8,8,8,.7); backdrop-filter: blur(4px); }
.apply-modal__card { position: relative; background: #fff; color: #111; border-radius: 14px; max-width: 620px; width: 100%; max-height: 90vh; overflow-y: auto; padding: 30px 28px; box-shadow: 0 30px 80px rgba(0,0,0,.4); }
.apply-modal__close { position: absolute; top: 12px; right: 16px; background: transparent; border: 0; font-size: 28px; line-height: 1; cursor: pointer; color: #555; }
.apply-modal__close:hover { color: #000; }
.apply-modal .field input[type="file"] { padding: 10px 12px; background: #f6f6f6; border-radius: 8px; cursor: pointer; width: 100%; box-sizing: border-box; }
.apply-modal .apply-file label { display: block; margin-bottom: 6px; font-size: 13px; }
.form-status { margin-top: 10px; font-size: 14px; }
@media (max-width: 600px) {
  .apply-modal__card { padding: 24px 18px; }
}

/* --- Audit pass additions --- */
.case.is-soon{cursor:default}
.case.is-soon::before{content:"Coming soon";position:absolute;top:14px;right:14px;z-index:2;background:rgba(10,37,64,.85);color:#fff;font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border-radius:999px}
.case.is-soon:hover img{transform:none;filter:grayscale(1) contrast(1.08) brightness(.6);object-position:center 12%}
.case.is-soon:hover::after{opacity:1}
.chip-disabled{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.55);font-size:13px;cursor:not-allowed}
.chip-disabled svg{opacity:.6}
/* No-JS fallback: reveal hidden content if reveal class never gets added */
@media (scripting: none){[data-reveal]{opacity:1!important;transform:none!important}}

/* Blog article body */
.art-wrap{max-width:768px}
.art-back{margin-bottom:28px}
.article{font-size:clamp(16px,1.3vw,18px);line-height:1.78}
.article p{margin:0 0 22px;color:var(--ink-2)}
.article p:first-of-type{font-size:1.1em;color:var(--ink)}
.article .art-h{font-family:var(--serif);font-weight:600;font-size:clamp(21px,2.3vw,29px);color:var(--navy);margin:38px 0 12px;line-height:1.18}


/* a11y utilities */
.skip-link{position:absolute;left:-9999px;top:0;z-index:99999;background:var(--ink);color:#fff;padding:10px 16px;font-family:var(--mono);font-weight:700;font-size:13px;letter-spacing:.08em;text-transform:uppercase;border-radius:0 0 6px 0}
.skip-link:focus{left:0}
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* CTA row (primary contact + secondary AI ghost) */
.cta-row{display:inline-flex;gap:14px;flex-wrap:wrap;align-items:center}
.center .cta-row,.cta-row.mt-m{justify-content:center}
@media(max-width:640px){.cta-row{display:flex;width:100%}.cta-row .btn,.cta-row .btn-ghost-ai{flex:1 1 100%;justify-content:center}}

/* AI sparkle icon — gentle pulse on hover */
.ai-spark{transition:transform .5s var(--ease);transform-origin:center;flex:0 0 auto}
.btn:hover .ai-spark,.btn-ghost-ai:hover .ai-spark{transform:rotate(90deg) scale(1.1)}

/* Secondary AI button — ghost style, sparkle accent */
.btn-ghost-ai{position:relative;display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-weight:700;font-size:12px;padding:14px 22px;border-radius:3px;border:1px solid color-mix(in oklab,var(--ink) 35%,transparent);color:var(--ink);background:transparent;text-decoration:none;transition:border-color .25s var(--ease),color .25s var(--ease),background .25s var(--ease)}
.btn-ghost-ai:hover{border-color:var(--ink);background:color-mix(in oklab,var(--gold,#d4af37) 12%,transparent)}
.btn-ghost-ai .ai-spark{color:var(--gold,#d4af37)}
.btn-ai-compact{padding:12px 14px;gap:8px;font-size:11px}
@media(max-width:1140px){.btn-ai-compact{display:none}}

/* AI banner on contact-us page */
.ai-banner-section{padding-top:0}
.ai-banner{display:flex;gap:32px;align-items:center;justify-content:space-between;flex-wrap:wrap;padding:28px 32px;border:1px solid var(--ink);border-radius:6px;background:linear-gradient(135deg,#fff 0%,#f4f6fb 100%);position:relative;overflow:hidden}
.ai-banner::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at top right,color-mix(in oklab,var(--blue) 12%,transparent),transparent 60%);pointer-events:none}
.ai-banner-text{flex:1 1 380px;position:relative;z-index:1}
.ai-banner-text h3{font-family:var(--display);font-size:clamp(22px,2.6vw,30px);margin:6px 0 6px;letter-spacing:-.01em}
.ai-banner-text p{color:var(--muted);font-size:15px;max-width:60ch}
.ai-banner .btn{position:relative;z-index:1;flex:0 0 auto}
@media(max-width:640px){.ai-banner{padding:22px}.ai-banner .btn{width:100%;justify-content:center}}

/* ITW sticky intel strip ===================================================*/
.itw-strip{
  position:fixed; left:0; right:0; bottom:0; z-index:60;
  display:flex; align-items:stretch; gap:0;
  background:linear-gradient(90deg, #0a2540 0%, #0d2b48 60%, #0a2540 100%);
  color:#f3efe6;
  border-top:1px solid rgba(212,175,55,.35);
  box-shadow:0 -10px 30px rgba(0,0,0,.25);
  transform:translateY(110%);
  transition:transform 320ms cubic-bezier(.2,.7,.2,1);
  font-family:inherit;
}
.itw-strip--shown{ transform:translateY(0); }
body.has-itw-strip{ padding-bottom:44px; }

.itw-strip-cta{
  display:inline-flex; align-items:center; gap:.55rem;
  padding:0 1.1rem; height:44px;
  background:linear-gradient(135deg,#d4af37,#b8932a);
  color:#0a2540 !important; font-weight:700; letter-spacing:.02em;
  font-size:.86rem; text-transform:uppercase;
  text-decoration:none; white-space:nowrap;
  border:none; border-right:1px solid rgba(0,0,0,.15);
  transition:filter .2s ease, transform .2s ease;
}
.itw-strip-cta:hover{ filter:brightness(1.06); }
.itw-strip-cta:hover .itw-spark svg{ transform:rotate(90deg); }
.itw-strip-cta .itw-spark{ display:inline-flex; }
.itw-strip-cta .itw-spark svg{ transition:transform .35s ease; }
.itw-strip-arr{ font-weight:600; }

.itw-strip-feed{
  position:relative; flex:1 1 auto; min-width:0;
  display:flex; align-items:center; gap:.75rem;
  padding-left:.9rem; overflow:hidden;
}
.itw-strip-eyebrow{
  display:inline-flex; align-items:center; gap:.4rem;
  font-size:.72rem; letter-spacing:.18em; text-transform:uppercase;
  color:#d4af37; font-weight:700; flex-shrink:0;
}
.itw-strip-dot{
  width:7px; height:7px; border-radius:50%; background:#d4af37;
  box-shadow:0 0 0 0 rgba(212,175,55,.7);
  animation:itw-pulse 1.8s infinite;
}
@keyframes itw-pulse{
  0%{ box-shadow:0 0 0 0 rgba(212,175,55,.55); }
  70%{ box-shadow:0 0 0 8px rgba(212,175,55,0); }
  100%{ box-shadow:0 0 0 0 rgba(212,175,55,0); }
}
.itw-strip-viewport{ flex:1 1 auto; min-width:0; overflow:hidden; mask-image:linear-gradient(90deg, transparent 0, #000 32px, #000 calc(100% - 32px), transparent 100%); -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 32px, #000 calc(100% - 32px), transparent 100%); }
.itw-strip-track{
  display:inline-flex; align-items:center; gap:0;
  white-space:nowrap; will-change:transform;
  animation:itw-marquee 80s linear infinite;
}
.itw-strip-track--static{ animation:none; padding-left:1rem; }
.itw-strip:hover .itw-strip-track,
.itw-strip:focus-within .itw-strip-track{ animation-play-state:paused; }
@keyframes itw-marquee{
  from{ transform:translateX(0); }
  to{ transform:translateX(-50%); }
}

.itw-strip-item{
  display:inline-flex; align-items:center; gap:.45rem;
  color:#f3efe6 !important; text-decoration:none;
  font-size:.86rem; padding:0 .25rem;
  transition:color .15s ease;
}
.itw-strip-item:hover{ color:#d4af37 !important; }
.itw-strip-item .itw-strip-ico{ color:#d4af37; font-size:.7rem; line-height:1; }
.itw-strip-item--stat .itw-strip-ico{ color:#7ce0a5; }
.itw-strip-item--opportunity .itw-strip-ico{ color:#d4af37; }
.itw-strip-item--news .itw-strip-ico{ color:#9fc6ff; }
.itw-strip-item .itw-strip-head{ font-weight:500; }
.itw-strip-item .itw-strip-src{ opacity:.65; font-size:.75rem; }
.itw-strip-item--ghost{ opacity:.7; font-style:italic; padding-left:.5rem; }
.itw-strip-sep{ display:inline-block; padding:0 1rem; opacity:.35; }

.itw-strip-close{
  flex-shrink:0;
  width:44px; height:44px;
  background:transparent; border:none; border-left:1px solid rgba(255,255,255,.08);
  color:#f3efe6; opacity:.55;
  font-size:1.5rem; line-height:1; cursor:pointer;
  transition:opacity .2s ease;
}
.itw-strip-close:hover{ opacity:1; color:#d4af37; }

@media (max-width: 720px){
  .itw-strip{ flex-direction:column; }
  .itw-strip-cta{ height:38px; justify-content:center; border-right:none; border-bottom:1px solid rgba(0,0,0,.18); font-size:.78rem; padding:0 .9rem; }
  .itw-strip-feed{ height:36px; padding-left:.6rem; }
  .itw-strip-close{ position:absolute; top:0; right:0; width:36px; height:38px; border-left:none; }
  body.has-itw-strip{ padding-bottom:80px; }
  .itw-strip-eyebrow{ font-size:.65rem; }
  .itw-strip-item{ font-size:.78rem; }
}

@media (prefers-reduced-motion: reduce){
  .itw-strip-track{ animation:none !important; padding-left:1rem; }
  .itw-strip{ transition:none; }
  .itw-strip-dot{ animation:none; }
}
