/* =========================
   BASE
========================= */
:root{
  --bg:#0b0b0b; 
  --fg:#fff;
  --sand:#f4ebd4; 
  --olive:#7f864f; 
  --gold:#eedcb7;
  --dark-gold:#c4a88d;
  --header-h:76px;              /* padding do body quando header é fixo */
  --header-top-offset:30px;     /* afastamento do header no desktop */
}
*{box-sizing:border-box}
html,body{
  margin:0; padding:0; background:var(--olive); color:var(--fg);
  font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
a{ color:inherit; text-decoration:none }
em{ font-style:italic }
.wrap,.container{ width:min(1200px,92vw); margin-inline:auto }
.has-fixed-header{ padding-top:var(--header-h) }

/* =========================
   HEADER
========================= */
.site-header.transparent{
  position:fixed; top:var(--header-top-offset); left:0; right:0; z-index:100;
  background:transparent; padding:14px 0;
}
.nav-wrap{
  width:min(1200px,92vw); margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
}
.brand-img{ height:34px; width:auto; display:block }


@media (min-width:1200px){ .brand-img{ height:38px } }

.primary-nav .menu{ 
    list-style:none; 
    margin:0; 
    padding:0; 
    display:flex; gap:44px 
    
}

.primary-nav .menu a{ 
    font-weight:600 
    
}

.primary-nav .menu a:hover {
    color: var(--olive);
}



/* toggle (escondido no desktop) */
#nav-toggle{ position:absolute; opacity:0; pointer-events:none }
.hamburger{ display:none }



/* =========================
   HERO + VIDEO BACKGROUND
========================= */
.section{ position:relative; min-height:92vh; display:flex; align-items:center }
.center{ text-align:center }

.video-bg{ 
    position:relative; 
    overflow:hidden; 
    z-index:0 
    
}
.video-bg > video.bgvid{
  position:absolute; 
  inset:0; 
  min-width:100%; 
  min-height:100%;
  max-width: none; 
  max-height: none;
  min-width: 0; 
  min-height: 0;
  object-fit:cover; 
  z-index:0; 
  filter:saturate(.95) contrast(1.05);
}

/* Se o vídeo for vertical (definimos a classe via JS) */
#hero.video-bg.is-portrait > video.bgvid{
  width: auto;      /* largura ajusta-se à proporção */
  height: 100%;     /* encosta em altura */
}

/* Se o vídeo for horizontal (classe via JS) */
#hero.video-bg.is-landscape > video.bgvid{
  width: 100%;
  height: auto;
}

/* iOS Safari: força aceleração e evita glitches */
@supports (-webkit-touch-callout: none) {
  #hero.video-bg > video.bgvid { transform: translateZ(0); }
}


.section .overlay.soft{ background:linear-gradient(180deg, rgb(0 0 0 / 15%), rgb(0 0 0 / 10%)); }

.hero{ min-height:100vh }
.hero .hero-inner{ position:relative; z-index:2; padding-top:clamp(120px,20vh,220px) }
.hero-title{
  font-family:"Playfair Display",serif; font-weight:600; color:#fff;
  margin:0 0 32px; font-size:clamp(32px,5vw,60px); line-height:1.1;
}

/* === HERO: botão circular com texto Playfair central === */
#hero .btn-circle{
  position: relative;
  display: inline-grid;
  place-items: center;                     /* centra o texto dentro do círculo */
  width: clamp(68px, 8vw, 200px);
  height: clamp(68px, 8vw, 200px);
  border: 0.2px solid rgba(255,255,255,.9);  /* anel principal */
  border-radius: 50%;
  color: #fff;
  text-decoration: none;
  line-height: 1;
  margin-top: -48px;                       /* invade levemente o título */
  z-index: 3;                              /* acima do background/título */
  font-style: italic;
}

#hero .btn-circle span{
  font-family: "Playfair Display", serif;  /* como pediste */
  font-size: clamp(12px, 1.4vw, 16px);
  letter-spacing: .06em;
}

/* hover/focus */
#hero .btn-circle:hover{ border-color:var(--sand); color:var(--sand);}
#hero .btn-circle:focus-visible{
  outline: 2px dashed rgba(255,255,255,.85);
  outline-offset: 4px;
}

