/* Template card base */
.template-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border-medium);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  margin-top: var(--space-sm);
  box-shadow: var(--shadow-sm);
  width: 100%;
  overflow-wrap: anywhere;
}

/* ── Explicação ── */
.template-explicacao .template-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
}

.template-explicacao .template-icon {
  font-size: var(--font-lg);
}

.template-explicacao .template-title {
  font-size: var(--font-lg);
  font-weight: 600;
  color: var(--text-primary);
}

.template-explicacao .template-body {
  font-size: var(--font-base);
  color: var(--text-primary);
  line-height: 1.7;
  margin-bottom: var(--space-md);
}

.template-explicacao .example-card {
  background: var(--bg-tertiary);
  border-radius: var(--radius-sm);
  padding: var(--space-sm) var(--space-md);
  margin-bottom: var(--space-sm);
}

.template-explicacao .example-en {
  font-size: var(--font-base);
  color: var(--text-primary);
}

.template-explicacao .example-en .highlight {
  color: var(--accent);
  font-weight: 600;
}

.template-explicacao .example-pt {
  font-size: var(--font-sm);
  color: var(--text-secondary);
  font-style: italic;
}

.template-explicacao .nota-extra {
  display: flex;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: var(--accent-subtle);
  border-radius: var(--radius-sm);
  margin-top: var(--space-md);
  font-size: var(--font-sm);
  color: var(--text-secondary);
  line-height: 1.5;
}

.template-explicacao .nota-extra .nota-icon {
  flex-shrink: 0;
}

/* ── Quiz ── */
.template-quiz .quiz-instruction {
  font-size: var(--font-sm);
  color: var(--text-secondary);
  margin-bottom: var(--space-sm);
}

.template-quiz .quiz-phrase {
  font-size: var(--font-md);
  color: var(--text-primary);
  margin-bottom: var(--space-md);
  line-height: 1.6;
}

.template-quiz .quiz-blank {
  color: var(--accent);
  font-weight: 600;
  text-decoration: underline;
  text-decoration-style: dashed;
  text-underline-offset: 3px;
}

.template-quiz .quiz-options {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.template-quiz .quiz-option {
  display: flex;
  align-items: flex-start;
  width: 100%;
  padding: var(--space-sm) var(--space-md);
  background: var(--bg-tertiary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  font-size: var(--font-base);
  color: var(--text-primary);
  transition: background var(--transition-fast), border-color var(--transition-fast);
  text-align: left;
  cursor: pointer;
}

.template-quiz .quiz-option:hover:not(.disabled) {
  background: var(--bg-hover);
  border-color: var(--border-medium);
}

.template-quiz .quiz-option .option-letter {
  font-weight: 600;
  margin-right: var(--space-sm);
  color: var(--text-secondary);
  min-width: 24px;
}

.template-quiz .quiz-option.disabled {
  cursor: default;
  opacity: 0.6;
}

.template-quiz .quiz-option.correct {
  border-color: var(--success);
  background: rgba(74, 222, 128, 0.1);
  opacity: 1;
}

.template-quiz .quiz-option.correct .option-letter {
  color: var(--success);
}

.template-quiz .quiz-option.wrong {
  border-color: var(--error);
  background: rgba(248, 113, 113, 0.1);
  opacity: 1;
}

.template-quiz .quiz-option.wrong .option-letter {
  color: var(--error);
}

.template-quiz .quiz-feedback {
  margin-top: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-sm);
  font-size: var(--font-sm);
  line-height: 1.5;
  animation: fadeIn 0.3s ease;
}

.template-quiz .quiz-feedback.success {
  background: rgba(74, 222, 128, 0.1);
  color: var(--success);
}

.template-quiz .quiz-feedback.error {
  background: rgba(248, 113, 113, 0.1);
  color: var(--error);
}

/* ── Lacuna ── */
.template-lacuna .lacuna-instruction {
  font-size: var(--font-sm);
  color: var(--text-secondary);
  margin-bottom: var(--space-sm);
}

.template-lacuna .lacuna-phrase {
  font-size: var(--font-md);
  color: var(--text-primary);
  margin-bottom: var(--space-md);
  line-height: 1.6;
}

.template-lacuna .lacuna-blank {
  color: var(--accent);
  font-weight: 600;
  letter-spacing: 2px;
}

.template-lacuna .lacuna-input-row {
  display: flex;
  align-items: stretch;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
}

.template-lacuna .lacuna-input {
  flex: 1;
  padding: var(--space-sm) var(--space-md);
  background: var(--bg-input);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: 16px;
  transition: border-color var(--transition-fast);
}

.template-lacuna .lacuna-input:focus {
  border-color: var(--accent-border);
}

.template-lacuna .lacuna-input:disabled {
  opacity: 0.5;
}

.template-lacuna .btn-lacuna-submit {
  padding: var(--space-sm) var(--space-md);
  background: var(--accent);
  color: var(--text-inverse);
  border-radius: var(--radius-sm);
  font-size: var(--font-sm);
  font-weight: 600;
  transition: background var(--transition-fast);
  white-space: nowrap;
}

.template-lacuna .btn-lacuna-submit:hover:not(:disabled) {
  background: var(--accent-hover);
}

.template-lacuna .btn-lacuna-submit:disabled {
  opacity: 0.5;
  cursor: default;
}

.template-lacuna .lacuna-attempts {
  font-size: var(--font-xs);
  color: var(--text-muted);
}

.template-lacuna .lacuna-hint {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: rgba(251, 191, 36, 0.1);
  border-radius: var(--radius-sm);
  font-size: var(--font-sm);
  color: var(--warning);
  margin-bottom: var(--space-sm);
  animation: fadeIn 0.3s ease;
}

.template-lacuna .lacuna-result {
  margin-top: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-sm);
  font-size: var(--font-sm);
  line-height: 1.5;
  animation: fadeIn 0.3s ease;
}

