/* ============================================
   ROOT & RESET
============================================ */
:root{
  --navy-950:#020a18;--navy-900:#071631;--navy-800:#0c2550;--navy-700:#10356b;
  --gold-500:#c9a227;--gold-400:#d4af37;--gold-300:#e5c76b;--gold-200:#f0dda0;
  --white:#fff;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-400:#9ca3af;
  --text-dark:#0f172a;--text-body:#374151;--text-muted:#6b7280;
  --surface:#fff;--surface-alt:#f8f9fc;--border:rgba(16,53,107,.08);
  --radius:8px;--radius-lg:16px;--container:1280px;
  --ease:cubic-bezier(.25,1,.5,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:#f8fbff;color:var(--text-body);line-height:1.65;overflow-x:hidden}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;display:block}
.shell{width:min(var(--container),100% - 40px);margin:0 auto}
::-webkit-scrollbar{width:7px}
::-webkit-scrollbar-track{background:#f0f4fa}
::-webkit-scrollbar-thumb{background:var(--navy-700);border-radius:4px}

/* ============================================
   TOPBAR
============================================ */
.topbar{background:var(--navy-900);color:rgba(255,255,255,.65);font-size:.78rem;border-bottom:1px solid rgba(212,175,55,.12)}
.topbar .shell{display:flex;justify-content:space-between;align-items:center;padding:9px 0;gap:12px;flex-wrap:wrap}
.topbar a{color:var(--gold-300);transition:color .2s}
.topbar a:hover{color:var(--gold-400)}
.topbar-right{display:flex;gap:18px;align-items:center}

/* ============================================
   NAVBAR
============================================ */
.navbar{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);padding:14px 0;border-bottom:1px solid var(--border);box-shadow:0 1px 20px rgba(16,53,107,.04);transition:box-shadow .3s}
.nav-inner{display:flex;justify-content:space-between;align-items:center}
.logo{font-weight:900;font-size:1.5rem;letter-spacing:2px;color:var(--navy-900);display:flex;align-items:center;gap:6px}
.logo i{color:var(--gold-400);font-style:normal}
.nav-links{display:flex;gap:26px}
.nav-links a{font-size:.83rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);position:relative;transition:color .3s}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-4px;width:0;height:2px;background:var(--gold-400);transition:width .35s var(--ease)}
.nav-links a:hover{color:var(--navy-900)}
.nav-links a:hover::after{width:100%}
.btn-nav{display:inline-flex;align-items:center;gap:6px;padding:11px 24px;border-radius:var(--radius);font-weight:700;font-size:.82rem;letter-spacing:1px;text-transform:uppercase;background:linear-gradient(180deg,var(--navy-800),var(--navy-950));border:2px solid var(--gold-400);color:var(--gold-400);cursor:pointer;transition:all .35s var(--ease);position:relative;overflow:hidden}
.btn-nav::before{content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(212,175,55,.12),transparent);transform:skewX(-20deg);transition:left .6s}
.btn-nav:hover::before{left:150%}
.btn-nav:hover{background:linear-gradient(180deg,var(--navy-700),var(--navy-900));box-shadow:0 6px 24px rgba(212,175,55,.2);transform:translateY(-1px)}

/* ============================================
   MEGA BANNER — Webflow / Framer level
============================================ */
.mega-banner{
  position:relative;min-height:100vh;display:flex;align-items:center;
  background:var(--navy-950);overflow:hidden;
}
.mega-banner::before{
  content:'';position:absolute;inset:0;z-index:3;pointer-events:none;
  opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
}

.mb-mesh{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 80% 60% at 15% 55%,rgba(212,175,55,.12),transparent),
    radial-gradient(ellipse 60% 70% at 75% 30%,rgba(16,53,107,.35),transparent),
    radial-gradient(ellipse 50% 50% at 50% 80%,rgba(201,162,39,.06),transparent);
  animation:meshShift 12s ease-in-out infinite alternate;
}
@keyframes meshShift{
  0%{transform:scale(1) translate(0,0)}
  50%{transform:scale(1.08) translate(-2%,3%)}
  100%{transform:scale(1) translate(2%,-2%)}
}

.mb-orb{
  position:absolute;border-radius:50%;filter:blur(80px);z-index:1;
  mix-blend-mode:screen;
}
.mb-orb-1{width:500px;height:500px;background:rgba(212,175,55,.09);top:-10%;left:-8%;animation:orbFloat1 18s ease-in-out infinite}
.mb-orb-2{width:350px;height:350px;background:rgba(16,53,107,.25);bottom:-5%;right:-5%;animation:orbFloat2 22s ease-in-out infinite}
.mb-orb-3{width:200px;height:200px;background:rgba(212,175,55,.06);top:50%;left:55%;animation:orbFloat3 15s ease-in-out infinite}

@keyframes orbFloat1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(60px,-40px) scale(1.15)}}
@keyframes orbFloat2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-50px,30px) scale(1.1)}}
@keyframes orbFloat3{0%,100%{transform:translate(0,0)}33%{transform:translate(30px,-50px)}66%{transform:translate(-40px,20px)}}

.mb-grid{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:
    linear-gradient(rgba(212,175,55,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(212,175,55,.03) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black 30%,transparent 72%);
  -webkit-mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black 30%,transparent 72%);
}

.mb-scanline{
  position:absolute;left:0;width:100%;height:1px;z-index:2;
  background:linear-gradient(90deg,transparent 10%,rgba(212,175,55,.18) 50%,transparent 90%);
  animation:scanDown 8s linear infinite;
  pointer-events:none;
}
@keyframes scanDown{0%{top:-2%}100%{top:102%}}

.mb-content{
  position:relative;z-index:10;display:grid;
  grid-template-columns:1fr 1fr;gap:50px;align-items:center;
  padding:120px 0 100px;
}

.mb-left{max-width:620px}

.mb-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 18px;border-radius:50px;
  background:rgba(212,175,55,.06);border:1px solid rgba(212,175,55,.15);
  color:var(--gold-300);font-size:.72rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;
  margin-bottom:28px;
  opacity:0;animation:revealUp .8s .3s var(--ease) forwards;
}
.mb-eyebrow .dot{
  width:7px;height:7px;border-radius:50%;background:var(--gold-400);
  box-shadow:0 0 12px rgba(212,175,55,.7);animation:dotPulse 2s infinite;
}
@keyframes dotPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.6);opacity:.4}}

.mb-title{
  font-size:clamp(2.4rem,5.2vw,4.2rem);font-weight:900;line-height:1.05;
  letter-spacing:-2px;color:#fff;margin-bottom:26px;
  opacity:0;animation:revealUp .9s .45s var(--ease) forwards;
}
.mb-title em{
  font-style:normal;position:relative;
  background:linear-gradient(90deg,var(--gold-400),var(--gold-300),var(--gold-500));
  background-size:200% 100%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:goldShimmer 4s ease infinite;
}
@keyframes goldShimmer{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

.mb-title .word{display:inline-block;overflow:hidden;vertical-align:bottom}
.mb-title .word-inner{display:inline-block;transform:translateY(110%);animation:wordUp .7s var(--ease) forwards}

.mb-desc{
  font-size:1.08rem;color:rgba(255,255,255,.5);line-height:1.75;max-width:520px;margin-bottom:40px;
  opacity:0;animation:revealUp .8s .6s var(--ease) forwards;
}

.mb-btns{
  display:flex;gap:14px;flex-wrap:wrap;
  opacity:0;animation:revealUp .8s .75s var(--ease) forwards;
}

.btn-hero-primary{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 34px;border-radius:var(--radius);
  font-weight:800;font-size:.88rem;letter-spacing:1px;text-transform:uppercase;
  background:linear-gradient(135deg,var(--gold-500),var(--gold-400),var(--gold-300));
  background-size:200% 200%;animation:gradX 3s ease infinite;
  color:var(--navy-950);border:none;cursor:pointer;
  box-shadow:0 8px 30px rgba(212,175,55,.25);
  transition:all .35s var(--ease);position:relative;overflow:hidden;
}
.btn-hero-primary::after{
  content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);
  transform:skewX(-20deg);transition:left .6s;
}
.btn-hero-primary:hover::after{left:160%}
.btn-hero-primary:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(212,175,55,.35)}
.btn-hero-primary svg{transition:transform .3s}
.btn-hero-primary:hover svg{transform:translateX(4px)}

@keyframes gradX{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

.btn-hero-outline{
  display:inline-flex;align-items:center;gap:8px;
  padding:16px 34px;border-radius:var(--radius);
  font-weight:700;font-size:.88rem;letter-spacing:.8px;text-transform:uppercase;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.7);cursor:pointer;backdrop-filter:blur(8px);
  transition:all .35s var(--ease);
}
.btn-hero-outline:hover{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(212,175,55,.3);transform:translateY(-3px)}

