/* Compact typography layer loaded after page-specific CSS.
   Purpose: enforce smaller, softer scale across all templates. */

html {
  font-size: 14px !important;
}

body {
  font-size: 0.9rem !important;
  line-height: 1.42 !important;
}

h1,
.h1 {
  font-size: clamp(1.35rem, 2vw, 1.85rem) !important;
}

h2,
.h2 {
  font-size: clamp(1.18rem, 1.6vw, 1.45rem) !important;
}

h3,
.h3 {
  font-size: clamp(1.03rem, 1.32vw, 1.22rem) !important;
}

h4,
.h4,
h5,
.h5 {
  font-size: 0.98rem !important;
}

.dashboard-content,
.main-area,
.wizard-shell,
.wizard-container {
  font-size: 0.9rem !important;
}

.form-control,
.form-select,
textarea,
input {
  font-size: 0.9rem !important;
}

.btn {
  font-size: 0.88rem !important;
}

.table {
  font-size: 0.88rem !important;
}

/* Wizard moderno (wizard_formacao_saas.css) */
.wizard-shell {
  font-size: 0.88rem !important;
}

.wizard-title {
  font-size: clamp(0.92rem, 1.2vw, 1.1rem) !important;
}

.wizard-panel__title {
  font-size: clamp(1.05rem, 1.52vw, 1.34rem) !important;
}

.wizard-panel__description,
.wizard-subtitle,
.wizard-section-text,
.wizard-section-text--wide,
.wizard-type-card__description,
.wizard-field__hint,
.wizard-empty__text,
.wizard-summary-card__text {
  font-size: 0.86rem !important;
  line-height: 1.5 !important;
}

.wizard-section-title--hero {
  font-size: clamp(1.35rem, 1.85vw, 1.85rem) !important;
  line-height: 1.1 !important;
  max-width: 18ch !important;
}

.wizard-shell[data-step="1"] .wizard-section-title--hero {
  font-size: clamp(1.45rem, 2.05vw, 2rem) !important;
}

.wizard-step__label {
  font-size: 0.72rem !important;
}

.wizard-step__meta {
  font-size: 0.62rem !important;
}

.wizard-progress-summary__value {
  font-size: 1.45rem !important;
}

.wizard-summary-card__title {
  font-size: 0.9rem !important;
}

.wizard-summary-value,
.wizard-summary-stat__label,
.wizard-status-pill {
  font-size: 0.76rem !important;
}

.wizard-summary-stat__number {
  font-size: 1.18rem !important;
}

.wizard-actions .btn {
  min-height: 2.65rem !important;
  font-size: 0.86rem !important;
}

/* Wizard legado + parciais com <style> interno */
.wizard-content .step-title {
  font-size: clamp(1.2rem, 1.9vw, 1.55rem) !important;
}

.progress-left h6 {
  font-size: 0.96rem !important;
}

.progress-percent {
  font-size: 1.45rem !important;
}

.progress-status,
.progress-message {
  font-size: 0.82rem !important;
}

.step-nav-item {
  font-size: 0.72rem !important;
  padding: 0.55rem 0.6rem !important;
}

.step-nav-number {
  font-size: 0.84rem !important;
}

.checklist-indicator {
  font-size: 1rem !important;
}

.completion-checklist,
.preview-container {
  font-size: 0.86rem !important;
}

/* Site público */
.layout,
.main-area {
  font-size: 0.9rem !important;
}

.hero h2 {
  font-size: clamp(1.35rem, 1.95vw, 1.8rem) !important;
}

.hero p,
.content-card,
.content-card p,
.content-card ul,
.content-card ol {
  font-size: 0.9rem !important;
}

.menu-list a,
.quick-link,
.pill {
  font-size: 0.84rem !important;
}

@media (max-width: 768px) {
  html {
    font-size: 13px !important;
  }

  .wizard-section-title--hero {
    font-size: clamp(1.25rem, 5.8vw, 1.55rem) !important;
  }

  .wizard-panel__title {
    font-size: clamp(1.02rem, 4.6vw, 1.28rem) !important;
  }
}
