:root {
  --color1: #ea5a0e;
  --color2: #1d1d1d;
  --color3: #fff;
  --container: 1200px;      /* largura máxima do conteúdo */
  --space: 48px;            /* espaçamento base */
  --paper:#fff;
  --panel:var(--color3);
  --panel-top: var(--color3);
  --ink: #1d1d1d;
  --radius-lg:28px;
  --container:1200px;
  --font-sans: "Montserrat", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --dep-bg:#fff;
  --dep-card:#f7f9fb;
  --dep-ink:#2f3f55;
  --dep-radius:18px;
}
body {
  padding: 0px;
  margin: 0px;
}
html, body, button, input, select, textarea {
  font-family: var(--font-sans);
}
/* pesos comuns do seu layout */
h1, h2, h3, .title { font-weight: 800; }
strong { font-weight: 700; }
p, li, .desc { font-weight: 400; }
.cta, .btn { font-weight: 600; }

/* suavização opcional (WebKit/Chromium) */
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

.alert {
  width: 100%;
  color: var(--color3);
  background-color: var(--color1);
  padding: 10px 0px 10px 0px;
  text-align: center;
  font-size: 1.25rem;
  position: fixed;
  top: 0;
  z-index: 9999;
  border-bottom: 1px solid var(--color3);
}

/* seção e grid */
.hero{
  background:#fff;                 /* fundo branco */
  color:var(--color2);
  padding-top: 1.5rem;
  font-family: var(--font-sans, "Montserrat", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif);
}
.hero .hero-container{
  max-width:var(100%);
  margin:0 auto;
  padding:0 clamp(16px, 4vw, var(--space));
  display:grid;
  grid-template-columns: 1fr;      /* mobile: 1 coluna */
  gap:clamp(20px, 4vw, 48px);
  align-items:center;
}

.hero-logo {
  width:30rem;
}

/* lado esquerdo (texto) */
.hero .texthero .hero-logo{
   height:auto; display:block;
  margin:0 0 clamp(5px,1.5vw,12px);
}
.hero .texthero .titulo{
  margin:0 0 clamp(10px, 2vw, 16px);
  font-weight:800;
  line-height:1.06;
  letter-spacing:.05em;
  font-size: 2rem;
  color:var(--color2);
}
.hero .texthero .titulo .hl{ color:var(--color1); }
.hero .texthero .subtitle{
  margin:0 0 clamp(18px, 3vw, 28px);
  max-width: 50ch;
  font-size:clamp(1rem, 1.2vw, 1.125rem);
  line-height:1.65;
  color:#344255;
}
.btn-pq {
  margin-top: 2rem;
  text-align: center;
}
/* CTA */
.btncta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  background:var(--color1);
  color:var(--color3);
  padding:14px 35px;
  font-size: 1.5rem;
  border-radius:999px;
  font-weight:700;
  text-decoration:none;
  box-shadow:0 8px 18px rgba(234,90,14,.25);
  transition: transform .15s ease, box-shadow .15s ease, opacity .15s ease;
  width:fit-content;
}
.hero .btncta:hover{ transform:translateY(-1px); box-shadow:0 10px 22px rgba(234,90,14,.32); }
.hero .btncta:active{ transform:translateY(0); box-shadow:0 6px 14px rgba(234,90,14,.22); }

/* lado direito (imagem em card 4:5) */
.hero .imageHero{
  justify-self:center;
  width:min(520px, 100%);
  position:relative;
  border-radius:var(--radius-hero);
  padding: clamp(8px, 1.6vw, 12px);  /* “moldura” */
  box-shadow: var(--shadow-hero), inset 0 0 0 10px var(--color3); /* borda branca grossa */
}
.hero .imageHero img{
  display:block;
  width:100%;
  height:auto;
  aspect-ratio:4/5;        /* recomendado 1080x1350 */
  object-fit:cover;
  border-radius:calc(var(--radius-hero) - 6px);
}

