/* ============================================================
   MILHAS TRAVEL — Design System
   Paleta do logo: sol laranja + onda azul royal, fundo claro
   ============================================================ */
:root{
  --ink:#10224E;
  --royal:#1E4FC2;
  --royal-dark:#16398F;
  --ceu:#EDF3FF;
  --laranja:#F4711F;
  --laranja-dark:#D95B0E;
  --sol:#FFB43A;
  --areia:#FFF9F1;
  --branco:#FFFFFF;
  --cinza:#5B6785;
  --linha:#DDE5F5;
  --verde:#0E9F6E;
  --radius:18px;
  --shadow:0 4px 20px rgba(16,34,78,.07);
  --font-display:"Bricolage Grotesque",system-ui,sans-serif;
  --font-body:"Figtree",system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{animation:none!important;transition:none!important}}
body{font-family:var(--font-body);color:var(--ink);background:var(--branco);line-height:1.6;font-size:16px}
img{max-width:100%;display:block}
a{color:var(--royal);text-decoration:none}
:focus-visible{outline:3px solid var(--laranja);outline-offset:2px;border-radius:4px}
.container{max-width:1140px;margin:0 auto;padding:0 20px}

h1,h2,h3,.display{font-family:var(--font-display);line-height:1.12;letter-spacing:-.01em}
h1{font-size:clamp(2.1rem,5vw,3.4rem);font-weight:800}
h2{font-size:clamp(1.6rem,3.4vw,2.3rem);font-weight:800}
h3{font-size:1.15rem;font-weight:700}
.eyebrow{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--laranja);margin-bottom:10px}
.sub{color:var(--cinza);max-width:640px}

