body {
  line-height: var(--interlinea);
  letter-spacing: var(--espaciadoletra);
}

/* Jerarquía de títulos */
h1 {
  font-size: clamp(2rem, 1rem + 4vw, 4.5rem);
  font-style: italic;
  color: var(--primario);

  font-variation-settings: 
    "wght" 700,
    "opsz" 48;
}

h2 {
  font-size: clamp(2rem, 1.2rem + 2vw, 3.5rem);
  font-weight: 725;

  font-variation-settings:
    "wght" 725,
    "opsz" 39;
}

h3 {
  font-size: clamp(1.5rem, 1.2rem + 1vw, 2.25rem);
font-weight: 500;font-weight: 500;
}

h4 {
  font-size: clamp(1.125rem, 1rem + 0.4vw, 1.5rem);
}

h2,
h3,
h4 {
  color: var(--primario);
  overflow-wrap: anywhere;
  word-break: normal;
  hyphens: none;
  max-inline-size: 32ch;
  text-wrap: balance;
}

/* Subrayado tipográfico */
a {
  text-underline-position: under;
}

/* Colofón */
.colofon {
  color: #595959;
}

main > section h3.colofon {
  font-size: large;
  padding-left: calc(100vw / 12);
}

.pie {
  font-size: medium;
  padding-left: calc(100vw / 12 + 0.05em);
}

/* Intro en la home */
main.inicio section:first-of-type h2 + p {
  font-size: clamp(1.5rem, 1rem + 1.2vw, 2.5rem);
  font-style: italic;
  padding-left: calc(100vw / 12);
  text-wrap: balance;
  max-inline-size: 32ch;
  line-height: normal;
  padding-bottom: 0.5em;

  font-weight: 500;

  font-variation-settings:
    "wght" 500,
    "opsz" 39;
}

main.inicio section:first-of-type h2 + p + .boton,
main.inicio section:first-of-type h2 + p + button {
  margin-left: calc(100vw / 12);
}

/* Bloques de texto principales */
main p,
main dl,
main ul {
  padding-left: calc(100vw / 12);
}

/* Listas en main */
main ul {
  list-style-position: outside;
}

main ul li {
  list-style-type: disc;
}

/* Si hay un <p> seguido de <ul>, los li van alineados “inside” */
p + ul > li {
  list-style-position: inside;
}

/* Botones dentro de main */
main .boton,
main button {
  margin-left: calc(100vw / 12);
}

/* Texto corrido y definiciones */
p,
dd {
  font-size: var(--tamañonormal);
  max-width: 47ch;
}

dd {
  padding-bottom: 0.5em;
}

/* Otros elementos de texto */
dl,
ul,
.boton,
button {
  font-size: var(--tamañonormal);
}

dt {
  font-weight: 600;

  font-variation-settings:
    "wght" 600,
    "opsz" 18;

  color: var(--primario);
}

/* Formularios – tipografía */
form label {
  font-size: clamp(0.9rem, 0.82rem + 0.28vw, 1.05rem);
}

footer {
  font-variant-numeric: lining-nums;
}

h3.colofon + p  {
  text-wrap: balance;
}

form input,
form select,
form textarea {
  font-size: clamp(0.9rem, 0.82rem + 0.28vw, 1.05rem);
  line-height: var(--interlinea);
  letter-spacing: var(--espaciadoletra);
  font-family: inherit;
  color: var(--secundario);
}

form input[type="submit"] {
  font-size: var(--tamañonormal);
}

/* Placeholder coherente con el “estado sin validar” */
form ::placeholder {
  font-size: clamp(0.9rem, 0.82rem + 0.28vw, 1.05rem);
  line-height: var(--interlinea);
  letter-spacing: var(--espaciadonegativo);
  font-family: inherit;
  color: var(--secundario);
  font-weight: 600;

  font-variation-settings:
    "wght" 600,
    "opsz" 19;
}

/* Abreviaturas sin subrayado */
abbr {
  text-decoration: none;
}

/* Versalitas y tracking reforzado */
.versalitas,
.boton,
button,
form input[type="submit"],
abbr {
  font-variant-caps: all-small-caps;
  letter-spacing: clamp(0.035em, 0.02em + 0.05vw, 0.08em);
}

/* Palabras no separables */
.noseparar {
  white-space: nowrap;
}

/* Nav secundario en servicios: quitar versalitas y peso de nav principal */
nav:nth-of-type(2) a {
  font-variant-caps: normal;
  font-weight: normal;
  font-size: medium;
  letter-spacing: normal;
}

header h1 a {
  color: inherit;       /* usa el color exacto del h1 */
  text-decoration: none;
}

header h1 a:hover {
  background-color: #fff;
  color: var(--primario);

  font-variation-settings:
    "wght" 400,
    "opsz" 48;
}

header h1 a:focus {
  color: #595959;
}

.color {
  color: var(--primario);
  padding-bottom: 0;
}

abbr {
  cursor: help;
}

body nav ul li:last-child a.rojo {
  color: var(--primario);
  text-decoration-color: var(--primario);
}