﻿/* ==========================================================================
   sec-single-curso.css — Template single de curso
   Tokens: Camada 2/3 apenas. Sem hex hardcoded.
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. ROOT / LAYOUTS
   -------------------------------------------------------------------------- */
.focofy-curso-single {
  width: 100%;
}

/* Layout split: midia | conteudo lado a lado */
.focofy-curso-single--layout-split .focofy-curso-single__body {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--grid-gap);
  align-items: start;
}

@media (min-width: 768px) {
  .focofy-curso-single--layout-split .focofy-curso-single__body {
    grid-template-columns: 1fr 1fr;
  }
}

@media (min-width: 1024px) {
  .focofy-curso-single--layout-split .focofy-curso-single__body {
    grid-template-columns: 3fr 2fr;
  }
}

/* Layout stacked: midia acima do conteudo */
.focofy-curso-single--layout-stacked .focofy-curso-single__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

/* Layout hero: midia full-width no topo */
.focofy-curso-single--layout-hero .focofy-curso-single__media {
  width: 100%;
  margin-bottom: var(--space-8);
}

/* Layout compact: sem midia proeminente */
.focofy-curso-single--layout-compact .focofy-curso-single__media {
  display: none;
}

/* Alinhamento */
.focofy-curso-single--align-center .focofy-curso-single__content {
  text-align: center;
  max-width: var(--container-narrow);
  margin-left: auto;
  margin-right: auto;
}

/* Larguras */
.focofy-curso-single--width-narrow { max-width: var(--container-narrow); margin-left: auto; margin-right: auto; }
.focofy-curso-single--width-wide   { max-width: var(--container-wide); }

/* Midia no topo (stacked) */
.focofy-curso-single--media-top .focofy-curso-single__media {
  order: -1;
}

/* --------------------------------------------------------------------------
   2. MIDIA
   -------------------------------------------------------------------------- */
.focofy-curso-single__media {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg);
  background: var(--color-surface-2);
}

.focofy-curso-single__img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

/* --------------------------------------------------------------------------
   3. CONTEUDO PRINCIPAL
   -------------------------------------------------------------------------- */
.focofy-curso-single__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

/* Eyebrow / badge acima do titulo */
.focofy-curso-single__eyebrow {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-accent);
}

/* Titulo do curso */
.focofy-curso-single__title {
  font-family: var(--font-heading);
  font-size: var(--font-size-4xl);
  font-weight: var(--fw-heading);
  color: var(--color-heading);
  line-height: var(--lh-tight);
  margin: 0;
}

/* Intro / resumo curto */
.focofy-curso-single__intro {
  font-size: var(--font-size-lg);
  color: var(--color-text-muted);
  line-height: var(--lh-relaxed);
  margin: 0;
}

/* --------------------------------------------------------------------------
   4. META (nivel, carga, formato, plataforma)
   -------------------------------------------------------------------------- */
.focofy-curso-single__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
}

/* meta-inline: itens em linha */
.focofy-curso-single--meta-inline .focofy-curso-single__meta {
  flex-direction: row;
}

/* meta-pills: badges arredondados */
.focofy-curso-single--meta-pills .focofy-curso-single__meta-item {
  background: var(--color-surface-2);
  border-radius: var(--radius-full);
  padding: var(--space-1) var(--space-4);
}

/* meta-cards: com borda */
.focofy-curso-single--meta-cards .focofy-curso-single__meta-item {
  background: var(--color-surface-1);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-4);
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-1);
}

