/* ==========================================================================
   Les Saveurs du Douro — sobre.css
   Estilos específicos da página /sobre (Template Name: Sobre Nós).
   Carregado por inc/enqueue.php apenas quando is_page_template('page-sobre.php').
   ========================================================================== */

.sobre {
  background: var(--c-bg);
}

/* --------------------------------------------------------------------------
   1. Hero — paisagem com overlay
   -------------------------------------------------------------------------- */
.sobre-hero {
  position: relative;
  height: 268px;
  color: var(--c-cream);
  overflow: hidden;
  isolation: isolate;
}
.sobre-hero__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
}
.sobre-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 42%;
}
.sobre-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    var(--c-olive-dark) 0%,
    rgba(42, 42, 38, 0.55) 60%,
    rgba(42, 42, 38, 0.1) 100%
  );
}
.sobre-hero__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-6);
  height: 100%;
  padding-block: 80px var(--sp-5);
}
.sobre-hero__title {
  font-family: var(--ff-serif);
  font-size: clamp(1.75rem, 1.2rem + 1.6vw, 2.5rem);
  color: var(--c-cream);
  margin: 0;
  font-weight: 400;
  letter-spacing: 0.02em;
}
.sobre-hero__intro {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  max-width: 291px;
}
.sobre-hero__intro-icon {
  flex-shrink: 0;
}
.sobre-hero__intro-text {
  font-family: var(--ff-serif);
  font-size: 14px;
  line-height: 1.3;
  color: var(--c-cream);
  margin: 0;
  font-weight: 600;
}

/* Decoração SVG do hero (Group 226 — ramos curvos com paleta multi-cor do Figma).
   NÃO sobrepor `color` aqui: o SVG carrega com `preserve_colors=true` e usa
   os hex originais (#0A0A04, #5D5F31, #6D6848, #929072, #B2A567, #C4C4B7). */
.sobre-hero__deco {
  position: absolute;
  left: -84px;
  bottom: -10px;
  width: 352px;
  height: 224px;
  pointer-events: none;
  z-index: 0;
}
.sobre-hero__deco svg { width: 100%; height: 100%; }
.sobre-hero__inner { position: relative; z-index: 1; }

/* Ícone branco no intro do hero — usa `sobre-poem-white__icon.svg`
   (já vem com fill #F4F1EA do Figma). Sem override de cor. */
.sobre-hero__intro-icon svg { width: 24px; height: 24px; display: block; }

/* --------------------------------------------------------------------------
   2. Sections "Sobre o mel / azeite / vinho"
   -------------------------------------------------------------------------- */
