/* Styles para el mini tutorial: diseño responsivo y limpio */
:root {
  /* Variables principales: definidas para centralizar colores, medidas y fuente. */
  /* Variables de color y layout principales (tema claro por defecto) */
  --bg: #f7f7f9;
  --card: #ffffff;
  --accent: #6b4eff;
  --gris10: #1b1b1f; /* color principal del texto en tema claro */
  --gris20: #666978; /* color secundario / máscara */
  --max-width: 980px;
  --radius: 12px;
  --container-padding: 1rem;
  --font: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
}

/* Estilos base */
* {
  box-sizing: border-box;
}

html, body {
  height: 100%;
}

body {
  margin: 0;
  font-family: var(--font);
  background: var(--bg);
  color: var(--gris10);
  line-height: 1.45;
  transition: background-color 0.3s, color 0.3s; /* NUEVO */
}

/* Layout containers */
.container {
  width: calc(100% - 2rem);
  max-width: var(--max-width);
  margin: 0 auto;
  padding: var(--container-padding);
}

/* Header styles */
.site-header {
  background: linear-gradient(90deg, rgba(107,78,255,0.12), rgba(107,78,255,0.06));
  padding: 2rem 0 1.25rem;
  border-bottom: 1px solid rgba(0,0,0,0.04);
}

.site-title {
  margin: 0 0 0.25rem;
  font-size: clamp(1.5rem, 3.5vw, 2.25rem);
  color: var(--accent);
  letter-spacing: -0.5px;
}

.subtitle {
  margin: 0;
  color: var(--gris20);
}

/* Table of contents */
.t-contents {
  margin-top: 1rem;
  background: var(--card);
  border-radius: var(--radius);
  box-shadow: 0 6px 20px rgba(24,24,24,0.04);
  padding: 1rem;
}

.t-contents h2 {
  margin: 0 0 0.5rem;
}

.t-contents ol {
  margin: 0;
  padding-left: 1.1rem;
  list-style-type: none;
}

.t-contents a {
  color: var(--accent);
  text-decoration: none;
}

.t-contents a:hover {
  text-decoration: underline;
}

/* Main content */
main {
  padding: 2rem 0;
}

.tutorial-section h3 {
  margin: 0 0 0.5rem;
  color: var(--gris10);
}

.section-content {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 1rem;
  align-items: center;
}

.section-content img {
  width: 100%;
  height: 110px;
  object-fit: cover;
  border-radius: 8px;
  display: block;
}

.tips {
  margin-top: 0.25rem;
  color: var(--gris20);
  font-size: 0.95rem;
}

/* Footer */
.site-footer {
  border-top: 1px solid rgba(0,0,0,0.04);
  background: transparent;
  padding: 1rem 0 2rem;
}

.site-footer .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.75rem;
}

/* Media queries */
@media (max-width: 600px) {
  .section-content {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .section-content img {
    margin: 0 auto;
  }

  .site-footer .container {
    flex-direction: column;
    text-align: center;
    gap: 0.5rem;
  }

  .t-contents {
    padding: 0.75rem;
  }
}

/* Accessibility */
a:focus {
  outline: 3px solid rgba(107,78,255,0.18);
  outline-offset: 2px;
}





/* Estilos para el header y botón de tema - NUEVO */
.header-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}


/* Theme toggle button */
/* === NUEVO (añadido) ===
  Botón que alterna el tema (clases .boton-tema / :hover). Agregado para
  mantener la coherencia con el script de tema.
=== */
.boton-tema {
  background: var(--card);
  color: var(--gris10);
  border: 1px solid rgba(0, 0, 0, 0.1);
  padding: 8px 16px;
  border-radius: 6px;
  cursor: pointer;
}

.boton-tema:hover {
  background: var(--accent);
  color: white;
}


/* Dark theme */
/* === NUEVO (añadido) ===
  Variables redefinidas para el modo oscuro (.tema-oscuro). Este bloque
  permite cambiar todo el esquema solo añadiendo la clase al elemento raíz.
=== */
.tema-oscuro {
  --bg: #13141b;
  --card: #1c1d26;
  --gris10: #ffffff;
  --gris20: #9193a5;
}