/* ============================================================
   OMNI — Marketing Agency  ·  BLUE edition
   Accent converted from amber/orange → electric blue
   ============================================================ */

:root{
  /* ---- core surface ---- */
  --bg:        #05070d;
  --bg-2:      #070a12;
  --ink:       #f4f6fb;
  --ink-dim:   #aeb6c6;
  --ink-faint: #6b7488;

  /* ---- BLUE accent system (was orange) ---- */
  --accent:        #2f7bff;   /* primary blue */
  --accent-bright: #56a0ff;   /* highlight */
  --accent-deep:   #0c3aa0;   /* shadow side */
  --accent-core:   #8cc0ff;   /* hot core of glows */

  /* glow rgba helpers */
  --glow:    47,123,255;      /* var(--accent) as rgb */
  --glow-hot: 120,180,255;

  --radius: 22px;
  --radius-lg: 30px;

  --maxw: 1280px;

  --font: "Helvetica Neue", Helvetica, "Inter", Arial, sans-serif;
}

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

html{ scroll-behavior:smooth; }

body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{ display:block; max-width:100%; }

.wrap{ width:min(100% - 48px, var(--maxw)); margin-inline:auto; }

/* faint film grain / vignette over whole page */
.page-vignette{
  position:fixed; inset:0; pointer-events:none; z-index:1;
  background:
    radial-gradient(120% 80% at 50% 0%, transparent 55%, rgba(0,0,0,.55) 100%);
  mix-blend-mode:multiply;
}

/* ============================================================
   Typography helpers
   ============================================================ */
.display{
  font-weight:800;
  letter-spacing:-0.04em;
  line-height:0.92;
  text-transform:uppercase;
}
.eyebrow{
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-dim); font-weight:600;
}
.muted{ color:var(--ink-dim); }
.faint{ color:var(--ink-faint); }

