/* ============================================================
   TANJER INFO SYSTEMS — V2 Design System
   Logo Colors: Navy #2B3A67 · Orange #E8882F
   Zero whitespace · Diagonal transitions · Bento grid
   ============================================================ */

/* ── Tokens ────────────────────────────────────────────────── */
:root {
  --navy:        #2B3A67;
  --navy-dark:   #1A2544;
  --navy-deep:   #111C36;
  --navy-light:  #3D5A80;
  --navy-100:    #E8ECF3;
  --navy-200:    #C5CDDE;

  --orange:      #E8882F;
  --orange-dark: #D47620;
  --orange-light:#F5A54B;
  --orange-glow: rgba(232,136,47,0.25);
  --orange-100:  #FFF0E0;

  --cream:       #FFF9F2;
  --cream-dark:  #F0E6D9;
  --white:       #FFFFFF;
  --black:       #0A0E1A;

  --text:        #1A1A2E;
  --text-mid:    #4A5568;
  --text-light:  #7A8599;

  --font:        'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --font-display:'Space Grotesk', var(--font);

  --ease:        cubic-bezier(.4,0,.2,1);
  --radius:      14px;
  --radius-sm:   8px;
  --radius-full: 100px;
}

/* ── Reset ─────────────────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:var(--font);font-size:16px;line-height:1.7;color:var(--text);background:var(--navy-deep);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);line-height:1.15;font-weight:800}
button{font-family:var(--font)}

/* ── Utility ───────────────────────────────────────────────── */
.container-lg{max-width:1300px;margin:0 auto;padding:0 32px}
.text-white{color:var(--white)!important}
.text-orange{color:var(--orange)!important}
.text-white-80{color:rgba(255,255,255,.7)!important}
.bg-cream{background:var(--cream)}
.bg-navy{background:var(--navy)}
.bg-navy-deep{background:var(--navy-deep)}
.bg-cream-full{background:var(--cream)}
.bg-orange-gradient{background:linear-gradient(135deg,var(--orange) 0%,var(--orange-dark) 100%)}

/* ── Diagonal angle dividers ──────────────────────────────── */
.angle-bottom{
  position:absolute;bottom:-1px;left:0;right:0;height:80px;z-index:2;
}
.angle-navy{
  background:var(--navy-deep);
  clip-path:polygon(0 100%,100% 0,100% 100%,0 100%);
}
.angle-cream{
  background:var(--cream);
  clip-path:polygon(0 100%,100% 0,100% 100%,0 100%);
}
.angle-orange{
  background:var(--orange);
  clip-path:polygon(0 100%,100% 0,100% 100%,0 100%);
}

/* ── Label tags ────────────────────────────────────────────── */
.label-tag{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 18px;border-radius:var(--radius-full);
  font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  background:var(--navy);color:var(--white);margin-bottom:18px;
}
.label-tag.tag-dark{background:rgba(255,255,255,.08);color:var(--orange-light);border:1px solid rgba(255,255,255,.1)}
.label-tag.tag-on-orange{background:rgba(255,255,255,.2);color:var(--white)}

/* ── Headings ──────────────────────────────────────────────── */
.heading-xl{font-size:clamp(2rem,4.5vw,3.4rem);letter-spacing:-.03em;margin-bottom:16px}
.sub-text{font-size:1.1rem;color:rgba(255,255,255,.6);max-width:640px;margin:0 auto}
.sub-text-dark{font-size:1.1rem;color:var(--text-mid);max-width:640px;margin:0 auto}

/* ── Buttons ───────────────────────────────────────────────── */
.btn-fill{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 36px;border-radius:var(--radius);
  font-weight:700;font-size:.95rem;color:var(--white);
  background:var(--orange);border:none;cursor:pointer;
  transition:all .3s var(--ease);
  box-shadow:0 6px 24px var(--orange-glow);
}
.btn-fill:hover{transform:translateY(-3px);box-shadow:0 10px 32px var(--orange-glow);background:var(--orange-dark)}
.btn-fill.btn-navy{background:var(--navy);box-shadow:0 6px 24px rgba(43,58,103,.3)}
.btn-fill.btn-navy:hover{background:var(--navy-dark)}
.btn-fill.btn-orange-solid{background:var(--orange);width:100%}

.btn-ghost{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 36px;border-radius:var(--radius);
  font-weight:700;font-size:.95rem;color:var(--white);
  background:transparent;border:2px solid rgba(255,255,255,.25);
  cursor:pointer;transition:all .3s var(--ease);
}
.btn-ghost:hover{border-color:rgba(255,255,255,.5);background:rgba(255,255,255,.06);transform:translateY(-3px)}

/* ══════════════════════════════════════════════════════════════
   TOPBAR — WHITE so logo colors pop
   ══════════════════════════════════════════════════════════════ */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:var(--white);
  transition:all .3s var(--ease);
  border-bottom:1px solid transparent;
}
.topbar.scrolled{
  box-shadow:0 2px 24px rgba(0,0,0,.08);
  border-bottom-color:var(--navy-100);
}
.topbar-inner{
  max-width:1400px;margin:0 auto;padding:0 32px;
  display:flex;align-items:center;justify-content:space-between;
  height:78px;transition:height .3s var(--ease);
}
.topbar.scrolled .topbar-inner{height:64px}

