/* =========================
   Fonte
   ========================= */
/* Protest Strike */
@font-face {
  font-family: "Protest Strike";
  src: url("fonts/ProtestStrike-Regular.woff2") format("woff2"),
       url("fonts/ProtestStrike-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* Inter Variable */
@font-face {
  font-family: "Inter";
  src: url("fonts/Inter-VariableFont_opsz,wght.woff2") format("woff2"),
       url("fonts/Inter-VariableFont_opsz,wght.ttf") format("truetype");
  font-weight: 100 900; /* intervalo completo do variable */
  font-style: normal;
  font-display: swap;
}

/* Inter Italic Variable */
@font-face {
  font-family: "Inter";
  src: url("fonts/Inter-Italic-VariableFont_opsz,wght.woff2") format("woff2"),
       url("fonts/Inter-Italic-VariableFont_opsz,wght.ttf") format("truetype");
  font-weight: 100 900;
  font-style: italic;
  font-display: swap;
}

/* =========================
   Reset / Base
   ========================= */
* { box-sizing: border-box; }
html, body { height: 100%; }
body{
  margin: 0;
  max-width: 100%;
  overflow-x: hidden;
  color: #e7eaed;
  background: #0d0d0d;
  font: 16px/1.5 system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
}
img{ max-width: 100%; display: block; }
a{ color: #ffd167; text-decoration: none; }
a:hover{ text-decoration: underline; }
.sr-only{ position: absolute; clip: rect(0 0 0 0); clip-path: inset(50%); width:1px; height:1px; overflow:hidden; white-space:nowrap; }

/* =========================
   Tokens
   ========================= */
:root{
  --brand:#ff9d00;
  --brand-2:#ffd167;
  --ink:#e7eaed;
  --muted:#9aa2ad;
  --bg:#0b0e12;
  --card:#12161d;
  --radius:1.25rem;
  --shadow:0 10px 30px rgba(0,0,0,.35);
  --container: min(1100px, 92vw);
}

/* =========================
   Layout
   ========================= */
.container{ 
  width: calc(100% - 10%);
  margin: auto;
 }
.container.narrow{ width: min(950px, 92vw); }
.center{ text-align:center; }
/* === HEADER FIXO === */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
  padding: 10px 0;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0) 100%);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

html {
  scroll-behavior: smooth;
}

.video-teaser iframe {
    position: absolute;
    inset: 0;
    width: 700px !important;
    max-width: 100%;
    height: 100%;
    border: 0;
    margin: auto;
}
.video-teaser {
  margin: 40px auto 0;
}
.header-flex {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.logo img {
  height: 64px;
  display: block;
}

.nav {
  display: flex;
  align-items: center;
  gap: 32px;
}

.nav a {
  color: #fff;
  text-transform: uppercase;
  transition: color 0.2s;
  font-family: "Protest Strike", system-ui, sans-serif;
  font-weight: 400;
  font-style: Regular;
  font-size: 20px;
  leading-trim: NONE;
  line-height: 20px;
  letter-spacing: 0%;
  text-align: center;

}

.nav a:hover {
  color: #ff9d00;
  text-decoration: none;
}

/* Botão destaque */
.btn-inscreve {
  background: #ff6a00;
  color: #fff !important;
  padding: 10px 20px;
  font-weight: 700;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.3);
  transition: background 0.2s, transform 0.2s;
}

.btn-inscreve:hover {
  background: #ff8500;
  transform: translateY(-2px);
}

.actions-increvete {
    text-align: center;
}
.actions-increvete img {
    max-width: 60%;
    margin-bottom: -20px !important;
    margin: auto;
}
/* === Fade escuro entre banners === */
.row.row-cover {
  position: relative;
  overflow: hidden;
}

.row.row-cover::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 120px; /* altura da sombra — ajusta à vontade */
  background: linear-gradient(to bottom, rgba(0,0,0,0) 0%, rgba(0,0,0,0.9) 100%);
  pointer-events: none;
  z-index: 2;
}

