:root {
  --bg: #0a0b0f;
  --bg-2: #0f1219;
  --surface: #14181f;
  --surface-2: #1b212c;
  --text: #eef2f7;
  --muted: #b4becb;            /* subido para contraste AA sobre el fondo oscuro */
  --muted-dim: #8b97a6;
  --brand: #4f8cff;
  --brand-2: #8b5cff;
  --accent: #2ee6c5;
  --on: #2ea043;
  --off: #6e7681;
  --border: #242c3a;
  --radius: 16px;
  --maxw: 1080px;
  --font-display: "Space Grotesk", system-ui, sans-serif;
  --font-body: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
h1, h2, h3, .brand, .wordmark { font-family: var(--font-display); }
a { color: var(--brand); text-decoration: none; }
a:hover { text-decoration: none; opacity: .9; }
main { min-height: 60vh; }
em { font-style: normal; color: var(--brand); }

/* ---------- Nav ---------- */
.nav {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 28px;
  background: rgba(10, 11, 15, .72);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border);
}
.brand { font-weight: 700; font-size: 1.35rem; color: var(--text); letter-spacing: -.02em; }
.brand span { color: var(--brand); }
.nav nav { display: flex; align-items: center; gap: 22px; }
.nav nav a { color: var(--muted); font-weight: 500; font-size: .95rem; }
.nav nav a:hover { color: var(--text); }
.nav-cta {
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  color: #fff !important; padding: 9px 18px; border-radius: 999px; font-weight: 600;
}
@media (max-width: 680px) {
  .nav { padding: 14px 18px; }
  .nav nav a:not(.nav-cta) { display: none; }   /* en móvil dejamos solo el CTA + marca */
}

/* ---------- Botones ---------- */
.btn {
  display: inline-block;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  color: #fff; font-weight: 600; padding: 13px 26px; border-radius: 999px;
  border: 0; cursor: pointer; font-size: 1rem; letter-spacing: .01em;
  box-shadow: 0 8px 30px -10px rgba(120, 110, 255, .6);
  transition: transform .15s ease, box-shadow .15s ease;
}
.btn:hover { transform: translateY(-2px); box-shadow: 0 14px 40px -12px rgba(120, 110, 255, .8); }
.btn.ghost { background: transparent; border: 1px solid var(--border); color: var(--text); box-shadow: none; }
.btn.ghost:hover { border-color: var(--brand); }
.btn.big { font-size: 1.2rem; padding: 16px 34px; }

/* ---------- Hero ---------- */
.hero {
  position: relative; text-align: center;
  min-height: calc(100vh - 64px);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 48px 20px 80px; overflow: hidden;
}
.hero-glow {
  position: absolute; inset: -15% 0 auto 0; height: 75%; z-index: 0; pointer-events: none;
  background:
    radial-gradient(60% 60% at 50% 28%, rgba(79, 140, 255, .20), transparent 70%),
    radial-gradient(45% 45% at 68% 50%, rgba(139, 92, 255, .18), transparent 70%),
    radial-gradient(40% 40% at 30% 55%, rgba(46, 230, 197, .10), transparent 70%);
  filter: blur(18px);
}
.hero > * { position: relative; z-index: 1; }
.kicker {
  text-transform: uppercase; letter-spacing: .26em; font-size: .8rem;
  color: var(--muted); margin: 0 0 22px; font-weight: 600;
}

