/* =============================================================================
   SGCI THEME V2 - DISEÑO RESPONSIVE
   Media queries y ajustes para dispositivos móviles y tablets
   ============================================================================= */

/* =============================================================================
   TABLET Y DISPOSITIVOS MÓVILES - MAX 768PX
   ============================================================================= */

@media screen and (max-width: 768px) {
    /* Contenedores principales */
    .sgci-admin-container {
        padding: 1rem 0;
    }
    
    /* Filtros en móviles */
    .filters-container {
        padding: 1rem;
        margin-bottom: 1rem;
    }
    
    .filters-active .filters-container::before {
        margin: -1rem -1rem 1rem -1rem;
        padding: 8px 12px;
        font-size: 0.8rem;
    }
    
    /* Tablas responsive */
    .sgci-table-container {
        margin-top: 1rem;
        border-radius: 6px;
    }
    
    .table-container th {
        padding: 0.75rem 0.5rem;
        font-size: 0.75rem;
    }
    
    .table-container td {
        padding: 0.65rem 0.5rem;
        font-size: 0.8rem;
    }
    
    /* Botones en móviles */
    .button {
        padding: 0.6rem 1rem;
        font-size: 0.8rem;
        margin-bottom: 0.5rem;
    }
    
    .button-group .button.tiny {
        width: 32px;
        height: 32px;
        min-width: 32px;
        max-width: 32px;
    }
    
    /* Celdas de acciones en móviles */
    td.text-right {
        min-width: 120px;
    }
}

/* =============================================================================
   DISPOSITIVOS MÓVILES PEQUEÑOS - MAX 640PX
   ============================================================================= */

@media screen and (max-width: 640px) {
    /* Filtros en móviles pequeños */
    .filters-container .cell {
        margin-bottom: 1rem;
    }
    
    /* Botones verticales en móviles */
    .button-group {
        flex-direction: column;
        gap: 8px;
    }
    
    .button-group .button {
        margin-bottom: 0.5rem;
        width: 100%;
    }
    
    /* Layout de celdas en móviles */
    .cell.medium-12 > div {
        flex-direction: column !important;
        gap: 10px !important;
    }
    
    /* Modales en móviles */
    .reveal {
        width: 95% !important;
        max-width: 95% !important;
        margin: 10px !important;
    }
    
    .reveal .cell.medium-12 .button {
        width: 100%;
        margin-bottom: 0.5rem;
        margin-right: 0;
    }
    
    /* Formularios en móviles */
    .sgci-form {
        padding: 1rem 0;
    }
    
    /* Inputs más grandes en móviles */
    input[type="text"], 
    input[type="email"], 
    input[type="search"], 
    input[type="password"], 
    input[type="url"], 
    input[type="tel"], 
    input[type="number"], 
    input[type="datetime"], 
    input[type="date"], 
    input[type="month"], 
    input[type="week"], 
    input[type="time"], 
    input[type="datetime-local"], 
    textarea, 
    select {
        padding: 0.75rem;
        font-size: 16px; /* Evita zoom en iOS */
        width: 100%;
        box-sizing: border-box;
    }
    
    /* Labels más pequeños en móviles */
    label {
        font-size: 0.85rem;
    }
    
    /* Excel import responsive */
    .sgci-excel-import-container {
        max-width: 100%;
        margin: 10px;
    }
    
    .sgci-excel-import-card {
        padding: 1rem;
        margin-top: 1rem;
    }
    
    .sgci-excel-import-form {
        padding: 1rem;
        margin: 1rem 0;
    }
    
    .sgci-excel-import-form input[type="file"] {
        width: 100%;
        margin-bottom: 1rem;
        margin-right: 0;
    }
}

/* =============================================================================
   DISPOSITIVOS MÓVILES MUY PEQUEÑOS - MAX 480PX
   ============================================================================= */

@media screen and (max-width: 480px) {
    /* Contenedores muy compactos */
    .sgci-admin-container {
        padding: 0.5rem 0;
    }
    
    /* Filtros muy compactos */
    .filters-container {
        padding: 0.75rem;
        border-radius: 6px;
    }
    
    /* Tablas muy pequeñas */
    .table-container th,
    .table-container td {
        padding: 0.5rem 0.25rem;
        font-size: 0.7rem;
    }
    
    /* Botones muy pequeños */
    .button {
        padding: 0.5rem 0.75rem;
        font-size: 0.75rem;
    }
    
    .button-group .button.tiny {
        width: 28px;
        height: 28px;
        min-width: 28px;
        max-width: 28px;
        font-size: 0.7rem;
    }
    
    /* Celdas de acciones muy pequeñas */
    td.text-right {
        min-width: 100px;
    }
    
    /* Búsqueda responsive */
    .sgci-search-results {
        max-height: 200px !important;
        font-size: 0.8rem;
    }
    
    .sgci-search-results .sgci-item {
        padding: 8px 12px;
    }
}

/* =============================================================================
   LANDSCAPE EN MÓVILES
   ============================================================================= */

@media screen and (max-width: 768px) and (orientation: landscape) {
    /* Ajustes para landscape en móviles */
    .sgci-admin-container {
        min-height: calc(100vh - 120px);
    }
    
    /* Modales más pequeños en landscape */
    .reveal {
        max-height: 85vh;
    }
    
    /* Indicador de carga eliminado - era molesto visualmente */
}

/* =============================================================================
   TABLETS EN LANDSCAPE - 768PX A 1024PX
   ============================================================================= */

@media screen and (min-width: 768px) and (max-width: 1024px) {
    /* Ajustes para tablets */
    .filters-container {
        padding: 1.25rem;
    }
    
    .button {
        padding: 0.65rem 1.1rem;
        font-size: 0.85rem;
    }
    
    .table-container th {
        padding: 0.85rem 0.65rem;
        font-size: 0.8rem;
    }
    
    .table-container td {
        padding: 0.75rem 0.65rem;
        font-size: 0.85rem;
    }
} 