/* ========== ADMIN RESPONSIVE STYLES ========== */

/* Mobile First Approach */

/* ========== NAVBAR & DROPDOWN FIX ========== */
@media (max-width: 991px) {
    /* Fix dropdown dentro del menú colapsable */
    .navbar-collapse .dropdown-menu {
        position: static !important;
        float: none;
        width: auto;
        margin-top: 0;
        background-color: transparent;
        border: 0;
        box-shadow: none;
        padding-left: 1rem;
    }

    .navbar-collapse .dropdown-menu .dropdown-item {
        color: rgba(255, 255, 255, 0.8);
        padding: 0.5rem 1rem;
    }

    .navbar-collapse .dropdown-menu .dropdown-item:hover {
        background-color: rgba(255, 255, 255, 0.1);
        color: white;
    }

    /* Mantener el menú abierto cuando se hace click en dropdown */
    .navbar-collapse .dropdown-toggle::after {
        display: inline-block;
        margin-left: 0.5em;
        vertical-align: 0.255em;
        content: "";
        border-top: 0.3em solid;
        border-right: 0.3em solid transparent;
        border-bottom: 0;
        border-left: 0.3em solid transparent;
    }

    .navbar-collapse .dropdown-toggle[aria-expanded="true"]::after {
        transform: rotate(180deg);
    }
}

/* ========== DASHBOARD ADMIN RESPONSIVE ========== */
@media (max-width: 768px) {
    /* Container padding ajustado */
    .dashboard-admin {
        padding: 1rem !important;
    }

    /* Header responsive */
    .dashboard-admin h1.h3 {
        font-size: 1.5rem !important;
    }

    .dashboard-admin p.text-muted {
        font-size: 0.875rem !important;
    }

    /* Botones del header */
    .dashboard-admin .btn-group {
        flex-direction: column;
        width: 100%;
    }

    .dashboard-admin .btn {
        width: 100%;
        margin-bottom: 0.5rem;
        font-size: 0.875rem;
        padding: 0.5rem;
    }

    /* Stats cards responsive */
    .stats-card, .admin-card {
        margin-bottom: 1rem !important;
        padding: 1rem !important;
    }

    .stat-number {
        font-size: 1.5rem !important;
    }

    .admin-stat-icon {
        width: 50px !important;
        height: 50px !important;
        font-size: 1.25rem !important;
    }

    /* Tabla de usuarios - Convertir a cards en móvil */
    .admin-table {
        display: none;
    }

    /* Crear vista de cards para móvil */
    .mobile-user-cards {
        display: block !important;
    }

    /* Ocultar columnas menos importantes en tablets */
    @media (max-width: 576px) {
        .d-sm-table-cell {
            display: none !important;
        }
    }
}

/* ========== MOBILE USER CARDS ========== */
.mobile-user-card {
    background: white;
    border-radius: 10px;
    padding: 1rem;
    margin-bottom: 1rem;
    border: 1px solid #e0e0e0;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.mobile-user-card .user-header {
    display: flex;
    align-items: center;
    margin-bottom: 1rem;
}

.mobile-user-card .user-avatar {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-weight: bold;
    font-size: 1.25rem;
    margin-right: 1rem;
}

.mobile-user-card .user-info {
    flex: 1;
}

.mobile-user-card .user-name {
    font-weight: bold;
    font-size: 1rem;
    margin-bottom: 0.25rem;
}

.mobile-user-card .user-username {
    color: #6c757d;
    font-size: 0.875rem;
}

.mobile-user-card .user-details {
    font-size: 0.875rem;
    margin-bottom: 0.5rem;
}

.mobile-user-card .user-actions {
    display: flex;
    gap: 0.5rem;
    margin-top: 1rem;
}

.mobile-user-card .user-actions .btn {
    flex: 1;
    font-size: 0.875rem;
    padding: 0.5rem;
}

/* ========== LISTA DE CLIENTES RESPONSIVE ========== */
@media (max-width: 768px) {
    /* Convertir tabla a cards */
    .table-responsive {
        display: none;
    }

    .mobile-client-cards {
        display: block !important;
    }

    .client-card-mobile {
        background: white;
        border-radius: 10px;
        padding: 1rem;
        margin-bottom: 1rem;
        border: 1px solid #e0e0e0;
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    }

    .client-card-mobile .client-header {
        display: flex;
        justify-content: space-between;
        align-items: start;
        margin-bottom: 0.75rem;
    }

    .client-card-mobile .client-name {
        font-weight: bold;
        font-size: 1.1rem;
        color: #333;
    }

    .client-card-mobile .client-badge {
        font-size: 0.75rem;
        padding: 0.25rem 0.5rem;
    }

    .client-card-mobile .client-info {
        display: grid;
        gap: 0.5rem;
        font-size: 0.875rem;
        color: #666;
    }

    .client-card-mobile .client-info-item {
        display: flex;
        align-items: center;
    }

    .client-card-mobile .client-info-item i {
        width: 20px;
        color: #1e3a5f;
        margin-right: 0.5rem;
    }

    .client-card-mobile .client-actions {
        display: flex;
        gap: 0.5rem;
        margin-top: 1rem;
        padding-top: 1rem;
        border-top: 1px solid #f0f0f0;
    }

    .client-card-mobile .client-actions .btn {
        flex: 1;
        font-size: 0.875rem;
        padding: 0.5rem;
    }
}