/* Brand logo */
.brand-img{height:52px;width:auto;transition:height .3s var(--ease)}
.topbar.scrolled .brand-img{height:40px}

.nav-list{display:flex;gap:4px}
.nav-item{
  padding:8px 16px;color:var(--navy);font-weight:600;font-size:.88rem;
  border-radius:var(--radius-sm);transition:all .2s var(--ease);
}
.nav-item:hover,.nav-item.active{
  background:var(--navy);color:var(--white);
}

.cta-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 28px;border-radius:var(--radius-full);
  background:var(--orange);color:var(--white);font-weight:700;font-size:.88rem;
  transition:all .3s var(--ease);
  box-shadow:0 4px 16px var(--orange-glow);
}
.cta-btn:hover{background:var(--orange-dark);transform:translateY(-2px);box-shadow:0 6px 20px var(--orange-glow)}

.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:6px;flex-direction:column;gap:5px;z-index:1100}
.menu-toggle span{display:block;width:26px;height:2.5px;background:var(--navy);border-radius:2px;transition:all .3s var(--ease)}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ══════════════════════════════════════════════════════════════
   HERO — Full navy, floating diamonds
   ══════════════════════════════════════════════════════════════ */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(160deg,var(--navy-deep) 0%,var(--navy-dark) 40%,var(--navy) 100%);
  padding:120px 32px 120px;overflow:hidden;
}
.hero-decor{position:absolute;inset:0;overflow:hidden;pointer-events:none}

.diamond{
  position:absolute;border:2px solid rgba(232,136,47,.15);
  transform:rotate(45deg);border-radius:6px;
}
.diamond-1{width:200px;height:200px;top:10%;left:5%;animation:drift 18s ease-in-out infinite}
.diamond-2{width:120px;height:120px;top:60%;right:8%;border-color:rgba(232,136,47,.1);animation:drift 22s ease-in-out infinite reverse}
.diamond-3{width:80px;height:80px;top:25%;right:25%;border-color:rgba(255,255,255,.06);animation:drift 15s ease-in-out infinite}
.diamond-4{width:300px;height:300px;bottom:5%;left:50%;border-color:rgba(255,255,255,.03);animation:drift 25s ease-in-out infinite reverse}

.hero-glow{
  position:absolute;width:500px;height:500px;top:40%;left:50%;transform:translate(-50%,-50%);
  background:radial-gradient(circle,var(--orange-glow) 0%,transparent 70%);
  filter:blur(40px);
}

@keyframes drift{
  0%,100%{transform:rotate(45deg) translate(0,0)}
  33%{transform:rotate(45deg) translate(20px,-20px)}
  66%{transform:rotate(45deg) translate(-15px,15px)}
}

.hero-inner{position:relative;z-index:3;text-align:center;max-width:860px}
.hero-overline{
  display:inline-block;padding:8px 22px;border-radius:var(--radius-full);
  background:rgba(232,136,47,.12);color:var(--orange-light);
  font-size:.85rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  margin-bottom:28px;border:1px solid rgba(232,136,47,.2);
}
.hero-heading{
  font-size:clamp(2.6rem,6.5vw,5rem);color:var(--white);
  letter-spacing:-.04em;margin-bottom:24px;
}
.hero-sub{
  font-size:clamp(1rem,1.8vw,1.2rem);color:rgba(255,255,255,.55);
  max-width:620px;margin:0 auto 40px;line-height:1.8;
}
.hero-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ══════════════════════════════════════════════════════════════
   TICKER — Full orange bar
   ══════════════════════════════════════════════════════════════ */
