/* ============================================================
   AVC Construcciones — Sistema visual
   Grotesca arquitectónica + monospace editorial.
   Gris claro / navy-oscuro. Turquesa solo en detalles.
   ============================================================ */

:root {
  /* Marca */
  --navy: #021D49;
  --accent: #1DCAD3;

  /* Fondos */
  --paper: #F4F5F6;        /* gris super claro */
  --paper-2: #E9EBED;
  --ink: #0b0f17;          /* gris super oscuro */
  --ink-2: #04132e;        /* navy profundo para secciones */

  /* Texto sobre claro */
  --t-strong: #0d1626;
  --t-mid: #444e60;
  --t-soft: #7c8696;

  /* Texto sobre oscuro */
  --on-strong: #F4F5F6;
  --on-mid: rgba(244,245,246,.66);
  --on-soft: rgba(244,245,246,.42);

  /* Líneas */
  --line-dark: rgba(13,22,38,.14);
  --line-light: rgba(244,245,246,.16);

  /* Tipografía */
  --display: "Schibsted Grotesk", system-ui, sans-serif;
  /* Texto pequeño, labels y navegación (antes Space Mono) */
  --mono: "Roboto", system-ui, sans-serif;

  /* Layout */
  --pad: clamp(20px, 5vw, 90px);
  --maxw: 1560px;

  /* Motion */
  --ease: cubic-bezier(.22, 1, .36, 1);
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--paper);
  color: var(--t-strong);
  font-family: var(--display);
  font-weight: 400;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* Lenis */
html.lenis, html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-stopped { overflow: hidden; }

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; border: 0; background: none; }

::selection { background: var(--accent); color: var(--navy); }

/* ---------- Tipografía utilitaria ---------- */
.mono {
  font-family: var(--mono);
  font-size: .7rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  font-weight: 400;
}
.eyebrow {
  font-family: var(--mono);
  font-size: clamp(.62rem, .8vw, .74rem);
  letter-spacing: .26em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: .8em;
  color: var(--t-mid);
}
.eyebrow .dot {
  width: 9px; height: 9px; background: var(--accent);
  display: inline-block; flex: none;
  /* triángulo del logo (mismo recorte que triangulo.svg) */
  clip-path: polygon(0 0, 100% 0, 0 100%);
}
.on-dark .eyebrow { color: var(--on-mid); }

h1, h2, h3 { font-weight: 500; margin: 0; letter-spacing: -.025em; line-height: .98; }

.display-xl { font-size: clamp(2.9rem, 9vw, 9rem); font-weight: 560; }
.display-lg { font-size: clamp(2.3rem, 6.2vw, 6rem); }
.display-md { font-size: clamp(1.7rem, 3.4vw, 3.1rem); font-weight: 500; }

p { margin: 0; }
.lead {
  font-size: clamp(1.05rem, 1.4vw, 1.3rem);
  line-height: 1.55;
  color: var(--t-mid);
  font-weight: 400;
  max-width: 46ch;
}
.on-dark .lead { color: var(--on-mid); }

/* ---------- Container ---------- */
.container { max-width: var(--maxw); margin: 0 auto; padding-inline: var(--pad); }
.section { position: relative; }

/* ---------- Reveal primitives (base = visible) ---------- */
.reveal-line { display: block; overflow: hidden; }
.reveal-line > span { display: block; }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: fixed; inset: 0 0 auto 0; z-index: 80;
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
  padding: 18px var(--pad);
  color: var(--on-strong);
  transition: background .5s var(--ease), color .5s var(--ease), padding .5s var(--ease), border-color .5s var(--ease);
  border-bottom: 1px solid transparent;
}
.nav--solid {
  background: rgba(244,245,246,.86);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  color: var(--t-strong);
  padding-top: 12px; padding-bottom: 12px;
  border-bottom: 1px solid var(--line-dark);
}
.nav__brand { display: flex; align-items: center; flex: none; }
.logo-svg { height: 46px; width: auto; display: block; transition: height .5s var(--ease); }
.logo-svg .cls-1 { fill: var(--accent); transition: fill .5s var(--ease); }
.logo-svg .cls-2 { fill: var(--on-strong); transition: fill .5s var(--ease); }
.nav--solid .logo-svg .cls-2 { fill: var(--navy); }
.nav--solid .logo-svg { height: 30px; }

