/* ============================================================
   MICELIO — styles.css
   Paleta, tipografía, retícula de tercios, 6 bloques + nav + footer
   ============================================================ */

/* ── Variables ─────────────────────────────────────────────── */
:root {
  --negro-sustrato: #1E210E;
  --verde-bio: #CBF750;
  --blanco: #FFFFFF;
  --turquesa: #4FDDE6;
  --magenta: #D347B3;
  --morado: #503260;
  --indigo: #007CA1;

  --negro-d1: #4B4D3E;
  --negro-d2: #787A6E;
  --negro-d3: #A5A69F;
  --negro-d4: #D2D3CF;

  --verde-d1: #D5F973;
  --verde-d4: #F5FDDC;

  --font-hubot: 'Hubot Sans', sans-serif;
  --font-archivo: 'Archivo', sans-serif;
  --font-serif: 'Instrument Serif', serif;
}

/* ── Reset ──────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-archivo);
  color: var(--negro-sustrato);
  background: var(--negro-sustrato);
  overflow-x: hidden;
}

img { display: block; max-width: 100%; }
a { text-decoration: none; color: inherit; }

/* ── Retícula base ──────────────────────────────────────────── */
.grid-tercios {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0;
}

.container {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 48px;
}

/* ── Scroll reveal ──────────────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 600ms ease-out, transform 600ms ease-out;
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* ════════════════════════════════════════════════════════════
   NAVEGACIÓN
   ════════════════════════════════════════════════════════════ */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  padding: 24px 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: background 300ms ease, box-shadow 300ms ease, padding 300ms ease;
}

.nav.scrolled {
  background: var(--negro-sustrato);
  box-shadow: 0 1px 0 rgba(203,247,80,0.08);
  padding: 16px 48px;
}

.nav__logo img {
  height: 28px;
  width: auto;
}

.nav__links {
  display: flex;
  align-items: center;
  gap: 32px;
  list-style: none;
}

.nav__links a {
  font-family: var(--font-archivo);
  font-weight: 400;
  font-size: 13px;
  color: var(--negro-d4);
  letter-spacing: 0.01em;
  transition: color 200ms ease;
}
.nav__links a:hover { color: var(--verde-bio); }

.nav__links .nav-traza .traza-arrow { color: var(--verde-bio); }

/* Hamburguesa */
.nav__hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  background: none;
  border: none;
  padding: 4px;
}
.nav__hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--negro-d4);
  transition: all 250ms ease;
}

/* Mobile menu */
.nav__mobile {
  display: none;
  position: fixed;
  inset: 0;
  background: var(--negro-sustrato);
  z-index: 99;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 40px;
}
.nav__mobile.open { display: flex; }
.nav__mobile a {
  font-family: var(--font-hubot);
  font-weight: 700;
  font-size: 24px;
  color: var(--negro-d4);
  transition: color 200ms;
}
.nav__mobile a:hover { color: var(--verde-bio); }

.nav__mobile-close {
  position: absolute;
  top: 24px; right: 48px;
  background: none;
  border: none;
  color: var(--negro-d4);
  font-size: 28px;
  cursor: pointer;
  line-height: 1;
}

/* ════════════════════════════════════════════════════════════
   BLOQUE 1 — HERO
   ════════════════════════════════════════════════════════════ */
