:root{
  --bg0:#07040a;
  --bg1:#120615;
  --wine:#1a0716;
  --violet:#2b0f3b;
  --violet2:#3b1652;
  --gold:#caa85b;
  --gold2:#e2cf8e;
  --text:#f2efe9;
  --muted:#c9c3bb;
  --line:rgba(202,168,91,.35);
  --card:rgba(18,6,21,.72);
  --card2:rgba(26,7,22,.78);
  --shadow:0 18px 40px rgba(0,0,0,.55);
  --radius:18px;
  --radius2:26px;
  --max:1160px;
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  --serif: ui-serif, Georgia, "Times New Roman", Times, serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--text);
  font-family:var(--font);
  background:
    radial-gradient(1200px 650px at 18% 10%, rgba(74, 20, 108,.25), transparent 60%),
    radial-gradient(1000px 600px at 85% 22%, rgba(202,168,91,.14), transparent 62%),
    radial-gradient(900px 600px at 50% 115%, rgba(35, 6, 44,.55), transparent 60%),
    linear-gradient(180deg, var(--bg0), var(--wine) 48%, var(--bg0));
  min-height:100vh;
}

a{color:inherit; text-decoration:none}
p{margin:0 0 14px 0; line-height:1.75; color:var(--text); text-align:justify; text-justify:inter-word}
small{color:var(--muted)}
ul{margin:0; padding-left:18px}
li{margin:6px 0; line-height:1.6; color:var(--text); text-align:justify}
h1,h2,h3{margin:0 0 12px 0}
h1{font-family:var(--serif); font-weight:700; letter-spacing:.2px; font-size: clamp(28px, 4.2vw, 52px);}
h2{font-family:var(--serif); font-weight:700; letter-spacing:.2px; font-size: clamp(22px, 3.2vw, 34px);}
h3{font-weight:700; letter-spacing:.2px; font-size: 18px;}
.container{max-width:var(--max); margin:0 auto; padding:0 20px;}
.section{padding:72px 0}
.section.tight{padding:52px 0}
.kicker{
  display:inline-flex; align-items:center; gap:10px;
  font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--gold2);
}
.kicker:before{
  content:""; width:44px; height:1px; background:var(--line);
}
.hr{
  height:1px; background:linear-gradient(90deg, transparent, var(--line), transparent);
  margin:18px 0 22px;
}
.card{
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  border:1px solid var(--line);
  border-radius:var(--radius2);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.card.pad{padding:22px}
.card.soft{
  background:linear-gradient(180deg, rgba(43,15,59,.22), rgba(18,6,21,.72));
}
.grid{
  display:grid; gap:18px;
}
.grid.hero{grid-template-columns: 1.15fr .85fr; align-items:center; gap:28px;}
.grid.two{grid-template-columns:1fr 1fr;}
.grid.three{grid-template-columns:1fr 1fr 1fr;}
@media (max-width: 980px){
  .grid.hero{grid-template-columns:1fr; gap:18px;}
  .grid.two{grid-template-columns:1fr;}
  .grid.three{grid-template-columns:1fr;}
}
.topbar{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(10px);
  background:rgba(7,4,10,.55);
  border-bottom:1px solid rgba(202,168,91,.18);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 0;
}
.brand{display:flex; align-items:center; gap:12px; min-width: 240px;}
.brand img{width:46px; height:46px; object-fit:contain}
.brand .name{line-height:1.05}
.brand .name b{font-family:var(--serif); font-size:14px; letter-spacing:.08em}
.brand .name span{display:block; font-size:11px; color:var(--muted); letter-spacing:.10em; text-transform:uppercase}

.navlinks{
  display:flex; align-items:center; gap:14px; flex-wrap:wrap;
  justify-content:flex-end;
}
.navlinks a{
  font-size:12.5px;
  color:rgba(242,239,233,.92);
  padding:10px 10px;
  border-radius:12px;
  border:1px solid transparent;
}
.navlinks a:hover{
  border-color:rgba(202,168,91,.22);
  background:rgba(43,15,59,.18);
}
.navcta{display:flex; gap:10px; align-items:center}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(202,168,91,.55);
  font-weight:700;
  letter-spacing:.02em;
  transition: transform .12s ease, background .12s ease, border-color .12s ease, box-shadow .12s ease;
  cursor:pointer;
  user-select:none;
}
.btn:active{transform:translateY(1px)}
.btn.gold{
  background:linear-gradient(180deg, rgba(226,207,142,.18), rgba(202,168,91,.12));
  color:var(--text);
  box-shadow: 0 14px 30px rgba(0,0,0,.45);
}
.btn.purple{
  background:linear-gradient(180deg, rgba(59,22,82,.45), rgba(18,6,21,.92));
  color:var(--text);
}
.btn.ghost{
  background:transparent;
  border-color:rgba(202,168,91,.25);
  color:rgba(242,239,233,.95);
}
.btn:hover{box-shadow: 0 18px 40px rgba(0,0,0,.55)}
.badge{
  display:inline-flex; align-items:center;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(202,168,91,.30);
  background:rgba(26,7,22,.60);
  font-size:12px;
  color:rgba(242,239,233,.92);
}
.hero{
  padding:44px 0 26px;
}
.hero .lead{font-size:16px; color:rgba(242,239,233,.92)}
.hero .actions{display:flex; gap:12px; flex-wrap:wrap; margin-top:18px}
.figure{
  padding:18px;
}
.figure .frame{
  border-radius:24px;
  border:1px solid rgba(202,168,91,.35);
  background:
    radial-gradient(600px 380px at 25% 15%, rgba(202,168,91,.12), transparent 62%),
    radial-gradient(620px 420px at 70% 60%, rgba(74,20,108,.22), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(0,0,0,.12));
  overflow:hidden;
  box-shadow:var(--shadow);
}
.figure .frame img{
  width:100%;
  height:auto;
  display:block;
  aspect-ratio: 1 / 1;
  object-fit:contain;
  padding:18px;
}
.pills{display:flex; gap:10px; flex-wrap:wrap; margin-top:16px}
.pill{
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(202,168,91,.22);
  background:rgba(43,15,59,.15);
  font-size:12px;
  color:rgba(242,239,233,.92);
}
.step{
  display:flex; gap:14px; align-items:flex-start;
}
.step .num{
  width:38px; height:38px;
  border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  border:1px solid rgba(202,168,91,.35);
  background:rgba(43,15,59,.28);
  font-weight:800;
}
.step .meta{flex:1}
.step .meta p{color:rgba(242,239,233,.92)}
.footer{
  padding:30px 0 42px;
  border-top:1px solid rgba(202,168,91,.18);
  background:rgba(7,4,10,.55);
}
.footer .cols{
  display:grid; gap:18px;
  grid-template-columns: 1.2fr .8fr .8fr;
}
@media (max-width: 980px){
  .footer .cols{grid-template-columns:1fr}
}
.footer a{color:rgba(242,239,233,.92)}
.footer a:hover{color:var(--gold2)}
.legalbar{
  margin-top:18px;
  padding-top:16px;
  border-top:1px solid rgba(202,168,91,.18);
  color:rgba(242,239,233,.80);
  font-size:12px;
  line-height:1.6;
  text-align:justify;
}
.note{
  color:rgba(242,239,233,.85);
  font-size:13px;
  text-align:justify;
}
.quote{
  font-family:var(--serif);
  font-style:italic;
  color:rgba(242,239,233,.92);
  border-left:2px solid rgba(202,168,91,.35);
  padding-left:14px;
  margin:14px 0 0;
  text-align:justify;
}
.callout{
  padding:18px;
  border-radius:22px;
  border:1px solid rgba(202,168,91,.25);
  background:linear-gradient(180deg, rgba(202,168,91,.10), rgba(43,15,59,.14));
}
.faq details{
  border:1px solid rgba(202,168,91,.22);
  border-radius:18px;
  padding:14px 14px;
  background:rgba(18,6,21,.58);
  margin:10px 0;
}
.faq summary{
  cursor:pointer;
  font-weight:800;
}
.faq summary::-webkit-details-marker{display:none}
.faq p{margin-top:10px}
.cookie{
  position:fixed; left:16px; right:16px; bottom:16px;
  max-width: 980px; margin:0 auto;
  z-index:60;
  display:none;
}
.cookie .wrap{
  display:flex; gap:14px; flex-wrap:wrap;
  align-items:center; justify-content:space-between;
}
.cookie .wrap p{margin:0; font-size:13px}