.ticker{
  background:var(--orange);padding:28px 0;position:relative;z-index:3;
}
.ticker-track{
  display:flex;align-items:center;justify-content:center;gap:36px;
  flex-wrap:wrap;max-width:1300px;margin:0 auto;padding:0 24px;
}
.ticker-item{text-align:center}
.ticker-num{display:block;font-family:var(--font-display);font-size:1.8rem;font-weight:800;color:var(--white)}
.ticker-label{font-size:.78rem;color:rgba(255,255,255,.8);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.ticker-sep{color:rgba(255,255,255,.3);font-size:.7rem}

/* ══════════════════════════════════════════════════════════════
   SPLIT SECTION (About)
   ══════════════════════════════════════════════════════════════ */
.split-section{
  display:grid;grid-template-columns:1fr 1fr;min-height:700px;
}
.split-left,.split-right{display:flex;align-items:center;justify-content:center;padding:80px 48px}
.split-right{overflow:hidden}
.split-content{max-width:520px}
.split-content .heading-xl{margin-bottom:16px}
.split-content p{color:var(--text-mid);font-size:1.05rem;margin-bottom:28px;line-height:1.8}

.split-features{display:flex;flex-direction:column;gap:18px}
.mini-feature{display:flex;align-items:flex-start;gap:14px}
.mini-icon{
  width:44px;height:44px;display:flex;align-items:center;justify-content:center;
  background:var(--orange-100);color:var(--orange);border-radius:var(--radius-sm);
  font-size:1rem;flex-shrink:0;
}
.mini-feature strong{display:block;font-size:.92rem;color:var(--text)}
.mini-feature span{font-size:.82rem;color:var(--text-light)}

/* Orbital spinner visual */
.split-visual{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}
.orbit-wrapper{
  position:relative;width:100%;height:100%;min-height:560px;
  overflow:hidden;
}

/* ── Fire glow ring — single dramatic circle ── */
.fire-ring{
  position:absolute;top:50%;left:50%;
  width:280px;height:280px;
  transform:translate(-50%,-50%);
  border-radius:50%;
  background:transparent;
  border:2px solid rgba(232,136,47,.25);
  box-shadow:
    0 0 30px rgba(232,136,47,.2),
    0 0 60px rgba(232,136,47,.12),
    0 0 100px rgba(232,136,47,.06),
    inset 0 0 30px rgba(232,136,47,.08),
    inset 0 0 60px rgba(232,136,47,.04);
  animation:fireBreath 3s ease-in-out infinite;
}
.fire-ring::before{
  content:'';position:absolute;inset:-6px;border-radius:50%;
  border:1px solid rgba(232,136,47,.1);
  animation:fireBreath 3s ease-in-out infinite reverse;
}
.fire-ring::after{
  content:'';position:absolute;inset:-14px;border-radius:50%;
  border:1px solid rgba(232,136,47,.05);
  animation:fireBreath 4s ease-in-out infinite .5s;
}

@keyframes fireBreath{
  0%,100%{
    box-shadow:
      0 0 30px rgba(232,136,47,.2),
      0 0 60px rgba(232,136,47,.12),
      0 0 100px rgba(232,136,47,.06),
      inset 0 0 30px rgba(232,136,47,.08),
      inset 0 0 60px rgba(232,136,47,.04);
    border-color:rgba(232,136,47,.25);
    transform:translate(-50%,-50%) scale(1);
  }
  50%{
    box-shadow:
      0 0 50px rgba(232,136,47,.35),
      0 0 90px rgba(232,136,47,.2),
      0 0 140px rgba(232,136,47,.1),
      inset 0 0 40px rgba(232,136,47,.15),
      inset 0 0 80px rgba(232,136,47,.08);
    border-color:rgba(232,136,47,.4);
    transform:translate(-50%,-50%) scale(1.04);
  }
}

/* Floating ember particles */
.ember{
  position:absolute;border-radius:50%;
  background:radial-gradient(circle,var(--orange),rgba(232,136,47,0));
  pointer-events:none;z-index:1;
}
.ember-1{width:6px;height:6px;top:20%;left:55%;animation:emberFloat 4s ease-in-out infinite}
.ember-2{width:4px;height:4px;top:30%;right:20%;animation:emberFloat 5s ease-in-out infinite .8s}
.ember-3{width:5px;height:5px;bottom:25%;left:35%;animation:emberFloat 4.5s ease-in-out infinite 1.5s}
.ember-4{width:3px;height:3px;top:45%;left:18%;animation:emberFloat 3.5s ease-in-out infinite .4s}
.ember-5{width:5px;height:5px;bottom:30%;right:28%;animation:emberFloat 5.5s ease-in-out infinite 2s}
.ember-6{width:4px;height:4px;top:65%;right:15%;animation:emberFloat 4s ease-in-out infinite 1.2s}

@keyframes emberFloat{
  0%,100%{opacity:.3;transform:translateY(0) scale(1)}
  25%{opacity:.8;transform:translateY(-15px) scale(1.4)}
  50%{opacity:1;transform:translateY(-25px) scale(1)}
  75%{opacity:.6;transform:translateY(-10px) scale(1.2)}
}

/* Central hub */
.orbit-center{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:120px;height:120px;border-radius:50%;
  background:linear-gradient(135deg,var(--orange),var(--orange-dark));
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:6px;z-index:3;
  box-shadow:
    0 0 40px var(--orange-glow),
    0 0 80px rgba(232,136,47,.15),
    0 0 120px rgba(232,136,47,.08);
}
.orbit-center i{font-size:1.8rem;color:var(--white);animation:beatPulse 1.5s ease-in-out infinite}
.orbit-center-logo{width:auto;height:65px;object-fit:contain;animation:beatPulse 1.5s ease-in-out infinite}
.orbit-center span{font-size:.72rem;font-weight:700;color:var(--white);text-transform:uppercase;letter-spacing:.06em}

/* Heartbeat logo in section heading */
.heartbeat-heading-logo{display:inline-block;width:auto;height:56px;object-fit:contain;vertical-align:middle;margin-right:8px}

/* Spinning wheel container */
.orbit-wheel{
  position:absolute;inset:0;
  animation:orbitSpin 22s linear infinite;
}
.orbit-wrapper:hover .orbit-wheel{animation-play-state:paused}

/* Each item positioned around the fire ring */
.orbit-item{
  position:absolute;top:50%;left:50%;
  width:0;height:0;
  transform:rotate(calc(var(--i) * 72deg)) translateY(-155px);
}

/* The visible node — counter-rotates so text stays upright */
.orbit-node{
  position:absolute;transform:translate(-50%,-50%) rotate(calc(var(--i) * -72deg));
  width:82px;height:82px;border-radius:50%;
  background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.12);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  backdrop-filter:blur(8px);transition:all .35s var(--ease);
  animation:counterSpin 22s linear infinite;
}
.orbit-wrapper:hover .orbit-node{animation-play-state:paused}
.orbit-node:hover{
  background:var(--orange);border-color:var(--orange);
  transform:translate(-50%,-50%) rotate(calc(var(--i) * -72deg)) scale(1.15);
  box-shadow:0 0 30px var(--orange-glow);
}
.orbit-node i{font-size:1.3rem;color:var(--orange);transition:color .3s var(--ease)}
.orbit-node:hover i{color:var(--white)}
.orbit-node span{font-size:.7rem;font-weight:700;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}
.orbit-node:hover span{color:var(--white)}