.row.row-cover + .row.row-cover::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 120px;
  background: linear-gradient(to top, rgba(0,0,0,0) 0%, rgba(0,0,0,0.9) 100%);
  pointer-events: none;
  z-index: 2;
}

/* garante que a imagem fica atrás das sombras */
.row.row-cover img {
  position: relative;
  z-index: 1;
}

.actions-increvete .btn {
  display: inline-block;
  background-color: #0f6eb2;
  color: white;
  font-family: "Protest Strike", system-ui, sans-serif;
  font-size: 36px;
  line-height: 67px;
  font-weight: 400;
  padding: 10px 15px;
  text-align: center;
  text-decoration: none !important;
  transform: translateY(0);
  transition: transform 0.25s ease, background-color 0.25s ease;
}

.actions-increvete .btn:hover {
  transform: translateY(-4px);
  background-color: #1383d2;
}

.inscrevete-text {
    position: absolute;
    bottom: 8%;
    left: 50%;
    z-index: 2;
    transform: translate(-50%, 0px);
}
.video-teaser {
  margin-top: 40px;
  position: relative;
  width: 100%;
  max-width: 900px;      /* ajusta se quiseres */
  padding-top: 56.25%;   /* 16:9 */
}


/* =========================
   Typography
   ========================= */
.title-xl{
  font-family: "Protest Strike", system-ui, sans-serif;
  font-size: clamp(38px, 8vw, 88px);
  line-height: .95;
  letter-spacing:.5px;
  text-transform: uppercase;
  margin: 0 0 14px;
  text-shadow: 0 6px 30px rgba(0,0,0,.6);
}

.lead{
  font-size: clamp(16px, 2.4vw, 20px);
  color: var(--ink);
  opacity:.95;
  margin: 0 0 22px;
}
.text{ color:#cdd3db; font-size: 18px; }

.container-banner {
    max-width: 50%;
    margin: auto;
    position: absolute;
    top: 50%;
    display: flex;
    justify-content: space-between;
    left: 50%;
    text-align: center;
    height: 100%;
    transform: translate(-50% , -50%);
    padding: 5% 0px;
    z-index: 2;
    flex-direction: column;
}/* Títulos grandes */
.title-lg-h3{
  font-family: "Protest Strike", system-ui, sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: clamp(20px, 3vw, 36px);
  line-height: 1.1;
  text-transform: uppercase;
  margin: 0 0 18px;
  color: #FFF785;
}

.title-lg-h2{
  font-family: "Protest Strike", system-ui, sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: clamp(28px, 4vw, 64px);
  line-height: 1.05;
  text-transform: uppercase;
  margin: 0 0 18px;
  color: #fff;
}

/* Bloco de destaque em baixo */
.text-down h6{
  color: #9BFF58;
  font-family: "Protest Strike", system-ui, sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: clamp(22px, 3vw, 48px);
  line-height: 1.15;
  text-align: center;
  margin: 0;
  margin-bottom: 30px !important;
}

.text-down p{
  color: #fff;
  font-family: "Inter", system-ui, sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: clamp(16px, 2vw, 36px);
  line-height: 1.35;          /* ~48px em desktop */
  letter-spacing: -0.01em;     /* -1% equivalente em em */
  text-align: center;
  margin: 0;
    margin-bottom: 20px !important;
}

/* GRID – Banner 3 */
.text-medio {
  margin-top: 0px;
}

.experiences-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 50px 20px;
    width: 100%;
    max-width: 100%;
    margin: 100px auto;
}

/* overlay real por cima do bg */
.banner3-overlay{
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.55) 0%,
    rgba(0,0,0,0.75) 100%
  );
}

/* conteúdo acima do overlay */
.container-banner3{
  position: relative;
  z-index: 2;
}
.exp {
  color: #fff;
}

.exp-img {
  display: block;
  width: 100%;
  aspect-ratio: 14 / 9; /* igual à proporção 552x354 */
  object-fit: cover;
  border-radius: 8px;
  filter: saturate(1.05) contrast(1.02);
  transition: transform .35s ease;
}


.exp:hover .exp-img {
  transform: scale(1.02);
}