/* === HERO BACKGROUND (Institucional) === */
section.hero{
  position:relative;
  overflow:hidden;
}
section.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("media/3fpcgz.jpg");
  background-size:cover;
  background-position: 50% 30%;
  background-repeat:no-repeat;
  opacity:.45; /* visível, mas discreto */
  filter:saturate(.95) contrast(1.05);
  transform:scale(1.05);
  pointer-events:none;
  z-index:0;
}
section.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(1200px 500px at 18% 40%, rgba(106,62,137,.22), transparent 60%),
    linear-gradient(180deg, rgba(7,4,10,.86), rgba(7,4,10,.72) 45%, rgba(7,4,10,.94));
  pointer-events:none;
  z-index:1;
}
section.hero > .container{
  position:relative;
  z-index:2;
}

/* Mobile: reposiciona o enquadramento para preservar rostos */
@media (max-width: 720px){
  section.hero::before{
    background-position: 35% 24%;
    opacity:.18;
  }
}

.card.media{
  min-height: 280px;
  display: flex;
  flex-direction: column;
}

.card.media .frame{
  flex: 1;
}

/* === Video embed (between Hero and Caminho) === */
#video .video-center{
  display:flex;
  justify-content:center;
}
#video .video-frame{
  width:min(980px, 100%);
  padding:10px;
  border-radius:18px;
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.01));
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
}
#video .video-frame:before{
  content:"";
  position:absolute;
  inset:-22px;
  background:radial-gradient(circle at 50% 45%, rgba(202,168,91,.22), transparent 60%);
  filter:blur(14px);
  opacity:.9;
  pointer-events:none;
}
#video .video-aspect{
  position:relative;
  padding-top:56.25%;
  border-radius:14px;
  overflow:hidden;
  z-index:1;
}
#video .video-aspect iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  border-radius:14px;
}

