/* /public/css/admin_styles.css */

/* --- Variables Específicas Admin --- */
:root {
    --admin-bg-light: #f8f9fa; /* Fondo general */
    --admin-bg-white: #ffffff;
    --admin-border-color: #dee2e6; /* Bordes sutiles */
    --admin-text-color: #495057; /* Texto principal */
    --admin-text-muted: #6c757d;
    --admin-text-dark: #212529;
    --admin-primary-color: #6c757d; /* Azul Bootstrap como primario */
    --admin-primary-color-rgb: 13, 110, 253;
    --admin-primary-hover: #6c757d;
    --admin-secondary-color: #6c757d; /* Gris Bootstrap */
    --admin-secondary-hover: #5c636a;
    --admin-success-color: #198754;
    --admin-danger-color: #dc3545;
    --admin-warning-color: #ffc107;
    --admin-info-color: #0dcaf0;

    --admin-header-bg: var(--admin-bg-white);
    --admin-header-border: var(--admin-border-color);
    --admin-sidebar-bg: #343a40; /* Ejemplo si hubiera sidebar */
    --admin-sidebar-link: #adb5bd;
    --admin-sidebar-link-hover: #ffffff;

    --admin-font-family: 'Poppins', sans-serif; /* Usar la fuente base */
    --admin-base-font-size: 0.95rem; /* Ligeramente más pequeño */
    --admin-border-radius: 0.375rem; /* Bootstrap default */
    --admin-shadow-sm: 0 .125rem .25rem rgba(0,0,0,.075);
    --admin-shadow: 0 .5rem 1rem rgba(0,0,0,.15);
}