/* mobile: aproxima um pouco do título para manter a sobreposição elegante */
@media (max-width: 920px){
  #hero .btn-circle{
  position: relative;
  display: inline-grid;
  place-items: center;                     /* centra o texto dentro do círculo */
  width: clamp(88px, 8vw, 200px);
  height: clamp(88px, 8vw, 200px);
  border: 0.2px solid rgba(255,255,255,.9);  /* anel principal */
  border-radius: 50%;
  color: #fff;
  text-decoration: none;
  line-height: 1;
  top: -18px;                       /* invade levemente o título */
  z-index: 3;                              /* acima do background/título */
  font-style: italic;
}
  #hero .btn-circle:hover{ border-color:var(--sand); color:var(--sand);}
  
  
  
}

/* === botão circular com texto Playfair central === */
.btn-circle{
  position: relative;
  display: inline-grid;
  place-items: center;                     /* centra o texto dentro do círculo */
  width: clamp(68px, 8vw, 200px);
  height: clamp(68px, 8vw, 200px);
  border: 0.2px solid rgba(255,255,255,.9);  /* anel principal */
  border-radius: 50%;
  color: #fff;
  text-decoration: none;
  line-height: 1;
  margin-top: -48px;                       /* invade levemente o título */
  z-index: 3;                              /* acima do background/título */
  font-style: italic;
}

.btn-circle span{
  font-family: "Playfair Display", serif;  /* como pediste */
  font-size: clamp(12px, 1.4vw, 16px);
  letter-spacing: .06em;
}

/* hover/focus */
.btn-circle:hover{ border-color:var(--sand); color:var(--sand);}
.btn-circle:focus-visible{
  outline: 2px dashed rgba(255,255,255,.85);
  outline-offset: 4px;
}

/* mobile: aproxima um pouco do título para manter a sobreposição elegante */
@media (max-width: 920px){
  .btn-circle{
  position: relative;
  display: inline-grid;
  place-items: center;                     /* centra o texto dentro do círculo */
  width: clamp(88px, 8vw, 200px);
  height: clamp(88px, 8vw, 200px);
  border: 0.2px solid rgba(255,255,255,.9);  /* anel principal */
  border-radius: 50%;
  color: #fff;
  text-decoration: none;
  line-height: 1;
  top: -18px;                       /* invade levemente o título */
  z-index: 3;                              /* acima do background/título */
  font-style: italic;
}
  .btn-circle:hover{ border-color:var(--sand); color:var(--sand);}
  
  
  
}

/* =========================
   CARTÕES / GRELHAS / FOOTER
========================= */

.card{
  padding:28px; background:rgba(0,0,0,.28); border:1px solid rgba(255,255,255,.12);
  color:#fff; text-decoration:none; backdrop-filter:blur(6px)
}
.card .link{ display:inline-block; margin-top:8px; color:var(--sand) }
.floating-photo img{ width:100%; height:auto; border-radius:12px; box-shadow:0 20px 80px rgba(0,0,0,.4) }
blockquote{ font-size:clamp(20px,3.4vw,34px); max-width:900px; margin:0 auto }
blockquote cite{ display:block; margin-top:16px; font-size:.9rem; opacity:.8 }



/* ====== GRID 2 ====== */
.grid-2{
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 40px;
    z-index: 2;
}

/* Estilo mais clean, sem caixas escuras */
.service{
  color: #fff;
  text-align: center;
  text-decoration: none;
  max-width: 420px;
  margin: 0 auto;
}

.service h3{
  font-family: "Playfair Display", serif;
  font-size: clamp(22px, 3vw, 32px);
  margin-bottom: 12px;
  font-weight: 600;
}

.service p{
  font-size: 15px;
  line-height: 1.6;
  opacity: .85;
}

.service .link{
  display: inline-block;
  margin-top: 12px;
  font-style: italic;
  font-size: 15px;
  color: #fff;
  border-bottom: 1px solid rgba(255,255,255,.6);
  padding-bottom: 2px;
  font-family: 'Playfair Display';
}

/* Mobile: stack em 1 coluna */
@media (max-width:920px){
  .grid-2{ grid-template-columns: 1fr; gap: 28px; }
}


