:root {
  --navy:#03081dc3; --pink:#e8197c; --pink-light:#ff4da6; --pink-dark:#c0146a;
  --white:#fff; --light:#f4f7ff; --gray:#6b7280; --dark:#111827;
  --shadow:0 4px 24px rgba(15,33,103,.12); --radius:14px;
  --transition:all .3s cubic-bezier(.4,0,.2,1);
  --navy: #03081dc3;
 --pink:    #e8197c;
  --pink-l:  #ff4da6;
  --pink-d:  #c0146a;
  --navy:    #03081d;
  --bg:      #08091a;
  --ease:    cubic-bezier(.4,0,.2,1);
  --spring:  cubic-bezier(.34,1.56,.64,1);

    
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Poppins',sans-serif;background:var(--white);color:var(--dark);overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
.container{max-width:1180px;margin:0 auto;padding:0 20px}
.section-tag{display:inline-block;background:rgba(232,25,124,.1);color:var(--pink);font-size:.78rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:5px 16px;border-radius:50px;margin-bottom:14px}
.section-title{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;color:var(--navy);line-height:1.2;margin-bottom:16px}
.section-subtitle{font-size:1.05rem;color:var(--gray);max-width:560px;line-height:1.7}
.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--pink);color:var(--white);padding:14px 32px;border-radius:50px;font-weight:700;font-size:.95rem;border:none;cursor:pointer;transition:var(--transition);box-shadow:0 4px 20px rgba(232,25,124,.35);font-family:'Poppins',sans-serif}
.btn-primary:hover{background:var(--pink-dark);transform:translateY(-2px);box-shadow:0 8px 28px rgba(232,25,124,.45)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--white);padding:14px 32px;border-radius:50px;font-weight:700;font-size:.95rem;border:2px solid rgba(255,255,255,.6);cursor:pointer;transition:var(--transition);font-family:'Poppins',sans-serif}
.btn-outline:hover{background:rgba(255,255,255,.15);border-color:var(--white)}
.fade-in{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* ============================================================
   NAVBAR
============================================================ */
#navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(15,33,103,.97);backdrop-filter:blur(12px);padding:12px 0;transition:var(--transition);box-shadow:0 2px 20px rgba(0,0,0,.2)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.nav-logo img{height:54px;width:auto;border-radius:8px; background: transparent}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{color:rgba(255,255,255,.85);font-size:.88rem;font-weight:500;padding:7px 14px;border-radius:50px;transition:var(--transition)}
.nav-links a:hover{color:var(--white);background:rgba(255,255,255,.1)}
.nav-right{display:flex;align-items:center;gap:12px}
.lang-switcher{display:flex;align-items:center;background:rgba(255,255,255,.1);border-radius:50px;padding:3px;gap:2px}
.lang-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:50px;font-size:.78rem;font-weight:600;cursor:pointer;border:none;background:transparent;color:rgba(255,255,255,.7);transition:var(--transition);font-family:'Poppins',sans-serif}
.lang-btn.active{background:var(--pink);color:var(--white);box-shadow:0 2px 12px rgba(232,25,124,.4)}
.lang-btn:hover:not(.active){color:var(--white);background:rgba(255,255,255,.1)}
.nav-cta{padding:9px 22px;font-size:.85rem}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none}
.hamburger span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:var(--transition)}
.mobile-menu{display:none;flex-direction:column;background:var(--navy);padding:16px 20px 20px;gap:4px}
.mobile-menu.open{display:flex}
.mobile-menu a{color:rgba(255,255,255,.85);font-size:.95rem;font-weight:500;padding:10px 14px;border-radius:8px;transition:var(--transition)}
.mobile-menu a:hover{background:rgba(255,255,255,.1);color:var(--white)}
.mobile-cta{margin-top:8px;text-align:center}
.mobile-lang{display:flex;gap:8px;padding:10px 14px}

/* ============================================================
   HERO
============================================================ */
#hero{min-height:100vh;margin-top: 30px; background:linear-gradient(135deg,var(--navy) 0%,#1a3a8f 50%,#0d1a5c 100%);display:flex;align-items:center;position:relative;overflow:hidden;padding:120px 0 80px;}
#hero::before{content:'';position:absolute;top:-20%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(232,25,124,.18) 0%,transparent 70%);border-radius:50%;animation:pulse 4s ease-in-out infinite}
#hero::after{content:'';position:absolute;bottom:-20%;left:-5%;width:400px;height:400px;background:radial-gradient(circle,rgba(232,25,124,.1) 0%,transparent 70%);border-radius:50%;animation:pulse 6s ease-in-out infinite reverse}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.7}}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(232,25,124,.15);border:1px solid rgba(232,25,124,.3);color:var(--pink-light);padding:6px 16px;border-radius:50px;font-size:.78rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;margin-bottom:24px}
.hero-title{font-size:clamp(2.2rem,5vw,2.5rem);font-weight:900;color:var(--white);line-height:1.15;margin-bottom:20px}
.hero-title span{color:var(--white)}
.hero-subtitle{font-size:1.05rem;color:rgba(255,255,255,.75);line-height:1.8;margin-bottom:36px;max-width:480px}
.hero-buttons{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}
.hero-stats{display:flex;gap:32px;flex-wrap:wrap}
.stat-item{text-align:left}
.stat-num{font-size:2rem;font-weight:800;color:var(--pink);line-height:1}
.stat-label{font-size:.8rem;color:rgba(255,255,255,.65);font-weight:500;margin-top:4px}
.hero-img-side{position:relative;display:flex;align-items:center;justify-content:center}
.hero-img-frame{position:relative;border-radius:28px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.4);animation:floatY 4s ease-in-out infinite}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.hero-video{width:100%;height:500px;object-fit:cover;display:block}
.hero-img-badge{position:absolute;bottom:24px;left:24px;background:rgba(255,255,255,.95);backdrop-filter:blur(8px);border-radius:14px;padding:14px 20px;display:flex;align-items:center;gap:12px;box-shadow:0 8px 30px rgba(0,0,0,.15)}
.hero-img-badge-icon{width:42px;height:42px;background:var(--pink);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--white);font-size:1.1rem;flex-shrink:0}
.hero-img-badge-text .num{font-size:1.3rem;font-weight:800;color:var(--navy);line-height:1}
.hero-img-badge-text .lbl{font-size:.72rem;color:var(--gray);font-weight:500}
.hero-img-dot1,.hero-img-dot2{position:absolute;border-radius:50%;background:var(--pink);opacity:.3}
.hero-img-dot1{width:80px;height:80px;top:-20px;right:-20px;animation:pulse 3s infinite}
.hero-img-dot2{width:50px;height:50px;bottom:80px;right:-30px;animation:pulse 4s infinite .5s}
.hero-mini-cards{position:absolute;top:30px;left:-30px;display:flex;flex-direction:column;gap:10px;z-index: 1100}
.hero-mini-card{background:rgba(255,255,255,.1);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:12px 16px;display:flex;align-items:center;gap:10px;color:var(--white)}
.hero-mini-card i{color:var(--pink);font-size:1rem}
.hero-mini-card span{font-size:.78rem;font-weight:600}