/* --- Estilo General Admin Body --- */
body.admin-body {
    background-color: var(--admin-bg-light);
    color: var(--admin-text-color);
    font-family: var(--admin-font-family);
    font-size: var(--admin-base-font-size);
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.admin-content-wrapper {
    flex: 1;
    display: flex;
    flex-direction: column;
}

/* Contenedor principal del contenido admin */
.admin-main {
    padding-top: 1.5rem;
    padding-bottom: 3rem;
    flex-grow: 1; /* Asegura que ocupe el espacio hasta el footer */
}

/* --- Header Admin --- */
.admin-header {
    background-color: var(--admin-header-bg);
    border-bottom: 1px solid var(--admin-header-border);
    box-shadow: var(--admin-shadow-sm);
    padding: 0.75rem 0; /* Ajuste padding */
}

.admin-header .navbar-brand {
    display: flex;
    align-items: center;
    padding-top: 0;
    padding-bottom: 0;
    margin-right: 1rem;
    font-size: 1.1rem; /* Ajuste tamaño */
    color: var(--admin-text-dark);
    font-weight: 600;
}

.admin-logo {
    height: 30px; /* Ajustar según el logo */
    width: auto;
}

.admin-brand-text {
    line-height: 1;
}

.admin-header .navbar-nav .nav-link {
    color: var(--admin-text-muted);
    padding: 0.6rem 1rem;
    font-size: 0.9rem;
    font-weight: 500;
    border-radius: var(--admin-border-radius);
    transition: color 0.2s ease, background-color 0.2s ease;
}

.admin-header .navbar-nav .nav-link:hover {
    color: var(--admin-text-dark);
    background-color: rgba(0,0,0,0.05);
}

.admin-header .navbar-nav .nav-link.active {
    color: var(--admin-primary-color);
    font-weight: 600;
    background-color: rgba(var(--admin-primary-color-rgb), 0.1);
}

.admin-header .navbar-toggler {
    border-color: rgba(0,0,0,0.1);
}
.admin-header .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(33, 37, 41, 0.75)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* Acciones del Header (Usuario, Ver Sitio) */
.admin-header-actions {
    gap: 0.75rem;
}
.admin-user-dropdown {
    color: var(--admin-text-muted);
    display: flex !important; /* Forzar flex para alinear icono y texto */
    align-items: center;
}
.admin-user-dropdown:hover {
    color: var(--admin-text-dark);
}
.admin-user-dropdown .admin-user-name {
    font-size: 0.9rem;
    font-weight: 500;
}
.admin-header .dropdown-menu {
    box-shadow: var(--admin-shadow);
    border-color: var(--admin-border-color);
    font-size: 0.9rem;
}
.admin-header .dropdown-item {
    padding: 0.5rem 1rem;
}
.admin-header .dropdown-item i {
    width: 1.5em; /* Espacio para el icono */
    color: var(--admin-text-muted);
}
.admin-header .btn-outline-secondary {
    border-color: var(--admin-border-color);
    color: var(--admin-text-muted);
    font-size: 0.85rem;
    padding: 0.3rem 0.7rem;
}
.admin-header .btn-outline-secondary:hover {
    background-color: var(--admin-secondary-color);
    color: var(--admin-bg-white);
    border-color: var(--admin-secondary-color);
}

/* --- Estilos Dashboard --- */
.admin-dashboard {
    background-color: var(--admin-bg-white);
    border: 1px solid var(--admin-border-color);
    border-radius: var(--admin-border-radius);
    /* Padding añadido directamente en el HTML con p-4 p-lg-5 */
}

/* --- Estilos para Tarjetas (Cards) --- */
.admin-main .card {
    border: 1px solid var(--admin-border-color);
    border-radius: var(--admin-border-radius);
    box-shadow: var(--admin-shadow-sm);
    margin-bottom: 1.5rem; /* Espaciado por defecto */
}
.admin-main .card-header {
    background-color: var(--admin-bg-light);
    border-bottom: 1px solid var(--admin-border-color);
    font-weight: 600;
    color: var(--admin-text-dark);
    padding: 0.9rem 1.25rem; /* === AJUSTE: Más padding vertical === */
    font-size: 1rem;
    /* Alineación vertical añadida en HTML (d-flex align-items-center) */
}
.admin-main .card-header i {
    /* Color se puede añadir en HTML (ej: text-primary) */
    margin-right: 0.6rem; /* === AJUSTE: Más espacio === */
    font-size: 1.05em; /* Ligeramente más grande */
    line-height: 1; /* Asegurar alineación */
}
.admin-main .card-body {
    padding: 1.25rem;
}
/* Si el card-body no tiene padding (p-0 para tablas) */
.admin-main .card-body.p-0 .table-responsive {
    border-radius: 0 0 var(--admin-border-radius) var(--admin-border-radius); /* Redondear esquinas inferiores */
    overflow: hidden; /* Asegurar que el borde redondeado funcione */
}

.admin-main .card-footer {
     background-color: var(--admin-bg-light);
     border-top: 1px solid var(--admin-border-color);
     padding: 0.75rem 1.25rem;
}

/* === AJUSTE: Estilos específicos Widget Dashboard === */
.admin-card-widget .list-group-item {
    border-left: 0;
    border-right: 0;
    border-radius: 0;
    color: var(--admin-text-color);
    font-weight: 500;
    transition: background-color 0.2s ease, color 0.2s ease, padding-left 0.2s ease;
    padding: 0.9rem 1.25rem; /* === AJUSTE: Más padding === */
    /* d-flex align-items-center se añade en HTML */
}
.admin-card-widget .list-group-item-icon {
    /* Color se puede añadir en HTML (ej: text-primary) */
    width: 1.7em; /* Más espacio icono */
    font-size: 1.05em; /* Ligeramente más grande */
    margin-right: 0.75rem !important; /* === AJUSTE: Más margen derecho === */
    text-align: center;
    color: var(--admin-text-muted); /* Color base para iconos */
}
.admin-card-widget .list-group-item:hover {
    background-color: rgba(var(--admin-primary-color-rgb), 0.05); /* Fondo suave */
    color: var(--admin-primary-color);
    padding-left: 1.5rem; /* Indentación al hacer hover */
}
.admin-card-widget .list-group-item:hover .list-group-item-icon {
    color: var(--admin-primary-color); /* Icono hereda color */
}
.admin-card-widget .list-group-item:first-child { border-top: 0;}
.admin-card-widget .list-group-item:last-child { border-bottom: 0;}
.admin-card-widget .list-group-item.disabled,
.admin-card-widget .list-group-item.disabled:hover {
    background-color: transparent;
    color: var(--admin-text-muted);
    padding-left: 1.25rem; /* Reset indent */
    cursor: not-allowed;
}
.admin-card-widget .list-group-item.disabled .list-group-item-icon {
     color: var(--admin-text-muted) !important; /* Forzar gris en deshabilitado */
     opacity: 0.6;
}


/* --- Estilos para Tablas --- */
.admin-main .table {
    margin-bottom: 0;
    border-color: var(--admin-border-color);
    color: var(--admin-text-color);
    table-layout: auto; /* Default: auto */
    width: 100%;
}
/* Usar fixed solo cuando se definen anchos específicos */
.admin-main table#photo-slider-table {
    table-layout: fixed;
}

