/* ============================================================
   ADMOND — Shared design system (v3)
   Used by: index, consulting, paid-media, analytics
   ============================================================ */

/* ===== Cross-document view transitions (Chrome/Safari) — Apple-style ===== */
@view-transition { navigation: auto; }
::view-transition-old(root),
::view-transition-new(root){
  animation-duration: 480ms;
  animation-timing-function: cubic-bezier(.32,.72,0,1);
}
::view-transition-old(root){ animation-name: vt-apple-out; }
::view-transition-new(root){ animation-name: vt-apple-in; }
@keyframes vt-apple-out{
  0%   { opacity:1; filter:blur(0); transform:scale(1) }
  100% { opacity:0; filter:blur(6px); transform:scale(.985) }
}
@keyframes vt-apple-in{
  0%   { opacity:0; filter:blur(6px); transform:scale(1.012) }
  100% { opacity:1; filter:blur(0); transform:scale(1) }
}

/* Pin the header and footer so they don't flicker across navigations */
header.nav{ view-transition-name: site-header; }
footer{ view-transition-name: site-footer; }

/* ===== Fallback fade-in for browsers without view transitions ===== */
@supports not (view-transition-name: a){
  @keyframes admond-page-in{
    from{ opacity:0; transform:translateY(8px) scale(.995); filter:blur(4px) }
    to  { opacity:1; transform:none; filter:blur(0) }
  }
  main{ animation: admond-page-in .55s cubic-bezier(.32,.72,0,1) both }
}

/* ===== Apple-style scroll reveal ===== */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .9s cubic-bezier(.32,.72,0,1), transform .9s cubic-bezier(.32,.72,0,1); will-change:opacity,transform }
.reveal.in{ opacity:1; transform:none }
.reveal-delay-1{ transition-delay:.06s }
.reveal-delay-2{ transition-delay:.12s }
.reveal-delay-3{ transition-delay:.18s }
.reveal-delay-4{ transition-delay:.24s }

@media (prefers-reduced-motion: reduce){
  ::view-transition-old(root),::view-transition-new(root){animation-duration:1ms!important;animation-name:none!important}
  main{animation:none!important}
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
}

:root{
  --bg:#0A0726;
  --bg-2:#0E0930;
  --surface:#160B3F;
  --surface-2:#1C1148;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);
  --ink:#FFFFFF;
  --muted:#A39FCD;
  --muted-2:#7C7AA9;
  --accent:#FF3DC4;
  --accent-2:#7C5CFF;
  --accent-3:#5BD2FF;
  --accent-4:#FFD23D;
  --light:#EFEAFE;
  --max:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:'Inter',ui-sans-serif,system-ui,sans-serif;-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.55}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 28px}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