/* ========== FORMULARIOS RESPONSIVE ========== */
@media (max-width: 768px) {
    /* Form builder tabs */
    .form-tabs .nav-link {
        font-size: 0.875rem;
        padding: 0.5rem;
    }

    .form-tabs .nav-link i {
        display: none;
    }

    /* Form builder content */
    .form-builder {
        padding: 1rem !important;
    }

    .question-item {
        padding: 0.75rem !important;
        margin-bottom: 0.75rem !important;
    }

    .question-controls {
        position: static !important;
        opacity: 1 !important;
        margin-top: 0.5rem;
        display: flex;
        gap: 0.25rem;
    }

    .question-controls .btn {
        padding: 0.25rem 0.5rem !important;
        font-size: 0.75rem !important;
    }

    /* Modal responsive */
    .modal-dialog {
        margin: 0.5rem;
    }

    .modal-content {
        border-radius: 10px;
    }

    .question-type-card {
        height: auto !important;
        padding: 1rem !important;
    }

    .question-type-card i {
        font-size: 1.5rem !important;
    }

    .question-type-card div {
        font-size: 0.875rem !important;
    }

    .question-type-card small {
        display: none;
    }
}

/* ========== OUTILS ADMINISTRATIFS RESPONSIVE ========== */
@media (max-width: 768px) {
    .admin-card .row {
        gap: 0.5rem;
    }

    .admin-card .btn {
        padding: 1rem !important;
        font-size: 0.875rem !important;
    }

    .admin-card .btn i {
        font-size: 1.5rem !important;
    }
}

/* ========== GENERAL MOBILE OPTIMIZATIONS ========== */
@media (max-width: 576px) {
    /* Reducir márgenes y padding generales */
    .container-fluid {
        padding: 0 0.5rem !important;
    }

    .card {
        margin-bottom: 0.75rem !important;
    }

    .card-header, .card-body {
        padding: 0.75rem !important;
    }

    /* Títulos más pequeños */
    h1, .h1 {
        font-size: 1.5rem !important;
    }

    h2, .h2 {
        font-size: 1.25rem !important;
    }

    h3, .h3, h4, .h4, h5, .h5 {
        font-size: 1.1rem !important;
    }

    /* Botones más pequeños */
    .btn {
        font-size: 0.875rem !important;
        padding: 0.375rem 0.75rem !important;
    }

    .btn-sm {
        font-size: 0.75rem !important;
        padding: 0.25rem 0.5rem !important;
    }

    /* Badges más pequeños */
    .badge {
        font-size: 0.7rem !important;
        padding: 0.2rem 0.4rem !important;
    }

    /* Formularios */
    .form-control, .form-select {
        font-size: 16px !important; /* Previene zoom en iOS */
        padding: 0.5rem !important;
    }

    .form-label {
        font-size: 0.875rem !important;
    }

    /* Alertas */
    .alert {
        padding: 0.5rem !important;
        font-size: 0.875rem !important;
    }
}

/* ========== TABLA RESPONSIVE CON SCROLL ========== */
@media (max-width: 991px) {
    .table-responsive {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .table {
        min-width: 600px;
    }

    /* Indicador de scroll */
    .table-responsive::after {
        content: "→ Desliza para ver más";
        display: block;
        text-align: center;
        color: #6c757d;
        font-size: 0.75rem;
        padding: 0.5rem;
    }
}

/* ========== NAVBAR FIXED EN MOBILE ========== */
@media (max-width: 768px) {
    .navbar {
        position: fixed !important;
        top: 0;
        width: 100%;
        z-index: 1030;
    }

    main {
        margin-top: 60px !important;
    }
}

/* ========== OPTIMIZACIÓN PARA LANDSCAPE MOBILE ========== */
@media (max-height: 500px) and (orientation: landscape) {
    .navbar {
        padding: 0.25rem 1rem !important;
    }

    .navbar-brand {
        font-size: 1rem !important;
    }

    .stats-card {
        padding: 0.5rem !important;
    }

    .stat-number {
        font-size: 1.25rem !important;
    }

    main {
        margin-top: 50px !important;
    }
}

/* ========== UTILIDADES RESPONSIVE ========== */
@media (max-width: 768px) {
    /* Ocultar en móvil */
    .hide-mobile {
        display: none !important;
    }

    /* Mostrar solo en móvil */
    .show-mobile {
        display: block !important;
    }

    /* Stack en móvil */
    .stack-mobile {
        flex-direction: column !important;
    }

    /* Ancho completo en móvil */
    .w-100-mobile {
        width: 100% !important;
    }

    /* Centrar texto en móvil */
    .text-center-mobile {
        text-align: center !important;
    }
}

/* ========== TOOLTIPS EN MOBILE ========== */
@media (hover: none) and (pointer: coarse) {
    /* Desactivar tooltips en dispositivos táctiles */
    [data-bs-toggle="tooltip"] {
        pointer-events: none;
    }

    /* Mostrar texto alternativo */
    .tooltip-text-mobile {
        display: inline !important;
    }
}

/* ========== PRINT STYLES ========== */
@media print {
    .no-print {
        display: none !important;
    }

    .navbar, .footer-gradient {
        display: none !important;
    }

    main {
        margin-top: 0 !important;
    }
}