/* ============================================================
   ARCO FISCAL — ABOUT PAGE
   css/pages/about.css
   ============================================================ */


/* ------------------------------------------------------------
   1. HERO SPLIT
   ------------------------------------------------------------ */
.sobre-hero {
  display: flex;
  flex-direction: column;
  min-height: 65svh;
}

.sobre-hero-left {
  background: var(--cream3);
  display: flex;
  flex-direction: column;
  align-items: flex-start;       /* evita encolhimento do wrapper */
  justify-content: center;
  padding: calc(var(--nav-height) + var(--space-8)) var(--gutter-mobile) var(--space-8);
  flex: 1;
  min-height: 100svh;
}

.sobre-hero-right {
  background: var(--black);
  min-height: 200px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

/* Corner marks */
.sobre-hero-right::before {
  content: '';
  position: absolute;
  top: var(--space-6);
  left: var(--space-6);
  width: 24px;
  height: 24px;
  border-top: 1px solid rgba(236, 227, 220, 0.2);
  border-left: 1px solid rgba(236, 227, 220, 0.2);
}

.sobre-hero-right::after {
  content: '';
  position: absolute;
  bottom: var(--space-6);
  right: var(--space-6);
  width: 24px;
  height: 24px;
  border-bottom: 1px solid rgba(236, 227, 220, 0.2);
  border-right: 1px solid rgba(236, 227, 220, 0.2);
}

@media (min-width: 1024px) {
  .sobre-hero {
    flex-direction: row;
    min-height: 60svh;
  }

  .sobre-hero-left {
    align-items: flex-start;
    padding: calc(var(--nav-height) + var(--space-8)) var(--gutter-desktop) var(--space-8);
    width: 58%;
    min-height: unset;
  }

  .sobre-hero-right {
    width: 42%;
    min-height: auto;
  }

  .sobre-hero-right::before {
    top: var(--space-8);
    left: var(--space-8);
    width: 32px;
    height: 32px;
  }

  .sobre-hero-right::after {
    bottom: var(--space-8);
    right: var(--space-8);
    width: 32px;
    height: 32px;
  }
}

/* Bloco de conteúdo centrado dentro do painel cream */
.sobre-hero-content-wrap {
  max-width: 560px;
  width: 100%;
  margin-inline: auto;   /* centra horizontalmente sem encolher */
}

/* H1 mais contido — o painel tem 58% da largura */
.sobre-hero h1 {
  font-size: clamp(2.2rem, 4vw, 5rem);
  margin-bottom: var(--space-6);
}

.sobre-hero .eyebrow {
  margin-bottom: var(--space-5);
}

.sobre-hero h1 {
  margin-bottom: var(--space-6);
}

.sobre-hero h1 em {
  color: var(--taupe);
}

.sobre-hero-sub {
  max-width: 480px;
  color: var(--text-secondary);
}

.sobre-hero-visual {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-6);
  padding: var(--space-12) var(--space-8);
  min-height: 200px;
  text-align: center;
}

.sobre-hero-monogram {
  width: 52%;
  max-width: 160px;
  height: auto;
  opacity: 0.55;
  user-select: none;
}

/* Texto sob o monograma */
.sobre-hero-caption {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  align-items: center;
}

.sobre-hero-caption-name {
  font-family: var(--font-display);
  font-size: clamp(0.85rem, 1.2vw, 1.1rem);
  font-weight: var(--weight-regular);
  color: var(--cream);
  opacity: 0.65;
  letter-spacing: var(--tracking-wide);
}

.sobre-hero-caption-year {
  font-family: var(--font-mono);
  font-size: 0.44rem;
  letter-spacing: var(--tracking-ultra);
  text-transform: uppercase;
  color: var(--taupe);
  opacity: 0.5;
}


/* ------------------------------------------------------------
   2. HISTÓRIA
   ------------------------------------------------------------ */
.sobre-historia {
  padding: var(--section-lg) 0;
  background: var(--cream);
  border-top: 1px solid var(--border-light);
}

.historia-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-16);
}

@media (min-width: 1024px) {
  .historia-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-20);
    align-items: start;
  }
}

.historia-content .eyebrow {
  margin-bottom: var(--space-5);
}

.historia-content h2 {
  margin-bottom: var(--space-8);
}

.historia-content p {
  color: var(--text-secondary);
  margin-bottom: var(--space-5);
  line-height: var(--leading-relaxed);
}

.historia-content p:last-child {
  margin-bottom: 0;
}

/* Linha do tempo */
.timeline {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-left: 1px solid var(--border-light);
  padding-left: var(--space-8);
  margin-left: var(--space-4);
}

.timeline-item {
  position: relative;
  padding-bottom: var(--space-8);
}

.timeline-item::before {
  content: '';
  position: absolute;
  left: calc(-1 * var(--space-8) - 4px);
  top: 6px;
  width: 7px;
  height: 7px;
  background: var(--taupe);
  opacity: 0.4;
}

.timeline-item:last-child {
  padding-bottom: 0;
}

.timeline-year {
  font-family: var(--font-mono);
  font-size: 0.44rem;
  letter-spacing: var(--tracking-ultra);
  text-transform: uppercase;
  color: var(--taupe);
  opacity: 0.5;
  margin-bottom: var(--space-2);
}