.nav__links { display: flex; gap: clamp(18px, 2.4vw, 40px); align-items: center; }
.nav__link {
  font-family: var(--mono);
  font-size: .72rem; letter-spacing: .16em; text-transform: uppercase;
  position: relative; padding: 6px 0; opacity: .82;
  transition: opacity .3s var(--ease);
}
.nav__link::after {
  content: ""; position: absolute; left: 0; bottom: 0; height: 1px; width: 0;
  background: var(--accent); transition: width .4s var(--ease);
}
.nav__link:hover { opacity: 1; }
.nav__link:hover::after { width: 100%; }

.nav__right { display: flex; align-items: center; gap: 18px; }
.lang {
  display: inline-flex; align-items: center; font-family: var(--mono);
  font-size: .7rem; letter-spacing: .12em; border: 1px solid currentColor;
  border-radius: 100px; overflow: hidden; opacity: .9;
}
.lang button { padding: 5px 11px; opacity: .5; transition: opacity .3s, background .3s, color .3s; }
.lang button.is-active { opacity: 1; background: #fff; color: var(--ink); }

.nav__burger { display: none; flex-direction: column; gap: 5px; padding: 8px 0; }
.nav__burger span { width: 26px; height: 1.5px; background: currentColor; display: block; transition: transform .4s var(--ease), opacity .3s; }

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; height: 100svh; min-height: 620px; overflow: hidden; color: var(--on-strong); }
.hero__media { position: absolute; inset: 0; z-index: 0; }
.hero__media video, .hero__media img {
  width: 100%; height: 100%; object-fit: cover;
  filter: saturate(.62) brightness(var(--hero-bright, .78)) contrast(1.02);
}
.hero__veil {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(180deg, rgba(2,18,46,.55) 0%, rgba(2,18,46,.18) 32%, rgba(7,11,20,.42) 72%, rgba(7,11,20,.82) 100%),
    radial-gradient(120% 90% at 50% 20%, transparent 40%, rgba(4,8,16,.4) 100%);
}
.hero__grain { position: absolute; inset: 0; z-index: 2; opacity: .05; mix-blend-mode: overlay; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.hero__inner {
  position: relative; z-index: 3; height: 100%;
  display: grid; grid-template-rows: 1fr auto; padding: 0 var(--pad);
  padding-top: clamp(110px, 16vh, 200px); padding-bottom: clamp(28px, 5vh, 64px);
}
.hero__top { align-self: end; padding-bottom: clamp(24px, 5vh, 56px); }
.hero__h1 {
  font-size: clamp(3rem, 11.5vw, 11.5rem);
  line-height: .9; font-weight: 560; letter-spacing: -.035em;
  margin-top: clamp(14px, 2.4vh, 28px);
}
.hero__h1 em { font-style: normal; color: var(--accent); }
.hero__bottom {
  display: flex; align-items: flex-end; justify-content: space-between; gap: 40px;
  border-top: 1px solid var(--line-light); padding-top: 22px;
}
.hero__sub { max-width: 40ch; color: var(--on-mid); font-size: clamp(.98rem, 1.2vw, 1.2rem); line-height: 1.5; }
.scrollcue { display: inline-flex; align-items: center; gap: 12px; font-family: var(--mono); font-size: .68rem; letter-spacing: .22em; text-transform: uppercase; color: var(--on-mid); white-space: nowrap; }
.scrollcue .bar { position: relative; width: 1px; height: 42px; background: var(--line-light); overflow: hidden; }
.scrollcue .bar::after { content: ""; position: absolute; inset: 0; background: var(--accent); transform: translateY(-100%); animation: cue 2.4s var(--ease) infinite; }
@keyframes cue { 0% { transform: translateY(-100%);} 45%,55%{ transform: translateY(0);} 100%{ transform: translateY(100%);} }

/* ============================================================
   MANIFIESTO (claro)
   ============================================================ */
.block { padding-block: clamp(90px, 14vh, 200px); }
.manifesto__grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: clamp(36px, 6vw, 110px); align-items: end; }
.manifesto__head h2 { margin: 26px 0 0; }
.manifesto__copy { display: flex; flex-direction: column; gap: 28px; padding-bottom: 8px; }
.figure { position: relative; overflow: hidden; background: var(--paper-2); }
.figure img { width: 100%; height: 100%; object-fit: cover; }
.figure--tall { aspect-ratio: 3/4; }
.figure__cap { position: absolute; left: 14px; bottom: 12px; color: #fff; font-family: var(--mono); font-size: .62rem; letter-spacing: .16em; text-transform: uppercase; mix-blend-mode: difference; }

.arrowlink { display: inline-flex; align-items: center; gap: 12px; font-family: var(--mono); font-size: .74rem; letter-spacing: .16em; text-transform: uppercase; }
.arrowlink .ico { width: 30px; height: 30px; border: 1px solid currentColor; border-radius: 100px; display: grid; place-items: center; transition: background .35s var(--ease), color .35s var(--ease), transform .35s var(--ease); }
.arrowlink:hover .ico { background: var(--accent); border-color: var(--accent); color: var(--navy); transform: translateX(3px); }

/* ============================================================
   CIFRAS (oscuro navy)
   ============================================================ */
.stats { background: var(--ink-2); color: var(--on-strong); }
.stats__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line-light); border-block: 1px solid var(--line-light); }
.stat { background: var(--ink-2); padding: clamp(36px, 5vw, 64px) clamp(20px, 3vw, 44px) clamp(30px, 4vw, 52px); }
.stat__num { font-size: clamp(2.6rem, 5.6vw, 5.4rem); font-weight: 540; letter-spacing: -.03em; line-height: 1; }
.stat__num .u { color: var(--accent); font-size: .42em; vertical-align: super; margin-left: .12em; }
.stat__label { margin-top: 16px; color: var(--on-mid); font-family: var(--mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; line-height: 1.5; }

/* ============================================================
   PROYECTOS — pin horizontal
   ============================================================ */
.projects { background: var(--ink); color: var(--on-strong); }
.projects__intro { display: flex; align-items: flex-end; justify-content: space-between; gap: 40px; padding: clamp(70px,10vh,130px) var(--pad) clamp(40px,6vh,70px); }
.projects__intro h2 { max-width: 16ch; margin-top: 22px; }
.projects__count { font-family: var(--mono); font-size: .72rem; letter-spacing: .18em; color: var(--on-mid); white-space: nowrap; }

.htrack { position: relative; height: 100svh; overflow: hidden; }
.htrack__rail { display: flex; height: 100%; will-change: transform; }
/* padding atado al inset de la imagen + 22px: el texto siempre queda ≥20px adentro de la imagen */
.panel { position: relative; flex: 0 0 min(82vw, 1080px); height: 100%; padding: calc(clamp(64px,9vh,120px) + 22px) calc(clamp(22px,3.4vw,60px) + 22px); display: flex; flex-direction: column; justify-content: flex-end; }
.panel__media { position: absolute; inset: clamp(64px,9vh,120px) clamp(22px,3.4vw,60px); overflow: hidden; background: var(--ink-2); }
.panel__media img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.08); transition: transform 1.2s var(--ease); filter: brightness(.82) saturate(.7); }
.panel:hover .panel__media img { transform: scale(1.01); }
.panel__media::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(4,8,16,.1) 0%, rgba(4,8,16,.0) 35%, rgba(4,8,16,.72) 100%); }
.panel__top { position: relative; z-index: 2; display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: auto; }
.panel__idx { font-family: var(--mono); font-size: .72rem; letter-spacing: .18em; color: var(--on-mid); }
.badge { font-family: var(--mono); font-size: .6rem; letter-spacing: .16em; text-transform: uppercase; padding: 7px 12px; border: 1px solid var(--line-light); border-radius: 100px; display: inline-flex; align-items: center; gap: 8px; -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); }
.badge .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }
.badge--done .dot { background: var(--on-soft); }
.panel__info { position: relative; z-index: 2; }
.panel__name { font-size: clamp(2.2rem, 5vw, 4.6rem); font-weight: 540; letter-spacing: -.03em; line-height: .96; }
.panel__meta { display: flex; gap: 26px; margin-top: 18px; flex-wrap: wrap; align-items: center; }
.panel__meta .k { font-family: var(--mono); font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: var(--on-mid); }
.panel__meta .k b { color: var(--on-strong); font-weight: 400; }
.panel__view { margin-top: 26px; }