/* ============================================================
   TRUST BAR
============================================================ */
#trust{background:var(--white);padding:28px 0;border-bottom:1px solid #e5e7eb}
.trust-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:32px}
.trust-item{display:flex;align-items:center;gap:10px;color:var(--navy);font-size:.88rem;font-weight:600}
.trust-item i{color:var(--pink);font-size:1.2rem}

/* ============================================================
   SERVICES CAROUSEL
============================================================ */
#services{padding:100px 0;background:var(--light);overflow:hidden}
.services-header{text-align:center;margin-bottom:60px}
.services-header .section-subtitle{margin:0 auto}
.carousel-wrapper{position:relative}
.carousel-track-outer{overflow:hidden;border-radius:var(--radius)}
.carousel-track{display:flex;gap:28px;transition:transform .6s cubic-bezier(.4,0,.2,1);will-change:transform}
.service-card{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);flex:0 0 calc((100% - 56px)/3);transition:var(--transition);cursor:default}
.service-card:hover{transform:translateY(-8px);box-shadow:0 16px 50px rgba(15,33,103,.18)}
.service-card-img{position:relative;height:220px;overflow:hidden}
.service-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.service-card:hover .service-card-img img{transform:scale(1.08)}
.service-card-img-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(15,33,103,.7) 100%)}
.service-card-img-tag{position:absolute;top:14px;left:14px;background:var(--pink);color:var(--white);font-size:.7rem;font-weight:700;padding:4px 12px;border-radius:50px;letter-spacing:.5px;text-transform:uppercase}
.service-card-body{padding:24px 24px 28px}
.service-card-body h3{font-size:1.15rem;font-weight:700;color:var(--navy);margin-bottom:10px}
.service-card-body p{font-size:.88rem;color:var(--gray);line-height:1.7;margin-bottom:16px}
.service-list{display:flex;flex-direction:column;gap:6px}
.service-list li{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--dark)}
.service-list li i{color:var(--pink);font-size:.72rem;flex-shrink:0}
.carousel-controls{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:36px}
.carousel-btn{width:44px;height:44px;border-radius:50%;border:2px solid var(--pink);background:var(--white);color:var(--pink);font-size:1rem;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}
.carousel-btn:hover{background:var(--pink);color:var(--white)}
.carousel-dots{display:flex;gap:8px}
.carousel-dot{width:10px;height:10px;border-radius:50%;background:#d1d5db;border:none;cursor:pointer;transition:var(--transition);padding:0}
.carousel-dot.active{background:var(--pink);width:26px;border-radius:5px}

/* ============================================================
   WHY CHOOSE US
============================================================ */
#why{padding:100px 0;background:var(--white)}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.why-benefits{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:40px}
.benefit-card{padding:24px;background:var(--light);border-radius:var(--radius);transition:var(--transition)}
.benefit-card:hover{background:var(--navy)}
.benefit-card:hover .benefit-title,.benefit-card:hover .benefit-desc{color:var(--white)}
.benefit-card:hover .benefit-icon{background:var(--pink);color:var(--white)}
.benefit-icon{width:44px;height:44px;background:rgba(232,25,124,.12);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--pink);font-size:1.1rem;margin-bottom:14px;transition:var(--transition)}
.benefit-title{font-size:.95rem;font-weight:700;color:var(--navy);margin-bottom:6px;transition:var(--transition)}
.benefit-desc{font-size:.82rem;color:var(--gray);line-height:1.6;transition:var(--transition)}
.why-visual{position:relative}
.why-img-wrapper{border-radius:24px;overflow:hidden;box-shadow:0 20px 60px rgba(15,33,103,.2)}
.why-img-wrapper img{width:100%;height:620px;object-fit:cover}
.why-badge{position:absolute;bottom:-20px;left:-20px;background:var(--pink);color:var(--white);padding:18px 24px;border-radius:16px;box-shadow:0 8px 30px rgba(232,25,124,.4)}
.why-badge-num{font-size:2rem;font-weight:900;line-height:1}
.why-badge-text{font-size:.78rem;font-weight:600;opacity:.9}

