/* ============================================================
   FAÇADE THIRTY ONE — futuristic black & orange
   ============================================================ */

/* ---------- design tokens ---------- */
:root{
  --black:        #07070a;
  --bg:           #0a0a0d;
  --bg-2:         #0e0e12;
  --surface:      #131318;
  --surface-2:    #17171e;
  --line:         rgba(255,255,255,.08);
  --line-strong:  rgba(255,255,255,.14);

  --orange:       #ff5b00;
  --orange-2:     #ff7a1a;
  --orange-bright:#ff9244;
  --orange-deep:  #e24800;
  --ember:        #ffb47a;

  --text:         #f4f4f6;
  --muted:        #9a9aa6;
  --muted-2:      #6c6c78;

  --grad-orange:  linear-gradient(135deg, #ff7a1a 0%, #ff5b00 45%, #e24800 100%);
  --glow:         0 0 0 1px rgba(255,91,0,.4), 0 14px 40px -10px rgba(255,91,0,.55);
  --glow-soft:    0 18px 60px -22px rgba(255,91,0,.45);

  --font-display: "Space Grotesk", system-ui, sans-serif;
  --font-body:    "Inter", system-ui, sans-serif;
  --font-mono:    "Space Mono", ui-monospace, monospace;

  --container: 1200px;
  --radius:    16px;
  --radius-sm: 10px;
  --ease:      cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }

body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }

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

.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:clamp(20px,5vw,40px);
}

/* ---------- overlays: grain, scanlines, scroll progress ---------- */
.grain{
  position:fixed; inset:0; z-index:9998; pointer-events:none;
  opacity:.04; mix-blend-mode:screen;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.scanlines{
  position:fixed; inset:0; z-index:9997; pointer-events:none; opacity:.35;
  background:repeating-linear-gradient(to bottom, rgba(0,0,0,0) 0 2px, rgba(0,0,0,.16) 2px 3px);
  mix-blend-mode:multiply;
}
.scroll-progress{
  position:fixed; top:0; left:0; height:2px; width:0%;
  background:var(--grad-orange); z-index:10000;
  box-shadow:0 0 12px rgba(255,91,0,.8);
}

/* ---------- buttons ---------- */
.btn{
  --pad-y:.85rem; --pad-x:1.5rem;
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  font-family:var(--font-display);
  font-weight:600; font-size:.95rem; letter-spacing:.01em;
  padding:var(--pad-y) var(--pad-x);
  border-radius:999px; border:1px solid transparent;
  cursor:pointer; white-space:nowrap;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease),
             background .25s var(--ease), border-color .25s var(--ease), color .25s var(--ease);
}
.btn svg{ transition:transform .25s var(--ease); }
.btn-primary{
  background:var(--grad-orange); color:#0a0a0d;
  box-shadow:var(--glow-soft);
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:var(--glow); }
.btn-primary:hover svg{ transform:translateX(3px); }
.btn-ghost{
  background:rgba(255,255,255,.03); color:var(--text);
  border-color:var(--line-strong);
}
.btn-ghost:hover{ border-color:var(--orange); color:#fff; transform:translateY(-2px); box-shadow:var(--glow-soft); }
.btn-sm{ --pad-y:.6rem; --pad-x:1.1rem; font-size:.85rem; }
.btn-lg{ --pad-y:1.05rem; --pad-x:1.9rem; font-size:1.02rem; }
.btn-block{ width:100%; }

/* ---------- header ---------- */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:1000;
  transition:background .35s var(--ease), border-color .35s var(--ease), backdrop-filter .35s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(10,10,13,.78);
  backdrop-filter:blur(16px) saturate(140%);
  border-bottom-color:var(--line);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  height:74px;
}
.brand{ display:inline-flex; align-items:center; gap:.6rem; }
.brand-word{
  font-family:var(--font-display); font-weight:700;
  font-size:1.6rem; letter-spacing:-.015em; color:#fff;
  text-transform:lowercase;
}
.brand-word .b-pro{ color:var(--orange); }