/* ---------- Wordmark (SIMPLIFICA -> SIMPLIFIK, pliegue sin reflow) ---------- */
.wordmark {
  position: relative;
  font-size: clamp(2.8rem, 12vw, 9rem);
  font-weight: 700; letter-spacing: -.04em; line-height: .95; margin: 0 0 6px;
  cursor: pointer; user-select: none;
  color: #f5f8ff; white-space: nowrap;
  text-shadow: 0 0 50px rgba(110, 120, 255, .30);
}
.wm-cota {
  position: absolute; top: -1.7rem; left: 50%; transform: translateX(-50%);
  font-family: var(--font-body); font-size: .72rem; letter-spacing: .18em;
  color: var(--accent); white-space: nowrap; opacity: 0; font-weight: 600;
  animation: cotaFlash 2.6s ease .5s both;
}
.wm-swap { display: inline-grid; vertical-align: bottom; }
.wm-ca, .wm-k { grid-area: 1 / 1; white-space: nowrap; }
.wm-ca {                       /* width 0 => la celda mide como la K; la CA desborda y se pliega */
  width: 0; overflow: visible; justify-self: start;
  animation: caFold 2.6s cubic-bezier(.7, 0, .2, 1) .5s both;
}
.wm-k {                        /* la K es la estrella: su propio degradado */
  opacity: 0;
  background: linear-gradient(135deg, var(--brand) 10%, var(--brand-2) 55%, var(--accent) 100%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
  animation: kUnfold 2.6s cubic-bezier(.7, 0, .2, 1) .5s both, kPulse .7s ease 2.4s both;
}
@keyframes caFold {
  0%, 30%  { clip-path: inset(0 0 0 0);    opacity: 1; transform: translateY(0); filter: blur(0); }
  62%,100% { clip-path: inset(0 0 100% 0); opacity: 0; transform: translateY(-.18em); filter: blur(5px); }
}
@keyframes kUnfold {
  0%, 35%  { clip-path: inset(100% 0 0 0); opacity: 0; transform: translateY(.18em); }
  70%,100% { clip-path: inset(0 0 0 0);    opacity: 1; transform: translateY(0); }
}
@keyframes kPulse {
  0%   { filter: drop-shadow(0 0 0 transparent); }
  50%  { filter: drop-shadow(0 0 20px rgba(46, 230, 197, .55)); }
  100% { filter: drop-shadow(0 0 0 transparent); }
}
@keyframes cotaFlash { 0%,22% { opacity: 0; } 44%,68% { opacity: .9; } 100% { opacity: 0; } }
/* re-lanzar al hacer clic */
.wordmark.replay .wm-ca   { animation: caFold 2.6s cubic-bezier(.7,0,.2,1) 0s both; }
.wordmark.replay .wm-k    { animation: kUnfold 2.6s cubic-bezier(.7,0,.2,1) 0s both, kPulse .7s ease 2.2s both; }
.wordmark.replay .wm-cota { animation: cotaFlash 2.6s ease 0s both; }

.hero-h1 {
  font-size: clamp(1.6rem, 4.6vw, 3rem); line-height: 1.1; letter-spacing: -.02em;
  margin: 18px 0 0; max-width: 820px;
}
.hero-sub {
  font-size: clamp(1.02rem, 2.2vw, 1.25rem); color: var(--muted);
  max-width: 600px; margin: 18px auto 0;
}
.cta-row { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; margin-top: 34px; }
.scroll-hint { position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%); color: var(--muted-dim); font-size: 1.5rem; z-index: 1; }
.scroll-hint:hover { color: var(--text); }

/* ---------- Manifiesto ---------- */
.manifesto { max-width: 880px; margin: 0 auto; padding: 100px 24px; text-align: center; font-family: var(--font-display); }
.manifesto p { font-size: clamp(1.3rem, 3.4vw, 2.15rem); line-height: 1.35; color: var(--muted); margin: 0 0 28px; font-weight: 500; }
.manifesto p.big { color: var(--text); }
.manifesto p strong { color: var(--brand); font-weight: 700; }
.manifesto p.sign { font-size: clamp(1.1rem, 2.6vw, 1.5rem); color: var(--text); margin-top: 8px; }

/* ---------- Secciones con título ---------- */
.section-title { font-size: clamp(1.8rem, 4vw, 2.6rem); text-align: center; margin: 0 0 12px; letter-spacing: -.02em; }
.section-lead { text-align: center; color: var(--muted); max-width: 620px; margin: 0 auto 56px; font-size: 1.12rem; }