.hero {
  position: relative;
  background: var(--negro-sustrato);
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.hero__inner {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 1320px;
  margin: 0 auto;
  padding: 140px 48px 100px;
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 0;
  align-items: center;
}

.hero__content {
  /* dos tercios izquierdos */
}

/* Corrección 2: logo cuadrado en tercio derecho */
.hero__deco {
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero__deco-logo {
  width: 300px;
  max-width: 100%;
  pointer-events: none;
  user-select: none;
}

.hero__titulo {
  font-family: var(--font-hubot);
  font-weight: 700;
  font-size: 80px;
  line-height: 1.05;
  color: var(--blanco);
  letter-spacing: -0.02em;
}

.hero__bajada {
  font-family: var(--font-archivo);
  font-weight: 400;
  font-size: 17px;
  color: var(--negro-d4);
  line-height: 1.6;
  margin-top: 40px;
  max-width: 580px;
}

.hero__cta {
  display: inline-block;
  font-family: var(--font-archivo);
  font-weight: 400;
  font-size: 14px;
  color: var(--verde-bio);
  margin-top: 40px;
  transition: text-decoration 150ms;
}
.hero__cta:hover { text-decoration: underline; }

/* Transición inferior hero → bloque 2 */
.hero::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 80px;
  background: linear-gradient(to bottom, transparent, var(--blanco));
  pointer-events: none;
  z-index: 2;
}

/* ════════════════════════════════════════════════════════════
   BLOQUE 2 — PROPÓSITO
   ════════════════════════════════════════════════════════════ */
.proposito {
  position: relative;
  background: var(--blanco);
  padding: 100px 0;
  overflow: hidden;
}

.proposito__icon-deco {
  position: absolute;
  bottom: -30px;
  right: -20px;
  width: 200px;
  opacity: 0.055;
  pointer-events: none;
  z-index: 0;
}

.proposito__inner {
  position: relative;
  z-index: 1;
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 48px;
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 0;
  align-items: stretch;
}

/* Bloque 2: ícono Cinta centrado en el primer tercio */
.proposito__marcador {
  position: relative;
  overflow: hidden;
}

.proposito__cinta {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 560px;
  pointer-events: none;
  /* Fuerza exactamente #D347B3 — mismo color que Comunicación estratégica Bloque 3 */
  filter: brightness(0) saturate(100%) invert(29%) sepia(85%) saturate(1800%) hue-rotate(270deg) brightness(105%);
}

.proposito__texto p {
  font-family: var(--font-archivo);
  font-weight: 100;
  font-size: 17px;
  color: var(--negro-sustrato);
  line-height: 1.75;
  margin-bottom: 32px;
  max-width: 680px;
}
.proposito__texto p:last-child { margin-bottom: 0; }

/* ════════════════════════════════════════════════════════════
   BLOQUE 3 — ÁREAS DE TRABAJO
   ════════════════════════════════════════════════════════════ */
.areas {
  background: var(--negro-sustrato);
  padding: 80px 0;
}

.areas__inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 48px;
}

.areas__header {
  font-family: var(--font-hubot);
  font-weight: 400;
  font-size: 13px;
  color: var(--negro-d4);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  margin-bottom: 48px;
}

.areas__grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 2px;
}

/* Tarjeta de área */
.area-card {
  position: relative;
  height: 520px;
  overflow: hidden;
  cursor: pointer;
}

.area-card__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  z-index: 0;
}

.area-card__overlay {
  position: absolute;
  inset: 0;
  background: var(--negro-sustrato);
  opacity: 0.42;
  z-index: 1;
  transition: opacity 300ms ease;
}
.area-card:hover .area-card__overlay { opacity: 0.26; }

.area-card__icon {
  position: absolute;
  left: 50%;
  top: 32%;
  transform: translate(-50%, -50%);
  width: 120px;
  opacity: 0.18;
  z-index: 2;
  pointer-events: none;
}

.area-card__content {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 32px;
  z-index: 3;
}