.nav{ display:flex; gap:.35rem; }
.nav a{
  font-family:var(--font-display); font-weight:500;
  font-size:.92rem; color:var(--muted);
  padding:.5rem .85rem; border-radius:999px;
  transition:color .2s var(--ease), background .2s var(--ease);
}
.nav a:hover{ color:#fff; background:rgba(255,255,255,.05); }

.header-actions{ display:flex; align-items:center; gap:1rem; }
.phone-link{
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:var(--font-mono); font-size:.82rem; color:var(--text);
  letter-spacing:.02em;
}
.phone-dot{
  width:7px; height:7px; border-radius:50%; background:var(--orange);
  box-shadow:0 0 0 0 rgba(255,91,0,.6); animation:pulse 2.2s infinite;
}
@keyframes pulse{
  0%{ box-shadow:0 0 0 0 rgba(255,91,0,.55); }
  70%{ box-shadow:0 0 0 8px rgba(255,91,0,0); }
  100%{ box-shadow:0 0 0 0 rgba(255,91,0,0); }
}

/* mobile toggle */
.menu-toggle{
  display:none; flex-direction:column; gap:5px;
  width:42px; height:42px; align-items:center; justify-content:center;
  background:rgba(255,255,255,.04); border:1px solid var(--line-strong);
  border-radius:10px; cursor:pointer;
}
.menu-toggle span{ width:18px; height:2px; background:var(--text); transition:.3s var(--ease); }
.menu-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.menu-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

.mobile-menu{
  position:fixed; inset:74px 0 auto 0; z-index:999;
  background:rgba(8,8,11,.97); backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
  transform:translateY(-130%); transition:transform .4s var(--ease);
  padding:1.2rem clamp(20px,5vw,40px) 2rem;
}
.mobile-menu.open{ transform:translateY(0); }
.mobile-menu nav{ display:flex; flex-direction:column; gap:.4rem; }
.mobile-menu a{
  font-family:var(--font-display); font-weight:500; font-size:1.1rem;
  padding:.7rem 0; border-bottom:1px solid var(--line); color:var(--text);
}
.mobile-menu .btn{ margin-top:1rem; border-bottom:none; justify-content:center; }
.mobile-menu .mm-phone{ font-family:var(--font-mono); color:var(--orange); border-bottom:none; }

/* ---------- hero ---------- */
.hero{
  position:relative; min-height:100svh;
  display:flex; align-items:center;
  padding-top:74px; overflow:hidden;
  background:
    radial-gradient(120% 80% at 80% -10%, rgba(255,91,0,.16), transparent 55%),
    radial-gradient(90% 70% at 0% 110%, rgba(255,91,0,.08), transparent 60%),
    var(--black);
}
.hero-grid{
  position:absolute; inset:0; z-index:0;
  background-image:
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(120% 90% at 70% 20%, #000 35%, transparent 78%);
  -webkit-mask-image:radial-gradient(120% 90% at 70% 20%, #000 35%, transparent 78%);
}
.hero-glow{
  position:absolute; z-index:0; width:560px; height:560px; right:-80px; top:8%;
  background:radial-gradient(circle, rgba(255,91,0,.35), transparent 65%);
  filter:blur(40px); animation:drift 14s ease-in-out infinite alternate;
}
@keyframes drift{ from{ transform:translate3d(0,0,0) scale(1);} to{ transform:translate3d(-50px,40px,0) scale(1.12);} }

/* animated facade panel columns on the right */
.hero-facade{
  position:absolute; inset:0 0 0 auto; width:46%; z-index:0;
  mask-image:linear-gradient(90deg, transparent, #000 40%);
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 40%);
  opacity:.9;
}
.facade-cols{
  position:absolute; inset:-10% -2% -10% 0;
  display:grid; grid-template-columns:repeat(5,1fr); gap:14px;
  transform:perspective(900px) rotateY(-16deg) rotateX(2deg);
  transform-origin:right center;
}
.facade-cols span{
  display:block; border-radius:6px;
  background:
    repeating-linear-gradient(180deg, rgba(255,255,255,.05) 0 38px, transparent 38px 44px);
  border:1px solid rgba(255,255,255,.06);
  position:relative; overflow:hidden;
}
.facade-cols span::after{
  content:""; position:absolute; left:0; right:0; height:38px; border-radius:4px;
  background:linear-gradient(180deg, rgba(255,91,0,.55), rgba(255,91,0,.05));
  box-shadow:0 0 24px rgba(255,91,0,.5);
  animation:litpanel 5s linear infinite;
}
.facade-cols span:nth-child(2)::after{ animation-delay:-1.2s; }
.facade-cols span:nth-child(3)::after{ animation-delay:-2.4s; }
.facade-cols span:nth-child(4)::after{ animation-delay:-3.1s; }
.facade-cols span:nth-child(5)::after{ animation-delay:-0.6s; }
.facade-cols span:nth-child(6)::after{ animation-delay:-2.9s; }
.facade-cols span:nth-child(7)::after{ animation-delay:-1.8s; }
.facade-cols span:nth-child(8)::after{ animation-delay:-4.2s; }
.facade-cols span:nth-child(9)::after{ animation-delay:-0.3s; }
.facade-cols span:nth-child(10)::after{ animation-delay:-3.6s; }
@keyframes litpanel{
  0%{ top:-44px; opacity:0; }
  10%{ opacity:1; }
  90%{ opacity:1; }
  100%{ top:100%; opacity:0; }
}

.hero-inner{ position:relative; z-index:2; max-width:880px; padding-block:6vh; }

.kicker{
  display:inline-flex; align-items:center; gap:.7rem;
  font-family:var(--font-mono); font-size:.78rem; text-transform:uppercase;
  letter-spacing:.22em; color:var(--ember);
  margin-bottom:1.6rem;
}
.kicker-bar{ width:34px; height:2px; background:var(--orange); display:inline-block; }

.hero-title{
  font-family:var(--font-display); font-weight:700;
  font-size:clamp(2.8rem, 7.2vw, 6rem);
  line-height:.98; letter-spacing:-.02em;
  margin-bottom:1.6rem;
}
.hero-title .hl{ position:relative; color:var(--orange); white-space:nowrap; }
.hero-title .hl::after{
  content:""; position:absolute; left:-.04em; right:-.04em; bottom:.06em; height:.5em;
  background:var(--orange); opacity:.16; z-index:-1; border-radius:3px;
  filter:blur(2px);
}
.hero-sub{
  font-size:clamp(1.05rem,1.7vw,1.32rem); color:var(--muted);
  max-width:60ch; margin-bottom:2.4rem;
}
.hero-cta{ display:flex; flex-wrap:wrap; gap:1rem; margin-bottom:3rem; }

.hero-meta{ display:flex; align-items:center; gap:1.6rem; flex-wrap:wrap; }
.hm-item{ display:flex; flex-direction:column; }
.hm-item strong{
  font-family:var(--font-display); font-weight:700; font-size:1.9rem;
  color:#fff; line-height:1;
}
.hm-item span{ font-size:.82rem; color:var(--muted-2); margin-top:.25rem; }
.hm-divider{ width:1px; height:38px; background:var(--line-strong); }

.scroll-hint{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%);
  width:26px; height:42px; border:1.5px solid var(--line-strong); border-radius:14px;
  z-index:2; display:flex; justify-content:center; padding-top:8px;
}
.scroll-hint span{ width:3px; height:8px; border-radius:2px; background:var(--orange); animation:scrolldot 1.8s var(--ease) infinite; }
@keyframes scrolldot{ 0%{ transform:translateY(0); opacity:1;} 70%{ transform:translateY(14px); opacity:0;} 100%{opacity:0;} }

/* ---------- marquee (client logos) ---------- */
.marquee-section{
  border-block:1px solid var(--line);
  background:linear-gradient(180deg, var(--bg-2), var(--bg));
  padding-block:1.8rem; overflow:hidden;
}
.marquee-head{ margin-bottom:1.2rem; }
.marquee-head span{
  font-family:var(--font-mono); font-size:.72rem; text-transform:uppercase;
  letter-spacing:.22em; color:var(--muted-2);
}
.marquee{ width:100%; overflow:hidden; -webkit-mask-image:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); mask-image:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.marquee-track{
  display:inline-flex; align-items:center; gap:1.8rem; white-space:nowrap;
  animation:marquee 34s linear infinite;
}
.marquee-track.logos{ gap:clamp(2.5rem,6vw,5rem); animation-duration:42s; }
.partner-logo{
  height:30px; width:auto; flex:none;
  filter:brightness(0) invert(1);
  opacity:.48; transition:opacity .3s var(--ease);
}
.partner-logo:hover{ opacity:.95; }
@keyframes marquee{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }

/* ---------- shared section bits ---------- */
section{ position:relative; }
.section-index{
  font-family:var(--font-mono); font-size:.78rem; text-transform:uppercase;
  letter-spacing:.2em; color:var(--orange); margin-bottom:1rem;
}
.section-head{ max-width:760px; margin-bottom:3.4rem; }
.section-title{
  font-family:var(--font-display); font-weight:700;
  font-size:clamp(2rem,4.4vw,3.4rem); line-height:1.04; letter-spacing:-.02em;
  margin-bottom:1.1rem;
}
.section-lead{ font-size:clamp(1rem,1.4vw,1.15rem); color:var(--muted); max-width:62ch; }
.hl{ color:var(--orange); }

/* ---------- statement ---------- */
.statement{ padding-block:clamp(5rem,11vw,9rem); background:var(--bg); }
.statement-text{
  font-family:var(--font-display); font-weight:600;
  font-size:clamp(1.7rem,4vw,3rem); line-height:1.16; letter-spacing:-.015em;
  max-width:20ch; margin-bottom:2.6rem;
}
.statement-cols{
  display:grid; grid-template-columns:1fr 1fr; gap:2.4rem;
  max-width:900px; color:var(--muted); font-size:1.05rem;
  padding-top:2rem; border-top:1px solid var(--line);
}

/* ---------- threat ---------- */
.threat{ padding-block:clamp(4rem,9vw,7rem); background:linear-gradient(180deg, var(--bg), var(--bg-2)); }
.threat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.threat-card{
  position:relative; background:var(--surface);
  border:1px solid var(--line); border-radius:var(--radius);
  padding:2rem 1.8rem 1.8rem; overflow:hidden;
  transition:transform .35s var(--ease), border-color .35s var(--ease), box-shadow .35s var(--ease);
}
.threat-card::before{
  content:""; position:absolute; inset:0; border-radius:inherit; padding:1px;
  background:linear-gradient(160deg, rgba(255,91,0,.5), transparent 40%);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; opacity:0; transition:opacity .35s var(--ease);
}
.threat-card:hover{ transform:translateY(-6px); border-color:transparent; box-shadow:var(--glow-soft); }
.threat-card:hover::before{ opacity:1; }
.threat-num{
  font-family:var(--font-mono); font-size:.85rem; color:var(--orange);
  margin-bottom:1.1rem; letter-spacing:.1em;
}
.threat-card h3{ font-family:var(--font-display); font-size:1.32rem; margin-bottom:.7rem; letter-spacing:-.01em; }
.threat-card p{ color:var(--muted); font-size:.98rem; margin-bottom:1.4rem; }
.threat-tag{
  display:inline-flex; align-items:center; gap:.4rem;
  font-family:var(--font-mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.12em;
  padding:.35rem .7rem; border-radius:999px;
}
.threat-tag::before{ content:""; width:6px; height:6px; border-radius:50%; }
.threat-tag.danger{ background:rgba(255,91,0,.12); color:var(--orange-bright); }
.threat-tag.danger::before{ background:var(--orange); box-shadow:0 0 8px var(--orange); }
.threat-tag.warn{ background:rgba(255,180,90,.1); color:var(--ember); }
.threat-tag.warn::before{ background:var(--ember); }

.threat-banner{
  position:relative; overflow:hidden;
  display:flex; align-items:center; gap:1.6rem; flex-wrap:wrap;
  margin-top:1.8rem; padding:1.6rem 1.9rem;
  background:linear-gradient(120deg, rgba(255,91,0,.1), rgba(255,91,0,.02));
  border:1px solid rgba(255,91,0,.28); border-radius:var(--radius);
}
.threat-banner p{ flex:1; min-width:260px; color:var(--text); font-size:1.05rem; }
.threat-banner strong{ color:var(--orange-bright); }
.tb-pulse{
  position:absolute; left:-40px; top:50%; width:200px; height:200px; transform:translateY(-50%);
  background:radial-gradient(circle, rgba(255,91,0,.25), transparent 70%); filter:blur(20px);
  animation:drift 9s ease-in-out infinite alternate;
}

/* ---------- services ---------- */
.services{ padding-block:clamp(4.5rem,10vw,8rem); background:var(--bg-2); }
.service-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.3rem; }
.service-card{
  position:relative; background:linear-gradient(180deg, var(--surface), var(--surface-2));
  border:1px solid var(--line); border-radius:var(--radius);
  padding:2rem 1.8rem; overflow:hidden;
  transition:transform .35s var(--ease), border-color .35s var(--ease), box-shadow .35s var(--ease);
}
.service-card::after{
  content:""; position:absolute; left:0; top:0; height:3px; width:0;
  background:var(--grad-orange); transition:width .4s var(--ease);
  box-shadow:0 0 16px rgba(255,91,0,.6);
}
.service-card:hover{ transform:translateY(-6px); border-color:var(--line-strong); box-shadow:var(--glow-soft); }
.service-card:hover::after{ width:100%; }
.svc-icon{
  width:56px; height:56px; border-radius:14px;
  display:grid; place-items:center; margin-bottom:1.4rem;
  background:radial-gradient(circle at 30% 25%, rgba(255,91,0,.22), rgba(255,91,0,.04));
  border:1px solid rgba(255,91,0,.25); color:var(--orange-bright);
}
.svc-icon svg{ width:28px; height:28px; }
.service-card h3{ font-family:var(--font-display); font-size:1.24rem; margin-bottom:.6rem; letter-spacing:-.01em; }
.service-card p{ color:var(--muted); font-size:.96rem; }

/* ---------- process ---------- */
.process{ padding-block:clamp(4.5rem,10vw,8rem); background:linear-gradient(180deg, var(--bg-2), var(--bg)); }
.process-steps{
  display:grid; grid-template-columns:repeat(5,1fr); gap:1rem;
  counter-reset:step;
}
.process-step{
  position:relative; padding:1.8rem 1.3rem; border-radius:var(--radius);
  background:var(--surface); border:1px solid var(--line);
  transition:transform .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease);
}
.process-step::before{
  content:""; position:absolute; top:50%; right:-1rem; width:1rem; height:1px;
  background:linear-gradient(90deg, var(--orange), transparent);
}
.process-step:last-child::before{ display:none; }
.process-step:hover{ transform:translateY(-5px); border-color:rgba(255,91,0,.35); background:var(--surface-2); }
.ps-num{
  font-family:var(--font-display); font-weight:700; font-size:2.4rem;
  background:var(--grad-orange); -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; line-height:1; margin-bottom:1rem;
}
.ps-body h3{ font-family:var(--font-display); font-size:1.2rem; margin-bottom:.55rem; }
.ps-body p{ color:var(--muted); font-size:.92rem; }

/* ---------- proof ---------- */
.proof{ padding-block:clamp(4.5rem,10vw,8rem); background:var(--bg); }
.stats-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem;
  margin-bottom:3rem;
  padding:2rem; border:1px solid var(--line); border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(255,91,0,.04), transparent);
}
.stat{ text-align:center; position:relative; }
.stat::after{ content:""; position:absolute; right:-.6rem; top:15%; height:70%; width:1px; background:var(--line); }
.stat:last-child::after{ display:none; }
.stat-num{
  font-family:var(--font-display); font-weight:700; font-size:clamp(2.6rem,5vw,3.6rem);
  line-height:1; color:#fff; letter-spacing:-.02em;
}
.stat-label{ font-size:.86rem; color:var(--muted); margin-top:.5rem; }

