
:root{
  --green:#063f34;
  --green-2:#0c6b54;
  --forest:#082620;
  --purple:#402083;
  --purple-2:#5b35b1;
  --gold:#cba052;
  --ivory:#fbf7ed;
  --paper:#fffdf8;
  --ink:#141719;
  --muted:#65716c;
  --line:rgba(12,51,45,.13);
  --shadow:0 24px 70px rgba(7,24,21,.13);
  --radius:22px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.nav-open{overflow:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button,input,textarea,select{font:inherit}
.skip-link{position:absolute;left:-999px;top:auto}
.skip-link:focus{left:16px;top:16px;z-index:10000;background:white;padding:12px 16px;border-radius:8px}
.container{width:min(var(--max),calc(100% - 40px));margin-inline:auto}
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;height:82px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 max(20px,calc((100vw - var(--max))/2));
  background:linear-gradient(180deg,rgba(3,14,13,.72),rgba(3,14,13,.24) 70%,transparent);
  color:white;transition:background .28s ease,backdrop-filter .28s ease,box-shadow .28s ease,height .28s ease;
}
.site-header.is-scrolled{height:68px;background:rgba(7,23,21,.86);backdrop-filter:blur(18px);box-shadow:0 12px 40px rgba(0,0,0,.16)}
.brand img{width:138px;height:auto;filter:drop-shadow(0 3px 10px rgba(0,0,0,.18))}
.nav{display:flex;gap:30px;align-items:center;font-size:14px;font-weight:650}
.nav a{opacity:.88;position:relative;padding:10px 0}
.nav a:after{content:"";position:absolute;left:0;right:0;bottom:3px;height:2px;background:linear-gradient(90deg,var(--gold),#62d071);transform:scaleX(0);transform-origin:left;transition:transform .24s ease}
.nav a:hover:after,.nav a:focus-visible:after{transform:scaleX(1)}
.header-actions{display:flex;align-items:center;gap:10px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:46px;padding:0 20px;border-radius:12px;border:1px solid transparent;
  font-size:14px;font-weight:760;letter-spacing:.01em;cursor:pointer;position:relative;overflow:hidden;
  transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{color:white;background:linear-gradient(135deg,var(--purple),var(--purple-2));box-shadow:0 16px 35px rgba(64,32,131,.24)}
.btn-primary:before{content:"";position:absolute;inset:-60% -80%;background:linear-gradient(120deg,transparent 35%,rgba(255,255,255,.28),transparent 65%);transform:translateX(-60%);animation:shine 4.8s ease-in-out infinite}
.btn-ghost{background:rgba(255,255,255,.08);color:inherit;border-color:rgba(255,255,255,.2)}
.btn-glass{color:white;background:rgba(3,17,15,.35);border-color:rgba(255,255,255,.28);backdrop-filter:blur(10px)}
.btn-sm{min-height:38px;padding:0 15px;font-size:13px}
.whatsapp-float-mini{height:38px;width:38px;border-radius:50%;display:grid;place-items:center;background:#27b45b;color:white;font-size:11px;font-weight:900;box-shadow:0 10px 22px rgba(39,180,91,.32)}
.menu-btn{display:none;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);height:42px;width:42px;border-radius:12px}
.menu-btn span{display:block;width:18px;height:2px;background:white;margin:5px auto;border-radius:2px}
.section{padding:92px 0}
.section-white{background:linear-gradient(180deg,#fff,#fcfaf5)}
.section-soft{background:linear-gradient(180deg,#fbf7ed,#fff)}
.section-dark{color:white;background:var(--forest)}
.eyebrow{
  color:#5ad06d;text-transform:uppercase;font-size:12px;font-weight:900;letter-spacing:.22em;margin:0 0 14px;
}
.section-heading{text-align:center;max-width:760px;margin:0 auto 42px}
.section-heading h2,.hero h1,.estate-copy h2,.founder h2,.final-cta h2,.reserve-copy h2{
  font-family:Georgia, "Times New Roman", serif;
  letter-spacing:-.035em;line-height:.96;
}
.section-heading h2{font-size:clamp(34px,4.4vw,58px);margin:0 0 16px;color:#10151a}
.section-heading p:not(.eyebrow){color:var(--muted);font-size:18px;line-height:1.65;margin:0}
.compact{margin-bottom:28px}
.hero{min-height:720px;position:relative;display:flex;align-items:flex-end;padding-top:100px;overflow:hidden}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.04);animation:slowZoom 18s ease-out forwards}
.hero-overlay{position:absolute;inset:0;background:
  radial-gradient(circle at 76% 14%,rgba(201,160,82,.32),transparent 25%),
  linear-gradient(90deg,rgba(3,13,13,.91) 0%,rgba(3,13,13,.74) 35%,rgba(3,13,13,.22) 76%),
  linear-gradient(0deg,rgba(3,13,13,.9) 0%,transparent 42%)}
.hero-inner{position:relative;z-index:2;padding:120px 0 150px}
.hero h1{font-size:clamp(50px,7vw,96px);max-width:780px;margin:0 0 24px;color:white}
.hero-copy{font-size:clamp(17px,2vw,22px);line-height:1.6;max-width:620px;color:rgba(255,255,255,.86);margin:0 0 28px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.stats-bar{
  position:absolute;z-index:3;left:50%;bottom:0;transform:translateX(-50%);
  width:min(var(--max),calc(100% - 40px));
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  background:rgba(3,30,27,.78);border:1px solid rgba(255,255,255,.16);backdrop-filter:blur(18px);
  border-radius:20px 20px 0 0;overflow:hidden;box-shadow:0 -20px 70px rgba(0,0,0,.18)
}
.stats-bar div{padding:27px 20px;text-align:center;border-right:1px solid rgba(255,255,255,.16)}
.stats-bar div:last-child{border-right:0}
.stats-bar strong{display:block;font-family:Georgia,serif;font-size:clamp(28px,3vw,42px);line-height:1;color:white}
.stats-bar span{display:block;margin-top:8px;color:#79e389;text-transform:uppercase;font-size:12px;font-weight:900;letter-spacing:.08em}
.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.feature-card,.promise-card,.process-card,.team-card,.reserve-form,.map-card,.faq-grid details{
  background:rgba(255,255,255,.78);border:1px solid var(--line);border-radius:18px;box-shadow:0 12px 45px rgba(17,31,27,.05);
}
.feature-card{padding:24px;min-height:250px;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}
.feature-card:hover{transform:translateY(-6px);border-color:rgba(203,160,82,.48);box-shadow:var(--shadow)}
.feature-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px}
.feature-top img{width:58px;height:58px;object-fit:contain;filter:drop-shadow(0 8px 18px rgba(5,63,52,.11))}
.feature-top span{font-family:Georgia,serif;font-size:42px;color:rgba(23,30,29,.08);font-weight:700}
.feature-card h3{font-family:Georgia,serif;font-size:21px;line-height:1.12;margin:0 0 10px;color:#10151a}
.feature-card p,.promise-card p,.process-card p,.team-card p{color:#55625e;line-height:1.55;margin:0}
.peak-section{background:linear-gradient(180deg,#fff,#fbf7ed)}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:stretch}
.media-card{position:relative;border-radius:22px;overflow:hidden;min-height:420px;box-shadow:var(--shadow);background:#061f1b;border:1px solid rgba(6,63,52,.12)}
.media-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.media-card:hover img{transform:scale(1.04)}
.video-card iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.play-btn{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:86px;height:86px;border-radius:50%;border:1px solid rgba(255,255,255,.45);background:rgba(255,255,255,.88);box-shadow:0 15px 35px rgba(0,0,0,.25);cursor:pointer}
.play-btn:after{content:"";position:absolute;left:35px;top:27px;border-left:24px solid var(--green);border-top:16px solid transparent;border-bottom:16px solid transparent}
.caption{position:absolute;left:18px;bottom:18px;background:rgba(0,0,0,.45);color:white;padding:10px 13px;border-radius:999px;font-size:13px}
.estate-copy{padding:42px;background:white;border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow)}
.estate-logo{width:150px;margin-bottom:18px}
.estate-copy h2{font-size:clamp(36px,4vw,56px);color:#1d1137;margin:0 0 16px}
.estate-copy p{color:#4f5c58;font-size:17px;line-height:1.7}
.check-list{list-style:none;padding:0;margin:22px 0;display:grid;gap:10px}
.check-list li{position:relative;padding-left:28px;color:#26302d;font-weight:650}
.check-list li:before{content:"✓";position:absolute;left:0;top:0;color:#19a963;font-weight:900}
.gallery-block{margin-top:30px;background:#fff;border:1px solid var(--line);border-radius:24px;padding:30px;box-shadow:0 14px 50px rgba(8,38,32,.06)}
.gallery-grid{display:grid;grid-template-columns:1.4fr repeat(2,1fr);grid-auto-rows:230px;gap:12px}
.gallery-item{border:0;background:transparent;padding:0;margin:0;border-radius:16px;overflow:hidden;position:relative;cursor:pointer}
.gallery-main{grid-row:span 2}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease,filter .45s ease}
.gallery-item:hover img{transform:scale(1.055);filter:saturate(1.08)}
.gallery-item span{position:absolute;left:12px;bottom:12px;background:rgba(4,17,15,.55);color:white;border-radius:999px;padding:7px 10px;font-size:12px;font-weight:750;opacity:0;transform:translateY(8px);transition:.25s ease}
.gallery-item:hover span{opacity:1;transform:translateY(0)}
.promise-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.promise-card{padding:28px;text-align:center}
.promise-card h3{font-family:Georgia,serif;font-size:23px;margin:0 0 12px;color:#14201d}
.process-section{background:white}
.process-line{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;position:relative}
.process-card{padding:24px;text-align:center;position:relative}
.process-card span{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:50%;background:var(--green-2);color:white;font-weight:900;margin-bottom:15px}
.process-card h3{font-family:Georgia,serif;font-size:21px;margin:0 0 10px}
.founder{position:relative;overflow:hidden;padding:95px 0}
.founder-bg{position:absolute;inset:0;opacity:.4}
.founder-bg img{width:100%;height:100%;object-fit:cover}
.founder:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#041211 0%,rgba(4,18,17,.88) 42%,rgba(4,18,17,.36))}
.founder-inner{position:relative;z-index:2}
.founder-card{display:grid;grid-template-columns:330px 1fr;gap:42px;align-items:center;max-width:940px}
.founder-card img{border-radius:24px;border:1px solid rgba(255,255,255,.16);box-shadow:0 28px 80px rgba(0,0,0,.28)}
.founder h2{font-size:clamp(44px,5vw,76px);margin:0 0 8px;color:white}
.founder-title{color:#6be36e!important;font-weight:800}
.founder p{color:rgba(255,255,255,.84);font-size:17px;line-height:1.72}
.team-section{background:#fff}
.team-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.team-card{overflow:hidden;transition:transform .22s ease,box-shadow .22s ease}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.team-card img{width:100%;height:210px;object-fit:cover;object-position:top center}
.team-card div{padding:16px}
.team-card h3{font-family:Georgia,serif;font-size:18px;line-height:1.1;margin:0 0 6px;color:#1d1137}
.team-card .role{color:var(--green-2);font-weight:800;font-size:13px;margin-bottom:8px}
.team-card p:not(.role){font-size:13px}
.diaspora{padding:44px 0;background:linear-gradient(135deg,#100a2b,#2a1260 48%,#063f34)}
.diaspora-inner{display:flex;align-items:center;justify-content:space-between;gap:30px}
.diaspora h2{font-family:Georgia,serif;font-size:42px;margin:0 0 8px}
.diaspora p{max-width:620px;color:rgba(255,255,255,.78)}
.flags{display:flex;gap:18px;align-items:center}
.flags span{display:grid;place-items:center;font-size:34px;min-width:64px}
.flags small{font-size:12px;color:rgba(255,255,255,.74);margin-top:5px}
.reserve-section{background:#fbfaf6}
.reserve-grid{display:grid;grid-template-columns:.9fr 1.1fr .8fr;gap:24px;align-items:start}
.reserve-copy h2{font-size:clamp(36px,4.3vw,58px);margin:0 0 14px;color:#1d1137}
.reserve-copy p{line-height:1.68;color:#54615c}
.contact-list{display:grid;gap:12px;margin-top:26px}
.contact-list a{background:white;border:1px solid var(--line);border-radius:16px;padding:15px;display:grid;gap:2px;box-shadow:0 8px 28px rgba(6,63,52,.04)}
.contact-list span{color:var(--green-2);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}
.contact-list strong{font-size:15px}
.reserve-form{padding:22px;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.reserve-form label{font-size:13px;font-weight:800;color:#26302d;display:grid;gap:7px}
.reserve-form input,.reserve-form textarea,.reserve-form select{width:100%;border:1px solid rgba(10,55,47,.18);border-radius:10px;background:#fff;padding:13px 12px;color:#121}
.reserve-form input:focus,.reserve-form textarea:focus,.reserve-form select:focus{outline:3px solid rgba(91,53,177,.15);border-color:var(--purple)}
.full{grid-column:1/-1}
.form-note{grid-column:1/-1;color:var(--muted);font-size:12px;text-align:center;margin:0}
.map-card{padding:18px}
.fake-map{height:315px;border-radius:16px;background:
  linear-gradient(45deg,rgba(78,176,129,.08) 25%,transparent 25%),
  linear-gradient(-45deg,rgba(78,176,129,.08) 25%,transparent 25%),
  linear-gradient(135deg,#eff8f1,#e8f3ee);
  background-size:42px 42px;
  position:relative;display:grid;place-items:center;text-align:center;color:#0e453b;margin-bottom:12px;overflow:hidden}
.fake-map:before{content:"";position:absolute;inset:48% -10% auto -10%;height:26px;background:rgba(87,126,158,.18);transform:rotate(-10deg)}
.fake-map .pin{width:30px;height:30px;background:#e8443f;border-radius:50% 50% 50% 0;transform:rotate(-45deg);display:block;margin:0 auto 8px;box-shadow:0 10px 26px rgba(232,68,63,.3)}
.fake-map .pin:after{content:"";position:absolute;width:10px;height:10px;border-radius:50%;background:white;left:10px;top:10px}
.fake-map strong,.fake-map small{position:relative;z-index:1;display:block}
.faq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.faq-grid details{padding:18px 20px}
.faq-grid summary{font-weight:800;cursor:pointer}
.faq-grid p{color:var(--muted);line-height:1.6}
.final-cta{padding:58px 0;background:linear-gradient(135deg,#100a2b,#2b176a 45%,#063f34)}
.final-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.final-cta h2{font-size:clamp(34px,4.2vw,60px);margin:0;color:white}
.footer{background:#111715;color:rgba(255,255,255,.78);padding:55px 0 22px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:38px}
.footer-logo{width:150px;height:auto;margin-bottom:10px}
.footer h3{color:white;font-size:14px;text-transform:uppercase;letter-spacing:.12em}
.footer a{display:block;margin:8px 0;color:rgba(255,255,255,.7)}
.footer-bottom{text-align:center;border-top:1px solid rgba(255,255,255,.08);margin-top:38px;padding-top:20px;font-size:13px;color:rgba(255,255,255,.55)}
.whatsapp-float{position:fixed;right:18px;bottom:18px;z-index:900;background:#25d366;color:white;font-weight:900;border-radius:999px;padding:14px 18px;box-shadow:0 16px 40px rgba(37,211,102,.33)}
.lightbox{position:fixed;inset:0;background:rgba(2,8,7,.88);z-index:2000;display:grid;place-items:center;padding:26px}
.lightbox[hidden]{display:none}
.lightbox img{max-width:min(1200px,92vw);max-height:86vh;border-radius:18px;box-shadow:0 30px 90px rgba(0,0,0,.42)}
.lightbox button{position:absolute;right:24px;top:20px;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.35);background:rgba(255,255,255,.09);color:white;font-size:28px;cursor:pointer}
.reveal{opacity:1;transform:none}
.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .65s ease,transform .65s ease}
.js .reveal.in{opacity:1;transform:none}
@keyframes shine{0%,65%{transform:translateX(-70%)}82%,100%{transform:translateX(70%)}}
@keyframes slowZoom{from{transform:scale(1.06)}to{transform:scale(1.01)}}
@media (max-width:1050px){
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .split,.reserve-grid{grid-template-columns:1fr}
  .promise-grid,.process-line{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:820px){
  .site-header{height:70px;padding-inline:16px;background:rgba(7,23,21,.86);backdrop-filter:blur(16px)}
  .brand img{width:118px}
  .menu-btn{display:block}
  .nav{position:fixed;left:14px;right:14px;top:78px;background:rgba(7,23,21,.96);border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:18px;display:none;flex-direction:column;align-items:flex-start;gap:10px}
  body.nav-open .nav{display:flex}
  .btn-sm{display:none}
  .hero{min-height:700px}
  .hero-inner{padding:130px 0 178px}
  .hero h1{font-size:clamp(44px,13vw,68px)}
  .stats-bar{grid-template-columns:repeat(2,1fr);width:calc(100% - 24px)}
  .stats-bar div{padding:17px 10px}
  .stats-bar strong{font-size:28px}
  .stats-bar span{font-size:10px}
  .section{padding:68px 0}
  .container{width:min(100% - 28px,var(--max))}
  .feature-grid,.promise-grid,.process-line,.faq-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-auto-rows:170px}
  .gallery-main{grid-column:1/-1;grid-row:span 2}
  .founder-card{grid-template-columns:1fr}
  .founder-card img{width:min(360px,100%)}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .team-card img{height:190px}
  .team-card p:not(.role){display:none}
  .diaspora-inner,.final-inner{display:block}
  .flags{margin-top:20px;flex-wrap:wrap}
  .reserve-form{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}
@media (max-width:480px){
  .hero-copy{font-size:16px}
  .hero-cta{display:grid}
  .gallery-grid{grid-template-columns:1fr;grid-auto-rows:210px}
  .gallery-main{grid-row:span 1}
  .team-grid{grid-template-columns:1fr 1fr;gap:12px}
  .team-card div{padding:12px}
  .team-card h3{font-size:16px}
  .whatsapp-float{font-size:13px;padding:12px 14px}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .js .reveal,.reveal{opacity:1!important;transform:none!important}
}



/* =========================================================
   FINAL MOBILE QA PATCH
   Purpose: remove blank reveal bug, lock mobile logo/header,
   improve WhatsApp CTA, tighten mobile rhythm.
   ========================================================= */

/* P0: content must never disappear if IntersectionObserver fails. */
.reveal,
.js .reveal,
.reveal.in,
.js .reveal.in {
  opacity: 1 !important;
  transform: none !important;
}

/* Locked compact brand for mobile and desktop header. */
.brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.brand .brand-mark {
  width: 38px !important;
  height: 38px !important;
  object-fit: contain;
  filter: drop-shadow(0 4px 12px rgba(0,0,0,.25));
  flex: 0 0 auto;
}
.brand .brand-text {
  display: grid;
  line-height: .9;
  letter-spacing: .02em;
}
.brand .brand-text strong {
  color: #fff;
  font-size: 20px;
  font-weight: 900;
}
.brand .brand-text small {
  color: #71d36b;
  font-size: 8px;
  font-weight: 900;
  letter-spacing: .22em;
  margin-top: 4px;
}

/* WhatsApp icon locked. */
.wa-svg {
  width: 19px;
  height: 19px;
  display: block;
  fill: currentColor;
}
.btn-wa {
  gap: 9px;
}
.whatsapp-float-mini {
  color: white;
  background: linear-gradient(135deg, #1eb85b, #20d46c);
  border: 1px solid rgba(255,255,255,.22);
}
.whatsapp-float {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  border: 1px solid rgba(255,255,255,.25);
  background: linear-gradient(135deg, #20b85a, #22d46e);
  color: #fff;
}

/* Better hero legibility and rhythm on all devices. */
.hero-copy {
  text-shadow: 0 2px 18px rgba(0,0,0,.22);
}
.hero h1 {
  text-wrap: balance;
}
.section-heading h2,
.estate-copy h2,
.reserve-copy h2 {
  text-wrap: balance;
}

/* More premium icon rendering inside cards. */
.feature-top img {
  object-fit: contain;
  background: rgba(255,255,255,.72);
  border-radius: 16px;
  padding: 4px;
}

/* Mobile polish */
@media (max-width: 820px) {
  .site-header {
    height: 64px;
    padding-inline: 14px;
    background: rgba(7,23,21,.91);
    backdrop-filter: blur(16px);
    box-shadow: 0 10px 34px rgba(0,0,0,.16);
  }
  .site-header.is-scrolled {
    height: 62px;
  }
  .brand .brand-mark {
    width: 34px !important;
    height: 34px !important;
  }
  .brand .brand-text strong {
    font-size: 18px;
  }
  .brand .brand-text small {
    font-size: 7px;
    letter-spacing: .18em;
  }
  .header-actions {
    gap: 8px;
  }
  .whatsapp-float-mini {
    width: 38px;
    height: 38px;
  }
  .menu-btn {
    width: 38px;
    height: 38px;
    border-radius: 11px;
  }
  .hero {
    min-height: 642px;
    align-items: flex-end;
  }
  .hero-inner {
    padding: 110px 0 156px;
  }
  .hero .eyebrow {
    font-size: 10px;
    letter-spacing: .18em;
    margin-bottom: 10px;
  }
  .hero h1 {
    font-size: clamp(42px, 12.8vw, 62px);
    line-height: .94;
    max-width: 360px;
    margin-bottom: 16px;
  }
  .hero-copy {
    font-size: 15px;
    line-height: 1.52;
    max-width: 350px;
    margin-bottom: 18px;
    color: rgba(255,255,255,.9);
  }
  .hero-cta {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    max-width: 350px;
  }
  .hero-cta .btn {
    min-height: 44px;
    border-radius: 11px;
  }
  .stats-bar {
    width: calc(100% - 22px);
    grid-template-columns: repeat(2, 1fr);
    border-radius: 16px 16px 0 0;
  }
  .stats-bar div {
    padding: 16px 8px 14px;
    border-right: 1px solid rgba(255,255,255,.13);
    border-bottom: 1px solid rgba(255,255,255,.09);
  }
  .stats-bar div:nth-child(2n) {
    border-right: 0;
  }
  .stats-bar strong {
    font-size: 25px;
  }
  .stats-bar span {
    font-size: 9px;
    letter-spacing: .06em;
    margin-top: 6px;
  }
  #why {
    padding-top: 46px;
  }
  .section {
    padding: 58px 0;
  }
  .section-heading {
    margin-bottom: 26px;
  }
  .section-heading h2 {
    font-size: clamp(30px, 9vw, 40px);
    line-height: 1;
  }
  .section-heading p:not(.eyebrow) {
    font-size: 15px;
    line-height: 1.58;
  }
  .feature-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 13px;
  }
  .feature-card {
    min-height: 0;
    padding: 18px;
    border-radius: 16px;
  }
  .feature-top {
    margin-bottom: 10px;
  }
  .feature-top img {
    width: 52px;
    height: 52px;
  }
  .feature-top span {
    font-size: 34px;
  }
  .feature-card h3 {
    font-size: 20px;
    margin-bottom: 8px;
  }
  .feature-card p {
    font-size: 14px;
    line-height: 1.5;
  }
  .split {
    gap: 16px;
  }
  .media-card {
    min-height: 300px;
    border-radius: 18px;
  }
  .estate-copy {
    padding: 24px 20px;
    border-radius: 18px;
  }
  .estate-logo {
    width: 128px;
    margin-bottom: 14px;
  }
  .estate-copy h2 {
    font-size: 34px;
  }
  .estate-copy p,
  .check-list li {
    font-size: 14px;
    line-height: 1.55;
  }
  .gallery-block {
    padding: 18px;
    border-radius: 18px;
  }
  .gallery-grid {
    grid-template-columns: 1fr;
    grid-auto-rows: 220px;
  }
  .gallery-main {
    grid-row: span 1;
  }
  .play-btn {
    width: 70px;
    height: 70px;
  }
  .play-btn:after {
    left: 29px;
    top: 22px;
    border-left-width: 21px;
    border-top-width: 14px;
    border-bottom-width: 14px;
  }
  .promise-grid,
  .process-line,
  .faq-grid {
    gap: 12px;
  }
  .process-card,
  .promise-card {
    padding: 20px;
  }
  .founder {
    padding: 64px 0;
  }
  .founder-card {
    gap: 22px;
  }
  .founder-card img {
    max-height: 420px;
    object-fit: cover;
  }
  .team-grid {
    grid-template-columns: 1fr 1fr;
  }
  .team-card img {
    height: 174px;
  }
  .team-card h3 {
    font-size: 16px;
  }
  .team-card .role {
    font-size: 12px;
  }
  .diaspora h2 {
    font-size: 32px;
  }
  .reserve-grid {
    gap: 16px;
  }
  .reserve-form,
  .map-card {
    border-radius: 18px;
  }
  .fake-map {
    height: 260px;
  }
  .final-cta h2 {
    font-size: 34px;
  }
  .whatsapp-float {
    right: 14px;
    bottom: 14px;
    padding: 12px 13px;
    font-size: 13px;
  }
}

@media (max-width: 390px) {
  .brand .brand-text strong {
    font-size: 16px;
  }
  .hero h1 {
    font-size: 40px;
  }
  .hero-copy {
    font-size: 14px;
  }
}



/* =========================================================
   FINAL DESKTOP + TABLET QA PATCH
   Purpose: make desktop feel more expensive, avoid tablet
   header crowding, improve team readability, lock final rhythm.
   ========================================================= */

/* Cleaner desktop header proportions */
@media (min-width: 821px) {
  .site-header {
    padding-inline: max(28px, calc((100vw - var(--max)) / 2));
  }
  .brand .brand-mark {
    width: 40px !important;
    height: 40px !important;
  }
  .brand .brand-text strong {
    font-size: 21px;
    letter-spacing: .035em;
  }
  .brand .brand-text small {
    font-size: 8px;
  }
  .nav {
    gap: clamp(18px, 2vw, 30px);
  }
  .hero-inner {
    padding-top: 135px;
  }
  .hero h1 {
    max-width: 720px;
  }
}

/* Tablet header: prevent cramped nav before mobile mode */
@media (max-width: 1120px) and (min-width: 821px) {
  .nav {
    gap: 16px;
    font-size: 13px;
  }
  .brand .brand-text strong {
    font-size: 18px;
  }
  .btn-sm {
    padding: 0 12px;
  }
}

/* Desktop team cards: more premium and readable than tiny 6-column cards */
@media (min-width: 1051px) {
  .team-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
  .team-card {
    display: grid;
    grid-template-columns: 142px 1fr;
    min-height: 230px;
  }
  .team-card img {
    height: 100%;
    min-height: 230px;
    border-right: 1px solid var(--line);
  }
  .team-card div {
    padding: 22px 20px;
  }
  .team-card h3 {
    font-size: 22px;
  }
  .team-card .role {
    font-size: 13px;
  }
  .team-card p:not(.role) {
    font-size: 14px;
    line-height: 1.55;
  }
}

/* Desktop visual polish */
@media (min-width: 900px) {
  .feature-card {
    will-change: transform;
  }
  .split,
  .gallery-block,
  .reserve-grid {
    scroll-margin-top: 90px;
  }
  .media-card,
  .estate-copy,
  .gallery-block,
  .reserve-form,
  .map-card {
    box-shadow: 0 22px 70px rgba(7, 24, 21, .09);
  }
  .final-cta .btn,
  .hero-cta .btn-primary {
    box-shadow: 0 18px 42px rgba(91, 53, 177, .28);
  }
}

/* Keep mobile team cards simple after desktop horizontal layout */
@media (max-width: 1050px) {
  .team-card {
    display: block;
  }
}

/* Better below-hero transition: section starts immediately, no dead air */
#why {
  position: relative;
  z-index: 2;
}

/* Prevent oversized empty vertical rhythm if images are slow */
.media-card,
.gallery-item,
.fake-map {
  background-color: #0b211d;
}



/* =========================================================
   FINAL REFINEMENT V5
   Reduce AI feel, improve typography tone, center portraits,
   and upgrade map card / link treatment.
   ========================================================= */

:root{
  --serif-refined:"Iowan Old Style","Palatino Linotype",Palatino,"Book Antiqua","New York",Georgia,serif;
  --sans-refined:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}

/* More editorial, less template-y */
body{
  font-family:var(--sans-refined);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
.hero h1,
.section-heading h2,
.reserve-copy h2,
.estate-copy h2,
.final-cta h2,
.founder h2{
  font-family:var(--serif-refined)!important;
  letter-spacing:-.034em;
}
.feature-card h3,
.promise-card h3,
.process-card h3,
.team-card h3,
.contact-list strong{
  font-family:var(--sans-refined)!important;
  letter-spacing:-.03em;
}
.stats-bar strong{
  font-family:var(--serif-refined)!important;
  letter-spacing:-.03em;
}

/* Founder section: tone down the AI look by darkening the generated background
   and letting Omar's real photo become the hero focus. */
.founder-bg{
  opacity:.22 !important;
}
.founder:before{
  background:linear-gradient(90deg,#041211 0%,rgba(4,18,17,.96) 42%,rgba(4,18,17,.82) 72%,rgba(4,18,17,.66) 100%) !important;
}
.founder-card{
  max-width:980px;
  gap:50px;
}
.founder-card img{
  width:100%;
  max-width:330px;
  aspect-ratio:4/5;
  object-fit:cover;
  object-position:center 16%;
  background:#e8efec;
}

/* Team cards: cleaner, more centered portraits */
.team-grid{
  gap:20px;
}
.team-card{
  overflow:hidden;
  border-radius:20px;
}
.team-card img{
  width:100%;
  height:100%;
  min-height:240px;
  object-fit:cover;
  object-position:center 18%;
  background:#ebf0ed;
}
.team-card div{
  padding:22px 20px;
}
.team-card h3{
  font-size:18px;
  font-weight:800;
  line-height:1.03;
  margin:0 0 8px;
}
.team-card .role{
  font-size:12px;
  letter-spacing:-.01em;
  margin-bottom:10px;
}
.team-card p:not(.role){
  font-size:13px;
  line-height:1.58;
}

/* Fine-tune each portrait crop */
.team-card img[src*="omar"],
.founder-card img[src*="omar"]{
  object-position:center 14%;
}
.team-card img[src*="sainabou"]{
  object-position:center 18%;
}
.team-card img[src*="haddijatou"]{
  object-position:center 16%;
}
.team-card img[src*="adama"]{
  object-position:center 20%;
}
.team-card img[src*="cherno"]{
  object-position:center 16%;
}
.team-card img[src*="matarr"]{
  object-position:center 14%;
}

/* Better map card: more premium, clearer action, better alignment */
.map-card{
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  min-height:100%;
  padding:18px;
}
.map-link{
  color:inherit;
  text-decoration:none;
}
.fake-map{
  height:315px;
  border-radius:18px;
  position:relative;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:10px;
  margin-bottom:14px;
  overflow:hidden;
  background:
    radial-gradient(circle at 25% 22%, rgba(115, 186, 154, .18) 0 16%, transparent 17%),
    radial-gradient(circle at 78% 70%, rgba(115, 186, 154, .12) 0 18%, transparent 19%),
    linear-gradient(135deg, #edf4ef, #e5efe9 54%, #eaf3ef);
  border:1px solid rgba(6,63,52,.08);
}
.fake-map:before{
  content:"";
  position:absolute;
  inset:52% -5% auto -6%;
  height:34px;
  background:linear-gradient(90deg, rgba(134,153,167,.12), rgba(126,145,159,.28), rgba(134,153,167,.12));
  transform:rotate(-11deg);
  box-shadow:0 0 0 6px rgba(255,255,255,.18);
}
.fake-map:after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, transparent 0 12%, rgba(255,255,255,.35) 12.4% 13.2%, transparent 13.6% 100%),
    linear-gradient(transparent 0 20%, rgba(255,255,255,.28) 20.6% 21.2%, transparent 21.8% 100%);
  opacity:.55;
}
.fake-map .map-chip{
  position:absolute;
  top:14px;
  right:14px;
  z-index:2;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.88);
  border:1px solid rgba(6,63,52,.10);
  color:#1b463c;
  font-size:11px;
  font-weight:800;
  letter-spacing:.05em;
  text-transform:uppercase;
  box-shadow:0 10px 22px rgba(6,63,52,.08);
}
.fake-map .pin{
  z-index:2;
}
.fake-map strong,
.fake-map small,
.fake-map .map-helper{
  position:relative;
  z-index:2;
}
.fake-map strong{
  font-family:var(--sans-refined);
  font-size:29px;
  font-weight:800;
  line-height:1.05;
  color:#083d34;
  text-align:center;
  max-width:250px;
}
.fake-map small{
  font-size:15px;
  color:#2f524b;
}
.fake-map .map-helper{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:6px;
  font-style:normal;
  color:#31544c;
  font-size:12px;
  font-weight:700;
  letter-spacing:.01em;
}
.fake-map .map-helper:before{
  content:"↗";
  display:inline-block;
  color:var(--purple-2);
  font-size:15px;
}
.map-card .btn{
  width:100%;
}
.map-note{
  margin:10px 4px 0;
  color:#61706a;
  font-size:12px;
  line-height:1.45;
  text-align:center;
}

/* Desktop team grid stays premium */
@media (min-width: 1051px){
  .team-grid{
    grid-template-columns:repeat(3,1fr);
  }
  .team-card{
    display:grid;
    grid-template-columns:146px 1fr;
    min-height:248px;
  }
  .team-card img{
    min-height:248px;
  }
}

/* Tablet and mobile cleanup */
@media (max-width: 1050px){
  .team-card{
    display:block;
  }
  .team-card img{
    height:220px;
    min-height:220px;
  }
}

@media (max-width: 820px){
  .founder-card{
    gap:26px;
  }
  .founder-card img{
    max-width:320px;
    margin-inline:auto;
  }
  .fake-map strong{
    font-size:26px;
  }
}



/* =========================================================
   V6 UX POLISH
   - Use actual SaiMar logo in header
   - Remove heavy 01/02/03/04/05 visual noise
   - Cleaner, less AI/template feel
   ========================================================= */

.brand-logo{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 14px;
  border-radius:18px;
  background:rgba(255,253,248,.96);
  border:1px solid rgba(12,51,45,.10);
  box-shadow:0 10px 34px rgba(0,0,0,.10), inset 0 1px 0 rgba(255,255,255,.55);
}
.brand-logo-full{
  display:block;
  width:auto;
  height:54px;
  object-fit:contain;
  filter:drop-shadow(0 2px 8px rgba(0,0,0,.08));
}

/* remove the synthetic text lockup from earlier versions if still present */
.brand-text{display:none !important;}

/* less clutter: remove giant sequence numbers */
.feature-top span,
.process-card > span{
  display:none !important;
}

/* rebalance cards after removing big numbers */
.feature-top{
  justify-content:flex-start;
  align-items:center;
  margin-bottom:16px;
}
.feature-top img{
  width:60px;
  height:60px;
}
.feature-card{
  min-height:230px;
}
.feature-card h3{
  font-family:var(--sans-refined)!important;
  font-size:20px;
  font-weight:800;
  line-height:1.08;
  letter-spacing:-.02em;
}
.feature-card p{
  font-size:14px;
  line-height:1.62;
}

/* process section should feel ultra clean */
.process-line{
  gap:18px;
}
.process-card{
  padding:26px 22px;
  text-align:left;
}
.process-card h3{
  font-family:var(--sans-refined)!important;
  font-size:18px;
  line-height:1.1;
  margin:0 0 8px;
}
.process-card p{
  font-size:14px;
  line-height:1.58;
}
.process-card:before{
  content:"";
  display:block;
  width:42px;
  height:4px;
  border-radius:999px;
  margin:0 0 16px;
  background:linear-gradient(90deg,var(--purple-2), var(--green-2));
  box-shadow:0 4px 14px rgba(91,53,177,.22);
}

/* headline rhythm a bit more premium */
.section-heading .eyebrow{
  letter-spacing:.16em;
}
.section-heading h2{
  max-width:820px;
}

/* desktop / tablet header polish */
@media (min-width:821px){
  .site-header{
    height:84px;
  }
  .site-header.is-scrolled{
    height:72px;
  }
  .nav{
    gap:26px;
  }
}

@media (max-width:1120px) and (min-width:821px){
  .brand-logo-full{
    height:48px;
  }
  .nav{
    gap:16px;
    font-size:13px;
  }
}

/* mobile header with real logo */
@media (max-width:820px){
  .brand-logo{
    padding:7px 10px;
    border-radius:14px;
  }
  .brand-logo-full{
    height:38px;
  }
  .site-header{
    padding-inline:12px;
  }
  .feature-card,
  .process-card{
    text-align:left;
  }
}


/* =========================================================
   V7 FINAL WOW POLISH
   Hero, logo, motion-lite dopamine, anti-template refinement
   ========================================================= */

/* Real logo lockup */
.brand-logo{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  gap:2px;
  padding:9px 14px 8px;
  border-radius:18px;
  background:rgba(255,252,246,.97);
  border:1px solid rgba(12,51,45,.08);
  box-shadow:0 12px 34px rgba(6,19,17,.12), inset 0 1px 0 rgba(255,255,255,.6);
}
.brand-logo-full{
  display:block;
  width:auto;
  height:46px;
  object-fit:contain;
  transform-origin:left center;
  filter:drop-shadow(0 2px 7px rgba(0,0,0,.06));
}
.brand-sub{
  display:block;
  font-size:8px;
  font-weight:800;
  letter-spacing:.24em;
  color:#1b4c41;
  margin-left:3px;
}
.site-header{
  backdrop-filter:blur(14px);
}
.site-header:after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.22), transparent);
  pointer-events:none;
}

/* Hero premium detail */
.hero{
  min-height:100svh;
}
.hero:before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 16% 18%, rgba(203,160,82,.26) 0 0, rgba(203,160,82,.26) 0%, rgba(203,160,82,0) 34%),
    radial-gradient(circle at 78% 20%, rgba(91,53,177,.22) 0%, rgba(91,53,177,0) 30%);
  pointer-events:none;
  z-index:1;
}
.hero-overlay{
  background:
    linear-gradient(180deg, rgba(4,15,12,.38) 0%, rgba(4,15,12,.52) 33%, rgba(4,15,12,.68) 100%),
    linear-gradient(90deg, rgba(4,15,12,.72) 0%, rgba(4,15,12,.54) 34%, rgba(4,15,12,.18) 72%);
}
.hero-inner{
  position:relative;
  z-index:2;
  padding-top:148px;
  padding-bottom:164px;
}
.hero .eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px;
  backdrop-filter:blur(10px);
  box-shadow:0 8px 24px rgba(0,0,0,.08);
}
.hero .eyebrow:before{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  background:linear-gradient(135deg, #6ef490, #b3ffd0);
  box-shadow:0 0 0 5px rgba(110,244,144,.14);
}
.hero h1{
  max-width:740px;
  font-size:clamp(54px, 6.4vw, 88px);
  line-height:.92;
  letter-spacing:-.05em;
  margin:18px 0 16px;
  text-wrap:balance;
}
.hero-copy{
  max-width:620px;
  font-size:18px;
  line-height:1.66;
  color:rgba(255,255,255,.88);
}
.hero-cta{
  margin-top:28px;
  gap:14px;
}
.btn-primary{
  box-shadow:0 18px 40px rgba(91,53,177,.28), inset 0 1px 0 rgba(255,255,255,.22);
}
.btn-primary:hover{
  box-shadow:0 22px 48px rgba(91,53,177,.36), 0 0 0 8px rgba(91,53,177,.10);
}
.btn-glass:hover{
  box-shadow:0 16px 36px rgba(0,0,0,.18);
}
.hero-trust{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:16px;
}
.hero-trust span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:38px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.92);
  font-size:13px;
  font-weight:700;
  backdrop-filter:blur(9px);
}
.hero-trust span:before{
  content:"";
  width:14px;
  height:14px;
  border-radius:50%;
  background:radial-gradient(circle at 35% 35%, #7dff9d 0 26%, #2bbc64 27% 100%);
  box-shadow:0 0 0 4px rgba(71,224,129,.12);
}
.stats-bar{
  z-index:3;
  width:min(1180px, calc(100% - 40px));
  left:50%;
  transform:translateX(-50%);
  bottom:0;
  background:linear-gradient(180deg, rgba(3,43,36,.95), rgba(3,38,32,.98));
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 26px 70px rgba(4,20,16,.28);
  overflow:hidden;
}
.stats-bar:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(91,53,177,.08), rgba(110,244,144,.03), rgba(203,160,82,.06));
  pointer-events:none;
}
.stats-bar div{
  position:relative;
  padding:28px 22px 24px;
}
.stats-bar strong{
  display:block;
  margin-bottom:6px;
  font-size:clamp(28px, 3vw, 46px);
  line-height:.92;
}
.stats-bar span{
  font-size:13px;
  font-weight:800;
  letter-spacing:.11em;
  text-transform:uppercase;
  color:#89f2a8;
}

/* Better section rhythm */
.section{
  padding:88px 0;
}
.section-heading{
  margin-bottom:34px;
}
.section-heading p:not(.eyebrow){
  max-width:700px;
}

/* Cleaner reasons / process cards */
.feature-card,
.process-card,
.promise-card,
.team-card,
.reserve-form,
.map-card,
.faq-grid details{
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.feature-card:hover,
.process-card:hover,
.promise-card:hover,
.map-card:hover,
.team-card:hover,
.faq-grid details:hover{
  transform:translateY(-5px);
  box-shadow:0 20px 54px rgba(9,32,27,.10);
  border-color:rgba(203,160,82,.32);
}
.feature-top{
  margin-bottom:14px;
}
.feature-card{
  padding:24px;
  min-height:218px;
}
.feature-card h3{
  margin-bottom:9px;
}
.process-line{
  grid-template-columns:repeat(5,1fr);
  gap:16px;
}
.process-card{
  padding:24px 22px 22px;
}
.process-card:before{
  content:"";
  display:block;
  width:42px;
  height:4px;
  border-radius:999px;
  margin:0 0 16px;
  background:linear-gradient(90deg,var(--purple-2), var(--green-2));
  box-shadow:0 4px 14px rgba(91,53,177,.16);
}

/* Final CTA and map polish */
.map-card .btn,
.final-cta .btn-primary{
  box-shadow:0 16px 34px rgba(7,24,21,.10);
}
.final-cta{
  position:relative;
}
.final-cta:before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 15% 20%, rgba(203,160,82,.10), transparent 28%), radial-gradient(circle at 80% 80%, rgba(91,53,177,.12), transparent 30%);
  pointer-events:none;
}

/* Responsive refinement */
@media (max-width: 1050px){
  .hero h1{font-size:clamp(48px, 8vw, 72px);max-width:650px}
  .process-line{grid-template-columns:repeat(2,1fr)}
}

@media (max-width: 820px){
  .brand-logo{padding:7px 10px 6px;border-radius:14px}
  .brand-logo-full{height:36px}
  .brand-sub{font-size:7px;letter-spacing:.22em}
  .hero-inner{padding-top:118px;padding-bottom:156px}
  .hero .eyebrow{padding:8px 12px;font-size:10px}
  .hero h1{font-size:clamp(42px, 12vw, 58px);max-width:360px;margin-top:14px}
  .hero-copy{font-size:15px;line-height:1.58;max-width:350px}
  .hero-trust{gap:8px;max-width:350px}
  .hero-trust span{font-size:12px;padding:0 12px;min-height:34px}
  .stats-bar{width:calc(100% - 22px)}
  .stats-bar div{padding:16px 10px 14px}
  .stats-bar strong{font-size:27px}
  .stats-bar span{font-size:9px;letter-spacing:.08em}
  .process-line{grid-template-columns:1fr}
}


/* =========================================================
   V8 CONVERSION + WOW POLISH
   Mobile sticky conversion bar, richer hero and cleaner motion.
   ========================================================= */

/* Header CTA more premium when scrolled */
.site-header.is-scrolled .brand-logo{
  box-shadow:0 10px 30px rgba(6,19,17,.10), inset 0 1px 0 rgba(255,255,255,.65);
}
.site-header .btn-sm{
  position:relative;
  overflow:hidden;
}
.site-header .btn-sm:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg, transparent 10%, rgba(255,255,255,.14) 32%, transparent 56%);
  transform:translateX(-120%);
  transition:transform .8s ease;
}
.site-header .btn-sm:hover:before{
  transform:translateX(120%);
}

/* Hero support proof */
.hero-proof{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:12px;
  max-width:760px;
  margin-top:18px;
}
.hero-proof > div{
  padding:14px 14px 12px;
  border-radius:18px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(10px);
  box-shadow:0 14px 34px rgba(0,0,0,.10);
}
.hero-proof strong{
  display:block;
  color:#fff;
  font-size:13px;
  font-weight:800;
  line-height:1.25;
  margin-bottom:4px;
}
.hero-proof small{
  display:block;
  color:rgba(255,255,255,.72);
  font-size:11px;
  line-height:1.35;
}
.hero-scroll{
  position:absolute;
  right:0;
  bottom:34px;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  color:#fff;
  font-size:12px;
  font-weight:800;
  letter-spacing:.05em;
  text-transform:uppercase;
  backdrop-filter:blur(10px);
  box-shadow:0 14px 36px rgba(0,0,0,.12);
}
.hero-scroll i{
  display:inline-block;
  width:16px;
  height:16px;
  border-right:2px solid rgba(255,255,255,.92);
  border-bottom:2px solid rgba(255,255,255,.92);
  transform:rotate(45deg) translateY(-2px);
}
.hero-scroll:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 44px rgba(0,0,0,.16);
}

/* CTA, cards and stats feel more alive but lightweight */
.btn,
.feature-card,
.process-card,
.promise-card,
.team-card,
.map-card,
.reserve-form,
.faq-grid details{
  will-change:transform;
}
.btn{
  transition:transform .22s ease, box-shadow .22s ease, background-color .22s ease, border-color .22s ease;
}
.btn:hover{transform:translateY(-2px)}
.stats-bar strong{ text-shadow:0 2px 10px rgba(0,0,0,.15); }

/* Section separator luxury rhythm */
.section-heading .eyebrow{
  position:relative;
}
.section-heading .eyebrow:after{
  content:"";
  display:inline-block;
  width:36px;
  height:2px;
  margin-left:10px;
  vertical-align:middle;
  background:linear-gradient(90deg, rgba(203,160,82,.9), rgba(203,160,82,0));
}

/* Mobile sticky conversion bar */
.mobile-convert{
  display:none;
}
@media (max-width: 820px){
  body{
    padding-bottom:96px;
  }
  .whatsapp-float{display:none !important}
  .hero-proof{
    grid-template-columns:1fr;
    max-width:350px;
    gap:9px;
    margin-top:12px;
  }
  .hero-proof > div{
    padding:11px 12px 10px;
    border-radius:14px;
  }
  .hero-proof strong{font-size:12px}
  .hero-proof small{font-size:10px}
  .hero-scroll{
    right:auto;
    left:0;
    bottom:96px;
    font-size:10px;
    padding:9px 12px;
  }
  .mobile-convert{
    display:block;
    position:fixed;
    left:12px;
    right:12px;
    bottom:12px;
    z-index:1200;
    padding:10px;
    border-radius:20px;
    background:rgba(7,24,21,.94);
    border:1px solid rgba(255,255,255,.10);
    box-shadow:0 18px 46px rgba(2,10,9,.28), inset 0 1px 0 rgba(255,255,255,.08);
    backdrop-filter:blur(14px);
  }
  .mobile-convert:before{
    content:"";
    position:absolute;
    inset:0;
    border-radius:20px;
    background:linear-gradient(90deg, rgba(91,53,177,.10), rgba(110,244,144,.04), rgba(203,160,82,.10));
    pointer-events:none;
  }
  .mobile-convert-meta{
    position:relative;
    z-index:1;
    margin:0 0 8px;
    text-align:center;
    color:rgba(255,255,255,.78);
    font-size:10px;
    font-weight:800;
    letter-spacing:.12em;
    text-transform:uppercase;
  }
  .mobile-convert-actions{
    position:relative;
    z-index:1;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
  }
  .mcv-btn{
    min-height:48px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:14px;
    font-size:14px;
    font-weight:900;
    letter-spacing:-.01em;
    text-decoration:none;
  }
  .mcv-primary{
    color:#fff;
    background:linear-gradient(135deg, var(--purple-2), #6d43d0);
    box-shadow:0 14px 30px rgba(91,53,177,.24);
  }
  .mcv-wa{
    color:#fff;
    background:linear-gradient(135deg, #119c46, #25d366);
    box-shadow:0 14px 30px rgba(37,211,102,.24);
  }
}

@media (min-width: 821px){
  .hero-proof > div:hover{
    transform:translateY(-3px);
    transition:transform .22s ease, box-shadow .22s ease;
    box-shadow:0 18px 44px rgba(0,0,0,.15);
  }
}


/* =========================================================
   V9 LIQUID GLASS / MOBILE WOW PASS
   Apple-like glass polish, richer micro-interactions, still lightweight.
   ========================================================= */

:root{
  --glass-stroke:rgba(255,255,255,.16);
  --glass-fill:rgba(255,255,255,.10);
  --glass-fill-strong:rgba(255,255,255,.14);
  --glass-shadow:0 18px 44px rgba(4,18,17,.14);
}
html{
  scroll-behavior:smooth;
}
body{
  background:
    radial-gradient(circle at 10% 8%, rgba(203,160,82,.06), transparent 22%),
    radial-gradient(circle at 90% 14%, rgba(91,53,177,.05), transparent 22%),
    linear-gradient(180deg, #f5f4ef 0%, #f8f8f4 22%, #f7f6f1 100%);
}

/* Shared glass surfaces */
.brand-logo,
.hero .eyebrow,
.hero-trust span,
.hero-proof > div,
.hero-scroll,
.stats-bar,
.mobile-convert,
.btn-glass,
.whatsapp-float,
.whatsapp-float-mini{
  position:relative;
  isolation:isolate;
}
.brand-logo:before,
.hero .eyebrow:after,
.hero-trust span:after,
.hero-proof > div:after,
.stats-bar:after,
.mobile-convert:after,
.btn-glass:after,
.whatsapp-float:after,
.whatsapp-float-mini:after{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:inherit;
  background:linear-gradient(180deg, rgba(255,255,255,.28), rgba(255,255,255,.04) 35%, rgba(255,255,255,.02) 100%);
  pointer-events:none;
  z-index:-1;
}
.brand-logo{
  background:linear-gradient(180deg, rgba(255,252,246,.92), rgba(255,249,242,.82));
  border:1px solid rgba(255,255,255,.55);
  box-shadow:0 14px 40px rgba(6,19,17,.10), inset 0 1px 0 rgba(255,255,255,.7), inset 0 -1px 0 rgba(255,255,255,.2);
}
.site-header{
  background:linear-gradient(180deg, rgba(3,14,13,.54), rgba(3,14,13,.24) 68%, transparent);
}
.site-header.is-scrolled{
  background:linear-gradient(180deg, rgba(7,23,21,.86), rgba(7,23,21,.80));
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav a,
.header-actions .btn-sm,
.whatsapp-float-mini{
  transition:transform .22s ease, opacity .22s ease, background-color .22s ease, box-shadow .22s ease;
}
.nav a:hover{transform:translateY(-1px)}

/* Liquid hero */
.hero:after{
  content:"";
  position:absolute;
  inset:auto auto 22% -5%;
  width:360px;
  height:360px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(90,53,177,.18) 0%, rgba(90,53,177,.12) 26%, rgba(90,53,177,0) 68%);
  filter:blur(18px);
  opacity:.95;
  animation:floatOrbA 9s ease-in-out infinite;
  pointer-events:none;
  z-index:1;
}
.hero-bg{
  filter:saturate(1.02) contrast(1.02);
}
.hero-copy{
  text-wrap:pretty;
}
.hero .eyebrow,
.hero-trust span,
.hero-proof > div,
.hero-scroll{
  background:linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,.06));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 16px 36px rgba(0,0,0,.10), inset 0 1px 0 rgba(255,255,255,.18);
}
.hero-trust span,
.hero-proof > div{
  backdrop-filter:blur(16px) saturate(1.14);
}
.hero-proof > div{
  overflow:hidden;
}
.hero-proof > div:before{
  content:"";
  position:absolute;
  inset:auto -20% -30% auto;
  width:90px;
  height:90px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(203,160,82,.15), rgba(203,160,82,0) 68%);
  pointer-events:none;
}
.hero-proof strong,
.hero-trust span{
  letter-spacing:-.02em;
}
.hero-cta .btn{
  min-width:210px;
}
.btn-primary{
  background:linear-gradient(135deg, #4a2ca0 0%, #6e43d2 52%, #7d5bf3 100%);
  box-shadow:0 18px 42px rgba(64,32,131,.28), inset 0 1px 0 rgba(255,255,255,.18);
}
.btn-primary:hover{
  transform:translateY(-3px) scale(1.01);
}
.btn-glass{
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.05));
  border-color:rgba(255,255,255,.22);
  box-shadow:0 16px 36px rgba(0,0,0,.12), inset 0 1px 0 rgba(255,255,255,.16);
}
.btn-glass:hover{
  background:linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.07));
}

/* Stats and cards */
.stats-bar{
  backdrop-filter:blur(24px) saturate(1.18);
  background:linear-gradient(180deg, rgba(3,38,32,.82), rgba(3,32,28,.94));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 26px 70px rgba(4,20,16,.28), inset 0 1px 0 rgba(255,255,255,.08);
}
.stats-bar div:hover{
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.00));
}
.feature-card,
.promise-card,
.process-card,
.team-card,
.reserve-form,
.map-card,
.faq-grid details{
  background:linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.72));
  backdrop-filter:blur(16px) saturate(1.08);
  box-shadow:0 18px 46px rgba(17,31,27,.06), inset 0 1px 0 rgba(255,255,255,.70);
}
.feature-card:before,
.promise-card:before,
.process-card:before,
.team-card:before,
.map-card:before,
.reserve-form:before,
.faq-grid details:before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  background:radial-gradient(circle at top right, rgba(203,160,82,.09), transparent 26%);
  opacity:.9;
}
.feature-card,
.promise-card,
.process-card,
.team-card,
.map-card,
.reserve-form,
.faq-grid details{overflow:hidden}

/* Gallery / video wow */
.media-card,
.gallery-card{
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 18px 48px rgba(8,28,24,.10);
}
[data-video]{
  transition:transform .28s ease, box-shadow .28s ease;
}
[data-video]:hover{
  transform:translateY(-4px);
  box-shadow:0 22px 52px rgba(8,28,24,.18);
}
[data-video] .play{
  box-shadow:0 16px 32px rgba(255,255,255,.22), 0 12px 34px rgba(0,0,0,.16);
  backdrop-filter:blur(14px);
}

/* Float button and sticky bar */
.whatsapp-float{
  background:linear-gradient(135deg, #119c46, #25d366);
  box-shadow:0 18px 40px rgba(37,211,102,.28), inset 0 1px 0 rgba(255,255,255,.18);
}
.whatsapp-float:hover{
  transform:translateY(-3px) scale(1.02);
}
.mobile-convert{
  transition:transform .28s ease, opacity .28s ease, box-shadow .28s ease;
}
.mobile-convert.is-hidden{
  transform:translateY(120%);
  opacity:0;
  pointer-events:none;
}
.mcv-btn{
  position:relative;
  overflow:hidden;
}
.mcv-btn:before{
  content:"";
  position:absolute;
  inset:-60% -80%;
  background:linear-gradient(120deg, transparent 36%, rgba(255,255,255,.24), transparent 64%);
  transform:translateX(-80%);
  animation:shine 5.5s ease-in-out infinite;
}
.mcv-primary,
.mcv-wa{
  backdrop-filter:blur(14px) saturate(1.08);
}
.mcv-primary{
  box-shadow:0 14px 30px rgba(91,53,177,.30), inset 0 1px 0 rgba(255,255,255,.18);
}
.mcv-wa{
  box-shadow:0 14px 30px rgba(37,211,102,.28), inset 0 1px 0 rgba(255,255,255,.18);
}
.mobile-convert-meta{
  text-shadow:0 1px 8px rgba(0,0,0,.10);
}

/* Tappable mobile richness */
@media (max-width: 820px){
  .site-header{padding-inline:12px}
  .brand-logo{padding:8px 10px 7px}
  .hero-overlay{
    background:
      linear-gradient(180deg, rgba(4,15,12,.42) 0%, rgba(4,15,12,.58) 32%, rgba(4,15,12,.76) 100%),
      linear-gradient(90deg, rgba(4,15,12,.78) 0%, rgba(4,15,12,.60) 44%, rgba(4,15,12,.22) 82%);
  }
  .hero:after{width:220px;height:220px;left:-10%;bottom:28%;filter:blur(10px)}
  .hero h1{letter-spacing:-.055em}
  .hero-cta{display:grid;grid-template-columns:1fr;max-width:350px}
  .hero-cta .btn{width:100%}
  .hero-trust span{min-height:34px}
  .stats-bar{width:calc(100% - 20px);border-radius:18px 18px 0 0}
  .stats-bar div{padding:16px 10px 15px}
  .feature-card:active,
  .promise-card:active,
  .process-card:active,
  .team-card:active,
  .map-card:active,
  .mcv-btn:active,
  .btn:active{
    transform:scale(.985);
  }
  .faq-grid details,
  .feature-card,
  .process-card,
  .team-card,
  .map-card,
  .reserve-form{border-radius:20px}
}

@keyframes floatOrbA{
  0%,100%{transform:translate3d(0,0,0) scale(1)}
  50%{transform:translate3d(18px,-18px,0) scale(1.04)}
}


/* =========================================================
   V10 GALLERY POLISH + HERO CLEANUP
   Remove fake hero chips. Make gallery feel premium and mobile-first.
   ========================================================= */

.hero-trust{display:none !important}
.hero-proof{
  margin-top:22px;
  max-width:720px;
}
.hero-proof > div{
  padding:16px 16px 14px;
  border-radius:20px;
}
.hero-proof strong{
  font-size:14px;
}
.hero-proof small{
  font-size:11px;
}

.gallery-helper{
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  gap:10px 18px;
  align-items:center;
  margin:-8px 0 18px;
  color:#52615b;
}
.gallery-helper p,
.gallery-helper span{
  margin:0;
  font-size:13px;
  line-height:1.4;
}
.gallery-helper span{
  font-weight:700;
  color:#1e4038;
}
.gallery-grid{
  position:relative;
  gap:14px;
}
.gallery-item{
  min-width:0;
  border:1px solid rgba(255,255,255,.58);
  box-shadow:0 14px 38px rgba(8,28,24,.08), inset 0 1px 0 rgba(255,255,255,.44);
  transition:transform .26s ease, box-shadow .26s ease, border-color .26s ease;
  -webkit-tap-highlight-color: transparent;
}
.gallery-item:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,0) 45%, rgba(4,17,15,.18) 100%);
  pointer-events:none;
  z-index:1;
}
.gallery-item:hover,
.gallery-item:focus-visible{
  transform:translateY(-4px);
  border-color:rgba(203,160,82,.48);
  box-shadow:0 22px 54px rgba(8,28,24,.14);
}
.gallery-item img{
  display:block;
}
.gallery-item span{
  z-index:2;
  left:14px;
  right:14px;
  bottom:14px;
  width:max-content;
  max-width:calc(100% - 28px);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  backdrop-filter:blur(12px) saturate(1.1);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 8px 22px rgba(0,0,0,.16);
}
.gallery-item:focus-visible{
  outline:2px solid rgba(91,53,177,.48);
  outline-offset:2px;
}

.lightbox{
  background:radial-gradient(circle at center, rgba(8,18,16,.66) 0%, rgba(3,8,7,.94) 72%);
  padding:18px;
}
.lightbox-stage{
  position:relative;
  display:grid;
  place-items:center;
  width:min(1280px, 100%);
}
.lightbox img{
  width:auto;
  max-width:min(1260px,92vw);
  max-height:72vh;
  object-fit:contain;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.14);
  background:#091311;
  box-shadow:0 36px 90px rgba(0,0,0,.42);
}
.lightbox button{
  transition:transform .22s ease, background-color .22s ease, box-shadow .22s ease;
}
.lightbox button:hover{transform:translateY(-2px)}
.lightbox [data-close]{
  right:14px;
  top:14px;
  z-index:3;
}
.lightbox-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:52px;
  height:52px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.24);
  background:rgba(255,255,255,.10);
  color:#fff;
  font-size:34px;
  line-height:1;
  display:grid;
  place-items:center;
  backdrop-filter:blur(14px);
  box-shadow:0 16px 36px rgba(0,0,0,.16);
  z-index:2;
}
.lightbox-nav.prev{left:20px}
.lightbox-nav.next{right:20px}
.lightbox-meta{
  width:min(1100px, 92vw);
  margin-top:14px;
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  align-items:center;
  gap:8px 20px;
  color:#fff;
}
.lightbox-count{
  font-size:12px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#96e5b0;
}
.lightbox-caption{
  flex:1 1 340px;
  margin:0;
  font-size:16px;
  font-weight:700;
  line-height:1.4;
}
.lightbox-hint{
  color:rgba(255,255,255,.68);
  font-size:12px;
}
.lightbox-thumbs{
  width:min(1100px, 92vw);
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:88px;
  gap:10px;
  overflow-x:auto;
  padding:12px 2px 2px;
  margin-top:10px;
  scrollbar-width:none;
}
.lightbox-thumbs::-webkit-scrollbar{display:none}
.lightbox-thumb{
  appearance:none;
  border:1px solid rgba(255,255,255,.14);
  background:transparent;
  padding:0;
  border-radius:14px;
  overflow:hidden;
  cursor:pointer;
  opacity:.62;
  transform:scale(.96);
  transition:opacity .2s ease, transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.lightbox-thumb img{
  width:100%;
  height:66px;
  object-fit:cover;
  display:block;
  border-radius:0;
  max-width:none;
  max-height:none;
  box-shadow:none;
  border:0;
}
.lightbox-thumb.is-active{
  opacity:1;
  transform:scale(1);
  border-color:rgba(203,160,82,.72);
  box-shadow:0 10px 24px rgba(0,0,0,.18);
}
.lightbox-thumb:focus-visible{
  outline:2px solid rgba(91,53,177,.52);
  outline-offset:2px;
}

@media (max-width:820px){
  .gallery-block{
    padding:22px 16px 18px;
    border-radius:22px;
  }
  .gallery-helper{
    margin:-4px 0 14px;
  }
  .gallery-helper p,
  .gallery-helper span{
    font-size:12px;
  }
  .gallery-grid{
    display:grid;
    grid-auto-flow:column;
    grid-auto-columns:84%;
    grid-template-columns:none;
    grid-auto-rows:auto;
    overflow-x:auto;
    overscroll-behavior-x:contain;
    scroll-snap-type:x mandatory;
    padding-bottom:6px;
    gap:12px;
    scrollbar-width:none;
  }
  .gallery-grid::-webkit-scrollbar{display:none}
  .gallery-main{grid-column:auto;grid-row:auto}
  .gallery-item{
    height:280px;
    scroll-snap-align:start;
    border-radius:18px;
  }
  .gallery-item span{
    opacity:1;
    transform:none;
    font-size:12px;
    left:12px;
    right:12px;
    bottom:12px;
  }
  .lightbox{
    padding:10px 10px 18px;
    align-content:end;
  }
  .lightbox-stage{
    width:100%;
  }
  .lightbox img{
    max-width:100%;
    max-height:60vh;
    border-radius:18px;
  }
  .lightbox [data-close]{
    width:42px;
    height:42px;
    font-size:26px;
    top:8px;
    right:8px;
  }
  .lightbox-nav{
    width:42px;
    height:42px;
    font-size:28px;
    top:auto;
    bottom:-54px;
    transform:none;
  }
  .lightbox-nav.prev{left:calc(50% - 52px)}
  .lightbox-nav.next{right:calc(50% - 52px)}
  .lightbox-meta{
    width:100%;
    margin-top:12px;
    padding:0 2px;
    gap:6px;
  }
  .lightbox-count{font-size:11px}
  .lightbox-caption{
    order:3;
    flex:1 1 100%;
    font-size:14px;
  }
  .lightbox-hint{
    font-size:11px;
  }
  .lightbox-thumbs{
    width:100%;
    grid-auto-columns:74px;
    gap:8px;
    padding-top:16px;
  }
  .lightbox-thumb img{height:56px}
  .hero-proof{
    grid-template-columns:1fr;
    gap:9px;
    max-width:350px;
  }
  .hero-proof > div{
    padding:12px 12px 10px;
    border-radius:16px;
  }
}


/* =========================================================
   V11 HERO + TEAM MOBILE ULTRA POLISH
   ========================================================= */

.site-header{
  backdrop-filter:saturate(1.1);
}
.site-header.is-scrolled{
  background:rgba(7,23,21,.74);
  backdrop-filter:blur(22px) saturate(1.15);
}
.brand img,
.brand-logo-full{
  image-rendering:auto;
}

.hero{
  min-height:760px;
}
.hero:before{
  content:"";
  position:absolute;
  inset:auto auto 168px -8%;
  width:420px;
  height:420px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(91,53,177,.24) 0%, rgba(91,53,177,.08) 35%, rgba(91,53,177,0) 72%);
  filter:blur(24px);
  pointer-events:none;
  z-index:1;
}
.hero:after{
  content:"";
  position:absolute;
  right:-40px;
  top:68px;
  width:300px;
  height:300px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(203,160,82,.20) 0%, rgba(203,160,82,.05) 38%, rgba(203,160,82,0) 72%);
  filter:blur(24px);
  pointer-events:none;
  z-index:1;
}
.hero-inner{
  max-width:760px;
}
.hero .eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:9px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  color:#90efaa;
  backdrop-filter:blur(10px);
  box-shadow:0 10px 30px rgba(0,0,0,.10);
}
.hero .eyebrow:before{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  background:#7bff9b;
  box-shadow:0 0 0 5px rgba(123,255,155,.14);
}
.hero h1{
  max-width:860px;
  text-wrap:balance;
  letter-spacing:-.052em;
  text-shadow:0 8px 40px rgba(0,0,0,.18);
}
.hero-copy{
  max-width:650px;
  font-size:clamp(17px,1.9vw,21px);
  color:rgba(255,255,255,.88);
}
.hero-cta .btn{
  min-height:52px;
  padding-inline:22px;
  border-radius:14px;
}
.hero-proof{
  max-width:780px;
  gap:14px;
}
.hero-proof > div{
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.06));
  border-color:rgba(255,255,255,.16);
  box-shadow:0 18px 42px rgba(0,0,0,.12), inset 0 1px 0 rgba(255,255,255,.10);
}
.hero-proof strong{
  font-size:13px;
  letter-spacing:.01em;
}
.hero-scroll{
  background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.18);
}
.stats-bar{
  background:linear-gradient(180deg, rgba(3,34,30,.88), rgba(3,28,25,.97));
}
.stats-bar div{
  position:relative;
}
.stats-bar div:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0));
  pointer-events:none;
}

