/* =========================================================
   Café Luciani · démo MarsAI · design system
   Heritage marseillais (1863), version 2026 : clair, premium, mobile-first.
   ========================================================= */
:root{
  --cream:#f7f1e6;
  --cream-2:#fcf8f0;
  --paper:#fffdf8;
  --espresso:#1f1510;
  --espresso-2:#2c1d14;
  --ink:#2a1c13;
  --muted:#6f5c4b;
  --muted-2:#8a7763;
  --gold:#b3863a;
  --gold-deep:#8c6620;
  --gold-soft:#cda85f;
  --rouge:#8c2f20;
  --green:#4d6b3f;
  --line:rgba(31,21,16,.12);
  --line-soft:rgba(31,21,16,.07);
  --shadow-s:0 1px 2px rgba(31,21,16,.05);
  --shadow:0 1px 2px rgba(31,21,16,.04),0 14px 40px rgba(31,21,16,.08);
  --shadow-l:0 30px 70px rgba(31,21,16,.16);
  --r:16px;
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--cream);color:var(--ink);
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:16.5px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4,.serif{font-family:"Cormorant Garamond",Georgia,serif;font-weight:600;color:var(--espresso);letter-spacing:.2px;line-height:1.08}
h1{font-size:clamp(34px,5.6vw,60px);font-weight:700;margin:0 0 16px}
h2{font-size:clamp(28px,4vw,42px);margin:0 0 14px}
h3{font-size:24px;margin:0 0 8px}
p{margin:0 0 14px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.narrow{max-width:780px}
.eyebrow{font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);margin:0 0 14px;display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:24px;height:1.5px;background:var(--gold)}
.lead{font-size:19px;color:var(--muted);line-height:1.6}
section{padding:74px 0;position:relative}
.center{text-align:center}
.center .eyebrow{justify-content:center}
.muted{color:var(--muted)}
.dark{background:var(--espresso);color:#efe6d8}
.dark h1,.dark h2,.dark h3{color:#fbf3e6}
.dark p,.dark .lead{color:#cdbfae}
.dark .eyebrow{color:var(--gold-soft)}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;background:var(--gold);color:#241608;font-weight:700;font-size:15.5px;padding:14px 26px;border-radius:999px;border:none;box-shadow:0 10px 26px rgba(179,134,58,.30);transition:transform .15s ease,box-shadow .15s ease;letter-spacing:.01em}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(179,134,58,.36)}
.btn.dark{background:var(--espresso);color:#fbf3e6;box-shadow:0 10px 26px rgba(31,21,16,.25)}
.btn.ghost{background:transparent;color:var(--espresso);border:1.5px solid var(--line);box-shadow:none}
.btn.ghost:hover{border-color:var(--gold);background:var(--cream-2)}
.btn.sm{padding:10px 18px;font-size:14px}
.btn.block{display:flex;width:100%}
.dark .btn.ghost{color:#fbf3e6;border-color:rgba(255,255,255,.25)}

/* ===== HEADER ===== */
.topbar{background:var(--espresso);color:#e9dcc9;font-size:12.5px;letter-spacing:.04em}
.topbar .wrap{display:flex;justify-content:center;gap:26px;align-items:center;height:38px;text-align:center}
.topbar b{color:var(--gold-soft)}
.topbar .tb-x{color:#cbb89f}
header.nav{position:sticky;top:0;z-index:60;background:rgba(247,241,230,.92);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line-soft)}
.nav .wrap{display:flex;align-items:center;gap:20px;height:74px}
.nav .logo{display:flex;align-items:center;gap:11px;font-family:"Cormorant Garamond",serif;font-weight:700;font-size:23px;color:var(--espresso);letter-spacing:.5px}
.nav .logo img{height:42px;width:auto}
.nav .est{font-family:"Inter",sans-serif;font-size:9.5px;font-weight:700;letter-spacing:.18em;color:var(--gold-deep);border:1px solid var(--gold);border-radius:999px;padding:2px 7px}
.nav .links{display:flex;gap:26px;margin-left:14px}
.nav .links a{font-size:14.5px;font-weight:600;color:var(--ink);position:relative;padding:4px 0;transition:color .15s}
.nav .links a:hover{color:var(--gold-deep)}
.nav .links a.active{color:var(--gold-deep)}
.nav .links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--gold);border-radius:2px}
.nav .actions{margin-left:auto;display:flex;align-items:center;gap:14px}
.nav .icon-btn{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:var(--paper);color:var(--espresso);position:relative;transition:.15s}
.nav .icon-btn:hover{border-color:var(--gold);color:var(--gold-deep)}
.nav .cart-count{position:absolute;top:-4px;right:-4px;background:var(--rouge);color:#fff;font-size:11px;font-weight:700;min-width:18px;height:18px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 4px;font-family:"Inter",sans-serif}
.nav .burger{display:none}
@media(max-width:940px){
  .nav .links{display:none;position:absolute;top:74px;left:0;right:0;background:var(--cream);flex-direction:column;gap:0;padding:8px 22px 18px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  .nav .links.open{display:flex}
  .nav .links a{padding:14px 0;border-bottom:1px solid var(--line-soft);font-size:17px}
  .nav .burger{display:inline-flex}
}

/* ===== HERO (home) ===== */
.hero{position:relative;min-height:78vh;display:flex;align-items:center;color:#fbf3e6;overflow:hidden}
.hero .bg{position:absolute;inset:0;z-index:0}
.hero .bg img{width:100%;height:100%;object-fit:cover}
.hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(20,13,9,.82) 0%,rgba(20,13,9,.55) 45%,rgba(20,13,9,.2) 100%)}
.hero .inner{position:relative;z-index:2;max-width:640px;padding:60px 0}
.hero h1{color:#fff}
.hero h1 em{font-style:italic;color:var(--gold-soft)}
.hero .lead{color:#e7dccb;max-width:520px}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.hero .trust{display:flex;gap:26px;margin-top:38px;flex-wrap:wrap}
.hero .trust .t{display:flex;flex-direction:column}
.hero .trust .n{font-family:"Cormorant Garamond",serif;font-size:30px;font-weight:700;color:#fff;line-height:1}
.hero .trust .l{font-size:12.5px;color:#cbb89f;margin-top:3px;letter-spacing:.03em}

.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.stars{color:var(--gold);letter-spacing:1px;font-size:14px;display:inline-flex;gap:1px}
.stars .s-empty{color:rgba(179,134,58,.32)}

/* ===== category tiles ===== */
.cats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.cat{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:3/4;box-shadow:var(--shadow-s);display:block}
.cat img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.cat:hover img{transform:scale(1.06)}
.cat .lab{position:absolute;inset:auto 0 0 0;padding:22px 18px 16px;background:linear-gradient(0deg,rgba(20,13,9,.85),transparent);color:#fff}
.cat .lab h3{color:#fff;margin:0;font-size:22px}
.cat .lab span{font-size:13px;color:#e7dccb}

/* ===== product card ===== */
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.pgrid.cols3{grid-template-columns:repeat(3,1fr)}
.pcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-s);transition:transform .18s ease,box-shadow .18s ease;display:flex;flex-direction:column;position:relative}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.pcard .pimg{aspect-ratio:1/1;background:#f1e7d6;position:relative;overflow:hidden}
.pcard .pimg img{width:100%;height:100%;object-fit:cover;mix-blend-mode:multiply}
.pcard .badges{position:absolute;top:12px;left:12px;display:flex;flex-direction:column;gap:6px}
.badge{font-size:11px;font-weight:700;letter-spacing:.05em;padding:4px 9px;border-radius:999px;text-transform:uppercase}
.badge.bio{background:#e7efe1;color:var(--green)}
.badge.abo{background:#f3e7d2;color:var(--gold-deep)}
.badge.star{background:var(--espresso);color:var(--gold-soft)}
.badge.signature{background:var(--rouge);color:#fff}
.pcard .pbody{padding:16px 16px 18px;display:flex;flex-direction:column;flex:1}
.pcard .porigin{font-size:12px;color:var(--muted-2);letter-spacing:.04em;text-transform:uppercase;font-weight:600}
.pcard h3{font-size:21px;margin:3px 0 4px}
.pcard .prate{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--muted);margin-bottom:8px}
.pcard .intensity{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);margin-bottom:12px}
.pcard .dots{display:inline-flex;gap:3px}
.pcard .dot{width:8px;height:8px;border-radius:50%;background:var(--line)}
.pcard .dot.on{background:var(--espresso-2)}
.pcard .pfoot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px}
.pcard .price{font-family:"Cormorant Garamond",serif;font-size:24px;font-weight:700;color:var(--espresso)}
.pcard .price small{font-size:13px;color:var(--muted);font-weight:600;font-family:"Inter",sans-serif}
.pcard .add{width:44px;height:44px;border-radius:50%;background:var(--espresso);color:var(--gold-soft);border:none;font-size:20px;display:inline-flex;align-items:center;justify-content:center;transition:.15s;flex:0 0 auto}
.pcard .add:hover{background:var(--gold);color:#241608;transform:scale(1.08)}

/* filters */
.shoplayout{display:grid;grid-template-columns:240px 1fr;gap:34px;align-items:start}
.filters{position:sticky;top:96px}
.filters h4{font-size:13px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted-2);font-family:"Inter",sans-serif;font-weight:700;margin:0 0 12px}
.filters .fgroup{padding:16px 0;border-top:1px solid var(--line-soft)}
.fopt{display:flex;align-items:center;gap:9px;padding:6px 0;font-size:14.5px;color:var(--ink);cursor:pointer}
.fopt input{accent-color:var(--gold-deep);width:16px;height:16px}
.shophead{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;flex-wrap:wrap;gap:12px}
.chiprow{display:flex;gap:8px;flex-wrap:wrap}
.fchip{font-size:13px;font-weight:600;padding:7px 14px;border-radius:999px;border:1px solid var(--line);background:var(--paper);color:var(--ink);transition:.15s}
.fchip.active{background:var(--espresso);color:var(--cream);border-color:var(--espresso)}

/* ===== product detail ===== */
.pdp{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.pdp .gallery{position:sticky;top:96px}
.pdp .gmain{background:var(--cream-2);border:1px solid var(--line);border-radius:var(--r);aspect-ratio:1/1;overflow:hidden;display:flex;align-items:center;justify-content:center}
.pdp .gmain img{width:86%;height:86%;object-fit:contain;mix-blend-mode:multiply}
.pdp .gthumbs{display:flex;gap:10px;margin-top:12px}
.pdp .gthumbs .th{width:74px;height:74px;border-radius:12px;border:1px solid var(--line);background:var(--cream-2);overflow:hidden;cursor:pointer;opacity:.7}
.pdp .gthumbs .th.on,.pdp .gthumbs .th:hover{opacity:1;border-color:var(--gold)}
.pdp .gthumbs .th img{width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply}
.pdp .pinfo .porigin{font-size:13px;color:var(--gold-deep);font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.pdp .pinfo h1{font-size:clamp(32px,4vw,46px);margin:6px 0 10px}
.pdp .raterow{display:flex;align-items:center;gap:10px;margin-bottom:18px;font-size:14px;color:var(--muted)}
.aroma{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0}
.aroma .a{background:var(--cream-2);border:1px solid var(--line-soft);border-radius:999px;padding:7px 14px;font-size:13.5px;color:var(--ink)}
.specrow{display:flex;gap:26px;margin:20px 0;flex-wrap:wrap}
.spec .sl{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-2);font-weight:700}
.spec .sv{font-family:"Cormorant Garamond",serif;font-size:22px;font-weight:700;color:var(--espresso)}
.buybox{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:22px;margin-top:22px;box-shadow:var(--shadow-s)}
.buytabs{display:flex;gap:8px;background:var(--cream-2);border-radius:12px;padding:5px;margin-bottom:18px}
.buytab{flex:1;text-align:center;padding:11px 8px;border-radius:9px;font-weight:600;font-size:14px;color:var(--muted);border:none;background:transparent;position:relative}
.buytab.on{background:var(--paper);color:var(--espresso);box-shadow:var(--shadow-s)}
.buytab .save{display:block;font-size:11px;color:var(--green);font-weight:700;margin-top:2px}
.optline{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.optline .ol{font-size:14px;font-weight:600;color:var(--ink)}
.segbtns{display:flex;gap:6px;flex-wrap:wrap}
.seg{padding:8px 14px;border-radius:9px;border:1px solid var(--line);background:var(--paper);font-size:13.5px;font-weight:600;color:var(--ink)}
.seg.on{background:var(--espresso);color:var(--cream);border-color:var(--espresso)}
.buyprice{display:flex;align-items:baseline;gap:10px;margin:16px 0}
.buyprice .bp{font-family:"Cormorant Garamond",serif;font-size:38px;font-weight:700;color:var(--espresso)}
.buyprice .bo{font-size:17px;color:var(--muted-2);text-decoration:line-through}
.buyprice .bsave{font-size:13px;font-weight:700;color:var(--green);background:#e7efe1;padding:3px 9px;border-radius:999px}
.reassure{display:flex;gap:18px;flex-wrap:wrap;margin-top:16px;font-size:13px;color:var(--muted)}
.reassure span{display:inline-flex;align-items:center;gap:6px}

/* reviews */
.reviews{display:grid;grid-template-columns:300px 1fr;gap:40px;align-items:start}
.rsum{background:var(--cream-2);border:1px solid var(--line-soft);border-radius:var(--r);padding:26px;text-align:center;position:sticky;top:96px}
.rsum .big{font-family:"Cormorant Garamond",serif;font-size:64px;font-weight:700;color:var(--espresso);line-height:1}
.rbar{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);margin-top:6px}
.rbar .track{flex:1;height:6px;background:var(--line);border-radius:3px;overflow:hidden}
.rbar .fill{height:100%;background:var(--gold)}
.rlist{display:flex;flex-direction:column;gap:18px}
.rev{border-bottom:1px solid var(--line-soft);padding-bottom:18px}
.rev .rh{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.rev .av{width:38px;height:38px;border-radius:50%;background:var(--espresso);color:var(--gold-soft);display:flex;align-items:center;justify-content:center;font-weight:700;font-family:"Cormorant Garamond",serif}
.rev .rn{font-weight:700;color:var(--espresso);font-size:15px}
.rev .rd{font-size:12px;color:var(--muted-2)}
.rev .verified{font-size:11px;color:var(--green);font-weight:600;margin-left:auto}

/* ===== subscription builder ===== */
.subwrap{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:start}
.step{margin-bottom:26px}
.step .sn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--gold-deep);color:#fff;font-weight:700;font-size:14px;font-family:"Cormorant Garamond",serif;margin-right:10px}
.step h3{display:inline;font-size:23px;vertical-align:middle}
.choices{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px}
.choice{border:1.5px solid var(--line);border-radius:12px;padding:14px 12px;text-align:center;background:var(--paper);transition:.15s;font-size:14px;font-weight:600;color:var(--ink)}
.choice.on{border-color:var(--gold);background:var(--cream-2);box-shadow:0 0 0 3px rgba(179,134,58,.14)}
.choice small{display:block;font-weight:500;color:var(--muted);font-size:12px;margin-top:3px}
.subsummary{background:var(--espresso);color:#efe6d8;border-radius:var(--r);padding:28px;position:sticky;top:96px;box-shadow:var(--shadow-l)}
.subsummary h3{color:#fbf3e6}
.subsummary .row{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:14.5px;color:#d7c9b6}
.subsummary .row b{color:#fbf3e6}
.subsummary .total{display:flex;justify-content:space-between;align-items:baseline;margin:16px 0 4px}
.subsummary .total .tv{font-family:"Cormorant Garamond",serif;font-size:34px;font-weight:700;color:var(--gold-soft)}

/* ===== quiz ===== */
.quizcard{max-width:680px;margin:0 auto;background:var(--paper);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);padding:40px;min-height:420px;position:relative;overflow:hidden}
.qprogress{height:5px;background:var(--line);border-radius:3px;overflow:hidden;margin-bottom:30px}
.qprogress .qf{height:100%;background:var(--gold);transition:width .35s ease;width:0}
.qstep{display:none;animation:fade .4s ease}
.qstep.on{display:block}
.qopts{display:grid;gap:12px;margin-top:22px}
.qopt{display:flex;align-items:center;gap:14px;padding:16px 18px;border:1.5px solid var(--line);border-radius:14px;background:var(--cream-2);transition:.15s;text-align:left;font-size:16px;font-weight:600;color:var(--ink)}
.qopt:hover{border-color:var(--gold);transform:translateX(3px)}
.qopt .qe{font-size:24px}
.qresult{display:none;text-align:center;animation:fade .4s ease}
.qresult.on{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ===== timeline / histoire ===== */
.timeline{position:relative;max-width:760px;margin:0 auto;padding-left:34px}
.timeline::before{content:"";position:absolute;left:8px;top:6px;bottom:6px;width:2px;background:linear-gradient(var(--gold),var(--line))}
.tev{position:relative;padding:0 0 34px 4px}
.tev::before{content:"";position:absolute;left:-34px;top:4px;width:16px;height:16px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px var(--cream)}
.tev .ty{font-family:"Cormorant Garamond",serif;font-size:30px;font-weight:700;color:var(--gold-deep);line-height:1}
.tev h3{margin:4px 0 4px}
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split img{border-radius:var(--r);box-shadow:var(--shadow);width:100%}

/* ===== generic cards / values ===== */
.vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.vcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:26px;box-shadow:var(--shadow-s)}
.vcard .vi{width:48px;height:48px;border-radius:12px;background:var(--cream-2);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:14px}
.vcard h3{font-size:21px}
.vcard p{font-size:15px;color:var(--muted);margin:0}

/* banner strip */
.strip{background:var(--espresso-2);color:#efe6d8;text-align:center}
.strip .quote{font-family:"Cormorant Garamond",serif;font-style:italic;font-size:clamp(23px,3.2vw,33px);line-height:1.3;color:#fbf3e6;max-width:840px;margin:0 auto 14px}
.strip .by{font-size:14px;color:var(--gold-soft);letter-spacing:.04em}

/* forms */
.form{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:30px;box-shadow:var(--shadow)}
.field{margin-bottom:16px}
.field label{display:block;font-size:13.5px;font-weight:600;color:var(--ink);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:11px;background:var(--cream-2);font-family:inherit;font-size:15px;color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);background:var(--paper)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* newsletter */
.news{background:linear-gradient(120% 100% at 0% 0%,rgba(179,134,58,.14),transparent 60%),var(--espresso);border-radius:24px;padding:48px;text-align:center;color:#efe6d8}
.news h2{color:#fbf3e6}
.news .ninput{display:flex;gap:10px;max-width:440px;margin:22px auto 0}
.news .ninput input{flex:1;padding:14px 18px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);color:#fff;font-size:15px}
.news .ninput input::placeholder{color:#bdae9b}

/* ===== footer ===== */
footer.site{background:#160e09;color:#bdae9b;padding:56px 0 30px;font-size:14.5px}
footer.site .cols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px}
footer.site h4{color:#fbf3e6;font-family:"Inter",sans-serif;font-size:13px;text-transform:uppercase;letter-spacing:.12em;margin:0 0 14px}
footer.site a{color:#cbb89f;display:block;padding:4px 0}
footer.site a:hover{color:var(--gold-soft)}
footer.site .flogo{font-family:"Cormorant Garamond",serif;font-size:26px;font-weight:700;color:#fbf3e6}
footer.site .fdesc{color:#9a8a76;max-width:280px;margin-top:10px;font-size:14px}
footer.site .fbottom{margin-top:36px;border-top:1px solid rgba(255,255,255,.08);padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:12.5px;color:#7c6c59}
.demobadge{position:fixed;left:14px;bottom:14px;z-index:80;background:var(--rouge);color:#fff;font-size:11.5px;font-weight:700;letter-spacing:.04em;padding:7px 13px;border-radius:999px;box-shadow:var(--shadow);text-transform:uppercase}
.demobadge b{color:#fff}

/* ===== conseiller IA chat ===== */
.chat-fab{position:fixed;right:20px;bottom:20px;z-index:90;display:flex;align-items:center;gap:10px;background:var(--espresso);color:#fbf3e6;border:none;border-radius:999px;padding:12px 18px 12px 12px;box-shadow:var(--shadow-l);font-weight:600;font-size:14.5px;transition:transform .15s}
.chat-fab:hover{transform:translateY(-2px)}
.chat-fab .bean{width:34px;height:34px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.chat-fab .pulse-d{position:absolute;top:10px;left:34px;width:9px;height:9px;border-radius:50%;background:#5fbf6a;box-shadow:0 0 0 0 rgba(95,191,106,.6);animation:cp 2s infinite}
@keyframes cp{70%{box-shadow:0 0 0 8px rgba(95,191,106,0)}100%{box-shadow:0 0 0 0 rgba(95,191,106,0)}}
.chat-panel{position:fixed;right:20px;bottom:20px;z-index:95;width:380px;max-width:calc(100vw - 32px);height:600px;max-height:calc(100vh - 40px);background:var(--cream);border-radius:20px;box-shadow:var(--shadow-l);display:none;flex-direction:column;overflow:hidden;border:1px solid var(--line)}
.chat-panel.open{display:flex;animation:cpop .25s ease}
@keyframes cpop{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
.chat-head{background:var(--espresso);color:#fbf3e6;padding:16px 18px;display:flex;align-items:center;gap:12px}
.chat-head .bean{width:40px;height:40px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.chat-head .ct{font-family:"Cormorant Garamond",serif;font-size:19px;font-weight:700}
.chat-head .cs{font-size:12px;color:#9fd6a4;display:flex;align-items:center;gap:5px}
.chat-head .cs::before{content:"";width:7px;height:7px;border-radius:50%;background:#5fbf6a}
.chat-head .cx{margin-left:auto;background:transparent;border:none;color:#cbb89f;font-size:22px;line-height:1;cursor:pointer}
.chat-body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px;background:
  radial-gradient(120% 60% at 100% 0%,rgba(179,134,58,.08),transparent 50%),var(--cream)}
.msg{max-width:84%;padding:11px 14px;border-radius:15px;font-size:14.5px;line-height:1.5;animation:fade .3s ease}
.msg.bot{background:var(--paper);border:1px solid var(--line);color:var(--ink);align-self:flex-start;border-bottom-left-radius:5px}
.msg.user{background:var(--espresso);color:#f3e9d8;align-self:flex-end;border-bottom-right-radius:5px}
.msg.bot a{color:var(--gold-deep);font-weight:600;text-decoration:underline}
.reco{display:flex;gap:11px;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:11px;margin-top:2px;align-self:flex-start;max-width:90%;align-items:center}
.reco img{width:52px;height:52px;border-radius:9px;object-fit:cover;background:#f1e7d6;mix-blend-mode:multiply}
.reco .rt{font-weight:700;color:var(--espresso);font-size:14.5px}
.reco .rp{font-size:13px;color:var(--muted)}
.reco .rlink{font-size:12.5px;color:var(--gold-deep);font-weight:600}
.typing{display:flex;gap:4px;padding:12px 14px;background:var(--paper);border:1px solid var(--line);border-radius:15px;align-self:flex-start;width:54px}
.typing span{width:7px;height:7px;border-radius:50%;background:var(--muted-2);animation:tb 1.2s infinite}
.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}
@keyframes tb{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}
.chat-chips{display:flex;gap:7px;flex-wrap:wrap;padding:0 14px 8px}
.chat-chip{font-size:12.5px;font-weight:600;padding:7px 12px;border-radius:999px;border:1px solid var(--line);background:var(--paper);color:var(--gold-deep);transition:.15s}
.chat-chip:hover{background:var(--cream-2);border-color:var(--gold)}
.chat-input{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--line);background:var(--cream-2)}
.chat-input input{flex:1;border:1px solid var(--line);border-radius:999px;padding:11px 16px;font-size:14.5px;font-family:inherit;background:var(--paper);color:var(--ink)}
.chat-input input:focus{outline:none;border-color:var(--gold)}
.chat-input button{width:42px;height:42px;border-radius:50%;background:var(--gold);color:#241608;border:none;font-size:18px;flex:0 0 auto}

/* toast */
.toast{position:fixed;left:50%;bottom:30px;transform:translateX(-50%) translateY(20px);background:var(--espresso);color:#fbf3e6;padding:13px 22px;border-radius:999px;font-size:14.5px;font-weight:600;box-shadow:var(--shadow-l);opacity:0;pointer-events:none;transition:.25s;z-index:200}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* responsive */
@media(max-width:940px){
  section{padding:54px 0}
  .cats{grid-template-columns:repeat(2,1fr)}
  .pgrid,.pgrid.cols3{grid-template-columns:repeat(2,1fr)}
  .shoplayout{grid-template-columns:1fr}
  .filters{position:static;display:none}
  .pdp{grid-template-columns:1fr;gap:28px}
  .pdp .gallery{position:static}
  .reviews{grid-template-columns:1fr}
  .rsum{position:static}
  .subwrap{grid-template-columns:1fr}
  .subsummary{position:static}
  .split{grid-template-columns:1fr;gap:24px}
  .vgrid{grid-template-columns:1fr}
  footer.site .cols{grid-template-columns:1fr 1fr}
  .frow{grid-template-columns:1fr}
}
@media(max-width:560px){
  .pgrid,.pgrid.cols3,.cats{grid-template-columns:1fr 1fr}
  .hero .trust{gap:18px}
  .news,.quizcard{padding:26px}
  footer.site .cols{grid-template-columns:1fr}
  .chat-panel{right:8px;bottom:8px}
}
