/* === HERO === */
#shader{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block;border-radius:20px}
.hero{position:relative;overflow:hidden;min-height:680px;height:calc(100vh - 30px);display:flex;flex-direction:column;isolation:isolate;border-radius:20px;background:#080820}
.hero::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(70% 80% at 25% 55%, rgba(7,7,16,.42) 0%, rgba(7,7,16,.15) 50%, transparent 75%),
    linear-gradient(180deg, rgba(7,7,16,.25) 0%, transparent 30%, transparent 70%, rgba(7,7,16,.85) 100%);
}
.hero h1, .hero .lede{cursor:default}
.hero .lede{text-shadow:0 1px 12px rgba(7,7,16,.75)}
.hero-content{flex:1;display:flex;flex-direction:column;justify-content:center;padding:30px 0;position:relative;z-index:4}
.h1{font-weight:700;letter-spacing:-.032em;line-height:1;font-size:clamp(44px,5.6vw,96px);margin:0 0 36px;text-wrap:balance;max-width:1240px}
.h1 em{font-style:normal;background:linear-gradient(120deg,var(--magenta) 0%,var(--amber) 50%,var(--magenta) 100%);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:sh 8s linear infinite;text-shadow:none}
@keyframes sh{from{background-position:0% 50%}to{background-position:200% 50%}}
.copy-row{display:grid;grid-template-columns:1.5fr 1fr;gap:80px;align-items:end;margin-bottom:36px}
.lede{font-size:20px;color:var(--muted);max-width:720px;margin:0}
.cta-col{display:flex;gap:14px;align-items:center;flex-wrap:wrap;justify-self:end}

