/* ============================================================
   OCEANAVAL — Componentes de página
   ============================================================ */

/* ============ HERO ============ */
.hero {
  position: relative; min-height: 100svh;
  display: flex; align-items: flex-end;
  overflow: hidden;
  padding-bottom: clamp(3rem, 8vh, 6rem);
}
.hero__media { position: absolute; inset: 0; z-index: 0; }
.hero__video, .hero__poster {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover;
}
.hero__poster { z-index: 1; transition: opacity 0.8s var(--ease-out); }
.hero__video.is-ready + .hero__poster { opacity: 0; }
/* Velo para legibilidad + tinte marino */
.hero__media::after {
  content: ""; position: absolute; inset: 0; z-index: 2;
  background:
    linear-gradient(180deg, oklch(18% 0.045 250 / 0.55) 0%, transparent 30%, oklch(18% 0.045 250 / 0.35) 55%, oklch(18% 0.045 250 / 0.95) 100%),
    radial-gradient(120% 80% at 80% 20%, oklch(78% 0.13 215 / 0.12), transparent 60%);
}
.hero__content { position: relative; z-index: 3; width: 100%; }
.hero__kicker { margin-bottom: 1.75rem; }
.hero__title {
  font-size: var(--t-mega);
  line-height: 0.92; font-weight: 600; letter-spacing: -0.03em;
  color: var(--c-paper); text-wrap: balance;
}
.hero__title .line { display: block; overflow: hidden; }
.hero__title .line span { display: block; }
.hero__title em {
  font-family: var(--f-serif); font-style: italic; font-weight: 400;
  color: var(--c-cyan); letter-spacing: -0.01em;
}
.hero__meta {
  margin-top: 2.5rem;
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 2rem; flex-wrap: wrap;
}
.hero__sub { max-width: 40ch; color: var(--c-mist); font-size: var(--t-lead); }
.hero__cta-row { display: flex; gap: 1rem; align-items: center; flex-wrap: wrap; }

/* Indicador de scroll + coordenadas técnicas */
.hero__hud {
  position: absolute; z-index: 3; left: var(--gutter); bottom: 2rem;
  font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: 0.15em;
  color: var(--c-slate); text-transform: uppercase;
  display: flex; gap: 1.5rem;
}
.hero__hud.right { left: auto; right: var(--gutter); }
.scroll-cue {
  position: absolute; z-index: 3; bottom: 2rem; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 0.5rem;
  font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: 0.25em;
  color: var(--c-slate); text-transform: uppercase;
}
.scroll-cue__line { width: 1px; height: 40px; background: linear-gradient(var(--c-cyan), transparent); position: relative; overflow: hidden; }
.scroll-cue__line::after { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 50%; background: var(--c-cyan); animation: scrolldot 1.8s var(--ease-in-out) infinite; }
@keyframes scrolldot { 0% { transform: translateY(-100%); } 100% { transform: translateY(200%); } }
/* En móvil el indicador decorativo se solapa con el CTA secundario del hero: lo ocultamos */
@media (max-width: 768px) { .scroll-cue { display: none; } }

/* ============ Marquee de transición ============ */
.marquee {
  border-block: 1px solid var(--c-line);
  padding-block: 1.5rem; overflow: hidden; white-space: nowrap;
  background: var(--c-deep);
}
.marquee__track { display: inline-flex; gap: 3rem; will-change: transform; }
.marquee__item {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(1.5rem, 3.5vw, 2.75rem); letter-spacing: -0.01em;
  color: transparent; -webkit-text-stroke: 1px var(--c-slate);
  display: inline-flex; align-items: center; gap: 3rem;
}
.marquee__item::after { content: "✳"; -webkit-text-stroke: 0; color: var(--c-cyan); font-size: 0.6em; }
.marquee__item.solid { color: var(--c-paper); -webkit-text-stroke: 0; }

