:root{
  --navy:#0E2350;
  --navy-deep:#050B1A;
  --gold:#2E6BE6;
  --gold-soft:#7FADF5;
  --cyan:#31E1DB;
  --violet:#7C6CF0;
  --teal:#14539E;
  --paper:#060C1E;
  --paper-dim:#0A1530;
  --ink:#F4F7FD;
  --ink-soft:rgba(244,247,253,0.66);
  --ink-dim:rgba(244,247,253,0.42);
  --line:rgba(255,255,255,0.13);
  --line-strong:rgba(255,255,255,0.24);
  --surface:rgba(255,255,255,0.045);
  --surface-hi:rgba(255,255,255,0.09);
  --grad-accent:linear-gradient(120deg, var(--gold) 0%, var(--cyan) 100%);
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:
    radial-gradient(1100px 700px at 12% -10%, rgba(46,107,230,0.16), transparent 60%),
    radial-gradient(900px 600px at 100% 10%, rgba(49,225,219,0.10), transparent 55%),
    var(--paper);
  color:var(--ink);
  font-family:'Inter',sans-serif;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  position:relative;
}
#fx{position:fixed; inset:0; width:100%; height:100%; z-index:-1; pointer-events:none; opacity:0.55;}
::selection{background:var(--gold); color:#fff;}
h1,h2,h3{font-family:'Fraunces',serif; font-weight:600; letter-spacing:-0.01em;}
.mono{font-family:'Space Mono',monospace;}
a{color:inherit; text-decoration:none;}
img{max-width:100%; display:block;}
.wrap{max-width:1120px; margin:0 auto; padding:0 24px;}
@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.001ms !important; transition-duration:0.001ms !important;}
}

/* ---------- Header : floating glass nav ---------- */
header{
  position:sticky; top:0; z-index:50;
  padding:18px 20px 0;
}
header .nav{
  max-width:1120px; margin:0 auto; padding:12px 22px;
  background:rgba(9,17,38,0.62);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border:1px solid var(--line);
  border-radius:100px;
  box-shadow:0 8px 30px rgba(2,6,16,0.35);
  transition:padding 0.25s ease, background 0.25s ease, box-shadow 0.25s ease;
}
header.scrolled .nav{
  padding:9px 22px;
  background:rgba(6,12,29,0.86);
  box-shadow:0 12px 34px rgba(2,6,16,0.5), 0 0 0 1px rgba(46,107,230,0.18);
}
.nav{display:flex; align-items:center; justify-content:space-between;}
.brand{display:flex; align-items:center; gap:12px; font-family:'Fraunces',serif; font-weight:600; font-size:1.05rem; color:var(--ink);}
.brand img{width:34px; height:34px; border-radius:9px; object-fit:cover; box-shadow:0 0 0 1px rgba(255,255,255,0.14);}
.navlinks{display:flex; align-items:center; gap:30px; font-size:0.9rem; font-weight:500;}
.navlinks a{color:var(--ink-soft); position:relative; padding:6px 0;}
.navlinks a:hover{color:var(--ink);}
.navlinks a::after{
  content:''; position:absolute; left:0; bottom:0; width:0; height:2px; border-radius:2px;
  background:var(--grad-accent); box-shadow:0 0 8px rgba(46,107,230,0.7);
  transition:width 0.25s ease;
}
.navlinks a:hover::after{width:100%;}
.navlinks a.active{color:var(--ink);}
.navlinks a.active::after{width:100%;}
.nav-cta{
  display:inline-flex; align-items:center; padding:10px 22px; border-radius:100px;
  background:var(--grad-accent); color:#04102A; font-weight:600; font-size:0.86rem;
  box-shadow:0 6px 18px rgba(46,107,230,0.3); transition:transform 0.2s ease, box-shadow 0.2s ease;
  margin-left:8px;
}
.nav-cta:hover{transform:translateY(-1px); box-shadow:0 10px 24px rgba(46,107,230,0.42);}
.navToggle{display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer;}
.navToggle span{width:22px; height:2px; background:var(--ink); border-radius:2px; transition:transform 0.25s ease, opacity 0.25s ease;}
.navlinks.open ~ .navToggle span:nth-child(1), .navToggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.navlinks.open ~ .navToggle span:nth-child(2), .navToggle.active span:nth-child(2){opacity:0;}
.navlinks.open ~ .navToggle span:nth-child(3), .navToggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
@media (max-width:860px){
  header{padding:14px 16px 0;}
  header .nav{border-radius:22px;}
  .navlinks{
    position:absolute; top:calc(100% + 10px); left:16px; right:16px;
    background:rgba(6,12,29,0.94); backdrop-filter:blur(18px);
    flex-direction:column; align-items:stretch; gap:0;
    border:1px solid var(--line); border-radius:18px; overflow:hidden;
    display:none; box-shadow:0 20px 40px rgba(2,6,16,0.5);
  }
  .navlinks.open{display:flex;}
  .navlinks a{padding:16px 22px; border-top:1px solid var(--line);}
  .navlinks a:first-child{border-top:none;}
  .nav-cta{margin:14px 22px 18px; justify-content:center;}
  .navToggle{display:flex;}
}

