  :root{
    /* ===== Thème SALOUVA — toute la palette dérive de --rose =====
       Changer --rose (réglage admin « couleur principale ») reteinte tout le site. */
    --rose:#E0518F;          /* couleur principale (boutons, accents) */
    --rose-deep:color-mix(in srgb, var(--rose), #000 24%);   /* survol */
    --rose-soft:color-mix(in srgb, var(--rose) 26%, #fff);   /* bandeaux/fonds */
    --rose-tint:color-mix(in srgb, var(--rose) 9%, #fff);    /* sections claires */
    --plum:#5E2138;          /* prune profond (titres, texte fort) */
    --gold:#C9A24B;
    --gold-deep:#A67C2E;
    /* Alias hérités (réutilisés par les composants existants) */
    --ocean:#5E2138;
    --ocean-2:#7A2E48;
    --lagoon:var(--rose);
    --lagoon-light:color-mix(in srgb, var(--rose) 42%, #fff);
    --sand:color-mix(in srgb, var(--rose) 7%, #fff);
    --sand-2:color-mix(in srgb, var(--rose) 16%, #fff);
    --coral:var(--rose);
    --ink:#4A3038;           /* texte chaud */
    --cream:#FFFFFF;
    --display:"Fraunces",Georgia,serif;
    --body:"Manrope",system-ui,sans-serif;
    --maxw:1200px;
    --shadow:0 18px 50px -22px rgba(94,33,56,.40);
  }

  /* ===== Mode sombre (bascule visiteur, mémorisé) ===== */
  html[data-theme="dark"]{
    --cream:#170e12;          /* fond de page sombre */
    --ink:#efe2e8;            /* texte clair */
    --plum:#f6e8ee;           /* titres clairs */
    --ocean:#f6e8ee;
    --sand:#241319;           /* surfaces sombres */
    --sand-2:#3a2530;         /* bordures sombres */
    --rose-tint:#241017;      /* sections sombres teintées */
    --rose-soft:#3a1c28;
    --shadow:0 18px 50px -22px rgba(0,0,0,.7);
  }
  html[data-theme="dark"] body{background:#120a0e}
  /* Surfaces blanches → sombres */
  html[data-theme="dark"] header,
  html[data-theme="dark"] .mainnav,
  html[data-theme="dark"] .hsearch,
  html[data-theme="dark"] .card,
  html[data-theme="dark"] .modal-card,
  html[data-theme="dark"] .feature-strip .inner,
  html[data-theme="dark"] .tcard,
  html[data-theme="dark"] .acc-card,
  html[data-theme="dark"] .order-card,
  html[data-theme="dark"] .panel,
  html[data-theme="dark"] .chip,
  html[data-theme="dark"] .qty-pick,
  html[data-theme="dark"] .gift-box,
  html[data-theme="dark"] .cookie-bar,
  html[data-theme="dark"] footer{ background:var(--sand); color:var(--ink); border-color:var(--sand-2) }
  html[data-theme="dark"] .field input,
  html[data-theme="dark"] .field textarea,
  html[data-theme="dark"] .field select,
  html[data-theme="dark"] .hsearch input{ background:#1f1016; color:var(--ink); border-color:var(--sand-2) }
  html[data-theme="dark"] .news,
  html[data-theme="dark"] .testimonials-sec,
  html[data-theme="dark"] .promo-hero,
  html[data-theme="dark"] .cat-hero{ background:linear-gradient(120deg,var(--rose-tint),#1f1016) }
  /* Textes gris codés en dur → éclaircis */
  html[data-theme="dark"] .card-desc,
  html[data-theme="dark"] .feature p,
  html[data-theme="dark"] .pv-info p,
  html[data-theme="dark"] .pg-desc,
  html[data-theme="dark"] .tcard blockquote,
  html[data-theme="dark"] .section-head p,
  html[data-theme="dark"] .acc-blank p,
  html[data-theme="dark"] .news p{ color:#d8c4cd }
  html[data-theme="dark"] .card-title,
  html[data-theme="dark"] .card-name-on,
  html[data-theme="dark"] .price{ color:var(--ink) }
  html[data-theme="dark"] .topbar{ background:#2a141d }
  html[data-theme="dark"] .naction,
  html[data-theme="dark"] .mainnav .menu a{ color:var(--ink) }
  html[data-theme="dark"] .disc-ph{ color:#fff }
  @media (prefers-reduced-motion:no-preference){
    html[data-theme],html[data-theme] body{transition:background-color .3s,color .3s}
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:var(--body);
    color:var(--ink);
    background:var(--cream);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
  }
  img{max-width:100%;display:block}
  a{color:inherit;text-decoration:none}
  button{font-family:inherit;cursor:pointer;border:none;background:none}
  ::selection{background:var(--lagoon);color:#fff}
  :focus-visible{outline:2.5px solid var(--gold);outline-offset:3px;border-radius:4px}

  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
  .eyebrow{
    font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
    font-weight:600;color:var(--gold-deep);
  }
  .serif{font-family:var(--display)}

  /* ---------- Announcement bar ---------- */
  .topbar{
    background:var(--ocean);color:var(--sand);
    font-size:.78rem;letter-spacing:.04em;text-align:center;
    padding:8px 16px;
  }
  .topbar b{color:var(--gold);font-weight:600}

  /* ---------- Header ---------- */
  header{
    position:sticky;top:0;z-index:60;
    background:rgba(252,250,244,.82);
    backdrop-filter:blur(12px);
    border-bottom:1px solid rgba(6,59,69,.10);
  }
  .nav{display:flex;align-items:center;justify-content:space-between;height:74px}
  .logo{display:flex;align-items:center;gap:11px;letter-spacing:.01em}
  .logo .emblem{width:42px;height:42px;flex:none}
  .logo-text{display:flex;flex-direction:column;line-height:1}
  .logo .mark{font-family:var(--display);font-size:1.45rem;font-weight:600;color:var(--ocean)}
  .logo .mark em{color:var(--gold-deep);font-style:italic}
  .logo .sub{font-size:.6rem;letter-spacing:.34em;text-transform:uppercase;color:var(--lagoon);margin-top:3px}
  .menu{display:flex;gap:34px;font-weight:500;font-size:.95rem}
  .menu a{position:relative;padding:4px 0}
  .menu a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--gold);transition:width .25s}
  .menu a:hover::after{width:100%}
  .nav-actions{display:flex;align-items:center;gap:8px}
  .cart-btn{
    display:flex;align-items:center;gap:8px;
    background:var(--ocean);color:var(--sand);
    padding:11px 18px;border-radius:40px;font-weight:600;font-size:.9rem;
    transition:transform .2s,background .2s;
  }
  .cart-btn:hover{background:var(--ocean-2);transform:translateY(-1px)}
  .cart-count{
    background:var(--gold);color:var(--ocean);min-width:21px;height:21px;
    border-radius:50%;display:grid;place-items:center;font-size:.74rem;font-weight:700;
  }
  .burger{display:none;width:44px;height:44px;border-radius:12px;color:var(--ocean)}

  /* ---------- Hero ---------- */
  .hero{position:relative;overflow:hidden;background:var(--ocean);color:var(--sand)}
  .hero-bg{position:absolute;inset:0;z-index:0}
  .hero-bg .blob{position:absolute;border-radius:50%;filter:blur(8px);opacity:.5}
  .b1{width:60vw;height:60vw;background:radial-gradient(circle,var(--lagoon),transparent 70%);top:-22vw;right:-12vw;opacity:.55}
  .b2{width:46vw;height:46vw;background:radial-gradient(circle,var(--lagoon-light),transparent 70%);bottom:-26vw;left:-10vw;opacity:.32}
  .b3{width:30vw;height:30vw;background:radial-gradient(circle,var(--gold),transparent 70%);top:30%;left:42%;opacity:.16}
  .hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;padding:74px 0 90px}
  .hero h1{font-family:var(--display);font-weight:500;font-size:clamp(2.6rem,6vw,4.6rem);line-height:1.02;letter-spacing:-.01em}
  .hero h1 em{font-style:italic;color:var(--gold)}
  .hero .lead{margin:22px 0 30px;max-width:30ch;color:#DCE9E6;font-size:1.08rem}
  .hero .eyebrow{color:var(--gold);margin-bottom:18px;display:inline-block}
  .hero-cta{display:flex;gap:14px;flex-wrap:wrap}
  .btn{
    display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.96rem;
    padding:15px 26px;border-radius:40px;transition:transform .2s,box-shadow .2s,background .2s,color .2s;
  }
  .btn-gold{background:var(--gold);color:var(--ocean)}
  .btn-gold:hover{background:#d8b25e;transform:translateY(-2px);box-shadow:0 14px 30px -12px rgba(201,162,75,.6)}
  .btn-ghost{border:1.5px solid rgba(247,242,232,.4);color:var(--sand)}
  .btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
  .hero-stats{display:flex;gap:30px;margin-top:42px}
  .hero-stats div span{display:block;font-family:var(--display);font-size:1.6rem;color:var(--gold)}
  .hero-stats div small{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:#B9CFCB}

  /* hero collage */
  .collage{position:relative;height:440px}
  .ph{
    position:absolute;border-radius:18px;overflow:hidden;
    box-shadow:0 30px 60px -28px rgba(0,0,0,.6);border:3px solid rgba(247,242,232,.12);
  }
  .ph .label{position:absolute;left:0;right:0;bottom:0;padding:14px;
    background:linear-gradient(transparent,rgba(6,59,69,.85));
    font-family:var(--display);font-size:1.05rem;color:#fff}
  .c-a{width:58%;height:78%;top:0;right:6%}
  .c-b{width:46%;height:50%;bottom:0;left:0}
  .c-tag{position:absolute;bottom:8%;right:0;background:var(--cream);color:var(--ocean);
    padding:12px 18px;border-radius:14px;box-shadow:var(--shadow);z-index:3}
  .c-tag b{display:block;font-family:var(--display);font-size:1.05rem}
  .c-tag small{color:var(--lagoon);font-weight:600;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase}

  .wave-divider{display:block;width:100%;height:60px;color:var(--cream)}

  /* ---------- Marquee ---------- */
  .marquee{background:var(--sand);border-block:1px solid var(--sand-2);overflow:hidden;padding:16px 0}
  .marquee-track{display:flex;gap:48px;white-space:nowrap;animation:slide 28s linear infinite;width:max-content}
  .marquee span{font-family:var(--display);font-style:italic;font-size:1.15rem;color:var(--ocean);opacity:.7;display:inline-flex;align-items:center;gap:48px}
  .marquee span::after{content:"✦";color:var(--gold);font-style:normal}
  @keyframes slide{to{transform:translateX(-50%)}}

  /* ---------- Section base ---------- */
  section{scroll-margin-top:90px}
  .section-pad{padding:86px 0}
  .section-head{max-width:560px;margin-bottom:48px}
  .section-head h2{font-family:var(--display);font-weight:500;font-size:clamp(2rem,4vw,2.9rem);line-height:1.08;margin:14px 0 12px}
  .section-head p{color:#4a5d60}

  /* ---------- Story ---------- */
  .story{background:var(--ocean);color:var(--sand)}
  .story .grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:center}
  .story h2{font-family:var(--display);font-weight:500;font-size:clamp(2rem,4vw,2.8rem);line-height:1.1;margin:14px 0 18px}
  .story h2 em{color:var(--gold);font-style:italic}
  .story p{color:#CFE0DD;margin-bottom:16px;max-width:46ch}
  .story .eyebrow{color:var(--gold)}
  .values{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:8px}
  .value{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:22px}
  .value .ic{width:40px;height:40px;border-radius:11px;background:rgba(201,162,75,.18);color:var(--gold);display:grid;place-items:center;margin-bottom:12px}
  .value h3{font-family:var(--display);font-size:1.15rem;font-weight:500;margin-bottom:5px}
  .value p{font-size:.9rem;color:#BDD2CE;margin:0}

  /* ---------- Catalogue ---------- */
  .filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:36px}
  .chip{
    padding:10px 20px;border-radius:40px;font-weight:600;font-size:.9rem;
    border:1.5px solid var(--sand-2);color:var(--ocean);background:#fff;transition:.2s;
  }
  .chip:hover{border-color:var(--lagoon)}
  .chip.active{background:var(--ocean);color:var(--sand);border-color:var(--ocean)}

  .grid-products{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
  .card{
    background:#fff;border-radius:20px;overflow:hidden;border:1px solid var(--sand-2);
    box-shadow:0 6px 22px -16px rgba(6,59,69,.35);transition:transform .28s,box-shadow .28s;
    display:flex;flex-direction:column;position:relative;
  }
  .card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
  .card-media{position:relative;aspect-ratio:4/5;cursor:pointer;overflow:hidden}
  .card-media .frame,.card-name-on{display:none}
  .badge{position:absolute;top:14px;left:14px;z-index:3;background:var(--coral);color:#fff;
    font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:6px 11px;border-radius:30px}
  .quick{position:absolute;top:12px;right:12px;z-index:3;width:40px;height:40px;border-radius:50%;
    background:rgba(252,250,244,.92);color:var(--ocean);display:grid;place-items:center;
    opacity:0;transform:translateY(-6px);transition:.22s}
  .card:hover .quick{opacity:1;transform:translateY(0)}
  .card-body{padding:13px 14px 16px;display:flex;flex-direction:column;gap:3px;flex:1}
  .card-cat{font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--lagoon);font-weight:600}
  .card-title{font-family:var(--display);font-size:1.02rem;font-weight:500;color:var(--ink);line-height:1.2}
  .card-desc{font-size:.78rem;color:#5d6f72;margin-bottom:6px}
  .card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;gap:8px}
  .price{font-family:var(--display);font-size:1.15rem;color:var(--ocean)}
  .price small{font-size:.85rem;color:#94a3a3;text-decoration:line-through;margin-right:6px;font-family:var(--body)}
  .add{background:var(--ocean);color:var(--sand);width:40px;height:40px;border-radius:11px;display:grid;place-items:center;transition:.2s;flex:none}
  .add:hover{background:var(--gold);color:var(--ocean);transform:rotate(90deg)}

  /* ---------- Banner CTA ---------- */
  .promo{position:relative;overflow:hidden;background:linear-gradient(120deg,var(--lagoon),var(--ocean));color:#fff;border-radius:28px;padding:60px 54px;margin:0 24px}
  .promo-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
  .promo h2{font-family:var(--display);font-weight:500;font-size:clamp(1.8rem,3.5vw,2.6rem);line-height:1.1}
  .promo p{color:#DCEFEC;margin-top:8px;max-width:42ch}
  .promo .pat{position:absolute;inset:0;opacity:.12;z-index:1}

  /* ---------- Newsletter ---------- */
  .news{background:var(--sand);text-align:center}
  .news .inner{max-width:560px;margin:0 auto}
  .news h2{font-family:var(--display);font-weight:500;font-size:clamp(1.8rem,3.5vw,2.5rem);margin:12px 0 10px}
  .news p{color:#4a5d60;margin-bottom:26px}
  .news form{display:flex;gap:10px;max-width:440px;margin:0 auto}
  .news input{flex:1;padding:15px 18px;border-radius:40px;border:1.5px solid var(--sand-2);font-family:inherit;font-size:.95rem;background:#fff}
  .news input:focus{outline:none;border-color:var(--lagoon)}

  /* ---------- Footer ---------- */
  footer{background:var(--ocean);color:#BCD0CD;padding:64px 0 30px;font-size:.92rem}
  .foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}
  footer h4{color:var(--sand);font-family:var(--display);font-size:1.1rem;font-weight:500;margin-bottom:16px}
  footer ul{list-style:none;display:flex;flex-direction:column;gap:9px}
  footer a:hover{color:var(--gold)}
  .foot-logo .mark{font-family:var(--display);font-size:1.5rem;color:var(--sand)}
  .foot-logo .mark em{color:var(--gold);font-style:italic}
  .foot-logo p{margin-top:14px;max-width:34ch;color:#9DB6B2}
  .socials{display:flex;gap:10px;margin-top:18px}
  .socials a{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.07);display:grid;place-items:center;color:var(--sand);transition:.2s}
  .socials a:hover{background:var(--gold);color:var(--ocean)}
  .pay{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}
  .pay span{font-size:.7rem;background:rgba(255,255,255,.08);padding:5px 10px;border-radius:7px;letter-spacing:.04em}
  .foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;flex-wrap:wrap;gap:12px;color:#85a09c;font-size:.82rem}
  .foot-links a{color:#9DB6B2}.foot-links a:hover{color:var(--gold)}

  /* ---------- Cart drawer ---------- */
  .overlay{position:fixed;inset:0;background:rgba(6,59,69,.5);backdrop-filter:blur(3px);z-index:90;opacity:0;pointer-events:none;transition:opacity .3s}
  .overlay.open{opacity:1;pointer-events:auto}
  .drawer{position:fixed;top:0;right:0;height:100%;width:420px;max-width:92vw;background:var(--cream);z-index:100;
    transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-20px 0 60px -20px rgba(0,0,0,.4)}
  .drawer.open{transform:translateX(0)}
  .drawer-head{display:flex;align-items:center;justify-content:space-between;padding:24px;border-bottom:1px solid var(--sand-2)}
  .drawer-head h3{font-family:var(--display);font-size:1.4rem;font-weight:500}
  .icon-btn{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:var(--ocean);transition:.2s}
  .icon-btn:hover{background:var(--sand-2)}
  .drawer-body{flex:1;overflow-y:auto;padding:16px 24px}
  .cart-empty{text-align:center;padding:60px 20px;color:#7d8e90}
  .cart-empty svg{margin:0 auto 16px;color:var(--lagoon-light)}
  .line{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--sand-2)}
  .line-media{width:70px;height:88px;border-radius:11px;overflow:hidden;flex:none;position:relative}
  .line-info{flex:1;min-width:0}
  .line-info h4{font-family:var(--display);font-size:1.02rem;font-weight:500}
  .line-info .lc{font-size:.74rem;color:var(--lagoon);text-transform:uppercase;letter-spacing:.1em;font-weight:600}
  .line-price{font-family:var(--display);color:var(--ocean);margin-top:3px}
  .qty{display:inline-flex;align-items:center;gap:0;border:1.5px solid var(--sand-2);border-radius:30px;margin-top:8px;background:#fff}
  .qty button{width:32px;height:32px;display:grid;place-items:center;color:var(--ocean);font-size:1.1rem}
  .qty span{min-width:26px;text-align:center;font-weight:600;font-size:.9rem}
  .line-remove{color:#a4b3b3;font-size:.78rem;margin-top:6px;display:inline-block}
  .line-remove:hover{color:var(--coral)}
  .drawer-foot{padding:22px 24px;border-top:1px solid var(--sand-2);background:var(--sand)}
  .ship-bar{height:7px;background:var(--sand-2);border-radius:10px;overflow:hidden;margin:4px 0 10px}
  .ship-bar i{display:block;height:100%;background:var(--gold);width:0;transition:width .4s}
  .ship-note{font-size:.8rem;color:#52656a;margin-bottom:14px}
  .ship-note b{color:var(--ocean)}
  .subtotal{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
  .subtotal .lab{font-size:.9rem;color:#52656a}
  .subtotal .val{font-family:var(--display);font-size:1.6rem;color:var(--ocean)}
  .btn-full{width:100%;justify-content:center}
  .btn-wa{background:#1FAE54;color:#fff;width:100%;justify-content:center;margin-top:10px}
  .btn-wa:hover{background:#19994a;transform:translateY(-2px)}

  /* ---------- Modal product / checkout ---------- */
  .modal{position:fixed;inset:0;z-index:110;display:none;align-items:center;justify-content:center;padding:20px}
  .modal.open{display:flex}
  .modal-card{background:var(--cream);border-radius:24px;max-width:880px;width:100%;max-height:90vh;overflow:auto;position:relative;box-shadow:var(--shadow);animation:pop .3s ease}
  @keyframes pop{from{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}
  .modal-close{position:absolute;top:16px;right:16px;z-index:5;background:rgba(252,250,244,.9)}
  .pv{display:grid;grid-template-columns:1fr 1fr}
  .pv>*{min-width:0}
  .pv-media{aspect-ratio:1;position:relative;overflow:hidden}
  .pv-media img,.pv-media svg{width:100%;height:100%;object-fit:cover;display:block}
  .pv-info{padding:42px 38px}
  .pv-info .card-cat{margin-bottom:8px}
  .pv-info h2{font-family:var(--display);font-weight:500;font-size:2rem;line-height:1.1;margin-bottom:14px}
  .pv-info .pv-price{font-family:var(--display);font-size:1.9rem;color:var(--ocean);margin:8px 0 18px}
  .pv-info p{color:#52656a;margin-bottom:22px}
  .pv-feat{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:26px}
  .pv-feat li{display:flex;gap:10px;align-items:center;font-size:.92rem;color:#3c4f52}
  .pv-feat svg{color:var(--gold-deep);flex:none}

  /* checkout */
  .checkout-card{max-width:560px}
  .checkout-card .ch-pad{padding:38px}
  .checkout-card h2{font-family:var(--display);font-weight:500;font-size:1.8rem;margin-bottom:6px}
  .checkout-card .sub{color:#52656a;font-size:.92rem;margin-bottom:24px}
  .field{margin-bottom:16px}
  .field label{display:block;font-size:.82rem;font-weight:600;margin-bottom:6px;color:var(--ocean)}
  .field input,.field textarea,.field select{width:100%;padding:13px 15px;border-radius:12px;border:1.5px solid var(--sand-2);font-family:inherit;font-size:.95rem;background:#fff}
  .field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--lagoon)}
  .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .ch-summary{background:var(--sand);border-radius:14px;padding:18px;margin:8px 0 20px;font-size:.9rem}
  .ch-summary .li{display:flex;justify-content:space-between;padding:5px 0;color:#3c4f52}
  .ch-summary .tot{display:flex;justify-content:space-between;border-top:1px dashed var(--sand-2);margin-top:8px;padding-top:10px;font-family:var(--display);font-size:1.2rem;color:var(--ocean)}
  .note-box{font-size:.8rem;background:rgba(21,154,170,.08);border:1px solid rgba(21,154,170,.25);border-radius:12px;padding:12px 14px;color:#2c545b;margin-top:14px}
  .success{text-align:center;padding:48px 38px}
  .success .check{width:74px;height:74px;border-radius:50%;background:rgba(31,174,84,.15);color:#1FAE54;display:grid;place-items:center;margin:0 auto 20px}
  .success h2{font-family:var(--display);font-size:1.8rem;margin-bottom:10px}
  .success p{color:#52656a;margin-bottom:24px}

  /* ---------- Toast ---------- */
  .toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(120%);
    background:var(--ocean);color:var(--sand);padding:14px 22px;border-radius:40px;z-index:130;
    display:flex;align-items:center;gap:10px;box-shadow:var(--shadow);font-weight:500;transition:transform .4s cubic-bezier(.4,0,.2,1)}
  .toast.show{transform:translateX(-50%) translateY(0)}
  .toast svg{color:var(--gold)}

  /* ---------- Reveal animation ---------- */
  .reveal{opacity:0;transform:translateY(24px);transition:opacity .7s,transform .7s}
  .reveal.in{opacity:1;transform:none}

  /* ---------- Responsive ---------- */
  @media(max-width:1100px){ .grid-products{grid-template-columns:repeat(4,1fr)} }
  @media(max-width:920px){
    .hero-inner{grid-template-columns:1fr;gap:30px;padding:54px 0 70px}
    .collage{height:360px;max-width:420px}
    .story .grid{grid-template-columns:1fr;gap:36px}
    .grid-products{grid-template-columns:repeat(3,1fr);gap:14px}
    .foot-grid{grid-template-columns:1fr 1fr}
    .pv{grid-template-columns:1fr}
    .pv-media{aspect-ratio:16/10}
  }
  @media(max-width:680px){
    .menu{display:none}
    .burger{display:grid;place-items:center}
    .cart-btn span.lbl{display:none}
    .grid-products{grid-template-columns:1fr 1fr;gap:14px}
    .card-desc{display:none}
    .hero-stats{gap:20px;flex-wrap:wrap}
    .promo{padding:42px 28px;margin:0 16px}
    .news form{flex-direction:column}
    .news input{border-radius:14px}
    .row2{grid-template-columns:1fr}
    .section-pad{padding:64px 0}
    .wrap{padding:0 18px}
  }
  @media(prefers-reduced-motion:reduce){
    *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
    .reveal{opacity:1;transform:none}
  }

  /* ---------- Ajouts multi-pages ---------- */
  .menu a.active{color:var(--gold-deep)}
  .menu a.active::after{width:100%}
  .menu.open{display:flex}
  /* Hero de catégorie (pages dédiées) */
  .cat-hero{position:relative;overflow:hidden;background:var(--ocean);color:var(--sand);text-align:center;padding:64px 0 78px}
  .cat-hero .hero-bg{position:absolute;inset:0;z-index:0}
  .cat-hero .inner{position:relative;z-index:2}
  .cat-hero h1{font-family:var(--display);font-weight:500;font-size:clamp(2.2rem,5vw,3.4rem);line-height:1.05}
  .cat-hero h1 em{font-style:italic;color:var(--gold)}
  .cat-hero p{max-width:46ch;margin:16px auto 0;color:#DCE9E6;font-size:1.05rem}
  .cat-hero .crumb{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:14px}
  @media(max-width:760px){
    .menu{display:none;position:absolute;top:74px;left:0;right:0;flex-direction:column;gap:0;
      background:var(--cream);border-bottom:1px solid rgba(6,59,69,.1);padding:8px 24px 16px}
    .menu a{padding:12px 0;border-bottom:1px solid var(--sand-2)}
    .burger{display:grid;place-items:center}
  }

  /* ---------- Barre de filtres (couleur / taille / prix) ---------- */
  .refine{display:flex;flex-wrap:wrap;align-items:center;gap:16px;margin:0 0 28px}
  .refine-group{display:flex;align-items:center;gap:8px}
  .refine-group label{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ocean)}
  .refine select{
    appearance:none;-webkit-appearance:none;
    background:#fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%23063B45' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>") no-repeat right 14px center;
    border:1.5px solid var(--sand-2);border-radius:30px;padding:9px 36px 9px 16px;
    font-family:var(--body);font-size:.9rem;font-weight:500;color:var(--ink);cursor:pointer;transition:border-color .2s;
  }
  .refine select:hover{border-color:var(--lagoon-light)}
  .refine select:focus{outline:none;border-color:var(--lagoon)}
  .refine-reset{background:none;color:var(--lagoon);font-weight:600;font-size:.85rem;text-decoration:underline;text-underline-offset:3px;padding:6px 2px}
  .refine-reset:hover{color:var(--ocean)}
  .refine-count{margin-left:auto;font-size:.85rem;color:#7d8e90;font-weight:500}
  @media(max-width:560px){.refine{gap:10px}.refine-count{margin-left:0;width:100%}}

  /* Tailles dans l'aperçu produit */
  .pv-sizes{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin:6px 0 14px}
  .pv-sizes-lab{font-size:.8rem;font-weight:700;color:var(--ocean);text-transform:uppercase;letter-spacing:.06em}
  .pv-size{display:inline-grid;place-items:center;min-width:34px;height:30px;padding:0 8px;border:1.5px solid var(--sand-2);border-radius:8px;font-size:.85rem;font-weight:600;color:var(--ocean);background:#fff}

/* ===== Stock épuisé ===== */
.card.is-out .card-media{ filter:grayscale(.35) opacity(.92); }
.badge.badge-out{ background:#7d8e90; color:#fff; }
.card .add:disabled{ opacity:.4; cursor:not-allowed; }

/* ===== Sélecteur de taille ===== */
.pv-sizes-row{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin:14px 0; }
.pv-sizes-lab{ font-family:var(--body); font-weight:600; color:var(--ocean); }
.size-pick{ display:flex; gap:8px; flex-wrap:wrap; }
.size-btn{ min-width:46px; padding:9px 12px; border:1.5px solid var(--sand-2); border-radius:12px;
  background:var(--cream); font-family:var(--body); font-weight:600; color:var(--ink); cursor:pointer; transition:.18s; }
.size-btn:hover:not(.out){ border-color:var(--lagoon); }
.size-btn.active{ background:var(--ocean); color:#fff; border-color:var(--ocean); }
.size-btn.out{ opacity:.45; text-decoration:line-through; cursor:not-allowed; }
.pv-out{ margin:12px 0; padding:10px 14px; background:#fbeae6; color:#b23b2e; border-radius:12px; font-weight:600; }
.pv-more{ display:inline-block; margin:6px 0 16px; color:var(--lagoon); font-weight:600; text-decoration:none; }
.pv-more:hover{ text-decoration:underline; }

/* ===== Panier : taille ===== */
.line-size{ display:inline-block; margin-left:6px; padding:1px 8px; background:var(--sand-2);
  border-radius:8px; font-size:.74rem; font-weight:600; color:var(--ocean); vertical-align:middle; }

/* ===== Code promo (caisse) ===== */
.coupon-row{ display:flex; gap:8px; }
.coupon-row input{ flex:1; }
.btn-mini{ padding:0 16px; border:none; border-radius:12px; background:var(--ocean); color:#fff;
  font-family:var(--body); font-weight:600; cursor:pointer; white-space:nowrap; }
.btn-mini:hover{ background:var(--ocean-2); }
.code-msg{ font-size:.85rem; font-weight:600; margin-top:6px; min-height:1em; }

/* ===== Recherche ===== */
.refine-search input{ min-width:200px; padding:9px 12px; border:1.5px solid var(--sand-2);
  border-radius:12px; background:var(--cream); font-family:var(--body); font-size:.92rem; }

/* ===== Fiche produit ===== */
#product-section{ min-height:60vh; }
.pg-crumb{ font-family:var(--body); color:#7d8e90; margin-bottom:22px; font-size:.92rem; }
.pg-crumb a{ color:var(--lagoon); text-decoration:none; }
.pg-crumb a:hover{ text-decoration:underline; }
.pg-wrap{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; }
.pg-media .pg-main{ border-radius:22px; overflow:hidden; aspect-ratio:4/5; background:var(--sand-2); box-shadow:0 20px 50px -28px rgba(6,59,69,.5); }
.pg-media .pg-main img, .pg-media .pg-main svg{ width:100%; height:100%; object-fit:cover; display:block; }
.pg-thumbs{ display:flex; gap:10px; margin-top:12px; flex-wrap:wrap; }
.pg-thumb{ width:68px; height:68px; border-radius:12px; overflow:hidden; border:2px solid transparent;
  padding:0; cursor:pointer; background:var(--sand-2); }
.pg-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.pg-thumb.active{ border-color:var(--gold); }
.pg-info h1{ font-family:var(--display); font-size:2.2rem; line-height:1.1; margin:6px 0 10px; color:var(--ocean); }
.pg-rating{ color:var(--gold-deep); margin-bottom:8px; }
.pg-rating small{ color:#7d8e90; font-family:var(--body); margin-left:6px; }
.pg-price{ font-family:var(--display); font-size:1.7rem; color:var(--ocean); margin:8px 0 14px; }
.pg-desc{ color:var(--ink); line-height:1.7; margin-bottom:8px; }
.star{ color:#d9d2c2; }
.star.on{ color:var(--gold); }

/* ===== Avis ===== */
.pg-reviews{ margin-top:64px; max-width:780px; }
.pg-reviews h2{ font-family:var(--display); font-size:1.7rem; color:var(--ocean); margin-bottom:20px; }
.rev{ padding:16px 0; border-bottom:1px solid var(--sand-2); }
.rev-h{ display:flex; align-items:center; gap:10px; margin-bottom:4px; }
.rev-stars{ font-size:.9rem; }
.rev-empty{ color:#7d8e90; }
.rev-form{ margin-top:28px; background:var(--cream); border:1px solid var(--sand-2); border-radius:18px; padding:22px; }
.rev-form h3{ font-family:var(--display); color:var(--ocean); margin-bottom:14px; }
.rev-form textarea{ width:100%; border:1.5px solid var(--sand-2); border-radius:12px; padding:10px 12px;
  font-family:var(--body); resize:vertical; }

@media(max-width:820px){ .pg-wrap{ grid-template-columns:1fr; gap:24px; } }

/* ============================================================
   ESPACE CLIENT
   ============================================================ */
/* Bouton compte (en-tête) */
.account-btn{
  display:flex;align-items:center;gap:8px;
  background:#fff;color:var(--ocean);border:1.5px solid var(--sand-2);
  padding:10px 16px;border-radius:40px;font-weight:600;font-size:.9rem;
  transition:transform .2s,border-color .2s,background .2s;
}
.account-btn:hover{border-color:var(--lagoon);transform:translateY(-1px)}
.account-btn.is-auth{background:var(--ocean);color:var(--sand);border-color:var(--ocean)}
@media(max-width:680px){ .account-btn span.lbl{display:none} .account-btn{padding:11px} }

/* Bouton secondaire foncé */
.btn-ghost-dark{border:1.5px solid var(--sand-2);color:var(--ocean);background:#fff}
.btn-ghost-dark:hover{border-color:var(--ocean);background:var(--sand)}

/* --- Robustesse mot de passe --- */
.pw-hint{margin-top:7px}
.pw-bar{display:block;height:5px;border-radius:6px;background:var(--sand-2);overflow:hidden;margin-bottom:4px}
.pw-bar i{display:block;height:100%;width:0;background:var(--rose);transition:width .25s,background .25s}
.pw-hint small{font-size:.74rem;color:#8a7480}

/* --- Connexion / inscription --- */
.acc-auth{max-width:460px;margin:0 auto}
.acc-auth-head{text-align:center;margin-bottom:24px}
.acc-auth-head h1{font-family:var(--display);font-weight:500;font-size:2.1rem;color:var(--ocean);margin-bottom:8px}
.acc-auth-head p{color:#52656a;font-size:.95rem}
.acc-tabs{display:flex;gap:6px;background:var(--sand);border-radius:40px;padding:5px;margin-bottom:22px}
.acc-tab{flex:1;padding:11px;border-radius:40px;font-weight:600;font-size:.9rem;color:#52656a;transition:.2s}
.acc-tab.active{background:#fff;color:var(--ocean);box-shadow:0 4px 14px -8px rgba(6,59,69,.4)}
.acc-card{background:#fff;border:1px solid var(--sand-2);border-radius:20px;padding:28px;box-shadow:0 6px 22px -16px rgba(6,59,69,.35)}
.acc-form h3{font-family:var(--display);font-weight:500;font-size:1.15rem;color:var(--ocean);margin:22px 0 12px;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.acc-form h3:first-child{margin-top:0}
.acc-form .btn{margin-top:8px}
.field label .opt{font-weight:400;color:#9aa;text-transform:none;letter-spacing:0}
.acc-same{font-size:.78rem;font-weight:500;color:#52656a;display:inline-flex;align-items:center;gap:6px;text-transform:none;letter-spacing:0}
.acc-same input{width:auto;margin:0}
.row3{display:grid;grid-template-columns:1fr 1.4fr 1fr;gap:14px}
@media(max-width:560px){ .row3{grid-template-columns:1fr} }

/* --- Tableau de bord --- */
.acc-top{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:24px}
.acc-hello{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--lagoon);font-weight:600}
.acc-top h1{font-family:var(--display);font-weight:500;font-size:2rem;color:var(--ocean);line-height:1.1;margin-top:4px}
.acc-nav{display:flex;gap:8px;border-bottom:1px solid var(--sand-2);margin-bottom:26px}
.acc-navbtn{padding:12px 4px;margin-bottom:-1px;font-weight:600;font-size:.95rem;color:#7d8e90;border-bottom:2.5px solid transparent;transition:.2s}
.acc-navbtn:hover{color:var(--ocean)}
.acc-navbtn.active{color:var(--ocean);border-bottom-color:var(--gold)}
.acc-navbtn + .acc-navbtn{margin-left:18px}
.acc-loading,.acc-empty{color:#7d8e90;padding:20px 0}
.acc-blank{text-align:center}
.acc-blank p{color:#52656a;margin-bottom:18px}
.acc-form{margin-bottom:20px}

/* --- Commandes --- */
.order-card{background:#fff;border:1px solid var(--sand-2);border-radius:18px;padding:22px;margin-bottom:16px;box-shadow:0 6px 22px -18px rgba(6,59,69,.35)}
.order-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.order-ref{font-family:var(--display);font-size:1.1rem;color:var(--ocean);font-weight:600}
.order-date{display:block;font-size:.8rem;color:#7d8e90;margin-top:2px}
.order-status{font-size:.74rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:6px 12px;border-radius:30px;white-space:nowrap}
.st-pending{background:#fdf3e0;color:#a6781e}
.st-processing{background:#e7f0fb;color:#2563a6}
.st-shipped{background:#eae6fb;color:#5a45a6}
.st-delivered{background:#e4f5ea;color:#1e7a45}
.st-cancelled{background:#fbeae6;color:#b23b2e}
.order-items{color:#52656a;font-size:.9rem;margin:14px 0 8px}
.order-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;border-top:1px solid var(--sand-2);padding-top:14px;margin-top:6px}
.order-total{font-family:var(--display);font-size:1.25rem;color:var(--ocean)}
.order-expand{display:none}
.order-expand.open{display:block;margin-top:16px}
.order-detail-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:18px;align-items:start}
.order-ship h4{font-family:var(--display);font-weight:500;color:var(--ocean);margin-bottom:8px}
.order-ship p{font-size:.88rem;color:#52656a;line-height:1.5}
.order-pay{margin-top:10px;font-size:.82rem;color:#7d8e90;text-transform:capitalize}
@media(max-width:560px){ .order-detail-grid{grid-template-columns:1fr} }

/* --- Suivi (timeline) --- */
.track{display:flex;margin:16px 0 4px}
.track-step{flex:1;text-align:center;position:relative}
.track-dot{display:block;width:16px;height:16px;border-radius:50%;background:var(--sand-2);margin:0 auto 8px;position:relative;z-index:2;transition:.2s}
.track-step::before{content:"";position:absolute;top:7px;left:-50%;width:100%;height:3px;background:var(--sand-2);z-index:1}
.track-step:first-child::before{display:none}
.track-step.done .track-dot{background:var(--gold)}
.track-step.done::before{background:var(--gold)}
.track-step.current .track-dot{box-shadow:0 0 0 4px rgba(201,162,75,.25)}
.track-lbl{font-size:.72rem;color:#7d8e90;font-weight:600}
.track-step.done .track-lbl{color:var(--ocean)}
@media(max-width:560px){ .track-lbl{font-size:.62rem} }

/* ============================================================
   THÈME SALOUVA — en-tête, navigation, accueil (rose & or)
   ============================================================ */

/* ---------- Bandeau d'annonce ---------- */
.topbar{
  background:var(--rose-soft);color:var(--plum);
  font-size:.8rem;font-weight:600;letter-spacing:.06em;text-align:center;padding:9px 16px;
}
.topbar b{color:var(--rose-deep);font-weight:800}

/* ---------- En-tête : recherche | logo | actions ---------- */
header{
  position:sticky;top:0;z-index:60;background:#fff;
  border-bottom:1px solid var(--sand-2);backdrop-filter:none;
}
header .nav{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:20px;height:auto;padding-top:16px;padding-bottom:16px;
}
.hsearch{justify-self:start;display:flex;align-items:center;width:100%;max-width:280px;
  background:#fff;border:1.5px solid var(--sand-2);border-radius:40px;overflow:hidden;transition:border-color .2s}
.hsearch:focus-within{border-color:var(--rose)}
.hsearch input{flex:1;min-width:0;border:none;background:none;padding:11px 16px;font-family:var(--body);font-size:.9rem;color:var(--ink)}
.hsearch input:focus{outline:none}
.hsearch button{flex:none;width:42px;height:42px;display:grid;place-items:center;color:var(--plum)}
.hsearch button:hover{color:var(--rose)}

.logo{justify-self:center;display:flex;align-items:center;gap:11px}
.logo-img{height:72px;width:auto;display:block;border-radius:12px}
.logo .logo-text{flex-direction:column;line-height:1;align-items:center}
.logo .mark{font-family:var(--display);font-size:1.7rem;font-weight:600;letter-spacing:.04em;
  background:linear-gradient(180deg,#E7C56A,var(--gold-deep));-webkit-background-clip:text;background-clip:text;color:transparent}
.logo .sub{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--rose);margin-top:4px}

.nav-actions{justify-self:end;display:flex;align-items:center;gap:22px}
.naction{display:flex;align-items:center;gap:7px;color:var(--plum);font-weight:600;font-size:.82rem;transition:color .2s}
.naction:hover{color:var(--rose)}
.naction .lbl{white-space:nowrap}
.naction.is-auth{color:var(--rose-deep)}
.ic-wrap{position:relative;display:inline-flex}
.naction-count{position:absolute;top:-7px;right:-9px;min-width:18px;height:18px;padding:0 4px;
  background:var(--rose);color:#fff;border-radius:50%;display:grid;place-items:center;
  font-size:.66rem;font-weight:700;line-height:1}
.burger{display:none;width:44px;height:44px;border-radius:12px;color:var(--plum)}

/* ---------- Barre de navigation ---------- */
.mainnav{background:#fff;border-top:1px solid var(--sand-2)}
.mainnav .menu{display:flex;justify-content:center;flex-wrap:wrap;gap:30px;padding:13px 0}
.mainnav .menu a{position:relative;font-size:.82rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--plum);padding:4px 0;transition:color .2s}
.mainnav .menu a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:2px;background:var(--gold);transition:width .25s}
.mainnav .menu a:hover{color:var(--rose)}
.mainnav .menu a:hover::after,.mainnav .menu a.active::after{width:100%}
.mainnav .menu a.active{color:var(--rose)}

/* ---------- Cœur favori sur les cartes ---------- */
.fav-btn{position:absolute;bottom:12px;right:12px;z-index:3;width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.92);color:var(--rose);display:grid;place-items:center;
  box-shadow:0 4px 12px -4px rgba(94,33,56,.4);transition:transform .2s,background .2s}
.fav-btn svg{fill:none;transition:fill .2s}
.fav-btn:hover{transform:scale(1.1)}
.fav-btn.on{background:var(--rose);color:#fff}
.fav-btn.on svg{fill:#fff}

/* ============================================================
   PAGE D'ACCUEIL
   ============================================================ */
/* ---------- Hero ---------- */
.promo-hero{background:linear-gradient(120deg,var(--rose-tint),var(--rose-soft));overflow:hidden}
.promo-hero .wrap{display:grid;grid-template-columns:.95fr 1.15fr;gap:40px;align-items:center;padding:54px 24px 60px}
.ph-text h1{font-family:var(--display);font-weight:600;font-size:clamp(2.4rem,5vw,3.6rem);line-height:1.05;color:var(--gold-deep)}
.ph-text h1 span{display:block}
.ph-text .ph-sign{font-family:var(--display);font-style:italic;color:var(--rose);font-size:clamp(1.6rem,3.5vw,2.2rem);margin-top:6px}
.ph-text .btn{margin-top:26px}
.ph-carousel{position:relative;border-radius:20px;overflow:hidden;box-shadow:var(--shadow);background:#fff}
.ph-slides{display:flex;transition:transform .6s cubic-bezier(.4,0,.2,1)}
.ph-slide{flex:none;width:100%;aspect-ratio:16/10;background:var(--sand-2)}
.ph-slide img{width:100%;height:100%;object-fit:cover}
.ph-slide svg{width:100%;height:100%}
.ph-dots{position:absolute;bottom:14px;left:0;right:0;display:flex;justify-content:center;gap:8px}
.ph-dots b{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.6);cursor:pointer;transition:.2s}
.ph-dots b.on{background:var(--rose);width:22px;border-radius:6px}

/* ---------- Bandeau réassurance ---------- */
.feature-strip{max-width:var(--maxw);margin:-32px auto 0;padding:0 24px;position:relative;z-index:5}
.feature-strip .inner{background:#fff;border:1px solid var(--sand-2);border-radius:18px;
  box-shadow:0 14px 40px -24px rgba(94,33,56,.45);display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:22px 18px}
.feature{display:flex;align-items:center;gap:13px}
.feature .fic{width:42px;height:42px;flex:none;border-radius:12px;background:var(--rose-tint);color:var(--rose);display:grid;place-items:center}
.feature h4{font-size:.9rem;color:var(--plum);font-weight:700;margin-bottom:2px}
.feature p{font-size:.78rem;color:#8a7480;line-height:1.3}
.feature + .feature{border-left:1px solid var(--sand-2);padding-left:22px}

/* ---------- En-têtes de section ---------- */
.sec-title{text-align:center;margin-bottom:34px}
.sec-title h2{font-family:var(--display);font-weight:600;font-size:clamp(1.7rem,3.5vw,2.3rem);
  background:linear-gradient(180deg,#E7C56A,var(--gold-deep));-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block}
.sec-title .deco{display:block;color:var(--gold);font-size:1rem;margin-top:4px;letter-spacing:.3em}
.sec-head-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px;border-bottom:2px solid var(--sand-2);padding-bottom:10px}
.sec-head-row h2{font-family:var(--display);font-weight:600;font-size:1.5rem;color:var(--plum)}
.sec-head-row a{color:var(--rose);font-weight:700;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase}
.sec-head-row a:hover{color:var(--rose-deep)}

/* ---------- Catégories en cercles ---------- */
.cat-circles{display:grid;grid-template-columns:repeat(5,1fr);gap:24px}
.cat-circle{text-align:center}
.cat-circle .disc{display:block;width:100%;max-width:170px;aspect-ratio:1;margin:0 auto 14px;border-radius:50%;overflow:hidden;
  border:4px solid #fff;box-shadow:0 14px 34px -18px rgba(94,33,56,.5);background:var(--rose-tint);position:relative;transition:transform .25s}
.cat-circle .disc img,.cat-circle .disc svg{width:100%;height:100%;object-fit:cover;display:block}
.cat-circle:hover .disc{transform:translateY(-4px)}
.disc-ph{width:100%;height:100%;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--rose-soft),var(--rose));color:#fff;
  font-family:var(--display);font-weight:600;font-size:2.8rem;line-height:1}
.cat-circle h3{font-family:var(--display);font-size:1.1rem;color:var(--plum);text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px}
.cat-circle .voir{display:inline-block;background:var(--rose);color:#fff;font-size:.72rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;padding:7px 20px;border-radius:30px;transition:background .2s}
.cat-circle .voir:hover{background:var(--rose-deep)}

/* ---------- Bannière CTA ---------- */
.banner-cta{margin:0 24px;border-radius:24px;overflow:hidden;
  background:linear-gradient(110deg,var(--rose-soft),var(--rose-tint));
  display:flex;align-items:center;justify-content:space-between;gap:24px;padding:46px 54px;flex-wrap:wrap}
.banner-cta h2{font-family:var(--display);font-weight:600;font-size:clamp(1.8rem,3.5vw,2.6rem);
  background:linear-gradient(180deg,#E7C56A,var(--gold-deep));-webkit-background-clip:text;background-clip:text;color:transparent}
.banner-cta p{color:var(--plum);margin-top:6px;font-size:1.05rem;font-family:var(--display);font-style:italic}

/* ---------- Boutons rose ---------- */
.btn-rose{background:var(--rose);color:#fff}
.btn-rose:hover{background:var(--rose-deep);transform:translateY(-2px);box-shadow:0 14px 30px -12px rgba(224,81,143,.55)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:var(--gold-deep)}

/* ---------- Newsletter (rose) ---------- */
.news{background:var(--rose-soft);text-align:center}
.news h2{color:var(--plum)}
.news p{color:var(--plum)}
.news input{border-color:#fff}
.news .btn{background:var(--rose);color:#fff}
.news .btn:hover{background:var(--rose-deep)}

/* ---------- Pied de page clair ---------- */
footer{background:#fff;color:#8a7480;padding:54px 0 26px;font-size:.9rem;border-top:3px solid var(--rose-soft)}
footer h4{color:var(--rose);font-family:var(--display);font-weight:600;font-size:1.05rem;margin-bottom:16px}
footer a{color:#8a7480}
footer a:hover{color:var(--rose)}
.foot-grid{grid-template-columns:1.5fr 1fr 1fr 1.2fr;border-bottom:1px solid var(--sand-2)}
.foot-logo .mark{font-family:var(--display);font-size:1.7rem;font-weight:600;
  background:linear-gradient(180deg,#E7C56A,var(--gold-deep));-webkit-background-clip:text;background-clip:text;color:transparent}
.foot-logo p{margin-top:12px;max-width:30ch;color:#8a7480}
.socials a{background:var(--rose-tint);color:var(--rose)}
.socials a:hover{background:var(--rose);color:#fff}
.foot-mail{color:var(--rose);font-weight:600}
.foot-bottom{color:#a8929c}
.foot-bottom a{color:#a8929c}.foot-bottom a:hover{color:var(--rose)}
.pay span{background:var(--rose-tint);color:var(--rose-deep);font-weight:700}

/* ---------- Page Favoris ---------- */
.fav-empty{text-align:center;padding:60px 20px;color:#8a7480}
.fav-empty svg{margin:0 auto 16px;color:var(--rose-soft)}
.fav-empty p{margin-bottom:18px}

/* ---------- Pages boutique / catégories ---------- */
.cat-hero{
  position:relative;overflow:hidden;text-align:center;
  background:linear-gradient(120deg,var(--rose-tint),var(--rose-soft));
  color:var(--plum);padding:72px 0 78px;
}
.cat-hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 18% 12%,rgba(255,255,255,.72),transparent 28%),
    radial-gradient(circle at 82% 18%,rgba(201,162,75,.2),transparent 30%);
  pointer-events:none;
}
.cat-hero.has-img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(94,33,56,.76),rgba(224,81,143,.36)),var(--cat-img) center/cover;
  z-index:0;
}
.cat-hero .inner{position:relative;z-index:2}
.cat-hero h1{
  font-family:var(--display);font-weight:600;
  font-size:clamp(2.1rem,5vw,3.5rem);line-height:1.05;
  background:linear-gradient(180deg,#E7C56A,var(--gold-deep));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.cat-hero p{max-width:52ch;margin:16px auto 0;color:#7b5868;font-size:1.05rem}
.cat-hero .crumb{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--rose);font-weight:800;margin-bottom:14px}
.cat-hero.has-img h1,.cat-hero.has-img .crumb{color:#fff;background:none;-webkit-text-fill-color:currentColor;text-shadow:0 3px 18px rgba(0,0,0,.25)}
.cat-hero.has-img p{color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.28)}
.cat-hero .hero-bg,.cat-hero .wave-divider{display:none}

.card{border-color:#f5dbe6;box-shadow:0 12px 28px -24px rgba(94,33,56,.5)}
.card-media{background:var(--rose-tint)}
.card-media img{transition:transform .35s ease}
.card:hover .card-media img{transform:scale(1.035)}

.empty-category{
  grid-column:1/-1;text-align:center;padding:58px 24px;border:1px solid var(--sand-2);
  border-radius:22px;background:linear-gradient(135deg,#fff,var(--rose-tint));
}
.empty-category h2{font-family:var(--display);font-size:1.7rem;color:var(--plum);margin-bottom:8px}
.empty-category p{color:#8a7480;margin:0 auto 20px;max-width:44ch}

/* ---------- Améliorations expérience utilisateur ---------- */
.stock-line{font-size:.78rem;font-weight:700;margin:4px 0 10px}
.stock-line.ok{color:#2f8a50}
.stock-line.low{color:var(--rose-deep)}
.stock-line.out{color:#b23b2e}
.text-link{display:inline-flex;width:max-content;color:var(--rose);font-weight:700;font-size:.88rem;text-decoration:underline;text-underline-offset:3px;margin:4px 0 12px}
.text-link:hover{color:var(--rose-deep)}
.mini-reassure{display:grid;grid-template-columns:1fr;gap:7px;margin:12px 0 14px}
.mini-reassure span{background:var(--rose-tint);color:var(--plum);font-size:.8rem;font-weight:700;border-radius:10px;padding:8px 10px}
.pv.info-only{display:block}
.info-modal{padding:34px;max-width:720px;margin:0 auto}
.info-modal h2{font-family:var(--display);font-size:1.9rem;color:var(--plum);margin-bottom:10px}
.info-modal p{color:#7b5868;margin-bottom:18px}
.info-modal .muted{font-size:.9rem;color:#8a7480;margin-top:14px}
.size-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--sand-2);border-radius:14px;overflow:hidden}
.size-table th,.size-table td{padding:12px 14px;border-bottom:1px solid var(--sand-2);text-align:left}
.size-table th{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--rose);background:var(--rose-tint)}
.size-table tr:last-child td{border-bottom:none}
.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:18px}
.info-grid div,.pg-trust div,.about-values div,.tip-box{background:#fff;border:1px solid var(--sand-2);border-radius:16px;padding:16px}
.info-grid b,.pg-trust b,.about-values b,.tip-box b{display:block;color:var(--plum);font-family:var(--display);font-size:1.05rem;margin-bottom:4px}
.info-grid span,.pg-trust span,.about-values span,.tip-box span{display:block;color:#8a7480;font-size:.9rem;line-height:1.45}
.pg-trust{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:18px 0 10px}
.pg-suggestions{margin-top:56px}
.pg-suggestions .grid-products{grid-template-columns:repeat(3,1fr)}
.info-page{max-width:860px}
.info-page section+section{margin-top:34px}
.info-page h2,.about-page h2{font-family:var(--display);color:var(--plum);font-size:1.9rem;margin-bottom:16px}
.info-page details{background:#fff;border:1px solid var(--sand-2);border-radius:14px;padding:16px 18px;margin-bottom:10px}
.info-page summary{cursor:pointer;font-weight:800;color:var(--plum)}
.info-page details p{color:#7b5868;margin-top:10px}
.about-page{display:grid;grid-template-columns:1.1fr .9fr;gap:42px;align-items:start}
.about-page p{color:#7b5868;margin:12px 0;line-height:1.8}
.about-values{display:grid;gap:14px}
.tip-box{display:flex;gap:10px;align-items:flex-start;margin-top:18px}
.soft-news{position:fixed;right:22px;bottom:22px;z-index:120;width:min(330px,calc(100vw - 44px));
  background:#fff;border:1px solid var(--sand-2);border-top:4px solid var(--rose);border-radius:18px;
  box-shadow:0 22px 60px -28px rgba(94,33,56,.55);padding:18px 18px 16px;transform:translateY(18px);opacity:0;transition:.25s}
.soft-news.show{transform:translateY(0);opacity:1}
.soft-news b{display:block;font-family:var(--display);color:var(--plum);font-size:1.2rem}
.soft-news span{display:block;color:#8a7480;font-size:.9rem;line-height:1.45;margin:4px 24px 12px 0}
.soft-news a{display:inline-flex;background:var(--rose);color:#fff;border-radius:30px;padding:8px 14px;font-weight:800;font-size:.82rem}
.soft-news-x{position:absolute;top:9px;right:10px;width:28px;height:28px;border-radius:50%;color:#9f7b8b;background:var(--rose-tint);font-size:1.2rem;line-height:1}

@media(max-width:820px){
  .pg-trust,.pg-suggestions .grid-products,.info-grid,.about-page{grid-template-columns:1fr}
}

/* ============================================================
   RESPONSIVE — thème SALOUVA
   ============================================================ */
@media(max-width:920px){
  .promo-hero .wrap{grid-template-columns:1fr;gap:28px;padding:40px 24px 48px}
  .feature-strip .inner{grid-template-columns:repeat(2,1fr);gap:18px}
  .feature:nth-child(odd){border-left:none;padding-left:0}
  .cat-circles{grid-template-columns:repeat(3,1fr);gap:18px}
}
@media(max-width:760px){
  header .nav{grid-template-columns:auto 1fr auto;gap:10px}
  .hsearch{display:none}
  .logo-img{height:56px}
  .naction .lbl{display:none}
  .nav-actions{gap:16px}
  .burger{display:grid;place-items:center}
  .mainnav .menu{display:none;flex-direction:column;align-items:center;gap:0;padding:6px 0}
  .mainnav .menu.open{display:flex}
  .mainnav .menu a{width:100%;text-align:center;padding:12px 0;border-bottom:1px solid var(--sand-2)}
}
@media(max-width:560px){
  .feature-strip .inner{grid-template-columns:1fr}
  .feature + .feature{border-left:none;padding-left:0;border-top:1px solid var(--sand-2);padding-top:14px}
  .cat-circles{grid-template-columns:repeat(2,1fr)}
  .banner-cta{padding:34px 26px;text-align:center;justify-content:center}
}

/* ============================================================
   Effet « GlowCard » — halo lumineux qui suit le curseur
   (adapté du composant React, accordé rose → or)
   Les variables --glow-x / --glow-y / --glow-xp sont posées par shop.js
   ============================================================ */
@media (hover:hover) and (pointer:fine){
  .card{ --glow-hue: calc(330 + (var(--glow-xp, 0) * 95)); } /* 330 rose → 425(=65) doré */

  /* Contour lumineux (anneau masqué qui s'illumine près du curseur) */
  .card::before{
    content:""; position:absolute; inset:0; z-index:6; pointer-events:none;
    border-radius:inherit; padding:2.5px;
    background:radial-gradient(180px 180px at calc(var(--glow-x, 50) * 1px) calc(var(--glow-y, 40) * 1px),
      hsl(var(--glow-hue,330) 95% 60% / 1), hsl(var(--glow-hue,330) 95% 60% / 0) 60%);
    -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
            mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite:xor; mask-composite:exclude;
    filter:saturate(1.25) brightness(1.15);
    opacity:0; transition:opacity .35s ease;
  }
  /* Lumière douce sur la carte près du curseur */
  .card::after{
    content:""; position:absolute; inset:0; z-index:5; pointer-events:none; border-radius:inherit;
    background:radial-gradient(230px 230px at calc(var(--glow-x, 50) * 1px) calc(var(--glow-y, 40) * 1px),
      hsl(var(--glow-hue,330) 95% 66% / .20), transparent 60%);
    opacity:0; transition:opacity .35s ease;
  }
  .card:hover::before,
  .card:hover::after{ opacity:1; }

  /* Ombre portée colorée assortie au halo */
  .card:hover{ box-shadow:0 20px 48px -18px hsl(var(--glow-hue,330) 85% 55% / .6); }
}
@media (prefers-reduced-motion:reduce){ .card::before{ transition:none } }

/* ============================================================
   Boutons « Shiny » — bordure dégradée animée (rose & or)
   Adapté du composant ShinyButton (React) en CSS pur
   ============================================================ */
@property --shiny-angle  { syntax:"<angle>";      initial-value:0deg; inherits:false; }
@property --shiny-offset { syntax:"<angle>";      initial-value:0deg; inherits:false; }
@property --shiny-percent{ syntax:"<percentage>"; initial-value:5%;   inherits:false; }
@property --shiny-shine  { syntax:"<color>";      initial-value:#fff; inherits:false; }

.btn-rose, .btn-gold, .news .btn{
  --shiny-bg:var(--rose);
  --shiny-edge:var(--gold);
  isolation:isolate; position:relative; overflow:hidden;
  border:2.5px solid transparent;
  background:
    linear-gradient(var(--shiny-bg), var(--shiny-bg)) padding-box,
    conic-gradient(from calc(var(--shiny-angle) - var(--shiny-offset)),
      transparent,
      var(--shiny-edge) var(--shiny-percent),
      var(--shiny-shine) calc(var(--shiny-percent) * 2),
      var(--shiny-edge) calc(var(--shiny-percent) * 3),
      transparent calc(var(--shiny-percent) * 4)) border-box;
  animation: shiny-rotate 3s linear infinite;
  transition:--shiny-percent 700ms cubic-bezier(.25,1,.5,1),
             --shiny-offset 700ms cubic-bezier(.25,1,.5,1),
             transform .25s ease, box-shadow .25s ease;
}
.btn-gold{ --shiny-bg:var(--gold); --shiny-edge:#ffffff; --shiny-shine:#ffe9b0; }
.news .btn{ --shiny-bg:var(--rose); --shiny-edge:var(--gold); }

/* Reflet intérieur qui balaie le bouton */
.btn-rose::after, .btn-gold::after, .news .btn::after{
  content:""; position:absolute; inset:0; z-index:-1; pointer-events:none; border-radius:inherit;
  background:linear-gradient(-50deg, transparent, rgba(255,255,255,.5), transparent);
  -webkit-mask:radial-gradient(circle at bottom, transparent 40%, #000);
          mask:radial-gradient(circle at bottom, transparent 40%, #000);
  opacity:.5; animation: shiny-sweep 4.5s linear infinite;
}

/* Survol : l'arc lumineux s'élargit, le fond s'assombrit légèrement */
.btn-rose:hover, .news .btn:hover{ --shiny-bg:var(--rose-deep); }
.btn-gold:hover{ --shiny-bg:var(--gold-deep); }
.btn-rose:hover, .btn-gold:hover, .news .btn:hover{
  --shiny-percent:20%; --shiny-offset:95deg;
  transform:translateY(-2px); box-shadow:0 14px 30px -12px rgba(94,33,56,.4);
}

@keyframes shiny-rotate{ to{ --shiny-angle:360deg } }
@keyframes shiny-sweep { to{ rotate:360deg } }

@media (prefers-reduced-motion:reduce){
  .btn-rose, .btn-gold, .news .btn,
  .btn-rose::after, .btn-gold::after, .news .btn::after{ animation:none }
}

/* ============================================================
   Menu de navigation — remplissage animé au survol (rose)
   Adapté du composant NavMenu (React) : fond + bordures haut/bas + texte blanc
   ============================================================ */
@media (min-width:761px){
  .mainnav .menu{ gap:14px; }
  .mainnav .menu a{
    position:relative; z-index:0; padding:8px 16px; overflow:hidden;
    transition:color .3s ease;
  }
  /* on neutralise l'ancien soulignement doré */
  .mainnav .menu a::after{ display:none; }
  /* remplissage rose qui descend, bordé haut & bas */
  .mainnav .menu a::before{
    content:""; position:absolute; inset:0; z-index:-1;
    background:var(--rose);
    border-top:2px solid var(--rose-deep);
    border-bottom:2px solid var(--rose-deep);
    transform:scaleY(0); transform-origin:top; opacity:0;
    transition:transform .3s ease, opacity .3s ease;
  }
  .mainnav .menu a:hover,
  .mainnav .menu a.active{ color:#fff; }
  .mainnav .menu a:hover::before,
  .mainnav .menu a.active::before{ transform:scaleY(1); opacity:1; }
}

/* ============================================================
   Options e-commerce — étoiles, quantité, partage, cadeau,
   cookies, témoignages, contact
   ============================================================ */
/* Étoiles sur les cartes */
.card-stars{display:flex;align-items:center;gap:2px;font-size:.86rem;margin:-2px 0 2px}
.card-stars .star{color:#e3cf8f}
.card-stars .star.on{color:var(--gold)}
.card-stars span{margin-left:5px;font-size:.72rem;color:#9a8a90;font-family:var(--body)}

/* Fiche produit : quantité + ajout */
.pg-buy{display:flex;align-items:stretch;gap:12px;margin-top:6px}
.qty-pick{display:inline-flex;align-items:center;border:1.5px solid var(--sand-2);border-radius:40px;background:#fff;flex:none}
.qty-pick button{width:42px;height:48px;display:grid;place-items:center;color:var(--ocean);font-size:1.25rem}
.qty-pick button:hover{color:var(--rose)}
.qty-pick span{min-width:30px;text-align:center;font-weight:700;color:var(--ocean)}
.pg-buy .btn{flex:1}

/* Partage produit */
.pg-share{display:flex;align-items:center;gap:10px;margin-top:14px}
.pg-share span{font-size:.82rem;color:#8a7480;font-weight:600}
.pg-share a,.pg-share button{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;
  background:var(--rose-tint);color:var(--rose);transition:.2s}
.pg-share a:hover,.pg-share button:hover{background:var(--rose);color:#fff;transform:translateY(-2px)}

/* Emballage cadeau (checkout) */
.gift-box{border:1.5px dashed var(--rose-soft);border-radius:14px;padding:12px 14px;margin-bottom:16px;background:var(--rose-tint)}
.gift-toggle{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--plum);font-size:.92rem;cursor:pointer}
.gift-toggle small{color:var(--rose-deep);font-weight:700}
.gift-box textarea{width:100%;margin-top:10px;border:1.5px solid var(--sand-2);border-radius:10px;padding:9px 11px;font-family:var(--body);resize:vertical}

/* Bandeau cookies (RGPD) */
.cookie-bar{position:fixed;left:50%;bottom:18px;transform:translateX(-50%) translateY(140%);
  width:min(680px,calc(100% - 32px));z-index:140;background:#fff;border:1px solid var(--sand-2);
  border-radius:18px;box-shadow:0 22px 60px -24px rgba(94,33,56,.5);padding:18px 20px;
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;transition:transform .35s cubic-bezier(.4,0,.2,1)}
.cookie-bar.show{transform:translateX(-50%) translateY(0)}
.cookie-bar p{flex:1;min-width:220px;font-size:.85rem;color:#52454b;margin:0}
.cookie-actions{display:flex;gap:8px;flex-wrap:wrap}
.btn-mini.ghost{background:#fff;color:var(--plum);border:1.5px solid var(--sand-2)}
.btn-mini.ghost:hover{border-color:var(--rose);color:var(--rose)}

/* Témoignages */
.testimonials-sec{background:var(--rose-tint)}
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tcard{background:#fff;border:1px solid var(--sand-2);border-radius:18px;padding:22px;
  box-shadow:0 8px 26px -20px rgba(94,33,56,.45)}
.tcard .tstars{color:var(--gold);font-size:1rem;margin-bottom:8px}
.tcard blockquote{margin:0 0 12px;color:#3c2f34;font-size:.95rem;line-height:1.6;font-style:italic}
.tcard figcaption{font-size:.84rem;color:#8a7480}
.tcard figcaption b{color:var(--plum)}
@media(max-width:860px){ .testimonials{grid-template-columns:1fr 1fr} }
@media(max-width:560px){ .testimonials{grid-template-columns:1fr} .pg-share{flex-wrap:wrap} }

/* ============================================================
   Assistant / chat bot
   ============================================================ */
#scChat{position:fixed;right:22px;bottom:22px;z-index:135}
.chat-fab{width:58px;height:58px;border-radius:50%;background:var(--rose);color:#fff;display:grid;place-items:center;
  box-shadow:0 14px 34px -10px rgba(224,81,143,.6);transition:transform .2s,background .2s}
.chat-fab:hover{transform:translateY(-2px);background:var(--rose-deep)}
.chat-fab .i-close{display:none}
#scChat.open .chat-fab .i-open{display:none}
#scChat.open .chat-fab .i-close{display:block}
.chat-panel{position:absolute;right:0;bottom:72px;width:344px;max-width:calc(100vw - 32px);
  height:474px;max-height:calc(100vh - 130px);background:var(--cream);border:1px solid var(--sand-2);
  border-radius:20px;box-shadow:var(--shadow);display:none;flex-direction:column;overflow:hidden;animation:pop .25s ease}
#scChat.open .chat-panel{display:flex}
.chat-head{background:linear-gradient(120deg,var(--rose),var(--rose-deep));color:#fff;padding:15px 18px;display:flex;align-items:center;justify-content:space-between}
.chat-head b{font-family:var(--display);font-size:1.12rem;display:block;line-height:1.1}
.chat-head span{font-size:.76rem;opacity:.9}
.chat-x{color:#fff;font-size:1.05rem;padding:4px;line-height:1}
.chat-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;background:var(--rose-tint)}
.chat-msg{max-width:86%;padding:10px 13px;border-radius:15px;font-size:.88rem;line-height:1.45}
.chat-msg.bot{background:#fff;color:var(--ink);border:1px solid var(--sand-2);border-bottom-left-radius:4px;align-self:flex-start}
.chat-msg.me{background:var(--rose);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}
.chat-msg a{color:var(--rose);font-weight:700;text-decoration:underline;text-underline-offset:2px}
.chat-msg.me a{color:#fff}
.chat-chips{display:flex;flex-wrap:wrap;gap:7px;align-self:flex-start;max-width:100%}
.chat-chip{background:#fff;border:1.5px solid var(--rose-soft);color:var(--rose-deep);font-size:.8rem;font-weight:600;padding:7px 12px;border-radius:20px;transition:.15s}
.chat-chip:hover{background:var(--rose);color:#fff;border-color:var(--rose)}
.chat-input{display:flex;gap:8px;padding:11px;border-top:1px solid var(--sand-2);background:var(--cream)}
.chat-input input{flex:1;border:1.5px solid var(--sand-2);border-radius:30px;padding:10px 14px;font-family:var(--body);font-size:.9rem;background:#fff;color:var(--ink)}
.chat-input input:focus{outline:none;border-color:var(--rose)}
.chat-input button{width:42px;height:42px;border-radius:50%;background:var(--rose);color:#fff;display:grid;place-items:center;flex:none;transition:background .2s}
.chat-input button:hover{background:var(--rose-deep)}
@media(max-width:480px){ #scChat{right:14px;bottom:14px} .chat-panel{width:calc(100vw - 28px)} }
/* mode sombre */
html[data-theme="dark"] .chat-msg.bot,
html[data-theme="dark"] .chat-chip,
html[data-theme="dark"] .chat-input input{ background:#241319;color:var(--ink);border-color:var(--sand-2) }

/* Page contact */
.contact-wrap{display:grid;grid-template-columns:.8fr 1.2fr;gap:32px;align-items:start}
.contact-info h3{font-family:var(--display);font-weight:500;font-size:1.4rem;color:var(--ocean);margin-bottom:16px}
.contact-info ul{list-style:none;display:flex;flex-direction:column;gap:14px;margin-bottom:20px}
.contact-info li{display:flex;flex-direction:column}
.contact-info li b{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--rose);margin-bottom:2px}
.contact-info li a,.contact-info li span{color:#3c2f34}
.contact-socials a{background:var(--rose-tint);color:var(--rose)}
.contact-form .btn{margin-top:6px}
@media(max-width:760px){ .contact-wrap{grid-template-columns:1fr;gap:22px} }

/* ============================================================
   Filtres à facettes (panneau latéral boutique/catégorie)
   ============================================================ */
.shop-layout{display:grid;grid-template-columns:236px 1fr;gap:28px;align-items:start}
.shop-main .grid-products{grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}
.filters-side{position:sticky;top:90px;background:#fff;border:1px solid var(--sand-2);border-radius:16px;
  padding:6px 18px 16px;max-height:calc(100vh - 110px);overflow:auto}
.filters-head{display:flex;align-items:center;justify-content:space-between;padding:14px 0 4px}
.filters-head h3{font-family:var(--display);font-size:1.25rem;color:var(--plum)}
.filters-clear{color:var(--rose);font-weight:600;font-size:.82rem;text-decoration:underline;text-underline-offset:2px}
.facet{padding:14px 0;border-top:1px solid var(--sand-2)}
.facet h4{font-size:.92rem;color:var(--plum);font-weight:700;margin-bottom:9px}
.fopt{display:flex;align-items:center;gap:9px;padding:5px 0;font-size:.9rem;color:var(--ink);cursor:pointer}
.fopt input[type=checkbox]{width:17px;height:17px;accent-color:var(--rose);flex:none;cursor:pointer}
.fopt>span{color:#9a8a90;font-size:.82rem;margin-left:auto}
.fopt-color i{width:17px;height:17px;border-radius:5px;border:1px solid var(--sand-2);flex:none}
.price-range{display:flex;align-items:center;gap:8px}
.price-range input{width:78px;padding:8px 10px;border:1.5px solid var(--sand-2);border-radius:9px;font-size:.86rem;background:#fff;color:var(--ink)}
.price-range span{color:#9a8a90}
.shop-topbar{display:flex;align-items:center;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.shop-count{color:#7d8e90;font-size:.9rem;font-weight:500}
.shop-sort{margin-left:auto;font-size:.85rem;color:var(--plum);font-weight:600;display:flex;align-items:center;gap:6px}
.shop-sort select{padding:8px 14px;border-radius:30px;border:1.5px solid var(--sand-2);font-family:var(--body);font-weight:500;color:var(--ink);background:#fff}
.filters-toggle{display:none}
.filters-overlay{display:none}
html[data-theme="dark"] .filters-side,
html[data-theme="dark"] .price-range input,
html[data-theme="dark"] .shop-sort select{background:var(--sand);color:var(--ink);border-color:var(--sand-2)}
@media(max-width:860px){
  .shop-layout{grid-template-columns:1fr}
  .shop-main .grid-products{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
  .filters-side{position:fixed;left:0;top:0;bottom:0;width:286px;max-width:86vw;z-index:121;border-radius:0;
    max-height:none;transform:translateX(-100%);transition:transform .3s;box-shadow:30px 0 60px -20px rgba(0,0,0,.4)}
  .filters-side.open{transform:none}
  .filters-toggle{display:inline-flex;align-items:center;gap:6px;background:var(--ocean);color:#fff;padding:9px 16px;border-radius:30px;font-weight:600;font-size:.85rem}
}
