/* =========================================================
   PÁGINA QUEM SOMOS - ESTRUTURA CODEPEN + LIGHT THEME FIGMA
   ========================================================= */

p {
  margin: 0;
}

.page-quem-somos {
  color: #111827;
  background-color: #FAFAFA; /* Fundo geral claro */
}

/* Restaurei o limitador do CodePen em vez de "margin: 0 10%" 
   para garantir que a grelha não quebra em ecrãs gigantes */
.container {
  margin: 0 10%;
  padding: 44px 0 18px 0;
}

/* =========================================================
   BLOCO 1: HERO
   ========================================================= */
.hero-qs .hero-inner {
  position: relative;
  display: grid;
  /* Proporção exata do CodePen */
  grid-template-columns: 1.35fr 0.65fr; 
  gap: 24px;
  align-items: stretch;
  border: 1px solid rgba(234, 240, 255, .14);
  box-shadow: 0 14px 40px rgba(0, 0, 0, .40);
  border-radius: 24px;
  background-image: linear-gradient(135deg, #1A0B2E 0%, #0B1B4D 50%, #063170 100%);
  padding: 34px 28px;
}

.hero-qs .hero-left {
  padding: 10px 10px 6px 10px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-right: 1px solid rgba(234, 240, 255, 0.14); /* Divisória subtil */
}

/* Kicker (Pílula superior) */
.hero-qs .kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  color: rgba(234, 240, 255, .86);
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(234, 240, 255, .16);
  background: rgba(234, 240, 255, .06);
  width: fit-content;
  margin-bottom: 14px;
}

.hero-qs .kicker .dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: #24DBFF; /* Ponto ciano */
}

/* Tipografia Esquerda */
.hero-qs h1 {
  font-size: 44px; /* Ajustado para a proporção do CodePen */
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.05;
  margin: 0 0 12px 0;
  color: #FFFFFF;
}

.hero-qs h1 .highlight-cyan {
  color: #24DBFF;
  display: inline-block;
}

.hero-qs .hero-sub {
  font-size: 16px;
  line-height: 1.55;
  color: rgba(234, 240, 255, .82);
  margin-bottom: 16px;
  max-width: 58ch;
}

/* Grid de Bullets 2x2 */
.hero-qs .hero-bullets {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 14px;
  list-style: none;
  padding: 0;
  margin: 6px 0 18px 0;
  max-width: 680px;
}

.hero-qs .hero-bullets li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: 14px; /* Reduzido levemente para caber na grelha */
  color: rgba(234, 240, 255, .86);
  font-weight: 500;
  line-height: 1.5;
  border: 1px solid rgba(234, 240, 255, .10);
  border-radius: 14px;
  padding: 10px 12px;
  background: rgba(234, 240, 255, .04);
}

.hero-qs .hero-bullets .check {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  background-color: rgba(100,255,182,.18);
  border: 1px solid rgba(100,255,182,.26);
  border-radius: 8px;
  color: #FFFFFF;
  flex-shrink: 0;
  margin-top: 1px;
}

.hero-qs .hero-bullets .check svg { width: 12px; height: 12px; }

/* Botões e Links Esquerda */
.hero-qs .hero-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.hero-qs .link-inline {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: rgba(234, 240, 255, .88);
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(234, 240, 255, .16);
  background: rgba(234, 240, 255, .04);
  text-decoration: none;
  font-size: 13px;
  font-weight: 600;
}

.btn.primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: 14px;
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  transition: all 0.2s ease;
  box-shadow: 0 8px 18px rgba(0, 0, 0, .22);
  color: #111827;
  border: 1px solid rgba(107, 228, 255, .38);
  background: linear-gradient(180deg, #6BE4FF, #24DBFF);
}

/* Cards da Direita */
.hero-qs .hero-right {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 12px 0 0 20px;
}

.hero-qs .hero-card {
  background: rgba(234, 240, 255, .04);
  border-radius: 18px;
  padding: 16px 14px;
  box-shadow: 0 10px 26px rgba(0,0,0,.34);
  border: 1px solid rgba(234, 240, 255, .16);
}

.hero-qs .hero-card h3 {
  margin: 0 0 8px 0;
  font-size: 13px;
  font-weight: 800;
  color: rgba(234, 240, 255, .92);
  letter-spacing: .02em;
}

.hero-qs .card-wysiwyg p {
  font-size: 13px;
  color: rgba(234, 240, 255, .86);
  margin-bottom: 10px;
  line-height: 1.4;
}

.hero-qs .card-wysiwyg ul {
  list-style: none;
  padding: 0;
  margin: 10px 0 0 0;
  display: grid;
  gap: 8px;
}

.hero-qs .card-wysiwyg ul li {
  position: relative;
  display: flex; 
  gap: 8px; 
  align-items: flex-start;
  font-size: 12.5px;
  color: rgba(234, 240, 255, .76);
}