.video-cover{
 position:relative;
 cursor:pointer;
 border:1px solid #c9a14a;
 border-radius:12px;
 overflow:hidden;
 box-shadow:0 0 40px rgba(201,161,74,.5);
 background:transparent;
 padding:0;
}
.video-cover:focus{outline:none}
.video-cover img{
 width:100%;
 display:block;
}
.play-btn{
 position:absolute;
 inset:0;
 display:flex;
 align-items:center;
 justify-content:center;
 font-size:64px;
 color:#fff;
 background:none;
}


/* --- BLOCO EXPANDIR (texto + vídeo) --- */
.hero--expandir{
  position: relative;
  padding: 72px 0;
  overflow: hidden;
}
.hero--expandir .hero-bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(1200px 600px at 18% 30%, rgba(255, 255, 255, .10), rgba(0,0,0,0) 55%),
    linear-gradient(180deg, rgba(0,0,0,.70), rgba(0,0,0,.70)),
    url("ilemp0.jpg") center/cover no-repeat;
  filter: saturate(1.05) contrast(1.02);
  opacity: .95;
}
.hero--expandir .container{ position: relative; }
.hero--expandir .hero-grid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 28px;
  align-items: start;
}
@media (max-width: 980px){
  .hero--expandir .hero-grid{ grid-template-columns: 1fr; }
}

.hero--expandir .kicker{
  font-size: 14px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 10px;
}

.hero--expandir .hero-copy{
  background: rgba(10,8,12,.55);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 22px 22px 18px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(6px);
}

.hero--expandir .readmore p{
  margin: 0 0 14px;
}
.hero--expandir .readmore p:last-child{ margin-bottom: 0; }

/* colapsar/expandir */
.hero--expandir .readmore{
  position: relative;
}
.hero--expandir .readmore.is-collapsed{
  max-height: 280px;
  overflow: hidden;
}
.hero--expandir .readmore.is-collapsed::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:0;
  height: 110px;
  background: linear-gradient(to bottom, rgba(10,8,12,0), rgba(10,8,12,.92));
}

