/* =========================================================
   GOEEN 360 Viewer - Clean reusable CSS
   Works with buttons: .js-vehicle-360-btn
   Modal IDs/classes are used by the index page viewer script.
   ========================================================= */

:root {
    --eco-brand: #8cc739;
    --eco-brand-dark: #5b8f20;
    --eco-dark: #111111;
    --eco-white: #ffffff;
    --eco-viewer-radius: 24px;
}

body.eco-viewer-open {
    overflow: hidden !important;
}

/* Open 360 Viewer Button - generic */
.open-viewer-btn,
.vehicle-360-mini-btn {
    border: 1px solid rgba(140, 199, 57, .55) !important;
    background: linear-gradient(135deg, #ffffff, #f2ffe8) !important;
    color: #111111 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    cursor: pointer !important;
    box-shadow: 0 6px 14px rgba(0, 0, 0, .10) !important;
    transition: transform .22s ease, box-shadow .22s ease, background .22s ease, color .22s ease !important;
}

.open-viewer-btn {
    padding: 12px 20px !important;
    border-radius: 12px !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    margin: 5px auto !important;
    position: relative !important;
    z-index: 50 !important;
}

.vehicle-360-mini-btn {
    width: auto !important;
    height: 28px !important;
    min-width: 58px !important;
    padding: 0 18px !important;
    border-radius: 999px !important;
    font-size: 12px !important;
    font-weight: 800 !important;
    line-height: 1 !important;
}

.open-viewer-btn i,
.vehicle-360-mini-btn i {
    color: var(--eco-brand) !important;
    line-height: 1 !important;
}

.vehicle-360-mini-btn i {
    font-size: 14px !important;
}

.open-viewer-btn:hover,
.open-viewer-btn:focus-visible,
.vehicle-360-mini-btn:hover,
.vehicle-360-mini-btn:focus-visible {
    transform: translateY(-2px) !important;
    background: linear-gradient(135deg, var(--eco-brand), #16c860) !important;
    color: #ffffff !important;
    box-shadow: 0 10px 22px rgba(140, 199, 57, .28) !important;
    outline: none !important;
}

.open-viewer-btn:hover i,
.open-viewer-btn:focus-visible i,
.vehicle-360-mini-btn:hover i,
.vehicle-360-mini-btn:focus-visible i {
    color: #ffffff !important;
}

.vehicle-header1 {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
}

.vehicle-name1 {
    margin: 0 !important;
}

/* Modal overlay */
.modal-overlayeco {
    position: fixed !important;
    inset: 0 !important;
    z-index: 2147483600 !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    padding: clamp(74px, 9vh, 110px) 16px 24px !important;
    background: rgba(0, 0, 0, .62) !important;
    backdrop-filter: blur(4px) !important;
    -webkit-backdrop-filter: blur(4px) !important;
    opacity: 0 !important;
    overflow: hidden !important;
    transition: opacity .25s ease !important;
}

.modal-overlayeco.activeeco {
    display: flex !important;
    opacity: 1 !important;
}

.modal-containereco {
    width: min(92vw, 1120px) !important;
    max-width: 1120px !important;
    max-height: calc(100dvh - 96px) !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    margin: 0 auto !important;
    padding: 0 !important;
    border-radius: var(--eco-viewer-radius) !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
    transform: scale(.96) !important;
    transition: transform .25s ease !important;
}

.modal-overlayeco.activeeco .modal-containereco {
    transform: scale(1) !important;
}

.viewer-wrappereco {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: var(--eco-viewer-radius) !important;
    background: transparent !important;
    overflow: hidden !important;
    box-shadow: 0 28px 80px rgba(0, 0, 0, .45) !important;
}

#viewereco {
    position: relative !important;
    width: 100% !important;
    height: min(64vh, 560px) !important;
    min-height: 380px !important;
    margin: 0 !important;
    border-radius: var(--eco-viewer-radius) !important;
    overflow: hidden !important;
    touch-action: none !important;
    cursor: grab !important;
    background: linear-gradient(135deg, #f08b58 0%, #f6c62a 100%) !important;
    border: 1px solid rgba(255, 255, 255, .16) !important;
}

#viewereco:active {
    cursor: grabbing !important;
}

#viewereco:hover {
    transform: none !important;
}