/* === LOGOS MARQUEE === */
.logos-marquee{background:var(--bg);overflow:hidden;padding:36px 0;position:relative}
.logos-marquee::before,.logos-marquee::after{content:"";position:absolute;top:0;bottom:0;width:160px;z-index:2;pointer-events:none}
.logos-marquee::before{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.logos-marquee::after{right:0;background:linear-gradient(-90deg,var(--bg),transparent)}
.lm-track{display:flex;gap:64px;width:max-content;will-change:transform;backface-visibility:hidden;transform:translate3d(0,0,0)}
.lm-item{font-size:26px;font-weight:600;letter-spacing:-.02em;color:var(--text);opacity:.40;white-space:nowrap;display:flex;align-items:center;gap:14px;cursor:pointer;text-decoration:none;transition:opacity .25s ease}
.lm-item:hover{opacity:1}
.lm-item::after{content:"";display:block;width:6px;height:6px;border-radius:50%;background:var(--amber);opacity:.55}
.lm-item:last-child::after{display:none}

/* === CLIENTS MAP === */
.clients-map{padding:120px 0 90px;background:var(--bg);position:relative;overflow:hidden}
.cm-head{max-width:780px;margin:0 auto 44px;padding:0 24px;text-align:center}
.cm-head .sec-tag{justify-content:center}
.cm-head h2{font-size:clamp(36px,4.2vw,64px);font-weight:700;letter-spacing:-.028em;line-height:1.04;margin:0 0 16px;text-wrap:balance;color:var(--text)}
.cm-head h2 em{font-style:normal;background:linear-gradient(120deg,var(--magenta),var(--amber));-webkit-background-clip:text;background-clip:text;color:transparent}
.cm-head p{font-size:16px;color:var(--muted);max-width:560px;margin:0 auto;line-height:1.6}
.cm-stage{position:relative;width:100vw;margin-left:calc(50% - 50vw);padding:0;overflow:hidden;isolation:isolate}
.cm-svg{width:100%;height:78vh;max-height:880px;min-height:600px;display:block}
.cm-stage::before,
.cm-stage::after{content:"";position:absolute;left:0;right:0;height:140px;pointer-events:none;z-index:2}
.cm-stage::before{top:0;background:linear-gradient(180deg,var(--bg) 0%,rgba(7,7,16,.85) 35%,rgba(7,7,16,0) 100%)}
.cm-stage::after{bottom:0;background:linear-gradient(0deg,var(--bg) 0%,rgba(7,7,16,.85) 35%,rgba(7,7,16,0) 100%)}
.cm-country{fill:rgba(244,242,239,.04);stroke:rgba(244,242,239,.14);stroke-width:.6;stroke-linejoin:round;cursor:default;pointer-events:none}
.map-m1 .cm-country{fill:rgba(244,242,239,.05);stroke:rgba(244,242,239,.18);stroke-width:.5}
.map-m2 .cm-country{fill:rgba(244,242,239,.05);stroke:rgba(244,242,239,.22);stroke-width:.6}
.map-m3 .cm-country{fill:url(#cmDots);stroke:none}
.map-m4 .cm-country{fill:rgba(244,242,239,.09);stroke:rgba(244,242,239,.16);stroke-width:.4;stroke-linejoin:round}
.map-m4 .cm-graticule{fill:none;stroke:rgba(244,242,239,.05);stroke-width:.4}
.cm-pin{cursor:pointer}

/* V1 — Drop pin (teardrop) */
.v1 .cm-pin-drop{fill:var(--amber);stroke:#fff;stroke-width:.8;filter:drop-shadow(0 1px 3px rgba(0,0,0,.6))}
.v1 .cm-pin-drop-inner{fill:#fff}
.v1 .cm-pin:hover .cm-pin-drop{fill:#ffac6b}

/* V2 — Radar rings */
.v2 .cm-pin-ring-out{fill:none;stroke:var(--amber);stroke-width:.5;opacity:.28}
.v2 .cm-pin-ring-mid{fill:none;stroke:var(--amber);stroke-width:.8;opacity:.55}
.v2 .cm-pin-dot{fill:var(--amber);stroke:#fff;stroke-width:.7;filter:drop-shadow(0 0 4px rgba(251,121,50,.7))}
.v2 .cm-pin-ring-mid{transform-box:fill-box;transform-origin:center;animation:v2Ping 3s ease-out infinite}
@keyframes v2Ping{0%{transform:scale(.4);opacity:.7}100%{transform:scale(2.2);opacity:0}}

/* V3 — Glow orb */
.v3 .cm-pin-glow{fill:url(#cmGlow)}
.v3 .cm-pin-core{fill:#fff;filter:drop-shadow(0 0 3px rgba(251,121,50,.9))}
.v3 .cm-pin:hover .cm-pin-core{fill:#ffb86b}

/* V4 — Country-code chip */
.v4 .cm-pin-stem{stroke:rgba(251,121,50,.7);stroke-width:.7;fill:none}
.v4 .cm-pin-tip{fill:var(--amber);filter:drop-shadow(0 0 3px rgba(251,121,50,.9))}
.v4 .cm-pin-chip{fill:#070710;stroke:var(--amber);stroke-width:.8}
.v4 .cm-pin-code{fill:var(--amber);font-family:Manrope,sans-serif;font-size:6px;font-weight:700;letter-spacing:.06em;text-anchor:middle;dominant-baseline:central;pointer-events:none}

/* V5 — Minimal dot + thin halo */
.v5 .cm-pin-halo{fill:none;stroke:var(--amber);stroke-width:.7;opacity:.55}
.v5 .cm-pin-dot{fill:var(--amber);filter:drop-shadow(0 0 2.5px rgba(251,121,50,.9))}
.v5 .cm-pin:hover .cm-pin-dot{fill:#fff}

/* V6 — Sparkle / 4-point star */
.v6 .cm-pin-star{fill:var(--amber);filter:drop-shadow(0 0 4px rgba(251,121,50,.85))}
.v6 .cm-pin-core{fill:#fff}
.v6 .cm-pin-star{transform-box:fill-box;transform-origin:center;animation:v6Shine 4s ease-in-out infinite}
@keyframes v6Shine{0%,100%{transform:scale(1) rotate(0deg);opacity:1}50%{transform:scale(1.15) rotate(45deg);opacity:.85}}

/* V7 — Diamond */
.v7 .cm-pin-diamond{fill:var(--amber);stroke:#fff;stroke-width:.6;filter:drop-shadow(0 0 3px rgba(251,121,50,.7))}
.v7 .cm-pin:hover .cm-pin-diamond{fill:#fff;stroke:var(--amber)}

/* V8 — Bullseye (nested rings). Outer ring pulses for visual weight without being noisy. */
.v8 .cm-pin-ring-1{fill:rgba(251,121,50,.08);stroke:rgba(251,121,50,.5);stroke-width:1;transform-box:fill-box;transform-origin:center;animation:v8Ping 2.6s ease-out infinite}
.v8 .cm-pin-ring-2{fill:none;stroke:var(--amber);stroke-width:1.4}
.v8 .cm-pin-core{fill:#fff;filter:drop-shadow(0 0 4px rgba(251,121,50,1)) drop-shadow(0 0 2px rgba(255,255,255,.6))}
.v8 .cm-pin:hover .cm-pin-core{fill:#ffe9b8}
@keyframes v8Ping{0%{transform:scale(.7);opacity:.9}70%{transform:scale(1.35);opacity:0}100%{transform:scale(1.35);opacity:0}}

.cm-pin-label{fill:#f4f2ef;font-family:Manrope,sans-serif;font-size:9px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;dominant-baseline:middle;pointer-events:none;paint-order:stroke;stroke:#070710;stroke-width:2.5;stroke-linejoin:round}
.cm-tooltip{
  position:fixed;pointer-events:none;z-index:20;
  padding:10px 14px 11px;border-radius:10px;
  background:#0c0c1c;border:1px solid var(--line);
  color:var(--text);letter-spacing:-.01em;
  white-space:nowrap;display:flex;flex-direction:column;gap:2px;
  box-shadow:0 14px 36px rgba(0,0,0,.55);
  opacity:0;transition:opacity .15s ease, transform .15s ease;
  transform:translate(-50%,-100%) translateY(-6px)
}
.cm-tooltip .cm-tip-country{font-size:13.5px;font-weight:700;color:var(--text)}
.cm-tooltip .cm-tip-meta{font-size:12px;font-weight:500;color:var(--muted)}
.cm-tooltip.show{opacity:1;transform:translate(-50%,-100%) translateY(-14px)}

/* Portfolio (.portfolio + .pf-*) styles moved to work.css — shared with /cases/ archive. */

/* === STACK MARQUEE (services) === */
.stack-section{padding:56px 0 56px;background:var(--bg);position:relative;overflow:hidden}
.stack-rows{display:flex;flex-direction:column;gap:22px}
.stack-row{position:relative;padding:6px 0;overflow:hidden}
.stack-row::before,.stack-row::after{content:"";position:absolute;top:0;bottom:0;width:200px;z-index:2;pointer-events:none}
.stack-row::before{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.stack-row::after{right:0;background:linear-gradient(-90deg,var(--bg),transparent)}
.stack-track{display:flex;gap:18px;width:max-content;will-change:transform;backface-visibility:hidden;transform:translate3d(0,0,0)}
.stack-item{
  display:inline-flex;align-items:center;gap:14px;
  padding:18px 28px;border-radius:14px;
  background:rgba(244,242,239,.025);border:1px solid var(--line);
  font-size:21px;font-weight:600;letter-spacing:-.018em;color:var(--text);
  opacity:.55;
  white-space:nowrap;flex-shrink:0;cursor:default;pointer-events:none
}
.stack-item img{height:26px;width:26px;object-fit:contain;display:block;flex-shrink:0;opacity:.92}

/* CTA-section styles moved to base.css (reused on /cases/, /modules/, etc). */

/* ====== RESPONSIVE ====== */
@media (max-width:960px){
  .copy-row{grid-template-columns:1fr;gap:24px}
  .cta-col{justify-self:start}
  .stack-section{padding:60px 0 50px}
  .clients-map{padding:80px 0 60px}
  .cm-head{margin-bottom:36px;padding:0 20px}
  .cm-stage{padding:0}
  .stack-item{font-size:17px;padding:14px 22px;gap:10px}
  .stack-item img{width:22px;height:22px}
  .stack-rows{gap:14px}
  .stack-track{gap:14px}
}
@media (max-width:900px){
  .h1{font-size:clamp(38px,7vw,72px);margin:0 0 28px}
  .lede{font-size:17px}
  .hero{min-height:0;height:auto;min-height:calc(100vh - 30px)}
  .hero-content{padding:40px 0}
  .copy-row{grid-template-columns:1fr;gap:28px;margin-bottom:24px;align-items:flex-start}
  .cta-col{justify-self:start;width:100%}
  .cm-svg{height:62vh;min-height:480px}
}
@media (max-width:600px){
  .hero{border-radius:14px;min-height:calc(100vh - 16px)}
  #shader{border-radius:14px}
  .h1{font-size:clamp(30px,8.5vw,48px);margin:0 0 20px;letter-spacing:-.022em}
  .hero-content{padding:24px 0 16px}
  .lede{font-size:15.5px;line-height:1.5}
  .copy-row{gap:22px;margin-bottom:18px}
  .cta-col{flex-direction:column;align-items:stretch;gap:10px;width:100%}
  .lm-item{font-size:18px}
  .lm-track{gap:32px}
  .logos-marquee{padding:24px 0}
  .stack-section{padding:36px 0}
  .stack-item{font-size:14.5px;padding:11px 16px;gap:10px}
  .stack-item img{width:18px;height:18px}
  .stack-rows{gap:14px}
  .stack-track{gap:12px}
  .clients-map{padding:64px 0 48px}
  .cm-head{margin-bottom:28px;padding:0 18px}
  .cm-head h2{font-size:clamp(28px,7vw,42px)}
  .cm-head p{font-size:14.5px}
  .cm-svg{height:54vh;min-height:380px}
}
@media (max-width:380px){
  .h1{font-size:clamp(26px,9vw,38px)}
  .lede{font-size:14.5px}
}
@media (max-width:320px){
  .h1{font-size:24px}
  .lm-item{font-size:16px}
  .stack-item{font-size:13px;padding:10px 14px}
}