/* =========================
   MOBILE MENU FULLSCREEN FIX
========================= */
@media (max-width:920px){
  :root{ --header-h:64px }

  /* Header acima de tudo e clicável */
  .site-header.transparent{
    top:max(env(safe-area-inset-top),0px);
    padding:22px 0;
    z-index:1001;
  }
  .hamburger{
    display:block; width:36px; height:28px;
    position:relative; cursor:pointer;
    z-index:1101;
  }
  .hamburger span{
    position:absolute; left:0; right:0;
    height:2px; background:#fff; border-radius:2px;
    transition:transform .25s ease, top .25s ease, opacity .2s;
  }
  .hamburger span:nth-child(1){ top:4px }
  .hamburger span:nth-child(2){ top:13px }
  .hamburger span:nth-child(3){ top:22px }
  #nav-toggle{ position:absolute; opacity:0; pointer-events:none; }
  #nav-toggle:checked + .hamburger span:nth-child(1){ top:13px; transform:rotate(45deg) }
  #nav-toggle:checked + .hamburger span:nth-child(2){ opacity:0 }
  #nav-toggle:checked + .hamburger span:nth-child(3){ top:13px; transform:rotate(-45deg) }

  /* Painel ocupa tela inteira mas com padding-top para não colar no header */
  .primary-nav{
    position:fixed; inset:0; z-index:950;
    display:flex; flex-direction:column; align-items:center;
    justify-content:flex-start;              /* começamos no topo */
    padding-top: calc(var(--header-h) + 40px); /* espaço abaixo do header */
    opacity:0; visibility:hidden; pointer-events:none;
    transform:translateY(-8px);
    transition:opacity .25s ease, transform .25s ease, visibility 0s linear .25s;
  }


  /* Estado aberto */
  #nav-toggle:checked ~ .primary-nav{
    opacity:1; visibility:visible; pointer-events:auto; transform:none;
    transition:opacity .25s ease, transform .25s ease, visibility 0s;
  }

  /* Lista de links */
  .primary-nav .menu{
    position:relative; z-index:1;
    display:flex; flex-direction:column; align-items:center;
    gap:22px; margin:0; padding:0; list-style:none;
    width:100%;
  }
  .primary-nav .menu a{
    display:block; padding:10px 16px;
    font-size:18px; font-weight:600; text-align:center; color:#fff;
  }

  /* Header também recebe vidro quando menu aberto */
  .menu-open .site-header.transparent{
    background:rgba(10,10,10,.25);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
  }

  /* Bloqueia scroll do body */
  .no-scroll{ overflow:hidden; }
}

/* ===== MOBILE MENU — fullscreen overlay + header por cima ===== */
@media (max-width:920px){
  :root{ --header-h:64px }

  /* Header acima do painel e clicável */
  .site-header.transparent{
    top:max(env(safe-area-inset-top),0px);
    padding:22px 0;
    z-index:1001;
  }
  .hamburger{
    display:block; width:36px; height:28px;
    position:relative; cursor:pointer; z-index:1101;
  }
  .hamburger span{
    position:absolute; left:0; right:0; height:2px; background:#fff; border-radius:2px;
    transition:transform .25s ease, top .25s ease, opacity .2s;
  }
  .hamburger span:nth-child(1){ top:4px }
  .hamburger span:nth-child(2){ top:13px }
  .hamburger span:nth-child(3){ top:22px }
  #nav-toggle{ position:absolute; opacity:0; pointer-events:none; }
  #nav-toggle:checked + .hamburger span:nth-child(1){ top:13px; transform:rotate(45deg) }
  #nav-toggle:checked + .hamburger span:nth-child(2){ opacity:0 }
  #nav-toggle:checked + .hamburger span:nth-child(3){ top:13px; transform:rotate(-45deg) }

  /* Painel do menu (sem fundo) — fica por cima do overlay e abaixo do header */
  .primary-nav{
    position:fixed; inset:0; z-index:950;
    display:flex; flex-direction:column; align-items:center;
    justify-content:flex-start;
    padding-top: calc(var(--header-h) + 40px);
    opacity:0; visibility:hidden; pointer-events:none;
    transform:translateY(-8px);
    transition:opacity .25s ease, transform .25s ease, visibility 0s linear .25s;
    background: transparent;           /* <<< sem fundo aqui */
    backdrop-filter: none;
  }
  #nav-toggle:checked ~ .primary-nav{
    opacity:1; visibility:visible; pointer-events:auto; transform:none;
    transition:opacity .25s ease, transform .25s ease, visibility 0s;
  }
  .primary-nav .menu{
    position:relative; z-index:1;
    display:flex; flex-direction:column; align-items:center;
    gap:22px; margin:0; padding:0; list-style:none; width:100%;
  }
  .primary-nav .menu a{
    display:block; padding:10px 16px; font-size:18px; font-weight:600;
    text-align:center; color:#fff;
  }

  /* OVERLAY FULLSCREEN no BODY quando o menu está aberto */
  body.menu-open::before{
    content:"";
    position:fixed; inset:0; z-index:900;        /* abaixo do header (1001) e do nav (950) */
    background: rgba(10,10,10,.25);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
  }

  /* Header também recebe o mesmo “vidro” para continuidade visual */
  .menu-open .site-header.transparent{
    background: rgba(10,10,10,.25);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
  }

  /* Bloqueia scroll do body quando aberto */
  .no-scroll{ overflow:hidden; }
}
@media (max-width:920px){
  .primary-nav{
    position:fixed; inset:0; z-index:950;
    display:flex; flex-direction:column; align-items:center;
    justify-content:flex-start;
    padding-top: calc(var(--header-h) + 40px);

    /* estado fechado */
    opacity:0; visibility:hidden; pointer-events:none;
    transform:translateY(-8px);
    transition:opacity .25s ease, transform .25s ease, visibility 0s linear .25s;

    /* 🔑 garante que não exista nenhum fundo próprio */
    background: transparent !important;
    backdrop-filter: none !important;
  }
}

 /* =========================
   VIDEO-BG UNIVERSAL
========================= */
.video-bg{
  position: relative;
  overflow: hidden;
  z-index: 0; /* stacking context */
  min-height: 100vh; /* garante altura mínima tela cheia */
}

