/* Colores base */
:root {
    --azul-pastel: #eaf6ff;
    --azul-pastel-oscuro: #a3d8f4;
    --azul-profesional: #4a90e2;
    --verde-habilitado: #d4edda;
    --azul-muy-claro: #f0f9ff;
    --texto: #333;
    --blanco: #fff;
}

/* Estructura general */
body {
    font-family: Arial, sans-serif;
    margin: 0;
    padding: 0;
    background-color: var(--azul-pastel);
    color: var(--texto);
}

/* Cabecera y Navbar */
header,
.navbar {
    background-color: var(--azul-pastel-oscuro);
    color: var(--blanco);
    padding: 20px;
    text-align: center;
    box-shadow: 0 4px 6px rgba(163,216,244,0.15);
}

header h1,
.navbar h2 {
    margin: 0;
    font-size: 2.5em;
}

header p {
    margin: 5px 0 0;
    font-size: 1.2em;
}

/* Menú de iconos */
.menu {
    display: flex;
    gap: 1rem;
    align-items: center;
    justify-content: flex-end;
}

.menu a {
    color: var(--blanco);
    text-decoration: none;
    font-size: 1rem;
}

.menu a:hover {
    text-decoration: underline;
}

.menu img {
    width: 24px;
    height: 24px;
    vertical-align: middle;
}

/* Contenedor principal */
.container,
.login-container {
    background: var(--blanco);
    border-radius: 10px;
    box-shadow: 0 4px 15px rgba(163,216,244,0.15);
    margin: 7rem auto 0 auto;
    max-width: 1000px;
    padding: 2rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.login-container {
    max-width: 400px;
    box-shadow: 0 4px 15px rgba(163,216,244,0.5);
}

h1, h2, h3 {
    color: var(--azul-profesional);
    margin-top: 0;
    text-align: center;
}

/* Mensajes de estado */
.error {
    color: #e74c3c;
    text-align: center;
    margin-bottom: 1rem;
}

.success {
    color: #27ae60;
    text-align: center;
    margin-bottom: 1rem;
}

/* Tabla de contenidos */
.table-container {
    overflow-x: auto;
    margin-top: 1rem;
    margin-bottom: 2rem;
}

table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 2rem;
    font-size: 1rem;
}

th, td {
    padding: 0.8rem;
    text-align: left;
    word-wrap: break-word;
    border: 1px solid var(--azul-pastel-oscuro);
}

th {
    background: var(--azul-pastel-oscuro);
    color: var(--blanco);
    font-weight: bold;
}

tr.enabled-row {
    background-color: var(--verde-habilitado) !important;
}

/* Botones de acción con iconos */
.toggle-btn,
.delete-btn,
.edit-btn {
    background: none;
    border: none;
    padding: 0;
    margin: 0 10px;
    cursor: pointer;
    vertical-align: middle;
}

.toggle-btn img,
.delete-btn img,
.edit-btn img {
    width: 32px;
    height: 32px;
    transition: filter 0.2s;
}

.toggle-btn:hover img,
.delete-btn:hover img,
.edit-btn:hover img {
    filter: brightness(0.85) drop-shadow(0 0 2px var(--azul-profesional));
}

/* Botón crear contenido */
.create-content-btn {
    display: inline-block;
    text-decoration: none;
    background: var(--azul-profesional);
    color: var(--blanco);
    padding: 0.5rem 1rem;
    border-radius: 5px;
    text-align: center;
    margin: 0 auto;
    transition: background 0.3s ease;
}

.create-content-btn:hover {
    background: var(--azul-pastel-oscuro);
}

.create-content-container {
    text-align: center;
    margin-bottom: 0;
}

/* Login y formularios */
.login-container h1 {
    margin-bottom: 1.5rem;
    font-size: 2rem;
    color: var(--azul-profesional);
}

.login-container form {
    display: flex;
    flex-direction: column;
}

.login-container input {
    padding: 0.8rem;
    margin-bottom: 1rem;
    border: 1px solid var(--azul-pastel-oscuro);
    border-radius: 5px;
    font-size: 1rem;
    background: var(--azul-muy-claro);
    color: var(--texto);
}

.login-container button {
    padding: 0.8rem;
    background: var(--azul-pastel-oscuro);
    border: none;
    border-radius: 5px;
    color: var(--blanco);
    font-size: 1rem;
    cursor: pointer;
    transition: background 0.3s ease;
}

.login-container button:hover {
    background: var(--azul-profesional);
}

.login-container a {
    color: var(--azul-profesional);
    text-decoration: none;
    font-size: 0.9rem;
    margin-top: 1rem;
    display: inline-block;
}

.login-container a:hover {
    text-decoration: underline;
    color: var(--azul-pastel-oscuro);
}

/* Productos en index */
.productos {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}

.producto {
    flex: 1 1 calc(33.333% - 20px);
    background-color: var(--azul-muy-claro);
    padding: 15px;
    border-radius: 10px;
    text-align: center;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.producto img {
    max-width: 100%;
    border-radius: 10px;
}

/* Footer */
footer,
.login-footer {
    background-color: var(--azul-pastel-oscuro);
    color: var(--blanco);
    text-align: center;
    padding: 10px 0;
    position: relative;
    font-size: 0.9rem;
    box-shadow: 0 -2px 5px rgba(163,216,244,0.15);
}

footer p,
.login-footer p {
    margin: 0;
}

.login-footer a {
    font-size: 0.7rem;
    color: var(--blanco);
}

/* Enlaces generales */
a {
    color: var(--azul-profesional);
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
    color: var(--azul-pastel-oscuro);
}

/* Responsive */
@media (max-width: 900px) {
    .container,
    .login-container {
        padding: 1rem;
        max-width: 98vw;
    }
    table {
        font-size: 0.95rem;
    }
    th, td {
        padding: 0.5rem;
    }
    h1 {
        font-size: 1.5rem;
    }
}

@media (max-width: 600px) {
    .container,
    .login-container {
        padding: 0.5rem;
        max-width: 100vw;
        margin-top: 4rem;
    }
    table {
        font-size: 0.85rem;
    }
    th, td {
        padding: 0.3rem;
    }
    h1 {
        font-size: 1.2rem;
    }
    .productos {
        flex-direction: column;
        gap: 10px;
    }
    .producto {
        flex: 1 1 100%;
    }
}

@media (max-width: 400px) {
    table {
        font-size: 0.75rem;
    }
    th, td {
        padding: 0.15rem;
    }
    h1 {
        font-size: 1rem;
    }
}