@keyframes orbitSpin{
  from{transform:rotate(0deg)}
  to{transform:rotate(360deg)}
}
@keyframes counterSpin{
  from{transform:translate(-50%,-50%) rotate(calc(var(--i) * -72deg + 0deg))}
  to{transform:translate(-50%,-50%) rotate(calc(var(--i) * -72deg + -360deg))}
}

/* ══════════════════════════════════════════════════════════════
   BENTO GRID (HeartBeat) — v2 Redesign
   ══════════════════════════════════════════════════════════════ */
.bento-section{
  background:var(--navy-deep);padding:100px 0 140px;position:relative;overflow:hidden;
}

/* ── Floating particles ── */
.bento-particles{position:absolute;inset:0;pointer-events:none;z-index:0}
.particle{
  position:absolute;
  left:var(--x);top:var(--y);
  width:var(--s);height:var(--s);
  border-radius:50%;
  background:var(--orange);
  opacity:0;
  animation:particleFloat var(--d) ease-in-out infinite;
}
.particle:nth-child(even){background:rgba(255,255,255,.35)}
@keyframes particleFloat{
  0%,100%{opacity:0;transform:translateY(0) scale(.5)}
  25%{opacity:.6}
  50%{opacity:.4;transform:translateY(-80px) scale(1)}
  75%{opacity:.2}
}

/* ── Header ── */
.bento-header{text-align:center;margin-bottom:56px;padding:0 32px;position:relative;z-index:1}
.bento-header .heading-xl{margin-bottom:12px}
.bento-header .heading-xl i{font-size:.85em;animation:beatPulse 1.5s ease-in-out infinite}
@keyframes beatPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.08)}}

/* ── Grid — flexbox for natural centering of row 2 ── */
.bento-grid{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:24px;
  max-width:1300px;margin:0 auto;padding:0 32px;
  position:relative;z-index:1;
}
/* ── Card — glassmorphism with animated border ── */
.bento-card{
  width:calc(25% - 18px); /* 4 per row, centered */
  position:relative;
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  padding:36px 28px 32px;
  overflow:hidden;
  transition:all .45s var(--ease);
  transition-delay:calc(var(--card-i,0) * 0.08s);
}

/* Animated gradient border glow on hover */
.bento-card-glow{
  position:absolute;inset:-1px;
  border-radius:19px;
  background:conic-gradient(from 0deg,var(--orange),transparent 25%,transparent 75%,var(--orange));
  opacity:0;
  transition:opacity .4s ease;
  z-index:-2;
  animation:borderSpin 3s linear infinite paused;
}
.bento-card:hover .bento-card-glow{
  opacity:1;
  animation-play-state:running;
}
@keyframes borderSpin{
  to{transform:rotate(360deg)}
}
/* Inner mask so glow only shows as border */
.bento-card::before{
  content:'';position:absolute;inset:1px;
  border-radius:17px;
  background:var(--navy-deep);
  z-index:-1;
  transition:background .4s ease;
}
.bento-card:hover::before{
  background:linear-gradient(135deg,rgba(43,58,103,.95),rgba(17,28,54,.98));
}

/* Shine sweep on hover */
.bento-card-shine{
  position:absolute;top:-50%;left:-60%;
  width:200%;height:200%;
  background:linear-gradient(
    to right,transparent 0%,rgba(255,255,255,.02) 44%,
    rgba(255,255,255,.12) 50%,rgba(255,255,255,.02) 56%,transparent 100%
  );
  transform:rotate(-45deg) translateX(-120%);
  pointer-events:none;z-index:1;
}
.bento-card:hover .bento-card-shine{
  transform:rotate(-45deg) translateX(120%);
  transition:transform .8s ease;
}

/* 3D lift on hover */
.bento-card:hover{
  transform:translateY(-8px);
  border-color:transparent;
  box-shadow:
    0 25px 50px rgba(0,0,0,.3),
    0 0 30px rgba(232,136,47,.08);
}

/* ── Icon — pulsing glow ring ── */
.bento-icon{
  width:52px;height:52px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--orange),var(--orange-dark));
  border-radius:14px;
  font-size:1.2rem;color:var(--white);margin-bottom:20px;
  position:relative;z-index:2;
  transition:transform .35s var(--ease);
}
.bento-icon::after{
  content:'';position:absolute;inset:-4px;
  border-radius:18px;
  border:2px solid var(--orange);
  opacity:0;
  animation:iconGlow 2.5s ease-in-out infinite;
}
@keyframes iconGlow{
  0%,100%{opacity:0;transform:scale(.95)}
  50%{opacity:.4;transform:scale(1.05)}
}
.bento-card:hover .bento-icon{
  transform:scale(1.1) rotate(-3deg);
}
.bento-card:hover .bento-icon::after{
  opacity:.6;
  animation:iconGlow 1.5s ease-in-out infinite;
}

