/* ============================================
   PROFESSOR ITTURRIET - Design System
   Cores, tipografia e componentes aprovados
   ============================================ */

:root{
  --c-primary:#187583;        /* teal escuro do logo/quote */
  --c-primary-dark:#0D4F5C;   /* hover */
  --c-accent:#369CAC;         /* títulos / destaques */
  --c-secondary:#E08D58;        /* terracota - melhor contraste em teal */
  --c-secondary-dark:#c47246;
  --c-dark:#04252A;             /* navy escuro do footer/CTA hover */
  --c-warning-bg:#FFF4E6;
  --c-warning-text:#9A5A11;
  --c-bg-card:#EAF4F6;
  --c-bg:#EAF4F6;             /* fundo geral light teal com dots */
  --c-bg-soft:#FAFCFD;
  --c-text:#1C1C1A;
  --c-text-soft:#5b6b6e;
  --c-border:#d6e5e8;
  --c-success:#2f8f5e;
  --c-warning:#d4a017;
  --c-danger:#b54545;
  --c-muted:#9a9a96;

  --radius:14px;
  --radius-lg:22px;

  --shadow-sm:0 2px 8px rgba(24,117,131,.07);
  --shadow:0 10px 30px rgba(24,117,131,.10);
  --shadow-lg:0 22px 60px rgba(24,117,131,.18);

  --font-serif:"Cormorant Garamond", Georgia, serif;
  --font-script:"Italianno","Pinyon Script", cursive;
  --font-sans:"Archivo", -apple-system, "Segoe UI", Helvetica, Arial, sans-serif;

  --container:1200px;
  --header-h:88px;
  --dot-bg:radial-gradient(rgba(24,117,131,.13) 2px, transparent 0);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{overflow-x:hidden}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-sans);
  color:var(--c-text);
  background-color:var(--c-bg);
  background-image:var(--dot-bg);
  background-size:30px 30px;
  background-position:-5px -5px;
  background-attachment:fixed;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  font-size:16px;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}

h1,h2,h3,h4{font-family:var(--font-sans);font-weight:700;line-height:1.18;color:var(--c-text);letter-spacing:-.01em}
h1{font-size:clamp(2rem,4vw,3rem);font-weight:400}
h1 b,h1 strong,.titulo{color:var(--c-accent);font-weight:700}
h2{font-size:clamp(1.6rem,2.6vw,2.2rem);font-weight:400}
h2 b,h2 strong{color:var(--c-accent);font-weight:700}
h3{font-size:clamp(1.15rem,1.6vw,1.4rem);font-weight:700;color:var(--c-primary)}
h4{font-size:1.05rem;font-weight:700;color:var(--c-primary)}
p{color:var(--c-text);font-size:.98rem}
.muted{color:var(--c-text-soft)}

.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.section{padding:72px 0}
.section-sm{padding:48px 0}
.courses-section,.method-section,.quick-access{background:transparent}
.course-card,.method-card,.dash-card,.step,.faq-item,.form-card,.login-card,.contact-info,.combo-card{background:#fff!important}
.combo-card{background:linear-gradient(135deg,var(--c-primary) 0%, var(--c-primary-dark) 100%)!important;color:#fff}
.combo-card h3,.combo-card .desc,.combo-card .teacher{color:#fff!important}
.course-card h3{color:var(--c-primary)}
.course-card{border-radius:18px}
.method-card{border-radius:16px}
.method-card-feature{
  background:linear-gradient(135deg,rgba(24,117,131,.08),rgba(54,156,172,.04))!important;
  border:1.5px solid var(--c-accent)!important;position:relative;
}
.method-card-feature::after{
  content:"DESTAQUE";position:absolute;top:14px;right:14px;
  font-size:.62rem;letter-spacing:.16em;font-weight:700;color:var(--c-accent);
  background:rgba(54,156,172,.12);padding:4px 10px;border-radius:99px;
}
.method-card-feature h4{color:var(--c-primary)}
.method-card-feature p b{color:var(--c-primary);font-weight:700}
@media(max-width:880px){.method-card-feature{grid-column:span 2!important}}
@media(max-width:560px){.method-card-feature{grid-column:auto!important}}
.eyebrow{font-family:var(--font-sans);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--c-accent);font-weight:700;margin-bottom:14px;display:inline-block}
.section-title{margin-bottom:14px}
.section-lead{color:var(--c-text-soft);max-width:640px;margin-bottom:48px;font-size:1.05rem}

/* ===== Botões (referência: Elementor cursosprofessoriturret.com) ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:12px;
  padding:18px 30px;border-radius:8px;
  font-family:var(--font-sans);font-weight:700;font-size:1rem;line-height:1.3;
  transition:background .4s, color .3s, border-color .3s, box-shadow .3s, transform .15s;
  white-space:nowrap;border:1px solid transparent;text-decoration:none;
}
.btn::after{
  content:"";display:inline-block;width:11px;height:9px;
  background-image:url('../assets/Vector-1.svg');
  background-repeat:no-repeat;background-position:center;background-size:contain;
  transition:transform .25s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn:hover::after{transform:translate(2px,-2px)}

.btn-primary{background:#187583;color:#fff;border-color:#4DC4D7BF}
.btn-primary:hover,.btn-primary:focus{background:#04252A;border-color:#fff;color:#fff;box-shadow:0 8px 22px rgba(4,37,42,.18)}

.btn-secondary{background:var(--c-secondary);color:#1c1c1a;border-color:transparent}
.btn-secondary:hover{background:var(--c-secondary-dark)}
.btn-secondary::after{background-image:url('../assets/Vector-3.svg');filter:brightness(0) invert(.18)}

.btn-ghost{background:transparent;color:#187583;border-color:#187583}
.btn-ghost::after{background-image:url('../assets/Vector-3.svg')}
.btn-ghost:hover{background:#187583;color:#fff}
.btn-ghost:hover::after{background-image:url('../assets/Vector-1.svg')}

.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn-ghost-light:hover{background:#fff;color:#187583}
.btn-ghost-light:hover::after{background-image:url('../assets/Vector-3.svg')}

.btn-block{width:100%}
.btn-sm{padding:12px 20px;font-size:.88rem;border-radius:8px;gap:8px}
.btn-no-arrow::after{display:none}

/* Botões com seta dupla — para CTAs de avanço/urgência */
.btn-double::after{content:"»";background:none;width:auto;height:auto;font-size:1.2rem;font-weight:700;line-height:1;letter-spacing:-2px}
.btn-double:hover::after{transform:translateX(4px)}

/* Botão dark (navy) — para CTA premium */
.btn-dark{background:var(--c-dark);color:#fff;border-color:var(--c-dark)}
.btn-dark:hover{background:#0a3a42;border-color:var(--c-accent);box-shadow:0 10px 28px rgba(4,37,42,.28)}

/* Botão accent (terracota) */
.btn-accent{background:var(--c-secondary);color:#fff;border-color:transparent}
.btn-accent::after{filter:none}
.btn-accent:hover{background:var(--c-secondary-dark);box-shadow:0 8px 22px rgba(224,141,88,.3)}

/* botão pulsante (CTA principal — equivalente ao Elementor pulsar) */
.btn-pulse{animation:btn-pulse 1.5s infinite}
@keyframes btn-pulse{
  0%{box-shadow:0 0 0 0 rgba(24,117,131,.45)}
  70%{box-shadow:0 0 0 14px rgba(24,117,131,0)}
  100%{box-shadow:0 0 0 0 rgba(24,117,131,0)}
}

/* divisor decorativo */
.divider-bonito{
  display:block;width:170px;height:42px;margin:36px auto;
  background:url('../assets/divisor-bonito.svg') center/contain no-repeat;
}

/* ===== Header ===== */
body{padding-top:calc(var(--header-h) + 36px)}
@media(max-width:980px){body{padding-top:calc(72px + 20px)}}
.site-header{
  position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:1000;
  max-width:calc(var(--container) - 24px);width:calc(100% - 36px);
  background:#FEFEFE;border:1px solid var(--c-border);
  border-radius:18px;height:var(--header-h);
  box-shadow:0 4px 18px rgba(24,117,131,.06);
  display:flex;align-items:center;padding:0 28px;
}
.site-header .inner{display:flex;align-items:center;justify-content:space-between;width:100%;position:relative}
.brand{display:flex;align-items:center}
.brand img{height:46px;width:auto}
.nav{display:flex;align-items:center;gap:4px}
@media(min-width:981px){
  .nav{
    position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);
    justify-content:center;flex-wrap:nowrap;white-space:nowrap;
  }
  .nav a{white-space:nowrap}
  .nav .nav-cta{position:absolute;right:0;top:50%;transform:translateY(-50%);margin-left:0}
}
.nav a{
  padding:10px 14px;color:#3a4a4d;font-size:.94rem;font-weight:400;
  border-radius:8px;transition:color .15s;position:relative;
}
.nav a:hover{color:var(--c-primary)}
.nav a.active{color:var(--c-primary);text-decoration:underline;text-underline-offset:6px;text-decoration-thickness:1.5px}
.nav .nav-cta{
  margin-left:14px;border:1px solid #187583;color:#187583;
  padding:13px 22px;border-radius:8px;font-weight:700;font-size:.94rem;
  display:inline-flex;align-items:center;gap:10px;transition:background .3s, color .3s;
}
.nav .nav-cta::after{
  content:"";display:inline-block;width:11px;height:9px;
  background:url('../assets/Vector-3.svg') center/contain no-repeat;transition:transform .25s, background-image .3s;
}
.nav .nav-cta:hover{background:#187583;color:#fff}
.nav .nav-cta:hover::after{background-image:url('../assets/Vector-1.svg');transform:translate(2px,-2px)}
.nav-toggle{display:none;background:none;border:0;color:var(--c-primary);font-size:1.6rem;line-height:1}
@media(max-width:980px){
  .site-header{padding:0 18px;height:72px;top:10px;width:calc(100% - 20px)}
  .brand img{height:38px}
  .nav-toggle{display:block}
  .nav{
    position:absolute;top:calc(100% + 8px);left:0;right:0;
    background:#fff;flex-direction:column;align-items:stretch;
    padding:12px;gap:2px;border:1px solid var(--c-border);border-radius:14px;
    box-shadow:var(--shadow);
    transform:translateY(-10px);opacity:0;pointer-events:none;transition:.2s;
  }
  .nav.open{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav a{padding:14px 16px}
  .nav .nav-cta{margin:8px 0 0;text-align:center;justify-content:center}
}

/* ===== Hero (home) ===== */
.hero{padding:60px 0 40px;position:relative;text-align:center}
.hero h1{font-size:clamp(2.2rem,4.4vw,3.4rem);font-weight:400;color:var(--c-text);max-width:880px;margin:0 auto 24px;line-height:1.2}
.hero h1 b,.hero h1 .titulo{color:var(--c-accent);font-weight:700}
.hero p.lead{color:var(--c-text);font-size:1rem;max-width:680px;margin:0 auto 36px;line-height:1.7}
.hero p.lead b{font-weight:700;color:var(--c-text)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:56px;justify-content:center}
.hero-visual{
  max-width:1100px;width:100%;margin:0 auto;
  aspect-ratio:16/9;
  background-image:url('../assets/hero.webp');background-size:contain;background-position:center;background-repeat:no-repeat;
  position:relative;
  filter:drop-shadow(0 30px 60px rgba(4,37,42,.18));
}
@media(max-width:768px){
  .hero-visual{aspect-ratio:4/3;max-width:none;width:calc(100% + 48px);margin-left:-24px;margin-right:-24px;background-size:cover;filter:drop-shadow(0 18px 36px rgba(4,37,42,.22))}
}
@media(max-width:480px){
  .hero-visual{aspect-ratio:1/1;width:calc(100% + 48px)}
}
.hero-quote{
  background:var(--c-primary);color:#fff;
  border-radius:24px;padding:48px 32px;max-width:920px;margin:60px auto 0;
  text-align:center;position:relative;overflow:hidden;
}
.hero-quote::before{
  content:"";position:absolute;inset:0;
  background-image:url('../assets/imagem1dobra.webp');background-size:cover;background-position:center;
  opacity:.15;
}
.hero-quote em{position:relative;font-family:var(--font-sans);font-style:normal;font-weight:400;font-size:clamp(1.4rem,2.4vw,2rem);color:#fff;display:block;margin-bottom:18px;line-height:1.35}
.hero-quote span{position:relative;font-family:var(--font-script),"Italianno",cursive;font-size:2rem;color:#fff;letter-spacing:.02em;font-style:italic}
@media(max-width:680px){.hero{padding:40px 0 20px}.hero-quote{padding:36px 22px}}

/* ===== Faixa animada (marquee) ===== */
.marquee-band{
  background:var(--c-dark);color:#fff;overflow:hidden;
  border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06);
  padding:18px 0;margin-top:32px;position:relative;
}
.marquee-band::before,.marquee-band::after{
  content:"";position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none;
}
.marquee-band::before{left:0;background:linear-gradient(90deg,var(--c-dark),transparent)}
.marquee-band::after{right:0;background:linear-gradient(-90deg,var(--c-dark),transparent)}
.marquee-track{display:flex;width:max-content;animation:marquee 38s linear infinite;will-change:transform}
.marquee-band:hover .marquee-track{animation-play-state:paused}
.marquee-row{display:flex;align-items:center;gap:36px;padding-right:36px;flex-shrink:0}
.m-item{font-family:var(--font-sans);font-weight:400;font-size:1.05rem;color:rgba(255,255,255,.78);white-space:nowrap;letter-spacing:.01em}
.m-item b{color:var(--c-accent);font-weight:700}
.m-dot{width:6px;height:6px;border-radius:50%;background:var(--c-secondary);flex-shrink:0;opacity:.7}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none}}

/* ===== Stats com cards ===== */
.stats{padding:80px 0 40px}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center;max-width:1100px;margin:0 auto}
.stat-item{
  padding:32px 20px;border-radius:18px;background:#fff;border:1px solid var(--c-border);
  transition:transform .3s, box-shadow .3s, border-color .3s;
  position:relative;overflow:hidden;
}
.stat-item::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--c-accent),var(--c-secondary));
  transform:scaleX(0);transform-origin:left;transition:transform .5s ease;
}
.stat-item:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--c-accent)}
.stat-item:hover::before{transform:scaleX(1)}
.stat-num{font-family:var(--font-sans);font-weight:700;font-size:clamp(2.6rem,4.5vw,3.4rem);color:var(--c-accent);line-height:1;margin-bottom:8px;letter-spacing:-.02em}
.stat-label{font-size:.86rem;color:var(--c-text-soft);letter-spacing:.04em;line-height:1.4}
@media(max-width:680px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:14px}.stat-item{padding:24px 14px}}

