/* ============================================================
   ELLKAPA WINGMEN — CORE STYLESHEET
   Design tokens: Deep Navy / Charcoal / Brushed Gold / Silver / Ember
   Signature motif: the "claw-mark" — three asymmetric diagonal strokes
   ============================================================ */

:root{
  --navy: #0A1F44;
  --navy-deep: #061227;
  --void: #070D1A;
  --charcoal: #111111;
  --charcoal-soft: #1a1a1a;
  --gold: #C8A44D;
  --gold-bright: #E2C275;
  --gold-dim: #8a7138;
  --silver: #D9D9D9;
  --silver-dim: #9aa3b0;
  --ember: #D9472B;
  --ember-bright: #f15a3c;

  --glass-bg: rgba(255,255,255,0.05);
  --glass-border: rgba(255,255,255,0.12);
  --glass-bg-strong: rgba(10,31,68,0.55);

  --font-display: 'Space Grotesk', sans-serif;
  --font-body: 'Inter', sans-serif;

  --container: 1240px;
  --radius: 18px;
  --radius-sm: 10px;

  --ease: cubic-bezier(.16,.84,.44,1);
  --ease-soft: cubic-bezier(.4,0,.2,1);

  --shadow-deep: 0 30px 80px -20px rgba(0,0,0,0.65);
  --shadow-gold: 0 0 0 1px rgba(200,164,77,0.25), 0 20px 60px -15px rgba(200,164,77,0.18);
}

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

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

html{ scroll-behavior:smooth; }

body{
  font-family: var(--font-body);
  background: var(--void);
  color: var(--silver);
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

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

a{ color:inherit; text-decoration:none; }

ul{ list-style:none; }

button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }

h1,h2,h3,h4{
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: #fff;
}

p{ color: var(--silver-dim); }

.container{
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 32px;
}

:focus-visible{
  outline: 2px solid var(--gold-bright);
  outline-offset: 3px;
  border-radius: 4px;
}

/* ============================================================
   LOADING SCREEN
   ============================================================ */
#loader{
  position: fixed; inset:0; z-index: 9999;
  background: var(--void);
  display:flex; align-items:center; justify-content:center;
  transition: opacity .6s var(--ease), visibility .6s var(--ease);
}
#loader.hidden{ opacity:0; visibility:hidden; pointer-events:none; }
.loader-mark{
  position:relative;
  width:120px; height:120px;
}
.loader-mark svg{ width:100%; height:100%; }
.loader-mark .claw-path{
  stroke: var(--gold);
  stroke-width: 4;
  fill:none;
  stroke-linecap:round;
  stroke-dasharray: 140;
  stroke-dashoffset: 140;
  animation: clawDraw 1.1s var(--ease) forwards infinite;
}
.loader-mark .claw-path:nth-child(2){ animation-delay: .12s; }
.loader-mark .claw-path:nth-child(3){ animation-delay: .24s; }
@keyframes clawDraw{
  0%{ stroke-dashoffset:140; opacity:0; }
  35%{ opacity:1; }
  60%{ stroke-dashoffset:0; opacity:1; }
  100%{ stroke-dashoffset:0; opacity:0; }
}
.loader-text{
  position:absolute; bottom:-36px; left:0; right:0; text-align:center;
  font-family:var(--font-display); letter-spacing:.3em; font-size:11px;
  color: var(--silver-dim); text-transform:uppercase;
}

/* ============================================================
   SCROLL PROGRESS BAR
   ============================================================ */
#scroll-progress{
  position: fixed; top:0; left:0; height:3px; width:0%;
  background: linear-gradient(90deg, var(--gold-dim), var(--gold-bright));
  z-index: 1001;
  transition: width .1s linear;
  box-shadow: 0 0 12px rgba(226,194,117,.6);
}

/* ============================================================
   AURORA / AMBIENT BACKGROUND
   ============================================================ */
.aurora-bg{
  position:fixed; inset:0; z-index:-2; overflow:hidden; pointer-events:none;
}
.aurora-bg::before, .aurora-bg::after{
  content:''; position:absolute; border-radius:50%;
  filter: blur(90px); opacity:.35; mix-blend-mode: screen;
}
.aurora-bg::before{
  width:60vw; height:60vw; top:-20vw; left:-10vw;
  background: radial-gradient(circle, var(--navy) 0%, transparent 70%);
  animation: auroraDrift1 22s ease-in-out infinite;
}
.aurora-bg::after{
  width:50vw; height:50vw; bottom:-15vw; right:-10vw;
  background: radial-gradient(circle, var(--gold-dim) 0%, transparent 70%);
  animation: auroraDrift2 26s ease-in-out infinite;
}
@keyframes auroraDrift1{
  0%,100%{ transform: translate(0,0) scale(1); }
  50%{ transform: translate(8vw,6vw) scale(1.15); }
}
@keyframes auroraDrift2{
  0%,100%{ transform: translate(0,0) scale(1); }
  50%{ transform: translate(-6vw,-8vw) scale(1.1); }
}