/* ── Card text ── */
.bento-card h3{
  color:var(--white);font-family:var(--font-display);
  font-size:1.15rem;margin-bottom:8px;position:relative;z-index:2;
  transition:color .3s ease;
}
.bento-card:hover h3{color:var(--orange-light)}
.bento-card p{
  color:rgba(255,255,255,.5);font-size:.88rem;line-height:1.7;margin-bottom:16px;
  position:relative;z-index:2;
  transition:color .3s ease;
}
.bento-card:hover p{color:rgba(255,255,255,.65)}

/* ── Tags with hover shimmer ── */
.bento-tags{display:flex;flex-wrap:wrap;gap:6px;position:relative;z-index:2}
.bento-tags span{
  padding:5px 14px;border-radius:var(--radius-full);font-size:.73rem;font-weight:600;
  background:rgba(232,136,47,.1);color:var(--orange-light);
  border:1px solid rgba(232,136,47,.18);
  transition:all .3s ease;
}
.bento-card:hover .bento-tags span{
  background:rgba(232,136,47,.2);
  border-color:rgba(232,136,47,.35);
  color:var(--orange);
}

/* ══════════════════════════════════════════════════════════════
   SOLUTIONS — Orange gradient
   ══════════════════════════════════════════════════════════════ */
.full-section{padding:100px 0 140px;position:relative;overflow:hidden}
.solutions-header{text-align:center;margin-bottom:56px}
.solutions-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:16px 0}

/* ── Modern glassmorphism cards with zoom popup effect ── */
.sol-card{
  position:relative;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;
  padding:44px 28px 36px;
  text-align:center;
  overflow:hidden;
  transition:all .45s cubic-bezier(.23,1,.32,1);
  z-index:1;
  transform-origin:center center;
}

/* Shimmer sweep on hover */
.sol-card::after{
  content:'';position:absolute;top:-50%;left:-60%;
  width:200%;height:200%;
  background:linear-gradient(
    to right,transparent 0%,rgba(255,255,255,.03) 44%,
    rgba(255,255,255,.14) 50%,rgba(255,255,255,.03) 56%,transparent 100%
  );
  transform:rotate(-45deg) translateX(-120%);
  transition:none;pointer-events:none;
}
.sol-card:hover::after{
  transform:rotate(-45deg) translateX(120%);
  transition:transform .9s ease;
}

/* ── ZOOM POPUP on hover ── */
.sol-card:hover{
  transform:scale(1.12) translateY(-8px);
  background:rgba(255,255,255,.15);
  border-color:rgba(255,255,255,.28);
  box-shadow:
    0 30px 70px rgba(0,0,0,.35),
    0 0 50px rgba(255,255,255,.06),
    0 0 0 1px rgba(255,255,255,.1);
  z-index:10;
}

/* Bottom glow line */
.sol-line{
  position:absolute;bottom:0;left:50%;
  width:0;height:3px;
  background:linear-gradient(90deg,transparent,var(--white),transparent);
  transition:all .5s var(--ease);
  transform:translateX(-50%);
}
.sol-card:hover .sol-line{width:80%}

/* Icon wrapper — flips on hover */
.sol-icon-wrap{
  width:68px;height:68px;margin:0 auto 22px;
  display:flex;align-items:center;justify-content:center;
  border-radius:18px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.1);
  font-size:1.5rem;color:var(--white);
  transition:all .55s var(--ease);
}
.sol-card:hover .sol-icon-wrap{
  background:var(--white);color:var(--orange-dark);
  transform:rotateY(180deg) scale(1.12);
  box-shadow:0 0 35px rgba(255,255,255,.2);
  border-color:transparent;
}
.sol-icon-wrap i{transition:transform .55s var(--ease)}
.sol-card:hover .sol-icon-wrap i{transform:rotateY(180deg)}

.sol-card h3{color:var(--white);font-size:1.05rem;margin-bottom:10px;transition:all .35s var(--ease)}
.sol-card:hover h3{color:var(--white);font-size:1.12rem;text-shadow:0 1px 8px rgba(255,255,255,.15)}
.sol-card p{color:rgba(255,255,255,.6);font-size:.88rem;line-height:1.7;transition:all .35s var(--ease)}
.sol-card:hover p{color:rgba(255,255,255,.92);font-size:.92rem}

/* ══════════════════════════════════════════════════════════════
   WHO WE SERVE — hex cards on navy
   ══════════════════════════════════════════════════════════════ */
.serve-header{text-align:center;margin-bottom:56px}
.serve-hex-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.hex-card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);padding:36px 20px;text-align:center;
  transition:all .35s var(--ease);
}
.hex-card:hover{background:rgba(232,136,47,.08);border-color:var(--orange);transform:translateY(-4px)}
.hex-icon{
  width:100px;height:100px;display:flex;align-items:center;justify-content:center;
  background:rgba(232,136,47,.1);color:var(--orange);border-radius:50%;
  font-size:2.6rem;margin:0 auto 20px;transition:all .3s var(--ease);
}
.hex-card:hover .hex-icon{background:var(--orange);color:var(--white);transform:scale(1.1)}
.hex-card h4{color:var(--white);font-size:1.9rem;font-weight:700}

