#toolbar #btnVectorAnalysis,
#btnVectorAnalysis {
    background: #000 !important;
    border-radius: 0 !important;
    width: 40px !important;
    height: 40px !important;
    margin: 0 !important;
    box-shadow: none !important;
    transition: all 0.3s ease !important;
    border: 1px solid rgba(255, 255, 255, 0.3) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    cursor: pointer !important;
}

#btnVectorAnalysis i {
    font-size: 1.2em !important;
    color: #fff !important;
    transition: all 0.3s ease !important;
}

#toolbar #btnVectorAnalysis:hover,
#btnVectorAnalysis:hover {
    transform: none !important;
    box-shadow: none !important;
    background: #000 !important;
}

#btnVectorAnalysis:hover i {
    color: var(--primary-color) !important;
}

#vectorAnalysisModal {
    width: 320px !important;
    background: #111 !important;
    box-shadow: 0 8px 32px rgba(100,255,218,0.08), 0 2px 8px rgba(0,0,0,0.18) !important;
    border: 1.5px solid var(--border-color) !important;
    color: #fff !important;
}

#vectorAnalysisModal h3 {
    background: #111 !important;
    border-bottom: 2px solid var(--accent-color) !important;
    color: #fff !important;
    font-weight: 700 !important;
    margin-bottom: 0 !important;
}

.va-container {
    padding: 15px !important;
}

.va-container .form-group {
    margin-bottom: 12px !important;
}

.va-container label {
    display: block !important;
    margin-bottom: 6px !important;
    font-size: 0.85em !important;
    color: #fff !important;
}

.va-container select {
    width: 100% !important;
    background: #111 !important;
    color: #fff !important;
    border: 1px solid #222 !important;
    padding: 8px !important;
    border-radius: 4px !important;
    font-size: 0.9em !important;
    box-sizing: border-box !important;
}

.va-buttons {
    display: flex !important;
    justify-content: flex-end !important;
    gap: 8px !important;
    margin-top: 14px !important;
    flex-wrap: wrap !important;
}

.va-buttons button {
    background: #111 !important;
    color: #fff !important;
    border: 1px solid #222 !important;
    min-height: 32px !important;
    border-radius: 4px !important;
    padding: 6px 12px !important;
    cursor: pointer !important;
    font-size: 0.85em !important;
}

.va-buttons button:hover {
    border-color: var(--accent-color) !important;
}

#vaProgressModal {
    width: 240px !important;
    background: #111 !important;
    border: 1.5px solid var(--border-color) !important;
    color: #fff !important;
    position: fixed !important;
    inset: auto auto 16px 16px !important;
    left: 16px !important;
    bottom: 16px !important;
    top: auto !important;
    right: auto !important;
    margin: 0 !important;
    transform: none !important;
    max-width: 240px !important;
}

#vaProgressModal h3 {
    background: #111 !important;
    border-bottom: 2px solid var(--accent-color) !important;
    color: #fff !important;
    margin-bottom: 0 !important;
    font-size: 12px !important;
    line-height: 1.2 !important;
    padding: 6px 8px !important;
}

.va-progress-container {
    padding: 8px !important;
}

.va-progress-text {
    color: #fff;
    font-size: 10px;
    margin-bottom: 6px;
}

.va-progress-dots {
    display: inline-flex;
    gap: 1px;
}

.va-progress-dots span {
    opacity: 0.2;
    animation: vaDotsBlink 1.2s infinite;
}

.va-progress-dots span:nth-child(2) {
    animation-delay: 0.2s;
}

.va-progress-dots span:nth-child(3) {
    animation-delay: 0.4s;
}

@keyframes vaDotsBlink {
    0% {
        opacity: 0.2;
    }
    50% {
        opacity: 1;
    }
    100% {
        opacity: 0.2;
    }
}

.va-progress-track {
    width: 100%;
    height: 6px;
    border-radius: 999px;
    background: #2a2a2a;
    overflow: hidden;
}