/* ============ Intro / quiénes somos ============ */
.intro__grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-7); align-items: start; }
.intro__lead { font-family: var(--f-serif); font-size: clamp(1.5rem, 3vw, 2.4rem); line-height: 1.35; color: var(--c-paper); font-weight: 400; }
.intro__lead .hl { color: var(--c-cyan); font-style: italic; }
.intro__body { color: var(--c-mist); }
.intro__body p + p { margin-top: 1.25rem; }
.intro__anchor {
  margin-top: 2.5rem; font-family: var(--f-display); font-weight: 600;
  font-size: var(--t-h3); color: var(--c-paper); line-height: 1.2;
}

/* ============ Stats / contadores ============ */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-4); margin-top: var(--s-6); }
.stat { border-top: 1px solid var(--c-line-strong); padding-top: 1.5rem; }
.stat__num { font-family: var(--f-display); font-weight: 600; font-size: clamp(2.5rem, 5vw, 4rem); color: var(--c-paper); line-height: 1; letter-spacing: -0.03em; }
.stat__num .unit { color: var(--c-cyan); }
.stat__label { margin-top: 0.6rem; font-family: var(--f-mono); font-size: var(--t-small); letter-spacing: 0.08em; color: var(--c-slate); text-transform: uppercase; }

/* ============ Servicios (lista numerada interactiva) ============ */
.services { position: relative; }
.services__head { display: grid; grid-template-columns: 1fr auto; gap: 2rem; align-items: end; margin-bottom: var(--s-5); }
.svc-list { border-top: 1px solid var(--c-line); }
.svc {
  display: grid; grid-template-columns: 5rem 1fr auto; gap: clamp(1rem, 3vw, 3rem);
  align-items: center; padding-block: clamp(1.75rem, 3.5vw, 2.75rem);
  border-bottom: 1px solid var(--c-line);
  position: relative; transition: background var(--d-base) var(--ease-out);
}
.svc::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(90deg, oklch(78% 0.13 215 / 0.06), transparent 70%);
  opacity: 0; transition: opacity var(--d-base) var(--ease-out);
}
.svc:hover::before { opacity: 1; }
.svc__num { font-family: var(--f-mono); font-size: var(--t-small); color: var(--c-cyan); letter-spacing: 0.05em; }
.svc__main { display: flex; flex-direction: column; gap: 0.6rem; }
.svc__title { font-family: var(--f-display); font-weight: 600; font-size: var(--t-h3); color: var(--c-paper); letter-spacing: -0.02em; transition: transform var(--d-base) var(--ease-out); }
.svc:hover .svc__title { transform: translateX(8px); }
.svc__desc { color: var(--c-slate); max-width: 62ch; font-size: var(--t-body); }
.svc__icon {
  width: 3rem; height: 3rem; flex-shrink: 0;
  display: grid; place-items: center; border: 1px solid var(--c-line-strong);
  border-radius: 50%; color: var(--c-mist);
  transition: transform var(--d-base) var(--ease-out), color var(--d-base), border-color var(--d-base);
}
.svc:hover .svc__icon { transform: rotate(-45deg); color: var(--c-abyss); background: var(--c-cyan); border-color: var(--c-cyan); }

/* Tarjetas de servicio (página servicios) */
.svc-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-3); }
.svc-card {
  position: relative; padding: clamp(1.75rem, 3vw, 2.75rem);
  border: 1px solid var(--c-line); border-radius: var(--radius);
  background: var(--c-deep); overflow: hidden;
  display: flex; flex-direction: column; gap: 1.25rem; min-height: 22rem;
  transition: border-color var(--d-base), transform var(--d-base) var(--ease-out);
}
.svc-card:hover { border-color: var(--c-cyan-deep); transform: translateY(-4px); }
.svc-card__top { display: flex; align-items: baseline; justify-content: space-between; }
.svc-card__num { font-family: var(--f-mono); font-size: 0.8rem; color: var(--c-cyan); letter-spacing: 0.1em; }
.svc-card__tag { font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: 0.18em; text-transform: uppercase; color: var(--c-slate); border: 1px solid var(--c-line-strong); padding: 0.3em 0.7em; border-radius: 100px; }
.svc-card__title { font-family: var(--f-display); font-weight: 600; font-size: var(--t-h3); color: var(--c-paper); margin-top: auto; }
.svc-card__desc { color: var(--c-mist); font-size: var(--t-body); }
.svc-card__line { position: absolute; left: 0; bottom: 0; height: 2px; width: 100%; background: var(--c-cyan); transform: scaleX(0); transform-origin: left; transition: transform var(--d-slow) var(--ease-out); }
.svc-card:hover .svc-card__line { transform: scaleX(1); }

