/* ============================================================
   SYMPHONIA · HOJA DEL SITIO  (sobre symphonia-web-tokens.css)
   ------------------------------------------------------------
   Recreación fiel del handoff de Claude Design, llevada a CSS
   externo con CLASES semánticas: ni un estilo en línea en el HTML,
   para una CSP totalmente estricta (style-src 'self', script-src
   'self', sin 'unsafe-inline'). Solo toca tokens SEMÁNTICOS.
   EL CREMA MANDA: única superficie oscura, el pie (verde del logo).
   Carga después de fonts.css y tokens.css.
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body { margin: 0; min-height: 100svh; overflow-x: hidden; }
img { max-width: 100%; height: auto; }
::selection { background: var(--linea-canon); color: var(--tinta-noche); }

/* Salto al contenido (accesibilidad) */
.saltar {
  position: absolute; left: 1rem; top: -3.5rem; z-index: 1000;
  background: var(--verde-forestal); color: var(--crema-claro);
  padding: 0.6rem 1rem; border-radius: var(--radio-s);
  font-family: var(--f-tecnica); font-size: var(--t-peque);
  transition: top var(--mov-medio) var(--ease);
}
.saltar:focus { top: 1rem; }

/* Contenedores */
.contenido { max-width: 1120px; margin-inline: auto; }
.columna   { max-width: 42rem;  margin-inline: auto; }

/* Padding lateral común (igual que el handoff) */
.nav-barra, .cabecera, .seccion, .pie { padding-inline: clamp(1.25rem, 5vw, 4.5rem); }
.seccion { padding-block: clamp(3.5rem, 7vw, 6rem); }
.seccion--fin { padding-bottom: clamp(4rem, 8vw, 6.5rem); }
.bg-crema { background: var(--fondo); }

/* ============================================================
   NAVEGACIÓN SUPERIOR
   ============================================================ */
.nav-barra {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--e3); flex-wrap: wrap;
  padding-block: clamp(1.25rem, 3vw, 2.25rem);
}
.nav-barra--hero { padding-inline: 0; } /* dentro del hero ya hay padding */
.marca { display: flex; align-items: center; gap: 0.7rem; text-decoration: none; background-image: none; }
.marca:hover { background-size: 0 0; }
.marca__sello { display: block; width: 46px; height: 46px; }
.marca__texto { display: flex; flex-direction: column; line-height: 1; }
.marca__nombre { font-family: var(--f-titulo); font-size: 1.18rem; letter-spacing: 0.18em; color: var(--texto); }
.marca__sub { font-family: var(--f-tecnica); font-size: 0.6rem; letter-spacing: 0.34em; text-transform: uppercase; color: var(--texto-tenue); margin-top: 3px; }

.nav-principal { display: flex; align-items: center; gap: clamp(0.9rem, 2vw, 1.7rem); flex-wrap: wrap; font-family: var(--f-tecnica); font-size: 0.78rem; letter-spacing: 0.08em; }
.nav-principal a { color: var(--texto); background-image: none; padding-block: 2px; }
.nav-principal a:hover { color: var(--acento); }
.nav-principal a[aria-current="page"] { color: var(--acento); }

/* ============================================================
   HERO (Inicio) · voz de presencia sobre crema
   ============================================================ */
.hero {
  position: relative; min-height: 100svh; display: flex; flex-direction: column;
  padding: clamp(1.25rem,3vw,2.25rem) clamp(1.25rem,5vw,4.5rem) clamp(2rem,4vw,3.5rem);
}
.hero__nav { position: relative; z-index: 3; }
.hero__tesis { flex: 1; display: flex; flex-direction: column; justify-content: center; position: relative; z-index: 2; max-width: min(720px, 100%); padding-block: clamp(2rem, 6vh, 5rem); }
.hero__eyebrow { font-family: var(--f-tecnica); text-transform: uppercase; letter-spacing: 0.28em; font-size: 0.74rem; color: var(--acento); margin: 0 0 clamp(1.4rem, 3vh, 2.2rem); }
.hero__titular { font-family: var(--f-titulo); font-size: clamp(2.5rem, 1.7rem + 3.6vw, 4.6rem); line-height: 1.06; margin: 0; color: var(--texto); max-width: 16ch; }
.hero__titular em { font-style: italic; color: var(--acento); }
.hero__entradilla { margin: clamp(1.6rem, 3.5vh, 2.6rem) 0 0; font-size: clamp(1.1rem, 0.95rem + 0.5vw, 1.32rem); line-height: 1.5; color: var(--texto-tenue); max-width: 42ch; }
.hero__acciones { margin-top: clamp(2rem, 4vh, 3rem); display: flex; align-items: center; gap: var(--e4); flex-wrap: wrap; }
.hero__cta { display: inline-flex; align-items: center; gap: 0.5rem; font-family: var(--f-tecnica); font-size: 0.82rem; letter-spacing: 0.06em; color: var(--acento); background-image: none; border-bottom: 1px solid color-mix(in srgb, var(--oro-viejo) 55%, transparent); padding-bottom: 3px; }
.hero__cta:hover { color: var(--acento-fuerte); }
.hero__link-suave { font-family: var(--f-tecnica); font-size: 0.82rem; letter-spacing: 0.06em; color: var(--texto-tenue); background-image: none; }
.hero__link-suave:hover { color: var(--texto); }

