/**
 * Ipasgo Saúde 2026 - Subpages Design System
 * Folha de estilo isolada para aplicar tipografia, cores e layout premium
 * em todas as subpáginas institucionais de forma unificada e responsiva.
 */

:root {
  /* Paleta de Cores Oficial - Figma 2026 */
  --verde-cerrado: #007940;
  --lima-goia: #C5E838;
  --areia-caldas: #F3EEE4;
  --verde-araguaia: #6EB02E;
  --amarelo-ipe: #E7C221;
  --luz-planalto: #EFE98C;
  --chumbo-serra: #2F302A;

  /* Escala Tipográfica Fluida (clamp) */
  --font-size-hero: clamp(48px, 7vw, 128px);
  --font-size-title: clamp(32px, 4.5vw, 65px);
  --font-size-subtitle: clamp(24px, 3vw, 45px);
  --font-size-topic: clamp(18px, 2vw, 30px);
  --font-size-body: clamp(15px, 1.2vw, 18px);
  --font-size-note: clamp(11px, 1vw, 14px);
}

/* Escopo para o Layout de Subpáginas */
.subpage-layout {
  background-color: var(--areia-caldas) !important;
  color: var(--chumbo-serra) !important;
  font-family: 'GeneralSans-Variable', 'GeneralSans-Regular', sans-serif !important;
}

/* 1. Cabeçalho de Título de Página e Breadcrumbs Premium */
.subpage-layout .page-title {
  background-color: var(--lima-goia) !important; /* Fundo Verde-Limão oficial conforme Figma */
  padding: 50px 0 !important; /* Altura compacta perfeita e fiel ao Figma */
  border-bottom: none !important; /* Remove a borda que não existe no Figma */
  position: relative;
  overflow: hidden;
}

/* Container de subpágina alinhado em left: 188px no desktop de acordo com o Figma */
@media (min-width: 1200px) {
  .subpage-layout .page-title .container {
    max-width: 100% !important;
    padding-left: 188px !important; /* Métrica exata left: 188px do Figma */
    padding-right: 40px !important;
  }
}
@media (min-width: 992px) and (max-width: 1199px) {
  .subpage-layout .page-title .container {
    max-width: 100% !important;
    padding-left: 80px !important;
    padding-right: 40px !important;
  }
}
@media (max-width: 991px) {
  .subpage-layout .page-title .container {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
}

/* Efeito orgânico de fundo no título (sem usar mesh clichê) */
.subpage-layout .page-title::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -20%;
  width: 600px;
  height: 600px;
  background-color: var(--verde-cerrado);
  opacity: 0.08; /* Mais sutil sobre o fundo verde-limão */
  border-radius: 50%;
  pointer-events: none;
}

/* Container do título e breadcrumb alinhados à esquerda e com ordem invertida visualmente */
.subpage-layout .page-title .text-center,
.subpage-layout .page-title [class*="col-"] {
  text-align: left !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  justify-content: center !important;
}

.subpage-layout .page-title nav.breadcrumbs {
  order: 1 !important; /* Força o nav do breadcrumb a ir para o topo */
  width: 100% !important;
  max-width: 493px !important; /* Mantém a largura de 493px do Figma */
  margin-bottom: 0 !important;
}

.subpage-layout .page-title h2.title {
  font-family: 'GeneralSans-Variable', 'GeneralSans-Regular', sans-serif !important;
  font-size: 32px !important; /* Tamanho de fonte exato de 32px do Figma */
  font-weight: 600 !important; /* Peso Semibold 600 exato do Figma */
  color: var(--chumbo-serra) !important; /* Cor #2F302A solicitada pelo usuário */
  line-height: 100% !important; /* Line height de 100% exato do Figma */
  letter-spacing: 0% !important; /* Letter spacing de 0% exato do Figma */
  max-width: 493px !important; /* Largura exata de 493px do Figma */
  width: 100% !important;
  margin-top: 6px !important; /* Espaçamento coladinho aos breadcrumbs */
  margin-bottom: 0 !important;
  text-transform: none !important;
  order: 2 !important; /* Título vem abaixo */
}

.subpage-layout .page-title h2.title span {
  color: var(--chumbo-serra) !important;
}

