/* ============================================================
   PROMO AREIA VERMELHA — Landing Page CSS
   Arquivo independente. NÃO altera nenhum CSS existente.
   ============================================================ */

/* ---------- Reset & Tokens ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --p-bg:#fff;
  --p-bg2:#0a1128;
  --p-card:rgba(255,255,255,.04);
  --p-card-border:rgba(255,255,255,.08);
  --p-txt:#000;
  --p-muted:#0f172a;
  --p-accent:#f0c419;
  --p-accent2:#facc15;
  --p-accent-glow:rgba(240,196,25,.25);
  --p-radius:20px;
  --p-font:'Inter',ui-sans-serif,system-ui,-apple-system,sans-serif;
  --p-serif:'Playfair Display',Georgia,serif;
}

html{scroll-behavior:smooth}

body{
  font-family:var(--p-font);
  color:var(--p-txt);
  background:#fff;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

.promo-container{max-width:1180px;margin:0 auto;padding:0 24px}
.accent{color:var(--p-accent)}

/* ---------- Navbar ---------- */
.promo-nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:16px 0;
  transition:all .35s ease;
}
.promo-nav.scrolled{
  background:rgba(255,255,255,.78);
  backdrop-filter:blur(20px) saturate(1.8);
  border-bottom:1px solid rgba(15,23,42,.12);
  padding:10px 0;
}
.promo-nav__inner{
  max-width:1180px;margin:0 auto;padding:0 24px;
  display:flex;align-items:center;justify-content:space-between;
}
.promo-nav__brand{
  display:flex;align-items:center;gap:10px;
  font-weight:800;font-size:18px;
  color:var(--p-txt);text-decoration:none;
}
.promo-nav__icon{font-size:22px}
.promo-nav__links{display:flex;align-items:center;gap:28px}
.promo-nav__links a{
  color:var(--p-muted);text-decoration:none;font-size:14px;font-weight:500;
  transition:color .25s;
}
.promo-nav__links a:hover{color:var(--p-txt)}
.promo-nav__cta{
  background:linear-gradient(135deg,var(--p-accent),#e6a817) !important;
  color:#111 !important;font-weight:700 !important;
  padding:10px 22px !important;border-radius:999px;
  transition:transform .2s, box-shadow .2s;
}
.promo-nav__cta:hover{transform:scale(1.04);box-shadow:0 8px 30px var(--p-accent-glow)}

.promo-nav__toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.promo-nav__toggle span{display:block;width:24px;height:2px;background:var(--p-txt);border-radius:2px;transition:all .3s}
.promo-nav__toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.promo-nav__toggle.active span:nth-child(2){opacity:0}
.promo-nav__toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ---------- Hero ---------- */
.promo-hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  background:#0b79bd;
}
.promo-hero__bg{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  object-position:center 58%;
  transform:none;
  animation:none;
}
@keyframes heroZoom{0%{transform:scale(1.08) translate(0,0)} 100%{transform:scale(1.15) translate(-1%,-1%)}}

.promo-hero__overlay{
  /* visibility controlled by page; default subtle for contrast */
}
.promo-hero__content{
  /* controlled by page overrides for current hero design (badge top, button bottom) */
}
.promo-hero__badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 20px;border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(12px);
  font-size:13px;font-weight:600;color:var(--p-txt);
  margin-bottom:8px;
  animation:fadeUp .8s ease both;
}
/* title removed per request */
.promo-hero__highlight{
  background:linear-gradient(135deg,var(--p-accent),#ff8a00);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.promo-hero__actions{
  display:flex;gap:14px;justify-content:center;flex-wrap:wrap;
  margin-top:0;
  animation:fadeUp .8s ease .45s both;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)}}

