/* =========================================================
   TECHNOSURE — Brand Stylesheet
   National Premium Edition
   ========================================================= */

/* ---- Self-hosted fonts (variable, latin subset) ---- */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('../fonts/inter-latin-var.woff2') format('woff2-variations'),
       url('../fonts/inter-latin-var.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Space Grotesk';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url('../fonts/space-grotesk-latin-var.woff2') format('woff2-variations'),
       url('../fonts/space-grotesk-latin-var.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ---- CLS-killing fallback fonts: Arial-based, metric-matched ---- */
@font-face {
  font-family: 'Inter Fallback';
  src: local('Arial');
  size-adjust: 107.4%;
  ascent-override: 90%;
  descent-override: 22.4%;
  line-gap-override: 0%;
}
@font-face {
  font-family: 'Space Grotesk Fallback';
  src: local('Arial');
  size-adjust: 102.5%;
  ascent-override: 96.5%;
  descent-override: 22%;
  line-gap-override: 0%;
}

:root{
  --blue:#0a3aa3;
  --blue-deep:#062366;
  --blue-bright:#1f5dd6;
  --blue-soft:#eaf0ff;
  --red:#e1162a;
  --red-deep:#a30c1d;
  --red-soft:#fde8eb;
  --yellow:#ffd60a;
  --yellow-soft:#ffe566;
  --yellow-deep:#a98904;
  --ink:#0b1020;
  --ink-2:#141a33;
  --ink-3:#1f2740;
  --muted:#5b657a;
  --muted-2:#8c98b8;
  --line:#e6e9f0;
  --line-2:#cfd5e3;
  --bg:#f6f7fb;
  --bg-warm:#faf8f3;
  --card:#ffffff;
  --radius-xs:8px;
  --radius-sm:10px;
  --radius:18px;
  --radius-lg:28px;
  --radius-xl:36px;
  --shadow-sm:0 1px 2px rgba(11,16,32,.06), 0 4px 12px -4px rgba(11,16,32,.08);
  --shadow:0 1px 2px rgba(11,16,32,.06), 0 12px 40px -12px rgba(11,16,32,.18);
  --shadow-lg:0 30px 60px -20px rgba(11,16,32,.35);
  --shadow-glow:0 20px 60px -20px rgba(10,58,163,.45);
  --ease-out:cubic-bezier(.2,.8,.2,1);
  --ease-in-out:cubic-bezier(.65,0,.35,1);
  --topbar-h:38px;
  --nav-h:74px;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-h) + var(--topbar-h) + 8px)}
body{
  font-family:'Inter','Inter Fallback',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.55;
  overflow-x:hidden;
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

::selection{background:var(--yellow);color:var(--ink)}

/* Custom scrollbar */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--blue),var(--red));border-radius:8px;border:2px solid var(--bg)}

.container{width:min(1280px,92%);margin-inline:auto}
.display{font-family:'Space Grotesk','Space Grotesk Fallback',Inter,sans-serif;letter-spacing:-.022em;line-height:1.04}

.skip{
  position:absolute;left:-1000px;top:-1000px;
  background:var(--ink);color:#fff;padding:.6rem 1rem;border-radius:8px;
  z-index:200;font-weight:600;
}
.skip:focus{left:16px;top:16px}

/* ============ EYEBROWS / BUTTONS ============ */
.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;
  color:var(--blue);
  background:rgba(10,58,163,.08);
  padding:.5rem .9rem;border-radius:999px;
  position:relative;
}
.eyebrow.red{color:var(--red);background:rgba(225,22,42,.08)}
.eyebrow.yellow{color:var(--yellow-deep);background:rgba(255,214,10,.18)}
.eyebrow .pulse{
  width:8px;height:8px;border-radius:50%;background:currentColor;
  position:relative;
}
.eyebrow .pulse::after{
  content:"";position:absolute;inset:-4px;border-radius:50%;
  background:currentColor;opacity:.35;
  animation:pulse 2s ease-out infinite;
}
@keyframes pulse{
  0%{transform:scale(.8);opacity:.6}
  100%{transform:scale(2.4);opacity:0}
}