.hprogress { position: absolute; left: var(--pad); right: var(--pad); bottom: clamp(22px,4vh,40px); z-index: 5; display: flex; align-items: center; gap: 16px; }
.hprogress__track { flex: 1; height: 1px; background: var(--line-light); position: relative; }
.hprogress__bar { position: absolute; inset: 0 auto 0 0; width: 0; background: var(--accent); }
.hprogress__label { font-family: var(--mono); font-size: .66rem; letter-spacing: .16em; color: var(--on-mid); }

/* fallback vertical (mobile/no-pin) */
.projects--stack .htrack { height: auto; }
.projects--stack .htrack__rail { flex-direction: column; transform: none !important; }
.projects--stack .panel { flex-basis: auto; height: 82svh; }

/* ============================================================
   MIRADA / materialidad (claro)
   ============================================================ */
.mirada__grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: clamp(20px, 3vw, 44px); align-items: start; }
.mirada__text { grid-column: 1 / 5; grid-row: 1; padding-top: clamp(8px, 3vh, 36px); }
.mirada__text h2 { margin: 24px 0 26px; }
.mirada__a { grid-column: 5 / 11; grid-row: 1; margin-top: clamp(80px, 13vh, 150px); }
.mirada__b { grid-column: 9 / 13; grid-row: 1; z-index: 2; }
.mirada__a .figure { aspect-ratio: 4/5; }
.mirada__b .figure { aspect-ratio: 3/4; box-shadow: 0 30px 70px -24px rgba(2, 29, 73, .4); }
/* Diferenciales (llenan la columna de texto) */
.mirada__list { list-style: none; margin: clamp(30px, 5vh, 54px) 0 0; padding: 0; display: flex; flex-direction: column; }
.mirada__item { display: grid; grid-template-columns: 44px 1fr; gap: 16px; padding: 20px 0; border-top: 1px solid var(--line-dark); }
.mirada__item:last-child { border-bottom: 1px solid var(--line-dark); }
.mirada__item .n { font-family: var(--mono); font-size: .68rem; letter-spacing: .14em; color: var(--accent); padding-top: 5px; }
.mirada__item h3 { margin: 0 0 6px; font-size: 1.04rem; font-weight: 600; letter-spacing: -.01em; color: var(--t-strong); }
.mirada__item p { margin: 0; color: var(--t-soft); font-size: .92rem; line-height: 1.55; max-width: 36ch; }
/* menos aire entre mirada y noticias (el rise deja hueco abajo) */
#mirada { padding-bottom: clamp(32px, 5vh, 72px); }
#noticias { padding-top: clamp(40px, 7vh, 90px); }
[data-rise] { will-change: transform; }

