/* ===================================================================
 * BASE — estilos de elementos HTML sin clase.
 * Body, tipografía base, headings, links, párrafos.
 * Cargado tras reset.css.
 * =================================================================*/

body {
  font-family: var(--horreo-font-body);
  font-size: var(--fs-base);
  font-weight: var(--fw-regular);
  line-height: var(--lh-normal);
  color: var(--horreo-text-primary);
  background-color: var(--horreo-bg-primary);
  background-image:
    radial-gradient(circle at 20% 10%, rgba(201, 169, 97, 0.04), transparent 40%),
    radial-gradient(circle at 80% 90%, rgba(201, 169, 97, 0.03), transparent 40%);
  background-attachment: fixed;
  min-height: 100vh;
  overflow-x: hidden;
}

/* ----------- HEADINGS ----------- */

h1, h2, h3, h4, h5, h6 {
  font-family: var(--horreo-font-display);
  font-weight: var(--fw-semibold);
  line-height: var(--lh-tight);
  color: var(--horreo-text-primary);
  letter-spacing: var(--tracking-tight);
}

h1 {
  font-size: var(--fs-2xl);
  font-weight: var(--fw-bold);
}

h2 {
  font-size: var(--fs-xl);
  font-weight: var(--fw-semibold);
}

h3 {
  font-size: var(--fs-lg);
  font-weight: var(--fw-semibold);
}

h4, h5, h6 {
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
}

/* ----------- PÁRRAFOS Y LECTURA ----------- */

p {
  font-family: var(--horreo-font-body);
  font-size: var(--fs-base);
  line-height: var(--lh-relaxed);
  color: var(--horreo-text-primary);
}

p + p {
  margin-top: var(--space-4);
}

/* Citas largas estilo storytelling (Gomiuvas, Cruz Mayo, La Casa) */
blockquote, .horreo-quote {
  font-family: var(--horreo-font-accent);
  font-size: var(--fs-lg);
  font-style: italic;
  font-weight: var(--fw-medium);
  line-height: var(--lh-relaxed);
  color: var(--horreo-text-primary);
  border-left: 2px solid var(--horreo-gold);
  padding-left: var(--space-5);
  margin-block: var(--space-6);
}

/* ----------- LINKS ----------- */

a {
  color: var(--horreo-gold);
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease-out);
}

a:hover {
  color: var(--horreo-gold-light);
}

/* Link con subrayado animado (componente .link-underline) */
.link-underline {
  position: relative;
  display: inline-block;
  padding-bottom: 2px;
}
.link-underline::after {
  content: '';
  position: absolute;
  left: 0; bottom: 0;
  width: 100%;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-base) var(--ease-out);
}
.link-underline:hover::after {
  transform: scaleX(1);
}

/* ----------- LISTAS ----------- */

ul, ol {
  padding-left: var(--space-5);
}

li + li {
  margin-top: var(--space-2);
}

/* ----------- HORIZONTAL RULE ----------- */

hr {
  border: 0;
  height: 1px;
  background: linear-gradient(
    to right,
    transparent,
    var(--horreo-border-strong),
    transparent
  );
  margin-block: var(--space-7);
}

/* ----------- IMÁGENES ----------- */

img {
  font-style: italic;     /* texto del alt si la imagen falla */
  vertical-align: middle;
}

/* ----------- CÓDIGO (uso esporádico en docs internos) ----------- */

code, pre, kbd, samp {
  font-family: var(--horreo-font-mono);
  font-size: 0.95em;
}
code {
  background: var(--horreo-bg-secondary);
  padding: 0.15em 0.4em;
  border-radius: var(--radius-sm);
  color: var(--horreo-gold-light);
}

/* ----------- FORMULARIOS BASE ----------- */

input, textarea, select {
  background: var(--horreo-bg-secondary);
  color: var(--horreo-text-primary);
  border: 1px solid var(--horreo-border);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  font-family: var(--horreo-font-body);
  font-size: var(--fs-base);
  width: 100%;
  transition: border-color var(--dur-fast) var(--ease-out);
}

input:focus, textarea:focus, select:focus {
  border-color: var(--horreo-gold);
}

input::placeholder, textarea::placeholder {
  color: var(--horreo-text-muted);
}

label {
  display: block;
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--horreo-text-secondary);
  margin-bottom: var(--space-2);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}

/* ----------- HELPERS DE LAYOUT BÁSICOS ----------- */

.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-px);
}

.container--narrow {
  max-width: var(--container-narrow);
}

.section {
  padding-block: var(--section-py);
}

/* iter-6: secciones semi-transparentes para que las burbujas Canvas
 * (canvas global z:0) se transparenten sutilmente a través del contenido.
 * El body sigue opaco como base; estos backgrounds son veladuras. */
.section--alt {
  background: rgba(26, 26, 26, 0.85);
}

/* Esconder en móvil / mostrar solo en desktop */
.hide-mobile {
  display: none;
}
@media (min-width: 1024px) {
  .hide-mobile { display: initial; }
  .hide-desktop { display: none; }
}

/* Logo wordmark dorado en versalitas (utilidad) */
.is-wordmark {
  font-family: var(--horreo-font-body);
  font-weight: var(--fw-medium);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--horreo-gold);
}