.focofy-curso-single__meta-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.focofy-curso-single__meta-label {
  font-size: var(--font-size-xs);
  font-weight: var(--fw-semibold);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.focofy-curso-single__meta-value {
  font-size: var(--font-size-sm);
  font-weight: var(--fw-medium);
  color: var(--color-text);
}

/* --------------------------------------------------------------------------
   5. PARA QUEM E' O CURSO
   -------------------------------------------------------------------------- */
.focofy-curso-single__para-quem {
  background: var(--color-surface-2);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  border-left: 4px solid var(--color-accent);
}

.focofy-curso-single__para-quem-text {
  font-size: var(--font-size-base);
  color: var(--color-text);
  line-height: var(--lh-relaxed);
  margin: 0;
}

/* --------------------------------------------------------------------------
   6. DESCRICAO COMPLETA
   -------------------------------------------------------------------------- */
.focofy-curso-single__descricao {
  font-size: var(--font-size-base);
  color: var(--color-text);
  line-height: var(--lh-relaxed);
}

.focofy-curso-single__section-title {
  font-family: var(--font-heading);
  font-size: var(--font-size-xl);
  font-weight: var(--fw-semibold);
  color: var(--color-heading);
  margin: 0 0 var(--space-4);
}

/* --------------------------------------------------------------------------
   7. OBJETIVOS
   -------------------------------------------------------------------------- */
.focofy-curso-single__objetivos-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

/* Modo cards */
.focofy-curso-single__objetivos--cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-3);
  list-style: none;
  margin: 0;
  padding: 0;
}

.focofy-curso-single__objetivo-card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: var(--card-radius);
  padding: var(--space-4);
  font-size: var(--font-size-sm);
  color: var(--color-text);
  line-height: var(--lh-snug);
  box-shadow: var(--card-shadow);
}

/* Modo pills */
.focofy-curso-single__objetivos--pills {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  list-style: none;
  margin: 0;
  padding: 0;
}

.focofy-curso-single__objetivo-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--badge-font-size);
  font-weight: var(--badge-fw);
  padding: var(--badge-padding-y) var(--badge-padding-x);
  border-radius: var(--badge-radius);
  background: var(--color-surface-2);
  color: var(--color-text);
  border: 1px solid var(--color-border-subtle);
}

/* Modo list */
.focofy-curso-single__objetivos--list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.focofy-curso-single__objetivos--list li {
  font-size: var(--font-size-sm);
  color: var(--color-text);
  padding-left: var(--space-6);
  position: relative;
  line-height: var(--lh-snug);
}

.focofy-curso-single__objetivos--list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.35em;
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background: var(--color-accent);
}

/* --------------------------------------------------------------------------
   8. MODULOS (CURRICULUM)
   -------------------------------------------------------------------------- */
.focofy-curso-single__modulos {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.focofy-curso-single__modulos-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.focofy-curso-single__modulo {
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
  background: var(--color-surface-1);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-md);
  padding: var(--space-4);
}

.focofy-curso-single__modulo-num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  background: var(--color-accent);
  color: var(--color-text-inverse);
  font-size: var(--font-size-sm);
  font-weight: var(--fw-bold);
  flex-shrink: 0;
}

.focofy-curso-single__modulo-body {
  flex: 1;
  min-width: 0;
}

.focofy-curso-single__modulo-title {
  font-size: var(--font-size-base);
  font-weight: var(--fw-semibold);
  color: var(--color-heading);
  margin: 0 0 var(--space-1);
}

.focofy-curso-single__modulo-desc {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  line-height: var(--lh-relaxed);
  margin: 0;
}

/* --------------------------------------------------------------------------
   9. INSTRUTOR
   -------------------------------------------------------------------------- */
.focofy-curso-single__instrutor {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.focofy-curso-single__instrutor-card {
  display: flex;
  gap: var(--space-4);
  align-items: center;
  background: var(--color-surface-1);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-md);
  padding: var(--space-4);
}

.focofy-curso-single__instrutor-photo {
  width: 72px;
  height: 72px;
  border-radius: var(--radius-full);
  overflow: hidden;
  flex-shrink: 0;
  background: var(--color-surface-2);
}

.focofy-curso-single__instrutor-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.focofy-curso-single__instrutor-info {
  flex: 1;
  min-width: 0;
}

.focofy-curso-single__instrutor-nome {
  font-size: var(--font-size-base);
  font-weight: var(--fw-semibold);
  color: var(--color-heading);
  margin: 0 0 var(--space-1);
}

.focofy-curso-single__instrutor-bio {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  line-height: var(--lh-relaxed);
  margin: 0;
}

/* --------------------------------------------------------------------------
   10. DEPOIMENTOS
   -------------------------------------------------------------------------- */
