@media screen and (min-width: 769px) and (max-width: 1000px) {
    .info-card {
        max-height: 80vh;
        width: calc(80vw - 30px);
        max-width: 290px;
        overflow: hidden;
    }
    
    .info-card .ecoparque-item {
        height: 100%;
        overflow-y: auto;
        padding: 18px 12px !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
    }
    
    .info-card .ecoparque-image-placeholder {
        aspect-ratio: 1/1;
        max-width: 90%;
        margin: 0 auto 12px auto !important;
        flex-shrink: 0;
    }
    
    .info-card .ecoparque-title {
        max-width: 200px; 
        font-size: 1.1rem !important;
        margin-bottom: 10px !important;
        line-height: 1.2;
    }
    
    .info-card .text-paragraph {
        max-width: 200px; 
        font-size: 0.9rem !important; 
        line-height: 1.4 !important;
    }
    
    .info-card .text-content {
        max-width: 280px; 
        margin: 0 auto; 
    }
}

@media screen and (max-width: 768px) {
      .info-card .ecoparque-image-placeholder {
        max-width: 98% !important;  
        margin: 0 auto 1px auto !important; 
    }

    .map-section {
        padding: 40px 15px;
    }
    
    .map-section-heading {
        font-size: 1.8rem;
        letter-spacing: 1px;
        margin-bottom: 12px;
    }
    
    .map-section-subtitle {
        font-size: 1rem;
    }
    
    .map-container {
        aspect-ratio: 9/11;
        margin-top: 30px;
        border-radius: 8px;
    }
    
    .map-container.height-constrained {
        max-height: 75vh !important;
    }
    
    .custom-pin.standard-pin {
        width: 28px;
        height: 28px;
    }
    
    .custom-pin.standard-pin::before {
        width: 10px;
        height: 10px;
    }
    
    .info-card {
        top: 50%;
        left: 50%;
        right: auto;
        width: calc(100vw - 30px);
        max-width: 350px;
        transform: translate(-50%, -50%) translateY(20px) scale(0.95);
    }
    
    .info-card.active {
        transform: translate(-50%, -50%) scale(1);
    }
    
    .info-card.switching {
        transform: translate(-50%, -50%) translateY(10px) !important;
    }
    
    .info-card-header {
        height: 180px;
        border-radius: 12px 12px 0 0;
    }
    
    .info-card .ecoparque-item {
        padding: 16px 12px !important;
    }
    
    .info-card .ecoparque-image-placeholder {
        aspect-ratio: 1/1 !important;
        margin-bottom: 12px !important;
    }
    
    .info-card .ecoparque-title {
        font-size: 1.1rem !important;
        margin-bottom: 10px !important;
    }
    
    .info-card .text-paragraph {
        font-size: 0.9rem !important;
        padding: 0 3px !important;
    }
    
    .map-toggle-button {
        top: 12px;
        right: 12px;
        font-size: 12px;
        padding: 8px 14px;
        z-index: 103;
    }
    
    .leaflet-control-container .leaflet-top.leaflet-right {
        top: 75px;
    }
    
    .map-container .leaflet-control-container .leaflet-control-attribution {
        margin-left: 140px;
        margin-bottom: 0;
        font-size: 11px;
    }

}

@media screen and (max-width: 600px) {
    .map-container {
        aspect-ratio: 9/12.5;
        margin-top: 30px;
        border-radius: 8px;
    }
}

@media screen and (max-width: 550px) {
    .map-container {
        aspect-ratio: 9/14;
        margin-top: 30px;
        border-radius: 8px;
    }
}

@media screen and (max-width: 480px) {
    .map-scroll-message {
        font-size: 13px;
        padding: 10px 16px;
        max-width: 250px;
    }
    
    .map-section {
        padding: 30px 12px;
    }
    
    .map-section-heading {
        font-size: 1.5rem;
        letter-spacing: 0.5px;
    }
    
    .map-section-subtitle {
        font-size: 0.95rem;
    }
    
    .map-container {
        border-radius: 6px;
    }
    
    .map-container.height-constrained {
        max-height: 75vh !important;
    }
    
    .custom-pin.standard-pin {
        width: 24px;
        height: 24px;
    }
    
    .custom-pin.standard-pin::before {
        width: 8px;
        height: 8px;
    }
    
    .info-card {
        width: calc(100vw - 20px);
        max-width: 320px;
        overflow-x: hidden;
    }
    
    .info-card.active {
        transform: translate(-50%, -50%) scale(1);
    }
    
    .info-card.switching {
        transform: translate(-50%, -50%) translateY(10px) !important;
    }
    
    .info-card-header {
        top: 8px;
        right: 8px;
    }
    
    .info-card-close {
        width: 28px;
        height: 28px;
        font-size: 16px;
    }
    
   .info-card .ecoparque-item {
        padding: 15px 6px !important;
        width: calc(100% - 12px) !important;
    }
    
    .info-card .ecoparque-image-placeholder {
        aspect-ratio: 1/1 !important;
        margin-bottom: 10px !important;
    }
    
    .info-card .ecoparque-title {
        font-size: 1rem !important;
        padding: 0 2px !important;
    }
    
    .info-card .text-paragraph {
        font-size: 0.85rem !important;
        padding: 0 2px !important;
    }
    
    .info-card-content {
        padding: 14px;
    }
    
    .map-toggle-button {
        top: 10px;
        right: 10px;
        font-size: 11px;
        padding: 8px 12px;
        border-radius: 6px;
    }
    
    .leaflet-control-container .leaflet-top.leaflet-right {
        top: 80px;
    }
    
    .map-container .leaflet-control-container .leaflet-control-attribution {
        margin-left: 120px;
        margin-bottom: 0;
        font-size: 10px;
    }
}

