/* =================================================
   PATTERN ALVÉOLE (honeycomb)
   ================================================= */
.pattern-alveole{position:relative;isolation:isolate}
.pattern-alveole{--pattern-s:15px;--pattern-c1:#0F182e50;--pattern-c2:transparent}
.pattern-alveole::before{content:'';position:absolute;inset:0;z-index:-1;pointer-events:none;--c:#0000,var(--pattern-c1) .5deg 119.5deg,#0000 120deg;--g1:conic-gradient(from 60deg at 56.25% calc(425%/6),var(--c));--g2:conic-gradient(from 180deg at 43.75% calc(425%/6),var(--c));--g3:conic-gradient(from -60deg at 50% calc(175%/12),var(--c));background:var(--g1),var(--g1) var(--pattern-s) calc(1.73*var(--pattern-s)),var(--g2),var(--g2) var(--pattern-s) calc(1.73*var(--pattern-s)),var(--g3) var(--pattern-s) 0,var(--g3) 0 calc(1.73*var(--pattern-s)) var(--pattern-c2);background-size:calc(2*var(--pattern-s)) calc(3.46*var(--pattern-s))}

/* =================================================
   HERO
   ================================================= */
.hero{position:relative;align-content:center;height:calc(100vh - 70px);color:var(--blanc);overflow-x:hidden;width:100%}
@media (max-width:1023px){.hero{height:calc(100vh - 60px)}}
.hero .wp-block-term-description,.hero .wp-block-term-description p,.hero .lead{line-height:1.6;margin-bottom:2rem}
.hero-ctas{display:flex;gap:1rem;align-items:center}
.hero-visual{display:flex;max-height:85%;}
.hero-visual img,.hero-visual video{object-fit:contain}
@media (max-width:1024px){.hero-frontpage-container{grid-template-rows:40% 45%;height:100%}}
@media (max-width:768px){.hero-ctas{display:inline-block}}

/* =================================================
   CARROUSEL LOGOS CLIENTS
   ================================================= */
@keyframes scroll{from{transform:translateX(-33.33%)}to{transform:translateX(-66.66%)}}
.clients-logos{display:flex;width:max-content}
.clients-logos .logo-item{display:flex;align-items:center;justify-content:center;width:100px;flex-shrink:0;margin-right:6.5rem}
.clients-logos .logo-item img{max-width:100%;max-height:100%;object-fit:contain}
.hero .clients-logos .logo-item img{filter:invert(1)}
@media (max-width:768px){.clients-logos .logo-item{margin-right:2rem}}

/* =================================================
   3 SOLUTIONS (CARDS)
   ================================================= */
.solutions-grid-wrap{position:relative;margin-top:var(--s-6);overflow:visible}
.solutions-connector{position:absolute;left:50%;top:calc(2.5rem + 175px / 2);transform:translate(-50%,-50%);width:calc(100% + 6rem);height:6px;background:var(--gris-fonce);z-index:0;border-radius:3px;pointer-events:none}
.solutions-grid-wrap{--solutions-progress:0}
.solutions-connector-fill{position:absolute;left:0;top:0;height:100%;width:calc(var(--solutions-progress,0) * 100%);background:var(--bleu-principal);border-radius:3px;z-index:0}
.solutions-connector-start,.solutions-connector-end{position:absolute;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;font-size:2.5rem;line-height:1;z-index:1}
.solutions-connector-start{left:0;color:var(--bleu-principal)}
.solutions-connector-end{right:0;left:auto;transform:translate(50%,-50%);color:color-mix(in srgb,var(--gris-fonce) calc((1 - clamp(0,calc((var(--solutions-progress,0) - 0.995) / 0.005),1)) * 100%),var(--bleu-principal) calc(clamp(0,calc((var(--solutions-progress,0) - 0.995) / 0.005),1) * 100%))}
.solutions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-6);position:relative;z-index:1}
.solution-card{position:relative;overflow:visible;background:var(--gris);padding:3rem;align-content:center;backface-visibility:hidden;transform:translateZ(0);-webkit-font-smoothing:subpixel-antialiased;text-decoration:none;color:inherit;display:block;cursor:pointer;border-radius:8px}
.solution-card::before{content:'';position:absolute;inset:-30px;z-index:-1;background:radial-gradient(ellipse 70% 50% at 50% 50%,rgba(15,24,46,.08) 0%,transparent 70%);filter:blur(50px);opacity:0;pointer-events:none;transition:opacity .65s cubic-bezier(.4,0,.2,1)}
.solutions-grid-wrap .solution-card:nth-child(1)::before{opacity:clamp(0,calc((var(--solutions-progress,0) - 0.1) / 0.2),1)}
.solutions-grid-wrap .solution-card:nth-child(2)::before{opacity:clamp(0,calc((var(--solutions-progress,0) - 0.28) / 0.2),1)}
.solutions-grid-wrap .solution-card:nth-child(3)::before{opacity:clamp(0,calc((var(--solutions-progress,0) - 0.46) / 0.2),1)}
@media (hover:hover) and (pointer:fine){.solution-card{transition:transform 0.18s ease,box-shadow 0.18s ease,background 0.18s ease}}
.solution-card:hover{transform:translateY(-4px)}
.solution-card-icon{margin-bottom:var(--s-5);display:flex;justify-content:center;align-items:center;min-height:175px}
.solution-card-icon img{width:175px;height:175px;object-fit:contain;display:block}
.solution-card .bouton-bleu{width:100%;padding:12px 0}
.solution-card h3{font-size:1.5rem;text-align:center}
.solution-card p{text-align:center}
.solution-features li{padding:.4rem 0;display:flex;align-items:center;gap:.5rem;justify-content:center}
.solution-features svg,.solution-features .ph{width:16px;height:16px;flex-shrink:0;font-size:16px}
.solution-features--etiquette svg,.solution-features--etiquette .ph{color:var(--bleu-etiquette);fill:var(--bleu-etiquette)}
.solution-features--imprimante svg,.solution-features--imprimante .ph{color:var(--bleu-imprimante);fill:var(--bleu-imprimante)}
.solution-features--etiqueteuse svg,.solution-features--etiqueteuse .ph{color:var(--bleu-etiqueteuse);fill:var(--bleu-etiqueteuse)}