.exp-meta {
  text-align: center;
  margin-top: 14px;
}
.exp-tag {
  font-family: "Protest Strike", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: clamp(14px, 1.5vw, 24px);
  line-height: 1.4;
  letter-spacing: 0;
  text-align: center;
  color: #fff;
}

.exp-title {
  font-family: "Protest Strike", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: clamp(22px, 2vw, 36px);
  line-height: 1.2;
  text-align: center;
  margin: 0 !important;
  color: #fff;
}
.form-note{
  color: #ff6a00;
}
.exp-desc {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: clamp(14px, 1vw, 16px);
  line-height: 1.4;
  letter-spacing: 0;
  text-align: center;
  max-width: 70%;
  margin: 20px auto;
  color: #fff;
}

.title-lg-bh3 {
  font-family: "Protest Strike", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: clamp(36px, 4vw, 64px);
  line-height: 1.2;
  letter-spacing: 0;
  text-align: center;
  margin: 0;
  color: #FFF785;
}

.banner3-bg {
  background-image: url("assets/banner3.jpg");
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  position: relative;
}

/* Se quiseres dar aquele escurecimento suave por cima (como na tua imagem original) */
.banner3-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.8) 100%);
  pointer-events: none;
  z-index: 0;
}

/* Garante que o conteúdo fica acima do fundo */
.banner3-bg .container-banner {
  position: relative;
  z-index: 1;
}

.container-banner3 {
    padding: 100px 0px;
    max-width: calc(100% - 10%);
    display: flex;
    margin: auto;
    justify-content: space-between;
    flex-direction: column;
}
.text-down h6.title-lg-bh6 {
  font-family: "Protest Strike", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: clamp(22px, 3vw, 40px); /* entre 22px e 40px conforme o ecrã */
  line-height: 1.4;
  text-align: center;
  color: white;
}
.banner4-bg {
    position: relative;
    background-image: url("assets/banner4.jpg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    display: flex;
    min-height: 100vh;
    justify-content: center;
    align-items: center;
}


/* Fundo + overlay mais leve já definido para banner4-bg */
.banner4-bg{
  position:relative;
  background-image:url("assets/banner4.jpg");
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
.banner4-overlay{
  position:absolute; inset:0; pointer-events:none; z-index:1;
  background: linear-gradient(to bottom, rgba(0,0,0,.35), rgba(0,0,0,.55));
}
.banner4-bg .container{ position:relative; z-index:2; }

/* Título e subtítulo */
.cta-title{
  font-family:"Protest Strike", sans-serif;
  color:#FFE36A;
  text-align:center;
  font-size:clamp(28px, 5vw, 48px);
  line-height:1.15;
  margin:0 0 10px;
  text-transform:uppercase;
}
.cta-sub{
  font-family:"Inter", system-ui, sans-serif;
  color:#ffffff;
  opacity:.9;
  text-align:center;
  font-size:clamp(14px, 1.4vw, 18px);
  margin:0 0 18px;
}

/* Benefícios (1–3) */
.cta-perks{
  display:flex; gap:clamp(16px, 4vw, 40px);
  justify-content:center; align-items:flex-start;
  list-style:none; margin:0 0 28px; padding:0;
  flex-wrap:wrap;
}
.perk{ display:flex; align-items:flex-start; gap:12px; color:#fff; align-items:center; }
.perk-num{
  font-family:"Protest Strike", sans-serif;
  font-size:clamp(34px, 5vw, 80px); line-height:1;
  color:#FFE36A;
}
.perk-text{
  font-family:"Inter", system-ui, sans-serif;
  font-size:clamp(14px, 1.5vw, 20px);
  line-height:1.35;
  opacity:.95;
  text-align: left;
}

.signup-card {
    width: min(640px, 92vw);
    margin: 0 auto;
    margin-top: 50px;
    background: rgba(255,255,255,.94);
    border-radius: 12px;
    box-shadow: 0 14px 40px rgba(0,0,0,.35);
    padding: clamp(18px, 3vw, 26px);
    text-align: left;
}
.card-title{
  font-family:"Protest Strike", sans-serif;
  color:#1b1b1b;
  font-size:clamp(18px, 2.2vw, 32px);
  line-height:1.1;
  text-align:center;
  margin:0 0 14px;
}

/* grelha inputs */
.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-bottom:10px;
}
.field-full{ grid-column:1 / -1; }

/* inputs */
.signup-card input[type="text"],
.signup-card input[type="email"]{
  width:100%;
  border:1px solid #d7d7d7;
  border-radius:6px;
  padding:12px 14px;
  font-family:"Inter", system-ui, sans-serif;
  font-size:16px;
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.signup-card input:focus{
  border-color:#7ab6ff;
  box-shadow:0 0 0 3px rgba(122,182,255,.25);
}

/* consentimento */
.consent{
  display:flex; gap:10px; align-items:flex-start;
  font-family:"Inter", system-ui, sans-serif;
  color:#333; font-size:13px; line-height:1.35;
  margin:6px 0 14px;
}
.consent input{ margin-top:3px; }

.btn-cta {
    display: block;
    width: fit-content;
    background: #ffe993;
    color: #1b1b1b;
  font-family:"Inter", system-ui, sans-serif;
    font-weight: 500;
    font-style: Medium;
    font-size: 20px;
    leading-trim: NONE;
    line-height: 100%;
    letter-spacing: 0%;
    padding: 12px 16px;
    border: 0;
    border-radius: 0px;
    cursor: pointer;
    transition: filter .2s ease, transform .08s ease;
    margin: auto;
}
.btn-cta:hover{ filter:brightness(1.06); }
.btn-cta:active{ transform: translateY(1px); }



/* overlay mais suave */
.banner4-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.35) 0%,   /* topo suave */
    rgba(0,0,0,0.55) 100%  /* um pouco mais forte em baixo */
  );
}