@media screen and (max-width: 360px) {
      .info-card {
        width: calc(100vw - 16px);
        max-width: 300px;
        overflow-x: hidden;
    }

    .map-toggle-button {
        font-size: 10px;
        padding: 6px 10px;
        white-space: normal;
        word-wrap: break-word;
        line-height: 1.3;
        height: auto;
        min-height: 44px; 
    }
    
    .map-toggle-button {
        font-size: 9px;
        padding: 4px 8px;
        white-space: normal;
        word-wrap: break-word;
        line-height: 1.2;
        height: 30px;
        min-height: 30px;
        max-height: 30px;
    }
    
    
    .info-card .ecoparque-item {
        padding: 12px 4px !important;
        width: calc(100% - 8px) !important;
    }
    
    .info-card .ecoparque-image-placeholder {
        margin-bottom: 8px !important;
    }
    
    .info-card .ecoparque-title {
        font-size: 0.95rem !important;
        padding: 0 1px !important;
    }
    
   .info-card .text-paragraph {
        font-size: 0.8rem !important;
        padding: 0 1px !important;
    }
    
    .map-container .leaflet-control-container .leaflet-control-attribution {
        margin-left: 90px;
        margin-bottom: 0;
        font-size: 9px;
    }
}

@media screen and (max-height: 320px) {
    .map-container {
        aspect-ratio: 9/4;
        margin-top: 30px;
        border-radius: 8px;
    }
}

@media screen and (max-height: 360px) {
    .map-container {
        aspect-ratio: 9/3.5;
        margin-top: 30px;
        border-radius: 8px;
    }
}

@media screen and (max-height: 420px) {
    .map-container {
        aspect-ratio: 9/4;
        margin-top: 30px;
        border-radius: 8px;
    }
}

@media screen and (max-height: 490px) {
  
        .info-card .ecoparque-image-placeholder {
        max-width: 70% !important;  
        margin: 0 auto 1px auto !important; 
}
    .map-container {
        aspect-ratio: 2/3.9;
        margin-top: 30px;
        border-radius: 8px;
    }
}
@media screen and (max-height: 655px) {
  
        .info-card .ecoparque-image-placeholder {
        max-width: 77% !important;  
        margin: 0 auto 1px auto !important; 
    }

}
@media screen and (max-width: 400px)  {
            .info-card .ecoparque-image-placeholder {
        max-width: 80% !important;  
        margin: 0 auto 1px auto !important; 
    }

}
@media screen and (max-width: 500px)  {
            .info-card .ecoparque-image-placeholder {
        max-width: 88% !important;  
        margin: 0 auto 1px auto !important; 
    }

}
@media screen and (max-width: 379px) and (max-height: 719px) {
    .info-card {
        width: calc(90vw - 20px) !important;
        max-width: 300px !important;
        overflow-x: hidden !important;
    }
    
    .info-card.active {
        transform: translate(-50%, -50%) scale(1) !important;
    }
    
    .info-card.switching {
        transform: translate(-50%, -50%) translateY(10px) !important;
    }
    
    .info-card .ecoparque-item {
        padding: 10px 4px !important;
        width: calc(100% - 8px) !important;
    }
    
    .info-card .ecoparque-image-placeholder {
        aspect-ratio: 1/1 !important;
        margin-bottom: 6px !important;
    }
    
    .info-card .ecoparque-title {
        font-size: 0.9rem !important;
        padding: 0 1px !important;
    }
    
    .info-card .text-paragraph {
        font-size: 0.75rem !important;
        padding: 0 1px !important;
    }
    
    .info-card-close {
        width: 28px !important;
        height: 28px !important;
        font-size: 16px !important;
    }
    
    .info-card-header {
        top: 8px !important;
        right: 8px !important;
    }
}