/* ═══════════════════════════════════════════════
   EDUBOX AFRIQUE — CSS GLOBAL
   ═══════════════════════════════════════════════ */
:root {
  --primary: #001d3d;
  --green: #00a651;
  --green-dark: #008040;
  --green-light: #f0faf4;
  --yellow: #ffc300;
  --red: #e53935;
  --gray-light: #f5f5f5;
  --gray: #e5e5e5;
  --gray-text: #888;
  --text: #333;
  --white: #fff;
  --shadow: 0 2px 12px rgba(0,0,0,0.08);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.13);
  --radius: 6px;
  --font: 'Montserrat', sans-serif;
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:var(--font); color:var(--text); background:#fff; font-size:14px; }
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
img { max-width:100%; }
input,select,textarea,button { font-family:var(--font); }

/* ── TOPBAR ── */
#topbar {
  background:var(--primary); color:#fff; font-size:12px;
  padding:6px 24px; display:flex; align-items:center;
  justify-content:space-between; gap:10px; flex-wrap:wrap;
}
#topbar a { color:#ccd9e8; }
#topbar a:hover { color:var(--green); }
.tb-left { display:flex; align-items:center; gap:6px; }
.tb-phone {
  background:var(--green); color:#fff !important; padding:5px 14px;
  border-radius:4px; font-weight:700; font-size:12px;
  display:flex; align-items:center; gap:8px;
}
.tb-phone small { font-size:10px; font-weight:500; opacity:.85; display:block; }
.tb-right { display:flex; align-items:center; gap:14px; }
.tb-right a { display:flex; align-items:center; gap:5px; font-size:12px; }

/* ── HEADER ── */
#header {
  background:#fff; padding:12px 24px;
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; border-bottom:1px solid var(--gray); flex-wrap:wrap;
  position:sticky; top:0; z-index:200; box-shadow:var(--shadow);
}
.logo { display:flex; align-items:center; gap:10px; }
.logo-icon {
  width:50px; height:50px; border-radius:8px;
  background:linear-gradient(135deg,var(--green),var(--primary));
  display:flex; align-items:center; justify-content:center;
  font-size:24px; flex-shrink:0;
}
.logo-texts .l1 { font-size:20px; font-weight:800; color:var(--primary); letter-spacing:-.5px; }
.logo-texts .l1 span { color:var(--green); }
.logo-texts .l2 { font-size:10px; font-weight:500; color:var(--gray-text); letter-spacing:.12em; text-transform:uppercase; }

.hdr-search {
  flex:1; max-width:440px; display:flex; border:1.5px solid var(--gray);
  border-radius:4px; overflow:hidden;
}
.hdr-search input {
  flex:1; padding:9px 14px; border:none; outline:none; font-size:13px;
}
.hdr-search button {
  background:var(--primary); border:none; padding:0 16px; cursor:pointer;
  color:#fff; font-size:16px;
}
.hdr-search button:hover { background:var(--green); }

