/* ============================================================
   GALA MISS Y MÍSTER CASARICHE — Estilos principales
   ============================================================ */

:root {
    --color-primario: #1a2744;
    --color-primario-claro: #2c3e6b;
    --color-acento: #c9a84c;
    --color-acento-hover: #b8953e;
    --color-exito: #2d7a4f;
    --color-error: #b33a3a;
    --color-info: #2a6496;
    --color-fondo: #f4f1ed;
    --color-blanco: #ffffff;
    --color-texto: #2c2c2c;
    --color-texto-suave: #6b6b6b;
    --color-borde: #ddd8d0;
    --sombra-suave: 0 2px 12px rgba(0, 0, 0, 0.08);
    --sombra-media: 0 4px 20px rgba(0, 0, 0, 0.12);
    --radio-borde: 8px;
    --fuente-principal: 'Georgia', 'Times New Roman', serif;
    --fuente-sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --ancho-maximo: 800px;
}

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

html {
    font-size: 16px;
    scroll-behavior: smooth;
}

body {
    font-family: var(--fuente-sans);
    color: var(--color-texto);
    background-color: var(--color-fondo);
    line-height: 1.6;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

/* ---- CONTENEDOR ---- */

.contenedor {
    width: 100%;
    max-width: var(--ancho-maximo);
    margin: 0 auto;
    padding: 0 1.5rem;
}

/* ---- CABECERA ---- */

.cabecera {
    background: linear-gradient(135deg, var(--color-primario) 0%, var(--color-primario-claro) 100%);
    padding: 1rem 0;
    box-shadow: var(--sombra-suave);
}

.cabecera .contenedor {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem;
}

.logo {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    text-decoration: none;
    color: var(--color-blanco);
}

.logo-icono {
    font-size: 1.8rem;
    color: var(--color-acento);
}

.logo-texto {
    font-family: var(--fuente-principal);
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: 0.02em;
}

.nav-principal a {
    color: var(--color-acento);
    text-decoration: none;
    font-size: 0.9rem;
    font-weight: 500;
    padding: 0.4rem 1rem;
    border: 1px solid var(--color-acento);
    border-radius: var(--radio-borde);
    transition: all 0.2s ease;
}

.nav-principal a:hover {
    background-color: var(--color-acento);
    color: var(--color-primario);
}

/* ---- CONTENIDO PRINCIPAL ---- */

.contenido-principal {
    flex: 1;
    padding: 2.5rem 0;
}

/* ---- TARJETA ---- */

.tarjeta {
    background: var(--color-blanco);
    border-radius: var(--radio-borde);
    box-shadow: var(--sombra-suave);
    overflow: hidden;
}

.tarjeta-cabecera {
    background: linear-gradient(135deg, var(--color-primario) 0%, var(--color-primario-claro) 100%);
    color: var(--color-blanco);
    padding: 2rem 2.5rem;
    text-align: center;
}

.tarjeta-cabecera h1 {
    font-family: var(--fuente-principal);
    font-size: 1.8rem;
    margin-bottom: 0.4rem;
    color: var(--color-acento);
}

.tarjeta-cabecera p {
    font-size: 0.95rem;
    opacity: 0.85;
}

/* ---- FORMULARIO ---- */

form {
    padding: 2rem 2.5rem;
}

.campo {
    margin-bottom: 1.5rem;
}

.campo label {
    display: block;
    font-weight: 600;
    margin-bottom: 0.4rem;
    font-size: 0.9rem;
    color: var(--color-primario);
}

.requerido {
    color: var(--color-error);
}

.campo input[type="date"],
.campo select,
.campo textarea {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 2px solid var(--color-borde);
    border-radius: var(--radio-borde);
    font-size: 1rem;
    font-family: var(--fuente-sans);
    color: var(--color-texto);
    background-color: var(--color-blanco);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.campo input:focus,
.campo select:focus,
.campo textarea:focus {
    outline: none;
    border-color: var(--color-acento);
    box-shadow: 0 0 0 3px rgba(201, 168, 76, 0.15);
}

.campo textarea {
    resize: vertical;
    min-height: 80px;
}

.campo select {
    cursor: pointer;
}

.campo-contador {
    text-align: right;
    font-size: 0.8rem;
    color: var(--color-texto-suave);
    margin-top: 0.3rem;
}

.campo-error {
    display: block;
    color: var(--color-error);
    font-size: 0.85rem;
    margin-top: 0.3rem;
    min-height: 1.2em;
}

.campo-invalido input,
.campo-invalido select,
.campo-invalido textarea {
    border-color: var(--color-error);
}

.campo-acciones {
    text-align: center;
    padding-top: 1rem;
}

/* ---- BOTONES ---- */

.btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.8rem;
    border: none;
    border-radius: var(--radio-borde);
    font-size: 1rem;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.2s ease;
    font-family: var(--fuente-sans);
}

.btn-primario {
    background: linear-gradient(135deg, var(--color-acento) 0%, var(--color-acento-hover) 100%);
    color: var(--color-primario);
}

.btn-primario:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(201, 168, 76, 0.35);
}