/* botão do ler mais */
.hero--expandir .readmore-toggle{
  margin-top: 12px;
}

/* vídeo do lado (usa o mesmo frame do vídeo principal) */
.hero--expandir .video-frame--side{
  max-width: 520px;
  margin-left: auto;
}
@media (max-width: 980px){
  .hero--expandir .video-frame--side{
    max-width: 760px;
    margin: 0 auto;
  }
}

/* garante capa/iframe ocupando o aspect box */
#video .video-aspect,
#expandir .video-aspect{
  position: relative;
  padding-top: 56.25%;
}
#video .video-aspect > iframe,
#video .video-aspect .video-cover,
#expandir .video-aspect > iframe,
#expandir .video-aspect .video-cover{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

#video .video-cover img{
  width:100%;
  height:100%;
  object-fit:cover;
}

#video .play-btn{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  font-size:64px;
  color:#fff;
  background:none;
}

/* DEIXAR O CARD DO VÍDEO MENOR (desktop) */
#video .video-frame{
  width: 100% !important;
  max-width: 760px !important;  /* <<< ajuste aqui: 680 / 720 / 760 / 820 */
}

/* mobile: ocupa a tela com respiro */
@media (max-width: 640px){
  #video .video-frame{
    max-width: 92vw !important;
  }
}

/* afasta o texto dos cards dos cursos */
#caminho .container > p:last-of-type{
  margin-bottom: 48px;
}


/* override: play icon branco (sem fundo) */
.play-btn{background:none !important;}
.play-btn-icon{width:78px; height:78px; display:block; filter:none;}
@media (max-width: 640px){.play-btn-icon{width:64px; height:64px;}}


/* --- FIX: play branco com tamanho controlado --- */
#video .play-btn,
#expandir .play-btn{
  background: none !important;
}

/* tamanho do ícone (desktop) */
#video .play-btn-icon,
#expandir .play-btn-icon{
  width: 84px !important;   /* ajuste aqui: 64 / 72 / 84 */
  height: 84px !important;
  display: block !important;
}

/* mobile */
@media (max-width: 640px){
  #video .play-btn-icon,
  #expandir .play-btn-icon{
    width: 64px !important;
    height: 64px !important;
  }
}


/* =========================
   MOBILE: ajustes finos (sem impactar desktop)
   ========================= */
@media (max-width: 720px){
  /* tipografia: leitura limpa */
  html{ -webkit-text-size-adjust: 100%; }
  body{ font-size:16px; }
  p, li, .lead, .note, .callout p{
    text-align: justify !important;
    text-justify: inter-word;
    hyphens: auto;
    overflow-wrap: anywhere;
    word-break: normal;
  }
  /* respiro lateral consistente */
  .container{ padding-left:18px; padding-right:18px; }
  /* hero: título menor apenas no mobile */
  .hero h1{
    font-size: clamp(22px, 6.2vw, 32px) !important;
    line-height: 1.18;
  }
  /* botões: empilhar e ocupar largura */
  .actions{ flex-direction: column; }
  .actions .btn{ width:100%; }
  /* evitar colunas/elementos comprimidos */
  .hero-grid{ grid-template-columns: 1fr !important; gap:18px !important; }
  /* cards e blocos: evitar overflow por padding/raios grandes */
  .card{ border-radius:18px; }
  /* imagens: nunca estourar */
  img, svg, video, iframe{ max-width:100%; height:auto; }
  /* iframes (youtube) */
  iframe{ width:100%; }
}

/* micro-ajustes para telas muito pequenas */
@media (max-width: 420px){
  .container{ padding-left:14px; padding-right:14px; }
  .pill{ font-size:11px; }
  .btn{ padding:12px 12px; }
}

.hero h1{
  font-size: 42px;
  line-height: 1.15;
}

/* --- Marca institucional (título + subtítulo) --- */

.brand-fixed{
  display:flex;
  align-items:center;
  gap:14px;
  text-decoration:none;
}

.brand-text{
  display:flex;
  flex-direction:column;
  justify-content:center;
  line-height:1;
}

