:root{
  --navy:#071152;
  --navy-2:#0d1c6e;
  --navy-deep:#040a33;
  --black:#0a0a0d;
  --black-2:#101015;
  --cream:#F7F4EB;
  --cream-2:#efe9d8;
  --muted:#a3a3ad;
  --accent:#4D8DFF;
  --ink:#0a0a0a;
  --radius:18px;
  --maxw:1280px;
  --ease:cubic-bezier(.16,.84,.32,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',sans-serif;
  background:var(--black);
  color:var(--cream);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.logo{font-family:'Bricolage Grotesque',sans-serif;}
em{font-style:normal;color:var(--accent);}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.section-inner,.header-inner,.footer-inner{
  max-width:var(--maxw);margin:0 auto;padding:0 32px;
}

/* grain overlay */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.035;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%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");
}

/* custom cursor dot (desktop only) */
.cursor-dot{
  position:fixed;width:10px;height:10px;border-radius:50%;background:var(--accent);
  pointer-events:none;z-index:9998;transform:translate(-50%,-50%);
  transition:width .25s var(--ease),height .25s var(--ease),opacity .25s;
  opacity:0;
}
@media(hover:hover) and (pointer:fine){ .cursor-dot{opacity:.85} }

/* ---------- HEADER ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:200;
  background:rgba(7,17,82,0);
  transition:background .4s var(--ease),box-shadow .4s var(--ease);
}
.site-header.scrolled{
  background:rgba(10,10,13,.82);
  backdrop-filter:blur(14px);
  box-shadow:0 1px 0 rgba(247,244,235,.08);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:78px;
}
.logo{font-size:1.4rem;font-weight:700;color:var(--cream);letter-spacing:-.02em;display:flex;align-items:center}
.logo span{color:var(--accent)}
.logo-img{height:30px;width:auto;display:block}
.footer-logo-img{height:26px}
.main-nav{display:flex;gap:36px}
.main-nav a{
  color:var(--cream);font-size:.92rem;opacity:.75;position:relative;
  transition:opacity .25s;
}
.main-nav a:hover{opacity:1}
.nav-cta{font-size:.85rem;padding:10px 20px}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  border-radius:999px;font-weight:600;font-size:.95rem;
  padding:14px 30px;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s;
  cursor:pointer;border:1px solid transparent;
}
.btn-primary{background:var(--cream);color:var(--navy)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(0,0,0,.25)}
.btn-ghost{background:transparent;border-color:rgba(247,244,235,.4);color:var(--cream);padding:10px 22px}
.btn-ghost:hover{background:rgba(247,244,235,.1)}
.btn-text{color:var(--cream);opacity:.75;padding:14px 6px}
.btn-text:hover{opacity:1}
.btn-lg{padding:18px 40px;font-size:1.05rem}

/* ---------- HERO ---------- */
.hero{
  position:relative;min-height:100vh;background:var(--navy);
  display:flex;align-items:center;overflow:hidden;
  padding:140px 0 80px;
}
.hero-bg{position:absolute;inset:0;overflow:hidden;}
.orb{
  position:absolute;border-radius:50%;filter:blur(60px);opacity:.55;
  background:radial-gradient(circle at 30% 30%,#3a4ed1,transparent 70%);
}
.hero-visual{
  position:absolute;top:0;right:0;height:100%;width:60%;object-fit:cover;object-position:right center;
  opacity:.55;
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,transparent 35%,black 75%);
  mask-image:linear-gradient(90deg,transparent 0%,transparent 35%,black 75%);
}
.hero-scrim{position:absolute;inset:0;background:linear-gradient(100deg,var(--navy) 0%,var(--navy) 38%,rgba(7,17,82,.35) 65%,transparent 100%);}
.orb-2{width:500px;height:500px;bottom:-220px;left:-160px;background:radial-gradient(circle at 30% 30%,#4D8DFF,transparent 70%);opacity:.25;}
.orb-3{width:700px;height:700px;top:50%;left:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,#3550e0,transparent 70%);opacity:.35;}
.grid-overlay{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(247,244,235,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(247,244,235,.05) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(circle at 30% 40%,black,transparent 75%);
}
.hero-inner{
  position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 32px;
  width:100%;
}
.hero-tag{
  color:var(--accent);font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:22px;font-weight:600;
}
.hero-title{
  color:var(--cream);font-size:clamp(2.6rem,6.2vw,5.2rem);
  line-height:1.05;font-weight:700;letter-spacing:-.02em;max-width:880px;
}
.hero-title .line{display:block;overflow:hidden}
.hero-sub{
  color:rgba(247,244,235,.75);font-size:1.15rem;line-height:1.6;max-width:560px;
  margin-top:28px;
}
.hero-actions{display:flex;align-items:center;gap:10px;margin-top:40px;flex-wrap:wrap}

.hero-card{
  position:absolute;right:6%;bottom:14%;z-index:3;
  width:300px;perspective:1200px;
}
.hero-card-inner{
  background:rgba(247,244,235,.08);border:1px solid rgba(247,244,235,.18);
  border-radius:var(--radius);backdrop-filter:blur(16px);
  padding:24px;color:var(--cream);
  box-shadow:0 30px 60px rgba(0,0,0,.35);
}
.hero-card-row{display:flex;justify-content:space-between;font-size:.85rem;padding:8px 0;opacity:.85}
.hero-card-stat{font-weight:700;color:var(--cream)}
.hero-card-stat.up{color:#8fd6a8}
.hero-card-bar{height:4px;background:rgba(247,244,235,.15);border-radius:4px;margin-top:14px;overflow:hidden}
.hero-card-fill{height:100%;width:30%;background:var(--accent);border-radius:4px}

.scroll-cue{
  position:absolute;left:32px;bottom:36px;z-index:3;color:rgba(247,244,235,.55);
  font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;display:flex;align-items:center;gap:10px;
}
.scroll-cue span{width:1px;height:36px;background:rgba(247,244,235,.4);display:block;position:relative;overflow:hidden}
.scroll-cue span::after{content:'';position:absolute;top:0;left:0;width:100%;height:40%;background:var(--accent);animation:scrollcue 2s infinite}
@keyframes scrollcue{0%{transform:translateY(-100%)}100%{transform:translateY(250%)}}

/* ---------- SECTIONS GENERIC ---------- */
.section{padding:130px 0;position:relative}
.eyebrow{
  color:var(--accent);font-weight:600;font-size:.82rem;letter-spacing:.12em;
  text-transform:uppercase;margin-bottom:18px;
}
.eyebrow-light{color:var(--accent)}
.section-title{
  font-size:clamp(1.9rem,3.6vw,3rem);line-height:1.18;font-weight:700;
  letter-spacing:-.01em;max-width:820px;
}
.section-title.light{color:var(--cream)}

/* ---------- NARRATIVE LEAD-IN (cinematic pinned reveal) ---------- */
.narrative{
  position:relative;background:var(--navy);overflow:hidden;
  min-height:100vh;display:flex;align-items:center;justify-content:center;
}
.narrative-bg{
  position:absolute;inset:-15%;z-index:1;pointer-events:none;
  background:radial-gradient(circle at 50% 38%,var(--navy-2) 0%,var(--black) 72%);
  clip-path:circle(0% at 50% 38%);
  will-change:clip-path;
}
.narrative-inner{
  position:relative;z-index:2;max-width:880px;margin:0 auto;padding:0 32px;text-align:center;
}
.narrative-line{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:400;
  font-size:clamp(1.4rem,2.5vw,2rem);line-height:1.45;
  letter-spacing:-.01em;color:rgba(247,244,235,.25);
  opacity:.15;filter:blur(6px);will-change:filter,opacity,color;
}
.narrative-line-2{margin-top:40px}
.narrative-line-3{margin-top:40px;font-weight:600;font-size:clamp(1.6rem,3vw,2.3rem)}
.narrative-cta{
  position:relative;z-index:2;margin-top:48px;opacity:0;transform:scale(.85);
  will-change:transform,opacity;
}

/* ---------- PROBLEM ---------- */
.problem{background:var(--black)}
.problem-grid{
  margin-top:64px;display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
}
.problem-card{
  background:rgba(247,244,235,.03);border:1px solid rgba(247,244,235,.1);border-radius:var(--radius);
  padding:34px 28px;transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s;
}
.problem-card:hover{transform:translateY(-6px);box-shadow:0 24px 50px rgba(0,0,0,.4);border-color:rgba(201,162,75,.4)}
.problem-num{font-size:.85rem;color:var(--accent);font-weight:700}
.problem-card h3{margin:14px 0 10px;font-size:1.25rem;color:var(--cream)}
.problem-card p{color:var(--muted);line-height:1.55;font-size:.95rem}

/* ---------- SERVICES ---------- */
.services{background:var(--black)}
.services-list{margin-top:60px;border-top:1px solid rgba(247,244,235,.12)}
.service-row{
  display:grid;grid-template-columns:60px 1fr 40px;align-items:center;gap:24px;
  padding:34px 0;border-bottom:1px solid rgba(247,244,235,.12);
  transition:padding-left .35s var(--ease),background .35s;
}
.service-row:hover{padding-left:14px;background:rgba(247,244,235,.03)}
.service-index{color:var(--accent);font-weight:700;font-size:.9rem}
.service-body h3{font-size:1.4rem;margin-bottom:8px;color:var(--cream)}
.service-body p{color:var(--muted);max-width:620px;line-height:1.55}
.service-arrow{font-size:1.4rem;color:var(--cream);opacity:.4;transition:transform .35s var(--ease),opacity .35s}
.service-row:hover .service-arrow{transform:translateX(8px);opacity:1}

/* ---------- PROCESS ---------- */
.process{background:var(--navy-deep);color:var(--cream)}
.process-track{position:relative;margin-top:70px;display:grid;grid-template-columns:repeat(5,1fr);gap:24px}
.process-line{
  position:absolute;top:13px;left:0;right:0;height:2px;background:rgba(247,244,235,.15);
  grid-column:1/-1;
}
.process-line-fill{height:100%;width:0%;background:var(--accent)}
.process-step{position:relative;padding-top:50px}
.process-dot{
  position:absolute;top:0;left:0;width:28px;height:28px;border-radius:50%;
  background:var(--navy-deep);border:2px solid var(--accent);color:var(--accent);
  display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;
}
.process-step h3{font-size:1.2rem;margin-bottom:10px}
.process-step p{color:rgba(247,244,235,.65);font-size:.9rem;line-height:1.55}

/* ---------- PROOF ---------- */
.proof{background:var(--navy);color:var(--cream);clip-path:polygon(0 3%,100% 0,100% 100%,0 100%)}
.proof-grid{margin-top:60px;display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.proof-card{
  border:1px solid rgba(247,244,235,.14);border-radius:var(--radius);padding:32px;
  background:rgba(247,244,235,.05);transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s,background .4s;
}
.proof-card:hover{transform:translateY(-6px);box-shadow:0 24px 50px rgba(0,0,0,.35);border-color:rgba(77,141,255,.5);background:rgba(247,244,235,.08)}
.proof-card h3{font-size:1.15rem;margin-bottom:10px;color:var(--cream)}
.proof-card p{color:rgba(247,244,235,.65);line-height:1.55;font-size:.93rem}
.proof-stats{
  margin-top:70px;display:flex;gap:60px;flex-wrap:wrap;border-top:1px solid rgba(247,244,235,.18);padding-top:50px;
}
.proof-stat{display:flex;flex-direction:column;gap:6px}
.proof-stat .num{font-size:2.6rem;font-weight:700;font-family:'Bricolage Grotesque',sans-serif;color:var(--accent)}
.proof-stat .label{font-size:.85rem;color:rgba(247,244,235,.65);letter-spacing:.02em}

/* ---------- FAQ ---------- */
.faq{background:var(--black)}
.faq-list{margin-top:56px;display:flex;flex-direction:column;gap:16px;max-width:760px}
.faq-item{
  background:rgba(247,244,235,.03);border:1px solid rgba(247,244,235,.1);border-radius:var(--radius);
  padding:6px 28px;transition:border-color .35s var(--ease),background .35s var(--ease);
}
.faq-item:hover{border-color:rgba(77,141,255,.35)}
.faq-item[open]{background:rgba(247,244,235,.05)}
.faq-item summary{
  list-style:none;cursor:pointer;padding:24px 0;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  font-weight:600;font-size:1.05rem;color:var(--cream);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-icon{
  flex:none;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:var(--accent);font-size:1.2rem;border:1px solid rgba(247,244,235,.2);
  transition:transform .35s var(--ease),background .35s;
}
.faq-item[open] .faq-icon{transform:rotate(45deg);background:rgba(77,141,255,.12)}
.faq-item p{color:var(--muted);line-height:1.6;font-size:.95rem;padding:0 0 26px;max-width:640px}

/* ---------- FINAL CTA ---------- */
.final-cta{
  background:var(--navy);color:var(--cream);text-align:center;
  clip-path:polygon(0 6%,100% 0,100% 100%,0 100%);
  padding:170px 0 150px;position:relative;overflow:hidden;
}
.cta-bg{position:absolute;inset:0;overflow:hidden}
.cta-inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center}
.cta-title{font-size:clamp(2.2rem,5vw,3.6rem);font-weight:700;line-height:1.15;max-width:760px}
.cta-sub{margin-top:22px;color:rgba(247,244,235,.75);max-width:520px;font-size:1.05rem;line-height:1.6}
.btn-lg{margin-top:40px}
.cta-contact{margin-top:22px;color:rgba(247,244,235,.5);font-size:.9rem;letter-spacing:.02em}

/* ---------- BOOKING MODAL ---------- */
.booking-modal{
  position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;
  padding:24px;opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility .3s;
}
.booking-modal.is-open{opacity:1;visibility:visible}
.booking-modal-backdrop{position:absolute;inset:0;background:rgba(4,5,10,.78);backdrop-filter:blur(6px)}
.booking-modal-panel{
  position:relative;z-index:1;background:var(--black-2);border:1px solid rgba(247,244,235,.12);
  border-radius:var(--radius);width:100%;max-width:560px;max-height:88vh;overflow:hidden;
  display:flex;flex-direction:column;transform:translateY(16px) scale(.98);
  transition:transform .35s var(--ease);box-shadow:0 40px 90px rgba(0,0,0,.5);
}
.booking-modal.is-open .booking-modal-panel{transform:translateY(0) scale(1)}
.booking-close{
  position:absolute;top:16px;right:16px;z-index:2;width:34px;height:34px;border-radius:50%;
  background:rgba(247,244,235,.08);border:1px solid rgba(247,244,235,.15);color:var(--cream);
  font-size:1.3rem;line-height:1;cursor:pointer;transition:background .25s;
}
.booking-close:hover{background:rgba(247,244,235,.16)}
.booking-scroll{overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}
.booking-step{padding:44px 36px}
.booking-step h3{font-size:1.4rem;margin-top:10px;margin-bottom:24px;line-height:1.3}
#bookingIntroForm{display:flex;flex-direction:column;gap:18px}
.booking-field{display:flex;flex-direction:column;gap:8px;font-size:.85rem;color:rgba(247,244,235,.7)}
.booking-field input{
  background:rgba(247,244,235,.05);border:1px solid rgba(247,244,235,.15);border-radius:10px;
  padding:13px 14px;color:var(--cream);font-size:1rem;font-family:inherit;
  transition:border-color .25s;
}
.booking-field input:focus{outline:none;border-color:var(--accent)}
.booking-error-msg{color:#ff8a8a;font-size:.85rem;margin:0}
#bookingIntroForm .btn{margin-top:6px;justify-content:center}
#bookingStepForm{padding:0;position:relative;min-height:75vh}
#jotformIframe{display:block;width:100%;height:75vh;min-height:600px;border:0}
.booking-loading{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:var(--black-2);color:var(--cream);font-size:.95rem;
  transition:opacity .3s;pointer-events:none;opacity:0;
}
.booking-loading.is-visible{opacity:1;pointer-events:auto}
#bookingStepError{text-align:center}
#bookingStepError p{color:rgba(247,244,235,.7);margin-bottom:24px;line-height:1.6}
#bookingStepError .btn{justify-content:center;width:100%}
body.modal-open{overflow:hidden}

@media (max-width:560px){
  .booking-modal{padding:0}
  .booking-modal-panel{max-width:100%;max-height:100%;height:100%;border-radius:0}
  #bookingStepForm{min-height:100%}
  #jotformIframe{height:100%;min-height:0}
}

/* ---------- FOOTER ---------- */
.site-footer{background:var(--black-2);border-top:1px solid rgba(247,244,235,.08);color:rgba(247,244,235,.55);padding:34px 0}
.footer-inner{display:flex;justify-content:space-between;align-items:center;font-size:.85rem}

/* ---------- REVEAL ANIM BASE ---------- */
[data-reveal]{opacity:0;will-change:transform,opacity,clip-path;}
[data-reveal="clip"]{opacity:1;}

/* ---------- RESPONSIVE ---------- */
@media (max-width:980px){
  .main-nav{display:none}
  .problem-grid{grid-template-columns:1fr}
  .process-track{grid-template-columns:1fr;gap:36px}
  .process-line{display:none}
  .proof-grid{grid-template-columns:1fr}
  .hero-card{display:none}
  .hero-title{font-size:clamp(2.2rem,8vw,3rem)}
}
@media (max-width:560px){
  .section{padding:90px 0}
  .proof-stats{gap:32px}
}