.project-grid{
  display:grid; grid-template-columns:repeat(3,1fr); grid-auto-rows:240px; gap:1.2rem;
}
.project-card{
  position:relative; border-radius:var(--radius); overflow:hidden;
  border:1px solid var(--line); cursor:pointer;
}
.project-card.big{ grid-row:span 2; }
.project-card.wide{ grid-column:span 2; }
.project-card img{
  width:100%; height:100%; object-fit:cover;
  filter:grayscale(.35) brightness(.62) contrast(1.05);
  transition:transform .6s var(--ease), filter .5s var(--ease);
}
.project-card::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 30%, rgba(7,7,10,.92));
}
.project-card:hover img{ transform:scale(1.06); filter:grayscale(0) brightness(.7) contrast(1.05); }
.pc-overlay{ position:absolute; inset:auto 0 0 0; padding:1.5rem; z-index:2; }
.pc-tag{
  display:inline-block; font-family:var(--font-mono); font-size:.7rem; text-transform:uppercase;
  letter-spacing:.14em; color:var(--orange-bright);
  background:rgba(255,91,0,.12); border:1px solid rgba(255,91,0,.3);
  padding:.3rem .6rem; border-radius:999px; margin-bottom:.7rem;
}
.pc-overlay h3{ font-family:var(--font-display); font-size:1.3rem; margin-bottom:.35rem; }
.pc-overlay p{ color:var(--muted); font-size:.92rem; max-width:46ch; }
.project-cta{ display:flex; justify-content:center; margin-top:2.6rem; }