.brand-title{
  margin:0;
  font-family: Georgia, "Times New Roman", Times, serif;
  font-weight:700;
  letter-spacing:.2px;
  color:#d4af37;
}

.brand-subtitle{
  margin-top:-1px;
  font-family: Georgia, "Times New Roman", Times, serif;
  font-weight:400;
  color:#d8d0c6;
}

/* --- TOPO --- */

header .brand-fixed .brand-title{
  font-size:16px;
}

header .brand-fixed .brand-subtitle{
  font-size:11px;
}

/* --- RODAPÉ --- */

footer .brand-fixed .brand-title{
  font-size:16px;
}

footer .brand-fixed .brand-subtitle{
  font-size:11px;
}

/* --- TAMANHO DO LOGO --- */

header .brand-fixed img{
  width:42px;
  height:42px;
}

footer .brand-fixed img{
  width:42px;
  height:42px;
}

main.section.tight h1{
  font-size: 25px;
  line-height: 1.12;
}


/* ===== FINAL MOBILE LAYOUT FIXES ===== */
.mobile-break{display:none;}

.contact-lines,.footer-contact{margin:0;}
.contact-line,.footer-line{
  display:block;
}

@media (max-width: 980px){
  .section{padding:56px 0;}
  .section.tight{padding:42px 0;}
  .container{padding-left:16px; padding-right:16px;}

  /* header */
  .topbar{
    padding:6px 0;
  }
  .nav{
    display:grid;
    grid-template-columns: 1fr auto;
    align-items:center;
    gap:12px;
    padding:10px 0;
  }
  .brand,
  .brand-fixed{
    display:flex;
    align-items:center;
    gap:10px;
    min-width:0;
    width:100%;
  }
  .brand img,
  .brand-fixed img,
  header .brand-fixed img{
    width:44px;
    height:44px;
    flex:0 0 44px;
  }
  .brand-text,
  .brand .name{
    min-width:0;
    flex:1 1 auto;
  }
  .brand-title,
  header .brand-fixed .brand-title{
    display:block;
    font-size:15px !important;
    line-height:1.02;
    letter-spacing:0;
    white-space:normal;
  }
  .brand-subtitle,
  header .brand-fixed .brand-subtitle,
  .brand .name span{
    display:block;
    font-size:7.8px !important;
    line-height:1.1;
    margin-top:3px;
    white-space:normal;
    color:var(--muted);
  }

  header .navcta{
    width:auto;
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap:0;
  }
  header .navcta .btn.ghost{
    min-width:124px;
    min-height:46px;
    padding:12px 16px;
    font-size:14px;
  }
  header .navcta .btn.purple{
    display:none !important;
  }

  /* lateral drawer */
  .navlinks{
    position:fixed;
    top:0;
    right:-100%;
    width:min(86vw, 330px);
    height:100dvh;
    display:flex !important;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    gap:8px;
    padding:92px 16px 24px;
    background:linear-gradient(180deg, rgba(18,6,21,.98), rgba(7,4,10,.98));
    border-left:1px solid rgba(202,168,91,.25);
    box-shadow:-18px 0 40px rgba(0,0,0,.55);
    z-index:120;
    transition:right .24s ease;
    overflow-y:auto;
  }
  .navlinks a{
    width:100%;
    text-align:left;
    padding:13px 14px;
    font-size:14px;
    border-radius:14px;
    border:1px solid rgba(202,168,91,.18);
    background:rgba(43,15,59,.16);
  }
  .navlinks[data-open="1"]{
    right:0;
  }
  body.menu-open{
    overflow:hidden;
  }

  /* hero */
  .hero{
    padding:32px 0 18px !important;
  }
  .hero .kicker{
    display:none !important;
  }
  .hero .hr{
    display:none !important;
  }
  .hero h1{
    margin:0 auto 14px;
    max-width:300px;
    font-size:22px !important;
    line-height:1.08 !important;
    text-wrap:balance;
    text-align:center !important;
  }
  .mobile-break{display:block;}
  .hero .lead{
    font-size:15px;
    line-height:1.72;
    text-align:justify !important;
  }
  .pills{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:8px;
  margin-top:14px;
}
  .pill{
    font-size:11px;
    padding:7px 9px;
  }
  .actions{
    display:flex;
    flex-direction:column;
    gap:10px;
    margin-top:16px;
  }
  .actions .btn,
  .btn,
  a.btn,
  button.btn{
    width:100%;
    min-height:48px;
    text-align:center;
  }

  /* cards / blocks */
  .card,
  .callout,
  .hero-copy,
  .video-frame,
  .figure .frame,
  .faq details{
    border-radius:18px;
  }
  .card.pad,
  .hero-copy,
  .figure{
    padding:16px;
  }
  .grid.hero,
  .grid.two,
  .grid.three,
  .hero--expandir .hero-grid{
    grid-template-columns:1fr !important;
    gap:16px !important;
  }
  .step{
    gap:12px;
    align-items:flex-start;
  }
  .step .num{
    flex:0 0 38px;
    width:38px;
    height:38px;
  }
  .step .meta{
    min-width:0;
  }
  .step .meta h3{
    line-height:1.3;
    font-size:17px;
  }
  .step .meta p{
    font-size:15px;
    line-height:1.72;
    text-align:justify !important;
  }

  /* media blocks */
  .figure .frame img{
    aspect-ratio:auto;
    padding:12px;
  }
  #video .video-frame,
  .hero--expandir .video-frame--side{
    max-width:100% !important;
    width:100% !important;
  }
  #video .video-aspect,
  #expandir .video-aspect{
    border-radius:14px;
    overflow:hidden;
  }

  /* text rhythm */
  p, li, .lead, .note, .quote, .callout p, .legalbar{
    text-align:justify !important;
    text-justify:inter-word;
    hyphens:auto;
    overflow-wrap:anywhere;
    word-break:normal;
  }
  h2{
    font-size:24px !important;
    line-height:1.18 !important;
    text-align:left;
  }
  h3{
    font-size:18px;
    line-height:1.3;
  }

  /* contact */
  #contato .grid.two{
    gap:14px !important;
  }
  #contato .actions{
    display:grid;
    grid-template-columns:1fr;
    gap:10px;
  }
  #contato .contact-line{
    white-space:nowrap;
    font-size:12.5px;
    line-height:1.45;
  }
  #contato .card p{
    margin-bottom:14px;
  }

  /* footer */
  .footer{
    padding:26px 0 34px;
  }
  .footer .cols{
    grid-template-columns:1fr !important;
    gap:18px;
  }
  footer .brand,
  footer .brand-fixed{
    display:flex;
    align-items:center;
    gap:10px;
    width:100%;
  }
  footer .brand-fixed img{
    width:44px;
    height:44px;
    flex:0 0 44px;
  }
  footer .brand-title{
    font-size:15px !important;
    line-height:1.02;
    white-space:nowrap;
  }
  footer .brand-subtitle{
    font-size:10px !important;
    line-height:1.1;
    white-space:nowrap;
  }
  .footer-contact{
    display:block;
    margin-top:6px;
  }
  .footer-line{
    display:block;
    white-space:nowrap;
    font-size:12px;
    line-height:1.5;
  }
  .footer .btn.ghost{
    width:100%;
  }

  /* cookie */
  .cookie{
    left:12px;
    right:12px;
    bottom:12px;
  }
  .cookie .wrap{
    gap:10px;
  }
}