#modulos{ background:#fff; padding:clamp(32px,6vw,72px) 0; }
#modulos .mod-container{ max-width:var(--container); margin:0 auto; padding:0 clamp(16px,4vw,var(--space)); }
#modulos #modulos-title{ color:var(--color2); font-weight:800; text-align:center; font-size:clamp(1.6rem,3vw,2.2rem); margin:0 0 clamp(16px,3vw,28px); }

#modulos .mod-grid{ display:grid; gap:clamp(12px,2vw,18px); grid-template-columns:1fr; }
@media (min-width:760px){ #modulos .mod-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1100px){ #modulos .mod-grid{ grid-template-columns:repeat(3,1fr); } }

#modulos .mod-card{ background:#f7f9fb; border:1px solid rgba(16,37,71,.08); border-radius:16px; padding:clamp(14px,2vw,18px); box-shadow:0 6px 18px rgba(16,37,71,.06); }
#modulos .mod-nome{ color:var(--color2); font-weight:700; margin:0 0 6px; font-size:1.05rem; }
#modulos .mod-prof{ color:#364658; margin:0; font-size:.95rem; }

/* ===== Responsivo ===== */

/* mobile: esconder imagem para performance/UX */
@media (max-width: 899px){
  .hero {padding-top: 4rem;}
  .hero .imageHero{ display:none; }
  .hero .texthero .subtitle{ max-width: 60ch; }  /* leitura confortável */
  .hero-logo {width: 100%;}
}

/* desktop: dois lados */
@media (min-width: 900px){
  .hero .hero-container{
    grid-template-columns: 1.05fr .95fr;
  }
} 
/* acessibilidade/animação reduzida */
@media (prefers-reduced-motion: reduce){
  .hero .btncta{ transition:none; }
}
/* opcional: foco visível no CTA para teclado */
.hero .btncta:focus-visible{
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color1) 30%, white),
              0 8px 18px rgba(234,90,14,.25);
}
.info-item .icon{ display:block; margin:0 auto 10px; width:48px; height:auto; }
.info-wrap{
  max-width:var(--container);
  margin:calc(var(--space) * 1) auto;
  padding:0 clamp(12px, 3vw, var(--space));
}
.info-grid{
  background:linear-gradient(0deg, var(--panel) 72%, var(--panel-top) 72%);
  border-radius:var(--radius-lg);
  padding:clamp(20px, 4vw, 38px) clamp(14px, 3vw, 28px);
  display:grid;
  gap:12px;
  grid-template-columns:1fr;
  box-shadow:0 8px 26px rgba(0,0,0,.50);
  color:var(--ink);
  text-align:center;
}

.info-item{ padding:16px 10px; }
.Info-icon {
  width: 50%;
}
.title{
  margin:6px 0 6px;
  text-transform:uppercase;
  font-weight:800;
  letter-spacing:.02em;
  line-height:1.12;
  font-size:clamp(1rem, 2.4vw, 1.125rem);
  color:var(--ink);
}
.desc{
  margin:0;
  font-weight:600;
  font-size:clamp(.95rem, 2.2vw, 1.125rem);
  color:var(--ink);
  opacity:.98;
}

/* Responsivo: 1 → 2 → 4 colunas */
@media (min-width:560px){ .info-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:960px){ .info-grid{ grid-template-columns:repeat(4,1fr); } }

#para-quem{ background:#fff; }
.pq-container{ max-width:var(--container); margin:0 auto; padding:0 clamp(16px,4vw,var(--space)); }

.pq-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(20px,4vw,48px);
  align-items:center;
}

/* Imagem simples 4:5 (1080x1350) */
.pq-media{
  margin:0;
  width:min(560px, 100%);
  justify-self:center;
}
.pq-media img{
  display:block;
  width:100%;
  aspect-ratio:4 / 5;    /* mantém 1080×1350 */
  height:auto;           /* deixa o navegador calcular */
  object-fit:cover;      /* corta com elegância se precisar */
  border-radius:16px;    /* opcional: remova se não quiser cantos arredondados */
  box-shadow:0 12px 28px rgba(0,0,0,.50);
}

