/* ============================================
   BASE CSS - Estilos fundamentales
   ============================================ */

/* 1. Configuración base del body */
body {
    font-family: var(--font-family-primary);
    font-size: var(--font-size-base);
    line-height: var(--line-height-normal);
    color: var(--color-gray-800);
    background-color: var(--color-white);
    overflow-x: hidden;
}

/* 2. Configuración de enlaces */
a {
    color: var(--color-primary);
    text-decoration: none;
    transition: color var(--transition-fast);
}

a:hover {
    color: var(--color-primary-dark);
}

a:focus {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
}

/* 3. Encabezados */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-family-heading);
    font-weight: var(--font-weight-bold);
    line-height: var(--line-height-tight);
    color: var(--color-gray-900);
    margin-bottom: var(--spacing-4);
}

h1 {
    font-size: var(--font-size-4xl);
}

h2 {
    font-size: var(--font-size-3xl);
}

h3 {
    font-size: var(--font-size-2xl);
}

h4 {
    font-size: var(--font-size-xl);
}

h5 {
    font-size: var(--font-size-lg);
}

h6 {
    font-size: var(--font-size-base);
}

/* 4. Párrafos y texto */
p {
    margin-bottom: var(--spacing-4);
}

small {
    font-size: var(--font-size-sm);
}

strong, b {
    font-weight: var(--font-weight-bold);
}

em, i {
    font-style: italic;
}

/* 5. Listas */
ul:not([class]),
ol:not([class]) {
    list-style-position: inside;
    margin-bottom: var(--spacing-4);
    padding-left: var(--spacing-4);
}

ul:not([class]) {
    list-style-type: disc;
}

ol:not([class]) {
    list-style-type: decimal;
}

li:not([class]) {
    margin-bottom: var(--spacing-2);
}

/* 6. Citas */
blockquote {
    border-left: 4px solid var(--color-primary);
    padding-left: var(--spacing-4);
    margin: var(--spacing-6) 0;
    font-style: italic;
    color: var(--color-gray-700);
}

cite {
    display: block;
    margin-top: var(--spacing-2);
    font-size: var(--font-size-sm);
    color: var(--color-gray-600);
    font-style: normal;
}

/* 7. Código y preformateado */
code {
    font-family: 'Courier New', monospace;
    background-color: var(--color-gray-100);
    padding: 2px 6px;
    border-radius: var(--border-radius-sm);
    font-size: var(--font-size-sm);
}

pre {
    background-color: var(--color-gray-100);
    padding: var(--spacing-4);
    border-radius: var(--border-radius);
    overflow-x: auto;
    margin-bottom: var(--spacing-4);
}

pre code {
    background: none;
    padding: 0;
}

/* 8. Líneas horizontales */
hr {
    border: none;
    height: 1px;
    background-color: var(--color-gray-200);
    margin: var(--spacing-8) 0;
}

/* 9. Imágenes responsivas */
img {
    max-width: 100%;
    height: auto;
    display: block;
}

figure {
    margin: var(--spacing-6) 0;
}

figcaption {
    text-align: center;
    font-size: var(--font-size-sm);
    color: var(--color-gray-600);
    margin-top: var(--spacing-2);
}

/* 10. Tablas */
table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: var(--spacing-6);
}

th {
    background-color: var(--color-gray-100);
    font-weight: var(--font-weight-semibold);
    text-align: left;
    padding: var(--spacing-3);
    border: 1px solid var(--color-gray-300);
}

td {
    padding: var(--spacing-3);
    border: 1px solid var(--color-gray-300);
}

tr:nth-child(even) {
    background-color: var(--color-gray-50);
}

/* 11. Formularios base */
input,
textarea,
select,
button {
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
}

/* 12. Clase utilitaria para contenedor */
.container {
    width: 100%;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--container-padding);
}

/* 13. Clase para cuando el menú está abierto */
.body-no-scroll {
    overflow: hidden !important;
    position: fixed;
    width: 100%;
    height: 100%;
}

/* 14. Soporte para WebP */
@supports (background: url('../assets/images/webp/hero-limpieza.webp')) {
    .hero {
        background-image: url('../assets/images/webp/hero-limpieza.webp');
    }
}