/* =========================================================
   RESET / BASE
   ========================================================= */

:root{
    --primary:#df001d;
    --primary-dark:#29136A;
    --text:#1f2937;
    --muted:#6b7280;
    --line:#e5e7eb;
    --bg-soft:#f8fafc;
    --card:#ffffff;
    --shadow:0 6px 18px rgba(0,0,0,.06);
    --radius-xl:24px;
    --radius-lg:20px;
    --radius-md:16px;
}

*{
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    margin:0;
    position:relative;
    background:#fff;
    color:var(--text);
    font:normal 12px Arial, Helvetica, sans-serif;
}

header,
footer,
nav,
article,
section,
figure,
main,
aside{
    display:block;
}

a,
a:link{
    text-decoration:none;
}

a img{
    border:0;
}

img{
    max-width:100%;
    height:auto;
}

.clearBoth{
    clear:both;
}

.gras{
    font-weight:700;
}

.pubTopDessusArche,
#oas_Top2{
    display:none !important;
    margin:0 !important;
    padding:0 !important;
    height:0 !important;
    min-height:0 !important;
    overflow:hidden !important;
}

/* =========================================================
   HEADER MODERNE
   ========================================================= */

#header,
#header.header-modern,
#header.th-header,
.header-modern{
    margin:0 !important;
    padding:0 !important;
    background:#fff !important;
    border-bottom:1px solid var(--line);
    z-index:100;
}

#header .contentHeader,
#header .contentHeader .aboConnect,
#header .contentHeader .bannier_v3{
    display:none !important;
}

.search-shell-banner,
.th-topbar{
    width:100%;
    max-width:1600px;
    margin:0 auto !important;
    padding:8px 24px !important;
    display:flex !important;
    align-items:center !important;
    gap:18px !important;
    box-sizing:border-box !important;
}

.titre,
.logo-1000achat,
.th-logo,
#header .titre,
#header .logo-1000achat,
#header .titre.logo-1000achat{
    display:inline-block !important;
    margin:0 !important;
    padding:0 !important;
    font-size:32px !important;
    line-height:1 !important;
    font-family:Arial, Helvetica, sans-serif !important;
    font-weight:800 !important;
    color:var(--primary) !important;
    text-decoration:none !important;
    text-shadow:none !important;
    white-space:nowrap !important;
    text-align:left !important;
    flex:0 0 auto;
}

.search-form-banner,
.th-search{
    flex:1 !important;
    display:flex !important;
    align-items:center !important;
    gap:8px !important;
    margin:0 !important;
    padding:6px !important;
    background:#fff !important;
    border:1px solid var(--line) !important;
    border-radius:16px !important;
    box-shadow:0 4px 12px rgba(0,0,0,.05) !important;
}

.search-input-banner,
.th-search-input{
    flex:1 !important;
    min-width:0 !important;
    height:40px !important;
    margin:0 !important;
    padding:0 12px !important;
    border:0 !important;
    outline:none !important;
    background:transparent !important;
    font-size:15px !important;
    line-height:40px !important;
    color:var(--text) !important;
}

.search-button-banner,
.th-search-button{
    height:40px !important;
    margin:0 !important;
    padding:0 18px !important;
    border:0 !important;
    border-radius:12px !important;
    background:var(--primary) !important;
    color:#fff !important;
    font-size:14px !important;
    font-weight:700 !important;
    line-height:40px !important;
    cursor:pointer !important;
    white-space:nowrap !important;
}

.search-button-banner:hover,
.th-search-button:hover{
    background:#b80018 !important;
}

.th-search-wrap{
    flex:1;
    display:flex;
    flex-direction:column;
    gap:8px;
}

.th-search-switch{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
}

.th-switch-btn{
    height:32px;
    padding:0 12px;
    border:1px solid var(--line);
    border-radius:999px;
    background:#fff;
    color:#444;
    font-size:13px;
    font-weight:700;
    cursor:pointer;
}

.th-switch-btn.is-active{
    background:var(--primary);
    color:#fff;
    border-color:var(--primary);
}

/* =========================================================
   MENU EXTERNE NOIR
   ========================================================= */

#header .navExterne,
.navExterne,
.th-nav-externe{
    margin:0 !important;
    padding:0 !important;
    background:#000 !important;
}