.hdr-actions { display:flex; align-items:center; gap:12px; }
.hdr-btn {
  display:flex; align-items:center; gap:6px; padding:8px 16px;
  border-radius:4px; font-size:12px; font-weight:700; cursor:pointer;
  border:none; transition:all .2s;
}
.hdr-btn-primary { background:var(--green); color:#fff; }
.hdr-btn-primary:hover { background:var(--green-dark); }
.hdr-btn-outline { background:transparent; color:var(--primary); border:1.5px solid var(--primary); }
.hdr-btn-outline:hover { background:var(--primary); color:#fff; }
.cart-btn {
  position:relative; display:flex; align-items:center; gap:6px;
  font-size:13px; font-weight:600; color:var(--primary); cursor:pointer;
  padding:6px 10px; border-radius:4px; transition:background .2s;
  text-decoration:none;
}
.cart-btn:hover { background:var(--gray-light); }
.cart-count {
  position:absolute; top:-6px; right:-6px; background:var(--red);
  color:#fff; font-size:9px; font-weight:800; min-width:18px; height:18px;
  border-radius:10px; display:flex; align-items:center; justify-content:center;
  padding:0 4px; line-height:1; z-index:2;
  box-shadow:0 0 0 2px #fff;
}
.user-btn {
  display:flex; align-items:center; gap:6px; font-size:12px;
  font-weight:600; color:var(--primary); cursor:pointer;
  padding:6px 10px; border-radius:4px; transition:background .2s;
  position:relative;
}
.user-btn:hover { background:var(--gray-light); }
.user-dropdown {
  position:absolute; top:calc(100% + 6px); right:0; width:200px;
  background:#fff; border:1px solid var(--gray); border-radius:var(--radius);
  box-shadow:var(--shadow-lg); z-index:300; overflow:hidden; display:none;
}
.user-dropdown.open { display:block; }
.user-dropdown a {
  display:flex; align-items:center; gap:10px; padding:11px 16px;
  font-size:12.5px; color:var(--text); border-bottom:1px solid var(--gray);
  transition:background .15s;
}
.user-dropdown a:hover { background:var(--green-light); color:var(--green); }
.user-dropdown a:last-child { border-bottom:none; }

/* ── MAIN NAV ── */
#mainnav {
  background:var(--primary); position:sticky; top:74px; z-index:190;
}
#mainnav ul {
  display:flex; max-width:1240px; margin:0 auto; padding:0 24px;
}
#mainnav ul > li { position:relative; }
#mainnav ul > li > a {
  display:flex; align-items:center; gap:5px; padding:0 18px; height:44px;
  color:#fff; font-size:12px; font-weight:700; text-transform:uppercase;
  letter-spacing:.04em; white-space:nowrap; transition:background .15s;
}
#mainnav ul > li > a:hover,
#mainnav ul > li.active > a { background:var(--green); }
.nav-arrow { font-size:8px; opacity:.7; }
.dropdown {
  display:none; position:absolute; top:100%; left:0; min-width:220px;
  background:#fff; border-top:3px solid var(--green); border-radius:0 0 6px 6px;
  box-shadow:var(--shadow-lg); z-index:300;
}
#mainnav ul > li:hover .dropdown { display:block; }
.dropdown a {
  display:block; padding:10px 18px; font-size:12px; color:var(--text);
  border-bottom:1px solid var(--gray-light); transition:all .15s;
}
.dropdown a:hover { background:var(--green-light); color:var(--green); padding-left:24px; }
.dropdown a:last-child { border-bottom:none; }

.hamburger {
  display:none; background:none; border:none; color:#fff;
  font-size:22px; padding:10px 24px; cursor:pointer;
}
#mobile-menu {
  display:none; background:var(--primary); flex-direction:column;
}
#mobile-menu.open { display:flex; }
#mobile-menu a {
  color:#fff; padding:12px 24px; border-bottom:1px solid rgba(255,255,255,.08);
  font-size:13px; font-weight:600; text-transform:uppercase;
}
#mobile-menu a:hover { background:var(--green); }

/* ── BREADCRUMB ── */
.breadcrumb {
  background:var(--gray-light); border-bottom:1px solid var(--gray);
  padding:9px 24px; font-size:12px; color:var(--gray-text);
}
.breadcrumb .bmax { max-width:1240px; margin:0 auto; }
.breadcrumb a { color:var(--gray-text); }
.breadcrumb a:hover { color:var(--green); }
.breadcrumb span { margin:0 6px; }

/* ── LAYOUT ── */
.container { max-width:1240px; margin:0 auto; padding:0 24px; }
.section { padding:40px 0; }
.section-title {
  font-size:22px; font-weight:800; color:var(--primary);
  text-align:center; text-transform:uppercase; letter-spacing:.04em;
  margin-bottom:8px;
}
.section-sep { width:48px; height:3px; background:var(--green); margin:0 auto 16px; }
.section-sub { text-align:center; color:var(--gray-text); font-size:13px; max-width:580px; margin:0 auto 32px; line-height:1.7; }