/* ---------- standard ---------- */
.standard{ padding-block:clamp(4.5rem,10vw,8rem); background:linear-gradient(180deg, var(--bg), var(--bg-2)); }
.standard-inner{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(2rem,5vw,4.5rem); align-items:start; }
.standard-copy{ position:sticky; top:100px; }
.cert-badges{ display:flex; align-items:center; gap:1.8rem; flex-wrap:wrap; margin:1.9rem 0 .4rem; }
.cert-badge{ height:52px; width:auto; opacity:.9; transition:opacity .3s var(--ease); }
.cert-badge:hover{ opacity:1; }
.standard-cta{ margin-top:1.6rem; }
.cred-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.cred{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-sm);
  padding:1.5rem 1.4rem; transition:transform .3s var(--ease), border-color .3s var(--ease);
}
.cred:hover{ transform:translateY(-4px); border-color:rgba(255,91,0,.35); }
.cred-icon{
  width:44px; height:44px; border-radius:11px; display:grid; place-items:center; margin-bottom:1rem;
  background:rgba(255,91,0,.1); border:1px solid rgba(255,91,0,.22); color:var(--orange-bright);
}
.cred-icon svg{ width:24px; height:24px; }
.cred strong{ display:block; font-family:var(--font-display); font-size:1.05rem; margin-bottom:.25rem; }
.cred span{ font-size:.85rem; color:var(--muted); }

