.luxury-footer{
    background:#000000;
    padding:72px 70px 0;
    overflow:hidden;
    position:relative;
}

/* =========================
   TOP GRID
========================= */

.footer-top{
    display:grid;
    grid-template-columns:1fr 1fr 1fr;
    gap:55px;
    padding-bottom:55px;
    align-items:flex-start;
}

.footer-column{
    display:flex;
    flex-direction:column;
}

.footer-column h4{
    font-size:11px;
    letter-spacing:.22em;
    font-weight:400;
    color:rgba(255,255,255,0.42);
    margin-bottom:26px;
}

.footer-column a{
    color:#ffffff;
    text-decoration:none;
    margin-bottom:8px;
    font-size:15px;
    font-weight:300;
    transition:.3s ease;
    width:fit-content;
    line-height:1.4;
}

.footer-column a:hover{
    opacity:.55;
}

/* =========================
   RIGHT SECTION
========================= */

.footer-right{
    display:flex;
    flex-direction:column;
    gap:42px;
}

.footer-block{
    display:flex;
    flex-direction:column;
}

.footer-links{
    display:flex;
    flex-direction:column;
    gap:8px;
}

.footer-block p{
    color:rgba(255,255,255,0.58);
    line-height:1.9;
    font-size:14px;
    max-width:520px;
    margin-bottom:24px;
}

/* =========================
   INPUT
========================= */

.footer-input-line{
    position:relative;
    display:flex;
    align-items:center;
    border-bottom:1px solid rgba(255,255,255,0.14);
    min-height:52px;
}

.footer-input-line input{

    width:100%;

    height:100%;

line-height:normal;

display:block;


    background:transparent !important;

    border:none;

    outline:none;

    box-shadow:none !important;

    color:#ffffff;

    -webkit-text-fill-color:#ffffff;

    caret-color:#ffffff;

    font-size:16px;

    font-family:'Futura PT Book',sans-serif;

    padding:0 32px 0 0;
    
    line-height:52px;

    opacity:1;

    appearance:none;

    -webkit-appearance:none;
}

.footer-input-line input:focus{
    outline:none;
    background:transparent !important;
}


.footer-input-line input::placeholder{

    color:rgba(255,255,255,.32);

    opacity:1;

    -webkit-text-fill-color:rgba(255,255,255,.32);

}

.footer-input-line input:-webkit-autofill,
.footer-input-line input:-webkit-autofill:hover,
.footer-input-line input:-webkit-autofill:focus{

    -webkit-box-shadow:0 0 0 1000px #000 inset !important;

    -webkit-text-fill-color:#ffffff !important;
}

.newsletter-submit{

    background:none;

    border:none;

    color:#ffffff;

    font-size:16px;

    cursor:pointer;

    padding:0;

    width:20px;

    height:20px;

    display:flex;

    align-items:center;

    justify-content:center;

    line-height:1;

    flex-shrink:0;
}
/* =========================
   COUNTRY
========================= */

.footer-country{
    color:#ffffff;
    font-size:15px;
    opacity:.9;
    margin-top:-2px;
}

/* =========================
   MIDDLE
========================= */

.footer-middle{
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:42px 0 50px;
}

.footer-copy{
    color:rgba(255,255,255,0.45);
    font-size:13px;
    display:flex;
    align-items:center;
    transform:translateY(-2px);
}

.footer-socials{
    display:flex;
    align-items:center;
    gap:38px;
    transform:translateY(-2px);
}

.footer-socials a{
    color:rgba(255,255,255,0.68);
    text-decoration:none;
    font-size:15px;
    transition:.3s ease;
    margin:0;
    padding:0;
    line-height:1;
}

.footer-socials a:hover{
    color:#ffffff;
}



/* =========================
   POPUP
========================= */

.newsletter-popup{
    position:fixed;
    left:40px;
    bottom:40px;
    z-index:999999;
    opacity:0;
    visibility:hidden;
    transform:translateY(30px);
    transition:.4s ease;
}

.newsletter-popup.active{
    opacity:1;
    visibility:visible;
    transform:translateY(0);
}

.newsletter-popup-box{
    background:#111111;
    border:1px solid rgba(255,255,255,0.08);
    padding:18px 24px;
    display:flex;
    align-items:center;
    gap:14px;
}

.newsletter-popup-icon{
    width:28px;
    height:28px;
    border-radius:50%;
    border:1px solid rgba(255,255,255,0.15);
    display:flex;
    align-items:center;
    justify-content:center;
    color:#ffffff;
    font-size:13px;
}

.newsletter-popup-text{
    color:#ffffff;
    font-size:13px;
    letter-spacing:.03em;
}

