:root{
  --bg:#080b12;
  --bg-2:#101827;
  --panel:#ffffff;
  --panel-2:#f4f7fb;
  --text:#111827;
  --muted:#5f6878;
  --light:#ffffff;
  --light-muted:#d7deeb;
  --line:rgba(15,23,42,.12);
  --brand:#1d8cff;
  --brand-2:#27d17f;
  --warm:#f6b94b;
  --danger:#ff6a3d;
  --shadow:0 24px 70px rgba(2,8,23,.20);
  --radius:28px;
  --radius-sm:18px;
  --container:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{width:100%;max-width:100%;overflow-x:hidden}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--text);
  background:#fff;
  line-height:1.55;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button,select,input,textarea{font:inherit}
.container{width:min(var(--container), calc(100% - 40px)); margin-inline:auto}
.section{padding:92px 0}
.section-tight{padding:58px 0}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  border:1px solid rgba(29,140,255,.26);
  background:rgba(29,140,255,.08);
  color:#0d68c4;
  padding:.5rem .8rem;
  border-radius:999px;
  font-weight:750;
  letter-spacing:.015em;
  font-size:.88rem;
}
.eyebrow.dark{
  color:#cde5ff;
  background:rgba(255,255,255,.09);
  border-color:rgba(255,255,255,.16);
}
h1,h2,h3{line-height:1.06;margin:0}
h1{font-size:clamp(2.65rem, 7vw, 6.2rem);letter-spacing:-.065em}
h2{font-size:clamp(2.1rem, 4vw, 4rem);letter-spacing:-.045em}
h3{font-size:1.25rem;letter-spacing:-.02em}
p{margin:0}
.lead{font-size:clamp(1.05rem, 2vw, 1.33rem); color:var(--muted)}
.lead.light{color:var(--light-muted)}
.site-header{
  position:fixed;
  inset:18px 0 auto 0;
  z-index:50;
  pointer-events:none;
}
body.menu-open{overflow:hidden}
.header-shell{
  width:min(var(--container), calc(100% - 28px));
  margin:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  background:rgba(8,11,18,.75);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 18px 50px rgba(2,8,23,.28);
  backdrop-filter:blur(18px);
  border-radius:999px;
  padding:10px 12px;
  pointer-events:auto;
  position:relative;
}
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  color:#fff;
  min-width:0;
  font-weight:850;
  letter-spacing:-.03em;
}
.brand img{
  width:42px;
  height:42px;
  object-fit:contain;
  border-radius:50%;
  background:#fff;
  padding:3px;
}
.brand span{white-space:nowrap}
.nav{
  display:flex;
  align-items:center;
  gap:4px;
}
.nav a{
  color:rgba(255,255,255,.82);
  font-weight:700;
  font-size:.94rem;
  padding:11px 13px;
  border-radius:999px;
  transition:.2s ease;
}
.nav a:hover{background:rgba(255,255,255,.11); color:#fff}
.header-actions{
  display:flex;
  align-items:center;
  gap:8px;
}
.lang-select{
  display:flex;
  align-items:center;
  gap:8px;
  color:#fff;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px;
  padding:6px 9px 6px 12px;
}
.lang-select select{
  color:#fff;
  background:transparent;
  border:0;
  outline:0;
  font-weight:800;
  cursor:pointer;
}
.lang-select option{color:#111827;background:#fff}
.menu-toggle{display:none}
.cta-small{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  color:#08111f;
  background:#fff;
  padding:11px 16px;
  border-radius:999px;
  font-weight:850;
  box-shadow:0 10px 24px rgba(255,255,255,.12);
}
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:flex-end;
  overflow:hidden;
  background:var(--bg);
  color:#fff;
  isolation:isolate;
}
.hero-media{
  position:absolute;
  inset:0;
  z-index:-2;
}
.hero-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:saturate(1.08) contrast(1.02);
}
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:
    radial-gradient(circle at 72% 12%, rgba(29,140,255,.28), transparent 32%),
    linear-gradient(90deg, rgba(3,7,18,.93) 0%, rgba(3,7,18,.72) 40%, rgba(3,7,18,.22) 72%, rgba(3,7,18,.6) 100%),
    linear-gradient(0deg, rgba(3,7,18,.86) 0%, transparent 55%);
}
.hero-inner{
  width:min(var(--container), calc(100% - 40px));
  margin:0 auto;
  padding:154px 0 78px;
}
.hero-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.05fr) 410px;
  gap:44px;
  align-items:end;
}
.hero-copy{
  display:flex;
  flex-direction:column;
  gap:24px;
}
.hero h1 strong{
  color:transparent;
  background:linear-gradient(120deg, #73c5ff 0%, #f8c45d 58%, #35e390 100%);
  -webkit-background-clip:text;
  background-clip:text;
}
.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:6px;
}
.btn{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  gap:.65rem;
  border:0;
  border-radius:999px;
  padding:15px 22px;
  font-weight:850;
  cursor:pointer;
  transition:.2s ease;
}
.btn.primary{
  color:#07101f;
  background:linear-gradient(135deg, #fff 0%, #d7ebff 100%);
  box-shadow:0 20px 50px rgba(29,140,255,.24);
}
.btn.secondary{
  color:#fff;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);
}
.btn.whatsapp{
  color:#062314;
  background:linear-gradient(135deg, #45ea8a, #c8ffd9);
}
.btn:hover{transform:translateY(-2px)}
.hero-card{
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.16);
  border-radius:var(--radius);
  padding:24px;
  backdrop-filter:blur(18px);
  box-shadow:0 24px 75px rgba(0,0,0,.24);
}
.hero-card img{
  width:96px;
  border-radius:18px;
  background:#fff;
  padding:6px;
  margin-bottom:20px;
}
.hero-card dl{
  margin:20px 0 0;
  display:grid;
  gap:14px;
}
.hero-card div{
  display:flex;
  justify-content:space-between;
  gap:16px;
  border-top:1px solid rgba(255,255,255,.12);
  padding-top:13px;
}
.hero-card dt{color:var(--light-muted);font-size:.88rem}
.hero-card dd{margin:0;font-weight:850;text-align:right}
.stats{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
  margin-top:30px;
}
.stat{
  padding:18px;
  border-radius:20px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
}
.stat b{display:block;font-size:1.55rem;letter-spacing:-.04em}
.stat span{color:var(--light-muted);font-size:.9rem}
.trustbar{
  background:#fff;
  border-bottom:1px solid var(--line);
}
.trustbar-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1px;
  background:var(--line);
  border-inline:1px solid var(--line);
}
.trust-item{
  background:#fff;
  padding:24px;
}
.trust-item strong{display:block;font-size:1rem}
.trust-item span{display:block;color:var(--muted);font-size:.94rem;margin-top:4px}
.section-head{
  display:grid;
  grid-template-columns:minmax(0, .9fr) minmax(280px, .55fr);
  gap:40px;
  align-items:end;
  margin-bottom:42px;
}
.section-head .lead{max-width:650px}
.service-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:20px;
}
.service-card{
  position:relative;
  padding:30px;
  min-height:310px;
  border-radius:var(--radius);
  background:linear-gradient(180deg, #fff 0%, #f6f8fc 100%);
  border:1px solid var(--line);
  box-shadow:0 18px 55px rgba(15,23,42,.07);
  overflow:hidden;
}
.service-card::before{
  content:"";
  position:absolute;
  inset:auto -30px -90px auto;
  width:180px;
  height:180px;
  background:radial-gradient(circle, rgba(29,140,255,.16), transparent 68%);
}
.service-icon{
  width:58px;
  height:58px;
  display:grid;
  place-items:center;
  border-radius:20px;
  background:#0b1220;
  color:#fff;
  font-size:1.6rem;
  margin-bottom:24px;
}
.service-card:nth-child(2) .service-icon{background:linear-gradient(135deg, #f6b94b, #ff6a3d)}
.service-card:nth-child(3) .service-icon{background:linear-gradient(135deg, #1d8cff, #27d17f)}
.service-card p{color:var(--muted); margin-top:14px}
.service-list{
  padding:0;
  margin:22px 0 0;
  list-style:none;
  display:grid;
  gap:9px;
}
.service-list li{
  color:#263041;
  font-weight:650;
}
.service-list li::before{
  content:"✓";
  color:var(--brand-2);
  margin-right:9px;
  font-weight:900;
}
.dark-band{
  background:
    radial-gradient(circle at 82% 20%, rgba(29,140,255,.20), transparent 35%),
    radial-gradient(circle at 18% 82%, rgba(246,185,75,.14), transparent 32%),
    var(--bg);
  color:#fff;
}
.split{
  display:grid;
  grid-template-columns:minmax(0, .85fr) minmax(0, 1fr);
  gap:48px;
  align-items:center;
}
.image-stack{
  position:relative;
}
.image-stack .main-img{
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
  border:1px solid rgba(255,255,255,.12);
}
.image-stack .main-img img{
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
}
.image-stack .mini-card{
  position:absolute;
  right:-18px;
  bottom:28px;
  width:min(300px, 58%);
  background:#fff;
  color:#111827;
  border-radius:24px;
  padding:18px;
  box-shadow:0 22px 60px rgba(0,0,0,.28);
}
.mini-card strong{display:block;font-size:1.05rem}
.mini-card span{display:block;color:var(--muted);font-size:.9rem;margin-top:4px}
.bullet-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:14px;
  margin-top:28px;
}
.bullet{
  padding:18px;
  border:1px solid rgba(255,255,255,.13);
  background:rgba(255,255,255,.07);
  border-radius:20px;
}
.bullet strong{display:block}
.bullet span{color:var(--light-muted);font-size:.95rem}
.process-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:16px;
}
.step{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:22px;
  box-shadow:0 12px 42px rgba(15,23,42,.06);
}
.step-num{
  width:38px;
  height:38px;
  border-radius:13px;
  display:grid;
  place-items:center;
  background:#0b1220;
  color:#fff;
  font-weight:900;
  margin-bottom:20px;
}
.step p{color:var(--muted);font-size:.95rem;margin-top:10px}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:16px;
}
.gallery-card{
  position:relative;
  border:0;
  padding:0;
  border-radius:22px;
  overflow:hidden;
  background:#0b1220;
  color:#fff;
  cursor:pointer;
  min-height:270px;
  box-shadow:0 16px 44px rgba(15,23,42,.12);
}
.gallery-card img{
  width:100%;
  height:100%;
  min-height:270px;
  object-fit:cover;
  transition:transform .35s ease, opacity .35s ease;
}
.gallery-card:hover img{transform:scale(1.04);opacity:.82}
.gallery-caption{
  position:absolute;
  inset:auto 0 0 0;
  padding:38px 16px 16px;
  background:linear-gradient(0deg, rgba(4,8,18,.86), transparent);
  text-align:left;
  font-weight:850;
}
.cta-panel{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 360px;
  gap:32px;
  align-items:center;
  padding:42px;
  border-radius:var(--radius);
  background:
    radial-gradient(circle at 80% 10%, rgba(39,209,127,.22), transparent 28%),
    linear-gradient(135deg, #0b1220, #12243a);
  color:#fff;
  box-shadow:var(--shadow);
}
.cta-panel p{color:var(--light-muted);margin-top:14px}
.contact-card{
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.16);
  border-radius:24px;
  padding:22px;
  display:grid;
  gap:12px;
}
.contact-line{
  display:flex;
  gap:12px;
  align-items:flex-start;
  color:#fff;
}
.contact-line span{color:#a9b5c9;min-width:24px}
.legal-teaser{
  background:#f6f8fc;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.notice{
  border-radius:24px;
  border:1px solid rgba(29,140,255,.2);
  background:#fff;
  box-shadow:0 12px 35px rgba(15,23,42,.06);
  padding:24px;
  display:flex;
  gap:18px;
  align-items:flex-start;
}
.notice .icon{
  width:42px;
  height:42px;
  border-radius:15px;
  display:grid;
  place-items:center;
  background:#e7f3ff;
  color:#106bc5;
  flex:0 0 auto;
}
.notice p{color:var(--muted)}
.site-footer{
  background:#060912;
  color:#fff;
  padding:54px 0 28px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:30px;
}
.footer-logo{
  display:flex;
  align-items:center;
  gap:12px;
  font-weight:900;
  font-size:1.2rem;
}
.footer-logo img{width:48px;height:48px;border-radius:50%;background:#fff;padding:3px}
.site-footer p, .site-footer a, .site-footer li{color:#bbc6d8}
.site-footer ul{margin:14px 0 0;padding:0;list-style:none;display:grid;gap:8px}
.footer-bottom{
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:16px;
  border-top:1px solid rgba(255,255,255,.12);
  margin-top:34px;
  padding-top:22px;
  color:#8490a5;
  font-size:.92rem;
}
.legal-hero{
  padding:154px 0 70px;
  background:
    radial-gradient(circle at 80% 20%, rgba(29,140,255,.18), transparent 34%),
    linear-gradient(135deg, #07101f, #111827);
  color:#fff;
}
.legal-hero p{color:var(--light-muted);max-width:760px;margin-top:18px}
.legal-content{
  padding:66px 0 86px;
}
.legal-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:0 18px 50px rgba(15,23,42,.08);
  padding:42px;
}
.legal-card h2{
  font-size:1.65rem;
  letter-spacing:-.025em;
  margin:34px 0 12px;
}
.legal-card h2:first-child{margin-top:0}
.legal-card p{color:#3d4656;margin-bottom:14px}
.legal-card ul{margin:0 0 16px 1.2rem;color:#3d4656}
.legal-card li{margin:7px 0}
.info-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:20px;
  margin:18px 0 26px;
}
.info-table th,.info-table td{
  padding:16px;
  border-bottom:1px solid var(--line);
  text-align:left;
  vertical-align:top;
}
.info-table tr:last-child th,.info-table tr:last-child td{border-bottom:0}
.info-table th{width:220px;background:#f7f9fc;color:#263041}
.lightbox{
  position:fixed;
  inset:0;
  z-index:100;
  display:none;
  place-items:center;
  background:rgba(2,6,15,.86);
  padding:24px;
}
.lightbox.is-open{display:grid}
.lightbox-content{
  width:min(1100px,100%);
  max-height:90vh;
  display:grid;
  gap:12px;
}
.lightbox img{
  max-height:78vh;
  width:100%;
  object-fit:contain;
  border-radius:22px;
  box-shadow:var(--shadow);
}
.lightbox-caption{
  color:#fff;
  font-weight:850;
  text-align:center;
}
.lightbox-close{
  position:absolute;
  right:22px;
  top:22px;
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.1);
  color:#fff;
  font-size:1.5rem;
  cursor:pointer;
}
.floating-whatsapp{
  position:fixed;
  right:20px;
  bottom:20px;
  z-index:45;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:62px;
  height:62px;
  border-radius:50%;
  background:#25d366;
  color:#062314;
  box-shadow:0 16px 42px rgba(37,211,102,.38);
  font-size:1.65rem;
}
@media (max-width:1020px){
  .nav{display:none}
  .menu-toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:42px;
    height:42px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.16);
    background:rgba(255,255,255,.1);
    color:#fff;
    cursor:pointer;
  }
  .header-actions{margin-left:auto}
  .nav.is-open{
    display:grid;
    position:absolute;
    left:0;
    right:0;
    top:calc(100% + 10px);
    z-index:80;
    max-height:calc(100vh - 96px);
    overflow-y:auto;
    pointer-events:auto;
    background:#080b12;
    border:1px solid rgba(255,255,255,.14);
    border-radius:24px;
    padding:10px;
    box-shadow:0 24px 60px rgba(0,0,0,.28);
  }
  .nav.is-open a{display:block}
  .cta-small{display:none}
  .hero-grid,.split,.cta-panel,.section-head{grid-template-columns:1fr}
  .hero-card{max-width:520px}
  .trustbar-grid,.process-grid{grid-template-columns:repeat(2,1fr)}
  .service-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2, 1fr)}
  .footer-grid{grid-template-columns:1fr}
}
@media (max-width:640px){
  .container{width:min(100% - 28px, var(--container))}
  .site-header{inset:8px 0 auto}
  .header-shell{width:calc(100% - 16px);border-radius:22px;padding:7px;gap:7px}
  .brand{gap:8px;min-width:0;max-width:140px}
  .brand img{width:34px;height:34px;flex:0 0 auto}
  .brand span{display:inline;font-size:.98rem;letter-spacing:-.02em;overflow:hidden;text-overflow:ellipsis}
  .header-actions{margin-left:auto;gap:6px}
  .lang-select{padding:7px 8px;gap:0}
  .lang-select span{display:none}
  .lang-select select{font-size:.93rem;min-width:42px}
  .menu-toggle{width:38px;height:38px;flex:0 0 auto}
  .nav.is-open{left:0;right:0;top:calc(100% + 8px);border-radius:20px}
  .nav.is-open a{padding:14px 16px;font-size:1rem}
  .hero-inner{width:calc(100% - 28px);padding:118px 0 48px}
  .hero-grid{gap:22px}
  .hero-copy{gap:18px}
  .hero-actions{flex-direction:column}
  .btn{width:100%;padding:14px 18px}
  .stats,.trustbar-grid,.bullet-grid,.process-grid,.gallery-grid{grid-template-columns:1fr}
  .stat{padding:15px}
  .service-card{min-height:auto;padding:24px}
  .image-stack .mini-card{right:10px;bottom:18px;width:min(290px,72%)}
  .gallery-card,.gallery-card img{min-height:230px}
  .section{padding:62px 0}
  .section-tight{padding:46px 0}
  .legal-card{padding:22px;border-radius:22px}
  .info-table{display:block;overflow:hidden}
  .info-table tbody,.info-table tr,.info-table th,.info-table td{display:block;width:100%}
  .info-table th{border-bottom:0;padding-bottom:4px}
  .cta-panel{padding:24px;gap:22px}
  h1{font-size:clamp(2.25rem, 12vw, 3.65rem);line-height:1.02;overflow-wrap:break-word}
  h2{overflow-wrap:break-word}
  .hero-card{padding:20px}
  .hero-card div{display:grid;gap:4px}
  .hero-card dd{text-align:left}
  .footer-bottom{display:grid;gap:10px}
  .floating-whatsapp{width:56px;height:56px;right:14px;bottom:14px}
}
@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto!important;transition:none!important}
}
/* ==========================================================
   Mobile fix v4 – stable header/menu for Android/iPhone
   ========================================================== */
