/* =================================================================
   IATE CLUBE DE ITACURUÇÁ — folha de estilo principal
   Paleta naval · tipografia editorial · layout responsivo
   ================================================================= */

/* Fonte de títulos premium (Fraunces, variável c/ optical sizing).
   Carregada de forma central → aplica em TODAS as páginas. */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,400;1,9..144,500;1,9..144,600&display=swap');

:root{
  /* Cores base */
  --navy-950:#081a2a;
  --navy-900:#0c2335;
  --navy-800:#122d44;
  --navy-700:#1b3b56;
  --navy-600:#27506e;
  --coral:#cf6f61;          /* acento principal */
  --coral-bright:#d98377;   /* itálico do título */
  --coral-deep:#b8584b;
  --cream:#f3efe7;
  --paper:#faf8f3;
  --sand:#e9e2d4;
  --ink:#152331;
  --muted:#5d6b78;
  --white-90:rgba(255,255,255,.9);
  --white-70:rgba(255,255,255,.72);
  --white-50:rgba(255,255,255,.5);

  /* Tipografia */
  --serif:'Fraunces', 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:'Jost', 'Trebuchet MS', system-ui, sans-serif;

  /* Medidas */
  --maxw:1240px;
  --radius:2px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  font-weight:300;
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ---------- utilidades ---------- */
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,56px)}
.eyebrow{
  font-family:var(--sans);font-weight:400;font-size:.72rem;
  letter-spacing:.32em;text-transform:uppercase;
}
.serif{font-family:var(--serif)}
.coral{color:var(--coral)}
.rule{width:46px;height:1px;background:var(--coral);display:inline-block;vertical-align:middle}

/* Refino tipográfico dos títulos (Fraunces variável) — ar editorial premium */
h1,h2,h3,h4,h5,h6,.hero2__title,.brand-name{font-optical-sizing:auto}
h1,h2,h3{letter-spacing:-.012em}

/* =================================================================
   NAVEGAÇÃO (topo)
   ================================================================= */