.banner4-bg .container {
    position: relative;
    z-index: 2;
    padding: 150px 0px;
}

/* ----- Footer base ----- */
.site-footer{
  background: #0d0d0d;
  color: #eaeaea;
  padding: clamp(40px, 6vw, 84px) 0;
}
.site-footer .footer-wrap{
  max-width: 100%;
  width: 750px;
  margin: 0 auto;
  padding: 0 20px;
}

/* Cabeçalho */
.footer-head{
  text-align: center;
  margin-bottom: clamp(28px, 5vw, 48px);
}
.footer-title{
  font-family: "Protest Strike", system-ui, sans-serif;
  font-weight: 400;
  font-style: Regular;
  font-size: 48px;
  leading-trim: NONE;
  line-height: 58px;
  letter-spacing: 0%;
  text-align: center;
}
.footer-sub{
  font-family: "Inter", system-ui, sans-serif;
  font-weight: 400;
  font-style: Regular;
  font-size: 20px;
  leading-trim: NONE;
  line-height: 29px;
  letter-spacing: 0%;
  text-align: center;
}

/* Grelha parceiros */
.partners-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(22px, 3.4vw, 32px);
  margin: clamp(18px, 4vw, 40px) 0 clamp(28px, 6vw, 60px);
    max-width: 646px;
    align-items: start;
    margin: auto;
}
.partner-logo {
    margin-top: 25px;
}
.partner {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 50px;
    align-items: start;
}
.partner-logo img{
  display: block;
  max-width: 100%;
  width: 161px;
  height: auto;
  filter: drop-shadow(0 6px 18px rgba(0,0,0,.25));
}
.partner-copy{
  min-width: 0;
}
.partner-badge{
  font-family: "Inter", system-ui, sans-serif;
  font-weight: 400;
  font-style: Regular;
  font-size: clamp(13px, 1.15vw, 15px);
  leading-trim: NONE;
  line-height: 30px;
  letter-spacing: 0%;
  color: #FFF785;

}
.partner-name{
  font-family: "Inter", system-ui, sans-serif;
  font-weight: 700;
  font-size: 24px;
  line-height: 30px;
  letter-spacing: 0%;
  margin: 0 !important;
}
.partner-text{
  font-family: "Inter", system-ui, sans-serif;
  color: #cfcfcf;
  opacity: .9;
  font-size: clamp(13px, 1.15vw, 15px);
  line-height: 1.45;
  margin: 0;
}