/* glass card shared look */
.glass{
  background:linear-gradient(160deg, rgba(30,36,52,.55), rgba(10,13,22,.45));
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  box-shadow:0 20px 60px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.06);
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  padding:20px clamp(20px,4vw,46px);
  transition:background .3s ease, backdrop-filter .3s ease;
}
.nav.scrolled{
  background:rgba(6,8,14,.7);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.brandmark{
  width:34px; height:34px; border-radius:50%;
  display:grid; place-items:center;
  background:
    radial-gradient(60% 60% at 35% 30%, rgba(var(--glow-hot),.9), transparent 70%),
    conic-gradient(from 200deg, var(--accent-deep), var(--accent), var(--accent-bright), var(--accent-deep));
  box-shadow:0 0 22px rgba(var(--glow),.55), inset 0 0 8px rgba(0,0,0,.5);
}
.brandmark svg{ width:18px; height:18px; }
.nav-links{
  display:flex; gap:clamp(18px,2.4vw,34px); list-style:none;
}
.nav-links a{
  color:var(--ink-dim); text-decoration:none;
  font-size:12px; letter-spacing:.14em; text-transform:uppercase; font-weight:600;
  transition:color .2s ease;
}
.nav-links a:hover{ color:var(--ink); }
.btn-pill{
  border:none; cursor:pointer;
  font-family:var(--font); font-weight:700; letter-spacing:.1em;
  text-transform:uppercase; font-size:11px;
  color:#fff; padding:12px 22px; border-radius:999px;
  background:linear-gradient(180deg, var(--accent-bright), var(--accent) 55%, var(--accent-deep));
  box-shadow:0 8px 26px rgba(var(--glow),.45), inset 0 1px 0 rgba(255,255,255,.35);
  transition:transform .2s ease, box-shadow .2s ease;
}
.btn-pill:hover{ transform:translateY(-1px); box-shadow:0 12px 34px rgba(var(--glow),.6), inset 0 1px 0 rgba(255,255,255,.45); }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; z-index:2;
  min-height:100vh;
  padding:120px clamp(20px,4vw,46px) 40px;
  overflow:hidden;
}
.hero-photo{
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background:#05070d url("assets/hero-bg.png") no-repeat;
  background-position:center 26%;
  background-size:cover;
}
/* fade the photo edges into the page so cards & wordmark stay readable */
.hero-photo::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(5,7,13,.85) 0%, rgba(5,7,13,.4) 14%, transparent 32%, transparent 68%, rgba(5,7,13,.4) 86%, rgba(5,7,13,.85) 100%),
    linear-gradient(180deg, rgba(5,7,13,.55) 0%, transparent 20%, transparent 60%, rgba(5,7,13,.8) 88%, #05070d 100%);
}
.hero-grain{
  position:absolute; inset:0; z-index:0; pointer-events:none; opacity:.5;
  background-image:radial-gradient(rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:3px 3px;
  mix-blend-mode:overlay;
}

/* the dark 3D object in the middle */
.hero-object{
  position:absolute; left:50%; top:44%; transform:translate(-50%,-50%);
  width:min(46vw,560px); aspect-ratio:1/1; z-index:1;
  pointer-events:none;
  animation:floaty 9s ease-in-out infinite;
}
@keyframes floaty{ 0%,100%{transform:translate(-50%,-50%) translateY(0)} 50%{transform:translate(-50%,-50%) translateY(-16px)} }

.blob{ position:absolute; inset:0; }
.blob i{
  position:absolute; border-radius:50%;
  background:
    radial-gradient(40% 40% at 35% 28%, #4a566e, #11151f 55%, #05070c 100%);
  box-shadow:
    inset 0 -22px 40px rgba(0,0,0,.8),
    inset 0 14px 30px rgba(120,150,200,.18),
    0 30px 80px rgba(0,0,0,.6);
}
.blob .b1{ width:62%; height:62%; left:19%; top:6%; }
.blob .b2{ width:40%; height:40%; left:8%; top:42%; transform:rotate(20deg); }
.blob .b3{ width:46%; height:46%; left:48%; top:48%; }
.blob .core-glow{
  position:absolute; inset:-14% ; border-radius:50%;
  background:radial-gradient(50% 50% at 50% 55%, rgba(140,192,255,.0), transparent 70%);
  box-shadow:0 0 140px 40px rgba(var(--glow),.35);
}

.hero-inner{ position:relative; z-index:3; height:100%;
  max-width:var(--maxw); margin-inline:auto; min-height:calc(100vh - 160px);
  display:grid; }

/* floating cards */
.float-card{ position:absolute; z-index:5; padding:18px 20px; border-radius:var(--radius);
  width:max-content; max-width:260px; }
.fc-perf{ left:0; top:42px; }
.fc-33{ left:0; top:236px; }
.fc-5mm{ right:0; top:64px; text-align:left; }

.float-card h4{ font-size:15px; font-weight:700; letter-spacing:-.01em; line-height:1.15; margin-bottom:8px; text-transform:uppercase; }
.float-card p{ font-size:12px; line-height:1.45; color:var(--ink-dim); }
.float-card .link{ display:inline-block; margin-top:12px; font-size:11px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--ink); text-decoration:none; border-bottom:1px solid var(--accent); padding-bottom:3px; }
.bigstat{ font-size:30px; font-weight:800; letter-spacing:-.03em; margin-bottom:4px; }
.fc-5mm .bigstat{ color:#fff; }

/* right side hero headline */
.hero-headline{ position:absolute; right:0; top:210px; text-align:right; }
.hero-headline .display{ font-size:clamp(46px,7vw,104px); }
.hero-cta{ display:flex; align-items:center; gap:16px; justify-content:flex-end; margin-top:26px; }
.hero-cta p{ font-size:13px; color:var(--ink-dim); max-width:180px; text-align:left; line-height:1.4; }
.arrow-btn{
  width:62px; height:62px; border-radius:50%; flex:none; cursor:pointer;
  display:grid; place-items:center;
  background:rgba(20,26,40,.5); border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(8px); transition:transform .25s ease, background .25s ease;
}
.arrow-btn:hover{ transform:rotate(-8deg) scale(1.05); background:rgba(var(--glow),.25); }
.arrow-btn svg{ width:22px; height:22px; stroke:#fff; }

/* OMNI wordmark */
.omni{
  position:absolute; left:-6px; bottom:6px;
  font-size:clamp(90px,17vw,260px); font-weight:800; letter-spacing:-.04em; line-height:.8;
  background:linear-gradient(180deg, #ffffff 0%, #c8d0de 30%, #6f7892 55%, #e8edf5 75%, #9aa3b6 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  filter:drop-shadow(0 8px 30px rgba(0,0,0,.5));
}
.hero-social{ position:absolute; right:4px; bottom:54px; display:flex; gap:16px; }
.hero-social a{ color:var(--ink-dim); transition:color .2s; }
.hero-social a:hover{ color:#fff; }
.hero-social svg{ width:18px; height:18px; }

/* ============================================================
   TRUSTED TOOLS
   ============================================================ */
.trusted{ position:relative; z-index:2; padding:70px 0 60px; text-align:center; }
.trusted h2{ font-size:clamp(22px,3vw,38px); font-weight:700; letter-spacing:-.02em; line-height:1.12; }
.trusted h2 .dim{ color:var(--ink-dim); }
.trusted .sub{ font-size:12px; color:var(--ink-faint); margin-top:18px; line-height:1.5; }
.logos{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:clamp(26px,5vw,64px); margin-top:42px; }
.logos .logo{ color:#5a6074; opacity:.6; font-weight:700; font-size:22px; display:flex; align-items:center; gap:8px; letter-spacing:-.01em;
  filter:grayscale(1) brightness(1.4); transition:opacity .25s, filter .25s; }
.logos .logo.hot{ color:#fff; opacity:1; filter:none; }
.logos .logo:hover{ opacity:1; filter:none; color:#fff; }
.logos .logo svg{ height:24px; width:auto; }

/* ============================================================
   BILLBOARD / CINEMA SCENE
   ============================================================ */
.cinema{ position:relative; z-index:2; padding:40px 0 100px; perspective:1900px; overflow:hidden;
  background:radial-gradient(75% 65% at 50% 36%, rgba(var(--glow),.12), transparent 72%); }
/* dark cinema room — vignette around the screen */
.cinema::before{ content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(68% 78% at 50% 40%, transparent 42%, rgba(0,0,0,.55) 78%, #05070d 100%); }
.stage{ position:relative; z-index:1; max-width:1040px; margin:0 auto; padding:20px 0 230px; transform-style:preserve-3d; }
.billboard{
  position:relative; border-radius:9px; overflow:hidden;
  transform:rotateX(9deg); transform-origin:center bottom;
  box-shadow:
    0 60px 150px rgba(var(--glow),.40),
    0 0 90px rgba(var(--glow),.30),
    0 0 0 1px rgba(140,190,255,.18),
    inset 0 0 0 1px rgba(255,255,255,.05);
}
/* bright 3D bottom edge / screen thickness catching the glow */
.billboard::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:6px; z-index:6;
  background:linear-gradient(180deg, rgba(180,215,255,.9), rgba(var(--glow),.5));
  box-shadow:0 6px 26px rgba(var(--glow),.8), 0 2px 8px rgba(180,215,255,.6); }
.billboard-bg{
  position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(70% 110% at 80% 45%, rgba(var(--glow-hot),.55), transparent 58%),
    radial-gradient(120% 140% at 62% 105%, rgba(var(--glow),.7), transparent 64%),
    linear-gradient(180deg, #0a1530, #06203f);
}
.billboard-inner{ position:relative; z-index:2; display:block; padding:clamp(28px,4vw,52px); min-height:470px; }
.bb-left{ display:flex; flex-direction:column; max-width:60%; min-height:calc(470px - 2*clamp(28px,4vw,52px)); }
.billboard h3{ font-size:clamp(26px,3.4vw,46px); font-weight:800; letter-spacing:-.03em; line-height:1.02; text-transform:uppercase; }
.billboard .bb-sub{ font-size:14px; color:var(--ink-dim); margin-top:18px; max-width:330px; line-height:1.5; }
.bb-stats{ display:flex; gap:36px; margin-top:auto; padding-top:40px; }
.bb-stat .n{ font-size:clamp(34px,4vw,58px); font-weight:800; letter-spacing:-.03em; }
.bb-stat .l{ font-size:11px; color:var(--ink-dim); letter-spacing:.04em; margin-top:2px; }
/* founder photo bleeds into the right of the billboard, fading into the bg */
.bb-photo{ position:absolute; right:0; top:0; bottom:0; width:62%; z-index:1; pointer-events:none; }
.bb-photo img{ width:100%; height:100%; object-fit:cover; object-position:72% 14%;
  -webkit-mask-image:linear-gradient(90deg, transparent 0%, rgba(0,0,0,.55) 26%, #000 52%), linear-gradient(180deg, #000 72%, transparent 99%);
  mask-image:linear-gradient(90deg, transparent 0%, rgba(0,0,0,.55) 26%, #000 52%), linear-gradient(180deg, #000 72%, transparent 99%);
  -webkit-mask-composite:source-in; mask-composite:intersect; }

/* floor + silhouette */
/* floor — glow pool spilling from the screen onto the ground */
.floor{ position:absolute; left:50%; bottom:40px; transform:translateX(-50%);
  width:118%; height:215px; z-index:0; pointer-events:none;
  background:
    radial-gradient(42% 85% at 50% 0%, rgba(var(--glow-hot),.42), transparent 64%),
    radial-gradient(66% 100% at 50% 6%, rgba(var(--glow),.30), transparent 72%);
  filter:blur(7px); }
/* person standing in front of the screen, on the floor */
.silhouette{ position:absolute; left:50%; bottom:48px; transform:translateX(-50%);
  width:80px; height:172px; z-index:5;
  background:#04060c;
  clip-path:polygon(42% 11%, 58% 11%, 72% 26%, 67% 34%, 63% 97%, 53% 97%, 50% 62%, 47% 97%, 37% 97%, 33% 34%, 28% 26%);
  filter:drop-shadow(0 0 10px rgba(var(--glow),.4)) drop-shadow(-4px 0 6px rgba(var(--glow-hot),.3)); }
/* head */
.silhouette::before{ content:""; position:absolute; left:50%; top:-22px; transform:translateX(-50%);
  width:30px; height:34px; border-radius:50% 50% 46% 46%;
  background:#04060c;
  filter:drop-shadow(0 0 10px rgba(var(--glow),.4)); }

/* ============================================================
   SERVICES
   ============================================================ */
.services{ position:relative; z-index:2; padding:40px 0 120px; }
.services .shead{ font-size:clamp(70px,13vw,200px); font-weight:800; letter-spacing:-.05em; line-height:.85; text-transform:uppercase; margin-bottom:50px; }
.svc-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(20px,3vw,42px); align-items:start; }
.svc-grid .col{ display:flex; flex-direction:column; gap:clamp(20px,3vw,42px); }
.svc-grid .col.right{ margin-top:90px; }
.svc-card{
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  border:1px solid rgba(255,255,255,.07);
  background:linear-gradient(180deg, rgba(20,24,36,.5), rgba(8,11,18,.6));
  padding:24px; min-height:330px; display:flex; flex-direction:column;
  transition:transform .3s ease, box-shadow .3s ease;
}
.svc-card:hover{ transform:translateY(-6px); box-shadow:0 30px 70px rgba(var(--glow),.25); }
.svc-glow{ position:absolute; left:50%; top:42%; transform:translate(-50%,-50%);
  width:104%; height:86%; z-index:0;
  background:
    radial-gradient(closest-side, rgba(175,212,255,.85), rgba(80,158,255,.5) 38%, rgba(var(--glow),.22) 60%, transparent 82%);
  filter:blur(22px); }
.svc-num{ position:relative; z-index:2; font-size:13px; color:rgba(255,255,255,.7); letter-spacing:.05em; }
.svc-icon{ position:relative; z-index:2; flex:1; display:grid; place-items:center; perspective:600px; }
/* 3D glossy black icons */
.svc-icon .glyph{ font-size:112px; font-weight:800; line-height:1; color:#0b0e15;
  text-shadow:
    0 -1.5px 0 #4a5468,
    0 1px 0 #070a10, 0 2px 0 #06080d, 0 3px 0 #05070b, 0 4px 0 #04060a,
    0 6px 2px rgba(0,0,0,.5), 0 16px 26px rgba(0,0,0,.6),
    0 0 2px rgba(150,200,255,.7);
  will-change:transform; }
.svc-icon svg{ width:108px; height:108px; color:#0b0e15;
  filter:
    drop-shadow(0 -1.5px 0 rgba(90,105,130,.9))
    drop-shadow(0 3px 0 #06080d)
    drop-shadow(0 5px 1px rgba(0,0,0,.5))
    drop-shadow(0 16px 24px rgba(0,0,0,.6))
    drop-shadow(0 0 6px rgba(150,200,255,.5));
  will-change:transform; }
.svc-icon svg path{ fill:#0b0e15; }
@media (prefers-reduced-motion:no-preference){
  .svc-icon .glyph, .svc-icon svg{ animation:svcFloat 4.5s ease-in-out infinite; }
  .svc-glow{ animation:svcPulse 4.5s ease-in-out infinite; }
  .svc-grid .col.left .svc-card:nth-child(2) .svc-icon .glyph,
  .svc-grid .col.left .svc-card:nth-child(2) .svc-icon svg{ animation-delay:-1.5s; }
  .svc-grid .col.right .svc-card:nth-child(1) .svc-icon .glyph,
  .svc-grid .col.right .svc-card:nth-child(1) .svc-icon svg{ animation-delay:-2.2s; }
  .svc-grid .col.right .svc-card:nth-child(2) .svc-icon .glyph,
  .svc-grid .col.right .svc-card:nth-child(2) .svc-icon svg{ animation-delay:-3.4s; }
}
@keyframes svcFloat{
  0%   { transform:translateY(0) rotateZ(-3deg) rotateY(-8deg); }
  50%  { transform:translateY(-12px) rotateZ(3deg) rotateY(8deg); }
  100% { transform:translateY(0) rotateZ(-3deg) rotateY(-8deg); }
}
@keyframes svcPulse{
  0%,100%{ opacity:.85; transform:translate(-50%,-50%) scale(.97); }
  50%    { opacity:1; transform:translate(-50%,-50%) scale(1.05); }
}
.svc-card:hover .glyph,
.svc-card:hover svg{ animation-play-state:paused; transform:translateY(-6px) rotateZ(-4deg) scale(1.06); }
.svc-body{ position:relative; z-index:2; }
.svc-body h3{ font-size:20px; font-weight:700; text-transform:uppercase; letter-spacing:-.01em; }
.svc-body p{ font-size:12px; color:var(--ink-dim); margin-top:8px; line-height:1.5; max-width:240px; }

/* ============================================================
   CASE STUDIES
   ============================================================ */
.cases{ position:relative; z-index:2; padding:60px 0 120px; }
.cases-head{ position:relative; }
.cases-head .l1{ font-size:clamp(54px,9.5vw,150px); font-weight:800; letter-spacing:-.05em; line-height:.86; text-transform:uppercase; }
.cases-head .l2{ text-align:right; font-size:clamp(30px,5.4vw,84px); font-weight:800; letter-spacing:-.04em; line-height:.9; text-transform:uppercase; color:var(--ink-dim); margin-top:-6px; }
.cases-head .l2 b{ color:#fff; font-weight:800; }
.real-pill{ position:absolute; right:9%; top:26%; padding:12px 16px; border-radius:16px; max-width:190px; }
.real-pill h5{ font-size:11px; letter-spacing:.16em; text-transform:uppercase; margin-bottom:6px; }
.real-pill p{ font-size:11px; color:var(--ink-dim); line-height:1.4; }

.tabs{ display:flex; gap:14px; margin:34px 0 28px; }
.tab{ cursor:pointer; border:1px solid rgba(255,255,255,.14); background:transparent; color:var(--ink-dim);
  font-family:var(--font); font-weight:600; font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  padding:11px 20px; border-radius:999px; transition:all .2s ease; }
.tab.active{ color:#fff; border-color:transparent;
  background:linear-gradient(180deg, var(--accent-bright), var(--accent) 60%, var(--accent-deep));
  box-shadow:0 8px 24px rgba(var(--glow),.45); }
.tab:hover:not(.active){ color:#fff; border-color:rgba(255,255,255,.3); }

.case-card{ position:relative; border-radius:var(--radius-lg); overflow:hidden; padding:clamp(28px,4vw,54px);
  display:grid; grid-template-columns:1fr 1.1fr; gap:30px; min-height:430px;
  border:1px solid rgba(255,255,255,.06); }
.case-card .cc-bg{ position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(70% 120% at 60% 115%, rgba(var(--glow-hot),.6), transparent 60%),
    radial-gradient(110% 130% at 50% 120%, rgba(var(--glow),.6), transparent 62%),
    linear-gradient(180deg, #0a0e1a, #0a1c3a); }
.case-left{ position:relative; z-index:2; }
.case-left .ctitle{ font-size:clamp(34px,4.4vw,62px); font-weight:800; letter-spacing:-.03em; line-height:.92; text-transform:uppercase; }
.case-left h4{ font-size:14px; letter-spacing:.1em; text-transform:uppercase; margin:30px 0 8px; }
.case-left p{ font-size:12.5px; color:var(--ink-dim); line-height:1.55; max-width:340px; }
.case-right{ position:relative; z-index:2; display:flex; flex-direction:column; justify-content:flex-end; }
.chart{ width:100%; height:200px; }
.chart svg{ width:100%; height:100%; overflow:visible; }
.cc-stats{ display:flex; gap:30px; margin-top:30px; }
.cc-stat .n{ font-size:clamp(28px,3.4vw,46px); font-weight:800; letter-spacing:-.03em; }
.cc-stat .l{ font-size:11px; color:var(--ink-dim); margin-top:4px; }

/* ============================================================
   AD CREATIVES
   ============================================================ */
.creatives{ position:relative; z-index:2; padding:40px 0 80px; overflow:hidden; }
.cr-head{ position:relative; }
.cr-head .l1{ font-size:clamp(46px,9vw,140px); font-weight:800; letter-spacing:-.05em; line-height:.86; text-transform:uppercase; }
.cr-head .l2{ text-align:right; font-size:clamp(30px,5vw,78px); font-weight:800; letter-spacing:-.04em; text-transform:uppercase; color:var(--ink-dim); margin-top:-4px; }
.cr-head .l2 b{ color:#fff; }
.win-pill{ position:absolute; left:2%; top:64%; padding:12px 16px; border-radius:16px; max-width:200px; }
.win-pill h5{ font-size:11px; letter-spacing:.16em; text-transform:uppercase; margin-bottom:6px; }
.win-pill p{ font-size:11px; color:var(--ink-dim); line-height:1.4; }
.cr-sub{ text-align:right; font-size:12.5px; color:var(--ink-dim); max-width:360px; margin:20px 0 20px auto; line-height:1.55; }

.fan{ position:relative; height:560px; margin-top:10px; }
.fan-glow{ position:absolute; left:50%; bottom:-40px; transform:translateX(-50%); width:70%; height:280px;
  background:radial-gradient(50% 70% at 50% 60%, rgba(var(--glow),.5), transparent 70%); z-index:0; filter:blur(6px); }
.fan .card{ position:absolute; left:50%; bottom:0; border-radius:20px; overflow:hidden; padding:0; cursor:pointer;
  background:#0c0f17; box-shadow:0 30px 70px rgba(0,0,0,.6); border:1px solid rgba(255,255,255,.08);
  transition:transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .3s ease; }
.fan .card:hover{ box-shadow:0 36px 90px rgba(var(--glow),.4); }
.fan .card image-slot{ width:100%; height:100%; }
.fan .c1{ width:200px; height:300px; transform:translateX(-340%) translateY(40px) rotate(-16deg); z-index:1; }
.fan .c2{ width:210px; height:330px; transform:translateX(-185%) translateY(8px) rotate(-8deg); z-index:2; }
.fan .c3{ width:240px; height:480px; transform:translateX(-50%) translateY(-20px); z-index:5; border-radius:34px; border:8px solid #15181f; }
.fan .c4{ width:210px; height:330px; transform:translateX(85%) translateY(8px) rotate(8deg); z-index:2; }
.fan .c5{ width:200px; height:300px; transform:translateX(240%) translateY(40px) rotate(16deg); z-index:1; }
.fan:hover .c1{ transform:translateX(-360%) translateY(30px) rotate(-19deg); }
.fan:hover .c5{ transform:translateX(260%) translateY(30px) rotate(19deg); }
.play-btn{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); z-index:6;
  width:48px; height:48px; border-radius:50%; background:rgba(255,255,255,.18); backdrop-filter:blur(6px);
  display:grid; place-items:center; pointer-events:none; opacity:0; transition:opacity .3s ease, transform .3s ease;
  box-shadow:0 6px 20px rgba(0,0,0,.4); }
.fan .card:hover .play-btn{ opacity:1; transform:translate(-50%,-50%) scale(1.08); }
.fan .c3 .play-btn{ opacity:1; width:56px; height:56px; }
.play-btn svg{ width:18px; height:18px; fill:#fff; margin-left:3px; }

/* ============================================================
   VIDEO LIGHTBOX
   ============================================================ */
.vlightbox{ position:fixed; inset:0; z-index:200; display:none; align-items:center; justify-content:center; gap:clamp(8px,3vw,40px);
  background:rgba(4,6,12,.86); backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px); }
.vlightbox.open{ display:flex; }
.vl-stage{ display:flex; flex-direction:column; align-items:center; gap:22px; }
.vl-phone{ position:relative; width:min(82vw,300px); aspect-ratio:9/19.5; border-radius:38px; overflow:hidden;
  background:#05070d; border:8px solid #15181f;
  box-shadow:0 40px 100px rgba(var(--glow),.45), 0 0 0 1px rgba(140,190,255,.2); }
.vl-phone video{ width:100%; height:100%; object-fit:cover; display:block; background:#05070d; }
.vl-empty{ position:absolute; inset:0; z-index:2; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:18px;
  background:
    radial-gradient(70% 50% at 50% 64%, rgba(var(--glow),.35), transparent 70%),
    linear-gradient(180deg, #0a0e1a, #0a1c3a); text-align:center; }
.vl-empty .play-ring{ width:64px; height:64px; border-radius:50%; display:grid; place-items:center;
  background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.3); }
.vl-empty .play-ring svg{ width:24px; height:24px; margin-left:3px; }
.vl-empty p{ font-size:12px; color:var(--ink-dim); line-height:1.6; letter-spacing:.02em; }
.vl-empty code{ font-family:ui-monospace,Menlo,monospace; color:var(--accent-bright); font-size:12px; }
.vl-dots{ display:flex; gap:9px; }
.vl-dots button{ width:8px; height:8px; border-radius:50%; border:none; padding:0; cursor:pointer;
  background:rgba(255,255,255,.25); transition:background .2s ease, transform .2s ease; }
.vl-dots button.on{ background:var(--accent-bright); transform:scale(1.3); }
.vl-close{ position:absolute; top:24px; right:26px; width:46px; height:46px; border-radius:50%; cursor:pointer;
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.18); display:grid; place-items:center; transition:background .2s ease; }
.vl-close:hover{ background:rgba(255,255,255,.2); }
.vl-close svg{ width:20px; height:20px; }
.vl-nav{ width:56px; height:56px; border-radius:50%; flex:none; cursor:pointer;
  background:rgba(20,26,40,.6); border:1px solid rgba(255,255,255,.14); display:grid; place-items:center;
  transition:background .2s ease, transform .2s ease; }
.vl-nav:hover{ background:rgba(var(--glow),.4); transform:scale(1.06); }
.vl-nav svg{ width:22px; height:22px; }
@media (max-width:680px){ .vl-nav{ width:46px; height:46px; } .vl-close{ top:16px; right:16px; } }

/* ============================================================
   FAQ + FOOTER
   ============================================================ */
.faq{ position:relative; z-index:2; padding:60px 0 80px; }
.faq .fhead{ font-size:clamp(70px,13vw,200px); font-weight:800; letter-spacing:-.05em; line-height:.85; text-transform:uppercase; margin-bottom:40px; }
.faq-list{ max-width:960px; display:flex; flex-direction:column; gap:16px; }
.faq-item{ position:relative; border-radius:16px; overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(100deg, rgba(18,23,36,.55), rgba(8,11,18,.65));
  transition:border-color .3s ease; }
.faq-item:hover{ border-color:rgba(140,190,255,.28); }
/* the light glow on the left edge of each card */
.faq-item::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:80%; z-index:0; pointer-events:none;
  background:
    radial-gradient(ellipse 46% 88% at 7% 64%, rgba(165,208,255,.95), rgba(70,160,255,.6) 26%, rgba(47,123,255,.28) 46%, transparent 66%),
    radial-gradient(ellipse 70% 130% at 0% 52%, rgba(47,123,255,.35), transparent 70%);
  transition:opacity .35s ease; }
.faq-item.open::before{ background:
    radial-gradient(ellipse 50% 90% at 6% 52%, rgba(165,208,255,.6), rgba(70,160,255,.34) 30%, transparent 64%),
    radial-gradient(ellipse 72% 130% at 0% 50%, rgba(47,123,255,.22), transparent 74%); }
.faq-q{ position:relative; z-index:2; width:100%; cursor:pointer; background:none; border:none; color:var(--ink); font-family:var(--font);
  display:flex; align-items:center; justify-content:space-between; gap:20px; text-align:left;
  padding:24px 26px; font-size:clamp(15px,1.7vw,20px); font-weight:600; letter-spacing:-.01em; text-transform:uppercase; line-height:1.2; }
.faq-q .pm{ flex:none; width:26px; height:26px; display:grid; place-items:center; position:relative; }
.faq-q .pm::before,.faq-q .pm::after{ content:""; position:absolute; background:#fff; border-radius:2px; }
.faq-q .pm::before{ width:16px; height:2px; }
.faq-q .pm::after{ width:2px; height:16px; transition:transform .3s ease; }
.faq-item.open .pm::after{ transform:scaleY(0); }
.faq-a{ position:relative; z-index:2; max-height:0; overflow:hidden; transition:max-height .35s ease; }
.faq-a p{ padding:0 26px 24px; color:var(--ink-dim); font-size:13px; line-height:1.6; max-width:760px; }

.foot{ position:relative; z-index:2; padding:80px 0 50px; border-top:1px solid rgba(255,255,255,.08); }
.foot-cta{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:30px; }
.foot-cta h3{ font-size:clamp(34px,5.5vw,84px); font-weight:800; letter-spacing:-.04em; text-transform:uppercase; line-height:.9; }
.foot-bottom{ display:flex; flex-wrap:wrap; gap:16px; justify-content:space-between; align-items:center;
  margin-top:70px; padding-top:24px; border-top:1px solid rgba(255,255,255,.07); font-size:12px; color:var(--ink-faint); }
.foot-bottom .omni-mini{ font-weight:800; letter-spacing:-.03em; font-size:18px; color:var(--ink); }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi{ position:relative; z-index:2; padding:60px 0 100px; }
.testi-head{ position:relative; }
.testi-head .t1{ font-size:clamp(54px,10vw,150px); font-weight:800; letter-spacing:-.05em; line-height:.86; text-transform:uppercase; }
.testi-head .t2{ text-align:right; font-size:clamp(34px,6vw,96px); font-weight:800; letter-spacing:-.04em; line-height:.9; text-transform:uppercase; color:var(--ink-dim); margin-top:-8px; }
.out-pill{ position:absolute; right:30%; top:34%; padding:12px 16px; border-radius:16px; max-width:200px; }
.out-pill h5{ font-size:11px; letter-spacing:.16em; text-transform:uppercase; margin-bottom:6px; }
.out-pill p{ font-size:11px; color:var(--ink-dim); line-height:1.4; }
.testi-sub{ text-align:right; font-size:12.5px; color:var(--ink-dim); max-width:340px; margin:18px 0 26px auto; line-height:1.55; }
.testi-tabs{ display:flex; gap:14px; margin-bottom:28px; flex-wrap:wrap; }
.ttab{ cursor:pointer; border:1px solid rgba(255,255,255,.14); background:transparent; color:var(--ink-dim);
  font-family:var(--font); font-weight:600; font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  padding:11px 20px; border-radius:999px; transition:all .2s ease; }
.ttab.active{ color:#fff; border-color:transparent;
  background:linear-gradient(180deg, var(--accent-bright), var(--accent) 60%, var(--accent-deep));
  box-shadow:0 8px 24px rgba(var(--glow),.45); }
.ttab:hover:not(.active){ color:#fff; border-color:rgba(255,255,255,.3); }

.testi-card{ display:grid; grid-template-columns:.85fr 1.15fr; gap:24px; align-items:stretch; }
.testi-photo{ position:relative; min-height:380px; border-radius:22px; overflow:hidden; }
.testi-photo image-slot{ position:absolute; inset:0; width:100%; height:100%; }
.testi-body{ position:relative; border-radius:var(--radius-lg); overflow:hidden; padding:clamp(28px,3.4vw,46px); display:flex; flex-direction:column;
  border:1px solid rgba(255,255,255,.06); }
.testi-bg{ position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(80% 120% at 50% 130%, rgba(var(--glow-hot),.65), transparent 60%),
    radial-gradient(120% 130% at 50% 120%, rgba(var(--glow),.6), transparent 62%),
    linear-gradient(180deg, #0a0e1a, #0a1c3a); }
.testi-quote{ position:relative; z-index:2; font-size:clamp(18px,2.2vw,27px); font-weight:700; letter-spacing:-.01em; line-height:1.28; text-transform:uppercase; max-width:620px; }
.testi-stats{ position:relative; z-index:2; display:flex; gap:clamp(24px,4vw,56px); margin-top:auto; padding-top:40px; }
.t-stat .n{ font-size:clamp(30px,3.6vw,52px); font-weight:800; letter-spacing:-.03em; }
.t-stat .l{ font-size:11px; color:rgba(255,255,255,.7); margin-top:4px; }
.testi-author{ position:relative; z-index:2; margin-top:34px; display:flex; flex-direction:column; gap:3px; }
.testi-author .who{ font-size:14px; font-weight:700; }
.testi-author .org{ font-size:12px; color:rgba(255,255,255,.65); }

/* ============================================================
   CONTACT
   ============================================================ */
.contact{ position:relative; z-index:2; padding:90px 0 100px; overflow:hidden; }
.contact-glow{ position:absolute; left:-10%; top:6%; width:60%; height:70%; z-index:0; pointer-events:none;
  background:radial-gradient(50% 50% at 40% 40%, rgba(var(--glow),.5), transparent 65%); filter:blur(10px); }
.contact-head{ position:relative; z-index:2; }
.contact-head .ch1{ font-size:clamp(60px,12vw,170px); font-weight:800; letter-spacing:-.05em; line-height:.84; text-transform:uppercase; }
.contact-head .ch2{ text-align:right; font-size:clamp(40px,7.4vw,118px); font-weight:800; letter-spacing:-.045em; line-height:.86; text-transform:uppercase; margin-top:-6px; }
.contact-head .ch2 .grow{ color:#fff; }
.contact-head .ch2 .dim{ color:var(--ink-dim); }
.talk-pill{ position:absolute; left:46%; top:34%; padding:12px 16px; border-radius:16px; max-width:180px; }
.talk-pill h5{ font-size:11px; letter-spacing:.16em; text-transform:uppercase; margin-bottom:6px; }
.talk-pill p{ font-size:11px; color:var(--ink-dim); line-height:1.4; }

.cform{ position:relative; z-index:2; display:grid; grid-template-columns:1fr 1fr; gap:30px clamp(40px,7vw,120px); margin-top:60px; }
.field{ display:flex; flex-direction:column; gap:12px; }
.field span{ font-size:13px; font-weight:600; letter-spacing:.01em; color:var(--ink); }
.field input, .field select{ background:transparent; border:none; border-bottom:1px solid rgba(255,255,255,.22);
  color:var(--ink); font-family:var(--font); font-size:14px; padding:8px 2px; outline:none; transition:border-color .2s ease; }
.field input::placeholder{ color:var(--ink-faint); }
.field select{ color:var(--ink-faint); appearance:none; cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%236b7488' stroke-width='1.6'><path d='M3 5l4 4 4-4'/></svg>");
  background-repeat:no-repeat; background-position:right 2px center; }
.field select option{ background:#0a0e1a; color:var(--ink); }
.field input:focus, .field select:focus{ border-color:var(--accent); }
.cform-submit{ grid-column:1 / -1; justify-self:stretch; margin-top:14px; cursor:pointer;
  height:62px; border-radius:999px; border:1px solid rgba(255,255,255,.18); background:rgba(20,26,40,.4);
  display:grid; place-items:center; transition:background .25s ease, transform .2s ease; }
.cform-submit:hover{ background:linear-gradient(180deg, var(--accent), var(--accent-deep)); transform:translateY(-2px); box-shadow:0 14px 34px rgba(var(--glow),.45); }
.cform-submit svg{ width:24px; height:24px; }

/* ============================================================
   BIG FOOTER (override of simple footer)
   ============================================================ */
.foot{ position:relative; z-index:2; padding:70px 0 30px; border-top:none; overflow:hidden; }
.foot-glow{ position:absolute; left:50%; bottom:-30%; transform:translateX(-50%); width:120%; height:90%; z-index:0; pointer-events:none;
  background:
    radial-gradient(50% 60% at 50% 100%, rgba(var(--glow-hot),.7), transparent 60%),
    radial-gradient(70% 80% at 50% 110%, rgba(var(--glow),.7), transparent 64%); }
.foot-cols{ position:relative; z-index:2; display:grid; grid-template-columns:1fr 1fr 1fr; gap:30px; align-items:start; padding-bottom:30px; }
.foot-nav{ display:flex; flex-direction:column; gap:14px; }
.foot-nav a{ color:var(--ink); text-decoration:none; font-size:12px; letter-spacing:.06em; text-transform:uppercase; transition:color .2s; }
.foot-nav a:hover{ color:var(--accent-bright); }
.foot-address{ text-align:center; }
.foot-address h5{ font-size:12px; letter-spacing:.16em; text-transform:uppercase; margin-bottom:14px; }
.foot-address p{ font-size:12px; color:var(--ink-dim); line-height:1.6; }
.foot-social{ display:flex; gap:18px; justify-content:flex-end; }
.foot-social a{ color:var(--ink); transition:color .2s; }
.foot-social a:hover{ color:var(--accent-bright); }
.foot-social svg{ width:20px; height:20px; }
.foot-wordmark{ position:relative; z-index:2; text-align:center; margin-top:10px;
  font-size:clamp(64px,16.5vw,250px); font-weight:800; letter-spacing:-.04em; line-height:.9; text-transform:uppercase;
  color:#fff; text-shadow:0 0 60px rgba(var(--glow),.4); }
.foot-legal{ position:relative; z-index:2; display:flex; justify-content:space-between; margin-top:18px; font-size:11px; color:rgba(255,255,255,.6); }

/* reveal animation — content is VISIBLE by default; JS adds .pre to hide,
   then removes it (on scroll / fallback) so content can NEVER stay hidden. */
.reveal{ transition:opacity .7s ease, transform .7s ease; }
@media (prefers-reduced-motion:no-preference){
  .reveal.pre{ opacity:0; transform:translateY(26px); }
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:1024px){
  .nav-links{ display:none; }
  .billboard-inner{ display:block; }
  .bb-left{ max-width:100%; }
  .bb-photo{ width:48%; opacity:.6; }
  .case-card{ grid-template-columns:1fr; }
  .testi-card{ grid-template-columns:1fr; }
  .testi-photo{ min-height:300px; }
  /* pills flow inline under their headings */
  .real-pill, .win-pill, .out-pill, .talk-pill{ position:static; max-width:none; margin-top:18px; }
  .cr-head .l2, .cr-sub, .testi-head .t2, .testi-sub, .contact-head .ch2, .cases-head .l2{ text-align:left; }
  .testi-sub, .cr-sub{ margin-left:0; margin-right:0; }
}

@media (max-width:760px){
  .nav{ padding:16px 20px; }
  .btn-pill{ padding:11px 18px; font-size:10px; }

  /* ---- HERO: image band on top, content stacked below ---- */
  .hero{ min-height:auto; padding:0 20px 48px; }
  .hero-photo{ height:clamp(330px,54vh,470px); inset:0 0 auto 0;
    background-size:cover; background-position:center 6%; }
  .hero-photo::after{ background:
    linear-gradient(180deg, rgba(5,7,13,.2) 0%, transparent 24%, rgba(5,7,13,.5) 62%, #05070d 92%),
    linear-gradient(90deg, rgba(5,7,13,.45), transparent 26%, transparent 74%, rgba(5,7,13,.45)); }
  .hero-grain{ display:none; }
  .hero-inner{ position:relative; min-height:0; display:flex; flex-direction:column; gap:14px;
    margin-top:clamp(290px,48vh,430px); }
  .hero-headline{ position:static; order:1; right:auto; top:auto; text-align:center; margin:0; }
  .hero-headline .display{ font-size:clamp(40px,13vw,72px); text-shadow:0 4px 26px rgba(5,7,13,.7); }
  .hero-cta{ flex-direction:column; align-items:center; justify-content:center; gap:14px; margin-top:18px; }
  .hero-cta p{ text-align:center; max-width:260px; }
  .float-card{ position:static!important; left:auto!important; right:auto!important; top:auto!important;
    order:2; margin:0; width:100%; max-width:none; text-align:left; }
  .fc-33{ order:3; }
  .fc-5mm{ order:4; }
  .omni{ position:static; order:5; left:auto; bottom:auto; text-align:center;
    font-size:clamp(70px,24vw,150px); margin-top:18px; }
  .hero-social{ position:static; order:6; right:auto; bottom:auto; justify-content:center; margin-top:6px; }

  /* ---- billboard ---- */
  .bb-photo{ width:62%; opacity:.5; }
  .bb-stats{ flex-wrap:wrap; gap:22px; }
  .stage{ padding-bottom:170px; }

  /* ---- services ---- */
  .svc-grid{ grid-template-columns:1fr; }
  .svc-grid .col.right{ margin-top:0; }
  .svc-card{ min-height:300px; }

  /* ---- cases / testimonials / contact ---- */
  .cc-stats{ flex-wrap:wrap; gap:20px; }
  .testi-stats{ flex-wrap:wrap; gap:20px 30px; }
  .cform{ grid-template-columns:1fr; gap:24px; margin-top:40px; }

  /* ---- ad creatives fan: show 3 centre cards ---- */
  .creatives{ padding-bottom:40px; }
  .fan{ transform:scale(.86); transform-origin:bottom center; height:430px; }
  .fan .c1, .fan .c5{ display:none; }
  .fan .c2{ transform:translateX(-122%) translateY(12px) rotate(-9deg); }
  .fan .c4{ transform:translateX(22%) translateY(12px) rotate(9deg); }
  .fan:hover .c2{ transform:translateX(-128%) translateY(6px) rotate(-11deg); }
  .fan:hover .c4{ transform:translateX(28%) translateY(6px) rotate(11deg); }

  /* ---- footer ---- */
  .foot-cols{ grid-template-columns:1fr; text-align:left; gap:24px; }
  .foot-address{ text-align:left; }
  .foot-social{ justify-content:flex-start; }
  .foot-legal{ flex-direction:column; gap:8px; align-items:flex-start; }
}

@media (max-width:430px){
  .hero-headline .display{ font-size:clamp(36px,13vw,60px); }
  .omni{ font-size:24vw; }
  .float-card{ padding:16px 18px; }
  .services .shead, .faq .fhead{ font-size:clamp(56px,19vw,90px); }
  .cases-head .l1, .cr-head .l1, .testi-head .t1{ font-size:clamp(44px,15vw,90px); }
  .contact-head .ch1{ font-size:clamp(48px,16vw,90px); }
  .contact-head .ch2{ font-size:clamp(34px,11vw,70px); }
  .fan{ transform:scale(.7); }
  .vl-nav{ width:42px; height:42px; }
}

/* ============ BURGER (mobile) — igual ao Vert Tech ============ */
.nav-burger{
  display:none; flex-direction:column; justify-content:center; gap:5px;
  width:40px; height:40px; padding:8px;
  border-radius:10px; border:1px solid rgba(255,255,255,.14);
  background:none; cursor:pointer;
}
.nav-burger span{
  display:block; height:2px; width:100%;
  background:#fff; border-radius:2px;
  transition:transform .3s cubic-bezier(.22,1,.36,1), opacity .3s;
}
.nav-burger.is-open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-burger.is-open span:nth-child(2){ opacity:0; }
.nav-burger.is-open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
@media (max-width:1024px){
  .nav-burger{ display:flex; }
  .btn-pill{ display:none; }
  .nav-links{
    display:flex; flex-direction:column; gap:0;
    position:fixed; top:0; right:0; left:auto;
    transform:translateX(100%);
    height:100vh; width:min(78vw,320px);
    padding:6rem 2.2rem 2rem; margin:0;
    background:rgba(5,7,13,.96);
    backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
    border-left:1px solid rgba(47,123,255,.2);
    transition:transform .45s cubic-bezier(.22,1,.36,1);
    z-index:99;
  }
  .nav-links.is-open{ transform:translateX(0); }
  .nav-links li{ list-style:none; }
  .nav-links a{
    display:block; padding:1.1rem 0;
    border-bottom:1px solid rgba(255,255,255,.1);
    color:#fff; font-size:14px;
  }
}

/* logo Vert no brandmark */
.brandmark img{ width:100%; height:100%; border-radius:50%; object-fit:cover; }