@media (max-width: 1020px){
  .site-header{
    inset: 0 0 auto 0 !important;
    padding: 10px 8px 0 !important;
    z-index: 200 !important;
    pointer-events: none !important;
  }
  .header-shell{
    width: 100% !important;
    max-width: 100% !important;
    min-height: 58px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    border-radius: 22px !important;
    padding: 8px !important;
    background: rgba(8,11,18,.96) !important;
    border: 1px solid rgba(255,255,255,.16) !important;
    box-shadow: 0 18px 50px rgba(0,0,0,.35) !important;
    position: relative !important;
    z-index: 210 !important;
    pointer-events: auto !important;
  }
  .brand{
    order: 1 !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    max-width: none !important;
    color: #fff !important;
  }
  .brand img{
    width: 40px !important;
    height: 40px !important;
    flex: 0 0 auto !important;
  }
  .brand span{
    display: inline-block !important;
    max-width: 130px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    color: #fff !important;
  }
  .header-actions{
    order: 2 !important;
    flex: 0 0 auto !important;
    margin-left: auto !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
  }
  .lang-select{
    min-height: 40px !important;
    padding: 6px 8px !important;
    border-radius: 999px !important;
    background: rgba(255,255,255,.12) !important;
    border: 1px solid rgba(255,255,255,.20) !important;
    color: #fff !important;
  }
  .lang-select span{display:none !important;}
  .lang-select select{
    min-width: 44px !important;
    color:#fff !important;
    background: transparent !important;
    font-weight: 900 !important;
  }
  .cta-small{display:none !important;}
  .menu-toggle{
    order: 3 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 0 42px !important;
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    min-height: 42px !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 50% !important;
    border: 1px solid rgba(255,255,255,.22) !important;
    background: rgba(255,255,255,.12) !important;
    color: #fff !important;
    cursor: pointer !important;
    line-height: 1 !important;
    font-size: 0 !important;
    z-index: 230 !important;
    -webkit-tap-highlight-color: transparent !important;
  }
  .menu-toggle::before{
    content: "☰";
    display: block;
    color: #fff;
    font-size: 24px;
    font-weight: 800;
    line-height: 1;
    transform: translateY(-1px);
  }
  .menu-toggle[aria-expanded="true"]::before{
    content: "×";
    font-size: 32px;
    font-weight: 400;
    transform: translateY(-2px);
  }
  .nav{
    display: none !important;
  }
  .nav.is-open{
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    position: fixed !important;
    top: 78px !important;
    left: 8px !important;
    right: 8px !important;
    width: auto !important;
    max-height: calc(100dvh - 92px) !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 14px !important;
    z-index: 220 !important;
    pointer-events: auto !important;
    background: #08111f !important;
    border: 1px solid rgba(255,255,255,.18) !important;
    border-radius: 22px !important;
    box-shadow: 0 24px 80px rgba(0,0,0,.55) !important;
  }
  .nav.is-open a{
    display: block !important;
    width: 100% !important;
    color: #fff !important;
    background: rgba(255,255,255,.08) !important;
    border: 1px solid rgba(255,255,255,.13) !important;
    border-radius: 16px !important;
    padding: 15px 16px !important;
    font-size: 1rem !important;
    font-weight: 850 !important;
    line-height: 1.25 !important;
  }
  .nav.is-open a:hover,
  .nav.is-open a:focus-visible{
    background: rgba(29,140,255,.22) !important;
    color: #fff !important;
    outline: none !important;
  }
  body.menu-open{
    overflow: hidden !important;
  }
  body.menu-open::before{
    content: "";
    position: fixed;
    inset: 0;
    z-index: 190;
    background: rgba(3,7,18,.56);
    backdrop-filter: blur(2px);
  }
  .hero-inner{
    padding-top: 128px !important;
  }
  .legal-hero{
    padding-top: 128px !important;
  }
}

