/*
Theme Name: Serre Ivoire
Theme URI: https://serreivoire.pro
Author: Serre Ivoire (avec Claude)
Author URI: https://serreivoire.pro
Description: Thème WordPress sur mesure pour Serre Ivoire. En-tête (méga-menu) + pied de page, et corps de page entièrement éditable dans l’éditeur WordPress (blocs HTML, codes courts, sections prêtes à l’emploi). Compatible WooCommerce. Couleurs de la Côte d’Ivoire.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: serreivoire
WC requires at least: 7.0
WC tested up to: 9.0
*/

:root{
  --orange:#F77F00; --orange-deep:#DE6E00;
  --green:#00A05A; --green-mid:#0B7A45;
  --green-deep:#0B5A38; --green-darker:#073D26;
  --leaf:#7CC243;
  --ivoire:#F6F4EC; --ivoire-2:#EFEDE2; --blanc:#FFFFFF;
  --ink:#13211A; --muted:#5B6A60;
  --line:#E2E1D5;
  --disp:"Bricolage Grotesque",Georgia,serif;
  --body:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
  --mono:"Spline Sans Mono",ui-monospace,monospace;
  --shadow:0 18px 50px -22px rgba(11,90,56,.35);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--ivoire);line-height:1.55;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.wrap{max-width:1240px;margin:0 auto;padding:0 28px}