#spinImgeco {
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain !important;
    object-position: center center !important;
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    user-select: none !important;
    -webkit-user-drag: none !important;
    pointer-events: none !important;
    filter: brightness(1.05) contrast(1.05) !important;
    transform-origin: center center !important;
    transform: translate(-50%, -50%) translate(var(--eco-auto-x, 0px), var(--eco-auto-y, 0px)) scale(var(--eco-zoom, 1)) !important;
    transition: transform .18s cubic-bezier(.17, .67, .83, .67), filter .18s ease !important;
}

/* Header controls inside viewer */
.eco-viewer-topbar {
    position: absolute !important;
    top: 18px !important;
    left: 24px !important;
    right: 18px !important;
    z-index: 70 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    pointer-events: none !important;
}

.info-paneleco {
    position: static !important;
    width: auto !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    flex-direction: row !important;
    gap: 16px !important;
    padding: 10px 14px !important;
    margin: 0 !important;
    border-radius: 14px !important;
    background: rgba(0, 0, 0, .66) !important;
    color: #ffffff !important;
    font-size: 15px !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    box-shadow: 0 10px 24px rgba(0, 0, 0, .22) !important;
    border: 1px solid rgba(255, 255, 255, .10) !important;
    pointer-events: auto !important;
}

.info-paneleco div {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    margin: 0 !important;
    padding: 0 !important;
    white-space: nowrap !important;
}

.info-paneleco i {
    font-size: 15px !important;
    line-height: 1 !important;
    color: #ffffff !important;
}

.close-modal-btneco {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    min-height: 42px !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 2px solid rgba(255, 255, 255, .92) !important;
    border-radius: 50% !important;
    background: rgba(0, 0, 0, .68) !important;
    color: #ffffff !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    line-height: 1 !important;
    font-size: 0 !important;
    cursor: pointer !important;
    box-shadow: 0 10px 26px rgba(0, 0, 0, .28) !important;
    pointer-events: auto !important;
    transition: transform .2s ease, background .2s ease, color .2s ease !important;
}

.close-modal-btneco i {
    font-size: 18px !important;
    line-height: 1 !important;
    color: #ffffff !important;
}

.close-modal-btneco:hover,
.close-modal-btneco:focus-visible {
    transform: scale(1.06) !important;
    background: #ef3b2d !important;
    outline: none !important;
}

/* Hidden old header/body support */
.modal-headereco,
.modal-bodyeco {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    height: 0 !important;
    min-height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
}

.loading-bareco {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 4px !important;
    background: rgba(255, 255, 255, .14) !important;
    z-index: 75 !important;
}