.solution-card--etiquette {box-shadow:none}
.solution-card--imprimante {box-shadow:none}
.solution-card--etiqueteuse {box-shadow:none}
.solution-card--etiquette:hover{box-shadow:0 4px 12px rgba(0,0,0,0.08),0 0 20px color-mix(in srgb,var(--bleu-etiquette) 25%,transparent)}
.solution-card--etiquette.active{transform:translateY(-6px);box-shadow:0 8px 24px rgba(0,0,0,0.12),0 0 30px color-mix(in srgb,var(--bleu-etiquette) 35%,transparent);background:color-mix(in srgb,var(--bleu-etiquette) 2%,var(--gris))}
.solution-card--imprimante:hover{box-shadow:0 4px 12px rgba(0,0,0,0.08),0 0 20px color-mix(in srgb,var(--bleu-imprimante) 25%,transparent)}
.solution-card--imprimante.active{transform:translateY(-6px);box-shadow:0 8px 24px rgba(0,0,0,0.12),0 0 30px color-mix(in srgb,var(--bleu-imprimante) 35%,transparent);background:color-mix(in srgb,var(--bleu-imprimante) 2%,var(--gris))}
.solution-card--etiqueteuse:hover{box-shadow:0 4px 12px rgba(0,0,0,0.08),0 0 20px color-mix(in srgb,var(--bleu-etiqueteuse) 25%,transparent)}
.solution-card--etiqueteuse.active{transform:translateY(-6px);box-shadow:0 8px 24px rgba(0,0,0,0.12),0 0 30px color-mix(in srgb,var(--bleu-etiqueteuse) 35%,transparent);background:color-mix(in srgb,var(--bleu-etiqueteuse) 2%,var(--gris))}