/* ══════════════════════════════════════════════════════════════
   COMPLIANCE — Circuit board background section
   ══════════════════════════════════════════════════════════════ */
.comp-section{
  background:var(--cream);position:relative;overflow:hidden;
}
.comp-circuit-bg{
  position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;
}
.comp-section .container-lg{position:relative;z-index:1}
.comp-header{text-align:center;margin-bottom:56px}
.comp-blocks{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}

/* Cards — frosted glass on cream */
.comp-block{
  background:rgba(255,255,255,.65);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(43,58,103,.08);
  border-radius:20px;
  padding:36px 28px;
  transition:all .4s var(--ease);
  box-shadow:0 4px 24px rgba(43,58,103,.04);
}
.comp-block:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 48px rgba(43,58,103,.1);
  border-color:rgba(232,136,47,.2);
  background:rgba(255,255,255,.85);
}

.comp-block-head{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.comp-flag{
  width:44px;height:44px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--navy),var(--navy-light));
  color:var(--white);border-radius:12px;font-size:1.1rem;
  box-shadow:0 4px 12px rgba(43,58,103,.2);
  transition:all .3s var(--ease);
}
.comp-block:hover .comp-flag{
  background:linear-gradient(135deg,var(--orange),var(--orange-dark));
  transform:scale(1.08);
}
.comp-block h3{font-size:1.15rem;color:var(--navy);font-weight:700}

.comp-pills{display:flex;flex-wrap:wrap;gap:8px}
.comp-pills span{
  padding:7px 18px;border-radius:var(--radius-full);font-size:.82rem;font-weight:600;
  background:var(--navy);color:var(--white);
  transition:all .25s var(--ease);
  box-shadow:0 2px 8px rgba(43,58,103,.15);
}
.comp-pills span:hover{
  background:var(--orange);
  transform:translateY(-2px);
  box-shadow:0 6px 16px rgba(232,136,47,.25);
}

/* ══════════════════════════════════════════════════════════════
   SECURITY GRID
   ══════════════════════════════════════════════════════════════ */
.sec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.sec-item{
  text-align:center;padding:32px 20px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);
  border-radius:var(--radius);transition:all .35s var(--ease);
}
.sec-item:hover{background:rgba(255,255,255,.08);transform:translateY(-4px)}
.sec-item i{font-size:1.8rem;color:var(--orange);margin-bottom:14px}
.sec-item h4{color:var(--white);font-size:.95rem;margin-bottom:6px}
.sec-item p{color:rgba(255,255,255,.5);font-size:.85rem}

/* ══════════════════════════════════════════════════════════════
   GLOBAL REACH — Night Globe
   ══════════════════════════════════════════════════════════════ */
.globe-section{
  position:relative;overflow:hidden;
  background:#030712;
  padding:0;
}

/* ── Header overlaid on dark background ── */
.globe-header{
  text-align:center;
  padding:72px 32px 0;
  position:relative;z-index:4;
}
.globe-subtitle{
  color:rgba(255,255,255,.5);
  font-size:1.05rem;
  max-width:620px;
  margin:14px auto 0;
  line-height:1.6;
}

/* ── Globe image container ── */
.globe-map-wrap{
  position:relative;
  width:100%;
  margin-top:-10px;
}

/* Globe image — entrance zoom animation */
.globe-map-img{
  width:100%;height:auto;display:block;
  opacity:0;
  transform:scale(1.08);
  transition:none;
}
[data-anim="globe-zoom"].in-view{
  animation:globeZoomIn 1.8s cubic-bezier(.22,.61,.36,1) forwards;
}
@keyframes globeZoomIn{
  0%{opacity:0;transform:scale(1.15)}
  40%{opacity:1}
  100%{opacity:1;transform:scale(1)}
}

/* ── Pulsing glow ring overlay ── */
.globe-glow-ring{
  position:absolute;
  top:50%;left:50%;
  width:60%;height:0;padding-bottom:60%;
  transform:translate(-50%,-50%);
  border-radius:50%;
  border:1px solid rgba(100,160,255,.08);
  box-shadow:
    0 0 60px 10px rgba(80,140,255,.06),
    inset 0 0 60px 10px rgba(80,140,255,.04);
  animation:glowPulse 4s ease-in-out infinite;
  pointer-events:none;
  z-index:1;
}
@keyframes glowPulse{
  0%,100%{
    box-shadow:0 0 60px 10px rgba(80,140,255,.06),inset 0 0 60px 10px rgba(80,140,255,.04);
    opacity:.6;
  }
  50%{
    box-shadow:0 0 80px 20px rgba(80,140,255,.1),inset 0 0 80px 20px rgba(80,140,255,.06);
    opacity:1;
  }
}

/* ── Floating particles (star-like sparkles) ── */
.globe-particle{
  position:absolute;
  left:var(--p-x);top:var(--p-y);
  width:3px;height:3px;
  border-radius:50%;
  background:rgba(180,200,255,.7);
  box-shadow:0 0 6px 2px rgba(150,180,255,.4);
  animation:particleFloat var(--p-dur,4s) ease-in-out infinite;
  animation-delay:var(--p-d,0s);
  pointer-events:none;
  z-index:2;
}
@keyframes particleFloat{
  0%,100%{transform:translateY(0) scale(1);opacity:.4}
  50%{transform:translateY(-12px) scale(1.5);opacity:.9}
}