.admin-main .table thead {
    background-color: var(--admin-bg-light);
    border-bottom: 2px solid var(--admin-border-color);
    color: var(--admin-text-dark);
    vertical-align: bottom; /* Mejor alineación cabecera */
}
.admin-main .table thead th {
    border-bottom-width: 0;
    font-size: 0.85rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 0.85rem 1rem;
    white-space: nowrap;
    vertical-align: middle;
}
.admin-main .table tbody td {
    font-size: 0.9rem;
    vertical-align: middle;
    padding: 0.85rem 1rem;
}
.admin-main .table tbody tr:hover {
    background-color: rgba(0,0,0,0.03);
}
.admin-main .table th[scope="row"] {
     font-weight: 600;
     color: var(--admin-text-dark);
}
.admin-main .table .table-light.fw-bold td,
.admin-main .table .table-light.fw-bold th {
    font-weight: 600 !important;
    background-color: #e9ecef !important;
    color: var(--admin-text-dark);
}
.admin-main .table .badge {
    font-size: 0.75rem;
    padding: 0.35em 0.6em;
    font-weight: 600;
    vertical-align: middle;
}
.admin-main .table img { /* Estilo general imagen tabla */
    max-height: 45px;
    max-width: 100%;
    height: auto;
    width: auto;
    border-radius: 3px;
    border: 1px solid var(--admin-border-color);
    background-color: var(--admin-bg-light);
    object-fit: contain;
    vertical-align: middle;
    display: inline-block;
}

/* Estilos generales para botones de acción en tablas */
.admin-main .table .action-btn-group {
    white-space: nowrap;
    display: inline-flex;
    vertical-align: middle; /* Alinear grupo verticalmente */
}
.admin-main .table .action-btn {
    padding: 0.3rem 0.6rem;
    font-size: 0.85rem;
    line-height: 1.2; /* Ajuste línea */
    min-width: 34px; /* Ancho mínimo botón */
    display: inline-flex; /* Usar flex para centrar icono */
    justify-content: center;
    align-items: center;
}
.admin-main .table .action-btn i {
    margin-right: 0;
    font-size: 1em;
    /* vertical-align ya no es necesario con flex */
}
/* Eliminar borde doble entre botones en el grupo */
.admin-main .table .action-btn-group > form > .action-btn,
.admin-main .table .action-btn-group > a.action-btn + form > .action-btn {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    margin-left: -1px;
}
.admin-main .table .action-btn-group > *:not(:last-child) > .action-btn {
     border-top-right-radius: 0;
     border-bottom-right-radius: 0;
}


/* === AJUSTE: Estilos específicos para #photo-slider-table === */
#photo-slider-table .photo-slider-preview-img {
    max-height: 80px; /* Aumentamos un poco más */
    max-width: 100%; /* Que ocupe el ancho disponible en la celda */
    object-fit: cover;
}