/* Texto */
.pq-content h2{
  color:var(--color2);
  font-size:clamp(1.8rem,3.4vw,3rem);
  line-height:1.05;
  margin:0 0 12px;
  font-weight:800;
}
.pq-content h3{
  color:var(--color2);
  font-size:clamp(1.05rem,1.6vw,1.25rem);
  margin:22px 0 8px;
  font-weight:800;
}
.pq-content p{
  color:#344255;
  font-size:clamp(1rem,1.25vw,1.05rem);
  line-height:1.6;
  margin:0 0 12px;
}
.pq-content p strong{ color:#0f2547; font-weight:800; }

/* Desktop: lado a lado */
@media (min-width:900px){
  .pq-grid{ grid-template-columns: 1.1fr 1fr; }
}

#publico-alvo{ background:#fff; padding:clamp(32px,6vw,72px) 0; }
.pa-container{ max-width:var(--container); margin:0 auto; padding:0 clamp(16px,4vw,var(--space)); }

#publico-alvo h2{
  color:var(--color2);
  text-align:center;
  font-weight:800;
  font-size:clamp(1.8rem,3.8vw,3rem);
  line-height:1.1;
  margin:0 0 clamp(20px,3vw,36px);
}

/* Grid */
.pa-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(16px,2.5vw,24px);
}

/* Card */
.pa-card{
  background:#f7f9fb;
  border:1px solid rgba(16,37,71,.10);
  border-radius:18px;
  box-shadow:0 6px 18px rgba(16,37,71,.08);
  padding:clamp(18px,3.5vw,28px);
  text-align:center;
}

.pa-icon{
  display:block;
  width:56px; height:auto;
  margin:0 auto clamp(10px,1.2vw,14px);
}

.pa-card h3{
  color:var(--color2);
  font-weight:800;
  font-size:clamp(1.05rem,1.5vw,1.25rem);
  margin:0 0 10px;
}

.pa-card p{
  color:#2f3f55;
  line-height:1.65;
  font-size:clamp(.98rem,1.1vw,1.05rem);
  margin:0;
}

/* Responsivo */
@media (min-width:760px){
  .pa-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (min-width:1100px){
  .pa-grid{ grid-template-columns:repeat(3,1fr); }
}

#reconhecimento{
  background:#fff; /* fundo branco, conforme pedido */
  padding:clamp(36px, 7vw, 88px) 0;
}

.rec-container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 clamp(16px, 4vw, var(--space));
  text-align:center;
}

#rec-title{
  color:var(--color2);
  font-weight:700;
  font-size:clamp(1.6rem, 3.4vw, 2.6rem);
  line-height:1.15;
  margin:0 0 clamp(18px, 4vw, 32px);
}
#rec-title .strong{
  font-weight:800;
}

/* Imagem central (responsiva) */
.rec-media{
  margin:0 auto;
  position:relative;
  width: min(760px, 100%);
}
.rec-media > img{
  display:block;
  width:100%;
  height:auto;
  border-radius:12px;
  box-shadow:0 10px 28px rgba(0,0,0,.12);
}

/* Selo opcional (imagem) */
.rec-badge{
  position:absolute;
  left:clamp(8px, 3vw, 24px);
  top:clamp(8px, 2.8vw, 20px);
  width:clamp(64px, 13vw, 110px);
  height:auto;
  transform:translateZ(0);
}

/* Espaço extra em telas grandes */
@media (min-width:1100px){
  #rec-title{ font-size:2.8rem; }
}
.selo-wrap {
  text-align: center;
  width: 100%;
  padding-bottom: 3rem;

}
#selofaculdade {
  width: 500px; padding: 0 3rem 0 3rem;
  vertical-align: baseline;
}
#selomec {
  width: 180px;  padding: 0 3rem 0 3rem;
  vertical-align: top;
}
@media (max-width:760px){
  #selofaculdade {width: 85%; padding: 0;}
  #selomec {width: 30%; padding: 0; margin-top: 35px;}
}
#futuro{
  background: var(--color1);
  color: var(--color3);
  padding: clamp(40px, 7vw, 96px) 0;
}

