@media (min-width: 500px) {
    /* Barra de pestañas */
    .sidebar {
        width: 50px;
    }

    /* anr */
    .sidebar-brand {
        height: 50px; 
    }

    .sidebar-brand span {
        font-size: 1rem;
    }

    /* Icono */
    .tab, .icon-svg-mex {
        width: 50px;
        height: 50px;
        font-size: 1rem;
    }

    .tab.active::after {
        width: 4px;
    }

    .icon-svg-mex {
        width: 32px;
    }

    /* Panel Desplegable */
    .panel {
        width: 270px;
        left: 45px;
    }

    /* Título General */
    .header-text h1 {
        font-size: .7rem; 
    }

    /* Subtítulo */
    .header-text h2 {
        font-size: 1rem; 
    }

    /* Botón de cierre del panel */
    .close-btn {
        font-size: 20px;
        width: 50px;
        height: 50px;
    }

    .info-header h3 { 
        font-size: 1rem; 
    }

    .info-header p { 
        font-size: .8rem; 
    }

    .fenomeno-section .subtitulo-seccion {
        font-size: .9rem;
    }

    .semaforo-label {
        font-size: .8rem;
    }

    /* Fichas con colores */
    .badge-semaforo {
        font-size: .7rem;
    }

    /* Peligros por nación */
    .sub-nacional {
        font-size: .9rem;
    }

    /* Contenedores de los grupos de botones radio */
    .radio-container {
        font-size: .8rem;
    }

    /* Figura del check-radio */
    .checkmark {
        height: 16px; 
        width: 16px;
    }

    .card-icon {
        font-size: 1.3rem;
    }

    .card-title { 
        font-size: 0.8rem; 
    }

    .card-value { 
        font-size: 1.1rem;
    }

    .accordion-header {
        font-size: .9rem;
    }

    .indicator-row {
        font-size: .75rem;
    }

    .inst-icon {
        font-size: 1.5rem;
    }

    .inst-info h4 {
        font-size: .8rem;
    }

    .inst-info p {
        font-size: .7rem;
    }

    /* Botones de instrumentos*/
    .btn-download {
        font-size: .8rem;
    }

    .decl-label {
        font-size: .63rem;
    }

    .decl-count {
        font-size: 1.1rem;
    }

    /* Iconos laterales */
    .download-icon {
        font-size: 1.6rem;
        margin-right: 4px;
    }

    .download-info h4 {
        font-size: .9rem;
    }

    .download-info p {
        font-size: .7rem;
    }

    /* Botón de acción dentro de la tarjeta */
    .btn-action-download {
        font-size: .8rem;
    }

    /* Nota al pie */
    .download-footer-note {
        font-size: .7rem;
    }

    .fuente-badge {
        font-size: .7rem;
    }

    /* Detalles de la tarjeta */
    .fuente-detalle strong {
        font-size: .9rem;
    }

    .fuente-detalle p {
        font-size: .8rem;
    }

    .contacto-item i {
        font-size: 1.1rem;
    }

    .contacto-item span {
        font-size: .7rem;
    }

    .contacto-label {
        font-size: .7rem !important;
    }
}

@media (min-width: 550px) {
    .coordenadas-widget {
        width: 130px;
    }
}