/* ---------- Cómo trabajamos ---------- */
.how { max-width: var(--maxw); margin: 0 auto; padding: 40px 24px 90px; }
.steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 18px; }
.step {
  background: linear-gradient(180deg, var(--surface), var(--bg-2));
  border: 1px solid var(--border); border-radius: var(--radius); padding: 26px 22px;
  transition: border-color .2s, transform .2s;
}
.step:hover { border-color: var(--brand); transform: translateY(-4px); }
.step-num {
  font-family: var(--font-display); font-size: 1.5rem; font-weight: 700;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
  display: block; margin-bottom: 10px;
}
.step h3 { margin: 0 0 8px; font-size: 1.18rem; }
.step p { color: var(--muted); margin: 0; font-size: .96rem; }

/* ---------- ADN band ---------- */
.adn { max-width: 860px; margin: 0 auto; padding: 0 24px 50px; text-align: center; }
.adn p { font-family: var(--font-display); font-size: clamp(1.05rem, 2.4vw, 1.45rem); color: var(--muted); line-height: 1.42; margin: 0; }
.adn strong { color: var(--text); }
.adn em { color: var(--accent); font-style: normal; }

/* ---------- Lo que dominamos (la prueba) ---------- */
.proof { max-width: var(--maxw); margin: 0 auto; padding: 40px 24px 80px; }
.proof-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 18px; }
.proof-card {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 26px; transition: border-color .2s, transform .2s;
}
.proof-card:hover { border-color: var(--brand); transform: translateY(-4px); }
.proof-card h3 { margin: 0 0 10px; font-size: 1.2rem; }
.proof-card p { color: var(--muted); margin: 0; }
.proof-card strong { color: var(--text); }
.stat-strip {
  list-style: none; display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 14px; margin: 40px 0 0; padding: 26px; text-align: center;
  border: 1px solid var(--border); border-radius: var(--radius);
  background: radial-gradient(120% 120% at 50% 0%, rgba(79,140,255,.10), transparent 60%), var(--surface);
}
.stat-strip li { color: var(--muted); font-size: .92rem; }
.stat-strip b {
  display: block; font-family: var(--font-display); font-size: 1.7rem; color: var(--text);
  background: linear-gradient(135deg, var(--brand), var(--accent));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}

/* ---------- Hook subvenciones ---------- */
.hook { padding: 30px 24px 110px; }
.hook-inner {
  max-width: 920px; margin: 0 auto; text-align: center; padding: 56px 40px;
  border-radius: 26px; border: 1px solid var(--border);
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(79,140,255,.16), transparent 55%),
    radial-gradient(120% 120% at 100% 100%, rgba(139,92,255,.18), transparent 55%),
    var(--surface);
}
.hook-inner h2 { font-size: clamp(1.7rem, 4.2vw, 2.7rem); margin: 0 0 16px; letter-spacing: -.02em; }
.hook-inner h2 span { color: var(--accent); }
.hook-inner p { color: var(--muted); max-width: 600px; margin: 0 auto 28px; font-size: 1.1rem; }
.hook-inner p strong { color: var(--text); }
.hook-foot { font-size: .92rem; margin-top: 22px !important; opacity: .8; }

/* ---------- Contacto ---------- */
.contact { text-align: center; padding: 40px 24px 120px; }
.contact h2 { font-size: clamp(2rem, 6vw, 3.2rem); margin: 0 0 12px; letter-spacing: -.03em; }
.contact p { color: var(--muted); max-width: 520px; margin: 0 auto 32px; font-size: 1.12rem; }

/* ---------- Reveal on scroll ---------- */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s ease, transform .7s ease; }
.reveal.is-visible { opacity: 1; transform: none; }