/* ── Bottom gradient fade ── */
.globe-bottom-fade{
  position:absolute;bottom:0;left:0;right:0;
  height:140px;
  background:linear-gradient(180deg,transparent 0%,#030712 100%);
  z-index:3;pointer-events:none;
}

/* ── Responsive ── */
@media(max-width:900px){
  .globe-header{padding:56px 24px 0}
  .globe-subtitle{font-size:.92rem}
  .globe-glow-ring{width:70%;padding-bottom:70%}
}
@media(max-width:600px){
  .globe-header{padding:48px 20px 0}
  .globe-header .heading-xl{font-size:1.8rem}
  .globe-subtitle{font-size:.85rem}
  .globe-bottom-fade{height:80px}
  .globe-particle{display:none}
}

/* ══════════════════════════════════════════════════════════════
   CAREERS
   ══════════════════════════════════════════════════════════════ */
.careers-wrap{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.careers-text .heading-xl{text-align:left}
.careers-text p{color:var(--text-mid);font-size:1.05rem;margin-bottom:24px;line-height:1.8}
.perk-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:28px}
.perk{display:flex;align-items:center;gap:10px;font-weight:600;font-size:.9rem;color:var(--text)}
.perk i{color:var(--orange);font-size:1rem}

.careers-badges{
  position:relative;display:flex;flex-wrap:wrap;gap:14px;justify-content:center;
  align-content:center;min-height:360px;
}
.role-tag{
  padding:14px 26px;border-radius:var(--radius-full);
  font-size:.88rem;font-weight:700;
  background:var(--white);color:var(--navy);border:2px solid var(--navy-200);
  box-shadow:0 4px 16px rgba(43,58,103,.06);
  transition:all .4s var(--ease);animation:tagFloat 5s ease-in-out infinite;
}
.role-tag:hover{border-color:var(--orange);color:var(--orange);transform:translateY(-4px)!important}
.rt-1{animation-delay:0s}.rt-2{animation-delay:-.7s}.rt-3{animation-delay:-1.4s}.rt-4{animation-delay:-2.1s}
.rt-5{animation-delay:-2.8s}.rt-6{animation-delay:-.35s}.rt-7{animation-delay:-1.05s}.rt-8{animation-delay:-1.75s}
@keyframes tagFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* ══════════════════════════════════════════════════════════════
   CONTACT
   ══════════════════════════════════════════════════════════════ */
.contact-header{text-align:center;margin-bottom:56px}
.contact-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:40px;align-items:start}

.c-form{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);padding:40px;backdrop-filter:blur(6px);
}
.form-duo{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin-bottom:18px}
.field label{display:block;font-size:.85rem;font-weight:600;color:rgba(255,255,255,.7);margin-bottom:6px}
.field input,.field select,.field textarea{
  width:100%;padding:13px 16px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);
  color:var(--white);font-family:var(--font);font-size:.92rem;
  outline:none;transition:all .2s var(--ease);
}
.field input::placeholder,.field textarea::placeholder{color:rgba(255,255,255,.3)}
.field select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='rgba(255,255,255,0.5)'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.field select option{background:var(--navy-dark);color:var(--white)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-glow)}
.field textarea{resize:vertical;min-height:100px}

.btn-txt,.btn-load{display:inline-flex;align-items:center;gap:8px}
.btn-load{display:none}
.btn-fill.loading .btn-txt{display:none}
.btn-fill.loading .btn-load{display:inline-flex}

.c-info{display:flex;flex-direction:column;gap:18px}
.info-block{
  display:flex;gap:16px;padding:22px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius);transition:all .3s var(--ease);
}
.info-block:hover{background:rgba(255,255,255,.08)}
.info-block>i{
  width:42px;height:42px;display:flex;align-items:center;justify-content:center;
  background:rgba(232,136,47,.15);color:var(--orange);border-radius:var(--radius-sm);
  font-size:1rem;flex-shrink:0;
}
.info-block h4{color:var(--white);font-size:.92rem;margin-bottom:4px}
.info-block p{color:rgba(255,255,255,.5);font-size:.88rem;line-height:1.6}
.info-block a{color:var(--orange-light);transition:color .2s}
.info-block a:hover{color:var(--white)}

/* ══════════════════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════════════════ */
.site-foot{background:var(--black);color:rgba(255,255,255,.5);padding:64px 0 0}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.06)}
.foot-logo{height:44px;margin-bottom:14px}
.foot-brand p{font-size:.88rem;line-height:1.7;margin-bottom:16px}
.foot-social{display:flex;gap:10px}
.foot-social a{
  width:38px;height:38px;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.06);color:rgba(255,255,255,.5);border-radius:var(--radius-sm);
  transition:all .3s var(--ease);
}
.foot-social a:hover{background:var(--orange);color:var(--white);transform:translateY(-2px)}
.foot-col h5{color:var(--white);font-size:.88rem;margin-bottom:16px}
.foot-col a{display:block;font-size:.88rem;color:rgba(255,255,255,.45);margin-bottom:10px;transition:all .2s}
.foot-col a:hover{color:var(--white);padding-left:3px}
.foot-bottom{padding:20px 0;text-align:center;font-size:.82rem;color:rgba(255,255,255,.25)}