.team-helper{
  display:flex;
  justify-content:space-between;
  gap:14px 24px;
  align-items:flex-end;
  margin:-10px 0 18px;
}
.team-helper p,
.team-helper span{
  margin:0;
}
.team-helper p{
  color:#5a6863;
  font-size:14px;
  line-height:1.5;
  max-width:620px;
}
.team-helper span{
  color:#1f4039;
  font-weight:800;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.team-grid{
  gap:18px;
}
.team-card{
  position:relative;
  border-radius:22px;
  overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.90));
  border:1px solid rgba(10,51,44,.10);
  box-shadow:0 18px 50px rgba(8,31,26,.07);
}
.team-card:before{
  content:"";
  position:absolute;
  left:0; right:0; top:0;
  height:4px;
  background:linear-gradient(90deg, rgba(91,53,177,.95), rgba(31,147,109,.92), rgba(203,160,82,.9));
  opacity:.88;
}
.team-card img{
  height:238px;
  object-position:center top;
  background:#edf3f1;
}
.team-card div{
  padding:16px 16px 18px;
}
.team-card h3{
  font-size:19px;
  letter-spacing:-.03em;
  margin-bottom:7px;
}
.team-card .role{
  display:inline-flex;
  align-items:center;
  padding:5px 10px;
  border-radius:999px;
  background:rgba(31,147,109,.08);
  font-size:12px;
  margin-bottom:10px;
}
.team-card p:not(.role){
  font-size:13px;
  line-height:1.58;
}
.team-card:hover{
  transform:translateY(-8px);
  box-shadow:0 26px 58px rgba(8,31,26,.12);
}