#header .navExterne ul,
.navExterne ul,
.th-nav-externe ul{
    width:98.40764%;
    max-width:1256px;
    margin:0 auto !important;
    padding:0 !important;
    list-style:none !important;
    font-size:0 !important;
}

#header .navExterne ul li,
.navExterne ul li,
.th-nav-externe li{
    display:inline-block !important;
    margin:0 !important;
    padding:0 !important;
    font-size:13px;
    font-weight:700;
    text-transform:uppercase;
}

#header .navExterne ul li a,
.navExterne ul li a,
.th-nav-externe a{
    display:inline-block !important;
    padding:10px 14px !important;
    color:#fff !important;
    text-decoration:none !important;
    line-height:1.2 !important;
    font-size:13px !important;
    font-weight:700 !important;
    text-transform:uppercase !important;
}

#header .navExterne ul li.navExtOn a,
#header .navExterne ul li a:hover,
.navExterne ul li.navExtOn a,
.navExterne ul li a:hover,
.th-home-item a,
.th-nav-externe a:hover{
    background:var(--primary) !important;
}

/* =========================================================
   MENU PRINCIPAL ROUGE
   ========================================================= */

#header .navPrincipale,
.navPrincipale,
.th-nav-main{
    margin:0 !important;
    padding:0 !important;
    background:var(--primary) !important;
}

#header .navPrincipale .listNavPrinc,
.navPrincipale .listNavPrinc,
.th-nav-main ul{
    width:98.40764%;
    max-width:1256px;
    margin:0 auto !important;
    padding:0 !important;
    list-style:none !important;
    font-size:0 !important;
}

#header .navPrincipale .listNavPrinc > li,
.navPrincipale .listNavPrinc > li,
.th-nav-main li{
    display:inline-block !important;
    position:relative !important;
    margin:0 !important;
    padding:0 !important;
}

#header .navPrincipale .listNavPrinc > li > a,
.navPrincipale .listNavPrinc > li > a,
.th-nav-main a{
    display:inline-block !important;
    padding:11px 12px !important;
    color:#fff !important;
    font-size:12px !important;
    font-weight:700 !important;
    text-transform:uppercase !important;
    text-decoration:none !important;
    line-height:1.2 !important;
    vertical-align:middle !important;
}

#header .navPrincipale .listNavPrinc > li > a:hover,
.navPrincipale .listNavPrinc > li > a:hover,
.th-nav-main a:hover{
    background:#fff !important;
    color:var(--primary) !important;
}

#header .navPrincipale .listNavPrinc > li .subNavPrinc,
.navPrincipale .listNavPrinc > li .subNavPrinc{
    display:none;
    z-index:10;
    position:absolute;
    left:0;
    top:100%;
    width:220px;
    margin:0;
    padding:10px 10px 14px;
    list-style:none;
    background:#fff;
    border:1px solid var(--primary);
}

#header .navPrincipale .listNavPrinc > li:hover .subNavPrinc,
.navPrincipale .listNavPrinc > li:hover .subNavPrinc{
    display:block;
}

#header .navPrincipale .listNavPrinc > li .subNavPrinc li,
.navPrincipale .listNavPrinc > li .subNavPrinc li{
    display:block;
    margin:8px 0 0;
    padding:0 0 0 10px;
    font-size:14px;
    font-weight:400;
    text-transform:none;
}

#header .navPrincipale .listNavPrinc > li .subNavPrinc li a,
.navPrincipale .listNavPrinc > li .subNavPrinc li a{
    color:#000;
    text-decoration:none;
}

#header .navPrincipale .listNavPrinc > li .subNavPrinc li a:hover,
.navPrincipale .listNavPrinc > li .subNavPrinc li a:hover{
    text-decoration:underline;
}

/* =========================================================
   BOUTONS / TITRES HISTORIQUES
   ========================================================= */

.boutonType1{
    display:inline-block;
    border:0;
    margin:20px 0 0;
    padding:8px 18px;
    background-color:var(--primary);
    font-size:15px;
    color:#fff;
    font-weight:700;
    text-transform:uppercase;
    cursor:pointer;
}

.boutonType1:hover,
a.boutonType1:hover{
    text-decoration:none;
    background-color:#404040;
    color:#fff;
}

.titreType1{
    margin:0 0 10px;
    padding-bottom:5px;
    font-size:18px;
    color:#222;
    font-weight:400;
    text-transform:uppercase;
    border-bottom:1px solid #d4d4d4;
}