/* ── Back to top ───────────────────────────────────────────── */
.btt{
  position:fixed;bottom:28px;right:28px;width:46px;height:46px;
  display:flex;align-items:center;justify-content:center;
  background:var(--orange);color:var(--white);border:none;border-radius:50%;
  cursor:pointer;font-size:.95rem;box-shadow:0 6px 20px var(--orange-glow);
  opacity:0;visibility:hidden;transform:translateY(16px);
  transition:all .3s var(--ease);z-index:999;
}
.btt.show{opacity:1;visibility:visible;transform:translateY(0)}
.btt:hover{background:var(--orange-dark);transform:translateY(-3px)}

/* ══════════════════════════════════════════════════════════════
   ANIMATIONS
   ══════════════════════════════════════════════════════════════ */
[data-anim]{opacity:0;transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-anim="fade-up"]{transform:translateY(40px)}
[data-anim="fade-right"]{transform:translateX(-40px)}
[data-anim="fade-left"]{transform:translateX(40px)}
[data-anim].in-view{opacity:1;transform:translate(0)}

[data-delay="1"]{transition-delay:.12s}
[data-delay="2"]{transition-delay:.24s}
[data-delay="3"]{transition-delay:.36s}

/* Staggered bento cards via --card-i */
.bento-card[data-anim]{transition-delay:calc(var(--card-i,0) * .1s)}
.bento-card[data-anim="fade-up"]{transform:translateY(50px) scale(.96)}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════ */
@media(max-width:1100px){
  .bento-card{width:calc(50% - 12px)}
  .solutions-row{grid-template-columns:1fr 1fr;gap:18px}
  .serve-hex-grid{grid-template-columns:repeat(3,1fr)}
}

@media(max-width:900px){
  .menu-toggle{display:flex}
  .nav{
    position:fixed;top:0;right:-100%;width:min(360px,85vw);height:100vh;
    background:var(--white);z-index:1050;padding:100px 28px 28px;
    transition:right .35s var(--ease);box-shadow:-10px 0 40px rgba(0,0,0,.1);
  }
  .nav.open{right:0}
  .nav-list{flex-direction:column;gap:0}
  .nav-item{padding:14px 16px;font-size:1rem;width:100%;border-bottom:1px solid var(--navy-100)}
  .cta-btn{display:none}

  .split-section{grid-template-columns:1fr}
  .split-right{min-height:440px}
  .orbit-wrapper{min-height:440px}
  .fire-ring{width:220px;height:220px}
  .orbit-item{transform:rotate(calc(var(--i) * 72deg)) translateY(-125px)}
  .orbit-node{width:68px;height:68px}
  .orbit-node i{font-size:1.1rem}
  .orbit-node span{font-size:.6rem}
  .orbit-center{width:95px;height:95px}
  .orbit-center i{font-size:1.5rem}
  .orbit-center-logo{width:auto;height:50px}
  .orbit-center span{font-size:.65rem}
  .careers-wrap{grid-template-columns:1fr;gap:40px}
  .contact-grid{grid-template-columns:1fr}
  .comp-blocks{grid-template-columns:1fr}
  .sec-grid{grid-template-columns:1fr 1fr}
  .foot-top{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1/-1}
}

@media(max-width:640px){
  .brand-img{height:38px}
  .hero{padding:110px 20px 100px}
  .hero-heading{font-size:clamp(2rem,8vw,3rem)}
  .hero-btns{flex-direction:column;width:100%}
  .hero-btns .btn-fill,.hero-btns .btn-ghost{width:100%;justify-content:center}
  .ticker-track{gap:20px}
  .ticker-sep{display:none}
  .split-left,.split-right{padding:48px 24px}
  .bento-card{width:100%}
  .solutions-row{grid-template-columns:1fr}
  .serve-hex-grid{grid-template-columns:1fr 1fr}
  .form-duo{grid-template-columns:1fr}
  .c-form{padding:28px 20px}
  .sec-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr;gap:24px}
  .angle-bottom{height:50px}
  .perk-row{grid-template-columns:1fr}
  .split-right{min-height:360px}
  .orbit-wrapper{min-height:360px}
  .fire-ring{width:170px;height:170px}
  .orbit-item{transform:rotate(calc(var(--i) * 72deg)) translateY(-95px)}
  .orbit-node{width:50px;height:50px}
  .orbit-node i{font-size:.8rem}
  .orbit-node span{font-size:.48rem}
  .orbit-center{width:65px;height:65px}
  .orbit-center i{font-size:1.1rem}
  .orbit-center-logo{width:auto;height:32px}
  .orbit-center span{font-size:.55rem}
  .ember{display:none}
}

@media(max-width:400px){
  .serve-hex-grid{grid-template-columns:1fr}
  .container-lg{padding:0 16px}
}

/* ── Reduced motion ────────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
  [data-anim]{opacity:1;transform:none}
}

/* ── Print ─────────────────────────────────────────────────── */
@media print{
  .topbar,.hero-decor,.angle-bottom,.btt,.menu-toggle{display:none!important}
  .full-section,.bento-section,.hero{background:white!important;color:black!important;padding:32px 0}
  [data-anim]{opacity:1;transform:none}
}
