/* BrahimGSM v2.0 — Thème clair (charge en dernier, override dark legacy) */

body { background: var(--bg-primary); color: var(--text-body); }
a { color: var(--blue-tech); }
a:hover { color: var(--blue-tech-hover); }

/* --- Topbar & Header --- */
.topbar {
    min-height: var(--topbar-height);
    background: var(--topbar-bg);
    color: #fff;
    font-size: 0.8125rem;
    border-bottom: none;
}
.topbar a, .topbar__link { color: #fff; }
.topbar__text { color: rgba(255,255,255,.9); opacity: 1; }
.topbar i { color: var(--orange-cta); }

.site-header {
    background: var(--header-bg);
    box-shadow: 0 2px 8px rgba(12,14,18,.06);
    border-bottom: 1px solid var(--color-border);
}
.site-header .btn-primary,
.site-header .input-group .btn-primary {
    background: var(--orange-cta);
    border-color: var(--orange-cta);
}
.site-header .btn-primary:hover {
    background: var(--orange-cta-hover);
    border-color: var(--orange-cta-hover);
}
.site-header .form-control {
    background: var(--bg-secondary);
    border-color: transparent;
    border-radius: var(--radius-md);
    min-height: 44px;
}
.site-header .form-control:focus {
    background: var(--white);
    border-color: var(--blue-tech);
    box-shadow: var(--focus-ring);
}
.icon-btn {
    background: var(--white);
    border-color: var(--color-border);
    color: var(--text-heading);
}
.icon-btn:hover {
    color: var(--blue-tech);
    border-color: var(--blue-tech-soft);
    background: var(--blue-tech-soft);
}
.icon-btn .badge,
.icon-btn .cart-count,
.icon-btn .wishlist-count {
    background: var(--orange-cta) !important;
    color: #fff !important;
}
.site-header .mg-nav__link.nav-link {
    color: var(--text-heading);
    font-weight: 500;
    background: transparent;
    border-bottom: 2px solid transparent;
    border-radius: 0;
    text-decoration: none;
}
.site-header .mg-nav__link.nav-link:hover,
.site-header .mg-nav__link.nav-link.active {
    color: var(--blue-tech);
    background: transparent;
    border-bottom-color: var(--orange-cta);
    text-decoration: none;
}
.mg-boutique-menu {
    background: var(--white) !important;
    border: 1px solid var(--color-border) !important;
    box-shadow: var(--shadow-lg) !important;
}

/* --- Hero (override v4-ui + variants dark) --- */
.mg-hero--gradient::before,
.hero-slide.hero,
.hero-v-cinematic .mg-hero::before,
.hero-v-cinematic .mg-hero--gradient::before,
.hero-v-minimal .mg-hero::before,
.hero-v-minimal .mg-hero--gradient::before {
    background: linear-gradient(135deg, #F0F6FF 0%, #FFFFFF 100%) !important;
}
.hero-v-cinematic .mg-hero--gradient::before {
    background:
        radial-gradient(ellipse 70% 55% at 85% 25%, rgba(15, 98, 168, 0.12), transparent 55%),
        linear-gradient(135deg, #E8F2FC 0%, #F0F6FF 40%, #FFF 100%) !important;
}
.hero-v-minimal .mg-hero--gradient {
    background-image:
        linear-gradient(rgba(15, 98, 168, 0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(15, 98, 168, 0.04) 1px, transparent 1px) !important;
    background-size: 32px 32px !important;
    background-color: var(--bg-secondary) !important;
}
.hero-v-cinematic .mg-hero__glow {
    background: radial-gradient(circle, rgba(15, 98, 168, 0.2) 0%, transparent 68%);
}
.hero-v-cinematic .mg-hero__title { text-shadow: none; color: var(--text-heading); }
.hero-v-cinematic .mg-hero__device-frame {
    background: linear-gradient(145deg, rgba(255,255,255,.9), rgba(245,247,250,.8));
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-lg);
}
.mg-hero__title { color: var(--text-heading); }
.mg-hero__subtitle { color: var(--text-muted); }
.mg-hero__eyebrow {
    background: var(--blue-tech-soft) !important;
    border: 1px solid rgba(15,98,168,.15) !important;
    color: var(--blue-tech) !important;
}
.mg-btn-hero-light {
    background: var(--orange-cta) !important;
    border-color: var(--orange-cta) !important;
    color: #fff !important;
    box-shadow: var(--shadow-cta);
}
.mg-btn-hero-light:hover {
    background: var(--orange-cta-hover) !important;
    border-color: var(--orange-cta-hover) !important;
}
.mg-btn-outline-blue {
    background: transparent;
    border: 2px solid var(--blue-tech);
    color: var(--blue-tech);
    font-weight: 600;
    border-radius: var(--radius-sm);
    padding: .65rem 1.25rem;
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    text-decoration: none;
    transition: background .2s ease, color .2s ease;
}
.mg-btn-outline-blue:hover {
    background: var(--blue-tech-soft);
    color: var(--blue-tech-hover);
    border-color: var(--blue-tech-hover);
}
.mg-page-hero.mg-hero--minimal {
    background: var(--bg-secondary);
    border-bottom: 1px solid var(--color-border);
}

/* mg-catalog-hero remplace l'ancien hero minimal sur catalogue */

/* --- Cartes produit --- */
.mg-product-card,
.card-v-standard .mg-product-card,
.card-v-glass .mg-product-card,
.card-v-spotlight .mg-product-card {
    background: var(--white);
    border: var(--card-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-card);
}
.card-v-spotlight .mg-product-card__body {
    position: static;
    background: transparent;
}
.mg-product-card:hover {
    box-shadow: var(--shadow-card-hover);
    transform: translateY(-2px);
}
.mg-product-card__media { background: var(--bg-image); }
.mg-product-card__badge, .product-badge {
    background: var(--badge-promo-red) !important;
    color: #fff !important;
    border-radius: 6px;
    font-size: 11px;
    font-weight: 700;
}
.mg-product-card__stock--ok, .stock-ok {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    padding: .15rem .5rem;
    border-radius: var(--radius-sm);
    background: var(--badge-stock-bg);
    color: var(--badge-stock-green) !important;
    font-size: 11px;
    font-weight: 600;
}
.mg-product-card__title {
    font-size: 15px;
    font-weight: 600;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.mg-product-card__price, .price { color: var(--blue-tech) !important; font-weight: 700; }
.mg-product-card__price-old, .price-old { color: var(--text-subtle) !important; }
.mg-product-card__footer {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
}
.mg-btn-cta-cart, .mg-product-card .mg-btn-cart {
    width: 44px;
    min-width: 44px;
    min-height: 44px;
    height: 44px;
    padding: 0;
    border-radius: var(--radius-sm);
    background: var(--orange-cta);
    border: none;
    color: #fff;
    font-weight: 600;
    box-shadow: none;
    flex-shrink: 0;
}
.mg-btn-cta-cart:hover, .mg-product-card .mg-btn-cart:hover {
    background: var(--orange-cta-hover);
    transform: scale(1.05);
}
.mg-product-card__cart-label { display: none !important; }
@media (max-width: 575.98px) {
    .mg-product-card__footer { flex-direction: column; align-items: stretch; }
    .mg-btn-cta-cart, .mg-product-card .mg-btn-cart {
        width: 100%;
        min-height: 48px;
        height: auto;
        padding: .65rem 1rem;
    }
    .mg-product-card__cart-label { display: inline !important; }
}

/* --- Catégories (cartes horizontales — categories-showcase.css) --- */
.mg-categories-section { background: var(--bg-primary); }

/* --- Features & confiance --- */
.mg-feature {
    background: var(--white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xs);
    text-align: center;
    padding: var(--space-6) var(--space-4);
}
.mg-feature__icon {
    width: 52px; height: 52px;
    margin: 0 auto var(--space-4);
    border-radius: 50%;
    background: var(--blue-tech-soft);
}
.mg-feature__icon svg { stroke: var(--blue-tech); }
.bg-brand-soft { background: var(--bg-secondary) !important; }
.review-card { background: var(--white); border: var(--card-border); box-shadow: var(--shadow-card); }
.mg-trust-section__bg {
    background: linear-gradient(180deg, var(--bg-secondary) 0%, var(--white) 100%) !important;
}
.mg-trust-section__panel { background: var(--white); border: var(--card-border); box-shadow: var(--shadow-md); }
.mg-promo-strip__card {
    background: var(--white) !important;
    border: var(--card-border);
}

/* --- Bottom nav --- */
.mg-bottom-nav {
    background: rgba(255,255,255,.98);
    border-top: 1px solid var(--color-border);
    box-shadow: 0 -2px 12px rgba(0,0,0,.06);
}
.mg-bottom-nav__item.active, .mg-bottom-nav__item:hover { color: var(--blue-tech); }
.mg-bottom-nav__badge { background: var(--orange-cta); }

/* --- Footer sombre --- */
.site-footer {
    background: var(--footer-dark);
    color: rgba(255,255,255,.82);
    border-top: none;
    padding: var(--space-xl) 0 var(--space-md);
}
.site-footer h5 { color: #fff; font-weight: 700; }
.site-footer a { color: rgba(255,255,255,.78); }
.site-footer a:hover { color: var(--orange-cta); }
.site-footer__divider {
    border-top: 1px solid rgba(255,255,255,.1);
    margin-top: var(--space-lg);
    padding-top: var(--space-md);
}
.footer-social a {
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.12);
    color: rgba(255,255,255,.85);
}
.footer-social a:hover { background: var(--orange-cta); border-color: var(--orange-cta); color: #fff; }

/* --- Bootstrap & sections --- */
.btn-primary { background: var(--orange-cta); border-color: var(--orange-cta); }
.btn-primary:hover { background: var(--orange-cta-hover); border-color: var(--orange-cta-hover); }
.section { padding: var(--space-lg) 0; }
@media (min-width: 992px) { .section { padding: var(--space-xl) 0; } }