.titreType2{
    margin:0 0 10px;
    font-size:34px;
    color:#000;
    font-weight:700;
}

.titreType3{
    margin:0 0 10px;
    padding-bottom:5px;
    font-size:13px;
    color:#222;
    font-weight:400;
    text-transform:uppercase;
    border-bottom:1px solid #d4d4d4;
}

.titreType4{
    margin:25px 0 0;
    font-size:45px;
    color:var(--primary);
    font-weight:700;
}

.titreType8{
    margin:0 0 20px;
    font-size:18px;
    color:var(--primary);
    font-weight:700;
    text-transform:uppercase;
}

.titreType10{
    margin:45px 0 0;
    position:relative;
    text-align:center;
}

.titreType10 .texte{
    display:inline-block;
    position:relative;
    z-index:2;
    padding:0 25px;
    background:#fff;
    font-size:30px;
    color:var(--primary);
    font-weight:400;
    text-transform:uppercase;
}

.titreType10 .filet{
    position:absolute;
    top:17px;
    left:0;
    width:100%;
    border-top:1px solid var(--primary);
}

.titreTypeCol1{
    position:relative;
    margin:0;
    padding:0 0 2px;
    font-size:18px;
    text-transform:uppercase;
    color:#fa8d00;
    border-bottom:1px solid #fa8d00;
}

.pictoTitreCol{
    position:absolute;
    right:0;
    bottom:-16px;
    width:43px;
    height:44px;
}

/* =========================================================
   LAYOUT HISTORIQUE
   ========================================================= */

.contenuPrincipal{
    width:98.40764%;
    max-width:1256px;
    margin:0 auto;
    padding:20px 10px 10px;
    background:#fff;
}

.contenuPrincipal:before,
.contenuPrincipal:after{
    content:" ";
    display:table;
}

.contenuPrincipal:after{
    clear:both;
}

.contenuPage{
    width:74.04459%;
    float:left;
    margin:0;
    padding:0;
    background:#fff;
}

.contenuPrincipal #colonneDroite{
    width:23.88535%;
    float:left;
    margin:10px 0 0 1.99045%;
    padding:0;
    background:#fff;
}

#colonneDroite > div{
    margin-top:30px;
}

#colonneDroite > div:first-child{
    margin-top:0;
}

#colonneDroite .blocTypeCol1{
    padding:0 0 15px;
}

#colonneDroite #espaceAbo ul{
    list-style:none;
    margin:0;
    padding:0;
}

#colonneDroite #espaceAbo ul li{
    margin:15px 0 0;
    padding:0 0 0 15px;
    font-size:16px;
}

#colonneDroite #espaceAbo ul li a{
    color:#000;
}

#colonneDroite #espaceAbo ul li a:hover{
    text-decoration:underline;
}

/* =========================================================
   TABLEAUX / FIL ARIANE HISTORIQUES
   ========================================================= */

table{
    width:100%;
    margin:6px 0 0;
    border-collapse:collapse;
    font-size:16px;
}

table tr:hover{
    background-color:#dbdbdb;
}

table tr td{
    height:35px;
    vertical-align:middle;
    border-bottom:1px solid #ececec;
    border-left:10px solid #fff;
}

table tr td:first-child{
    border-left:0;
}

#filAriane{
    list-style:none;
    margin:0;
    padding:0;
    color:#000;
    font-size:0;
}

#filAriane li{
    display:inline;
    margin:0 0 0 10px;
    padding:0 0 0 15px;
    font-size:14px;
}

#filAriane li:first-child{
    margin:0;
    padding:0;
}

#filAriane li a{
    color:#000;
}

#filAriane li a:hover{
    text-decoration:underline;
}

#pagination{
    margin:15px 0 0;
    text-align:center;
    font-size:16px;
    color:#1f1f1f;
}

/* =========================================================
   FOOTER
   ========================================================= */

.footer{
    clear:both;
    background-color:#000;
}

.footer .contentFooter{
    width:98.40764%;
    max-width:1256px;
    margin:0 auto;
    padding:20px 0;
    color:#fff;
}

.footer .contentFooter:before,
.footer .contentFooter:after{
    content:" ";
    display:table;
}

.footer .contentFooter:after{
    clear:both;
}