/* ---------- Buttons ---------- */
.promo-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 30px;border-radius:999px;
  font-weight:700;font-size:15px;text-decoration:none;
  transition:all .3s ease;cursor:pointer;border:none;
}
.promo-btn--primary{
  background:linear-gradient(135deg,var(--p-accent),#e6a817);
  color:#111;
  box-shadow:0 12px 40px var(--p-accent-glow);
}
.promo-btn--primary:hover{transform:translateY(-2px);box-shadow:0 18px 50px rgba(240,196,25,.35)}
.promo-btn--ghost{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.15);
  color:var(--p-txt);backdrop-filter:blur(8px);
}
.promo-btn--ghost:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.25)}
.promo-btn--whatsapp{
  background:linear-gradient(135deg,#25d366,#128c7e);
  color:#fff;
  box-shadow:0 12px 40px rgba(37,211,102,.2);
}
.promo-btn--whatsapp:hover{transform:translateY(-2px);box-shadow:0 18px 50px rgba(37,211,102,.3)}
.promo-btn--large{padding:18px 40px;font-size:17px}

/* ---------- Sections ---------- */
.promo-section{padding:100px 0;position:relative}
.promo-section--dark{
  background:
    radial-gradient(800px at 20% 50%, rgba(240,196,25,.04), transparent),
    radial-gradient(600px at 80% 30%, rgba(59,130,246,.04), transparent),
    linear-gradient(180deg,rgba(255,255,255,.01),var(--p-bg));
}
.promo-section__header{text-align:center;max-width:640px;margin:0 auto 56px}
.promo-label{
  display:inline-block;
  font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  color:var(--p-accent);margin-bottom:12px;
}
.promo-heading{
  font-family:var(--p-serif);
  font-size:clamp(28px,4vw,48px);
  font-weight:800;line-height:1.2;margin-bottom:16px;
}
.promo-heading__sub{font-size:16px;color:var(--p-muted);line-height:1.7}

/* ---------- About ---------- */
.promo-about{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
.promo-about__text{opacity:0;transform:translateX(-30px);transition:all .7s ease}
.promo-about__text.visible{opacity:1;transform:translateX(0)}
.promo-about__text p{color:var(--p-muted);font-size:16px;margin-bottom:16px;line-height:1.8}
.promo-about__highlights{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.promo-chip{
  padding:8px 16px;border-radius:999px;font-size:13px;font-weight:600;
  background:rgba(240,196,25,.08);
  border:1px solid rgba(240,196,25,.18);
  color:var(--p-accent2);
  transition:all .25s;
}
.promo-chip:hover{background:rgba(240,196,25,.15);transform:translateY(-2px)}
.promo-about__image{
  position:relative;
  opacity:0;transform:translateX(30px);transition:all .7s ease .15s;
}
.promo-about__image.visible{opacity:1;transform:translateX(0)}
.promo-about__image img{
  width:100%;border-radius:var(--p-radius);
  box-shadow:0 30px 80px rgba(0,0,0,.5);
}
.promo-about__float{
  position:absolute;bottom:-16px;right:-16px;
  background:linear-gradient(135deg,var(--p-accent),#e6a817);
  color:#111;padding:16px 22px;border-radius:16px;
  display:flex;flex-direction:column;align-items:center;
  box-shadow:0 12px 40px var(--p-accent-glow);
}
.promo-about__float strong{font-size:26px;font-weight:900;line-height:1}
.promo-about__float span{font-size:12px;font-weight:600;opacity:.8}

/* ---------- Gallery ---------- */
.promo-gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:auto auto;
  gap:16px;
}
.promo-gallery__item{
  position:relative;overflow:hidden;border-radius:var(--p-radius);
  opacity:0;transform:translateY(30px);transition:all .6s ease;
}
.promo-gallery__item.visible{opacity:1;transform:translateY(0)}
.promo-gallery__item--large{grid-column:span 2;grid-row:span 2}
.promo-gallery__item img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .5s ease;min-height:220px;
}
.promo-gallery__item:hover img{transform:scale(1.06)}
.promo-gallery__caption{
  position:absolute;bottom:0;left:0;right:0;
  padding:16px 20px;
  background:linear-gradient(transparent,rgba(0,0,0,.7));
  font-size:14px;font-weight:600;color:#fff;
  transform:translateY(100%);transition:transform .35s ease;
}
.promo-gallery__item:hover .promo-gallery__caption{transform:translateY(0)}

/* ---------- Features ---------- */
.promo-features{
  display:grid;grid-template-columns:repeat(3,1fr);gap:30px;
}
.promo-feature{
  background:#fff;
  border:1px solid rgba(240,196,25,.22);
  border-top:4px solid var(--p-accent);
  border-radius:22px;
  padding:50px 42px 44px;
  min-height:310px;
  text-align:center;
  opacity:0;transform:translateY(24px);transition:all .5s ease;
  position:relative;overflow:hidden;
  box-shadow:0 26px 70px rgba(15,23,42,.12);
}
.promo-feature.visible{opacity:1;transform:translateY(0)}
.promo-feature::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--p-accent),rgba(250,204,21,.25),transparent);
  opacity:1;transition:opacity .3s;
}
.promo-feature:hover::before{opacity:1}
.promo-feature:hover{
  border-color:rgba(240,196,25,.38);
  transform:translateY(-4px);
  box-shadow:0 32px 82px rgba(15,23,42,.16);
}
.promo-feature__icon{font-size:42px;margin-bottom:24px;display:block}
.promo-feature h3{font-size:24px;font-weight:900;margin-bottom:14px;color:#000}
.promo-feature p{font-size:18px;color:#0f172a;line-height:1.55}

/* ---------- Testimonials ---------- */
.promo-testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.promo-testimonial{
  background:var(--p-card);
  border:1px solid var(--p-card-border);
  border-radius:var(--p-radius);padding:28px 24px;
  opacity:0;transform:translateY(24px);transition:all .5s ease;
}
.promo-testimonial.visible{opacity:1;transform:translateY(0)}
.promo-testimonial:hover{border-color:rgba(240,196,25,.2);transform:translateY(-4px)}
.promo-testimonial__stars{color:var(--p-accent);font-size:18px;margin-bottom:14px;letter-spacing:2px}
.promo-testimonial p{font-size:15px;color:var(--p-muted);line-height:1.7;margin-bottom:20px;font-style:italic}
.promo-testimonial__author{display:flex;flex-direction:column;gap:2px}
.promo-testimonial__author strong{font-size:15px;color:var(--p-txt)}
.promo-testimonial__author span{font-size:12px;color:var(--p-muted)}

/* ---------- CTA ---------- */
.promo-cta{
  position:relative;padding:120px 0;overflow:hidden;text-align:center;
}
.promo-cta__bg{position:absolute;inset:0}
.promo-cta__bg img{width:100%;height:100%;object-fit:cover}
.promo-cta__overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, var(--p-bg) 0%, rgba(3,7,18,.8) 30%, rgba(3,7,18,.85) 70%, var(--p-bg) 100%),
    radial-gradient(ellipse at center, rgba(240,196,25,.1), transparent 60%);
}
.promo-cta__content{position:relative;z-index:2}
.promo-cta__content h2{
  font-family:var(--p-serif);
  font-size:clamp(28px,4vw,48px);
  font-weight:800;margin-bottom:16px;
}
.promo-cta__content p{font-size:18px;color:var(--p-muted);margin-bottom:36px;max-width:540px;margin-left:auto;margin-right:auto}
.promo-cta__buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:32px}
.promo-cta__trust{display:flex;gap:24px;justify-content:center;flex-wrap:wrap}
.promo-cta__trust span{font-size:13px;color:var(--p-muted);font-weight:500}