/* Definir anchos de columna (Ajustados) */
#photo-slider-table th.col-id,
#photo-slider-table td:nth-child(1) {
    width: 5%;
}
#photo-slider-table th.col-image,
#photo-slider-table td:nth-child(2) {
    width: 20%; /* Más espacio para la imagen */
}
#photo-slider-table th.col-alt,
#photo-slider-table td:nth-child(3) {
    width: 25%; /* Reducido de 40% */
}
#photo-slider-table th.col-order,
#photo-slider-table td:nth-child(4) {
    width: 10%;
    text-align: center;
}
#photo-slider-table th.col-active,
#photo-slider-table td:nth-child(5) {
    width: 10%;
    text-align: center;
}
#photo-slider-table th.col-actions,
#photo-slider-table td:nth-child(6) {
    width: 15%;
    text-align: center;
}
/* Truncar texto Alt Text */
#photo-slider-table .text-truncate {
    display: block;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    vertical-align: middle;
}
/* === FIN AJUSTE === */


/* --- Estilos Formularios Admin --- */
.admin-main form label {
    font-weight: 500;
    font-size: 0.9rem;
    margin-bottom: 0.4rem;
    color: var(--admin-text-dark);
}
.admin-main form .form-control,
.admin-main form .form-select {
    font-size: 0.9rem;
    border-color: var(--admin-border-color);
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}
/* Input más grande */
.admin-main form .form-control-lg {
    font-size: 1.1rem;
    padding: 0.6rem 1rem;
}
.admin-main form .form-control:focus,
.admin-main form .form-select:focus {
    border-color: rgba(var(--admin-primary-color-rgb), 0.5);
    box-shadow: 0 0 0 0.2rem rgba(var(--admin-primary-color-rgb), 0.25);
    outline: 0;
}
.admin-main form textarea.form-control {
    min-height: 100px;
}
.admin-main form .form-text,
.admin-main form .text-muted {
    font-size: 0.85rem; /* Ligeramente más grande */
    display: block; /* Asegurar que ocupe línea */
    margin-top: 0.25rem;
}
.admin-main form .form-check-label {
    font-weight: normal;
    font-size: 0.9rem;
    color: var(--admin-text-color);
}
.admin-main form .form-switch .form-check-input {
    cursor: pointer;
}
.admin-main form .form-switch .form-check-input:checked {
    background-color: var(--admin-primary-color);
    border-color: var(--admin-primary-color);
}

/* Botones de Formulario */
.admin-main form .btn {
    font-size: 0.9rem; /* Tamaño base botón */
    font-weight: 500;
}
.admin-main form .btn-primary {
    background-color: var(--admin-primary-color);
    border-color: var(--admin-primary-color);
}
.admin-main form .btn-primary:hover {
    background-color: var(--admin-primary-hover);
    border-color: var(--admin-primary-hover);
}
.admin-main form .btn-secondary {
    background-color: var(--admin-secondary-color);
    border-color: var(--admin-secondary-color);
    color: #fff;
}
.admin-main form .btn-secondary:hover {
    background-color: var(--admin-secondary-hover);
    border-color: var(--admin-secondary-hover);
}
.admin-main form .btn-outline-secondary {
    border-color: var(--admin-secondary-color);
    color: var(--admin-secondary-color);
}
.admin-main form .btn-outline-secondary:hover {
    background-color: var(--admin-secondary-color);
    color: #fff;
}
.admin-main form .btn i {
    margin-right: 0.35rem;
    font-size: 0.9em;
}