.area-card__etiqueta {
  font-family: var(--font-archivo);
  font-weight: 400;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.area-card__nombre {
  font-family: var(--font-hubot);
  font-weight: 700;
  font-size: 22px;
  line-height: 1.2;
  margin-top: 8px;
}

.area-card__desc {
  font-family: var(--font-archivo);
  font-weight: 400;
  font-size: 14px;
  color: var(--blanco);
  line-height: 1.55;
  margin-top: 12px;
}

.area-card__cta {
  display: inline-block;
  font-family: var(--font-archivo);
  font-weight: 400;
  font-size: 13px;
  margin-top: 16px;
  transition: transform 300ms ease;
}
.area-card:hover .area-card__cta { transform: translateX(4px); }

/* Colores por área */
.area-comunidades .area-card__etiqueta,
.area-comunidades .area-card__nombre,
.area-comunidades .area-card__cta { color: var(--verde-bio); }

.area-desarrollo .area-card__etiqueta,
.area-desarrollo .area-card__nombre,
.area-desarrollo .area-card__cta { color: var(--turquesa); }

.area-comunicacion .area-card__etiqueta,
.area-comunicacion .area-card__nombre,
.area-comunicacion .area-card__cta { color: var(--magenta); }

/* Transición áreas → trabajo reciente */
.areas__transicion {
  height: 60px;
  background: linear-gradient(to bottom, var(--negro-sustrato), var(--negro-d4));
}

/* ════════════════════════════════════════════════════════════
   BLOQUE 4 — TRABAJO RECIENTE
   ════════════════════════════════════════════════════════════ */
.trabajo {
  background: var(--negro-d4);
  padding: 100px 0;
}

.trabajo__inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 48px;
}

.trabajo__header {
  font-family: var(--font-hubot);
  font-weight: 400;
  font-size: 13px;
  color: var(--negro-d1);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  margin-bottom: 48px;
}

/* Grid asimétrico: 2/3 + 1/3 */
.trabajo__grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  grid-template-rows: auto;
  gap: 2px;
}

/* Corrección 4: tarjetas igual altura — el grid hace stretch automático */
.trabajo__grid {
  align-items: stretch;
}

.proyecto-card {
  position: relative;
  background: var(--blanco);
  border: 1px solid var(--negro-d3);
  overflow: hidden;
  cursor: pointer;
  transition: box-shadow 250ms ease;
  display: flex;
  flex-direction: column;
}
.proyecto-card:hover { box-shadow: 0 4px 24px rgba(30,33,14,0.1); }

.proyecto-card__imagen {
  position: relative;
  overflow: hidden;
  flex: 1; /* imagen ocupa el espacio sobrante → las tarjetas se igualan en altura */
  min-height: 80px;
}

.proyecto-card--grande .proyecto-card__imagen {
  min-height: 160px;
}
.proyecto-card--pequeno .proyecto-card__imagen {
  min-height: 80px;
}

.proyecto-card__imagen-bg {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--blanco);
}

.proyecto-card__imagen-overlay {
  position: absolute;
  inset: 0;
  transition: background 250ms ease;
}

.proyecto-card__imagen-icono {
  position: relative;
  z-index: 1;
  width: 80px;
  opacity: 0.20;
}

.proyecto-card__info {
  padding: 28px;
}
.proyecto-card--pequeno .proyecto-card__info { padding: 20px; }