/* ============================================================
   ABOUT
============================================================ */
#about{padding:100px 0;background:linear-gradient(135deg,var(--navy) 0%,#1a3a8f 100%);color:var(--white);overflow:hidden;position:relative}
#about::before{content:'';position:absolute;top:0;right:0;width:500px;height:500px;background:radial-gradient(circle,rgba(232,25,124,.12) 0%,transparent 70%);border-radius:50%}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative;z-index:1}
.about-tag{background:rgba(232,25,124,.2);color:var(--pink-light)}
.about-title{color:var(--white)}
.about-text{font-size:.95rem;color:rgba(255,255,255,.75);line-height:1.8;margin-bottom:16px}
.about-highlights{display:flex;flex-direction:column;gap:14px;margin-top:28px}
.about-highlight{display:flex;align-items:flex-start;gap:14px}
.about-highlight i{color:var(--pink);font-size:1rem;margin-top:3px;flex-shrink:0}
.about-highlight p{font-size:.9rem;color:rgba(255,255,255,.8);line-height:1.6}
.about-visual{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.about-stat-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:28px 22px;text-align:center;backdrop-filter:blur(8px);transition:var(--transition)}
.about-stat-card:hover{background:rgba(232,25,124,.15);border-color:rgba(232,25,124,.3)}
.about-stat-card:nth-child(2),.about-stat-card:nth-child(4){margin-top:24px}
.about-stat-num{font-size:2.2rem;font-weight:900;color:var(--pink);margin-bottom:6px}
.about-stat-label{font-size:.82rem;color:rgba(255,255,255,.7);font-weight:500}

/* ============================================================
   TESTIMONIALS
============================================================ */
#testimonials{padding:100px 0;background:var(--light)}
.testimonials-header{text-align:center;margin-bottom:60px}
.testimonials-header .section-subtitle{margin:0 auto}
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:28px}
.testimonial-card{background:var(--white);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow);transition:var(--transition)}
.testimonial-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px rgba(15,33,103,.16)}
.testimonial-quote{font-size:3rem;color:var(--pink);line-height:.5;margin-bottom:16px;opacity:.3}
.testimonial-text{font-size:.92rem;color:var(--dark);line-height:1.75;margin-bottom:24px;font-style:italic}
.testimonial-author{display:flex;align-items:center;gap:14px}
.author-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--pink),var(--navy));display:flex;align-items:center;justify-content:center;color:var(--white);font-weight:700;font-size:1rem;flex-shrink:0}
.author-name{font-weight:700;font-size:.9rem;color:var(--navy)}
.author-city{font-size:.78rem;color:var(--gray)}
.stars{color:#f59e0b;font-size:.85rem;margin-bottom:4px}

/* ============================================================
   SERVICE AREA
============================================================ */
#service-area{padding:100px 0;background:var(--white)}
.area-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.city-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:32px}
.city-card{display:flex;align-items:center;gap:12px;background:var(--light);border-radius:12px;padding:16px 18px;font-weight:600;font-size:.88rem;color:var(--navy);transition:var(--transition);border:2px solid transparent}
.city-card:hover{background:var(--navy);color:var(--white);border-color:var(--pink)}
.city-card:hover i{color:var(--pink-light)}
.city-card i{color:var(--pink);font-size:1rem;transition:var(--transition)}
.map-wrap{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.map-wrap iframe{width:100%;height:400px;border:none;display:block}



/* ── SECTION ─────────────────────────────────────── */

#before-after{padding:100px 0;background:#0a0f1e;position:relative;overflow:hidden }
#before-after::before{content:'';position:absolute;top:-200px;right:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(232,25,124,.08) 0%,transparent 70%);border-radius:50%;pointer-events:none}
#before-after::after{content:'';position:absolute;bottom:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(26,58,143,.15) 0%,transparent 70%);border-radius:50%;pointer-events:none}

.ba-header{text-align:center;margin-bottom:56px;position:relative;z-index:1}
.ba-header .section-tag{background:rgba(232,25,124,.2);color:var(--pink-light);border:1px solid rgba(232,25,124,.25)}
.ba-header .section-title{color:var(--white)}
.ba-header .section-subtitle{color:rgba(255,255,255,.55);margin:0 auto}


/* ── FILTER BAR ──────────────────────────────────── */
.gallery-filters {
  display:flex; align-items:center; justify-content:center;
  gap:10px; margin-bottom:38px;
  position:relative; z-index:2; flex-wrap:wrap;
}
.filter-btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 26px; border-radius:50px;
  border:1.5px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
  color:rgba(255,255,255,.55);
  font-family:'Poppins',sans-serif; font-size:.82rem; font-weight:700;
  letter-spacing:.5px; cursor:pointer;
  transition:all .3s var(--ease);
  backdrop-filter:blur(8px);
}
.filter-btn i { font-size:.9rem; transition:transform .3s var(--ease) }
.filter-btn:hover {
  border-color:rgba(232,25,124,.5); color:rgba(255,255,255,.88);
  background:rgba(232,25,124,.1); transform:translateY(-2px);
}
.filter-btn:hover i { transform:scale(1.2) }
.filter-btn.active {
  background:var(--pink); border-color:var(--pink); color:#fff;
  box-shadow:0 6px 28px rgba(232,25,124,.45);
}
.filter-count {
  display:inline-flex; align-items:center; justify-content:center;
  min-width:22px; height:22px; border-radius:50px;
  background:rgba(255,255,255,.2);
  font-size:.7rem; font-weight:800; font-style:normal; padding:0 6px;
}