@media (max-width:1024px){.solution-card::before{filter:blur(35px);inset:-20px}}
@media (max-width:899px){.solutions-grid{grid-template-columns:1fr}.solutions-connector{left:50%;top:50%;transform:translate(-50%,-50%);width:6px;height:calc(100% + 6rem)}.solutions-connector-fill{width:100%;height:calc(var(--solutions-progress,0) * 100%);top:0;left:0}.solutions-connector-start{top:0;left:50%;transform:translate(-50%,-50%);color:var(--bleu-principal)}.solutions-connector-end{bottom:0;top:auto;left:50%;transform:translate(-50%,50%);color:color-mix(in srgb,var(--gris-fonce) calc((1 - clamp(0,calc((var(--solutions-progress,0) - 0.995) / 0.005),1)) * 100%),var(--bleu-principal) calc(clamp(0,calc((var(--solutions-progress,0) - 0.995) / 0.005),1) * 100%))}.solution-card::before{display:none}}

/* =================================================
   SECTEURS SLIDER (Style MR MARVIS)
   ================================================= */
.section-header--with-nav{display:flex;justify-content:space-between;align-items:flex-end;gap:var(--s-4)}
.sectors-nav{display:flex;gap:var(--s-2)}
.sectors-nav__btn{width:44px;height:44px;border-radius:50%;border:1px solid var(--gris);background:var(--blanc);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:var(--text)}
.sectors-nav__btn:hover{background:var(--bleu-principal);border-color:var(--bleu-principal);color:var(--blanc)}
.sectors-slider{overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;padding:var(--s-6) 0 var(--s-8);margin-top:var(--s-4)}
.sectors-slider::-webkit-scrollbar{display:none}
.sectors-track{display:flex;gap:var(--s-5);padding-left:max(var(--s-6),calc((100vw - 1200px)/2 + var(--s-6)));padding-right:var(--s-6)}
.sector-item{flex:0 0 auto;width:220px;scroll-snap-align:start;text-decoration:none;color:inherit;transition:transform .2s ease}
.sector-item:hover{transform:translateY(-4px)}
.sector-item__image{width:100%;aspect-ratio:4/5;border-radius:8px;overflow:hidden;margin-bottom:var(--s-4);background:#f5f5f5}
.sector-item__image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}
.sector-item:hover .sector-item__image img{transform:scale(1.03)}
.sector-item__title{font-family:'Satoshi',sans-serif;font-size:var(--fs-h5);font-weight:600;margin:0 0 var(--s-2);color:var(--text);line-height:1.3}
.sector-item__desc{font-size:var(--fs-small);color:var(--muted);margin:0;line-height:1.5}
@media (max-width:768px){.section-header--with-nav{flex-direction:column;align-items:flex-start}.sectors-nav{align-self:flex-end}.sectors-track{padding-left:var(--s-4);gap:var(--s-4)}.sector-item{width:180px}}

/* =================================================
   FAQ (catégories)
   ================================================= */
.faq-section-category__inner{text-align:center;display:flex;flex-direction:column;align-items:center}
.faq-section-category .section-header{text-align:center}
.faq-section-category .section-header p{margin-left:auto;margin-right:auto}
.faq-list.product-accordions{max-width:700px;width:100%;margin: var(--s-6) 0;text-align:left}
.faq-list .product-accordion-content{padding-bottom:var(--s-5)}
.faq-list .accordion-inner,.faq-list .accordion-inner .prose,.faq-list .accordion-inner p{line-height:1.7;color:var(--muted)}
.faq-list .accordion-inner p{margin-bottom:var(--s-3)}
.faq-list .accordion-inner p:last-child{margin-bottom:0}
.faq-list .accordion-inner a{text-decoration:underline;color:var(--muted)}
.faq-list .accordion-inner a:hover{color:var(--text)}
.faq-cta{text-align:center;max-width:800px;margin-left:auto;margin-right:auto}
.faq-cta__title{margin:0 0 var(--s-1);font-size:var(--fs-body);color:var(--text)}
.faq-cta__subtitle{margin:0 0 var(--s-5);font-size:var(--fs-body);color:var(--muted);font-weight:400}
@media (max-width:768px){.faq-list .product-accordion-header{padding:var(--s-4) 0}}

