/* ============================================================
   PAGE · NOSOTROS — manifiesto, valores, testimonios (marquee), CTA + form
   (hero/slider → 05-hero.css · botones/formulario → 04-components.css · divider → 03-layout.css)
   ============================================================ */

/* === EYEBROW DE SECCIÓN === */
.section-eyebrow {
  font-size: 11px; font-weight: 400;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-dim);
  margin-bottom: 48px;
}

/* === MANIFIESTO === */
.manifesto {
  padding: 100px 40px;
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 80px;
}
.manifesto-num {
  font-family: var(--font-display);
  font-size: 11px; font-style: normal;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-dim); padding-top: 6px;
}
.manifesto-num small {
  display: block;
  font-family: var(--font-body);
  font-size: 10px; font-weight: 500;
  color: var(--gold); letter-spacing: 0.1em; margin-top: 6px;
}
.manifesto-content h2 {
  font-family: var(--font-display);
  font-size: clamp(34px, 3.5vw, 52px);
  line-height: 1.05; letter-spacing: -0.02em;
  margin-bottom: 40px;
}
.manifesto-content h2 em { font-style: italic; color: var(--gold); }
.manifesto-content h2 .strike { text-decoration: line-through; color: var(--ink-dim); }
.manifesto-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
}
.manifesto-p { font-size: 16px; line-height: 1.8; color: var(--ink-dim); }
.manifesto-p strong { color: var(--ink); }

/* === VALORES === */
.valores {
  padding: 100px 40px;
  max-width: 1200px;
  margin: 0 auto;
}
.valores-h {
  font-family: var(--font-display);
  font-size: clamp(34px, 3.5vw, 52px);
  line-height: 1.05; letter-spacing: -0.02em;
  margin-bottom: 64px;
}
.valores-h em { font-style: italic; color: var(--gold); }
.valores-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
}
.valor { background: var(--bg); padding: 48px 36px; transition: background 0.3s; }
.valor:hover { background: var(--bg2); }
.valor-num {
  font-size: 11px; letter-spacing: 0.12em;
  color: var(--gold); margin-bottom: 24px; font-weight: 700;
}
.valor h3 {
  font-family: var(--font-display);
  font-size: 24px; letter-spacing: -0.01em;
  margin-bottom: 16px;
}
.valor p { font-size: 14px; line-height: 1.8; color: var(--ink-dim); }

/* === TESTIMONIOS · Marquee infinito === */
.v2-testi { padding: 100px 0; overflow: hidden; }
.v2-head { max-width: 1200px; margin: 0 auto 56px; padding: 0 40px; }
.v2-head .section-eyebrow { margin-bottom: 20px; }
.v2-h {
  font-family: var(--font-display);
  font-size: clamp(34px, 3.5vw, 52px);
  line-height: 1.05; letter-spacing: -0.02em;
}
.v2-h em { font-style: italic; color: var(--gold); }
.v2-row { display: flex; gap: 20px; width: max-content; }
.v2-row.r1 { animation: v2scroll 60s linear infinite paused; }
.v2-row.r2 { animation: v2scroll 75s linear infinite reverse paused; margin-top: 20px; }
.v2-testi:hover .v2-row { animation-play-state: running; }
.v2-testi:has(.v2-card:hover) .v2-row { animation-play-state: paused; }
@keyframes v2scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.v2-card {
  flex: 0 0 380px;
  background: var(--bg2);
  border: 1px solid var(--border);
  padding: 30px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.v2-q { font-size: 15px; line-height: 1.6; color: var(--ink); }
.v2-foot { display: flex; align-items: center; gap: 12px; margin-top: auto; padding-top: 8px; }
.v2-av {
  width: 104px; height: 48px; border-radius: 10px;
  background: #fff; border: 1px solid var(--border-strong);
  display: flex; align-items: center; justify-content: center;
  flex: 0 0 auto; overflow: hidden; padding: 8px 12px;
}
.v2-av img { width: 100%; height: 100%; object-fit: contain; }
.v2-av img[src*="fluke"] { transform: scale(1.4); }
.v2-av img[src*="antun"] { transform: scale(1.35); }
.v2-name { font-family: var(--font-display); font-weight: 500; font-size: 14px; }
.v2-role { font-size: 12px; color: var(--ink-dim); }

/* === TIMELINE · TRAYECTORIA === */
.timeline-section {
  padding: 100px 40px;
  max-width: var(--max);
  margin: 0 auto;
}
.timeline-h {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--t-h2);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin-bottom: 64px;
}
.timeline-h em { font-style: italic; color: var(--gold); }
.timeline-list { border-top: 1px solid var(--border); }
.timeline-item {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 40px;
  padding: 36px 0;
  border-bottom: 1px solid var(--border);
  align-items: start;
  transition: background 0.2s;
}
.timeline-year {
  font-family: var(--font-display);
  font-size: 32px;
  color: var(--ink-faint);
  letter-spacing: -0.02em;
  line-height: 1;
  padding-top: 4px;
  transition: color 0.3s;
}
.timeline-item:hover .timeline-year { color: var(--gold); }
.timeline-content h3 {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin-bottom: 8px;
}
.timeline-content p { font-size: 14px; line-height: 1.7; color: var(--ink-dim); }