@media (min-width: 768px) {
    /* Barra de pestañas */
    .sidebar {
        width: 60px;
    }

    /* anr */
    .sidebar-brand {
        height: 60px;
    }

    .sidebar-brand span {
        font-size: 1.2rem;
    }

    /* Icono */
    .tab, .icon-svg-mex {
        width: 60px;
        height: 60px;
        font-size: 1.4rem;
    }

    /* Selector de visibilidad */
    .tab.active::after {
        width: 5px;
    }

    /* SVG nacional */
    .icon-svg-mex {
        width: 36px;
    }

    /* Panel Desplegable */
    .panel {
        width: 320px;
        left: 55px;
    }

    /* Encabezado del panel */
    .panel-header {
        padding: 12px 20px;
    }

    /* Título General */
    .header-text h1 {
        font-size: .8rem;
    }

    /* Subtítulo */
    .header-text h2 {
        font-size: 1.1rem; 
    }

    /* Botón de cierre del panel */
    .close-btn {
        font-size: 24px;
    }

    .close-btn:hover {
        transform: scale(1.1); 
    }

    /* Caratula de municipio nombre y estado */
    .info-header {
        padding: 15px 20px;
    }

    .info-header h3 {  
        font-size: 1.1rem;
    }

    .info-header p { 
        font-size: .9rem; 
    }

    /* Contenido del municipio y sus atributos */
    .info-body {
        padding: 20px;
    }

    .subtitulo-seccion {
        font-size: 1rem;
    }

    .semaforo-label {
        font-size: .85rem;
    }

    /* Fichas con colores */
    .badge-semaforo {
        padding: 4px 10px;
        min-width: 85px;
    }

    /* Contenedores de los grupos de botones radio */
    .radio-container {
        font-size: .85rem;
    }

    /* Figura del check-radio */
    .checkmark {
        height: 18px; 
        width: 18px;
    }

    /* Tarjeta individual */
    .card {
        padding: 15px;
    }

    .card-icon {
        font-size: 1.5rem;
    }

    .card-value { 
        font-size: 1.2rem;
    }

    .indicator-row {
        font-size: .85rem;
    }

    /* Tarjetas de Instrumentos */
    .instrumento-card {
        padding: 15px;
    }

    .inst-icon {
        font-size: 1.8rem;
    }

    .inst-info h4 {
        font-size: .95rem;
    }

    .inst-info p {
        font-size: .85rem;
    }

    /* Botones de instrumentos*/
    .btn-download {
        padding: 6px 12px;
    }

    /* Declaratorias */
    .declaratorias-grid {
        display: grid;
        grid-template-columns: 1fr 1fr; /* Dos columnas */
        gap: 10px;
    }

    /* Tarjetas declaratorias */
    .decl-card {
        margin-bottom: 0px;
    }

    .decl-label {
        font-size: .6rem;
    }

    .decl-count {
        font-size: 1.2rem;
    }

    /* Total declaratorias */
    .decl-card.total {
        grid-column: span 2;
    }

    /* Infografías */
    .info-gallery {
        grid-template-columns: repeat(3, 1fr); /* 3 columnas */
    }

    /* Descargas */
    /* Contenedor de la tarjeta de descarga */
    .download-card {
        padding: 15px;
    }

    /* Iconos laterales */
    .download-icon {
        font-size: 1.8rem;
        margin-right: 8px;
        min-width: 50px;
    }

    .download-info h4 {
        font-size: 1rem;
    }

    .download-info p {
        font-size: .75rem;
    }

    /* Botón de acción dentro de la tarjeta */
    .btn-action-download {
        padding: 8px 15px;
    }

    /* Configuración */
    /* Contenedor de los temas de colores */
    .theme-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
    }

    /* Contenedor de cada tema / o cada tarjeta */
    .theme-card {
        margin-bottom: 0px;
    }

    /* Nombre de la tarjeta de tema */
    .theme-name {
        font-size: .8rem;
    }

    /* Contacto */
    .contacto-grid {
        display: grid;
        grid-template-columns: repeat(3, 1fr); /* Redes sociales en fila */
    }

    .contacto-item {
        flex-direction: column;
        text-align: center;
    }

    .contacto-item i {
        font-size: 1.5rem;
        margin-bottom: 8px;
        margin-right: 0;
    }

    /* correo */
    .contacto-item.email-full {
        grid-column: span 3;
        flex-direction: row;
        padding: 15px;
    }

    .contacto-text {
        gap: 0;
        margin-left: 15px;
    }

    .contacto-mail {
        font-size: .7rem;
    }

    .coordenadas-widget {
        padding: 10px 15px;
        font-size: 12px;
        width: 180px;
    }
}

@media (min-width: 1024px) {
    /* Panel Desplegable */
    .panel {
        width: 400px;
        position: initial;
    }

    .indicaciones {
        font-size: 1.5rem;
    }

    /* Tarjetas declaratorias */
    .decl-label {
        font-size: .7rem;
    }

    /* Iconos laterales */
    .download-icon {
        font-size: 2rem;
        margin-right: 15px;
    }

    /* Nombre de la tarjeta de tema */
    .theme-name {
        font-size: .85rem;
    }

    /* Círculos de vista previa para identificar colores*/
    .preview-circle {
        width: 20px;
        height: 20px;
    }

    .contacto-label {
        font-size: .75rem !important;
    }

    .contacto-mail {
        font-size: .6rem;
        word-break: normal;
    }

    #viewDiv { flex-grow: 1; height: 100%; width: auto;}

    .coordenadas-widget {
        bottom: 20px;
        right: 20px;
        width: 230px;
    }
}