/* --- Estilos Login Page --- */
body.admin-login-body {
    background-color: var(--admin-bg-light);
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    padding: 1rem;
}
.login-card {
    background-color: var(--admin-bg-white);
    padding: 2.5rem;
    border-radius: var(--admin-border-radius);
    border: 1px solid var(--admin-border-color);
    box-shadow: var(--admin-shadow);
    width: 100%;
    max-width: 420px;
    margin: 1rem auto;
}
.login-logo img {
    max-height: 45px;
    margin-bottom: 1.5rem;
}
.login-card h2 {
    color: var(--admin-text-dark);
    font-weight: 600;
    font-size: 1.3rem; /* Ajuste tamaño */
}
.login-card .form-label {
    font-weight: 500;
    font-size: 0.9rem; /* Asegurar consistencia */
}
.login-card .form-control {
    border-color: var(--admin-border-color);
    font-size: 0.95rem;
}
.login-card .form-control:focus {
    border-color: rgba(var(--admin-primary-color-rgb), 0.5);
    box-shadow: 0 0 0 0.2rem rgba(var(--admin-primary-color-rgb), 0.25);
    outline: 0;
}
.login-card .input-group-text {
     background-color: var(--admin-bg-light);
     border-color: var(--admin-border-color);
     color: var(--admin-text-muted);
}
.login-card .btn-login {
    background-color: var(--admin-primary-color);
    border-color: var(--admin-primary-color);
    color: #fff;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 0.65rem; /* Ajuste padding */
    font-size: 0.95rem; /* Ajuste tamaño */
    transition: background-color .15s ease-in-out, border-color .15s ease-in-out;
}
.login-card .btn-login:hover {
    background-color: var(--admin-primary-hover);
    border-color: var(--admin-primary-hover);
}
.login-card .alert-danger {
    background-color: #f8d7da;
    border-color: #f5c2c7;
    color: #842029;
    font-size: 0.85rem;
    padding: 0.75rem 1rem;
}
.login-card .alert-danger .btn-close {
    padding: 0.75rem 1rem;
}

/* --- Footer Admin --- */
.admin-footer {
    background-color: var(--admin-bg-white);
    color: var(--admin-text-muted);
    font-size: 0.85rem;
    border-top: 1px solid var(--admin-border-color);
    padding: 1rem 0;
    margin-top: auto; /* Empuja al final */
}
.admin-footer small {
    display: block;
}

/* --- Responsive Adjustments --- */
@media (max-width: 991.98px) {
    .admin-header .navbar-collapse {
        margin-top: 0.5rem;
        border-top: 1px solid var(--admin-border-color);
        padding-top: 0.5rem;
        padding-bottom: 0.5rem;
        background-color: var(--admin-header-bg);
        box-shadow: var(--admin-shadow-sm);
        position: absolute;
        top: calc(100% - 1px); /* Ajustar posición */
        left: 0;
        right: 0;
        z-index: 10;
        max-height: calc(100vh - 70px); /* Limitar altura */
        overflow-y: auto; /* Scroll si es necesario */
    }
    .admin-header .navbar-nav {
        align-items: flex-start;
        padding-left: 1rem;
        padding-right: 1rem;
    }
    .admin-header .admin-header-actions {
        padding: 0.75rem 1rem;
        margin-top: 0.5rem;
        border-top: 1px solid var(--admin-border-color);
        width: 100%;
        justify-content: flex-start;
    }
    .admin-header .dropdown-menu {
        position: static !important;
        width: 100%;
        box-shadow: none;
        border: none;
        margin-top: 0.5rem;
        background-color: transparent;
    }
    .admin-header .dropdown-item {
        padding-left: 0.5rem;
    }
     /* Ocultar nombre usuario en móvil */
     .admin-user-dropdown .admin-user-name.d-none.d-lg-inline {
        display: none !important;
    }
    /* Ocultar texto 'Ver Sitio' en móvil */
    .admin-header .btn-outline-secondary .d-none.d-lg-inline {
        display: none !important;
    }
     .admin-header .btn-outline-secondary {
         padding: 0.3rem 0.6rem; /* Hacer botón un poco más pequeño */
     }

    /* Ajustar anchos de columna tabla slider fotos en móvil */
    #photo-slider-table {
        table-layout: auto; /* Volver a auto en móvil */
    }
    #photo-slider-table th, #photo-slider-table td {
        width: auto !important; /* Resetear anchos fijos */
        min-width: 0 !important;
    }
    #photo-slider-table .text-truncate {
        max-width: 150px; /* Limitar truncado en móvil */
    }
     #photo-slider-table th.col-actions,
     #photo-slider-table td:nth-child(6) {
         text-align: right; /* Alinear acciones a la derecha en móvil */
     }
}