/*
Theme Name: Bati Maroc
Theme URI: https://bati-maroc.ma
Author: Vivvo Ichou
Description: Thème BTP e-commerce - matériaux, location, transport, Maroc - v3.0
Version: 3.0.0
Requires at least: 6.0
Requires PHP: 8.0
Text Domain: bati-maroc
*/

/* ══════════════════════════════════════
   VARIABLES
   ══════════════════════════════════════ */
:root {
  --blue:        #1F3EAA;
  --blue-dark:   #162E84;
  --blue-mid:    #2B52D4;
  --blue-light:  #EEF2FF;
  --blue-pale:   #F0F4FF;
  --yellow:      #F5B800;
  --yellow-dk:   #D9A200;
  --yellow-lt:   #FFF8E1;
  --green:       #10B981;
  --green-lt:    #D1FAE5;
  --red:         #EF4444;
  --red-lt:      #FEE2E2;
  --orange:      #F97316;
  --bg:          #F4F5F7;
  --white:       #FFFFFF;
  --text:        #0F172A;
  --text-2:      #334155;
  --text-3:      #64748B;
  --text-4:      #94A3B8;
  --border:      #E2E8F0;
  --border-2:    #CBD5E1;
  --r-sm:        6px;
  --r:           10px;
  --r-lg:        16px;
  --r-xl:        24px;
  --shadow-sm:   0 1px 4px rgba(0,0,0,.06);
  --shadow:      0 4px 20px rgba(0,0,0,.08);
  --shadow-lg:   0 8px 40px rgba(0,0,0,.12);
  --font:        'Inter','Segoe UI',system-ui,sans-serif;
  --w:           1280px;
  --t:           .2s cubic-bezier(.4,0,.2,1);
}

/* ══════════════════════════════════════ BASE ══ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.6}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}
input,select,textarea,button{font-family:inherit}
.bm-w{max-width:var(--w);margin:0 auto;padding:0 24px}

/* ══ BUTTONS ══ */
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;border-radius:var(--r);font-weight:700;font-size:.88rem;cursor:pointer;border:none;transition:var(--t);white-space:nowrap;text-decoration:none}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-dark);transform:translateY(-1px)}
.btn-yellow{background:var(--yellow);color:var(--text)}
.btn-yellow:hover{background:var(--yellow-dk)}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{opacity:.9}
.btn-outline{background:transparent;border:2px solid var(--blue);color:var(--blue)}
.btn-outline:hover{background:var(--blue);color:#fff}
.btn-outline-white{background:transparent;border:2px solid rgba(255,255,255,.7);color:#fff}
.btn-outline-white:hover{background:#fff;color:var(--blue)}
.btn-lg{padding:13px 28px;font-size:.95rem}
.btn-sm{padding:7px 14px;font-size:.78rem}
.btn-full{width:100%;justify-content:center}

/* ══ SECTION ══ */
.bm-section{padding:48px 0}
.bm-section-label{font-size:.7rem;font-weight:700;color:var(--blue);letter-spacing:.8px;text-transform:uppercase;margin-bottom:6px;display:flex;align-items:center;gap:6px}
.bm-section-label::before{content:'';width:14px;height:2px;background:var(--blue);border-radius:2px}
.bm-section-title{font-size:1.65rem;font-weight:800;color:var(--text);letter-spacing:-.5px;margin-bottom:4px}
.bm-section-desc{color:var(--text-3);font-size:.9rem}
.bm-section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:12px}

/* ══ FORMS ══ */
.bm-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.bm-form-group{display:flex;flex-direction:column;gap:5px}
.bm-form-group.full{grid-column:1/-1}
.bm-form-group label{font-size:.72rem;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.3px}
.bm-form-group input,.bm-form-group select,.bm-form-group textarea{padding:10px 13px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:.9rem;color:var(--text);outline:none;transition:var(--t);background:var(--white)}
.bm-form-group input:focus,.bm-form-group select:focus,.bm-form-group textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(31,62,170,.08)}
.bm-form-group textarea{resize:vertical}

/* ══ CARDS ══ */
.bm-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:var(--t)}
.bm-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}

/* ══════════════════════════════════════
   HEADER
   ══════════════════════════════════════ */