/* === CTA BANNER (con foto institucional + formulario) === */
.cta-banner {
  background: var(--bg3);
  border-top: 1px solid var(--border);
  padding: 100px 40px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta-bg-photo {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image: url('../../../img/contacto/contacto-01.jpg');
  background-size: cover; background-position: center;
  filter: grayscale(100%) contrast(1.1) brightness(0.62) sepia(0.85) hue-rotate(-15deg) saturate(2.2);
}
.cta-bg-overlay {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(ellipse at 30% 50%, rgba(10,10,10,0.25) 0%, rgba(10,10,10,0.7) 80%),
    linear-gradient(180deg, rgba(10,10,10,0.2) 0%, rgba(10,10,10,0.9) 100%);
}
.cta-banner-inner { position: relative; z-index: 1; }
.cta-banner h2 {
  font-family: var(--font-display);
  font-size: clamp(40px, 5vw, 72px);
  line-height: 1.0; letter-spacing: -0.02em;
  margin-bottom: 24px;
}
.cta-banner h2 em { font-style: italic; color: var(--gold); }
.cta-banner p {
  font-size: 17px; color: var(--ink-dim);
  max-width: 560px; margin: 0 auto 48px; line-height: 1.7;
}

/* === GALERÍA MASONRY === */
.portfolio-masonry-section {
  padding: 100px 40px;
  max-width: 1400px;
  margin: 0 auto;
}
.portfolio-masonry-head {
  margin-bottom: 56px;
}
.portfolio-masonry-h {
  font-family: var(--font-display);
  font-size: clamp(34px, 3.5vw, 52px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin-top: 16px;
}
.portfolio-masonry-h em { font-style: italic; color: var(--gold); }

.portfolio-masonry-grid {
  columns: 3;
  column-gap: 10px;
}
.pm-item {
  break-inside: avoid;
  margin-bottom: 10px;
  position: relative;
  overflow: hidden;
  display: block;
}
.pm-item img {
  width: 100%;
  display: block;
  transition: transform 0.45s var(--ease);
}
.pm-item:hover img { transform: scale(1.04); }
.pm-tag {
  position: absolute;
  bottom: 10px;
  left: 10px;
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #0a0a0a;
  background: var(--gold);
  padding: 4px 8px;
  line-height: 1;
  pointer-events: none;
}

/* === RESPONSIVE === */
@media (max-width: 900px) {
  .portfolio-masonry-grid { columns: 2; }
}
@media (max-width: 768px) {
  .manifesto { grid-template-columns: 1fr; gap: 32px; padding: 60px 20px; }
  .manifesto-body { grid-template-columns: 1fr; }
  .valores { padding: 60px 20px; }
  .valores-grid { grid-template-columns: 1fr; }
  .v2-testi { padding: 60px 0; }
  .v2-head { padding: 0 20px; }
  .v2-card { flex-basis: 300px; padding: 24px; }
  .timeline-section { padding: 60px 20px; }
  .timeline-item { grid-template-columns: 80px 1fr; gap: 20px; }
  .cta-banner { padding: 60px 20px; }
  .portfolio-masonry-section { padding: 60px 20px; }
  .portfolio-masonry-grid { columns: 1; }
}
