body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}
.custom-button{color:#fff;background-color:#212529;border-color:#212529;}
.custom-button:hover{color:#fff;background-color:#1c1f23;border-color:#1a1e21;}
.custom-button:focus,.custom-button.focus{color:#fff;background-color:#1c1f23;border-color:#1a1e21;box-shadow:0 0 0 0.25rem rgba(66,70,73,.5);}
.custom-button:active,.custom-button.active,.show>.custom-button.dropdown-toggle{color:#fff;background-color:#1a1e21;border-color:#191c1f;}
.custom-button:active:focus,.custom-button.active:focus,.show>.custom-button.dropdown-toggle:focus{box-shadow:0 0 0 0.25rem rgba(66,70,73,.5);}
.custom-button:disabled,.custom-button.disabled{color:#fff;background-color:#212529;border-color:#212529;}
.navbar { border-bottom: 1px solid #d7d7d7; }
.hero{padding:6rem 0}
.hero h1{font-weight:700}
.hero p{max-width:520px; color:#555}
.product-card{transition:all .25s ease;border-radius:1rem; border: 1px solid #f5f5f5}
.product-card:hover{transform:translateY(-6px);box-shadow:0 1.5rem 3rem rgba(0,0,0,.08)}
.product-img{height:220px;display:flex;align-items:center;justify-content:center;border-radius:.75rem}
.cart-btn{background:#e9e9e9;border:none}
.cart-btn:hover{background:#d2d2d2}
.nav-item:hover{background-color: #d2d2d2;border-radius: 50px;transition: all 0.3s;}
.sticky-btn {position: sticky;top: 20px;align-self: flex-start;width: 400px;border-radius: 25px;border: 1px solid #eee;background-color: #fcfcfc;padding-top: 25px; padding-bottom: 25px;}
.feature-icon {font-size: 1.5rem;margin-right: 10px;color: #333}
.product-description p {line-height: 1.6}
.add-to-cart-btn {background-color: #333;color: #fff;border: none;transition: background-color 0.3s}
.add-to-cart-btn:hover {background-color: #555;}
.car-img {width: 100%;height: 420px;object-fit: cover;border-radius: 1rem;}
.object-fit-cover {object-fit: cover}
.carousel-thumb {width: 70px;height: 70px;object-fit: cover;cursor: pointer;border-radius: 0.5rem;opacity: 0.6;border: 2px solid transparent;transition: all 0.2s ease}
.carousel-thumb:hover {opacity: 1}
.carousel-thumb.active {opacity: 1;border-color: #000}
.carousel-control-prev-icon, .carousel-control-next-icon {background-color: rgb(0, 0, 0);border-radius: 5px}
.badge { cursor: pointer; }
.color-swatch {width: 30px;height: 30px;border-radius: 50%;border: 2px solid #ccc;cursor: pointer;transition: all 0.2s;}
.color-swatch:hover {transform: scale(1.1);border-color: #000;}
.color-swatch.selected {border-color: #000;box-shadow: 0 0 0 2px #000 inset;}
.fade-slide {opacity: 0;transform: translateY(-20px);transition: opacity 0.6s ease, transform 0.6s ease;}
.fade-slide.show {opacity: 1;transform: translateY(0);}
.badge.bg-warning {animation: pulse 1.4s infinite;}
@keyframes pulse {0% { transform: scale(1); }50% { transform: scale(1.05); }100% { transform: scale(1); }}
.product-card img { object-fit: contain; height: 240px; }
.stars { letter-spacing: 1px; }
.buy-now-btn { background: linear-gradient(135deg, #000000, #1a1a1a); color: #fff; border: none; transition: transform 0.15s ease, box-shadow 0.15s ease; }
.buy-now-btn:hover { color: #fff; transform: translateY(-1px); box-shadow: 0 10px 25px rgba(0,0,0,0.25); }
.wishlist-btn { background: #282828; border: 1px solid #e0e0e0; color: #dddddd; transition: all 0.15s ease; }
.wishlist-btn:hover { background: #fff; border-color: #ccc; }
.wishlist-btn.active { background: #ffeaea; border-color: #ff5a5a; color: #ff5a5a; }
.add-to-cart-btn { border: 1px solid #000; transition: transform 0.15s ease, box-shadow 0.15s ease; }
.add-to-cart-btn:hover { transform: translateY(-1px); box-shadow: 0 10px 25px rgba(0,0,0,0.25); }
#cartOverlay { position: fixed; inset: 0; background: rgba(0,0,0,0.45); opacity: 0; pointer-events: none; transition: 0.3s; z-index: 9999; }
#cartSidebar { position: fixed; top: 0; right: -420px; width: 420px; height: 100vh; background: #fff; z-index: 1050; display: flex; flex-direction: column; transition: 0.35s ease; box-shadow: -10px 0 40px rgba(0,0,0,0.15); }
#cartSidebar.active { right: 0; }
#cartOverlay.active { opacity: 1; pointer-events: auto; }
.sidebar-header { padding: 20px; border-bottom: 1px solid #eee; display: flex; justify-content: space-between; align-items: center; }
.close-btn { background: none; border: none; font-size: 20px; }
.sidebar-body { padding: 20px; flex-grow: 1; overflow-y: auto; }
.sidebar-footer { padding: 20px; border-top: 1px solid #eee; }
.quantity-control { border: 1.5px solid #000; border-radius: 999px; padding: 6px 10px; width: fit-content; }
.qty-btn { width: 36px; height: 36px; border-radius: 50%; border: none; background: #000; color: #fff; font-size: 18px; font-weight: 600; cursor: pointer; transition: transform 0.15s ease, background 0.15s ease; }
.qty-btn:hover { transform: scale(1.08); background: #222; }
.qty-input { width: 42px; text-align: center; border: none; background: transparent; font-weight: 600; font-size: 16px; outline: none; }
.wishlist-card { transition: transform 0.25s ease, box-shadow 0.25s ease; border-radius: 16px; }
.wishlist-card:hover { transform: translateY(-6px); box-shadow: 0 12px 30px rgba(0, 0, 0, 0.12); }
.wishlist-image-wrapper { height: 220px; background: #f8f9fa; display: flex; align-items: center; justify-content: center; border-top-left-radius: 16px; border-top-right-radius: 16px; }
.wishlist-image { max-height: 180px; max-width: 90%; object-fit: contain; }
.marquee-wrapper { width: 100%; overflow: hidden; background: #000; color: #fff; height: 44px; display: flex; align-items: center; position: relative; z-index: 1000; }
.marquee-track { display: flex; width: max-content; animation: scroll-left 18s linear infinite; }
.marquee-content { display: flex; gap: 60px; padding-right: 60px; white-space: nowrap; }
.marquee-content span { font-weight: 600; font-size: 0.9rem; letter-spacing: 0.4px; }
@keyframes scroll-left { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.marquee-wrapper:hover .marquee-track { animation-play-state: paused; }
.marquee-wrapper { background: #ffffff; color: #000000; }
.marquee-wrapper::before { left: 0; background: linear-gradient(to right, #ffffff, transparent); }
.marquee-wrapper::after { right: 0; background: linear-gradient(to left, #ffffff, transparent); }
.footer-features { background: #171717; color: #fff; padding: 60px 0; }
.feature-item i { font-size: 2rem; color: #1E90FF; margin-bottom: 10px; }
.feature-item h6 { font-weight: 600; letter-spacing: 0.5px; }
.feature-item p { font-size: 0.9rem; color: #aaa; margin: 0; }
.main-footer { background: #171717; color: #aaa; }
.footer-brand { font-weight: 700; color: #fff; }
.footer-text { font-size: 0.9rem; }
.main-footer h6 { color: #fff; font-weight: 600; }
.main-footer ul { list-style: none; padding: 0; }
.main-footer li { margin-bottom: 8px; }
.main-footer a { color: #aaa; text-decoration: none; transition: color 0.2s; }
.main-footer a:hover { color: #1E90FF; }
.footer-bottom { border-top: 1px solid #4a4a4a; text-align: center; padding: 15px; font-size: 0.85rem; color: #777; }
.footer-separator { background: #171717; padding: 14px 0; overflow: hidden; }
.footer-separator span { display: block; height: 0.5px; width: 120%; background: linear-gradient(90deg, transparent, #1E90FF, transparent); animation: separator-glow 4s linear infinite; }
@keyframes separator-glow { from { transform: translateX(-100%); } to { transform: translateX(100%); } }
.cart-item { display: flex; gap: 16px; padding: 16px 0; align-items: center; }
.cart-item-img { width: 90px; height: 90px; object-fit: contain; background: #f8f8f8; border-radius: 12px; padding: 8px; }
.cart-item-info { flex-grow: 1; }
.cart-item-info h6 { font-weight: 600; margin-bottom: 4px; }
.cart-meta { font-size: 0.85rem; color: #6c757d; display: flex; flex-direction: column; gap: 2px; }
.cart-price { margin-top: 6px; font-weight: 600; }
.cart-controls { display: flex; align-items: center; gap: 10px; border: 1px solid #e0e0e0; border-radius: 999px; padding: 4px 10px; }
.cart-controls button { background: none; border: none; font-size: 18px; width: 28px; height: 28px; cursor: pointer; }
.cart-controls span { min-width: 20px; text-align: center; font-weight: 500; }
.cart-item:hover { background: rgba(0,0,0,0.02); }
.cart-summary { background: #fafafa; border: 1px solid #eaeaea; }
.cookie-banner { position: fixed; bottom: 0; background: #eeeeee; padding: 16px 20px; width: 100%; z-index: 9999; opacity: 0; pointer-events: none; transform: translateY(20px); transition: all 0.3s ease; }
.cookie-banner.show { opacity: 1; pointer-events: auto; transform: translateY(0); }
.cookie-content h6 { font-weight: 600; }
.cookie-content p { color: #555; line-height: 1.4; }
.cookie-actions { display: flex; gap: 10px; margin-top: 10px; }
#themeToggle { position: fixed; bottom: 20px; left: 20px; width: 50px; height: 50px; border-radius: 50%; border: none; background: #1E1E1E; color: #fff; cursor: pointer; font-size: 20px; display: flex; align-items: center; justify-content: center; z-index: 10000; box-shadow: 0 4px 12px rgba(0,0,0,0.25); transition: background 0.3s, color 0.3s; }
#themeToggle:hover { background: #333; }
.cta {background-color: #222;color: #cfcfcf;}
.price {color: #282828;}
.border-toggle {border: 2px solid rgb(0, 0, 0)}
.outline-toggle {border: 1px solid #1d1d1d; color: #1d1d1d}
.btn-toggle {background-color: #1d1d1d; color: #f8f8f8}
.cart-item-img {grid-area: img;}
.cart-item-info {grid-area: info;}
.cart-controls {grid-area: controls;margin-top: 6px;align-self: start;}
/* --- Hero Section Styling --- */
.hero {
  /* Centers content vertically and horizontally */
  display: flex;
  align-items: center;
  justify-content: center;
  
  /* Sets a minimum height so it takes up a good portion of the screen */
  min-height: 70vh; 
  
  /* Adds a background image with a dark overlay so text is readable */
  /* Replace 'your-image-url.jpg' with your actual image path */
  background: linear-gradient(rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.6)), 
              url('your-image-url.jpg') no-repeat center center;
  background-size: cover;
  
  /* Sets text color to white for contrast */
  color: white;
  
  /* Adds padding for better spacing on smaller screens */
  padding: 4rem 1rem;
}

/* --- Typography Styling --- */

/* Targets the main headline */
.hero h1.display-5 {
  /* Makes the font larger and bolder for emphasis */
  font-size: 3.5rem; 
  font-weight: 700;
  
  /* Adds a subtle text shadow for better definition */
  text-shadow: 2px 2px 4px rgba(0,0,0,0.5);
}

/* Targets the paragraph text */
.hero p.text-muted {
  /* Overrides the default 'text-muted' color to a lighter, readable gray */
  color: rgba(255, 255, 255, 0.8) !important;
  
  /* Increases font size for better readability */
  font-size: 1.25rem;
  font-weight: 300;
  
  /* Limits line length for easier reading */
  max-width: 600px;
}

/* --- Animation Styling --- */

/* Defines the animation class */
.fade-slide {
  /* Refers to the keyframes defined below */
  animation: slideUpFadeIn 1s ease-out forwards;
  
  /* Starts elements as invisible to avoid a flash before animation */
  opacity: 0;
}

/* Adds a slight delay to the paragraph for a staggered effect */
.hero p.fade-slide {
  animation-delay: 0.3s;
}

/* Defines the animation keyframes */
@keyframes slideUpFadeIn {
  from {
    opacity: 0;
    /* Starts the element 30 pixels down from its final position */
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    /* Ends the element in its original position */
    transform: translateY(0);
  }
}
.gm-hero-section {
    /* Use Flexbox to center content vertically and horizontally */
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;

    /* Set height to a good portion of the viewport */
    min-height: 85vh;
    /* Ensure padding doesn't affect width calculation */
    box-sizing: border-box; 
    padding: 2rem 1rem;

    /* Text color for contrast against the dark background */
    color: #ffffff;
    position: relative;
    
    /* Ensure default font for this section if site doesn't have one */
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

    /* --- Background Image & Overlay --- */
    /* Dark, slight purple/blue gradient overlay so text is readable over any image. */
    background: linear-gradient(
                    rgba(10, 10, 30, 1), 
                    rgba(30, 10, 60, 0.3)
                ),
                /* REPLACE THE PATH BELOW WITH YOUR IMAGE */
                url('images/hero-image.png') no-repeat center center;
    
    background-size: cover;
}
/* Section Background Color */
.gm-dark-bg { background-color: #121212; }

/* Custom Dark Card Styling */
.gm-card { background-color: #1a1a1a; border: 1px solid #333; transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease; }
/* Card Hover Effect - Lift and subtle glow */
.gm-card:hover { transform: translateY(-7px); box-shadow: 0 10px 25px -5px rgba(0,0,0,0.5); border-color: #555; }

/* Image wrapper fixed height to ensure cards are same size */
.img-wrapper { height: 220px; display: flex; align-items: center; justify-content: center; padding: 10px; }
/* Ensures image fits inside wrapper without stretching */
.contain-fit { max-height: 100%; max-width: 100%; object-fit: contain; }

/* Custom Outline Button for Dark Mode */
.gm-btn-outline { color: #fff !important; border: 2px solid #fff !important; transition: all 0.3s ease; }
.gm-btn-outline:hover { background-color: #fff; color: #000; border-color: #fff; box-shadow: 0 0 15px rgba(255,255,255,0.3); }

/* Utility for letter spacing */
.ls-1 { letter-spacing: 1px; }
/* Overriding Bootstrap text-white-50 to ensure visibility */
.text-white-50 { color: rgba(255, 255, 255, 0.6) !important; }
/* Content Wrapper */
.gm-hero-container {
    position: relative;
    top: -100px;
    /* Constrain width on large screens so text doesn't stretch too far */
    width: 100%;
    max-width: 1600px;
    z-index: 1; /* Ensure content sits above background */
}

/* Typography */
.gm-hero-headline {
    /* Big, bold, and uppercase for gaming impact */
    font-size: 2.5rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin: 0 0 1.5rem 0; /* Reset margins and add bottom spacing */
    line-height: 1.1;

    /* Optional: A slight text shadow to make it pop */
    text-shadow: 3px 3px 6px rgba(0,0,0,0.6);
}

.gm-hero-description {
    font-size: 1.125rem;
    line-height: 1.6;
    margin: 0 auto 2.5rem auto; /* Center horizontally and spacing below */
    /* Slightly transparent white for better hierarchy against the title */
    color: rgba(255, 255, 255, 0.9);
    max-width: 600px;
}

/* Button Group Container */
.gm-hero-cta-group {
    display: flex;
    justify-content: center;
    gap: 15px; /* Space between buttons */
    flex-wrap: wrap; /* Ensure they stack on very small mobile screens */
}

/* =========================================
   Isolated Button Styles
   ========================================= */

/* Base Button Style (Applies to both buttons) */
.gm-hero-btn {
    display: inline-block;
    box-sizing: border-box;
    padding: 14px 30px;
    border-radius: 4px;
    text-decoration: none;
    font-weight: 700;
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    transition: all 0.3s ease;
    cursor: pointer;
    border: 2px solid transparent; /* Placeholder for alignment */
    line-height: 1; /* Ensures accurate padding */
}

/* Hover effect lift for all hero buttons */
.gm-hero-btn:hover {
    transform: translateY(-4px);
}

/* Variant 1: The Primary "Glow" Button (Electric Cyan) */
.gm-hero-btn-glow {
    background-color: #00e5ff; /* Cyberpunk Cyan color */
    color: #000000; /* Black text on bright background for contrast */
}

.gm-hero-btn-glow:hover {
    background-color: #5cf0ff; /* Slightly lighter on hover */
    box-shadow: 0 0 20px rgba(0, 229, 255, 0.6); /* Intense glowing effect */
}

/* Variant 2: The Secondary "Outline" Button */
.gm-hero-btn-outline {
    background-color: transparent;
    border-color: #ffffff;
    color: #ffffff;
}

.gm-hero-btn-outline:hover {
    background-color: #ffffff;
    color: #000000;
    box-shadow: 0 0 15px rgba(255, 255, 255, 0.3); /* subtle white glow */
}

/* =========================================
   Responsive Breakpoints for Hero Section
   ========================================= */
/* On larger screens (tablets and desktops), make fonts bigger */
@media (min-width: 768px) {
    .gm-hero-headline {
        font-size: 4.5rem;
    }

    .gm-hero-description {
        font-size: 1.35rem;
    }

    .gm-hero-btn {
        padding: 16px 36px;
    }
}
/* --- Responsive Adjustments --- */
@media (max-width: 768px) {
  .hero h1.display-5 {
    font-size: 2.5rem; /* Smaller headline on mobile */
  }
  .hero p.text-muted {
    font-size: 1.1rem; /* Smaller paragraph on mobile */
  }
}
@media (max-width: 576px) {
    .cart-item {align-items: stretch;}
    .cart-item-img {width: 80px;height: 80px;}
    .cart-controls {align-self: flex-start;}}
footer{font-size:.9rem}

body.dark-mode { background: #1d1d1d; color: #dedede; }
body.dark-mode .custom-button{color:#000;background-color:#f8f9fa;border-color:#f8f9fa;}
body.dark-mode .custom-button:hover{color:#000;background-color:#e2e6ea;border-color:#dae0e5;}
body.dark-mode .custom-button:focus,body.dark-mode .custom-button.focus{color:#000;background-color:#e2e6ea;border-color:#dae0e5;box-shadow:0 0 0 0.25rem rgba(211,212,213,.5);}
body.dark-mode .custom-button:active,body.dark-mode .custom-button.active,body.dark-mode .show>.custom-button.dropdown-toggle{color:#000;background-color:#dae0e5;border-color:#d3d9df;}
body.dark-mode .custom-button:active:focus,body.dark-mode .custom-button.active:focus,body.dark-mode .show>.custom-button.dropdown-toggle:focus{box-shadow:0 0 0 0.25rem rgba(211,212,213,.5);}
body.dark-mode .custom-button:disabled,body.dark-mode .custom-button.disabled{color:#000;background-color:#f8f9fa;border-color:#f8f9fa;}
body.dark-mode .navbar-brand { color: #cfcfcf;  background-color: #1d1d1d;}
body.dark-mode .navbar { border-bottom: 1px solid #3f3f3f; }
body.dark-mode .navbar .nav-link { color: #e3e3e3; }
body.dark-mode .text-muted { color: #aaa !important; }
body.dark-mode .nav-item:hover{background-color: #373737;border-radius: 50px;transition: all 0.3s;}
body.dark-mode .hero p { color: #cecece; }
body.dark-mode .carousel-control-prev-icon, body.dark-mode .carousel-control-next-icon { color: #ffffff; background-color: #1d1d1d; }
body.dark-mode .product-card { background-color: #1d1d1d; border: 1px solid #333;}
body.dark-mode .product-btn {background-color: #1d1d1d1d; color: #d7d7d7; border: 1px solid white;}
body.dark-mode .product-btn:hover {background: #d7d7d7; color: #1d1d1d;}
body.dark-mode .card-title { color: #e8e8e8; }
body.dark-mode .buy-now-btn { background: #f8f9fa;; color: #181818;}
body.dark-mode .wishlist-btn { background: #222; border-color: #555; color: #fff; }
body.dark-mode .sticky-btn { background: #212121; border-color: #242424; color: #fff; }
body.dark-mode .marquee-wrapper { width: 100%; overflow: hidden; background: #1d1d1d; color: #fff; height: 44px; display: flex; align-items: center; position: relative; z-index: 1000; }
body.dark-mode .marquee-wrapper::before, body.dark-mode .marquee-wrapper::after { content: ''; position: absolute; top: 0; width: 40px; height: 100%; z-index: 2; }
body.dark-mode .marquee-wrapper::before { left: 0; background: linear-gradient(to right, #1d1d1d, transparent); }
body.dark-mode .marquee-wrapper::after { right: 0; background: linear-gradient(to left, #1d1d1d, transparent); }
body.dark-mode .footer-features, body.dark-mode .main-footer { background: #000000; color: #ffffff; }
body.dark-mode .feature-item i { color: #1E90FF; }
body.dark-mode .feature-item p, body.dark-mode .footer-text { color: #aaa; }
body.dark-mode .footer-bottom { border-color: #555; color: #aaa; }
body.dark-mode .footer-separator { background-color: #000; }
body.dark-mode .footer-separator span { background: linear-gradient(90deg, transparent, #1E90FF, transparent); }
body.dark-mode .explore-collection { background-color: #1E90FF; color: #fff; border: none; }
body.dark-mode .cart-summary { background: #222; border-color: #444; color: #fff; }
body.dark-mode .cart-item:hover { background: rgba(255,255,255,0.05); }
body.dark-mode .cookie-banner { background: #1E1E1E; color: #fff; }
body.dark-mode .sidebar-body { background: #1E1E1E; color: #fff; }
body.dark-mode #themeToggle { background: #eeeeee; color: #fff; }
body.dark-mode .cta {background-color: #cfcfcf;color: #222;}
body.dark-mode .price {color: #d5d5d5;}
body.dark-mode .wishlist-image-wrapper { height: 220px; background: #2b2b2b; display: flex; align-items: center; justify-content: center; border-top-left-radius: 16px; border-top-right-radius: 16px; }
body.dark-mode .wishlist-body {background-color: #1d1d1d;}
body.dark-mode .wishlist-name {color: #d5d5d5;}
body.dark-mode .wishlist-price {color: #d5d5d5}
body.dark-mode .wishlist-btn { background: #d0d0d0; border: 1px solid #e0e0e0; color: #1d1d1d; transition: all 0.15s ease; }
body.dark-mode .wishlist-btn:hover { background: #272727; border-color: #ccc;  color: #d0d0d0;}
body.dark-mode #cartPanel {background-color: #1d1d1d !important; border: 1px solid #434343 !important;}
body.dark-mode #checkoutBtn {background-color: #e3e3e3; color: #1d1d1d;}
body.dark-mode #checkoutBtn:hover {background-color: #b5b5b5;}
body.dark-mode .border-bottom {color: #2b2b2b !important;}
.payment-container {display: flex;gap: 20px;justify-content: end;align-items: center}
.payment-icon {width: 60px;transition: transform 0.2s}
body.dark-mode .outline-toggle {border: 1px solid #f8f9fa; color: #f9f9f9}
/* Smooth transition */
.text-toggle{transition:color .2s ease;}

/* Light mode */
.text-toggle{color:#212529;}

/* Dark mode */
body.dark-mode .text-toggle{color:#f8f9fa;}
body.dark-mode .border-toggle {border: 2px solid rgb(255, 255, 255)}
body.dark-mode .btn-toggle {background-color: #f9f9f9; color: #1d1d1d}
body.dark-mode .btn-toggle:hover {background-color: #1d1d1d; color: #f9f9f9;}
body.dark-mode .name-toggle {color: #d1d1d1;}
body.dark-mode .p-toggle {color: #e1e1e1;}
body.dark-mode .sidebar-header {background-color: #1E1E1E; border-bottom: 1px solid #1E1E1E;}
body.dark-mode .sidebar-footer {background-color: #1E1E1E; border-top: 1px solid #1E1E1E}
body.dark-mode .qty-input {color: #f8f9fa;}
body.dark-mode .login-card {background-color: #212529;}
body.dark-mode .login-card h2 {color: #f8f9fa;}
body.dark-mode .form-control {background-color: #212529;}
body.dark-mode input::placeholder {color: #f8f9fa;}
body.dark-mode input {border: 1px solid #394047}
#cartSidebar {z-index: 9999;}
body.dark-mode .toggle-icon-light {display: none;}
body.dark-mode .toggle-icon-dark {display: block;}
.toggle-icon-light {display: block;}
.toggle-icon-dark {display: none;}
body.dark-mode .back-btn {color: #f8f9fa}
/* Premium Modal Styling */
.modal-content {
    border: none;
    border-radius: 1rem;
    box-shadow: 0 15px 35px rgba(0,0,0,0.2);
    font-family: 'Inter', sans-serif;
}
.modal-header {
    border-bottom: none;
    padding-bottom: 0;
}
.modal-footer {
    border-top: none;
    justify-content: center;
    gap: 10px;
    padding-bottom: 1.5rem;
}
.btn-premium-yes {
    background-color: #333;
    color: white;
    border-radius: 50px;
    padding: 0.6rem 2rem;
    font-weight: 600;
    transition: all 0.2s;
}
.btn-premium-yes:hover {
    background-color: #000;
    transform: translateY(-1px);
}
.btn-premium-no {
    color: #666;
    background: transparent;
    border: 1px solid #ddd;
    border-radius: 50px;
    padding: 0.6rem 2rem;
    font-weight: 600;
    transition: all 0.2s;
}
.btn-premium-no:hover {
    background: #f8f9fa;
    color: #333;
    border-color: #ccc;
}
body.dark-mode .checkout-leave-header {color: #1d1d1d;}
@media (max-width: 991px) {
        .offcanvas {
          background-color: rgba(255, 255, 255, 0.95) !important; /* Glass effect */
          backdrop-filter: blur(15px);
          -webkit-backdrop-filter: blur(15px);
          width: 80% !important; /* Premium width (not full screen, not too skinny) */
          max-width: 350px;
          border-left: 1px solid rgba(0,0,0,0.05);
          box-shadow: -10px 0 30px rgba(0,0,0,0.1);
        }
        body.dark-mode .offcanvas {
            background-color: rgba(10, 10, 10, 0.95) !important;
            z-index: 9999 !important;
        }
        
        .offcanvas-header {
          border-bottom: 1px solid rgba(0,0,0,0.05);
          padding: 1.5rem;
        }
        body.dark-mode .offcanvas-header {
            border-bottom: 1px solid rgba(61, 61, 61, 0.443);
        }

        .offcanvas-body {
          padding: 2rem 1.5rem;
        }

        /* Mobile Menu Links */
        .navbar-nav .nav-item {
          margin-bottom: 1rem;
        }

        .navbar-nav .nav-link {
          font-size: 1.25rem; /* Larger text for mobile touch */
          font-weight: 600;
          color: #333;
          transition: transform 0.2s ease;
        }
        body.dark-mode .navbar-nav .nav-link {
            color: #f8f9fa;
        }

        .navbar-nav .nav-link:active {
          transform: translateX(5px);
          color: #1E90FF !important;
        }

        /* Mobile Icons Row */
        .mobile-icons-row {
          margin-top: auto;
          padding-top: 2rem;
          border-top: 1px solid rgba(0,0,0,0.05);
          display: flex;
          justify-content: space-evenly;
        }
        body.dark-mode .mobile-icons-row {
          border-top: 1px solid rgba(61, 61, 61, 0.443);
        }
      }
      body.dark-mode .toggle-hamburger {
    filter: invert(1) grayscale(100%) brightness(200%);
}
body.dark-mode .review-form {background-color: #f8f9fa !important;}