.futuro-container{
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 clamp(16px, 4vw, var(--space));
  text-align: center;
}

#futuro h2{
  color: var(--color3);
  margin: 0 0 clamp(16px, 3vw, 28px);
  font-weight: 800;
  line-height: 1.1;
  font-size: clamp(1.8rem, 4vw, 3rem);
}

#futuro p{
  color: var(--color3);
  margin: 0 auto;
  max-width: 80ch;               /* largura confortável para leitura */
  line-height: 1.75;
  font-size: clamp(1rem, 1.2vw, 1.125rem);
  opacity: .95;                  /* leve suavizada como no mock */
}
.container{
  max-width: var(--container);
  margin-inline: auto;                       /* centraliza horizontalmente */
  padding-inline: clamp(16px, 4vw, var(--space));
  padding: 48px 0px 48px 0px
}

#inscricao {
  display: grid;
  justify-items: center;                     
  gap: var(--space);
  text-align: center;
}

#form{
  width: min(640px, 100%);             
  margin-inline: auto; 
  box-shadow: 0 12px 28px rgba(0, 0, 0, .50);
}
#form div section div div {
  background-color: #fff;  
}
#rd-button-mevosh6q.bricks--component-button    {
  background-color: var(--color1);
  border-color: #943f11;
}

/* Depoimentos */
#videos{
  background:#111;                 /* para destacar como no print */
  padding:clamp(20px,5vw,48px) 0;
  color:var(--color3);
}
.vid-container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 clamp(16px,4vw,var(--space));
}
#videos-title{
  margin:0 0 clamp(12px,3vw,20px);
  font:800 clamp(1.2rem,3vw,1.6rem)/1 "Montserrat",system-ui,sans-serif;
  color:var(--color3);
}

/* faixa rolável com scroll-snap */
.vid-track{
  display:flex;
  gap:clamp(12px,2.8vw,24px);
  overflow-x:auto;
  padding:8px 4px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
}
.vid-track::-webkit-scrollbar{ height:8px }
.vid-track::-webkit-scrollbar-thumb{ background:#333; border-radius:999px }

/* card */
.vid-card{
  flex:0 0 clamp(260px, 36vw, 360px);
  display:block;
  position:relative;
  border-radius:var(--card-radius);
  overflow:hidden;
  scroll-snap-align:center;
  text-decoration:none;
  box-shadow:0 10px 24px rgba(0,0,0,.35);
  background:#000;
  isolation:isolate;
}
.vid-card img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  aspect-ratio:16/9;
  filter:brightness(.8);
  transition:filter .2s ease, transform .2s ease;
}
.vid-card::after{ /* leve gradiente para legibilidade do título */
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.0) 40%, rgba(0,0,0,.35) 100%);
  z-index:1;
}

/* ícone play */
.vid-card .play{
  position:absolute; inset:0;
  margin:auto; width:64px; height:64px;
  border:3px solid rgba(255,255,255,.9);
  border-radius:50%;
  z-index:2;
}
.vid-card .play::before{
  content:"";
  position:absolute; left:50%; top:50%;
  transform:translate(-40%,-50%);
  border-style:solid;
  border-width:12px 0 12px 18px;
  border-color:transparent transparent transparent rgba(255,255,255,.95);
}

/* título grande sobre o thumb (como no print) */
.vid-card .title{
  position:absolute; left:18px; right:18px; bottom:14px;
  z-index:2;
  font:800 clamp(.9rem,2.2vw,1.2rem)/1 "Montserrat",system-ui,sans-serif;
  color:#fff;
  letter-spacing:.06em;
  text-transform:uppercase;
  text-shadow:0 6px 14px rgba(0,0,0,.6);
}

