/* ============================================================
   Snowland — paginas.css (institucionais: Atrações / Contato / FAQ)
   Reusa style.css (reset, :root, .btn, header, footer, .socials).
   ============================================================ */

/* ---------- Page hero (faixa gradiente + onda) ---------- */
.page-hero{
  position:relative;background:var(--grad-brand);overflow:hidden;text-align:center;
  padding:calc(var(--header-h) + 56px) 0 96px;
}
.page-hero-inner{position:relative;z-index:2;padding:0 24px}
.page-hero h1{
  font-family:var(--font-display);font-weight:700;color:#fff;text-transform:uppercase;
  font-size:clamp(30px,5vw,52px);line-height:1.05;letter-spacing:.01em;
  text-shadow:0 4px 22px rgba(20,10,60,.35);
}
.page-hero p{color:rgba(255,255,255,.92);font-size:clamp(15px,1.8vw,18px);max-width:680px;margin:14px auto 0;line-height:1.5}
.page-crumb{font-family:var(--font-display);font-weight:600;font-size:12.5px;letter-spacing:.04em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-bottom:14px}
.page-crumb a{color:#fff}
.page-crumb a:hover{opacity:.8}
.page-wave{position:absolute;left:0;right:0;bottom:-1px;width:100%;height:68px;z-index:1;display:block}

.page-section{padding:56px 0 80px}
.lead-line{text-align:center;color:var(--ink-soft);font-size:clamp(15px,2vw,18px);max-width:740px;margin:0 auto 46px;line-height:1.55}

/* ---------- CTA band (Comprar Ingressos) ---------- */
.cta-band{position:relative;background:var(--grad-brand);text-align:center;padding:54px 24px;overflow:hidden}
.cta-band h2{font-family:var(--font-display);font-weight:700;color:#fff;font-size:clamp(22px,3vw,32px);margin-bottom:8px}
.cta-band p{color:rgba(255,255,255,.9);margin-bottom:22px;font-size:15px}

/* ============================================================
   ATRAÇÕES — grid
   ============================================================ */
.atr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.atr-block{display:flex;flex-direction:column;background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 12px 30px rgba(20,20,60,.12);transition:transform .18s ease,box-shadow .2s ease}
.atr-block:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(20,20,60,.18)}
.atr-block-photo{position:relative;aspect-ratio:4/3;overflow:hidden}
.atr-block-photo img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.atr-block:hover .atr-block-photo img{transform:scale(1.05)}
.atr-block-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(rgba(20,16,55,.05),rgba(20,16,55,.42))}
.atr-block-sign{position:absolute;z-index:2;left:50%;bottom:7%;transform:translateX(-50%);width:76%;max-width:250px}
.atr-block-sign img{width:100%;display:block;filter:drop-shadow(0 6px 14px rgba(0,0,0,.45))}
.atr-block-sign span{
  position:absolute;top:37%;left:50%;transform:translate(-50%,-50%);width:80%;text-align:center;
  font-family:var(--font-display);font-weight:700;color:#fff;text-transform:uppercase;line-height:1.04;
  font-size:15px;text-shadow:0 2px 4px rgba(60,30,0,.6);
}
.atr-block-body{padding:18px 20px 22px;display:flex;flex-direction:column;gap:12px;flex:1}
.atr-block-desc{color:var(--ink-soft);font-size:14px;line-height:1.55}
.atr-block-rest{font-size:12.5px;color:var(--muted);line-height:1.45;margin-top:auto;border-top:1px solid #eef2f7;padding-top:10px}
.atr-block-rest strong{color:var(--ink-soft);font-family:var(--font-display)}

/* ============================================================
   CONTATO E LOCALIZAÇÃO
   ============================================================ */
.contato-grid{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:start}
.contato-card{background:#fff;border-radius:18px;padding:30px;box-shadow:0 12px 30px rgba(20,20,60,.1)}
.contato-card h2{font-family:var(--font-display);font-weight:700;color:var(--accent-blue);font-size:22px;margin-bottom:6px}
.contato-card .card-sub{color:var(--ink-soft);font-size:14.5px;margin-bottom:22px}

.ci-item{display:flex;gap:14px;align-items:flex-start;margin-bottom:20px}
.ci-ic{flex-shrink:0;width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#43a6ec,#1e73c4);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 14px rgba(30,115,196,.3)}
.ci-text h4{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:14.5px;margin-bottom:3px}
.ci-text p{color:var(--ink-soft);font-size:14px;line-height:1.5}
.ci-text a{color:var(--accent-blue);font-weight:600}
.contato-card .socials-blue{margin-top:8px}

/* form */
.contato-form .field{display:flex;flex-direction:column;margin-bottom:16px}
.contato-form .field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contato-form label{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:13px;margin-bottom:6px}
.contato-form input,.contato-form select,.contato-form textarea{
  border:1px solid #d7deea;border-radius:10px;padding:12px 14px;font-family:var(--font-body);font-size:14px;
  color:var(--ink);background:#f3f6fa;width:100%;
}
.contato-form input:focus,.contato-form select:focus,.contato-form textarea:focus{outline:none;border-color:var(--cal-blue,#2c6fd4);background:#fff}
.contato-form textarea{resize:vertical;min-height:120px}
.contato-consent{display:flex;gap:10px;align-items:flex-start;font-size:12px;color:var(--ink-soft);line-height:1.45;cursor:pointer;margin-bottom:16px}
.contato-consent input{margin-top:3px;flex-shrink:0;width:16px;height:16px;accent-color:var(--magenta)}
.contato-form .btn{width:100%}
.contato-msg{font-family:var(--font-display);font-weight:600;color:#1e8e4a;text-align:center;margin-top:14px}
.contato-msg[hidden]{display:none}

.contato-map{margin-top:40px}
.contato-map iframe{width:100%;height:420px;border:0;display:block;border-radius:18px;box-shadow:0 12px 30px rgba(20,20,60,.12)}

/* ============================================================
   FAQ / INFORMAÇÕES
   ============================================================ */
.faq-info{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:54px}
.faq-info-card{background:#fff;border-radius:16px;padding:24px 22px;box-shadow:0 10px 24px rgba(20,20,60,.1);text-align:center}
.fi-ic{width:64px;height:64px;border-radius:50%;margin:0 auto 14px;background:radial-gradient(circle at 50% 32%,#eef6ff,#cde3fb);display:flex;align-items:center;justify-content:center;color:var(--accent-blue);box-shadow:0 8px 18px rgba(30,115,196,.16)}
.faq-info-card h3{font-family:var(--font-display);font-weight:700;color:var(--accent-blue);font-size:16px;margin-bottom:6px}
.faq-info-card p{color:var(--ink-soft);font-size:13.5px;line-height:1.5}

.faq-accordion{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:#fff;border-radius:14px;box-shadow:0 8px 20px rgba(20,20,60,.08);overflow:hidden}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:18px;padding:18px 22px;text-align:left;font-family:var(--font-display);font-weight:600;color:var(--ink);font-size:15.5px;line-height:1.3;cursor:pointer}
.faq-q:hover{color:var(--accent-blue)}
.faq-ic{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:#eaf3fb;color:var(--accent-blue);display:flex;align-items:center;justify-content:center;font-size:20px;line-height:1;transition:transform .25s ease,background .2s ease}
.faq-item.open .faq-ic{transform:rotate(45deg);background:var(--accent-blue);color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-item.open .faq-a{max-height:900px}
.faq-a-inner{padding:0 22px 20px;color:var(--ink-soft);font-size:14px;line-height:1.65}
.faq-a-inner strong{color:var(--ink)}
.faq-a-inner a{color:var(--accent-blue);font-weight:600}

/* ============================================================
   RESPONSIVO
   ============================================================ */
@media (max-width:960px){
  .atr-grid{grid-template-columns:repeat(2,1fr);gap:22px}
  .faq-info{grid-template-columns:repeat(3,1fr);gap:14px}
  .contato-grid{grid-template-columns:1fr;gap:24px}
}
@media (max-width:768px){
  .page-hero{padding:calc(var(--header-h) + 36px) 0 70px}
  .page-section{padding:42px 0 60px}
  .atr-grid{grid-template-columns:1fr;gap:20px}
  .faq-info{grid-template-columns:1fr;gap:14px}
  .contato-form .field-row{grid-template-columns:1fr;gap:0}
  .contato-map iframe{height:320px}
}