/* ---------- Header ---------- */
.topbar{background:var(--ink);color:#CBD6F2;font-size:.8rem;text-align:center;padding:7px 12px}
.topbar strong{color:var(--sol)}
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--linha)}
.nav{display:flex;align-items:center;gap:26px;padding:14px 0}
.logo{font-family:var(--font-display);font-weight:800;font-size:1.3rem;color:var(--ink);display:flex;align-items:center;gap:9px}
.logo .sun{width:30px;height:30px;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--sol),var(--laranja));position:relative;overflow:hidden;flex:none}
.logo .sun::after{content:"";position:absolute;bottom:-4px;left:-6px;right:-6px;height:14px;background:var(--royal);border-radius:50% 50% 0 0}
.logo em{color:var(--laranja);font-style:normal}
nav.menu{display:flex;gap:22px;margin-left:auto;font-weight:600;font-size:.93rem}
nav.menu a{color:var(--ink)}
nav.menu a:hover{color:var(--laranja)}
.btn{display:inline-block;font-family:var(--font-display);font-weight:700;border-radius:999px;padding:13px 26px;border:none;cursor:pointer;font-size:.98rem;transition:transform .15s ease,box-shadow .15s ease;text-align:center}
.btn:hover{transform:translateY(-2px)}
.btn-laranja{background:var(--laranja);color:#fff;box-shadow:0 4px 14px rgba(244,113,31,.28)}
.btn-laranja:hover{background:var(--laranja-dark)}
.btn-royal{background:var(--royal);color:#fff}
.btn-ghost{background:transparent;color:var(--royal);border:2px solid var(--royal)}
.btn-wa{background:#25D366;color:#fff}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.menu-toggle{display:none;margin-left:auto;background:none;border:none;font-size:1.6rem;color:var(--ink);cursor:pointer}

/* ---------- Hero ---------- */
.hero{position:relative;background:linear-gradient(180deg,var(--ink) 0%,var(--royal-dark) 58%,var(--royal) 100%);color:#fff;overflow:hidden}
.hero .sunball{position:absolute;right:-120px;top:40px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle at 40% 35%,var(--sol),var(--laranja) 70%);opacity:.9;filter:blur(2px)}
.hero .wave{position:absolute;bottom:-2px;left:0;right:0}
.hero-inner{position:relative;padding:84px 0 130px;max-width:640px}
.hero h1 em{font-style:normal;color:var(--sol)}
.hero p{margin:18px 0 30px;color:#D9E3FB;font-size:1.08rem;max-width:520px}
.hero .chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.chip{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;border-radius:999px;padding:8px 16px;font-size:.86rem;font-weight:600}
.chip:hover{background:rgba(255,255,255,.22)}

/* ---------- Sections ---------- */
section.bloco{padding:72px 0}
section.bloco.ceu{background:var(--ceu)}
section.bloco.areia{background:var(--areia)}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:36px;flex-wrap:wrap}

/* ---------- Cartão de embarque (promo card) ---------- */
.grid-promos{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:26px}
.pass{background:var(--branco);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;position:relative;transition:transform .18s ease}
.pass{border:1px solid var(--linha)}
.pass:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(16,34,78,.12)}
.pass-top{background:linear-gradient(135deg,var(--royal-dark),var(--royal));color:#fff;padding:16px 20px;display:flex;justify-content:space-between;align-items:center}
.pass-top .rota{font-family:var(--font-display);font-weight:800;font-size:1.25rem;letter-spacing:.02em;display:flex;align-items:center;gap:10px}
.pass-top .rota .aviao{font-size:.95rem;opacity:.85}
.pass-top .tag{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;background:rgba(255,255,255,.16);padding:4px 10px;border-radius:999px}
.pass-body{padding:20px;flex:1}
.pass-body .destino{font-family:var(--font-display);font-weight:800;font-size:1.35rem;margin-bottom:2px}
.pass-body .datas{color:var(--cinza);font-size:.9rem;font-weight:600;margin-bottom:14px}
.pass-body ul{list-style:none;font-size:.9rem;color:var(--ink)}
.pass-body ul li{padding:3px 0 3px 24px;position:relative}
.pass-body ul li::before{content:"✓";position:absolute;left:0;color:var(--verde);font-weight:800}
.selo{position:absolute;top:64px;right:-1px;background:var(--laranja);color:#fff;font-family:var(--font-display);font-weight:700;font-size:.72rem;letter-spacing:.06em;padding:6px 14px;border-radius:8px 0 0 8px;text-transform:uppercase}
.pass-stub{border-top:2px dashed var(--linha);position:relative;padding:16px 20px;display:flex;justify-content:space-between;align-items:center;gap:12px;background:var(--areia)}
.pass-stub::before,.pass-stub::after{content:"";position:absolute;top:-11px;width:22px;height:22px;border-radius:50%;background:var(--ceu)}
.pass-stub::before{left:-11px}
.pass-stub::after{right:-11px}
.preco .de{font-size:.78rem;color:var(--cinza)}
.preco .valor{font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:var(--royal-dark);line-height:1.1}
.preco .parc{font-size:.82rem;color:var(--laranja-dark);font-weight:700}
.preco .pp{font-size:.74rem;color:var(--cinza)}
.pass-stub .btn{padding:11px 20px;font-size:.9rem;white-space:nowrap}
.validade{font-size:.72rem;color:var(--cinza);padding:8px 20px 14px;background:var(--areia)}

/* ---------- Filtros ---------- */
.filtros{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:30px}
.filtros button{border:2px solid var(--linha);background:#fff;border-radius:999px;padding:9px 18px;font-family:var(--font-body);font-weight:600;font-size:.88rem;color:var(--ink);cursor:pointer}
.filtros button.ativo{background:var(--royal);border-color:var(--royal);color:#fff}

/* ---------- Passos / como funciona ---------- */
.passos{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:24px}
.passo{background:#fff;border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);border:1px solid var(--linha)}
.passo .num{width:42px;height:42px;border-radius:12px;background:var(--ceu);color:var(--royal-dark);font-family:var(--font-display);font-weight:800;font-size:1.05rem;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.passo p{font-size:.92rem;color:var(--cinza)}

/* ---------- Disney hub ---------- */
.grid-disney{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:26px}
.parque{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:26px;position:relative;border-top:6px solid var(--royal)}
.parque.visitado{border-top-color:var(--laranja)}
.parque .pais{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--cinza);padding-right:86px}
.parque h3{margin:6px 0 10px;font-size:1.3rem;padding-right:86px}
.parque p{font-size:.92rem;color:var(--cinza);margin-bottom:16px}
.carimbo{position:absolute;top:16px;right:16px;width:80px;height:80px;border:3px solid var(--laranja);border-radius:50%;display:flex;align-items:center;justify-content:center;text-align:center;font-family:var(--font-display);font-weight:800;font-size:.62rem;letter-spacing:.04em;color:var(--laranja);transform:rotate(10deg);text-transform:uppercase;padding:6px;line-height:1.25}
.carimbo.azul{border-color:var(--royal);color:var(--royal);transform:rotate(-8deg)}

/* ---------- Formulários ---------- */
.form-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:34px;max-width:760px;margin:0 auto}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.campo{display:flex;flex-direction:column;gap:6px}
.campo.full{grid-column:1/-1}
.campo label{font-weight:700;font-size:.85rem}
.campo input,.campo select,.campo textarea{border:2px solid var(--linha);border-radius:12px;padding:12px 14px;font-family:var(--font-body);font-size:.95rem;color:var(--ink);background:#fff}
.campo input:focus,.campo select:focus,.campo textarea:focus{border-color:var(--royal);outline:none}
.passageiro{border:2px solid var(--linha);border-radius:14px;padding:18px;margin-bottom:16px}
.passageiro h4{font-family:var(--font-display);font-size:.95rem;margin-bottom:12px;color:var(--royal-dark)}
.aviso{background:var(--ceu);border-left:4px solid var(--royal);border-radius:10px;padding:14px 18px;font-size:.88rem;margin:18px 0}
.sucesso{text-align:center;padding:40px 20px}
.sucesso .icone{width:80px;height:80px;border-radius:50%;background:var(--verde);color:#fff;font-size:2.2rem;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}

/* ---------- Resumo da reserva ---------- */
.resumo{background:var(--ink);color:#fff;border-radius:var(--radius);padding:26px;margin-bottom:26px}
.resumo .destino{font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:var(--sol)}
.resumo .linha-r{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.12);font-size:.92rem}
.resumo .linha-r:last-child{border:none}

/* ---------- Prova social ---------- */
.prova{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;text-align:center}
.prova .item .big{font-family:var(--font-display);font-weight:800;font-size:2.2rem;color:var(--laranja)}
.prova .item p{color:var(--cinza);font-size:.9rem}

/* ---------- Footer ---------- */
footer.site{background:var(--ink);color:#B9C6E8;padding:56px 0 30px;font-size:.9rem}
footer.site .cols{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:36px;margin-bottom:36px}
footer.site h4{color:#fff;font-family:var(--font-display);margin-bottom:14px;font-size:1rem}
footer.site a{color:#B9C6E8;display:block;padding:3px 0}
footer.site a:hover{color:var(--sol)}
footer.site .legal{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;font-size:.78rem;color:#8494BF}

/* ---------- Flutuante WhatsApp ---------- */
.wa-float{position:fixed;bottom:22px;right:22px;z-index:60;width:56px;height:56px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(0,0,0,.22);transition:transform .15s ease}
.wa-float:hover{transform:scale(1.06)}
.wa-float svg{width:28px;height:28px}

/* ---------- Responsivo ---------- */
@media(max-width:840px){
  nav.menu{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;gap:0;padding:10px 20px 20px;border-bottom:1px solid var(--linha)}
  nav.menu.aberto{display:flex}
  nav.menu a{padding:12px 0;border-bottom:1px solid var(--linha)}
  .menu-toggle{display:block}
  .nav .btn{display:none}
  .hero-inner{padding:60px 0 110px}
  .hero .sunball{width:260px;height:260px;right:-90px;top:auto;bottom:120px;opacity:.55}
  .form-grid{grid-template-columns:1fr}
  footer.site .cols{grid-template-columns:1fr 1fr}
}
@media(max-width:520px){
  footer.site .cols{grid-template-columns:1fr}
  .pass-stub{flex-direction:column;align-items:stretch;text-align:center}
}

/* Seção foto Disney */
@media(max-width:840px){
  .bloco .container[style*="grid-template-columns:1fr 1.1fr"]{grid-template-columns:1fr!important}
}



/* Comunidade (grupo + YouTube) */
.comunidade{border-top:1px solid var(--linha)}
.com-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.com-card{display:flex;align-items:center;gap:20px;background:#fff;border:1px solid var(--linha);border-radius:var(--radius);padding:26px 28px;color:var(--ink);transition:border-color .15s ease,transform .15s ease,box-shadow .15s ease}
.com-card:hover{border-color:var(--royal);transform:translateY(-2px);box-shadow:var(--shadow)}
.com-icon{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex:none}
.com-icon.mini{width:40px;height:40px}
.com-body h3{font-size:1.05rem;margin-bottom:4px}
.com-body p{font-size:.9rem;color:var(--cinza);line-height:1.5}
.com-arrow{margin-left:auto;font-size:1.3rem;color:var(--royal);flex:none}
.banner-grupo{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--linha);border-left:4px solid #25D366;border-radius:14px;padding:16px 22px;margin-bottom:26px;color:var(--ink);font-size:.94rem;transition:box-shadow .15s ease}
.banner-grupo:hover{box-shadow:var(--shadow)}
.banner-grupo .com-arrow{color:#1DA851}
.btn-yt{background:#fff;border:1px solid var(--linha);color:var(--ink)}
.btn-yt:hover{border-color:#E02424}
@media(max-width:840px){.com-grid{grid-template-columns:1fr}}