.mb-micros{
  display:flex;gap:40px;margin-top:48px;padding-top:32px;
  border-top:1px solid rgba(255,255,255,.06);
  opacity:0;animation:revealUp .8s .9s var(--ease) forwards;
}
.mb-micro{display:flex;flex-direction:column;gap:4px}
.mb-micro strong{font-size:1.6rem;color:#fff;font-weight:800;line-height:1}
.mb-micro span{font-size:.7rem;color:var(--gold-300);text-transform:uppercase;letter-spacing:2px;font-weight:600}

.mb-right{
  position:relative;display:flex;align-items:center;justify-content:center;
  perspective:1200px;min-height:520px;
  opacity:0;animation:revealRight 1s .5s var(--ease) forwards;
}

.mb-card-stack{position:relative;width:420px;height:480px}

.mb-card{
  position:absolute;border-radius:var(--radius-lg);overflow:hidden;
  transition:all .6s var(--ease);
  box-shadow:0 30px 60px rgba(0,0,0,.4);
  backface-visibility:hidden;
}

.mb-card-1{
  width:380px;height:430px;top:30px;left:45px;
  background:linear-gradient(160deg,var(--navy-700),var(--navy-800));
  border:1px solid rgba(212,175,55,.06);
  transform:rotateY(-6deg) rotateX(3deg) scale(.92);
  z-index:1;
}
.mb-card-2{
  width:390px;height:450px;top:15px;left:25px;
  background:linear-gradient(160deg,var(--navy-800),var(--navy-900));
  border:1px solid rgba(212,175,55,.1);
  transform:rotateY(-3deg) rotateX(1.5deg) scale(.96);
  z-index:2;
}
.mb-card-3{
  width:400px;height:470px;top:0;left:0;
  background:linear-gradient(160deg,#0d1f3c,#091729);
  border:1px solid rgba(212,175,55,.15);
  transform:rotateY(0deg) rotateX(0deg);
  z-index:3;
}

.mb-card-stack:hover .mb-card-1{transform:rotateY(-12deg) rotateX(5deg) scale(.88) translateX(30px)}
.mb-card-stack:hover .mb-card-2{transform:rotateY(-6deg) rotateX(2.5deg) scale(.94) translateX(15px)}
.mb-card-stack:hover .mb-card-3{transform:rotateY(2deg) rotateX(-1deg) translateX(-10px);box-shadow:0 40px 80px rgba(0,0,0,.5)}

.mb-card-inner{position:relative;width:100%;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:36px;overflow:hidden}

.mb-card-bg{
  position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1504307651254-35680f356f12?auto=format&fit=crop&w=800&q=80') center/cover;
  opacity:.35;transition:opacity .6s,transform .8s var(--ease);
}
.mb-card-stack:hover .mb-card-3 .mb-card-bg{opacity:.45;transform:scale(1.05)}

.mb-card-inner::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 30%,rgba(7,22,49,.95));
  z-index:1;
}

.mb-card-content{position:relative;z-index:2}
.mb-card-tag{
  display:inline-block;font-size:.65rem;font-weight:700;letter-spacing:2px;
  text-transform:uppercase;color:var(--gold-400);margin-bottom:12px;
  padding:4px 12px;background:rgba(212,175,55,.1);border-radius:50px;
}
.mb-card-title{font-size:1.4rem;font-weight:800;color:#fff;margin-bottom:8px;line-height:1.2}
.mb-card-desc{font-size:.82rem;color:rgba(255,255,255,.45);line-height:1.5}

.mb-floating-badge{
  position:absolute;top:24px;right:24px;z-index:4;
  background:rgba(212,175,55,.12);backdrop-filter:blur(16px);
  border:1px solid rgba(212,175,55,.2);border-radius:12px;
  padding:14px 18px;text-align:center;
  animation:badgeFloat 5s ease-in-out infinite;
}
.mb-floating-badge strong{display:block;font-size:1.4rem;color:var(--gold-400);font-weight:800;line-height:1}
.mb-floating-badge span{font-size:.62rem;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:1.5px;font-weight:600}
@keyframes badgeFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

.mb-ring{
  position:absolute;border:1px solid rgba(212,175,55,.06);border-radius:50%;
  z-index:0;pointer-events:none;
  animation:ringRotate 40s linear infinite;
}
.mb-ring-1{width:600px;height:600px;top:-100px;right:-140px}
.mb-ring-2{width:450px;height:450px;top:-30px;right:-70px;border-color:rgba(212,175,55,.04);animation-direction:reverse;animation-duration:35s}
@keyframes ringRotate{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}

@keyframes revealUp{0%{opacity:0;transform:translateY(50px)}100%{opacity:1;transform:translateY(0)}}
@keyframes revealRight{0%{opacity:0;transform:translateX(60px)}100%{opacity:1;transform:translateX(0)}}
@keyframes wordUp{to{transform:translateY(0)}}

/* ============================================
   HORIZONTAL MARQUEE TICKER
============================================ */
.mb-ticker{
  position:absolute;bottom:0;left:0;right:0;z-index:10;
  border-top:1px solid rgba(255,255,255,.04);
  background:rgba(7,22,49,.6);backdrop-filter:blur(12px);
  overflow:hidden;
}
.mb-ticker-track{
  display:flex;gap:0;animation:ticker 40s linear infinite;width:max-content;
}
.mb-ticker-item{
  display:flex;align-items:center;gap:20px;
  padding:16px 50px;
  white-space:nowrap;
  font-size:.78rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;
  color:rgba(255,255,255,.25);
}
.mb-ticker-item .sep{
  width:6px;height:6px;border-radius:50%;background:var(--gold-400);opacity:.3;flex-shrink:0;
}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ============================================
   MEGA BANNER 2 — SPLIT PARALLAX SHOWCASE
============================================ */
.showcase-banner{
  position:relative;padding:0;overflow:hidden;
  background:linear-gradient(180deg,#f8fbff 0%,#ffffff 100%);
}

.showcase-banner::before{
  content:'';position:absolute;top:-2px;left:0;right:0;height:80px;
  background:#f8fbff;
  clip-path:ellipse(55% 100% at 50% 0%);
  z-index:5;
}

.sc-split{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}

.sc-media{
  position:sticky;top:0;height:100vh;overflow:hidden;
  background:var(--navy-900);
}
.sc-media-img{
  position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1542361345-89e58247f2d5?auto=format&fit=crop&w=1200&q=80') center/cover;
  opacity:.4;transition:transform .6s var(--ease);
}
.sc-media:hover .sc-media-img{transform:scale(1.04)}
.sc-media::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(7,22,49,.8),rgba(7,22,49,.5));
}
.sc-media-content{
  position:relative;z-index:2;height:100%;
  display:flex;flex-direction:column;justify-content:center;
  padding:80px 60px;
}
.sc-big-num{
  font-size:clamp(6rem,14vw,12rem);font-weight:900;line-height:.85;
  color:transparent;letter-spacing:-6px;
  -webkit-text-stroke:1px rgba(212,175,55,.15);
  margin-bottom:20px;
  user-select:none;
}
.sc-media-title{font-size:2.4rem;font-weight:800;color:#fff;line-height:1.1;margin-bottom:16px}
.sc-media-title em{
  font-style:normal;
  background:linear-gradient(90deg,var(--gold-400),var(--gold-300));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.sc-media-desc{color:rgba(255,255,255,.45);font-size:1rem;max-width:400px;line-height:1.7}

.sc-pulse-ring{
  position:absolute;bottom:60px;right:60px;z-index:2;
  width:120px;height:120px;border-radius:50%;
  border:2px solid rgba(212,175,55,.15);
  display:grid;place-items:center;
}
.sc-pulse-ring::before{
  content:'';position:absolute;inset:-15px;border-radius:50%;
  border:1px solid rgba(212,175,55,.08);
  animation:pulseRing 3s ease-out infinite;
}
.sc-pulse-ring::after{
  content:'';position:absolute;inset:-30px;border-radius:50%;
  border:1px solid rgba(212,175,55,.04);
  animation:pulseRing 3s .5s ease-out infinite;
}
@keyframes pulseRing{0%{transform:scale(.8);opacity:1}100%{transform:scale(1.4);opacity:0}}
.sc-pulse-inner{font-size:.68rem;color:var(--gold-300);font-weight:700;letter-spacing:1.5px;text-transform:uppercase;text-align:center;line-height:1.3}
.sc-pulse-inner strong{display:block;font-size:1.6rem;color:var(--gold-400);font-weight:800;margin-bottom:2px}

.sc-cards{
  padding:120px 50px;
  display:grid;grid-template-columns:1fr 1fr;gap:30px;
  perspective:1200px;
}
.sc-card{
  padding:44px;border-radius:var(--radius-lg);
  border:1px solid var(--border);background:var(--white);
  box-shadow:0 4px 24px rgba(16,53,107,.04);
  transition:all .6s var(--ease);
  position:relative;overflow:hidden;
  transform-style:preserve-3d;
}
/* Animated border shimmer */
.sc-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold-500),var(--gold-300),var(--gold-400));
  background-size:200% 100%;animation:gradX 3s ease infinite;
  transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);
}
.sc-card::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle 300px at var(--mx,50%) var(--my,50%),rgba(212,175,55,.04),transparent 60%);
  opacity:0;transition:opacity .4s;
}
.sc-card:hover::before{transform:scaleX(1)}
.sc-card:hover::after{opacity:1}
.sc-card:hover{
  border-color:rgba(212,175,55,.15);
  box-shadow:0 25px 60px rgba(16,53,107,.1);
  transform:translateY(-8px) rotateX(2deg);
}
.sc-card-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,rgba(212,175,55,.08),rgba(212,175,55,.02));
  border:1px solid rgba(212,175,55,.12);
  font-size:1rem;font-weight:800;color:var(--gold-500);
  margin-bottom:20px;
  transition:all .4s var(--ease);
  position:relative;
}
.sc-card-num::after{
  content:'';position:absolute;inset:-3px;border-radius:16px;
  border:2px solid transparent;
  background:conic-gradient(from 0deg,transparent,rgba(212,175,55,.3),transparent 40%) border-box;
  -webkit-mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .4s;
  animation:ringRotate 6s linear infinite;
}
.sc-card:hover .sc-card-num{transform:scale(1.1) rotate(-5deg);background:linear-gradient(135deg,rgba(212,175,55,.15),rgba(212,175,55,.05))}
.sc-card:hover .sc-card-num::after{opacity:1}
.sc-card h3{
  font-size:1.3rem;font-weight:800;color:var(--navy-900);margin-bottom:12px;line-height:1.2;
  transition:color .3s;
}
.sc-card:hover h3{color:var(--navy-800)}
.sc-card p{color:var(--text-muted);font-size:.95rem;line-height:1.7;margin-bottom:18px}
.sc-card-tags{display:flex;flex-wrap:wrap;gap:8px}
.sc-card-tag{
  padding:5px 14px;border-radius:50px;font-size:.72rem;font-weight:600;
  background:var(--surface-alt);border:1px solid var(--border);color:var(--text-muted);
  transition:all .35s var(--ease);
}
.sc-card:hover .sc-card-tag{
  border-color:rgba(212,175,55,.15);color:var(--gold-500);
  transform:translateY(-1px);
}
.sc-card:hover .sc-card-tag:nth-child(1){transition-delay:0s}
.sc-card:hover .sc-card-tag:nth-child(2){transition-delay:.05s}
.sc-card:hover .sc-card-tag:nth-child(3){transition-delay:.1s}