/* Registros: la firma de los cuatro elementos asomando desde la derecha */
.registros { position: absolute; inset: 0; pointer-events: none; z-index: 1; }
.registro { position: absolute; right: 0; height: 1px; }
.registro__rotulo { position: absolute; right: clamp(1.25rem,5vw,4.5rem); text-align: right; font-family: var(--f-tecnica); font-size: 0.62rem; letter-spacing: 0.24em; text-transform: uppercase; }
.registro--aire  { top: 40%; width: min(40%,480px); background: linear-gradient(to right, transparent, var(--el-aire));  opacity: .80; }
.registro--fuego { top: 54%; width: min(31%,380px); background: linear-gradient(to right, transparent, var(--el-fuego)); opacity: .78; }
.registro--agua  { top: 68%; width: min(46%,560px); background: linear-gradient(to right, transparent, var(--el-agua));  opacity: .80; }
.registro--noche { top: 82%; width: min(24%,300px); background: linear-gradient(to right, transparent, var(--el-noche)); opacity: .62; }
.rotulo--aire  { top: calc(40% - 1.5rem); color: var(--el-aire); }
.rotulo--fuego { top: calc(54% - 1.5rem); color: var(--el-fuego); }
.rotulo--agua  { top: calc(68% - 1.5rem); color: var(--el-agua); }
.rotulo--noche { top: calc(82% - 1.5rem); color: var(--el-noche); }

/* ============================================================
   CABECERA DE PÁGINA (interiores) · eyebrow + 4 puntos + H1
   ============================================================ */
.cabecera { padding-block: clamp(2.5rem,6vw,5rem) clamp(3rem,6vw,5rem); }
.cabecera__firma { display: flex; align-items: center; gap: 0.9rem; margin-bottom: clamp(1.4rem, 3vw, 2rem); }
.cabecera .eyebrow { margin: 0; }
.puntos { display: inline-flex; gap: 6px; }
.puntos span { width: 7px; height: 7px; border-radius: 50%; }
.punto--aire { background: var(--el-aire); }
.punto--fuego { background: var(--el-fuego); }
.punto--noche { background: var(--el-noche); }
.punto--agua { background: var(--el-agua); }

.titular { font-family: var(--f-titulo); font-size: clamp(2.5rem, 1.8rem + 3.4vw, 4.4rem); line-height: 1.05; margin: 0; color: var(--texto); }
.titular em { font-style: italic; color: var(--acento); }
.entradilla { font-family: var(--f-cuerpo); font-size: clamp(1.18rem, 1.05rem + 0.6vw, 1.5rem); line-height: 1.5; color: var(--texto-tenue); margin: clamp(1.6rem, 3vw, 2.4rem) 0 0; }

/* ============================================================
   TRES PUERTAS · índice editorial (no tarjetas SaaS)
   ============================================================ */
.puerta { display: grid; grid-template-columns: auto 1fr auto; align-items: baseline; gap: clamp(1rem, 3vw, 2.5rem); padding-block: clamp(1.4rem, 3vw, 2.1rem); border-top: 1px solid var(--linea); background-image: none; color: var(--texto); }
.puertas .puerta:last-child { border-bottom: 1px solid var(--linea); }
.puerta:hover { color: var(--enlace); }
.puerta__num { font-family: var(--f-titulo); font-size: clamp(1.1rem, 1.4vw, 1.35rem); letter-spacing: 0.05em; }
.puerta--aire  .puerta__num { color: var(--el-aire); }
.puerta--noche .puerta__num { color: var(--el-noche); }
.puerta--agua  .puerta__num { color: var(--el-agua); }
.puerta__cuerpo { display: flex; flex-direction: column; gap: 0.4rem; }
.puerta__nombre { font-family: var(--f-titulo); font-size: var(--t-h2); line-height: 1; color: inherit; }
.puerta__sub { font-family: var(--f-cuerpo); font-size: 1.1rem; color: var(--texto-tenue); max-width: 52ch; }
.puerta__flecha { font-family: var(--f-titulo); font-size: 1.6rem; color: var(--acento); align-self: center; transition: transform var(--mov-medio) var(--ease); }
.puerta:hover .puerta__flecha { transform: translateX(6px); }