.proyecto-card__etiqueta {
  font-family: var(--font-archivo);
  font-weight: 400;
  font-size: 11px;
  color: var(--negro-d1);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.proyecto-card--pequeno .proyecto-card__etiqueta { font-size: 10px; }

.proyecto-card__nombre {
  font-family: var(--font-hubot);
  font-weight: 700;
  font-size: 20px;
  color: var(--negro-sustrato);
  margin-top: 6px;
  line-height: 1.25;
  transition: color 250ms ease;
}
.proyecto-card--pequeno .proyecto-card__nombre { font-size: 17px; }

.proyecto-card__desc {
  font-family: var(--font-archivo);
  font-weight: 100;
  font-size: 14px;
  color: var(--negro-d1);
  line-height: 1.55;
  margin-top: 10px;
}

.proyecto-card__cta {
  display: inline-block;
  font-family: var(--font-archivo);
  font-weight: 400;
  font-size: 13px;
  color: var(--negro-sustrato);
  margin-top: 14px;
}
.proyecto-card--pequeno .proyecto-card__cta { font-size: 12px; }

/* Columna derecha: dos tarjetas apiladas */
.trabajo__columna-derecha {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

/* ════════════════════════════════════════════════════════════
   BLOQUE 5 — EL ESTUDIO
   ════════════════════════════════════════════════════════════ */
.estudio {
  background: var(--negro-d4);
  padding: 100px 0;
  border-top: 1px solid var(--negro-d3);
}

.estudio__inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 48px;
}

.estudio__header {
  font-family: var(--font-hubot);
  font-weight: 400;
  font-size: 13px;
  color: var(--negro-d1);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  margin-bottom: 48px;
}

.estudio__grid {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 64px;
  align-items: start;
}

/* Placeholder foto */
.foto-placeholder {
  aspect-ratio: 3 / 4;
  background: var(--negro-d1);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}

.foto-placeholder span {
  font-family: var(--font-serif);
  font-style: normal;
  font-size: 48px;
  color: var(--negro-d4);
}

.foto-cristobal {
  aspect-ratio: 3 / 4;
  width: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

.estudio__texto p {
  font-family: var(--font-archivo);
  font-weight: 100;
  font-size: 17px;
  color: var(--negro-sustrato);
  line-height: 1.75;
  margin-bottom: 28px;
  max-width: 560px;
}
.estudio__texto p:last-child { margin-bottom: 0; }

/* ════════════════════════════════════════════════════════════
   BLOQUE 6 — CIERRE Y CONTACTO
   ════════════════════════════════════════════════════════════ */
.cierre {
  position: relative;
  background: var(--negro-sustrato);
  padding: 120px 0 0;
  overflow: hidden;
}

.cierre__textura-deco {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 40%;
  opacity: 0.045;
  pointer-events: none;
  z-index: 0;
}

.cierre__inner {
  position: relative;
  z-index: 1;
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 48px;
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 80px;
  align-items: stretch;
}

/* Corrección 5: ícono Corriente centrado verticalmente, ancho completo, sin opacidad reducida */
.cierre__visual {
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: stretch; /* ocupa toda la altura del grid */
}

.cierre__icono {
  width: 100%;
  max-width: 280px;
  opacity: 1;
}

.cierre__pregunta {
  font-family: var(--font-hubot);
  font-weight: 700;
  font-size: 28px;
  line-height: 1.2;
  color: var(--blanco);
  max-width: 500px;
}

.cierre__subtexto {
  font-family: var(--font-archivo);
  font-weight: 400;
  font-size: 16px;
  color: var(--negro-d4);
  margin-top: 16px;
}

/* Formulario */
.formulario-contacto {
  margin-top: 40px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.formulario-contacto input,
.formulario-contacto textarea {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--negro-d1);
  color: var(--blanco);
  font-family: var(--font-archivo);
  font-weight: 400;
  font-size: 15px;
  padding: 10px 0;
  width: 100%;
  outline: none;
  border-radius: 0;
  transition: border-color 200ms;
}
.formulario-contacto input:focus,
.formulario-contacto textarea:focus {
  border-color: var(--negro-d3);
}
.formulario-contacto input::placeholder,
.formulario-contacto textarea::placeholder {
  color: var(--negro-d2);
}
.formulario-contacto textarea {
  resize: none;
  min-height: 100px;
}

.formulario-contacto button {
  align-self: flex-start;
  font-family: var(--font-hubot);
  font-weight: 700;
  font-size: 15px;
  color: var(--negro-sustrato);
  background: var(--turquesa);
  border: none;
  border-radius: 0;
  padding: 12px 28px;
  cursor: pointer;
  transition: background 200ms ease;
}
.formulario-contacto button:hover { background: var(--verde-bio); }

.cierre__contacto-datos {
  margin-top: 32px;
  display: flex;
  gap: 40px;
  flex-wrap: wrap;
}
.cierre__contacto-datos a,
.cierre__contacto-datos span {
  font-family: var(--font-archivo);
  font-weight: 400;
  font-size: 14px;
  color: var(--negro-d4);
}
.cierre__contacto-datos a:hover { color: var(--verde-bio); }

/* ── Footer ── */
.footer {
  position: relative;
  z-index: 1;
  max-width: 1320px;
  margin: 60px auto 0;
  padding: 24px 48px 40px;
  border-top: 1px solid var(--negro-d1);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}

.footer__copy,
.footer__lugar {
  font-family: var(--font-archivo);
  font-weight: 400;
  font-size: 12px;
  color: var(--negro-d3);
}

.footer__links {
  display: flex;
  gap: 24px;
}
.footer__links a {
  font-family: var(--font-archivo);
  font-weight: 400;
  font-size: 12px;
  color: var(--negro-d3);
  transition: color 200ms;
}
.footer__links a:hover { color: var(--verde-bio); }

/* ════════════════════════════════════════════════════════════
   RESPONSIVE — Tablet (768–1023px)
   ════════════════════════════════════════════════════════════ */
@media (max-width: 1023px) {
  .container,
  .hero__inner,
  .proposito__inner,
  .areas__inner,
  .trabajo__inner,
  .estudio__inner,
  .cierre__inner,
  .footer { padding-left: 32px; padding-right: 32px; }

  .hero__titulo { font-size: 56px; }
  .hero__content { max-width: 80%; }

  .proposito__inner { grid-template-columns: 80px 1fr; }

  .areas__grid { grid-template-columns: 1fr 1fr; }
  .area-card:last-child { grid-column: 1 / -1; }

  .trabajo__grid { grid-template-columns: 1fr; }
  .trabajo__columna-derecha { flex-direction: row; }
  .trabajo__columna-derecha .proyecto-card { flex: 1; }
  .proyecto-card--grande .proyecto-card__imagen { height: 220px; }

  .estudio__grid { grid-template-columns: 180px 1fr; gap: 40px; }

  .cierre__inner { grid-template-columns: 1fr; gap: 48px; }
  .cierre__icono { width: 100px; }
  .cierre__anio { font-size: 48px; }
}

/* ════════════════════════════════════════════════════════════
   RESPONSIVE — Mobile (<768px)
   ════════════════════════════════════════════════════════════ */
@media (max-width: 767px) {
  .nav { padding: 20px 24px; }
  .nav.scrolled { padding: 14px 24px; }
  .nav__links { display: none; }
  .nav__hamburger { display: flex; }

  .hero__inner { padding: 120px 24px 80px; }
  .hero__content { max-width: 100%; }
  .hero__titulo { font-size: 38px; letter-spacing: -0.01em; }
  .hero__bajada { font-size: 15px; margin-top: 28px; }
  .hero__cta { margin-top: 28px; }
  .hero__icon-deco { width: 160px; right: -20px; opacity: 0.07; }

  .proposito { padding: 72px 0; }
  .proposito__inner {
    padding: 0 24px;
    grid-template-columns: 1fr;
  }
  .proposito__marcador { display: none; }

  .areas { padding: 60px 0; }
  .areas__inner { padding: 0 24px; }
  .areas__grid { grid-template-columns: 1fr; }
  .area-card { height: 400px; }

  .trabajo { padding: 72px 0; }
  .trabajo__inner { padding: 0 24px; }
  .trabajo__grid { grid-template-columns: 1fr; }
  .trabajo__columna-derecha { flex-direction: column; }
  .proyecto-card--grande .proyecto-card__imagen { height: 200px; }
  .proyecto-card--pequeno .proyecto-card__imagen { height: 100px; }

  .estudio { padding: 72px 0; }
  .estudio__inner { padding: 0 24px; }
  .estudio__grid { grid-template-columns: 1fr; gap: 32px; }
  .foto-placeholder { max-width: 240px; }

  .cierre { padding: 80px 0 0; }
  .cierre__inner { padding: 0 24px; grid-template-columns: 1fr; gap: 40px; }
  .cierre__pregunta { font-size: 22px; }
  .cierre__icono { width: 90px; }
  .cierre__anio { font-size: 40px; }
  .cierre__textura-deco { width: 70%; }

  .footer {
    padding: 24px 24px 32px;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 8px;
  }

  .nav__mobile-close { right: 24px; }
}