/* ============================================
   SCROLL ANIMATED SECTION
============================================ */
.ani{opacity:0;transform:translateY(40px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.ani-left{opacity:0;transform:translateX(-40px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.ani-right{opacity:0;transform:translateX(40px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.ani-scale{opacity:0;transform:scale(.92);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.ani.on,.ani-left.on,.ani-right.on,.ani-scale.on{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}.d5{transition-delay:.5s}

/* ============================================
   COUNTS BAND
============================================ */
.counts-band{position:relative;z-index:20;margin-top:-50px}
.counts-inner{
  display:grid;grid-template-columns:repeat(5,1fr);gap:1px;
  background:var(--border);border-radius:16px;overflow:hidden;
  box-shadow:0 20px 50px rgba(16,53,107,.08);
  position:relative;
}
.counts-inner::before{
  content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background:linear-gradient(120deg,transparent 30%,rgba(212,175,55,.04) 50%,transparent 70%);
  background-size:200% 100%;
  animation:statsShimmer 4s ease-in-out infinite;
}
@keyframes statsShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.count-box{
  background:#fff;padding:38px 20px;text-align:center;
  transition:all .5s var(--ease);position:relative;overflow:hidden;
}
.count-box::before{
  content:'';position:absolute;bottom:0;left:50%;width:0;height:2px;
  background:linear-gradient(90deg,var(--gold-500),var(--gold-300));
  transform:translateX(-50%);transition:width .5s var(--ease);
}
.count-box:hover::before{width:60%}
.count-box::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 50% 120%,rgba(212,175,55,.06),transparent 60%);
  opacity:0;transition:opacity .5s;
}
.count-box:hover::after{opacity:1}
.count-box:hover{background:var(--surface-alt);transform:translateY(-2px)}
.count-box .val{
  display:block;font-size:2.4rem;font-weight:800;color:var(--navy-900);margin-bottom:4px;
  position:relative;z-index:1;
}
.count-box .val .sfx{font-size:1rem;color:var(--gold-500);font-weight:600}
.count-box .lbl{
  font-size:.72rem;text-transform:uppercase;letter-spacing:2px;color:var(--text-muted);
  position:relative;z-index:1;
}

/* ============================================
   SHARED SECTION HEADERS
============================================ */
.section-header{text-align:center;max-width:640px;margin:0 auto 60px}
.section-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 18px;border-radius:50px;
  background:rgba(212,175,55,.06);border:1px solid rgba(212,175,55,.12);
  color:var(--gold-500);font-size:.72rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;
  margin-bottom:20px;
}
.pulse-dot{width:7px;height:7px;border-radius:50%;background:var(--gold-400);box-shadow:0 0 12px rgba(212,175,55,.6);animation:dotPulse 2s infinite}
.section-title{font-size:clamp(2rem,4vw,3rem);font-weight:900;line-height:1.1;color:var(--navy-900);margin-bottom:16px;letter-spacing:-1px}
.section-title em{font-style:normal;background:linear-gradient(90deg,var(--gold-500),var(--gold-300));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.section-desc{color:var(--text-muted);font-size:1.05rem;line-height:1.7}

/* ============================================
   BENTO GRID — Capabilities
============================================ */
.bento-section{padding:120px 0;background:var(--white);position:relative;overflow:hidden}
.bento-section::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 60% 50% at 30% 20%,rgba(212,175,55,.03),transparent),
             radial-gradient(ellipse 50% 60% at 80% 80%,rgba(16,53,107,.03),transparent);
}

.bento-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:auto auto;
  gap:20px;position:relative;z-index:1;
}
.bento-lg{grid-column:1;grid-row:1/3}
.bento-sm{grid-column:auto}
.bento-wide{grid-column:1/3}

.bento-card{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  background:var(--surface-alt);
  transition:all .5s var(--ease);cursor:default;
}
.bento-card-glow{
  position:absolute;inset:-1px;border-radius:inherit;z-index:0;
  background:conic-gradient(from 180deg at 50% 50%,transparent 0deg,rgba(212,175,55,.15) 60deg,transparent 120deg,rgba(16,53,107,.1) 240deg,transparent 360deg);
  opacity:0;transition:opacity .5s;
  animation:ringRotate 8s linear infinite;
}
.bento-card:hover .bento-card-glow{opacity:1}
.bento-card-border{
  position:absolute;inset:0;border-radius:inherit;z-index:1;
  border:1px solid var(--border);transition:border-color .4s;
}
.bento-card:hover .bento-card-border{border-color:rgba(212,175,55,.2)}
.bento-card-inner{position:relative;z-index:2;padding:36px;height:100%;display:flex;flex-direction:column}
.bento-card:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(16,53,107,.08)}

.bento-icon{
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,rgba(212,175,55,.08),rgba(212,175,55,.02));
  border:1px solid rgba(212,175,55,.12);
  display:grid;place-items:center;margin-bottom:20px;
  color:var(--gold-500);
}
.bento-icon svg{width:26px;height:26px}
.bento-card h3{font-size:1.2rem;font-weight:800;color:var(--navy-900);margin-bottom:10px;line-height:1.2}
.bento-card p{color:var(--text-muted);font-size:.9rem;line-height:1.65;margin-bottom:auto}

.bento-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.bento-tags span{
  padding:5px 14px;border-radius:50px;font-size:.7rem;font-weight:600;
  background:var(--white);border:1px solid var(--border);color:var(--text-muted);
  transition:all .3s;
}
.bento-card:hover .bento-tags span{border-color:rgba(212,175,55,.15);color:var(--gold-500)}

/* 3D rotating cube */
.bento-visual{flex:1;display:grid;place-items:center;min-height:120px;margin:20px 0}
.bento-3d-cube{
  width:80px;height:80px;position:relative;
  transform-style:preserve-3d;
  animation:cubeRotate 12s linear infinite;
}
.cube-face{
  position:absolute;width:80px;height:80px;
  border:1.5px solid rgba(212,175,55,.2);background:rgba(212,175,55,.03);
  backface-visibility:visible;
}
.cube-front{transform:translateZ(40px)}
.cube-back{transform:rotateY(180deg) translateZ(40px)}
.cube-left{transform:rotateY(-90deg) translateZ(40px)}
.cube-right{transform:rotateY(90deg) translateZ(40px)}
.cube-top{transform:rotateX(90deg) translateZ(40px)}
@keyframes cubeRotate{0%{transform:rotateX(-20deg) rotateY(0deg)}100%{transform:rotateX(-20deg) rotateY(360deg)}}

/* Circular metric ring */
.bento-metric{display:flex;align-items:center;gap:16px;margin-top:20px}
.metric-ring{position:relative;width:70px;height:70px}
.metric-ring svg{width:70px;height:70px;transform:rotate(-90deg)}
.metric-fill{transition:stroke-dashoffset 1.5s var(--ease)}
.metric-val{position:absolute;inset:0;display:grid;place-items:center;font-size:.85rem;font-weight:800;color:var(--gold-500)}
.metric-label{font-size:.75rem;color:var(--text-muted);font-weight:600}

/* Wave animation */
.bento-wave{margin-top:auto;padding-top:16px}
.bento-wave svg{width:100%;height:40px}
.wave-path{animation:waveMove 3s ease-in-out infinite}
.wave-2{animation-delay:.5s;animation-duration:4s}
@keyframes waveMove{0%,100%{d:path('M0,30 Q25,10 50,30 T100,30 T150,30 T200,30')}50%{d:path('M0,30 Q25,50 50,30 T100,30 T150,30 T200,30')}}

/* Horizontal layout */
.bento-horizontal{flex-direction:row;gap:40px;align-items:center}
.bento-horizontal > div:first-child{flex:1}

/* Animated bars */
.bento-bars{flex:1;display:flex;flex-direction:column;gap:14px;min-width:220px}
.bar-item{display:flex;align-items:center;gap:12px}
.bar-label{font-size:.72rem;font-weight:600;color:var(--text-muted);width:80px;text-align:right}
.bar-track{flex:1;height:8px;background:var(--white);border-radius:50px;overflow:hidden}
.bar-fill{height:100%;width:var(--w);background:linear-gradient(90deg,var(--gold-500),var(--gold-300));border-radius:50px;transform:scaleX(0);transform-origin:left;transition:transform 1.2s var(--ease)}
.bento-card:hover .bar-fill,.bento-card.on .bar-fill{transform:scaleX(1)}
.bar-val{font-size:.75rem;font-weight:800;color:var(--gold-500);width:36px}

/* Mini counter */
.bento-counter-mini{margin-top:auto;padding:16px 0 0;border-top:1px solid var(--border)}
.bento-counter-mini strong{display:block;font-size:1.5rem;color:var(--navy-900);font-weight:800}
.bento-counter-mini span{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;font-weight:600}

/* ============================================
   DASHBOARD METRICS
============================================ */
.dash-section{padding:120px 0;background:var(--surface-alt);position:relative;overflow:hidden}
.dash-section::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 50% 40% at 20% 30%,rgba(16,53,107,.03),transparent),
    radial-gradient(ellipse 40% 50% at 80% 70%,rgba(212,175,55,.03),transparent);
}
.dash-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;position:relative;z-index:1;
}

