/* ============================================================
   assets/css/base.css
   Variables globales + reset + tipografía
   Reemplaza Tailwind CDN — importar primero
   ============================================================ */

/* --- Variables de diseño ----------------------------------- */
:root {
    /* Colores */
    --color-primary:     #009EE3;
    --color-primary-dk:  #007bb5;
    --color-dark:        #0f172a;
    --color-dark-soft:   #1e293b;
    --color-mid:         #334155;
    --color-muted:       #64748b;
    --color-border:      #e2e8f0;
    --color-bg:          #f8fafc;
    --color-white:       #ffffff;

    /* Semánticos */
    --color-success:     #22c55e;
    --color-warning:     #f59e0b;
    --color-danger:      #ef4444;
    --color-info:        #3b82f6;

    /* Tipografía */
    --font-base:         'Inter', system-ui, -apple-system, sans-serif;
    --font-size-xs:      0.75rem;    /* 12px */
    --font-size-sm:      0.875rem;   /* 14px */
    --font-size-base:    1rem;       /* 16px */
    --font-size-lg:      1.125rem;   /* 18px */
    --font-size-xl:      1.25rem;    /* 20px */
    --font-size-2xl:     1.5rem;     /* 24px */
    --font-size-3xl:     1.875rem;   /* 30px */
    --font-size-4xl:     2.25rem;    /* 36px */

    /* Espaciado */
    --space-1:   0.25rem;
    --space-2:   0.5rem;
    --space-3:   0.75rem;
    --space-4:   1rem;
    --space-5:   1.25rem;
    --space-6:   1.5rem;
    --space-8:   2rem;
    --space-10:  2.5rem;
    --space-12:  3rem;
    --space-16:  4rem;

    /* Bordes */
    --radius-sm:   0.375rem;
    --radius-md:   0.75rem;
    --radius-lg:   1rem;
    --radius-xl:   1.5rem;
    --radius-full: 9999px;

    /* Sombras */
    --shadow-sm:  0 1px 2px rgba(0,0,0,.06);
    --shadow-md:  0 4px 12px rgba(0,0,0,.10);
    --shadow-lg:  0 8px 32px rgba(0,0,0,.14);
    --shadow-xl:  0 20px 60px rgba(0,0,0,.18);

    /* Transiciones */
    --transition: 0.2s ease;

    /* Layout */
    --container-max: 1200px;
    --container-pad: var(--space-4);
}

/* --- Reset ------------------------------------------------- */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
}

body {
    font-family: var(--font-base);
    font-size: var(--font-size-base);
    color: var(--color-dark);
    background-color: var(--color-bg);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}

img, video {
    max-width: 100%;
    height: auto;
    display: block;
}

a {
    color: var(--color-primary);
    text-decoration: none;
    transition: color var(--transition);
}

a:hover { color: var(--color-primary-dk); }

ul, ol { list-style: none; }

button, input, select, textarea {
    font-family: inherit;
    font-size: inherit;
}

button { cursor: pointer; }

/* --- Contenedor -------------------------------------------- */
.container {
    width: 100%;
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-pad);
}

/* --- Tipografía utilitaria --------------------------------- */
.text-xs   { font-size: var(--font-size-xs); }
.text-sm   { font-size: var(--font-size-sm); }
.text-base { font-size: var(--font-size-base); }
.text-lg   { font-size: var(--font-size-lg); }
.text-xl   { font-size: var(--font-size-xl); }
.text-2xl  { font-size: var(--font-size-2xl); }
.text-3xl  { font-size: var(--font-size-3xl); }
.text-4xl  { font-size: var(--font-size-4xl); }

.font-normal   { font-weight: 400; }
.font-semibold { font-weight: 600; }
.font-bold     { font-weight: 700; }
.font-extrabold{ font-weight: 800; }

.text-center { text-align: center; }
.text-left   { text-align: left; }
.text-right  { text-align: right; }