/* ============================================================
   BLOQUES DE TEXTO · puente, lectura, destacados
   ============================================================ */
.centro { text-align: center; }
.puente { max-width: 24ch; margin-inline: auto; text-align: center; }
.puente h2 { font-family: var(--f-titulo); font-size: var(--t-h1); line-height: 1.08; margin: 0; }
.puente h2 em { font-style: italic; color: var(--acento); }
.puente__sub { font-family: var(--f-cuerpo); font-size: 1.2rem; color: var(--texto-tenue); max-width: 48ch; margin: var(--e4) auto 0; line-height: 1.55; }

.lectura-larga { font-family: var(--f-cuerpo); font-size: var(--t-cuerpo); line-height: 1.62; color: var(--texto); }
.lectura-larga p { margin: 0 0 1.4em; }
.lectura-larga p:last-child { margin-bottom: 0; }
.lectura-larga em { font-style: italic; }

.bloque-titulo { font-family: var(--f-titulo); font-size: var(--t-h2); line-height: 1.18; margin: 0; color: var(--texto); }
.bloque-titulo--h3 { font-size: var(--t-h3); line-height: 1.2; }
.intro-bloque { max-width: 42rem; margin: 0 0 clamp(2.5rem, 5vw, 3.5rem); }

/* Lista "por capas" (Salud) y similares */
.capas { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 0; }
.capa { display: grid; grid-template-columns: auto 1fr; gap: 1.1rem; align-items: baseline; padding: clamp(1.3rem,2.5vw,1.7rem) clamp(1.4rem,2.5vw,2rem) clamp(1.3rem,2.5vw,1.7rem) 0; border-top: 1px solid var(--linea); }
.capa__num { font-family: var(--f-titulo); font-size: 1.2rem; }
.capa__texto { font-family: var(--f-cuerpo); font-size: 1.12rem; line-height: 1.45; color: var(--texto); }
.capa__texto strong { font-weight: 600; }
.num--aire { color: var(--el-aire); } .num--fuego { color: var(--el-fuego); }
.num--noche { color: var(--el-noche); } .num--agua { color: var(--el-agua); } .num--oro { color: var(--acento); }

/* Bloque elevado genérico (honestidad, invitación, etc.) */
.panel { background: var(--fondo-elevado); border: 1px solid var(--linea); border-radius: var(--radio-m); box-shadow: var(--sombra-1); padding: clamp(2rem,4vw,3.2rem) clamp(1.8rem,4vw,3.4rem); }
.panel--fuego { border-top: 3px solid var(--el-fuego); }
.panel--noche { border-top: 3px solid var(--el-noche); }
.panel--aire  { border-top: 3px solid var(--el-aire); }
.panel--agua  { border-top: 3px solid var(--el-agua); }
.panel__lead { font-family: var(--f-cuerpo); font-size: clamp(1.2rem, 1.05rem + 0.7vw, 1.55rem); line-height: 1.45; color: var(--texto); max-width: 34ch; margin: 0; }
.panel__lead em { font-style: italic; color: var(--acento); }
.panel__nota { font-family: var(--f-cuerpo); font-size: 1.12rem; line-height: 1.55; color: var(--texto-tenue); max-width: 54ch; margin: var(--e4) 0 0; }

/* Cita límite (recuadro de responsabilidad) */
.limite { border-left: 2px solid var(--el-agua); padding: 0.2rem 0 0.2rem 1.4rem; }
.limite p { margin: 0; font-family: var(--f-cuerpo); font-style: italic; font-size: 1.08rem; line-height: 1.55; color: var(--texto-tenue); }
.nota-pie-seccion { max-width: 1120px; margin: var(--e4) auto 0; font-size: var(--t-peque); color: var(--texto-tenue); font-style: italic; }

/* Cierre con CTA a la derecha */
.cierre-cta { margin-top: clamp(2.5rem,5vw,3.5rem); padding-top: clamp(2rem,4vw,2.6rem); border-top: 1px solid var(--linea); display: flex; align-items: center; gap: var(--e4); flex-wrap: wrap; justify-content: space-between; }
.cierre-cta p { margin: 0; font-family: var(--f-titulo); font-size: var(--t-h3); line-height: 1.2; color: var(--texto); max-width: 24ch; }

/* Franja con botón (invitación test, lecturas, cita) */
.franja { display: flex; align-items: center; justify-content: space-between; gap: var(--e4); flex-wrap: wrap; }
.franja--panel { background: var(--fondo-elevado); border: 1px solid var(--linea); border-radius: var(--radio-m); box-shadow: var(--sombra-1); padding: clamp(1.6rem,3vw,2.4rem) clamp(1.6rem,3.5vw,2.8rem); }