.grain-overlay{
  position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.035;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ============================================================
   FLOATING PARTICLES (ambient, decorative)
   ============================================================ */
.particle-field{
  position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:1;
}
.particle{
  position:absolute; border-radius:50%;
  background: radial-gradient(circle, rgba(226,194,117,.9), rgba(226,194,117,0));
  animation: floatUp linear infinite;
}
@keyframes floatUp{
  0%{ transform: translateY(0) translateX(0); opacity:0; }
  10%{ opacity:.8; }
  90%{ opacity:.5; }
  100%{ transform: translateY(-110vh) translateX(var(--drift, 40px)); opacity:0; }
}

/* ============================================================
   HEADER / NAVIGATION
   ============================================================ */
.site-header{
  position: fixed; top:0; left:0; right:0; z-index: 1000;
  padding: 18px 0;
  transition: background .4s var(--ease-soft), padding .4s var(--ease-soft), box-shadow .4s var(--ease-soft);
}
.site-header.scrolled{
  background: rgba(7,13,26,0.82);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  padding: 10px 0;
  box-shadow: 0 1px 0 rgba(255,255,255,0.06), 0 20px 50px -20px rgba(0,0,0,.6);
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap: 24px;
}
.brand{
  display:flex; align-items:center; gap:12px;
  transition: transform .35s var(--ease);
}
.brand:hover{ transform: translateY(-1px); }
.brand img{
  height: 58px; width:auto;
  filter: drop-shadow(0 4px 18px rgba(0,0,0,.5));
  transition: height .4s var(--ease-soft);
}
.site-header.scrolled .brand img{ height: 46px; }

.nav-links{
  display:flex; align-items:center; gap: 6px;
}
.nav-links li{ position:relative; }
.nav-links a{
  display:block;
  padding: 10px 16px;
  font-family: var(--font-display);
  font-size: 14.5px;
  font-weight: 500;
  letter-spacing:.01em;
  color: var(--silver);
  position:relative;
  transition: color .3s var(--ease);
}
.nav-links a::after{
  content:'';
  position:absolute; left:16px; right:16px; bottom:6px; height:2px;
  background: linear-gradient(90deg, var(--gold), var(--ember));
  transform: scaleX(0); transform-origin:left;
  transition: transform .35s var(--ease);
  border-radius: 2px;
}
.nav-links a:hover{ color:#fff; }
.nav-links a:hover::after{ transform: scaleX(1); }
.nav-links a.active{ color: var(--gold-bright); }
.nav-links a.active::after{ transform: scaleX(1); }

.nav-cta{
  display:flex; align-items:center; gap:14px;
}

.nav-toggle{
  display:none;
  width:44px; height:44px;
  border-radius: 10px;
  border: 1px solid var(--glass-border);
  background: var(--glass-bg);
  flex-direction:column; align-items:center; justify-content:center; gap:5px;
}
.nav-toggle span{
  width:20px; height:2px; background: var(--silver);
  transition: transform .3s var(--ease), opacity .3s var(--ease);
}
.nav-toggle.open span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2){ opacity:0; }
.nav-toggle.open span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

.mobile-nav{
  position: fixed; top:0; right:0; height:100vh; width:min(360px,86vw);
  background: rgba(7,13,26,0.97);
  backdrop-filter: blur(20px);
  border-left: 1px solid var(--glass-border);
  z-index: 1100;
  transform: translateX(100%);
  transition: transform .45s var(--ease);
  padding: 110px 36px 40px;
  display:flex; flex-direction:column; gap:6px;
}
.mobile-nav.open{ transform: translateX(0); }
.mobile-nav a{
  font-family: var(--font-display);
  font-size: 20px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(255,255,255,.06);
  color: var(--silver);
}
.mobile-nav a.active{ color: var(--gold-bright); }
.mobile-backdrop{
  position:fixed; inset:0; background: rgba(0,0,0,.5); z-index:1050;
  opacity:0; visibility:hidden; transition: opacity .4s var(--ease);
}
.mobile-backdrop.open{ opacity:1; visibility:visible; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  position: relative;
  display: inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 15px;
  letter-spacing:.01em;
  padding: 16px 30px;
  border-radius: 100px;
  overflow: hidden;
  isolation: isolate;
  transition: transform .35s var(--ease), box-shadow .35s var(--ease);
  white-space: nowrap;
}
.btn:active{ transform: scale(.96); }

.btn-primary{
  background: linear-gradient(135deg, var(--gold-bright), var(--gold) 50%, var(--gold-dim));
  color: var(--void);
  box-shadow: var(--shadow-gold);
}
.btn-primary:hover{ transform: translateY(-3px); box-shadow: 0 0 0 1px rgba(200,164,77,.4), 0 28px 60px -12px rgba(200,164,77,.35); }

.btn-ember{
  background: linear-gradient(135deg, var(--ember-bright), var(--ember));
  color:#fff;
  box-shadow: 0 0 0 1px rgba(217,71,43,.3), 0 20px 50px -15px rgba(217,71,43,.45);
}
.btn-ember:hover{ transform: translateY(-3px); box-shadow: 0 0 0 1px rgba(217,71,43,.5), 0 28px 60px -12px rgba(217,71,43,.55); }

.btn-ghost{
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: #fff;
  backdrop-filter: blur(10px);
}
.btn-ghost:hover{ background: rgba(255,255,255,.1); transform: translateY(-3px); border-color: rgba(200,164,77,.4); }

.btn-sm{ padding:11px 22px; font-size:13.5px; }
.btn-block{ width:100%; }

.btn-ripple{ position:absolute; border-radius:50%; background: rgba(255,255,255,.5); transform:scale(0); animation: rippleAnim .6s ease-out; pointer-events:none; }
@keyframes rippleAnim{ to{ transform:scale(2.6); opacity:0; } }

/* magnetic wrapper used via JS */
.magnetic{ will-change: transform; }

/* ============================================================
   SECTION SCAFFOLDING
   ============================================================ */
section{ position: relative; padding: 120px 0; }
.section-tight{ padding: 90px 0; }

.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family: var(--font-display);
  font-size: 12.5px; font-weight:600; letter-spacing:.25em; text-transform:uppercase;
  color: var(--gold-bright);
  margin-bottom: 18px;
}
.eyebrow::before{
  content:''; width:26px; height:1px; background: var(--gold);
}