@media (max-width: 640px){
  .site-header{
    padding: 8px 8px 0 !important;
  }
  .header-shell{
    min-height: 56px !important;
    border-radius: 20px !important;
    gap: 6px !important;
    padding: 7px !important;
  }
  .brand img{
    width: 38px !important;
    height: 38px !important;
  }
  .brand span{
    max-width: 110px !important;
    font-size: 1rem !important;
  }
  .menu-toggle{
    flex-basis: 40px !important;
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    min-height: 40px !important;
  }
  .nav.is-open{
    top: 72px !important;
    left: 8px !important;
    right: 8px !important;
    max-height: calc(100dvh - 86px) !important;
    border-radius: 20px !important;
  }
  .hero{
    min-height: 100svh !important;
  }
  .hero-media img{
    object-position: center top !important;
  }
  .hero::after{
    background:
      radial-gradient(circle at 82% 10%, rgba(29,140,255,.22), transparent 32%),
      linear-gradient(90deg, rgba(3,7,18,.90) 0%, rgba(3,7,18,.72) 48%, rgba(3,7,18,.36) 100%),
      linear-gradient(0deg, rgba(3,7,18,.88) 0%, rgba(3,7,18,.30) 64%, rgba(3,7,18,.65) 100%) !important;
  }
  .hero-inner{
    padding-top: 108px !important;
  }
  .legal-hero{
    padding-top: 108px !important;
  }
}