/* ============================================================
   BOTONES (extiende tokens) · microcopy activo
   ============================================================ */
.boton { text-decoration: none; background-image: none; white-space: nowrap; }
.enlace-tecnico { font-family: var(--f-tecnica); font-size: 0.82rem; letter-spacing: 0.06em; color: var(--enlace); background-image: none; }
.enlace-tecnico:hover { color: var(--enlace-hover); }

/* ============================================================
   LIBROS
   ============================================================ */
.libro-ficha { display: grid; grid-template-columns: auto 1fr; gap: clamp(1.5rem,4vw,3rem); align-items: start; padding: clamp(1.8rem,3.5vw,2.6rem); }
.libro-ficha + .libro-ficha { margin-top: clamp(1.5rem,3vw,2.2rem); }
.libro-ficha__portada { width: clamp(128px, 17vw, 176px); border-radius: var(--radio-s); box-shadow: var(--sombra-2); overflow: hidden; align-self: start; }
.libro-ficha__portada img { display: block; width: 100%; height: 100%; object-fit: cover; }
.sello-linea { font-family: var(--f-tecnica); text-transform: uppercase; letter-spacing: 0.2em; font-size: 0.66rem; margin: 0 0 0.7rem; }
.sello-linea--aire { color: var(--el-aire); } .sello-linea--agua { color: var(--el-agua); }
.sello-linea--tenue { color: var(--texto-tenue); }
.libro-titulo { font-family: var(--f-titulo); font-style: italic; font-size: var(--t-h2); line-height: 1.12; margin: 0; color: var(--texto); }
.libro-desc { font-family: var(--f-cuerpo); font-size: 1.1rem; line-height: 1.55; color: var(--texto-tenue); max-width: 54ch; margin: var(--e3) 0 0; }
.libro-acciones { display: flex; gap: 0.8rem; flex-wrap: wrap; margin-top: var(--e4); }
.libro-puente { margin: var(--e4) 0 0; padding-top: var(--e3); border-top: 1px solid var(--linea); font-family: var(--f-cuerpo); font-style: italic; font-size: 1rem; color: var(--texto-tenue); }

.tarjetas { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: clamp(1.5rem,3vw,2.2rem); }
.tarjeta { background: var(--fondo); border: 1px solid var(--linea); border-radius: var(--radio-m); box-shadow: var(--sombra-1); padding: clamp(1.6rem,3vw,2.2rem); display: flex; flex-direction: column; }
.tarjeta--aire { border-top: 3px solid var(--el-aire); } .tarjeta--fuego { border-top: 3px solid var(--el-fuego); }
.tarjeta--noche { border-top: 3px solid var(--el-noche); } .tarjeta--agua { border-top: 3px solid var(--el-agua); }
.tarjeta__kicker { font-family: var(--f-tecnica); text-transform: uppercase; letter-spacing: 0.2em; font-size: 0.64rem; color: var(--texto-tenue); margin: 0 0 0.7rem; }
.tarjeta__titulo { font-family: var(--f-titulo); font-style: italic; font-size: var(--t-h3); line-height: 1.15; margin: 0; color: var(--texto); }
.tarjeta__desc { font-family: var(--f-cuerpo); font-size: 1.05rem; line-height: 1.5; color: var(--texto-tenue); margin: var(--e3) 0 var(--e4); }
.tarjeta .boton { margin-top: auto; align-self: flex-start; }

/* En el horizonte */
.horizonte-grupo h2 { font-family: var(--f-titulo); font-size: var(--t-h3); color: var(--texto); margin: clamp(1.4rem,3vw,2rem) 0 0.2rem; }
.horizonte-grupo p.sub { font-family: var(--f-cuerpo); font-style: italic; font-size: 1.02rem; color: var(--texto-tenue); margin: 0 0 0.7rem; }
.horizonte-lista { list-style: none; margin: 0 0 clamp(2.2rem,4.5vw,3rem); padding: 0; }
.horizonte-lista li { display: grid; grid-template-columns: auto 1fr; gap: 1.2rem; align-items: baseline; padding: 1.05rem 0; border-top: 1px solid var(--linea); border-bottom: 1px solid var(--linea); }
.horizonte-lista .vinieta { font-family: var(--f-titulo); }
.horizonte-lista .tit { font-family: var(--f-titulo); font-size: 1.2rem; color: var(--texto); }