/* ===== Sobre — redesenhado ===== */
.about-section{padding:120px 0 80px}
.about-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:80px;align-items:center}
.about-media{position:relative;padding:0 30px 80px 0}
.about-media .about-photo{
  border-radius:24px;overflow:hidden;box-shadow:0 30px 60px rgba(4,37,42,.18);
  aspect-ratio:4/5;background:#eee;position:relative;z-index:1;
}
.about-media .about-photo img{width:100%;height:100%;object-fit:cover}
.about-media::before{
  content:"";position:absolute;top:24px;left:24px;right:54px;bottom:104px;
  border:2px solid var(--c-accent);border-radius:24px;z-index:0;opacity:.55;
}
.about-badge{
  position:absolute;top:20px;right:0;z-index:3;
  background:var(--c-primary);color:#fff;border-radius:50%;
  width:120px;height:120px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;
  box-shadow:0 18px 42px rgba(24,117,131,.45);
  border:3px solid var(--c-accent);
  transform:rotate(-8deg);transition:transform .35s;
}
.about-badge:hover{transform:rotate(0)}
.about-badge .badge-num{font-family:var(--font-sans);font-weight:700;font-size:2.4rem;line-height:1}
.about-badge .badge-text{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;margin-top:4px;line-height:1.3;color:#fff}
.about-quote-card{
  position:absolute;left:-20px;bottom:0;z-index:3;
  background:#fff;border-radius:20px;padding:24px 26px;
  box-shadow:0 22px 48px rgba(4,37,42,.16);
  max-width:300px;border:1px solid var(--c-border);
}
.about-quote-card .quote-mark{width:24px;height:24px;color:var(--c-accent);margin-bottom:8px}
.about-quote-card p{font-size:.96rem;line-height:1.5;color:var(--c-text);margin:0;font-weight:500}
.about-quote-card .signature{
  display:block;margin-top:8px;font-family:var(--font-script);font-size:1.8rem;
  color:var(--c-primary);line-height:1;
}

.about-text .lead-soft{
  font-size:1.1rem;color:var(--c-text-soft);margin:14px 0 28px;
  padding-left:14px;border-left:3px solid var(--c-accent);
}
.about-list{list-style:none;display:flex;flex-direction:column;gap:14px;margin-bottom:36px}
.about-list li{display:flex;gap:14px;align-items:flex-start}
.about-list .check{
  width:32px;height:32px;border-radius:10px;background:var(--c-bg-card);color:var(--c-primary);
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:background .2s, color .2s;
}
.about-list .check svg{width:18px;height:18px}
.about-list li:hover .check{background:var(--c-primary);color:#fff}
.about-list li b{display:block;font-weight:700;color:var(--c-text);font-size:1rem;margin-bottom:2px}
.about-list li span{display:block;color:var(--c-text-soft);font-size:.92rem;line-height:1.4}

@media(max-width:980px){
  .about-grid{grid-template-columns:1fr;gap:64px}
  .about-section{padding:80px 0}
  .about-media{padding:0 20px 70px 0;max-width:520px;margin:0 auto}
  .about-quote-card{left:0;max-width:280px}
}
@media(max-width:560px){
  .about-badge{width:118px;height:118px;top:10px;padding:6px}
  .about-badge .badge-num{font-size:2.1rem}
  .about-badge .badge-text{font-size:.6rem;letter-spacing:.12em;line-height:1.25}
  .about-quote-card{padding:18px 20px;left:-10px}
  .about-quote-card .signature{font-size:1.5rem}
}

/* ===== Cards de cursos ===== */
.courses-section{background:var(--c-bg);position:relative}
.courses-header{text-align:center;max-width:780px;margin:0 auto 56px}
.courses-header .eyebrow{display:inline-flex;align-items:center;gap:10px;justify-content:center}
.courses-header .eyebrow-line{width:28px;height:2px;background:var(--c-primary);border-radius:2px;display:inline-block}
.courses-header .section-lead{margin:0 auto}
.course-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:28px}
.course-tag{
  font-size:.82rem;font-weight:600;color:var(--c-text-soft);
  padding:8px 16px;border-radius:99px;background:#fff;
  border:1px solid var(--c-border);cursor:pointer;
  transition:color .2s, background .2s, border-color .2s, transform .15s;
}
.course-tag:hover{color:var(--c-primary);border-color:var(--c-primary);transform:translateY(-1px)}
.course-tag.is-active{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}

.courses-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.course-card{
  position:relative;overflow:hidden;
  background:#fff;border:1px solid var(--c-border);border-radius:18px;
  padding:24px 22px;display:flex;flex-direction:column;gap:12px;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.course-card::after{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg, var(--c-primary), var(--c-primary-dark));
  transform:scaleX(0);transform-origin:left;transition:transform .35s ease;
}
.course-card:hover{transform:translateY(-4px);box-shadow:0 14px 32px -14px rgba(13,79,92,.28);border-color:var(--c-primary)}
.course-card:hover::after{transform:scaleX(1)}
.course-card.is-featured{border-color:rgba(24,117,131,.35);background:linear-gradient(180deg,#fff,#f5fbfc)}
.course-card.is-featured::after{transform:scaleX(1)}

.cc-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.cc-icon{
  width:40px;height:40px;border-radius:10px;flex:none;
  display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, rgba(24,117,131,.12), rgba(24,117,131,.04));
  color:var(--c-primary);
  transition:background .25s ease, color .25s ease, transform .25s ease;
}
.cc-icon svg{width:22px;height:22px}
.course-card:hover .cc-icon{background:var(--c-primary);color:#fff;transform:rotate(-4deg) scale(1.05)}

.course-card h3{font-size:1.18rem;color:var(--c-primary);margin:2px 0 0;line-height:1.25}
.course-card .desc{color:var(--c-text-soft);font-size:.92rem;flex:1;line-height:1.55;margin:0}
.cc-meta{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:6px 14px;font-size:.78rem;color:var(--c-text-soft);font-weight:500}
.cc-meta li{display:inline-flex;align-items:center;gap:6px}
.cc-meta .dot{width:5px;height:5px;border-radius:50%;background:var(--c-primary);opacity:.6}
.course-card .teacher{font-size:.74rem;color:var(--c-text-soft);letter-spacing:.06em;text-transform:uppercase;font-weight:600;padding-top:10px;border-top:1px dashed var(--c-border)}
.course-card .btn{margin-top:auto;align-self:stretch;justify-content:center}

.combo-card .cc-icon{background:rgba(255,255,255,.18);color:#fff}
.combo-card:hover .cc-icon{background:#fff;color:var(--c-primary)}
.combo-card .desc,.combo-card .teacher{opacity:.92}
.combo-card .cc-meta{color:rgba(255,255,255,.85)}
.combo-card .cc-meta .dot{background:#fff;opacity:.8}
.combo-card .teacher{border-top-color:rgba(255,255,255,.25)}
.combo-card::after{background:linear-gradient(90deg,#fff,rgba(255,255,255,.4));transform:scaleX(1)}
.badge-combo{background:rgba(255,255,255,.2);color:#fff}
.badge-combo::before{background:#fff}
.badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;font-weight:500;
  padding:5px 11px;border-radius:99px;width:fit-content;
}
.badge::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.badge-success{background:#e3f3eb;color:var(--c-success)}
.badge-warning{background:#fbf2dc;color:var(--c-warning)}
.badge-danger{background:#f8e1e1;color:var(--c-danger)}
.badge-muted{background:#ececea;color:var(--c-muted)}
@media(max-width:1100px){.courses-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:880px){.courses-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.courses-grid{grid-template-columns:1fr}}

/* ===== Professores - cards modernos ===== */
.teachers-section{background:var(--c-dark);color:#fff;border-radius:32px;margin:40px 16px;padding:60px 0 80px!important;position:relative;overflow:hidden}
@media(max-width:680px){.teachers-section{padding:48px 0 64px!important;margin:24px 12px}}
.teachers-section::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 0%,rgba(54,156,172,.18),transparent 50%),radial-gradient(circle at 80% 100%,rgba(224,141,88,.08),transparent 50%);pointer-events:none}
.teachers-section .container{max-width:1140px;position:relative}
.teachers-section h2,.teachers-section h3{color:#fff}
.teachers-section h2 b,.teachers-section h2 strong{color:var(--c-accent)}
.teachers-section .eyebrow{color:var(--c-accent)}
.teachers-section .section-lead{color:rgba(255,255,255,.75)}

.teachers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.teacher-card{
  position:relative;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:20px;overflow:hidden;aspect-ratio:3/4;
  transition:transform .35s cubic-bezier(.2,.8,.2,1), border-color .3s, box-shadow .3s;
  cursor:pointer;
}
.teacher-card:hover{transform:translateY(-6px);border-color:var(--c-accent);box-shadow:0 24px 60px rgba(0,0,0,.4)}
.teacher-card .photo{position:absolute;inset:0;background-size:cover;background-position:center top}
.teacher-card .photo-fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0a3a42,#04252A);font-family:var(--font-script);font-size:7rem;color:rgba(54,156,172,.5)}
.teacher-card .overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%, rgba(4,37,42,.55) 60%, rgba(4,37,42,.96) 100%);transition:background .3s}
.teacher-card:hover .overlay{background:linear-gradient(180deg,rgba(4,37,42,.2) 0%, rgba(4,37,42,.7) 50%, rgba(4,37,42,.98) 100%)}
.teacher-card .info{position:absolute;left:0;right:0;bottom:0;padding:26px 24px;color:#fff}
.teacher-card .role{display:inline-block;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--c-accent);font-weight:700;margin-bottom:6px}
.teacher-card h3{color:#fff;font-size:1.35rem;margin-bottom:10px;line-height:1.2}
.teacher-card .bio{font-size:.86rem;color:rgba(255,255,255,.78);line-height:1.55;max-height:0;overflow:hidden;opacity:0;transition:max-height .35s ease, opacity .3s ease, margin-top .3s}
.teacher-card:hover .bio{max-height:200px;opacity:1;margin-top:6px}

/* Solo card — Itturriet em destaque */
.teachers-grid.teachers-solo{grid-template-columns:1fr;max-width:820px;margin:0 auto}
.teacher-card-solo{aspect-ratio:16/10}
.teacher-card-solo .info .bio,.teacher-card-solo .info .bio-highlight{max-height:none;opacity:1;margin-top:8px}
.teacher-card-solo .info{padding:36px 38px}
.teacher-card-solo .bio-highlight{
  display:inline-block;margin-top:14px!important;padding:8px 14px;border-radius:99px;
  background:rgba(54,156,172,.18);color:var(--c-accent);
  font-size:.82rem;font-weight:700;letter-spacing:.04em;
}
@media(max-width:680px){
  .teacher-card-solo{aspect-ratio:auto;display:flex;flex-direction:column;overflow:hidden}
  .teacher-card-solo .photo,.teacher-card-solo .photo-fallback{position:relative;inset:auto;aspect-ratio:1/1;width:100%;height:auto;background-position:center top}
  .teacher-card-solo .overlay{display:none}
  .teacher-card-solo .info{position:relative;left:auto;right:auto;bottom:auto;padding:24px 22px;background:#04252A;color:#fff}
  .teacher-card-solo .info h3{font-size:1.3rem}
  .teacher-card-solo .info .bio{font-size:.92rem;color:rgba(255,255,255,.85)}
}

@media(max-width:880px){
  .teachers-grid{grid-template-columns:1fr;gap:18px}
  .teacher-card{aspect-ratio:5/4}
  .teacher-card .bio{max-height:200px;opacity:1;margin-top:6px}
}
.teacher-row{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center;margin-bottom:64px}
.teacher-row:nth-child(even){grid-template-columns:1fr 1.1fr}
.teacher-row:nth-child(even) .teacher-photo{order:2}
.teacher-photo{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/5;background:#dcd9d2;box-shadow:var(--shadow-lg)}
.teacher-photo img{width:100%;height:100%;object-fit:cover}
.teacher-info h3{color:#fff;font-size:1.8rem;margin-bottom:6px}
.teacher-info .role{color:var(--c-secondary);font-size:.9rem;letter-spacing:.06em;text-transform:uppercase;margin-bottom:18px;display:block}
.teacher-info p{color:rgba(255,255,255,.82);margin-bottom:14px;font-size:1rem;line-height:1.75}
@media(max-width:880px){
  .teacher-row,.teacher-row:nth-child(even){grid-template-columns:1fr;gap:24px;margin-bottom:48px}
  .teacher-row:nth-child(even) .teacher-photo{order:0}
}

/* ===== Diferenciais (Método) ===== */
.method-section{background:var(--c-bg)}
.method-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.method-card{
  background:#fff;border:1px solid var(--c-border);border-radius:var(--radius);padding:30px 26px;
  display:flex;flex-direction:column;gap:14px;transition:transform .15s, box-shadow .2s;
}
.method-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.method-icon{
  width:54px;height:54px;border-radius:14px;
  background:linear-gradient(135deg,var(--c-primary) 0%,#0f5c63 100%);
  display:flex;align-items:center;justify-content:center;color:#fff;
  box-shadow:0 6px 18px -6px rgba(15,92,99,.45);
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.method-icon svg{width:28px;height:28px;stroke:#fff;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round}
.method-card:hover .method-icon{transform:translateY(-2px) rotate(-3deg);box-shadow:0 10px 22px -6px rgba(15,92,99,.55);background:linear-gradient(135deg,#0f5c63,var(--c-primary))}
.method-card h4{color:var(--c-primary);font-size:1.05rem}
.method-card p{color:var(--c-text-soft);font-size:.94rem}
@media(max-width:880px){.method-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.method-grid{grid-template-columns:1fr}}

/* ===== Resultados / Galeria ===== */
.results-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.result-card{
  background:var(--c-bg-card);border-radius:var(--radius);aspect-ratio:1/1.2;
  display:flex;align-items:center;justify-content:center;color:var(--c-text-soft);
  font-size:.85rem;text-align:center;padding:20px;border:1px dashed rgba(13,79,92,.18);
}
@media(max-width:880px){.results-grid{grid-template-columns:repeat(2,1fr)}}

/* ===== Acesso rápido — destaque Plantão ===== */
.quick-grid-2{display:grid;grid-template-columns:2fr 1fr;gap:18px;margin-top:32px;text-align:left}
.quick-grid-2-equal{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:32px;text-align:left;max-width:1100px;margin-left:auto;margin-right:auto}
.quick-grid-2-equal .quick-card{padding:32px 30px;min-height:200px;justify-content:flex-start}
.quick-grid-2-equal .quick-card .ico{width:56px;height:56px;border-radius:14px;margin-bottom:16px}
.quick-grid-2-equal .quick-card .ico svg{width:28px;height:28px}
.quick-grid-2-equal .quick-card .qc-title{font-size:1.25rem}
.quick-grid-2-equal .quick-card .qc-sub{font-size:.92rem;line-height:1.55}
@media(max-width:880px){.quick-grid-2-equal{grid-template-columns:1fr;max-width:560px}}
.quick-card-hero{
  position:relative;background:linear-gradient(135deg,var(--c-primary),var(--c-dark))!important;
  color:#fff;border:0!important;padding:40px 38px;display:flex;align-items:center;
  border-radius:22px;overflow:hidden;min-height:240px;
  transition:transform .25s, box-shadow .3s;
}
.quick-card-hero:hover{transform:translateY(-4px);box-shadow:0 30px 60px rgba(4,37,42,.32)}
.qc-hero-bg{
  position:absolute;inset:0;
  background:radial-gradient(circle at 80% 20%,rgba(54,156,172,.4),transparent 50%),radial-gradient(circle at 20% 80%,rgba(224,141,88,.18),transparent 50%);
  pointer-events:none;
}
.qc-hero-content{position:relative;z-index:2;max-width:60%}
.quick-card.quick-card-hero .qc-title{font-family:var(--font-sans);font-size:clamp(1.6rem,2.4vw,2.1rem);font-weight:700;color:#fff;display:block;margin:8px 0 8px;line-height:1.15}
.quick-card.quick-card-hero .qc-sub{display:block;color:rgba(255,255,255,.85);font-size:.96rem;line-height:1.55;margin-bottom:6px}
.quick-card-hero .qc-tag{
  display:inline-block;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;
  padding:6px 14px;border-radius:99px;background:var(--c-secondary);color:#fff;
}
.quick-card-hero .qc-hero-icon{
  position:absolute;right:-30px;bottom:-30px;width:240px;height:240px;
  color:rgba(255,255,255,.08);z-index:1;
}
.quick-card-hero .qc-hero-icon svg{width:100%;height:100%}
@media(max-width:880px){
  .quick-grid-2{grid-template-columns:1fr}
  .quick-card-hero{padding:32px 28px;min-height:auto}
  .qc-hero-content{max-width:100%}
  .quick-card-hero .qc-hero-icon{width:160px;height:160px;right:-30px;bottom:-30px}
}

/* ===== Acesso rápido alunos ===== */
.quick-access{background:var(--c-bg-card)}
.quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:36px}
.quick-card{
  position:relative;overflow:hidden;
  background:#fff;border-radius:16px;padding:28px 24px 24px;text-align:left;
  border:1px solid var(--c-border);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  display:flex;flex-direction:column;gap:6px;align-items:flex-start;
  text-decoration:none;
}
.quick-card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(135deg, rgba(24,117,131,.06), rgba(24,117,131,0) 60%);
  opacity:0;transition:opacity .25s ease;
}
.quick-card:hover{transform:translateY(-4px);box-shadow:0 12px 28px -12px rgba(13,79,92,.25);border-color:var(--c-primary)}
.quick-card:hover::before{opacity:1}
.quick-card .ico{
  width:48px;height:48px;border-radius:12px;
  display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, rgba(24,117,131,.12), rgba(24,117,131,.04));
  color:var(--c-primary);margin-bottom:10px;
  transition:background .25s ease, transform .25s ease, color .25s ease;
}
.quick-card .ico svg{width:24px;height:24px}
.quick-card:hover .ico{background:var(--c-primary);color:#fff;transform:scale(1.05)}
.quick-card .qc-title{font-size:1rem;color:var(--c-text);font-weight:700;line-height:1.25}
.quick-card .qc-sub{font-size:.82rem;color:#6b7a82;font-weight:500}
.quick-card .qc-arrow{
  position:absolute;top:24px;right:24px;color:var(--c-primary);
  font-size:1.1rem;font-weight:700;opacity:0;transform:translateX(-6px);
  transition:opacity .25s ease, transform .25s ease;
}
.quick-card:hover .qc-arrow{opacity:1;transform:translateX(0)}
@media(max-width:880px){.quick-grid{grid-template-columns:repeat(2,1fr);gap:14px}.quick-card{padding:22px 18px 20px}}

/* ===== Page hero (interno) ===== */
.page-hero{padding:60px 0 32px;text-align:center}
.page-hero h1{margin-bottom:16px}
.page-hero h1 b,.page-hero h1 .titulo{color:var(--c-accent);font-weight:700}
.page-hero p{color:var(--c-text-soft);max-width:680px;margin:0 auto;font-size:1.02rem}

/* ===== Tabela ENEM ===== */
.spec-table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.spec-table th,.spec-table td{padding:18px 22px;text-align:left;border-bottom:1px solid var(--c-border);font-size:.96rem}
.spec-table th{background:var(--c-bg-card);color:var(--c-primary);font-family:var(--font-sans);font-weight:500;font-size:.86rem;letter-spacing:.06em;text-transform:uppercase}
.spec-table tr:last-child td{border-bottom:0}
.spec-table td:first-child{font-weight:500;color:var(--c-primary);width:30%}
@media(max-width:680px){.spec-table th,.spec-table td{padding:14px 12px;font-size:.88rem}}

/* ===== Avisos / callouts ===== */
.callout{
  background:var(--c-bg-card);border-left:4px solid var(--c-secondary);
  padding:22px 26px;border-radius:0 var(--radius) var(--radius) 0;margin:32px 0;
}
.callout strong{color:var(--c-primary);display:block;margin-bottom:6px;font-weight:600}
.callout-warning{background:#fbf2dc;border-left-color:#d4a017}
.callout-warning strong{color:#a67d12}

/* ===== Formulários ===== */
.form-card{background:#fff;border-radius:var(--radius);padding:36px;border:1px solid var(--c-border);box-shadow:var(--shadow-sm)}
.field{margin-bottom:18px}
#loginForm .btn-block{margin-top:8px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-grid .full{grid-column:1/-1}
.field label{display:block;font-size:.86rem;color:var(--c-text);margin-bottom:6px;font-weight:500}
.field label .req{color:#b54545;margin-left:2px}
.field input,.field select,.field textarea{
  width:100%;padding:13px 14px;border:1px solid var(--c-border);border-radius:8px;
  font-family:inherit;font-size:.96rem;color:var(--c-text);background:#fff;transition:border-color .15s, box-shadow .15s;
}
.field textarea{resize:vertical;min-height:110px}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(13,79,92,.08)}
.field .err{display:none;color:#b54545;font-size:.82rem;margin-top:4px}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:#b54545}
.field.invalid .err{display:block}
@media(max-width:680px){.form-grid{grid-template-columns:1fr}}

/* ===== FAQ ===== */
.faq-list{max-width:760px;margin:0 auto}
.faq-item{background:#fff;border:1px solid var(--c-border);border-radius:var(--radius);margin-bottom:12px;overflow:hidden}
.faq-q{width:100%;text-align:left;padding:20px 22px;font-weight:500;color:var(--c-primary);display:flex;justify-content:space-between;align-items:center;font-size:1rem;background:#fff}
.faq-q::after{content:"+";font-size:1.4rem;color:var(--c-secondary);transition:transform .2s}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;padding:0 22px;color:var(--c-text-soft)}
.faq-item.open .faq-a{padding:0 22px 22px;max-height:400px}

/* ===== Steps (matrículas) ===== */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:24px}
.step{background:#fff;border:1px solid var(--c-border);border-radius:var(--radius);padding:24px 20px}
.step-num{font-family:var(--font-serif);font-size:1.6rem;color:var(--c-secondary);margin-bottom:8px;display:block}
.step h4{color:var(--c-primary);font-size:.98rem;margin-bottom:8px;font-family:var(--font-sans);font-weight:500}
.step p{font-size:.86rem;color:var(--c-text-soft)}
@media(max-width:980px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.steps{grid-template-columns:1fr}}

/* ===== Login / Dashboard aluno ===== */
.login-wrap{min-height:calc(100vh - var(--header-h) - 280px);display:flex;align-items:center;justify-content:center;padding:80px 24px;background:var(--c-bg-card)}
.login-card{background:#fff;border-radius:var(--radius);padding:42px;box-shadow:var(--shadow);max-width:440px;width:100%}
.login-card h1{font-size:1.8rem;color:var(--c-primary);margin-bottom:8px}
.login-card .lead{color:var(--c-text-soft);margin-bottom:28px;font-size:.95rem}
.login-links{margin-top:18px;font-size:.88rem;text-align:center}
.login-links a{color:var(--c-primary);text-decoration:underline;text-underline-offset:3px}
.login-links a:hover{color:var(--c-secondary-dark)}
.login-links .small{display:block;margin-top:10px;color:var(--c-text-soft)}

.dashboard{padding:60px 0}
.dashboard h1{color:var(--c-primary);margin-bottom:8px}
.dashboard .greet{color:var(--c-text-soft);margin-bottom:36px}
.dashboard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.dash-card{
  background:#fff;border:1px solid var(--c-border);border-radius:var(--radius);
  padding:30px 26px;display:flex;flex-direction:column;gap:14px;align-items:flex-start;
  transition:transform .15s, box-shadow .2s, border-color .15s;
}
.dash-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm);border-color:var(--c-primary)}
.dash-card .ico{font-size:1.6rem}
.dash-card h3{font-size:1.1rem;color:var(--c-primary)}
.dash-card p{font-size:.9rem;color:var(--c-text-soft)}
@media(max-width:880px){.dashboard-grid{grid-template-columns:1fr}}

/* ===== Contato ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:48px}
.contact-info h3{color:var(--c-primary);margin-bottom:14px;font-size:1.4rem}
.contact-info p{margin-bottom:14px;color:var(--c-text);font-size:.98rem}
.contact-info strong{color:var(--c-primary);display:block;font-family:var(--font-sans);font-weight:500;font-size:.84rem;letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px}
.map-wrap{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);aspect-ratio:16/9}
.map-wrap iframe{width:100%;height:100%;border:0}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr}}

/* ===== Footer ===== */
.site-footer{margin-top:60px}
.footer-top{background:#04252A;color:#fff}
.footer-top-inner{
  display:flex;align-items:center;justify-content:center;gap:48px;
  padding:28px 24px;flex-wrap:wrap;
}
.footer-top .footer-brand img{height:44px;width:auto;display:block}
.footer-top .footer-item{
  font-family:var(--font-sans);font-weight:600;font-size:.95rem;
  color:#fff;letter-spacing:.04em;
}
.footer-top .footer-credit{
  color:#fff;font-style:italic;font-weight:400;text-decoration:none;
  border-bottom:1px solid rgba(255,255,255,.4);transition:color .2s;
}
.footer-top .footer-credit:hover{color:var(--c-accent)}
.footer-bottom{background:#187583;color:#fff;text-align:center;padding:18px 24px;font-size:.95rem;letter-spacing:.02em}
.footer-bottom b{font-weight:700;text-transform:uppercase;letter-spacing:.06em}
@media(max-width:880px){
  .footer-top-inner{gap:18px;flex-direction:column;text-align:center;padding:32px 20px}
  .footer-top .footer-item{font-size:.88rem}
  .footer-bottom{font-size:.86rem;padding:18px 20px}
}

/* ===== WhatsApp flutuante ===== */
.wa-float{
  position:fixed;right:22px;bottom:22px;z-index:999;
  width:58px;height:58px;border-radius:50%;background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(37,211,102,.4);
  transition:transform .2s, box-shadow .2s;font-size:1.6rem;
}
.wa-float:hover{transform:scale(1.06);box-shadow:0 10px 30px rgba(37,211,102,.55)}

/* ===== Cursos page extras ===== */
.combo-card{
  background:linear-gradient(135deg,var(--c-primary) 0%, var(--c-primary-dark) 100%);
  color:#fff;border:0;
}
.combo-card h3,.combo-card .badge-success{color:#fff}
.combo-card .desc,.combo-card .teacher{color:rgba(255,255,255,.78)}

/* ===== Icon system (SVG sprite) ===== */
.ico-svg{width:24px;height:24px;display:inline-block;vertical-align:middle;flex-shrink:0}
.ico-lg{width:36px;height:36px}
.ico-xl{width:44px;height:44px}
.ico-circle{
  width:48px;height:48px;border-radius:14px;background:var(--c-bg-card);
  display:inline-flex;align-items:center;justify-content:center;color:var(--c-primary);
  flex-shrink:0;transition:background .2s, color .2s, transform .2s;
}
.dash-card:hover .ico-circle,.quick-card:hover .ico-circle{background:var(--c-primary);color:#fff;transform:scale(1.05)}
.ico-circle .ico-svg{width:24px;height:24px}

/* ===== Reveal on scroll ===== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s cubic-bezier(.2,.8,.2,1)}
.reveal.is-visible{opacity:1;transform:translateY(0)}
.marquee-band.reveal{transform:translateY(0);opacity:0;transition:opacity .8s ease}
.marquee-band.reveal.is-visible{opacity:1}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important}}

/* ===== Util ===== */
.text-center{text-align:center}
.mt-32{margin-top:32px}
.mt-48{margin-top:48px}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:32px}

/* ===== Banner aviso topo ===== */
.notice-bar{background:var(--c-secondary);color:#1c1c1a;text-align:center;padding:10px 16px;font-size:.86rem}
.notice-bar a{text-decoration:underline;font-weight:500}

/* ============================================
   MODERNIZAÇÃO — micro-interações, scroll reveal,
   foco acessível, polimento global
   ============================================ */

/* Smooth scroll respeitando header fixo */
html{scroll-padding-top:calc(var(--header-h) + 24px)}

/* Seleção de texto on-brand */
::selection{background:rgba(24,117,131,.22);color:var(--c-primary-dark)}

/* Foco acessível global (apenas teclado) */
:focus{outline:none}
:focus-visible{
  outline:3px solid rgba(24,117,131,.55);
  outline-offset:3px;
  border-radius:6px;
  transition:outline-offset .15s ease;
}
.btn:focus-visible{outline-offset:4px}

/* Scrollbar discreta */
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-track{background:transparent}
*::-webkit-scrollbar-thumb{background:rgba(24,117,131,.25);border-radius:8px;border:2px solid transparent;background-clip:padding-box}
*::-webkit-scrollbar-thumb:hover{background:rgba(24,117,131,.45);background-clip:padding-box;border:2px solid transparent}

/* Header inteligente — densifica ao rolar */
.site-header{transition:height .25s ease, box-shadow .25s ease, background .25s ease, top .25s ease}
.site-header.scrolled{
  height:72px;
  box-shadow:0 8px 28px rgba(13,79,92,.14);
  background:#FEFEFE;
}
@media(max-width:980px){.site-header.scrolled{height:64px}}

/* Scroll Reveal — entradas suaves */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.is-visible{opacity:1;transform:none}
.reveal-left{transform:translateX(-28px)}
.reveal-right{transform:translateX(28px)}
.reveal-left.is-visible,.reveal-right.is-visible{transform:none}
.reveal-stagger > *{opacity:0;transform:translateY(20px);transition:opacity .6s ease, transform .6s cubic-bezier(.2,.7,.2,1)}
.reveal-stagger.is-visible > *{opacity:1;transform:none}
.reveal-stagger.is-visible > *:nth-child(1){transition-delay:.05s}
.reveal-stagger.is-visible > *:nth-child(2){transition-delay:.12s}
.reveal-stagger.is-visible > *:nth-child(3){transition-delay:.19s}
.reveal-stagger.is-visible > *:nth-child(4){transition-delay:.26s}
.reveal-stagger.is-visible > *:nth-child(5){transition-delay:.33s}
.reveal-stagger.is-visible > *:nth-child(6){transition-delay:.40s}
.reveal-stagger.is-visible > *:nth-child(7){transition-delay:.47s}
.reveal-stagger.is-visible > *:nth-child(n+8){transition-delay:.54s}

/* Hero — entrada cinematográfica */
.hero h1,.hero p.lead,.hero-cta,.hero-visual,.hero-quote{opacity:0;animation:hero-in .9s cubic-bezier(.2,.7,.2,1) forwards}
.hero p.lead{animation-delay:.12s}
.hero-cta{animation-delay:.22s}
.hero-visual{animation-delay:.32s}
.hero-quote{animation-delay:.42s}
@keyframes hero-in{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* Stats — número conta com leve realce */
.stat-num{transition:transform .4s ease, color .4s ease}
.stat-num.counting{transform:translateY(-2px)}

/* Course card — brilho sutil ao passar o mouse */
.course-card{position:relative}
.course-card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.55) 50%,transparent 70%);
  transform:translateX(-120%);transition:transform .9s ease;mix-blend-mode:overlay;opacity:0;
}
.course-card:hover::before{transform:translateX(120%);opacity:1}

/* Method card — leve elevação progressiva */
.method-card{transition:transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s ease, border-color .3s ease}
.method-card:hover{transform:translateY(-6px);border-color:rgba(24,117,131,.3);box-shadow:0 18px 38px -22px rgba(13,79,92,.35)}

/* Quick / Dash cards consistência */
.quick-card,.dash-card{transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease}
.quick-card:hover,.dash-card:hover{transform:translateY(-3px);box-shadow:0 14px 30px -18px rgba(13,79,92,.3)}

/* Botão primário com brilho ao hover */
.btn-primary{position:relative;overflow:hidden;isolation:isolate}
.btn-primary::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(120deg,transparent 35%,rgba(255,255,255,.22) 50%,transparent 65%);
  transform:translateX(-110%);transition:transform .6s ease;
}
.btn-primary:hover::before{transform:translateX(110%)}

/* Tag de curso — feedback de seleção */
.course-tag{user-select:none}
.course-tag:active{transform:translateY(0) scale(.97)}

/* Card filtrável (sumiço suave quando filtro não combina) */
.course-card.is-hidden{opacity:0;transform:scale(.96);pointer-events:none;height:0;padding:0;margin:0;border:0;overflow:hidden;transition:.35s ease}

/* Estado vazio do filtro de cursos */
.courses-empty{
  display:flex;flex-direction:column;align-items:center;gap:14px;
  padding:36px 24px;text-align:center;color:var(--c-text-soft);
  background:#fff;border:1px dashed var(--c-border);border-radius:18px;margin-top:8px;
}
.courses-empty p{margin:0;font-size:.98rem}

/* Back to top */
.back-to-top{
  position:fixed;right:22px;bottom:96px;z-index:900;
  width:46px;height:46px;border-radius:50%;
  background:var(--c-primary);color:#fff;border:0;
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 10px 24px -8px rgba(13,79,92,.45);
  opacity:0;transform:translateY(12px) scale(.9);pointer-events:none;
  transition:opacity .3s ease, transform .3s ease, background .25s ease;
}
.back-to-top.is-visible{opacity:1;transform:none;pointer-events:auto}
.back-to-top:hover{background:var(--c-primary-dark);transform:translateY(-2px)}
.back-to-top svg{width:20px;height:20px;stroke:currentColor;stroke-width:2.2;fill:none;stroke-linecap:round;stroke-linejoin:round}

/* WhatsApp float — pulse discreto */
.wa-float{transition:transform .25s ease, box-shadow .25s ease}
.wa-float:hover{transform:translateY(-3px) scale(1.05)}
.wa-float::after{
  content:"";position:absolute;inset:0;border-radius:inherit;
  box-shadow:0 0 0 0 rgba(37,211,102,.55);animation:wa-pulse 2.4s ease-out infinite;
}
@keyframes wa-pulse{
  0%{box-shadow:0 0 0 0 rgba(37,211,102,.55)}
  70%{box-shadow:0 0 0 16px rgba(37,211,102,0)}
  100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}
}

/* Imagens com leve zoom no hover do card */
.course-card img,.about-photo img{transition:transform .6s ease}
.about-photo:hover img{transform:scale(1.04)}

/* Mobile nav — animação de entrada item a item */
@media(max-width:980px){
  .nav.open a{animation:nav-in .35s both}
  .nav.open a:nth-child(2){animation-delay:.04s}
  .nav.open a:nth-child(3){animation-delay:.08s}
  .nav.open a:nth-child(4){animation-delay:.12s}
  .nav.open a:nth-child(5){animation-delay:.16s}
  .nav.open a:nth-child(6){animation-delay:.20s}
  .nav.open .nav-cta{animation:nav-in .35s .24s both}
}
@keyframes nav-in{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* Form fields — foco mais elegante */
input,select,textarea{transition:border-color .2s ease, box-shadow .2s ease, background .2s ease}
input:focus,select:focus,textarea:focus{
  border-color:var(--c-primary)!important;
  box-shadow:0 0 0 4px rgba(24,117,131,.15)!important;
}

/* Field inválido com shake leve */
.field.invalid input,.field.invalid select,.field.invalid textarea{
  border-color:var(--c-danger)!important;
  box-shadow:0 0 0 4px rgba(181,69,69,.12)!important;
  animation:shake .35s ease;
}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}

/* FAQ — animação suave de abertura */
.faq-item{overflow:hidden}
.faq-item .faq-q{transition:color .2s ease}
.faq-item .faq-q:hover{color:var(--c-primary)}

/* =========================================================
   MATRÍCULAS 2026 — UX redesign
   ========================================================= */

/* HERO refinado */
.enroll-hero{
  position:relative;overflow:hidden;
  background:linear-gradient(180deg,#f5fbfc 0%, var(--c-bg-card) 100%);
  padding:72px 0 56px;
}
.enroll-hero::before{
  content:"";position:absolute;inset:auto -10% -40% auto;width:520px;height:520px;
  background:radial-gradient(closest-side, rgba(24,117,131,.18), transparent 70%);
  pointer-events:none;
}
.enroll-hero-inner{position:relative;text-align:center;max-width:760px;margin:0 auto}
.enroll-hero h1{margin:18px 0 16px;font-size:clamp(2rem,4vw,3rem);line-height:1.1}
.enroll-hero h1 .titulo{color:var(--c-accent);font-weight:700}
.enroll-hero p{color:var(--c-text-soft);font-size:1.05rem;max-width:600px;margin:0 auto 22px}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;border:1px solid var(--c-border);
  padding:7px 14px;border-radius:99px;
  font-size:.78rem;font-weight:600;letter-spacing:.04em;
  color:var(--c-primary);text-transform:uppercase;
  box-shadow:var(--shadow-sm);
}
.hero-badge .dot{width:8px;height:8px;border-radius:50%;background:#2f8f5e;box-shadow:0 0 0 4px rgba(47,143,94,.18);animation:pulse-dot 1.8s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 4px rgba(47,143,94,.18)}50%{box-shadow:0 0 0 8px rgba(47,143,94,.05)}}
.hero-pills{
  list-style:none;padding:0;margin:0 auto 28px;
  display:flex;flex-wrap:wrap;justify-content:center;gap:8px;
}
.hero-pills li{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;background:#fff;border:1px solid var(--c-border);
  border-radius:99px;font-size:.86rem;color:var(--c-text);font-weight:500;
}
.hero-pills svg{width:14px;height:14px;color:var(--c-primary);flex:none}
.enroll-hero .hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* TIMELINE / Como funciona */
.timeline{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(5,1fr);gap:16px;
  position:relative;
}
.timeline::before{
  content:"";position:absolute;top:42px;left:6%;right:6%;height:2px;
  background:repeating-linear-gradient(90deg, var(--c-border) 0 8px, transparent 8px 16px);
  z-index:0;
}
.tl-step{
  position:relative;z-index:1;
  background:#fff;border:1px solid var(--c-border);border-radius:18px;
  padding:24px 20px;display:flex;flex-direction:column;gap:8px;align-items:flex-start;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.tl-step:hover{transform:translateY(-3px);box-shadow:0 12px 28px -14px rgba(13,79,92,.25);border-color:var(--c-primary)}
.tl-icon{
  width:44px;height:44px;border-radius:12px;
  display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, var(--c-primary), var(--c-primary-dark));
  color:#fff;box-shadow:0 6px 16px -8px rgba(13,79,92,.5);
}
.tl-icon svg{width:22px;height:22px}
.tl-num{font-size:.72rem;font-weight:700;letter-spacing:.1em;color:var(--c-primary);text-transform:uppercase;opacity:.7}
.tl-step h4{color:var(--c-primary);font-size:1rem;font-weight:700;margin:0;line-height:1.25}
.tl-step p{font-size:.86rem;color:var(--c-text-soft);margin:0;line-height:1.5}
@media(max-width:1024px){.timeline{grid-template-columns:repeat(3,1fr)}.timeline::before{display:none}}
@media(max-width:680px){.timeline{grid-template-columns:repeat(2,1fr)}}
@media(max-width:420px){.timeline{grid-template-columns:1fr}}
.timeline-sm{grid-template-columns:repeat(3,1fr);margin-top:24px}
.timeline-sm::before{display:none}
@media(max-width:680px){.timeline-sm{grid-template-columns:1fr}}

/* SEÇÃO DE INSCRIÇÃO 2-COLUNAS */
.enroll-section{padding:64px 0 80px;background:var(--c-bg-card)}
.enroll-layout{
  display:grid;grid-template-columns:minmax(0,1.7fr) minmax(0,1fr);gap:32px;align-items:start;
}
.enroll-aside{position:sticky;top:96px;display:flex;flex-direction:column;gap:16px}

/* Callout v2 */
.callout-v2{
  display:flex;gap:14px;align-items:flex-start;
  background:#fff7e9;border:1px solid #f3dca5;border-left:4px solid #d4a017;
  padding:18px 22px;border-radius:14px;margin-bottom:22px;
}
.cv2-icon{
  flex:none;width:36px;height:36px;border-radius:10px;
  background:#fbf2dc;color:#a67d12;
  display:inline-flex;align-items:center;justify-content:center;
}
.cv2-icon svg{width:20px;height:20px}
.callout-v2 strong{display:block;color:#7a5a0e;font-weight:700;margin-bottom:4px;font-size:.95rem}
.callout-v2 p{margin:0;color:#6b5a32;font-size:.9rem;line-height:1.5}

/* Form Card v2 */
.form-card-v2{
  background:#fff;border-radius:20px;
  padding:36px 36px 32px;
  border:1px solid var(--c-border);
  box-shadow:0 14px 40px -20px rgba(13,79,92,.18);
}
.form-head{margin-bottom:24px;text-align:left}
.form-head h2{margin:8px 0 6px;color:var(--c-primary);font-size:1.5rem}
.form-head p{font-size:.9rem;margin:0}
.form-head .eyebrow{display:inline-flex;align-items:center;gap:8px;justify-content:flex-start}
.form-head .eyebrow-line{width:24px;height:2px;background:var(--c-primary);border-radius:2px;display:inline-block}

.form-section{border:0;padding:0;margin:0 0 24px}
.form-section legend{
  display:flex;align-items:center;gap:10px;
  font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  color:var(--c-text-soft);
  padding:0 0 14px;margin:0 0 18px;width:100%;
  border-bottom:1px dashed var(--c-border);
}
.fs-num{
  width:22px;height:22px;border-radius:50%;
  background:var(--c-primary);color:#fff;font-size:.74rem;font-weight:700;
  display:inline-flex;align-items:center;justify-content:center;
}

.field .hint{display:block;font-size:.78rem;color:var(--c-text-soft);margin-top:4px}
.field.invalid .hint{display:none}
.field input,.field select,.field textarea{padding:12px 14px;font-size:.95rem;border-radius:10px}
.field select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23187583'><path d='M5.5 7.5l4.5 4.5 4.5-4.5z'/></svg>");background-repeat:no-repeat;background-position:right 12px center;background-size:18px;padding-right:38px}
.field label .muted{color:var(--c-text-soft);font-weight:400;font-size:.82rem;margin-left:4px}

.btn-lg{padding:16px 24px;font-size:1rem;border-radius:12px}
.form-submit{margin-top:8px}
.form-fineprint{
  display:flex;align-items:center;justify-content:center;gap:6px;
  font-size:.8rem;color:var(--c-text-soft);margin:14px 0 0;text-align:center;
}
.form-fineprint svg{flex:none;color:var(--c-primary)}
.form-fineprint a{color:var(--c-primary);text-decoration:underline;font-weight:500}

/* Sidebar cards */
.aside-card{
  background:#fff;border:1px solid var(--c-border);border-radius:18px;
  padding:22px;
}
.aside-label{
  display:block;font-size:.74rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--c-primary);margin-bottom:14px;
}
.aside-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.aside-list li{display:flex;gap:10px;align-items:flex-start}
.aside-list > li > svg{
  flex:none;width:18px;height:18px;color:#fff;
  background:var(--c-primary);border-radius:50%;padding:3px;margin-top:2px;
  box-sizing:content-box;
}
.aside-list b{display:block;font-size:.92rem;color:var(--c-text);font-weight:700;line-height:1.3}
.aside-list span{font-size:.82rem;color:var(--c-text-soft);line-height:1.4}

.aside-help{background:linear-gradient(135deg, var(--c-primary), var(--c-primary-dark));color:#fff;border-color:transparent}
.aside-help .help-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.help-avatar{width:44px;height:44px;border-radius:50%;overflow:hidden;flex:none;border:2px solid rgba(255,255,255,.3)}
.help-avatar img{width:100%;height:100%;object-fit:cover}
.aside-help strong{display:block;font-size:.95rem;color:#fff}
.aside-help .muted{font-size:.8rem;color:rgba(255,255,255,.75)}
.btn-whats{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:#25D366;color:#fff;border:0;border-radius:12px;
  padding:13px 18px;font-weight:600;font-size:.95rem;
  transition:background .2s, transform .15s;
}
.btn-whats:hover{background:#1eb85a;transform:translateY(-1px);color:#fff}
.btn-whats svg{width:18px;height:18px}

.aside-trust{padding:18px 22px}
.trust-row{display:flex;align-items:center;gap:10px;font-size:.84rem;color:var(--c-text-soft);padding:8px 0}
.trust-row + .trust-row{border-top:1px dashed var(--c-border)}
.trust-row svg{width:18px;height:18px;color:var(--c-primary);flex:none}

/* Success state */
.success-state{text-align:center;padding:8px 0 24px}
.success-check{
  width:72px;height:72px;margin:0 auto 14px;color:var(--c-success);
  animation:popIn .45s cubic-bezier(.2,.8,.2,1.1);
}
.success-check svg{width:100%;height:100%}
@keyframes popIn{0%{transform:scale(.6);opacity:0}100%{transform:scale(1);opacity:1}}
.success-state h2{color:var(--c-primary);margin:0 0 6px;font-size:1.4rem}
.success-state p{max-width:480px;margin:0 auto;font-size:.95rem}

/* FAQ refinado (toggle de + para chevron animado) */
.faq-q{position:relative;padding-right:54px!important;font-weight:600!important}
.faq-q::after{display:none!important}
.faq-toggle{
  position:absolute;right:18px;top:50%;transform:translateY(-50%);
  width:28px;height:28px;border-radius:50%;
  background:var(--c-bg-card);
  display:inline-flex;align-items:center;justify-content:center;
  transition:background .2s, transform .25s;
}
.faq-toggle::before,.faq-toggle::after{
  content:"";position:absolute;background:var(--c-primary);border-radius:2px;
}
.faq-toggle::before{width:12px;height:2px}
.faq-toggle::after{width:2px;height:12px;transition:transform .25s}
.faq-item.open .faq-toggle{background:var(--c-primary)}
.faq-item.open .faq-toggle::before,.faq-item.open .faq-toggle::after{background:#fff}
.faq-item.open .faq-toggle::after{transform:scaleY(0)}
.faq-item:hover{border-color:var(--c-primary)}

/* Responsive */
@media(max-width:980px){
  .enroll-layout{grid-template-columns:1fr;gap:20px}
  .enroll-aside{position:static}
  .form-card-v2{padding:28px 22px 24px}
}
@media(max-width:560px){
  .enroll-hero{padding:48px 0 36px}
  .enroll-section{padding:40px 0 56px}
}

/* ============================================
   Página ENEM Estratégico
   ============================================ */
.enem-hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(1200px 400px at 80% -10%, rgba(54,156,172,.18), transparent 70%),
    radial-gradient(900px 360px at 0% 110%, rgba(224,141,88,.14), transparent 60%);
  padding:64px 0 48px;
}
.enem-hero h1{font-size:clamp(2rem,4.6vw,3.4rem);max-width:880px;margin:0 auto 18px;font-weight:400}
.enem-hero h1 b{color:var(--c-accent);font-weight:700}
.enem-hero p{font-size:1.06rem;line-height:1.75;color:var(--c-text-soft);max-width:760px;margin:0 auto}

.enem-hero-tags{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.enem-tag{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px;border-radius:99px;font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  background:rgba(24,117,131,.10);color:var(--c-primary);border:1px solid rgba(24,117,131,.18);
}
.enem-tag--accent{background:rgba(54,156,172,.14);color:var(--c-accent);border-color:rgba(54,156,172,.28)}
.enem-tag--alert{background:rgba(224,141,88,.16);color:var(--c-secondary-dark);border-color:rgba(224,141,88,.32)}
.enem-tag--alert::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--c-secondary);animation:pulse-dot 1.8s infinite}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 0 rgba(224,141,88,.55)}50%{box-shadow:0 0 0 6px rgba(224,141,88,0)}}

.enem-highlights{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
  margin:42px auto 0;max-width:980px;
}
.enem-hl{
  display:flex;align-items:center;gap:14px;text-align:left;
  background:#fff;border:1px solid var(--c-border);border-radius:14px;padding:14px 16px;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.enem-hl:hover{transform:translateY(-3px);box-shadow:0 14px 28px -18px rgba(13,79,92,.3);border-color:rgba(24,117,131,.35)}
.enem-hl-ico{
  width:42px;height:42px;flex:none;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--c-primary),var(--c-primary-dark));color:#fff;
}
.enem-hl-ico svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.enem-hl-label{display:block;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--c-text-soft);font-weight:700;margin-bottom:2px}
.enem-hl strong{display:block;font-size:.98rem;color:var(--c-primary);font-weight:700}
@media(max-width:880px){.enem-highlights{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.enem-highlights{grid-template-columns:1fr}}

.enem-compare{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:28px}
.enem-disc{
  background:#fff;border:1px solid var(--c-border);border-radius:18px;padding:26px 24px;
  display:flex;flex-direction:column;gap:18px;
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.enem-disc:hover{transform:translateY(-4px);border-color:rgba(24,117,131,.35);box-shadow:0 18px 38px -22px rgba(13,79,92,.32)}
.enem-disc > header{display:flex;align-items:center;gap:14px}
.enem-disc-ico{
  width:54px;height:54px;flex:none;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,rgba(24,117,131,.14),rgba(24,117,131,.04));color:var(--c-primary);
}
.enem-disc-ico svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.enem-disc-eyebrow{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--c-secondary-dark);font-weight:700}
.enem-disc h3{font-size:1.5rem;margin:2px 0 0}
.enem-disc-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.enem-disc-list li{
  display:flex;align-items:flex-start;justify-content:space-between;gap:14px;
  padding:12px 14px;background:var(--c-bg-card);border-radius:10px;font-size:.92rem;line-height:1.4;
}
.enem-disc-list li > span{color:var(--c-text-soft);font-weight:500;flex:none}
.enem-disc-list li > b{color:var(--c-primary);font-weight:600;text-align:right}
@media(max-width:780px){.enem-compare{grid-template-columns:1fr}}

.enem-invest{
  display:grid;grid-template-columns:1.2fr 1fr;gap:24px;align-items:center;
  background:linear-gradient(135deg,var(--c-primary) 0%, var(--c-primary-dark) 100%);
  color:#fff;border-radius:22px;padding:32px 36px;margin:28px 0;
  position:relative;overflow:hidden;
}
.enem-invest::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(600px 200px at 100% 0%, rgba(54,156,172,.35), transparent 60%);
  pointer-events:none;
}
.enem-invest-block{position:relative}
.enem-invest-block .enem-hl-label{color:rgba(255,255,255,.75)}
.enem-price{display:block;font-family:var(--font-sans);font-size:clamp(2rem,4vw,2.8rem);line-height:1;margin:6px 0 8px;letter-spacing:-.02em}
.enem-invest-meta{font-size:.92rem;color:rgba(255,255,255,.85)}
.enem-invest-cta{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end;position:relative}
.enem-invest-cta .btn-primary{background:#fff;color:var(--c-primary);border-color:#fff}
.enem-invest-cta .btn-primary:hover{background:var(--c-secondary);color:#fff;border-color:var(--c-secondary)}
.enem-invest-cta .btn-ghost{color:#fff;border-color:rgba(255,255,255,.6)}
.enem-invest-cta .btn-ghost::after{filter:brightness(0) invert(1)}
.enem-invest-cta .btn-ghost:hover{background:#fff;color:var(--c-primary)}
.enem-invest-cta .btn-ghost:hover::after{filter:none}
@media(max-width:780px){.enem-invest{grid-template-columns:1fr;text-align:center;padding:28px 22px}.enem-invest-cta{justify-content:center}}

/* Tags de diferenciais por disciplina */
.enem-disc-extra{padding-top:16px;border-top:1px dashed var(--c-border)}
.enem-disc-extra-label{display:block;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--c-secondary-dark);font-weight:700;margin-bottom:10px}
.enem-disc-tags{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:6px}
.enem-disc-tags li{
  position:relative;font-size:.82rem;color:var(--c-primary);font-weight:500;
  padding:6px 12px 6px 28px;background:var(--c-bg-card);border-radius:99px;line-height:1.3;
}
.enem-disc-tags li::before{
  content:"";position:absolute;left:9px;top:50%;transform:translateY(-50%);
  width:14px;height:14px;border-radius:50%;background:var(--c-primary);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
  background-size:10px;background-position:center;background-repeat:no-repeat;
}

/* Linha compartilhada (dia/horário, início) */
.enem-shared{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:0 0 24px;
}
.enem-shared-row{
  background:#fff;border:1px solid var(--c-border);border-radius:14px;padding:18px 22px;
  display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
}
.enem-shared-row strong{color:var(--c-primary);font-size:1.05rem}
@media(max-width:780px){.enem-shared{grid-template-columns:1fr}}

/* Observações */
.enem-notes{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:22px}
.enem-note{
  background:var(--c-warning-bg, #FFF4E6);border-left:4px solid var(--c-secondary);
  border-radius:12px;padding:18px 20px;
}
.enem-note-tag{
  display:inline-block;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
  font-weight:700;color:var(--c-secondary-dark);margin-bottom:8px;
}
.enem-note p{margin:0;color:var(--c-text);font-size:.94rem;line-height:1.6}
@media(max-width:780px){.enem-notes{grid-template-columns:1fr}}

/* ============================================
   Grade de horários (cursos.html)
   ============================================ */
.schedule-section{background:transparent}
.schedule-wrap{
  background:linear-gradient(135deg,var(--c-primary) 0%, var(--c-primary-dark) 100%);
  border-radius:24px;padding:32px;color:#fff;
  box-shadow:0 22px 60px rgba(13,79,92,.18);overflow:hidden;
}
.schedule{
  display:grid;
  grid-template-columns:120px repeat(5,minmax(0,1fr));
  gap:6px;background:rgba(255,255,255,.08);border-radius:14px;padding:6px;
}
.sch-cell{
  background:rgba(255,255,255,.06);border-radius:8px;
  min-height:78px;padding:10px;
  display:flex;align-items:center;justify-content:center;text-align:center;
  font-size:.86rem;
}
.sch-head{
  font-weight:700;letter-spacing:.18em;font-size:.78rem;text-transform:uppercase;
  background:rgba(255,255,255,.14);min-height:auto;padding:14px 8px;
}
.sch-time{
  font-weight:600;font-size:.82rem;letter-spacing:.02em;
  background:rgba(255,255,255,.14);color:rgba(255,255,255,.92);
}
.sch-class{
  display:flex;flex-direction:column;gap:4px;width:100%;
  padding:10px 8px;border-radius:8px;line-height:1.25;
  transition:transform .25s ease, box-shadow .25s ease;cursor:default;
}
.sch-class b{font-weight:700;font-size:.86rem;color:#fff}
.sch-class i{font-style:normal;font-size:.72rem;letter-spacing:.06em;color:rgba(255,255,255,.85);text-transform:uppercase;font-weight:600}
.sch-class:hover{transform:translateY(-2px);box-shadow:0 10px 22px -10px rgba(0,0,0,.35)}

/* Cores por disciplina */
.sch-c--redacao{background:linear-gradient(135deg,#369CAC,#1f7e8e)}
.sch-c--gramatica{background:linear-gradient(135deg,#5fb0bf,#2f8c9d)}
.sch-c--matematica{background:linear-gradient(135deg,#E08D58,#c47246)}
.sch-c--enem{background:linear-gradient(135deg,#C9A84C,#a98a32);color:#1c1c1a}
.sch-c--enem b{color:#1c1c1a}
.sch-c--enem i{color:rgba(28,28,26,.7)}
.sch-c--online{background:linear-gradient(135deg,#7c8aa6,#4f5d7a)}

.sch-legend{
  display:flex;flex-wrap:wrap;justify-content:center;gap:18px 22px;
  margin-top:22px;font-size:.84rem;color:rgba(255,255,255,.92);font-weight:600;
}
.sch-legend span{display:inline-flex;align-items:center;gap:8px}
.sch-legend .dot{display:inline-block;width:14px;height:14px;border-radius:4px}

@media(max-width:880px){
  .schedule-wrap{padding:18px;border-radius:20px}
  .schedule{grid-template-columns:80px repeat(5,minmax(110px,1fr));gap:4px;overflow-x:auto}
  .sch-cell{min-height:64px;font-size:.78rem;padding:6px}
  .sch-time{font-size:.7rem;padding:8px 4px}
  .sch-class b{font-size:.78rem}
  .sch-class i{font-size:.66rem}
}
@media(max-width:560px){
  .schedule{grid-auto-flow:row;overflow-x:auto;min-width:680px}
  .schedule-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
}

/* Print/Acessibilidade — reduzir movimento */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{transition:none!important;animation:none!important}
  .reveal,.reveal-left,.reveal-right,.reveal-stagger > *{opacity:1!important;transform:none!important}
  .hero h1,.hero p.lead,.hero-cta,.hero-visual,.hero-quote{opacity:1!important;animation:none!important}
}