/* ── BENTO GRID — TODOS (padrão) ────────────────── */
/*
  Layout 12 colunas × 5 linhas:
  ┌──────────────────────┬──────────┐
  │  A  sala1 (hero)     │  B foto  │  linha 1
  │  7 colunas × 2 lin   ├──────────┤
  │                      │  C vid   │  linha 2
  ├────────┬─────────────┴──────────┤
  │  D vid │  E  ilustre.mp4        │  linha 3
  ├────────┼──────────┬─────────────┤
  │  F vid │  G vid   │  H vid      │  linha 4
  ├────────┴──────────┴─────────────┤
  │  I  ilustre.jpeg (panorâmica)   │  linha 5
  └─────────────────────────────────┘
*/
.gallery-bento {
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-template-rows:340px 340px 340px 310px 320px;
  gap:14px;
  position:relative; z-index:1;
  margin-bottom: -200px;
}
.gallery-item--a { grid-column:1/8;  grid-row:1/3 }  /* hero */
.gallery-item--b { grid-column:8/13; grid-row:1/2 }
.gallery-item--c { grid-column:8/13; grid-row:2/3 }
.gallery-item--d { grid-column:1/5;  grid-row:3/4 }
.gallery-item--e { grid-column:5/13; grid-row:3/4 }
.gallery-item--f { grid-column:1/5;  grid-row:4/5 }
.gallery-item--g { grid-column:5/9;  grid-row:4/5 }
.gallery-item--h { grid-column:9/13; grid-row:4/5 }
.gallery-item--i { grid-column:1/13; grid-row:5/6 }  /* panorâmica */

/* Modo filtrado — grid uniforme */
.gallery-bento.mode-filtered {
  grid-template-columns:repeat(auto-fill,minmax(290px,1fr));
  grid-template-rows:auto;
}
.gallery-bento.mode-filtered .gallery-item {
  grid-column:auto !important;
  grid-row:auto !important;
  min-height:245px;
}
/* Item panorâmico em modo filtrado não ocupa mais largura total */
.gallery-bento.mode-filtered .gallery-item--i { min-height:245px }

/* ── ITEM BASE ───────────────────────────────────── */
.gallery-item {
  position:relative; border-radius:18px;
  overflow:hidden; cursor:pointer; background:#0d1020;
  outline:none;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), opacity .4s var(--ease);
}
.gallery-item:focus-visible { box-shadow:0 0 0 3px var(--pink) }
.gallery-item:hover {
  transform:translateY(-4px) scale(1.01);
  box-shadow:0 24px 64px rgba(0,0,0,.6);
}
.gallery-item.hidden {
  opacity:0; pointer-events:none;
  transform:scale(.93) translateY(8px);
  position:absolute; visibility:hidden;
}

/* ── MÍDIA ───────────────────────────────────────── */
.gallery-item img,
.gallery-item video {
  width:100%; height:100%;
  object-fit:cover; display:block;
  transition:transform .7s var(--ease);
}
.gallery-item:hover img,
.gallery-item:hover video { transform:scale(1.06) }

/* Gradiente inferior permanente */
.gallery-item::before {
  content:''; position:absolute;
  bottom:0; left:0; right:0; height:120px;
  background:linear-gradient(transparent,rgba(3,8,25,.7));
  pointer-events:none; z-index:2;
  transition:opacity .4s var(--ease);
}
.gallery-item:hover::before { opacity:0 }