/* ====================================================================== */
/* Páginas internas: subvenciones                                          */
/* ====================================================================== */
.sub-hero { max-width: 820px; margin: 0 auto; padding: 80px 24px 30px; text-align: center; }
.sub-hero h1 { font-size: clamp(2rem, 5.5vw, 3.4rem); line-height: 1.08; margin: 10px 0 18px; letter-spacing: -.02em; }
.sub-lead { color: var(--muted); font-size: 1.15rem; max-width: 640px; margin: 0 auto; }

.page { max-width: var(--maxw); margin: 0 auto; padding: 30px 24px 80px; }
.page h1 { margin: 0 0 6px; }
.muted { color: var(--muted); }
.catalog-head { display: flex; align-items: baseline; justify-content: space-between; flex-wrap: wrap; gap: 8px; margin-bottom: 6px; }
.catalog-head h2 { margin: 0; font-size: 1.5rem; }
.back { display: inline-block; margin-bottom: 14px; color: var(--muted); }

.filters {
  display: flex; flex-wrap: wrap; gap: 10px; align-items: center;
  margin: 18px 0 28px; padding: 16px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius);
}
.filters input[type=search], .filters select {
  background: var(--bg); color: var(--text); border: 1px solid var(--border);
  border-radius: 10px; padding: 11px 13px; font-size: .95rem; font-family: var(--font-body);
}
.filters input[type=search] { flex: 1; min-width: 200px; }
.filters input[type=search]:focus, .filters select:focus { outline: none; border-color: var(--brand); }
.check { display: flex; align-items: center; gap: 6px; color: var(--muted); }

.grants { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 16px; }
.grant {
  display: block; background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 20px; color: var(--text);
  transition: border-color .15s, transform .15s;
}
.grant:hover { border-color: var(--brand); transform: translateY(-3px); }
.grant h3 { margin: 8px 0 10px; font-size: 1.08rem; line-height: 1.3; }
.grant .meta { color: var(--muted); font-size: .9rem; margin: 2px 0; }
.grant-head { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.estado { font-size: .72rem; text-transform: uppercase; letter-spacing: .04em; padding: 3px 9px; border-radius: 999px; }
.estado-on { background: rgba(46,160,67,.18); color: #4ad66d; }
.estado-off { background: rgba(110,118,129,.18); color: var(--off); }
.score { font-size: .78rem; color: var(--brand); font-weight: 700; }
.empty { color: var(--muted); padding: 24px 0; }

.roadmap { margin-top: 70px; }
.roadmap h2 { font-size: 1.5rem; margin: 0 0 18px; }
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 16px; }
.card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 22px; position: relative; }
.card h3 { margin: 0 0 8px; }
.card p { color: var(--muted); margin: 0 0 14px; }
.card.soon { opacity: .72; }
.badge { font-size: .72rem; text-transform: uppercase; letter-spacing: .05em; background: var(--surface-2); color: var(--muted); padding: 4px 10px; border-radius: 999px; }
.badge.on { background: rgba(46,160,67,.18); color: #4ad66d; }

.detail .facts { display: grid; grid-template-columns: max-content 1fr; gap: 8px 20px; margin: 20px 0; }
.detail dt { color: var(--muted); }
.detail dd { margin: 0; }
.checklist { padding-left: 18px; }
.checklist li { margin: 6px 0; }

/* ---------- Footer ---------- */
.footer { max-width: var(--maxw); margin: 0 auto; padding: 40px 24px 60px; border-top: 1px solid var(--border); color: var(--muted); text-align: center; }
.footer-brand { font-family: var(--font-display); font-weight: 700; font-size: 1.2rem; color: var(--text); margin-bottom: 8px; }
.footer-brand span { color: var(--brand); }
.footer p { margin: 4px 0; font-size: .9rem; }
.footer .small { font-size: .82rem; opacity: .7; }

/* ---------- Accesibilidad: menos movimiento ---------- */
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; }
  .wm-ca, .wm-cota { display: none; }
  .wm-k { opacity: 1; clip-path: none; }
}