.footer .contentFooter .contentReseaux{
    width:16.71975%;
    float:left;
    margin:0;
    padding:0;
}

.footer .contentFooter .contentReseaux p{
    margin:0 0 15px;
    font-size:14px;
}

.footer .contentFooter .contentReseaux a{
    padding-right:12.5%;
}

.footer .contentFooter .descriptionFooter{
    width:27.86624%;
    float:left;
    margin:0 0 0 2.38854%;
    padding:0 0 0 15.92357%;
    border-left:1px solid #b0b0b0;
    font-size:14px;
}

.footer .contentFooter .descriptionFooter p{
    margin:5px 0 0;
}

.footer .contentFooter .descriptionFooter p.titreDescriFooter{
    margin:20px 0 0;
    font-weight:700;
}

.footer .contentFooter .descriptionFooter p.titreDescriFooter:first-child{
    margin:0;
}

.footer .contentFooter .linkFooter,
.footer .contentFooter .linkFooter2{
    width:12.73885%;
    float:left;
    margin:0 0 0 2.38854%;
    padding:15px 0 15px 1.59236%;
    border-left:1px solid #b0b0b0;
    list-style:none;
}

.footer .contentFooter .linkFooter li,
.footer .contentFooter .linkFooter2 li{
    margin:10px 0 0;
    padding:0 0 0 10px;
}

.footer .contentFooter .linkFooter li:first-child,
.footer .contentFooter .linkFooter2 li:first-child{
    margin:0;
}

.footer .contentFooter .linkFooter2{
    width:15.92357%;
    padding-top:22px;
}

/* =========================================================
   LAYOUT MODERNE COMMUN
   ========================================================= */

.page-shell,
.home-shell{
    width:100%;
    max-width:1600px;
    margin:20px auto 40px;
    padding:0 24px;
    display:grid;
    grid-template-columns:minmax(0,1fr) 320px;
    gap:28px;
    box-sizing:border-box;
}

.main-column,
.side-column{
    min-width:0;
}

.content-card{
    margin:20px 0;
    padding:20px;
    border:1px solid var(--line);
    border-radius:20px;
    background:#fff;
}

.content-card h2{
    margin:0 0 12px;
    font-size:30px;
}

.content-card p{
    margin:0 0 12px;
    font-size:17px;
    line-height:1.7;
}

.content-card ul{
    margin:12px 0 0 20px;
}

.content-card li{
    margin:8px 0;
    line-height:1.6;
}

.sidebar-card{
    border:1px solid var(--line);
    border-radius:18px;
    background:#fff;
    padding:16px;
    margin-bottom:16px;
    box-shadow:var(--shadow);
}

.sidebar-card h2{
    margin:0 0 12px;
    font-size:20px;
}

.sidebar-card ul{
    margin:0;
    padding:0;
    list-style:none;
}

.sidebar-card li{
    padding:7px 0;
    border-bottom:1px solid #f1f1f1;
}

.sidebar-card li:last-child{
    border-bottom:0;
}

.sidebar-card a{
    color:var(--text);
    font-weight:600;
}

.mini-note,
.side-note{
    margin:0;
    font-size:14px;
    line-height:1.6;
    color:var(--muted);
}

/* =========================================================
   BOUTONS MODERNES
   ========================================================= */

.home-btn,
.home-btn-secondary,
.btn-primary,
.btn-secondary{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    text-decoration:none;
    font-weight:700;
}

.home-btn,
.home-btn-secondary{
    min-height:44px;
    padding:0 18px;
    border-radius:12px;
}

.home-btn{
    border:0;
    background:var(--primary);
    color:#fff;
    cursor:pointer;
}

.home-btn-secondary{
    background:#fff;
    color:var(--primary-dark);
    border:1px solid var(--line);
}

.btn-primary,
.btn-secondary{
    min-height:36px;
    padding:0 12px;
    border-radius:10px;
    font-size:13px;
    color:#fff;
}

.btn-primary{
    background:var(--primary);
    border:0;
}

.btn-secondary,
.product-actions .btn-secondary{
    background:var(--primary-dark) !important;
    border:0 !important;
    color:#fff !important;
}

/* =========================================================
   HOME / PAGE D'ACCUEIL
   ========================================================= */