@media (max-width: 420px){
  .container{padding-left:14px; padding-right:14px;}
  .brand-title,
  header .brand-fixed .brand-title,
  footer .brand-title{
    font-size:14px !important;
  }
  .brand-subtitle,
  header .brand-fixed .brand-subtitle,
  footer .brand-subtitle{
    font-size:10px !important;
  }
  .brand-title,
  .brand-subtitle{
    white-space:normal !important;
  }
  .hero h1{
    max-width:290px;
    font-size:22px !important;
  }
  #contato .contact-line,
  .footer-line{
    font-size:9.5px;
  }
}

@media (max-width: 720px){
  .hero h1{
    display:none !important;
  }
}

#tee .faq h3{
  margin-top:40px;
}

@media (max-width: 720px){

  header .brand-subtitle{
    font-size:12px !important;
  }

  footer .brand-subtitle{
    font-size:12px !important;
  }

}

@media (max-width: 720px){

  #caminho h2{
    font-size:20px !important;
    line-height:1.2;
  }

}

@media (max-width: 720px){

  #tee h2{
    text-align: justify !important;
    text-justify: inter-word;
  }

}

@media (max-width: 720px){

  header .brand-fixed .brand-subtitle,
  footer .brand-fixed .brand-subtitle{
    font-size:11.5px !important;
    line-height:1.15;
  }

}