body::before{content:"";position:fixed;inset:-20% -10% auto auto;width:70vw;height:70vh;background:radial-gradient(closest-side, rgba(124,92,255,.35), transparent 70%);filter:blur(40px);z-index:0;pointer-events:none}
body::after{content:"";position:fixed;inset:auto auto -30% -10%;width:70vw;height:60vh;background:radial-gradient(closest-side, rgba(255,61,196,.22), transparent 70%);filter:blur(40px);z-index:0;pointer-events:none}
main, header, footer{position:relative;z-index:1}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;border-radius:99px;font-weight:500;font-size:14px;border:1px solid transparent;transition:transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease;cursor:pointer}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:#fff;color:#0A0726}
.btn-primary:hover{background:#f1ecff}
.btn-accent{background:var(--accent);color:#fff;box-shadow:0 8px 30px rgba(255,61,196,.35)}
.btn-accent:hover{background:#ff2bbb}
.btn-ghost{border-color:var(--line-2);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.3)}
.btn .arrow{display:inline-block;transition:transform .25s ease}
.btn:hover .arrow{transform:translateX(3px)}
.icon-btn{width:44px;height:44px;border-radius:99px;display:inline-flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;flex-shrink:0;transition:transform .25s ease, background .25s ease}
.icon-btn:hover{transform:translateX(3px);background:#ff2bbb}

.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.eyebrow::before{content:"";width:8px;height:8px;border-radius:99px;background:var(--accent);box-shadow:0 0 0 4px rgba(255,61,196,.18)}

/* ===== FUNKY HEADER ===== */
header.nav{position:sticky;top:0;z-index:50;padding-top:0}

.marquee{
  background:linear-gradient(90deg,#FF3DC4 0%,#7C5CFF 35%,#5BD2FF 70%,#FFD23D 100%);
  color:#0A0726;font-weight:700;font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  overflow:hidden;border-bottom:1px solid rgba(0,0,0,.25);
}
.marquee-track{display:flex;gap:32px;white-space:nowrap;padding:8px 0;animation:marquee 30s linear infinite;width:max-content}
.marquee-track span{display:inline-flex;align-items:center;gap:32px}
.marquee-track .star{display:inline-block;color:#0A0726;font-size:14px;transform:translateY(-1px)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.nav-wrap{padding:14px 0;background:transparent;position:relative}
.nav-wrap::before{content:"";position:absolute;inset:0;backdrop-filter:saturate(160%) blur(14px);background:rgba(10,7,38,.55);border-bottom:1px solid var(--line);z-index:-1}
.nav-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:8px 8px 8px 22px;border-radius:99px;background:linear-gradient(140deg, rgba(124,92,255,.22), rgba(255,61,196,.12) 60%, rgba(91,210,255,.18));border:1px solid var(--line-2);box-shadow:0 12px 40px rgba(124,92,255,.18), inset 0 1px 0 rgba(255,255,255,.08)}

.logo{display:inline-flex;align-items:center;gap:8px;font-family:'Inter',sans-serif;font-weight:800;font-size:20px;letter-spacing:-.04em;color:#fff;position:relative}
.logo-img{height:22px;width:auto;display:block}
.logo-img-foot{height:26px}
.logo .chrome-dot{width:14px;height:14px;border-radius:50%;background:conic-gradient(from 220deg,#5BD2FF,#7C5CFF,#FF3DC4,#FFD23D,#5BD2FF);box-shadow:0 0 0 3px rgba(255,61,196,.18), 0 0 18px rgba(255,61,196,.55);animation:spin 6s linear infinite;flex-shrink:0}
.logo .bracket{color:var(--muted);font-weight:400;opacity:.6}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}

.nav-links{display:flex;gap:6px;align-items:center;background:rgba(10,7,38,.4);border-radius:99px;padding:6px;border:1px solid var(--line)}
.nav-links a{font-size:13px;font-weight:500;color:#dad6f5;padding:8px 14px;border-radius:99px;position:relative;transition:color .2s ease, background .2s ease}
.nav-links a:hover{color:#fff;background:rgba(255,255,255,.08)}
.nav-links a.active{background:#fff;color:#0A0726}

.hamburger{display:none;width:44px;height:44px;border-radius:99px;background:rgba(10,7,38,.55);border:1px solid var(--line-2);align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .25s ease}
.hamburger:hover{background:rgba(10,7,38,.8)}
.hamburger .bars{display:flex;flex-direction:column;gap:5px;width:18px}
.hamburger .bars span{display:block;height:2px;background:#fff;border-radius:2px;transition:transform .3s ease, opacity .25s ease, width .3s ease}
.hamburger .bars span:nth-child(2){width:12px;align-self:flex-end}
.hamburger.open .bars span:nth-child(1){transform:translateY(7px) rotate(45deg);width:18px}
.hamburger.open .bars span:nth-child(2){opacity:0}
.hamburger.open .bars span:nth-child(3){transform:translateY(-7px) rotate(-45deg);width:18px}

/* Mobile menu — slide in/out reversibly. Visibility is non-animatable, so we
   delay its flip until AFTER the transform animation on close. On open we
   override the delay to 0s so the menu becomes visible immediately, then the
   transform animates it in. */
.mobile-menu{position:fixed;inset:0;z-index:60;background:radial-gradient(120% 100% at 0% 0%, rgba(124,92,255,.45), transparent 55%),radial-gradient(120% 110% at 100% 100%, rgba(255,61,196,.35), transparent 55%),linear-gradient(160deg,#120832,#070418);padding:96px 28px 40px;transform:translateX(100%);transition:transform .35s cubic-bezier(.65,0,.35,1), visibility 0s linear .35s;overflow-y:auto;visibility:hidden}
.mobile-menu.open{transform:translateX(0);visibility:visible;transition:transform .35s cubic-bezier(.65,0,.35,1), visibility 0s linear 0s}
.menu-close{position:absolute;top:24px;right:24px;width:48px;height:48px;border-radius:99px;background:rgba(255,255,255,.08);border:1px solid var(--line-2);color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease, transform .25s ease;font-size:18px;line-height:1;-webkit-tap-highlight-color:transparent}
.menu-close:hover{background:var(--accent);border-color:var(--accent);transform:rotate(90deg)}
.menu-close svg{width:18px;height:18px;display:block}
.mobile-menu .m-links{display:flex;flex-direction:column;gap:0;margin:8px 0 28px;counter-reset:mlink;border-top:1px solid rgba(255,255,255,.08)}
.mobile-menu .m-links a{display:flex;align-items:center;justify-content:space-between;padding:22px 4px;border:0;background:transparent;border-radius:0;border-bottom:1px solid rgba(255,255,255,.08);font-family:'Inter',sans-serif;font-weight:600;font-size:22px;letter-spacing:-.02em;color:#fff;transition:background .2s ease, transform .2s ease}
.mobile-menu .m-links a{position:relative;font-size:28px;font-weight:600;letter-spacing:-.02em;color:#fff;line-height:1.1;transition:color .25s ease, padding .25s ease}
.mobile-menu .m-links a::before{
  counter-increment:mlink;content:counter(mlink, decimal-leading-zero);
  position:absolute;left:0;top:50%;transform:translateY(-50%);
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;
  color:rgba(255,255,255,.35);font-weight:500;
  transition:color .25s ease, transform .25s ease;
}
.mobile-menu .m-links a{padding-left:38px}
.mobile-menu .m-links a::after{
  content:"→";color:rgba(255,255,255,.4);font-weight:300;font-size:22px;
  transition:transform .3s cubic-bezier(.32,.72,0,1), color .25s ease;
}
.mobile-menu .m-links a:hover,.mobile-menu .m-links a:active{color:#fff;background:transparent;transform:none;padding-left:46px}
.mobile-menu .m-links a:hover::before,.mobile-menu .m-links a:active::before{color:#FF3DC4;transform:translateY(-50%) translateX(4px)}
.mobile-menu .m-links a:hover::after,.mobile-menu .m-links a:active::after{color:#FF3DC4;transform:translateX(6px)}
.mobile-menu .m-links a.active{background:transparent;border-color:rgba(255,255,255,.08);color:#fff}
.mobile-menu .m-links a.active::before{color:#FF3DC4}
.mobile-menu .m-links a.active::after{color:#FF3DC4;transform:none}
.mobile-menu .m-cta{display:flex;align-items:center;justify-content:center;gap:10px;padding:18px 22px;border-radius:99px;background:var(--accent);color:#fff;font-weight:600;font-size:15px;box-shadow:0 8px 24px rgba(255,61,196,.4)}
.mobile-menu .m-meta{margin-top:32px;padding-top:24px;border-top:1px solid var(--line-2);color:var(--muted);font-size:13px;line-height:1.7}
.mobile-menu .m-meta strong{color:#fff;display:block;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:4px;font-weight:600}
body.menu-open{overflow:hidden}

.nav-cta{display:inline-flex;align-items:center;gap:10px;padding:10px 8px 10px 20px;border-radius:99px;background:var(--accent);color:#fff;font-weight:600;font-size:13px;letter-spacing:.01em;box-shadow:0 8px 24px rgba(255,61,196,.4), inset 0 1px 0 rgba(255,255,255,.3);transition:transform .25s ease, box-shadow .25s ease}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 12px 32px rgba(255,61,196,.55)}
.nav-cta .arrow-circle{width:32px;height:32px;border-radius:99px;background:#fff;color:#FF3DC4;display:inline-flex;align-items:center;justify-content:center;font-size:14px;overflow:hidden;position:relative}
.nav-cta .arrow-circle::before,.nav-cta .arrow-circle::after{content:"→";position:absolute;font-weight:700;animation:arrow-loop 2.2s ease-in-out infinite}
.nav-cta .arrow-circle::after{animation-delay:1.1s}
@keyframes arrow-loop{0%{transform:translateX(-110%);opacity:0}25%{transform:translateX(0);opacity:1}65%{transform:translateX(0);opacity:1}100%{transform:translateX(110%);opacity:0}}

@media (max-width:1080px){
  .nav-links{display:none}
  .nav-cta{display:none}
  .nav-f .nav-links{display:none}
  .nav-f .nav-cta{display:none}
  .hamburger{display:inline-flex}
  .nav-row{padding:8px 14px}
}

/* ===== Option F header (editorial bold inside floating pill) ===== */
.nav-f .vf-rail{height:3px;background:linear-gradient(90deg,#FF3DC4,#7C5CFF,#5BD2FF,#FFD23D)}
.nav-f .nav-wrap{padding:18px 0 22px}
.nav-f .nav-wrap::before{display:none}
.nav-f .nav-row{
  display:flex;align-items:center;gap:28px;
  padding:14px 14px 14px 28px;
  background:rgba(20,12,60,.6);
  backdrop-filter:saturate(160%) blur(20px);
  -webkit-backdrop-filter:saturate(160%) blur(20px);
  border:1px solid rgba(255,255,255,.12);
  border-radius:99px;
  box-shadow:0 20px 60px rgba(10,7,38,.6), inset 0 1px 0 rgba(255,255,255,.06);
  justify-content:space-between;
}
.nav-f .logo{flex-shrink:0}
.nav-f .logo-img{height:28px}
.nav-f .nav-links{flex:1;justify-content:center;display:flex;align-items:center;gap:28px;background:transparent;border:0;padding:0}
.nav-f .nav-links a{
  font-family:'Inter',sans-serif;font-size:11px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:#dad6f5;
  position:relative;padding:6px 0;transition:color .2s ease;
}
.nav-f .nav-links a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:#FF3DC4;
  transform:scaleX(0);transform-origin:left;transition:transform .25s ease;
}
.nav-f .nav-links a:hover{color:#fff;background:transparent}
.nav-f .nav-links a:hover::after{transform:scaleX(1)}
.nav-f .nav-links a.active{background:transparent;color:#fff}
.nav-f .nav-links a.active::after{transform:scaleX(1)}

/* Remove circular frame around language flag */
.nav-f .lang-switch.in-nav button{border:0 !important;background:transparent !important;width:auto !important;height:auto !important;padding:6px !important}
.nav-f .lang-switch.in-nav button:hover{background:transparent !important;border-color:transparent !important}
.nav-f .lang-switch.in-nav .flag{width:22px;height:16px}
.nav-f .lang-switch.in-nav{width:auto;height:auto}
.nav-f .nav-cta{
  display:inline-flex;align-items:center;gap:10px;padding:12px 22px;
  border:1.5px solid #FF3DC4;border-radius:0;background:transparent;color:#fff;
  font-weight:600;font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  transition:background .2s ease;
}
.nav-f .nav-cta:hover{background:#FF3DC4}
.nav-f .nav-cta .arrow-circle{display:none}
.nav-f .nav-cta::after{content:"→";font-size:13px;letter-spacing:0}

/* Mobile header — slim Apple-style condensed (option 07b) */
@media (max-width:1080px){
  /* Hide the gradient rail and GMP strip on mobile — keep the header minimal */
  .nav-f .vf-rail{display:none}
  .nav-f .gmp-strip{display:none}
  /* Hide desktop nav + CTA on mobile (override the .nav-f overrides above) */
  .nav-f .nav-links{display:none}
  .nav-f .nav-cta{display:none}
  .nav-f .lang-switch.in-nav{display:none}
  .hamburger{display:inline-flex}

  .nav-f .nav-wrap{padding:0}
  .nav-f .nav-wrap::before{display:none}

  /* Container has no horizontal padding so the glass bar spans full bleed */
  header.nav .container{padding:0}

  .nav-f .nav-row{
    padding:10px 16px;
    border-radius:0;
    background:rgba(10,7,38,.55);
    backdrop-filter:blur(20px) saturate(180%);
    -webkit-backdrop-filter:blur(20px) saturate(180%);
    border:0;
    border-bottom:.5px solid rgba(255,255,255,.06);
    box-shadow:none;
    gap:10px;
    justify-content:space-between;
    transition:background .25s ease, border-color .25s ease, box-shadow .25s ease;
  }

  /* Apple-style: more opaque/solid as the user scrolls */
  header.nav.scrolled .nav-row{
    background:rgba(10,7,38,.85);
    border-bottom-color:rgba(255,255,255,.12);
    box-shadow:0 1px 18px rgba(0,0,0,.28);
  }

  .nav-f .logo-img{height:30px}

  .hamburger{
    width:36px;height:36px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.1);
    border-radius:99px;
  }
  .hamburger:hover{background:rgba(255,255,255,.12)}
}
@media (max-width:560px){
  .nav-f .nav-row{padding:9px 14px}
  .nav-f .logo-img{height:26px}
  .hamburger{width:34px;height:34px}
  .mobile-menu{padding:80px 20px 32px}
  .mobile-menu .m-links a{padding:20px 0 20px 34px;font-size:26px}
  .mobile-menu .m-links a:hover,.mobile-menu .m-links a:active{padding-left:42px}
  .menu-close{top:14px;right:14px;width:42px;height:42px}
}

/* ===== Sections ===== */
section{padding:96px 0}
.sec-head{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:end;margin-bottom:48px}
@media(max-width:880px){.sec-head{grid-template-columns:1fr;gap:24px}}
.sec-head h2{font-weight:700;font-size:clamp(34px,4.6vw,60px);line-height:1.02;letter-spacing:-.025em;max-width:16ch}
.sec-head h2 .grad{background:linear-gradient(92deg,#fff 30%,#C9B6FF 55%,#FF8CE2);-webkit-background-clip:text;background-clip:text;color:transparent}
.sec-head p{color:var(--muted);font-size:16px;max-width:48ch}
.sec-head.center{grid-template-columns:1fr;text-align:center;justify-items:center}
.sec-head.center h2{max-width:24ch}

/* ===== Subpage hero ===== */
.sub-hero{padding:72px 0 56px;position:relative}
.sub-hero h1{font-weight:700;font-size:clamp(44px,7vw,96px);line-height:.98;letter-spacing:-.035em;max-width:14ch;margin-top:24px}
.sub-hero h1 .grad{background:linear-gradient(92deg,#fff 30%,#C9B6FF 55%,#FF8CE2 80%,#5BD2FF);-webkit-background-clip:text;background-clip:text;color:transparent}
.sub-hero p.lead{margin-top:22px;color:var(--muted);font-size:17px;max-width:62ch}
.sub-hero .actions{margin-top:30px;display:flex;gap:12px;flex-wrap:wrap}
.sub-hero-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:48px;align-items:center}
@media(max-width:880px){.sub-hero-grid{grid-template-columns:1fr}}
.hero-illu{aspect-ratio:1.1/1;border-radius:24px;background:radial-gradient(120% 100% at 0% 0%, rgba(91,210,255,.35), transparent 55%),radial-gradient(120% 110% at 100% 100%, rgba(255,61,196,.45), transparent 55%),linear-gradient(160deg,#1B1148,#0E0930);position:relative;overflow:hidden;border:1px solid var(--line-2)}
.hero-illu .blob{position:absolute;border-radius:50%;filter:blur(2px);mix-blend-mode:screen}
.hero-illu .blob.a{left:-40px;top:-40px;width:220px;height:220px;background:conic-gradient(from 90deg,#5BD2FF,#7C5CFF,#FF3DC4);opacity:.7}
.hero-illu .blob.b{right:-50px;bottom:-50px;width:240px;height:240px;background:conic-gradient(from 220deg,#FFD23D,#FF3DC4,#5BD2FF);opacity:.7}
.hero-illu .blob.c{right:30%;top:40%;width:120px;height:120px;background:conic-gradient(from 40deg,#FF3DC4,#5BD2FF,#FFD23D);opacity:.85}
.hero-illu .badge{position:absolute;top:24px;left:24px;display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:99px;background:rgba(10,7,38,.65);border:1px solid var(--line-2);color:#fff;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.hero-illu .badge .dot{width:8px;height:8px;border-radius:99px;background:#5BFF8A}

/* ===== Sectors strip ===== */
.sectors{margin:24px 0 0;padding:24px 28px;border-radius:18px;background:linear-gradient(140deg, rgba(124,92,255,.18), rgba(20,9,58,.6));border:1px solid var(--line-2);display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:center}
@media(max-width:880px){.sectors{grid-template-columns:1fr}}
.sectors .label{display:flex;align-items:center;gap:10px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);min-width:160px}
.sectors .label .icon{width:28px;height:28px;border-radius:99px;background:rgba(255,255,255,.08);border:1px solid var(--line-2);display:flex;align-items:center;justify-content:center;color:#fff}
.sectors .grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px 16px;font-size:13px;color:#dad6f5}
@media(max-width:880px){.sectors .grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.sectors .grid{grid-template-columns:repeat(2,1fr)}}
.sectors .grid span{padding:4px 0}

/* ===== Service grid (icon-led, 3-col) ===== */
.svc-icon-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:980px){.svc-icon-grid{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.svc-icon-grid{grid-template-columns:1fr}}
.svc-icon{background:rgba(255,255,255,.04);border:1px solid var(--line-2);border-radius:20px;padding:28px;display:flex;flex-direction:column;gap:14px;transition:transform .25s ease, border-color .25s ease;position:relative;overflow:hidden}
.svc-icon:hover{transform:translateY(-3px);border-color:rgba(255,255,255,.28)}
.svc-icon .dot{width:38px;height:38px;border-radius:50%;background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.7), transparent 50%),conic-gradient(from 220deg,#5BD2FF,#7C5CFF,#FF3DC4,#FFD23D,#5BD2FF);position:relative;flex-shrink:0}
.svc-icon.b .dot{background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.7), transparent 50%),conic-gradient(from 90deg,#7C5CFF,#FF3DC4,#FFD23D,#5BD2FF,#7C5CFF)}
.svc-icon.c .dot{background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.7), transparent 50%),conic-gradient(from 40deg,#FF3DC4,#7C5CFF,#5BD2FF,#FFD23D,#FF3DC4)}
.svc-icon h3{font-weight:600;font-size:20px;letter-spacing:-.01em}
.svc-icon p{color:var(--muted);font-size:14px;line-height:1.55}

/* ===== Full Performance Coverage band ===== */
.fpc{border-radius:32px;padding:80px 56px;color:#fff;position:relative;overflow:hidden;background:radial-gradient(120% 100% at 0% 0%, rgba(124,92,255,.35), transparent 55%),radial-gradient(120% 110% at 100% 100%, rgba(255,61,196,.22), transparent 55%),linear-gradient(160deg,#120832,#070418)}
.fpc h2{font-weight:700;font-size:clamp(34px,4.6vw,60px);line-height:1.02;letter-spacing:-.025em;text-align:center}
.fpc .eyebrow{justify-content:center;display:inline-flex}
.fpc .head{text-align:center;max-width:780px;margin:0 auto 48px}
.fpc-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:48px;align-items:center}
@media(max-width:880px){.fpc-grid{grid-template-columns:1fr;gap:32px}}
.fpc-col{display:flex;flex-direction:column;gap:48px}
.fpc-step{display:flex;gap:18px;align-items:flex-start}
.fpc-step .ic{width:54px;height:54px;border-radius:14px;background:rgba(255,255,255,.06);border:1px solid var(--line-2);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:24px}
.fpc-step h4{font-weight:600;font-size:18px;letter-spacing:-.005em}
.fpc-step p{color:var(--muted);font-size:13px;margin-top:6px;max-width:34ch}
.fpc-center{aspect-ratio:1/1;width:240px;border-radius:50%;border:1px solid var(--line-2);background:radial-gradient(circle at 50% 50%, rgba(255,61,196,.25), transparent 65%);display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;font-weight:600;letter-spacing:-.01em;line-height:1.3;justify-self:center;position:relative}
.fpc-center::before{content:"";position:absolute;inset:-8px;border-radius:50%;border:1px dashed rgba(255,61,196,.3);animation:spin 30s linear infinite}
.fpc-center span{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:block;margin-top:6px}

/* ===== Toolstack ===== */
.tools-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
@media(max-width:980px){.tools-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:560px){.tools-grid{grid-template-columns:repeat(3,1fr)}}
.tool{background:rgba(255,255,255,.04);border:1px solid var(--line-2);border-radius:18px;padding:22px 14px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px;transition:transform .2s ease, border-color .2s ease}
.tool:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.28)}
.tool .ic{width:42px;height:42px;border-radius:10px;background:linear-gradient(140deg,#7C5CFF,#FF3DC4);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px}
.tool.b .ic{background:linear-gradient(140deg,#5BD2FF,#7C5CFF)}
.tool.c .ic{background:linear-gradient(140deg,#FFD23D,#FF3DC4)}
.tool.d .ic{background:linear-gradient(140deg,#FF3DC4,#5BD2FF)}
.tool .name{font-size:13px;font-weight:500;color:#dad6f5}

/* ===== LIT methodology ===== */
.lit{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
@media(max-width:880px){.lit{grid-template-columns:1fr;gap:32px}}
.lit-dash{aspect-ratio:1.4/1;border-radius:20px;background:linear-gradient(160deg,#1B1148,#0E0930);border:1px solid var(--line-2);position:relative;overflow:hidden;padding:18px;display:flex;flex-direction:column;gap:10px}
.lit-dash::before{content:"";position:absolute;inset:auto -20% -30% 30%;width:80%;height:90%;border-radius:50%;background:radial-gradient(closest-side, rgba(255,61,196,.3), transparent 70%);filter:blur(4px)}
.lit-dash .row{display:flex;gap:8px;align-items:center}
.lit-dash .chip{padding:4px 10px;background:rgba(255,255,255,.06);border:1px solid var(--line-2);border-radius:6px;font-family:'JetBrains Mono',monospace;font-size:10px;color:#dad6f5;letter-spacing:.06em}
.lit-dash .chip.act{background:var(--accent);color:#fff;border-color:var(--accent)}
.lit-dash .bars{display:grid;grid-template-columns:repeat(20,1fr);gap:3px;align-items:flex-end;flex:1;margin-top:8px}
.lit-dash .bars i{display:block;background:linear-gradient(180deg,#FF3DC4,#7C5CFF);border-radius:2px;height:var(--h,40%);min-height:8px}
.lit-dash .legend{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.lit-dash .legend div{padding:6px 0;border-top:1px solid var(--line-2)}
.lit-dash .legend strong{display:block;color:#fff;font-size:14px;margin-top:2px;font-family:'Inter',sans-serif;font-weight:700;letter-spacing:-.01em;text-transform:none}
.lit-list{display:flex;flex-direction:column;gap:24px}
.lit-item{display:grid;grid-template-columns:auto 1fr;gap:16px;padding:20px 0;border-top:1px solid var(--line)}
.lit-item:first-child{border-top:0}
.lit-item .num{font-family:'Inter',sans-serif;font-weight:700;font-size:42px;letter-spacing:-.04em;color:#fff;line-height:1;background:linear-gradient(180deg,#FF3DC4,#7C5CFF);-webkit-background-clip:text;background-clip:text;color:transparent;width:60px}
.lit-item h4{font-weight:600;font-size:18px;letter-spacing:-.005em}
.lit-item p{color:var(--muted);font-size:14px;margin-top:6px;max-width:44ch}

/* ===== Channel cards (Paid Media) ===== */
.channels{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:8px}
@media(max-width:880px){.channels{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.channels{grid-template-columns:1fr}}
.channel{background:rgba(255,255,255,.04);border:1px solid var(--line-2);border-radius:18px;padding:20px;display:flex;flex-direction:column;gap:12px;transition:transform .2s ease, border-color .2s ease}
.channel:hover{transform:translateY(-3px);border-color:rgba(255,255,255,.28)}
.channel .preview{aspect-ratio:16/10;border-radius:12px;background:linear-gradient(160deg,#1B1148,#0E0930);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.channel .preview .pill{padding:6px 12px;border-radius:99px;background:rgba(255,255,255,.08);border:1px solid var(--line-2);font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#fff}
.channel .preview .glow{position:absolute;inset:-20% -10% -50% -10%;background:conic-gradient(from 220deg,#5BD2FF,#7C5CFF,#FF3DC4,#FFD23D,#5BD2FF);filter:blur(40px);opacity:.55;mix-blend-mode:screen}
.channel.meta .glow{background:radial-gradient(circle at 30% 50%, #5BD2FF, transparent 60%),radial-gradient(circle at 70% 80%, #7C5CFF, transparent 60%)}
.channel.tt .glow{background:radial-gradient(circle at 50% 50%, #FF3DC4, transparent 50%),radial-gradient(circle at 30% 30%, #5BD2FF, transparent 50%)}
.channel.li .glow{background:radial-gradient(circle at 50% 50%, #5BD2FF, transparent 60%)}
.channel.x .glow{background:radial-gradient(circle at 50% 50%, #fff, transparent 60%);opacity:.25}
.channel h4{font-weight:600;font-size:17px;letter-spacing:-.01em;margin-top:6px}
.channel .more{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}

/* Tab nav (centered pill) */
.tabs{margin:0 auto 40px;display:inline-flex;gap:6px;background:rgba(255,255,255,.06);border:1px solid var(--line-2);border-radius:99px;padding:6px}
.tab{padding:10px 18px;border-radius:99px;color:#dad6f5;font-size:13px;font-weight:500;cursor:pointer;border:none;background:transparent}
.tab.active{background:var(--accent);color:#fff;box-shadow:0 6px 20px rgba(255,61,196,.35)}

/* ===== Real-Time Dashboards (Analytics) ===== */
.rtd{border-radius:32px;padding:64px 56px;color:#fff;position:relative;overflow:hidden;background:radial-gradient(120% 100% at 100% 0%, rgba(91,210,255,.3), transparent 55%),radial-gradient(120% 110% at 0% 100%, rgba(255,61,196,.22), transparent 55%),linear-gradient(160deg,#120832,#070418)}
.rtd-grid{display:grid;grid-template-columns:.7fr 1.3fr;gap:48px;align-items:center}
@media(max-width:880px){.rtd-grid{grid-template-columns:1fr;gap:32px}}
.rtd h2{font-weight:700;font-size:clamp(28px,3.6vw,44px);line-height:1.04;letter-spacing:-.02em}
.rtd ul{margin-top:24px;display:flex;flex-direction:column;gap:8px;list-style:none}
.rtd ul li{display:flex;align-items:center;gap:12px;padding:14px 18px;background:rgba(255,255,255,.04);border:1px solid var(--line-2);border-radius:14px;font-size:14px}
.rtd ul li::before{content:"";width:10px;height:10px;border-radius:50%;background:linear-gradient(140deg,#FF3DC4,#7C5CFF);flex-shrink:0}
.rtd-screen{aspect-ratio:16/10;border-radius:14px;background:linear-gradient(160deg,#0F0828,#070418);border:1px solid var(--line-2);overflow:hidden;display:grid;grid-template-columns:120px 1fr;position:relative}
.rtd-screen .side{background:rgba(255,255,255,.03);padding:14px;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:6px}
.rtd-screen .side .nav-i{padding:8px 10px;border-radius:8px;font-size:11px;color:#dad6f5;font-family:'JetBrains Mono',monospace;letter-spacing:.06em}
.rtd-screen .side .nav-i.act{background:rgba(255,61,196,.18);color:#fff}
.rtd-screen .body{padding:14px;display:flex;flex-direction:column;gap:10px;overflow:hidden}
.rtd-screen .kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.rtd-screen .kpi{padding:10px;background:rgba(255,255,255,.04);border:1px solid var(--line-2);border-radius:8px;font-size:11px}
.rtd-screen .kpi b{display:block;font-size:18px;font-weight:700;letter-spacing:-.01em;margin-top:2px}
.rtd-screen .kpi .delta{color:#5BFF8A;font-size:10px}
.rtd-screen .chart{flex:1;background:linear-gradient(180deg, transparent 30%, rgba(255,61,196,.15)),repeating-linear-gradient(0deg, var(--line) 0 1px, transparent 1px 30px);border:1px solid var(--line-2);border-radius:8px;position:relative;overflow:hidden}
.rtd-screen .chart::after{content:"";position:absolute;inset:auto 0 20% 0;height:60%;background:radial-gradient(closest-side at 30% 100%, rgba(255,61,196,.5), transparent 70%),radial-gradient(closest-side at 70% 100%, rgba(91,210,255,.5), transparent 70%)}
.rtd-screen .chart::before{content:"";position:absolute;inset:auto 0 25% 0;height:2px;background:linear-gradient(90deg,#FF3DC4,#5BD2FF);clip-path:polygon(0% 80%, 12% 60%, 22% 70%, 33% 40%, 45% 55%, 56% 30%, 68% 50%, 80% 25%, 90% 35%, 100% 10%)}
.rtd-screen .row2{display:grid;grid-template-columns:1fr 1fr;gap:8px;height:80px}
.rtd-screen .row2 div{background:rgba(255,255,255,.04);border:1px solid var(--line-2);border-radius:8px}

/* ===== Light section / Founder ===== */
.light{background:var(--light);color:#15123A;border-radius:32px;padding:64px 56px;position:relative;overflow:hidden}
.light h2{color:#15123A;font-weight:700;font-size:clamp(32px,4.4vw,56px);line-height:1.02;letter-spacing:-.025em}
.light h2 em{font-style:italic;color:#7C5CFF}
.light p{color:#5b5790}
.light .eyebrow{color:#6c5ce7}
.light .eyebrow::before{background:#7C5CFF;box-shadow:0 0 0 4px rgba(124,92,255,.18)}
.founder-card{margin-top:40px;background:#fff;border:1px solid #E5DEF8;border-radius:22px;padding:32px;display:grid;grid-template-columns:auto 1fr;gap:28px;align-items:start;box-shadow:0 8px 30px rgba(86,52,200,.08)}
@media(max-width:680px){.founder-card{grid-template-columns:1fr}}
.avatar{width:96px;height:96px;border-radius:99px;background:linear-gradient(160deg,#7C5CFF,#FF3DC4);position:relative;overflow:hidden;flex-shrink:0}
.avatar svg{position:absolute;inset:0;margin:auto;width:60%;opacity:.92}
.founder-card .who{font-weight:700;font-size:20px;letter-spacing:-.01em}
.founder-card .role{color:#7C5CFF;font-weight:600;font-size:13px;letter-spacing:.04em;margin-top:2px;font-family:'JetBrains Mono',monospace;text-transform:uppercase}
.founder-card p{color:#3d3970;font-size:15px;line-height:1.6;margin-top:14px;max-width:62ch}
.logo-row{margin-top:24px;display:flex;flex-wrap:wrap;gap:28px;align-items:center}
.logo-row .lg{font-weight:700;font-size:16px;letter-spacing:-.01em;color:#5b5790;opacity:.8}
.logo-row .lg.bold{color:#15123A;opacity:1}

/* ===== Results row (homepage) ===== */
.results-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:32px}
@media(max-width:880px){.results-row{grid-template-columns:1fr}}
.result-card{
  background:#fff;border:1px solid #E5DEF8;border-radius:22px;padding:32px 28px;
  display:flex;flex-direction:column;gap:12px;color:#15123A;
  transition:transform .25s ease, box-shadow .25s ease;text-decoration:none;
  position:relative;overflow:hidden;min-height:300px;
}
.result-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(86,52,200,.14)}
.result-card::before{
  content:"";position:absolute;inset:auto -10% -30% auto;width:60%;height:80%;border-radius:50%;
  background:radial-gradient(closest-side, rgba(255,61,196,.1), transparent 70%);
  pointer-events:none;
}
.result-card .meta{display:flex;justify-content:space-between;align-items:center;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;gap:8px;flex-wrap:wrap}
.result-card .meta .brand{color:#7C5CFF}
.result-card .meta .cat{color:#5b5790;font-weight:500}
.result-card .stat-big{
  font-weight:700;font-size:clamp(48px,5.4vw,72px);letter-spacing:-.04em;line-height:.95;
  background:linear-gradient(140deg,#FF3DC4,#7C5CFF);-webkit-background-clip:text;background-clip:text;color:transparent;
  margin-top:6px;
}
.result-card .stat-big small{display:block;font-size:14px;color:#5b5790;font-weight:500;letter-spacing:0;margin-top:8px;background:none;-webkit-text-fill-color:#5b5790}
.result-card .stat-sub{font-weight:600;font-size:18px;color:#15123A;letter-spacing:-.01em;margin-top:4px}
.result-card .stat-sub em{font-style:normal;color:#7C5CFF}
.result-card p{color:#5b5790;font-size:14px;line-height:1.55;margin-top:auto;max-width:36ch}
.result-card .more{display:inline-flex;align-items:center;gap:6px;color:#5b3df5;font-weight:600;font-size:13px;margin-top:6px}
.result-card .more .arr{transition:transform .25s ease}
.result-card:hover .more .arr{transform:translateX(3px)}

.diff{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:32px}
@media(max-width:380px){.diff{grid-template-columns:1fr}}
.diff-card{background:#fff;border:1px solid #E5DEF8;border-radius:18px;padding:26px}
.diff-card .icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(140deg,#7C5CFF,#FF3DC4);display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;margin-bottom:16px}
.diff-card h3{font-weight:600;font-size:18px;letter-spacing:-.005em;color:#15123A}
.diff-card p{color:#5b5790;font-size:14px;margin-top:8px}
@media (max-width:720px){
  .diff{gap:10px;margin-top:48px;grid-template-columns:1fr 1fr}
  .diff-card{padding:14px 12px;border-radius:12px;display:flex;flex-direction:column}
  .diff-card .icon{width:24px;height:24px;border-radius:7px;font-size:13px;margin-bottom:8px}
  .diff-card h3{font-size:14.5px;line-height:1.2;letter-spacing:-.005em}
  .diff-card p{font-size:12.5px;line-height:1.45;margin-top:6px;
    display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden;
  }
}
@media (max-width:560px){
  .diff{grid-template-columns:1fr;gap:10px;margin-top:40px}
  .diff-card{padding:14px}
  .diff-card p{-webkit-line-clamp:unset;display:block;overflow:visible}
}

/* ===== Testimonial ===== */
.testi{border-radius:32px;padding:80px 56px;position:relative;overflow:hidden;color:#fff;background:radial-gradient(120% 100% at 0% 0%, rgba(124,92,255,.4), transparent 55%),radial-gradient(120% 110% at 100% 100%, rgba(255,61,196,.22), transparent 55%),linear-gradient(160deg,#140934,#070418)}
.testi-grid{display:grid;grid-template-columns:.9fr 1.6fr;gap:48px;align-items:center}
@media(max-width:880px){.testi-grid{grid-template-columns:1fr;gap:32px}}
.testi .who-block{display:flex;align-items:center;gap:18px}
.testi .avatar{background:#1a1538}
.testi .avatar img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:99px;display:block;opacity:0;transition:opacity .5s ease}
.testi .avatar img.active{opacity:1}
.testi .name,.testi .role,.testi .quote{transition:opacity .4s ease}
.testi.fading .name,.testi.fading .role,.testi.fading .quote{opacity:0}
.testi-dots{display:flex;gap:8px;margin-top:14px}
.testi-dots button{width:7px;height:7px;border-radius:99px;border:0;background:rgba(255,255,255,.25);padding:0;cursor:pointer;transition:width .25s ease,background .25s ease}
.testi-dots button[aria-current="true"]{width:22px;background:#fff}
.testi .name{font-weight:700;font-size:18px}
.testi .role{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:4px}
.testi .quote{font-size:clamp(20px,2.4vw,28px);line-height:1.4;letter-spacing:-.01em;max-width:60ch;font-weight:500}
.testi .quote::before{content:"\201C";font-size:1.4em;color:var(--accent);margin-right:.05em;display:inline}
.testi .nav-arrows{display:inline-flex;gap:8px;margin-top:20px}
.testi .arr{width:42px;height:42px;border-radius:99px;border:1px solid var(--line-2);display:flex;align-items:center;justify-content:center;color:#fff;background:rgba(255,255,255,.04);cursor:pointer}
.testi .arr:hover{background:rgba(255,255,255,.1)}

/* ===== FAQ ===== */
.faq-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:start}
@media(max-width:880px){.faq-grid{grid-template-columns:1fr;gap:24px}}
.faq-illu{aspect-ratio:1.1/1;border-radius:24px;background:radial-gradient(120% 100% at 0% 0%, rgba(91,210,255,.3), transparent 55%),radial-gradient(120% 110% at 100% 100%, rgba(255,61,196,.3), transparent 55%),linear-gradient(160deg,#1B1148,#0E0930);position:relative;overflow:hidden;border:1px solid var(--line-2)}
.faq-illu .blob{position:absolute;width:200px;height:200px;border-radius:50%;filter:blur(2px);opacity:.7}
.faq-illu .blob.a{left:-40px;top:-40px;background:conic-gradient(from 90deg,#5BD2FF,#7C5CFF,#FF3DC4)}
.faq-illu .blob.b{right:-50px;bottom:-50px;background:conic-gradient(from 220deg,#FFD23D,#FF3DC4,#5BD2FF)}
.faq-illu .center-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:80px;font-weight:700;letter-spacing:-.04em;opacity:.92}
details.faq{border:1px solid var(--line-2);border-radius:16px;background:rgba(255,255,255,.03);padding:0;overflow:hidden;margin-bottom:10px}
details.faq summary{padding:20px 24px;cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:16px;font-weight:500;font-size:16px}
details.faq summary::-webkit-details-marker{display:none}
details.faq summary::after{content:"+";font-family:'JetBrains Mono',monospace;font-size:22px;color:var(--accent);font-weight:400;transition:transform .25s ease}
details.faq[open] summary::after{transform:rotate(45deg)}
details.faq .ans{padding:0 24px 22px;color:var(--muted);font-size:14px;max-width:62ch}
details.faq[open]{background:rgba(124,92,255,.08);border-color:rgba(255,61,196,.3)}

/* ===== Connect form ===== */
.connect{margin-top:48px;border-radius:32px;padding:0;color:#fff;position:relative;overflow:hidden;background:radial-gradient(120% 110% at 0% 0%, rgba(91,210,255,.45), transparent 55%),radial-gradient(120% 120% at 100% 100%, rgba(255,61,196,.55), transparent 55%),linear-gradient(120deg,#5b3df5,#8b30c9 60%,#3a1da3)}
.connect-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:0}
@media(max-width:880px){.connect-grid{grid-template-columns:1fr}}
.connect .left{padding:64px 48px;display:flex;flex-direction:column;justify-content:center;gap:18px}
.connect h2{font-weight:700;font-size:clamp(36px,5vw,64px);line-height:1.02;letter-spacing:-.025em}
.connect p{color:#e7defb;max-width:42ch}
.connect .meta{display:flex;flex-direction:column;gap:6px;font-size:14px;color:#e7defb;margin-top:10px}
.connect .meta .row{display:flex;gap:12px;align-items:flex-start}
.connect .meta .row strong{color:#fff;font-weight:600;min-width:80px}
.connect .right{padding:48px;background:rgba(10,7,38,.35);backdrop-filter:blur(8px);border-left:1px solid rgba(255,255,255,.12)}
.form{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:680px){.form{grid-template-columns:1fr}}
.form .full{grid-column:1/-1}
.input,.area{width:100%;padding:14px 16px;background:rgba(255,255,255,.95);border:1px solid rgba(255,255,255,.6);border-radius:12px;font-family:inherit;font-size:14px;color:#1a1244;outline:none}
.area{min-height:120px;resize:vertical}
.check{display:flex;gap:10px;align-items:flex-start;color:#e7defb;font-size:12px}
.check input{margin-top:3px}
.submit{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 22px;background:#0A0726;color:#fff;border:none;border-radius:99px;font-weight:600;font-size:14px;cursor:pointer;transition:transform .2s ease, background .2s ease}
.submit:hover{transform:translateY(-1px);background:#000}

/* ===== Footer ===== */
footer{padding:48px 0 40px;border-top:1px solid var(--line);margin-top:64px}
.foot{display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:40px}
@media(max-width:880px){.foot{grid-template-columns:1fr 1fr}}
.foot h5{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:16px}
.foot ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot a{font-size:14px;color:#dad6f5}
.foot a:hover{color:#fff;text-decoration:underline;text-underline-offset:3px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:48px;padding-top:24px;border-top:1px solid var(--line);color:var(--muted);font-size:13px;flex-wrap:wrap;gap:14px}
.free-pill{display:inline-flex;gap:8px;align-items:center;padding:10px 18px;border-radius:99px;background:var(--accent);color:#fff;font-weight:600;font-size:13px}

/* ===== HOMEPAGE-SPECIFIC ===== */
.hero{padding:80px 0 64px;position:relative}
.hero h1{font-weight:700;font-size:clamp(44px,7vw,104px);line-height:.98;letter-spacing:-.035em;max-width:16ch;margin-top:24px}
.hero h1 .grad{background:linear-gradient(92deg,#fff 30%,#C9B6FF 55%,#FF8CE2 80%,#5BD2FF);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{margin-top:22px;color:var(--muted);font-size:17px;max-width:62ch}
.hero .actions{margin-top:30px;display:flex;gap:12px;flex-wrap:wrap}
.pills{margin-top:28px;display:flex;gap:8px;flex-wrap:wrap}
.pill-tag{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--line-2);border-radius:99px;font-size:13px;color:#dad6f5;background:rgba(255,255,255,.03)}
.pill-tag .dot{width:6px;height:6px;border-radius:99px;background:var(--accent)}

.stat-row{margin-top:56px;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:980px){.stat-row{grid-template-columns:1fr 1fr}}
@media(max-width:380px){.stat-row{grid-template-columns:1fr}}
.stat-card{position:relative;background:linear-gradient(160deg, rgba(124,92,255,.18), rgba(20,9,58,.6));border:1px solid var(--line-2);border-radius:22px;padding:24px;min-height:200px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}
.stat-card .top{display:flex;align-items:center;gap:12px}
.stat-card .pill{width:32px;height:32px;border-radius:99px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.08);border:1px solid var(--line-2);font-size:14px}
.stat-card .who{font-family:'Inter',sans-serif;font-weight:600;font-size:14px}
.stat-card .who .sub{display:block;font-weight:400;color:var(--muted);font-size:12px;margin-top:2px}
.stat-card .x{font-weight:700;font-size:60px;letter-spacing:-.04em;line-height:1}
.stat-card .x small{font-weight:500;font-size:.45em;letter-spacing:0;color:var(--muted)}
.stat-card .label{color:var(--muted);font-size:13px;margin-top:6px}
.stat-card.feature{background:radial-gradient(120% 100% at 100% 0%, rgba(91,210,255,.25), transparent 60%),radial-gradient(120% 120% at 0% 100%, rgba(255,61,196,.25), transparent 60%),linear-gradient(160deg, rgba(124,92,255,.22), rgba(20,9,58,.65));border-color:rgba(255,255,255,.16)}
.stat-card.feature .chrome{right:-60px;bottom:-60px;width:160px;height:160px;opacity:.5}
.stat-card.feature .quote{font-size:14px;color:#e9e3ff;line-height:1.5;max-width:30ch}
.chrome{position:absolute;right:-30px;bottom:-30px;width:200px;height:200px;background:conic-gradient(from 220deg,#5BD2FF,#7C5CFF,#FF3DC4,#FFD23D,#5BD2FF);border-radius:50%;filter:blur(2px);opacity:.65;mix-blend-mode:screen}
.chrome::after{content:"";position:absolute;inset:18%;border-radius:50%;background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.6), transparent 50%),conic-gradient(from 40deg,#FF3DC4,#7C5CFF,#5BD2FF,#FFD23D,#FF3DC4);filter:blur(.5px)}

/* Dark consulting band (homepage) */
.band{border-radius:32px;padding:80px 56px;color:#fff;position:relative;overflow:hidden;background:radial-gradient(120% 100% at 0% 0%, rgba(124,92,255,.35), transparent 55%),radial-gradient(120% 110% at 100% 100%, rgba(255,61,196,.22), transparent 55%),linear-gradient(160deg,#120832,#070418)}
.band h2{font-weight:700;font-size:clamp(34px,4.6vw,60px);line-height:1.02;letter-spacing:-.025em}
.band > .container-inner{max-width:1080px;margin:0 auto;text-align:center}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;text-align:left}
.svc-grid[hidden]{display:none}
@media(max-width:980px){.svc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.svc-grid{grid-template-columns:1fr}}
.svc-card{background:rgba(255,255,255,.04);border:1px solid var(--line-2);border-radius:18px;padding:26px;display:flex;flex-direction:column;justify-content:space-between;min-height:240px;transition:transform .25s ease, border-color .25s ease}
.svc-card:hover{transform:translateY(-3px);border-color:rgba(255,255,255,.28)}
.svc-card .num{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;color:var(--muted)}
.svc-card h3{font-weight:600;font-size:22px;letter-spacing:-.01em;margin-top:12px}
.svc-card p{color:var(--muted);font-size:14px;margin-top:10px}
.svc-card .more{margin-top:18px;display:inline-flex;gap:6px;font-size:13px;font-weight:500;color:#fff;align-items:center}
.svc-card .more .arrow{transition:transform .25s ease}
.svc-card:hover .more .arrow{transform:translateX(3px)}

/* Projects (homepage) */
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:880px){.proj-grid{grid-template-columns:1fr}}
.proj-card{background:#fff;border:1px solid #E5DEF8;border-radius:22px;padding:26px;color:#15123A;display:flex;flex-direction:column;gap:16px;transition:transform .25s ease, box-shadow .25s ease}
.proj-card:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(86,52,200,.12)}
.proj-card .thumb{aspect-ratio:16/10;border-radius:14px;background:radial-gradient(120% 100% at 0% 0%, rgba(91,210,255,.45), transparent 60%),radial-gradient(140% 110% at 100% 100%, rgba(255,61,196,.5), transparent 60%),linear-gradient(160deg,#221257,#0E0930);position:relative;overflow:hidden}
.proj-card .thumb::after{content:"";position:absolute;inset:auto auto -10% 50%;transform:translateX(-50%);width:62%;height:80%;border-radius:50%;background:conic-gradient(from 220deg,#5BD2FF,#7C5CFF,#FF3DC4,#FFD23D,#5BD2FF);filter:blur(1px);opacity:.85;mix-blend-mode:screen}
.proj-card .thumb.b::after{background:conic-gradient(from 90deg,#7C5CFF,#FF3DC4,#FFD23D,#5BD2FF,#7C5CFF)}
.proj-card .thumb.c::after{background:conic-gradient(from 40deg,#FF3DC4,#7C5CFF,#5BD2FF,#FFD23D,#FF3DC4)}
.proj-card .thumb.d::after{background:conic-gradient(from 160deg,#FFD23D,#FF3DC4,#7C5CFF,#5BD2FF,#FFD23D)}
.proj-card .thumb.e::after{background:conic-gradient(from 280deg,#5BD2FF,#FFD23D,#FF3DC4,#7C5CFF,#5BD2FF)}
.proj-card .thumb.f::after{background:conic-gradient(from 10deg,#7C5CFF,#5BD2FF,#FFD23D,#FF3DC4,#7C5CFF)}
.proj-card .thumb.has-img{background-size:cover;background-position:center;background-repeat:no-repeat}
.proj-card .thumb.has-img::after{display:none}
.faq-illu.has-photo{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:4/3;background:#0A0726}
.faq-illu.has-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.faq-illu.has-photo .caption{position:absolute;left:16px;bottom:14px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:rgba(10,7,38,.55);backdrop-filter:blur(6px);padding:6px 10px;border-radius:99px}
.proj-card h3{font-weight:600;font-size:18px;letter-spacing:-.005em;line-height:1.3}
.proj-card .country{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#7C5CFF}
.proj-card .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}
.proj-card .tag{padding:6px 12px;border-radius:99px;background:#F4F0FF;color:#5b3df5;font-size:12px;font-weight:500}
.proj-card .more{display:inline-flex;align-items:center;gap:6px;color:#5b3df5;font-weight:600;font-size:13px;align-self:flex-start;margin-top:6px}

.exp-block{margin-top:32px}
.exp-block .head{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#7C5CFF;margin-bottom:16px;display:flex;align-items:center;gap:10px;justify-content:center}
.exp-block .head::before,.exp-block .head::after{content:"";flex:1;height:1px;background:#E5DEF8;max-width:120px}
.logos-color{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;align-items:center;justify-items:center}
@media(max-width:880px){.logos-color{grid-template-columns:repeat(3,1fr)}}
.logos-color .lg{padding:14px 18px;border-radius:14px;background:#fff;border:1px solid #E5DEF8;font-weight:700;font-size:18px;letter-spacing:-.01em;color:#15123A;text-align:center;width:100%;box-shadow:0 4px 14px rgba(86,52,200,.06)}
.logos-mono{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;align-items:center;justify-items:center;margin-top:18px}
@media(max-width:880px){.logos-mono{grid-template-columns:repeat(3,1fr)}}
.logos-mono .lg{padding:14px 12px;font-weight:600;font-size:14px;color:#9b97c2;width:100%;text-align:center;border:1px dashed #D8D2EE;border-radius:12px}

/* Logo marquee */
.logo-marquee{position:relative;overflow:hidden;margin-top:8px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.logo-track{display:flex;align-items:center;gap:36px;width:max-content;animation:logo-scroll 50s linear infinite;will-change:transform}
.logo-marquee:hover .logo-track{animation-play-state:paused}
.logo-item{flex:0 0 auto;display:flex;align-items:center;justify-content:center;height:64px;padding:0 8px}
.logo-item img{height:100%;width:auto;max-width:240px;object-fit:contain;opacity:.85;transition:opacity .25s ease,filter .25s ease}
.logo-item:hover img{opacity:1}
/* Darken only the client row (greyscale PNGs) for more contrast on white */
.logo-track.reverse .logo-item img{filter:brightness(0) saturate(100%) opacity(.7)}
.logo-track.reverse .logo-item:hover img{filter:brightness(0) saturate(100%) opacity(1)}
/* per-logo height tweaks for visual balance */
.logo-item.tall img{height:185%;max-width:260px}
.logo-item.short img{height:90%}
.logo-item.small img{height:80%;max-width:140px}
.logo-item.colgate{height:80px;width:80px}
.logo-item.colgate img{height:100%;max-width:none}
@keyframes logo-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.logo-track.reverse{animation-name:logo-scroll-rev;animation-duration:70s}
@keyframes logo-scroll-rev{from{transform:translateX(-50%)}to{transform:translateX(0)}}
@media(max-width:680px){.logo-track{gap:48px}.logo-item{height:48px}}

/* ===== ABOUT PAGE ===== */
.cert-row{margin-top:32px;display:flex;flex-wrap:wrap;gap:16px;align-items:center}
.cert{width:90px;height:90px;border-radius:50%;background:rgba(255,255,255,.04);border:1px solid var(--line-2);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#dad6f5;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.08em;text-transform:uppercase;text-align:center;padding:8px;line-height:1.2;flex-shrink:0;position:relative;overflow:hidden}
.cert::before{content:"";position:absolute;inset:6px;border-radius:50%;border:1px dashed rgba(255,61,196,.35)}
.cert .ic{font-family:'Inter',sans-serif;font-weight:700;font-size:18px;background:linear-gradient(140deg,#FF3DC4,#7C5CFF,#5BD2FF);-webkit-background-clip:text;background-clip:text;color:transparent;display:block;margin-bottom:4px}
.cert.b{background:linear-gradient(140deg,rgba(124,92,255,.2),rgba(255,61,196,.1))}
.cert.c{background:linear-gradient(140deg,rgba(91,210,255,.18),rgba(124,92,255,.1))}
.cert.d{background:linear-gradient(140deg,rgba(255,210,61,.14),rgba(255,61,196,.1))}

/* Founder portrait section */
.founder-block{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:center}
@media(max-width:880px){.founder-block{grid-template-columns:1fr;gap:32px}}
.portrait{aspect-ratio:1/1;border-radius:24px;background:linear-gradient(160deg,#1B1148,#0E0930);border:1px solid var(--line-2);position:relative;overflow:hidden;display:flex;align-items:flex-end;justify-content:center}
.portrait::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 35%,rgba(124,92,255,.4),transparent 55%),radial-gradient(circle at 70% 80%,rgba(255,61,196,.35),transparent 60%)}
.portrait svg{position:relative;width:60%;color:#fff;opacity:.95}
.portrait .tag{position:absolute;top:20px;left:20px;display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:99px;background:rgba(10,7,38,.65);border:1px solid var(--line-2);color:#fff;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.founder-block .name{font-weight:700;font-size:clamp(28px,3.6vw,44px);line-height:1.04;letter-spacing:-.025em}
.founder-block .role{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-top:8px}
.founder-block p{color:var(--muted);font-size:15px;line-height:1.6;margin-top:18px;max-width:60ch}

/* Strategic Convergence framework */
.convergence{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:32px;position:relative}
.conv-head{grid-column:1/-1;text-align:center;font-weight:700;font-size:clamp(20px,2.4vw,28px);line-height:1.2;letter-spacing:-.015em;margin-bottom:8px}
.conv-head .grad{background:linear-gradient(92deg,#FF3DC4,#FFD23D);-webkit-background-clip:text;background-clip:text;color:transparent}
.conv-card{background:rgba(255,255,255,.04);border:1px solid var(--line-2);border-radius:18px;padding:22px;display:flex;flex-direction:column;gap:8px;align-items:center;text-align:center;position:relative}
.conv-card::after{content:"↑";position:absolute;top:-14px;left:50%;transform:translateX(-50%);font-size:14px;color:var(--accent);background:var(--bg);padding:0 8px}
.conv-card .ic{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:linear-gradient(140deg,#FF3DC4,#7C5CFF);font-size:22px;color:#fff}
.conv-card.b .ic{background:linear-gradient(140deg,#5BD2FF,#7C5CFF)}
.conv-card.c .ic{background:linear-gradient(140deg,#FFD23D,#FF3DC4)}
.conv-card.d .ic{background:linear-gradient(140deg,#7C5CFF,#5BD2FF)}
.conv-card h4{font-weight:600;font-size:14px;letter-spacing:-.005em}

/* ===== Our Process band ===== */
.process{border-radius:32px;padding:64px 48px;color:#fff;position:relative;overflow:hidden;background:linear-gradient(160deg,#0c0624,#070418)}
.process-grid{display:grid;grid-template-columns:.8fr 2fr;gap:48px;align-items:start}
@media(max-width:880px){.process-grid{grid-template-columns:1fr;gap:32px}}
.process h2{font-weight:700;font-size:clamp(32px,4.4vw,52px);line-height:1.04;letter-spacing:-.025em}
.process h2 em{font-style:italic;color:var(--muted)}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:980px){.process-steps{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.process-steps{grid-template-columns:1fr}}
.process-step{display:flex;flex-direction:column;gap:10px;padding-top:16px;border-top:1px solid var(--line-2);position:relative}
.process-step::before{content:"";position:absolute;top:-1px;left:0;width:32px;height:2px;background:var(--accent)}
.process-step .num{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;color:var(--accent);text-transform:uppercase}
.process-step h4{font-weight:600;font-size:18px;letter-spacing:-.005em}
.process-step p{color:var(--muted);font-size:13px;line-height:1.55}

/* ===== Portfolio cards ===== */
.cases{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:880px){.cases{grid-template-columns:1fr}}
.case{background:#fff;border:1px solid #E5DEF8;border-radius:24px;padding:18px;color:#15123A;display:flex;flex-direction:column;gap:16px;transition:transform .25s ease, box-shadow .25s ease}
.case:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(86,52,200,.16)}
.case .img{aspect-ratio:16/9;border-radius:14px;position:relative;overflow:hidden;background:linear-gradient(160deg,#1B1148,#0E0930)}
.case .img .badge{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:78px;height:78px;border-radius:18px;background:#fff;display:flex;align-items:center;justify-content:center;color:#15123A;font-weight:800;font-size:13px;letter-spacing:-.02em;box-shadow:0 8px 24px rgba(0,0,0,.3);text-align:center;line-height:1.1;padding:6px}
.case.a .img{background:linear-gradient(160deg,#FF8A3D,#E84A1A)}
.case.b .img{background:linear-gradient(160deg,#3a5a7a 30%,#c46e3a)}
.case.c .img{background:linear-gradient(160deg,#3DDFB0,#1A8F70)}
.case.d .img{background:linear-gradient(160deg,#8b6c4a,#5a4530)}
.case.e .img{background:linear-gradient(160deg,#3a3a3a,#1a1a1a)}
.case.f .img{background:linear-gradient(160deg,#c8945a,#8b6638)}
.case h3{font-weight:700;font-size:22px;letter-spacing:-.01em;color:#15123A;margin-top:4px}
.case .desc{color:#5b5790;font-size:14px;line-height:1.55}
.case .countries{font-size:13px;color:#5b5790}
.case .countries strong{color:#15123A;font-weight:600}
.case .ctags{display:flex;flex-wrap:wrap;gap:6px}
.case .ctag{padding:6px 14px;border-radius:99px;background:#F4F0FF;color:#5b3df5;font-size:12px;font-weight:500;border:1px solid #E5DEF8}
.case .more-btn{align-self:flex-start;padding:12px 22px;border-radius:99px;border:1px solid #15123A;color:#15123A;font-size:13px;font-weight:500;transition:background .2s ease,color .2s ease;text-decoration:none;display:inline-flex;align-items:center;gap:6px}
.case .more-btn:hover{background:#15123A;color:#fff}

/* ===== Larger client grid (Portfolio) ===== */
.exp-section{margin-top:64px;text-align:center}
.exp-section h2{font-weight:700;font-size:clamp(28px,3.4vw,40px);letter-spacing:-.02em;color:#15123A}
.exp-section .eyebrow{justify-content:center;display:inline-flex;color:#7C5CFF}
.exp-section .eyebrow::before{background:#7C5CFF;box-shadow:0 0 0 4px rgba(124,92,255,.18)}
.color-logos{margin-top:32px;display:grid;grid-template-columns:repeat(5,1fr);gap:32px;align-items:center;justify-items:center}
@media(max-width:880px){.color-logos{grid-template-columns:repeat(3,1fr);gap:24px}}
.color-logos .lg{padding:18px 22px;border-radius:14px;background:#fff;border:1px solid #E5DEF8;font-weight:800;font-size:18px;letter-spacing:-.02em;color:#15123A;text-align:center;width:100%;box-shadow:0 4px 14px rgba(86,52,200,.06)}
.gray-logos{margin-top:28px;display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
@media(max-width:880px){.gray-logos{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.gray-logos{grid-template-columns:repeat(2,1fr)}}
.gray-logos .lg{padding:18px 12px;font-weight:700;font-size:14px;color:#a39ec0;text-align:center;border:1px solid #E5DEF8;border-radius:12px;letter-spacing:-.01em;background:rgba(255,255,255,.5)}

/* ===== GMP Partner top strip (Variant A header) ===== */
.gmp-strip{
  background:linear-gradient(90deg,rgba(91,210,255,.18),rgba(124,92,255,.18) 50%,rgba(255,61,196,.18));
  border-bottom:1px solid var(--line-2);
  padding:12px 16px;display:flex;justify-content:center;align-items:center;gap:14px;color:#fff;font-size:13px;
  position:relative;flex-wrap:nowrap;
}
.gmp-strip::before{content:"";position:absolute;inset:auto 0 0 0;height:1px;background:linear-gradient(90deg,transparent,#FF3DC4 30%,#5BD2FF 70%,transparent);pointer-events:none}
.gmp-strip .star{font-size:14px;color:#FFD23D;line-height:1;display:inline-block;flex-shrink:0}
.gmp-strip strong{font-weight:700;letter-spacing:.01em;font-family:'Inter',sans-serif}
.gmp-strip .sep{color:var(--muted);opacity:.6;flex-shrink:0}
.gmp-strip .cta-link{
  display:inline-flex;align-items:center;gap:6px;color:#fff;font-weight:600;
  border-bottom:1px solid var(--accent);padding-bottom:1px;font-size:13px;
  transition:color .2s ease,border-color .2s ease;flex-shrink:0;white-space:nowrap;
}
.gmp-strip .cta-link:hover{color:var(--accent)}
.gmp-strip .lab-short{display:none}
@media(max-width:880px){
  .gmp-strip{gap:10px;font-size:12px;padding:10px 14px}
  .gmp-strip .lab-long{display:none}
  .gmp-strip .lab-short{display:inline}
}
@media(max-width:560px){
  .gmp-strip{gap:8px;font-size:11px;padding:8px 12px;letter-spacing:.02em}
  .gmp-strip .star{font-size:12px}
  .gmp-strip .cta-link{font-size:11px;padding-bottom:0}
}

/* ===== DV360 · SA360 Announce chip (header) ===== */
.announce{padding:10px 0 0;display:flex;justify-content:center;background:transparent;position:relative}
.dv-chip{
  display:inline-flex;align-items:center;gap:12px;padding:6px 6px 6px 16px;border-radius:99px;
  background:linear-gradient(140deg,rgba(91,210,255,.12),rgba(255,61,196,.12));
  border:1px solid var(--line-2);position:relative;
  box-shadow:0 6px 20px rgba(124,92,255,.15), inset 0 1px 0 rgba(255,255,255,.06);
  color:#fff;font-size:13px;transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.dv-chip:hover{transform:translateY(-1px);border-color:rgba(255,61,196,.4);box-shadow:0 10px 28px rgba(255,61,196,.25)}
.dv-chip::before{
  content:"";position:absolute;inset:-1px;border-radius:99px;padding:1px;
  background:linear-gradient(120deg,#5BD2FF,#7C5CFF,#FF3DC4,#FFD23D);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.55;pointer-events:none;
}
.dv-chip .pulse-dot{
  width:10px;height:10px;border-radius:50%;
  background:conic-gradient(from 220deg,#5BD2FF,#7C5CFF,#FF3DC4,#FFD23D,#5BD2FF);
  box-shadow:0 0 0 3px rgba(255,61,196,.18), 0 0 12px rgba(255,61,196,.45);
  animation:spin 6s linear infinite;flex-shrink:0;
}
.dv-chip .lbl{display:flex;flex-direction:column;line-height:1.15;text-align:left}
.dv-chip .lbl strong{font-weight:700;letter-spacing:-.01em;font-size:13px;color:#fff}
.dv-chip .lbl small{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:500;margin-top:2px}
.dv-chip .badge-pro{
  margin-left:4px;padding:3px 8px;border-radius:99px;background:var(--accent);color:#fff;
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
}
.dv-chip .arrow-mini{
  width:28px;height:28px;border-radius:99px;background:#fff;color:#0A0726;
  display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;
  transition:transform .25s ease;flex-shrink:0;
}
.dv-chip:hover .arrow-mini{transform:translateX(2px)}
@media(max-width:680px){
  .dv-chip{padding:6px 6px 6px 12px;gap:8px}
  .dv-chip .lbl small{display:none}
  .dv-chip .badge-pro{display:none}
}

/* ===== DV360 · SA360 Scroll-stopper section ===== */
.dv-stop{
  border-radius:32px;padding:80px 56px;color:#fff;position:relative;overflow:hidden;
  background:radial-gradient(120% 100% at 0% 0%, rgba(91,210,255,.4), transparent 55%),
             radial-gradient(120% 110% at 100% 100%, rgba(255,61,196,.45), transparent 55%),
             linear-gradient(160deg,#0F0830,#070418);
}
.dv-stop::before{
  content:"";position:absolute;right:-80px;top:-80px;width:380px;height:380px;border-radius:50%;
  background:conic-gradient(from 220deg,#5BD2FF,#7C5CFF,#FF3DC4,#FFD23D,#5BD2FF);
  filter:blur(40px);opacity:.45;pointer-events:none;animation:spin 30s linear infinite;
}
.dv-stop::after{
  content:"";position:absolute;left:-100px;bottom:-120px;width:320px;height:320px;border-radius:50%;
  background:conic-gradient(from 90deg,#7C5CFF,#FF3DC4,#FFD23D,#5BD2FF,#7C5CFF);
  filter:blur(50px);opacity:.35;pointer-events:none;
}
.dv-stop > .inner{position:relative;z-index:1}
.dv-stop .head{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:end;margin-bottom:48px}
@media(max-width:880px){.dv-stop{padding:48px 24px}.dv-stop .head{grid-template-columns:1fr;gap:24px}}
.dv-stop h2{font-weight:700;font-size:clamp(36px,5vw,68px);line-height:1.0;letter-spacing:-.03em;max-width:14ch}
.dv-stop h2 .grad{background:linear-gradient(92deg,#fff 30%,#C9B6FF 55%,#FF8CE2 80%,#5BD2FF);-webkit-background-clip:text;background-clip:text;color:transparent}
.dv-stop .sub{color:var(--muted);font-size:16px;line-height:1.55;max-width:42ch}
.dv-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:880px){.dv-cards{grid-template-columns:1fr}}
.dv-card{background:rgba(255,255,255,.04);border:1px solid var(--line-2);border-radius:22px;padding:32px;display:flex;flex-direction:column;gap:18px;backdrop-filter:blur(8px);position:relative;overflow:hidden;transition:transform .25s ease, border-color .25s ease}
.dv-card:hover{transform:translateY(-3px);border-color:rgba(255,255,255,.28)}
.dv-card .platform{display:flex;align-items:center;gap:14px}
.dv-card .platform .logo-blk{width:54px;height:54px;border-radius:14px;background:linear-gradient(140deg,#5BD2FF,#7C5CFF,#FF3DC4);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;letter-spacing:-.02em;color:#fff;flex-shrink:0;box-shadow:0 6px 20px rgba(124,92,255,.35)}
.dv-card.b .platform .logo-blk{background:linear-gradient(140deg,#FFD23D,#FF3DC4,#7C5CFF)}
.dv-card .platform .name{font-weight:700;font-size:24px;letter-spacing:-.02em;line-height:1.1}
.dv-card .platform .name small{display:block;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:500;margin-top:4px}
.dv-card .desc{color:var(--muted);font-size:14px;line-height:1.55}
.dv-card ul{list-style:none;display:flex;flex-direction:column;gap:8px;margin-top:auto}
.dv-card ul li{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:#dad6f5}
.dv-card ul li::before{content:"";width:6px;height:6px;border-radius:50%;background:linear-gradient(140deg,#FF3DC4,#7C5CFF);flex-shrink:0;margin-top:7px}

.dv-stop .terms{margin-top:32px;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:880px){.dv-stop .terms{grid-template-columns:1fr}}
.dv-term{padding:20px;background:rgba(255,255,255,.04);border:1px solid var(--line-2);border-radius:16px}
.dv-term .num{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;color:var(--accent);text-transform:uppercase}
.dv-term h4{font-weight:600;font-size:16px;letter-spacing:-.005em;margin-top:8px}
.dv-term p{color:var(--muted);font-size:13px;margin-top:6px;line-height:1.5}

.dv-stop .footer-cta{margin-top:40px;display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between}
.dv-stop .footer-cta .note{color:var(--muted);font-size:13px;max-width:42ch}
.dv-stop .badge-row{margin-top:24px;display:flex;flex-wrap:wrap;gap:8px}
.dv-stop .badge-mini{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--line-2);border-radius:99px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.dv-stop .badge-mini .d{width:6px;height:6px;border-radius:50%;background:var(--accent)}

/* ===== PROGRAMMATIC PAGE ===== */
/* €1,000 prepayment hero band */
.prepay-hero{
  border-radius:32px;padding:80px 40px;color:#fff;position:relative;overflow:hidden;text-align:center;
  background:radial-gradient(120% 100% at 0% 0%, rgba(91,210,255,.4), transparent 55%),
             radial-gradient(120% 110% at 100% 100%, rgba(255,61,196,.45), transparent 55%),
             linear-gradient(160deg,#0F0830,#070418);
}
.prepay-hero::before{content:"";position:absolute;right:-100px;top:-100px;width:400px;height:400px;border-radius:50%;background:conic-gradient(from 220deg,#5BD2FF,#7C5CFF,#FF3DC4,#FFD23D,#5BD2FF);filter:blur(50px);opacity:.4;pointer-events:none;animation:spin 40s linear infinite}
.prepay-hero::after{content:"";position:absolute;left:-120px;bottom:-120px;width:380px;height:380px;border-radius:50%;background:conic-gradient(from 90deg,#7C5CFF,#FF3DC4,#FFD23D,#5BD2FF,#7C5CFF);filter:blur(50px);opacity:.3;pointer-events:none}
.prepay-hero .inner{position:relative;z-index:1;max-width:980px;margin:0 auto}
.prepay-hero .price{
  font-weight:800;font-size:clamp(96px,16vw,220px);line-height:.9;letter-spacing:-.06em;
  background:linear-gradient(92deg,#fff 10%,#FFD23D 35%,#FF3DC4 65%,#5BD2FF);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.prepay-hero .price .euro{font-weight:600;font-size:.55em;vertical-align:0.15em;letter-spacing:0;margin-right:.05em}
.prepay-hero .price-cap{margin-top:14px;font-size:clamp(20px,2.4vw,28px);font-weight:600;letter-spacing:-.015em;color:#fff;line-height:1.2}
.prepay-hero p.note{margin-top:18px;color:var(--muted);max-width:62ch;margin-left:auto;margin-right:auto;font-size:15px;line-height:1.6}
.prepay-hero .actions{margin-top:32px;display:inline-flex;gap:12px;flex-wrap:wrap;justify-content:center}

/* Two ways cards (Self Service / Managed) */
.way-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:32px}
@media(max-width:880px){.way-cards{grid-template-columns:1fr}}
.way{
  background:rgba(255,255,255,.04);border:1px solid var(--line-2);border-radius:22px;padding:32px;
  display:flex;flex-direction:column;gap:18px;
}
.way .way-head{display:flex;align-items:center;gap:14px}
.way .way-head .ic{width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;color:#fff;font-weight:700;flex-shrink:0}
.way.a .way-head .ic{background:linear-gradient(140deg,#5BD2FF,#7C5CFF)}
.way.b .way-head .ic{background:linear-gradient(140deg,#FF3DC4,#FFD23D)}
.way h3{font-weight:700;font-size:24px;letter-spacing:-.02em;line-height:1.15}
.way h3 small{display:block;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:6px;font-weight:500}
.way p.lead-line{color:#dad6f5;font-size:15px;line-height:1.55}
.way ul{list-style:none;display:flex;flex-direction:column;gap:8px;margin-top:8px}
.way ul li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--muted)}
.way ul li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:7px}
.way .for{margin-top:auto;padding-top:18px;border-top:1px solid var(--line-2);font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:600}
.way .for span{color:var(--muted);font-weight:500;margin-left:8px;text-transform:none;letter-spacing:0;font-family:'Inter',sans-serif;font-size:13px}

/* Comparison tables */
.compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:32px}
@media(max-width:980px){.compare-grid{grid-template-columns:1fr}}
.compare{
  background:rgba(255,255,255,.03);border:1px solid var(--line-2);border-radius:22px;overflow:hidden;
}
.compare .top{padding:24px 28px;border-bottom:1px solid var(--line-2);background:rgba(124,92,255,.08)}
.compare.b .top{background:rgba(255,61,196,.08)}
.compare .top .tier{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.compare .top h3{font-weight:700;font-size:22px;letter-spacing:-.015em;margin-top:6px}
.compare .top p{color:var(--muted);font-size:13px;margin-top:6px}
.compare .row{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:14px;padding:14px 24px;align-items:center;border-bottom:1px solid var(--line);font-size:14px}
.compare .row:last-child{border-bottom:0}
.compare .row.head{padding:14px 24px;background:rgba(0,0,0,.2);font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600}
.compare .row.head .us{color:var(--accent)}
.compare .row .label{color:#fff;font-weight:500}
.compare .row .v{text-align:center;color:#dad6f5}
.compare .row .v.us{color:#fff;font-weight:700;background:linear-gradient(140deg,rgba(255,61,196,.18),rgba(124,92,255,.1));border-radius:8px;padding:6px 8px;position:relative}
.compare .row .v.na{color:var(--muted-2);font-style:italic;font-size:13px}
.compare .row.highlight{background:rgba(124,92,255,.05)}

/* Features grid */
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:32px}
@media(max-width:980px){.feat-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.feat-grid{grid-template-columns:1fr}}
.feat{
  background:rgba(255,255,255,.04);border:1px solid var(--line-2);border-radius:18px;padding:22px;
  display:flex;flex-direction:column;gap:10px;transition:transform .25s ease, border-color .25s ease;
}
.feat:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.28)}
.feat .ic{width:38px;height:38px;border-radius:10px;background:linear-gradient(140deg,#FF3DC4,#7C5CFF);display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;font-weight:700}
.feat.b .ic{background:linear-gradient(140deg,#5BD2FF,#7C5CFF)}
.feat.c .ic{background:linear-gradient(140deg,#FFD23D,#FF3DC4)}
.feat.d .ic{background:linear-gradient(140deg,#7C5CFF,#5BD2FF)}
.feat h4{font-weight:600;font-size:16px;letter-spacing:-.005em}
.feat p{color:var(--muted);font-size:13px;line-height:1.55}

/* ============= PROJECT CAROUSEL ============= */
.proj-carousel-wrap{position:relative;margin-top:36px}
.proj-carousel{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;padding:8px 4px 32px;scroll-padding:4px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.proj-carousel::-webkit-scrollbar{display:none}
.proj-carousel .ccard{flex:0 0 78%;max-width:780px;scroll-snap-align:start;position:relative;border-radius:24px;overflow:hidden;background:#1a1428;text-decoration:none;color:#fff;display:flex;flex-direction:column;aspect-ratio:16/10;transition:transform .4s ease}
.proj-carousel .ccard:hover{transform:translateY(-4px)}
.proj-carousel .ccard .img{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;transition:transform .8s ease}
.proj-carousel .ccard:hover .img{transform:scale(1.04)}
.proj-carousel .ccard .veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,7,38,.1) 30%,rgba(10,7,38,.85) 100%);z-index:1}
.proj-carousel .ccard .row{position:relative;z-index:2;display:flex;justify-content:flex-start;padding:24px 28px;align-items:flex-start}
.proj-carousel .ccard .brand{display:inline-flex;align-items:center;gap:12px;min-height:40px}
/* Logo chip — white pill so logos keep their natural colors with reliable contrast on any photo */
.proj-carousel .ccard .logo-slot{
  display:inline-flex;align-items:center;justify-content:center;
  height:40px;padding:0 14px;min-width:40px;
  background:#fff;border-radius:10px;
  box-shadow:0 4px 18px rgba(0,0,0,.25), 0 0 0 1px rgba(255,255,255,.4);
}
/* Letter placeholder (used only when no logo is supplied yet) */
.proj-carousel .ccard .logo-slot:not(:has(img)){
  font-family:'Inter',sans-serif;font-weight:700;font-size:15px;
  color:#15123A;letter-spacing:0;padding:0;width:40px;
}
.proj-carousel .ccard .logo-slot img{
  display:block;height:22px;width:auto;max-width:140px;object-fit:contain;
}
.proj-carousel .ccard .brand-name{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.95);display:inline-flex;align-items:center;gap:8px}
.proj-carousel .ccard .brand-name::before{content:"";width:6px;height:6px;background:#ff3d8b;border-radius:50%}
.proj-carousel .ccard .bottom{position:relative;z-index:2;margin-top:auto;padding:28px;display:grid;grid-template-columns:1fr auto;align-items:flex-end;gap:24px}
.proj-carousel .ccard .bottom .heading{max-width:32ch}
.proj-carousel .ccard h3{font-size:30px;line-height:1.15;margin:0 0 14px;font-weight:600;letter-spacing:-.015em;color:#fff}
.proj-carousel .ccard .tags{display:flex;gap:6px;flex-wrap:wrap}
.proj-carousel .ccard .tags span{font-size:10px;font-family:'JetBrains Mono',monospace;letter-spacing:.1em;text-transform:uppercase;border:1px solid rgba(255,255,255,.3);padding:5px 9px;border-radius:999px;color:rgba(255,255,255,.85)}
.proj-carousel .ccard .stat{font-family:'Instrument Serif','Times New Roman',serif;font-style:italic;font-size:64px;line-height:.95;letter-spacing:-.02em;color:#fff;text-align:right;white-space:nowrap;font-weight:400}
.proj-carousel .ccard .stat small{display:block;font-family:'Inter',sans-serif;font-style:normal;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:10px;font-weight:500}
.proj-carousel .ccard .stat sup{font-size:.5em;color:#ff3d8b;font-family:'Inter',sans-serif;font-style:normal;font-weight:600;vertical-align:super;margin-left:3px}
.proj-carousel .ccard.no-stat .bottom{grid-template-columns:1fr}
.proj-carousel .ccard.no-stat h3{font-size:32px;margin-bottom:18px}
.ctrl-row{display:flex;justify-content:space-between;align-items:center;margin-top:8px;padding:0 4px;gap:18px}
.ctrl-row .hint{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--muted,#6b6f7d);letter-spacing:.14em}
.ctrl-row .progress{flex:1;height:2px;background:rgba(0,0,0,.08);border-radius:2px;overflow:hidden}
.ctrl-row .progress .bar{height:100%;background:linear-gradient(90deg,#ff3d8b,#7c4dff);width:20%;border-radius:2px;transition:width .3s}
.ctrl-row .arrows{display:flex;gap:8px}
.ctrl-row .arrows button{width:44px;height:44px;border-radius:50%;border:1px solid #e8e6ee;background:#fff;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .25s;color:#0b0b14}
.ctrl-row .arrows button:hover{background:#0b0b14;color:#fff;border-color:#0b0b14}
@media (max-width:760px){
  /* Option B — image hero + solid caption block */
  .proj-carousel .ccard{
    flex:0 0 88%;
    aspect-ratio:auto;          /* drop the 16:10 lock so card sizes to content */
    background:#1a1428;
    overflow:hidden;
  }
  /* Image becomes a fixed-height hero at the top */
  .proj-carousel .ccard .img{
    position:relative;inset:auto;
    width:100%;height:220px;flex-shrink:0;
  }
  /* Veil only covers the image area, fading downward into the caption */
  .proj-carousel .ccard .veil{
    inset:0 0 auto 0;height:220px;
    background:linear-gradient(180deg, rgba(10,7,38,.0) 40%, rgba(10,7,38,.55) 100%);
  }
  /* Logo chip floats on top of the image hero */
  .proj-carousel .ccard .row{
    position:absolute;top:0;left:0;right:0;z-index:3;
    padding:18px;
  }
  .proj-carousel .ccard .logo-slot{height:36px;padding:0 12px;min-width:36px}
  .proj-carousel .ccard .logo-slot img{height:20px;max-width:120px}

  /* Caption block — solid dark, sits below the image */
  .proj-carousel .ccard .bottom{
    position:relative;z-index:4;
    margin-top:0;
    grid-template-columns:1fr;
    gap:14px;padding:20px;
    background:#1a1428;
    display:flex;flex-direction:column;
  }
  .proj-carousel .ccard h3{font-size:20px;line-height:1.25;margin:0 0 4px}
  .proj-carousel .ccard .tags{order:3}

  /* Stat becomes an inline row: big italic + mono label, hairlines above/below */
  .proj-carousel .ccard .bottom .stat{
    order:2;
    display:flex;align-items:baseline;gap:12px;
    padding:12px 0;margin:0;
    border-top:1px solid rgba(255,255,255,.08);
    border-bottom:1px solid rgba(255,255,255,.08);
    font-size:30px;line-height:1;text-align:left;white-space:normal;
  }
  .proj-carousel .ccard .bottom .stat small{
    display:inline;margin-top:0;flex:1;
    font-size:10.5px;letter-spacing:.14em;
  }
  /* No-stat cards: drop the hairline-row entirely (no <div class="stat">) */
  .ctrl-row .hint{display:none}
}

/* ============= BLOG ============= */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:900px){.blog-grid{grid-template-columns:1fr}}
.blog-card{display:flex;flex-direction:column;background:#fff;border:1px solid #e8e6ee;border-radius:18px;overflow:hidden;text-decoration:none;color:inherit;transition:transform .3s ease, box-shadow .3s ease;padding-bottom:24px}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(11,11,20,.08)}
.blog-card .thumb{position:relative;aspect-ratio:16/10;display:flex;align-items:flex-end;padding:24px;color:#fff;overflow:hidden}
.blog-card .thumb .bg-num{position:absolute;top:24px;right:24px;font-family:'JetBrains Mono',monospace;font-size:13px;letter-spacing:.18em;opacity:.7}
.blog-card .thumb .bg-label{font-family:'Instrument Serif','Times New Roman',serif;font-style:italic;font-size:56px;line-height:1;letter-spacing:-.02em;font-weight:400}
.blog-card .meta{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 0;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#6b6f7d}
.blog-card .meta .cat{color:#ff3d8b;font-weight:600}
.blog-card h3{font-size:20px;line-height:1.25;margin:14px 24px 10px;font-weight:600;letter-spacing:-.01em}
.blog-card p{margin:0 24px 16px;color:#6b6f7d;font-size:14px;line-height:1.55}
.blog-card .more{margin:auto 24px 0;font-weight:600;font-size:14px;color:#0b0b14;display:inline-flex;align-items:center;gap:6px}
.blog-card .more .arr{transition:transform .25s}
.blog-card:hover .more .arr{transform:translateX(4px)}

/* ============= ARTICLE PAGE ============= */
.article-hero{padding:120px 0 60px;background:#0A0726;color:#fff}
.article-hero .container{max-width:780px}
.article-hero .crumb{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:24px}
.article-hero .crumb a{color:rgba(255,255,255,.6);text-decoration:none}
.article-hero .crumb a:hover{color:#fff}
.article-hero .cat{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#ff3d8b;padding:6px 12px;border:1px solid rgba(255,61,139,.35);border-radius:999px;margin-bottom:24px}
.article-hero h1{font-size:clamp(36px,5vw,60px);letter-spacing:-.025em;line-height:1.05;margin:0 0 24px;font-weight:700}
.article-hero h1 em{font-family:'Instrument Serif','Times New Roman',serif;font-style:italic;font-weight:400}
.article-hero .dek{font-size:18px;color:rgba(255,255,255,.75);line-height:1.55;max-width:60ch}
.article-hero .byline{display:flex;align-items:center;gap:16px;margin-top:36px;font-size:14px;color:rgba(255,255,255,.7)}
.article-hero .byline strong{color:#fff;font-weight:600}
.article-body{padding:60px 0 100px;background:var(--paper,#f6f4ef)}
.article-body .container{max-width:740px}
.article-body p{font-size:17px;line-height:1.7;color:#1a1a25;margin:0 0 22px}
.article-body p.lead{font-size:20px;line-height:1.55;color:#0b0b14}
.article-body h2{font-size:28px;letter-spacing:-.015em;line-height:1.2;margin:48px 0 18px;font-weight:700}
.article-body h3{font-size:20px;line-height:1.3;margin:36px 0 14px;font-weight:600}
.article-body ul,.article-body ol{padding-left:24px;margin:0 0 22px}
.article-body li{font-size:17px;line-height:1.65;margin-bottom:10px;color:#1a1a25}
.article-body strong{font-weight:600;color:#0b0b14}
.article-body em{font-family:'Instrument Serif','Times New Roman',serif;font-style:italic}
.article-body blockquote{margin:36px 0;padding:24px 28px;border-left:3px solid #ff3d8b;background:#fff;border-radius:0 12px 12px 0;font-size:18px;line-height:1.55;color:#0b0b14;font-weight:500}
.article-body .callout{margin:36px 0;padding:24px 28px;background:#0A0726;color:#fff;border-radius:14px}
.article-body .callout h4{margin:0 0 10px;font-size:14px;font-family:'JetBrains Mono',monospace;letter-spacing:.16em;text-transform:uppercase;color:#ff3d8b;font-weight:600}
.article-body .callout p{color:rgba(255,255,255,.85);font-size:16px;margin:0}
.article-body hr{border:none;border-top:1px solid #e8e6ee;margin:48px 0}
.article-cta{padding:48px 0 80px;background:var(--paper,#f6f4ef)}
.article-cta .box{max-width:740px;margin:0 auto;padding:36px;background:#0A0726;color:#fff;border-radius:18px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.article-cta h3{margin:0 0 6px;font-size:22px;font-weight:600}
.article-cta p{margin:0;color:rgba(255,255,255,.75);font-size:15px}

/* Blog carousel — homepage */
.blog-carousel-wrap{position:relative;margin-top:36px}
.blog-carousel{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;padding:8px 4px 32px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.blog-carousel::-webkit-scrollbar{display:none}
.blog-carousel > .blog-card{flex:0 0 calc((100% - 40px)/3);scroll-snap-align:start;min-width:280px}
@media (max-width:900px){.blog-carousel > .blog-card{flex:0 0 calc((100% - 20px)/2)}}
@media (max-width:600px){.blog-carousel > .blog-card{flex:0 0 86%}}
.blog-grid-all{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:900px){.blog-grid-all{grid-template-columns:1fr}}


/* ============================================================
   MOBILE SPACING PATCH — tighten margins so content fills the
   screen on phones. Previously container had 28px sides and
   the dark "band" boxes (.fpc/.band/.testi/.rtd/.dv-stop/
   .connect/.process) kept their 56px internal padding even on
   mobile, leaving ~220px of usable content on a 390px screen.
   ============================================================ */
@media (max-width:720px){
  .container{padding:0 18px}
  section{padding:64px 0}
  .sub-hero{padding:32px 0 56px}

  /* Big rounded "band" boxes — pull internal padding way in */
  .fpc,.band,.testi,.rtd,.connect,.process,.dv-stop,.light{
    padding:48px 18px;border-radius:24px;
  }
  .connect .left,.connect .right{padding:36px 22px}

  /* Section headings shrink + don't cap at 16ch (too narrow) */
  .sec-head h2{max-width:none;font-size:clamp(28px,8vw,40px)}
  .sub-hero h1{font-size:clamp(30px,9vw,44px)}
  .sub-hero .lead{font-size:16px}

  /* Card grids reduce gaps */
  .channels,.results-row,.diff,.cases,.proj-grid,
  .way-cards,.dv-cards,.svc-grid{gap:12px}

  /* Card internal padding tighter */
  .result-card,.proj-card,.case,
  .dv-card,.way,.feat,.channel{padding:22px}
  .diff-card{padding:14px}
  .stat-card{padding:12px;min-height:160px}
  .stat-card .x{font-size:42px}
  .stat-card .label{font-size:12px}
  .stat-card .who{font-size:13px}
  .stat-card .who .sub{font-size:11px}
  .stat-card .pill{width:26px;height:26px;font-size:12px}
}
@media (max-width:480px){
  .container{padding:0 14px}
  section{padding:48px 0}
  .fpc,.band,.testi,.rtd,.connect,.process,.dv-stop,.light{
    padding:36px 12px;border-radius:20px;
  }
  .connect .left,.connect .right{padding:28px 16px}
  .sectors{padding:18px 16px}
}


/* ============================================================
   MOBILE — Services accordion (Option A)
   On ≤720px screens, the desktop tabs + svc-grid are hidden
   and a stacked accordion (#svcMobile) is shown in their place.
   Built by JS from the same content so i18n keys work as-is.
   ============================================================ */
.svc-mobile{display:none}
@media (max-width:720px){
  .band .tabs,
  .band .svc-grid{display:none !important}
  .svc-mobile{display:flex;flex-direction:column;gap:10px;margin-top:18px;text-align:left}
}

/* Category */
.svcm-cat{border:1px solid rgba(255,255,255,.1);border-radius:16px;background:rgba(255,255,255,.03);overflow:hidden;transition:background .2s ease}
.svcm-cat[open]{background:rgba(255,255,255,.05)}
.svcm-cat > summary{
  list-style:none;cursor:pointer;
  padding:16px 18px;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
}
.svcm-cat > summary::-webkit-details-marker{display:none}
.svcm-cat-title{display:flex;align-items:center;gap:12px;font-weight:600;font-size:15px;letter-spacing:.005em;color:#fff}
.svcm-ic{
  width:28px;height:28px;border-radius:8px;
  background:linear-gradient(140deg,#7C5CFF,#FF3DC4);
  color:#fff;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.svcm-cat-right{display:flex;align-items:center;gap:10px;color:#A39FCD}
.svcm-count{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.12em}
.svcm-chev{font-size:12px;transition:transform .25s ease}
.svcm-cat[open] .svcm-chev{transform:rotate(180deg)}

/* Service rows */
.svcm-items{padding:2px 8px 10px}
.svcm-item{border-top:1px solid rgba(255,255,255,.06)}
.svcm-item:first-child{border-top:0}
.svcm-item > summary{
  list-style:none;cursor:pointer;
  padding:14px 10px;
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;
}
.svcm-item > summary::-webkit-details-marker{display:none}
.svcm-num{font-family:'JetBrains Mono',monospace;font-size:11px;color:#7C5CFF;letter-spacing:.12em}
.svcm-ttl{font-size:15px;font-weight:500;color:#fff;line-height:1.3}
.svcm-more{
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.12em;
  color:#A39FCD;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:6px;white-space:nowrap;
}
.svcm-more::after{content:"+";color:#FF3DC4;font-size:14px;font-family:'Inter',sans-serif;font-weight:400;line-height:1}
.svcm-item[open] .svcm-more::after{content:"−"}

.svcm-body{
  padding:0 10px 16px 46px;
  color:#bcb6e0;font-size:14px;line-height:1.55;
  opacity:0;transform:translateY(-4px);
  transition:opacity .4s ease .15s, transform .4s ease .15s;
}
.svcm-item[open] .svcm-body{opacity:1;transform:none}
.svcm-body p{margin:0 0 10px}
.svcm-link{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:600;color:#FF3DC4;text-decoration:none;
}
.svcm-link:hover{color:#fff}

/* Smooth height + chevron / icon transitions */
.svcm-item, .svcm-cat{transition:background .25s ease, border-color .25s ease}
.svcm-cat[open]{border-color:rgba(255,255,255,.16)}
.svcm-item[open]{background:rgba(124,92,255,.04)}
.svcm-more::after{transition:transform .25s ease, color .25s ease}
.svcm-item[open] .svcm-more::after{transform:rotate(180deg)}
@media (prefers-reduced-motion: reduce){
  .svcm-body, .svcm-item, .svcm-cat, .svcm-chev, .svcm-more::after{transition:none !important;animation:none !important}
}

@media (max-width:480px){
  .svcm-cat > summary{padding:14px 14px}
  .svcm-items{padding:2px 6px 8px}
  .svcm-item > summary{padding:12px 8px;gap:10px}
  .svcm-body{padding:0 8px 14px 38px;font-size:13.5px}
  .svcm-ttl{font-size:14px}
}