.nav{
  position:fixed;display:flex;top:0;left:0;right:0;z-index:50;
  align-items:center;justify-content:space-between;
  padding:18px clamp(20px,5vw,56px);
  transition:background .4s var(--ease), padding .4s var(--ease), box-shadow .4s var(--ease);
}
.nav.is-solid{
  background:rgba(9,27,42,.92);
  backdrop-filter:blur(10px);
  padding-top:12px;padding-bottom:12px;
  box-shadow:0 8px 30px rgba(0,0,0,.25);
}
.brand{display:flex;align-items:center;gap:13px;color:#fff}
.brand-mark{width:38px;height:38px;flex:0 0 auto}
.brand-name{font-family:var(--serif);font-size:1.35rem;letter-spacing:.04em;line-height:1;font-weight:500}
.brand-tag{font-size:.6rem;letter-spacing:.34em;text-transform:uppercase;color:var(--white-70);margin-top:3px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{
  color:var(--white-90);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;font-weight:400;
  position:relative;padding:4px 0;transition:color .25s var(--ease);
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;background:var(--coral);
  transition:width .3s var(--ease);
}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:#fff}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{width:100%}

/* redes sociais no topo (ao lado de Contato) */
.nav-soc a{
  display:grid;place-items:center;
  width:36px;height:36px;border-radius:50%;padding:0;
  border:1px solid rgba(255,255,255,.4);color:#fff;
  animation:navSocPulse 2.8s var(--ease) infinite;
  transition:transform .3s var(--ease),background .3s var(--ease),border-color .3s var(--ease),box-shadow .3s var(--ease);
}
.nav-soc + .nav-soc{margin-left:-16px}
.nav-soc a svg{width:16px;height:16px}
.nav-soc a::after{display:none}
.nav-soc a:hover{
  background:var(--coral);border-color:var(--coral);
  transform:translateY(-2px) scale(1.08);
  box-shadow:0 12px 26px rgba(184,88,75,.4);
  animation:none;
}
@keyframes navSocPulse{
  0%{box-shadow:0 0 0 0 rgba(207,111,97,.55)}
  70%{box-shadow:0 0 0 9px rgba(207,111,97,0)}
  100%{box-shadow:0 0 0 0 rgba(207,111,97,0)}
}

.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:34px;height:28px;position:relative}
.nav-toggle span{position:absolute;left:0;right:0;height:2px;background:#fff;transition:.3s var(--ease)}
.nav-toggle span:nth-child(1){top:4px}
.nav-toggle span:nth-child(2){top:13px}
.nav-toggle span:nth-child(3){top:22px}
.nav-toggle.is-open span:nth-child(1){top:13px;transform:rotate(45deg)}
.nav-toggle.is-open span:nth-child(2){opacity:0}
.nav-toggle.is-open span:nth-child(3){top:13px;transform:rotate(-45deg)}

/* =================================================================
   HERO — página inicial
   ================================================================= */
.hero{
  --frame-x:clamp(16px,3vw,30px);
  --frame-top:clamp(86px,10vw,116px);
  --frame-bottom:clamp(20px,3vw,30px);
  position:relative;min-height:78vh;min-height:78svh;
  display:flex;flex-direction:column;justify-content:center;
  color:#fff;
  background:var(--navy-950);
  isolation:isolate;
  padding:var(--frame-top) var(--frame-x) var(--frame-bottom);
}
.hero__bg{
  position:absolute;z-index:-2;
  top:var(--frame-top);right:var(--frame-x);bottom:var(--frame-bottom);left:var(--frame-x);
  border-radius:16px;
  background:var(--navy-900) url('../assets/hero.jpg?v=3') center/cover;
  box-shadow:0 30px 70px rgba(8,24,38,.32);
}
.hero__overlay{
  position:absolute;z-index:-1;
  top:var(--frame-top);right:var(--frame-x);bottom:var(--frame-bottom);left:var(--frame-x);
  border-radius:16px;
  background:
    linear-gradient(100deg, rgba(8,24,38,.70) 0%, rgba(8,24,38,.34) 48%, rgba(8,24,38,.08) 100%),
    linear-gradient(0deg, rgba(8,24,38,.68) 0%, rgba(8,24,38,0) 52%);
}
.hero .wrap{position:relative;z-index:1;padding-top:clamp(20px,4vw,40px);padding-bottom:clamp(84px,11vw,118px)}
.hero .eyebrow{color:var(--white-90);display:flex;align-items:center;gap:16px;margin-bottom:26px}
.hero h1{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(2.9rem,7.2vw,5.6rem);
  line-height:1.02;letter-spacing:.005em;
  text-shadow:0 2px 30px rgba(0,0,0,.35);
}
.hero h1 em,.hero h1 span{display:block;font-style:italic;color:var(--coral-bright);font-weight:500}
.hero__lead{
  margin-top:30px;max-width:560px;
  font-size:clamp(1rem,1.5vw,1.18rem);font-weight:300;color:var(--white-90);
  line-height:1.7;
}
.dest{display:flex;flex-wrap:wrap;gap:14px;margin-top:46px;max-width:680px}
.dest a{
  display:inline-flex;align-items:center;justify-content:center;
  padding:16px 22px;min-width:120px;
  border:1px solid rgba(255,255,255,.4);
  border-radius:var(--radius);
  font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:400;
  color:#fff;background:rgba(255,255,255,.04);
  backdrop-filter:blur(2px);
  transition:all .3s var(--ease);
}
.dest a:hover{
  border-color:var(--coral);
  background:var(--coral);
  transform:translateY(-3px);
  box-shadow:0 14px 30px rgba(184,88,75,.35);
}
/* rodapé do hero: 81 anos + navegue */
.hero__foot{
  position:absolute;left:var(--frame-x);right:var(--frame-x);bottom:var(--frame-bottom);
  padding:0 clamp(20px,5vw,56px) 30px;
  display:flex;align-items:flex-end;justify-content:space-between;gap:20px;
}
.years__num{font-family:var(--serif);font-style:italic;font-size:clamp(2.6rem,5vw,3.6rem);color:var(--coral-bright);line-height:.9}
.years__lbl{font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--white-70);margin-top:6px}
.scrollcue{display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--white-70)}
.scrollcue span{font-size:.64rem;letter-spacing:.34em;text-transform:uppercase}
.scrollcue i{width:1px;height:54px;background:linear-gradient(var(--white-50),transparent);display:block}

/* =================================================================
   CABEÇALHO INTERNO (subpáginas)
   ================================================================= */