.video-bg > video.bgvid{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;   /* cobre sempre */
  z-index: 0;
  filter: saturate(.95) contrast(1.05);
}

/* overlay por cima do vídeo */
.video-bg .overlay{
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(180deg, rgb(0 0 0 / 15%), rgb(0 0 0 / 10%));
}
.video-bg .overlay.soft{
  background: linear-gradient(180deg, rgb(0 0 0 / 15%), rgb(0 0 0 / 10%));
}

/* conteúdo vem por cima */
.video-bg .container{
  position: relative;
  z-index: 2;
}
/* ===== SECTION 3 — Editorial ===== */

.editorial-inner{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  align-items:center;
  gap: clamp(28px, 6vw, 56px);
}

#editorial .copy{
  max-width: 820px;
  color:#fff;
}

#editorial .kicker{
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  opacity:.8;
  margin-bottom:14px;
}

#editorial .editorial-title{
  font-family:"Playfair Display",serif;
  font-weight:600;
  font-size:clamp(28px,4.6vw,54px);
  line-height:1.1;
  margin:0 0 14px;
  text-transform:uppercase;
  letter-spacing:.02em;
}

#editorial .editorial-text{
  font-size:16px;
  line-height:1.7;
  opacity:.9;
  margin:0 0 18px;
  max-width: 60ch;
}

#editorial .editorial-cta{
  display:inline-block;
  font-style:italic;
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,.7);
  padding-bottom:2px;
  font-family: 'Playfair Display';
}

/* Foto flutuante com raio e sombra suave */
#editorial .floating-photo{
  position:relative;
  transform: translateY(6px); /* leve desnível para parecer “flutuante” */
}
#editorial .floating-photo img{
  display:block;
  width:100%; height:auto;
  border-radius:18px;
  box-shadow: 0 28px 90px rgba(0,0,0,.40);
}

/* Responsivo */
@media (max-width: 980px){
  .editorial-inner{
    grid-template-columns:1fr; 
    text-align:center;
  }
  #editorial .copy{ margin-inline:auto; }
  #editorial .editorial-text{ margin-inline:auto; }
  #editorial .floating-photo{ max-width: 520px; margin: 8px auto 0; transform:none; }
}

/* ===== SECTION 4 — Testimonials ===== */

.testimonials-inner{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(24px, 5vw, 60px);
  align-items:center;
}

.quote{
  position:relative;
  color:#fff;
  max-width: 720px;
  margin: 0 auto;
}

.quote blockquote{
  font-family:"Playfair Display", serif;
  font-style: italic;
  font-size: clamp(20px, 3.2vw, 34px);
  line-height: 1.35;
  margin: 0 0 14px;
}

.quote figcaption{
  font-size: 14px;
  opacity: .9;
}