@media (max-width: 820px){
  .site-header{
    height:66px;
    padding-inline:14px;
    background:rgba(7,23,21,.78);
    backdrop-filter:blur(18px) saturate(1.12);
  }
  .site-header.is-scrolled{height:62px}
  .brand-logo{
    padding:6px 9px 5px;
    border-radius:13px;
    box-shadow:0 8px 24px rgba(0,0,0,.12), inset 0 1px 0 rgba(255,255,255,.7);
  }
  .brand-logo-full{
    height:31px;
  }
  .hero{
    min-height:760px;
    align-items:flex-start;
  }
  .hero-inner{
    padding-top:112px;
    padding-bottom:184px;
    max-width:100%;
  }
  .hero .eyebrow{
    font-size:10px;
    padding:8px 12px;
  }
  .hero h1{
    font-size:clamp(40px, 12.5vw, 56px);
    line-height:.92;
    max-width:330px;
    margin:16px 0 16px;
  }
  .hero-copy{
    font-size:15px;
    max-width:332px;
    margin-bottom:20px;
  }
  .hero-cta{
    display:grid;
    grid-template-columns:1fr;
    gap:10px;
    max-width:334px;
  }
  .hero-cta .btn{
    width:100%;
    min-height:50px;
    justify-content:center;
  }
  .hero-proof{
    max-width:334px;
    margin-top:14px;
    gap:10px;
  }
  .hero-proof > div{
    padding:12px 12px 11px;
    border-radius:17px;
  }
  .hero-proof strong{font-size:12px}
  .hero-proof small{font-size:10px}
  .hero-scroll{
    left:0;
    right:auto;
    bottom:114px;
    padding:9px 12px;
    font-size:10px;
  }
  .stats-bar{
    width:calc(100% - 20px);
    border-radius:22px 22px 0 0;
  }
  .stats-bar strong{font-size:25px}
  .stats-bar span{font-size:9px}

  .team-section .container{
    width:min(100% - 22px,var(--max));
  }
  .team-helper{
    margin:-8px 0 14px;
    display:block;
  }
  .team-helper p{
    font-size:13px;
    margin-bottom:8px;
  }
  .team-helper span{
    display:inline-flex;
    align-items:center;
    gap:8px;
    font-size:11px;
  }
  .team-helper span:before{
    content:"";
    width:26px;
    height:2px;
    background:linear-gradient(90deg, rgba(91,53,177,.9), rgba(31,147,109,.25));
  }
  .team-grid{
    display:grid;
    grid-auto-flow:column;
    grid-auto-columns:78%;
    grid-template-columns:none;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    overscroll-behavior-x:contain;
    gap:14px;
    padding-bottom:6px;
    scrollbar-width:none;
  }
  .team-grid::-webkit-scrollbar{display:none}
  .team-card{
    min-width:0;
    scroll-snap-align:start;
    border-radius:22px;
    box-shadow:0 18px 46px rgba(8,31,26,.09);
  }
  .team-card img{
    height:290px;
  }
  .team-card div{
    padding:14px 14px 16px;
  }
  .team-card h3{
    font-size:22px;
    line-height:1;
    margin-bottom:8px;
  }
  .team-card .role{
    font-size:12px;
    line-height:1.35;
    padding:6px 10px;
    margin-bottom:10px;
  }
  .team-card p:not(.role){
    display:block;
    font-size:13px;
    line-height:1.55;
  }
}