/* =========================
   RESPONSIVE
========================= */

@media(max-width:1100px){

    .footer-top{
        grid-template-columns:1fr;
        gap:55px;
    }

}

@media(max-width:768px){

    .luxury-footer{
        padding:60px 24px 0;
    }

    .footer-top{
        gap:45px;
        padding-bottom:42px;
    }

    .footer-middle{

    display:flex;

    flex-direction:column-reverse !important;

    justify-content:flex-start !important;

    align-items:flex-start;

    gap:18px;

    padding:28px 0;
}

    .footer-socials{
        gap:20px;
        flex-wrap:wrap;
    }

    .footer-logo-big{
        display:none;
    }

    .newsletter-popup{
        left:20px;
        right:20px;
        bottom:20px;
    }
    
    .footer-input-line input{

    color:#ffffff !important;

    -webkit-text-fill-color:#ffffff !important;
}

.footer-input-line input::placeholder{

    color:#8d8d8d !important;

    -webkit-text-fill-color:#8d8d8d !important;

    opacity:1 !important;
}

    .newsletter-popup-box{
        min-width:100%;
    }
    
    #newsletterEmail{

    color:#ffffff !important;

    -webkit-text-fill-color:#ffffff !important;

    caret-color:#ffffff !important;
}

#newsletterEmail::placeholder{

    color:rgba(255,255,255,.38) !important;

    -webkit-text-fill-color:rgba(255,255,255,.38) !important;
}


#newsletterEmail{

    font-size:16px !important;

    color:#ffffff !important;

    -webkit-text-fill-color:#ffffff !important;
}
.newsletter-form{

    display:none !important;
}

.footer-block p{

    display:none !important;
}
.footer-right .footer-block:nth-child(2){

    display:none !important;
}


}

/* =========================================
FINAL BAG FIX
========================================= */

.bag-panel{

    overflow:hidden !important;
}

.bag-content{

    flex:1;

    overflow-y:auto;

    min-height:0;
}

.bag-footer{

    position:relative;

    bottom:auto;

    left:auto;

    right:auto;

    width:100%;

    flex-shrink:0;

    background:#000000;

    z-index:10;
}

.bag-subtotal{

    display:flex;

    align-items:flex-start;

    justify-content:space-between;

    gap:20px;

    width:100%;
}

.subtotal-left{

    display:flex;

    flex-direction:column;

    gap:4px;
}

.subtotal-title{

    font-size:18px;

    color:#ffffff;
}

.subtotal-items{

    font-size:14px;

    color:rgba(255,255,255,.45);
}

.subtotal-price{

    font-size:18px;

    color:#ffffff;

    font-weight:500;
}

/* =========================================
DESKTOP BAG
========================================= */

.bag-item-bottom{

    display:flex;

    align-items:center;

    justify-content:space-between;

    gap:20px;

    width:100%;
}

.quantity-box{

    display:flex;

    align-items:center;

    gap:18px;
}

.quantity-controls{

    display:flex;

    align-items:center;

    gap:14px;
}

.remove-item{

    margin-left:auto;

    white-space:nowrap;
}

/* =========================================
MOBILE BAG FIX
========================================= */

@media(max-width:768px){

    .bag-panel{

        width:100% !important;

        max-width:100% !important;
    }

    .bag-item{

        gap:14px;
    }

    .bag-item-details{

        width:100%;

        min-width:0;
    }

    .bag-item-bottom{

        display:flex !important;

        align-items:center !important;

        justify-content:space-between !important;

        gap:10px !important;

        width:100%;
    }

    .quantity-box{

        display:flex !important;

        align-items:center !important;

        gap:10px !important;

        flex-wrap:nowrap;
    }

    .quantity-controls{

        display:flex !important;

        align-items:center !important;

        gap:12px !important;

        visibility:visible !important;

        opacity:1 !important;
    }

    .quantity-btn{

        display:flex !important;

        align-items:center !important;

        justify-content:center !important;

        visibility:visible !important;

        opacity:1 !important;

        color:#ffffff !important;

        font-size:22px !important;

        width:28px;

        height:28px;
    }

    .quantity-value{

        display:block !important;

        visibility:visible !important;

        opacity:1 !important;

        color:#ffffff !important;

        min-width:12px;
    }

    .remove-item{

        display:block !important;

        visibility:visible !important;

        opacity:1 !important;

        margin-left:auto !important;

        color:#ffffff !important;

        text-decoration:underline;

        white-space:nowrap;

        font-size:12px;
    }

    .bag-checkout{

        height:54px;

        font-size:14px;
    }



}