.loading-progresseco {
    height: 100% !important;
    width: 0% !important;
    background: linear-gradient(90deg, #111111, var(--eco-brand)) !important;
    transition: width .25s ease !important;
    border-radius: 0 4px 4px 0 !important;
}

.frame-countereco {
    display: none !important;
}

/* Bottom controls - no green title bar */
.controlseco {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 0 !important;
    margin: 0 auto !important;
    padding: 12px 16px !important;
    border-radius: 18px !important;
    background: linear-gradient(135deg, rgba(8, 12, 10, .86), rgba(20, 30, 22, .74)) !important;
    border: 1px solid rgba(255, 255, 255, .18) !important;
    box-shadow: 0 16px 42px rgba(0, 0, 0, .34) !important;
    backdrop-filter: blur(12px) saturate(130%) !important;
    -webkit-backdrop-filter: blur(12px) saturate(130%) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 14px !important;
    flex-wrap: wrap !important;
    z-index: 90 !important;
}

.control-groupeco {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    margin: 0 !important;
    padding: 0 !important;
    flex: 0 0 auto !important;
}

.control-btneco {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    min-height: 42px !important;
    border: 1px solid rgba(255, 255, 255, .28) !important;
    border-radius: 50% !important;
    background: rgba(255, 255, 255, .12) !important;
    color: #ffffff !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    margin: 0 !important;
    line-height: 1 !important;
    font-size: 1.05rem !important;
    cursor: pointer !important;
    box-shadow: none !important;
    transition: transform .2s ease, background .2s ease, border-color .2s ease !important;
}

.control-btneco:hover,
.control-btneco:focus-visible {
    transform: translateY(-2px) !important;
    background: var(--eco-brand) !important;
    border-color: var(--eco-brand) !important;
    outline: none !important;
}

.slider-containereco {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    margin: 0 !important;
    padding: 0 !important;
    flex: 1 1 260px !important;
    min-width: 240px !important;
    color: #ffffff !important;
}

.slider-containereco label {
    margin: 0 !important;
    padding: 0 !important;
    color: #ffffff !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
}

.slider-containereco label i {
    color: var(--eco-brand) !important;
    margin-right: 5px !important;
}

.slidereco {
    flex: 1 1 auto !important;
    width: 100% !important;
    min-width: 110px !important;
    height: 8px !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    background: rgba(255, 255, 255, .16) !important;
    border-radius: 999px !important;
    outline: none !important;
    accent-color: var(--eco-brand) !important;
    cursor: pointer !important;
}

.slidereco::-webkit-slider-thumb {
    -webkit-appearance: none !important;
    appearance: none !important;
    width: 20px !important;
    height: 20px !important;
    border-radius: 50% !important;
    background: linear-gradient(135deg, #ffffff, var(--eco-brand)) !important;
    cursor: pointer !important;
    box-shadow: 0 0 10px rgba(140, 199, 57, .55) !important;
}

.slidereco::-moz-range-thumb {
    width: 20px !important;
    height: 20px !important;
    border: none !important;
    border-radius: 50% !important;
    background: linear-gradient(135deg, #ffffff, var(--eco-brand)) !important;
    cursor: pointer !important;
    box-shadow: 0 0 10px rgba(140, 199, 57, .55) !important;
}

/* Bootstrap modal z-index safety */
.modal-backdrop,
.modal-backdrop.show {
    z-index: 2147483000 !important;
}

.viewer-coming-soon-modal {
    z-index: 2147483100 !important;
}

@media (max-width: 768px) {
    .modal-overlayeco {
        padding: clamp(66px, 9vh, 96px) 12px 18px !important;
    }

    .modal-containereco {
        width: calc(100vw - 24px) !important;
        max-height: calc(100dvh - 72px) !important;
        border-radius: 18px !important;
        gap: 10px !important;
    }

    .viewer-wrappereco,
    #viewereco {
        border-radius: 18px !important;
    }

    #viewereco {
        height: min(58vh, 460px) !important;
        min-height: 300px !important;
    }

    .eco-viewer-topbar {
        top: 12px !important;
        left: 12px !important;
        right: 12px !important;
        gap: 8px !important;
    }

    .info-paneleco {
        gap: 8px !important;
        padding: 8px 10px !important;
        border-radius: 12px !important;
        font-size: 11px !important;
    }

    .info-paneleco div {
        gap: 4px !important;
    }

    .info-paneleco i {
        font-size: 12px !important;
    }

    .close-modal-btneco {
        width: 36px !important;
        height: 36px !important;
        min-width: 36px !important;
        min-height: 36px !important;
    }

    .close-modal-btneco i {
        font-size: 15px !important;
    }

    .controlseco {
        padding: 10px 12px !important;
        border-radius: 16px !important;
        gap: 10px !important;
    }

    .control-groupeco {
        flex: 1 1 100% !important;
        justify-content: center !important;
    }

    .control-btneco {
        width: 38px !important;
        height: 38px !important;
        min-width: 38px !important;
        min-height: 38px !important;
    }

    .slider-containereco {
        flex: 1 1 100% !important;
        min-width: 0 !important;
        gap: 8px !important;
    }

    .slider-containereco label {
        width: 118px !important;
        font-size: 12px !important;
    }
}

@media (max-width: 420px) {
    #viewereco {
        height: min(54vh, 390px) !important;
        min-height: 270px !important;
    }

    .eco-viewer-topbar {
        left: 12px !important;
        right: 10px !important;
        top: 12px !important;
        gap: 8px !important;
    }

    .info-paneleco {
        gap: 7px !important;
        padding: 8px 9px !important;
        font-size: 10px !important;
        border-radius: 11px !important;
    }

    .close-modal-btneco {
        width: 34px !important;
        height: 34px !important;
        min-width: 34px !important;
        min-height: 34px !important;
    }

    .close-modal-btneco i {
        font-size: 14px !important;
    }

    .slider-containereco label {
        width: 108px !important;
        font-size: 11px !important;
    }
}