/* Base dashboard card — inherits bento style */
.dash-card{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  background:var(--white);
  transition:all .5s var(--ease);cursor:default;
}
.dash-card:hover{transform:translateY(-5px);box-shadow:0 20px 50px rgba(16,53,107,.08)}
.dash-card .bento-card-glow{
  position:absolute;inset:-1px;border-radius:inherit;z-index:0;
  background:conic-gradient(from 180deg at 50% 50%,transparent 0deg,rgba(212,175,55,.12) 60deg,transparent 120deg,rgba(16,53,107,.08) 240deg,transparent 360deg);
  opacity:0;transition:opacity .5s;animation:ringRotate 8s linear infinite;
}
.dash-card:hover .bento-card-glow{opacity:1}
.dash-card .bento-card-border{
  position:absolute;inset:0;border-radius:inherit;z-index:1;
  border:1px solid var(--border);transition:border-color .4s;
}
.dash-card:hover .bento-card-border{border-color:rgba(212,175,55,.18)}
.dash-card-inner{position:relative;z-index:2;padding:28px;height:100%;display:flex;flex-direction:column}

/* Grid placements */
.dash-kpi{grid-column:span 1}
.dash-chart-main{grid-column:span 3}
.dash-chart-side{grid-column:span 1}
.dash-bottom-wide{grid-column:span 2}
.dash-bottom-mid{grid-column:span 1}
.dash-bottom-sm{grid-column:span 1}

/* ---- KPI Cards ---- */
.kpi-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.kpi-icon{
  width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
}
.kpi-icon svg{width:20px;height:20px}
.kpi-icon--blue{background:rgba(16,53,107,.06);color:var(--navy-700)}
.kpi-icon--gold{background:rgba(212,175,55,.08);color:var(--gold-500)}
.kpi-icon--green{background:rgba(34,197,94,.08);color:#22c55e}
.kpi-icon--navy{background:rgba(16,53,107,.06);color:var(--navy-800)}

.kpi-badge{
  font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:50px;
}
.kpi-badge--up{background:rgba(34,197,94,.08);color:#16a34a}
.kpi-badge--stable{background:rgba(16,53,107,.06);color:var(--navy-700)}

.kpi-label{font-size:.78rem;color:var(--text-muted);font-weight:600;margin-bottom:6px}
.kpi-value{
  font-size:2rem;font-weight:900;color:var(--navy-900);line-height:1;margin-bottom:auto;
}
.kpi-unit{font-size:.85rem;font-weight:600;color:var(--text-muted);margin-left:2px}

/* Sparkline */
.kpi-spark{margin-top:16px;height:36px}
.kpi-spark svg{width:100%;height:100%}
.spark-line{stroke-dasharray:200;stroke-dashoffset:200;transition:stroke-dashoffset 1.5s var(--ease)}
.dash-card:hover .spark-line,.dash-card.on .spark-line{stroke-dashoffset:0}

/* Gauge bar */
.kpi-gauge{margin-top:16px}
.gauge-track{height:8px;border-radius:50px;background:var(--surface-alt);overflow:hidden}
.gauge-fill{
  height:100%;width:var(--gw);border-radius:50px;
  background:linear-gradient(90deg,var(--gold-500),var(--gold-300));
  transform:scaleX(0);transform-origin:left;transition:transform 1.2s var(--ease);
}
.dash-card:hover .gauge-fill,.dash-card.on .gauge-fill{transform:scaleX(1)}

/* Mini bar chart in KPI */
.kpi-mini-bars{display:flex;align-items:flex-end;gap:3px;margin-top:16px;height:36px}
.kpi-mini-bars span{
  flex:1;border-radius:3px 3px 0 0;
  background:linear-gradient(180deg,var(--gold-400),var(--gold-300));
  height:var(--h);transform:scaleY(0);transform-origin:bottom;
  transition:transform .8s var(--ease);
}
.kpi-mini-bars span:nth-child(odd){background:linear-gradient(180deg,var(--navy-700),var(--navy-800))}
.dash-card:hover .kpi-mini-bars span,.dash-card.on .kpi-mini-bars span{transform:scaleY(1)}
.kpi-mini-bars span:nth-child(2){transition-delay:.05s}
.kpi-mini-bars span:nth-child(3){transition-delay:.1s}
.kpi-mini-bars span:nth-child(4){transition-delay:.15s}
.kpi-mini-bars span:nth-child(5){transition-delay:.2s}
.kpi-mini-bars span:nth-child(6){transition-delay:.25s}
.kpi-mini-bars span:nth-child(7){transition-delay:.3s}
.kpi-mini-bars span:nth-child(8){transition-delay:.35s}
.kpi-mini-bars span:nth-child(9){transition-delay:.4s}
.kpi-mini-bars span:nth-child(10){transition-delay:.45s}

/* Pulsing dots */
.kpi-dots{display:flex;gap:8px;margin-top:16px;align-items:center}
.dot-pulse{
  width:10px;height:10px;border-radius:50%;
  background:var(--gold-400);opacity:.3;
  animation:dotPulse 2s ease-in-out infinite;
}
.dot-pulse.d1{animation-delay:.3s}.dot-pulse.d2{animation-delay:.6s}.dot-pulse.d3{animation-delay:.9s}.dot-pulse.d4{animation-delay:1.2s}
@keyframes dotPulse{0%,100%{opacity:.2;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}

/* ---- Chart Cards ---- */
.dash-card h3{font-size:1.1rem;font-weight:800;color:var(--navy-900);margin-bottom:4px;line-height:1.3}
.chart-sub{font-size:.75rem;color:var(--text-muted);font-weight:500}
.chart-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.chart-legend{font-size:.72rem;color:var(--text-muted);display:flex;align-items:center;gap:6px;font-weight:500}
.legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.legend-gold{background:var(--gold-400)}
.legend-navy{background:var(--navy-700)}
.legend-light{background:rgba(212,175,55,.2)}

/* Bar chart */
.chart-bars{display:flex;align-items:flex-end;gap:8px;height:160px;padding-top:8px}
.chart-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%;justify-content:flex-end}
.chart-col span{font-size:.6rem;color:var(--text-muted);font-weight:600}
.cbar{width:100%;border-radius:4px 4px 0 0;transform:scaleY(0);transform-origin:bottom;transition:transform 1s var(--ease)}
.cbar-1{height:var(--v1);background:linear-gradient(180deg,var(--gold-400),var(--gold-300))}
.cbar-2{height:var(--v2);background:linear-gradient(180deg,var(--navy-700),var(--navy-800))}
.dash-card:hover .cbar,.dash-card.on .cbar{transform:scaleY(1)}

/* Donut chart */
.donut-wrap{position:relative;width:140px;height:140px;margin:20px auto}
.donut-svg{width:100%;height:100%;transform:rotate(-90deg)}
.donut-seg{stroke-dashoffset:377;transition:stroke-dashoffset 1.2s var(--ease)}
.dash-card:hover .donut-seg,.dash-card.on .donut-seg{stroke-dashoffset:0}
.donut-seg-1{transition-delay:0s}
.donut-seg-2{transition-delay:.2s}
.donut-seg-3{transition-delay:.4s}
/* Reset targeted dashoffsets on hover */
.dash-card:hover .donut-seg-1,.dash-card.on .donut-seg-1{stroke-dashoffset:0}
.dash-card:hover .donut-seg-2,.dash-card.on .donut-seg-2{stroke-dashoffset:-226}
.dash-card:hover .donut-seg-3,.dash-card.on .donut-seg-3{stroke-dashoffset:-339}
.donut-center{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
}
.donut-center strong{font-size:1.6rem;font-weight:900;color:var(--navy-900);line-height:1}
.donut-center span{font-size:.7rem;color:var(--text-muted);font-weight:600}
.donut-legend{display:flex;flex-direction:column;gap:8px;margin-top:16px}
.donut-legend div{display:flex;align-items:center;gap:8px;font-size:.72rem;color:var(--text-muted);font-weight:500}

/* ---- Delivery bars ---- */
.delivery-rows{display:flex;flex-direction:column;gap:14px;margin-top:20px}
.del-row{display:flex;align-items:center;gap:12px}
.del-label{font-size:.72rem;font-weight:600;color:var(--text-muted);min-width:110px}
.del-track{flex:1;height:8px;background:var(--surface-alt);border-radius:50px;overflow:hidden}
.del-fill{
  height:100%;width:var(--dw);border-radius:50px;
  background:linear-gradient(90deg,var(--gold-500),var(--gold-300));
  transform:scaleX(0);transform-origin:left;transition:transform 1.2s var(--ease);
}
.dash-card:hover .del-fill,.dash-card.on .del-fill{transform:scaleX(1)}
.del-val{font-size:.75rem;font-weight:800;color:var(--gold-500);min-width:34px}

/* ---- Live Production Lines ---- */
.live-lines{display:flex;flex-direction:column;gap:10px;margin-top:16px}
.ll-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius);background:var(--surface-alt);transition:background .3s}
.ll-row:hover{background:rgba(212,175,55,.04)}
.ll-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.ll-dot--active{background:#22c55e;box-shadow:0 0 6px rgba(34,197,94,.4);animation:dotBlink 2s ease infinite}
.ll-dot--warn{background:#f59e0b;box-shadow:0 0 6px rgba(245,158,11,.4);animation:dotBlink 1s ease infinite}
.ll-dot--idle{background:rgba(16,53,107,.15)}
@keyframes dotBlink{0%,100%{opacity:1}50%{opacity:.4}}
.ll-name{flex:1;font-size:.75rem;font-weight:600;color:var(--navy-900)}
.ll-status{font-size:.65rem;font-weight:700;padding:3px 10px;border-radius:50px}
.ll-status--active{background:rgba(34,197,94,.08);color:#16a34a}
.ll-status--warn{background:rgba(245,158,11,.08);color:#d97706}
.ll-status--idle{background:rgba(16,53,107,.05);color:var(--text-muted)}
.live-summary{display:flex;gap:20px;margin-top:16px;padding-top:14px;border-top:1px solid var(--border)}
.live-summary div{display:flex;flex-direction:column}
.live-summary strong{font-size:1.1rem;font-weight:800;color:var(--navy-900)}
.live-summary span{font-size:.65rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:1px}

/* ---- Certifications ---- */
.cert-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}
.cert-badge{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:14px 8px;border-radius:var(--radius);background:var(--surface-alt);
  border:1px solid var(--border);transition:all .35s var(--ease);
}
.cert-badge:hover{border-color:rgba(212,175,55,.2);background:rgba(212,175,55,.02);transform:translateY(-2px)}
.cert-icon{font-size:1.2rem;margin-bottom:6px}
.cert-badge strong{font-size:.72rem;font-weight:800;color:var(--navy-900);line-height:1.2}
.cert-badge small{font-size:.6rem;color:var(--text-muted);font-weight:500;margin-top:2px}

/* ============================================
   PRODUCT CARDS
============================================ */
.products-section{padding:120px 0;background:var(--surface-alt);position:relative;overflow:hidden}
.products-section::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 60% 50% at 30% 20%,rgba(212,175,55,.03),transparent),
             radial-gradient(ellipse 50% 60% at 80% 80%,rgba(16,53,107,.03),transparent);
}

.prod-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  position:relative;z-index:1;
  perspective:1400px;
}