.phead{
  position:relative;color:#fff;overflow:hidden;
  padding:clamp(130px,18vw,180px) 0 clamp(48px,7vw,72px);
  background:linear-gradient(120deg,var(--navy-950),var(--navy-800) 60%,var(--navy-700));
}
.phead::after{
  content:"";position:absolute;right:-60px;top:50%;transform:translateY(-50%);
  width:420px;height:420px;opacity:.08;pointer-events:none;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cg fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round'%3E%3Ccircle cx='50' cy='50' r='40'/%3E%3Ccircle cx='50' cy='50' r='32'/%3E%3Ccircle cx='50' cy='50' r='8'/%3E%3Cline x1='50' y1='42' x2='50' y2='18'/%3E%3Cline x1='55.66' y1='44.34' x2='72.63' y2='27.37'/%3E%3Cline x1='58' y1='50' x2='82' y2='50'/%3E%3Cline x1='55.66' y1='55.66' x2='72.63' y2='72.63'/%3E%3Cline x1='50' y1='58' x2='50' y2='82'/%3E%3Cline x1='44.34' y1='55.66' x2='27.37' y2='72.63'/%3E%3Cline x1='42' y1='50' x2='18' y2='50'/%3E%3Cline x1='44.34' y1='44.34' x2='27.37' y2='27.37'/%3E%3Cline x1='50' y1='10' x2='50' y2='4'/%3E%3Cline x1='78.28' y1='21.72' x2='82.53' y2='17.47'/%3E%3Cline x1='90' y1='50' x2='96' y2='50'/%3E%3Cline x1='78.28' y1='78.28' x2='82.53' y2='82.53'/%3E%3Cline x1='50' y1='90' x2='50' y2='96'/%3E%3Cline x1='21.72' y1='78.28' x2='17.47' y2='82.53'/%3E%3Cline x1='10' y1='50' x2='4' y2='50'/%3E%3Cline x1='21.72' y1='21.72' x2='17.47' y2='17.47'/%3E%3Ccircle cx='50' cy='4' r='2.4'/%3E%3Ccircle cx='82.53' cy='17.47' r='2.4'/%3E%3Ccircle cx='96' cy='50' r='2.4'/%3E%3Ccircle cx='82.53' cy='82.53' r='2.4'/%3E%3Ccircle cx='50' cy='96' r='2.4'/%3E%3Ccircle cx='17.47' cy='82.53' r='2.4'/%3E%3Ccircle cx='4' cy='50' r='2.4'/%3E%3Ccircle cx='17.47' cy='17.47' r='2.4'/%3E%3C/g%3E%3C/svg%3E") center/contain no-repeat;
}
.phead .eyebrow{color:var(--coral-bright);display:flex;align-items:center;gap:14px;margin-bottom:18px}
.phead h1{font-family:var(--serif);font-weight:500;font-size:clamp(2.4rem,5.5vw,3.9rem);line-height:1.05}
.phead p{margin-top:18px;max-width:620px;color:var(--white-90);font-weight:300}

/* =================================================================
   SEÇÕES DE CONTEÚDO
   ================================================================= */
