/* ============================================================
   Snowland — style.css (base / globais)
   ============================================================ */

:root{
  /* Marca */
  --purple:#6a2cc0;
  --purple-deep:#4d1f99;
  --blue:#2c6fd4;
  --blue-deep:#1e4fb0;
  --magenta:#d6177f;
  --accent-blue:#1e73c4;
  --green:#3bb54a;

  /* Texto / neutros */
  --ink:#1d2540;
  --ink-soft:#52597a;
  --muted:#8a90ab;
  --white:#fff;

  /* Gradientes */
  --grad-brand:linear-gradient(120deg,#9c1f8e 0%,#6a2cc0 45%,#2c6fd4 100%);
  --grad-pink:linear-gradient(90deg,#d81b86 0%,#9a2fb2 100%);
  --grad-title:linear-gradient(90deg,#6a2cc0 0%,#d6177f 100%);
  --grad-blue:linear-gradient(90deg,#2f6fd6 0%,#1e4fb0 100%);

  /* Layout */
  --container:1200px;
  --header-h:74px;
  --radius:18px;

  --font-display:'Fredoka',system-ui,-apple-system,sans-serif;
  --font-body:'Nunito',system-ui,-apple-system,sans-serif;
}

/* ---------- Reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{overflow-x:clip;scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:#fff;
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{background:none;border:0;font:inherit;cursor:pointer;color:inherit}
ul{list-style:none}

.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 24px}

/* ---------- Botões ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-display);font-weight:600;font-size:15px;line-height:1;
  padding:13px 28px;border-radius:999px;cursor:pointer;white-space:nowrap;
  transition:transform .15s ease,box-shadow .2s ease,filter .2s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-ingressos{background:var(--grad-pink);color:#fff;text-transform:uppercase;letter-spacing:.02em;box-shadow:0 8px 20px rgba(216,27,134,.32)}
.btn-ingressos:hover{box-shadow:0 12px 26px rgba(216,27,134,.42)}
.btn-hero{background:var(--grad-pink);color:#fff;text-transform:uppercase;font-size:16px;padding:15px 32px;box-shadow:0 10px 24px rgba(216,27,134,.4)}
.btn-blue{background:var(--grad-blue);color:#fff;text-transform:uppercase;box-shadow:0 8px 20px rgba(30,79,176,.3)}
.btn-light{background:#fff;color:var(--accent-blue);text-transform:uppercase;box-shadow:0 8px 20px rgba(0,0,0,.18)}

/* ---------- Títulos de seção ---------- */
.section-title{
  font-family:var(--font-display);font-weight:700;text-align:center;
  font-size:clamp(26px,4vw,42px);line-height:1.1;margin-bottom:38px;
}
.title-grad,.title-grad .hash{
  background:var(--grad-title);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.title-blue{color:var(--accent-blue)}

/* ---------- Ícones sociais (círculo azul) ---------- */
.socials{display:flex;gap:12px;align-items:center}
.socials-blue a{
  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,.35);transition:transform .15s ease;
}
.socials-blue a:hover{transform:translateY(-3px)}

/* ============================================================
   HEADER (fixo, transparente sobre o hero -> sólido no scroll)
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:200;
  padding:16px 0;transition:background .25s ease,box-shadow .25s ease,padding .25s ease;
}
.header-inner{display:flex;align-items:center;gap:22px}
.logo{display:flex;align-items:center}
.logo img{height:48px;width:auto}
.logo-white{display:block}
.logo-color{display:none} /* branco sobre o hero; colorido aparece no scroll */

.nav-desktop{display:flex;align-items:center;gap:24px;margin-left:auto}
.nav-desktop .nav-item{
  font-family:var(--font-display);font-weight:500;font-size:14px;color:#fff;
  text-transform:uppercase;letter-spacing:.03em;display:inline-flex;align-items:center;gap:6px;
  transition:opacity .2s ease;cursor:pointer;
}
.nav-desktop .nav-item:hover{opacity:.8}
.nav-ig{color:#fff}
.caret{font-size:10px;opacity:.85}

.nav-item.has-dropdown{position:relative}
.dropdown{
  position:absolute;top:130%;left:50%;transform:translateX(-50%) translateY(8px);
  background:#fff;border-radius:14px;box-shadow:0 16px 40px rgba(20,20,60,.18);
  padding:10px;min-width:210px;display:flex;flex-direction:column;
  opacity:0;visibility:hidden;transition:opacity .2s ease,transform .2s ease;z-index:10;
}
.nav-item.has-dropdown:hover .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown a{
  padding:10px 14px;border-radius:10px;font-family:var(--font-display);font-weight:500;font-size:14px;
  color:var(--ink);text-transform:none;letter-spacing:0;
}
.dropdown a:hover{background:#f3effb;color:var(--purple)}

.btn-ingressos.btn{padding:11px 22px;font-size:13px}
.header-inner > .btn-ingressos{margin-left:0}

/* burger só no mobile */
.burger{display:none;flex-direction:column;gap:5px;width:46px;height:46px;border-radius:50%;
  background:#1f5ec9;align-items:center;justify-content:center;box-shadow:0 6px 16px rgba(31,94,201,.35)}
.burger span{display:block;width:22px;height:2.5px;border-radius:2px;background:#fff}

/* ----- estado scrolled ----- */
.site-header.is-scrolled{background:#fff;box-shadow:0 6px 22px rgba(20,20,60,.10);padding:8px 0}
.site-header.is-scrolled .logo-white{display:none}
.site-header.is-scrolled .logo-color{display:block}
.site-header.is-scrolled .nav-desktop .nav-item{color:var(--ink)}

/* ============================================================
   MENU MOBILE (overlay full-screen)
   ============================================================ */
.mobile-menu{
  position:fixed;inset:0;z-index:300;background:#1f5ec9;
  display:flex;flex-direction:column;align-items:flex-start;
  opacity:0;visibility:hidden;transition:opacity .28s ease;padding:76px 34px 40px;overflow-y:auto;
}
.mobile-menu.is-open{opacity:1;visibility:visible}
.menu-close{position:absolute;top:20px;right:24px;font-size:38px;line-height:1;color:#fff;font-family:var(--font-display)}
.mobile-nav{display:flex;flex-direction:column;align-items:flex-start;gap:2px;width:100%}
.mobile-nav > a{
  font-family:var(--font-display);font-weight:600;font-size:17px;color:#fff;
  text-transform:uppercase;letter-spacing:.03em;padding:11px 0;
}
.mobile-nav > a:hover{opacity:.85}
.m-socials{margin-top:26px;gap:14px}
.mobile-nav > a.m-ingressos{margin-top:26px;width:100%;max-width:300px;font-size:16px;padding:15px 28px;text-align:center}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{position:relative;background:var(--grad-brand);color:#fff;padding:84px 0 44px;margin-top:0}
.footer-wave{position:absolute;left:0;right:0;top:-57px;width:100%;height:60px;display:block}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr 1fr;gap:48px;align-items:start}
.f-col p{margin-bottom:14px;font-size:14px;color:rgba(255,255,255,.9)}
.f-col p strong{color:#fff;font-family:var(--font-display);font-weight:600}
.f-logo{height:62px;margin-bottom:22px}

.f-links{display:flex;flex-direction:column;gap:14px}
.f-links a{font-family:var(--font-display);font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:.03em;color:#fff;transition:opacity .2s ease}
.f-links a:hover{opacity:.75}
.f-social{margin-top:10px}

.f-newsletter h4{font-family:var(--font-display);font-weight:700;font-size:20px;margin-bottom:18px}
.nl-form{display:flex;flex-direction:column;gap:12px;max-width:340px}
.nl-form input[type=text],.nl-form input[type=email]{
  border:0;border-radius:10px;padding:13px 16px;font-family:var(--font-body);font-size:14px;background:#fff;color:var(--ink);
}
.nl-form input::placeholder{color:#9aa0bc}
.nl-consent{display:flex;gap:10px;align-items:flex-start;font-size:11.5px;color:rgba(255,255,255,.85);line-height:1.45;cursor:pointer}
.nl-consent input{margin-top:3px;flex-shrink:0;width:16px;height:16px;accent-color:var(--magenta)}
.nl-submit{align-self:flex-start;margin-top:4px}
.nl-msg{font-family:var(--font-display);font-weight:600;color:#d7ffea}

/* ============================================================
   RESPONSIVO
   ============================================================ */
@media (max-width:960px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .f-newsletter{grid-column:1 / -1}
}
@media (max-width:768px){
  .nav-desktop{display:none}
  .burger{display:flex}
  .header-inner{justify-content:space-between;gap:10px}
  .logo{flex:1;display:flex;justify-content:center}
  .logo img{height:44px}
  .header-inner > .btn-ingressos{padding:10px 18px;font-size:13px}
  .header-inner > .btn-ingressos svg{display:none}
  .ing-full{display:none}
  .footer-grid{grid-template-columns:1fr;gap:30px;text-align:center}
  .f-links{align-items:center}
  .f-social{justify-content:center}
  .nl-form{margin:0 auto}
  .nl-consent{text-align:left}
}
@media (max-width:480px){
  .container{padding:0 16px}
}