.prod-card{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  background:var(--white);border:1px solid var(--border);
  transition:all .6s var(--ease);
  transform-style:preserve-3d;
}
.prod-card:hover{
  transform:translateY(-10px) rotateX(2deg);
  box-shadow:0 30px 70px rgba(16,53,107,.12);
  border-color:rgba(212,175,55,.15);
}

/* Spotlight follow cursor */
.prod-card-spotlight{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(circle 250px at var(--mx,50%) var(--my,50%),rgba(212,175,55,.05),transparent 60%);
  opacity:0;transition:opacity .4s;
}
.prod-card:hover .prod-card-spotlight{opacity:1}

/* Image area */
.prod-card-img{
  position:relative;height:210px;overflow:hidden;
}
.prod-card-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s var(--ease),filter .6s;
}
.prod-card:hover .prod-card-img img{transform:scale(1.1) translateY(-4px);filter:brightness(1.05)}
.prod-card-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(7,22,49,.6));
  opacity:.6;transition:opacity .5s;
}
.prod-card:hover .prod-card-overlay{opacity:.3}

/* Badge */
.prod-card-badge{
  position:absolute;top:14px;right:14px;z-index:2;
  padding:5px 14px;border-radius:50px;
  font-size:.68rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  background:linear-gradient(135deg,var(--gold-500),var(--gold-400));
  color:var(--navy-950);
  box-shadow:0 4px 16px rgba(212,175,55,.3);
  animation:badgeFloat 3s ease-in-out infinite;
}

/* Card body */
.prod-card-body{
  padding:28px;display:flex;flex-direction:column;gap:12px;position:relative;z-index:1;
}

.prod-card-icon{
  width:48px;height:48px;border-radius:14px;
  background:linear-gradient(135deg,rgba(212,175,55,.08),rgba(212,175,55,.02));
  border:1px solid rgba(212,175,55,.12);
  display:grid;place-items:center;
  color:var(--gold-500);
  transition:all .5s var(--ease);
  position:relative;
}
.prod-card-icon::after{
  content:'';position:absolute;inset:-2px;border-radius:16px;
  background:conic-gradient(from 0deg,transparent,rgba(212,175,55,.25),transparent 40%) border-box;
  -webkit-mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .4s;animation:ringRotate 5s linear infinite;
}
.prod-card-icon svg{width:22px;height:22px}
.prod-card:hover .prod-card-icon{
  background:linear-gradient(135deg,var(--gold-500),var(--gold-400));
  color:var(--navy-950);border-color:transparent;
  box-shadow:0 8px 24px rgba(212,175,55,.25);
  transform:scale(1.08) rotate(-4deg);
}
.prod-card:hover .prod-card-icon::after{opacity:1}

.prod-card-body h3{
  font-size:1.15rem;font-weight:800;color:var(--navy-900);line-height:1.2;
  margin:0;transition:color .3s;
}
.prod-card:hover .prod-card-body h3{color:var(--navy-800)}
.prod-card-body p{
  color:var(--text-muted);font-size:.88rem;line-height:1.65;margin:0;
}

.prod-card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.prod-card-tags span{
  padding:4px 12px;border-radius:50px;font-size:.68rem;font-weight:600;
  background:var(--surface-alt);border:1px solid var(--border);color:var(--text-muted);
  transition:all .35s var(--ease);
  transform:translateY(0);
}
.prod-card:hover .prod-card-tags span{border-color:rgba(212,175,55,.15);color:var(--gold-500);transform:translateY(-2px)}
.prod-card:hover .prod-card-tags span:nth-child(1){transition-delay:0s}
.prod-card:hover .prod-card-tags span:nth-child(2){transition-delay:.06s}
.prod-card:hover .prod-card-tags span:nth-child(3){transition-delay:.12s}

.prod-card-link{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.82rem;font-weight:700;color:var(--gold-500);
  margin-top:auto;padding-top:8px;
  transition:all .3s var(--ease);position:relative;
}
.prod-card-link::after{
  content:'';position:absolute;bottom:-2px;left:0;width:0;height:1.5px;
  background:linear-gradient(90deg,var(--gold-500),var(--gold-300));
  transition:width .3s var(--ease);
}
.prod-card-link:hover::after{width:100%}
.prod-card-link svg{transition:transform .3s}
.prod-card-link:hover{color:var(--navy-900)}
.prod-card-link:hover svg{transform:translateX(5px)}

/* Gold top line on hover */
.prod-card > .prod-card-line{
  position:absolute;top:0;left:0;right:0;height:3px;z-index:3;
  background:linear-gradient(90deg,var(--gold-500),var(--gold-300),var(--gold-400));
  background-size:200% 100%;animation:gradX 3s ease infinite;
  transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);
}
.prod-card:hover > .prod-card-line{transform:scaleX(1)}

/* ============================================
   PROCESS TIMELINE
============================================ */
.process-section{padding:120px 0 80px;background:var(--white);position:relative;overflow:hidden}
.process-track-wrapper{overflow-x:auto;overflow-y:visible;padding:0 0 40px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.process-track-wrapper::-webkit-scrollbar{display:none}
.process-track{
  display:flex;align-items:flex-start;gap:0;
  padding:40px 60px 20px;min-width:max-content;position:relative;
}

.process-line{
  position:absolute;top:60px;left:80px;right:80px;height:2px;
  background:var(--border);z-index:0;
}
.process-line-fill{
  width:0;height:100%;
  background:linear-gradient(90deg,var(--gold-500),var(--gold-300));
  border-radius:50px;transition:width 2s var(--ease);
}

.process-step{
  position:relative;z-index:2;
  display:flex;flex-direction:column;align-items:center;
  width:260px;flex-shrink:0;
}

.step-node{position:relative;width:44px;height:44px;margin-bottom:24px}
.step-dot{
  position:absolute;inset:12px;border-radius:50%;
  background:var(--gold-400);
  box-shadow:0 0 20px rgba(212,175,55,.3);
  z-index:2;transition:all .5s var(--ease);
}
.process-step:hover .step-dot{transform:scale(1.5);box-shadow:0 0 30px rgba(212,175,55,.5)}
.step-ring{
  position:absolute;inset:0;border-radius:50%;
  border:2px solid rgba(212,175,55,.2);
  transition:all .5s var(--ease);
}
.process-step:hover .step-ring{border-color:var(--gold-400);transform:scale(1.4);border-width:3px}
.step-ping{
  position:absolute;inset:0;border-radius:50%;
  border:2px solid var(--gold-400);opacity:0;
  animation:pulseRing 3s ease-out infinite;
}

.step-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:28px 24px;
  text-align:center;
  box-shadow:0 4px 20px rgba(16,53,107,.04);
  transition:all .6s var(--ease);position:relative;overflow:hidden;
  width:220px;transform-style:preserve-3d;
}
.step-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold-500),var(--gold-300));
  transform:scaleX(0);transition:transform .5s var(--ease);
}
.step-card::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle 200px at 50% 0%,rgba(212,175,55,.04),transparent 60%);
  opacity:0;transition:opacity .4s;
}
.process-step:hover .step-card::before{transform:scaleX(1)}
.process-step:hover .step-card::after{opacity:1}
.process-step:hover .step-card{
  transform:translateY(-10px) rotateX(2deg);
  box-shadow:0 24px 60px rgba(16,53,107,.1);
  border-color:rgba(212,175,55,.15);
}

.step-num{
  display:inline-block;font-size:.7rem;font-weight:800;color:var(--gold-500);
  letter-spacing:2px;margin-bottom:12px;
  padding:4px 14px;border-radius:50px;
  background:rgba(212,175,55,.06);border:1px solid rgba(212,175,55,.12);
  transition:all .4s var(--ease);
}
.process-step:hover .step-num{background:linear-gradient(135deg,var(--gold-500),var(--gold-400));color:var(--navy-950);border-color:transparent}
.step-card h4{font-size:1.05rem;font-weight:800;color:var(--navy-900);margin-bottom:8px;line-height:1.2}
.step-card p{font-size:.82rem;color:var(--text-muted);line-height:1.6}