/* Declaración / cierre centrado con filete */
.declaracion { max-width: 34rem; margin-inline: auto; text-align: center; }
.filete-oro { width: 54px; height: 2px; background: linear-gradient(to right, transparent, var(--acento), transparent); margin: 0 auto clamp(1.6rem,3vw,2.3rem); }
.declaracion p { font-family: var(--f-cuerpo); font-size: clamp(1.34rem, 1.1rem + 0.9vw, 1.78rem); line-height: 1.42; color: var(--texto); margin: 0; }
.declaracion a { color: var(--acento); background-image: none; }
.declaracion a:hover { color: var(--acento-fuerte); }

/* ============================================================
   CONSULTA · pasos
   ============================================================ */
.pasos { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 0; }
.paso { padding: clamp(1.6rem,3vw,2.2rem) clamp(1.4rem,2.5vw,2rem); }
.paso--aire { border-top: 3px solid var(--el-aire); } .paso--noche { border-top: 3px solid var(--el-noche); } .paso--agua { border-top: 3px solid var(--el-agua); }
.paso__rotulo { font-family: var(--f-tecnica); text-transform: uppercase; letter-spacing: 0.2em; font-size: 0.66rem; margin: 0 0 0.8rem; }
.paso--aire .paso__rotulo { color: var(--el-aire); } .paso--noche .paso__rotulo { color: var(--el-noche); } .paso--agua .paso__rotulo { color: var(--el-agua); }
.paso p.cuerpo { font-family: var(--f-cuerpo); font-size: 1.08rem; line-height: 1.55; color: var(--texto); margin: 0; }
.dos-columnas { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: clamp(2rem,5vw,4rem); align-items: center; }
.recibe { font-family: var(--f-cuerpo); font-size: clamp(1.2rem, 1.05rem + 0.7vw, 1.5rem); line-height: 1.5; color: var(--texto); margin: 0; }
.recibe strong { font-weight: 600; } .recibe em { font-style: italic; color: var(--acento); }

/* ============================================================
   SOBRE MÍ · carta + firma manuscrita
   ============================================================ */
.carta { max-width: 40rem; margin-inline: auto; }
.carta__h1 { font-family: var(--f-titulo); font-size: clamp(2.4rem, 1.7rem + 3vw, 4rem); line-height: 1.05; margin: 0; color: var(--texto); max-width: 14ch; }
.carta__h1 em { font-style: italic; color: var(--acento); }
.carta__cuerpo { font-family: var(--f-cuerpo); font-size: clamp(1.16rem, 1.05rem + 0.5vw, 1.38rem); line-height: 1.62; color: var(--texto); }
.carta__cuerpo p { margin: 0 0 1.5em; }
.carta__cuerpo p:last-child { margin-bottom: 0; }
.carta__cuerpo em { font-style: italic; }
.firma-bloque { margin-top: clamp(3rem,6vw,4.5rem); }
.firma-bloque .filete { width: 64px; height: 1px; background: linear-gradient(to right, var(--acento), transparent); margin-bottom: clamp(1rem,2.5vw,1.6rem); }
.firma-caligrafia { display: block; font-family: "Pinyon Script", cursive; font-size: clamp(3.2rem,9vw,5rem); line-height: 0.9; color: var(--texto); padding-left: 0.1em; }
.firma-pie { margin: 0.7rem 0 0; font-family: var(--f-tecnica); font-size: 0.74rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--texto-tenue); }

/* ============================================================
   CONTACTO
   ============================================================ */
.contacto-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: clamp(2.5rem,6vw,4.5rem); }
.canal { padding-block: var(--e4); border-bottom: 1px solid var(--linea); }
.canal:first-child { padding-top: 0; }
.canal:last-child { border-bottom: 0; }
.canal__dato { font-family: var(--f-titulo); font-size: var(--t-h3); color: var(--texto); background-image: none; }
.canal__dato:hover { color: var(--enlace); }
.canal__dato--peque { font-size: 1.2rem; }
.canal p { font-family: var(--f-cuerpo); font-size: 1.08rem; line-height: 1.5; color: var(--texto-tenue); margin: 0 0 var(--e3); max-width: 40ch; }

/* ============================================================
   FORMULARIOS · claros, accesibles, microcopy honesto
   ============================================================ */