.faq .faq-section{margin:60px 0}
.faq .faq-title{font-family:'Satoshi',sans-serif;font-size:var(--fs-h2);line-height:var(--lh-h2);font-weight:700;margin:0 0 30px;padding-bottom:10px}
.faq .faq-item{margin-bottom:38px}
.faq .faq-question{font-size:var(--fs-h3);line-height:var(--lh-h3);font-weight:600;margin:40px 0 10px;color:#212529}
.faq .faq-answer{font-size:clamp(1.125rem,.6vw + 1rem,1.5rem);line-height:1.7;color:#373737;margin-bottom:8px;}


/* =================================================
   CONTENT LAYOUT (EEAT & Articles)
   ================================================= */
.content-layout{display:grid;grid-template-columns:1fr 3fr;gap:var(--s-8);margin-top:var(--s-8)}
.content-nav{position:sticky;top:146px}
.content-nav nav ol{font-family:'Satoshi',sans-serif}
.content-nav nav li{margin-bottom:var(--s-5);width:100%}
.content-nav nav a{background:var(--gris);padding:.5rem}
.content-nav nav a.active{color:var(--blanc);background:var(--bleu-principal)}
.content-main h2{margin-top:var(--s-8);padding-top:var(--s-8);border-top:1px solid #e9ecef}
.content-main > h2:first-child,.content-main > *:first-child > h2:first-child,.content-main > .wp-block-post-content > h2:first-child{margin-top:0;padding-top:0;border-top:none}
.content-main ul,.content-main ol{list-style:revert;padding:revert}
.content-main p, .content-main li{color:var(--muted)}
.content-main a{text-decoration:underline}
.content-main a:hover{color:var(--text)}
@media (max-width:1024px){.content-layout{grid-template-columns:1fr;gap:var(--s-6)}.content-nav{position:static;margin-bottom:var(--s-4)}.content-nav nav ol{list-style:none;padding-left:0;display:flex;flex-wrap:wrap;gap:var(--s-3)}.content-nav nav li{margin-bottom:0}}

/* =================================================
   TABLEAU COMPARATIF
   ================================================= */
.table-responsive{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;font-family:'Satoshi',sans-serif;margin-top:var(--s-8)}
.table-responsive::-webkit-scrollbar{display:none}
.comparative-table{border-collapse:separate;table-layout:fixed;width:100%;border-spacing:0;border:none!important;font-family:inherit;color:#212529;background:transparent}
.comparative-table th,.comparative-table td{padding:15px;vertical-align:middle;white-space:normal;color:#212529;border-radius:0!important}
.col-feature-title{width:50%;min-width:200px;text-align:left;padding-left:24px}
.col-other{width:16.66%;min-width:120px;text-align:center;vertical-align:middle}
.col-other>div{font-size:1.4rem;color:#212529;text-align:center;font-family:inherit;display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1.18}
.col-other>div:first-child{font-weight:600}
.col-other>div:nth-child(2){font-weight:400}
.comparative-table th:nth-child(2),.comparative-table td:nth-child(2){border-left:1px solid #7dbd8b;border-right:1px solid #7dbd8b}
.comparative-table th:nth-child(2){border-top:1px solid #7dbd8b;border-top-left-radius:12px;border-top-right-radius:12px}
.comparative-table tbody tr:last-child td.blank-space:nth-child(2){border-bottom:1px solid #7dbd8b;border-bottom-left-radius:12px;border-bottom-right-radius:12px}
.comparative-table td.feature{background-color:#f7f7f7;padding-top:20px;padding-bottom:14px}
.feature-title h4{margin:0;font-size:1.15rem;font-weight:600;line-height:1.22;color:#212529}
.feature-title .feature-text{display:inline-flex;align-items:center;color:#212529;gap:.20em}
.feature-title .main-text{font-weight:600;color:#212529}
.feature-title .sub-text{font-weight:400;color:#212529}
.feature-text .main-text,.feature-text .sub-text,.col-other>div{font-family:inherit}
.brand-logo{max-height:60px;border-radius:8px;padding-top:10px}
.checkmark,.crossmark{width:22px;height:22px;display:block;margin:0 auto}
.entry-content tr td{border-top:none!important}
@media (max-width:1024px){.table-responsive{margin-top:var(--s-6)}.col-feature-title{width:46%}.col-other{width:27%}}
@media (max-width:768px){.table-responsive{overflow-x:scroll;margin-top:var(--s-5)}.comparative-table{table-layout:auto;width:max-content;min-width:600px}.comparative-table th,.comparative-table td{padding:12px}.brand-logo{max-height:26px}.feature-title h4{font-size:1rem}.feature-title{font-size:16px}.feature-text .main-text,.col-other>div:first-child{font-size:1rem}.feature-text .sub-text{display:none!important}}

/* =================================================
   GRILLE 4 ITEMS (Layout de base)
   ================================================= */
.grid-4items{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-6)}
@media (max-width:1024px){.grid-4items{grid-template-columns:repeat(2,1fr);gap:var(--s-5)}}
@media (max-width:768px){.grid-4items{grid-template-columns:1fr;gap:var(--s-4)}}

/* =================================================
   BANNER VALUES (Section bleue - principal)
   ================================================= */
.banner-values{padding:var(--s-4)}
.banner-values-item{display:flex;align-items:center}
.banner-values-item__icon{width:100px}
.banner-values-item__title{font-size:var(--fs-h5);font-weight:600;font-family:'Satoshi',sans-serif;margin:0}
.banner-values-item__text{font-size:var(--fs-body);margin:0}
@media (max-width:768px){.banner-values-item__icon{width:60px;height:60px}}

/* =================================================
   BANNER SERVICES (Section blanche avec liens)
   ================================================= */
.banner-services{padding:var(--s-8)!important}
.banner-services-item{display:flex;flex-direction:column;align-items:center;text-align:center;cursor:pointer;transition:transform .3s ease;text-decoration:none;color:inherit;padding:var(--s-4)}
.banner-services-item:hover{transform:translateY(-4px);color:inherit}
.banner-services-item img{transition:transform .3s ease}
.banner-services-item:hover img{transform:translate(0,-8px)}
.banner-services-item__icon{width:40%;max-width:80px;margin:0 auto var(--s-4);display:block}
.banner-services-item__title{font-size:var(--fs-h4);font-weight:600;font-family:'Satoshi',sans-serif;margin:0 0 var(--s-2)}
.banner-services-item__text{font-size:var(--fs-body);margin:0}
@media (max-width:768px){.banner-services-item__icon{width:60px;height:60px}}

/* =================================================
   ETIQUETAGE ITEMS (Cards avec liens)
   ================================================= */
.etiquetage-items__card{display:flex;flex-direction:column;align-items:center;text-align:center;cursor:pointer;transition:transform .3s ease;text-decoration:none;color:inherit;padding:var(--s-2)}
.etiquetage-items__card:hover{transform:translateY(-4px);color:inherit}
.etiquetage-items__card img{transition:transform .3s ease}
.etiquetage-items__card:hover img{transform:translate(0,-8px)}
.etiquetage-items__image{width:100%;max-width:200px;aspect-ratio:1;object-fit:contain;margin:0 auto var(--s-4);display:block}
.etiquetage-items__content{width:100%}
.etiquetage-items__title{font-size:var(--fs-h4);font-weight:600;font-family:'Satoshi',sans-serif;margin:0 0 var(--s-2);color:var(--text)}
.etiquetage-items__text{font-size:var(--fs-body);margin:0;color:var(--muted);line-height:1.6}
@media (max-width:768px){.etiquetage-items__image{max-width:150px}}

/* Bloc signaux page étiquetage (section-bleu) — pictos au-dessus, centré, pas de bordure */
.etiquetage-signals{display:grid;grid-template-columns:1fr;gap:var(--s-8);margin:0;padding:0;border:none}
.etiquetage-signal-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--s-2)}
.etiquetage-signal-item i{font-size:2.25rem;flex-shrink:0}
.etiquetage-signal-title{font-size:var(--fs-h5);font-weight:600;color:var(--blanc);line-height:1.3}
.etiquetage-signal-micro{font-size:var(--fs-body);color:rgba(255,255,255,.9);line-height:1.4}
.etiquetage-signals--etiquettes .etiquetage-signal-item i{color:var(--bleu-etiquette)}
.etiquetage-signals--imprimantes .etiquetage-signal-item i{color:var(--bleu-imprimante)}
.etiquetage-signals--etiqueteuses .etiquetage-signal-item i{color:var(--bleu-etiqueteuse)}

/* =================================================
   ACCORDÉONS ETIQUETAGE (section-bleu)
   ================================================= */
.section-bleu .product-accordions .product-accordion{border-bottom:none}
.section-bleu .product-accordion-header{width:auto;gap:1rem;padding:0 0 var(--s-4) var(--s-2);font-size:var(--fs-h4);color:var(--blanc)}
.section-bleu .accordion-icon{color:var(--blanc)}
.section-bleu .product-accordion-content{color:var(--blanc)}
.section-bleu .accordion-inner{color:var(--blanc)}
.section-bleu .accordion-inner p{color:var(--blanc)}
.section-bleu .accordion-inner h3{color:var(--blanc);font-size:var(--fs-h5);font-weight:600;margin:var(--s-5) 0 var(--s-3)}
.section-bleu .accordion-inner h3:first-child{margin-top:0}
.section-bleu .accordion-inner h4{color:var(--blanc)}
.section-bleu .accordion-inner strong{color:var(--blanc)}
.section-bleu .accordion-inner a{color:var(--blanc)}
.section-bleu .accordion-title{color:var(--blanc);margin:0;font-size:inherit;font-weight:inherit}
.section-bleu .accordion-title strong{color:var(--blanc);font-weight:600}

/* =================================================
   PARALLAXE HORIZONTALE AU SCROLL
   ================================================= */
.scroll-parallax{will-change:transform;position:absolute;top:0;left:0;z-index:2;transform:translate3d(0,0,0)}
.scroll-parallax[data-direction="right"]{transform:translate3d(100%,0,0)}
.scroll-parallax[data-direction="left"]{transform:translate3d(-100%,0,0)}
[data-parallax-section]{position:relative;overflow:visible !important}
.parallax-section,.parallax-section .container,.parallax-section [data-parallax-section]{overflow:visible !important}


/* =================================================
   TRUST SECTION
   ================================================= */
.ti-widget.ti-goog .ti-controls .ti-next, .ti-widget.ti-goog .ti-controls .ti-prev{background-color:var(--bleu-principal)!important}
.ti-widget.ti-goog .ti-controls .ti-next:before, .ti-widget.ti-goog .ti-controls .ti-prev:before{border-color:var(--blanc)!important}
.ti-widget.ti-goog .ti-controls .ti-next:hover, .ti-widget.ti-goog .ti-controls .ti-next:focus, .ti-widget.ti-goog .ti-controls .ti-prev:hover, .ti-widget.ti-goog .ti-controls .ti-prev:focus {background-color:var(--bleu-principal)!important;outline:none !important}

/* =================================================
   EXPERTISE ICONS (Entreprise)
   ================================================= */
.expertise-icons{gap:var(--s-4)}
.expertise-icon{aspect-ratio:1;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:transform .3s ease,box-shadow .3s ease}
.expertise-icon i{font-size:32px}
.expertise-icon:hover{box-shadow:0 4px 12px rgba(0,0,0,.15)}
@media (max-width:768px){.expertise-icons{grid-template-columns:repeat(2,1fr);gap:var(--s-3)}}