:root{
  --bg:#070817;
  --card:#111327;
  --pink:#ff4fa3;
  --orange:#ff8a00;
  --green:#a6ff00;
  --text:#fff;
  --muted:#d5d7e2;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text)}
a{color:inherit}
.header{
  position:sticky;top:0;z-index:50;
  min-height:112px;padding:14px 6vw;
  display:flex;align-items:center;justify-content:space-between;gap:28px;
  background:rgba(5,6,18,.94);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.08)
}
.brand{display:flex;align-items:center;text-decoration:none}

.logo{
  width:420px;
  height:110px;
  object-fit:contain;
  border-radius:16px;
  display:block;
  filter:drop-shadow(0 8px 18px rgba(0,0,0,.55));
}
.menu{display:flex;gap:24px;font-weight:700}
.menu a{text-decoration:none;opacity:.9}
.menu a:hover{color:var(--pink)}
.top-btn,.btn{
  display:inline-block;text-decoration:none;color:#fff;font-weight:800;
  background:linear-gradient(90deg,var(--pink),var(--orange));
  border-radius:999px;padding:15px 24px;
  box-shadow:0 12px 28px rgba(255,79,163,.28)
}
.top-btn{padding:13px 20px;white-space:nowrap}
.hero{
  min-height:calc(100vh - 112px);
  display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;
  padding:70px 7vw;
  background:
    radial-gradient(circle at 12% 18%,rgba(255,79,163,.28),transparent 28%),
    radial-gradient(circle at 88% 25%,rgba(79,195,255,.18),transparent 30%),
    linear-gradient(135deg,#170016 0%,#08091b 48%,#0c2a45 100%);
}
.hero h1{font-size:clamp(3.4rem,7vw,6.7rem);line-height:.92;margin:22px 0}
.hero p{font-size:1.45rem;line-height:1.45;color:var(--muted);max-width:720px}
.pill{display:inline-block;background:var(--green);color:#111;font-weight:900;text-transform:uppercase;letter-spacing:.04em;border-radius:999px;padding:10px 16px;font-size:.84rem}
.buttons{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.btn.ghost{background:transparent;border:2px solid rgba(255,255,255,.35);box-shadow:none}
.btn.ghost.dark{color:#111;border-color:#222}
.info{margin-top:34px;display:grid;grid-template-columns:210px 1fr;gap:20px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:22px;color:#fff}
.hero-photo img{width:100%;height:650px;object-fit:cover;border-radius:34px;box-shadow:0 24px 80px rgba(0,0,0,.5),0 0 45px rgba(255,79,163,.25)}
.section{padding:82px 7vw;text-align:center}
.section h2,.promo h2{font-size:clamp(2.3rem,4.6vw,4.4rem);line-height:1;margin:18px 0 28px}
.section p,.promo p{font-size:1.18rem;color:#555}
.white{background:#fff;color:#111}
.cards{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:left}
.cards article{background:#fff;color:#111;border-radius:24px;padding:24px;font-weight:800;box-shadow:0 14px 34px rgba(0,0,0,.1);border:1px solid #eee}
.promo{margin:25px 7vw 70px;padding:44px;display:grid;grid-template-columns:1fr 420px;gap:36px;align-items:center;background:linear-gradient(135deg,#141426,#1a1a39);border-radius:36px;border:1px solid rgba(255,255,255,.1)}
.promo p{color:#d7d8e8}
.promo img{width:100%;border-radius:28px;box-shadow:0 18px 50px rgba(0,0,0,.4)}
.light{background:#f7f8fb;color:#111}
.gallery{max-width:1500px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.gallery img{width:100%;height:420px;object-fit:cover;border-radius:24px;box-shadow:0 14px 34px rgba(0,0,0,.13)}
.reviews,.contact{background:#fff;color:#111}
.whatsapp{position:fixed;right:24px;bottom:24px;width:70px;height:70px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#25d366;color:#fff;text-decoration:none;font-size:38px;z-index:100;box-shadow:0 12px 34px rgba(37,211,102,.45)}
footer{padding:34px 20px;text-align:center;background:#050512;color:#dfe2f2}
.center{justify-content:center}
@media(max-width:1100px){
 .header{min-height:auto;flex-wrap:wrap}.menu{display:none}.top-btn{display:none}
 .logo{width:300px;height:82px}
 .hero{grid-template-columns:1fr;padding:44px 24px}.hero-photo{order:-1}.hero-photo img{height:460px}
 .info{grid-template-columns:1fr}.cards{grid-template-columns:repeat(2,1fr)}
 .promo{grid-template-columns:1fr;margin:20px 24px 60px;padding:28px}.gallery{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
 .logo{width:245px;height:76px}.hero h1{font-size:3.1rem}.hero p{font-size:1.15rem}.cards,.gallery{grid-template-columns:1fr}.gallery img{height:430px}
}


.gallery-section{
    padding-bottom: 40px !important;
    margin-bottom: 0 !important;
}

footer{
    margin-top: 0 !important;
}

body{
    overflow-x:hidden;
}


.gallery-section{
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}

footer{
  display:none !important;
}

body, html{
  margin:0 !important;
  padding:0 !important;
  overflow-x:hidden;
  background:#efefef;
}

section:last-child{
  margin-bottom:0 !important;
  padding-bottom:20px !important;
}


/* Ajuste final da galeria para não sobrar buraco branco */
.gallery{
  max-width: 1500px !important;
  width: 92vw !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 22px !important;
}

.gallery img{
  width: 100% !important;
  height: 360px !important;
  object-fit: cover !important;
  border-radius: 22px !important;
}

.light{
  padding-left: 3vw !important;
  padding-right: 3vw !important;
}

@media(max-width: 1100px){
  .gallery{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    width: 94vw !important;
  }

  .gallery img{
    height: 360px !important;
  }
}

@media(max-width: 600px){
  .gallery{
    grid-template-columns: 1fr !important;
    width: 92vw !important;
  }

  .gallery img{
    height: 430px !important;
  }
}