.hero-home{
    padding:28px;
    border:1px solid var(--line);
    border-radius:24px;
    background:linear-gradient(180deg,#fff,#f8fbff);
    box-shadow:var(--shadow);
}

.hero-home h1{
    margin:0 0 12px;
    font-size:42px;
    line-height:1.12;
}

.hero-home p{
    margin:0 0 12px;
    font-size:18px;
    line-height:1.7;
    color:var(--text);
}

.hero-badges{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin:18px 0 0;
    padding:0;
    list-style:none;
}

.hero-badges li{
    background:#fff;
    border:1px solid #d8e5f3;
    border-radius:999px;
    padding:8px 14px;
    font-size:14px;
    font-weight:700;
}

.hero-search-box{
    margin-top:24px;
    padding:18px;
    background:#fff;
    border:1px solid var(--line);
    border-radius:18px;
}

.hero-search-grid{
    display:grid;
    grid-template-columns:200px 260px 1fr;
    gap:12px;
    align-items:end;
}

.hero-search-field label{
    display:block;
    margin-bottom:6px;
    font-weight:700;
    font-size:14px;
}

.hero-search-field select,
.hero-search-field input[type="text"]{
    width:100%;
    height:46px;
    padding:0 12px;
    border:1px solid var(--line);
    border-radius:10px;
    background:#fff;
    color:var(--text);
}

.hero-search-actions{
    margin-top:14px;
    display:flex;
    gap:10px;
    flex-wrap:wrap;
}

.grid3,
.grid4,
.guidesGrid{
    display:grid;
    gap:18px;
}

.grid3{
    grid-template-columns:repeat(3,1fr);
}

.grid4{
    grid-template-columns:repeat(4,1fr);
}

.guidesGrid{
    grid-template-columns:1fr;
}

.cardBox,
.guideCard,
.cardProductHome{
    background:#fff;
    border:1px solid var(--line);
    border-radius:16px;
    overflow:hidden;
    transition:transform .2s ease, box-shadow .2s ease;
}

.cardBox:hover,
.guideCard:hover,
.cardProductHome:hover{
    transform:translateY(-2px);
    box-shadow:0 10px 24px rgba(0,0,0,.08);
}

.cardBox{
    padding:18px;
}

.cardBox h3,
.cardProductHomeBody h3,
.guideCard h3{
    margin:0 0 10px;
    font-size:24px;
    line-height:1.3;
}

.cardBox p,
.cardProductHomeBody p,
.guideCard p{
    margin:0 0 12px;
    font-size:16px;
    line-height:1.65;
}

.cardProductHome a{
    display:block;
    color:inherit;
    height:100%;
}

.cardProductHomeImg{
    margin:0;
}

.cardProductHomeImg img{
    display:block;
    width:100%;
    height:170px;
    object-fit:cover;
}

.cardProductHomeBody{
    padding:16px;
}

.cardProductHomeCta,
.guideCard .cta,
.cardBox a{
    display:inline-block;
    font-weight:700;
    color:#1f6fb2;
}

.guideCard a{
    display:grid;
    grid-template-columns:1fr 225px;
    gap:18px;
    color:inherit;
    padding:16px;
}

.guideCard figure{
    margin:0;
}

.guideCard img{
    display:block;
    width:225px;
    height:126px;
    object-fit:cover;
    border-radius:8px;
}

.quickLinkList{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:10px 20px;
    margin:16px 0 0;
    padding:0;
    list-style:none;
}

.quickLinkList a{
    font-weight:700;
    color:#1f6fb2;
}

.brand-list{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
}

.brand-list a{
    padding:6px 10px;
    border-radius:999px;
    background:#f3f4f6;
    color:#374151;
    font-size:13px;
    font-weight:700;
}

/* =========================================================
   TABLEAUX MODERNES
   ========================================================= */

.table-compare{
    width:100%;
    border-collapse:collapse;
    margin-top:14px;
    background:#fff;
    border:1px solid var(--line);
    border-radius:14px;
    overflow:hidden;
}

.table-compare th,
.table-compare td{
    padding:14px;
    text-align:left;
    border-bottom:1px solid var(--line);
    vertical-align:top;
}

.table-compare th{
    background:#f8fafc;
    font-size:15px;
}

.table-compare tr:last-child td{
    border-bottom:0;
}

/* =========================================================
   GRILLE PRODUITS MODERNE
   ========================================================= */

.product-cache-shell{
    width:100%;
}

.product-cache-shell .page-wide{
    width:100%;
    max-width:none;
    margin:0;
    padding:0;
}

.product-cache-shell .products-grid{
    width:100%;
}

.products-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:18px;
    margin-top:18px;
}