/* ============================================================
   NOTICIAS teaser (claro)
   ============================================================ */
.news__head { display: flex; align-items: flex-end; justify-content: space-between; gap: 30px; margin-bottom: 40px; }
.news__list { border-top: 1px solid var(--line-dark); }
.news__item { display: grid; grid-template-columns: 130px 1fr auto; gap: clamp(16px,3vw,50px); align-items: center; padding: clamp(22px,2.6vw,34px) 0; border-bottom: 1px solid var(--line-dark); transition: padding .4s var(--ease); }
.news__item:hover { padding-left: 16px; }
.news__date { font-family: var(--mono); font-size: .7rem; letter-spacing: .1em; color: var(--t-soft); }
.news__title { font-size: clamp(1.2rem, 2vw, 1.9rem); font-weight: 500; letter-spacing: -.02em; }
.news__cat { font-family: var(--mono); font-size: .64rem; letter-spacing: .16em; text-transform: uppercase; color: var(--t-soft); }
.news__item .arr { transition: transform .4s var(--ease); }
.news__item:hover .arr { transform: translateX(6px); color: var(--navy); }

/* ============================================================
   CIERRE / CTA (oscuro)
   ============================================================ */
.outro { background: var(--ink); color: var(--on-strong); overflow: hidden; }
.outro__inner { padding-block: clamp(90px, 16vh, 220px); text-align: center; }
.outro__kicker { margin-bottom: clamp(34px, 6vh, 70px); }
.outro__big { font-size: clamp(2.6rem, 11vw, 11.5rem); line-height: .92; font-weight: 560; letter-spacing: -.035em; display: flex; flex-direction: column; align-items: center; gap: .04em; }
.outro__big .row { display: inline-flex; align-items: center; gap: clamp(14px, 2.4vw, 40px); flex-wrap: wrap; justify-content: center; }
.outro__chip { display: inline-block; height: clamp(42px, 7vw, 1em); aspect-ratio: 16/10; overflow: hidden; background: var(--ink-2); vertical-align: middle; }
.outro__chip img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.7) brightness(.9); }
.outro__mark { display: inline-flex; align-items: center; }
.outro__mark svg { height: clamp(34px, 5.5vw, .66em); width: auto; fill: var(--accent); display: block; }
.outro__cta { margin-top: clamp(44px, 8vh, 90px); display: inline-flex; }
.btn {
  display: inline-flex; align-items: center; gap: 16px; padding: 18px 26px;
  border: 1px solid var(--line-light); border-radius: 100px;
  font-family: var(--mono); font-size: .76rem; letter-spacing: .16em; text-transform: uppercase;
  transition: background .4s var(--ease), color .4s var(--ease), border-color .4s var(--ease), transform .4s var(--ease);
}
.btn .ico { width: 26px; height: 26px; border-radius: 100px; background: var(--accent); color: var(--navy); display: grid; place-items: center; transition: transform .4s var(--ease); }
.btn:hover { background: var(--accent); color: var(--navy); border-color: var(--accent); }
.btn:hover .ico { background: var(--navy); color: var(--accent); transform: rotate(45deg); }

