/* --- 1. THE STRUCTURAL RESET (CLEAN) --- */
html { margin-top: 0 !important; padding-top: 0 !important; overflow-x: clip !important; }
body { margin: 0 !important; padding: 0 !important; position: relative !important; width: 100%; overflow-x: clip !important; }

/* The Unlock - Mandatory for the summary to stick within the details block */
.wp-site-blocks, #page, #wrapper, main { 
    overflow: visible !important; 
}

/* THE HEADER: The Shield that stays on top */
header, .wp-block-template-part-header {
    position: sticky !important;
    top: 0;
    z-index: 9999 !important; 
    background-color: #ffffff !important;
}

/* --- 2. THE PROGRESS BAR (Absolute Top) --- */
#tt3-progress-container { position: fixed; top: 0; left: 0; width: 100%; z-index: 100000; background: transparent; }
#tt3-progress-bar { height: 3px; width: 0%; transition: width 0.1s ease-out; background: #000; }

/* --- 3. THE SCROLL TO TOP BUTTON (Fixed Corner) --- */
#tt3-scroll-btn { 
    position: fixed !important; 
    bottom: 30px !important; 
    right: 30px !important; 
    display: none; 
    align-items: center; 
    justify-content: center; 
    cursor: pointer; 
    z-index: 100001 !important; 
    border: none; 
    color: white; 
    background: #000; 
    width: 44px; 
    height: 44px; 
    border-radius: 50%;
    transition: opacity 0.3s ease, transform 0.3s ease; 
}
#tt3-scroll-btn.show { display: flex; }

/* --- 4. THE SUMMARY STICKY ENGINE --- */
main details.tt3-pro-details { 
    border-bottom: 1px solid #eee; 
    background-color: #ffffff !important; 
    position: relative;
    z-index: 9 !important; 
}

main details.tt3-pro-details summary { 
    list-style: none; 
    display: flex; 
    justify-content: space-between; 
    align-items: center; 
    padding: 0 !important; 
    font-size: 1.25em; 
    font-weight: 600; 
    cursor: pointer !important; 
    background-color: #ffffff !important;
    position: -webkit-sticky !important;
    position: sticky !important;
    top: 70px !important; 
    z-index: 10 !important;
}

main details.tt3-pro-details summary::-webkit-details-marker { display: none; } 
main details.tt3-pro-details summary::after { 
    content: '\2193'; 
    font-size: 1.5em; 
    transition: transform 0.3s ease; 
    padding: 0 !important; 
    margin: 0 !important;
}
main details.tt3-pro-details[open] summary::after { transform: rotate(180deg); }

/* --- 5. ARCHIVE GRID (ROLLOVER STYLES) --- */
.tt3-image-wrapper { position: relative; aspect-ratio: 1 / 1; overflow: hidden; background: #000; cursor: pointer; }
.tt3-grid-img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease, filter 0.6s ease; display: block; }
.tt3-title-center-box { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(0, 0, 0, 0.65); opacity: 0; transition: opacity 0.4s ease; z-index: 2; pointer-events: none; }
.tt3-custom-title { color: #fff !important; text-align: center; padding: 20px; margin: 0; font-size: 1.1em; font-weight: 700; }
.tt3-image-wrapper.in-view .tt3-title-center-box, .tt3-image-wrapper:hover .tt3-title-center-box { opacity: 1; }
.tt3-image-wrapper.in-view .tt3-grid-img, .tt3-image-wrapper:hover .tt3-grid-img { filter: blur(4px); transform: scale(1.05); }

/* --- 6. THE MODAL (ANIMATED & RIGHT ALIGN) --- */
body.has-modal-open { overflow: hidden !important; height: 100vh !important; }

.wp-block-navigation__responsive-container.is-menu-open {
    height: 100vh !important;
    z-index: 200000 !important;
    background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.25) 20%, rgba(255, 255, 255, 1) 45%, rgba(255, 255, 255, 1) 100%) !important;
}

.is-menu-open .wp-block-navigation__responsive-container-content,
.is-menu-open .wp-block-navigation__responsive-container-content ul,
.is-menu-open .wp-block-navigation__responsive-container-content li { 
    display: flex !important; 
    flex-direction: column !important; 
    align-items: flex-end !important; 
    text-align: right !important; 
    list-style: none !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

.is-menu-open .wp-block-navigation__responsive-container-content {
    padding: 100px 40px 40px 40px !important; 
}

.is-menu-open .wp-block-navigation-item { 
    font-size: 1.4em !important; 
    font-weight: 800 !important; 
    margin-bottom: 25px !important; 
    opacity: 0;
    transform: translateX(30px);
    animation: tt3FadeInRight 0.5s ease forwards;
}

.is-menu-open .wp-block-navigation-item:nth-child(1) { animation-delay: 0.1s; }
.is-menu-open .wp-block-navigation-item:nth-child(2) { animation-delay: 0.2s; }
.is-menu-open .wp-block-navigation-item:nth-child(3) { animation-delay: 0.3s; }
.is-menu-open .wp-block-navigation-item:nth-child(4) { animation-delay: 0.4s; }
.is-menu-open .wp-block-navigation-item:nth-child(5) { animation-delay: 0.5s; }

.is-menu-open .wp-block-navigation__submenu-container .wp-block-navigation-item {
    font-size: 0.95em !important; 
    font-weight: 400 !important; 
    margin-bottom: 10px !important;
    margin-top: 5px !important;
    animation: none !important; 
    opacity: 1 !important;
    transform: none !important;
}

@keyframes tt3FadeInRight {
    from { opacity: 0; transform: translateX(30px); }
    to { opacity: 1; transform: translateX(0); }
}

/* --- 7. DESKTOP NAVIGATION (STABLE REVERT) --- */
@media screen and (min-width: 782px) {
    header .wp-block-navigation:not(.wp-block-navigation__responsive-container-content) .wp-block-navigation-item__content { padding: 0 !important; }
    
    header .wp-block-navigation:not(.wp-block-navigation__responsive-container-content) .wp-block-navigation__submenu-container {
        position: absolute !important; 
        top: 100% !important; 
        left: 0 !important; 
        display: none !important; 
        flex-direction: row !important; 
        gap: 20px !important; 
        z-index: 10;
        border: none !important; 
        padding: 0 !important; 
    }

    header .wp-block-navigation__submenu-container .wp-block-navigation-item {
        margin: 0 !important;
        padding: 0 !important;
        border: none !important;
    }

    header .wp-block-navigation-item.has-child:hover > .wp-block-navigation__submenu-container { 
        display: flex !important; 
    }
}