.step-icon-float{
  position:absolute;top:-10px;right:-10px;
  width:46px;height:46px;border-radius:50%;
  background:var(--navy-900);color:var(--gold-400);
  display:grid;place-items:center;
  box-shadow:0 8px 24px rgba(7,22,49,.25);
  opacity:0;transform:scale(.5) rotate(-25deg);
  transition:all .6s var(--ease);
}
.step-icon-float svg{width:20px;height:20px}
.process-step:hover .step-icon-float{opacity:1;transform:scale(1) rotate(0)}

/* ============================================
   TRUST / CERTIFICATES MARQUEE
============================================ */
.trust-section{padding:100px 0;background:var(--white);overflow:hidden}

.trust-marquee-wrap{margin-top:20px;display:flex;flex-direction:column;gap:16px}
.trust-marquee{overflow:hidden;position:relative;padding:6px 0}
.trust-marquee::before,.trust-marquee::after{
  content:'';position:absolute;top:0;bottom:0;width:180px;z-index:2;pointer-events:none;
}
.trust-marquee::before{left:0;background:linear-gradient(90deg,var(--white),transparent)}
.trust-marquee::after{right:0;background:linear-gradient(-90deg,var(--white),transparent)}

.trust-marquee-track{
  display:flex;gap:16px;width:max-content;
  animation:trustScroll 35s linear infinite;
}
.trust-reverse{animation-name:trustScrollReverse}

@keyframes trustScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes trustScrollReverse{0%{transform:translateX(-50%)}100%{transform:translateX(0)}}

.trust-badge{
  flex-shrink:0;padding:20px 32px;border-radius:14px;
  background:var(--surface-alt);border:1px solid var(--border);
  transition:all .4s var(--ease);position:relative;overflow:hidden;
}
.trust-badge::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(212,175,55,.04),transparent);
  opacity:0;transition:opacity .4s;
}
.trust-badge:hover::before{opacity:1}
.trust-badge:hover{border-color:rgba(212,175,55,.2);transform:translateY(-4px);box-shadow:0 12px 30px rgba(16,53,107,.06)}

.trust-badge-inner{text-align:center}
.trust-badge-inner strong{display:block;font-size:1.1rem;font-weight:800;color:var(--navy-900);margin-bottom:4px}
.trust-badge-inner span{font-size:.68rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;font-weight:600}

.trust-badge.accent{background:var(--navy-900);border-color:rgba(212,175,55,.1)}
.trust-badge.accent .trust-badge-inner strong{color:var(--gold-400)}
.trust-badge.accent .trust-badge-inner span{color:rgba(255,255,255,.45)}
.trust-badge.accent:hover{background:var(--navy-800);border-color:rgba(212,175,55,.25)}

/* Pause on hover */
.trust-marquee:hover .trust-marquee-track{animation-play-state:paused}

/* ============================================
   CTA MEGA BANNER
============================================ */
.cta-section{
  position:relative;padding:140px 0;overflow:hidden;
  background:var(--navy-950);
}

.cta-blob{
  position:absolute;border-radius:50%;filter:blur(120px);
  mix-blend-mode:screen;z-index:1;
}
.cta-blob-1{
  width:600px;height:600px;top:-200px;left:-100px;
  background:rgba(212,175,55,.08);
  animation:ctaBlob1 20s ease-in-out infinite;
}
.cta-blob-2{
  width:400px;height:400px;bottom:-100px;right:-50px;
  background:rgba(16,53,107,.3);
  animation:ctaBlob2 18s ease-in-out infinite;
}
.cta-blob-3{
  width:300px;height:300px;top:50%;left:50%;
  transform:translate(-50%,-50%);
  background:rgba(212,175,55,.05);
  animation:ctaBlob3 15s ease-in-out infinite;
}
@keyframes ctaBlob1{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(60px,40px) scale(1.1)}66%{transform:translate(-30px,80px) scale(.9)}}
@keyframes ctaBlob2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-80px,-50px) scale(1.15)}}
@keyframes ctaBlob3{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.3)}}

.cta-grid-overlay{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background-image:
    linear-gradient(rgba(212,175,55,.02) 1px,transparent 1px),
    linear-gradient(90deg,rgba(212,175,55,.02) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 60% 60% at 50% 50%,black 20%,transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse 60% 60% at 50% 50%,black 20%,transparent 70%);
}

/* Floating shapes */
.cta-shapes{position:absolute;inset:0;z-index:2;pointer-events:none}
.cta-shape{position:absolute;border:1px solid rgba(212,175,55,.08)}
.shape-1{width:60px;height:60px;border-radius:50%;top:15%;left:10%;animation:shapeFloat1 12s ease-in-out infinite}
.shape-2{width:40px;height:40px;top:70%;left:20%;transform:rotate(45deg);animation:shapeFloat2 10s ease-in-out infinite}
.shape-3{width:80px;height:80px;border-radius:50%;top:20%;right:15%;border-width:2px;animation:shapeFloat3 14s ease-in-out infinite}
.shape-4{width:30px;height:30px;bottom:20%;right:25%;transform:rotate(30deg);animation:shapeFloat1 11s ease-in-out infinite reverse}
.shape-5{width:50px;height:50px;border-radius:50%;bottom:30%;left:40%;animation:shapeFloat2 16s ease-in-out infinite}

@keyframes shapeFloat1{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-30px) rotate(180deg)}}
@keyframes shapeFloat2{0%,100%{transform:translateY(0) rotate(45deg)}50%{transform:translateY(-25px) rotate(225deg)}}
@keyframes shapeFloat3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-20px,-30px) scale(1.1)}}

.cta-badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 20px;border-radius:50px;
  background:rgba(212,175,55,.06);border:1px solid rgba(212,175,55,.12);
  color:var(--gold-300);font-size:.72rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  margin-bottom:28px;
}
.cta-badge-dot{width:7px;height:7px;border-radius:50%;background:var(--gold-400);box-shadow:0 0 12px rgba(212,175,55,.6);animation:dotPulse 2s infinite}

.cta-title{font-size:clamp(2rem,4.5vw,3.4rem);font-weight:900;line-height:1.1;color:#fff;letter-spacing:-1.5px;margin-bottom:24px}
.cta-title-gradient{
  background:linear-gradient(90deg,var(--gold-400),var(--gold-300),var(--gold-500));
  background-size:200% 100%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:goldShimmer 4s ease infinite;
}

.cta-desc{font-size:1.08rem;color:rgba(255,255,255,.45);line-height:1.8;margin-bottom:40px}

.cta-btns{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-bottom:48px}

.cta-btn-primary{
  display:inline-flex;align-items:center;gap:10px;
  padding:18px 38px;border-radius:var(--radius);
  font-weight:800;font-size:.88rem;letter-spacing:1px;text-transform:uppercase;
  background:linear-gradient(135deg,var(--gold-500),var(--gold-400));
  color:var(--navy-950);border:none;cursor:pointer;position:relative;overflow:hidden;
  box-shadow:0 10px 40px rgba(212,175,55,.25);
  transition:all .4s var(--ease);
}
.cta-btn-shine{
  position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);
  transform:skewX(-20deg);transition:left .6s;
}
.cta-btn-primary:hover .cta-btn-shine{left:160%}
.cta-btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 50px rgba(212,175,55,.35)}
.cta-btn-primary svg{transition:transform .3s}
.cta-btn-primary:hover svg{transform:translateX(4px)}

.cta-btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  padding:18px 34px;border-radius:var(--radius);
  font-weight:700;font-size:.88rem;letter-spacing:.5px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.7);cursor:pointer;
  transition:all .35s var(--ease);
}
.cta-btn-ghost:hover{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(212,175,55,.25);transform:translateY(-3px)}

.cta-trust-row{
  display:flex;justify-content:center;align-items:center;gap:24px;flex-wrap:wrap;
  padding-top:40px;border-top:1px solid rgba(255,255,255,.06);
}
.cta-trust-item{font-size:.85rem;color:rgba(255,255,255,.35)}
.cta-trust-item strong{color:var(--gold-400);font-weight:800}
.cta-trust-sep{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.15)}

/* ============================================
   FAQ ACCORDION
============================================ */
.faq-section{padding:120px 0;background:var(--surface-alt)}

.faq-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start}
.faq-left{position:sticky;top:100px}

.faq-decoration{position:relative;width:200px;height:200px;margin-top:40px}
.faq-deco-ring{
  position:absolute;inset:0;border:2px solid rgba(212,175,55,.08);border-radius:50%;
  animation:ringRotate 30s linear infinite;
}
.faq-deco-ring-2{inset:20px;border-color:rgba(16,53,107,.06);animation-direction:reverse;animation-duration:25s}
.faq-deco-dots{
  position:absolute;inset:0;display:grid;
  grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);
  place-items:center;padding:50px;
}
.faq-deco-dots span{
  width:6px;height:6px;border-radius:50%;background:rgba(212,175,55,.15);
  animation:dotPulse 3s ease-in-out infinite;
}
.faq-deco-dots span:nth-child(2){animation-delay:.3s}
.faq-deco-dots span:nth-child(3){animation-delay:.6s}
.faq-deco-dots span:nth-child(4){animation-delay:.9s}
.faq-deco-dots span:nth-child(5){animation-delay:1.2s;background:var(--gold-400);width:10px;height:10px}
.faq-deco-dots span:nth-child(6){animation-delay:1.5s}
.faq-deco-dots span:nth-child(7){animation-delay:1.8s}
.faq-deco-dots span:nth-child(8){animation-delay:2.1s}
.faq-deco-dots span:nth-child(9){animation-delay:2.4s}