/* ============================================================
   FOOTER (oscuro)
   ============================================================ */
.footer { background: var(--ink); color: var(--on-strong); border-top: 1px solid var(--line-light); padding-top: clamp(60px, 9vh, 110px); }
.footer__top { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: clamp(34px, 5vw, 80px); padding-bottom: clamp(50px,8vh,90px); }
.footer__nav { display: flex; flex-direction: column; gap: 8px; }
.footer__nav a { font-size: clamp(1.8rem, 4vw, 3.2rem); font-weight: 500; letter-spacing: -.03em; line-height: 1.05; color: var(--on-strong); width: max-content; transition: color .3s var(--ease), transform .35s var(--ease); }
.footer__nav a:hover { color: var(--accent); transform: translateX(8px); }
.footer__col h4 { font-family: var(--mono); font-size: .66rem; letter-spacing: .2em; text-transform: uppercase; color: var(--on-soft); margin: 0 0 18px; font-weight: 400; }
.footer__col p, .footer__col a { color: var(--on-mid); font-size: .98rem; line-height: 1.7; }
.footer__col a:hover { color: var(--accent); }
.footer__contact > div { margin-bottom: 20px; }
.footer__lbl { font-family: var(--mono); font-size: .62rem; letter-spacing: .2em; text-transform: uppercase; color: var(--on-soft); display: inline-block; margin-bottom: 4px; }
.footer__bottom { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 28px 0 36px; border-top: 1px solid var(--line-light); flex-wrap: wrap; }
.footer__bottom .mono { color: var(--on-soft); }
.footer__by { display: inline-flex; align-items: center; gap: 10px; font-family: var(--mono); font-size: .62rem; letter-spacing: .14em; text-transform: uppercase; color: var(--on-soft); transition: color .3s var(--ease); }
.footer__by img { height: 18px; width: auto; display: block; opacity: .85; transition: opacity .3s var(--ease); }
.footer__by:hover { color: var(--on-strong); }
.footer__by:hover img { opacity: 1; }
.footer__logo .logo-svg { height: 30px; }
.footer__logo .logo-svg .cls-2 { fill: var(--on-strong); }