.section-head{
  max-width: 720px; margin-bottom: 64px;
}
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head h2{ font-size: clamp(2rem, 4vw, 3rem); margin-bottom: 18px; }
.section-head p{ font-size: 17px; }

/* the claw-mark signature divider */
.claw-mark{
  display:flex; gap:6px; align-items:flex-end; height:22px; margin-bottom:14px;
}
.claw-mark span{
  display:block; width:3px; border-radius:2px;
  background: linear-gradient(180deg, var(--gold-bright), var(--ember));
  transform-origin: bottom;
}
.claw-mark span:nth-child(1){ height:10px; transform: rotate(-14deg); }
.claw-mark span:nth-child(2){ height:22px; transform: rotate(-4deg); }
.claw-mark span:nth-child(3){ height:15px; transform: rotate(8deg); }

/* ============================================================
   GLASS CARD / PANEL
   ============================================================ */
.glass{
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  backdrop-filter: blur(16px) saturate(140%);
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  border-radius: var(--radius);
}

.card{
  position: relative;
  border-radius: var(--radius);
  background: linear-gradient(160deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border: 1px solid var(--glass-border);
  padding: 36px 30px;
  transition: transform .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease);
  overflow:hidden;
}
.card::before{
  content:'';
  position:absolute; inset:-1px; border-radius: var(--radius);
  background: linear-gradient(135deg, transparent 40%, rgba(200,164,77,.5), transparent 60%);
  opacity:0; transition: opacity .5s var(--ease);
  pointer-events:none;
  z-index:0;
}
.card:hover::before{ opacity:1; }
.card:hover{
  transform: translateY(-8px);
  border-color: rgba(200,164,77,.35);
  box-shadow: 0 30px 60px -20px rgba(0,0,0,.6);
}
.card > *{ position:relative; z-index:1; }

.card-icon{
  width: 56px; height:56px; border-radius: 14px;
  display:flex; align-items:center; justify-content:center;
  background: linear-gradient(135deg, rgba(200,164,77,.18), rgba(200,164,77,.04));
  border: 1px solid rgba(200,164,77,.25);
  color: var(--gold-bright);
  font-size: 22px;
  margin-bottom: 22px;
  transition: transform .4s var(--ease), background .4s var(--ease);
}
.card:hover .card-icon{ transform: scale(1.1) rotate(-6deg); background: linear-gradient(135deg, rgba(200,164,77,.3), rgba(217,71,43,.08)); }

.card h3{ font-size: 20px; margin-bottom: 12px; }
.card p{ font-size: 15px; }

/* ============================================================
   GRIDS
   ============================================================ */