/* Anel circular decorativo (varia a posição p/ cada lado) */
.quote .ring{
  position:absolute;
  width: clamp(120px, 18vw, 180px);
  height: clamp(120px, 18vw, 180px);
  border: .2px solid rgba(255,255,255,.55);
  border-radius: 50%;
  pointer-events: none;
}

.quote--left .ring{ left: -24px; top: -10px; }
.quote--right .ring{ left: -12%; top: -16px; } /* move mais para o centro do bloco */

.quote:hover .ring{ border-color: rgba(255,255,255,.8); }

/* Responsivo */
@media (max-width: 980px){
  .testimonials-inner{ grid-template-columns:1fr; gap: 86px; }
  .quote .ring{ left: -10px; top: -8px; }
}

/* ===== FOOTER CONTACT SECTION (2 colunas) ===== */
.contact-inner.two-cols{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: start;
  min-height: 60vh;
  color: #fff;
  text-align: left;
}

.contact-block h2{
  font-family: "Playfair Display", serif;
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 600;
  margin: 0 0 16px;
}

.contact-block p,
.hours-block li{
  font-family: "Lato", sans-serif;
  font-size: 15px;
  line-height: 1.6;
  margin: 6px 0;
}

.contact-block a{
  color:#fff;
  text-decoration:none;
}
.contact-block a:hover{ text-decoration:underline; }


/* horários */
.hours-block ul{
  list-style:none;
  margin:0; padding:0;
}
.hours-block li{
  opacity:.9;
  text-align:right;
}

/* rodapé inferior */
.site-footer .wrap{
  border-top:1px solid rgba(255,255,255,.15);
  padding:16px 0;
  text-align:center;
  font-size:13px;
  opacity:.8;
}

/* mobile */
@media (max-width:920px){
  .contact-inner.two-cols{
    grid-template-columns: 1fr;
    text-align:center;
    gap: 24px;
  }
  .hours-block li{ text-align:center; }
}

/* ===== ABOUT page ===== */
.about-hero-inner{ padding-top: clamp(140px, 22vh, 240px); }
.about-hero-title{
  font-family:"Playfair Display",serif; font-weight:600;
  font-size: clamp(32px, 5.2vw, 62px); line-height:1.08; margin:0 0 10px;
}
.about-hero-sub{ opacity:.9; max-width: 60ch; margin: 0 auto; }

.about-section{ padding: clamp(60px, 12vw, 120px) 0; }

.about-grid{
  display:grid; grid-template-columns: 1.15fr .85fr; gap: clamp(28px, 6vw, 56px); align-items:center;
}
.about-copy{ color:#fff; }
.about-title{
  font-family:"Playfair Display",serif; font-weight:600;
  font-size: clamp(26px, 4.2vw, 48px); line-height:1.12; margin:0 0 14px;
}
.about-copy p{ opacity:.9; line-height:1.7; margin: 0 0 14px; }
.about-photo img{ width:100%; height:auto; border-radius:18px; box-shadow:0 28px 90px rgba(0,0,0,.4) }

#philosophy .about-values{ color:#fff; max-width: 900px; }
#philosophy .kicker{ letter-spacing:.18em; text-transform:uppercase; opacity:.85; font-size:12px; margin-bottom:10px; }
.values-list{ margin:16px 0 0; padding:0; list-style:none; display:grid; gap:10px; }
.values-list li{ opacity:.95; }
.values-list strong{ font-weight:600; }

.pillar h3{
  font-family:"Playfair Display",serif; font-size: clamp(22px, 3vw, 32px); margin-bottom: 10px; font-weight:600;
}

.section#pillars {
    background: var(--dark-gold);
}
.pillar p{ opacity:.9; line-height:1.65; max-width:52ch; margin:0 auto 8px; }
.pillar .link{ display:inline-block; margin-top:8px; font-style:italic; border-bottom:1px solid rgba(255,255,255,.7); padding-bottom:2px; }

.about-cta-inner .about-title{ margin-bottom:8px; }
#about-cta p{ opacity:.9; margin-bottom:10px; }

/* Responsive */
@media (max-width: 980px){
  .about-grid{ grid-template-columns:1fr; text-align:center; }
  .about-copy{ margin-inline:auto; }
  .about-photo{ max-width:520px; margin: 8px auto 0; }
}