.product-card{
    background:#fff;
    border:1px solid var(--line);
    border-radius:18px;
    overflow:hidden;
    transition:transform .2s ease, box-shadow .2s ease;
    box-shadow:var(--shadow);
}

.product-card:hover{
    transform:translateY(-2px);
    box-shadow:0 10px 24px rgba(0,0,0,.08);
}

.product-image-wrap{
    display:block;
    background:#fff;
    padding:16px;
    border-bottom:1px solid var(--line);
}

.product-image-wrap img{
    display:block;
    width:100%;
    height:230px;
    object-fit:contain;
}

.product-body{
    padding:16px;
}

.product-badge{
    display:inline-block;
    margin-bottom:10px;
    padding:6px 10px;
    border-radius:999px;
    background:#f3f4f6;
    color:#374151;
    font-size:12px;
    font-weight:700;
}

.product-price{
    font-size:24px;
    font-weight:800;
    color:var(--primary);
    margin-bottom:10px;
}

.product-title{
    display:block;
    color:var(--text);
    font-size:17px;
    line-height:1.45;
    font-weight:700;
    margin-bottom:10px;
}

.product-desc{
    font-size:14px;
    line-height:1.6;
    color:var(--muted);
    margin-bottom:12px;
    min-height:68px;
}

.product-meta{
    font-size:13px;
    line-height:1.5;
    color:#4b5563;
    margin-bottom:14px;
}

.product-actions{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
}

.products-more{
    margin-top:18px;
    display:flex;
    justify-content:flex-end;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */

@media (max-width:1200px){
    .grid4{
        grid-template-columns:repeat(2,1fr);
    }

    .hero-search-grid{
        grid-template-columns:1fr 1fr;
    }

    .page-shell,
    .home-shell{
        grid-template-columns:1fr;
    }

    .products-grid{
        grid-template-columns:repeat(3,1fr);
    }
}

@media (max-width:1024px){
    .contenuPage{
        width:100%;
        float:none;
    }

    .contenuPrincipal #colonneDroite{
        width:100%;
        float:none;
        margin:40px 0 0;
    }
}

@media (max-width:980px){
    .grid3,
    .quickLinkList{
        grid-template-columns:1fr;
    }

    .guideCard a{
        grid-template-columns:1fr;
    }

    .guideCard img{
        width:100%;
        height:auto;
    }
}

@media (max-width:900px){
    .products-grid{
        grid-template-columns:repeat(2,1fr);
    }
}

@media (max-width:768px){
    .search-shell-banner,
    .th-topbar{
        flex-direction:column;
        align-items:stretch !important;
        gap:8px !important;
        padding:8px 24px !important;
        width:100%;
        box-sizing:border-box !important;
    }

    .titre,
    .logo-1000achat,
    .th-logo{
        text-align:center !important;
        font-size:30px !important;
    }

    .search-form-banner,
    .th-search{
        width:100% !important;
    }

    .footer .contentFooter .descriptionFooter,
    .footer .contentFooter .linkFooter,
    .footer .contentFooter .linkFooter2{
        display:none;
    }

    .footer .contentFooter .contentReseaux{
        width:100%;
        float:none;
        text-align:center;
    }

    .footer .contentFooter .contentReseaux p{
        display:none;
    }

    .footer .contentFooter .contentReseaux a{
        padding:0 15px;
    }
}

@media (max-width:700px){
    .hero-search-grid{
        grid-template-columns:1fr;
    }

    .hero-home h1{
        font-size:32px;
    }

    .grid4{
        grid-template-columns:1fr;
    }
}

@media (max-width:640px){
    .products-grid{
        grid-template-columns:1fr;
    }
}