/* ============ Bloque imagen + texto (calado / showcase) ============ */
.showcase { position: relative; overflow: hidden; }
.showcase__media {
  position: relative; border-radius: var(--radius); overflow: hidden;
}
.showcase__media img { width: 100%; height: 100%; object-fit: cover; will-change: transform; }
.showcase__media.parallax { height: clamp(22rem, 60vh, 42rem); }
.showcase__media.parallax img { height: 130%; }

.feature-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-6); align-items: center; }
.feature-row.flip .feature-row__text { order: -1; }
.feature-row__media { position: relative; aspect-ratio: 4/3; border-radius: var(--radius); overflow: hidden; }
.feature-row__media img { width: 100%; height: 100%; object-fit: cover; }
.feature-row__badge {
  position: absolute; top: 1rem; left: 1rem;
  font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: 0.15em;
  text-transform: uppercase; color: var(--c-cyan);
  background: oklch(18% 0.045 250 / 0.7); backdrop-filter: blur(6px);
  padding: 0.5em 0.9em; border: 1px solid var(--c-line);
}

/* ============ Valores ============ */
.values { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--c-line); border: 1px solid var(--c-line); }
.value {
  background: var(--c-abyss); padding: clamp(1.75rem, 3vw, 2.75rem);
  display: flex; flex-direction: column; gap: 1rem; min-height: 16rem;
  position: relative; transition: background var(--d-base) var(--ease-out);
}
.value:hover { background: var(--c-deep); }
.value__num { font-family: var(--f-mono); font-size: var(--t-small); color: var(--c-cyan); }
.value__title { font-family: var(--f-display); font-weight: 600; font-size: 1.4rem; color: var(--c-paper); letter-spacing: 0.01em; }
.value__desc { color: var(--c-slate); font-size: 0.98rem; margin-top: auto; }

/* ============ Sostenibilidad (frase ancla pin) ============ */
.statement { position: relative; text-align: center; padding-block: clamp(6rem, 18vh, 14rem); }
.statement__text {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(2rem, 6vw, 5.5rem); line-height: 1.05; letter-spacing: -0.03em;
  color: var(--c-paper); max-width: 18ch; margin-inline: auto;
}
.statement__text .word { display: inline-block; }
.statement__text .hl { color: var(--c-cyan); font-family: var(--f-serif); font-style: italic; font-weight: 400; }
.statement__sub { margin-top: 2rem; color: var(--c-mist); font-size: var(--t-lead); max-width: 48ch; margin-inline: auto; }

/* ============ Partners (muro de logos en chips) ============ */
.partners__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-3); }
.partner-chip {
  background: var(--c-paper); border-radius: var(--radius);
  aspect-ratio: 16/9; display: grid; place-items: center;
  padding: clamp(1.25rem, 2.5vw, 2.25rem);
  position: relative; overflow: hidden;
  transition: transform var(--d-base) var(--ease-out);
}
.partner-chip::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(120deg, transparent 30%, oklch(78% 0.13 215 / 0.18) 50%, transparent 70%);
  transform: translateX(-100%); transition: transform 0.7s var(--ease-out);
}
.partner-chip:hover { transform: translateY(-4px); }
.partner-chip:hover::after { transform: translateX(100%); }
.partner-chip img { max-height: 64%; max-width: 78%; width: auto; object-fit: contain; }