@media (max-width: 560px){
  .hero:before{
    width:300px;
    height:300px;
    left:-18%;
    bottom:210px;
  }
  .hero:after{
    width:220px;
    height:220px;
    right:-50px;
    top:52px;
  }
  .team-grid{
    grid-auto-columns:84%;
  }
  .team-card img{
    height:262px;
  }
}


/* =========================================================
   V12 MOBILE HERO REFINEMENT
   Cleaner spacing, less AI-looking chip, stronger mobile UX.
   ========================================================= */

@media (max-width: 820px){
  .container{
    width:min(100% - 34px, var(--max));
  }
  .site-header{
    height:74px;
    padding-inline:16px;
    background:linear-gradient(180deg, rgba(6,18,17,.88) 0%, rgba(6,18,17,.64) 65%, rgba(6,18,17,.28) 100%);
  }
  .site-header.is-scrolled{
    height:68px;
    background:rgba(6,18,17,.84);
  }
  .brand-logo{
    padding:6px 10px 5px;
    border-radius:16px;
    background:rgba(255,255,255,.96);
    box-shadow:0 10px 28px rgba(3,12,11,.16);
  }
  .brand-logo-full{
    height:26px;
    width:auto;
    display:block;
  }
  .brand-sub{
    font-size:6.5px;
    letter-spacing:.22em;
    margin-top:1px;
  }
  .whatsapp-float-mini,
  .menu-btn{
    height:44px;
    width:44px;
    border-radius:14px;
    backdrop-filter:blur(10px);
    box-shadow:0 10px 24px rgba(0,0,0,.12);
  }
  .whatsapp-float-mini{background:#25D366;border:1px solid rgba(255,255,255,.28)}
  .menu-btn{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22)}

  .hero{
    min-height:auto;
    padding-top:74px;
    padding-bottom:0;
    display:block;
  }
  .hero:before,
  .hero:after{
    filter:blur(38px);
    opacity:.9;
  }
  .hero-inner{
    padding-top:34px;
    padding-bottom:26px;
    padding-inline:2px;
    max-width:100%;
  }
  .hero .eyebrow{
    display:inline-flex;
    gap:7px;
    padding:0;
    border:0;
    background:transparent;
    box-shadow:none;
    backdrop-filter:none;
    color:#8af3a6;
    font-size:11px;
    font-weight:900;
    letter-spacing:.16em;
    text-transform:uppercase;
    line-height:1.35;
  }
  .hero .eyebrow:before{
    width:7px;
    height:7px;
    flex:0 0 7px;
    margin-top:3px;
    box-shadow:0 0 0 4px rgba(123,255,155,.18);
  }
  .hero h1{
    font-size:clamp(42px, 12vw, 54px);
    line-height:.92;
    letter-spacing:-.05em;
    max-width:320px;
    margin:14px 0 14px;
    text-shadow:0 8px 26px rgba(0,0,0,.18);
  }
  .hero-copy{
    max-width:310px;
    font-size:15px;
    line-height:1.65;
    color:rgba(255,255,255,.90);
    margin-bottom:18px;
  }
  .hero-cta{
    max-width:310px;
    gap:10px;
  }
  .hero-cta .btn{
    min-height:52px;
    padding-inline:18px;
    border-radius:14px;
    font-size:15px;
    font-weight:800;
  }
  .hero-cta .btn-primary{
    background:linear-gradient(135deg, #6437dd 0%, #7a54f2 100%);
    box-shadow:0 16px 34px rgba(79,53,177,.28);
  }
  .hero-cta .btn-wa{
    background:rgba(11,18,18,.64);
    border:1px solid rgba(255,255,255,.20);
    color:#fff;
    box-shadow:0 12px 28px rgba(0,0,0,.14);
  }
  .hero-cta .btn-wa .wa-svg{width:18px;height:18px;fill:#fff}

  .hero-proof{
    grid-template-columns:1fr;
    max-width:310px;
    gap:9px;
    margin-top:14px;
  }
  .hero-proof > div{
    padding:12px 14px 11px;
    border-radius:16px;
    background:linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.10));
    border:1px solid rgba(255,255,255,.16);
    box-shadow:0 12px 28px rgba(0,0,0,.10);
  }
  .hero-proof strong{
    font-size:12px;
    margin-bottom:3px;
  }
  .hero-proof small{
    font-size:10px;
  }
  .hero-scroll{display:none}

  .stats-bar{
    position:relative;
    left:auto;
    bottom:auto;
    transform:none;
    width:min(100% - 34px, var(--max));
    margin:10px auto 0;
    grid-template-columns:1fr 1fr;
    border-radius:18px;
    overflow:hidden;
    box-shadow:0 18px 42px rgba(0,0,0,.16);
  }
  .stats-bar div{
    padding:18px 10px 16px;
    min-height:88px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    border-right:1px solid rgba(255,255,255,.12);
    border-bottom:1px solid rgba(255,255,255,.12);
  }
  .stats-bar div:nth-child(2n){border-right:0}
  .stats-bar div:nth-last-child(-n+2){border-bottom:0}
  .stats-bar strong{
    font-size:24px;
    margin-bottom:6px;
  }
  .stats-bar span{
    font-size:10px;
    line-height:1.3;
  }

  #why.section{padding-top:52px}
  .section-heading p:not(.eyebrow){
    font-size:15px;
    line-height:1.6;
  }
}

@media (max-width: 560px){
  .container{width:min(100% - 32px, var(--max))}
  .hero-inner{padding-top:36px}
  .hero h1{max-width:300px;font-size:clamp(40px, 11.5vw, 50px)}
  .hero-copy,.hero-cta,.hero-proof{max-width:296px}
  .stats-bar{width:calc(100% - 32px)}
}