/* Breadcrumbs Elegantes Alinhados à Esquerda no Topo */
.subpage-layout .breadcrumbs {
  font-family: 'GeneralSans-Variable', 'GeneralSans-Regular', sans-serif !important;
  font-size: 13px !important; /* Tamanho reduzido super delicado */
  font-weight: 500 !important;
  color: var(--verde-cerrado) !important; /* Texto em Verde Cerrado */
  opacity: 0.85 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important; /* Alinhado à esquerda! */
  flex-wrap: wrap !important;
  gap: 8px !important;
}

.subpage-layout .breadcrumbs a {
  color: var(--verde-cerrado) !important;
  text-decoration: none !important;
  transition: color 0.2s ease !important;
}

.subpage-layout .breadcrumbs a:hover {
  color: var(--chumbo-serra) !important;
}

.subpage-layout .breadcrumbs span.active,
.subpage-layout .breadcrumbs span.active span {
  color: var(--verde-cerrado) !important;
  font-weight: 600 !important;
}

.subpage-layout .breadcrumbs span,
.subpage-layout .breadcrumbs span span,
.subpage-layout .breadcrumbs i {
  color: var(--verde-cerrado) !important;
}

/* Forçar o caractere '>' em vez do ícone de seta do FontAwesome */
.subpage-layout .breadcrumbs i.fa-angle-right::before {
  content: ">" !important;
  font-family: 'GeneralSans-Variable', sans-serif !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: var(--verde-cerrado) !important;
}

.subpage-layout .breadcrumbs i {
  color: var(--verde-cerrado) !important;
  font-size: 11px !important;
}

/* 2. Conteúdo Principal das Subpáginas */
.subpage-layout .main-content-section {
  padding: 80px 0 !important;
  background-color: var(--areia-caldas) !important;
}

/* Corpo de texto e elementos de bloco */
.subpage-layout .subpage-content {
  font-size: var(--font-size-body) !important;
  line-height: 1.65 !important;
  font-weight: 400 !important;
  color: var(--chumbo-serra) !important;
}

.subpage-layout .subpage-content p {
  margin-bottom: 25px !important;
  color: var(--chumbo-serra) !important;
}

/* Estilização de Títulos e Tópicos no Conteúdo */
.subpage-layout .subpage-content h1 {
  font-size: var(--font-size-title) !important;
  font-weight: 600 !important;
  color: var(--verde-cerrado) !important;
  margin-bottom: 30px !important;
  line-height: 1.2 !important;
}

.subpage-layout .subpage-content h2 {
  font-size: var(--font-size-subtitle) !important;
  font-weight: 600 !important;
  color: var(--verde-cerrado) !important;
  margin-top: 40px !important;
  margin-bottom: 25px !important;
  line-height: 1.25 !important;
}

.subpage-layout .subpage-content h3 {
  font-size: var(--font-size-topic) !important;
  font-weight: 600 !important;
  color: var(--verde-araguaia) !important;
  margin-top: 35px !important;
  margin-bottom: 20px !important;
}

.subpage-layout .subpage-content h4,
.subpage-layout .subpage-content h5 {
  font-size: 20px !important;
  font-weight: 600 !important;
  color: var(--chumbo-serra) !important;
  margin-top: 30px !important;
  margin-bottom: 15px !important;
}

/* Links do corpo de texto */
.subpage-layout .subpage-content a:not(.btn) {
  color: var(--verde-cerrado) !important;
  font-weight: 600 !important;
  text-decoration: underline !important;
  text-decoration-thickness: 1.5px !important;
  text-underline-offset: 4px !important;
  transition: color 0.2s ease, text-decoration-color 0.2s ease !important;
}

.subpage-layout .subpage-content a:not(.btn):hover {
  color: var(--verde-araguaia) !important;
  text-decoration-color: var(--lima-goia) !important;
}

/* 3. Listas Organizadas e Elegantes */
.subpage-layout .subpage-content ul,
.subpage-layout .subpage-content ol {
  margin-bottom: 30px !important;
  padding-left: 20px !important;
}

.subpage-layout .subpage-content li {
  margin-bottom: 12px !important;
  position: relative !important;
  line-height: 1.6 !important;
}

.subpage-layout .subpage-content ul li {
  list-style: none !important;
  padding-left: 20px !important;
}

.subpage-layout .subpage-content ul li::before {
  content: '✓';
  position: absolute;
  left: 0;
  top: 0;
  color: var(--verde-cerrado);
  font-weight: 800;
  font-size: 14px;
}