/* ---------- cta ---------- */
.cta{
  position:relative; overflow:hidden;
  padding-block:clamp(5rem,11vw,8rem);
  background:
    radial-gradient(80% 120% at 50% 0%, rgba(255,91,0,.14), transparent 60%),
    var(--black);
  border-top:1px solid var(--line);
}
.cta-glow{
  position:absolute; left:50%; top:-120px; transform:translateX(-50%);
  width:680px; height:340px;
  background:radial-gradient(ellipse, rgba(255,91,0,.3), transparent 70%); filter:blur(50px);
}
.cta-inner{ position:relative; z-index:2; display:grid; grid-template-columns:1fr 1fr; gap:clamp(2.5rem,6vw,5rem); align-items:start; }
.cta-title{
  font-family:var(--font-display); font-weight:700;
  font-size:clamp(2.2rem,4.6vw,3.5rem); line-height:1.05; letter-spacing:-.02em;
  margin-bottom:1.1rem;
}
.cta-lead{ color:var(--muted); font-size:1.1rem; margin-bottom:1.8rem; max-width:48ch; }
.cta-points{ display:flex; flex-direction:column; gap:.85rem; margin-bottom:2rem; }
.cta-points li{ display:flex; align-items:flex-start; gap:.7rem; color:var(--text); font-size:1rem; }
.cta-points li::before{
  content:""; flex:none; width:20px; height:20px; margin-top:1px; border-radius:50%;
  background:var(--grad-orange);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M5 12l4 4 10-10' fill='none' stroke='%23000' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/70% no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M5 12l4 4 10-10' fill='none' stroke='%23000' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/70% no-repeat;
}
.cta-direct{ display:flex; flex-direction:column; gap:.3rem; padding-top:1.6rem; border-top:1px solid var(--line); }
.cta-phone{ font-family:var(--font-display); font-weight:700; font-size:1.7rem; color:#fff; }
.cta-phone:hover{ color:var(--orange); }
.cta-email{ font-family:var(--font-mono); font-size:.9rem; color:var(--muted); }
.cta-email:hover{ color:var(--orange-bright); }

/* form */
.cta-form{
  background:linear-gradient(180deg, var(--surface), var(--surface-2));
  border:1px solid var(--line-strong); border-radius:var(--radius);
  padding:clamp(1.6rem,3vw,2.2rem);
}
.hp-field{ display:none; }   /* Netlify Forms honeypot */
.field{ display:flex; flex-direction:column; gap:.45rem; margin-bottom:1.1rem; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field label{ font-family:var(--font-mono); font-size:.74rem; text-transform:uppercase; letter-spacing:.12em; color:var(--muted); }
.field input, .field textarea{
  font-family:var(--font-body); font-size:.98rem; color:var(--text);
  background:rgba(0,0,0,.35); border:1px solid var(--line-strong); border-radius:10px;
  padding:.85rem 1rem; resize:vertical;
  transition:border-color .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
}
.field input::placeholder, .field textarea::placeholder{ color:var(--muted-2); }
.field input:focus, .field textarea:focus{
  outline:none; border-color:var(--orange);
  box-shadow:0 0 0 3px rgba(255,91,0,.18); background:rgba(0,0,0,.5);
}
.form-note{ margin-top:1rem; font-size:.9rem; min-height:1.2em; }
.form-note.ok{ color:var(--orange-bright); }
.form-note.err{ color:#ff6b6b; }

/* ---------- footer ---------- */
.site-footer{ background:var(--black); border-top:1px solid var(--line); padding-block:3.5rem 1.6rem; }
.footer-top{ display:grid; grid-template-columns:1.4fr 2fr; gap:3rem; padding-bottom:2.6rem; border-bottom:1px solid var(--line); }
.footer-brand .brand{ margin-bottom:1rem; }
.footer-tag{ color:var(--muted); max-width:34ch; font-size:.98rem; }
.footer-nav{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.footer-nav h4{ font-family:var(--font-mono); font-size:.74rem; text-transform:uppercase; letter-spacing:.14em; color:var(--orange); margin-bottom:1rem; font-weight:700; }
.footer-nav a, .footer-loc{ display:block; color:var(--muted); font-size:.93rem; padding:.28rem 0; transition:color .2s var(--ease); }
.footer-nav a:hover{ color:#fff; }
.footer-loc{ color:var(--muted-2); margin-top:.4rem; }
.footer-bottom{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; padding-top:1.6rem; font-size:.82rem; color:var(--muted-2); }
.footer-fine{ font-family:var(--font-mono); }

/* ---------- transformation: scroll-scrubbed video ---------- */
.transformation{ position:relative; height:500vh; background:var(--black); }
.tf-sticky{
  position:sticky; top:0; height:100vh; overflow:hidden;
  display:flex; align-items:flex-end;
}
.tf-video{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; z-index:0; background:#000;
}
.tf-shade{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    linear-gradient(180deg, rgba(7,7,10,.72) 0%, rgba(7,7,10,.12) 24%, rgba(7,7,10,.2) 55%, rgba(7,7,10,.94) 100%),
    radial-gradient(110% 80% at 6% 100%, rgba(255,91,0,.18), transparent 55%);
}
.tf-grid-overlay{
  position:absolute; inset:0; z-index:1; pointer-events:none; opacity:.45;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:linear-gradient(180deg, transparent, #000 65%);
  -webkit-mask-image:linear-gradient(180deg, transparent, #000 65%);
}
/* 3D scan chamber — a perspective orange grid (floor + ceiling) rushing toward a glowing
   horizon, pairing with the video's wireframe opening. JS fades it out as you scroll. */
.tf-scan3d{
  position:absolute; inset:0; z-index:1; pointer-events:none; overflow:hidden;
  mix-blend-mode:screen;
  -webkit-mask-image:radial-gradient(150% 125% at 50% 50%, #000 28%, transparent 80%);
          mask-image:radial-gradient(150% 125% at 50% 50%, #000 28%, transparent 80%);
}
.s3d-grid{
  position:absolute; left:-30%; right:-30%; height:135%;
  background-image:
    linear-gradient(rgba(255,91,0,.55) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,107,0,.45) 1px, transparent 1px);
  background-size:54px 54px;
  animation:s3dmove 2.2s linear infinite;
  will-change:background-position;
}
.s3d-floor{
  bottom:0; transform-origin:50% 100%; transform:perspective(380px) rotateX(62deg);
  -webkit-mask-image:linear-gradient(to top, #000, transparent 72%);
          mask-image:linear-gradient(to top, #000, transparent 72%);
}
.s3d-ceil{
  top:0; transform-origin:50% 0%; transform:perspective(380px) rotateX(-62deg); opacity:.5;
  -webkit-mask-image:linear-gradient(to bottom, #000, transparent 72%);
          mask-image:linear-gradient(to bottom, #000, transparent 72%);
}
.tf-scan3d::after{   /* glowing horizon line where floor meets ceiling */
  content:""; position:absolute; left:0; right:0; top:50%; height:2px; transform:translateY(-1px);
  background:linear-gradient(90deg, transparent, rgba(255,150,70,.85) 30%, rgba(255,150,70,.85) 70%, transparent);
  box-shadow:0 0 26px 5px rgba(255,91,0,.45);
}
@keyframes s3dmove{ from{ background-position:0 0; } to{ background-position:0 54px; } }
@media (prefers-reduced-motion:reduce){ .s3d-grid{ animation:none; } }
.tf-content{ position:relative; z-index:2; width:100%; padding-bottom:clamp(2.6rem,8vh,6rem); }
.tf-title{
  font-family:var(--font-display); font-weight:700;
  font-size:clamp(2.2rem,6vw,4.6rem); line-height:1; letter-spacing:-.02em;
  margin:.5rem 0 1.6rem; max-width:16ch; color:#fff;
}
.tf-captions{ position:relative; min-height:9em; max-width:600px; }
/* grounded "lower-third" card so captions read as intentional UI, not floating text */
.tf-cap{
  position:absolute; left:0; right:0; bottom:0;
  padding:1.15rem 1.45rem 1.2rem;
  background:linear-gradient(120deg, rgba(8,8,11,.68), rgba(8,8,11,.34));
  -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px);
  border:1px solid var(--line); border-left:3px solid var(--orange);
  border-radius:3px 14px 14px 3px;
  opacity:0; transform:translateY(16px);
  transition:opacity .5s var(--ease), transform .5s var(--ease);
  pointer-events:none;
}
.tf-cap.active{ opacity:1; transform:none; }
.tf-stage{
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:var(--font-mono); font-size:.8rem;
  text-transform:uppercase; letter-spacing:.16em; color:var(--orange-bright);
  margin-bottom:.5rem;
}
.tf-stage::before{ content:""; width:18px; height:2px; background:var(--orange); display:inline-block; }
.tf-cap p{ font-size:clamp(1.02rem,1.9vw,1.4rem); color:#fff; font-weight:500; line-height:1.34; }

.tf-rail{
  position:absolute; right:clamp(18px,5vw,40px); top:50%; transform:translateY(-50%);
  z-index:2; display:flex; flex-direction:column; gap:1.15rem;
}
.tf-rail span{
  position:relative; width:10px; height:10px; border-radius:50%;
  background:rgba(255,255,255,.2);
  transition:background .3s var(--ease), box-shadow .3s var(--ease), transform .3s var(--ease);
}
.tf-rail span.active{ background:var(--orange); box-shadow:0 0 12px rgba(255,91,0,.85); transform:scale(1.25); }
.tf-rail span::after{
  content:attr(data-label);
  position:absolute; right:22px; top:50%; transform:translateY(-50%);
  font-family:var(--font-mono); font-size:.66rem; text-transform:uppercase; letter-spacing:.12em;
  color:var(--muted); white-space:nowrap; opacity:0; transition:opacity .3s var(--ease);
}
.tf-rail span.active::after{ opacity:1; color:#fff; }

.tf-progress-rail{
  position:absolute; left:0; right:0; bottom:0; height:3px; z-index:3;
  background:rgba(255,255,255,.08);
}
.tf-progress{
  height:100%; width:100%; transform:scaleX(0); transform-origin:left;
  background:var(--grad-orange); box-shadow:0 0 14px rgba(255,91,0,.75);
}

/* ---------- reveal animation (JS-gated so content is visible without JS) ---------- */
.js .reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.js .reveal.in{ opacity:1; transform:none; }

/* ---------- Lenis smooth scroll ---------- */
html.lenis, html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }
.lenis.lenis-smooth [data-lenis-prevent]{ overscroll-behavior:contain; }
.lenis.lenis-stopped{ overflow:hidden; }

/* ---------- opener (scroll-scrub video hero) ---------- */
.opener .tf-sticky{ align-items:stretch; }
.opener-hero, .opener .tf-content{
  position:absolute; left:0; right:0; bottom:0; z-index:2;
  padding-bottom:clamp(3rem,9vh,7rem);
}
.opener .tf-content{ opacity:0; }            /* fades in as you scroll */
.opener-title{
  font-family:var(--font-display); font-weight:700;
  font-size:clamp(2.7rem,7.4vw,6.2rem); line-height:.96; letter-spacing:-.025em;
  margin:1.3rem 0 1.5rem; color:#fff;
}
.opener-title em{ font-style:italic; color:var(--orange); }
.opener-sub{ font-size:clamp(1.02rem,1.6vw,1.28rem); color:var(--muted); max-width:60ch; }
.opener-cta{ display:flex; flex-wrap:wrap; gap:1rem; margin-top:2.2rem; }
.opener-scrollhint{
  margin-top:2.3rem; font-family:var(--font-mono); font-size:.74rem;
  text-transform:uppercase; letter-spacing:.18em; color:var(--muted-2);
  display:flex; align-items:center; gap:.6rem;
}
.opener-scrollhint span{ color:var(--orange); animation:bobdown 1.8s var(--ease) infinite; display:inline-block; }
@keyframes bobdown{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(5px);} }

/* ---------- story ---------- */
.story{ padding-block:clamp(5rem,11vw,9rem); background:var(--bg); }
.story-inner{ display:grid; grid-template-columns:1.3fr .85fr; gap:clamp(2rem,5vw,4.5rem); align-items:start; }
.story-body{ color:var(--muted); margin-top:1.4rem; font-size:1.05rem; }
.story-cycle{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:1.8rem; position:sticky; top:100px; }
.story-cycle h4{ font-family:var(--font-mono); font-size:.74rem; text-transform:uppercase; letter-spacing:.14em; color:var(--orange); margin-bottom:1.1rem; font-weight:700; }
.story-cycle ul{ display:flex; flex-direction:column; }
.story-cycle li{ display:flex; gap:1rem; align-items:baseline; padding:.85rem 0; border-top:1px solid var(--line); color:var(--text); font-size:.97rem; }
.story-cycle li:first-child{ border-top:none; padding-top:0; }
.story-cycle li span{ font-family:var(--font-mono); color:var(--orange); font-size:.82rem; flex:none; }

/* ---------- performance solutions ---------- */
.performance{ position:relative; overflow:hidden; padding-block:clamp(5rem,11vw,9rem); background:linear-gradient(180deg,var(--bg),var(--bg-2)); }
.performance-glow{ position:absolute; right:-10%; top:-5%; width:600px; height:600px; background:radial-gradient(circle,rgba(255,91,0,.16),transparent 65%); filter:blur(50px); }
.performance-inner{ position:relative; z-index:2; max-width:820px; }
.performance-quote{
  font-family:var(--font-display); font-weight:500; font-size:clamp(1.2rem,2.2vw,1.7rem);
  line-height:1.4; color:#fff; margin:2rem 0; padding-left:1.4rem; border-left:3px solid var(--orange);
}

/* ---------- big quote ---------- */
.quote-section{ padding-block:clamp(4.5rem,10vw,8rem); background:var(--bg-2); }
.big-quote{ font-family:var(--font-display); font-weight:600; font-size:clamp(1.7rem,4vw,3.1rem); line-height:1.18; letter-spacing:-.015em; color:#fff; max-width:24ch; }
.quote-sub{ margin-top:2rem; color:var(--muted); font-size:1.1rem; max-width:60ch; padding-top:1.6rem; border-top:1px solid var(--line); }

/* ---------- service number ---------- */
.svc-num{ position:absolute; top:1.5rem; right:1.7rem; font-family:var(--font-mono); font-size:.8rem; color:var(--muted-2); letter-spacing:.1em; }

/* ---------- partners ---------- */
.partners{ padding-block:clamp(4.5rem,10vw,7rem); background:var(--bg); }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head.center .section-lead{ margin-inline:auto; }
.partners .marquee{ margin-top:3rem; }

/* ---------- contact address ---------- */
.cta-addr{ font-family:var(--font-mono); font-size:.82rem; color:var(--muted-2); margin-top:.3rem; }

/* ============ responsive ============ */
@media (max-width:1024px){
  .nav{ display:none; }
  .menu-toggle{ display:flex; }
  .phone-link{ display:none; }
  .header-actions .btn-sm{ display:none; }
  .threat-grid{ grid-template-columns:1fr 1fr; }
  .service-grid{ grid-template-columns:1fr 1fr; }
  .process-steps{ grid-template-columns:repeat(2,1fr); }
  .process-step::before{ display:none; }
  .standard-inner{ grid-template-columns:1fr; }
  .standard-copy{ position:static; }
  .cta-inner{ grid-template-columns:1fr; }
  .story-inner{ grid-template-columns:1fr; }
  .story-cycle{ position:static; }
  .service-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:680px){
  .header-actions .btn-sm{ display:none; }
  .statement-cols{ grid-template-columns:1fr; gap:1.2rem; }
  .threat-grid{ grid-template-columns:1fr; }
  .service-grid{ grid-template-columns:1fr; }
  .stats-grid{ grid-template-columns:1fr 1fr; gap:1.6rem 1rem; }
  .stat::after{ display:none; }
  .project-grid{ grid-template-columns:1fr; grid-auto-rows:220px; }
  .project-card.big{ grid-row:span 1; }
  .project-card.wide{ grid-column:span 1; }
  .cred-grid{ grid-template-columns:1fr; }
  .field-row{ grid-template-columns:1fr; }
  .footer-top{ grid-template-columns:1fr; gap:2rem; }
  .footer-nav{ grid-template-columns:1fr 1fr; }
  .hero-facade{ opacity:.35; }
  .hm-divider{ display:none; }
  .hero-meta{ gap:1.4rem; }
  .transformation{ height:420vh; }
  .tf-rail{ gap:.85rem; }
  .tf-rail span::after{ display:none; }
  .cert-badge{ height:42px; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; scroll-behavior:auto; }
  .js .reveal{ opacity:1; transform:none; transition:none; }
}

/* ============================================================
   WOW PACK
   ============================================================ */

/* ---------- richer reveals: blur + rise ---------- */
.js .reveal{
  filter:blur(7px);
  transition:opacity .8s var(--ease), transform .8s var(--ease), filter .8s var(--ease);
}
.js .reveal.in{ filter:blur(0); }

/* ---------- preloader ---------- */
.preloader{
  position:fixed; inset:0; z-index:10001;
  background:var(--black);
  display:flex; align-items:center; justify-content:center;
  transition:transform .8s cubic-bezier(.76,0,.24,1);
}
.preloader.done{ transform:translateY(-101%); }
.pl-inner{ display:flex; flex-direction:column; align-items:center; gap:1.1rem; }
.pl-brand{
  font-family:var(--font-display); font-weight:700; font-size:1.6rem;
  letter-spacing:-.015em; color:#fff; text-transform:lowercase;
}
.pl-brand .b-pro{ color:var(--orange); }
.pl-pct{
  font-family:var(--font-display); font-weight:700;
  font-size:clamp(4rem,12vw,7.5rem); line-height:1; color:#fff; letter-spacing:-.03em;
  font-variant-numeric:tabular-nums;
}
.pl-bar{ width:min(320px,60vw); height:2px; background:rgba(255,255,255,.1); overflow:hidden; border-radius:2px; }
.pl-bar i{ display:block; height:100%; width:0%; background:var(--grad-orange); box-shadow:0 0 12px rgba(255,91,0,.8); }
.pl-tag{
  font-family:var(--font-mono); font-size:.7rem; text-transform:uppercase;
  letter-spacing:.22em; color:var(--muted-2);
}
html:not(.js) .preloader{ display:none; }
@media (prefers-reduced-motion:reduce){ .preloader{ display:none; } }

/* ---------- opener intro choreography (post-preloader) ---------- */
.opener-title .w{ display:inline-block; overflow:hidden; vertical-align:bottom; }
.opener-title .wi{ display:inline-block; transform:translateY(115%); }
html.ready .opener-title .wi{
  transform:translateY(0);
  transition:transform .95s var(--ease); transition-delay:var(--d,0ms);
}
.js .opener-hero .kicker,
.js .opener-sub,
.js .opener-cta,
.js .opener-scrollhint{
  opacity:0; transform:translateY(18px);
  transition:opacity .8s var(--ease), transform .8s var(--ease);
}
html.ready .opener-hero .kicker{ opacity:1; transform:none; transition-delay:.15s; }
html.ready .opener-sub{ opacity:1; transform:none; transition-delay:.75s; }
html.ready .opener-cta{ opacity:1; transform:none; transition-delay:.95s; }
html.ready .opener-scrollhint{ opacity:1; transform:none; transition-delay:1.25s; }
@media (prefers-reduced-motion:reduce){
  .opener-title .wi{ transform:none; }
  .js .opener-hero .kicker, .js .opener-sub, .js .opener-cta, .js .opener-scrollhint{ opacity:1; transform:none; transition:none; }
}

/* ---------- custom cursor ---------- */
.cursor-dot, .cursor-ring{
  position:fixed; left:0; top:0; z-index:10002; pointer-events:none;
  border-radius:50%; opacity:0;
}
.cursor-dot{ width:7px; height:7px; background:var(--orange); }
.cursor-ring{ width:38px; height:38px; border:1.5px solid rgba(255,91,0,.6); }
html.cursor-on .cursor-dot, html.cursor-on .cursor-ring{ opacity:1; }
@media (pointer:coarse){ .cursor-dot, .cursor-ring{ display:none; } }

/* ---------- scrub HUD ---------- */
.tf-hud{
  position:absolute; top:96px; right:clamp(18px,5vw,40px); z-index:2;
  display:flex; flex-direction:column; align-items:flex-end; gap:.2rem;
  padding:.7rem .95rem;
  background:rgba(7,7,10,.45); backdrop-filter:blur(10px);
  border:1px solid var(--line); border-radius:var(--radius-sm);
}
.hud-label{
  font-family:var(--font-mono); font-size:.62rem; text-transform:uppercase;
  letter-spacing:.18em; color:var(--muted);
}
.tf-hud strong{
  font-family:var(--font-display); font-weight:700; font-size:1.5rem; line-height:1;
  color:var(--orange-bright); font-variant-numeric:tabular-nums;
}
@media (max-width:680px){ .tf-hud{ top:86px; padding:.5rem .7rem; } .tf-hud strong{ font-size:1.15rem; } }
.tf-hud.buffering strong{ color:var(--ember); }
.tf-hud.buffering .hud-label{ color:var(--ember); animation:hudpulse 1.1s ease-in-out infinite; }
@keyframes hudpulse{ 0%,100%{ opacity:1; } 50%{ opacity:.45; } }

/* ---------- giant marquee ---------- */
.giant-marquee{
  padding-block:clamp(3rem,7vw,5.5rem);
  border-block:1px solid var(--line);
  background:var(--bg-2); overflow:hidden;
}
.gm-track{ display:flex; white-space:nowrap; will-change:transform; }
.gm-track span{
  font-family:var(--font-display); font-weight:700;
  font-size:clamp(3.4rem,9vw,8rem); line-height:1; letter-spacing:-.02em;
  color:transparent; -webkit-text-stroke:1.5px rgba(255,91,0,.55);
  padding-right:1.5rem; flex:none;
}
.gm-track em{ font-style:normal; color:var(--orange); -webkit-text-stroke:0; }
.gm-track i{ font-style:normal; color:transparent; -webkit-text-stroke:1px rgba(255,255,255,.18); }

/* ---------- mega CTA ---------- */
.mega-cta{
  padding-block:clamp(5rem,12vw,10rem);
  background:var(--bg);
}
.mega-link{ display:block; }
.mega-line{
  display:block;
  font-family:var(--font-display); font-weight:700;
  font-size:clamp(3rem,9.5vw,8.5rem); line-height:1.02; letter-spacing:-.03em;
  color:transparent; -webkit-text-stroke:2px rgba(255,255,255,.85);
  transition:color .45s var(--ease), -webkit-text-stroke-color .45s var(--ease);
}
.mega-line em{ font-style:normal; color:var(--orange); -webkit-text-stroke:0; }
.mega-link:hover .mega-line{ color:#fff; -webkit-text-stroke-color:transparent; }
.mega-link:hover .mega-line em{ color:var(--orange); }
.mega-go{
  display:inline-flex; align-items:center; gap:.7rem; margin-top:2.2rem;
  font-family:var(--font-mono); font-size:.95rem; text-transform:uppercase;
  letter-spacing:.18em; color:var(--orange);
}
.mega-go svg{ transition:transform .35s var(--ease); }
.mega-link:hover .mega-go svg{ transform:translateX(8px); }

/* ---------- header auto-hide ---------- */
.site-header{ transition:background .35s var(--ease), border-color .35s var(--ease), backdrop-filter .35s var(--ease), transform .45s var(--ease); }
.site-header.headhide{ transform:translateY(-101%); }

/* ---------- project card hover boost ---------- */
.project-card::before{
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(135deg, rgba(255,91,0,0) 30%, rgba(255,91,0,.35));
  opacity:0; transition:opacity .45s var(--ease); mix-blend-mode:overlay;
}
.project-card:hover::before{ opacity:1; }
.project-card:hover{ border-color:rgba(255,91,0,.4); }

/* ---------- hover-to-play project video (auto-activates when a real file loads) ---------- */
.pv-video{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  opacity:0; transition:opacity .45s var(--ease); z-index:2; pointer-events:none;
}
.has-video.pv-playing .pv-video{ opacity:1; }
.pv-badge{
  position:absolute; top:1rem; left:1rem; z-index:4; pointer-events:none;
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:var(--font-mono); font-size:.66rem; text-transform:uppercase; letter-spacing:.14em;
  color:#fff; background:rgba(7,7,10,.55); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
  padding:.42rem .72rem; border-radius:999px; border:1px solid rgba(255,91,0,.4);
  opacity:0; transform:translateY(-4px); transition:opacity .35s var(--ease), transform .35s var(--ease);
}
.has-video .pv-badge{ opacity:1; transform:none; }                 /* visible once a film is attached */
.has-video.pv-playing .pv-badge{ opacity:0; }                       /* hide while playing */
.pv-badge .pv-dot{ width:6px; height:6px; border-radius:50%; background:var(--orange); box-shadow:0 0 8px var(--orange); }

/* ---------- magnetic buttons ---------- */
.btn{ will-change:transform; }

/* ---------- service-card "explore" link ---------- */
.svc-go{
  display:inline-flex; align-items:center; gap:.5rem; margin-top:1.3rem;
  font-family:var(--font-mono); font-size:.74rem; text-transform:uppercase;
  letter-spacing:.16em; color:var(--orange-bright);
  opacity:.75; transition:opacity .3s var(--ease), gap .3s var(--ease);
}
.service-card:hover .svc-go{ opacity:1; gap:.85rem; }