.timeline-text {
  font-family: var(--font-serif);
  font-size: var(--text-body);
  font-weight: var(--weight-light);
  color: var(--text-secondary);
  line-height: var(--leading-snug);
}


/* ------------------------------------------------------------
   3. VALORES
   ------------------------------------------------------------ */
.sobre-valores {
  padding: var(--section-lg) 0;
  background: var(--cream2);
  border-top: 1px solid var(--border-light);
}

.valores-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1px;
  background: var(--border-light);
  margin-top: var(--space-12);
}

@media (min-width: 640px) {
  .valores-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.valor-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding: var(--space-10) var(--space-8);
  background: var(--cream2);
}

.valor-display {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3.5rem);
  font-weight: var(--weight-regular);
  color: var(--taupe);
  opacity: 0.25;
  line-height: 1;
}

.valor-title {
  font-family: var(--font-serif);
  font-size: clamp(1.2rem, 2vw, 1.6rem);
  font-weight: var(--weight-light);
  color: var(--text-primary);
}

.valor-desc {
  font-size: var(--text-body-sm);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
}

@media (min-width: 1024px) {
  .valor-card {
    padding: var(--space-12) var(--space-10);
  }
}


/* ------------------------------------------------------------
   4. NÚMEROS
   ------------------------------------------------------------ */
.sobre-numeros {
  padding: var(--section-md) 0;
  background: var(--black);
  border-top: 1px solid rgba(236, 227, 220, 0.08);
}

.numeros-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: rgba(236, 227, 220, 0.08);
}

@media (min-width: 640px) {
  .numeros-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.numero-item {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-10) var(--space-8);
}

.numero-valor {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 4vw, 3.5rem);
  font-weight: var(--weight-light);
  color: var(--cream);
  line-height: 1;
  letter-spacing: var(--tracking-tight);
}

.numero-label {
  font-family: var(--font-mono);
  font-size: 0.48rem;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--taupe);
  opacity: 0.7;
}

@media (min-width: 1024px) {
  .numero-item {
    padding: var(--space-12) var(--space-10);
  }
}


/* ------------------------------------------------------------
   5. EQUIPA
   ------------------------------------------------------------ */
.sobre-equipa {
  padding: var(--section-lg) 0;
  background: var(--cream3);
}

.equipa-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  margin-top: var(--space-12);
}

@media (min-width: 640px) {
  .equipa-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .equipa-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.membro-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.membro-foto {
  aspect-ratio: 4 / 5;
  background: var(--brown);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.membro-foto img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.membro-foto-placeholder {
  width: 60%;
  max-width: 100px;
  height: auto;
  opacity: 0.15;
}

.membro-nome {
  font-family: var(--font-serif);
  font-size: clamp(1.1rem, 1.8vw, 1.4rem);
  font-weight: var(--weight-light);
  color: var(--text-primary);
}

.membro-cargo {
  font-family: var(--font-mono);
  font-size: 0.48rem;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--text-secondary);
  opacity: 0.6;
}

.membro-bio {
  font-size: var(--text-body-sm);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
}


/* ------------------------------------------------------------
   6. CERTIFICAÇÕES
   ------------------------------------------------------------ */
.sobre-certs {
  padding: var(--section-md) 0;
  background: var(--cream);
  border-top: 1px solid var(--border-light);
}

.certs-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-8);
  align-items: center;
  margin-top: var(--space-10);
}

.cert-item {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-6) var(--space-8);
  border: 1px solid var(--border-light);
  min-width: 160px;
}

.cert-label {
  font-family: var(--font-display);
  font-size: clamp(1rem, 1.5vw, 1.3rem);
  font-weight: var(--weight-regular);
  color: var(--text-primary);
  letter-spacing: var(--tracking-wide);
}

.cert-desc {
  font-family: var(--font-mono);
  font-size: 0.44rem;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--text-secondary);
  opacity: 0.5;
}


/* ------------------------------------------------------------
   7. LOCALIZAÇÃO
   ------------------------------------------------------------ */
.sobre-localizacao {
  padding: var(--section-md) 0;
  background: var(--cream2);
  border-top: 1px solid var(--border-light);
}

.localizacao-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
}

@media (min-width: 640px) {
  .localizacao-grid {
    grid-template-columns: 1fr 2fr;
    align-items: start;
    gap: var(--space-16);
  }
}

.localizacao-info .eyebrow {
  margin-bottom: var(--space-5);
}

.localizacao-info h2 {
  font-size: clamp(1.4rem, 2.5vw, 2.5rem);
  margin-bottom: var(--space-6);
}

.localizacao-address {
  font-style: normal;
  font-family: var(--font-serif);
  font-weight: var(--weight-light);
  color: var(--text-secondary);
  line-height: 1.9;
  margin-bottom: var(--space-6);
}

.localizacao-horario {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-top: var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px solid var(--border-light);
}

.horario-note {
  font-family: var(--font-mono);
  font-size: 0.44rem;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--taupe);
  opacity: 0.65;
  line-height: 1.7;
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--border-light);
  font-style: italic;
}

.horario-line {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 0.48rem;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
}

.horario-line .dia {
  color: var(--text-secondary);
  opacity: 0.55;
}

.horario-line .hora {
  color: var(--text-body);
}