@media (max-width:480px){
    .titreType2{
        font-size:22px;
    }

    .titreType4{
        margin:0;
        font-size:20px;
    }

    #header .navExterne ul li a,
    #header .navPrincipale .listNavPrinc > li > a,
    .navExterne ul li a,
    .navPrincipale .listNavPrinc > li > a,
    .th-nav-externe a,
    .th-nav-main a{
        padding-left:10px !important;
        padding-right:10px !important;
    }
}
.side-column img{
    max-height:50px;
    width:auto;
    object-fit:contain;
}
  .hero-home{
            padding:32px;
            border:1px solid var(--line);
            border-radius:24px;
            background:linear-gradient(180deg,#fff,var(--bg-soft));
            box-shadow:var(--shadow);
        }

        .hero-home h1{
            margin:0 0 14px;
            font-size:42px;
            line-height:1.12;
        }

        .hero-home p{
            margin:0 0 12px;
            font-size:18px;
            line-height:1.75;
            color:var(--text);
        }

        .hero-badges{
            display:flex;
            flex-wrap:wrap;
            gap:10px;
            margin:18px 0 0;
            padding:0;
            list-style:none;
        }

        .hero-badges li{
            background:#fff;
            border:1px solid #d8e5f3;
            border-radius:999px;
            padding:8px 14px;
            font-size:14px;
            font-weight:700;
        }

        .hero-actions{
            margin-top:22px;
            display:flex;
            gap:10px;
            flex-wrap:wrap;
        }

        .content-card h2{
            margin:0 0 12px;
            font-size:31px;
            line-height:1.2;
        }

        .content-card h3{
            margin:18px 0 8px;
            font-size:22px;
            line-height:1.3;
        }

        .content-card p{
            margin:0 0 12px;
            font-size:17px;
            line-height:1.75;
        }

        .product-cache-shell{
            margin-top:18px;
        }

        .product-cache-shell .page-wide{
            width:100%;
            max-width:none;
            margin:0;
        }

        .products-grid{
            display:grid;
            grid-template-columns:repeat(4,1fr);
            gap:18px;
            align-items:stretch;
        }

        .product-card{
            display:flex;
            flex-direction:column;
            height:100%;
            border:1px solid var(--line);
            border-radius:18px;
            overflow:hidden;
            background:#fff;
            box-shadow:0 4px 12px rgba(0,0,0,.05);
            transition:transform .2s ease, box-shadow .2s ease;
        }

        .product-card:hover{
            transform:translateY(-2px);
            box-shadow:0 10px 24px rgba(0,0,0,.08);
        }

        .product-image-wrap{
            aspect-ratio:4/3;
            display:flex;
            align-items:center;
            justify-content:center;
            padding:14px;
            background:#fff;
            border-bottom:1px solid var(--line);
        }

        .product-image-wrap img{
            max-width:100%;
            max-height:220px;
            object-fit:contain;
            display:block;
        }

        .product-body{
            padding:14px;
            display:flex;
            flex-direction:column;
            gap:10px;
            flex:1;
        }

        .product-price{
            font-size:24px;
            font-weight:800;
            color:#990099;
            line-height:1.1;
        }

        .product-title{
            font-size:15px;
            font-weight:700;
            color:var(--text);
            line-height:1.35;
            min-height:40px;
            display:-webkit-box;
            -webkit-line-clamp:2;
            -webkit-box-orient:vertical;
            overflow:hidden;
        }

        .product-desc{
            font-size:13px;
            color:var(--muted);
            line-height:1.45;
            min-height:56px;
            display:-webkit-box;
            -webkit-line-clamp:3;
            -webkit-box-orient:vertical;
            overflow:hidden;
        }

        .product-meta-mini{
            font-size:12px;
            color:var(--muted);
            margin-top:auto;
            min-height:18px;
        }

        .product-actions-mini{
            display:flex;
            gap:8px;
            flex-wrap:nowrap;
            margin-top:10px;
        }

        .product-actions-mini a{
            flex:1;
            min-height:40px;
            display:inline-flex;
            align-items:center;
            justify-content:center;
            text-align:center;
            white-space:nowrap;
            padding:0 12px;
            border-radius:10px;
            font-size:13px;
            font-weight:700;
        }

        @media (max-width:900px){
            .products-grid{
                grid-template-columns:repeat(2,1fr);
            }
        }

        @media (max-width:700px){
            .hero-home{
                padding:24px;
            }

            .hero-home h1{
                font-size:32px;
            }

            .content-card{
                padding:18px;
            }

            .table-compare th,
            .table-compare td{
                padding:10px;
                font-size:14px;
            }

            .product-image-wrap img{
                height:200px;
            }
        }

        @media (max-width:640px){
            .products-grid{
                grid-template-columns:1fr;
            }

            .product-actions-mini{
                flex-direction:column;
            }
        }