.template-lacuna .lacuna-result.success {
  background: rgba(74, 222, 128, 0.1);
  color: var(--success);
}

.template-lacuna .lacuna-result.error {
  background: rgba(248, 113, 113, 0.1);
  color: var(--text-primary);
}

.template-lacuna .lacuna-completed .completed-phrase {
  font-size: var(--font-md);
  color: var(--text-primary);
  margin-bottom: var(--space-sm);
}

.template-lacuna .lacuna-completed .completed-answer {
  color: var(--accent);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* ── Roleplay ── */
.template-roleplay {
  border-color: var(--accent-border);
}

.template-roleplay .roleplay-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
}

.template-roleplay .roleplay-icon {
  font-size: var(--font-lg);
}

.template-roleplay .roleplay-title {
  font-size: var(--font-lg);
  font-weight: 600;
  color: var(--text-primary);
}

.template-roleplay .roleplay-situation {
  font-size: var(--font-base);
  color: var(--text-primary);
  margin-bottom: var(--space-sm);
  line-height: 1.6;
}

.template-roleplay .roleplay-context {
  font-size: var(--font-sm);
  color: var(--text-secondary);
  margin-bottom: var(--space-md);
}

.template-roleplay .roleplay-vocab {
  background: var(--accent-subtle);
  border-radius: var(--radius-sm);
  padding: var(--space-sm) var(--space-md);
  margin-bottom: var(--space-md);
}

.template-roleplay .roleplay-vocab-label {
  font-size: var(--font-xs);
  color: var(--accent);
  font-weight: 600;
  margin-bottom: var(--space-xs);
}

.template-roleplay .roleplay-vocab-words {
  font-size: var(--font-sm);
  color: var(--text-primary);
}

.template-roleplay .roleplay-dialogue {
  border-top: 1px dashed var(--border-medium);
  padding-top: var(--space-md);
  margin-top: var(--space-sm);
}

.template-roleplay .roleplay-line {
  font-size: var(--font-base);
  color: var(--text-primary);
  font-style: italic;
  margin-bottom: var(--space-sm);
}

.template-roleplay .roleplay-character {
  font-style: normal;
  font-weight: 600;
  color: var(--accent);
}

.template-roleplay .roleplay-footer {
  border-top: 1px dashed var(--border-medium);
  padding-top: var(--space-sm);
  margin-top: var(--space-md);
  font-size: var(--font-xs);
  color: var(--text-muted);
}

/* ── Resumo da Sessão ── */
.template-resumo .resumo-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
}

.template-resumo .resumo-icon {
  font-size: var(--font-lg);
}

.template-resumo .resumo-title {
  font-size: var(--font-lg);
  font-weight: 600;
  color: var(--text-primary);
}

.template-resumo .resumo-foco {
  font-size: var(--font-sm);
  color: var(--text-secondary);
  margin-bottom: var(--space-md);
}

.template-resumo .resumo-section {
  border-radius: var(--radius-sm);
  padding: var(--space-sm) var(--space-md);
  margin-bottom: var(--space-sm);
}

.template-resumo .resumo-conquistas {
  background: rgba(74, 222, 128, 0.08);
}

.template-resumo .resumo-atencao {
  background: rgba(251, 191, 36, 0.08);
}

.template-resumo .resumo-section-title {
  font-size: var(--font-sm);
  font-weight: 600;
  margin-bottom: var(--space-xs);
}

.template-resumo .resumo-conquistas .resumo-section-title {
  color: var(--success);
}

.template-resumo .resumo-atencao .resumo-section-title {
  color: var(--warning);
}

.template-resumo .resumo-list {
  list-style: none;
  font-size: var(--font-sm);
  color: var(--text-primary);
}

.template-resumo .resumo-list li {
  padding: 2px 0;
  display: flex;
  align-items: flex-start;
  gap: var(--space-xs);
}

.template-resumo .resumo-list li::before {
  content: "•";
  color: var(--text-muted);
  flex-shrink: 0;
}

.template-resumo .resumo-metrics {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-lg);
  padding: var(--space-sm) 0;
  margin: var(--space-sm) 0;
  border-top: 1px solid var(--border-subtle);
  border-bottom: 1px solid var(--border-subtle);
  font-size: var(--font-sm);
}

.template-resumo .metric-acertos {
  color: var(--success);
  font-weight: 600;
}

.template-resumo .metric-erros {
  color: var(--error);
  font-weight: 600;
}

.template-resumo .resumo-mensagem {
  font-style: italic;
  font-size: var(--font-base);
  color: var(--text-primary);
  line-height: 1.6;
  margin: var(--space-md) 0;
}

.template-resumo .btn-nova-sessao {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  width: 100%;
  padding: var(--space-sm) var(--space-md);
  background: var(--accent);
  color: var(--text-inverse);
  border-radius: var(--radius-sm);
  font-size: var(--font-base);
  font-weight: 600;
  transition: background var(--transition-fast);
  margin-top: var(--space-sm);
}

.template-resumo .btn-nova-sessao:hover {
  background: var(--accent-hover);
}

@media (max-width: 768px) {
  .template-card {
    padding: var(--space-md);
  }

  .template-explicacao .template-header,
  .template-roleplay .roleplay-header,
  .template-resumo .resumo-header {
    align-items: flex-start;
    flex-wrap: wrap;
  }

  .template-lacuna .lacuna-input-row {
    flex-direction: column;
  }

  .template-lacuna .btn-lacuna-submit {
    width: 100%;
  }

  .template-resumo .resumo-metrics {
    flex-direction: column;
    gap: var(--space-sm);
  }
}