/* ---------- Footer ---------- */
.promo-footer{
  padding:40px 0;
  border-top:1px solid rgba(255,255,255,.06);
  background:rgba(0,0,0,.3);
}
.promo-footer__inner{
  display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;
}
.promo-footer__inner strong{font-size:16px}
.promo-footer__inner p{font-size:13px;color:rgba(255,255,255,.7)}
.promo-footer__links{display:flex;gap:20px}
.promo-footer__links a{color:rgba(255,255,255,.7);text-decoration:none;font-size:13px;transition:color .2s}
.promo-footer__links a:hover{color:var(--p-accent)}
.promo-footer__copy{font-size:12px;color:rgba(255,255,255,.3);margin-top:8px}

.promo-footer__legal {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 13px;
}
.promo-footer__legal a {
  color: rgba(255,255,255,.7);
  text-decoration: none;
  transition: color 0.2s;
}
.promo-footer__legal a:hover {
  color: #fff;
}

.promo-footer__social {
  display: flex;
  gap: 10px;
  align-items: center;
}
.promo-footer__social a {
  color: rgba(255,255,255,.7);
  text-decoration: none;
  transition: color .2s;
  display: inline-flex;
  line-height: 0;
}
.promo-footer__social a:hover {
  color: #fff;
}
.promo-footer__social svg {
  width: 18px;
  height: 18px;
}