.grid{ display:grid; gap: 28px; }
.grid-2{ grid-template-columns: repeat(2,1fr); }
.grid-3{ grid-template-columns: repeat(3,1fr); }
.grid-4{ grid-template-columns: repeat(4,1fr); }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  min-height: 100vh;
  display:flex; align-items:center;
  position: relative;
  overflow: hidden;
  padding-top: 140px;
  padding-bottom: 80px;
}
.hero-bg{
  position:absolute; inset:0; z-index:0;
}
.hero-bg img{
  width:100%; height:100%; object-fit:cover;
  transform: scale(1.08);
  animation: heroZoom 16s ease-in-out infinite alternate;
}
@keyframes heroZoom{ from{ transform: scale(1.08); } to{ transform: scale(1.16); } }
.hero-overlay{
  position:absolute; inset:0; z-index:1;
  background:
    radial-gradient(ellipse 80% 60% at 30% 20%, rgba(200,164,77,.18), transparent 60%),
    linear-gradient(180deg, rgba(7,13,26,.55) 0%, rgba(7,13,26,.88) 65%, var(--void) 100%),
    linear-gradient(100deg, rgba(7,13,26,.95) 10%, rgba(7,13,26,.55) 50%, rgba(7,13,26,.85) 100%);
}
.hero-content{
  position: relative; z-index:2;
  max-width: 760px;
}
.hero-panel{
  padding: 52px 46px;
  border-radius: 24px;
}
.hero-eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family: var(--font-display); font-size:13px; letter-spacing:.3em; text-transform:uppercase;
  color: var(--gold-bright); margin-bottom:22px;
  opacity:0; animation: fadeUp .8s var(--ease) .2s forwards;
}
.hero h1{
  font-size: clamp(2.6rem, 6vw, 5rem);
  margin-bottom: 22px;
  opacity:0; animation: fadeUp .9s var(--ease) .35s forwards;
}
.hero h1 .accent{
  background: linear-gradient(100deg, var(--gold-bright), var(--ember-bright));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero .lead{
  font-size: clamp(1.05rem, 1.6vw, 1.35rem);
  color: var(--silver);
  font-weight:500;
  margin-bottom: 16px;
  opacity:0; animation: fadeUp .9s var(--ease) .5s forwards;
}
.hero .desc{
  font-size: 16.5px; max-width: 540px; margin-bottom: 36px;
  opacity:0; animation: fadeUp .9s var(--ease) .65s forwards;
}
.hero-actions{
  display:flex; gap:18px; flex-wrap:wrap;
  opacity:0; animation: fadeUp .9s var(--ease) .8s forwards;
}
@keyframes fadeUp{
  from{ opacity:0; transform: translateY(26px); }
  to{ opacity:1; transform: translateY(0); }
}

.scroll-cue{
  position:absolute; bottom: 38px; left:50%; transform:translateX(-50%);
  z-index:2; display:flex; flex-direction:column; align-items:center; gap:10px;
  color: var(--silver-dim); font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  opacity:0; animation: fadeUp .9s var(--ease) 1.2s forwards;
}
.scroll-cue .line{ width:1px; height:34px; background: linear-gradient(180deg, var(--gold), transparent); position:relative; overflow:hidden; }
.scroll-cue .line::after{
  content:''; position:absolute; top:-100%; left:0; width:100%; height:100%;
  background: var(--gold-bright);
  animation: scrollLine 1.8s ease-in-out infinite;
}
@keyframes scrollLine{ 0%{ top:-100%; } 50%{ top:100%; } 100%{ top:100%; } }

/* small hero variant for inner pages */
.hero-sm{ min-height: 64vh; padding-top:160px; padding-bottom:90px; }
.hero-sm h1{ font-size: clamp(2.2rem, 4.6vw, 3.6rem); }

/* ============================================================
   STATS
   ============================================================ */
.stats-band{
  display:grid; grid-template-columns: repeat(4,1fr);
  gap: 28px;
}
.stat{
  text-align:center; padding: 30px 16px;
  border-right: 1px solid rgba(255,255,255,.08);
}
.stat:last-child{ border-right:none; }
.stat .num{
  font-family: var(--font-display); font-size: clamp(2.2rem,4vw,3.2rem); font-weight:700;
  background: linear-gradient(135deg,#fff, var(--gold-bright));
  -webkit-background-clip:text; background-clip:text; color:transparent;
  display:block; margin-bottom:8px;
}
.stat .label{ font-size:13px; letter-spacing:.08em; text-transform:uppercase; color: var(--silver-dim); }

/* ============================================================
   PROCESS / TIMELINE
   ============================================================ */
.process-track{
  position:relative;
  display:grid; grid-template-columns: repeat(3,1fr); gap: 36px;
}
.process-track::before{
  content:''; position:absolute; top:38px; left:8%; right:8%; height:1px;
  background: linear-gradient(90deg, transparent, var(--gold-dim), var(--gold), var(--gold-dim), transparent);
}
.process-step{ position:relative; text-align:center; padding-top: 0; }
.process-num{
  width:76px; height:76px; border-radius:50%; margin: 0 auto 24px;
  display:flex; align-items:center; justify-content:center;
  font-family: var(--font-display); font-size:24px; font-weight:700;
  background: linear-gradient(160deg, var(--navy), var(--charcoal));
  border: 1px solid var(--glass-border);
  color: var(--gold-bright);
  position:relative; z-index:1;
  box-shadow: 0 0 0 6px var(--void);
}
.process-step h3{ font-size:19px; margin-bottom:10px; }
.process-step p{ font-size:14.5px; max-width:280px; margin-inline:auto; }

/* ============================================================
   SPLIT LAYOUTS
   ============================================================ */
.split{
  display:grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items:center;
}
.split.reverse > .split-media{ order:2; }
.split-media{
  position:relative; border-radius: 22px; overflow:hidden;
  box-shadow: var(--shadow-deep);
}
.split-media img{ width:100%; height:100%; object-fit:cover; transition: transform .8s var(--ease); }
.split-media:hover img{ transform: scale(1.06); }
.split-media::after{
  content:''; position:absolute; inset:0;
  background: linear-gradient(160deg, rgba(200,164,77,.12), transparent 50%);
  pointer-events:none;
}
.media-frame{
  aspect-ratio: 4/3;
}
.split-text h2{ font-size: clamp(1.8rem,3.4vw,2.6rem); margin-bottom:20px; }
.split-text p{ font-size:16px; margin-bottom:16px; }

/* ============================================================
   CTA BANNER
   ============================================================ */
.cta-banner{
  position:relative; border-radius: 28px; overflow:hidden;
  padding: 80px 60px;
  text-align:center;
  background: linear-gradient(135deg, var(--navy-deep), var(--charcoal));
  border: 1px solid rgba(200,164,77,.2);
}
.cta-banner::before{
  content:''; position:absolute; inset:0;
  background: radial-gradient(circle at 30% 20%, rgba(200,164,77,.25), transparent 55%),
              radial-gradient(circle at 80% 80%, rgba(217,71,43,.18), transparent 55%);
}
.cta-banner > *{ position:relative; z-index:1; }
.cta-banner h2{ font-size: clamp(1.9rem,3.6vw,2.8rem); margin-bottom:18px; }
.cta-banner p{ max-width:560px; margin: 0 auto 34px; font-size:16.5px; }
.cta-actions{ display:flex; gap:18px; justify-content:center; flex-wrap:wrap; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  background: var(--charcoal);
  border-top: 1px solid rgba(255,255,255,.06);
  padding: 80px 0 30px;
  position: relative;
}
.footer-grid{
  display:grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
  gap: 50px;
  margin-bottom: 60px;
}
.footer-brand img{ height:54px; margin-bottom:18px; }
.footer-brand p{ font-size:14.5px; max-width:280px; }
.footer-col h4{
  font-size:14px; letter-spacing:.1em; text-transform:uppercase; color:#fff;
  margin-bottom:20px;
}
.footer-col ul{ display:flex; flex-direction:column; gap:12px; }
.footer-col a{
  font-size:14.5px; color: var(--silver-dim);
  transition: color .3s var(--ease), padding-left .3s var(--ease);
  display:inline-block;
}
.footer-col a:hover{ color: var(--gold-bright); padding-left:4px; }
.footer-social{ display:flex; gap:12px; margin-top:18px; }
.footer-social a{
  width:38px; height:38px; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  background: var(--glass-bg); border:1px solid var(--glass-border);
  transition: all .3s var(--ease);
}
.footer-social a:hover{ background: rgba(200,164,77,.15); border-color: var(--gold); transform: translateY(-3px); }

.footer-disclaimer{
  font-size: 12.5px; color: var(--silver-dim); opacity:.75;
  border-top: 1px solid rgba(255,255,255,.06);
  padding-top: 26px; margin-bottom: 20px;
  line-height:1.7;
}
.footer-bottom{
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px;
  font-size: 13px; color: var(--silver-dim);
}

/* ============================================================
   REVEAL ON SCROLL
   ============================================================ */
.reveal{ opacity:0; transform: translateY(36px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:translateY(0); }
.reveal-stagger > *{ opacity:0; transform: translateY(30px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal-stagger.in > *{ opacity:1; transform:translateY(0); }
.reveal-stagger.in > *:nth-child(1){ transition-delay: 0s; }
.reveal-stagger.in > *:nth-child(2){ transition-delay: .1s; }
.reveal-stagger.in > *:nth-child(3){ transition-delay: .2s; }
.reveal-stagger.in > *:nth-child(4){ transition-delay: .3s; }
.reveal-stagger.in > *:nth-child(5){ transition-delay: .4s; }
.reveal-stagger.in > *:nth-child(6){ transition-delay: .5s; }

/* ============================================================
   BADGES / TAGS / PILLS
   ============================================================ */
.pill{
  display:inline-flex; align-items:center; gap:8px;
  padding: 7px 16px; border-radius:100px;
  font-size:12.5px; font-weight:600; letter-spacing:.04em;
  background: var(--glass-bg); border:1px solid var(--glass-border);
  color: var(--silver);
}
.pill.gold{ color: var(--gold-bright); border-color: rgba(200,164,77,.35); }
.pill.ember{ color: var(--ember-bright); border-color: rgba(217,71,43,.35); }

/* ============================================================
   DIVISIONS ACCORDIONS
   ============================================================ */
.division-block{
  border-radius: 22px;
  border: 1px solid var(--glass-border);
  background: linear-gradient(160deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  margin-bottom: 22px;
  overflow:hidden;
}
.division-head{
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  padding: 28px 32px;
  cursor:pointer;
  transition: background .3s var(--ease);
}
.division-head:hover{ background: rgba(255,255,255,.03); }
.division-title{ display:flex; align-items:center; gap:18px; }
.division-icon{
  width:54px; height:54px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  font-size:22px;
  background: linear-gradient(135deg, rgba(200,164,77,.2), rgba(217,71,43,.08));
  border:1px solid rgba(200,164,77,.3);
  color: var(--gold-bright);
  flex-shrink:0;
}
.division-title h3{ font-size:20px; margin-bottom:4px; }
.division-title p{ font-size:14px; margin:0; max-width:480px; }
.division-chevron{
  width:38px; height:38px; border-radius:50%;
  border: 1px solid var(--glass-border);
  display:flex; align-items:center; justify-content:center;
  transition: transform .4s var(--ease), background .3s var(--ease);
  flex-shrink:0;
}
.division-block.open .division-chevron{ transform: rotate(135deg); background: rgba(200,164,77,.15); }

.division-body{
  max-height:0; overflow:hidden;
  transition: max-height .55s var(--ease);
}
.division-services{
  display:grid; grid-template-columns: repeat(2,1fr); gap:18px;
  padding: 0 32px 32px;
}
.service-tile{
  border-radius: 16px;
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.06);
  padding: 22px;
  transition: transform .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease);
}
.service-tile:hover{ transform: translateY(-4px); border-color: rgba(200,164,77,.3); background: rgba(200,164,77,.05); }
.service-tile h4{ font-size:16px; color:#fff; margin-bottom:8px; display:flex; align-items:center; gap:10px; }
.service-tile h4 i{ color: var(--gold-bright); font-size:14px; }
.service-tile p{ font-size:13.8px; margin-bottom:16px; }
.service-tile-actions{ display:flex; gap:10px; flex-wrap:wrap; }
.link-arrow{
  display:inline-flex; align-items:center; gap:6px;
  font-size:13px; font-weight:600; color: var(--gold-bright);
  font-family: var(--font-display);
}
.link-arrow i{ transition: transform .3s var(--ease); font-size:11px; }
.link-arrow:hover i{ transform: translateX(4px); }

/* ============================================================
   PRICING CARDS
   ============================================================ */
.pricing-grid{ display:grid; grid-template-columns: repeat(3,1fr); gap:30px; align-items:stretch; }
.price-card{
  border-radius: 22px;
  padding: 42px 34px;
  border: 1px solid var(--glass-border);
  background: linear-gradient(160deg, rgba(255,255,255,.06), rgba(255,255,255,.015));
  display:flex; flex-direction:column;
  position:relative; overflow:hidden;
  transition: transform .45s var(--ease), box-shadow .45s var(--ease);
}
.price-card::before{
  content:''; position:absolute; top:-2px; left:-2px; right:-2px; bottom:-2px; border-radius:24px;
  background: conic-gradient(from 0deg, transparent, rgba(200,164,77,.5), transparent 30%);
  opacity:0; transition: opacity .5s var(--ease); z-index:-1;
  animation: rotateBorder 5s linear infinite;
}
.price-card:hover::before{ opacity:1; }
.price-card:hover{ transform: translateY(-10px); box-shadow: var(--shadow-deep); }
@keyframes rotateBorder{ to{ transform: rotate(360deg); } }
.price-card.featured{ border-color: rgba(200,164,77,.45); }
.price-card .pill{ align-self:flex-start; margin-bottom:20px; }
.price-card h3{ font-size:22px; margin-bottom:10px; }
.price-card .price{ font-family: var(--font-display); font-size:42px; color:#fff; margin-bottom:6px; }
.price-card .price span{ font-size:15px; color: var(--silver-dim); font-family: var(--font-body); }
.price-card .price-sub{ font-size:13.5px; margin-bottom:24px; }
.price-card ul{ display:flex; flex-direction:column; gap:12px; margin-bottom:30px; flex-grow:1; }
.price-card ul li{ font-size:14px; color: var(--silver); display:flex; gap:10px; align-items:flex-start; }
.price-card ul li i{ color: var(--gold-bright); margin-top:3px; font-size:12px; }
.price-card-actions{ display:flex; flex-direction:column; gap:10px; }

/* ============================================================
   FAQ ACCORDION
   ============================================================ */
.faq-item{
  border-radius: 16px;
  border: 1px solid var(--glass-border);
  background: linear-gradient(160deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  margin-bottom: 16px;
  overflow:hidden;
}
.faq-q{
  display:flex; align-items:center; justify-content:space-between; gap:18px;
  padding: 24px 28px; cursor:pointer;
}
.faq-q h3{ font-size:16.5px; font-weight:600; }
.faq-q .faq-plus{
  width:32px; height:32px; border-radius:50%; flex-shrink:0;
  border:1px solid var(--glass-border);
  display:flex; align-items:center; justify-content:center;
  transition: transform .4s var(--ease), background .3s var(--ease);
}
.faq-item.open .faq-plus{ transform: rotate(135deg); background: rgba(200,164,77,.15); }
.faq-a{ max-height:0; overflow:hidden; transition: max-height .5s var(--ease); }
.faq-a-inner{ padding: 0 28px 26px; font-size:15px; color: var(--silver-dim); }

/* ============================================================
   FORMS
   ============================================================ */
.form-card{
  border-radius: 24px;
  padding: 44px;
  background: var(--glass-bg-strong);
  border: 1px solid var(--glass-border);
  backdrop-filter: blur(16px);
}
.form-group{ margin-bottom: 22px; }
.form-group label{
  display:block; font-size:13px; letter-spacing:.05em; text-transform:uppercase;
  color: var(--gold-bright); margin-bottom:10px; font-weight:600;
}
.form-group input, .form-group textarea, .form-group select{
  width:100%; padding: 15px 18px;
  background: rgba(0,0,0,.25);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  color: #fff; font-size:15px; font-family: var(--font-body);
  transition: border-color .3s var(--ease), background .3s var(--ease);
}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus{
  border-color: var(--gold); background: rgba(0,0,0,.4); outline:none;
}
.form-group textarea{ resize:vertical; min-height:130px; }
.form-group select option{ background: var(--navy-deep); }
.form-hint{ font-size:12.5px; color: var(--silver-dim); margin-top:8px; }
.form-error{ font-size:12.5px; color: var(--ember-bright); margin-top:8px; display:none; }
.form-error.show{ display:block; }
.honeypot{ position:absolute; left:-9999px; opacity:0; height:0; width:0; }
.math-check{ display:flex; align-items:center; gap:14px; }
.math-check .math-q{ font-family: var(--font-display); font-size:18px; color:#fff; white-space:nowrap; }
.contact-tabs{ display:flex; gap:10px; margin-bottom:34px; }
.contact-tab{
  flex:1; padding:14px; text-align:center; border-radius:12px;
  border:1px solid var(--glass-border); font-family:var(--font-display); font-size:14px; font-weight:600;
  transition: all .3s var(--ease); color: var(--silver-dim);
}
.contact-tab.active{ background: linear-gradient(135deg, rgba(200,164,77,.2), rgba(217,71,43,.08)); border-color: var(--gold); color:#fff; }
.tab-panel{ display:none; }
.tab-panel.active{ display:block; }

/* ============================================================
   RELATED / BREADCRUMB
   ============================================================ */
.breadcrumb{
  display:flex; align-items:center; gap:10px; font-size:13.5px; color: var(--silver-dim);
  margin-bottom:18px;
}
.breadcrumb a{ color: var(--silver-dim); transition: color .3s var(--ease); }
.breadcrumb a:hover{ color: var(--gold-bright); }
.breadcrumb i{ font-size:10px; }

.step-list{ display:flex; flex-direction:column; gap:0; }
.step-item{ display:flex; gap:24px; padding: 28px 0; border-bottom:1px solid rgba(255,255,255,.06); }
.step-item:last-child{ border-bottom:none; }
.step-mark{
  width:48px; height:48px; border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:700; color: var(--gold-bright);
  border: 1px solid rgba(200,164,77,.35);
  background: rgba(200,164,77,.08);
}
.step-text h4{ font-size:17px; margin-bottom:6px; }
.step-text p{ font-size:14.5px; margin:0; }

.benefit-row{ display:flex; gap:18px; align-items:flex-start; padding:18px 0; border-bottom:1px solid rgba(255,255,255,.05); }
.benefit-row:last-child{ border-bottom:none; }
.benefit-row i{ color: var(--gold-bright); font-size:18px; margin-top:3px; }
.benefit-row h4{ font-size:15.5px; margin-bottom:4px; }
.benefit-row p{ font-size:14px; margin:0; }

.related-grid{ display:grid; grid-template-columns: repeat(3,1fr); gap:24px; }
.related-card{
  border-radius:16px; padding:26px;
  border:1px solid var(--glass-border);
  background: linear-gradient(160deg, rgba(255,255,255,.05), rgba(255,255,255,.01));
  transition: transform .35s var(--ease), border-color .35s var(--ease);
}
.related-card:hover{ transform: translateY(-6px); border-color: rgba(200,164,77,.35); }
.related-card i{ color: var(--gold-bright); font-size:20px; margin-bottom:14px; display:block; }
.related-card h4{ font-size:15.5px; margin-bottom:8px; }
.related-card p{ font-size:13.5px; margin-bottom:14px; }

.service-hero-meta{ display:flex; gap:14px; flex-wrap:wrap; margin-bottom:28px; }

/* ============================================================
   MOUSE GLOW (cursor follow light)
   ============================================================ */
.mouse-glow{
  position: fixed; width: 460px; height:460px; border-radius:50%;
  background: radial-gradient(circle, rgba(200,164,77,.10), transparent 70%);
  pointer-events:none; z-index:0; transform: translate(-50%,-50%);
  transition: opacity .3s ease; opacity:0;
  display:none;
}
@media (min-width:1024px){ .mouse-glow{ display:block; } }

/* ============================================================
   ANIMATED GRID BACKDROP (used in select sections)
   ============================================================ */
.grid-backdrop{
  position:absolute; inset:0; z-index:0; opacity:.25;
  background-image:
    linear-gradient(rgba(200,164,77,.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200,164,77,.12) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 60% 60% at 50% 30%, black, transparent 80%);
}

/* ============================================================
   UTILITIES
   ============================================================ */
.text-center{ text-align:center; }
.mt-0{ margin-top:0; }
.mb-0{ margin-bottom:0; }
.relative{ position:relative; }
.z1{ z-index:1; }
.flex-center{ display:flex; align-items:center; justify-content:center; }
.gap-12{ gap:12px; }
.gap-18{ gap:18px; }
.divider-line{ height:1px; background: linear-gradient(90deg, transparent, rgba(255,255,255,.12), transparent); margin: 60px 0; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px){
  .grid-4{ grid-template-columns: repeat(2,1fr); }
  .grid-3{ grid-template-columns: repeat(2,1fr); }
  .footer-grid{ grid-template-columns: 1fr 1fr; gap:40px; }
  .pricing-grid{ grid-template-columns: 1fr; max-width:480px; margin-inline:auto; }
  .related-grid{ grid-template-columns: repeat(2,1fr); }
  .stats-band{ grid-template-columns: repeat(2,1fr); }
  .stat{ border-right:none; border-bottom:1px solid rgba(255,255,255,.08); padding-bottom:24px; }
}

@media (max-width: 860px){
  .nav-links{ display:none; }
  .nav-toggle{ display:flex; }
  .split{ grid-template-columns:1fr; gap:36px; }
  .split.reverse > .split-media{ order:0; }
  .process-track{ grid-template-columns:1fr; gap:50px; }
  .process-track::before{ display:none; }
  .division-services{ grid-template-columns:1fr; }
  .grid-2{ grid-template-columns:1fr; }
  .grid-3{ grid-template-columns:1fr; }
  .grid-4{ grid-template-columns: repeat(2,1fr); }
  .related-grid{ grid-template-columns:1fr; }
  .hero-panel{ padding: 36px 28px; }
  .nav-cta .btn span{ display:none; }
}

@media (max-width: 600px){
  .container{ padding: 0 20px; }
  section{ padding: 80px 0; }
  .hero{ padding-top:120px; }
  .stats-band{ grid-template-columns: 1fr 1fr; }
  .footer-grid{ grid-template-columns: 1fr 1fr; gap:30px; }
  .cta-banner{ padding: 56px 28px; }
  .form-card{ padding:28px; }
  .nav-cta .btn-ghost{ display:none; }
  .grid-4{ grid-template-columns: 1fr 1fr; }
   }