.va-progress-fill {
    width: 0%;
    height: 100%;
    background: var(--accent-color);
    transition: width 0.25s ease;
}

/* ── PC (≥ 1280px): tamaño fijo, sin cambios ── */
@media screen and (min-width: 1280px) {
    #vectorAnalysisResultModal {
        --va-result-map-h: 118mm;
        --va-result-stats-max-h: 58mm;
        width: 289mm !important;
        max-width: 289mm !important;
        height: 202mm !important;
        max-height: 202mm !important;
        padding: 6mm 8mm !important;
        box-sizing: border-box !important;
        background: #111 !important;
        border: 1.5px solid var(--border-color) !important;
        color: #fff !important;
    }

    #vectorAnalysisResultModal.modal.visible {
        display: flex !important;
        flex-direction: column !important;
        overflow: hidden !important;
    }

    #vectorAnalysisResultModal h3 {
        flex: 0 0 auto !important;
        background: #111 !important;
        border-bottom: 2px solid var(--accent-color) !important;
        color: #fff !important;
        margin: 0 0 4px 0 !important;
        padding: 2px 0 4px 0 !important;
        font-size: 11pt !important;
        line-height: 1.2 !important;
    }

    #vectorAnalysisResultModal .va-container {
        flex: 1 1 auto !important;
        min-height: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        overflow: hidden !important;
        padding: 0 !important;
        box-sizing: border-box !important;
    }

    #vectorAnalysisResultMap {
        flex: 0 0 var(--va-result-map-h) !important;
        width: 100% !important;
        height: var(--va-result-map-h) !important;
        min-height: var(--va-result-map-h) !important;
        max-height: var(--va-result-map-h) !important;
        border-radius: 4px !important;
        border: 1px solid #333 !important;
        margin: 0 !important;
        background: #1a1a1a !important;
        box-sizing: border-box !important;
    }

    #vectorAnalysisResultModal .va-result-stats {
        flex: 0 1 auto !important;
        max-height: var(--va-result-stats-max-h) !important;
        overflow-y: auto !important;
        margin-top: 3mm !important;
        padding: 6px 8px !important;
        font-size: 8.5pt !important;
        line-height: 1.35 !important;
    }

    #vectorAnalysisResultModal .va-result-actions {
        flex: 0 0 auto !important;
        margin-top: 3mm !important;
    }
}

/* ── Laptop (1024px – 1279px): responsive ── */
@media screen and (min-width: 1024px) and (max-width: 1279px) {
    #vectorAnalysisResultModal {
        --va-result-map-h: 42vh;
        --va-result-stats-max-h: 22vh;
        width: calc(100vw - 48px) !important;
        max-width: 860px !important;
        height: auto !important;
        max-height: calc(100vh - 48px) !important;
        padding: 14px 18px !important;
        box-sizing: border-box !important;
        background: #111 !important;
        border: 1.5px solid var(--border-color) !important;
        color: #fff !important;
    }

    #vectorAnalysisResultModal.modal.visible {
        display: flex !important;
        flex-direction: column !important;
        overflow: hidden !important;
    }

    #vectorAnalysisResultModal h3 {
        flex: 0 0 auto !important;
        background: #111 !important;
        border-bottom: 2px solid var(--accent-color) !important;
        color: #fff !important;
        margin: 0 0 6px 0 !important;
        padding: 2px 0 6px 0 !important;
        font-size: 10.5pt !important;
        line-height: 1.2 !important;
    }

    #vectorAnalysisResultModal .va-container {
        flex: 1 1 auto !important;
        min-height: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        overflow: hidden !important;
        padding: 0 !important;
        box-sizing: border-box !important;
    }

    #vectorAnalysisResultMap {
        flex: 0 0 var(--va-result-map-h) !important;
        width: 100% !important;
        height: var(--va-result-map-h) !important;
        min-height: var(--va-result-map-h) !important;
        max-height: var(--va-result-map-h) !important;
        border-radius: 4px !important;
        border: 1px solid #333 !important;
        margin: 0 !important;
        background: #1a1a1a !important;
        box-sizing: border-box !important;
    }

    #vectorAnalysisResultModal .va-result-stats {
        flex: 0 1 auto !important;
        max-height: var(--va-result-stats-max-h) !important;
        overflow-y: auto !important;
        margin-top: 8px !important;
        padding: 8px 10px !important;
        font-size: 8pt !important;
        line-height: 1.4 !important;
    }

    #vectorAnalysisResultModal .va-result-actions {
        flex: 0 0 auto !important;
        margin-top: 8px !important;
    }
}