.formulario { display: flex; flex-direction: column; gap: 0.9rem; }
.form-fila { display: flex; gap: 0.6rem; flex-wrap: wrap; }
.form-fila input[type="email"] { flex: 1; min-width: 220px; }
.campo { display: flex; flex-direction: column; gap: 0.45rem; }
.campo > label, .etiqueta { font-family: var(--f-tecnica); font-size: 0.72rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--texto-tenue); }
.campo .opcional { text-transform: none; letter-spacing: 0; font-style: italic; }
input[type="email"], input[type="text"], input[type="tel"], textarea, select {
  width: 100%; font-family: var(--f-cuerpo); font-size: 1.05rem; color: var(--texto);
  background: var(--fondo-elevado); border: 1px solid var(--linea); border-radius: var(--radio-s);
  padding: 0.8rem 0.95rem;
  transition: border-color var(--mov-medio) var(--ease), box-shadow var(--mov-medio) var(--ease);
}
textarea { min-height: 7rem; resize: vertical; line-height: 1.5; }
input:focus, textarea:focus, select:focus { border-color: var(--acento); box-shadow: 0 0 0 3px color-mix(in srgb, var(--acento) 22%, transparent); outline: none; }

/* Consentimiento: casilla NO premarcada + enlace a privacidad */
.consentimiento { display: grid; grid-template-columns: auto 1fr; gap: 0.7rem; align-items: start; }
.consentimiento input[type="checkbox"] { width: 1.15rem; height: 1.15rem; margin-top: 0.2rem; accent-color: var(--verde-forestal); }
.consentimiento label { font-family: var(--f-cuerpo); font-size: 0.95rem; color: var(--texto-tenue); line-height: 1.45; text-transform: none; letter-spacing: 0; }
.privacidad-nota { font-family: var(--f-cuerpo); font-style: italic; font-size: 0.98rem; color: var(--texto-tenue); margin: var(--e3) 0 0; }
.privacidad-nota a { font-style: normal; color: var(--enlace); }

/* Mensajes de estado de formulario */
.form-aviso { font-family: var(--f-cuerpo); font-size: 1rem; line-height: 1.5; padding: 0.9rem 1.1rem; border-radius: var(--radio-s); margin-top: 0.2rem; }
.form-aviso[hidden] { display: none; }
.form-aviso--ok { background: color-mix(in srgb, var(--verde-forestal) 10%, var(--papel-crema)); border: 1px solid var(--verde-forestal); color: var(--verde-forestal); }
.form-aviso--error { background: color-mix(in srgb, var(--grana) 8%, var(--papel-crema)); border: 1px solid var(--grana); color: var(--grana); }

/* ============================================================
   TEST CONSTITUCIONAL (interactivo, CSP-seguro)
   ============================================================ */
.test { max-width: 44rem; margin-inline: auto; }
.test [hidden] { display: none !important; }
.test__barra { height: 4px; background: var(--linea); border-radius: 999px; overflow: hidden; margin-bottom: clamp(1.5rem,3vw,2.2rem); }
.test__progreso { height: 100%; width: 0; background: var(--acento); transition: width var(--mov-medio) var(--ease); }
.test__paso-num { font-family: var(--f-tecnica); font-size: var(--t-peque); letter-spacing: 0.08em; color: var(--texto-tenue); text-align: center; margin: 0 0 var(--e3); }
.pregunta__texto { font-family: var(--f-titulo); font-size: var(--t-h2); line-height: 1.18; text-wrap: balance; margin: 0 0 var(--e4); color: var(--texto); }
.opciones { display: grid; gap: var(--e2); list-style: none; padding: 0; margin: 0; }
.opcion { display: block; width: 100%; text-align: left; cursor: pointer; font-family: var(--f-cuerpo); font-size: var(--t-cuerpo); line-height: 1.45; color: var(--texto); background: var(--fondo-elevado); border: 1px solid var(--linea); border-radius: var(--radio-m); padding: var(--e3); transition: border-color var(--mov-medio) var(--ease), background var(--mov-medio) var(--ease), box-shadow var(--mov-medio) var(--ease); }
.opcion:hover { border-color: var(--acento); background: var(--papel-crema); }
.opcion[aria-pressed="true"] { border-color: var(--acento); box-shadow: inset 0 0 0 1px var(--acento); }
.test__navegacion { display: flex; justify-content: space-between; align-items: center; margin-top: var(--e6); }
.test__atras { font-family: var(--f-tecnica); font-size: 0.8rem; letter-spacing: 0.05em; color: var(--texto-tenue); background: transparent; border: 0; cursor: pointer; }
.test__atras:hover { color: var(--texto); }
.test__atras[disabled] { opacity: 0; pointer-events: none; }