/* 4. Tabelas Institucionais Premium */
.subpage-layout .subpage-content table {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  margin: 40px 0 !important;
  border-radius: 25px !important;
  overflow: hidden !important;
  border: 1.5px solid var(--verde-cerrado) !important;
  background-color: #FFF !important;
  box-shadow: 0 8px 20px rgba(0, 121, 64, 0.04) !important;
}

.subpage-layout .subpage-content table th {
  background-color: var(--verde-cerrado) !important;
  color: var(--areia-caldas) !important;
  font-weight: 600 !important;
  font-size: 16px !important;
  padding: 16px 20px !important;
  text-align: left !important;
  border: none !important;
}

.subpage-layout .subpage-content table td {
  padding: 15px 20px !important;
  font-size: 15px !important;
  color: var(--chumbo-serra) !important;
  border-bottom: 1px solid rgba(0, 121, 64, 0.08) !important;
  border-top: none !important;
  background-color: transparent !important;
}

.subpage-layout .subpage-content table tr:last-child td {
  border-bottom: none !important;
}

.subpage-layout .subpage-content table tr:nth-child(even) td {
  background-color: rgba(243, 238, 228, 0.4) !important;
}

/* Hover premium na linha da tabela */
.subpage-layout .subpage-content table tr:hover td {
  background-color: rgba(197, 232, 56, 0.15) !important;
  transition: background-color 0.2s ease !important;
}

/* 5. Caixa de Alertas e Destaques */
.subpage-layout .subpage-content blockquote,
.subpage-layout .subpage-content .alert {
  background-color: var(--areia-caldas) !important;
  border: none !important;
  border-left: 6px solid var(--lima-goia) !important;
  border-radius: 4px 25px 25px 4px !important;
  padding: 25px !important;
  margin: 35px 0 !important;
  color: var(--chumbo-serra) !important;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.02) !important;
}

.subpage-layout .subpage-content blockquote p,
.subpage-layout .subpage-content .alert p {
  margin-bottom: 0 !important;
  font-style: italic !important;
  font-weight: 500 !important;
  color: var(--verde-cerrado) !important;
}

/* 6. Botões e Ações Premium */
.subpage-layout .btn,
.subpage-layout .btn-theme-colored {
  border-radius: 25px !important;
  font-family: 'GeneralSans-Variable', 'GeneralSans-Regular', sans-serif !important;
  font-weight: 600 !important;
  padding: 12px 30px !important;
  font-size: 15px !important;
  transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), box-shadow 0.3s ease, background-color 0.3s ease, color 0.3s ease !important;
  border: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
}

/* Botão Verde Cerrado (Padrão Principal) */
.subpage-layout .btn-primary,
.subpage-layout .btn-theme-colored {
  background-color: var(--verde-cerrado) !important;
  color: var(--areia-caldas) !important;
  box-shadow: 0 4px 10px rgba(0, 121, 64, 0.15) !important;
}

.subpage-layout .btn-primary:hover,
.subpage-layout .btn-theme-colored:hover {
  background-color: var(--verde-araguaia) !important;
  transform: translateY(-3px) scale(1.02) !important;
  box-shadow: 0 10px 20px rgba(110, 176, 46, 0.3) !important;
}

/* Botão Lima Goiá (Secundário/Destaque) */
.subpage-layout .btn-accent {
  background-color: var(--lima-goia) !important;
  color: var(--verde-cerrado) !important;
  box-shadow: 0 4px 10px rgba(197, 232, 56, 0.2) !important;
}

.subpage-layout .btn-accent:hover {
  background-color: var(--verde-araguaia) !important;
  color: var(--areia-caldas) !important;
  transform: translateY(-3px) scale(1.02) !important;
  box-shadow: 0 10px 20px rgba(110, 176, 46, 0.3) !important;
}

/* Responsividade de Spacers e Containers nas Subpáginas */
@media (max-width: 767px) {
  .subpage-layout .page-title {
    padding: 40px 0 45px 0 !important;
  }
  .subpage-layout .main-content-section {
    padding: 40px 0 !important;
  }
  .subpage-layout .subpage-content table {
    display: block !important;
    overflow-x: auto !important;
    border-radius: 15px !important;
  }
  .subpage-layout .subpage-content table th,
  .subpage-layout .subpage-content table td {
    padding: 12px 14px !important;
  }
}