.faq-item{
  border:1px solid var(--border);border-radius:var(--radius-lg);
  background:var(--white);margin-bottom:12px;overflow:hidden;
  transition:all .4s var(--ease);position:relative;
}
.faq-item::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--gold-500),var(--gold-300));
  transform:scaleY(0);transform-origin:top;transition:transform .4s var(--ease);
  border-radius:0 2px 2px 0;
}
.faq-item.active::before{transform:scaleY(1)}
.faq-item:hover,.faq-item.active{border-color:rgba(212,175,55,.15);box-shadow:0 12px 40px rgba(16,53,107,.06)}
.faq-item.active{transform:translateX(4px)}

.faq-trigger{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:22px 28px;background:none;border:none;cursor:pointer;
  font-size:.95rem;font-weight:700;color:var(--navy-900);text-align:left;
  font-family:inherit;transition:color .3s;
}
.faq-trigger:hover{color:var(--gold-500)}

.faq-icon{
  position:relative;width:32px;height:32px;flex-shrink:0;
  border-radius:10px;background:rgba(212,175,55,.06);
  border:1px solid rgba(212,175,55,.12);
  transition:all .4s var(--ease);
}
.faq-icon span{
  position:absolute;background:var(--gold-500);border-radius:2px;
  transition:transform .4s var(--ease);
}
.faq-icon span:first-child{width:12px;height:2px;top:50%;left:50%;transform:translate(-50%,-50%)}
.faq-icon span:last-child{width:2px;height:12px;top:50%;left:50%;transform:translate(-50%,-50%)}
.faq-item.active .faq-icon span:last-child{transform:translate(-50%,-50%) rotate(90deg)}
.faq-item.active .faq-icon{
  background:linear-gradient(135deg,var(--gold-500),var(--gold-400));
  border-color:var(--gold-400);transform:rotate(45deg);
}
.faq-item.active .faq-icon span{background:#fff}

.faq-answer{
  max-height:0;overflow:hidden;
  transition:max-height .5s var(--ease),opacity .3s;
  opacity:0;
}
.faq-item.active .faq-answer{max-height:300px;opacity:1}

.faq-answer-inner{
  padding:0 28px 24px;color:var(--text-muted);font-size:.9rem;line-height:1.75;
  border-top:1px solid var(--border);padding-top:16px;margin:0 16px;
  animation:faqSlideIn .4s var(--ease);
}
@keyframes faqSlideIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

/* FAQ number badge */
.faq-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:8px;flex-shrink:0;
  background:linear-gradient(135deg,rgba(212,175,55,.06),rgba(212,175,55,.02));
  border:1px solid rgba(212,175,55,.1);
  font-size:.7rem;font-weight:800;color:var(--gold-500);
  transition:all .4s var(--ease);
}
.faq-item.active .faq-num{
  background:linear-gradient(135deg,var(--gold-500),var(--gold-400));
  color:var(--navy-950);border-color:transparent;
  transform:scale(1.1);box-shadow:0 4px 14px rgba(212,175,55,.2);
}

/* CTA floating particles */
.cta-particles{position:absolute;inset:0;z-index:2;pointer-events:none;overflow:hidden}
.cta-particle{
  position:absolute;width:3px;height:3px;border-radius:50%;
  background:rgba(212,175,55,.3);
  animation:particleRise linear infinite;
}
.cta-particle:nth-child(1){left:10%;animation-duration:8s;animation-delay:0s}
.cta-particle:nth-child(2){left:20%;animation-duration:12s;animation-delay:2s;width:2px;height:2px}
.cta-particle:nth-child(3){left:35%;animation-duration:10s;animation-delay:4s}
.cta-particle:nth-child(4){left:50%;animation-duration:9s;animation-delay:1s;width:4px;height:4px;background:rgba(212,175,55,.15)}
.cta-particle:nth-child(5){left:65%;animation-duration:11s;animation-delay:3s;width:2px;height:2px}
.cta-particle:nth-child(6){left:75%;animation-duration:7s;animation-delay:5s}
.cta-particle:nth-child(7){left:85%;animation-duration:13s;animation-delay:0.5s;width:4px;height:4px;background:rgba(16,53,107,.4)}
.cta-particle:nth-child(8){left:90%;animation-duration:9s;animation-delay:6s;width:2px;height:2px}
@keyframes particleRise{
  0%{transform:translateY(100vh) scale(0);opacity:0}
  10%{opacity:1;transform:translateY(90vh) scale(1)}
  90%{opacity:.6}
  100%{transform:translateY(-20px) scale(0);opacity:0}
}

/* CTA glow pulse on content */
.cta-content{text-align:center;max-width:700px;margin:0 auto;position:relative}
.cta-content::before{
  content:'';position:absolute;
  width:400px;height:400px;top:50%;left:50%;
  transform:translate(-50%,-50%);border-radius:50%;
  background:radial-gradient(circle,rgba(212,175,55,.06),transparent 60%);
  animation:ctaGlowPulse 4s ease-in-out infinite;pointer-events:none;
}
@keyframes ctaGlowPulse{0%,100%{transform:translate(-50%,-50%) scale(.8);opacity:.5}50%{transform:translate(-50%,-50%) scale(1.2);opacity:1}}

/* ============================================
   CONTACT SECTION
============================================ */
.contact-section{padding:120px 0;background:var(--white);position:relative;overflow:hidden}
.contact-section::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 50% 40% at 10% 20%,rgba(212,175,55,.03),transparent),
    radial-gradient(ellipse 40% 50% at 90% 80%,rgba(16,53,107,.03),transparent);
}

.contact-grid{
  display:grid;grid-template-columns:1fr 1.3fr;gap:30px;
  position:relative;z-index:1;
}

/* Contact Info Cards */
.contact-info{display:flex;flex-direction:column;gap:16px}
.contact-card{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  background:var(--surface-alt);transition:all .5s var(--ease);cursor:default;
}
.contact-card-glow{
  position:absolute;inset:-1px;border-radius:inherit;z-index:0;
  background:conic-gradient(from 180deg at 50% 50%,transparent 0deg,rgba(212,175,55,.12) 60deg,transparent 120deg,rgba(16,53,107,.08) 240deg,transparent 360deg);
  opacity:0;transition:opacity .5s;animation:ringRotate 8s linear infinite;
}
.contact-card:hover .contact-card-glow{opacity:1}
.contact-card-border{
  position:absolute;inset:0;border-radius:inherit;z-index:1;
  border:1px solid var(--border);transition:border-color .4s;
}
.contact-card:hover .contact-card-border{border-color:rgba(212,175,55,.18)}
.contact-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(16,53,107,.07)}
.contact-card-inner{
  position:relative;z-index:2;padding:24px 28px;
  display:flex;align-items:flex-start;gap:18px;
}
.contact-card-icon{
  width:48px;height:48px;border-radius:14px;flex-shrink:0;
  background:linear-gradient(135deg,rgba(212,175,55,.08),rgba(212,175,55,.02));
  border:1px solid rgba(212,175,55,.12);
  display:grid;place-items:center;color:var(--gold-500);
  transition:all .4s var(--ease);
}
.contact-card-icon svg{width:22px;height:22px}
.contact-card:hover .contact-card-icon{
  background:linear-gradient(135deg,var(--gold-500),var(--gold-400));
  color:var(--navy-950);border-color:transparent;
  box-shadow:0 6px 20px rgba(212,175,55,.2);transform:scale(1.05);
}
.contact-card h4{font-size:1rem;font-weight:800;color:var(--navy-900);margin-bottom:6px}
.contact-card p{font-size:.88rem;color:var(--text-muted);line-height:1.6;margin:0}
.contact-card a{color:var(--navy-900);font-weight:600;transition:color .3s}
.contact-card a:hover{color:var(--gold-500)}
.contact-sub{font-size:.75rem!important;color:var(--text-light)!important;margin-top:4px!important}

/* Contact Form */
.contact-form-wrap{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  background:var(--surface-alt);
}
.contact-form-glow{
  position:absolute;inset:-1px;border-radius:inherit;z-index:0;
  background:conic-gradient(from 90deg at 50% 50%,transparent 0deg,rgba(212,175,55,.1) 90deg,transparent 180deg,rgba(16,53,107,.06) 300deg,transparent 360deg);
  opacity:0;transition:opacity .6s;animation:ringRotate 10s linear infinite;
}
.contact-form-wrap:hover .contact-form-glow{opacity:1}
.contact-form-border{
  position:absolute;inset:0;border-radius:inherit;z-index:1;
  border:1px solid var(--border);transition:border-color .4s;
}
.contact-form-wrap:hover .contact-form-border{border-color:rgba(212,175,55,.15)}
.contact-form-inner{position:relative;z-index:2;padding:40px}
.contact-form-inner h3{font-size:1.4rem;font-weight:800;color:var(--navy-900);margin-bottom:6px}
.contact-form-desc{font-size:.88rem;color:var(--text-muted);margin-bottom:28px}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.form-group label{
  font-size:.75rem;font-weight:700;color:var(--navy-900);
  letter-spacing:.5px;text-transform:uppercase;
}
.form-group input,
.form-group select,
.form-group textarea{
  padding:14px 18px;border-radius:var(--radius);
  border:1px solid var(--border);background:var(--white);
  font-family:inherit;font-size:.9rem;color:var(--navy-900);
  transition:all .3s var(--ease);outline:none;
  -webkit-appearance:none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  border-color:var(--gold-400);
  box-shadow:0 0 0 3px rgba(212,175,55,.08);
}
.form-group input::placeholder,
.form-group textarea::placeholder{color:rgba(16,53,107,.25)}
.form-group select{cursor:pointer;color:var(--text-muted)}
.form-group textarea{resize:vertical;min-height:100px}