/* Logo grande (hero) */
.footer-hero{
  display: flex;
  justify-content: center;
  align-items: center;
  margin: clamp(26px, 6vw, 80px) 0 clamp(14px, 4vw, 26px);
}
.footer-hero img{
  width: min(680px, 90vw);
  height: auto;
  filter: drop-shadow(0 18px 40px rgba(0,0,0,.45));
}

/* Copyright */
.copy{
  text-align: center;
  font-family: "Inter", system-ui, sans-serif;
  font-size: 13px;
  color: #bdbdbd;
  opacity: .8;
  margin: 0;
}

/* === BANNER 2 - Background como imagem === */
.banner2-bg {
  position: relative;
  background: url('assets/banner2.jpg') center center / cover no-repeat;
  width: 100%;
  min-height: 100vh; /* ocupa o ecrã inteiro */
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  text-align: center;
}

.banner2-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.45); /* overlay leve para legibilidade */
  z-index: 0;
}

.banner2-bg .container-banner {
  position: relative;
  z-index: 1;
  max-width: 1100px;
  padding: 60px 20px;
}
.container-banner-2 {
    gap:  30vh;
    text-align: center;
    padding: 5% 0px;
    max-width: 60%;
    display: flex;
    margin: auto;
    flex-direction: column;
}



/* ===== Base úteis ===== */
:root{
  --container: 1220px;
  --gutter: 20px;
}

.container,
.container-banner,
.container-banner3,
.container.center,
.container.narrow,
.footer-wrap{ padding-left: var(--gutter); padding-right: var(--gutter); }

/* Scroll suave (âncoras) */
html{ scroll-behavior:smooth; }

/* Header fixo: compensa o topo nas âncoras */
[id^="banner"]{ scroll-margin-top: 84px; }

/* ===== Breakpoint ≥ 1200 (desktop largo) ===== */
@media (min-width:1200px){
  .title-lg-h2{ font-size: 64px; }
  .title-lg-bh3{ font-size: 48px; }
}

/* ===== ≤ 1200px ===== */
@media (max-width:1200px){
  .cta-title{ font-size: clamp(34px,4.2vw,48px); }
  .title-lg-h2{ font-size: clamp(32px,5vw,56px); }
  .title-lg-h3{ font-size: clamp(18px,2.4vw,28px); }
  .title-lg-bh3{ font-size: clamp(22px,3vw,36px); }
  .title-lg-bh6{ font-size: clamp(24px,2.6vw,34px); }
  .experiences-grid{ gap: 20px 20px; }
  .hero-slick__img{ height: 46vh; }
}

/* ===== ≤ 992px (tablet) ===== */
@media (max-width:992px){
  .site-header .nav a{ padding: 10px 10px; font-size: 14px; }
  .banner2-bg,
  .banner3-bg,
  .banner4-bg{ min-height: 80vh; }

  .experiences-grid{
    grid-template-columns: repeat(2,1fr);
    gap: 20px 20px;
  }

  .exp-title{ font-size: clamp(20px,2.6vw,28px); }
  .exp-tag{ font-size: clamp(14px,2vw,18px); line-height:1.2; }
  .exp-desc{ font-size: 15px; max-width: 80%; }

  .cta-perks{
    display:grid;
    grid-template-columns: repeat(3,1fr);
    gap: 14px;
    justify-items:center;
  }

  .signup-card .form-grid{
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
  }
  .signup-card .field-full{ grid-column: 1 / -1; }

  .footer-head .footer-title{ font-size: clamp(22px,3vw,30px); }
  .partner{ display:grid; grid-template-columns: 160px 1fr; gap:16px; align-items:center; }
}

