/* ===========================================================================
   Aqualan Boutique — theme e-commerce aquariophilie (Ocean profond & corail)
   =========================================================================== */
:root{
  --ocean:#0A3D46; --ocean-deep:#072d35; --teal:#0E7C86; --teal-600:#0c6a73;
  --aqua:#19A8B8; --aqua-light:#37c2d4; --coral:#FF6F5E; --coral-600:#f4593f;
  --ink:#0E2A33; --text:#1b3a43; --muted:#5d7882; --line:#e7eeef;
  --sand:#FBF7F1; --sand-2:#F3ECE0; --card:#ffffff;
  --r:16px; --r-sm:11px; --r-lg:24px;
  --sh-sm:0 2px 8px rgba(10,45,53,.06); --sh:0 12px 30px rgba(10,45,53,.10);
  --sh-lg:0 22px 50px rgba(10,45,53,.16);
  --font-body:var(--font-body-set,"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif);
  --font-head:var(--font-head-set,"Poppins","Inter",system-ui,Arial,sans-serif);
  --header-h:74px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);color:var(--text);background:var(--sand);line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto}
a{color:var(--teal);text-decoration:none}
a:hover{color:var(--coral)}
h1,h2,h3,h4{font-family:var(--font-head);color:var(--ink);line-height:1.18;font-weight:800;margin:0 0 .5em}
.wrap{max-width:1180px;margin:0 auto;padding:0 1.25rem}
.section{padding:3.2rem 1.25rem}
.muted{color:var(--muted)}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-head);font-weight:700;font-size:.98rem;
  padding:.85rem 1.5rem;border-radius:999px;border:2px solid transparent;cursor:pointer;transition:transform .12s ease,box-shadow .2s ease,background .2s}
.btn:hover{transform:translateY(-2px)}
.btn-coral{background:var(--coral);color:#fff;box-shadow:0 10px 24px rgba(255,111,94,.34)}
.btn-coral:hover{background:var(--coral-600);color:#fff;box-shadow:0 14px 30px rgba(255,111,94,.42)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn-ghost:hover{background:rgba(255,255,255,.14);color:#fff;border-color:#fff}

/* ── Top bar ── */
.top-bar{background:linear-gradient(90deg,var(--ocean-deep),var(--teal));color:#dff3f5;font-size:.8rem}
.top-bar-inner{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.45rem 1.25rem;flex-wrap:wrap}
.tb-items{display:flex;gap:1.4rem;flex-wrap:wrap}
.tb-items span{display:inline-flex;align-items:center;gap:.35rem;opacity:.92}
.tb-items span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--coral)}
.tb-note{opacity:.7}
@media(max-width:760px){.tb-note{display:none}.tb-items{gap:1rem;font-size:.74rem}}

/* ── Header ── */
.site-header{position:sticky;top:0;z-index:1000;background:#fff;border-bottom:1px solid var(--line);transition:box-shadow .25s}
.site-header.scrolled{box-shadow:0 6px 22px rgba(10,45,53,.10)}
.header-inner{display:flex;align-items:center;gap:1rem;min-height:var(--header-h)}
.site-logo{display:flex;align-items:center;gap:.65rem;font-family:var(--font-head)}
.logo-mark,.logo-img{display:block;border-radius:10px}
.logo-img{max-height:46px;width:auto}
.logo-text{font-weight:800;font-size:1.3rem;color:var(--ocean);letter-spacing:-.01em;line-height:1.05;display:flex;flex-direction:column}
.logo-text small{font-weight:500;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--aqua)}
.nav-wrap{margin-left:auto}
.site-nav{display:flex;align-items:center;gap:.3rem;list-style:none;margin:0;padding:0}
.site-nav>li{position:relative}
.site-nav>li>a{display:block;padding:.6rem .85rem;color:var(--ink);font-weight:600;font-size:.95rem;border-radius:9px;transition:color .15s,background .15s}
.site-nav>li>a:hover,.site-nav>li.active>a{color:var(--teal);background:var(--sand-2)}
.site-nav .sub-menu{list-style:none;margin:0;padding:.4rem;position:absolute;top:calc(100% + 8px);left:0;min-width:210px;background:#fff;
  border:1px solid var(--line);border-radius:14px;box-shadow:var(--sh);opacity:0;visibility:hidden;transform:translateY(6px);transition:.18s;z-index:50}
.site-nav>li:hover>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.site-nav .sub-menu a{display:block;padding:.5rem .75rem;border-radius:8px;color:var(--text);font-size:.92rem}
.site-nav .sub-menu a:hover{background:var(--sand-2);color:var(--teal)}
.sub-toggle{display:none}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:.4rem;margin-right:.2rem}
.nav-toggle span{width:24px;height:2.5px;background:var(--ocean);border-radius:2px;transition:.2s}
.nav-overlay{display:none}