@media (max-width: 720px){

  .pills{
    gap:6px;
  }

  .pills span,
  .pills a{
    font-size:11px !important;
    padding:6px 10px !important;
    border-radius:12px;
  }

}

/* ===== CARDS COM LEVE DOURADO + GLOW ===== */

.card{
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(212,175,55,0.25);
  box-shadow:
    0 0 0 1px rgba(212,175,55,0.08),
    0 10px 30px rgba(0,0,0,0.5),
    0 0 18px rgba(212,175,55,0.08);
}

/* overlay dourado suave */
.card::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(
    120deg,
    rgba(212,175,55,0.06),
    rgba(212,175,55,0.02),
    transparent 40%
  );
  pointer-events:none;
}

/* glow mais visível no hover (pc) */
.card:hover{
  border: 1px solid rgba(212,175,55,0.4);
  box-shadow:
    0 0 0 1px rgba(212,175,55,0.15),
    0 12px 40px rgba(0,0,0,0.6),
    0 0 28px rgba(212,175,55,0.18);
}


@media (max-width: 720px){

  .card{
    background: linear-gradient(
      180deg,
      rgba(212,175,55,0.12),
      rgba(18,6,21,0.9) 60%
    ) !important;
  }

}

@media (max-width: 720px){
  /* destaque somente nos cards da oferta em #caminho */
  #caminho .card.pad.soft{
    position: relative;
    overflow: hidden;
    background:
      linear-gradient(180deg, rgba(46,10,30,.96), rgba(18,6,21,.98)) !important;
    border: 1.5px solid rgba(212,175,55,.72) !important;
    box-shadow:
      0 0 0 1px rgba(212,175,55,.18),
      0 14px 34px rgba(0,0,0,.55),
      0 0 22px rgba(212,175,55,.22),
      inset 0 1px 0 rgba(255,235,170,.10) !important;
  }

  #caminho .card.pad.soft::before{
    content:"";
    position:absolute;
    inset:0;
    pointer-events:none;
    background:
      linear-gradient(
        135deg,
        rgba(255,235,170,.16) 0%,
        rgba(212,175,55,.10) 18%,
        rgba(212,175,55,.04) 34%,
        rgba(0,0,0,0) 52%
      );
    opacity: 1 !important;
  }

  #caminho .card.pad.soft::after{
    content:"";
    position:absolute;
    inset:0;
    border-radius: inherit;
    pointer-events:none;
    box-shadow:
      inset 0 0 0 1px rgba(255,225,140,.12),
      inset 0 -18px 30px rgba(0,0,0,.18);
  }

  #caminho .step .num{
    border-color: rgba(212,175,55,.78) !important;
    color: #f3d88d !important;
    background: linear-gradient(180deg, rgba(80,24,52,.78), rgba(30,8,20,.92)) !important;
    box-shadow: 0 0 14px rgba(212,175,55,.12);
  }

  #caminho .step .meta h3{
    color: #f3d88d !important;
  }

  #caminho .step .meta p{
    color: #f5efe4 !important;
  }

  #caminho .actions .btn.gold{
    background: linear-gradient(180deg, #d7b35c, #b98b2c) !important;
    border-color: rgba(255,224,138,.85) !important;
    color: #2a0718 !important;
    box-shadow:
      0 8px 20px rgba(0,0,0,.32),
      0 0 16px rgba(212,175,55,.18) !important;
  }

  #caminho .actions .btn.gold:hover,
  #caminho .actions .btn.gold:active{
    transform: none !important;
    filter: brightness(1.03);
  }
}