/* ===== ≤ 768px (mobile grande) ===== */
@media (max-width:768px){
  /* header */
  .site-header{ padding:8px 0; background: rgba(0,0,0,.55); }
  .header-flex{ gap: 10px; }
  .site-header .nav{ display:flex; gap:8px; }
  .site-header .nav a{ font-size:13px; padding:8px 10px; }

  /* heros / banners */
  .banner2-bg,
  .banner3-bg,
  .banner4-bg{ min-height: auto; padding: 48px 0; }
  .container-banner,
  .container-banner-2,
  .container-banner3{ padding: 0 14px; }

  .title-lg-h2{ line-height:1.1; }
  .text-down h6{ font-size: clamp(20px,5.5vw,28px); line-height:1.2; }
  .text-down p{ font-size: clamp(14px,4.2vw,18px); line-height:1.4; }

  /* grid experiências */
  .experiences-grid{ grid-template-columns: 1fr; gap: 18px 20px; }
  .exp-img{ aspect-ratio:16/9; }
  .exp-meta{ margin-top:10px; }
  .exp-title{ font-size: clamp(18px,5vw,24px); }
  .exp-desc{ max-width: 92%; }

  /* CTA */
  .cta-title{ font-size: clamp(26px,6vw,34px); }
  .cta-sub{ font-size: 16px; }
  .cta-perks{ grid-template-columns: 1fr; gap:10px; }
  .perk{ display:flex; align-items:center; gap:10px; text-align:left; }

  /* Form */
  .signup-card{ padding: 16px; }
  .signup-card .form-grid{ grid-template-columns: 1fr; }
  .btn-cta,
  .actions-increvete .btn{ width: 100%; }

  /* Footer */
  .partners-grid{ display:grid; grid-template-columns: 1fr; gap: 24px; }
  .partner{ grid-template-columns: 1fr; text-align:center; }
  .partner-copy{ text-align:center; }
  .footer-hero img{ width: min(86vw, 560px); height: auto; }
}

/* ===== ≤ 560px (mobile) ===== */
@media (max-width:560px){
  .logo img{ height: 36px; width:auto; }
  .hero-slick__img{ height: 42vh; }
 .actions-increvete img {
    max-width: 50vw;
    height: auto;
}

  .title-lg-h3{ font-size: clamp(16px,4.4vw,20px); }
  .title-lg-h2{ font-size: clamp(22px,7.2vw,30px); }
  .title-lg-bh3{ font-size: clamp(18px,6vw,24px); }
  .title-lg-bh6{ font-size: clamp(20px,5.2vw,26px); }

  .exp-title{ font-size: clamp(16px,5.2vw,22px); }
  .exp-tag{ font-size: 14px; }
  .exp-desc{ font-size: 14px; }

  .cta-perks .perk-text{ font-size: 15px; line-height:1.3; }
  .btn-cta{ padding: 12px 18px; font-size: 16px; }


#banner1 img.hero-img {
    height: 62vh;
    margin-top: 30px;
    object-fit: cover;
    object-position: center;
}
.experiences-grid {
    margin: 50px auto;
}

  #banner1 .actions-increvete .btn {
      font-size: 20px;
      line-height: 30px;
      margin-top: 20px;
  }

.container {
    width: calc(100% - 6%);
        padding: 5px 0;
}
.header-flex {
    gap: 5px;
    padding: 5px 0;
}
.container-banner-2 {
    gap: 10vh;
    text-align: center;
    padding: 5% 0px;
    max-width: 90%;
}
.cta-perks {
    gap: 25px;
}
.signup-card {
    width: min(640px, 100%);
}
.footer-sub {
    font-size: 16px;
    line-height: 20px;
}

.partner-logo img {
    width: 161px;
    margin: auto;
}
.partner-copy .partner-name{
  display: none;
}
.exp {
    color: #fff;
    margin-top: 50px;
}


.inscrevete-text{
    z-index:9999;
}

}

/* ===== ≤ 380px (telefones pequenos) ===== */
@media (max-width:380px){
  .site-header .nav a{ font-size:12px; padding:6px 8px; }
  .cta-title{ font-size: 22px; }
  .exp-desc{ font-size: 13px; }
  .signup-card{ padding: 14px 12px; }
}