.focofy-curso-single__depoimentos {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.focofy-curso-single__depoimentos-grid {
  display: grid;
  gap: var(--space-4);
  grid-template-columns: 1fr;
}

@media (min-width: 768px) {
  .focofy-curso-single__depoimentos-grid {
    grid-template-columns: 1fr 1fr;
  }
}

.focofy-curso-single__depoimento-card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: var(--card-radius);
  padding: var(--card-padding);
  box-shadow: var(--card-shadow);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.focofy-curso-single__depoimento-quote {
  font-size: var(--font-size-sm);
  color: var(--color-text);
  line-height: var(--lh-relaxed);
  margin: 0;
  font-style: italic;
}

.focofy-curso-single__depoimento-author {
  font-size: var(--font-size-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-text-muted);
}

/* --------------------------------------------------------------------------
   11. FAQ
   -------------------------------------------------------------------------- */
.focofy-curso-single__faq {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.focofy-curso-single__faq-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  list-style: none;
  margin: 0;
  padding: 0;
}

.focofy-curso-single__faq-item {
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.focofy-curso-single__faq-question {
  display: block;
  width: 100%;
  text-align: left;
  padding: var(--space-4) var(--space-6);
  background: var(--color-surface-1);
  font-size: var(--font-size-base);
  font-weight: var(--fw-medium);
  color: var(--color-heading);
  cursor: pointer;
  border: none;
  transition: background var(--transition-fast);
}

.focofy-curso-single__faq-question:hover {
  background: var(--color-surface-2);
}

.focofy-curso-single__faq-answer {
  padding: var(--space-4) var(--space-6);
  font-size: var(--font-size-sm);
  color: var(--color-text);
  line-height: var(--lh-relaxed);
  border-top: 1px solid var(--color-border-subtle);
  background: var(--color-bg);
}

/* --------------------------------------------------------------------------
   12. CTA FINAL
   -------------------------------------------------------------------------- */
.focofy-curso-single__cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-8);
  background: var(--color-surface-2);
  border-radius: var(--radius-lg);
  text-align: center;
}

.focofy-curso-single__cta-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-lg);
  font-weight: var(--btn-font-weight);
  padding: var(--btn-padding-y) var(--btn-padding-x);
  border-radius: var(--btn-radius);
  background: var(--btn-primary-bg);
  color: var(--btn-primary-text);
  border: 1px solid var(--btn-primary-border);
  text-decoration: none;
  transition: background var(--btn-transition), color var(--btn-transition);
  box-shadow: var(--btn-shadow);
}

.focofy-curso-single__cta-btn:hover {
  background: var(--btn-primary-hover-bg);
  color: var(--btn-primary-hover-text);
  border-color: var(--btn-primary-hover-border);
}

/* --------------------------------------------------------------------------
   13. DARK MODE
   -------------------------------------------------------------------------- */
[data-bg="dark"] .focofy-curso-single__title,
[data-bg="dark"] .focofy-curso-single__section-title,
[data-bg="dark"] .focofy-curso-single__modulo-title,
[data-bg="dark"] .focofy-curso-single__instrutor-nome {
  color: var(--color-text-inverse);
}

[data-bg="dark"] .focofy-curso-single__intro,
[data-bg="dark"] .focofy-curso-single__descricao,
[data-bg="dark"] .focofy-curso-single__resumo,
[data-bg="dark"] .focofy-curso-single__modulo-desc,
[data-bg="dark"] .focofy-curso-single__instrutor-bio {
  color: var(--color-text-muted);
}

[data-bg="dark"] .focofy-curso-single__para-quem {
  background: var(--color-surface-dark);
}

[data-bg="dark"] .focofy-curso-single__modulo,
[data-bg="dark"] .focofy-curso-single__instrutor-card,
[data-bg="dark"] .focofy-curso-single__faq-question {
  background: var(--color-surface-dark);
  border-color: var(--color-border-subtle);
}

[data-bg="dark"] .focofy-curso-single__depoimento-card {
  background: var(--color-surface-dark);
  border-color: var(--color-border-subtle);
}

[data-bg="dark"] .focofy-curso-single__cta {
  background: var(--color-surface-dark);
}