/* Resultado en la firma de su elemento (reusa la estética de retrato) */
.retrato { border: 1px solid var(--linea); border-radius: var(--radio-m); box-shadow: var(--sombra-1); padding: clamp(1.8rem,3.5vw,2.6rem); }
.retrato--aire  { background: radial-gradient(120% 70% at 50% 0%, color-mix(in srgb, var(--el-aire) 10%, transparent), transparent 58%), var(--fondo-elevado); border-top: 3px solid var(--el-aire); }
.retrato--fuego { background: radial-gradient(120% 70% at 50% 0%, color-mix(in srgb, var(--el-fuego) 9%, transparent), transparent 58%), var(--fondo-elevado); border-top: 3px solid var(--el-fuego); }
.retrato--noche { background: radial-gradient(120% 70% at 50% 0%, color-mix(in srgb, var(--el-noche) 9%, transparent), transparent 58%), var(--fondo-elevado); border-top: 3px solid var(--el-noche); }
.retrato--agua  { background: radial-gradient(120% 70% at 50% 0%, color-mix(in srgb, var(--el-agua) 10%, transparent), transparent 58%), var(--fondo-elevado); border-top: 3px solid var(--el-agua); }
.retrato__elemento { font-family: var(--f-tecnica); text-transform: uppercase; letter-spacing: 0.2em; font-size: 0.66rem; margin: 0 0 0.5rem; }
.retrato__titulo { font-family: var(--f-titulo); font-size: var(--t-h2); line-height: 1.12; margin: 0 0 var(--e3); color: var(--texto); }
.retrato__cuerpo { font-family: var(--f-cuerpo); font-size: 1.08rem; line-height: 1.55; color: var(--texto); margin: 0; }
.retrato__reto { font-family: var(--f-cuerpo); font-size: 1.04rem; line-height: 1.55; color: var(--texto-tenue); margin: var(--e3) 0 0; }
.retrato__reto .et { font-family: var(--f-tecnica); text-transform: uppercase; letter-spacing: 0.14em; font-size: 0.62rem; }
.retrato__matiz { font-family: var(--f-cuerpo); font-style: italic; font-size: 1.1rem; line-height: 1.5; color: var(--texto-tenue); margin: var(--e4) 0 0; }
.retrato__capitulo { margin: var(--e4) 0 0; padding-top: var(--e3); border-top: 1px solid var(--linea); }
.aire .retrato__elemento, .et-aire { color: var(--el-aire); } .fuego .retrato__elemento, .et-fuego { color: var(--el-fuego); }
.noche .retrato__elemento, .et-noche { color: var(--el-noche); } .agua .retrato__elemento, .et-agua { color: var(--el-agua); }

/* Cuadrícula de los 4 retratos (presentación estática en la intro del test) */
.retratos-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: clamp(1.5rem,3vw,2.2rem); }
.retrato--mini .retrato__titulo { font-size: var(--t-h3); }
.matiz-ejemplos { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: clamp(1.2rem,3vw,2rem); margin-top: var(--e6); }
.matiz-ejemplos p { font-family: var(--f-cuerpo); font-size: 1.05rem; line-height: 1.55; color: var(--texto-tenue); margin: 0; padding-left: 1.2rem; }
.matiz-ejemplos .ej-fuego { border-left: 2px solid var(--el-fuego); } .matiz-ejemplos .ej-noche { border-left: 2px solid var(--el-noche); }

/* ============================================================
   PIE · única superficie oscura, verde del logo (NUNCA azul)
   ============================================================ */
.pie { background: var(--verde-forestal); color: var(--crema-claro); padding-block: clamp(3rem,6vw,5rem) clamp(2rem,4vw,3rem); }
.pie a { background-image: none; }
.pie__sup { display: flex; gap: clamp(2rem,6vw,5rem); flex-wrap: wrap; justify-content: space-between; align-items: flex-start; padding-bottom: clamp(2rem,4vw,3rem); border-bottom: 1px solid color-mix(in srgb, var(--linea-canon) 22%, transparent); }
.pie__marca { max-width: 34ch; }
.pie__marca-fila { display: flex; align-items: center; gap: 0.7rem; margin-bottom: var(--e3); }
.pie__marca-fila img { width: 40px; height: 40px; }
.pie__marca-fila span { font-family: var(--f-titulo); font-size: 1.05rem; letter-spacing: 0.18em; color: var(--crema-claro); }
.pie__kicker { font-family: var(--f-tecnica); text-transform: uppercase; letter-spacing: 0.2em; font-size: 0.66rem; color: color-mix(in srgb, var(--crema-claro) 60%, transparent); margin: 0 0 0.9rem; }
.pie__desc { font-family: var(--f-cuerpo); font-size: 1.02rem; line-height: 1.5; color: color-mix(in srgb, var(--crema-claro) 78%, transparent); margin: 0; }
.pie__alta { display: flex; flex-direction: column; gap: 0.7rem; }
.pie__alta input[type="email"] { flex: 1; min-width: 180px; background: color-mix(in srgb, var(--papel-crema) 8%, transparent); border: 1px solid color-mix(in srgb, var(--linea-canon) 32%, transparent); color: var(--crema-claro); }
.pie__alta input::placeholder { color: color-mix(in srgb, var(--crema-claro) 55%, transparent); }
.pie__nav { display: flex; flex-direction: column; gap: 0.7rem; font-family: var(--f-tecnica); font-size: 0.82rem; letter-spacing: 0.06em; }
.pie__nav a { color: color-mix(in srgb, var(--crema-claro) 82%, transparent); }
.pie__nav a:hover { color: var(--oro-viejo); }
.pie__inf { display: flex; gap: var(--e4); flex-wrap: wrap; justify-content: space-between; align-items: center; padding-top: var(--e4); font-family: var(--f-tecnica); font-size: 0.72rem; letter-spacing: 0.04em; color: color-mix(in srgb, var(--crema-claro) 55%, transparent); }
.pie__legal { display: flex; gap: var(--e3); flex-wrap: wrap; }
.pie__legal a { color: color-mix(in srgb, var(--crema-claro) 60%, transparent); }
.pie__legal a:hover { color: var(--oro-viejo); }
.pie__copia { margin: 0; max-width: 52ch; }