.sobre-story {
  padding-block: 80px;
}
.sobre-story--azeite,
.sobre-story--vinho {
  background: var(--c-bg-warm); /* #efeadd */
  border-top: 1px solid var(--c-olive-dark);
}
.sobre-story__grid {
  display: grid;
  grid-template-columns: 592px 592px;
  gap: 32px;
  align-items: center;
  justify-content: center;
}
.sobre-story--reversed .sobre-story__grid {
  direction: ltr;
}
.sobre-story__text {
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.sobre-story__title {
  font-family: var(--ff-serif);
  font-size: 56px;
  font-weight: 400;
  line-height: 1.3;
  letter-spacing: -0.58px;
  color: var(--c-ink);
  margin: 0;
}
.sobre-story__intro {
  font-family: var(--ff-sans);
  font-size: 14px;
  line-height: 24px;
  color: var(--c-ink-soft);
  margin: 0;
}
.sobre-story__poem {
  font-family: var(--ff-sans);
  font-size: 14px;
  line-height: 24px;
  color: var(--c-ink-soft);
}
.sobre-story__poem p {
  margin: 0 0 24px;
}
.sobre-story__poem p:last-child {
  margin-bottom: 0;
}

.sobre-story__media {
  margin: 0;
  width: 592px;
  height: 592px;
  overflow: hidden;
  border-radius: 2px;
  box-shadow:
    3px 3px 5px rgba(0, 0, 0, 0.1),
    12px 13px 9px rgba(0, 0, 0, 0.09),
    28px 29px 12px rgba(0, 0, 0, 0.05),
    49px 51px 14px rgba(0, 0, 0, 0.01);
}
.sobre-story__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* --------------------------------------------------------------------------
   3. Princípios — bloco escuro com onda
   -------------------------------------------------------------------------- */
.sobre-principios {
  position: relative;
  background: var(--c-olive-dark); /* #2a2a26 */
  color: var(--c-cream);
  overflow: hidden;
  padding-block: 80px;
  border-top: 1px solid var(--c-olive-dark);
}
.sobre-principios__wave {
  position: absolute;
  left: -225px;
  top: 52px;
  width: 1889px;
  height: 833px;
  color: var(--c-cream);
  pointer-events: none;
  opacity: 0.5;
  z-index: 0;
  display: block;
}
.sobre-principios__wave svg { width: 100%; height: 100%; display: block; }
.sobre-principios__inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 64px;
}
.sobre-principios__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-6);
}
.sobre-principios__title {
  font-family: var(--ff-serif);
  font-size: 56px;
  font-weight: 400;
  color: var(--c-white);
  margin: 0;
  letter-spacing: -0.58px;
  line-height: 1.3;
}
.sobre-principios__title span {
  color: var(--c-olive);
}
.sobre-principios__lead {
  font-family: var(--ff-sans);
  font-size: 15px;
  line-height: 24px;
  color: var(--c-bg-warm); /* #efeadd */
  max-width: 592px;
  margin: 0;
}
.sobre-principios__cols {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 384px));
  gap: 32px;
  justify-content: space-between;
}
.sobre-principios__col {
  border-top: 1px solid #777;
  padding-top: 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.sobre-principios__eyebrow {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: 1.1px;
  color: #bab5a7;
}
.sobre-principios__col-title {
  font-family: var(--ff-serif);
  font-size: 24px;
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: 1px;
  color: var(--c-white);
  margin: 0;
}

/* --------------------------------------------------------------------------
   4. Produtos — 3 cards com bg honeycomb
   -------------------------------------------------------------------------- */
.sobre-produtos {
  position: relative;
  padding-block: 90px;
  overflow: hidden;
  isolation: isolate;
  background: var(--c-bg);
}
.sobre-produtos__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
}
.sobre-produtos__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  mix-blend-mode: luminosity;
  opacity: 0.06;
}
.sobre-produtos__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 72px;
}
.sobre-produtos__title {
  font-family: var(--ff-serif);
  font-size: 56px;
  font-weight: 400;
  line-height: 1.3;
  letter-spacing: -0.58px;
  color: var(--c-ink);
  margin: 0;
  text-align: center;
}
.sobre-produtos__grid {
  display: grid;
  grid-template-columns: repeat(3, 382px);
  gap: 37px;
  width: 100%;
  justify-content: center;
}
.sobre-produtos__card {
  position: relative;
  height: 491px;
  overflow: hidden;
  display: block;
  color: var(--c-ink);
  transition: transform 0.35s var(--ease);
}
.sobre-produtos__card:hover {
  transform: translateY(-3px);
}
.sobre-produtos__media {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.sobre-produtos__overlay {
  position: absolute;
  inset: 0;
  background: rgba(42, 42, 38, 0.25);
  transition: background 0.35s var(--ease);
}
.sobre-produtos__card:hover .sobre-produtos__overlay {
  background: rgba(42, 42, 38, 0.4);
}
.sobre-produtos__label {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: var(--ff-serif);
  font-size: 48px;
  color: var(--c-ink);
  letter-spacing: -0.58px;
  line-height: 1.3;
  white-space: nowrap;
  z-index: 1;
}

/* --------------------------------------------------------------------------
   5. Poema final — bloco centrado
   -------------------------------------------------------------------------- */
.sobre-poem {
  background: var(--c-bg-warm); /* #efeadd */
  border-top: 1px solid var(--c-olive-dark);
  padding-block: 80px;
}
.sobre-poem__inner {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 16px;
  max-width: 600px;
  margin-inline: auto;
}
/* Ícone do poema final — `sobre-poem-icon.svg` vem com cor original do Figma
   (#2A2A26 + white). Sem override de cor via CSS. */
.sobre-poem__icon {
  flex-shrink: 0;
  margin-top: 6px;
  width: 40px;
  height: 40px;
  display: inline-block;
}
.sobre-poem__icon svg {
  width: 40px;
  height: 40px;
  display: block;
}
.sobre-poem__text {
  font-family: var(--ff-serif);
  font-weight: 600;
  font-size: 24px;
  line-height: 1.3;
  color: var(--c-ink);
  letter-spacing: -0.58px;
}
.sobre-poem__text p {
  margin: 0 0 24px;
}
.sobre-poem__text p:last-child {
  margin-bottom: 0;
}

.sobre__extra {
  padding-block: 80px;
}

/* --------------------------------------------------------------------------
   6. Responsive
   -------------------------------------------------------------------------- */
@media (max-width: 1024px) {
  .sobre-story__grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .sobre-story__media {
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
  }
  .sobre-story--reversed .sobre-story__media {
    order: -1;
  }
  .sobre-story__title {
    font-size: clamp(2rem, 5vw, 3rem);
  }
  .sobre-principios__cols {
    grid-template-columns: 1fr;
  }
  .sobre-principios__head {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--sp-4);
  }
  .sobre-principios__title {
    font-size: clamp(2rem, 5vw, 3rem);
  }
  .sobre-produtos__grid {
    grid-template-columns: repeat(2, 1fr);
    max-width: 800px;
  }
  .sobre-produtos__title {
    font-size: clamp(2rem, 5vw, 3rem);
  }
  .sobre-hero {
    height: auto;
    min-height: 240px;
  }
  .sobre-hero__inner {
    flex-direction: column;
    align-items: flex-start;
    padding-block: 60px var(--sp-4);
  }
  .sobre-poem__text {
    font-size: 18px;
  }
}

@media (max-width: 640px) {
  .sobre-produtos__grid {
    grid-template-columns: 1fr;
    max-width: 400px;
  }
  .sobre-produtos__card {
    height: 360px;
  }
  .sobre-produtos__label {
    font-size: 36px;
  }
  .sobre-poem__inner {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
}