/* ── SHIMMER (loading do thumbnail) ─────────────── */
.gallery-item video { background:#0d1020 }
.gallery-item video.loading {
  background:linear-gradient(
    110deg,
    #0d1020 25%,
    #1a1f35 50%,
    #0d1020 75%
  );
  background-size:200% 100%;
  animation:shimmer 1.6s infinite;
}
@keyframes shimmer {
  0%   { background-position:200% 0 }
  100% { background-position:-200% 0 }
}

/* ── HERO (item A) — sala1.mp4 ───────────────────── */
.gallery-item--a {
  border:1.5px solid rgba(232,25,124,.22);
  animation:heroGlow 4s ease-in-out infinite;
}
@keyframes heroGlow {
  0%,100% { box-shadow:0 0 0 0   rgba(232,25,124,.0) }
  50%     { box-shadow:0 0 45px 4px rgba(232,25,124,.18) }
}
/* Badge "Reproduzindo" */
.hero-live-badge {
  position:absolute; top:16px; left:16px; z-index:6;
  display:inline-flex; align-items:center; gap:7px;
  background:rgba(232,25,124,.9); backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.2); color:#fff;
  font-size:.72rem; font-weight:700; letter-spacing:1.2px;
  text-transform:uppercase; padding:6px 14px; border-radius:50px;
  box-shadow:0 4px 18px rgba(232,25,124,.5);
}
.hero-live-dot {
  width:7px; height:7px; border-radius:50%;
  background:#fff; flex-shrink:0;
  animation:livePulse 1.4s ease-in-out infinite;
}
@keyframes livePulse {
  0%,100%{ opacity:1; transform:scale(1) }
  50%    { opacity:.35; transform:scale(.75) }
}
/* Botão "Assistir com som" */
.hero-play-btn {
  position:absolute; bottom:20px; right:20px; z-index:6;
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(0,0,0,.55); backdrop-filter:blur(10px);
  border:1.5px solid rgba(255,255,255,.2); color:#fff;
  font-size:.75rem; font-weight:700; letter-spacing:.5px;
  padding:9px 18px; border-radius:50px; text-transform:uppercase;
  transition:all .3s var(--ease);
}
.hero-play-btn i { color:var(--pink); font-size:.85rem; transition:color .3s }
.gallery-item--a:hover .hero-play-btn {
  background:var(--pink); border-color:var(--pink);
  box-shadow:0 6px 24px rgba(232,25,124,.5);
}
.gallery-item--a:hover .hero-play-btn i { color:#fff }

/* ── PLAY BUTTON — vídeos não-hero ──────────────── */
.gallery-play-btn {
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%);
  display:flex; flex-direction:column; align-items:center; gap:10px;
  z-index:5; pointer-events:none;
  transition:transform .4s var(--spring);
}
.gallery-item:hover .gallery-play-btn {
  transform:translate(-50%,-56%);
}
.play-circle {
  width:62px; height:62px; border-radius:50%;
  background:rgba(232,25,124,.88);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 0 12px rgba(232,25,124,.16), 0 10px 32px rgba(232,25,124,.5);
  transition:background .3s var(--ease), box-shadow .3s var(--ease), transform .3s var(--spring);
  position:relative;
}
.gallery-item:hover .play-circle {
  background:var(--pink);
  box-shadow:0 0 0 18px rgba(232,25,124,.22), 0 14px 40px rgba(232,25,124,.65);
  transform:scale(1.12);
}
.play-circle svg { width:24px; height:24px; fill:#fff; margin-left:3px }
/* Ring de pulso */
.play-circle::after {
  content:''; position:absolute;
  width:62px; height:62px; border-radius:50%;
  border:2px solid rgba(232,25,124,.45);
  animation:ringPulse 2.2s linear infinite;
}
@keyframes ringPulse {
  0%  { transform:scale(1);   opacity:.7 }
  100%{ transform:scale(2.2); opacity:0  }
}
.play-label {
  color:#fff; font-size:.7rem; font-weight:700;
  letter-spacing:1.8px; text-transform:uppercase; white-space:nowrap;
  opacity:0; transform:translateY(6px);
  transition:opacity .3s var(--ease), transform .3s var(--ease);
  text-shadow:0 2px 8px rgba(0,0,0,.5);
}
.gallery-item:hover .play-label { opacity:1; transform:translateY(0) }

/* ── BADGES ──────────────────────────────────────── */
/* "● VÍDEO" / "● FOTO" — canto superior direito */
.type-badge {
  position:absolute; top:14px; right:14px; z-index:6;
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(0,0,0,.58); backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.12); color:#fff;
  font-size:.67rem; font-weight:700; letter-spacing:.8px;
  padding:5px 12px; border-radius:50px;
}
.type-dot {
  width:7px; height:7px; border-radius:50%;
  background:var(--pink); flex-shrink:0;
  animation:typePulse 1.7s ease-in-out infinite;
}
@keyframes typePulse {
  0%,100%{ opacity:1; transform:scale(1) }
  50%    { opacity:.3; transform:scale(.75) }
}
.type-badge.is-photo .type-dot { background:var(--pink-l); animation:none }

/* Categoria — canto inferior esquerdo */
.cat-badge {
  position:absolute; bottom:14px; left:14px; z-index:6;
  display:inline-flex; align-items:center; gap:7px;
  background:rgba(3,8,25,.62); backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.1); color:rgba(255,255,255,.85);
  font-size:.68rem; font-weight:600; padding:5px 12px; border-radius:50px;
  transition:opacity .35s var(--ease), transform .35s var(--ease);
}
.cat-badge i { color:var(--pink); font-size:.72rem }
.gallery-item:hover .cat-badge { opacity:0; transform:translateY(4px) }