.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--green);font-weight:500}
h1,h2,h3{font-family:var(--disp);line-height:1.04;letter-spacing:-.02em;font-weight:700}
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.95rem;padding:.85rem 1.5rem;border-radius:999px;transition:transform .25s,box-shadow .25s,background .25s}
.btn:focus-visible{outline:3px solid var(--orange);outline-offset:3px}
.btn-orange{background:var(--orange);color:#fff;box-shadow:0 10px 26px -10px rgba(247,127,0,.7)}
.btn-orange:hover{background:var(--orange-deep);transform:translateY(-2px)}
.btn-ghost{border:1.5px solid rgba(255,255,255,.45);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-outline{border:1.5px solid var(--green-deep);color:var(--green-deep)}
.btn-outline:hover{background:var(--green-deep);color:#fff}

/* TOP BAR */
.topbar{background:var(--green-darker);color:#dff0e6;font-size:.82rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:40px;gap:1rem}
.topbar .ti{display:flex;align-items:center;gap:.4rem;white-space:nowrap}
.topbar .left{display:flex;gap:1.4rem;overflow:hidden}
.topbar a:hover{color:#fff}
.topbar .wa{color:var(--leaf);font-weight:600}
@media(max-width:760px){.topbar .left .ti:nth-child(2){display:none}}

/* HEADER */
.site-header{position:sticky;top:0;z-index:60;background:rgba(246,244,236,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.site-header .wrap{display:flex;align-items:center;gap:1.5rem;height:74px}
.logo{display:flex;align-items:center;gap:.6rem;font-family:var(--disp);font-weight:800;font-size:1.3rem;letter-spacing:-.03em}
.logo .mark{width:34px;height:34px;flex:none}
.logo b{color:var(--green-deep)}.logo .o{color:var(--orange)}
.logo img,.logo .custom-logo{max-height:42px;width:auto !important;height:auto !important;object-fit:contain}
.main-nav{display:flex;align-items:center;gap:.3rem;margin-left:.5rem}
.main-nav a,.main-nav .navitem>button{font-size:.92rem;font-weight:600;color:var(--ink);padding:.55rem .8rem;border-radius:8px;display:inline-flex;align-items:center;gap:.3rem;transition:color .2s,background .2s}
.main-nav a:hover,.main-nav .navitem>button:hover{color:var(--green-deep);background:rgba(0,160,90,.08)}
.main-nav ul{list-style:none;display:flex;align-items:center;gap:.3rem;margin:0;padding:0}
.navitem{position:static}
.caret{width:9px;height:9px;transition:transform .3s}
.navitem.open .caret{transform:rotate(180deg)}
.actions{margin-left:auto;display:flex;align-items:center;gap:.4rem}
.iconbtn{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;color:var(--ink);position:relative;transition:background .2s}
.iconbtn:hover{background:rgba(0,160,90,.1)}
.iconbtn svg{width:20px;height:20px}
.cartcount{position:absolute;top:4px;right:4px;background:var(--orange);color:#fff;font-size:.62rem;font-weight:700;min-width:16px;height:16px;border-radius:9px;display:grid;place-items:center;padding:0 4px;font-family:var(--mono)}
.cartcount.bump{animation:bump .4s}
@keyframes bump{0%,100%{transform:scale(1)}40%{transform:scale(1.5)}}
.site-header .quote{margin-left:.3rem}
.burger{display:none}
@media(max-width:1080px){.main-nav,.site-header .quote{display:none}.burger{display:grid}}

/* MEGA MENU */
.mega{position:absolute;left:0;right:0;top:100%;background:var(--blanc);border-top:1px solid var(--line);box-shadow:0 30px 60px -20px rgba(11,90,56,.3);opacity:0;visibility:hidden;transform:translateY(-12px);transition:opacity .3s,transform .3s,visibility .3s;z-index:55}
.navitem.open .mega{opacity:1;visibility:visible;transform:translateY(0)}
.mega-inner{max-width:1240px;margin:0 auto;padding:30px 28px 34px;display:grid;grid-template-columns:repeat(4,1fr) 1.1fr;gap:26px}
.mega-col h4{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);margin-bottom:14px;font-weight:500}
.mega-prod{display:flex;align-items:center;gap:11px;padding:8px;border-radius:12px;margin:0 -8px;transition:background .2s;opacity:0;transform:translateY(8px)}
.navitem.open .mega-prod{animation:megain .45s forwards}
.mega-prod:hover{background:var(--ivoire)}
.mega-prod .thumb{width:50px;height:50px;border-radius:10px;flex:none;overflow:hidden;background:var(--ivoire-2);display:grid;place-items:center}
.mega-prod .thumb img,.mega-prod .thumb svg{width:100%;height:100%;object-fit:cover}
.mega-prod .pn{font-size:.86rem;font-weight:600;line-height:1.15;color:var(--ink)}
.mega-prod .pp{font-size:.78rem;color:var(--orange);font-family:var(--mono);font-weight:500}
.mega-prod .pp .amount{font-family:var(--mono)}
.mega-feat{background:linear-gradient(150deg,var(--green-deep),var(--green-darker));border-radius:18px;padding:22px;color:#fff;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.mega-feat .tag{font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--leaf)}
.mega-feat h5{font-family:var(--disp);font-size:1.45rem;line-height:1.05;margin:.4rem 0 .2rem}
.mega-feat p{font-size:.83rem;color:#cfe7d8;margin-bottom:1rem}
.mega-feat .promo{position:absolute;top:-30px;right:-30px;width:120px;height:120px;background:radial-gradient(circle,rgba(247,127,0,.5),transparent 70%)}
.mega-feat .btn{align-self:flex-start}
@keyframes megain{to{opacity:1;transform:translateY(0)}}

/* HERO */
.hero{position:relative;background:linear-gradient(165deg,var(--green-deep) 0%,var(--green-darker) 70%);color:#fff;overflow:hidden;padding:96px 0 110px}
.hero-arch{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.hero-grain{position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(60% 50% at 70% 30%,rgba(247,127,0,.16),transparent 60%)}
.hero .wrap{position:relative;z-index:3;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}
.hero-left{max-width:600px}
.hero .eyebrow{color:var(--leaf)}
.hero h1{font-size:clamp(2.6rem,5.2vw,4.3rem);margin:1rem 0 1.2rem;font-weight:800}
.hero h1 .hl{color:var(--orange);white-space:nowrap}
.hero p.lead{font-size:1.12rem;color:#d6e8dd;max-width:480px;margin-bottom:2rem}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap}
.reveal-load{opacity:0;transform:translateY(22px);animation:riseIn .9s cubic-bezier(.2,.7,.2,1) forwards}
.d1{animation-delay:.1s}.d2{animation-delay:.25s}.d3{animation-delay:.4s}.d4{animation-delay:.55s}.d5{animation-delay:.7s}
@keyframes riseIn{to{opacity:1;transform:translateY(0)}}
.hero-right{position:relative;z-index:3}
.spec-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:20px;padding:22px;backdrop-filter:blur(6px)}
.spec-card .sc-top{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem}
.spec-card .dot{width:9px;height:9px;border-radius:50%;background:var(--leaf);box-shadow:0 0 0 4px rgba(124,194,67,.2)}
.spec-card .sc-top span{font-family:var(--mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:#cfe7d8}
.spec-row{display:flex;justify-content:space-between;align-items:baseline;padding:.7rem 0;border-bottom:1px dashed rgba(255,255,255,.16)}
.spec-row:last-child{border-bottom:none}
.spec-row .k{font-size:.9rem;color:#cfe7d8}
.spec-row .v{font-family:var(--mono);font-weight:500;color:#fff}
@media(max-width:920px){.hero .wrap{grid-template-columns:1fr;gap:30px}.hero{padding:70px 0 80px}.hero-right{max-width:420px}}

/* STATS */
.stats{background:var(--ivoire);border-bottom:1px solid var(--line)}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:38px 28px}
.stat{text-align:center}
.stat .num{font-family:var(--disp);font-size:2.6rem;font-weight:800;color:var(--green-deep);line-height:1}
.stat .num .u{color:var(--orange)}
.stat .lab{font-size:.83rem;color:var(--muted);margin-top:.35rem}
@media(max-width:680px){.stats .wrap{grid-template-columns:1fr 1fr;gap:26px}}

/* SECTION SHELL */
.sec{padding:84px 0}
.sec-head{max-width:640px;margin-bottom:46px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(2rem,3.6vw,2.9rem);margin:.7rem 0 .6rem;color:var(--ink)}
.sec-head p{color:var(--muted);font-size:1.05rem}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:translateY(0)}

/* SERVICES */
.serv{background:var(--green-deep);color:#fff}
.serv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.12);border-radius:20px;overflow:hidden;margin-top:30px}
.serv-item{background:var(--green-deep);padding:30px 24px;transition:background .3s}
.serv-item:hover{background:var(--green-mid)}
.serv-item svg{width:30px;height:30px;color:var(--leaf);margin-bottom:14px}
.serv-item h3{font-size:1.18rem;margin-bottom:.4rem}
.serv-item p{font-size:.88rem;color:#cfe7d8}
@media(max-width:820px){.serv-grid{grid-template-columns:1fr 1fr}}

/* CATALOGUE */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.cat-card{background:var(--blanc);border:1px solid var(--line);border-radius:20px;overflow:hidden;transition:transform .35s,box-shadow .35s;display:flex;flex-direction:column}
.cat-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.cat-vis{aspect-ratio:4/3;background:linear-gradient(160deg,#eef3ec,#e2ecdf);position:relative;overflow:hidden}
.cat-vis svg,.cat-vis img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cat-tag{position:absolute;top:12px;left:12px;background:var(--green-deep);color:#fff;font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;padding:.3rem .65rem;border-radius:7px;z-index:2}
.cat-body{padding:18px 20px 22px;display:flex;flex-direction:column;gap:.5rem;flex:1}
.cat-body h3{font-size:1.22rem}
.cat-body p{font-size:.86rem;color:var(--muted);flex:1}
.cat-meta{font-family:var(--mono);font-size:.78rem;color:var(--green-deep)}
.cat-card .btn{margin-top:.4rem;align-self:flex-start;font-size:.85rem;padding:.6rem 1.1rem}
@media(max-width:980px){.cat-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.cat-grid{grid-template-columns:1fr}}

/* SHOP / PRODUCTS (also styles WooCommerce shop) */
.shop{background:var(--ivoire-2)}
.shop-grid,.woocommerce ul.products{display:grid !important;grid-template-columns:repeat(4,1fr);gap:22px;list-style:none;margin:0;padding:0}
.woocommerce ul.products li.product{width:auto !important;margin:0 !important;float:none !important}
.prod,.woocommerce ul.products li.product{background:var(--blanc);border:1px solid var(--line);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:transform .35s,box-shadow .35s;text-align:left}
.prod:hover,.woocommerce ul.products li.product:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.prod-vis{aspect-ratio:1;background:var(--ivoire);position:relative;overflow:hidden}
.prod-vis svg,.prod-vis img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s}
.prod:hover .prod-vis svg{transform:scale(1.07)}
.woocommerce ul.products li.product a img{margin:0;border-radius:0;transition:transform .5s}
.woocommerce ul.products li.product:hover a img{transform:scale(1.05)}
.badge{position:absolute;top:11px;left:11px;background:var(--orange);color:#fff;font-size:.66rem;font-weight:700;font-family:var(--mono);letter-spacing:.06em;padding:.28rem .55rem;border-radius:6px;z-index:2}
.badge.green{background:var(--green)}
.woocommerce span.onsale{background:var(--orange);color:#fff;border-radius:6px;font-family:var(--mono);font-size:.68rem;min-height:auto;min-width:auto;padding:.28rem .55rem;top:11px;left:11px;right:auto;margin:0}
.prod-body{padding:15px 16px 17px;display:flex;flex-direction:column;gap:.3rem;flex:1}
.woocommerce ul.products li.product .woocommerce-loop-product__link{padding:15px 16px 8px;display:block}
.prod-cat{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.prod-body h3,.woocommerce ul.products li.product h2,.woocommerce ul.products li.product .woocommerce-loop-product__title{font-size:1rem !important;font-weight:700;font-family:var(--body) !important;line-height:1.2;padding:0}
.prod-price{margin-top:auto;display:flex;align-items:baseline;gap:.4rem;padding-top:.5rem}
.prod-price .now,.woocommerce ul.products li.product .price{font-family:var(--mono) !important;font-weight:500;color:var(--green-deep) !important;font-size:1.05rem}
.woocommerce ul.products li.product .price{padding:0 16px}
.woocommerce ul.products li.product .price del{color:#aaa;font-weight:400}
.woocommerce ul.products li.product .price ins{text-decoration:none}
.prod-price .was{font-size:.8rem;color:#aaa;text-decoration:line-through}
.add{margin-top:.7rem;width:100%;justify-content:center;background:var(--ivoire-2);color:var(--green-deep);font-weight:600;font-size:.85rem;padding:.6rem;border-radius:10px;display:flex;align-items:center;gap:.4rem;transition:.25s}
.add:hover{background:var(--orange);color:#fff}
.add svg{width:16px;height:16px}
/* WooCommerce add-to-cart buttons on-brand */
.woocommerce a.button,.woocommerce button.button,.woocommerce ul.products li.product .button,.woocommerce #respond input#submit,.woocommerce input.button{background:var(--green-deep);color:#fff;border-radius:10px;font-weight:600;font-family:var(--body);transition:.25s;text-transform:none;letter-spacing:0}
.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce ul.products li.product .button:hover,.woocommerce input.button:hover{background:var(--orange);color:#fff}
.woocommerce ul.products li.product .button{margin:8px 16px 16px;display:block;text-align:center}
.woocommerce a.button.alt,.woocommerce button.button.alt,.woocommerce #respond input#submit.alt{background:var(--orange)}
.woocommerce a.button.alt:hover,.woocommerce button.button.alt:hover{background:var(--orange-deep)}
.woocommerce .woocommerce-message,.woocommerce .woocommerce-info{border-top-color:var(--green)}
.woocommerce .woocommerce-message::before,.woocommerce .woocommerce-info::before{color:var(--green)}
.woocommerce-store-notice,p.demo_store{background:var(--green-deep)}
.filters{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:34px}
.chip{font-size:.85rem;font-weight:600;padding:.55rem 1.1rem;border-radius:999px;background:var(--blanc);border:1px solid var(--line);color:var(--muted);transition:.2s}
.chip:hover{border-color:var(--green)}
.chip.active{background:var(--green-deep);color:#fff;border-color:var(--green-deep)}
@media(max-width:980px){.shop-grid,.woocommerce ul.products{grid-template-columns:1fr 1fr}}

/* WHY */
.why .wrap{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.why-vis{position:relative;border-radius:24px;overflow:hidden;aspect-ratio:1/1;background:linear-gradient(160deg,var(--green-deep),var(--green-darker))}
.why-vis svg{position:absolute;inset:0;width:100%;height:100%}
.why-list{display:flex;flex-direction:column;gap:18px;margin-top:26px}
.why-item{display:flex;gap:14px;align-items:flex-start}
.why-item .ic{width:42px;height:42px;border-radius:12px;background:rgba(0,160,90,.12);color:var(--green-deep);display:grid;place-items:center;flex:none}
.why-item .ic svg{width:21px;height:21px}
.why-item h3{font-size:1.1rem;margin-bottom:.15rem}
.why-item p{font-size:.9rem;color:var(--muted)}
@media(max-width:860px){.why .wrap{grid-template-columns:1fr}.why-vis{max-width:380px;order:-1}}

/* FORMATION band */
.formation{background:linear-gradient(165deg,var(--green-deep),var(--green-darker));color:#fff;text-align:center}
.formation .wrap{max-width:760px}
.formation h2{color:#fff;font-size:clamp(2rem,4vw,3rem);margin:.7rem 0 1rem}
.formation p{color:#d6e8dd;font-size:1.1rem;margin-bottom:2rem}

/* TESTIMONIALS */
.testi{background:var(--green-darker);color:#fff;overflow:hidden}
.testi-track{display:flex;gap:22px;margin-top:14px}
.tcard{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:26px;min-width:330px;flex:1}
.tcard .stars{color:var(--orange);font-size:1rem;letter-spacing:2px;margin-bottom:.8rem}
.tcard p{font-size:.98rem;color:#e7f2ec;margin-bottom:1.2rem}
.tcard .who{display:flex;align-items:center;gap:.7rem}
.tcard .av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--leaf));display:grid;place-items:center;font-weight:700;color:#fff;font-family:var(--disp)}
.tcard .who b{display:block;font-size:.9rem}
.tcard .who small{color:#9dbdaa;font-size:.78rem}
@media(max-width:820px){.testi-track{flex-direction:column}.tcard{min-width:0}}

/* CTA BAND */
.cta-band{padding:0 0 84px}
.cta-inner{background:linear-gradient(120deg,var(--orange),#ffa23d);border-radius:28px;padding:54px 44px;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;position:relative;overflow:hidden}
.cta-inner::after{content:"";position:absolute;right:-60px;top:-60px;width:260px;height:260px;border-radius:50%;background:rgba(255,255,255,.16)}
.cta-inner h2{color:#fff;font-size:clamp(1.7rem,3vw,2.4rem);max-width:560px;position:relative;z-index:2}
.cta-inner .btn{position:relative;z-index:2;background:var(--green-darker);color:#fff}
.cta-inner .btn:hover{background:#04321f}

/* FOOTER */
.site-footer{background:var(--green-darker);color:#bcd4c4;padding:64px 0 26px;font-size:.9rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.4fr;gap:36px}
.site-footer h4{color:#fff;font-family:var(--disp);font-size:1.05rem;margin-bottom:1rem}
.site-footer a{display:block;padding:.28rem 0;transition:color .2s}
.site-footer a:hover{color:var(--leaf)}
.site-footer ul{list-style:none;margin:0;padding:0}
.foot-logo{font-family:var(--disp);font-weight:800;font-size:1.4rem;color:#fff;margin-bottom:.8rem}
.foot-logo span{color:var(--orange)}
.newsl{display:flex;gap:.5rem;margin-top:.8rem}
.newsl input{flex:1;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:10px;padding:.7rem .9rem;color:#fff;font-family:inherit;font-size:.88rem}
.newsl input::placeholder{color:#8fb09e}
.newsl input:focus{outline:none;border-color:var(--leaf)}
.newsl button{background:var(--orange);color:#fff;border-radius:10px;padding:0 1rem;font-weight:600}
.foot-bot{margin-top:46px;padding-top:22px;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.82rem;color:#8fb09e}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}

/* TOAST + MODAL */
.toast{position:fixed;bottom:26px;left:50%;translate:-50% 120px;background:var(--green-deep);color:#fff;padding:.9rem 1.4rem;border-radius:14px;display:flex;align-items:center;gap:.6rem;font-weight:600;font-size:.92rem;box-shadow:var(--shadow);z-index:200;transition:translate .4s cubic-bezier(.2,.8,.2,1)}
.toast.show{translate:-50% 0}
.toast svg{width:20px;height:20px;color:var(--leaf)}
.modal-bg{position:fixed;inset:0;background:rgba(7,40,28,.55);backdrop-filter:blur(4px);z-index:150;opacity:0;visibility:hidden;transition:.3s;display:grid;place-items:center;padding:20px}
.modal-bg.show{opacity:1;visibility:visible}
.modal{background:var(--blanc);border-radius:22px;padding:34px;max-width:420px;width:100%;text-align:center;transform:scale(.92);transition:transform .35s}
.modal-bg.show .modal{transform:scale(1)}
.modal .mclose{position:absolute;top:18px;right:22px;font-size:1.6rem;color:var(--muted);line-height:1;background:none}
.modal h3{font-size:1.5rem;color:var(--ink);margin-bottom:.4rem}
.modal p{color:var(--muted);font-size:.92rem;margin-bottom:1.5rem}
.modal .chans{display:flex;flex-direction:column;gap:.7rem}
.chan{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:.95rem;border-radius:14px;font-weight:600;transition:.2s}
.chan.wa{background:#25D366;color:#fff}.chan.wa:hover{background:#1eb858}
.chan.em{background:var(--green-deep);color:#fff}.chan.em:hover{background:var(--green-darker)}

/* Generic WP content (pages, blog) */
.page-wrap{max-width:820px;margin:0 auto;padding:70px 28px}
.page-wrap h1{font-size:clamp(2rem,4vw,3rem);margin-bottom:1.2rem;color:var(--ink)}
.page-wrap h2{font-size:1.6rem;margin:1.6rem 0 .6rem}
.page-wrap p{margin-bottom:1rem;font-size:1.05rem}
.page-wrap a{color:var(--green-deep);text-decoration:underline}
.woocommerce-breadcrumb{font-family:var(--mono);font-size:.8rem;color:var(--muted)}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s !important;transition-duration:.05s !important}
  html{scroll-behavior:auto}
}

/* ---- Zone de contenu éditable (pages construites dans l'éditeur) ---- */
.si-page{padding:0}
/* texte et blocs standards : largeur lisible et centrée */
.si-page > *:not(section):not(.alignfull):not(.alignwide){
  max-width:1080px;margin-left:auto;margin-right:auto;padding-left:28px;padding-right:28px;
}
.si-page > *:first-child{margin-top:48px}
.si-page > *:last-child{margin-bottom:48px}
.si-page > .alignwide{max-width:1240px;margin-left:auto;margin-right:auto}
.si-page > .alignfull{max-width:none;padding-left:0;padding-right:0}
/* nos sections (codes courts) restent en pleine largeur, sans marge ajoutée */
.si-page > section{margin:0}
.si-page--full > *{max-width:none;padding-left:0;padding-right:0}
.si-page--full > *:not(section){padding-left:28px;padding-right:28px}

/* ---- Sous-catégories dans le méga-menu (familles d'irrigation, etc.) ---- */
.mega-sub{list-style:none;margin:0;padding:0}
.mega-sub li{margin:0}
.mega-sub a{display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:7px 10px;margin:0 -10px;border-radius:9px;font-size:.88rem;font-weight:600;
  color:var(--ink);transition:background .2s,color .2s}
.mega-sub a:hover{background:var(--ivoire);color:var(--green-deep)}
.mega-sub a span{font-family:var(--mono);font-size:.7rem;font-weight:500;color:#fff;
  background:var(--green);border-radius:20px;padding:1px 7px;min-width:20px;text-align:center}

/* ---- Bandeau promo / pub en haut (réglable dans le Personnalisateur) ---- */
.si-topbanner{padding:.55rem 0;font-size:.9rem;font-weight:600}
.si-topbanner .wrap{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap;text-align:center}
.si-topbanner--orange{background:linear-gradient(90deg,var(--orange),#ffa23d);color:#fff}
.si-topbanner--green{background:var(--green-deep);color:#fff}
.si-topbanner--darker{background:var(--green-darker);color:#fff}
.si-tb-btn{display:inline-block;background:#fff;color:var(--green-darker);border-radius:999px;padding:.35rem 1.05rem;font-weight:700;font-size:.82rem;transition:transform .2s}
.si-tb-btn:hover{transform:translateY(-1px)}
.si-topbanner img{display:inline-block;max-height:64px;width:auto}
.si-topbanner a{color:inherit;text-decoration:underline}
.si-topbanner a.si-tb-btn{text-decoration:none}

/* ---- Catalogue produits (sans WooCommerce) ---- */
.si-cat-tools{margin-bottom:18px}
.si-cat-search{width:100%;max-width:440px;padding:.8rem 1.1rem;border:1px solid var(--line);border-radius:999px;
  font-family:var(--body);font-size:.95rem;background:#fff;color:var(--ink);transition:border-color .2s,box-shadow .2s}
.si-cat-search:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px rgba(0,160,90,.12)}
.si-cat-grid .add{cursor:pointer}
.si-cat-empty{display:none;text-align:center;color:var(--muted);padding:34px;font-size:1rem}
.filters{max-height:none}