/* ── BUTTONS ── */
.btn {
  display:inline-flex; align-items:center; gap:7px; padding:11px 22px;
  border-radius:4px; font-weight:700; font-size:13px; cursor:pointer;
  border:none; transition:all .2s; white-space:nowrap;
}
.btn-green { background:var(--green); color:#fff; }
.btn-green:hover { background:var(--green-dark); transform:translateY(-1px); }
.btn-primary { background:var(--primary); color:#fff; }
.btn-primary:hover { background:#002a55; transform:translateY(-1px); }
.btn-outline { background:transparent; color:var(--primary); border:1.5px solid var(--primary); }
.btn-outline:hover { background:var(--primary); color:#fff; }
.btn-red { background:var(--red); color:#fff; }
.btn-red:hover { background:#c62828; }
.btn-full { width:100%; justify-content:center; }
.btn-lg { padding:13px 28px; font-size:14px; }
.btn-sm { padding:7px 14px; font-size:11px; }

/* ── CARDS ── */
.card {
  background:#fff; border:1px solid var(--gray); border-radius:var(--radius);
  overflow:hidden; transition:box-shadow .2s, transform .2s;
}
.card:hover { box-shadow:var(--shadow-lg); }
.card-body { padding:16px; }

/* ── PRODUCT CARD ── */
.product-card {
  background:#fff; border:1px solid var(--gray); border-radius:var(--radius);
  overflow:hidden; transition:all .2s; display:flex; flex-direction:column;
}
.product-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-2px); }
.product-img {
  height:150px; background:var(--gray-light); display:flex;
  align-items:center; justify-content:center; font-size:56px;
  position:relative;
}
.product-badge {
  position:absolute; top:8px; left:8px; background:var(--green);
  color:#fff; font-size:10px; font-weight:700; padding:3px 8px;
  border-radius:3px; text-transform:uppercase;
}
.product-badge.new { background:var(--yellow); color:#333; }
.product-badge.promo { background:var(--red); }
.product-body { padding:12px; flex:1; display:flex; flex-direction:column; }
.product-brand { font-size:10px; font-weight:700; color:var(--green); text-transform:uppercase; letter-spacing:.07em; margin-bottom:4px; }
.product-name { font-size:12.5px; font-weight:600; color:var(--text); line-height:1.45; flex:1; margin-bottom:10px; }
.product-price { font-size:14px; font-weight:800; color:var(--primary); margin-bottom:10px; }
.product-price .old { font-size:11px; color:var(--gray-text); text-decoration:line-through; margin-left:6px; font-weight:400; }
.product-actions { display:flex; gap:6px; }
.btn-add-cart {
  flex:1; background:var(--primary); color:#fff; border:none; border-radius:4px;
  padding:8px; font-size:11px; font-weight:700; cursor:pointer;
  text-transform:uppercase; transition:background .2s; text-align:center;
}
.btn-add-cart:hover { background:var(--green); }
.btn-wishlist {
  width:34px; height:34px; background:var(--gray-light); border:none;
  border-radius:4px; cursor:pointer; font-size:14px; transition:background .2s;
  display:flex; align-items:center; justify-content:center;
}
.btn-wishlist:hover { background:#ffe0e0; }

/* ── FORMS ── */
.form-group { margin-bottom:16px; }
.form-label { display:block; font-size:12px; font-weight:700; color:#555; margin-bottom:6px; }
.form-label .req { color:var(--red); }
.form-input, .form-select, .form-textarea {
  width:100%; padding:10px 14px; border:1.5px solid var(--gray);
  border-radius:4px; font-size:13px; color:var(--text);
  outline:none; transition:border .2s; background:#fff;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color:var(--green);
}
.form-input.error { border-color:var(--red); }
.form-textarea { resize:vertical; min-height:100px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-help { font-size:11px; color:var(--gray-text); margin-top:4px; }
.form-error { font-size:11px; color:var(--red); margin-top:4px; display:none; }

/* ── ALERTS ── */
.alert { padding:12px 16px; border-radius:4px; font-size:13px; margin-bottom:16px; display:flex; align-items:flex-start; gap:10px; }
.alert-success { background:#e8f5e9; border-left:4px solid var(--green); color:#1b5e20; }
.alert-error { background:#ffebee; border-left:4px solid var(--red); color:#b71c1c; }
.alert-info { background:#e3f2fd; border-left:4px solid #1976d2; color:#0d47a1; }
.alert-warning { background:#fff8e1; border-left:4px solid var(--yellow); color:#795548; }
.alert.hidden { display:none; }

/* ── TABLE ── */
.table { width:100%; border-collapse:collapse; font-size:13px; }
.table th {
  background:var(--primary); color:#fff; padding:10px 14px;
  text-align:left; font-weight:700; font-size:11px; text-transform:uppercase;
  letter-spacing:.04em;
}
.table td { padding:10px 14px; border-bottom:1px solid var(--gray); vertical-align:middle; }
.table tr:hover td { background:var(--gray-light); }
.table tr:last-child td { border-bottom:none; }

/* ── STATUS BADGES ── */
.status {
  display:inline-block; padding:3px 10px; border-radius:20px;
  font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.05em;
}
.status-pending { background:#fff3e0; color:#e65100; }
.status-confirmed { background:#e8f5e9; color:#2e7d32; }
.status-shipped { background:#e3f2fd; color:#1565c0; }
.status-delivered { background:#f3e5f5; color:#6a1b9a; }
.status-cancelled { background:#ffebee; color:#c62828; }

/* ── SIDEBAR FILTER ── */
.shop-layout { display:grid; grid-template-columns:240px 1fr; gap:24px; align-items:start; }
.filter-box {
  background:#fff; border:1px solid var(--gray); border-radius:var(--radius);
  overflow:hidden; position:sticky; top:130px;
}
.filter-box-title {
  background:var(--primary); color:#fff; padding:12px 16px;
  font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.05em;
}
.filter-section { padding:14px 16px; border-bottom:1px solid var(--gray); }
.filter-section h4 { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--primary); margin-bottom:10px; }
.filter-item {
  display:flex; align-items:center; gap:8px; padding:5px 0;
  font-size:12.5px; cursor:pointer;
}
.filter-item input[type="checkbox"] { accent-color:var(--green); width:14px; height:14px; }
.filter-item label { cursor:pointer; flex:1; display:flex; justify-content:space-between; }
.filter-item .cnt { color:var(--gray-text); font-size:11px; }
.filter-price { display:flex; gap:8px; align-items:center; }
.filter-price input { flex:1; padding:6px 8px; border:1px solid var(--gray); border-radius:4px; font-size:11px; }
.filter-gamme { display:flex; flex-direction:column; gap:6px; }
.gamme-btn {
  padding:8px 12px; border:1.5px solid var(--gray); border-radius:4px;
  font-size:12px; font-weight:600; cursor:pointer; background:#fff;
  transition:all .2s; text-align:left;
}
.gamme-btn.active, .gamme-btn:hover { background:var(--primary); color:#fff; border-color:var(--primary); }

/* ── SORT BAR ── */
.sort-bar {
  background:#fff; border:1px solid var(--gray); border-radius:var(--radius);
  padding:10px 16px; display:flex; align-items:center;
  justify-content:space-between; margin-bottom:16px; flex-wrap:wrap; gap:8px;
}
.sort-bar .results { font-size:12px; color:var(--gray-text); }
.sort-bar .sort-controls { display:flex; align-items:center; gap:8px; }
.sort-bar select { font-size:12px; padding:5px 10px; border:1px solid var(--gray); border-radius:4px; }
.pagination { display:flex; gap:6px; justify-content:center; margin-top:24px; }
.page-btn {
  width:34px; height:34px; border-radius:4px; border:1px solid var(--gray);
  background:#fff; font-size:12px; font-weight:700; cursor:pointer;
  display:flex; align-items:center; justify-content:center; transition:all .2s;
}
.page-btn.active, .page-btn:hover { background:var(--primary); color:#fff; border-color:var(--primary); }

/* ── MODAL ── */
.modal-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,.5);
  z-index:1000; display:none; align-items:center; justify-content:center;
  padding:20px;
}
.modal-overlay.open { display:flex; }
.modal {
  background:#fff; border-radius:8px; width:100%; max-width:500px;
  max-height:90vh; overflow-y:auto; box-shadow:var(--shadow-lg);
  animation:modalIn .25s ease;
}
@keyframes modalIn { from{opacity:0;transform:scale(.95)} to{opacity:1;transform:scale(1)} }
.modal-header {
  padding:20px 24px; border-bottom:1px solid var(--gray);
  display:flex; align-items:center; justify-content:space-between;
}
.modal-header h3 { font-size:16px; font-weight:800; color:var(--primary); }
.modal-close { background:none; border:none; font-size:20px; cursor:pointer; color:var(--gray-text); line-height:1; }
.modal-body { padding:24px; }
.modal-footer { padding:16px 24px; border-top:1px solid var(--gray); display:flex; gap:10px; justify-content:flex-end; }

/* ── TABS ── */
.tabs { display:flex; border-bottom:2px solid var(--gray); margin-bottom:24px; }
.tab {
  padding:10px 20px; font-size:13px; font-weight:700; cursor:pointer;
  border:none; background:none; color:var(--gray-text);
  border-bottom:3px solid transparent; margin-bottom:-2px; transition:all .2s;
}
.tab.active, .tab:hover { color:var(--green); border-bottom-color:var(--green); }

/* ── FOOTER ── */
#footer { background:var(--primary); color:#7a9eb0; margin-top:48px; }
.footer-grid {
  display:grid; grid-template-columns:2.2fr 1fr 1fr 1fr;
  gap:36px; padding:40px 24px; max-width:1240px; margin:0 auto;
}
.footer-col h4 { color:#fff; font-size:12px; text-transform:uppercase; letter-spacing:.06em; margin-bottom:14px; font-weight:700; }
.footer-col p, .footer-col a { font-size:12.5px; line-height:2.1; display:block; color:#7a9eb0; }
.footer-col a:hover { color:var(--green); }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,.08); padding:16px 24px;
  max-width:1240px; margin:0 auto; display:flex;
  justify-content:space-between; align-items:center; font-size:12px; flex-wrap:wrap; gap:8px;
}
.footer-logo .l1 { font-size:18px; font-weight:800; color:#fff; }
.footer-logo .l1 span { color:var(--green); }
.footer-logo .l2 { font-size:10px; color:#7a9eb0; letter-spacing:.1em; text-transform:uppercase; margin-top:2px; }
.footer-social { display:flex; gap:8px; margin-top:14px; }
.social-btn {
  width:34px; height:34px; border-radius:4px; background:rgba(255,255,255,.07);
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:13px; font-weight:700; transition:background .2s;
}
.social-btn:hover { background:var(--green); }

/* ── TOAST NOTIFICATIONS ── */
#toast-container { position:fixed; bottom:24px; right:24px; z-index:2000; display:flex; flex-direction:column; gap:10px; }
.toast {
  background:#fff; border-radius:6px; padding:14px 18px; box-shadow:var(--shadow-lg);
  display:flex; align-items:center; gap:12px; font-size:13px; font-weight:500;
  min-width:280px; border-left:4px solid var(--green);
  animation:toastIn .3s ease;
}
.toast.error { border-left-color:var(--red); }
.toast.info { border-left-color:#1976d2; }
@keyframes toastIn { from{opacity:0;transform:translateX(20px)} to{opacity:1;transform:translateX(0)} }

/* ── LOADING ── */
.spinner {
  width:36px; height:36px; border:3px solid var(--gray);
  border-top-color:var(--green); border-radius:50%; animation:spin .7s linear infinite;
}
@keyframes spin { to{transform:rotate(360deg)} }
.loading-overlay {
  position:fixed; inset:0; background:rgba(255,255,255,.8);
  z-index:500; display:none; align-items:center; justify-content:center; flex-direction:column; gap:12px;
}
.loading-overlay.show { display:flex; }

/* ════════════════════════════════════════════
   RESPONSIVE — Tablette & Mobile
   ════════════════════════════════════════════ */

/* ── TABLETTE LARGE (≤1200px) ── */
@media(max-width:1200px) {
  .pg { grid-template-columns:repeat(3,1fr); }
  .pg4 { grid-template-columns:repeat(3,1fr); }
}

/* ── TABLETTE (≤1024px) ── */
/* ════════════════════════════════════════════
   RESPONSIVE — Desktop · Tablette · Mobile
   ════════════════════════════════════════════ */

/* ── TABLETTE LARGE (≤1200px) ── */
@media(max-width:1200px) {
  .pg { grid-template-columns:repeat(3,1fr); }
}

/* ── TABLETTE (≤1024px) ── */
@media(max-width:1024px) {
  .sl { grid-template-columns:200px 1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:28px; }
  .pg { grid-template-columns:repeat(3,1fr); }
  .hdr-search { max-width:320px; }
}

/* ── TABLETTE PORTRAIT (≤900px) ── */
@media(max-width:900px) {
  #header { flex-wrap:wrap; padding:10px 16px; gap:10px; }
  .hdr-search { order:3; flex:1 1 100%; max-width:100%; margin-top:4px; }
  .hdr-actions { gap:8px; }
  .hdr-btn-primary { padding:7px 12px; font-size:11px; }
  .cart-label { display:none; }
  .user-label { display:none; }
  #mainnav ul li a { padding:12px 10px; font-size:11.5px; }
  .pg { grid-template-columns:repeat(2,1fr); gap:12px; }
  .sl { grid-template-columns:1fr; }
  .fil { position:static; margin-bottom:16px; }
  .h-vis { display:none; }
  .fg { grid-template-columns:repeat(2,1fr) !important; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:24px; }
}

/* ── MOBILE (≤768px) ── */
@media(max-width:768px) {
  #topbar { flex-wrap:wrap; gap:6px; padding:6px 14px; justify-content:space-between; font-size:11px; }
  .tb-left { display:none; }
  .tb-phone small { display:none; }
  #header { padding:10px 14px; gap:8px; }
  .hdr-actions { gap:6px; }
  .hamburger { display:flex !important; }
  #mainnav ul { display:none; }
  .pg { grid-template-columns:repeat(2,1fr); gap:10px; }
  .form-row { grid-template-columns:1fr; }
  .cgl { grid-template-columns:1fr; }
  .section { padding:28px 0; }
  .section-title { font-size:20px; }
  .container { padding:0 14px; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:20px; }
  .fg { grid-template-columns:1fr !important; }
  .brand-logo-grid { padding:14px 12px; gap:8px; }
  .blc { min-width:80px; padding:8px 10px; height:52px; }
}

/* ── MOBILE PETIT (≤480px) ── */
@media(max-width:480px) {
  #header { padding:8px 12px; }
  .logo img { height:40px !important; }
  .logo-texts .l1 { font-size:15px; }
  .logo-texts .l2 { font-size:9px; }
  .pg { grid-template-columns:1fr !important; }
  .footer-grid { grid-template-columns:1fr; gap:16px; }
  .container { padding:0 12px; }
  .section { padding:20px 0; }
  .section-title { font-size:18px; }
  .fg { grid-template-columns:1fr !important; }
  .modal { width:100% !important; max-width:100% !important; border-radius:12px 12px 0 0 !important; }
  .modal-overlay { align-items:flex-end; }
}

/* ── NAV MOBILE (panneau latéral) ── */
#mobile-nav {
  display:none; position:fixed; top:0; left:0; width:280px; height:100%;
  background:#fff; z-index:1100; overflow-y:auto;
  transition:transform .3s ease; transform:translateX(-100%);
  box-shadow:4px 0 24px rgba(0,0,0,.18); padding-bottom:40px;
}
#mobile-nav.open { display:block; transform:translateX(0); }
#mobile-overlay {
  display:none; position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:1099;
}
#mobile-overlay.open { display:block; }
#mobile-nav .mn-header {
  background:var(--primary); padding:18px 20px;
  display:flex; justify-content:space-between; align-items:center; gap:8px;
}
#mobile-nav .mn-header span { color:#fff; font-weight:800; font-size:15px; }
#mobile-nav .mn-close {
  background:none; border:none; color:#fff; font-size:24px; cursor:pointer;
  line-height:1; padding:0 4px;
}
#mobile-nav a {
  display:flex; align-items:center; padding:13px 20px;
  font-size:13px; font-weight:600; color:var(--primary);
  border-bottom:1px solid var(--gray); text-decoration:none; transition:background .15s;
}
#mobile-nav a:hover, #mobile-nav a:active { background:var(--green-light); color:var(--green); }
#mobile-nav .mn-section {
  padding:10px 20px 4px; font-size:10px; font-weight:800;
  color:#999; text-transform:uppercase; letter-spacing:.1em; margin-top:4px;
}

/* Hover overlay cartes produit */
.product-card:hover .card-hover-overlay { opacity:1 !important; }
.product-card { transition:box-shadow .25s, transform .25s; }
.product-card:hover { box-shadow:0 8px 32px rgba(0,0,0,.16); transform:translateY(-3px); }
#pdm .modal { max-width:860px; width:96%; }
@media(max-width:700px) {
  #pdm .modal > div:last-child > div { display:flex; flex-direction:column; }
}

/* ── HEADER RESPONSIVE HELPERS ── */
.btn-text { } /* visible par défaut desktop */
@media(max-width:860px) {
  .btn-text { display:none; } /* cacher texte Devis sur tablette */
  .hdr-btn-primary { padding:8px 10px; }
}
@media(max-width:640px) {
  .tb-phone { font-size:11px; padding:3px 8px; }
  .tb-phone small { display:none; }
}


/* ══════════════════════════════════════════
   AMÉLIORATIONS RESPONSIVE SUPPLÉMENTAIRES
   ══════════════════════════════════════════ */

/* Footer 1 colonne sur mobile petit */
@media(max-width:420px) {
  .footer-grid { grid-template-columns:1fr !important; gap:20px; }
  .footer-logo img { height:36px; }
}

/* Topbar email menu sur mobile */
@media(max-width:480px) {
  #email-menu { left:50% !important; transform:translateX(-50%); right:auto !important; min-width:200px; }
}

/* Dropdown recherche sur mobile */
@media(max-width:600px) {
  #search-dropdown { position:fixed !important; left:10px !important; right:10px !important;
    top:auto !important; width:auto !important; }
}

/* Breadcrumb mobile */
@media(max-width:480px) {
  .breadcrumb { font-size:11px; padding:8px 12px; }
}

/* Boutons CTA full-width sur mobile */
@media(max-width:480px) {
  .h-btns .btn { width:100%; text-align:center; justify-content:center; }
}

/* Tables dans les fiches produit */
@media(max-width:600px) {
  table { font-size:12px; }
  th, td { padding:8px 10px !important; }
}

/* Widget WhatsApp — éviter chevauchement */
@media(max-width:480px) {
  #wa-widget { bottom:16px; right:12px; }
  #wa-bubble { max-width:180px; font-size:12px; }
}