.bm-header-top{background:var(--blue);color:rgba(255,255,255,.8);font-size:.75rem;padding:7px 0}
.bm-header-top-inner{display:flex;justify-content:space-between;align-items:center}
.bm-top-left,.bm-top-right{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.bm-top-item{display:flex;align-items:center;gap:5px}
.bm-top-right a{color:rgba(255,255,255,.8);transition:var(--t)}
.bm-top-right a:hover{color:#fff}
.bm-header{background:var(--white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:999}
.bm-header-main{padding:14px 0}
.bm-header-main-inner{display:flex;align-items:center;gap:20px}
/* Logo */
.bm-logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.bm-logo-icon{width:40px;height:40px;background:var(--blue);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.bm-logo-icon svg{width:22px;height:22px;stroke:#fff;fill:none;stroke-width:2}
.bm-logo-name{font-size:1.2rem;font-weight:800;color:var(--text);letter-spacing:-.4px;line-height:1}
.bm-logo-name span{color:var(--blue)}
.bm-logo-tagline{font-size:.65rem;color:var(--text-4);letter-spacing:.3px;text-transform:uppercase;margin-top:2px}
/* Search */
.bm-search{flex:1;display:flex;align-items:center;background:var(--bg);border:1.5px solid var(--border);border-radius:50px;height:44px;padding:0 6px 0 16px;transition:var(--t);min-width:0}
.bm-search:focus-within{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(31,62,170,.1)}
.bm-search svg{width:15px;height:15px;color:var(--text-4);flex-shrink:0}
.bm-search input{flex:1;border:none;background:none;outline:none;font-size:.88rem;color:var(--text);padding:0 8px;min-width:0}
.bm-search input::placeholder{color:var(--text-4)}
.bm-search-btn{background:var(--blue);color:#fff;border:none;border-radius:50px;padding:8px 16px;font-size:.78rem;font-weight:700;cursor:pointer;flex-shrink:0;display:flex;align-items:center;gap:6px;transition:var(--t)}
.bm-search-btn:hover{background:var(--blue-dark)}
/* Header actions */
.bm-header-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}
.bm-hdr-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 10px;border-radius:var(--r-sm);background:none;border:none;cursor:pointer;color:var(--text-2);font-size:.65rem;font-weight:600;transition:var(--t);position:relative;white-space:nowrap}
.bm-hdr-btn:hover{background:var(--bg);color:var(--blue)}
.bm-hdr-btn svg{width:22px;height:22px;stroke-width:1.5;fill:none;stroke:currentColor}
.bm-cart-badge{position:absolute;top:3px;right:5px;background:var(--red);color:#fff;width:17px;height:17px;border-radius:50%;font-size:.6rem;font-weight:800;display:flex;align-items:center;justify-content:center;border:2px solid #fff}
/* Nav */
.bm-nav{background:var(--text);border-top:1px solid rgba(255,255,255,.06)}
.bm-nav-inner{display:flex;align-items:center;height:46px}
.bm-nav-cat-btn{display:flex;align-items:center;gap:8px;background:var(--blue);color:#fff;padding:0 20px;height:100%;font-size:.8rem;font-weight:700;cursor:pointer;border:none;flex-shrink:0;transition:var(--t);letter-spacing:.3px}
.bm-nav-cat-btn:hover{background:var(--blue-dark)}
.bm-nav-links{display:flex;align-items:center;flex:1;overflow-x:auto;scrollbar-width:none}
.bm-nav-links::-webkit-scrollbar{display:none}
.bm-nav-link{color:rgba(255,255,255,.72);font-size:.78rem;font-weight:500;padding:0 14px;height:46px;display:flex;align-items:center;cursor:pointer;transition:var(--t);white-space:nowrap;letter-spacing:.2px;flex-shrink:0}
.bm-nav-link:hover{color:#fff;background:rgba(255,255,255,.07)}
.bm-nav-link.active{color:#fff;font-weight:700}
.bm-nav-link.flash{color:var(--yellow);font-weight:700}
.bm-nav-link.loc{color:#6EE7B7}
.bm-nav-end{margin-left:auto;padding-right:8px;flex-shrink:0}
.bm-j1-pill{display:flex;align-items:center;gap:6px;background:var(--green);color:#fff;font-size:.7rem;font-weight:700;padding:5px 12px;border-radius:20px}

/* ══════════════════════════════════════
   HERO SLIDER (administrable)
   ══════════════════════════════════════ */
.bm-hero-slider{position:relative;overflow:hidden;background:var(--blue-pale)}
.bm-hero-track{display:flex;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.bm-hero-slide{min-width:100%;padding:56px 0 48px}
.bm-hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.bm-hero-tag{display:inline-flex;align-items:center;gap:6px;background:var(--blue-light);color:var(--blue);font-size:.7rem;font-weight:700;padding:4px 12px;border-radius:20px;letter-spacing:.4px;text-transform:uppercase;margin-bottom:16px}
.bm-hero-slide h1{font-size:2.3rem;font-weight:800;color:var(--text);line-height:1.12;letter-spacing:-1px;margin-bottom:12px}
.bm-hero-slide h1 em{font-style:normal;color:var(--blue)}
.bm-hero-desc{color:var(--text-2);font-size:.95rem;line-height:1.7;margin-bottom:22px}
.bm-hero-btns{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:26px}
.bm-hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.bm-hero-stat{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;text-align:center}
.bm-hero-stat-num{font-size:1.4rem;font-weight:800;color:var(--blue)}
.bm-hero-stat-lbl{font-size:.68rem;color:var(--text-3);margin-top:1px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}
/* Hero visual panel */
.bm-hero-panel{background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);padding:22px;box-shadow:var(--shadow)}
.bm-hero-panel-title{font-size:.68rem;font-weight:700;color:var(--text-4);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}
.bm-hero-prod{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--r);margin-bottom:8px;transition:var(--t);text-decoration:none}
.bm-hero-prod:hover{border-color:var(--blue);background:var(--blue-pale)}
.bm-hero-prod-icon{width:44px;height:44px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.bm-hero-prod-name{font-size:.82rem;font-weight:700;color:var(--text)}
.bm-hero-prod-price{font-size:.95rem;font-weight:800;color:var(--blue);margin-top:1px}
.bm-hero-prod-price span{font-size:.7rem;color:var(--text-4);font-weight:400}
.bm-hero-prod-action{margin-left:auto;flex-shrink:0}
.bm-hero-sale-badge{background:var(--red-lt);color:var(--red);font-size:.68rem;font-weight:700;padding:2px 8px;border-radius:10px}
/* Slider controls */
.bm-hero-controls{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:10}
.bm-hero-dot{width:8px;height:8px;border-radius:50%;background:rgba(31,62,170,.2);cursor:pointer;transition:var(--t);border:none}
.bm-hero-dot.active{background:var(--blue);width:24px;border-radius:4px}
.bm-hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:40px;height:40px;background:var(--white);border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--t);box-shadow:var(--shadow-sm)}
.bm-hero-arrow:hover{background:var(--blue);border-color:var(--blue);color:#fff}
.bm-hero-arrow-prev{left:20px}
.bm-hero-arrow-next{right:20px}

/* ══════════════════════════════════════
   CATEGORIES
   ══════════════════════════════════════ */
.bm-cats-section{background:var(--white);padding:36px 0}
.bm-cats-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:10px;margin-top:20px}
.bm-cat-card{display:flex;flex-direction:column;align-items:center;gap:7px;padding:16px 8px;background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;transition:var(--t);text-align:center;text-decoration:none}
.bm-cat-card:hover{border-color:var(--blue);background:var(--blue-pale);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.bm-cat-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;transition:var(--t)}
.bm-cat-card:hover .bm-cat-icon{transform:scale(1.1)}
.bm-cat-icon svg{transition:var(--t)}
.bm-cat-name{font-size:.72rem;font-weight:700;color:var(--text-2);line-height:1.3;text-align:center}
/* Bannières avec photo */
.bm-banner-card img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;z-index:0;border-radius:14px}

/* ══════════════════════════════════════
   LOCATION MATÉRIEL — style Kiloutou
   ══════════════════════════════════════ */
.bm-loc-section{background:var(--bg);padding:48px 0}
.bm-loc-slider-wrap{overflow:hidden;margin:0 -8px}
.bm-loc-track{display:flex;transition:transform .4s cubic-bezier(.4,0,.2,1);padding:8px}
.bm-loc-track>*{flex:0 0 calc(25% - 16px);margin:0 8px}
/* Slider arrows — style Kiloutou jaune */
.bm-slider-arrows{display:flex;gap:8px}
.bm-s-arrow{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--border);background:var(--white);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--t)}
.bm-s-arrow:hover,.bm-s-arrow.on{background:var(--yellow);border-color:var(--yellow);color:var(--text)}
.bm-s-arrow svg{width:16px;height:16px}
/* Card location */
.bm-loc-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);display:flex;flex-direction:column;transition:var(--t)}
.bm-loc-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.bm-loc-card-img{height:155px;background:var(--bg);border-radius:var(--r-lg) var(--r-lg) 0 0;display:flex;align-items:flex-end;justify-content:center;position:relative;overflow:visible}
.bm-loc-card-img img{max-height:155px;width:auto;object-fit:contain;filter:drop-shadow(0 8px 20px rgba(0,0,0,.18));position:relative;z-index:2}
.bm-loc-card-img .bm-emoji-img{font-size:68px;padding-bottom:8px;filter:drop-shadow(0 6px 14px rgba(0,0,0,.15));z-index:2;position:relative}
.bm-loc-top-badge{position:absolute;bottom:-10px;left:14px;background:var(--yellow);color:var(--text);font-size:.68rem;font-weight:800;padding:3px 10px;border-radius:10px;z-index:3;letter-spacing:.2px}
.bm-loc-avail{margin:20px 14px 10px;background:#FFF8F0;border:1px solid #FDD9A8;border-radius:var(--r-sm);padding:9px 10px;display:flex;align-items:flex-start;gap:7px;font-size:.75rem;color:var(--text-2);line-height:1.4}
.bm-loc-avail-icon{width:16px;height:16px;background:var(--orange);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.bm-loc-avail a{color:var(--blue);font-weight:600}
.bm-loc-body{padding:0 14px 16px;display:flex;flex-direction:column;flex:1}
.bm-loc-name{font-size:.9rem;font-weight:800;color:var(--text);line-height:1.35;margin-bottom:3px}
.bm-loc-ref{font-size:.68rem;color:var(--text-4);text-transform:uppercase;letter-spacing:.3px;margin-bottom:12px}
.bm-loc-tarif-label{font-size:.75rem;font-weight:700;color:var(--text-2);margin-bottom:6px;display:flex;align-items:center;justify-content:space-between}
.bm-loc-tarif-label svg{width:13px;height:13px;color:var(--text-4)}
.bm-loc-select{width:100%;padding:7px 10px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:.8rem;background:var(--white);cursor:pointer;outline:none;margin-bottom:8px;transition:var(--t)}
.bm-loc-select:focus{border-color:var(--blue)}
.bm-loc-prix{display:flex;align-items:baseline;gap:4px;margin-bottom:10px}
.bm-loc-prix-val{font-size:1.15rem;font-weight:800;color:var(--text)}
.bm-loc-prix-unit{font-size:.75rem;color:var(--text-3)}
.bm-btn-prix{width:100%;background:transparent;border:2px solid var(--blue);color:var(--blue);border-radius:var(--r-sm);padding:8px;font-size:.8rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:7px;transition:var(--t)}
.bm-btn-prix:hover{background:var(--blue);color:#fff}
.bm-btn-voir{width:100%;background:var(--blue);color:#fff;border:none;border-radius:var(--r-sm);padding:9px;font-size:.82rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:var(--t);text-decoration:none}
.bm-btn-voir:hover{background:var(--blue-dark)}
.bm-btn-voir::after{content:' »'}
.bm-loc-brand{display:inline-flex;align-items:center;background:var(--bg);border:1px solid var(--border);padding:3px 9px;border-radius:20px;font-size:.68rem;font-weight:700;color:var(--text-2);margin-top:8px;cursor:pointer}

/* ══════════════════════════════════════
   PRODUITS WOOCOMMERCE
   ══════════════════════════════════════ */
.bm-prods-section{background:var(--white);padding:48px 0}
.bm-prods-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.bm-prod-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:var(--t);display:flex;flex-direction:column}
.bm-prod-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:#93C5FD}
.bm-prod-img{height:180px;display:flex;align-items:center;justify-content:center;font-size:52px;position:relative;text-decoration:none;overflow:hidden;background:#F4F5F7}
.bm-prod-img img{width:100%;height:180px;object-fit:cover;transition:transform .3s ease}
.bm-prod-card:hover .bm-prod-img img{transform:scale(1.05)}
.bm-prod-sale-b{position:absolute;top:10px;left:10px;background:var(--red);color:#fff;font-size:.68rem;font-weight:800;padding:3px 8px;border-radius:5px}
.bm-prod-stock-b{position:absolute;top:10px;right:10px;background:var(--green-lt);color:#065F46;font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:20px}
.bm-prod-body{padding:13px;display:flex;flex-direction:column;flex:1}
.bm-prod-cat-lbl{font-size:.65rem;color:var(--text-4);text-transform:uppercase;letter-spacing:.4px;font-weight:700;margin-bottom:4px}
.bm-prod-name{font-size:.85rem;font-weight:700;color:var(--text);line-height:1.4;margin-bottom:10px;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.bm-prod-price-row{display:flex;align-items:baseline;gap:6px;margin-bottom:10px;flex-wrap:wrap}
.bm-prod-price-val{font-size:1.15rem;font-weight:800;color:var(--text)}
.bm-prod-unit{font-size:.72rem;color:var(--text-4)}
.bm-prod-old{font-size:.78rem;color:var(--text-4);text-decoration:line-through}
.bm-prod-add-btn{background:var(--blue);color:#fff;border:none;border-radius:var(--r-sm);padding:9px;font-size:.8rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:var(--t);width:100%}
.bm-prod-add-btn:hover{background:var(--blue-dark)}

/* ══════════════════════════════════════
   DEVIS BANNER
   ══════════════════════════════════════ */
.bm-devis-banner{background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 100%);padding:56px 0}
.bm-devis-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.bm-devis-info h2{font-size:1.9rem;font-weight:800;color:#fff;letter-spacing:-.5px;margin-bottom:12px;line-height:1.2}
.bm-devis-info p{color:rgba(255,255,255,.8);font-size:.95rem;line-height:1.7;margin-bottom:20px}
.bm-devis-feats{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.bm-devis-feat{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.88);font-size:.88rem}
.bm-devis-feat-ic{width:28px;height:28px;background:rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.82rem;flex-shrink:0}
.bm-devis-form-card{background:var(--white);border-radius:var(--r-xl);padding:26px;box-shadow:var(--shadow-lg)}
.bm-devis-form-card h3{font-size:1.05rem;font-weight:800;color:var(--text);margin-bottom:18px;padding-bottom:13px;border-bottom:2px solid var(--blue)}

/* ══════════════════════════════════════
   TRANSPORTEURS GRID
   ══════════════════════════════════════ */
.bm-drivers-section{background:var(--bg);padding:48px 0}
.bm-drivers-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.bm-driver-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;text-align:center;cursor:pointer;transition:var(--t);position:relative}
.bm-driver-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:var(--blue)}
.bm-driver-avatar-wrap{position:relative;width:72px;height:72px;margin:0 auto 12px}
.bm-driver-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;border:3px solid var(--blue-light)}
.bm-driver-avatar-ph{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:var(--blue);border:3px solid var(--blue-light)}
.bm-driver-status-dot{position:absolute;bottom:2px;right:2px;width:14px;height:14px;border-radius:50%;border:2px solid #fff}
.bm-driver-status-dot.dispo{background:var(--green)}
.bm-driver-status-dot.occ{background:var(--red)}
.bm-driver-name{font-size:.92rem;font-weight:700;color:var(--text);margin-bottom:3px}
.bm-driver-ville{font-size:.75rem;color:var(--text-3);margin-bottom:7px;display:flex;align-items:center;justify-content:center;gap:3px}
.bm-driver-veh{background:var(--blue-light);color:var(--blue);font-size:.68rem;font-weight:700;padding:3px 10px;border-radius:20px;display:inline-block;margin-bottom:10px}
.bm-driver-stars{color:var(--yellow);font-size:.82rem}
.bm-driver-meta{display:flex;gap:8px;justify-content:center;margin:8px 0 12px}
.bm-driver-meta-item{background:var(--bg);border-radius:var(--r-sm);padding:6px 10px;text-align:center;flex:1}
.bm-driver-meta-num{font-size:.95rem;font-weight:800;color:var(--blue)}
.bm-driver-meta-lbl{font-size:.62rem;color:var(--text-4);font-weight:600;text-transform:uppercase}
.bm-driver-status-pill{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;font-weight:700;padding:4px 10px;border-radius:20px}
.bm-driver-status-pill.dispo{background:var(--green-lt);color:#065F46}
.bm-driver-status-pill.occ{background:var(--red-lt);color:#991B1B}
.bm-driver-view-btn{display:block;margin-top:12px;background:var(--blue);color:#fff;border:none;border-radius:var(--r-sm);padding:8px;font-size:.78rem;font-weight:700;cursor:pointer;width:100%;transition:var(--t)}
.bm-driver-view-btn:hover{background:var(--blue-dark)}

/* ══════════════════════════════════════
   SINGLE CONDUCTEUR — avec sidebar
   ══════════════════════════════════════ */
.bm-driver-single{padding:40px 0 80px;background:var(--bg)}
.bm-driver-layout{display:grid;grid-template-columns:1fr 340px;gap:28px;align-items:start}
.bm-driver-main{display:flex;flex-direction:column;gap:20px}
/* Profile card */
.bm-driver-profile-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px}
.bm-driver-profile-top{display:flex;align-items:center;gap:20px;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border)}
.bm-driver-profile-avatar{width:90px;height:90px;border-radius:50%;object-fit:cover;border:4px solid var(--blue-light);flex-shrink:0}
.bm-driver-profile-avatar-ph{width:90px;height:90px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:800;color:var(--blue);border:4px solid var(--blue-light);flex-shrink:0}
.bm-driver-profile-info h1{font-size:1.4rem;font-weight:800;color:var(--text);margin-bottom:4px}
.bm-driver-profile-sub{font-size:.85rem;color:var(--text-3);margin-bottom:8px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.bm-driver-profile-badges{display:flex;gap:8px;flex-wrap:wrap}
.bm-driver-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}
.bm-driver-stat-card{background:var(--bg);border-radius:var(--r);padding:14px;text-align:center}
.bm-driver-stat-val{font-size:1.4rem;font-weight:800;color:var(--blue)}
.bm-driver-stat-lbl{font-size:.72rem;color:var(--text-3);font-weight:600;text-transform:uppercase;letter-spacing:.3px}
/* Avis */
.bm-avis-list{display:flex;flex-direction:column;gap:12px}
.bm-avis-item{background:var(--bg);border-radius:var(--r);padding:14px}
.bm-avis-top{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.bm-avis-avatar{width:32px;height:32px;border-radius:50%;background:var(--blue-light);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:800;color:var(--blue);flex-shrink:0}
.bm-avis-name{font-weight:700;font-size:.85rem;color:var(--text)}
.bm-avis-date{font-size:.72rem;color:var(--text-4);margin-left:auto}
.bm-avis-text{font-size:.85rem;color:var(--text-2);line-height:1.6}
/* Contact sidebar */
.bm-driver-sidebar{display:flex;flex-direction:column;gap:16px;position:sticky;top:84px}
.bm-contact-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px}
.bm-contact-card h3{font-size:1rem;font-weight:800;color:var(--text);margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--blue)}
.bm-contact-form .bm-form-group{margin-bottom:12px}
.bm-contact-form .bm-form-group:last-of-type{margin-bottom:0}
.bm-contact-msg-sent{background:var(--green-lt);color:#065F46;padding:12px;border-radius:var(--r-sm);font-size:.85rem;font-weight:700;text-align:center;display:none}
/* Pub sidebar */
.bm-pub-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.bm-pub-label{font-size:.65rem;color:var(--text-4);padding:8px 12px;border-bottom:1px solid var(--border);letter-spacing:.3px;text-transform:uppercase}
.bm-pub-content{padding:16px;text-align:center}
.bm-pub-img{width:100%;border-radius:var(--r-sm);margin-bottom:10px;aspect-ratio:4/3;object-fit:cover;background:var(--bg)}
.bm-pub-placeholder{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,var(--blue-light),#E0E7FF);border-radius:var(--r-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;margin-bottom:10px}
.bm-pub-placeholder-icon{font-size:2rem;margin-bottom:6px}
.bm-pub-cta{font-size:.8rem;font-weight:700;color:var(--blue);text-decoration:none}

/* ══════════════════════════════════════
   POSTULER TRANSPORTEUR
   ══════════════════════════════════════ */
.bm-postuler-section{background:linear-gradient(135deg,var(--blue-pale) 0%,#F0FDF8 100%);padding:56px 0;border-top:1px solid var(--border)}
.bm-postuler-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.bm-postuler-info h2{font-size:1.85rem;font-weight:800;color:var(--text);letter-spacing:-.5px;margin-bottom:12px}
.bm-postuler-info p{color:var(--text-2);line-height:1.7;margin-bottom:20px}
.bm-avantages{display:flex;flex-direction:column;gap:10px;margin-bottom:22px}
.bm-avantage{display:flex;align-items:center;gap:12px;padding:11px 14px;background:var(--white);border:1px solid var(--border);border-radius:var(--r);transition:var(--t)}
.bm-avantage:hover{border-color:var(--blue);background:var(--blue-pale)}
.bm-avantage-ic{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.bm-avantage strong{display:block;font-size:.85rem;color:var(--text)}
.bm-avantage span{font-size:.75rem;color:var(--text-3)}
.bm-steps-list{display:flex;flex-direction:column}
.bm-step{display:flex;gap:14px;padding:10px 0 10px 18px;border-left:2px solid var(--border);margin-left:11px;position:relative}
.bm-step::before{content:'';position:absolute;left:-7px;top:14px;width:12px;height:12px;border-radius:50%;background:var(--blue);border:2px solid var(--white);box-shadow:0 0 0 2px var(--blue)}
.bm-step:last-child{border-left-color:transparent}
.bm-step strong{display:block;font-size:.85rem;color:var(--text)}
.bm-step span{font-size:.75rem;color:var(--text-3)}
/* Form postuler */
.bm-postuler-form{background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);padding:26px;box-shadow:var(--shadow)}
.bm-postuler-form h3{font-size:1rem;font-weight:800;color:var(--text);margin-bottom:18px;display:flex;align-items:center;gap:8px}
.bm-file-upload{border:2px dashed var(--border-2);border-radius:var(--r);padding:18px;text-align:center;cursor:pointer;transition:var(--t);position:relative}
.bm-file-upload:hover{border-color:var(--blue);background:var(--blue-pale)}
.bm-file-upload input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.bm-file-upload-text{font-size:.8rem;color:var(--text-3)}
.bm-file-upload-text strong{color:var(--blue)}

/* ══════════════════════════════════════
   FOOTER
   ══════════════════════════════════════ */
.bm-footer{background:#0F172A;padding:48px 0 22px}
.bm-footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:32px;margin-bottom:32px}
.bm-footer-brand-name{font-size:1.2rem;font-weight:800;color:#fff;letter-spacing:-.3px;margin-bottom:6px}
.bm-footer-brand-name span{color:#3B82F6}
.bm-footer-desc{font-size:.8rem;color:#64748B;line-height:1.7;margin-bottom:14px}
.bm-footer-contacts{display:flex;flex-direction:column;gap:7px}
.bm-footer-contact{display:flex;align-items:center;gap:7px;font-size:.8rem;color:#94A3B8}
.bm-footer-contact svg{width:13px;height:13px;color:#3B82F6;flex-shrink:0;fill:none;stroke:currentColor;stroke-width:2}
.bm-footer-col-title{font-size:.68rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px}
.bm-footer-links{display:flex;flex-direction:column;gap:8px}
.bm-footer-link{font-size:.8rem;color:#64748B;cursor:pointer;transition:var(--t)}
.bm-footer-link:hover{color:#93C5FD}
.bm-footer-bottom{border-top:1px solid #1E293B;padding-top:18px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.bm-footer-copy{font-size:.75rem;color:#475569}
.bm-footer-pay{display:flex;gap:6px}
.bm-pay-badge{background:#1E293B;color:#94A3B8;font-size:.65rem;font-weight:700;padding:3px 9px;border-radius:4px}
/* WhatsApp float */
.bm-wa-float{position:fixed;bottom:24px;right:24px;z-index:9999;width:52px;height:52px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:var(--t);cursor:pointer}
.bm-wa-float:hover{transform:scale(1.1)}
.bm-wa-float svg{width:28px;height:28px;fill:#fff}

/* ══════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════ */
@media(max-width:1024px){
  .bm-hero-inner,.bm-devis-inner,.bm-postuler-inner{grid-template-columns:1fr}
  .bm-hero-panel,.bm-devis-form-card{display:none}
  .bm-cats-grid{grid-template-columns:repeat(4,1fr)}
  .bm-prods-grid,.bm-drivers-grid{grid-template-columns:repeat(2,1fr)}
  .bm-loc-track>*{flex:0 0 calc(50% - 16px)}
  .bm-footer-grid{grid-template-columns:1fr 1fr}
  .bm-driver-layout{grid-template-columns:1fr}
  .bm-driver-sidebar{position:static}
}
@media(max-width:768px){
  .bm-bm-w{padding:0 16px}
  .bm-header-main-inner{flex-wrap:wrap;gap:10px}
  .bm-search{order:3;flex-basis:100%}
  .bm-hero-slide h1{font-size:1.75rem}
  .bm-cats-grid{grid-template-columns:repeat(4,1fr)}
  .bm-form-grid{grid-template-columns:1fr}
  .bm-form-group.full{grid-column:1}
  .bm-footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .bm-cats-grid{grid-template-columns:repeat(3,1fr)}
  .bm-prods-grid,.bm-drivers-grid{grid-template-columns:1fr}
  .bm-loc-track>*{flex:0 0 calc(100% - 16px)}
  .bm-footer-grid{grid-template-columns:1fr}
  .bm-hero-stats{grid-template-columns:repeat(3,1fr)}
  .bm-top-left{display:none}
}

/* ══════════════════════════════════════
   HERO SLIDER — 3 slides avec bannières catégories
   ══════════════════════════════════════ */
.bm-hero-slide-bg{background-size:cover;background-position:center;position:relative}
.bm-hero-slide-bg::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(240,244,255,.96) 45%,rgba(240,244,255,.3) 100%)}
.bm-hero-slide-dark{background:linear-gradient(135deg,#0D1B3E 0%,#1a2d5a 100%)}
.bm-hero-slide-dark::before{display:none}
.bm-hero-slide-dark h1,.bm-hero-slide-dark .bm-hero-desc{color:#fff}
.bm-hero-slide-dark .bm-hero-tag{background:rgba(255,255,255,.15);color:#fff}
.bm-hero-slide-dark .bm-hero-stat{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2)}
.bm-hero-slide-dark .bm-hero-stat-num{color:#F5B800}
.bm-hero-slide-dark .bm-hero-stat-lbl{color:rgba(255,255,255,.7)}
/* Bannières catégories sous le slider */
.bm-banners-row{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;padding:18px 0 0}
.bm-banner-card{border-radius:16px;overflow:hidden;position:relative;cursor:pointer;aspect-ratio:5/4;background:#F4F5F7;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 14px;text-decoration:none;border:1px solid rgba(0,0,0,.06);transition:transform .25s,box-shadow .25s}
.bm-banner-card:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(0,0,0,.14)}
.bm-banner-card img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;z-index:0;border-radius:16px}
.bm-banner-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);padding:12px;color:#fff;z-index:2}
.bm-banner-name{font-size:.82rem;font-weight:800;color:#fff}
.bm-banner-promo{font-size:.7rem;color:rgba(255,255,255,.85)}

/* ══════════════════════════════════════
   DURÉE LOCATION — sélecteur libre
   ══════════════════════════════════════ */
.bm-duration-picker{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.bm-duration-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.bm-duration-btn{padding:5px 12px;border:1.5px solid var(--border);border-radius:20px;background:#fff;font-size:.78rem;font-weight:600;cursor:pointer;transition:var(--t);color:var(--text-2)}
.bm-duration-btn:hover,.bm-duration-btn.active{border-color:var(--blue);background:var(--blue);color:#fff}
.bm-duration-custom{display:flex;align-items:center;gap:6px;margin-top:6px}
.bm-duration-custom input{width:70px;padding:6px 8px;border:1.5px solid var(--border);border-radius:6px;font-size:.85rem;text-align:center;outline:none}
.bm-duration-custom input:focus{border-color:var(--blue)}
.bm-duration-custom span{font-size:.82rem;color:var(--text-3)}
.bm-duration-total{background:var(--blue-pale);border:1px solid var(--blue-light);border-radius:8px;padding:10px 14px;display:flex;justify-content:space-between;align-items:center}
.bm-duration-total-lbl{font-size:.8rem;color:var(--text-3)}
.bm-duration-total-val{font-size:1.2rem;font-weight:800;color:var(--blue)}

/* ══════════════════════════════════════
   TRANSPORT — moteur de recherche moderne
   ══════════════════════════════════════ */
.bm-transport-hero{background:linear-gradient(135deg,#0D1B3E 0%,#1F3EAA 100%);padding:60px 0 0;color:#fff}
.bm-transport-hero h1{font-size:2rem;font-weight:800;color:#fff;margin-bottom:8px}
.bm-transport-hero p{color:rgba(255,255,255,.8);margin-bottom:28px}
.bm-transport-search-card{background:#fff;border-radius:var(--r-xl) var(--r-xl) 0 0;padding:28px 28px 0;margin-top:24px}
.bm-transport-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:24px}
.bm-transport-tab{padding:12px 20px;font-size:.85rem;font-weight:700;color:var(--text-3);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:var(--t);background:none;border-top:none;border-left:none;border-right:none}
.bm-transport-tab.active{color:var(--blue);border-bottom-color:var(--blue)}
.bm-transport-form-grid{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:12px;align-items:end;margin-bottom:20px}
.bm-transport-form-grid-2{grid-template-columns:1fr 1fr 1fr 1fr auto}
.bm-tf-group{display:flex;flex-direction:column;gap:5px}
.bm-tf-label{font-size:.72rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.3px;display:flex;align-items:center;gap:4px}
.bm-tf-input{padding:11px 13px;border:1.5px solid var(--border);border-radius:var(--r);font-size:.9rem;color:var(--text);outline:none;transition:var(--t);background:#fff;font-family:inherit}
.bm-tf-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(31,62,170,.08)}
.bm-transport-search-btn{background:var(--blue);color:#fff;border:none;border-radius:var(--r);padding:12px 22px;font-size:.9rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:8px;white-space:nowrap;transition:var(--t);height:46px}
.bm-transport-search-btn:hover{background:var(--blue-dark)}
.bm-transport-options{display:flex;gap:16px;flex-wrap:wrap;padding-bottom:20px;border-bottom:1px solid var(--border);margin-bottom:0}
.bm-transport-option{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--text-2);cursor:pointer}
.bm-transport-option input{accent-color:var(--blue)}
.bm-transport-results{background:#F8FAFC;border-radius:0 0 var(--r-xl) var(--r-xl);padding:20px 28px;min-height:80px;display:none}
.bm-transport-results.show{display:block}
.bm-price-result-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.bm-price-result-main{font-size:2rem;font-weight:800;color:var(--blue)}
.bm-price-result-detail{font-size:.82rem;color:var(--text-3)}
/* Options véhicules visuelles */
.bm-veh-picker{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}
.bm-veh-option{border:2px solid var(--border);border-radius:var(--r);padding:12px 8px;text-align:center;cursor:pointer;transition:var(--t);background:#fff}
.bm-veh-option:hover,.bm-veh-option.active{border-color:var(--blue);background:var(--blue-pale)}
.bm-veh-option-icon{font-size:1.8rem;margin-bottom:4px}
.bm-veh-option-name{font-size:.72rem;font-weight:700;color:var(--text-2)}
.bm-veh-option-ton{font-size:.65rem;color:var(--text-4)}
.bm-veh-option-price{font-size:.8rem;font-weight:800;color:var(--blue);margin-top:3px}

/* ══════════════════════════════════════
   PROFESSIONNELS BTP — Section
   ══════════════════════════════════════ */
.bm-pros-section{background:var(--white);padding:56px 0}
.bm-pros-hero-inner{background:linear-gradient(135deg,var(--blue-pale) 0%,#F0FDF8 100%);border-radius:var(--r-xl);padding:36px;margin-bottom:32px;display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center}
.bm-pros-hero-inner h2{font-size:1.6rem;font-weight:800;color:var(--text);letter-spacing:-.4px;margin-bottom:12px}
.bm-pros-hero-inner p{color:var(--text-2);line-height:1.7;font-size:.92rem}
.bm-pro-types{display:flex;flex-direction:column;gap:8px}
.bm-pro-type{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#fff;border:1px solid var(--border);border-radius:var(--r);transition:var(--t);cursor:pointer}
.bm-pro-type:hover{border-color:var(--blue);background:var(--blue-pale)}
.bm-pro-type-ic{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}
.bm-pro-type-name{font-size:.85rem;font-weight:700;color:var(--text)}
.bm-pro-type-desc{font-size:.72rem;color:var(--text-3)}
.bm-pro-search-form{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:22px}
.bm-pro-search-form h3{font-size:1rem;font-weight:800;color:var(--text);margin-bottom:16px}
/* Grille pros */
.bm-pros-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.bm-pro-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;transition:var(--t);cursor:pointer}
.bm-pro-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:var(--blue)}
.bm-pro-card-top{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.bm-pro-av{width:52px;height:52px;border-radius:50%;border:3px solid var(--blue-light);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:800;color:var(--blue)}
.bm-pro-badge{background:var(--blue-light);color:var(--blue);font-size:.65rem;font-weight:700;padding:2px 8px;border-radius:10px;display:inline-block;margin-bottom:3px}
.bm-pro-name{font-weight:800;font-size:.92rem;color:var(--text)}
.bm-pro-meta{font-size:.75rem;color:var(--text-3)}
.bm-pro-stars{color:var(--yellow);font-size:.82rem}
.bm-pro-tags{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:10px}
.bm-pro-tag{background:var(--bg);font-size:.68rem;font-weight:600;color:var(--text-2);padding:3px 8px;border-radius:20px}
.bm-pro-contact-btn{width:100%;background:var(--blue);color:#fff;border:none;border-radius:var(--r-sm);padding:8px;font-size:.78rem;font-weight:700;cursor:pointer;transition:var(--t);font-family:inherit}
.bm-pro-contact-btn:hover{background:var(--blue-dark)}
.bm-pro-verified{color:var(--green);font-size:.7rem;font-weight:700;display:flex;align-items:center;gap:3px}

/* ══════════════════════════════════════
   SIMULATEUR BÉTON
   ══════════════════════════════════════ */
.bm-simulateur-section{background:var(--bg);padding:48px 0}
.bm-simulateur-inner{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
.bm-simulateur-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden}
.bm-simulateur-header{background:var(--blue);color:#fff;padding:18px 22px;display:flex;align-items:center;justify-content:space-between}
.bm-simulateur-header h3{font-size:1rem;font-weight:700;margin:0;color:#fff}
.bm-simulateur-body{padding:22px}
.bm-sim-field{margin-bottom:18px}
.bm-sim-field label{display:block;font-weight:700;color:var(--text);font-size:.85rem;margin-bottom:6px}
.bm-sim-field .note{font-size:.75rem;color:var(--text-4);margin-bottom:8px}
.bm-sim-input{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--r);font-size:1rem;outline:none;transition:var(--t);font-family:inherit}
.bm-sim-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(31,62,170,.08)}
.bm-sim-select{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--r);font-size:.9rem;outline:none;background:#fff;cursor:pointer;font-family:inherit}
.bm-sim-select:focus{border-color:var(--blue)}
.bm-sim-calc-btn{width:100%;background:transparent;border:2px solid var(--blue);color:var(--blue);border-radius:var(--r);padding:13px;font-size:.95rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:var(--t);font-family:inherit;margin-bottom:10px}
.bm-sim-calc-btn:hover,.bm-sim-calc-btn:focus{background:var(--blue);color:#fff}
.bm-sim-reset{width:100%;background:none;border:none;color:var(--text-3);font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;font-family:inherit}
.bm-sim-reset:hover{color:var(--text)}
/* Résultats simulateur */
.bm-sim-results{background:var(--bg);border-radius:var(--r);padding:18px;display:none}
.bm-sim-results.show{display:block}
.bm-sim-results-title{font-weight:800;font-size:.95rem;color:var(--text);margin-bottom:14px;display:flex;align-items:center;gap:6px}
.bm-sim-result-item{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border)}
.bm-sim-result-item:last-child{border:none}
.bm-sim-result-mat{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-2)}
.bm-sim-result-mat-ic{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.9rem}
.bm-sim-result-qty{font-weight:800;color:var(--blue);font-size:.92rem}
.bm-sim-result-qty span{font-size:.72rem;color:var(--text-4);font-weight:400}
.bm-sim-add-btn{width:100%;background:var(--blue);color:#fff;border:none;border-radius:var(--r);padding:12px;font-weight:700;cursor:pointer;margin-top:14px;font-family:inherit;font-size:.88rem;transition:var(--t)}
.bm-sim-add-btn:hover{background:var(--blue-dark)}
/* Infos simulateur */
.bm-sim-info{display:flex;flex-direction:column;gap:14px}
.bm-sim-info-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:20px}
.bm-sim-info-card h4{font-size:.95rem;font-weight:800;color:var(--text);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.bm-sim-type-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.bm-sim-type-item{background:var(--bg);border-radius:var(--r-sm);padding:10px;cursor:pointer;transition:var(--t);border:1px solid transparent;text-align:center}
.bm-sim-type-item:hover{border-color:var(--blue);background:var(--blue-pale)}
.bm-sim-type-icon{font-size:1.4rem;margin-bottom:4px}
.bm-sim-type-name{font-size:.72rem;font-weight:700;color:var(--text-2)}
@media(max-width:900px){
  .bm-simulateur-inner,.bm-pros-hero-inner{grid-template-columns:1fr}
  .bm-transport-form-grid,.bm-transport-form-grid-2{grid-template-columns:1fr 1fr}
  .bm-pros-grid{grid-template-columns:1fr 1fr}
  .bm-banners-row{grid-template-columns:repeat(3,1fr)}
  .bm-veh-picker{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .bm-transport-form-grid,.bm-transport-form-grid-2{grid-template-columns:1fr}
  .bm-pros-grid{grid-template-columns:1fr}
  .bm-banners-row{grid-template-columns:repeat(2,1fr)}
  .bm-sim-type-grid{grid-template-columns:1fr 1fr}
}

/* Alias de compatibilité */
.bm-container{max-width:var(--w);margin:0 auto;padding:0 24px}

/* ══ Alias .container → .bm-w ══ */
.container{max-width:1280px;margin:0 auto;padding:0 24px}

/* ══ Boutique — corrections layout ══ */
.bm-shop{padding:32px 0 60px;background:#F4F5F7;min-height:60vh}
.bm-shop-layout{display:grid;grid-template-columns:260px 1fr;gap:24px;align-items:start}
.bm-shop-sidebar .bm-filter-box{background:#fff;border:1px solid #E2E8F0;border-radius:12px;padding:20px;position:sticky;top:80px}
.bm-shop-sidebar .bm-filter-box h3{font-size:1rem;font-weight:800;color:#0F172A;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid #F5B800}
.bm-filter-group{margin-bottom:16px}
.bm-filter-group label{display:block;font-size:.75rem;font-weight:700;color:#334155;text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px}
.bm-filter-group select{width:100%;padding:9px 12px;border:1.5px solid #E2E8F0;border-radius:8px;font-size:.88rem;background:#fff;outline:none;cursor:pointer}
.bm-filter-group select:focus{border-color:#1F3EAA}
.bm-cat-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:3px}
.bm-cat-list a{display:flex;justify-content:space-between;align-items:center;padding:7px 10px;border-radius:7px;font-size:.85rem;color:#334155;text-decoration:none;transition:.15s}
.bm-cat-list a:hover,.bm-cat-list a.active{background:#EEF2FF;color:#1F3EAA;font-weight:700}
.bm-cat-list span{font-size:.72rem;color:#94A3B8}
.bm-price-range-inputs{display:flex;justify-content:space-between;font-size:.78rem;color:#64748B;margin-top:6px}
.bm-price-range-inputs strong{color:#0F172A;font-weight:700}
input[type=range]{width:100%;accent-color:#1F3EAA}
.bm-filter-apply-btn{width:100%;padding:10px;background:#F4F5F7;border:1.5px solid #E2E8F0;border-radius:8px;font-size:.85rem;font-weight:700;cursor:pointer;transition:.15s;margin-top:4px}
.bm-filter-apply-btn:hover{background:#1F3EAA;color:#fff;border-color:#1F3EAA}
/* Grille produits */
.bm-products-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:10px}
.bm-products-header h1{font-size:1.2rem;font-weight:800;color:#0F172A;margin:0}
.bm-view-btns{display:flex;gap:4px}
.bm-view-btn{width:34px;height:34px;border:1.5px solid #E2E8F0;border-radius:7px;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.15s}
.bm-view-btn.active,.bm-view-btn:hover{background:#1F3EAA;border-color:#1F3EAA;color:#fff}
.bm-products-grid ul.products{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:0;padding:0;list-style:none}
.bm-products-grid ul.products li.product{background:#fff;border:1px solid #E2E8F0;border-radius:12px;overflow:hidden;transition:.2s;display:flex;flex-direction:column}
.bm-products-grid ul.products li.product:hover{box-shadow:0 8px 32px rgba(0,0,0,.1);transform:translateY(-2px);border-color:#93C5FD}
.bm-products-grid ul.products li.product a.woocommerce-loop-product__link{display:block;text-decoration:none}
.bm-products-grid ul.products li.product img{width:100%;height:200px;object-fit:cover;display:block}
.bm-products-grid ul.products li.product a.woocommerce-loop-product__link{display:block;overflow:hidden}
.bm-products-grid ul.products li.product .woocommerce-loop-product__title{font-size:.9rem;font-weight:700;color:#0F172A;padding:12px 14px 4px;margin:0;line-height:1.4}
.bm-products-grid ul.products li.product .price{display:flex;align-items:baseline;gap:6px;padding:0 14px 10px;font-size:1rem;font-weight:800;color:#0F172A}
.bm-products-grid ul.products li.product .price del{font-size:.78rem;color:#94A3B8;font-weight:400}
.bm-products-grid ul.products li.product .price ins{text-decoration:none;color:#EF4444}
.bm-products-grid ul.products li.product .button{display:flex;align-items:center;justify-content:center;gap:6px;margin:0 14px 14px;padding:10px;background:#1F3EAA;color:#fff;border-radius:8px;font-size:.82rem;font-weight:700;text-decoration:none;border:none;cursor:pointer;transition:.15s;width:calc(100% - 28px)}
.bm-products-grid ul.products li.product .button:hover{background:#162E84}
.bm-onsale{position:absolute;top:10px;left:10px;background:#EF4444;color:#fff;font-size:.7rem;font-weight:800;padding:3px 9px;border-radius:20px;z-index:2}
/* Pagination */
.woocommerce-pagination{margin-top:28px;text-align:center}
.woocommerce-pagination ul{display:inline-flex;gap:4px;list-style:none;padding:0;margin:0}
.woocommerce-pagination ul li a,.woocommerce-pagination ul li span{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1.5px solid #E2E8F0;border-radius:8px;font-size:.85rem;font-weight:600;color:#334155;text-decoration:none;transition:.15s}
.woocommerce-pagination ul li span.current{background:#1F3EAA;color:#fff;border-color:#1F3EAA}
.woocommerce-pagination ul li a:hover{background:#EEF2FF;border-color:#1F3EAA;color:#1F3EAA}
@media(max-width:900px){
  .bm-shop-layout{grid-template-columns:1fr}
  .bm-shop-sidebar .bm-filter-box{position:static}
  .bm-products-grid ul.products{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:500px){
  .bm-products-grid ul.products{grid-template-columns:1fr}
}

/* ══ Images produits WooCommerce — cover forcé ══ */
.woocommerce ul.products li.product img,
.bm-products-grid img.attachment-woocommerce_thumbnail,
.bm-products-grid img.size-woocommerce_thumbnail{
    width:100%!important;
    height:200px!important;
    object-fit:cover!important;
    display:block!important;
}
/* Fix images trop petites / pas en cover */
.bm-pc>a img{
    width:100%!important;
    height:180px!important;
    object-fit:cover!important;
}

/* Animation spin pour le loader panier */
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}


/* ═══════════════════════════════════════
   PALETTE & SECTIONS — Harmonisation v2
   ═══════════════════════════════════════ */

/* Variables palette BatiMaroc */
:root{
  --blue:        #1F3EAA;
  --blue-dark:   #162E84;
  --blue-mid:    #2B4FCA;
  --blue-light:  #DBEAFE;
  --blue-pale:   #EFF6FF;
  --yellow:      #F5B800;
  --yellow-dark: #D4A000;
  --green:       #10B981;
  --red:         #EF4444;
  --text:        #0F172A;
  --text-2:      #1E293B;
  --text-3:      #475569;
  --text-4:      #94A3B8;
  --bg:          #F8FAFC;
  --bg-2:        #F1F5F9;
  --border:      #E2E8F0;
  --white:       #FFFFFF;
  --r:           14px;
  --r-sm:        8px;
  --t:           all .2s ease;
}

/* Sections alternées blanc / gris */
section, .bm-cats-section, .bm-loc-section,
.bm-drivers-section, .bm-pros-section,
.bm-devis-section, .bm-postuler-section{
  position: relative;
}

/* Padding uniforme pour toutes les sections */
.bm-loc-section,
.bm-drivers-section,
.bm-pros-section,
.bm-devis-section,
.bm-postuler-section{
  padding: 52px 0;
}

/* Section DEVIS — fond bleu, textes blancs */
.bm-devis-section .bm-section-label{ color: rgba(255,255,255,.7) !important; }
.bm-devis-section .bm-section-title{ color: #fff !important; }
.bm-devis-section .bm-section-desc{  color: rgba(255,255,255,.75) !important; }
.bm-devis-section .bm-devis-form{    background: rgba(255,255,255,.1) !important; border-color: rgba(255,255,255,.2) !important; }
.bm-devis-section input,
.bm-devis-section select,
.bm-devis-section textarea{
  background: rgba(255,255,255,.95) !important;
  border-color: rgba(255,255,255,.3) !important;
  color: #0F172A !important;
}

/* En-têtes de sections — uniformes */
.bm-section-label{
  font-size: .72rem;
  font-weight: 700;
  color: var(--blue);
  text-transform: uppercase;
  letter-spacing: .6px;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.bm-section-label::before{
  content: '';
  display: inline-block;
  width: 20px;
  height: 2px;
  background: var(--blue);
  border-radius: 2px;
}
.bm-section-title{
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--text);
  margin-bottom: 8px;
  line-height: 1.2;
}
.bm-section-desc{
  font-size: .9rem;
  color: var(--text-3);
  line-height: 1.6;
}
.bm-section-header{
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 32px;
  flex-wrap: wrap;
}

/* Boutons harmonisés */
.btn{
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 11px 22px;
  border-radius: 9px;
  font-size: .88rem;
  font-weight: 700;
  cursor: pointer;
  transition: var(--t);
  text-decoration: none;
  border: 2px solid transparent;
  font-family: inherit;
  white-space: nowrap;
}
.btn-primary{ background: var(--blue); color: #fff; border-color: var(--blue); }
.btn-primary:hover{ background: var(--blue-dark); border-color: var(--blue-dark); }
.btn-yellow{ background: var(--yellow); color: #0F172A; border-color: var(--yellow); }
.btn-yellow:hover{ background: var(--yellow-dark); border-color: var(--yellow-dark); }
.btn-outline{ background: transparent; color: var(--blue); border-color: var(--blue); }
.btn-outline:hover{ background: var(--blue); color: #fff; }
.btn-white{ background: #fff; color: var(--blue); border-color: #fff; }
.btn-white:hover{ background: var(--blue-pale); }
.btn-green{ background: var(--green); color: #fff; border-color: var(--green); }
.btn-sm{ padding: 8px 16px; font-size: .8rem; }
.btn-full{ width: 100%; justify-content: center; }

/* Cards harmonisées */
.bm-card{
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--r);
  transition: var(--t);
}
.bm-card:hover{
  box-shadow: 0 8px 32px rgba(0,0,0,.09);
  transform: translateY(-3px);
  border-color: #BFDBFE;
}

/* Badges statut harmonisés */
.bm-badge{
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: .7rem;
  font-weight: 700;
}
.bm-badge-blue{   background: #EFF6FF; color: var(--blue); }
.bm-badge-green{  background: #D1FAE5; color: #065F46; }
.bm-badge-yellow{ background: #FEF3C7; color: #92400E; }
.bm-badge-red{    background: #FEE2E2; color: #991B1B; }

/* Séparateur visuel entre sections */
.bm-divider{
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
  margin: 0;
}