/* ---------- Page hero (sub-pages) ---------- */
.page-hero{
  background:
    radial-gradient(680px 380px at 85% -10%, rgba(49,225,219,0.16), transparent 60%),
    radial-gradient(600px 400px at 0% 0%, rgba(46,107,230,0.22), transparent 55%),
    linear-gradient(180deg, rgba(5,11,26,0.62) 0%, rgba(6,12,29,0.74) 100%),
    url('assets/hero-bg.png');
  background-size:cover, cover, cover, cover;
  background-position:center, center, center, center 30%;
  color:#fff; padding:96px 0 68px; position:relative; overflow:hidden;
  border-bottom:1px solid var(--line);
}
.page-hero h1, .page-hero p.lead, .page-hero .crumb, .page-hero .eyebrow{text-shadow:0 2px 16px rgba(0,0,0,0.5);}
.page-hero::before{
  content:''; position:absolute; inset:0;
  background-image:linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size:44px 44px;
  -webkit-mask-image:linear-gradient(180deg, #000, transparent 85%);
  mask-image:linear-gradient(180deg, #000, transparent 85%);
  pointer-events:none;
}
.page-hero .wrap{position:relative;}
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:'Space Mono',monospace; font-size:0.75rem; letter-spacing:0.08em; text-transform:uppercase;
  color:var(--gold-soft);
  border:1px solid rgba(46,107,230,0.4);
  padding:6px 14px; border-radius:100px;
  margin-bottom:22px;
}
.eyebrow::before{content:''; width:6px; height:6px; border-radius:50%; background:var(--cyan); box-shadow:0 0 8px 2px rgba(49,225,219,0.7); animation:pulse-dot 2.2s ease-in-out infinite;}
@keyframes pulse-dot{0%,100%{opacity:1;} 50%{opacity:0.35;}}
.page-hero h1{font-size:clamp(2rem, 4.4vw, 3.1rem); line-height:1.1; max-width:720px; color:#fff;}
.page-hero h1 em{font-style:normal; color:var(--gold-soft);}
.page-hero p.lead{margin-top:18px; font-size:1.08rem; color:rgba(255,255,255,0.72); max-width:560px;}
.crumb{font-family:'Space Mono',monospace; font-size:0.78rem; color:rgba(255,255,255,0.5); margin-bottom:18px;}
.crumb a{color:rgba(255,255,255,0.75);}
.crumb a:hover{color:var(--gold-soft);}

/* ---------- Legacy home hero (retained for reference / other templates) ---------- */
.hero{
  position:relative; overflow:hidden;
  background:
    radial-gradient(900px 560px at 88% -6%, rgba(49,225,219,0.18), transparent 58%),
    radial-gradient(760px 520px at 8% 6%, rgba(46,107,230,0.26), transparent 55%),
    linear-gradient(180deg, rgba(5,11,26,0.58) 0%, rgba(6,12,29,0.66) 55%, var(--paper) 100%),
    url('assets/home-bg.png');
  background-size:cover, cover, cover, cover;
  background-position:center, center, center, center 25%;
  color:#fff;
  padding:132px 0 108px;
  border-bottom:1px solid var(--line);
}
.hero::before{
  content:''; position:absolute; inset:0;
  background-image:linear-gradient(rgba(255,255,255,0.045) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.045) 1px, transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:radial-gradient(1200px 700px at 60% 0%, #000, transparent 75%);
  mask-image:radial-gradient(1200px 700px at 60% 0%, #000, transparent 75%);
  pointer-events:none;
}
.hero .wrap{position:relative;}
.hero h1{
  font-size:clamp(2.5rem, 5.2vw, 4.1rem);
  line-height:1.06;
  max-width:780px;
  color:#fff;
  letter-spacing:-0.015em;
  text-shadow:0 4px 28px rgba(0,0,0,0.55);
}
.hero h1 em{
  font-style:normal;
  background:var(--grad-accent);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero p.tagline{
  margin-top:16px; font-size:1.2rem; font-style:italic; font-family:'Fraunces',serif; font-weight:500;
  color:var(--gold-soft); max-width:600px; text-shadow:0 2px 16px rgba(0,0,0,0.5);
}
.hero p.lead{
  margin-top:18px; font-size:1.15rem; color:rgba(255,255,255,0.78); max-width:560px;
  text-shadow:0 2px 16px rgba(0,0,0,0.5);
}
.hero-ctas{display:flex; gap:16px; margin-top:36px; flex-wrap:wrap;}
.btn{
  position:relative; overflow:hidden; isolation:isolate;
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 28px; border-radius:100px; font-weight:600; font-size:0.95rem;
  cursor:pointer; border:none; transition:transform 0.2s ease, box-shadow 0.25s ease;
}
.btn::after{
  content:''; position:absolute; left:var(--rx,50%); top:var(--ry,50%);
  width:10px; height:10px; border-radius:50%; background:rgba(255,255,255,0.55);
  transform:translate(-50%,-50%) scale(0); opacity:0; pointer-events:none; z-index:-1;
}
.btn.rippling::after{animation:btn-ripple 0.6s ease-out;}
@keyframes btn-ripple{
  0%{transform:translate(-50%,-50%) scale(0); opacity:0.55;}
  100%{transform:translate(-50%,-50%) scale(22); opacity:0;}
}
.btn-gold{background:var(--grad-accent); color:#04102A; box-shadow:0 8px 24px rgba(46,107,230,0.32);}
.btn-gold:hover{transform:translateY(-2px); box-shadow:0 12px 30px rgba(46,107,230,0.5), 0 0 0 1px rgba(255,255,255,0.15) inset;}
.btn-outline{border:1px solid rgba(255,255,255,0.28); color:#fff; background:rgba(255,255,255,0.04); backdrop-filter:blur(6px);}
.btn-outline:hover{border-color:rgba(255,255,255,0.6); transform:translateY(-2px); background:rgba(255,255,255,0.08);}

.stats{
  margin-top:80px; display:grid; grid-template-columns:repeat(4,1fr); gap:1px;
  background:var(--line); border-radius:16px; overflow:hidden;
  border:1px solid var(--line); backdrop-filter:blur(10px);
}
.stat{background:rgba(9,17,38,0.55); padding:26px 22px; text-align:left; transition:background 0.25s ease;}
.stat:hover{background:rgba(46,107,230,0.14);}
.stat .num{font-family:'Space Mono',monospace; font-size:1.9rem; color:var(--gold-soft); font-weight:700;}
.stat .label{font-size:0.8rem; color:rgba(255,255,255,0.6); margin-top:4px;}
@media (max-width:700px){ .stats{grid-template-columns:repeat(2,1fr);} }

/* ---------- Section basics ---------- */
section{padding:100px 0;}
.section-head{max-width:640px; margin-bottom:56px;}
.kicker{
  font-family:'Space Mono',monospace; font-size:0.78rem; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--teal); margin-bottom:14px; display:block;
}
.section-head h2{font-size:clamp(1.8rem,3vw,2.5rem); color:var(--ink);}
.section-head p{margin-top:14px; color:var(--ink-soft); font-size:1.05rem;}
.section-head.center{max-width:620px; margin-left:auto; margin-right:auto; text-align:center;}

/* ---------- Teaser cards (used on Home to link out to sub-pages) ---------- */
.teaser-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:20px;}
@media (max-width:860px){ .teaser-grid{grid-template-columns:1fr;} }
.teaser-card{
  background:var(--surface); border:1px solid var(--line); border-radius:16px; padding:32px 28px;
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  transition:transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease, background 0.25s ease; display:flex; flex-direction:column;
}
.teaser-card:hover{transform:translateY(-4px); box-shadow:0 20px 44px rgba(2,6,16,0.4), 0 0 0 1px rgba(46,107,230,0.35) inset; border-color:rgba(46,107,230,0.4); background:var(--surface-hi);}
.teaser-card .idx{font-family:'Space Mono',monospace; color:var(--gold); font-size:0.85rem; margin-bottom:14px; display:block;}
.teaser-card h3{font-size:1.15rem; color:var(--ink); margin-bottom:10px;}
.teaser-card p{color:var(--ink-soft); font-size:0.95rem; flex-grow:1;}
.teaser-card .goto{margin-top:18px; font-weight:600; font-size:0.9rem; color:var(--gold-soft);}
.teaser-card .goto::after{content:'→'; margin-left:6px; transition:transform 0.2s ease; display:inline-block;}
.teaser-card:hover .goto::after{transform:translateX(4px);}

/* ---------- About page ---------- */
.about-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:32px; margin-top:20px;}
.about-card{
  background:var(--surface); border:1px solid var(--line); border-radius:16px; padding:32px 28px;
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  transition:transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease, background 0.25s ease;
}
.about-card:hover{transform:translateY(-4px); box-shadow:0 20px 44px rgba(2,6,16,0.4), 0 0 0 1px rgba(46,107,230,0.35) inset; border-color:rgba(46,107,230,0.4); background:var(--surface-hi);}
.about-card .idx{font-family:'Space Mono',monospace; color:var(--gold); font-size:0.85rem; margin-bottom:14px; display:block;}
.about-card h3{font-size:1.15rem; color:var(--ink); margin-bottom:10px;}
.about-card p{color:var(--ink-soft); font-size:0.95rem;}
@media (max-width:860px){ .about-grid{grid-template-columns:1fr;} }

.value-row{display:grid; grid-template-columns:repeat(2,1fr); gap:24px; margin-top:20px;}
@media (max-width:700px){ .value-row{grid-template-columns:1fr;} }
.value-item{padding:28px; border-left:2px solid var(--gold); background:var(--surface); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-top:1px solid var(--line); border-right:1px solid var(--line); border-bottom:1px solid var(--line); border-radius:0 12px 12px 0;}
.value-item h4{color:var(--ink); font-family:'Fraunces',serif; font-size:1.1rem; margin-bottom:8px;}
.value-item p{color:var(--ink-soft); font-size:0.94rem;}

/* ---------- Divisions page (signature pathway) ---------- */
.divisions-page{background:var(--navy-deep); color:#fff; position:relative;}
.divisions-page .section-head h2{color:#fff;}
.divisions-page .section-head p{color:rgba(255,255,255,0.65);}
.divisions-page .kicker{color:var(--gold-soft);}
.path-wrap{position:relative;}
.path-line{
  position:absolute; left:32px; top:0; bottom:0; width:2px;
  background:repeating-linear-gradient(180deg, rgba(46,107,230,0.5) 0 8px, transparent 8px 16px);
  display:none;
}
@media (min-width:860px){ .path-line{display:block;} }
.div-list{display:flex; flex-direction:column; gap:28px; position:relative;}
.div-card{
  display:grid; grid-template-columns:64px 1fr; gap:24px; align-items:start;
  background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.1);
  border-radius:16px; padding:34px; position:relative;
}
.div-node{
  width:64px; height:64px; border-radius:50%; background:var(--navy);
  border:2px solid var(--gold); display:flex; align-items:center; justify-content:center;
  font-family:'Space Mono',monospace; font-weight:700; color:var(--gold-soft); font-size:1.1rem;
  z-index:2;
}
.div-card.teal .div-node{border-color:var(--teal); color:#7fd6c9;}
.div-body h3{font-size:1.4rem; color:#fff; margin-bottom:8px;}
.div-body .tagline{font-family:'Space Mono',monospace; font-size:0.75rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--gold-soft); margin-bottom:12px; display:block;}
.div-card.teal .tagline{color:#7fd6c9;}
.div-body p{color:rgba(255,255,255,0.68); margin-bottom:20px; max-width:640px;}
.tag-list{display:flex; flex-wrap:wrap; gap:10px; margin-bottom:24px;}
.tag-list span{
  font-size:0.82rem; padding:6px 14px; border-radius:100px;
  border:1px solid rgba(255,255,255,0.18); color:rgba(255,255,255,0.8);
}
.div-link{font-weight:600; font-size:0.92rem; color:var(--gold-soft); display:inline-flex; align-items:center; gap:6px;}
.div-card.teal .div-link{color:#7fd6c9;}
.div-link::after{content:'→'; transition:transform 0.2s ease;}
.div-link:hover::after{transform:translateX(4px);}
@media (max-width:640px){
  .div-card{grid-template-columns:1fr; }
  .div-node{width:48px; height:48px; font-size:0.95rem;}
}

/* ---------- Why us page ---------- */
.why-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:14px; overflow:hidden; margin-top:20px;}
.why-card{background:var(--surface); padding:36px 30px; backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px); transition:background 0.25s ease;}
.why-card:hover{background:var(--surface-hi);}
.why-card .idx{font-family:'Space Mono',monospace; color:var(--gold); font-size:0.8rem; display:block; margin-bottom:12px;}
.why-card h3{font-size:1.1rem; color:var(--ink); margin-bottom:8px;}
.why-card p{color:var(--ink-soft); font-size:0.92rem;}
@media (max-width:860px){ .why-grid{grid-template-columns:1fr;} }

.impact-strip{
  margin-top:60px; background:var(--surface); border:1px solid var(--line); border-radius:18px; padding:44px;
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center;
}
.impact-strip .num{font-family:'Space Mono',monospace; font-size:2.1rem; font-weight:700; background:var(--grad-accent); -webkit-background-clip:text; background-clip:text; color:transparent;}
.impact-strip .label{color:var(--ink-soft); font-size:0.85rem; margin-top:6px;}
@media (max-width:700px){ .impact-strip{grid-template-columns:repeat(2,1fr);} }

/* ---------- Testimonials page ---------- */
.testi-card{
  background:var(--navy); color:#fff; border-radius:18px; padding:52px;
  max-width:760px; margin:20px auto 0; position:relative;
}
.testi-card .quote-mark{font-family:'Fraunces',serif; font-size:4rem; color:var(--gold); line-height:1; margin-bottom:8px;}
.testi-card p.quote{font-size:1.25rem; line-height:1.6; font-family:'Fraunces',serif; font-weight:400;}
.testi-foot{display:flex; align-items:center; gap:14px; margin-top:28px;}
.avatar{
  width:44px; height:44px; border-radius:50%; background:var(--gold);
  display:flex; align-items:center; justify-content:center; font-weight:700; color:var(--navy-deep);
}
.testi-foot .name{font-weight:600;}
.testi-foot .role{color:rgba(255,255,255,0.6); font-size:0.85rem;}

/* ---------- Contact page ---------- */
.contact-grid{display:grid; grid-template-columns:0.9fr 1.1fr; gap:56px; margin-top:20px;}
@media (max-width:860px){ .contact-grid{grid-template-columns:1fr;} }
.contact-info .item{display:flex; gap:16px; padding:20px 0; border-top:1px solid var(--line);}
.contact-info .item:last-child{border-bottom:1px solid var(--line);}
.contact-info .ic{
  width:44px; height:44px; border-radius:12px;
  background:linear-gradient(145deg, rgba(46,107,230,0.22), rgba(49,225,219,0.14));
  border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--gold-soft);
}
.contact-info .ic svg{width:20px; height:20px;}
.contact-info h4{font-size:0.78rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--ink-soft); margin-bottom:6px; font-family:'Space Mono',monospace;}
.contact-info a, .contact-info span{display:block; color:var(--ink); font-weight:500; font-size:0.98rem;}

form{background:var(--surface); border:1px solid var(--line); border-radius:18px; padding:36px; backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:16px;}
@media (max-width:520px){ .form-row{grid-template-columns:1fr;} }
.field{margin-bottom:18px;}
.field label{display:block; font-size:0.82rem; font-weight:600; color:var(--ink); margin-bottom:6px;}
.field input, .field select, .field textarea{
  width:100%; padding:12px 14px; border:1px solid var(--line); border-radius:10px;
  font-family:'Inter',sans-serif; font-size:0.95rem; background:rgba(255,255,255,0.035); color:var(--ink);
}
.field select option{background:var(--navy); color:var(--ink);}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:2px solid var(--gold); outline-offset:1px; border-color:var(--gold);
}
.field textarea{resize:vertical; min-height:110px;}
form .btn-gold{width:100%; justify-content:center; margin-top:6px;}

/* ---------- Footer ---------- */
footer{background:var(--navy-deep); color:rgba(255,255,255,0.65); padding:64px 0 32px;}
.foot-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px;}
@media (max-width:700px){ .foot-grid{grid-template-columns:1fr; gap:32px;} }
.foot-brand{display:flex; align-items:center; gap:12px; color:#fff; font-family:'Fraunces',serif; font-weight:600; margin-bottom:14px;}
.foot-brand img{width:34px; height:34px; border-radius:8px;}
footer h5{font-family:'Space Mono',monospace; font-size:0.78rem; text-transform:uppercase; letter-spacing:0.08em; color:rgba(255,255,255,0.4); margin-bottom:16px;}
footer ul{list-style:none;}
footer li{margin-bottom:10px; font-size:0.92rem;}
footer li a:hover{color:var(--gold-soft);}
.foot-bottom{margin-top:48px; padding-top:24px; border-top:1px solid rgba(255,255,255,0.1); font-size:0.85rem; text-align:center; color:rgba(255,255,255,0.4);}

/* ---------- Features ---------- */
.feature-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:20px;}
@media (max-width:860px){ .feature-grid{grid-template-columns:1fr 1fr;} }
@media (max-width:600px){ .feature-grid{grid-template-columns:1fr;} }
.feature-card{
  background:var(--surface); border:1px solid var(--line); border-radius:16px; padding:28px 26px;
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  transition:transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
.feature-card:hover{transform:translateY(-4px); box-shadow:0 20px 44px rgba(2,6,16,0.4), 0 0 0 1px rgba(49,225,219,0.3) inset; border-color:rgba(49,225,219,0.35); background:var(--surface-hi);}
.feature-icon{
  width:52px; height:52px; border-radius:14px;
  background:linear-gradient(145deg, rgba(46,107,230,0.28), rgba(49,225,219,0.16));
  border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center; margin-bottom:18px;
  color:var(--gold-soft); transition:transform 0.25s ease, color 0.25s ease;
}
.feature-icon svg{width:24px; height:24px; stroke-width:1.8;}
.feature-card:hover .feature-icon{transform:scale(1.08) rotate(-4deg); color:var(--cyan);}
.feature-card h3{font-size:1.05rem; color:var(--ink); margin-bottom:8px;}
.feature-card p{color:var(--ink-soft); font-size:0.92rem;}

/* ---------- Moving testimonial marquee ---------- */
.marquee-outer{
  overflow:hidden; position:relative; margin-top:20px;
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
  mask-image:linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}
.marquee-track{
  display:flex; gap:24px; width:max-content;
  animation:marquee 38s linear infinite;
}
.marquee-outer:hover .marquee-track{animation-play-state:paused;}
@keyframes marquee{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}
@keyframes marqueeReverse{
  from{transform:translateX(-50%);}
  to{transform:translateX(0);}
}
.marquee-track.reverse{animation-name:marqueeReverse;}
.mini-testi{
  background:var(--surface); border:1px solid var(--line); border-radius:16px; padding:26px;
  width:320px; flex-shrink:0; backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
}
.mini-testi .quote-mark{font-family:'Fraunces',serif; font-size:2.2rem; color:var(--gold); line-height:1; display:block; margin-bottom:6px;}
.mini-testi p.quote{font-size:0.96rem; color:var(--ink); line-height:1.55; min-height:96px;}
.mini-testi .testi-foot{margin-top:16px;}
.mini-testi .avatar{width:38px; height:38px; font-size:0.9rem;}
.mini-testi .name{font-size:0.92rem;}
.mini-testi .role{font-size:0.78rem;}
/* ---------- Scroll progress bar ---------- */
#scrollProgress{
  position:fixed; top:0; left:0; height:3px; width:0%;
  background:linear-gradient(90deg, var(--teal), var(--gold-soft));
  z-index:200; transition:width 0.1s ease-out;
}

/* ---------- Floating action buttons ---------- */
.fab-stack{position:fixed; right:22px; bottom:22px; display:flex; flex-direction:column; gap:12px; z-index:150;}
.fab{
  width:54px; height:54px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  box-shadow:0 10px 28px rgba(2,6,16,0.45); cursor:pointer; border:none;
  transition:transform 0.2s ease, box-shadow 0.2s ease; text-decoration:none;
}
.fab:hover{transform:translateY(-3px) scale(1.04);}
.fab-whatsapp{background:#1FAA59; color:#fff; font-size:1.5rem;}
.fab-top{
  background:var(--navy); color:var(--ink); border:1px solid var(--line); font-size:1.1rem;
  opacity:0; pointer-events:none; transform:translateY(8px);
}
.fab-top.visible{opacity:1; pointer-events:auto; transform:translateY(0);}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0; transform:translateY(22px); transition:opacity 0.7s ease, transform 0.7s ease;}
.reveal.in{opacity:1; transform:translateY(0);}
.reveal-stagger > *{opacity:0; transform:translateY(22px); transition:opacity 0.6s ease, transform 0.6s ease;}
.reveal-stagger.in > *{opacity:1; transform:translateY(0);}
.reveal-stagger.in > *:nth-child(1){transition-delay:0.05s;}
.reveal-stagger.in > *:nth-child(2){transition-delay:0.13s;}
.reveal-stagger.in > *:nth-child(3){transition-delay:0.21s;}
.reveal-stagger.in > *:nth-child(4){transition-delay:0.29s;}
.reveal-stagger.in > *:nth-child(5){transition-delay:0.37s;}
.reveal-stagger.in > *:nth-child(6){transition-delay:0.45s;}
@media (prefers-reduced-motion: reduce){
  .reveal, .reveal-stagger > *{opacity:1 !important; transform:none !important; transition:none !important;}
}

/* ---------- Card tilt polish + cursor spotlight ---------- */
.tilt{position:relative; transition:transform 0.25s ease, box-shadow 0.25s ease; will-change:transform; overflow:hidden;}
.tilt::before{
  content:''; position:absolute; inset:0; z-index:0; opacity:0; pointer-events:none;
  background:radial-gradient(220px circle at var(--mx,50%) var(--my,50%), rgba(46,107,230,0.16), transparent 65%);
  transition:opacity 0.3s ease;
}
.tilt:hover::before{opacity:1;}
.tilt > *{position:relative; z-index:1;}

/* ---------- Ambient gradient blobs (cta / footer / divisions) ---------- */
.cta-band, footer, .divisions-page{position:relative; overflow:hidden;}
.cta-band::before, footer::before, .divisions-page::before{
  content:''; position:absolute; z-index:0; pointer-events:none;
  width:520px; height:520px; border-radius:50%; filter:blur(100px);
  background:radial-gradient(circle, rgba(46,107,230,0.18), transparent 70%);
  top:-220px; left:-120px;
}
.cta-band::after, footer::after, .divisions-page::after{
  content:''; position:absolute; z-index:0; pointer-events:none;
  width:420px; height:420px; border-radius:50%; filter:blur(100px);
  background:radial-gradient(circle, rgba(49,225,219,0.12), transparent 70%);
  bottom:-200px; right:-80px;
}
.cta-band .wrap, footer .wrap, .divisions-page .wrap{position:relative; z-index:1;}
@media (prefers-reduced-motion:no-preference){
  .cta-band::before, footer::before, .divisions-page::before{animation:blob-float 14s ease-in-out infinite;}
  .cta-band::after, footer::after, .divisions-page::after{animation:blob-float 16s ease-in-out infinite reverse;}
}
@keyframes blob-float{
  0%,100%{transform:translate(0,0);}
  50%{transform:translate(30px,20px);}
}

/* ---------- Badge row (trust markers) — quiet, no motion ---------- */
.badge-row{display:flex; flex-wrap:wrap; gap:10px; margin-top:28px;}
.badge-pill{
  display:inline-flex; align-items:center; gap:8px; font-size:0.82rem; font-weight:500;
  background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.14);
  color:rgba(255,255,255,0.78); padding:8px 16px 8px 14px; border-radius:100px;
  backdrop-filter:blur(8px);
}
.badge-pill svg{width:14px; height:14px; color:var(--gold-soft); flex-shrink:0;}

/* ---------- FAQ accordion ---------- */
.faq-list{margin-top:20px; border-top:1px solid var(--line);}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{
  width:100%; text-align:left; background:none; border:none; cursor:pointer;
  padding:22px 4px; display:flex; align-items:center; justify-content:space-between; gap:20px;
  font-family:'Fraunces',serif; font-size:1.05rem; color:var(--ink); font-weight:600;
}
.faq-q .plus{
  flex-shrink:0; width:28px; height:28px; border-radius:50%; border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center; font-family:'Space Mono',monospace;
  color:var(--gold-soft); transition:transform 0.25s ease;
}
.faq-item.open .faq-q .plus{transform:rotate(45deg); background:var(--grad-accent); color:#04102A; border-color:transparent; box-shadow:0 0 12px rgba(46,107,230,0.5);}
.faq-a{max-height:0; overflow:hidden; transition:max-height 0.3s ease;}
.faq-a p{padding:0 4px 22px; color:var(--ink-soft); font-size:0.95rem; max-width:640px;}

/* ---------- Package / bundle cards ---------- */
.package-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:20px;}
@media (max-width:860px){ .package-grid{grid-template-columns:1fr;} }
.package-card{
  background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.12); border-radius:16px;
  padding:34px 30px; position:relative; display:flex; flex-direction:column;
}
.package-card.featured{border-color:var(--gold-soft); background:rgba(127,173,245,0.08);}
.package-card .ribbon{
  position:absolute; top:-13px; right:24px; background:var(--gold); color:var(--navy-deep);
  font-family:'Space Mono',monospace; font-size:0.72rem; font-weight:700; padding:5px 12px; border-radius:100px;
  text-transform:uppercase; letter-spacing:0.06em;
}
.package-card h3{color:#fff; font-size:1.25rem; margin-bottom:6px;}
.package-card .sub{color:rgba(255,255,255,0.55); font-size:0.88rem; margin-bottom:22px;}
.package-card ul{list-style:none; flex-grow:1; margin-bottom:26px;}
.package-card li{
  color:rgba(255,255,255,0.78); font-size:0.92rem; padding:9px 0; padding-left:26px; position:relative;
  border-top:1px solid rgba(255,255,255,0.08);
}
.package-card li:first-child{border-top:none;}
.package-card li::before{content:'✓'; position:absolute; left:0; color:var(--gold-soft); font-weight:700;}

/* ---------- Process timeline ---------- */
.process-row{display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:20px; counter-reset:step;}
@media (max-width:860px){ .process-row{grid-template-columns:1fr 1fr;} }
@media (max-width:560px){ .process-row{grid-template-columns:1fr;} }
.process-step{position:relative; padding-top:12px;}
.process-step::before{
  counter-increment:step; content:counter(step,decimal-leading-zero);
  font-family:'Space Mono',monospace; font-size:0.8rem; color:var(--gold);
  display:block; margin-bottom:10px;
}
.process-step h4{color:var(--ink); font-family:'Fraunces',serif; font-size:1.05rem; margin-bottom:8px;}
.process-step p{color:var(--ink-soft); font-size:0.9rem;}
.process-step:not(:last-child)::after{
  content:''; position:absolute; top:16px; left:38px; right:-24px; height:1px; background:var(--line);
}
@media (max-width:860px){ .process-step::after{display:none;} }

/* ---------- CTA band (used across pages) ---------- */
.cta-band{background:var(--navy); color:#fff; padding:64px 0; text-align:center;}
.cta-band h2{color:#fff; font-size:clamp(1.6rem,3vw,2.2rem); margin-bottom:14px;}
.cta-band p{color:rgba(255,255,255,0.68); max-width:520px; margin:0 auto 28px;}

/* ==========================================================
   HOMEPAGE V2 — premium hero, illustration, services grid
   ========================================================== */

.hero-v2{
  position:relative; padding:76px 0 0;
  background:
    radial-gradient(760px 460px at 92% -12%, rgba(49,225,219,0.14), transparent 60%),
    radial-gradient(640px 420px at -6% 10%, rgba(46,107,230,0.20), transparent 58%),
    linear-gradient(180deg, rgba(5,11,26,0.72) 0%, rgba(6,12,29,0.86) 55%, var(--paper) 100%),
    url('assets/home-bg.png');
  background-size:cover, cover, cover, cover;
  background-position:center, center, center, center 25%;
  border-bottom:1px solid var(--line);
}
.hero-v2::before{
  content:''; position:absolute; inset:0; pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size:48px 48px;
  -webkit-mask-image:radial-gradient(1100px 620px at 30% 0%, #000, transparent 78%);
  mask-image:radial-gradient(1100px 620px at 30% 0%, #000, transparent 78%);
}
.hero-v2 .wrap{position:relative;}
.hero-v2-grid{display:grid; grid-template-columns:1.05fr 0.95fr; gap:56px; align-items:center; padding:56px 0 64px;}
@media (max-width:960px){ .hero-v2-grid{grid-template-columns:1fr; gap:48px; padding:24px 0 40px;} }

.hero-v2-content h1{
  font-size:clamp(2.15rem, 4.2vw, 3.3rem); line-height:1.12; letter-spacing:-0.015em; color:#fff;
  max-width:600px; text-shadow:0 4px 26px rgba(0,0,0,0.5);
}
.hero-v2-content h1 .accent{
  background:var(--grad-accent); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero-v2-content p.hero-v2-lead{
  margin-top:20px; font-size:1.08rem; line-height:1.65; color:rgba(244,247,253,0.82); max-width:520px;
  text-shadow:0 2px 16px rgba(0,0,0,0.45);
}

/* Boxed hero lead — glass card with accent rule */
.hero-lead-box{
  position:relative; margin-top:24px; max-width:540px;
  padding:22px 26px 22px 28px;
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.14);
  border-radius:14px;
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  box-shadow:0 14px 34px rgba(2,6,16,0.35);
}
.hero-lead-box::before{
  content:''; position:absolute; left:0; top:14px; bottom:14px; width:3px; border-radius:3px;
  background:var(--grad-accent); box-shadow:0 0 10px rgba(46,107,230,0.6);
}
.hero-lead-box p.hero-v2-lead{
  margin-top:0; max-width:none;
}
@media (max-width:600px){
  .hero-lead-box{padding:18px 20px 18px 22px;}
}

/* Typewriter cursor */
.hero-v2-lead.typing::after{
  content:'';
  display:inline-block;
  width:2px;
  height:1.05em;
  margin-left:2px;
  vertical-align:-0.15em;
  background:var(--cyan);
  box-shadow:0 0 6px rgba(49,225,219,0.7);
  animation:cursorBlink 0.85s step-end infinite;
}
.hero-v2-lead.typed-done::after{
  content:'';
}
@keyframes cursorBlink{
  0%,100%{opacity:1;}
  50%{opacity:0;}
}
@media (prefers-reduced-motion:reduce){
  .hero-v2-lead.typing::after{display:none;}
}

.hero-v2-ctas{display:flex; gap:14px; margin-top:34px; flex-wrap:wrap;}
.hero-v2-services{
  display:flex; flex-wrap:wrap; gap:10px 22px; margin-top:36px; padding-top:26px;
  border-top:1px solid var(--line);
}
.hero-v2-services span{
  display:inline-flex; align-items:center; gap:8px; font-size:0.86rem; color:rgba(244,247,253,0.82); font-weight:500;
  text-shadow:0 2px 12px rgba(0,0,0,0.4);
}
.hero-v2-services span::before{content:''; width:6px; height:6px; border-radius:50%; background:var(--gold-soft); flex-shrink:0;}

/* Illustration panel */
.hero-illu{position:relative; width:100%; aspect-ratio:1/0.95; max-width:520px; margin:0 auto;}
.hero-illu svg{width:100%; height:100%; display:block;}
@media (max-width:960px){ .hero-illu{max-width:420px;} }
@media (prefers-reduced-motion:no-preference){
  .illu-float-a{animation:illuFloatA 6s ease-in-out infinite;}
  .illu-float-b{animation:illuFloatB 7s ease-in-out infinite;}
}
@keyframes illuFloatA{0%,100%{transform:rotate(-4deg) translateY(0);} 50%{transform:rotate(-4deg) translateY(-9px);}}
@keyframes illuFloatB{0%,100%{transform:rotate(3deg) translateY(0);} 50%{transform:rotate(3deg) translateY(8px);}}

/* Stat strip beneath hero */
.hero-v2-stats{
  position:relative; z-index:1;
  display:grid; grid-template-columns:repeat(4,1fr); gap:1px;
  background:var(--line); border:1px solid var(--line); border-radius:16px; overflow:hidden;
  margin-bottom:-40px; transform:translateY(40px);
  box-shadow:0 24px 60px rgba(2,6,16,0.45);
}
@media (max-width:700px){ .hero-v2-stats{grid-template-columns:repeat(2,1fr);} }
.hstat{background:rgba(9,17,38,0.75); backdrop-filter:blur(14px); padding:26px 24px; transition:background 0.25s ease;}
.hstat:hover{background:rgba(46,107,230,0.14);}
.hstat .num{font-family:'Space Mono',monospace; font-size:1.85rem; font-weight:700; color:#fff;}
.hstat .label{font-size:0.8rem; color:var(--ink-soft); margin-top:4px;}

/* Services grid — replaces the generic "teaser" pattern on the homepage */
.services-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:20px;}
@media (max-width:860px){ .services-grid{grid-template-columns:1fr;} }
.service-card{
  background:var(--surface); border:1px solid var(--line); border-radius:18px; padding:34px 30px;
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  display:flex; flex-direction:column;
  transition:transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease, background 0.25s ease;
}
.service-card:hover{
  transform:translateY(-5px);
  box-shadow:0 24px 50px rgba(2,6,16,0.4), 0 0 0 1px rgba(46,107,230,0.35) inset;
  border-color:rgba(46,107,230,0.4); background:var(--surface-hi);
}
.service-icon{
  width:50px; height:50px; border-radius:13px;
  background:linear-gradient(145deg, rgba(46,107,230,0.26), rgba(49,225,219,0.14));
  border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center; margin-bottom:20px;
  color:var(--gold-soft);
}
.service-icon svg{width:23px; height:23px; stroke-width:1.7;}
.service-card .service-tag{
  font-family:'Space Mono',monospace; font-size:0.72rem; letter-spacing:0.06em; text-transform:uppercase;
  color:var(--teal); margin-bottom:10px; display:block;
}
.service-card h3{font-size:1.18rem; color:var(--ink); margin-bottom:10px;}
.service-card p{color:var(--ink-soft); font-size:0.94rem; flex-grow:1;}
.service-card .goto{margin-top:20px; font-weight:600; font-size:0.9rem; color:var(--gold-soft); display:inline-flex; align-items:center; gap:6px;}
.service-card .goto::after{content:'→'; transition:transform 0.2s ease; display:inline-block;}
.service-card:hover .goto::after{transform:translateX(4px);}

/* Split "why us" band for homepage */
.why-split{display:grid; grid-template-columns:0.9fr 1.1fr; gap:56px; align-items:center;}
@media (max-width:900px){ .why-split{grid-template-columns:1fr; gap:36px;} }
.why-split-list{display:flex; flex-direction:column; gap:0;}
.why-line{display:flex; gap:18px; padding:22px 0; border-top:1px solid var(--line);}
.why-split-list .why-line:last-child{border-bottom:1px solid var(--line);}
.why-line .num{font-family:'Space Mono',monospace; color:var(--gold); font-size:0.85rem; padding-top:3px; flex-shrink:0; width:26px;}
.why-line h4{color:var(--ink); font-size:1.02rem; margin-bottom:6px; font-family:'Fraunces',serif; font-weight:600;}
.why-line p{color:var(--ink-soft); font-size:0.92rem;}

.why-highlight{
  background:var(--surface); border:1px solid var(--line); border-radius:20px; padding:40px;
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
}
.why-highlight .quote-mark{font-family:'Fraunces',serif; font-size:3rem; color:var(--gold); line-height:1; margin-bottom:6px; display:block;}
.why-highlight p.quote{font-size:1.15rem; line-height:1.6; font-family:'Fraunces',serif; font-weight:400; color:var(--ink);}
.why-highlight .testi-foot{margin-top:24px;}
.why-highlight .hl-stat{
  margin-top:26px; padding-top:22px; border-top:1px solid var(--line);
  display:flex; align-items:baseline; gap:10px;
}
.why-highlight .hl-stat .num{font-family:'Space Mono',monospace; font-size:1.5rem; font-weight:700; color:var(--gold-soft);}
.why-highlight .hl-stat .label{font-size:0.88rem; color:var(--ink-soft);}

/* ---------- Homepage mobile refinements ---------- */
@media (max-width:600px){
  header{padding:10px 14px 0;}
  section{padding:64px 0;}
  .hero-v2{padding:56px 0 0; background-position:center, center, center, center 15%;}
  .hero-v2-grid{padding:16px 0 32px; gap:40px;}
  .hero-v2-content h1{font-size:clamp(2rem, 8vw, 2.5rem);}
  .hero-v2-ctas{margin-top:26px;}
  .hero-v2-ctas .btn{width:100%; justify-content:center;}
  .hero-v2-services{margin-top:28px; padding-top:20px;}
  .hero-illu{max-width:320px; margin-top:8px;}
  .hero-v2-stats{grid-template-columns:repeat(2,1fr); margin-bottom:-28px; transform:translateY(28px);}
  .hstat{padding:20px 18px;}
  .services-grid, .about-grid, .feature-grid{grid-template-columns:1fr;}
  .why-split{gap:32px;}
  .btn{padding:15px 26px; font-size:1rem;}
}