/* ============ CTA contacto ============ */
.cta {
  position: relative; overflow: hidden;
  border-radius: var(--radius); border: 1px solid var(--c-line-strong);
  padding: clamp(3rem, 8vw, 7rem) var(--gutter);
  text-align: center; background: var(--c-deep);
}
.cta__title { font-size: var(--t-h1); letter-spacing: -0.03em; margin-bottom: 1.5rem; }
.cta__title em { font-family: var(--f-serif); font-style: italic; font-weight: 400; color: var(--c-cyan); }
.cta__sub { color: var(--c-mist); font-size: var(--t-lead); max-width: 46ch; margin: 0 auto 2.5rem; }
.cta__phone { display: inline-flex; align-items: center; gap: 0.6rem; margin-top: 2rem; font-family: var(--f-mono); font-size: var(--t-small); letter-spacing: 0.12em; color: var(--c-slate); }
.cta__phone a { color: var(--c-cyan); }

/* ============ Section heading genérico ============ */
.sec-head { display: grid; gap: 1.5rem; margin-bottom: var(--s-5); max-width: 60rem; }
.sec-head__title { font-size: var(--t-h2); }
.sec-head__title em { font-family: var(--f-serif); font-style: italic; font-weight: 400; color: var(--c-cyan); }
.sec-head--split { grid-template-columns: 1fr 1fr; align-items: end; max-width: none; gap: var(--s-5); }
.sec-head__intro { color: var(--c-mist); font-size: var(--t-lead); }

/* ============ Reveal base (JS añade .in) ============ */
[data-reveal] { opacity: 0; transform: translateY(28px); }
[data-reveal].in { opacity: 1; transform: none; transition: opacity 0.9s var(--ease-out), transform 0.9s var(--ease-out); }
[data-reveal-stagger] > * { opacity: 0; transform: translateY(24px); }

/* ============ Page hero (subpáginas) ============ */
.page-hero { position: relative; padding-top: calc(var(--header-h) + clamp(3rem,9vh,7rem)); padding-bottom: clamp(2rem,6vh,4rem); overflow: hidden; }
.page-hero__index { font-family: var(--f-mono); font-size: var(--t-small); color: var(--c-cyan); letter-spacing: 0.2em; margin-bottom: 1.5rem; display: block; }
.page-hero__title { font-size: var(--t-h1); letter-spacing: -0.03em; }
.page-hero__title em { font-family: var(--f-serif); font-style: italic; font-weight: 400; color: var(--c-cyan); }
.page-hero__sub { margin-top: 1.75rem; max-width: 52ch; color: var(--c-mist); font-size: var(--t-lead); }
.breadcrumb { font-family: var(--f-mono); font-size: var(--t-small); color: var(--c-slate); letter-spacing: 0.08em; margin-bottom: 2rem; }
.breadcrumb a { color: var(--c-slate); transition: color var(--d-fast); }
.breadcrumb a:hover { color: var(--c-cyan); }
.breadcrumb [aria-current] { color: var(--c-mist); }

/* ============ Responsive ============ */
@media (max-width: 900px) {
  .intro__grid { grid-template-columns: 1fr; gap: var(--s-5); }
  .stats { grid-template-columns: repeat(2, 1fr); }
  .svc-cards { grid-template-columns: 1fr; }
  .values { grid-template-columns: 1fr; }
  .feature-row { grid-template-columns: 1fr; gap: var(--s-4); }
  .feature-row.flip .feature-row__text { order: 0; }
  .partners__grid { grid-template-columns: repeat(2, 1fr); }
  .sec-head--split { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .svc { grid-template-columns: 2.5rem 1fr; }
  .svc__icon { display: none; }
  .hero__hud { display: none; }
  .partners__grid { grid-template-columns: repeat(2, 1fr); }
}