@media (max-width: 980px){
  /* 1) cabeçalho em duas linhas: marca em cima, botão menu embaixo */
  .nav{
    grid-template-columns: 1fr !important;
    align-items: start !important;
    gap: 10px !important;
  }

  .brand,
  .brand-fixed{
    width: 100% !important;
  }

  header .navcta{
    grid-column: 1 / -1 !important;
    width: 100% !important;
    display: block !important;
  }

  /* 2) botão menu ocupa a largura como botão normal */
  header .navcta .btn.ghost{
    width: 100% !important;
    min-width: 0 !important;
    min-height: 48px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 14px 18px !important;
    border-radius: 22px !important;

    /* 3) mesma linguagem visual do botão "Entrar no Portal" */
    background: linear-gradient(180deg, rgba(98,76,78,.92), rgba(70,50,55,.92)) !important;
    border: 1px solid rgba(212,175,55,.55) !important;
    color: #f3efe9 !important;
    box-shadow:
      0 10px 24px rgba(0,0,0,.28),
      inset 0 1px 0 rgba(255,255,255,.05) !important;

    font-size: 16px !important;
    font-weight: 700 !important;
    text-align: center !important;
font-family: var(--serif) !important;
    letter-spacing: .2px !important;
  }
}


@media (max-width: 980px){
  h2{
    font-size: 20px !important;
    line-height: 1.2 !important;
  }
}

/* Apenas bloco "Programas" do rodapé — PC e mobile */
.footer .cols > div:nth-child(2) h3,
.footer .cols > div:nth-child(2) ul li,
.footer .cols > div:nth-child(2) ul li a{
  color: var(--gold) !important;
}
.topo-capa{
  width:100%;
}

.topo-capa img{
  width:100%;
  height:auto;
  display:block;
}

/* Desktop: esconde o botão/menu mobile */
#navToggle{
  display: none !important;
}

/* Mobile: mostra o botão/menu mobile */
@media (max-width: 980px){
  #navToggle{
    display: flex !important;
  }
}

html, body {
  margin: 0;
  padding: 0;
  background: #12030a !important; /* use o tom mais escuro real do site */
  min-height: 100%;
}

body {
  overflow-x: hidden;
}

#app, main, .site-wrap, .page, .page-wrap {
  background: transparent;
}

html {
  overscroll-behavior-y: none;
  overscroll-behavior-x: none;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background: linear-gradient(180deg, #1a060c 0%, #12030a 100%);
  z-index: -1;
  pointer-events: none;
}

footer small{
  display:block;
  text-align: justify;
}

html, body{
  max-width: 100%;
  overflow-x: hidden;
}

img, section, div{
  max-width: 100%;
}

html, body {
  -webkit-user-select: none !important;
  -moz-user-select: none !important;
  -ms-user-select: none !important;
  user-select: none !important;
  -webkit-touch-callout: none !important;
}

img, picture, svg, video, canvas {
  -webkit-user-drag: none !important;
  user-drag: none !important;
  -webkit-touch-callout: none !important;
}

img {
  pointer-events: none;
}

input, textarea, [contenteditable="true"] {
  -webkit-user-select: text !important;
  -moz-user-select: text !important;
  -ms-user-select: text !important;
  user-select: text !important;
}

.devtools-open body {
  filter: blur(10px);
  pointer-events: none;
}

body::after{
  content: "ICH • USO RESTRITO";
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
  width: max-content;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 3px;
  line-height: 1;
  color: rgba(212,175,55,0.18);
  text-shadow: 0 0 2px rgba(0,0,0,0.25);
  white-space: nowrap;
  pointer-events: none;
  z-index: 2147483647;
}


html, body {
  margin: 0;
  padding: 0;
  background: #12030a !important; /* use o tom mais escuro real do site */
  min-height: 100%;
}

body {
  overflow-x: hidden;
}

#app, main, .site-wrap, .page, .page-wrap {
  background: transparent;
}

html {
  overscroll-behavior-y: none;
  overscroll-behavior-x: none;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background: linear-gradient(180deg, #1a060c 0%, #12030a 100%);
  z-index: -1;
  pointer-events: none;
}

.card.pad p {
  font-size: 14px;
  line-height: 1.6;
}