/* ── OVERLAY HOVER ───────────────────────────────── */
.gallery-overlay {
  position:absolute; inset:0; z-index:4;
  background:linear-gradient(180deg,rgba(3,8,29,0) 28%,rgba(3,8,29,.9) 100%);
  opacity:0; transition:opacity .4s var(--ease);
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:22px 24px;
}
/* Panorâmica: distribuído em row */
.gallery-item--i .gallery-overlay {
  flex-direction:row; align-items:flex-end; justify-content:space-between;
}
.gallery-item:hover .gallery-overlay { opacity:1 }
.overlay-tag {
  display:inline-flex; align-items:center; gap:6px;
  background:var(--pink); color:#fff;
  font-size:.66rem; font-weight:700; letter-spacing:1px; text-transform:uppercase;
  padding:4px 12px; border-radius:50px; margin-bottom:8px; align-self:flex-start;
}
.overlay-title { font-size:1rem; font-weight:700; color:#fff; line-height:1.3; margin-bottom:4px }
.overlay-desc  { font-size:.78rem; color:rgba(255,255,255,.6) }
.overlay-block { display:flex; flex-direction:column }

/* ── LIGHTBOX ────────────────────────────────────── */
.gallery-lightbox {
  position:fixed; inset:0; z-index:3000;
  background:rgba(0,0,0,.96); backdrop-filter:blur(22px);
  display:flex; align-items:center; justify-content:center;
  padding:20px; opacity:0; pointer-events:none;
  transition:opacity .35s var(--ease);
}
.gallery-lightbox.open { opacity:1; pointer-events:all }
.gallery-lightbox.open .lb-shell {
  animation:lbIn .4s var(--spring) both;
}
@keyframes lbIn {
  from{ transform:scale(.86) translateY(24px); opacity:0 }
  to  { transform:scale(1)   translateY(0);    opacity:1 }
}
.lb-shell {
  position:relative; max-width:980px; width:100%;
  display:flex; flex-direction:column; align-items:center;
}
.lb-media {
  width:100%; max-height:80vh;
  object-fit:contain; display:block;
  border-radius:16px; background:#000;
}
.lb-footer {
  display:flex; align-items:center; justify-content:space-between;
  width:100%; margin-top:16px; padding:0 2px;
}
.lb-caption {
  display:flex; align-items:center; gap:8px;
  color:rgba(255,255,255,.6); font-size:.85rem; font-family:'Poppins',sans-serif;
}
.lb-caption i { color:var(--pink) }
.lb-actions { display:flex; align-items:center; gap:10px }
.lb-esc { color:rgba(255,255,255,.3); font-size:.72rem; font-family:'Poppins',sans-serif }
.lb-close {
  width:42px; height:42px; border-radius:50%;
  background:var(--pink); border:none; color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:1rem; cursor:pointer;
  transition:all .3s var(--ease);
  box-shadow:0 4px 18px rgba(232,25,124,.4);
}
.lb-close:hover { background:var(--pink-d); transform:scale(1.1) }

/* ── RESPONSIVE ──────────────────────────────────── */
@media(max-width:1060px) {
  .gallery-bento {
    grid-template-columns:repeat(6,1fr);
    grid-template-rows:280px 220px 220px 200px 200px 200px;
  }
  .gallery-item--a { grid-column:1/7; grid-row:1/2 }
  .gallery-item--b { grid-column:1/4; grid-row:2/3 }
  .gallery-item--c { grid-column:4/7; grid-row:2/3 }
  .gallery-item--d { grid-column:1/4; grid-row:3/4 }
  .gallery-item--e { grid-column:4/7; grid-row:3/4 }
  .gallery-item--f { grid-column:1/3; grid-row:4/5 }
  .gallery-item--g { grid-column:3/5; grid-row:4/5 }
  .gallery-item--h { grid-column:5/7; grid-row:4/5 }
  .gallery-item--i { grid-column:1/7; grid-row:5/6 }
  .gallery-bento.mode-filtered {
    grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
    grid-template-rows:auto;
  }
}
@media(max-width:680px) {
  .gallery-bento {
    grid-template-columns:1fr 1fr;
    grid-template-rows:220px 190px 190px 190px 190px;
    gap:10px;
  }
  .gallery-item--a { grid-column:1/3; grid-row:1/2 }
  .gallery-item--b { grid-column:1/2; grid-row:2/3 }
  .gallery-item--c { grid-column:2/3; grid-row:2/3 }
  .gallery-item--d { grid-column:1/2; grid-row:3/4 }
  .gallery-item--e { grid-column:2/3; grid-row:3/4 }
  .gallery-item--f { grid-column:1/2; grid-row:4/5 }
  .gallery-item--g { grid-column:2/3; grid-row:4/5 }
  .gallery-item--h { grid-column:1/2; grid-row:5/6 }
  .gallery-item--i { grid-column:2/3; grid-row:5/6 }
  .overlay-desc    { display:none }
  .play-label      { display:none }
  .gallery-bento.mode-filtered {
    grid-template-columns:1fr 1fr;
    grid-template-rows:auto;
  }
  .gallery-bento.mode-filtered .gallery-item { min-height:200px }
}
@media(max-width:400px) {
  .gallery-bento,
  .gallery-bento.mode-filtered {
    grid-template-columns:1fr;
    grid-template-rows:auto;
  }
  .gallery-item--a,.gallery-item--b,.gallery-item--c,.gallery-item--d,
  .gallery-item--e,.gallery-item--f,.gallery-item--g,.gallery-item--h,
  .gallery-item--i {
    grid-column:auto !important; grid-row:auto !important; min-height:210px;
  }
}

/* ============================================================
   FAQ
============================================================ */
#faq{padding:100px 0;background:var(--white)}
.faq-grid{display:grid;grid-template-columns:1fr 1.6fr; gap:40px;align-items:start}
.faq-visual{position:relative}
.faq-visual img{width:100%;height:720px;object-fit:cover;border-radius:24px;box-shadow:0 20px 60px rgba(15,33,103,.2)}
.faq-visual-badge{position:absolute;bottom:-20px;right:-20px;background:var(--navy);color:var(--white);padding:20px 24px;border-radius:16px;box-shadow:0 8px 30px rgba(15,33,103,.35);text-align:center}
.faq-visual-badge .num{font-size:2rem;font-weight:900;color:var(--pink)}
.faq-visual-badge .lbl{font-size:.78rem;opacity:.8;font-weight:500}
.faq-list{display:flex;flex-direction:column;gap:14px}
.faq-item{border-radius:14px;overflow:hidden;box-shadow:0 2px 12px rgba(15,33,103,.08);background:var(--white);border:1px solid #e5e7eb;transition:var(--transition)}
.faq-item.open{border-color:var(--pink);box-shadow:0 4px 24px rgba(232,25,124,.12)}
.faq-question{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;cursor:pointer;gap:16px}
.faq-question-text{font-size:.95rem;font-weight:600;color:var(--navy);line-height:1.4;transition:var(--transition)}
.faq-item.open .faq-question-text{color:var(--pink)}
.faq-icon{width:34px;height:34px;border-radius:50%;background:var(--light);display:flex;align-items:center;justify-content:center;color:var(--navy);font-size:.85rem;flex-shrink:0;transition:var(--transition)}
.faq-item.open .faq-icon{background:var(--pink);color:var(--white);transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1),padding .3s ease}
.faq-answer-inner{padding:0 24px 20px;font-size:.9rem;color:var(--gray);line-height:1.75}
.faq-item.open .faq-answer{max-height:600px}

/* ============================================================
   CTA SECTION
============================================================ */
#cta-section{padding:100px 0;background:linear-gradient(135deg,var(--pink-dark) 0%,var(--pink) 50%,var(--pink-light) 100%);position:relative;overflow:hidden;text-align:center}
#cta-section::before{content:'';position:absolute;top:-50%;left:-10%;width:400px;height:400px;background:rgba(255,255,255,.08);border-radius:50%}
#cta-section::after{content:'';position:absolute;bottom:-40%;right:-5%;width:350px;height:350px;background:rgba(255,255,255,.06);border-radius:50%}
.cta-inner{position:relative;z-index:1}
.cta-tag{background:rgba(255,255,255,.2);color:var(--white)}
.cta-title{font-size:clamp(2rem,4.5vw,3rem);font-weight:900;color:var(--white);margin-bottom:18px}
.cta-subtitle{font-size:1.05rem;color:rgba(255,255,255,.85);max-width:560px;margin:0 auto 36px;line-height:1.7}
.cta-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.btn-white{display:inline-flex;align-items:center;gap:8px;background:var(--white);color:var(--pink);padding:16px 36px;border-radius:50px;font-weight:700;font-size:1rem;border:none;cursor:pointer;transition:var(--transition);box-shadow:0 4px 20px rgba(0,0,0,.15);text-decoration:none;font-family:'Poppins',sans-serif}
.btn-white:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(0,0,0,.25)}
.btn-white-outline{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--white);padding:16px 36px;border-radius:50px;font-weight:700;font-size:1rem;border:2px solid rgba(255,255,255,.7);cursor:pointer;transition:var(--transition);text-decoration:none}
.btn-white-outline:hover{background:rgba(255,255,255,.15);border-color:var(--white)}