.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.95rem 1.4rem;border-radius:12px;font-weight:600;font-size:.95rem;
  transition:transform .25s var(--ease-out),box-shadow .25s,background .2s,color .2s,border-color .2s;
  border:1px solid transparent;cursor:pointer;
  font-family:inherit;line-height:1;
  position:relative;overflow:hidden;
  white-space:nowrap;
}
.btn::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.25) 50%,transparent 70%);
  transform:translateX(-110%);transition:transform .8s var(--ease-out);
}
.btn:hover::after{transform:translateX(110%)}
.btn-lg{padding:1.1rem 1.7rem;font-size:1rem}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 10px 28px -10px rgba(10,58,163,.65)}
.btn-primary:hover{background:var(--blue-deep);transform:translateY(-2px);box-shadow:0 14px 36px -12px rgba(10,58,163,.7)}
.btn-outline{border-color:var(--ink);color:var(--ink);background:transparent}
.btn-outline:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.btn-outline-dark{border-color:rgba(11,16,32,.85);color:var(--ink);background:transparent}
.btn-outline-dark:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.btn-red{background:var(--red);color:#fff;box-shadow:0 10px 28px -10px rgba(225,22,42,.65)}
.btn-red:hover{background:var(--red-deep);transform:translateY(-2px)}
.btn-yellow{background:var(--yellow);color:#1a1303;box-shadow:0 10px 28px -10px rgba(255,214,10,.7)}
.btn-yellow:hover{background:var(--yellow-soft);transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.18)}
.btn-ghost:hover{background:rgba(255,255,255,.16);transform:translateY(-2px)}

/* ============ TOP UTILITY BAR ============ */
.topbar{
  background:var(--ink);color:#cfd6e8;
  font-size:.78rem;height:var(--topbar-h);
  display:flex;align-items:center;
  position:fixed;top:0;left:0;right:0;z-index:61;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.topbar-row{
  display:flex;align-items:center;gap:1rem;height:100%;
  justify-content:flex-end;
}
.tb-item{
  display:inline-flex;align-items:center;gap:.5rem;
  color:#cfd6e8;transition:color .2s;
}
.tb-item svg{width:14px;height:14px;color:var(--yellow)}
a.tb-item:hover{color:#fff}
.tb-sep{width:1px;height:14px;background:rgba(255,255,255,.14)}
.tb-item,
.tb-item *{white-space:nowrap}
.tb-show-md{display:none}
@media(max-width:1100px){
  .tb-hide-md{display:none}
  .tb-show-md{display:inline}
}
@media(max-width:820px){
  .tb-hide-sm{display:none}
  .topbar-row{justify-content:center;gap:.7rem}
  .topbar{font-size:.74rem}
}
@media(max-width:560px){
  .tb-sep,
  .tb-hide-md{display:none}
  /* On phones, keep topbar to ONE line: phone only */
  .tb-item:not(.tb-keep){display:none}
  .tb-item.tb-keep{display:inline-flex}
  .topbar-row{gap:.5rem;justify-content:center}
}

/* ============ NAV ============ */
header.nav{
  position:fixed;top:var(--topbar-h);left:0;right:0;z-index:60;
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  background:rgba(255,255,255,.74);
  border-bottom:1px solid transparent;
  transition:background .3s,border-color .3s,box-shadow .3s;
}
header.nav.scrolled{
  background:rgba(255,255,255,.94);
  border-bottom-color:var(--line);
  box-shadow:0 4px 20px -10px rgba(11,16,32,.12);
}
.nav-row{display:flex;align-items:center;justify-content:space-between;height:var(--nav-h);gap:1rem}
.brand{display:flex;align-items:center;gap:.7rem;font-weight:700}
.brand-mark{
  width:44px;height:44px;border-radius:11px;
  background:var(--yellow);
  display:grid;place-items:center;overflow:hidden;
  padding:5px;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.08), 0 6px 18px -6px rgba(255,214,10,.6);
  transition:transform .4s var(--ease-out);
  flex:none;
}
.brand:hover .brand-mark{transform:rotate(-8deg) scale(1.05)}
.brand-mark img{width:100%;height:100%;object-fit:contain}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-name{font-family:'Space Grotesk','Space Grotesk Fallback',sans-serif;font-size:1.18rem;letter-spacing:-.01em}
.brand-sub{font-size:.68rem;color:var(--muted);font-weight:500;letter-spacing:.06em;text-transform:uppercase;margin-top:2px}

nav.links{display:flex;gap:.2rem;align-items:center}
nav.links a{
  font-size:.92rem;font-weight:500;color:#2a3142;
  padding:.55rem .9rem;border-radius:8px;position:relative;
  transition:color .2s,background .2s;
}
nav.links a:hover{color:var(--blue);background:rgba(10,58,163,.06)}
nav.links a.active{color:var(--blue)}
nav.links a.active::after{
  content:"";position:absolute;left:50%;bottom:2px;
  width:18px;height:3px;background:var(--blue);border-radius:2px;
  transform:translateX(-50%);
}
.mobile-cta{display:none}

.nav-cta{display:flex;gap:.6rem;align-items:center}
.menu-toggle{
  display:none;background:none;border:0;cursor:pointer;padding:.5rem;color:var(--ink);
}
.menu-toggle svg{width:26px;height:26px}

@media(max-width:1040px){
  nav.links a{padding:.55rem .7rem;font-size:.88rem}
  .desktop-cta{padding:.85rem 1.1rem;font-size:.9rem}
}
@media(max-width:920px){
  header.nav{position:fixed}
  nav.links{
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;gap:.15rem;align-items:stretch;
    background:#fff;border-top:1px solid var(--line);
    padding:.9rem 1rem 1.2rem;transform:translateY(-130%);
    transition:transform .35s var(--ease-out);
    box-shadow:0 20px 40px -20px rgba(11,16,32,.2);
    max-height:calc(100vh - var(--nav-h));overflow-y:auto;
  }
  nav.links.open{transform:translateY(0)}
  nav.links a{padding:.85rem 1rem;border-radius:10px;width:100%;font-size:.98rem;line-height:1.2}
  nav.links a.btn-primary,
  nav.links a.btn-primary:hover{color:#fff;background:var(--blue)}
  nav.links a.btn-primary:hover{background:var(--blue-deep)}
  .menu-toggle{display:inline-flex}
  .desktop-cta{display:none}
  .mobile-cta{display:flex;justify-content:center;align-items:center;margin-top:.8rem;padding:1rem 1.4rem}
  .brand-sub{display:none}
}

/* ============ SECTIONS ============ */
section{padding:110px 0;position:relative}
section.tight{padding:64px 0}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:2.4rem;margin-bottom:54px;flex-wrap:wrap}
.section-head > div{max-width:760px}
h2.section-title{font-size:clamp(2rem,3.8vw,3rem);font-weight:700;margin:.7rem 0 .25rem;letter-spacing:-.025em}
.section-sub{color:var(--muted);max-width:62ch;font-size:1.06rem;margin:1rem 0 0;line-height:1.65}

/* ============ HERO ============ */
.hero{
  position:relative;overflow:hidden;
  padding:calc(var(--topbar-h) + var(--nav-h) + 70px) 0 110px;
  background:linear-gradient(180deg,#fbfcff 0%,#f4f6fc 100%);
}
.hero-bg{
  position:absolute;inset:0;pointer-events:none;z-index:0;
}
.hero-bg .blob{
  position:absolute;border-radius:50%;filter:blur(70px);opacity:.55;
  animation:float 14s ease-in-out infinite;
}
.hero-bg .blob.b1{width:560px;height:560px;background:rgba(10,58,163,.42);top:-180px;left:-200px}
.hero-bg .blob.b2{width:480px;height:480px;background:rgba(225,22,42,.25);top:-100px;right:-180px;animation-delay:-4s;animation-duration:18s}
.hero-bg .blob.b3{width:420px;height:420px;background:rgba(255,214,10,.4);bottom:-200px;left:30%;animation-delay:-8s;animation-duration:22s}
@keyframes float{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(30px,-40px) scale(1.06)}
}

.hero-bg .grid-overlay{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(11,16,32,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(11,16,32,.05) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,#000 50%,transparent 90%);
  -webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,#000 50%,transparent 90%);
}

.hero-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.18fr .85fr;gap:80px;align-items:center;
}
@media(max-width:980px){.hero-grid{grid-template-columns:1fr;gap:50px}}

.hero-title{
  font-size:clamp(2.6rem,5.6vw,4.8rem);
  margin:1.2rem 0 1.4rem;font-weight:700;
}
.hero-title .word{display:inline-block;overflow:hidden;vertical-align:bottom;margin-right:.18em}
.hero-title .word > span{
  display:inline-block;
  transform:translateY(110%);
  animation:rise .9s var(--ease-out) forwards;
}
.hero-title .accent-blue{color:var(--blue)}
.hero-title .accent-red{color:var(--red)}
.hero-title .accent-yellow{
  background:linear-gradient(135deg,var(--yellow-deep),var(--yellow));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  position:relative;
}
.hero-title .word:nth-child(1) > span{animation-delay:.05s}
.hero-title .word:nth-child(2) > span{animation-delay:.10s}
.hero-title .word:nth-child(3) > span{animation-delay:.15s}
.hero-title .word:nth-child(4) > span{animation-delay:.20s}
.hero-title .word:nth-child(5) > span{animation-delay:.25s}
.hero-title .word:nth-child(6) > span{animation-delay:.30s}
.hero-title .word:nth-child(7) > span{animation-delay:.35s}
.hero-title .word:nth-child(8) > span{animation-delay:.40s}
.hero-title .word:nth-child(9) > span{animation-delay:.45s}
@keyframes rise{
  to{transform:translateY(0)}
}

.hero p.lead{
  font-size:1.13rem;color:#3a4256;max-width:60ch;margin:0 0 1.8rem;
  opacity:0;transform:translateY(20px);
  animation:fade-up .9s var(--ease-out) .6s forwards;
}
.hero-cta{
  display:flex;flex-wrap:wrap;gap:.75rem;
  opacity:0;transform:translateY(20px);
  animation:fade-up .9s var(--ease-out) .75s forwards;
}
@keyframes fade-up{
  to{opacity:1;transform:none}
}

.capability-tags{
  list-style:none;padding:0;margin:1.8rem 0 0;
  display:flex;flex-wrap:wrap;gap:.5rem;
  opacity:0;transform:translateY(20px);
  animation:fade-up .9s var(--ease-out) .85s forwards;
}
.capability-tags li{
  font-size:.78rem;font-weight:600;letter-spacing:.05em;
  padding:.45rem .8rem;border-radius:999px;
  background:#fff;border:1px solid var(--line);color:var(--ink-3);
  box-shadow:var(--shadow-sm);
}

.hero-stats{
  margin-top:2.4rem;display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;
  border-top:1px solid var(--line);padding-top:1.8rem;max-width:620px;
  opacity:0;transform:translateY(20px);
  animation:fade-up .9s var(--ease-out) 1s forwards;
}
.stat-num{
  font-family:'Space Grotesk','Space Grotesk Fallback',Arial,sans-serif;font-size:1.9rem;font-weight:700;color:var(--ink);line-height:1;
  display:flex;align-items:baseline;gap:2px;
}
.stat-num .plus{color:var(--red);font-size:1.2rem}
.stat-lbl{font-size:.78rem;color:var(--muted);margin-top:.45rem;letter-spacing:.04em;line-height:1.4}

/* Hero visual / animated showcase */
.hero-visual{
  position:relative;aspect-ratio:1/1;max-width:520px;justify-self:end;width:100%;
  opacity:0;
  animation:fade-up 1.1s var(--ease-out) .35s forwards;
}
.hero-orbit{
  position:absolute;inset:0;
}
.hero-orbit .orbit-ring{
  position:absolute;inset:0;border:1px dashed rgba(10,58,163,.22);border-radius:50%;
  animation:spin 32s linear infinite;
}
.hero-orbit .orbit-ring.r2{inset:11%;border-color:rgba(225,22,42,.2);animation-duration:24s;animation-direction:reverse}
.hero-orbit .orbit-ring.r3{inset:22%;border-color:rgba(255,214,10,.5);animation-duration:18s}
@keyframes spin{to{transform:rotate(360deg)}}

.hero-card{
  position:absolute;inset:18%;border-radius:30px;overflow:hidden;
  background:linear-gradient(135deg,var(--yellow) 0%,var(--yellow-soft) 100%);
  box-shadow:var(--shadow-lg);
  display:grid;place-items:center;
  animation:float-card 6s ease-in-out infinite;
}
@keyframes float-card{
  0%,100%{transform:translateY(0) rotate(0)}
  50%{transform:translateY(-12px) rotate(-1.5deg)}
}
.hero-card::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.55), transparent 50%),
    radial-gradient(circle at 80% 80%, rgba(225,22,42,.18), transparent 45%);
}
.hero-card img{width:78%;height:auto;position:relative;z-index:2;filter:drop-shadow(0 8px 24px rgba(0,0,0,.18))}