/* search */
.nav-search{position:relative;display:flex;align-items:center;margin-left:.4rem}
.nav-search-btn{background:var(--sand-2);border:0;color:var(--ocean);cursor:pointer;padding:.5rem;border-radius:10px;display:flex}
.nav-search-btn:hover{background:var(--aqua);color:#fff}
.nav-search-btn svg{width:20px;height:20px}
.nav-search-form{position:absolute;top:50%;right:calc(100% + .5rem);transform:translateY(-50%);display:none;gap:.4rem;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--sh-lg);padding:.5rem;z-index:200}
.nav-search.open .nav-search-form{display:flex}
.nav-search-form input{border:1px solid var(--line);border-radius:8px;padding:.55rem .7rem;width:230px;max-width:60vw;font:inherit}
.nav-search-form input:focus{outline:none;border-color:var(--aqua);box-shadow:0 0 0 3px rgba(25,168,184,.18)}
.nav-search-form button{background:var(--teal);color:#fff;border:0;border-radius:8px;padding:.4rem .8rem;font-weight:700;cursor:pointer}

/* ── Breadcrumb ── */
.breadcrumb-wrap{background:#fff;border-bottom:1px solid var(--line)}
.breadcrumb{display:flex;flex-wrap:wrap;align-items:center;gap:.45rem;padding:.7rem 1.25rem;font-size:.84rem;color:var(--muted)}
.breadcrumb a{color:var(--muted)}.breadcrumb a:hover{color:var(--coral)}
.breadcrumb .sep{color:var(--line)}
.breadcrumb .current{color:var(--ink);font-weight:600}

/* ── Hero (home) ── */
.hero{position:relative;background:
  radial-gradient(1100px 500px at 80% -10%,rgba(55,194,212,.45),transparent 60%),
  radial-gradient(800px 500px at 0% 110%,rgba(255,111,94,.30),transparent 55%),
  linear-gradient(135deg,var(--ocean-deep),var(--teal) 70%,var(--aqua));
  color:#fff;overflow:hidden}
.hero-inner{position:relative;z-index:2;padding:5rem 1.25rem 7rem;max-width:880px}
.hero-eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;font-weight:700;color:#bff0f6;margin:0 0 1rem}
.hero h1{color:#fff;font-size:clamp(2.2rem,5.4vw,3.7rem);margin:0 0 1rem;letter-spacing:-.02em}
.hero-sub{font-size:clamp(1.05rem,2.2vw,1.32rem);color:rgba(255,255,255,.92);max-width:640px;margin:0 0 2rem}
.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap}
.hero-wave{position:absolute;left:0;right:0;bottom:-1px;line-height:0;z-index:1}
.hero-wave svg{width:100%;height:90px;display:block}

/* ── Hero : barre de recherche produit ── */
.hero-search{display:flex;align-items:center;gap:.4rem;max-width:580px;background:#fff;border-radius:999px;padding:.45rem .45rem .45rem 1.15rem;box-shadow:0 20px 44px rgba(7,45,53,.30);border:1px solid rgba(255,255,255,.65)}
.hero-search:focus-within{box-shadow:0 20px 48px rgba(7,45,53,.36),0 0 0 3px rgba(25,168,184,.40)}
.hero-search-ic{display:flex;align-items:center;color:var(--teal);flex:0 0 auto}
.hero-search-ic svg{width:22px;height:22px}
.hero-search input{flex:1 1 auto;min-width:0;border:0;outline:0;background:none;font:inherit;font-size:1.02rem;color:var(--ink);padding:.6rem .25rem}
.hero-search input::placeholder{color:var(--muted)}
.hero-search-btn{flex:0 0 auto;display:inline-flex;align-items:center;gap:.4rem;background:var(--coral);color:#fff;border:0;border-radius:999px;padding:.72rem 1.45rem;font-family:var(--font-head);font-weight:700;font-size:.98rem;cursor:pointer;box-shadow:0 8px 20px rgba(255,111,94,.40);transition:background .2s,transform .12s,box-shadow .2s}
.hero-search-btn:hover{background:var(--coral-600);transform:translateY(-1px);box-shadow:0 12px 26px rgba(255,111,94,.50)}
.hero-search-hint{margin:.95rem 0 0;color:rgba(255,255,255,.82);font-size:.85rem}
@media(max-width:560px){
  .hero-search{border-radius:18px;flex-wrap:wrap;padding:.55rem;gap:.35rem}
  .hero-search-ic{padding-left:.35rem}
  .hero-search input{flex:1 1 140px;padding:.55rem .3rem;font-size:1rem}
  .hero-search-btn{flex:1 1 100%;justify-content:center;padding:.78rem;border-radius:12px}
  .hero-search-hint{font-size:.8rem}
}

/* ── Value props ── */
.value-props{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:-2.4rem;position:relative;z-index:3;padding-bottom:.5rem}
.vp{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.1rem 1.15rem;display:flex;gap:.8rem;align-items:flex-start;box-shadow:var(--sh-sm)}
.vp-ic{font-size:1.5rem;line-height:1}
.vp strong{display:block;color:var(--ink);font-size:.98rem}
.vp span{color:var(--muted);font-size:.86rem}
@media(max-width:900px){.value-props{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.value-props{grid-template-columns:1fr}}

/* ── Section heads ── */
.section-head{text-align:center;max-width:640px;margin:0 auto 2rem}
.section-head h2{font-size:clamp(1.6rem,3.4vw,2.2rem);position:relative;display:inline-block}
.section-head h2::after{content:"";display:block;width:54px;height:4px;border-radius:3px;background:var(--coral);margin:.6rem auto 0}
.section-head p{color:var(--muted);margin:.2rem 0 0}

/* ── Category cards ── */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.cat-card{position:relative;display:flex;flex-direction:column;gap:.5rem;padding:1.5rem;border-radius:var(--r);
  background:linear-gradient(150deg,#fff,#f4fbfc);border:1px solid var(--line);box-shadow:var(--sh-sm);
  transition:transform .15s ease,box-shadow .25s ease,border-color .2s;overflow:hidden}
.cat-card::before{content:"";position:absolute;inset:0;background:linear-gradient(150deg,var(--teal),var(--aqua));opacity:0;transition:.25s}
.cat-card>*{position:relative;z-index:2;transition:color .2s}
.cat-card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg);border-color:transparent}
.cat-card:hover::before{opacity:1}
.cat-card:hover .cat-card-name,.cat-card:hover .cat-card-count,.cat-card:hover .cat-card-go{color:#fff}
.cat-card-ic{width:54px;height:54px;border-radius:14px;background:#eafafc;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-sm)}
.cat-card:hover .cat-card-ic{background:rgba(255,255,255,.2)}
.cat-card-name{font-family:var(--font-head);font-weight:800;font-size:1.18rem;color:var(--ink)}
.cat-card-count{font-size:.84rem;color:var(--muted)}
.cat-card-go{margin-top:auto;font-weight:700;color:var(--coral)}
@media(max-width:860px){.cat-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.cat-grid{grid-template-columns:1fr}}

/* ── Product cards (home + listings) ── */
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.prod-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-sm);transition:transform .14s,box-shadow .25s;color:inherit}
.prod-card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg);color:inherit}
.prod-thumb{display:block;aspect-ratio:1/1;background:linear-gradient(160deg,#f7fbfb,#eef6f7);padding:.7rem}
.prod-thumb img{width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply}
.prod-body{display:flex;flex-direction:column;gap:.4rem;padding:1rem 1.05rem 1.15rem}
.prod-brand{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--aqua);font-weight:800}
.prod-title{font-weight:700;color:var(--ink);line-height:1.32;font-size:.98rem}
.prod-cta{margin-top:auto;color:var(--coral);font-weight:700;font-size:.9rem}
@media(max-width:1000px){.prod-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:720px){.prod-grid{grid-template-columns:repeat(2,1fr)}}

/* stars */
.stars{display:inline-flex;align-items:center;gap:.15rem;font-size:.95rem}
.stars span{color:#dce3e4}
.stars span.on{color:#f5a623}
.stars span.half{background:linear-gradient(90deg,#f5a623 50%,#dce3e4 50%);-webkit-background-clip:text;background-clip:text;color:transparent}
.stars small{color:var(--muted);font-size:.8rem;margin-left:.2rem}

/* ── Post cards ── */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.post-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-sm);transition:transform .14s,box-shadow .25s;color:inherit}
.post-card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg)}
.post-thumb{display:block;aspect-ratio:16/9;background:var(--sand-2);overflow:hidden}
.post-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.post-card:hover .post-thumb img{transform:scale(1.05)}
.post-body{display:flex;flex-direction:column;gap:.5rem;padding:1.1rem 1.2rem 1.3rem}
.post-title{font-family:var(--font-head);font-weight:800;color:var(--ink);font-size:1.08rem;line-height:1.3}
.post-exc{color:var(--muted);font-size:.9rem}
.post-more{margin-top:auto;color:var(--coral);font-weight:700;font-size:.9rem}
@media(max-width:860px){.post-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.post-grid{grid-template-columns:1fr}}

/* ── Page hero (interior) ── */
.page-hero{background:linear-gradient(135deg,var(--ocean-deep),var(--teal));color:#fff;padding:2.8rem 1.25rem 2.4rem}
.page-hero .wrap{padding:0 1.25rem}
.page-hero h1{color:#fff;font-size:clamp(1.7rem,4vw,2.6rem)}
.page-hero-sub{color:rgba(255,255,255,.9);max-width:720px;margin:.4rem 0 0}
.page-hero-shop{background:
  radial-gradient(700px 300px at 90% -40%,rgba(55,194,212,.5),transparent 60%),
  linear-gradient(135deg,var(--ocean-deep),var(--teal))}
.post-meta{display:flex;gap:1rem;color:rgba(255,255,255,.85);font-size:.9rem;margin:.6rem 0 0}
.post-meta span{display:inline-flex;align-items:center;gap:.35rem}

/* ── Content card / article ── */
.site-main{padding:2.4rem 1.25rem 3rem}
.site-main.with-sidebar{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:2rem;align-items:start}
.content-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh);padding:2rem 2.2rem;max-width:860px;margin:0 auto;width:100%}
.with-sidebar .content-card{margin:0;max-width:none}
.content-cover{margin:-2rem -2.2rem 1.8rem;line-height:0;overflow:hidden}
.content-cover img{width:100%;max-height:430px;object-fit:cover}
.article-body{font-size:1.04rem;color:#22454e}
.article-body h2{font-size:1.55rem;margin:2rem 0 .7rem;padding-top:.3rem}
.article-body h3{font-size:1.22rem;margin:1.5rem 0 .5rem}
.article-body p{margin:0 0 1.1rem}
.article-body a{color:var(--teal);text-decoration:underline;text-underline-offset:2px}
.article-body a:hover{color:var(--coral)}
.article-body img{border-radius:12px;margin:1rem 0}
.article-body ul,.article-body ol{margin:0 0 1.1rem 1.2rem}
.article-body li{margin:.35rem 0}
.article-body blockquote{margin:1.4rem 0;padding:.6rem 1.2rem;border-left:4px solid var(--coral);background:var(--sand);border-radius:0 10px 10px 0;color:var(--ink)}
.article-body table{width:100%;border-collapse:collapse;margin:1.2rem 0}
.article-body th,.article-body td{border:1px solid var(--line);padding:.55rem .7rem;text-align:left}
.article-body th{background:var(--sand-2)}
.sidebar{position:sticky;top:calc(var(--header-h) + 16px)}
.after-content{max-width:860px;margin:0 auto;padding:0 1.25rem 2rem}

/* ── Editorial / notice / CTA band ── */
.editorial .article-body{max-width:780px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:2rem;box-shadow:var(--sh-sm)}
.notice-card{background:#fff;border:1px dashed var(--aqua);border-radius:var(--r);padding:2rem;text-align:center;max-width:680px;margin:0 auto}
.cta-band{background:linear-gradient(120deg,var(--coral),#ff9a6b);color:#fff}
.cta-inner{text-align:center;padding:3rem 1.25rem}
.cta-inner h2{color:#fff}
.cta-inner p{color:rgba(255,255,255,.92);margin:.3rem 0 1.3rem}
.cta-band .btn-coral{background:#fff;color:var(--coral-600);box-shadow:0 10px 24px rgba(0,0,0,.18)}

/* ── Pagination ── */
.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:2.2rem}
.pagination a{background:#fff;border:1px solid var(--line);border-radius:999px;padding:.55rem 1.2rem;font-weight:700;color:var(--teal);box-shadow:var(--sh-sm)}
.pagination a:hover{background:var(--teal);color:#fff;border-color:var(--teal)}
.pg-info{color:var(--muted);font-size:.9rem}

/* ── Footer ── */
.site-footer{position:relative;background:var(--ocean-deep);color:#cfe3e6;margin-top:3rem}
.footer-wave{color:var(--sand);line-height:0;margin-top:-1px}
.footer-wave svg{width:100%;height:64px;display:block;transform:translateY(1px)}
.footer-top{display:grid;grid-template-columns:1.8fr 1fr;gap:2rem;padding:2.4rem 1.25rem 2rem}
.footer-brand .site-logo{margin-bottom:.7rem}
.footer-brand p{color:rgba(255,255,255,.66);font-size:.92rem;margin:.3rem 0}
.aff-disclosure{font-size:.78rem;color:rgba(255,255,255,.42)!important}
.footer-col h4{color:#fff;font-size:1rem;margin:0 0 .8rem}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{margin:.4rem 0}
.footer-col a{color:rgba(255,255,255,.7);font-size:.92rem}
.footer-col a:hover{color:var(--coral)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);font-size:.84rem;color:rgba(255,255,255,.5)}
.footer-bottom .wrap{padding:1.1rem 1.25rem}
@media(max-width:780px){.footer-top{grid-template-columns:1fr 1fr}.footer-brand{grid-column:1/-1}}

/* ── Back to top ── */
.back-to-top{position:fixed;right:18px;bottom:18px;width:46px;height:46px;border-radius:50%;border:0;background:var(--coral);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh);opacity:0;visibility:hidden;transform:translateY(10px);transition:.25s;z-index:900}
.back-to-top.show{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top svg{width:22px;height:22px}

/* ── Polish des classes du plugin sur les pages boutique ── */
.shop-offer{border-radius:12px!important}
.shop-offer--amazon{--brand:#0E7C86}
.shop-product__buy .shop-offer:first-child{background:var(--coral);border-color:var(--coral);color:#fff}
.shop-product__buy .shop-offer:first-child .shop-offer__cta{color:#fff}
.shop-card,.shop-product__media>img{border-radius:var(--r)!important}
.content-card .shop-grid{margin-top:.5rem}

/* ── Mobile nav : autres ajustements (le tiroir est defini plus bas, source unique) ── */
@media(max-width:900px){
  .site-main.with-sidebar{grid-template-columns:1fr}
  .sidebar{position:static}
  .content-card{padding:1.4rem 1.25rem}
  .content-cover{margin:-1.4rem -1.25rem 1.4rem}
}

/* ============================ Barre de categories ============================ */
.header-inner .nav-search{margin-left:auto}
.cat-bar{background:#fff;border-top:1px solid var(--line)}
.cat-bar .nav-wrap{margin:0}
.cat-bar .site-nav{width:max-content;max-width:100%;margin:0 auto;padding:.1rem 1rem;justify-content:flex-start;flex-wrap:nowrap;gap:.15rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--line) transparent}
.cat-bar .site-nav::-webkit-scrollbar{height:6px}
.cat-bar .site-nav::-webkit-scrollbar-thumb{background:var(--line);border-radius:6px}
.cat-bar .site-nav::-webkit-scrollbar-track{background:transparent}
.cat-bar .site-nav>li{flex:0 0 auto}
.cat-bar .site-nav>li>a{padding:.7rem .72rem;font-size:.9rem;white-space:nowrap;border-radius:0;position:relative;background:none}
.cat-bar .site-nav>li>a::after{content:"";position:absolute;left:.8rem;right:.8rem;bottom:.4rem;height:2px;background:var(--coral);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .2s}
.cat-bar .site-nav>li>a:hover::after,.cat-bar .site-nav>li.active>a::after{transform:scaleX(1)}
.cat-bar .site-nav>li>a:hover,.cat-bar .site-nav>li.active>a{background:none;color:var(--teal)}
html.nav-collapsed .cat-bar{border:0;padding:0;background:none}

/* ====================== Pages boutique : embellissement ====================== */
.site-content .shop-cat-intro{font-size:1.05rem;color:#3a5a62;max-width:760px;margin:0 0 1.6rem}
.site-content .shop-subgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin:0 0 1.8rem}
.site-content .shop-subcard{display:flex;flex-direction:column;gap:.5rem;padding:1.2rem 1.3rem;border:1px solid var(--line);border-radius:var(--r);background:linear-gradient(150deg,#fff,#f4fbfc);box-shadow:var(--sh-sm);transition:transform .14s,box-shadow .25s,border-color .2s;color:var(--ink)}
.site-content .shop-subcard:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:transparent}
.site-content .shop-subcard__name{font-family:var(--font-head);font-weight:800;font-size:1.08rem}
.site-content .shop-subcard__go{margin-top:auto;color:var(--coral);font-weight:700;font-size:.88rem}

.site-content .shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.2rem}
.site-content .shop-card{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff;box-shadow:var(--sh-sm);transition:transform .14s,box-shadow .25s}
.site-content .shop-card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg)}
.site-content .shop-card__img{aspect-ratio:1/1;background:linear-gradient(160deg,#f7fbfb,#eef6f7);padding:.7rem}
.site-content .shop-card__img img{width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply}
.site-content .shop-card__body{padding:1rem 1.05rem 1.15rem;display:flex;flex-direction:column;gap:.4rem}
.site-content .shop-card__title{font-weight:700;color:var(--ink);line-height:1.32}
.site-content .shop-card__cta{margin-top:auto;color:var(--coral);font-weight:700;font-size:.9rem}

.site-content .shop-rating .star.on{color:#f5a623}
.site-content .shop-offer{border-radius:12px}
.site-content .shop-product__buy .shop-offer:first-child{background:var(--coral);border-color:var(--coral);color:#fff}
.site-content .shop-product__buy .shop-offer:first-child .shop-offer__cta{color:#fff}
.site-content .shop-empty{color:var(--muted);font-style:italic;padding:1.4rem 0}

/* ============= Contenu SEO catégorie (sous les produits) : H2 designés ============= */
.site-content .shop-cat-intro{font-size:1.08rem;color:#34555d;max-width:820px}
.site-content .shop-cat-content{max-width:840px;margin:2.6rem auto 0;border-top:1px solid var(--line);padding-top:2.2rem}
.site-content .shop-cat-content h2{position:relative;font-size:1.5rem;line-height:1.25;margin:2.2rem 0 .8rem;padding-left:1.1rem}
.site-content .shop-cat-content h2::before{content:"";position:absolute;left:0;top:.18em;bottom:.18em;width:5px;border-radius:3px;background:linear-gradient(180deg,var(--coral),var(--aqua))}
.site-content .shop-cat-content h2::after{content:"";display:block;width:56px;height:3px;border-radius:2px;background:var(--coral);margin:.55rem 0 0}
.site-content .shop-cat-content h3{font-size:1.18rem;margin:1.4rem 0 .5rem;color:var(--teal-600)}
.site-content .shop-cat-content p{margin:0 0 1.05rem;color:#26474f}
.site-content .shop-cat-content strong{color:var(--ink);font-weight:800}
.site-content .shop-cat-content ul{margin:0 0 1.1rem 1.2rem}
.site-content .shop-cat-content li{margin:.35rem 0}
.site-content .shop-cat-content li::marker{color:var(--coral)}

/* ===================================================================
   TIROIR MOBILE — SOURCE UNIQUE (<=1024px : telephones + tablettes).
   Selecteurs a forte specificite (.cat-bar #site-nav) pour battre
   les regles desktop de la cat-bar.
   =================================================================== */

  /* Ordre mobile : LOGO, puis RECHERCHE a sa droite, et HAMBURGER a l'extreme droite */
  html.nav-collapsed .site-logo{order:0;margin-right:.1rem}
  html.nav-collapsed .header-inner .nav-search{order:1;margin-left:.15rem;margin-right:auto}
  html.nav-collapsed .nav-toggle{display:flex;order:5;margin-left:0;margin-right:0}
  /* Bouton recherche : pastille brand, belle cible tactile */
  html.nav-collapsed .nav-search-btn{width:44px;height:44px;justify-content:center;background:linear-gradient(135deg,var(--teal),var(--aqua));color:#fff;border-radius:13px;box-shadow:0 6px 16px rgba(14,124,134,.30)}
  html.nav-collapsed .nav-search-btn:hover{background:linear-gradient(135deg,var(--teal-600),var(--teal));color:#fff}
  html.nav-collapsed .nav-search-btn svg{width:22px;height:22px}
  /* Menu de recherche : ouverture sous le bouton, aligne a gauche, large */
  /* Recherche mobile : barre pleine largeur ancree SOUS l'en-tete (pas de debordement, ne couvre pas le contenu de travers) */
  html.nav-collapsed .nav-search{position:static}
  html.nav-collapsed .nav-search-form{position:absolute;top:100%;left:.6rem;right:.6rem;transform:none;min-width:0;border-radius:14px;padding:.55rem;gap:.5rem;margin-top:.4rem}
  html.nav-collapsed .nav-search-form input{flex:1 1 auto;width:auto;max-width:none;padding:.7rem .8rem}
  html.nav-collapsed .nav-search-form button{padding:.7rem 1.1rem}
  /* L'en-tete (contexte d'empilement) doit passer AU-DESSUS du voile,
     sinon le voile recouvre le tiroir qui est a l'interieur -> clics bloques */
  html.nav-collapsed .site-header{z-index:1200}

  /* La barre de categories n'est plus une rangee : juste un conteneur du tiroir */
  html.nav-collapsed .cat-bar{border:0;padding:0;background:none}
  html.nav-collapsed .cat-bar .nav-wrap{position:static;margin:0;padding:0;width:auto;background:none;box-shadow:none;transform:none;overflow:visible}

  /* Le tiroir = le <ul id="site-nav"> lui-meme, panneau vertical a gauche */
  html.nav-collapsed .cat-bar #site-nav{
    position:fixed;top:var(--admin-h,0px);right:0;left:auto;bottom:0;z-index:1200;
    width:300px;max-width:84vw;max-height:100vh;
    margin:0;padding:calc(var(--header-h) + 14px) .6rem 2rem;
    background:#fff;box-shadow:var(--sh-lg);
    display:flex;flex-direction:column;flex-wrap:nowrap;
    align-items:stretch;justify-content:flex-start;gap:.1rem;
    overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;min-height:0;
    transform:translateX(100%);transition:transform .25s ease;
  }
  html.nav-collapsed .cat-bar #site-nav.open{transform:translateX(0)}

  /* Items en pleine largeur */
  html.nav-collapsed .cat-bar #site-nav>li{position:relative;width:100%;margin:0}
  html.nav-collapsed .cat-bar #site-nav>li>a{display:block;width:100%;padding:.85rem .9rem;font-size:1rem;font-weight:600;color:var(--ink);border-radius:10px;background:none;white-space:normal}
  html.nav-collapsed .cat-bar #site-nav>li>a::after{display:none}
  html.nav-collapsed .cat-bar #site-nav>li>a:hover, html.nav-collapsed .cat-bar #site-nav>li.active>a{background:var(--sand-2);color:var(--teal)}

  /* Sous-menus en accordeon */
  html.nav-collapsed .cat-bar #site-nav .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;border-left:2px solid var(--line);border-radius:0;min-width:0;margin:.15rem 0 .45rem .7rem;padding:0;display:none}
  html.nav-collapsed .cat-bar #site-nav .sub-menu.open{display:block}
  html.nav-collapsed .cat-bar #site-nav .sub-menu a{display:block;padding:.6rem .75rem;border-radius:8px;color:var(--text)}

  /* Bouton +/- d'ouverture de sous-menu */
  html.nav-collapsed .cat-bar #site-nav .sub-toggle{display:flex;position:absolute;right:.5rem;top:.5rem;width:32px;height:32px;align-items:center;justify-content:center;border:0;background:var(--sand-2);border-radius:8px;font-size:1.2rem;font-weight:800;color:var(--ocean);cursor:pointer}

  /* Voile sombre derriere le tiroir */
  html.nav-collapsed .nav-overlay{display:block;position:fixed;inset:0;background:rgba(7,45,53,.5);opacity:0;visibility:hidden;transition:.25s;z-index:1100}
  html.nav-collapsed .nav-overlay.open{opacity:1;visibility:visible}

/* Bouton de fermeture du tiroir (visible quand le menu est ouvert) */
.nav-close{display:none;position:fixed;top:calc(var(--admin-h,0px) + 14px);right:14px;z-index:1300;width:46px;height:46px;border-radius:12px;border:0;background:#fff;color:var(--ocean);font-size:1.9rem;line-height:1;cursor:pointer;box-shadow:var(--sh-lg);align-items:center;justify-content:center;padding:0}
.nav-close.show{display:flex}
body.nav-open-lock{overflow:hidden}
.nav-close:hover{background:var(--sand-2);color:var(--coral)}


/* ======================= Accueil : sections riches ======================= */
/* Intro editoriale */
.home-intro{max-width:880px;margin:0 auto;text-align:center}
.home-kicker{text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;font-weight:800;color:var(--coral);margin:0 0 .7rem}
.home-intro h2{font-size:clamp(1.7rem,3.6vw,2.45rem)}
.home-lead{font-size:1.18rem;color:var(--ink);font-weight:600;margin:1rem 0 1.6rem;line-height:1.6}
.home-intro>p{color:#33545c;font-size:1.04rem;line-height:1.85;text-align:left}

/* Deux univers (eau douce / recifal) */
.uni-split{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.uni-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:2rem 2rem 1.6rem;box-shadow:var(--sh-sm);overflow:hidden}
.uni-card::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--teal),var(--aqua))}
.uni-reef::before{background:linear-gradient(90deg,var(--coral),#ff9d7d)}
.uni-ic{font-size:2.4rem;line-height:1;display:block;margin-bottom:.7rem}
.uni-card h3{font-size:1.4rem;color:var(--ocean);margin-bottom:.8rem}
.uni-card p{color:#33545c;line-height:1.8;margin:0}
@media(max-width:760px){.uni-split{grid-template-columns:1fr}}

/* Materiel essentiel */
.gear-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1.1rem}
.gear-card{background:var(--sand);border:1px solid var(--line);border-radius:var(--r);padding:1.5rem;transition:transform .15s ease,box-shadow .2s ease,border-color .2s}
.gear-card:hover{transform:translateY(-3px);box-shadow:var(--sh);border-color:#d7e6e6}
.gear-ic{font-size:1.9rem;line-height:1;display:block;margin-bottom:.55rem}
.gear-card h3{font-size:1.16rem;color:var(--teal);margin-bottom:.4rem}
.gear-card p{color:#3a5a62;font-size:.96rem;line-height:1.7;margin:0}

/* Etapes (timeline numerotee) */
.steps{list-style:none;margin:0 auto;padding:0;max-width:860px;display:grid;gap:1rem}
.step{display:flex;gap:1.1rem;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.3rem 1.5rem;box-shadow:var(--sh-sm)}
.step-n{flex:0 0 auto;width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--aqua));color:#fff;font-family:var(--font-head);font-weight:800;font-size:1.25rem;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 18px rgba(14,124,134,.30)}
.step h3{font-size:1.16rem;color:var(--ocean);margin:.15rem 0 .4rem}
.step p{color:#3a5a62;line-height:1.75;margin:0}

/* FAQ accordeons natifs <details> */
.acc-wrap{max-width:860px;margin:0 auto;display:grid;gap:.7rem}
.acc{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-sm);overflow:hidden;transition:box-shadow .2s}
.acc[open]{box-shadow:var(--sh)}
.acc>summary{cursor:pointer;list-style:none;padding:1.15rem 1.4rem;font-family:var(--font-head);font-weight:700;font-size:1.04rem;color:var(--ocean);display:flex;align-items:center;justify-content:space-between;gap:1rem;transition:background .15s,color .15s}
.acc>summary::-webkit-details-marker{display:none}
.acc>summary:hover{background:var(--sand)}
.acc[open]>summary{color:var(--teal)}
.acc-mark{flex:0 0 auto;width:24px;height:24px;position:relative}
.acc-mark::before,.acc-mark::after{content:"";position:absolute;background:var(--coral);border-radius:2px;transition:transform .25s ease}
.acc-mark::before{top:10.75px;left:3px;right:3px;height:2.5px}
.acc-mark::after{left:10.75px;top:3px;bottom:3px;width:2.5px}
.acc[open] .acc-mark::after{transform:scaleY(0)}
.acc-body{padding:.1rem 1.4rem 1.3rem;color:#3a5a62;line-height:1.8}
.acc-body p{margin:0}

/* Entretien (cartes par frequence) */
.care-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.care-card{background:#fff;border:1px solid var(--line);border-top:4px solid var(--aqua);border-radius:var(--r);padding:1.6rem;box-shadow:var(--sh-sm)}
.care-tag{display:inline-block;background:var(--sand-2);color:var(--teal-600);font-weight:700;font-size:.76rem;text-transform:uppercase;letter-spacing:.06em;padding:.25rem .7rem;border-radius:999px;margin-bottom:.7rem}
.care-card h3{font-size:1.16rem;color:var(--ocean);margin-bottom:.4rem}
.care-card p{color:#3a5a62;line-height:1.7;margin:0;font-size:.97rem}
@media(max-width:820px){.care-grid{grid-template-columns:1fr}}

/* Engagements (bandeau sombre) */
.pledge-band{background:
  radial-gradient(800px 400px at 100% 0%,rgba(55,194,212,.30),transparent 60%),
  linear-gradient(135deg,var(--ocean-deep),var(--teal));
  color:#eaf6f7;padding:3.6rem 1.25rem;margin-top:3rem}
.section-head-light h2{color:#fff}
.section-head-light p{color:rgba(255,255,255,.82)}
.pledge-grid{max-width:1100px;margin:1.6rem auto 0;display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.pledge-item{text-align:center;padding:.3rem}
.pledge-ic{font-size:2rem;line-height:1;display:block;margin-bottom:.55rem}
.pledge-item h3{color:#fff;font-size:1.08rem;margin-bottom:.4rem}
.pledge-item p{color:rgba(255,255,255,.82);font-size:.92rem;line-height:1.65;margin:0}
@media(max-width:860px){.pledge-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.pledge-grid{grid-template-columns:1fr}}

/* Derniers produits : aere le titre */
.latest-section{padding-top:3rem}

/* Encart note moyenne : occupe 2 cellules sur écran large, 1 seule sur mobile (responsive) */
.gear-rating{grid-column:auto}
@media(min-width:640px){.gear-rating{grid-column:span 2}}

/* Blog : zones de contenu SEO (haut/bas) */
.blog-seo{max-width:820px;margin-left:auto;margin-right:auto;color:#33474e;line-height:1.75}
.blog-seo p{margin:.6rem 0 1.15rem}
.blog-seo h2{position:relative;font-family:var(--font-head);font-weight:800;color:var(--ink);font-size:1.5rem;margin:1.9rem 0 .7rem;padding-left:.9rem}
.blog-seo h2::before{content:"";position:absolute;left:0;top:.2em;bottom:.2em;width:4px;border-radius:3px;background:linear-gradient(180deg,var(--coral),var(--aqua))}
.blog-seo h3{font-family:var(--font-head);font-weight:700;color:var(--teal);font-size:1.18rem;margin:1.3rem 0 .5rem}
.blog-seo ul{margin:.4rem 0 1.2rem;padding-left:1.2rem}.blog-seo li{margin:.35rem 0}
.blog-seo strong{color:var(--ink)}.blog-seo em{font-style:italic;color:#4b5a63}
.blog-seo-bottom{border-top:1px solid var(--line);padding-top:1.6rem;margin-top:.5rem}
