:root{
  --navy:#1E3A5F;
  --gold:#C79A4B;
  --bg:#FFFFFF;
  --tint:#F4F6F8;
  --ink:#232A31;
  --muted:#5C6770;
  --gray:#8A9099;
  --maxw:1200px;
  --rad:14px;
  --shadow:0 18px 50px -22px rgba(30,58,95,.42);
}

*,*::before,*::after{box-sizing:border-box}
html,body{max-width:100%;overflow-x:hidden}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Lato',system-ui,sans-serif;
  color:var(--ink);
  background:var(--bg);
  font-weight:400;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img,svg,video,iframe{max-width:100%}
img{height:auto;display:block}
a{color:inherit}
h1,h2,h3{line-height:1.08;letter-spacing:-.02em;margin:0}

.container{
  width:100%;
  max-width:var(--maxw);
  margin-inline:auto;
  padding-inline:clamp(18px,5vw,40px);
}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.4em;
  font-weight:900;font-size:.92rem;letter-spacing:.01em;
  text-decoration:none;border:0;cursor:pointer;
  padding:.85em 1.5em;border-radius:999px;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease;
  min-height:44px;
}
.btn--gold{background:var(--gold);color:#fff;box-shadow:0 10px 26px -12px rgba(199,154,75,.85)}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 16px 34px -12px rgba(199,154,75,.9)}
.btn--navy{background:var(--navy);color:#fff}
.btn--navy:hover{transform:translateY(-2px);box-shadow:0 14px 30px -14px rgba(30,58,95,.7)}
.btn--lg{font-size:1rem;padding:1.05em 1.9em}
:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:6px}

/* ---- promo bar ---- */
.promobar{background:var(--navy);color:#fff;font-size:.82rem}
.promobar__inner{display:flex;gap:1rem;align-items:center;justify-content:center;flex-wrap:wrap;padding:.5rem 0;text-align:center}
.promobar a{color:var(--gold);font-weight:700;text-decoration:none}
.promobar a:hover{text-decoration:underline}

/* ---- header ---- */
.header{
  position:sticky;top:0;z-index:60;background:rgba(255,255,255,.94);
  backdrop-filter:blur(10px);
  border-bottom:1px solid #eceff2;
  transition:padding .25s ease,box-shadow .25s ease;
}
.header.scrolled{box-shadow:0 6px 26px -16px rgba(30,58,95,.4)}
.header__inner{display:flex;align-items:center;gap:1.2rem;padding:.85rem 0;transition:padding .25s ease}
.header.scrolled .header__inner{padding:.55rem 0}
.brand{flex:0 0 auto;display:flex;align-items:center}
.brand__logo{height:38px;width:auto;transition:height .25s ease}
.header.scrolled .brand__logo{height:32px}

.nav{margin-left:auto}
.nav__list{display:flex;gap:.3rem;list-style:none;margin:0;padding:0}
.nav__item{position:relative}
.nav__link{
  display:inline-flex;align-items:center;gap:.35em;
  text-decoration:none;color:var(--navy);font-weight:700;font-size:.92rem;
  padding:.6rem .7rem;border-radius:8px;
}
.nav__link:hover{color:var(--gold)}
.caret{width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid currentColor;opacity:.7}
.drop{
  position:absolute;top:100%;left:0;min-width:248px;
  background:#fff;border:1px solid #eceff2;border-radius:12px;
  box-shadow:var(--shadow);list-style:none;margin:.4rem 0 0;padding:.5rem;
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .18s ease,transform .18s ease,visibility .18s;
}
.has-drop:hover .drop,.has-drop:focus-within .drop{opacity:1;visibility:visible;transform:translateY(0)}
.drop a{display:block;text-decoration:none;color:var(--ink);font-size:.9rem;font-weight:700;padding:.6rem .7rem;border-radius:8px}
.drop a:hover{background:var(--tint);color:var(--navy)}

.header__right{display:flex;align-items:center;gap:.9rem;flex:0 0 auto}
.nav + .header__right{margin-left:0}
.social{display:flex;gap:.55rem;list-style:none;margin:0;padding:0}
.social a{display:inline-flex;color:var(--navy);width:32px;height:32px;align-items:center;justify-content:center;border-radius:50%;transition:.18s}
.social a:hover{color:var(--gold);background:var(--tint)}
.header__cta{font-size:.78rem;padding:.7em 1.2em}

.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:8px;cursor:pointer}
.hamburger span{width:24px;height:2px;background:var(--navy);transition:.25s}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---- mobile menu ---- */
.mobile-menu{
  position:fixed;top:0;right:0;width:min(86vw,340px);height:100vh;
  background:#fff;z-index:70;box-shadow:-12px 0 40px -20px rgba(0,0,0,.4);
  transform:translateX(100%);transition:transform .3s ease;
  padding:5.2rem 1.4rem 2rem;overflow-y:auto;
}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu summary,.m-link{
  display:block;font-weight:900;color:var(--navy);font-size:1.05rem;
  padding:.85rem .2rem;border-bottom:1px solid #eef1f4;cursor:pointer;text-decoration:none;
  list-style:none;
}
.mobile-menu summary::-webkit-details-marker{display:none}
.mobile-menu summary::after{content:"+";float:right;color:var(--gold);font-weight:700}
.m-drop[open] summary::after{content:"–"}
.m-drop a{display:block;text-decoration:none;color:var(--muted);font-weight:700;padding:.55rem .2rem .55rem 1rem;font-size:.94rem}
.m-cta{width:100%;margin-top:1.3rem}
.m-social{display:flex;gap:1rem;margin-top:1.4rem;flex-wrap:wrap}
.m-social a{color:var(--navy);font-weight:700;text-decoration:none;font-size:.9rem}
.scrim-active{overflow:hidden}
.backdrop{position:fixed;inset:0;background:rgba(20,30,42,.5);z-index:65;opacity:0;visibility:hidden;transition:.3s}
.backdrop.show{opacity:1;visibility:visible}

/* ---- shared section bits ---- */
.eyebrow{font-weight:900;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin:0 0 .6rem}
.eyebrow--center{text-align:center}
.eyebrow--light{color:#d9bd86}
.section-title{font-weight:900;font-size:clamp(1.7rem,4vw,2.6rem);color:var(--navy)}
.section-title--center{text-align:center;max-width:18ch;margin:0 auto}

/* ---- hero ---- */
.hero{position:relative;min-height:clamp(560px,86vh,760px);display:flex;align-items:center;overflow:hidden;background:var(--navy)}
.hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:52% 42%}
.hero__scrim{position:absolute;inset:0;background:
  linear-gradient(100deg,rgba(20,33,52,.92) 0%,rgba(24,40,62,.74) 38%,rgba(24,40,62,.12) 66%,rgba(24,40,62,0) 100%);}
.hero__content{position:relative;z-index:2;color:#fff;padding-block:clamp(2.5rem,6vw,4rem);max-width:760px}
.hero__eyebrow{display:inline-flex;align-items:center;gap:.55rem;font-weight:700;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:#dfe6ee;margin-bottom:1.4rem}
.hero__eyebrow .dot{width:10px;height:10px;border-radius:50%;background:var(--gold);animation:breathe 4.5s ease-in-out infinite}
@keyframes breathe{0%,100%{transform:scale(.75);opacity:.6}50%{transform:scale(1.25);opacity:1}}
.hero__title{font-weight:900;font-size:clamp(2.5rem,7.5vw,4.6rem);letter-spacing:-.03em}
.hero__title span{display:block}
.hero__title--gold{color:var(--gold);margin-top:.05em}
.hero__sub{font-size:clamp(1.05rem,2.2vw,1.3rem);font-weight:300;max-width:46ch;margin:1.4rem 0 2rem;color:#eef2f6}
.hero__cta{display:flex;flex-direction:column;align-items:flex-start;gap:.7rem}
.hero__cta-note{font-size:.82rem;color:#cdd6e0;letter-spacing:.04em}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}
.reveal.d3{transition-delay:.3s}.reveal.d4{transition-delay:.4s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.hero__eyebrow .dot{animation:none}}

/* ---- how it works ---- */
.how{background:var(--navy);color:#fff;padding:clamp(2.5rem,5vw,3.5rem) 0}
.how__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.how__item{border-left:2px solid rgba(199,154,75,.5);padding-left:1.2rem}
.how__num{font-weight:900;color:var(--gold);font-size:.9rem;letter-spacing:.1em}
.how__item h3{font-size:1.2rem;margin:.4rem 0 .35rem}
.how__item p{margin:0;color:#d4dbe4;font-size:.95rem;font-weight:300}

/* ---- clients ---- */
.clients{padding:clamp(3.5rem,7vw,5.5rem) 0 clamp(2rem,4vw,3rem)}
.marquee{margin-top:2.5rem;overflow:hidden;position:relative;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
.marquee__track{display:flex;gap:clamp(2.5rem,6vw,5rem);align-items:center;width:max-content;animation:slide 38s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.logo{flex:0 0 auto;display:flex;align-items:center;height:46px}
.logo img{max-height:42px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.62;transition:.3s}
.logo:hover img{filter:none;opacity:1}
@keyframes slide{to{transform:translateX(calc(-50% - clamp(1.25rem,3vw,2.5rem)))}}

/* ---- problem ---- */
.problem{padding:clamp(3rem,6vw,5.5rem) 0;background:var(--tint)}
.problem__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.problem__media{position:relative}
.problem__media img{border-radius:var(--rad);box-shadow:var(--shadow);width:100%;aspect-ratio:4/5;object-fit:cover;object-position:50% 35%}
.problem__badge{position:absolute;left:-12px;bottom:24px;background:var(--navy);color:#fff;border-radius:12px;padding:.9rem 1.1rem;max-width:200px;box-shadow:var(--shadow)}
.problem__badge strong{display:block;color:var(--gold);font-size:1.5rem;line-height:1}
.problem__badge span{font-size:.82rem;font-weight:300;color:#dce3eb}
.checklist{list-style:none;margin:.4rem 0 1.8rem;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:.55rem 1.6rem}
.checklist li{position:relative;padding-left:1.7rem;font-size:.95rem;color:var(--ink)}
.checklist li::before{content:"";position:absolute;left:0;top:.18em;width:16px;height:16px;border-radius:50%;background:var(--gold);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/13px no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/13px no-repeat;}
.problem__thesis{font-weight:900;font-size:clamp(1.3rem,2.6vw,1.75rem);color:var(--navy);line-height:1.2;margin:0 0 1.3rem;letter-spacing:-.01em}
.problem__narrative p{margin:0 0 .85rem;max-width:62ch;color:var(--ink)}
.problem__narrative .btn{margin-top:.5rem}
.hl-gold{color:#a87b29;font-weight:700}
.hl-navy{color:var(--navy);font-weight:700;font-style:italic}

/* ---- testimonials ---- */
.testimonials{padding:clamp(3.5rem,7vw,5.5rem) 0}
.vid-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin:2.8rem 0 1.8rem}
.vid-card{background:#fff;border:1px solid #ebeef1;border-radius:var(--rad);overflow:hidden;box-shadow:0 12px 30px -22px rgba(30,58,95,.5);transition:transform .25s ease,box-shadow .25s ease}
.vid-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.vid-card__frame{position:relative;aspect-ratio:16/9;background:#0d1722}
.vid-card__frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.vid-card__cap{padding:.9rem 1.1rem 1.1rem}
.vid-card__cap strong{display:block;color:var(--navy);font-size:1rem}
.vid-card__cap span{font-size:.86rem;color:var(--muted)}
.vid-card--cta{display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,var(--navy),#16304e);color:#fff;border:0}
.vid-cta{text-align:center;padding:2rem 1.4rem}
.vid-cta p{font-weight:900;font-size:1.25rem;margin:0 0 1.1rem}

.quote-grid{columns:3;column-gap:1.4rem;margin-top:1rem}
.quote{break-inside:avoid;margin:0 0 1.4rem;background:var(--tint);border-radius:var(--rad);padding:1.4rem 1.5rem;border:1px solid #e9edf1}
.quote__head{display:flex;align-items:center;gap:.8rem;margin-bottom:.9rem}
.quote__head img{width:52px;height:52px;border-radius:50%;object-fit:cover;flex:0 0 auto;border:2px solid var(--gold)}
.quote__head strong{display:block;color:var(--navy);font-size:.98rem}
.quote__head span{font-size:.82rem;color:var(--muted)}
.quote blockquote{margin:0;font-size:.93rem;color:#3a444d;line-height:1.6}

/* ---- cta band ---- */
.ctaband{background:linear-gradient(135deg,var(--navy) 0%,#16304e 100%);color:#fff;padding:clamp(3rem,6vw,5rem) 0;position:relative;overflow:hidden}
.ctaband::after{content:"";position:absolute;right:-120px;top:-120px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(199,154,75,.25),transparent 70%)}
.ctaband__inner{display:grid;grid-template-columns:1.3fr .9fr;gap:clamp(2rem,5vw,3.5rem);align-items:center;position:relative;z-index:1}
.ctaband__text h2{font-size:clamp(1.7rem,4vw,2.5rem);font-weight:900;max-width:16ch;margin:.3rem 0 1.1rem}
.ctaband__sub{color:#d3dbe5;font-weight:300;max-width:52ch;margin:0 0 1.8rem}
.ctaband__sub a{color:var(--gold)}
.ctaband__card{background:#fff;color:var(--ink);border-radius:var(--rad);padding:1.8rem 1.6rem;text-align:center;box-shadow:var(--shadow)}
.ctaband__avatar{width:74px;height:74px;border-radius:50%;object-fit:cover;margin:0 auto .9rem;border:3px solid var(--gold)}
.ctaband__card strong{display:block;color:var(--navy);font-size:1.05rem}
.ctaband__card>p{color:var(--muted);font-size:.9rem;margin:.3rem 0 1.1rem}
.ctaband__list{list-style:none;margin:0;padding:0;text-align:left;display:grid;gap:.5rem}
.ctaband__list li{position:relative;padding-left:1.4rem;font-size:.88rem;color:#3a444d}
.ctaband__list li::before{content:"✓";position:absolute;left:0;color:var(--gold);font-weight:900}

/* ---- certs ---- */
.certs{padding:clamp(3rem,5vw,4.5rem) 0}
.certs__row{display:flex;flex-wrap:wrap;gap:clamp(2rem,6vw,5rem);align-items:center;justify-content:center;margin-top:1.5rem}
.certs__row img{max-height:78px;width:auto;object-fit:contain}

/* ---- footer ---- */
.footer{background:var(--navy);color:#cfd8e2;padding:clamp(3rem,5vw,4rem) 0 1.4rem}
.footer__grid{display:grid;grid-template-columns:1.2fr 1fr 1.1fr;gap:clamp(2rem,5vw,3.5rem)}
.footer__logo{height:38px;width:auto;margin-bottom:1rem;background:#fff;padding:8px 12px;border-radius:8px}
.footer__name{font-weight:900;color:#fff;font-size:1.1rem;margin:0 0 .5rem}
.footer address{font-style:normal;line-height:1.9;font-size:.92rem}
.footer address a{color:#cfd8e2;text-decoration:none}
.footer address a:hover{color:var(--gold)}
.footer__social{list-style:none;display:flex;gap:1rem;padding:0;margin:1.2rem 0 0;flex-wrap:wrap}
.footer__social a{color:#fff;font-weight:700;font-size:.85rem;text-decoration:none}
.footer__social a:hover{color:var(--gold)}
.footer__nav{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.footer__nav h3{color:#fff;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin:0 0 .7rem}
.footer__nav h3.mt{margin-top:1.4rem}
.footer__nav a{display:block;color:#cfd8e2;text-decoration:none;font-size:.9rem;padding:.28rem 0}
.footer__nav a:hover{color:var(--gold)}
.footer__map h3{color:#fff;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin:0 0 .5rem}
.footer__maptag{font-size:.9rem;margin:0 0 1rem}
.mapcard{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:1.1rem;display:grid;gap:.9rem}
.mapcard__loc{display:flex;gap:.7rem;align-items:flex-start}
.mapcard__pin{flex:0 0 auto;width:14px;height:14px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);background:var(--gold);margin-top:.3rem}
.mapcard__loc strong{display:block;color:#fff;font-size:.95rem}
.mapcard__loc span{font-size:.82rem;color:#aab8c6}
.mapcard__dir{color:var(--gold);font-weight:700;text-decoration:none;font-size:.9rem}
.mapcard__dir:hover{text-decoration:underline}
.footer__cta{margin-top:1.2rem;width:100%}
.footer__bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.12);margin-top:2.5rem;padding-top:1.4rem;font-size:.8rem;color:#9aa8b6}

/* ---- responsive ---- */
@media (max-width:980px){
  .nav,.header__cta,.social{display:none}
  .hamburger{display:flex}
  .ctaband__inner{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr 1fr}
  .footer__map{grid-column:1/-1}
  .vid-grid{grid-template-columns:repeat(2,1fr)}
  .quote-grid{columns:2}
}
@media (max-width:760px){
  .problem__grid{grid-template-columns:1fr}
  .problem__media{max-width:420px}
  .problem__badge{left:auto;right:14px}
  .how__grid{grid-template-columns:1fr}
  .checklist{grid-template-columns:1fr}
}
@media (max-width:600px){
  .vid-grid{grid-template-columns:1fr}
  .quote-grid{columns:1}
  .footer__grid{grid-template-columns:1fr}
  .footer__nav{grid-template-columns:1fr 1fr}
  .hero{min-height:auto;padding-top:1rem}
  .hero__scrim{background:linear-gradient(180deg,rgba(20,33,52,.55),rgba(20,33,52,.9))}
}