.uppercase     { text-transform: uppercase; }
.tracking-wide { letter-spacing: 0.05em; }
.tracking-wider{ letter-spacing: 0.1em; }

.text-muted   { color: var(--color-muted); }
.text-primary { color: var(--color-primary); }
.text-white   { color: var(--color-white); }
.text-dark    { color: var(--color-dark); }

/* --- Flex / Grid utilitario -------------------------------- */
.flex         { display: flex; }
.inline-flex  { display: inline-flex; }
.grid         { display: grid; }
.block        { display: block; }
.hidden       { display: none; }

.items-center  { align-items: center; }
.items-start   { align-items: flex-start; }
.justify-center{ justify-content: center; }
.justify-between{ justify-content: space-between; }
.flex-col      { flex-direction: column; }
.flex-wrap     { flex-wrap: wrap; }
.gap-2  { gap: var(--space-2); }
.gap-3  { gap: var(--space-3); }
.gap-4  { gap: var(--space-4); }
.gap-6  { gap: var(--space-6); }
.gap-8  { gap: var(--space-8); }

/* --- Spacing utilitario ------------------------------------ */
.p-4  { padding: var(--space-4); }
.p-6  { padding: var(--space-6); }
.p-8  { padding: var(--space-8); }
.px-4 { padding-inline: var(--space-4); }
.py-2 { padding-block: var(--space-2); }
.py-4 { padding-block: var(--space-4); }
.py-8 { padding-block: var(--space-8); }
.py-16{ padding-block: var(--space-16); }
.mt-2 { margin-top: var(--space-2); }
.mt-4 { margin-top: var(--space-4); }
.mt-6 { margin-top: var(--space-6); }
.mt-8 { margin-top: var(--space-8); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-6 { margin-bottom: var(--space-6); }
.mb-8 { margin-bottom: var(--space-8); }
.mx-auto { margin-inline: auto; }

/* --- Width / Height utilitario ----------------------------- */
.w-full  { width: 100%; }
.h-full  { height: 100%; }
.min-h-screen { min-height: 100vh; }
.max-w-sm  { max-width: 24rem; }
.max-w-md  { max-width: 28rem; }
.max-w-lg  { max-width: 32rem; }
.max-w-xl  { max-width: 36rem; }
.max-w-2xl { max-width: 42rem; }

/* --- Colores de fondo utilitario --------------------------- */
.bg-white     { background-color: var(--color-white); }
.bg-dark      { background-color: var(--color-dark); }
.bg-dark-soft { background-color: var(--color-dark-soft); }
.bg-primary   { background-color: var(--color-primary); }
.bg-slate-900 { background-color: #0f172a; }
.bg-slate-800 { background-color: #1e293b; }

/* --- Border radius utilitario ------------------------------ */
.rounded    { border-radius: var(--radius-sm); }
.rounded-md { border-radius: var(--radius-md); }
.rounded-lg { border-radius: var(--radius-lg); }
.rounded-xl { border-radius: var(--radius-xl); }
.rounded-2xl{ border-radius: 1rem; }
.rounded-full{ border-radius: var(--radius-full); }

/* --- Sombras utilitario ------------------------------------ */
.shadow    { box-shadow: var(--shadow-sm); }
.shadow-md { box-shadow: var(--shadow-md); }
.shadow-lg { box-shadow: var(--shadow-lg); }
.shadow-xl { box-shadow: var(--shadow-xl); }
.shadow-2xl{ box-shadow: 0 25px 50px rgba(0,0,0,.25); }

/* --- Overflow ---------------------------------------------- */
.overflow-hidden { overflow: hidden; }
.truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* --- Posición ---------------------------------------------- */
.relative { position: relative; }
.absolute { position: absolute; }
.fixed    { position: fixed; }
.inset-0  { inset: 0; }

/* --- Responsive -------------------------------------------- */
@media (min-width: 640px) {
    :root { --container-pad: var(--space-6); }
}
@media (min-width: 1024px) {
    :root { --container-pad: var(--space-8); }
}