/* Páginas legales (lectura sobria) */
.legal { max-width: 46rem; margin-inline: auto; }
.legal h2 { font-family: var(--f-titulo); font-size: var(--t-h3); color: var(--texto); margin: var(--e8) 0 var(--e2); }
.legal h2:first-of-type { margin-top: var(--e4); }
.legal p, .legal li { font-family: var(--f-cuerpo); font-size: 1.06rem; line-height: 1.62; color: var(--texto); }
.legal ul { padding-left: 1.2rem; } .legal li { margin-bottom: 0.5rem; }
.legal strong { font-weight: 600; }
.legal .actualizado { font-style: italic; color: var(--texto-tenue); font-size: var(--t-peque); }
.legal .marcador { background: color-mix(in srgb, var(--acento) 14%, transparent); padding: 0 0.2em; border-radius: 3px; }

/* ============================================================
   AYUDAS DE PÁGINA (clases referenciadas por el generador)
   ============================================================ */
.cursiva-oro { font-style: italic; color: var(--acento); }
.tenue { color: var(--texto-tenue); }
.sello-grande { width: min(220px, 55vw); height: auto; opacity: 0.92; margin-inline: auto; }
.pagina-foco { display: flex; flex-direction: column; }
.enlaces-fila { display: flex; gap: var(--e4); flex-wrap: wrap; margin-top: clamp(2rem, 4vw, 2.8rem); }
.form-alta-compacta { min-width: min(320px, 100%); }
.cabecera-carta { margin-bottom: clamp(2.5rem, 5vw, 3.8rem); }
.titular--legal { font-size: clamp(2.1rem, 1.6rem + 2.4vw, 3.2rem); margin-bottom: var(--e2); }
.cabecera__firma--centro { justify-content: center; }
.formulario--ancho { max-width: 40rem; }
.test__intro-nota { max-width: 46ch; margin-inline: auto; }
.test__intro-alt { margin-top: var(--e3); }
.test__alta { margin-top: clamp(2.5rem, 5vw, 3.5rem); }
.test__nota-honesta { margin-top: clamp(2rem, 4vw, 2.6rem); }
.test__rehacer { margin-top: var(--e4); text-align: center; }
.test__rehacer button { background: transparent; border: 0; cursor: pointer; }

/* Accesibilidad: oculto visual, visible para lector de pantalla */
.vh { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }

/* Consentimiento compacto dentro del pie (verde) */
.pie .consentimiento { margin-top: 0.7rem; }
.pie .consentimiento label { color: color-mix(in srgb, var(--crema-claro) 78%, transparent); font-size: 0.82rem; }
.pie .consentimiento a { color: var(--oro-viejo); text-decoration: underline; }
.pie__alta { margin-bottom: 0; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 52rem) {
  .libro-ficha { grid-template-columns: 1fr; }
  .libro-ficha__portada { width: clamp(150px, 42vw, 200px); }
}
@media (max-width: 40rem) {
  .nav-barra { gap: var(--e2); }
  .nav-principal { font-size: 0.74rem; gap: 0.7rem 1rem; width: 100%; }
  .cierre-cta, .franja { gap: var(--e3); }
  .registro__rotulo { display: none; } /* en móvil, líneas sin rótulo */
}

/* Cierre de movimiento (refuerza los tokens) */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { scroll-behavior: auto !important; }
}

/* Fix responsive: los registros del hero (firma) solo cuando hay sitio;
   en ventanas estrechas se ocultan para no cruzar el titular. */
/* registros-responsive-fix */
@media (max-width: 64rem) {
  .hero .registros { display: none; }
}