/* ---------- Mapa responsivo (Google Maps / embeds) ---------- */
.map-container {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 */
  height: 0;
  overflow: hidden;
  max-width: 100%;
  border-radius: 16px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  background: #f0f0f0;
  opacity: 0;
  transform: translateY(20px);
  transition: all .6s ease;
}
.map-container.visible {
  opacity: 1;
  transform: none;
}
.map-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
.map-address {
  text-align: center;
  margin-top: 12px;
  font-size: 14px;
  color: #555;
  line-height: 1.4;
}
.map-address small {
  font-size: 12px;
  opacity: 0.8;
}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .promo-about{grid-template-columns:1fr;gap:40px}
  .promo-gallery{grid-template-columns:1fr 1fr}
  .promo-gallery__item--large{grid-column:span 2}
  .promo-features{grid-template-columns:1fr 1fr}
  .promo-testimonials{grid-template-columns:1fr}
}
@media(max-width:640px){
  /* NAV fully mobile, no overflow */
  .promo-nav__inner { padding: 0 12px; }
  .promo-nav__brand { font-size: 15px; }
  .promo-nav__links{
    display:none;
    position:fixed;top:0;right:-100%;width:75%;max-width:300px;height:100vh;
    background:rgba(3,7,18,.97);backdrop-filter:blur(20px);
    flex-direction:column;padding:80px 32px 32px;gap:20px;
    transition:right .35s ease;
    border-left:1px solid rgba(255,255,255,.06);
  }
  .promo-nav__links.open{ display:flex; right:0 }
  .promo-nav__links a{font-size:18px}
  .promo-nav__cta{text-align:center;width:100%;justify-content:center}
  .promo-nav__toggle{display:flex}

  /* General container + sections - fill without cut, smaller padding */
  .promo-container { padding: 0 12px; }
  .promo-section { padding: 48px 0; }
  .promo-section__header { margin-bottom: 32px; }
  .promo-heading { font-size: clamp(22px, 7vw, 32px); }
  .promo-heading__sub { font-size: 14px; }

  /* Hero */
  .promo-hero { min-height: 70vh; }
  .promo-hero__content { display: flex !important; flex-direction: column; justify-content: space-between; align-items: center; text-align: center; padding: 70px 12px 25px; }
  .promo-hero__actions { gap: 10px; margin-top: 0; }
  .promo-hero__badge { font-size: 11px; padding: 6px 14px; margin-bottom: 8px; }

  /* About */
  .promo-about__text p { font-size: 14px; }
  .promo-about__float { padding: 10px 14px; bottom: -8px; right: 8px; }
  .promo-about__float strong { font-size: 18px; }
  .promo-about__float span { font-size: 10px; }
  .promo-chip { font-size: 11px; padding: 5px 10px; }

  /* Gallery */
  .promo-gallery{grid-template-columns:1fr}
  .promo-gallery__item--large{grid-column:span 1;grid-row:span 1}
  .promo-gallery__item img { min-height: 160px; }
  .promo-gallery__caption { padding: 10px 12px; font-size: 12px; }

  /* Features / Incluso */
  .promo-features{grid-template-columns:1fr; gap: 16px; }
  .promo-feature {
    padding: 24px 16px;
    min-height: auto;
  }
  .promo-feature__icon { font-size: 28px; margin-bottom: 12px; }
  .promo-feature h3 { font-size: 17px; margin-bottom: 8px; }
  .promo-feature p { font-size: 13px; }

  /* Testimonials */
  .promo-testimonials{grid-template-columns:1fr; gap:12px}
  .promo-testimonial { padding: 18px 14px; }
  .promo-testimonial p { font-size: 13px; margin-bottom: 12px; }

  /* CTA */
  .promo-cta { padding: 48px 0; }
  .promo-cta__content h2 { font-size: clamp(22px,7vw,32px); }
  .promo-cta__content p { font-size: 14px; margin-bottom: 24px; }
  .promo-cta__buttons { gap: 10px; }
  .promo-cta__trust { gap: 12px; font-size: 11px; }

  /* Footer already handled, extra safety */
  .promo-footer { padding: 28px 0; }
  .promo-footer__inner strong { font-size: 14px; }
  .promo-footer__links a, .promo-footer__legal a { font-size: 12px; }

  .map-address {
    font-size: 12px;
  }
  .map-address small {
    font-size: 11px;
  }
}