/* hover */
.vid-card:hover img{ filter:brightness(.95); transform:scale(1.02); }

/* ===== Lightbox CSS-only (usa :target) ===== */
.vid-lightbox{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.85);
  display:none;
  align-items:center;
  justify-content:center;
  padding:clamp(12px,4vw,24px);
  z-index:9999;
}
.vid-lightbox:target{ display:flex; }

/* quadro do vídeo */
.vid-lightbox .frame{
  width:min(1024px, 96vw);
  aspect-ratio:16/9;
  background:#000;
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.5);
}
.vid-lightbox iframe{
  width:100%; height:100%; border:0; display:block;
}

/* botão fechar (canto superior) */
.vid-lightbox .close{
  position:fixed;
  top:clamp(8px,2.5vw,16px);
  right:clamp(8px,2.5vw,16px);
  width:42px; height:42px;
  border-radius:50%;
  background:rgba(255,255,255,.12);
  backdrop-filter: blur(4px);
}
.vid-lightbox .close::before,
.vid-lightbox .close::after{
  content:""; position:absolute; inset:0; margin:auto;
  width:22px; height:2px; background:#fff; border-radius:2px;
}
.vid-lightbox .close::before{ transform:rotate(45deg); }
.vid-lightbox .close::after{ transform:rotate(-45deg); }


#faq{
  background:#fff;
  padding:clamp(36px,7vw,80px) 0;
}

.faq-container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 clamp(16px,4vw,var(--space));
  position:relative;
  text-align:center;
}

/* Título + marca d’água “FAQ” */
#faq-title{
  color:#222;
  font-weight:800;
  font-size:clamp(1.8rem,3.6vw,3rem);
  margin:0 0 clamp(20px,4vw,36px);
  position:relative;
  z-index:2;
}
.faq-container::before{
  content:"FAQ";
  position:absolute;
  inset:auto 0 auto 0;
  top:0.2rem;
  margin:auto;
  text-align:center;
  font-weight:900;
  font-size:clamp(3rem,15vw,9rem);
  color: var(--color1);
  opacity:.12;                 /* bem suave, como no mock */
  z-index:1;
  pointer-events:none;
}

/* Lista */
.faq-list{
  display:grid;
  gap:clamp(10px,1.8vw,16px);
  text-align:left;
}

/* Item */
.faq-item{
  background:var(--card);
  border-radius:var(--radius);
  overflow:hidden;             /* arredondado também no conteúdo aberto */
  border:1px solid rgba(16,37,71,.08);
  box-shadow: 0 2px 8px rgba(16,37,71,.06);
}

/* Cabeçalho do item */
.faq-item > summary{
  list-style:none;
  cursor:pointer;
  padding:clamp(14px,2.6vw,18px) clamp(14px,3vw,20px);
  font-weight:700;
  color:var(--ink);
  position:relative;
  outline:none;
}
.faq-item > summary::-webkit-details-marker{ display:none; }

/* Ícone +/− à direita */
.faq-item > summary::after{
  content:"+";
  position:absolute;
  right:clamp(12px,2.5vw,18px);
  top:50%;
  transform:translateY(-50%);
  font-size:1.25rem;
  color:var(--color2);
  transition:transform .2s ease;
}
.faq-item[open] > summary::after{
  content:"−";
  transform:translateY(-50%);
}

/* Conteúdo */
.faq-content{
  padding:0 clamp(14px,3vw,20px) clamp(14px,2.6vw,18px);
  color:#364658;
  line-height:1.65;
  font-size:clamp(.98rem,1.05vw,1.05rem);
}

/* Acessibilidade ao focar via teclado */
.faq-item > summary:focus-visible{
  box-shadow:0 0 0 3px color-mix(in srgb, var(--color1) 30%, white);
  border-radius:var(--radius);
}
.EMEC {
  align-items: center;
  width: 250px;
}
.EMEC:hover {
  width: 270px;
}