/* ── Tablet (600px – 1023px): responsive ── */
@media screen and (min-width: 600px) and (max-width: 1023px) {
    #vectorAnalysisResultModal {
        --va-result-map-h: 38vh;
        --va-result-stats-max-h: 26vh;
        width: calc(100vw - 24px) !important;
        max-width: 100% !important;
        height: auto !important;
        max-height: calc(100vh - 24px) !important;
        padding: 10px 12px !important;
        box-sizing: border-box !important;
        background: #111 !important;
        border: 1.5px solid var(--border-color) !important;
        color: #fff !important;
        /* centrado en pantalla */
        position: fixed !important;
        top: 50% !important;
        left: 50% !important;
        transform: translate(-50%, -50%) !important;
        margin: 0 !important;
    }

    #vectorAnalysisResultModal.modal.visible {
        display: flex !important;
        flex-direction: column !important;
        overflow: hidden !important;
    }

    #vectorAnalysisResultModal h3 {
        flex: 0 0 auto !important;
        background: #111 !important;
        border-bottom: 2px solid var(--accent-color) !important;
        color: #fff !important;
        margin: 0 0 6px 0 !important;
        padding: 2px 0 6px 0 !important;
        font-size: 10pt !important;
        line-height: 1.2 !important;
    }

    #vectorAnalysisResultModal .va-container {
        flex: 1 1 auto !important;
        min-height: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        overflow: hidden !important;
        padding: 0 !important;
        box-sizing: border-box !important;
    }

    #vectorAnalysisResultMap {
        flex: 0 0 var(--va-result-map-h) !important;
        width: 100% !important;
        height: var(--va-result-map-h) !important;
        min-height: var(--va-result-map-h) !important;
        max-height: var(--va-result-map-h) !important;
        border-radius: 4px !important;
        border: 1px solid #333 !important;
        margin: 0 !important;
        background: #1a1a1a !important;
        box-sizing: border-box !important;
    }

    #vectorAnalysisResultModal .va-result-stats {
        flex: 0 1 auto !important;
        max-height: var(--va-result-stats-max-h) !important;
        overflow-y: auto !important;
        margin-top: 6px !important;
        padding: 6px 8px !important;
        font-size: 7.5pt !important;
        line-height: 1.4 !important;
    }

    #vectorAnalysisResultModal .va-result-actions {
        flex: 0 0 auto !important;
        margin-top: 6px !important;
    }

    /* Modal de configuración también responsive en tablet */
    #vectorAnalysisModal {
        width: calc(100vw - 24px) !important;
        max-width: 380px !important;
    }
}

.va-result-stats {
    margin-top: 12px !important;
    padding: 12px !important;
    background: #0d0d0d !important;
    border-radius: 4px !important;
    font-size: 0.9em !important;
    line-height: 1.5 !important;
}

.va-result-stats strong {
    color: var(--accent-color) !important;
}

.va-area-unit-select {
    width: auto !important;
    min-width: 72px !important;
    max-width: 90px !important;
    display: inline-block !important;
    vertical-align: middle !important;
    margin-left: 6px !important;
    padding: 2px 4px !important;
    background: #111 !important;
    color: #fff !important;
    border: 1px solid #222 !important;
    border-radius: 3px !important;
}

.va-result-actions {
    display: flex !important;
    justify-content: flex-end !important;
    margin-top: 12px !important;
}