.contact-submit{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 36px;border-radius:var(--radius);
  font-weight:800;font-size:.88rem;letter-spacing:1px;text-transform:uppercase;
  background:linear-gradient(135deg,var(--gold-500),var(--gold-400));
  color:var(--navy-950);border:none;cursor:pointer;
  position:relative;overflow:hidden;
  box-shadow:0 8px 30px rgba(212,175,55,.2);
  transition:all .4s var(--ease);font-family:inherit;
}
.contact-submit-shine{
  position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);
  transform:skewX(-20deg);transition:left .6s;
}
.contact-submit:hover .contact-submit-shine{left:160%}
.contact-submit:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(212,175,55,.3)}
.contact-submit svg{transition:transform .3s}
.contact-submit:hover svg{transform:translateX(4px)}

/* Map */
.contact-map{
  margin-top:40px;border-radius:var(--radius-lg);overflow:hidden;
  height:260px;position:relative;
  background:linear-gradient(135deg,var(--navy-900),var(--navy-950));
  border:1px solid rgba(212,175,55,.08);
}
.contact-map-overlay{
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 40% 50%,rgba(212,175,55,.06),transparent 40%),
    linear-gradient(135deg,rgba(16,53,107,.9),rgba(2,10,24,.95));
  display:flex;align-items:center;justify-content:center;
}
.contact-map-pin{
  display:flex;flex-direction:column;align-items:center;gap:12px;
  color:var(--gold-400);text-align:center;
}
.contact-map-pin svg{animation:pinBounce 2s ease-in-out infinite}
.contact-map-pin span{font-size:.85rem;color:rgba(255,255,255,.5);font-weight:500}
@keyframes pinBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* ============================================
   FOOTER
============================================ */
.footer-section{
  background:var(--navy-950);padding:80px 0 0;position:relative;overflow:hidden;
  border-top:1px solid rgba(212,175,55,.06);
}
.footer-section::before{
  content:'';position:absolute;top:0;left:50%;width:600px;height:600px;
  transform:translate(-50%,-60%);border-radius:50%;
  background:radial-gradient(circle,rgba(212,175,55,.04),transparent 60%);pointer-events:none;
}

.footer-top{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1.3fr;gap:40px;
  padding-bottom:60px;
}

/* Brand */
.footer-brand{max-width:280px}
.footer-logo{
  display:inline-flex;align-items:center;gap:8px;
  font-weight:900;font-size:1.1rem;letter-spacing:2px;
  color:var(--gold-400);margin-bottom:16px;
}
.footer-logo-icon{display:flex;color:var(--gold-400)}
.footer-logo-icon svg{width:28px;height:28px}
.footer-desc{font-size:.84rem;color:rgba(255,255,255,.35);line-height:1.7;margin-bottom:24px}

.footer-socials{display:flex;gap:10px}
.footer-social{
  width:38px;height:38px;border-radius:10px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);
  display:grid;place-items:center;color:rgba(255,255,255,.4);
  transition:all .35s var(--ease);
}
.footer-social svg{width:16px;height:16px}
.footer-social:hover{
  background:rgba(212,175,55,.1);border-color:rgba(212,175,55,.2);
  color:var(--gold-400);transform:translateY(-3px);
  box-shadow:0 6px 20px rgba(212,175,55,.1);
}

/* Link Groups */
.footer-links-group h5{
  font-size:.78rem;font-weight:800;color:var(--gold-400);
  letter-spacing:2px;text-transform:uppercase;margin-bottom:20px;
}
.footer-links-group ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.footer-links-group li a{
  font-size:.84rem;color:rgba(255,255,255,.35);
  transition:all .3s var(--ease);display:inline-flex;align-items:center;gap:0;
  position:relative;
}
.footer-links-group li a::before{
  content:'';width:0;height:1px;
  background:var(--gold-400);margin-right:0;
  transition:all .3s var(--ease);
}
.footer-links-group li a:hover{color:var(--gold-400)}
.footer-links-group li a:hover::before{width:12px;margin-right:8px}

/* Newsletter */
.footer-newsletter h5{
  font-size:.78rem;font-weight:800;color:var(--gold-400);
  letter-spacing:2px;text-transform:uppercase;margin-bottom:12px;
}
.footer-newsletter p{font-size:.82rem;color:rgba(255,255,255,.3);line-height:1.6;margin-bottom:16px}

.footer-nl-form{display:flex;gap:0;margin-bottom:20px}
.footer-nl-form input{
  flex:1;padding:12px 16px;border-radius:var(--radius) 0 0 var(--radius);
  border:1px solid rgba(255,255,255,.08);border-right:none;
  background:rgba(255,255,255,.04);
  font-family:inherit;font-size:.84rem;color:#fff;outline:none;
  transition:all .3s;
}
.footer-nl-form input::placeholder{color:rgba(255,255,255,.2)}
.footer-nl-form input:focus{border-color:rgba(212,175,55,.3);background:rgba(255,255,255,.06)}
.footer-nl-form button{
  padding:12px 18px;border-radius:0 var(--radius) var(--radius) 0;
  background:linear-gradient(135deg,var(--gold-500),var(--gold-400));
  border:none;cursor:pointer;color:var(--navy-950);
  transition:all .3s var(--ease);display:grid;place-items:center;
}
.footer-nl-form button:hover{background:linear-gradient(135deg,var(--gold-400),var(--gold-300));transform:translateX(2px)}

.footer-badges{display:flex;gap:8px;flex-wrap:wrap}
.footer-cert{
  padding:4px 12px;border-radius:6px;
  font-size:.65rem;font-weight:700;letter-spacing:1px;
  background:rgba(212,175,55,.06);border:1px solid rgba(212,175,55,.1);
  color:var(--gold-400);
}

/* Divider */
.footer-divider{
  height:1px;width:100%;
  background:linear-gradient(90deg,transparent,rgba(212,175,55,.12),rgba(255,255,255,.04),rgba(212,175,55,.12),transparent);
}

/* Bottom */
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding:24px 0;flex-wrap:wrap;gap:16px;
}
.footer-bottom span{font-size:.78rem;color:rgba(255,255,255,.25)}
.footer-bottom-links{display:flex;gap:24px}
.footer-bottom-links a{font-size:.78rem;color:rgba(255,255,255,.25);transition:color .3s}
.footer-bottom-links a:hover{color:var(--gold-400)}

/* ============================================
   RESPONSIVE
============================================ */
@media(max-width:1100px){
  .mb-content{grid-template-columns:1fr;gap:40px;padding:100px 0 120px}
  .mb-right{min-height:400px}
  .mb-card-stack{width:340px;height:400px}
  .mb-card-1{width:300px;height:350px;left:30px}
  .mb-card-2{width:320px;height:370px;left:16px}
  .mb-card-3{width:330px;height:390px}
  .sc-split{grid-template-columns:1fr}
  .sc-media{position:relative;height:60vh}
  .counts-inner{grid-template-columns:repeat(3,1fr)}
  .prod-grid{grid-template-columns:1fr 1fr}
  .bento-grid{grid-template-columns:1fr 1fr}
  .bento-lg{grid-column:1/3;grid-row:auto}
  .bento-wide{grid-column:1/3}
  .faq-layout{grid-template-columns:1fr;gap:40px}
  .faq-left{position:static}
  .faq-decoration{display:none}
  .bento-horizontal{flex-direction:column;gap:24px}
  .dash-grid{grid-template-columns:repeat(2,1fr)}
  .dash-chart-main{grid-column:span 2}
  .dash-chart-side{grid-column:span 2}
  .dash-bottom-wide{grid-column:span 2}
  .dash-bottom-mid{grid-column:span 1}
  .dash-bottom-sm{grid-column:span 1}
  .contact-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr 1fr 1fr;gap:30px}
  .footer-brand{max-width:100%;grid-column:1/3}
  .footer-newsletter{grid-column:3/5}
}
@media(max-width:768px){
  .nav-links{display:none}
  .topbar{display:none}
  .mb-content{padding:80px 0 110px}
  .mb-title{font-size:clamp(2rem,8vw,2.6rem);letter-spacing:-.5px}
  .mb-micros{flex-wrap:wrap;gap:20px}
  .mb-micro{width:calc(50% - 10px)}
  .mb-right{display:none}
  .sc-media{height:50vh}
  .sc-media-content{padding:40px 24px}
  .sc-big-num{font-size:5rem}
  .sc-cards{padding:60px 20px;gap:20px;grid-template-columns:1fr}
  .sc-card{padding:28px}
  .sc-pulse-ring{display:none}
  .counts-inner{grid-template-columns:1fr 1fr}
  .prod-grid{grid-template-columns:1fr}
  .products-section{padding:80px 0}
  .bento-grid{grid-template-columns:1fr}
  .bento-lg,.bento-wide{grid-column:1}
  .bento-section{padding:80px 0}
  .process-section{padding:80px 0 40px}
  .cta-section{padding:80px 0}
  .cta-title{font-size:clamp(1.8rem,6vw,2.4rem)}
  .faq-section{padding:80px 0}
  .trust-section{padding:60px 0}
  .section-header{margin-bottom:40px}
  .dash-grid{grid-template-columns:1fr}
  .dash-kpi,.dash-chart-main,.dash-chart-side,.dash-bottom-wide,.dash-bottom-mid,.dash-bottom-sm{grid-column:1}
  .dash-section{padding:80px 0}
  .chart-bars{height:120px}
  .dash-card-inner{padding:22px}
  .cert-grid{grid-template-columns:repeat(3,1fr)}
  .contact-section{padding:80px 0}
  .contact-grid{grid-template-columns:1fr}
  .contact-form-inner{padding:28px}
  .form-row{grid-template-columns:1fr}
  .contact-map{height:200px}
  .footer-top{grid-template-columns:1fr 1fr;gap:30px}
  .footer-brand{grid-column:1/3;max-width:100%}
  .footer-newsletter{grid-column:1/3}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:12px}
  .footer-bottom-links{flex-wrap:wrap;gap:16px}
}