.btn-secundario {
    background-color: var(--color-fondo);
    color: var(--color-primario);
    border: 2px solid var(--color-borde);
}

.btn-secundario:hover {
    background-color: var(--color-borde);
}

.btn-grande {
    padding: 1rem 2.5rem;
    font-size: 1.1rem;
}

/* ---- ALERTAS ---- */

.alerta {
    padding: 1rem 1.5rem;
    border-radius: var(--radio-borde);
    margin-bottom: 1.5rem;
    font-size: 0.95rem;
    border-left: 4px solid;
}

.alerta-exito {
    background-color: #e8f5ee;
    border-color: var(--color-exito);
    color: var(--color-exito);
}

.alerta-error {
    background-color: #fce8e8;
    border-color: var(--color-error);
    color: var(--color-error);
}

.alerta-info {
    background-color: #e8f0f8;
    border-color: var(--color-info);
    color: var(--color-info);
}

/* ---- FICHA ---- */

.ficha {
    background: var(--color-blanco);
    border-radius: var(--radio-borde);
    box-shadow: var(--sombra-media);
    overflow: hidden;
    max-width: 700px;
    margin: 0 auto;
}

.ficha-cabecera {
    background: linear-gradient(135deg, var(--color-primario) 0%, var(--color-primario-claro) 100%);
    color: var(--color-blanco);
    padding: 2.5rem 2rem;
    text-align: center;
    position: relative;
}

.ficha-emblema {
    font-size: 3rem;
    color: var(--color-acento);
    margin-bottom: 0.5rem;
}

.ficha-titulo {
    font-family: var(--fuente-principal);
    font-size: 1.5rem;
    color: var(--color-acento);
    margin-bottom: 0.3rem;
}

.ficha-subtitulo {
    font-size: 1rem;
    opacity: 0.8;
    margin-bottom: 0.8rem;
}

.ficha-categoria {
    display: inline-block;
    background-color: var(--color-acento);
    color: var(--color-primario);
    padding: 0.3rem 1.2rem;
    border-radius: 20px;
    font-weight: 700;
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.ficha-cuerpo {
    padding: 2rem 2.5rem;
}

.ficha-nombre-principal {
    text-align: center;
    padding-bottom: 1.5rem;
    margin-bottom: 1.5rem;
    border-bottom: 2px solid var(--color-fondo);
}

.ficha-nombre-principal h2 {
    font-family: var(--fuente-principal);
    font-size: 1.8rem;
    color: var(--color-primario);
}

.ficha-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}

.ficha-campo {
    margin-bottom: 1.2rem;
}

.ficha-etiqueta {
    display: block;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-acento-hover);
    margin-bottom: 0.3rem;
}

.ficha-valor {
    font-size: 1rem;
    color: var(--color-texto);
    line-height: 1.5;
}

.ficha-pie {
    background-color: var(--color-fondo);
    padding: 1rem 2rem;
    text-align: center;
    font-size: 0.85rem;
    color: var(--color-texto-suave);
    border-top: 1px solid var(--color-borde);
}

.ficha-actualizada {
    font-style: italic;
    margin-top: 0.3rem;
}

.ficha-acciones {
    display: flex;
    justify-content: center;
    gap: 1rem;
    margin-top: 2rem;
    flex-wrap: wrap;
}

/* ---- PIE DE PÁGINA ---- */

.pie {
    background-color: var(--color-primario);
    color: var(--color-blanco);
    text-align: center;
    padding: 1.5rem 0;
    font-size: 0.85rem;
    opacity: 0.9;
    margin-top: auto;
}

/* ---- ADMIN PLACEHOLDER ---- */

.admin-placeholder {
    text-align: center;
    padding: 4rem 2rem;
}

.admin-placeholder h1 {
    font-family: var(--fuente-principal);
    color: var(--color-primario);
    margin-bottom: 1rem;
}

.admin-placeholder p {
    color: var(--color-texto-suave);
    font-size: 1.1rem;
}

.admin-placeholder .icono-grande {
    font-size: 4rem;
    display: block;
    margin-bottom: 1rem;
    color: var(--color-acento);
}

/* ---- RESPONSIVE ---- */

@media (max-width: 600px) {
    .cabecera .contenedor {
        justify-content: center;
        text-align: center;
    }

    .logo-texto {
        font-size: 1rem;
    }

    form {
        padding: 1.5rem;
    }

    .tarjeta-cabecera {
        padding: 1.5rem;
    }

    .tarjeta-cabecera h1 {
        font-size: 1.4rem;
    }

    .ficha-cuerpo {
        padding: 1.5rem;
    }

    .ficha-grid {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .ficha-nombre-principal h2 {
        font-size: 1.4rem;
    }

    .ficha-acciones {
        flex-direction: column;
        align-items: center;
    }

    .btn-grande {
        width: 100%;
        justify-content: center;
    }
}