/* ===== Massage page ===== */
#massage-hero .hero-title{
  font-family:"Playfair Display",serif;
  font-size: clamp(32px, 5vw, 60px);
  line-height: 1.2;
}
#massage-hero .hero-title span{
  font-size: clamp(20px, 3vw, 28px);
  font-weight: 400;
  display: block;
  margin-top: 6px;
}

#massage-intro p{
  font-size: 17px;
  line-height: 1.7;
  max-width: 70ch;
  margin: 0 auto;
  opacity: .9;
}

.grid-4{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
}
.grid-4 .card{
  background: rgba(0,0,0,.28);
  border: 1px solid rgba(255,255,255,.12);
  padding: 24px;
  border-radius: 12px;
  backdrop-filter: blur(6px);
  color:#fff;
}
.grid-4 h3{
  font-family:"Playfair Display",serif;
  margin-bottom: 10px;
  font-size: 20px;
}
.grid-4 p{ font-size: 15px; line-height:1.6; }

.photo-section{
  padding: 0;
  background: var(--dark-gold);
}
.photo-section .photo-full{
  width: 100%;
  height: auto;
  display: block;
}

/* responsivo */
@media (max-width: 980px){
  .grid-4{ grid-template-columns: 1fr; }
  #massage-hero .hero-title{ font-size: clamp(26px, 8vw, 42px); }
}


/* ============================================ 
Beauty page 
=============================================== */
#beauty-hero .hero-title{
  font-family:"Playfair Display",serif;
  font-size: clamp(32px, 5vw, 60px);
  line-height: 1.2;
}
#beauty-hero .hero-title span{
  font-size: clamp(20px, 3vw, 28px);
  font-weight: 400;
  display: block;
  margin-top: 6px;
}

#beauty-intro p{
  font-size: 17px;
  line-height: 1.7;
  max-width: 70ch;
  margin: 0 auto;
  opacity: .9;
}

/* Reaproveita a tua grid-4/card existentes da Massage page */
#beauty-services .grid-4 .card h3{
  font-family:"Playfair Display",serif;
  margin-bottom:10px;
  font-size:20px;
}
#beauty-services .grid-4 .card p{ font-size:15px; line-height:1.6; }

/* Seção de imagem com dark gold */
#beauty-photo.photo-section{
  padding: 0;
  background: var(--dark-gold);
}
#beauty-photo .photo-full{
  width:100%; height:auto; display:block;
}

/* Responsivo */
@media (max-width: 980px){
  #beauty-hero .hero-title{ font-size: clamp(26px, 8vw, 42px); }
}


/* ===================================== 
Contact page 
======================================== */
section#contact-intro {
    background: var(--dark-gold);
}

#contact-hero .hero-title{
  font-family:"Playfair Display",serif;
  font-size: clamp(32px, 5vw, 56px);
  line-height: 1.2;
}

.contact-grid{
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 40px;
  padding: 40px 0;
}
.contact-block h3{
  font-family:"Playfair Display",serif;
  font-size: 20px;
  margin-bottom: 8px;
}
.contact-block p{ margin:0 0 18px; }

.map-embed iframe{
  width: 100%;
  border-radius: 12px;
  box-shadow: 0 10px 40px rgba(0,0,0,.3);
}

/* Mobile */
@media (max-width: 920px){
  .contact-grid{ grid-template-columns: 1fr; gap: 28px; }
}

/* Evita qualquer scroll lateral que deixe “aparecer” o fundo */
html, body { overflow-x: hidden; }

/* Vídeo SEMPRE a cobrir o contêiner, inclusive em webview iOS */
.video-bg { position: relative; overflow: hidden; z-index: 0; }
.video-bg > video.bgvid{
  position: absolute; left: 0; top: 0; right: 0; bottom: 0;
  width: 100%; height: 100%;
  min-width: 100%; min-height: 100%;
  object-fit: cover; object-position: center center;
  z-index: 0;
  /* impede clique no vídeo (evita mostrar UI nativa ao toque) */
  pointer-events: none;
}

/* iOS/Instagram: força compositor a “colar” o vídeo e evitar gaps sub-pixel */
@supports (-webkit-touch-callout: none) {
  .video-bg > video.bgvid{
    transform: translateZ(0.001px);
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
  }
}

/* Esconde UI de controles caso algum apareça por bug */
video::-webkit-media-controls { display:none !important; }
video::-webkit-media-controls-enclosure { display:none !important; }