/* ============================================================
   PRELOADER
   ============================================================ */
/* ============================================================
   WHATSAPP FLOTANTE
   ============================================================ */
.wa-float {
  position: fixed; right: clamp(16px, 2.5vw, 28px); bottom: clamp(16px, 3vh, 28px); z-index: 90;
  width: 54px; height: 54px; border-radius: 50%; background: #25D366;
  display: grid; place-items: center;
  box-shadow: 0 14px 34px -10px rgba(4, 19, 46, .5);
  opacity: 0; visibility: hidden; transform: translateY(14px);
  transition: opacity .45s var(--ease), transform .45s var(--ease), visibility 0s linear .45s, background .3s var(--ease);
}
.wa-float.is-visible { opacity: 1; visibility: visible; transform: none; transition: opacity .45s var(--ease), transform .45s var(--ease), visibility 0s, background .3s var(--ease); }
.wa-float svg { width: 28px; height: 28px; fill: #fff; display: block; }
.wa-float:hover { background: #1fbd5a; transform: translateY(-3px); }

.preloader { position: fixed; inset: 0; z-index: 200; background: var(--ink); display: grid; place-items: center; }
.preloader__inner { text-align: center; color: var(--on-strong); }
.preloader__logo .logo-svg { height: clamp(66px, 12vw, 120px); }
.preloader__logo .logo-svg .cls-2 { fill: var(--on-strong); }
/* Loader: 4 triángulos del molinete que se prenden de a uno (TL→TR→BR→BL) */
.preloader__tri { width: clamp(56px, 10vw, 96px); height: auto; display: block; margin: 0 auto; }
.preloader__tri polygon { fill: var(--accent); opacity: .5; animation: triChase 1.6s ease-in-out infinite; }
.preloader__tri polygon:nth-child(1) { animation-delay: 0s; }    /* superior izquierda */
.preloader__tri polygon:nth-child(2) { animation-delay: .4s; }   /* superior derecha */
.preloader__tri polygon:nth-child(3) { animation-delay: .8s; }   /* inferior derecha */
.preloader__tri polygon:nth-child(4) { animation-delay: 1.2s; }  /* inferior izquierda */
@keyframes triChase {
  0%, 100% { opacity: .5; }
  12.5%    { opacity: 1; }
  25%      { opacity: .5; }
}
@media (prefers-reduced-motion: reduce) {
  .preloader__tri polygon { animation: none; opacity: 1; }
}
.preloader__bar { width: min(220px, 50vw); height: 1px; background: var(--line-light); margin: 26px auto 0; position: relative; overflow: hidden; }
.preloader__bar i { position: absolute; inset: 0 auto 0 0; width: 0; background: var(--accent); }
.preloader__pct { margin-top: 14px; font-family: var(--mono); font-size: .66rem; letter-spacing: .2em; color: var(--on-mid); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1040px) {
  .manifesto__grid { grid-template-columns: 1fr; gap: 48px; }
  .manifesto__copy { padding-bottom: 0; }
  .mirada__text, .mirada__a, .mirada__b { grid-column: auto; grid-row: auto; z-index: auto; }
  .mirada__a { margin-top: 0; }
  .mirada__grid { grid-template-columns: 1fr 1fr; }
  .mirada__text { grid-column: 1 / -1; }
  .footer__top { grid-template-columns: 1fr; }
  .stats__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 720px) {
  .nav__links { display: none; }
  .nav__burger { display: flex; }
  .hero__bottom { flex-direction: column; align-items: flex-start; gap: 22px; }
  .news__item { grid-template-columns: 1fr auto; }
  .news__date { grid-column: 1 / -1; }
  .mirada__grid { grid-template-columns: 1fr; }
  .stats__grid { grid-template-columns: 1fr 1fr; }
  .projects__intro { flex-direction: column; align-items: flex-start; }
}

@media (prefers-reduced-motion: reduce) {
  .scrollcue .bar::after { animation: none; }
  * { scroll-behavior: auto !important; }
}