/* ============================================================
   CONTACT
============================================================ */
#contact{padding:100px 0;background:var(--white)}
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:80px;align-items:start}
.contact-info p{font-size:.95rem;color:var(--gray);line-height:1.7;margin-bottom:36px}
.contact-items{display:flex;flex-direction:column;gap:20px}
.contact-item{display:flex;align-items:flex-start;gap:16px}
.contact-item-icon{width:46px;height:46px;background:rgba(232,25,124,.1);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--pink);font-size:1.1rem;flex-shrink:0}
.contact-item-label{font-size:.78rem;font-weight:700;color:var(--gray);text-transform:uppercase;letter-spacing:1px;margin-bottom:3px}
.contact-item-value{font-size:.92rem;font-weight:600;color:var(--navy)}
.contact-form{background:var(--light);border-radius:20px;padding:40px;box-shadow:var(--shadow)}
.form-title{font-size:1.4rem;font-weight:700;color:var(--navy);margin-bottom:28px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.form-group label{font-size:.82rem;font-weight:600;color:var(--dark)}
.form-group input,.form-group select,.form-group textarea{padding:13px 16px;border:2px solid #e5e7eb;border-radius:10px;font-size:.92rem;font-family:'Poppins',sans-serif;background:var(--white);color:var(--dark);transition:var(--transition);outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--pink);box-shadow:0 0 0 3px rgba(232,25,124,.1)}
.form-group textarea{resize:vertical;min-height:110px}
.form-submit{width:100%;padding:15px;border-radius:50px;font-size:1rem;font-weight:700;margin-top:6px}
.form-success{display:none;background:#dcfce7;border:1px solid #86efac;border-radius:10px;padding:16px;text-align:center;color:#16a34a;font-weight:600;font-size:.92rem;margin-top:12px}

/* ============================================================
   FOOTER
============================================================ */
#footer{background:var(--dark);color:rgba(255,255,255,.75);padding:70px 0 30px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:50px}
.footer-brand img{height:100px;border-radius:10px;margin-bottom:18px}
.footer-brand p{font-size:.88rem;line-height:1.75}
.footer-socials{display:flex;gap:10px;margin-top:20px}
.footer-social{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);font-size:.9rem;transition:var(--transition)}
.footer-social:hover{background:var(--pink);color:var(--white)}
.footer-col h4{font-size:.9rem;font-weight:700;color:var(--white);margin-bottom:18px}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-links a{font-size:.85rem;transition:var(--transition)}
.footer-links a:hover{color:var(--pink)}
.footer-contact-items{display:flex;flex-direction:column;gap:12px}
.footer-contact-item{display:flex;align-items:flex-start;gap:10px;font-size:.85rem}
.footer-contact-item i{color:var(--pink);margin-top:2px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:28px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-bottom p{font-size:.82rem}
.footer-bottom-links{display:flex;gap:20px}
.footer-bottom-links a{font-size:.82rem;transition:var(--transition)}
.footer-bottom-links a:hover{color:var(--pink)}

/* ============================================================
   QUOTE MODAL
============================================================ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .3s ease}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--white);border-radius:24px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 30px 80px rgba(0,0,0,.3);transform:translateY(20px) scale(.97);transition:transform .3s ease;position:relative}
.modal-overlay.open .modal-box{transform:translateY(0) scale(1)}
.modal-header{background:linear-gradient(135deg,var(--navy),#1a3a8f);padding:28px 32px;border-radius:24px 24px 0 0;display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.modal-header-text h3{font-size:1.3rem;font-weight:800;color:var(--white);margin-bottom:6px}
.modal-header-text p{font-size:.85rem;color:rgba(255,255,255,.75)}
.modal-close{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.15);border:none;color:var(--white);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);flex-shrink:0}
.modal-close:hover{background:rgba(255,255,255,.3)}
.modal-body{padding:32px}
.modal-form .form-group{margin-bottom:18px}
.modal-form .form-group label{font-size:.82rem;font-weight:600;color:var(--dark);display:flex;align-items:center;gap:6px;margin-bottom:6px}
.modal-form .form-group label i{color:var(--pink);font-size:.8rem}
.modal-form input,.modal-form select{width:100%;padding:13px 16px;border:2px solid #e5e7eb;border-radius:10px;font-size:.92rem;font-family:'Poppins',sans-serif;background:var(--white);color:var(--dark);transition:var(--transition);outline:none}
.modal-form input:focus,.modal-form select:focus{border-color:var(--pink);box-shadow:0 0 0 3px rgba(232,25,124,.1)}
.extras-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px}
.extra-check{display:flex;align-items:center;gap:10px;background:var(--light);border-radius:10px;padding:12px 14px;cursor:pointer;transition:var(--transition);border:2px solid transparent}
.extra-check:has(input:checked){background:rgba(232,25,124,.08);border-color:var(--pink)}
.extra-check input[type=checkbox]{width:16px;height:16px;accent-color:var(--pink);cursor:pointer;flex-shrink:0}
.extra-check span{font-size:.82rem;font-weight:500;color:var(--dark)}
.modal-submit{width:100%;padding:15px;font-size:1rem;border-radius:50px;margin-top:8px}
.modal-success{display:none;text-align:center;padding:20px 0}
.modal-success i{font-size:3rem;color:#16a34a;margin-bottom:16px}
.modal-success h4{font-size:1.2rem;font-weight:700;color:var(--navy);margin-bottom:8px}
.modal-success p{font-size:.9rem;color:var(--gray)}

/* ============================================================
   FLOATING BUTTONS
============================================================ */
.floating-buttons{position:fixed;bottom:28px;right:28px;display:flex;flex-direction:column;gap:12px;z-index:999}
.float-btn{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--white);cursor:pointer;border:none;box-shadow:0 4px 20px rgba(0,0,0,.25);transition:var(--transition);text-decoration:none}
.float-btn:hover{transform:scale(1.1)}
.float-btn.whatsapp{background:#25d366;box-shadow:0 4px 20px rgba(37,211,102,.45)}
.float-btn.phone{background:var(--pink);box-shadow:0 4px 20px rgba(232,25,124,.45)}
.float-btn-label{position:absolute;right:64px;background:var(--dark);color:var(--white);font-size:.78rem;padding:5px 12px;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:var(--transition)}
.float-btn-wrap{position:relative;display:flex;align-items:center}
.float-btn-wrap:hover .float-btn-label{opacity:1}
.float-btn.whatsapp::before{content:'';position:absolute;width:56px;height:56px;border-radius:50%;background:rgba(37,211,102,.4);animation:ringPulse 2s infinite}
@keyframes ringPulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.8);opacity:0}}
#scroll-top{position:fixed;bottom:28px;left:28px;width:44px;height:44px;border-radius:50%;background:var(--navy);color:var(--white);display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;box-shadow:var(--shadow);font-size:.9rem;opacity:0;pointer-events:none;transition:var(--transition);z-index:998}
#scroll-top.visible{opacity:1;pointer-events:all}
#scroll-top:hover{background:var(--pink);transform:translateY(-3px)}

