:root{
  --bg:#07111b;
  --bg-soft:#0d1824;
  --card:#0f1d2b;
  --card-2:#122335;
  --line:rgba(255,255,255,.09);
  --text:#eef4fb;
  --muted:#b5c3d4;
  --gold:#d6b06b;
  --gold-soft:rgba(214,176,107,.14);
  --shadow:0 22px 60px rgba(0,0,0,.35);
  --radius:28px;
  --radius-sm:18px;
  --max:1220px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Inter",system-ui,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 15% 15%, rgba(214,176,107,.11), transparent 26%),
    radial-gradient(circle at 85% 20%, rgba(122,163,255,.12), transparent 20%),
    linear-gradient(180deg, #07111b 0%, #091420 42%, #071019 100%);
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.page-shell{min-height:100vh}
.topbar{
  position:sticky; top:0; z-index:20;
  backdrop-filter:blur(18px);
  background:rgba(7,17,27,.72);
  border-bottom:1px solid var(--line);
  display:flex; align-items:center; justify-content:space-between;
  gap:20px; padding:16px 24px;
}
.brand{display:flex; align-items:center; gap:14px}
.brand-mark{
  width:44px;height:44px;border-radius:14px;
  display:grid;place-items:center;
  background:linear-gradient(135deg, rgba(214,176,107,.24), rgba(255,255,255,.08));
  border:1px solid rgba(214,176,107,.24);
  font-weight:800; color:var(--gold);
}
.brand-copy strong{display:block;font-size:15px}
.brand-copy small{display:block;color:var(--muted);font-size:12px;margin-top:2px}
.topnav{display:flex;align-items:center;gap:22px}
.topnav a{color:var(--muted);font-size:14px}
.topnav a:hover{color:var(--text)}
.topnav .nav-cta{
  color:var(--text);
  padding:12px 16px;border-radius:999px;
  border:1px solid rgba(214,176,107,.3);
  background:rgba(214,176,107,.08);
}
.menu-toggle{
  display:none; background:none;border:1px solid var(--line);color:var(--text);
  border-radius:999px;padding:10px 14px;font:inherit
}
.mobile-nav{
  display:none; flex-direction:column; gap:14px;
  padding:0 24px 18px; background:rgba(7,17,27,.94);
  border-bottom:1px solid var(--line)
}
.mobile-nav.open{display:flex}
.section-inner{
  width:min(var(--max), calc(100% - 40px));
  margin:0 auto;
}
.narrow{max-width:880px}
.hero{
  width:min(var(--max), calc(100% - 40px));
  margin:28px auto 0;
  display:grid; grid-template-columns:1.05fr .95fr; gap:44px;
  align-items:center;
  min-height:calc(100vh - 110px);
  padding:42px 0 56px;
}
.eyebrow,.section-label,.quote-kicker{
  text-transform:uppercase;
  letter-spacing:.18em;
  color:var(--gold);
  font-size:12px;
  font-weight:700;
}
.hero h1,.section h2{
  font-family:"Playfair Display", Georgia, serif;
  line-height:1.04;
  letter-spacing:-.02em;
  margin:14px 0 18px;
}
.hero h1{font-size:clamp(2.8rem, 5vw, 5.6rem); max-width:12ch}
.hero .lead{
  color:var(--muted); font-size:1.12rem; line-height:1.75;
  max-width:62ch; margin-bottom:26px;
}
.hero-actions{
  display:flex; flex-wrap:wrap; gap:14px; margin-bottom:24px;
}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  min-height:54px; padding:0 22px; border-radius:999px; font-weight:700;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease, border-color .25s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{
  color:#08111a;
  background:linear-gradient(135deg, #e6c180, #cfa55f);
  box-shadow:0 16px 36px rgba(214,176,107,.22);
}
.btn-secondary{
  color:var(--text);
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
}
.btn-ghost{
  color:var(--text);
  border:1px solid rgba(214,176,107,.22);
  background:transparent;
}
.btn-wide{width:100%}
.trust-row{
  display:flex; flex-wrap:wrap; gap:10px; margin-top:8px;
}
.trust-row span{
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  padding:10px 14px; border-radius:999px;
  color:var(--muted); font-size:13px;
}
.hero-visual{
  position:relative; min-height:640px;
}
.hero-card{
  overflow:hidden; border-radius:32px; box-shadow:var(--shadow);
  border:1px solid rgba(255,255,255,.08);
}
.hero-card img{width:100%; height:100%; object-fit:cover}
.hero-card-main{
  position:absolute; inset:0 70px 80px 0;
}
.hero-card-accent{
  position:absolute; right:0; bottom:26px;
  width:260px; height:330px;
}
.hero-stat{
  position:absolute; left:24px; bottom:18px;
  max-width:320px; padding:18px 20px;
  border-radius:22px; backdrop-filter:blur(16px);
  background:rgba(9,20,32,.74);
  border:1px solid rgba(214,176,107,.25);
  box-shadow:var(--shadow);
}
.hero-stat strong{display:block; margin-bottom:8px}
.hero-stat span{color:var(--muted); line-height:1.6; font-size:14px}
.section{padding:88px 0}
.quote-band{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,0));
}
.quote-band h2{font-size:clamp(2rem,3vw,3.2rem)}
.quote-band p{color:var(--muted); line-height:1.8}
.grid-2{
  display:grid; grid-template-columns:1fr 1fr; gap:36px;
}
.align-center{align-items:center}
.copy-block p{
  color:var(--muted); line-height:1.85;
  font-size:1.03rem;
}
.copy-block h2{font-size:clamp(2rem,3vw,3.4rem)}
.feature-stack{display:grid; gap:18px}
.feature-card,.service-card,.proof-panel,.contact-card{
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018));
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.feature-card{
  padding:26px 26px 24px;
}
.feature-card h3,.service-card h3{margin:0 0 10px;font-size:1.15rem}
.feature-card p,.service-card p{margin:0;color:var(--muted);line-height:1.75}
.impact-section{
  background:
    linear-gradient(180deg, rgba(214,176,107,.05), transparent 26%),
    linear-gradient(180deg, rgba(255,255,255,.025), transparent);
}
.gallery-mosaic{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  grid-template-rows:220px 220px 220px;
  gap:16px;
}
.mosaic-card{
  overflow:hidden; border-radius:24px; border:1px solid var(--line);
  box-shadow:var(--shadow)
}
.mosaic-card img{width:100%;height:100%;object-fit:cover}
.mosaic-card.tall{grid-row:1 / span 2}
.mosaic-card.wide{grid-column:1 / span 2}
.benefit-list{display:grid; gap:18px; margin-top:24px}
.benefit-list article{
  padding:18px 20px; border-radius:20px; border:1px solid var(--line);
  background:rgba(255,255,255,.03);
}
.benefit-list strong{display:block; margin-bottom:8px}
.benefit-list p{margin:0}
.services-section .section-head{text-align:center; margin-bottom:28px}
.services-section .section-head h2{
  font-size:clamp(2rem,3vw,3.2rem); max-width:850px; margin-inline:auto;
}
.services-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:20px;
}
.service-card{padding:28px; position:relative}
.service-no{
  width:48px;height:48px;border-radius:14px;
  display:grid;place-items:center;
  background:var(--gold-soft); color:var(--gold);
  border:1px solid rgba(214,176,107,.24);
  font-weight:800; margin-bottom:18px;
}
.service-card ul{
  margin:20px 0 0; padding-left:18px; color:var(--muted);
  line-height:1.8;
}
.service-card li::marker{color:var(--gold)}
.proof-panel{padding:24px}
.proof-item{
  padding:16px 0; border-bottom:1px solid var(--line);
}
.proof-item:last-of-type{border-bottom:0}
.proof-title{
  display:block; font-size:13px; text-transform:uppercase; letter-spacing:.14em;
  color:var(--gold); margin-bottom:8px; font-weight:700;
}
.proof-item p{margin:0; color:var(--muted); line-height:1.75}
.proof-image{
  margin-top:18px; width:100%; height:290px; object-fit:cover;
  border-radius:22px; border:1px solid var(--line)
}
.premium-note{
  margin-top:24px; padding:18px 20px;
  border-radius:22px; background:rgba(214,176,107,.08);
  border:1px solid rgba(214,176,107,.22);
}
.premium-note span{display:block; color:var(--muted); margin-top:8px; line-height:1.7}
.authority-band{
  border-block:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.012));
}
.band-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:32px; align-items:center;
}
.band-grid h2{font-size:clamp(2rem,3vw,3rem)}
.band-grid p{color:var(--muted); line-height:1.8}
.contact-section{padding-bottom:110px}
.contact-card{padding:32px}
.contact-card h3{margin-top:0; font-size:1.6rem}
.contact-card p{color:var(--muted); line-height:1.7}
.contact-list{
  display:grid; gap:10px; margin:20px 0 24px;
}
.contact-list a{
  padding:15px 16px; border-radius:16px; background:rgba(255,255,255,.03);
  border:1px solid var(--line); color:var(--text); font-weight:600;
}
.contact-card .btn + .btn{margin-top:12px}
.microcopy{
  margin-top:22px; padding-left:16px; border-left:2px solid rgba(214,176,107,.34)
}
.reveal{
  opacity:0; transform:translateY(26px);
  transition:opacity .75s ease, transform .75s ease;
}
.reveal.visible{opacity:1; transform:none}
.delay-1{transition-delay:.12s}
.delay-2{transition-delay:.22s}
.floating-card{
  animation:floatCard 6s ease-in-out infinite;
}
@keyframes floatCard{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-12px)}
}
@media (max-width: 1080px){
  .hero{grid-template-columns:1fr; min-height:auto; padding-top:24px}
  .hero h1{max-width:14ch}
  .hero-visual{min-height:620px}
  .grid-2,.band-grid,.services-grid{grid-template-columns:1fr}
  .services-grid{gap:18px}
}
@media (max-width: 820px){
  .topnav{display:none}
  .menu-toggle{display:block}
  .brand-copy small{display:none}
  .hero-visual{min-height:520px}
  .hero-card-main{inset:0 34px 84px 0}
  .hero-card-accent{width:190px;height:240px}
  .gallery-mosaic{
    grid-template-columns:1fr 1fr;
    grid-template-rows:180px 180px 180px;
  }
}
@media (max-width: 640px){
  .topbar{padding:14px 16px}
  .mobile-nav{padding:0 16px 16px}
  .section-inner,.hero{width:min(var(--max), calc(100% - 24px))}
  .hero{margin-top:12px; gap:28px}
  .hero h1{font-size:clamp(2.3rem, 12vw, 4rem)}
  .hero .lead{font-size:1rem}
  .hero-actions .btn{width:100%}
  .hero-visual{min-height:430px}
  .hero-card-main{inset:0 20px 72px 0}
  .hero-card-accent{width:140px;height:190px; bottom:52px}
  .hero-stat{left:12px; right:12px; max-width:none; bottom:0}
  .section{padding:72px 0}
  .quote-band h2,.copy-block h2,.services-section .section-head h2,.band-grid h2{font-size:clamp(1.8rem, 9vw, 2.7rem)}
  .feature-card,.service-card,.proof-panel,.contact-card{border-radius:22px}
  .gallery-mosaic{
    grid-template-columns:1fr;
    grid-template-rows:220px 180px 180px 220px;
  }
  .mosaic-card.tall,.mosaic-card.wide{grid-column:auto;grid-row:auto}
}
