/* AUTOMSOURCE Shop — feuille de style commune (design v2) */
:root{
  --teal:#0a9396; --teal-d:#077377; --dark:#0f1b2d; --dark2:#1a2942;
  --bg:#f5f7fa; --card:#fff; --line:#e6ebf1; --muted:#6b7a90; --ink:#0f1b2d;
  --accent:#ff8a00; --accent-d:#e87c00; --green:#16a34a; --green-bg:#e7f8ee;
  --amber:#b45309; --amber-bg:#fef3c7; --radius:14px;
  --shadow:0 1px 3px rgba(16,27,45,.06); --shadow-h:0 10px 28px rgba(16,27,45,.12);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.55;font-size:15px;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.container{max-width:1260px;margin:0 auto;padding:0 22px}
.muted{color:var(--muted)}

/* TOPBAR */
.topbar{background:var(--dark);color:#aebbcf;font-size:12.5px}
.topbar .container{display:flex;justify-content:space-between;align-items:center;height:36px}
.topbar b{color:#fff}
.topbar .tb-right span{margin-left:22px}

/* HEADER */
header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;box-shadow:var(--shadow)}
.head{display:flex;align-items:center;gap:28px;height:78px}
.logo-img{height:46px;width:auto;flex-shrink:0}
.search{flex:1;display:flex;border:2px solid var(--teal);border-radius:10px;overflow:hidden;max-width:680px}
.search input{flex:1;border:0;padding:12px 16px;font-size:15px;outline:none}
.search button{background:var(--teal);color:#fff;border:0;padding:0 24px;font-weight:600;cursor:pointer;font-size:14px}
.search button:hover{background:var(--teal-d)}
.head-actions{display:flex;gap:22px;align-items:center;margin-left:auto}
.ico{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:12px;font-weight:600;color:var(--ink)}
.ico small{font-weight:500;color:var(--muted)}
.pill{background:var(--accent);color:#fff;border-radius:9px;padding:11px 20px;font-weight:700;white-space:nowrap;font-size:14px}
.pill:hover{background:var(--accent-d)}

/* NAV + MEGA */
nav.main{background:var(--dark2)}
nav.main .container{display:flex;gap:2px;flex-wrap:wrap;position:relative}
nav.main>.container>a,.has-mega>a{color:#e4ebf4;padding:13px 16px;font-size:14px;font-weight:600;display:inline-block}
nav.main a:hover{background:rgba(255,255,255,.08)}
nav.main a.hot{color:var(--accent)}
.has-mega{position:static;display:inline-block}
.mega{display:none;position:absolute;left:0;right:0;top:100%;background:#fff;border-radius:0 0 16px 16px;box-shadow:var(--shadow-h);padding:26px 30px;z-index:60;grid-template-columns:repeat(4,1fr);gap:28px;border-top:3px solid var(--accent)}
.has-mega:hover .mega{display:grid}
.mega h4{color:var(--teal);font-size:12px;text-transform:uppercase;margin-bottom:12px;letter-spacing:.05em;font-weight:700}
.mega a{display:block;color:var(--ink)!important;padding:6px 0;font-size:14px;font-weight:500;background:none!important}
.mega a:hover{color:var(--teal)!important;padding-left:4px;transition:.12s}

/* HERO */
.hero{background:linear-gradient(120deg,var(--dark) 0%,var(--dark2) 60%,var(--teal-d) 135%);color:#fff;padding:60px 0}
.hero h1{font-size:40px;line-height:1.12;max-width:780px;margin-bottom:16px;font-weight:800;letter-spacing:-.5px}
.hero h1 span{color:var(--accent)}
.hero p{font-size:17px;color:#c2cfe0;max-width:660px;margin-bottom:28px}
.hero-search{display:flex;max-width:680px;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 16px 40px rgba(0,0,0,.28)}
.hero-search input{flex:1;border:0;padding:18px 22px;font-size:16px;outline:none}
.hero-search button{background:var(--accent);color:#fff;border:0;padding:0 30px;font-weight:800;cursor:pointer;font-size:15px}
.hero-search button:hover{background:var(--accent-d)}
.hero-tags{margin-top:18px;font-size:13px;color:#9fb0c6}
.hero-tags a{color:#fff;border:1px solid rgba(255,255,255,.28);padding:5px 13px;border-radius:16px;margin-right:8px;display:inline-block;margin-top:8px;transition:.12s}
.hero-tags a:hover{background:rgba(255,255,255,.12)}

/* REASSURANCE */
.reass{background:#fff;border-bottom:1px solid var(--line)}
.reass .container{display:grid;grid-template-columns:repeat(4,1fr)}
.reass .item{padding:22px 18px;text-align:center;border-right:1px solid var(--line);display:flex;flex-direction:column;align-items:center;gap:2px}
.reass .item:last-child{border-right:0}
.reass .em{font-size:24px;margin-bottom:6px}
.reass .item b{font-size:14px}
.reass .item small{color:var(--muted);font-size:12px}

/* STATS */
.stats{background:var(--dark)}
.stats .container{display:grid;grid-template-columns:repeat(4,1fr);padding:38px 22px}
.stats .s{text-align:center;border-right:1px solid rgba(255,255,255,.1);padding:6px}
.stats .s:last-child{border-right:0}
.stats .n{font-size:38px;font-weight:800;color:var(--accent);line-height:1;letter-spacing:-1px}
.stats .l{font-size:13px;color:#aebbcf;margin-top:10px}

section{padding:50px 0}
.sec-title{font-size:25px;margin-bottom:6px;font-weight:800;letter-spacing:-.4px}
.sec-sub{color:var(--muted);margin-bottom:28px;font-size:15px}

/* BRANDS */
.brands{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.brand{background:#fff;border:1px solid var(--line);border-radius:12px;padding:22px 10px;text-align:center;font-weight:700;font-size:15px;box-shadow:var(--shadow);transition:.15s}
.brand:hover{border-color:var(--teal);box-shadow:var(--shadow-h);transform:translateY(-2px)}
.brand small{display:block;font-weight:500;color:var(--muted);font-size:11px;margin-top:3px}

/* CATEGORIES */
.cats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);transition:.15s}
.cat:hover{border-color:var(--teal);transform:translateY(-3px);box-shadow:var(--shadow-h)}
.cat .em{font-size:30px}
.cat h3{margin:14px 0 6px;font-size:18px;font-weight:700}
.cat p{color:var(--muted);font-size:13.5px;margin-bottom:12px}
.cat .lk{color:var(--teal);font-weight:700;font-size:13.5px}

/* WHY */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.why{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);transition:.15s}
.why:hover{border-color:var(--teal);box-shadow:var(--shadow-h)}
.why .em{font-size:28px}
.why h3{font-size:16px;margin:12px 0 6px;font-weight:700}
.why p{color:var(--muted);font-size:13.5px}

/* OBSO BANNER */
.obso{background:linear-gradient(120deg,var(--teal) 0%,var(--teal-d) 100%);color:#fff;border-radius:18px;padding:40px 44px;display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap;box-shadow:var(--shadow-h)}
.obso h2{font-size:27px;margin-bottom:8px;font-weight:800}
.obso p{color:#dbf5f5;max-width:660px;font-size:15px}
.obso .btn{background:#fff;color:var(--teal-d);font-weight:800;padding:15px 28px;border-radius:10px;white-space:nowrap}
.obso .btn:hover{background:#f0fdfd}

/* PRODUCT CARDS (grille) */
.prods{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.prod{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.15s;display:flex;flex-direction:column;box-shadow:var(--shadow)}
.prod:hover{border-color:var(--teal);box-shadow:var(--shadow-h);transform:translateY(-3px)}
.prod .ph{height:160px;background:#fff;display:flex;align-items:center;justify-content:center;padding:14px;border-bottom:1px solid var(--line);position:relative}
.prod .ph img{max-height:100%;max-width:100%;object-fit:contain}
.prod .ph .noimg{color:#c2ccd9;font-size:12px}
.badge{position:absolute;top:10px;left:10px;font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px}
.b-stock{background:var(--green-bg);color:var(--green)}
.b-obso{background:var(--amber-bg);color:var(--amber)}
.prod .body{padding:15px;flex:1;display:flex;flex-direction:column}
.prod .brand-tag{font-size:11px;color:var(--teal);font-weight:700;text-transform:uppercase;letter-spacing:.03em}
.prod .ref{font-family:'SFMono-Regular',Menlo,monospace;font-weight:700;font-size:14.5px;margin:4px 0 5px}
.prod .desc{color:var(--muted);font-size:12.5px;margin-bottom:13px;flex:1}
.prod .cta{background:var(--dark);color:#fff;text-align:center;padding:11px;border-radius:8px;font-weight:700;font-size:13px}
.prod .cta:hover{background:var(--teal)}

/* BLOG */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.post{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.post .ph{height:130px;background:linear-gradient(120deg,var(--dark2),var(--teal-d))}
.post .body{padding:18px}
.post .tag{font-size:11px;color:var(--teal);font-weight:700;text-transform:uppercase}
.post h4{margin:8px 0;font-size:15.5px;line-height:1.35;font-weight:700}
.post a.lk{color:var(--teal);font-weight:700;font-size:13px}

/* FOOTER */
footer{background:var(--dark);color:#9fb0c6;padding:48px 0 26px;font-size:13.5px;margin-top:14px}
.fcols{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:34px;margin-bottom:30px}
footer h5{color:#fff;font-size:13px;margin-bottom:14px;text-transform:uppercase;letter-spacing:.05em}
footer li{list-style:none;padding:4px 0}
footer a:hover{color:#fff}
.flogo-img{height:54px;background:#fff;padding:9px 16px;border-radius:10px;margin-bottom:14px;display:inline-block}
.fbar{border-top:1px solid #25324a;padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:#7e8caa;font-size:12px}

@media(max-width:920px){
  .reass .container,.stats .container,.brands,.cats,.prods,.posts,.why-grid,.fcols,.mega{grid-template-columns:repeat(2,1fr)}
  .head{flex-wrap:wrap;height:auto;padding:12px 0;gap:14px}
  .hero h1{font-size:30px}
}

/* ========== FICHE PRODUIT ========== */
.bc{font-size:13px;color:var(--muted);padding:18px 0 4px}.bc a{color:var(--teal)}
.ptop{display:grid;grid-template-columns:1fr 1fr;gap:38px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;margin-top:8px;box-shadow:var(--shadow)}
.gallery .main-img{height:360px;background:#fff;border:1px solid var(--line);border-radius:12px;display:flex;align-items:center;justify-content:center;padding:24px}
.gallery .main-img img{max-width:90%;max-height:90%;object-fit:contain}
.gallery .noimg{color:#b4c0d0;font-size:13px;text-align:center;line-height:1.6}
.pinfo .brand{color:var(--teal);font-weight:800;text-transform:uppercase;font-size:13px;letter-spacing:.04em}
.pinfo h1{font-size:27px;margin:6px 0 4px;font-family:'SFMono-Regular',Menlo,monospace;letter-spacing:-.5px}
.pinfo .sub{color:var(--muted);font-size:15px;margin-bottom:14px}
.stock{display:inline-flex;align-items:center;gap:7px;background:var(--green-bg);color:var(--green);font-weight:700;padding:7px 14px;border-radius:8px;font-size:14px;margin-bottom:18px}
.stock.devis{background:var(--amber-bg);color:var(--amber)}
.stock .dot{width:9px;height:9px;border-radius:50%;background:currentColor}
.specs-mini{width:100%;border-collapse:collapse;margin-bottom:18px;font-size:14px}
.specs-mini td{padding:9px 0;border-bottom:1px solid var(--line)}
.specs-mini td:first-child{color:var(--muted);width:48%}
.specs-mini td:last-child{font-weight:600}
.buybox{background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:18px}
.btn-main{display:block;width:100%;background:var(--accent);color:#fff;text-align:center;padding:15px;border-radius:9px;font-weight:800;font-size:16px;border:0;cursor:pointer}
.btn-main:hover{background:var(--accent-d)}
.btn-sec{display:block;width:100%;background:var(--dark);color:#fff;text-align:center;padding:13px;border-radius:9px;font-weight:700;margin-top:10px}
.reassure{display:flex;gap:16px;margin-top:16px;flex-wrap:wrap;font-size:12.5px;color:var(--muted)}
.reassure b{color:var(--ink)}
/* Stock/prix temps réel (endpoints publics) */
.b-stock{background:var(--green-bg);color:var(--green)}
.price-zone{margin:0 0 14px}
.price-zone .amount{font-size:26px;font-weight:800;color:var(--ink)}
.price-zone .onquote{font-size:15px;font-weight:700;color:var(--muted)}
.dbl-garantie{margin-top:12px;font-size:12.5px;color:var(--muted)}
.dbl-garantie b{color:var(--ink)}
.card-price{margin:4px 0 2px}
.card-price .amount{font-weight:800;color:var(--ink);font-size:16px}
/* Panier */
.btn-buy{display:block;width:100%;background:var(--green,#16a34a);color:#fff;text-align:center;padding:15px;border-radius:9px;font-weight:800;font-size:16px;border:0;cursor:pointer;margin-bottom:10px}
.btn-buy:hover{filter:brightness(.95)}
.btn-buy:disabled{opacity:.55;cursor:not-allowed}
.pill-cart{position:relative}
.cart-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--accent,#f97316);color:#fff;font-size:11px;font-weight:800;margin-left:4px}
.psec{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;margin-top:20px;box-shadow:var(--shadow)}
.psec h2{font-size:20px;margin-bottom:14px;padding-bottom:8px;border-bottom:2px solid var(--teal);display:inline-block;font-weight:800}
.specs-full{width:100%;border-collapse:collapse;font-size:14.5px}
.specs-full td{padding:11px 12px;border-bottom:1px solid var(--line)}
.specs-full tr:nth-child(odd){background:var(--bg)}
.specs-full td:first-child{color:var(--muted);width:40%}
.migr{background:linear-gradient(120deg,var(--teal),var(--teal-d));color:#fff;border-radius:12px;padding:22px 26px}
.migr h3{font-size:18px;margin-bottom:6px}.migr p{color:#dbf5f5;font-size:14.5px;margin-bottom:12px}
.migr a{background:#fff;color:var(--teal-d);font-weight:700;padding:10px 18px;border-radius:8px;display:inline-block;font-size:14px}
.faq details{border:1px solid var(--line);border-radius:8px;padding:12px 16px;margin-bottom:10px;background:var(--bg)}
.faq summary{font-weight:700;cursor:pointer}.faq p{margin-top:8px;color:#334155;font-size:14px}
.rel{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.rel .c{background:#fff;border:1px solid var(--line);border-radius:10px;padding:14px;box-shadow:var(--shadow)}
.rel .c:hover{border-color:var(--teal);box-shadow:var(--shadow-h)}
.rel .ph{height:96px;background:#fff;border:1px solid var(--line);border-radius:7px;margin-bottom:10px;display:flex;align-items:center;justify-content:center;padding:8px}
.rel .ph img{max-width:100%;max-height:100%;object-fit:contain}
.rel .ph .noimg{color:#c2ccd9;font-size:11px}
.rel .ref{font-family:'SFMono-Regular',Menlo,monospace;font-weight:700;font-size:13px}
.rel .br{color:var(--teal);font-size:11px;font-weight:700;text-transform:uppercase}
.rel a.lk{color:var(--teal);font-weight:700;font-size:12.5px}

/* ========== PAGE GAMME (catégorie) ========== */
.gamme-head{background:linear-gradient(120deg,var(--dark),var(--dark2));color:#fff;padding:34px 0}
.gamme-head h1{font-size:30px;font-weight:800;letter-spacing:-.4px}
.gamme-head p{color:#c2cfe0;margin-top:8px;max-width:760px;font-size:15px}
.gamme-layout{display:grid;grid-template-columns:230px 1fr;gap:26px;padding:34px 0}
.filters{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);align-self:start;position:sticky;top:96px}
.filters h4{font-size:12px;text-transform:uppercase;color:var(--muted);letter-spacing:.05em;margin:14px 0 8px}
.filters h4:first-child{margin-top:0}
.filters label{display:flex;align-items:center;gap:8px;font-size:13.5px;padding:4px 0;cursor:pointer}
.gamme-count{color:var(--muted);font-size:14px;margin-bottom:16px}
.noimg-ph{color:#c2ccd9;font-size:12px;text-align:center}
@media(max-width:920px){.ptop,.rel{grid-template-columns:1fr}.gamme-layout{grid-template-columns:1fr}.filters{position:static}}