/* ============================================================
   RESPONSIVE
============================================================ */
@media(max-width:1100px){
  .service-card{flex:0 0 calc((100% - 28px)/2)}
  
}
@media(max-width:1024px){
  .hero-grid,.why-grid,.about-grid,.area-grid,.contact-grid,.faq-grid{grid-template-columns:1fr;gap:50px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .why-badge{bottom:10px;left:10px}
  .gallery-bento{
    grid-template-columns:1fr 1fr;
    grid-template-rows:280px 220px 220px 200px;
    gap:12px
  }
  .gallery-item--a{grid-column:1/3;grid-row:1/2}
  .gallery-item--b{grid-column:1/2;grid-row:2/3}
  .gallery-item--c{grid-column:2/3;grid-row:2/3}
  .gallery-item--d{grid-column:1/2;grid-row:3/4}
  .gallery-item--e{grid-column:2/3;grid-row:3/4}
  .gallery-item--f{grid-column:1/3;grid-row:4/5}
  
}
@media(max-width:768px){
  .nav-links,.nav-cta,.lang-switcher{display:none}
  .hamburger{display:flex}
  .hero-grid{text-align:center}
  .hero-subtitle{margin:0 auto 36px}
  .hero-buttons{justify-content:center}
  .hero-stats{justify-content:center}
  .hero-img-side{display:none}
  .why-benefits{grid-template-columns:1fr}
  .about-visual{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .form-row{grid-template-columns:1fr}
  .contact-form{padding:28px 20px}
  .city-cards{grid-template-columns:1fr}
  .service-card{flex:0 0 85vw}
  .extras-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr}
   .modal-body{padding:24px 20px}
  .gallery-bento{
    grid-template-columns:1fr 1fr;
    grid-template-rows:220px 180px 180px 160px;
    gap:10px
  }
  .gallery-overlay-desc{display:none}
}
@media(max-width:520px){
  .gallery-bento{
    grid-template-columns:1fr;
    grid-template-rows:auto;
    gap:10px
  }
  .gallery-item--a,.gallery-item--b,.gallery-item--c,
  .gallery-item--d,.gallery-item--e,.gallery-item--f{
    grid-column:auto;grid-row:auto;min-height:220px
  }
  .trust-grid{flex-direction:column;align-items:center;text-align:center}
  .cta-buttons{flex-direction:column;align-items:center}

}