.hero-qs .card-wysiwyg ul li::before {
  content: "";
  display: block;
  width: 6px; 
  height: 6px; 
  border-radius: 50%;
  background: rgba(234, 240, 255, .40);
  margin-top: 6px;
  flex: 0 0 auto;
}

/* =========================================================
   BLOCO 2: SEÇÃO 1 (TRÊS COLUNAS)
   ========================================================= */
.qs-section-1 {
  padding: 18px 0 26px 0;
}

.qs-panel-1 {
  padding: 26px 22px;
  border: 1px solid #E5E7EB;
  border-radius: 24px;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.02);
  background: #FFFFFF;
}

.qs-section-1 .section-head {
  display: flex; 
  align-items: flex-end; 
  justify-content: space-between; 
  gap: 16px; 
  margin-bottom: 16px;
}

.qs-section-1 .section-head h2 {
  font-size: 28px;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0;
}

/* Grid das 3 Colunas Principais (1fr 1fr 1.2fr) */
.triple-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1.2fr;
  gap: 14px;
  align-items: stretch;
}

.sec1-card {
  display: flex;
  flex-direction: column;
  border-radius: 18px;
  border: 1px solid #E5E7EB;
  padding: 16px 14px;
  background: #F9FAFB;
  position: relative;
  overflow: hidden;
  min-height: 160px;
}

.sec1-card h3 {
  font-size: 14px;
  font-weight: 800;
  margin-bottom: 8px;
  color: #111827;
}

.sec1-card > p {
  font-size: 13px;
  line-height: 1.5;
  color: #4B5563;
  margin: 0;
}

/* Imagens (Missão e Visão) */
.sec1-card.has-img-fill .img-slot {
  margin-top: 12px;
  border-radius: 16px;
  border: 1px solid #E5E7EB;
  height: 276px; /* Altura exata do CodePen */
  position: relative;
  overflow: hidden;
}

.sec1-card.has-img-fill .img-slot img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.img-label {
  position: absolute;
  left: 10px; 
  bottom: 10px;
  font-size: 12px;
  color: #111827;
  background: rgba(255, 255, 255, 0.85); /* Fundo claro translúcido */
  border: 1px solid #E5E7EB;
  padding: 6px 8px;
  border-radius: 12px;
  backdrop-filter: blur(10px);
  font-weight: 700;
  z-index: 10;
}

/* =========================================================
   GRID DO CARD 3 (Valores - 2x2 com números gigantes)
   ========================================================= */
.values-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 10px;
}

.value-item {
  position: relative;
  padding: 14px 12px 12px 12px;
  border-radius: 16px;
  border: 1px solid #E5E7EB;
  background: #FFFFFF;
  overflow: hidden;
  min-height: 120px;
  display: flex;
  flex-direction: column;
}

/* O "Truque" do CodePen: Número gigante no fundo */
.value-item::before {
  content: attr(data-n); /* Puxa o número do HTML se você usar data-n="1" */
  position: absolute;
  top: -22px; right: 8px;
  font-size: 78px;
  font-weight: 800;
  letter-spacing: -.06em;
  color: #24daff2a; /* Cinza super claro para fundo branco */
  transform: rotate(7deg);
  pointer-events: none;
}

.value-item h4 {
  position: relative; 
  z-index: 1;
  font-size: 13px; 
  margin: 0 0 8px 0;
  color: #111827;
  letter-spacing: .01em;
}

.value-item p {
  position: relative; 
  z-index: 1;
  font-size: 12.5px; 
  margin: 0;
  color: #4B5563;
  line-height: 1.5;
}

/* O quinto valor (espanhado) */
.value-full {
  margin-top: 12px;
}

/* Faz com que o último item ocupe a linha inteira se a contagem total for ímpar (ex: 3, 5) */
.value-item:last-child:nth-child(odd) {
  grid-column: 1 / -1;
}

/* =========================================================
   RESPONSIVIDADE (Preservando as quebras originais)
   ========================================================= */
@media (max-width: 980px) {
  .hero-qs .hero-inner {
    grid-template-columns: 1fr;
    padding: 26px 18px;
  }
  .hero-qs .hero-left {
    border-right: none;
    padding: 0;
  }
  .hero-qs .hero-right {
    padding: 0;
  }
  .hero-qs h1 { font-size: 38px; }
  .triple-grid { grid-template-columns: 1fr; }
  .values-grid { grid-template-columns: 1fr 1fr; }
  .sec1-card.has-img-fill .img-slot { height: 160px; }
}

@media (max-width: 560px) {
  .hero-qs h1 { font-size: 34px; }
  .hero-qs .hero-bullets { grid-template-columns: 1fr; }
  .values-grid { grid-template-columns: 1fr; }
  .sec1-card.has-img-fill .img-slot { height: 170px; }
}