/* ============================================================
   Essência Cognitiva — Página do curso "Performance com Sentido"
   Complementa styles/home.css · acento sálvia
   ============================================================ */

/* ---------- hero do curso ---------- */

.course-hero { padding: 88px 0 72px; }

.course-hero .wrap {
  display: grid;
  gap: 26px;
  justify-items: center;
  text-align: center;
  max-width: 880px;
}

.course-hero .status {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--sage);
  border: 1.5px dashed color-mix(in oklab, var(--sage) 55%, transparent);
  border-radius: 999px;
  padding: 9px 18px;
}

.course-hero .status::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--sage);
}

.course-hero h1 {
  font-size: clamp(40px, 5vw, 62px);
  letter-spacing: -0.015em;
}

.course-hero .lead { max-width: 56ch; }

.course-hero .hero-note { font-size: 14px; color: var(--ink-soft); }

/* ---------- para quem ---------- */

.course-for {
  padding: 90px 0;
  background: var(--surface);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.course-for .wrap {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 72px;
  align-items: start;
}

@media (max-width: 900px) {
  .course-for .wrap { grid-template-columns: 1fr; gap: 44px; }
}

/* ---------- módulos ---------- */

.modules { padding: 110px 0; }

.module-list {
  display: grid;
  gap: 0;
  border-top: 1px solid var(--line);
  counter-reset: module;
}

.module {
  counter-increment: module;
  display: grid;
  grid-template-columns: 110px 1fr 1.2fr;
  gap: 36px;
  align-items: start;
  padding: 34px 0;
  border-bottom: 1px solid var(--line);
}

.module .num {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 42px;
  line-height: 1;
  color: var(--sage);
}

.module .num::before { content: "0" counter(module); }

.module h3 { font-size: 23px; }

.module .theme {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-top: 8px;
}

.module p { color: var(--ink-soft); font-size: 15.5px; text-wrap: pretty; }

@media (max-width: 900px) {
  .module { grid-template-columns: 64px 1fr; }
  .module p { grid-column: 2; }
  .module .num { font-size: 32px; }
}

/* ---------- formato ---------- */

.format {
  padding: 96px 0;
  background: var(--slate-deep);
  color: #EDF1EE;
}

.format .eyebrow { color: var(--sage); }
.format .eyebrow::before { background: var(--sage); }
.format .section-head h2 { color: #F4F1EA; }
.format .section-head p { color: rgba(237, 241, 238, 0.72); }

.format-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid rgba(244, 241, 234, 0.16);
}

.format-item {
  padding: 30px 30px 6px 0;
  border-right: 1px solid rgba(244, 241, 234, 0.16);
  display: grid;
  gap: 8px;
  align-content: start;
}

.format-item:last-child { border-right: none; }

.format-item .big {
  font-family: var(--font-display);
  font-size: 28px;
  color: #F4F1EA;
  line-height: 1.15;
}

.format-item p { font-size: 14px; color: rgba(237, 241, 238, 0.72); }

@media (max-width: 900px) {
  .format-grid { grid-template-columns: repeat(2, 1fr); }
  .format-item { border-right: none; padding: 22px 0 6px; }
}

/* ---------- quem conduz ---------- */

.teachers { padding: 110px 0; }

.teachers-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
}

.teacher-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-card);
  padding: 36px 34px;
  display: grid;
  grid-template-columns: 76px 1fr;
  gap: 22px;
  align-items: start;
}

.teacher-card image-slot, .teacher-card .photo { width: 76px; height: 76px; }

.teacher-card h3 { font-size: 22px; }

.teacher-card .crp { font-size: 13px; color: var(--ink-soft); letter-spacing: 0.04em; margin: 4px 0 10px; }

.teacher-card p { font-size: 15px; color: var(--ink-soft); }

.teacher-card a {
  display: inline-block;
  margin-top: 12px;
  font-size: 14.5px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 4px;
}

@media (max-width: 900px) {
  .teachers-grid { grid-template-columns: 1fr; }
}

/* ---------- lista de espera ---------- */

.waitlist { padding: 0 0 110px; }

.waitlist .inner {
  background: var(--sage-soft);
  border-radius: 28px;
  padding: 72px 64px;
  display: grid;
  gap: 22px;
  justify-items: center;
  text-align: center;
}

.waitlist h2 { font-size: clamp(30px, 3.6vw, 42px); max-width: 24ch; }

.waitlist p { color: var(--ink-soft); max-width: 54ch; text-wrap: pretty; }

.waitlist .perks {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}

.waitlist .perks span {
  font-size: 13.5px;
  font-weight: 600;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 8px 16px;
  color: var(--ink-soft);
}

.waitlist .btn { background: var(--sage); color: #FFF; box-shadow: 0 8px 22px -10px var(--sage); }

.waitlist .whats-note { font-size: 13.5px; color: var(--ink-soft); }
