/* --- LAYER 1: CORE BRANDING & FONTS --- */
@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css');
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@600;700;800&display=swap');

:root {
    --coral: #FF5252;
    --slate: #0f172a;
    --border-pro: #e2e8f0;
    --glow: rgba(255, 82, 82, 0.25);
}

body { font-family: 'Plus Jakarta Sans', sans-serif !important; }

/* --- LAYER 2: GLOBAL BUTTONS & NAV --- */
.navbar a[href*="shop/register"], 
#cartButtonHolder a, 
.btn-cart, 
.btn-outline-primary, 
#promo_code_btn {
    background: #fff !important; color: var(--slate) !important; border: 1.5px solid var(--border-pro) !important;
    padding: 10px 22px !important; border-radius: 50px !important; font-weight: 700 !important;
    display: inline-flex !important; align-items: center !important; justify-content: center !important;
    transition: 0.3s ease !important; text-transform: none !important; box-shadow: none !important;
}

#promo_code_btn:hover, .btn-outline-primary:hover, .navbar a:hover, #cartButtonHolder a:hover {
    background: var(--coral) !important; color: #fff !important; border-color: var(--coral) !important;
}

#cartButtonHolder a i, .btn-cart i, .fa-shopping-basket { margin-right: 12px !important; color: #000000 !important; }

/* --- LAYER 3: MODERN FOOTER & SEARCH BAR --- */
footer a, footer .btn, .footer a, .footer .nav-link {
    background: transparent !important; border: none !important; color: var(--slate) !important;
    font-weight: 600 !important; font-size: 0.95rem !important; padding: 5px 12px !important;
    box-shadow: none !important; transition: 0.2s ease !important; display: inline-block !important;
}
footer a:hover, footer .btn:hover { color: var(--coral) !important; }

.col-md-4 .form-group .input-group { 
    background: #fff !important; border-radius: 40px !important; 
    border: 1.5px solid var(--border-pro) !important; overflow: hidden !important; 
    display: flex !important; align-items: center !important; box-shadow: none !important;
}
.col-md-4 #txtlocation { 
    border: none !important; height: 55px !important; padding-left: 20px !important; 
    flex: 1 !important; box-shadow: none !important; background: transparent !important;
}
.col-md-4 .input-group-append .input-group-text { background: transparent !important; border: none !important; padding-right: 20px !important; cursor: pointer !important; }
.col-md-4 .fa-map-pin { color: var(--coral) !important; font-size: 1.2rem; }

/* --- LAYER 4: HOMEPAGE CITY CARDS (Text-Safe Fix) --- */
.strip_city { 
    height: 180px !important; width: 100% !important; overflow: hidden !important; 
    border-radius: 28px !important; border: 1.5px solid var(--border-pro) !important; 
    position: relative !important; display: block !important;
}
.strip_city figure { height: 100% !important; width: 100% !important; margin: 0 !important; display: block !important; position: relative !important; }

/* TARGET ONLY THE IMAGE LINK wrapper, protecting the text links below it */
.strip_city figure > a:first-child { height: 100% !important; width: 100% !important; display: block !important; }
.strip_city img { width: 100% !important; height: 100% !important; object-fit: cover !important; display: block !important; transition: transform 0.4s ease !important; }
.strip_city:hover img { transform: scale(1.05); }

/* Restores City Text overlay */
.strip_city .city_title { position: absolute !important; bottom: 35px !important; left: 20px !important; z-index: 5 !important; display: block !important; }
.strip_city .city_letter { position: absolute !important; bottom: 15px !important; left: 20px !important; z-index: 5 !important; display: block !important; }
.strip_city .text-white { color: #fff !important; }

/* --- LAYER 5: SHOP LIST CARDS (Leeds Alignment) --- */
.resitems .strip { 
    border-radius: 24px !important; background: #ffffff !important; 
    border: 1.5px solid var(--border-pro) !important; overflow: hidden !important; 
    display: flex !important; flex-direction: column !important; cursor: pointer !important;
    margin-bottom: 30px !important; transition: 0.3s ease !important;
}
.resitems .strip:hover { transform: translateY(-5px); box-shadow: 0 12px 30px rgba(0,0,0,0.08); }

.resitems .res_title_row { 
    display: flex !important; justify-content: space-between !important; align-items: center !important;
    padding: 20px 20px 10px 20px !important; width: 100% !important; 
}
.resitems .res_title { margin: 0 !important; font-weight: 800 !important; font-size: 1.15rem !important; color: var(--slate) !important; }
.resitems .res_description { 
    padding: 0 20px 15px 20px !important; color: #64748b !important; 
    font-size: 0.9rem !important; white-space: nowrap !important; 
    overflow: hidden !important; text-overflow: ellipsis !important; margin: 0 !important;
}
.resitems .res_mimimum { 
    margin: 0 20px 20px 20px !important; padding: 6px 12px !important; 
    background: #FFF5F5 !important; color: var(--coral) !important; 
    border-radius: 8px !important; font-weight: 700 !important; 
    font-size: 0.85rem !important; width: fit-content !important; display: inline-block !important;
}

/* --- LAYER 6: CHECKOUT CARDS (Block-Level Natural Text Flow) --- */
.custom-control-label { 
    /* Block layout replaces Flexbox so text flows naturally left-to-right without shattering */
    display: block !important; 
    width: 100% !important; padding: 25px 20px !important; 
    border-radius: 20px !important; border: 1.5px solid var(--border-pro) !important; 
    cursor: pointer !important; transition: 0.3s all ease !important; background: #fff !important;
    font-weight: 700 !important; text-align: center !important; color: var(--slate) !important;
}
.custom-control-label::before, .custom-control-label::after { display: none !important; }

.custom-control-input:checked ~ .custom-control-label { 
    border-color: var(--coral) !important; background: #FFF9F9 !important; color: var(--coral) !important; 
    box-shadow: 0 8px 25px var(--glow) !important;
}

/* --- LAYER 7: TERMS UX (Clean & Clickable) --- */
label[for="privacypolicy"] { 
    border: 2px dashed #cbd5e1 !important; 
    line-height: 1.6 !important; 
    font-size: 0.95rem !important; 
}
label[for="privacypolicy"] a { 
    color: var(--coral) !important; text-decoration: underline !important; 
    position: relative !important; z-index: 10 !important; 
}

#stripeSend { width: 100% !important; height: 65px !important; background: var(--coral) !important; border-radius: 20px !important; font-weight: 800 !important; border: none !important; color: #fff !important; margin-top: 15px !important;}