.orbit-icon{
  position:absolute;width:66px;height:66px;border-radius:18px;
  background:#fff;box-shadow:var(--shadow);
  display:grid;place-items:center;color:var(--blue);
  animation:counter-spin 32s linear infinite;
}
.orbit-icon svg{width:28px;height:28px}
.orbit-icon.i1{top:0;left:50%;margin-left:-33px;color:var(--blue)}
.orbit-icon.i2{top:50%;right:0;margin-top:-33px;color:var(--red)}
.orbit-icon.i3{bottom:0;left:50%;margin-left:-33px;color:var(--yellow-deep)}
.orbit-icon.i4{top:50%;left:0;margin-top:-33px;color:var(--blue-bright)}
@keyframes counter-spin{to{transform:rotate(-360deg)}}

.badge-floating{
  position:absolute;background:#fff;border-radius:14px;padding:.85rem 1rem;
  box-shadow:var(--shadow);display:flex;align-items:center;gap:.7rem;font-weight:600;font-size:.86rem;z-index:5;
  animation:badge-pop .8s var(--ease-out) 1s backwards;
  border:1px solid var(--line);
}
.badge-tl{top:-12px;left:-16px;animation-delay:1.1s}
.badge-br{bottom:8px;right:-18px;animation-delay:1.3s}
.badge-bl{bottom:38%;left:-28px;animation-delay:1.5s}
@keyframes badge-pop{
  from{opacity:0;transform:scale(.6) translateY(20px)}
  to{opacity:1;transform:none}
}
.dot{width:9px;height:9px;border-radius:50%;background:var(--blue)}
.dot.red{background:var(--red);box-shadow:0 0 0 4px rgba(225,22,42,.15)}
.dot.green{background:#16a34a;box-shadow:0 0 0 4px rgba(22,163,74,.15)}
.dot.live{position:relative;background:#16a34a}
.dot.live::after{
  content:"";position:absolute;inset:-3px;border-radius:50%;background:#16a34a;opacity:.35;
  animation:pulse 1.6s ease-out infinite;
}

.scroll-cue{
  position:absolute;bottom:14px;left:50%;transform:translateX(-50%);
  font-size:.68rem;letter-spacing:.3em;color:var(--muted);
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  z-index:3;
}
.scroll-cue::after{
  content:"";width:1px;height:42px;
  background:linear-gradient(to bottom,var(--muted),transparent);
  animation:scroll-line 2s ease-in-out infinite;
}
@keyframes scroll-line{
  0%{transform:scaleY(0);transform-origin:top}
  50%{transform:scaleY(1);transform-origin:top}
  51%{transform:scaleY(1);transform-origin:bottom}
  100%{transform:scaleY(0);transform-origin:bottom}
}

@media(max-width:980px){
  .hero-visual{max-width:420px;justify-self:center}
}
@media(max-width:560px){
  .badge-bl{display:none}
  .hero-visual{max-width:340px}
}

/* ============ MARQUEE — TRUSTED BY ============ */
.trust-strip{
  background:#fff;border-block:1px solid var(--line);
  padding:42px 0;
}
.trust-strip h3{
  font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.24em;
  color:var(--muted);text-align:center;margin:0 0 1.8rem
}
.marquee{
  overflow:hidden;
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.marquee-track{
  display:flex;gap:3.5rem;align-items:center;
  animation:scroll-x 38s linear infinite;width:max-content;
  will-change:transform;
}
.marquee-track:hover{animation-play-state:paused}
.brand-logo{
  display:flex;align-items:center;justify-content:center;
  width:170px;height:64px;flex:none;
  padding:.4rem .6rem;
  filter:grayscale(100%);opacity:.6;
  transition:filter .3s,opacity .3s,transform .3s;
}
.brand-logo img{
  max-height:100%;max-width:100%;width:auto;height:auto;
  object-fit:contain;
  display:block;
}
.brand-logo:hover{filter:none;opacity:1;transform:scale(1.06)}
@keyframes scroll-x{
  to{transform:translateX(-50%)}
}

/* ============ WHY TECHNOSURE ============ */
.why-section{
  background:var(--bg-warm);position:relative;overflow:hidden;
}
.why-section::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(700px 400px at 100% 0%, rgba(255,214,10,.18), transparent 60%),
    radial-gradient(600px 400px at 0% 100%, rgba(10,58,163,.08), transparent 60%);
  pointer-events:none;
}
.why-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;
}
@media(max-width:1000px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.why-grid{grid-template-columns:1fr}}
.why-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.8rem 1.6rem;position:relative;overflow:hidden;
  transition:transform .35s var(--ease-out),box-shadow .35s,border-color .25s;
  display:flex;flex-direction:column;gap:.6rem;
}
.why-card::before{
  content:"";position:absolute;left:0;top:0;width:0;height:3px;
  background:linear-gradient(90deg,var(--blue),var(--red),var(--yellow));
  transition:width .5s var(--ease-out);
}
.why-card:hover::before{width:100%}
.why-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--line-2)}
.why-num{
  font-family:'Space Grotesk','Space Grotesk Fallback',Arial,sans-serif;font-size:.78rem;font-weight:700;
  color:var(--muted-2);letter-spacing:.16em;
}
.why-icon{
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,rgba(10,58,163,.12),rgba(10,58,163,.04));
  color:var(--blue);display:grid;place-items:center;
  margin:.4rem 0 .8rem;
  transition:transform .4s var(--ease-out);
}
.why-card:nth-child(2) .why-icon{background:linear-gradient(135deg,rgba(225,22,42,.14),rgba(225,22,42,.04));color:var(--red)}
.why-card:nth-child(3) .why-icon{background:linear-gradient(135deg,rgba(255,214,10,.28),rgba(255,214,10,.06));color:var(--yellow-deep)}
.why-card:nth-child(4) .why-icon{background:linear-gradient(135deg,rgba(31,93,214,.16),rgba(31,93,214,.04));color:var(--blue-bright)}
.why-card:hover .why-icon{transform:rotate(-8deg) scale(1.06)}
.why-icon svg{width:26px;height:26px}
.why-card h3{font-family:'Space Grotesk','Space Grotesk Fallback',Arial,sans-serif;font-size:1.18rem;margin:0;letter-spacing:-.01em}
.why-card p{margin:0;color:#475066;font-size:.95rem;line-height:1.6}

/* ============ ABOUT ============ */
.about-section{background:#fff}
.about-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
@media(max-width:900px){.about-grid{grid-template-columns:1fr}}
.value-card{
  background:var(--bg);border-radius:var(--radius);padding:2rem;
  border:1px solid var(--line);transition:transform .35s var(--ease-out),box-shadow .35s,border-color .35s;
  position:relative;overflow:hidden;
}
.value-card::before{
  content:"";position:absolute;inset:0;border-radius:var(--radius);
  background:radial-gradient(380px circle at var(--mx,50%) var(--my,0%), rgba(10,58,163,.08), transparent 60%);
  opacity:0;transition:opacity .4s;
  pointer-events:none;
}
.value-card:hover::before{opacity:1}
.value-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--line-2);background:#fff}
.value-card.red::before{background:radial-gradient(380px circle at var(--mx,50%) var(--my,0%), rgba(225,22,42,.08), transparent 60%)}
.value-card.yellow::before{background:radial-gradient(380px circle at var(--mx,50%) var(--my,0%), rgba(255,214,10,.18), transparent 60%)}
.value-card .num{
  font-family:'Space Grotesk','Space Grotesk Fallback',Arial,sans-serif;font-size:.85rem;font-weight:700;color:var(--muted);
  display:flex;align-items:center;gap:.6rem;margin-bottom:1.1rem;letter-spacing:.06em;
}
.value-card .num::before{content:"";width:28px;height:2px;background:var(--blue);transition:width .3s}
.value-card.red .num::before{background:var(--red)}
.value-card.yellow .num::before{background:var(--yellow);height:3px}
.value-card:hover .num::before{width:48px}
.value-card h3{font-family:'Space Grotesk','Space Grotesk Fallback',Arial,sans-serif;font-size:1.4rem;margin:.3rem 0 .65rem;letter-spacing:-.015em}
.value-card p{margin:0;color:#475066;font-size:.97rem;line-height:1.65}
.value-card .icon-wrap{
  width:48px;height:48px;border-radius:14px;
  background:linear-gradient(135deg,rgba(10,58,163,.12),rgba(10,58,163,.04));
  display:grid;place-items:center;color:var(--blue);
  margin-bottom:1.2rem;
}
.value-card.red .icon-wrap{background:linear-gradient(135deg,rgba(225,22,42,.12),rgba(225,22,42,.04));color:var(--red)}
.value-card.yellow .icon-wrap{background:linear-gradient(135deg,rgba(255,214,10,.25),rgba(255,214,10,.05));color:var(--yellow-deep)}
.value-card .icon-wrap svg{width:24px;height:24px}

/* ============ SERVICES ============ */
.services-bg{
  background:var(--ink);color:#e9edf7;position:relative;overflow:hidden;
}
.services-bg::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(900px 600px at 100% 0%, rgba(10,58,163,.55), transparent 60%),
    radial-gradient(800px 500px at 0% 100%, rgba(225,22,42,.30), transparent 60%);
  pointer-events:none;
}
.services-bg::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:54px 54px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,#000 30%,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,#000 30%,transparent 80%);
}
.services-bg .section-sub{color:#a8b1c8}
.services-bg h2{color:#fff}
.services-bg .eyebrow{background:rgba(255,214,10,.14);color:var(--yellow)}
.services-bg .section-head{align-items:flex-end}
.services{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;z-index:2}
@media(max-width:1000px){.services{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.services{grid-template-columns:1fr}}
.svc{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;padding:1.7rem 1.6rem 1.5rem;
  transition:transform .35s var(--ease-out),background .25s,border-color .25s;
  position:relative;overflow:hidden;
  cursor:pointer;
}
.svc::before{
  content:"";position:absolute;inset:0;border-radius:18px;padding:1px;
  background:linear-gradient(135deg,transparent,rgba(255,214,10,.5),transparent);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .3s;
}
.svc:hover{
  background:rgba(255,255,255,.07);
  transform:translateY(-6px);
}
.svc:hover::before{opacity:1}
.svc-icon{
  width:54px;height:54px;border-radius:14px;
  background:linear-gradient(135deg,var(--blue),var(--blue-bright));
  display:grid;place-items:center;color:#fff;margin-bottom:1.1rem;
  transition:transform .4s var(--ease-out);
}
.svc:hover .svc-icon{transform:rotate(-6deg) scale(1.08)}
.svc:nth-child(2n) .svc-icon{background:linear-gradient(135deg,var(--red),#ff4055)}
.svc:nth-child(3n) .svc-icon{background:linear-gradient(135deg,var(--yellow-deep),var(--yellow));color:#1a1303}
.svc-icon svg,.svc-icon img{width:28px;height:28px}
.svc h4{font-family:'Space Grotesk','Space Grotesk Fallback',Arial,sans-serif;font-size:1.14rem;margin:0 0 .5rem;color:#fff;letter-spacing:-.01em}
.svc p{margin:0;color:#a8b1c8;font-size:.92rem;line-height:1.6}
.svc .arrow{
  margin-top:1.2rem;color:var(--yellow);font-size:.74rem;letter-spacing:.16em;font-weight:600;
  text-transform:uppercase;display:inline-flex;align-items:center;gap:.4rem;
  opacity:.75;transition:opacity .25s,gap .25s;
}
.svc .arrow svg{width:14px;height:14px}
.svc:hover .arrow{opacity:1;gap:.7rem}

/* ============ PROCESS ============ */
.process-section{
  background:linear-gradient(180deg,#fff 0%,var(--bg) 100%);
  position:relative;overflow:hidden;
}
.process-section::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(90deg,transparent 49.5%,rgba(10,58,163,.06) 49.5%,rgba(10,58,163,.06) 50.5%,transparent 50.5%);
  pointer-events:none;mask-image:radial-gradient(ellipse 60% 40% at 50% 60%,#000,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 60% 40% at 50% 60%,#000,transparent 80%);
}
.process-grid{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;
  position:relative;z-index:1;
  counter-reset:step;
}
@media(max-width:1000px){.process-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.process-grid{grid-template-columns:1fr}}
.step{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.8rem;position:relative;overflow:hidden;
  transition:transform .35s var(--ease-out),box-shadow .35s,border-color .25s;
}
.step:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--line-2)}
.step::after{
  content:"";position:absolute;right:-1px;top:50%;width:24px;height:1px;
  background:var(--line-2);
}
.step:last-child::after{display:none}
@media(max-width:1000px){.step::after{display:none}}
.step-num{
  font-family:'Space Grotesk','Space Grotesk Fallback',Arial,sans-serif;font-size:2.6rem;font-weight:700;
  background:linear-gradient(135deg,var(--blue),var(--red));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  line-height:1;margin-bottom:1rem;letter-spacing:-.04em;
}
.step h4{font-family:'Space Grotesk','Space Grotesk Fallback',Arial,sans-serif;font-size:1.3rem;margin:0 0 .55rem;letter-spacing:-.015em}
.step > p{margin:0 0 1rem;color:#475066;font-size:.95rem;line-height:1.6}
.step-bullets{
  list-style:none;padding:0;margin:.8rem 0 0;border-top:1px solid var(--line);padding-top:.9rem;
}
.step-bullets li{
  font-size:.86rem;color:#475066;padding:.3rem 0;
  display:flex;align-items:center;gap:.55rem;
}
.step-bullets li::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--red));flex:none;
}

/* ============ SHOWCASE ============ */
.showcase{
  background:linear-gradient(135deg,var(--blue-deep) 0%,var(--blue) 60%,var(--blue-bright) 100%);
  color:#fff;border-radius:var(--radius-xl);padding:3.6rem;
  display:grid;grid-template-columns:1.05fr .95fr;gap:2.6rem;align-items:center;
  overflow:hidden;position:relative;
}
.showcase::after{
  content:"";position:absolute;right:-120px;top:-100px;width:420px;height:420px;
  background:var(--yellow);border-radius:50%;opacity:.22;filter:blur(50px);pointer-events:none;
  animation:float 14s ease-in-out infinite;
}
.showcase::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:40px 40px;
  mask-image:radial-gradient(ellipse 80% 80% at 0% 50%,#000,transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse 80% 80% at 0% 50%,#000,transparent 70%);
  pointer-events:none;
}
@media(max-width:900px){.showcase{grid-template-columns:1fr;padding:2rem}}
.showcase-copy{position:relative;z-index:1}
.showcase h2{color:#fff;margin:.6rem 0 1rem}
.showcase p{color:#cfd9ff;margin:0 0 1.7rem;max-width:50ch;font-size:1.02rem;line-height:1.65}
.showcase-cta{display:flex;flex-wrap:wrap;gap:.7rem}
.showcase-media{position:relative;z-index:1;min-width:0}
.showcase-img{
  display:block;width:100%;height:auto;
  border-radius:20px;
  border:6px solid #fff;
  transform:rotate(1.5deg);
  box-shadow:0 30px 60px -20px rgba(0,0,0,.5);
  transition:transform .4s var(--ease-out);
}
.showcase:hover .showcase-img{transform:rotate(0)}
.showcase .eyebrow{background:rgba(255,214,10,.18);color:var(--yellow)}

/* ============ CLIENTS ============ */
.clients-section{
  background:linear-gradient(180deg,#fff 0%, #f4f6fb 100%);
}

/* Highlight ribbon */
.client-highlights{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1rem;margin:0 0 3rem;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:2rem;box-shadow:var(--shadow-sm);
  position:relative;overflow:hidden;
}
.client-highlights::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(700px 220px at 50% -50%, rgba(10,58,163,.10), transparent 70%);
  pointer-events:none;
}
@media(max-width:760px){.client-highlights{grid-template-columns:repeat(2,1fr);gap:1.4rem}}
.hl-stat{
  text-align:center;padding:.5rem .25rem;position:relative;z-index:1;
  border-right:1px solid var(--line);
}
.hl-stat:last-child{border-right:0}
@media(max-width:760px){
  .hl-stat{border-right:0;border-bottom:1px solid var(--line);padding:1rem .25rem}
  .hl-stat:nth-last-child(-n+2){border-bottom:0;padding-bottom:.25rem}
  .hl-stat:nth-child(-n+2){padding-top:.25rem}
}
.hl-num{
  font-family:'Space Grotesk','Space Grotesk Fallback',Arial,sans-serif;font-size:clamp(2rem,4vw,2.7rem);font-weight:700;
  background:linear-gradient(135deg,var(--blue),var(--red));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  line-height:1;display:inline-flex;align-items:baseline;gap:2px;letter-spacing:-.03em;
}
.hl-num .plus{color:var(--red);font-size:.7em;-webkit-text-fill-color:currentColor}
.hl-lbl{
  font-size:.76rem;font-weight:600;color:var(--muted);
  margin-top:.55rem;letter-spacing:.08em;text-transform:uppercase;
}

/* Featured wordmarks */
.client-featured{
  margin:0 0 3rem;padding:2.4rem;border-radius:var(--radius-lg);
  background:linear-gradient(135deg,var(--ink) 0%,var(--ink-2) 100%);
  position:relative;overflow:hidden;color:#fff;
}
.client-featured::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(500px 300px at 0% 0%, rgba(10,58,163,.4), transparent 60%),
    radial-gradient(500px 300px at 100% 100%, rgba(225,22,42,.25), transparent 60%);
  pointer-events:none;
}
.cf-label{
  font-size:.74rem;font-weight:700;letter-spacing:.2em;
  text-transform:uppercase;color:var(--yellow);margin-bottom:1.4rem;
  display:flex;align-items:center;gap:.6rem;position:relative;z-index:1;
}
.cf-label::before{
  content:"";width:24px;height:2px;background:var(--yellow);
}
.cf-wordmarks{
  display:flex;flex-wrap:wrap;gap:.65rem;position:relative;z-index:1;
}
.cf-wordmarks span{
  display:inline-flex;align-items:center;
  padding:.6rem 1rem;border-radius:10px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  font-family:'Space Grotesk','Space Grotesk Fallback',Arial,sans-serif;font-weight:600;font-size:.92rem;
  color:rgba(255,255,255,.92);letter-spacing:.005em;
  transition:transform .25s,background .25s,border-color .25s,color .25s;
}
.cf-wordmarks span:hover{
  transform:translateY(-2px);
  background:rgba(255,214,10,.16);
  border-color:rgba(255,214,10,.45);
  color:var(--yellow);
}

/* Category cards */
.clients-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
@media(max-width:1100px){.clients-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.clients-grid{grid-template-columns:1fr}}
.client-cat{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.8rem;transition:transform .35s var(--ease-out),box-shadow .35s,border-color .25s;
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;
}
.client-cat::before{
  content:"";position:absolute;left:0;top:0;height:4px;width:0;
  background:linear-gradient(90deg,var(--blue),var(--red));
  transition:width .5s var(--ease-out);
}
.client-cat:hover::before{width:100%}
.client-cat:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--line-2)}

.cc-head{
  display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;
}
.client-cat .ic{
  width:46px;height:46px;border-radius:12px;background:rgba(10,58,163,.1);
  color:var(--blue);display:grid;place-items:center;
  transition:transform .4s var(--ease-out);
}
.client-cat:hover .ic{transform:rotate(-8deg) scale(1.06)}
.client-cat[data-cat="bank"] .ic,
.client-cat[data-cat="auto"] .ic,
.client-cat[data-cat="industry"] .ic{background:rgba(225,22,42,.09);color:var(--red)}
.client-cat[data-cat="health"] .ic,
.client-cat[data-cat="retail"] .ic{background:rgba(255,214,10,.20);color:#8a6e00}
.client-cat[data-cat="logistics"] .ic{background:rgba(10,58,163,.1);color:var(--blue-bright)}
.client-cat .ic svg{width:22px;height:22px}

.cc-count{
  font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  padding:.35rem .65rem;border-radius:999px;
  background:rgba(10,58,163,.08);color:var(--blue);
  white-space:nowrap;
}
.client-cat[data-cat="bank"] .cc-count,
.client-cat[data-cat="auto"] .cc-count,
.client-cat[data-cat="industry"] .cc-count{background:rgba(225,22,42,.09);color:var(--red)}
.client-cat[data-cat="health"] .cc-count,
.client-cat[data-cat="retail"] .cc-count{background:rgba(255,214,10,.22);color:#8a6e00}

.client-cat h4{font-family:'Space Grotesk','Space Grotesk Fallback',Arial,sans-serif;margin:0 0 .55rem;font-size:1.18rem;letter-spacing:-.01em}
.cc-blurb{
  font-size:.9rem;color:#475066;margin:0 0 1rem;line-height:1.55;
  padding-bottom:1rem;border-bottom:1px solid var(--line);
}
.client-cat ul{padding:0;margin:0;list-style:none;font-size:.88rem;color:#475066}
.client-cat ul li{
  padding:.34rem 0;
  display:flex;align-items:flex-start;gap:.55rem;line-height:1.5;
}
.client-cat ul li::before{
  content:"";width:5px;height:5px;border-radius:50%;
  background:var(--blue);margin-top:.55rem;flex:none;opacity:.6;
}
.client-cat[data-cat="bank"] ul li::before,
.client-cat[data-cat="auto"] ul li::before,
.client-cat[data-cat="industry"] ul li::before{background:var(--red)}
.client-cat[data-cat="health"] ul li::before,
.client-cat[data-cat="retail"] ul li::before{background:var(--yellow);opacity:1}

/* ============ CTA BAND ============ */
.cta-band{
  background:linear-gradient(135deg,var(--yellow) 0%, var(--yellow-soft) 100%);
  border-radius:var(--radius-xl);padding:3.6rem;
  display:grid;grid-template-columns:1.4fr auto;align-items:center;
  gap:2rem;position:relative;overflow:hidden;
}
@media(max-width:820px){.cta-band{grid-template-columns:1fr;padding:2.2rem}}
.cta-band::before{
  content:"";position:absolute;right:-80px;bottom:-80px;width:340px;height:340px;
  background:rgba(225,22,42,.18);border-radius:50%;filter:blur(40px);
}
.cta-band::after{
  content:"";position:absolute;left:-60px;top:-60px;width:240px;height:240px;
  background:rgba(10,58,163,.18);border-radius:50%;filter:blur(50px);
}
.cta-band > *{position:relative;z-index:1}
.cta-band .eyebrow{background:rgba(11,16,32,.08);color:var(--ink)}
.cta-band h2{font-family:'Space Grotesk','Space Grotesk Fallback',Arial,sans-serif;margin:.8rem 0 .6rem;font-size:clamp(1.7rem,3.2vw,2.4rem);max-width:24ch;color:#1a1303;letter-spacing:-.02em;line-height:1.1}
.cta-band p{margin:0;color:#3d3308;max-width:52ch}
.cta-actions{display:flex;flex-wrap:wrap;gap:.7rem;align-items:center}

/* ============ DISTRIBUTION / BRAND PORTFOLIO ============ */
.distribution-section{
  background:linear-gradient(180deg,var(--bg) 0%,#fff 100%);
  position:relative;overflow:hidden;
}
.distribution-section::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(700px 360px at 100% 0%, rgba(225,22,42,.08), transparent 60%),
    radial-gradient(600px 320px at 0% 100%, rgba(255,214,10,.10), transparent 60%);
  pointer-events:none;
}
.dist-tier{
  position:relative;z-index:1;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:2.4rem;margin-bottom:1.4rem;box-shadow:var(--shadow-sm);
}
.dist-tier--primary{
  background:linear-gradient(135deg,var(--ink) 0%,var(--ink-2) 100%);
  border-color:transparent;color:#fff;
  position:relative;overflow:hidden;
}
.dist-tier--primary::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(500px 280px at 0% 0%, rgba(225,22,42,.35), transparent 60%),
    radial-gradient(500px 280px at 100% 100%, rgba(255,214,10,.18), transparent 60%);
  pointer-events:none;
}
.dist-tier-head{margin-bottom:1.6rem;position:relative;z-index:1}
.dist-tier-tag{
  display:inline-block;font-size:.72rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.18em;
  padding:.45rem .85rem;border-radius:999px;margin-bottom:.9rem;
  background:rgba(225,22,42,.10);color:var(--red);
}
.dist-tier--primary .dist-tier-tag{
  background:rgba(255,214,10,.18);color:var(--yellow);
}
.dist-tier-tag--secondary{background:rgba(10,58,163,.10);color:var(--blue)}
.dist-tier-blurb{
  font-size:1rem;line-height:1.6;margin:0;max-width:62ch;color:var(--muted);
}
.dist-tier--primary .dist-tier-blurb{color:#cfd9ff}
.dist-tier-cluster{margin-top:1.6rem;position:relative;z-index:1}
.dist-tier-cluster:first-of-type{margin-top:0}
.dist-cluster-title{
  font-family:'Space Grotesk','Space Grotesk Fallback',sans-serif;
  font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);margin:0 0 .9rem;
}
.dist-brand-grid{
  list-style:none;padding:0;margin:0;position:relative;z-index:1;
  display:grid;gap:.7rem;
  grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
}
.dist-brand-grid--primary{
  grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
}
.dist-brand{
  display:flex;align-items:center;justify-content:center;
  padding:1rem 1rem;border-radius:14px;
  background:#fff;border:1px solid var(--line);
  font-family:'Space Grotesk','Space Grotesk Fallback',sans-serif;
  font-weight:700;font-size:1rem;letter-spacing:-.005em;color:var(--ink);
  transition:transform .25s var(--ease-out),border-color .25s,box-shadow .25s,background .25s;
  text-align:center;
}
.dist-brand:hover{
  transform:translateY(-3px);border-color:var(--line-2);
  box-shadow:var(--shadow-sm);background:var(--bg);
}
.dist-tier--primary .dist-brand{
  background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12);color:#fff;
  font-size:1.1rem;padding:1.2rem 1rem;
}
.dist-tier--primary .dist-brand:hover{
  background:rgba(255,214,10,.16);border-color:rgba(255,214,10,.5);color:var(--yellow);
  transform:translateY(-3px);
}

/* ============ CONTACT / BRANCHES ============ */
.contact-section{background:#fff}

/* Balanced 5-card layout: 3 on top, 2 centered below */
.branches{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:1.4rem;
}
.branch{grid-column:span 2}
.branch:nth-child(4){grid-column:2 / span 2}
.branch:nth-child(5){grid-column:4 / span 2}

/* Tablet: 2 wide → 2+2+1 with the orphan centered */
@media(max-width:1100px){
  .branches{grid-template-columns:repeat(4,1fr)}
  .branch{grid-column:span 2}
  .branch:nth-child(4){grid-column:auto}
  .branch:nth-child(5){grid-column:2 / span 2}
}

/* Mobile: single column */
@media(max-width:640px){
  .branches{grid-template-columns:1fr}
  .branch,
  .branch:nth-child(4),
  .branch:nth-child(5){grid-column:auto}
}
.branch.hub-cebu::before{background:linear-gradient(to bottom,#16a34a,#22c55e)}
.branch.hub-davao::before{background:linear-gradient(to bottom,var(--yellow-deep),var(--yellow))}
.branch.hub-manila::before{background:linear-gradient(to bottom,#7c3aed,#a78bfa)}
.branch.hub-cebu .tag{color:#0f7a36;background:rgba(22,163,74,.10)}
.branch.hub-davao .tag{color:var(--yellow-deep);background:rgba(255,214,10,.18)}
.branch.hub-manila .tag{color:#5b21b6;background:rgba(124,58,237,.10)}
.branch.hub-cebu .tag .dot{background:#16a34a}
.branch.hub-davao .tag .dot{background:var(--yellow-deep)}
.branch.hub-manila .tag .dot{background:#7c3aed}
.branch.hub-cebu address svg{color:#16a34a}
.branch.hub-davao address svg{color:var(--yellow-deep)}
.branch.hub-manila address svg{color:#7c3aed}
.branch.soon{
  background:linear-gradient(135deg,#f8f5ff 0%,#fff 100%);
  border-color:rgba(124,58,237,.18);
  position:relative;
}
.branch.soon::after{
  content:"COMING SOON";
  position:absolute;top:1.4rem;right:1.4rem;
  font-size:.62rem;font-weight:700;letter-spacing:.18em;
  padding:.3rem .55rem;border-radius:999px;
  background:rgba(124,58,237,.12);color:#5b21b6;
}
.tag-soon{font-style:italic}
.branch{
  background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);
  padding:2.2rem;position:relative;overflow:hidden;
  transition:transform .35s var(--ease-out),box-shadow .35s,border-color .25s,background .25s;
}
.branch:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-2);background:#fff}
.branch::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:6px;
  background:linear-gradient(to bottom,var(--blue),var(--blue-bright));
}
.branch.bacolod::before{background:linear-gradient(to bottom,var(--red),#ff4055)}
.branch .tag{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.7rem;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--blue);margin-bottom:.9rem;
  background:rgba(10,58,163,.08);padding:.4rem .8rem;border-radius:999px;
}
.branch.bacolod .tag{color:var(--red);background:rgba(225,22,42,.08)}
.branch h3{font-family:'Space Grotesk','Space Grotesk Fallback',Arial,sans-serif;font-size:1.5rem;margin:0 0 .6rem;letter-spacing:-.02em}
.branch address{
  font-style:normal;color:#475066;margin-bottom:1.4rem;font-size:.96rem;
  display:flex;gap:.55rem;align-items:flex-start;line-height:1.6;
}
.branch address svg{flex:none;color:var(--blue);margin-top:.2rem}
.branch.bacolod address svg{color:var(--red)}
.contact-row{display:flex;flex-wrap:wrap;gap:.6rem;font-size:.92rem}
.contact-row a{
  display:inline-flex;align-items:center;gap:.45rem;padding:.6rem .9rem;
  border-radius:9px;background:#fff;color:#1f2940;font-weight:600;
  border:1px solid var(--line);
  transition:transform .2s,background .2s,color .2s,border-color .2s;
}
.branch:hover .contact-row a{background:#f1f3f9}
.contact-row a:hover{background:var(--ink) !important;color:#fff;transform:translateY(-2px);border-color:var(--ink)}
.contact-row a svg{width:16px;height:16px}

/* ============ FOOTER ============ */
footer{background:var(--ink);color:#a8b1c8;padding:84px 0 32px;margin-top:0;position:relative;overflow:hidden}
footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--blue),var(--yellow),var(--red));
}
footer::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(700px 400px at 100% 0%, rgba(10,58,163,.18), transparent 60%);
  pointer-events:none;
}
.footer-top{
  display:grid;grid-template-columns:1.3fr 2fr;gap:3rem;position:relative;z-index:1;
}
@media(max-width:900px){.footer-top{grid-template-columns:1fr}}
.footer-pitch{max-width:420px}
.footer-blurb{font-size:.94rem;line-height:1.65;margin:0 0 1.2rem;color:#a8b1c8}
.footer-cols{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.8rem;
}
@media(max-width:780px){.footer-cols{grid-template-columns:repeat(2,1fr);gap:1.6rem}}
@media(max-width:420px){.footer-cols{grid-template-columns:1fr}}
footer h5{font-family:'Space Grotesk','Space Grotesk Fallback',Arial,sans-serif;color:#fff;font-size:.95rem;margin:0 0 1.1rem;letter-spacing:-.005em}
footer ul{list-style:none;padding:0;margin:0}
footer ul li{padding:.32rem 0;font-size:.88rem;transition:color .2s}
footer ul li a{transition:color .2s}
footer ul li a:hover{color:var(--yellow)}
.footer-brand{display:flex;align-items:center;gap:.85rem;margin-bottom:1.1rem}
.footer-brand .brand-mark{width:48px;height:48px}
.footer-brand .brand-name{color:#fff;font-family:'Space Grotesk','Space Grotesk Fallback',Arial,sans-serif;font-size:1.18rem;letter-spacing:-.01em}
.footer-brand .brand-sub{font-size:.7rem;color:var(--muted-2);font-weight:500;letter-spacing:.06em;text-transform:uppercase;margin-top:2px}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);margin-top:48px;padding-top:24px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.82rem;color:#6c7691;
  position:relative;z-index:1;
}
.social{display:flex;gap:.55rem}
.social a{
  width:38px;height:38px;border-radius:10px;display:grid;place-items:center;
  background:rgba(255,255,255,.06);color:#fff;
  transition:background .25s,transform .25s,color .25s;
}
.social a:hover{background:var(--yellow);color:var(--ink);transform:translateY(-2px)}
.social svg{width:16px;height:16px}

/* ============ ICONS ============ */
.ico{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.svc-icon .ico,.svc-icon img{width:28px;height:28px}
.value-card .icon-wrap .ico{width:24px;height:24px}
.client-cat .ic .ico{width:18px;height:18px}

/* ============ REVEAL / SCROLL ANIMATIONS ============ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease-out), transform .9s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal-stagger > *{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease-out), transform .8s var(--ease-out)}
.reveal-stagger.in > *{opacity:1;transform:none}
.reveal-stagger.in > *:nth-child(1){transition-delay:.05s}
.reveal-stagger.in > *:nth-child(2){transition-delay:.10s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.15s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.20s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.25s}
.reveal-stagger.in > *:nth-child(6){transition-delay:.30s}
.reveal-stagger.in > *:nth-child(7){transition-delay:.35s}
.reveal-stagger.in > *:nth-child(8){transition-delay:.40s}

/* Back-to-top */
.to-top{
  position:fixed;right:24px;bottom:24px;z-index:55;
  width:48px;height:48px;border-radius:14px;
  background:var(--ink);color:#fff;display:grid;place-items:center;
  box-shadow:var(--shadow);
  opacity:0;transform:translateY(20px);pointer-events:none;
  transition:opacity .3s,transform .3s,background .2s;
}
.to-top.show{opacity:1;transform:none;pointer-events:auto}
.to-top:hover{background:var(--blue)}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
}