.section{padding:clamp(56px,8vw,96px) 0}
.section--cream{background:var(--cream)}
.section--paper{background:var(--paper)}
.section--navy{background:var(--navy-900);color:#fff}
.section-head{max-width:680px;margin-bottom:46px}
.section-head .eyebrow{color:var(--coral-deep);display:flex;align-items:center;gap:14px;margin-bottom:14px}
.section-head h2{font-family:var(--serif);font-weight:500;font-size:clamp(1.9rem,4vw,2.8rem);line-height:1.1;color:var(--ink)}
.section--navy .section-head h2{color:#fff}
.section-head p{margin-top:16px;color:var(--muted);font-size:1.02rem}
.section--navy .section-head p{color:var(--white-70)}

/* publicações (revistas) */
.pubs{display:flex;flex-wrap:wrap;gap:40px}
.pub{width:280px;cursor:pointer}
.pub__cover{
  position:relative;aspect-ratio:3/4;border-radius:var(--radius);overflow:hidden;
  background:linear-gradient(150deg,var(--navy-700),var(--navy-900));
  box-shadow:0 22px 45px rgba(12,35,53,.28);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.pub:hover .pub__cover{transform:translateY(-8px) rotate(-.6deg);box-shadow:0 30px 60px rgba(12,35,53,.4)}
.pub__cover img{width:100%;height:100%;object-fit:cover}
.pub__badge{
  position:absolute;top:12px;left:12px;
  background:var(--coral);color:#fff;
  font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;padding:6px 11px;border-radius:2px;
}
.pub__open{
  position:absolute;inset:0;display:grid;place-items:center;
  background:rgba(8,24,38,.55);opacity:0;transition:.3s var(--ease);
}
.pub:hover .pub__open{opacity:1}
.pub__open span{
  border:1px solid #fff;color:#fff;padding:11px 20px;border-radius:2px;
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
}
.pub__meta{margin-top:18px}
.pub__meta h3{font-family:var(--serif);font-size:1.5rem;font-weight:500;color:var(--ink)}
.pub__meta p{color:var(--muted);font-size:.9rem;margin-top:3px}

/* bloco "em breve" (eventos / restaurante sem conteúdo ainda) */
.soon{
  display:flex;flex-direction:column;align-items:flex-start;gap:22px;
  padding:clamp(40px,6vw,72px);
  border:1px solid var(--sand);border-radius:var(--radius);
  background:linear-gradient(135deg,#fff,var(--cream));
}
.soon .tag{font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;color:var(--coral-deep)}
.soon h3{font-family:var(--serif);font-size:clamp(1.8rem,4vw,2.6rem);font-weight:500;color:var(--ink);line-height:1.1}
.soon p{max-width:560px;color:var(--muted)}

/* prosa / texto corrido */
.prose{max-width:760px}
.prose p{margin-bottom:18px;color:#33424f;font-size:1.05rem}
/* seção O Clube: texto + foto */
.club-intro{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,56px);align-items:stretch;margin-bottom:46px}
.club-intro .section-head{margin-bottom:0;align-self:center}
.club-intro__media{border-radius:14px;overflow:hidden;box-shadow:0 24px 50px rgba(8,24,38,.18);min-height:340px}
.club-intro__media img{width:100%;height:100%;object-fit:cover}
@media(max-width:760px){
  .club-intro{grid-template-columns:1fr;gap:30px}
  .club-intro__media{min-height:0}
  .club-intro__media img{aspect-ratio:4/3;height:auto}
}

.feature-grid{display:grid;gap:26px;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));margin-top:18px}
.feature{padding:26px;background:#fff;border:1px solid var(--sand);border-radius:var(--radius)}
.feature h4{font-family:var(--serif);font-size:1.35rem;font-weight:500;color:var(--ink);margin-bottom:8px}
.feature p{color:var(--muted);font-size:.96rem}
.feature .ic{width:40px;height:40px;color:var(--coral);margin-bottom:14px}

/* botão de texto */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border-radius:var(--radius);
  font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;font-weight:400;
  transition:all .3s var(--ease);
}
.btn--solid{background:var(--coral);color:#fff}
.btn--solid:hover{background:var(--coral-deep);transform:translateY(-2px)}
.btn--ghost{border:1px solid var(--navy-700);color:var(--navy-800)}
.btn--ghost:hover{background:var(--navy-800);color:#fff}

/* =================================================================
   RESTAURANTE — prévia do Instagram + links (link na bio)
   ================================================================= */
.ig-preview{display:flex;flex-direction:column;align-items:center;gap:28px;margin-top:8px}
.ig-card{
  display:block;width:100%;max-width:460px;
  background:#fff;border-radius:16px;overflow:hidden;
  box-shadow:0 24px 50px rgba(8,24,38,.16);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.ig-card:hover{transform:translateY(-4px);box-shadow:0 32px 64px rgba(8,24,38,.24)}
.ig-card__head{display:flex;align-items:center;gap:12px;padding:14px 16px}
.ig-card__avatar{
  width:42px;height:42px;border-radius:50%;flex:0 0 auto;
  display:grid;place-items:center;color:#fff;
  background:linear-gradient(45deg,#feda75,#fa7e1e,#d62976,#962fbf,#4f5bd5);
}
.ig-card__avatar svg{width:21px;height:21px}
.ig-card__name{display:flex;flex-direction:column;line-height:1.2;font-family:var(--sans);font-weight:500;font-size:.94rem;color:var(--ink)}
.ig-card__name small{font-weight:300;font-size:.76rem;color:var(--muted);margin-top:2px}
.ig-card__media{aspect-ratio:1/1;background:var(--navy-800)}
.ig-card__media img{width:100%;height:100%;object-fit:cover;display:block}

.ig-chip{
  display:inline-flex;align-items:center;gap:13px;
  padding:13px 24px;border-radius:50px;color:#fff;
  background:linear-gradient(45deg,#feda75,#fa7e1e,#d62976,#962fbf,#4f5bd5);
  box-shadow:0 12px 28px rgba(214,41,118,.35);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.ig-chip:hover{transform:translateY(-2px);box-shadow:0 18px 38px rgba(214,41,118,.5)}
.ig-chip svg{width:23px;height:23px;flex:0 0 auto}
.ig-chip__txt{display:flex;flex-direction:column;line-height:1.18}
.ig-chip__txt strong{font-weight:500;font-size:.92rem;letter-spacing:.01em}
.ig-chip__txt small{font-weight:300;font-size:.68rem;opacity:.92;text-transform:uppercase;letter-spacing:.18em;margin-top:1px}

.biolinks{max-width:520px;margin:0 auto;display:flex;flex-direction:column;gap:16px}
.biolink{
  display:flex;align-items:center;justify-content:center;gap:12px;
  padding:20px 24px;border-radius:12px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.22);
  color:#fff;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;font-weight:400;
  transition:transform .3s var(--ease),background .3s var(--ease),border-color .3s var(--ease),box-shadow .3s var(--ease);
}
.biolink svg{width:18px;height:18px;flex:0 0 auto}
.biolink:hover{
  background:var(--coral);border-color:var(--coral);
  transform:translateY(-3px);
  box-shadow:0 16px 34px rgba(184,88,75,.4);
}

/* =================================================================
   BOTÕES DE AÇÃO PREMIUM — reutilizados em Restaurante, Marina e Contato
   ================================================================= */
.actbtns{display:flex;flex-direction:column;gap:16px;max-width:580px}
.actbtns--center{margin-left:auto;margin-right:auto}
.actbtn{
  position:relative;overflow:hidden;isolation:isolate;
  display:flex;align-items:center;gap:18px;width:100%;
  padding:16px 22px;border-radius:18px;
  font-family:var(--sans);font-weight:500;font-size:.86rem;letter-spacing:.12em;text-transform:uppercase;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),background .4s var(--ease),border-color .4s var(--ease),color .4s var(--ease);
}
/* badge do ícone */
.actbtn__ic{
  position:relative;z-index:3;flex:0 0 auto;
  width:48px;height:48px;border-radius:13px;
  display:grid;place-items:center;
  background:rgba(255,255,255,.16);
  transition:transform .4s var(--ease),background .4s var(--ease);
}
.actbtn__ic svg{width:24px;height:24px;display:block}
.actbtn__ic img{width:27px;height:27px;display:block}
.actbtn__ic--brand{background:#fff}
.actbtn:hover .actbtn__ic{transform:scale(1.08) rotate(-4deg)}
/* texto em duas linhas */
.actbtn__txt{position:relative;z-index:3;display:flex;flex-direction:column;gap:3px;line-height:1.15;text-align:left}
.actbtn__txt b{font-weight:600;letter-spacing:.1em}
.actbtn__txt small{font-weight:300;font-size:.7rem;letter-spacing:.04em;opacity:.82;text-transform:none}
/* seta */
.actbtn__arrow{position:relative;z-index:3;margin-left:auto;flex:0 0 auto;opacity:.55;transition:transform .4s var(--ease),opacity .4s var(--ease)}
.actbtn__arrow svg{width:20px;height:20px;display:block}
.actbtn:hover .actbtn__arrow{transform:translateX(5px);opacity:1}
/* shine sweep */
.actbtn::before{
  content:"";position:absolute;top:0;left:-75%;z-index:1;width:45%;height:100%;pointer-events:none;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.38),transparent);
  transform:skewX(-20deg);transition:left .65s var(--ease);
}
.actbtn:hover::before{left:135%}
.actbtn:focus-visible{outline:3px solid rgba(207,111,97,.75);outline-offset:3px}

.actbtn--primary{background:linear-gradient(135deg,var(--coral),var(--coral-deep));color:#fff;box-shadow:0 16px 34px rgba(184,88,75,.34)}
.actbtn--primary:hover{transform:translateY(-4px);box-shadow:0 28px 54px rgba(184,88,75,.5)}
.actbtn--light{background:#fff;color:var(--navy-800);border:1.5px solid var(--sand);box-shadow:0 12px 28px rgba(12,35,53,.08)}
.actbtn--light:hover{transform:translateY(-4px);border-color:var(--coral);box-shadow:0 24px 46px rgba(12,35,53,.16)}
.actbtn--light .actbtn__ic{background:var(--cream)}
.actbtn--dark{background:rgba(255,255,255,.06);color:#fff;border:1.5px solid rgba(255,255,255,.22)}
.actbtn--dark:hover{transform:translateY(-4px);background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.42);box-shadow:0 24px 46px rgba(0,0,0,.32)}
.actbtn--dark .actbtn__ic{background:rgba(255,255,255,.1)}
.actbtn--inline{display:inline-flex;width:auto}
@media (prefers-reduced-motion:reduce){
  .actbtn::before{display:none}
  .actbtn:hover{transform:none}
}

/* layout da página de Contato */
.contact-layout{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,4vw,56px);align-items:start}
.contact-actions .eyebrow{color:var(--coral-deep);display:flex;align-items:center;gap:14px;margin-bottom:14px}
.contact-actions h2{font-family:var(--serif);font-weight:500;font-size:clamp(1.7rem,3.4vw,2.4rem);color:var(--ink);line-height:1.1;margin-bottom:28px}
.contact-info{display:flex;flex-direction:column;gap:18px}
.contact-info .feature{margin:0}
@media (max-width:760px){.contact-layout{grid-template-columns:1fr}}

/* =================================================================
   RODAPÉ
   ================================================================= */
.footer{background:var(--navy-950);color:var(--white-70);padding:64px 0 30px}
.footer__top{display:grid;gap:40px;grid-template-columns:1.4fr 1fr 1fr}
.footer .brand{margin-bottom:16px}
.footer .brand-name{font-size:1.5rem}
.footer__about{max-width:340px;font-size:.95rem;line-height:1.7}
.footer h5{color:#fff;font-family:var(--sans);font-weight:400;font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;margin-bottom:18px}
.footer li{margin-bottom:10px;font-size:.95rem}
.footer a:hover{color:var(--coral-bright)}
.footer__social{display:flex;gap:14px;margin-top:8px}
.footer__social a{width:40px;height:40px;border:1px solid rgba(255,255,255,.18);border-radius:50%;display:grid;place-items:center;transition:.3s var(--ease)}
.footer__social a:hover{border-color:var(--coral);background:var(--coral);color:#fff}
.footer__social svg{width:18px;height:18px}
.footer__bar{margin-top:48px;padding-top:22px;border-top:1px solid rgba(255,255,255,.1);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.78rem;color:var(--white-50)}

/* =================================================================
   LIGHTBOX (galeria) e MODAL DE PDF
   ================================================================= */
.lightbox,.pdfmodal{
  position:fixed;inset:0;z-index:100;display:none;
  background:rgba(6,18,30,.94);backdrop-filter:blur(4px);
  align-items:center;justify-content:center;padding:30px;
}
.lightbox.is-open,.pdfmodal.is-open{display:flex}
.lightbox img{max-width:92vw;max-height:84vh;object-fit:contain;border-radius:2px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb-close,.pdf-close{
  position:absolute;top:22px;right:26px;background:none;border:1px solid rgba(255,255,255,.4);
  color:#fff;width:46px;height:46px;border-radius:50%;font-size:1.3rem;cursor:pointer;transition:.25s var(--ease);
}
.lb-close:hover,.pdf-close:hover{background:var(--coral);border-color:var(--coral)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:none;border:1px solid rgba(255,255,255,.35);
  color:#fff;width:54px;height:54px;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:.25s var(--ease)}
.lb-nav:hover{background:var(--coral);border-color:var(--coral)}
.lb-prev{left:24px}
.lb-next{right:24px}
.lb-caption{position:absolute;bottom:26px;left:0;right:0;text-align:center;color:var(--white-70);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase}
.pdfmodal__frame{width:min(1000px,94vw);height:88vh;background:#fff;border-radius:2px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.pdfmodal__frame iframe{width:100%;height:100%;border:0}
.pdfmodal__bar{position:absolute;top:22px;left:26px;display:flex;gap:12px}
.pdfmodal__bar a{border:1px solid rgba(255,255,255,.4);color:#fff;padding:9px 16px;border-radius:2px;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase}
.pdfmodal__bar a:hover{background:var(--coral);border-color:var(--coral)}

/* no desktop o cabeçalho do modal "some" (o X continua absoluto, como sempre) */
.pdfmodal__head{display:contents}

/* --- Modal de PDF no MOBILE: tela cheia, PDF ajustado à largura,
       cabeçalho com X (sempre visível) e botões reais (coral, com ícone)
       no rodapé. Desktop permanece como está. --- */
@media (max-width:640px){
  .pdfmodal{flex-direction:column;align-items:stretch;justify-content:flex-start;padding:0}
  /* cabeçalho: barra escura de largura total com o X à direita (fora da área
     do PDF, sempre visível e acessível) */
  .pdfmodal__head{
    order:0;display:flex;align-items:center;justify-content:flex-end;
    width:100%;padding:8px 12px;background:rgba(6,18,30,.96);
  }
  .pdf-close{
    position:static;width:44px;height:44px;
    background:var(--coral);border-color:var(--coral);color:#fff;
    box-shadow:0 6px 16px rgba(0,0,0,.35);
  }
  .pdfmodal__frame{
    order:1;flex:1 1 auto;min-height:0;
    width:100%;height:auto;border-radius:0;
  }
  .pdfmodal__bar{
    order:2;position:static;top:auto;left:auto;width:100%;
    flex-direction:column;gap:10px;
    padding:12px 14px calc(14px + env(safe-area-inset-bottom,0px));
    background:rgba(6,18,30,.96);
  }
  .pdfmodal__bar a{
    width:100%;display:flex;align-items:center;justify-content:center;gap:9px;
    padding:14px 12px;border-radius:12px;font-size:.72rem;letter-spacing:.08em;white-space:nowrap;
    background:linear-gradient(135deg,var(--coral),var(--coral-deep));
    border-color:transparent;color:#fff;box-shadow:0 12px 26px rgba(184,88,75,.42);
    transition:filter .25s var(--ease),box-shadow .25s var(--ease);
  }
  .pdfmodal__bar a:hover,.pdfmodal__bar a:focus-visible{background:linear-gradient(135deg,var(--coral),var(--coral-deep));filter:brightness(1.07)}
  .pdfmodal__bar a:focus-visible{outline:3px solid var(--coral-bright);outline-offset:2px}
  .pdfmodal__bar a::before{
    content:"";width:16px;height:16px;flex:0 0 auto;
    background-position:center;background-repeat:no-repeat;background-size:contain;
  }
  .pdfmodal__bar a[data-pdf-open]::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M15 3h6v6'/%3E%3Cpath d='M10 14 21 3'/%3E%3Cpath d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'/%3E%3C/svg%3E")}
  .pdfmodal__bar a[data-pdf-download]::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'/%3E%3Cpath d='M7 10l5 5 5-5'/%3E%3Cpath d='M12 15V3'/%3E%3C/svg%3E")}
}

/* =================================================================
   ANIMAÇÕES
   ================================================================= */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].is-visible{opacity:1;transform:none}
.hero [data-anim]{opacity:0;transform:translateY(22px);animation:rise .9s var(--ease) forwards}
.hero [data-anim="1"]{animation-delay:.15s}
.hero [data-anim="2"]{animation-delay:.30s}
.hero [data-anim="3"]{animation-delay:.45s}
.hero [data-anim="4"]{animation-delay:.62s}
.hero [data-anim="5"]{animation-delay:.80s}
@keyframes rise{to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  [data-reveal]{opacity:1;transform:none}
}

/* =================================================================
   RESPONSIVO
   ================================================================= */
@media (max-width:880px){
  .footer__top{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .nav-toggle{display:block;z-index:60}
  /* no mobile a barra sólida não deve criar containing block (backdrop-filter),
     senão o overlay do menu cobre só a faixa da barra em vez da tela toda */
  .nav.is-solid{-webkit-backdrop-filter:none;backdrop-filter:none}
  .nav-links{
    position:fixed;inset:0;z-index:55;
    flex-direction:column;justify-content:flex-start;align-items:center;
    gap:22px;padding:94px 24px 44px;
    overflow-y:auto;-webkit-overflow-scrolling:touch;
    background:rgba(8,24,38,.98);transform:translateX(100%);transition:transform .4s var(--ease);
  }
  .nav-links.is-open{transform:none}
  .nav-links a{font-size:1rem}
  /* menu vertical: alinhar Instagram e WhatsApp (sem o overlap do desktop) */
  .nav-soc + .nav-soc{margin-left:0}
  .hero__foot{flex-direction:column;align-items:flex-start;gap:24px}
  .scrollcue{display:none}
  .dest a{flex:1 1 calc(50% - 14px);min-width:0}
  .footer__top{grid-template-columns:1fr}
}
