/* =====================================================================
   WELYE — Design System (charte centralisée)
   ---------------------------------------------------------------------
   👉 POUR RE-SKINNER TOUT LE SITE : ne touchez QUE le bloc :root ci-dessous.
   Les couleurs de marque (--brand-*) sont des PLACEHOLDERS en attendant
   le logo Welye. La couleur "punchy" validée = vert lime électrique.
   ===================================================================== */
:root{
  /* --- Marque WELYE (bleu exact du logo : #30A8D8) --- */
  --brand-900:#08222E;   /* teal-navy profond (dérivé du bleu) */
  --brand-700:#0E5C7E;
  --brand-600:#1E8FC4;   /* bleu plus soutenu (hover) */
  --brand-500:#30A8D8;   /* ✅ BLEU LOGO WELYE exact */
  --brand-300:#7CD0EE;
  --acc:#178FC4;         /* bleu lisible pour texte/lien sur fond clair */

  /* --- Accent = BLEU WELYE et ses déclinaisons (les noms "lime" sont conservés
     pour compatibilité interne, mais les valeurs sont désormais BLEUES) --- */
  --lime:#30A8D8;        /* bleu logo (accent vif) */
  --lime-deep:#1B7CA8;   /* bleu soutenu (texte/lien sur fond clair) */
  --lime-soft:#DCF1F9;   /* bleu très clair (aplats doux) */
  --blue-700:#155E80;
  --blue-900:#0B3A52;

  /* --- Neutres (légèrement teintés teal pour rester dans l'univers Welye) --- */
  --ink:#081820;         /* encre profonde teal-noir */
  --ink-soft:#0E2832;
  --paper:#F3F7F8;
  --paper-2:#E4EDF0;
  --line:rgba(8,24,32,.09);
  --white:#FFFFFF;
  --muted:#5C6669;

  /* --- Dégradés (charte) --- */
  --grad-ink:linear-gradient(150deg,#081820 0%,#0E3242 60%,#081820 100%);
  --grad-brand:linear-gradient(135deg,var(--brand-900),var(--brand-500));
  --grad-brand-lime:linear-gradient(120deg,var(--brand-500),var(--lime));
  --grad-lime:linear-gradient(120deg,var(--lime),var(--lime-deep));
  --grad-glow:radial-gradient(820px 520px at 80% 4%,rgba(48,168,216,.30),transparent 60%),
              radial-gradient(680px 480px at 6% 96%,rgba(124,208,238,.18),transparent 55%);
  --grad-cta:linear-gradient(135deg,#0B3A52 0%,#155E80 45%,#30A8D8 100%);
  --grad-btn:linear-gradient(135deg,#30A8D8,#1B7CA8);

  --radius:22px; --radius-sm:14px; --radius-lg:34px;
  --maxw:1200px;
  --ease:cubic-bezier(.16,1,.3,1);
  --shadow:0 24px 50px rgba(10,11,13,.10);
}

/* ===================== Base ===================== */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Jost',system-ui,sans-serif;background:var(--paper);color:var(--ink);
  -webkit-font-smoothing:antialiased;line-height:1.55;overflow-x:hidden}
h1,h2,h3,h4,.display{font-family:'Jost',sans-serif;font-weight:700;line-height:1.04;letter-spacing:-.02em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.wrap-narrow{max-width:820px;margin:0 auto;padding:0 24px}
section{position:relative}
.center{text-align:center}
.lime-text{color:var(--lime-deep)}

/* placeholder image blocks (en attendant les vraies photos Welye) */
.ph{background:linear-gradient(135deg,var(--paper-2),#dfe2db);position:relative;overflow:hidden;border-radius:var(--radius)}
.ph::after{content:attr(data-label);position:absolute;inset:0;display:grid;place-items:center;
  font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#9aa09a}
.ph.dark{background:linear-gradient(135deg,#1a1d22,#0f1115)}
.ph.dark::after{color:#4a4e54}

/* ===================== Reveal ===================== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ===================== Header ===================== */
header{position:fixed;top:0;left:0;right:0;z-index:60;transition:.4s var(--ease)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
header.scrolled{background:rgba(245,246,244,.85);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
header.light .brand{color:var(--white)}
header.light nav a.link{color:rgba(255,255,255,.85)}
header.light .lang{border-color:rgba(255,255,255,.4)}
header.light .lang button{color:rgba(255,255,255,.75)}
header.scrolled.light .brand,header.scrolled .brand{color:var(--ink)}
header.scrolled.light nav a.link,header.scrolled nav a.link{color:var(--ink)}
header.scrolled.light .lang,header.scrolled .lang{border-color:rgba(0,0,0,.18)}
header.scrolled.light .lang button,header.scrolled .lang button{color:var(--muted)}
.brand{display:flex;align-items:center}
.brand .logo{height:30px;width:auto;display:block}
.brand .logo-white{display:none}
header.light .brand .logo-blue{display:none}
header.light .brand .logo-white{display:block}
header.scrolled.light .brand .logo-blue{display:block}
header.scrolled.light .brand .logo-white{display:none}
nav ul{display:flex;gap:28px;list-style:none;align-items:center}
nav a.link{font-size:14.5px;font-weight:500;color:var(--ink);transition:.3s}
nav a.link:hover,nav a.link.active{color:var(--lime-deep)}
.nav-right{display:flex;align-items:center;gap:16px}
.lang{display:flex;border:1px solid rgba(0,0,0,.18);border-radius:30px;overflow:hidden;font-size:13px;font-weight:600}
.lang button{background:none;border:none;color:var(--muted);padding:6px 13px;cursor:pointer;font-family:inherit;font-weight:600;transition:.3s}
.lang button.active{background:var(--lime);color:#fff}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:currentColor;display:block;transition:.3s}
header.light .burger{color:#fff}
header.scrolled .burger{color:var(--ink)}

/* mobile menu */
.mmenu{position:fixed;inset:0;z-index:55;background:var(--ink);color:#fff;display:none;flex-direction:column;justify-content:center;padding:40px;gap:6px}
.mmenu.open{display:flex}
.mmenu a{font-family:'Jost';font-weight:700;font-size:30px;padding:10px 0;color:#fff}
.mmenu a:hover{color:var(--lime)}
.mmenu .close{position:absolute;top:24px;right:24px;font-size:34px;background:none;border:none;color:#fff;cursor:pointer}

/* ===================== Buttons ===================== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 22px;border-radius:40px;font-weight:600;
  font-size:14.5px;cursor:pointer;border:none;transition:.35s var(--ease);font-family:inherit;white-space:nowrap}
.btn-lime{background:var(--grad-btn);color:#fff}
.btn-lime:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(27,124,168,.42)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(10,11,13,.25)}
.btn-white{background:#fff;color:var(--ink)}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(0,0,0,.18)}
.btn-ghost{background:transparent;border:1.5px solid rgba(255,255,255,.5);color:#fff}
.btn-ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn-line{background:transparent;border:1.5px solid var(--ink);color:var(--ink)}
.btn-line:hover{background:var(--ink);color:#fff}
.btn-lg{padding:16px 28px;font-size:16px}

/* ===================== Hero (home) ===================== */
.hero{background:var(--ink);color:#fff;padding:170px 0 110px;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:var(--grad-glow)}
.grain{position:absolute;inset:0;opacity:.5;mix-blend-mode:overlay;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E")}
.hero .wrap{position:relative;z-index:2}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:600;letter-spacing:.04em;
  text-transform:uppercase;color:#fff;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);
  padding:8px 16px;border-radius:30px;margin-bottom:28px}
.eyebrow .pulse{width:8px;height:8px;border-radius:50%;background:var(--lime);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,122,41,.55)}70%{box-shadow:0 0 0 10px rgba(255,122,41,0)}100%{box-shadow:0 0 0 0 rgba(255,122,41,0)}}
.hero h1{font-size:clamp(44px,7vw,92px);font-weight:800;max-width:14ch}
.hero h1 em{font-style:normal;color:var(--lime)}
.hero p.lead{font-size:clamp(17px,2vw,21px);color:rgba(255,255,255,.72);max-width:50ch;margin:26px 0 36px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-meta{display:flex;gap:34px;margin-top:54px;flex-wrap:wrap}
.hero-meta .n{font-family:'Jost';font-size:30px;font-weight:700;display:block}
.hero-meta .l{font-size:13.5px;color:rgba(255,255,255,.6)}

/* ===================== Page hero (inner) ===================== */
.phero{background:var(--ink);color:#fff;padding:150px 0 70px;position:relative;overflow:hidden}
.phero::before{content:"";position:absolute;inset:0;background:var(--grad-glow)}
.phero .wrap{position:relative;z-index:2}
.phero h1{font-size:clamp(38px,5.5vw,68px);font-weight:800;max-width:18ch}
.phero p{color:rgba(255,255,255,.72);font-size:clamp(16px,2vw,20px);max-width:56ch;margin-top:20px}
.breadcrumb{display:flex;gap:8px;align-items:center;font-size:13.5px;color:rgba(255,255,255,.55);margin-bottom:26px}
.breadcrumb a:hover{color:var(--lime)}
.breadcrumb .sep{opacity:.5}

/* ===================== Marquee ===================== */
.marquee{background:var(--lime);color:var(--ink);padding:15px 0;overflow:hidden;white-space:nowrap}
.marquee-track{display:inline-flex;gap:46px;animation:scroll 28s linear infinite;
  font-family:'Jost';font-weight:700;font-size:17px}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ===================== Sections ===================== */
.sec{padding:100px 0}
.sec-sm{padding:70px 0}
.sec-head{max-width:680px;margin-bottom:54px}
.sec-head.center{margin-left:auto;margin-right:auto}
.tag{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--acc);margin-bottom:14px;display:block}
.sec-head h2{font-size:clamp(32px,4.6vw,54px)}
.sec-head p{color:var(--muted);font-size:18px;margin-top:16px;max-width:56ch}
.sec-head.center p{margin-left:auto;margin-right:auto}

/* ===================== Cards / product grid ===================== */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.card{background:var(--white);border-radius:var(--radius);padding:30px;min-height:280px;display:flex;
  flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;
  border:1px solid var(--line);transition:.5s var(--ease);cursor:pointer}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card .ico{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;font-size:25px;background:var(--paper-2);transition:.5s}
.card:hover .ico{background:var(--lime);transform:rotate(-8deg)}
.card h3{font-size:23px;margin:22px 0 8px}
.card p{color:var(--muted);font-size:14.5px}
.card .arrow{position:absolute;top:28px;right:28px;font-size:20px;opacity:0;transform:translateX(-6px);transition:.45s var(--ease);color:var(--acc)}
.card:hover .arrow{opacity:1;transform:none}
.card.feature{background:var(--ink);color:#fff;border:none}
.card.feature .ico{background:rgba(255,255,255,.1)}
.card.feature p{color:rgba(255,255,255,.6)}
.card.feature .badge{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--lime)}

/* product catalog card with image */
.pcard{background:var(--white);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);
  transition:.5s var(--ease);display:flex;flex-direction:column}
.pcard:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pcard .pimg{height:200px}
.pcard .pbody{padding:24px}
.pcard h3{font-size:21px;margin-bottom:8px}
.pcard p{color:var(--muted);font-size:14px;margin-bottom:16px}
.pcard .plink{font-weight:600;font-size:14px;color:var(--acc);display:inline-flex;gap:6px;align-items:center}
.pcard:hover .plink{gap:10px}

/* filter chips */
.chips{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:40px}
.chip{padding:9px 18px;border-radius:30px;border:1px solid var(--line);background:#fff;font-size:14px;
  font-weight:500;cursor:pointer;transition:.3s}
.chip:hover{border-color:var(--ink)}
.chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ===================== Salons feature ===================== */
.salons{background:var(--ink);color:#fff;border-radius:var(--radius-lg);overflow:hidden;
  display:grid;grid-template-columns:1.1fr .9fr;position:relative}
.salons::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 400px at 90% 10%,rgba(255,122,41,.22),transparent 55%)}
.salons-txt{padding:62px;position:relative;z-index:2}
.salons-txt h2{font-size:clamp(30px,4vw,46px);margin:16px 0 18px}
.salons-txt p{color:rgba(255,255,255,.72);font-size:17px;max-width:42ch;margin-bottom:30px}
.salons-list{list-style:none;display:grid;gap:14px;margin-bottom:34px}
.salons-list li{display:flex;gap:12px;align-items:flex-start;font-size:15.5px;color:rgba(255,255,255,.86)}
.salons-list .chk{color:var(--lime);font-weight:800;flex-shrink:0}
.salons-visual{position:relative;z-index:2;display:grid;place-items:center;padding:40px}
.rollup{width:200px;height:340px;background:linear-gradient(160deg,#fff,#ece7dc);border-radius:14px 14px 6px 6px;
  box-shadow:0 40px 80px rgba(0,0,0,.5);position:relative;transform:rotate(3deg);padding:26px 20px}
.rollup .rh{font-family:'Jost';font-weight:800;font-size:26px;color:var(--ink);line-height:1}
.rollup .ra{color:var(--lime-deep)}
.rollup .rbar{height:7px;width:60%;background:var(--lime-deep);border-radius:4px;margin:16px 0}
.rollup .rtxt{height:7px;background:#d9d3c6;border-radius:4px;margin:9px 0}
.rollup .rtxt.s{width:80%}
.rollup .foot{position:absolute;bottom:18px;left:20px;right:20px;height:54px;border-radius:8px;background:var(--grad-brand)}
.rollup-base{width:240px;height:16px;background:#3a3a44;border-radius:6px;margin-top:-4px}

/* ===================== Steps / timeline ===================== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:s}
.step{padding:30px 26px;background:var(--white);border-radius:var(--radius);border:1px solid var(--line);position:relative}
.step::before{counter-increment:s;content:"0" counter(s);font-family:'Jost';font-weight:800;
  font-size:46px;color:var(--paper-2);line-height:1;display:block;margin-bottom:14px}
.step h3{font-size:19px;margin-bottom:8px}
.step p{color:var(--muted);font-size:14px}

/* ===================== Reviews ===================== */
.reviews{background:var(--ink-soft);color:#fff;border-radius:var(--radius-lg);padding:64px}
.rev-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:40px}
.gscore{display:flex;align-items:center;gap:16px}
.gscore .num{font-family:'Jost';font-size:54px;font-weight:800;line-height:1}
.stars{color:var(--lime);font-size:20px;letter-spacing:2px}
.gsub{font-size:14px;color:rgba(255,255,255,.6)}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.rev{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:26px}
.rev .stars{font-size:15px;margin-bottom:12px}
.rev p{font-size:14.5px;color:rgba(255,255,255,.82);margin-bottom:16px}
.rev .who{display:flex;align-items:center;gap:11px}
.rev .av{width:36px;height:36px;border-radius:50%;background:var(--grad-lime);color:var(--ink);
  display:grid;place-items:center;font-weight:700;font-size:14px}
.rev .who b{font-size:14px}
.rev .who span{font-size:12.5px;color:rgba(255,255,255,.5);display:block}

/* ===================== CTA band ===================== */
.cta{background:var(--grad-cta);color:#fff;border-radius:var(--radius-lg);padding:72px;text-align:center;position:relative;overflow:hidden}
.cta::after{content:"";position:absolute;inset:0;background:radial-gradient(620px 360px at 18% 130%,rgba(48,168,216,.45),transparent)}
.cta h2{font-size:clamp(32px,5vw,58px);position:relative;z-index:2;max-width:18ch;margin:0 auto}
.cta p{position:relative;z-index:2;font-size:18px;opacity:.85;margin:18px auto 34px;max-width:48ch}
.cta .btn-row{position:relative;z-index:2;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ===================== Stats / values ===================== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat .n{font-family:'Jost';font-size:clamp(38px,5vw,58px);font-weight:800;background:var(--grad-brand);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.stat .l{color:var(--muted);font-size:15px;margin-top:6px}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.value{padding:32px;border-radius:var(--radius);background:#fff;border:1px solid var(--line)}
.value .ico{font-size:30px;margin-bottom:16px}
.value h3{font-size:21px;margin-bottom:10px}
.value p{color:var(--muted);font-size:15px}
.split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.split .ph{height:420px}

/* ===================== Product detail ===================== */
.pd{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:start}
.pd-gallery .ph{height:440px;margin-bottom:14px}
.pd-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.pd-thumbs .ph{height:90px;margin:0;border-radius:var(--radius-sm);cursor:pointer}
.pd-info h1{font-size:clamp(30px,4vw,46px);margin:10px 0 16px}
.pd-info .desc{color:var(--muted);font-size:17px;margin-bottom:26px}
.pd-feats{list-style:none;display:grid;gap:12px;margin-bottom:30px}
.pd-feats li{display:flex;gap:12px;font-size:15px}
.pd-feats .chk{color:var(--acc);font-weight:800}
.spec{width:100%;border-collapse:collapse;margin:20px 0 34px}
.spec th,.spec td{text-align:left;padding:14px 0;border-bottom:1px solid var(--line);font-size:15px}
.spec th{color:var(--muted);font-weight:500;width:40%}
.pd-cta{display:flex;gap:12px;flex-wrap:wrap;padding:24px;background:var(--paper-2);border-radius:var(--radius)}

/* ===================== FAQ accordion ===================== */
.faq{max-width:820px;margin:0 auto}
.qa{border-bottom:1px solid var(--line)}
.qa button{width:100%;text-align:left;background:none;border:none;padding:24px 0;font-family:'Jost';
  font-weight:600;font-size:19px;cursor:pointer;display:flex;justify-content:space-between;gap:20px;color:var(--ink)}
.qa .plus{transition:.3s;color:var(--acc);font-size:24px}
.qa.open .plus{transform:rotate(45deg)}
.qa .ans{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.qa .ans p{color:var(--muted);font-size:15.5px;padding-bottom:24px}

/* ===================== Forms (devis / contact) ===================== */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:7px}
.field.full{grid-column:1 / -1}
.field label{font-size:13.5px;font-weight:600;color:var(--ink)}
.field input,.field select,.field textarea{font-family:inherit;font-size:15px;padding:13px 16px;border:1px solid var(--line);
  border-radius:12px;background:#fff;transition:.25s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--lime-deep);box-shadow:0 0 0 3px rgba(255,122,41,.25)}
.field textarea{resize:vertical;min-height:120px}
.dropzone{border:2px dashed var(--line);border-radius:14px;padding:28px;text-align:center;color:var(--muted);
  font-size:14px;cursor:pointer;transition:.3s}
.dropzone:hover{border-color:var(--lime-deep);background:rgba(255,122,41,.06)}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--muted)}
.consent input{margin-top:3px}

/* contact info */
.cinfo{display:grid;gap:22px}
.cinfo .row{display:flex;gap:16px;align-items:flex-start}
.cinfo .ci-ico{width:46px;height:46px;border-radius:13px;background:var(--lime);display:grid;place-items:center;font-size:20px;flex-shrink:0}
.cinfo .row b{display:block;font-family:'Jost';font-size:18px}
.cinfo .row span{color:var(--muted);font-size:15px}

/* ===================== Portfolio ===================== */
.masonry{columns:3;column-gap:18px}
.masonry .item{break-inside:avoid;margin-bottom:18px;border-radius:var(--radius);overflow:hidden;position:relative;cursor:pointer}
.masonry .item .ph{border-radius:var(--radius)}
.masonry .item.t1 .ph{height:300px}
.masonry .item.t2 .ph{height:220px}
.masonry .item.t3 .ph{height:360px}
.masonry .cap{position:absolute;left:0;right:0;bottom:0;padding:20px;background:linear-gradient(transparent,rgba(0,0,0,.7));
  color:#fff;opacity:0;transition:.4s}
.masonry .item:hover .cap{opacity:1}
.masonry .cap b{font-family:'Jost';font-size:18px}
.masonry .cap span{font-size:13px;opacity:.8;display:block}

/* ===================== Resources / blog ===================== */
.rcard{background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);transition:.5s var(--ease)}
.rcard:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.rcard .ph{height:190px;border-radius:0}
.rcard .rbody{padding:24px}
.rcard .meta{font-size:12.5px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--acc);margin-bottom:10px}
.rcard h3{font-size:20px;margin-bottom:10px}
.rcard p{color:var(--muted);font-size:14px}

/* ===================== Legal prose ===================== */
.prose{max-width:760px;margin:0 auto}
.prose h2{font-size:26px;margin:38px 0 14px}
.prose p,.prose li{color:var(--muted);font-size:15.5px;margin-bottom:12px}
.prose ul{padding-left:20px}
.prose a{color:var(--acc);font-weight:600}

/* ===================== Footer ===================== */
footer{background:var(--ink);color:rgba(255,255,255,.7);padding:70px 0 30px;margin-top:90px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.1)}
footer .brand{color:#fff;margin-bottom:16px}
footer .brand .logo-dot{box-shadow:14px 0 0 var(--brand-300),28px 0 0 #fff}
footer h4{color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:16px;font-family:'Jost';font-weight:600}
footer ul{list-style:none;display:grid;gap:10px}
footer ul a{font-size:14.5px;color:rgba(255,255,255,.6);transition:.3s}
footer ul a:hover{color:var(--lime)}
.foot-bottom{display:flex;justify-content:space-between;padding-top:24px;font-size:13px;color:rgba(255,255,255,.45);flex-wrap:wrap;gap:10px}
.foot-bottom a:hover{color:var(--lime)}
.foot-contact b{color:#fff;font-size:17px;font-family:'Jost'}

/* ===================== Mobile sticky bar ===================== */
.mobile-bar{display:none}

/* ===================== Responsive ===================== */
@media(max-width:980px){
  .pd{grid-template-columns:1fr;gap:30px}
  .split{grid-template-columns:1fr;gap:30px}
  .split .ph{height:300px}
}
@media(max-width:900px){
  nav ul,.nav-right .btn,.nav-right .lang{display:none}
  .burger{display:flex}
  .grid,.grid-4,.steps,.rev-grid,.values,.stats{grid-template-columns:1fr 1fr}
  .salons{grid-template-columns:1fr}
  .salons-visual{display:none}
  .salons-txt{padding:40px}
  .reviews,.cta{padding:44px 28px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .masonry{columns:2}
  .form-grid{grid-template-columns:1fr}
}
@media(max-width:600px){
  .grid,.grid-2,.grid-4,.steps,.rev-grid,.values,.stats,.foot-grid{grid-template-columns:1fr}
  .masonry{columns:1}
  .hero{padding:140px 0 80px}
  .mobile-bar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:60;background:var(--white);
    box-shadow:0 -4px 20px rgba(0,0,0,.12);padding:10px;gap:10px}
  .mobile-bar a{flex:1;justify-content:center}
  footer{padding-bottom:90px}
}


/* ===================== Lucide icons ===================== */
.btn svg{width:18px;height:18px;flex-shrink:0}
.card .ico svg,.value .ico svg{width:26px;height:26px}
.ci-ico svg{width:21px;height:21px}
p svg,label svg,.pd-info svg{width:16px;height:16px;vertical-align:-3px}
.salons-list svg{width:16px;height:16px}

/* ===================== Méga-menu produits ===================== */
.has-mega{position:static}
.mega{position:absolute;top:100%;left:50%;width:min(1180px,96vw);z-index:70;
  padding-top:16px;                 /* PONT invisible : empêche la disparition au survol */
  transform:translateX(-50%);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .22s var(--ease),visibility .22s}
.has-mega:hover .mega,.has-mega:focus-within .mega{opacity:1;visibility:visible;pointer-events:auto}
.mega-inner{background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;
  box-shadow:0 34px 90px rgba(8,24,32,.22);display:grid;
  grid-template-columns:repeat(5,1fr)}
.mega-col{padding:24px 18px;border-right:1px solid var(--line)}
.mega-col:nth-child(5){border-right:none}
.mega h5{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;
  color:var(--ink);margin-bottom:14px;display:flex;align-items:center;gap:9px}
.mega h5 .mh-ico{width:30px;height:30px;border-radius:9px;background:var(--lime-soft);
  display:grid;place-items:center;color:var(--blue-700);flex-shrink:0}
.mega h5 .mh-ico svg{width:16px;height:16px}
.mega ul{list-style:none;display:grid;gap:1px}
.mega ul a{font-size:13px;color:var(--muted);font-weight:500;transition:.18s;display:flex;
  align-items:center;gap:8px;padding:6px 9px;border-radius:8px}
.mega ul a::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--line);transition:.18s;flex-shrink:0}
.mega ul a:hover{color:var(--ink);background:var(--paper)}
.mega ul a:hover::before{background:var(--lime)}
.mega-foot{grid-column:1/-1;background:var(--grad-cta);color:#fff;display:flex;align-items:center;
  justify-content:space-between;gap:14px;padding:16px 24px;flex-wrap:wrap}
.mega-foot b{font-family:'Jost';font-size:15.5px}
.mega-foot span.sub{font-size:13px;color:rgba(255,255,255,.72)}
.mega-foot .btn{background:#fff;color:var(--blue-900)}
header{will-change:background}
@media(max-width:1180px){.mega-inner{grid-template-columns:repeat(3,1fr)}}
@media(max-width:900px){.mega{display:none!important}}

/* ===================== Bandeau clients ===================== */
.clients{padding:54px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff}
.clients .clabel{text-align:center;font-size:13px;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted);margin-bottom:28px}
.client-row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:18px 48px}
.client-logo{font-family:'Jost';font-weight:700;font-size:21px;letter-spacing:.02em;color:#9aa3a8;
  filter:grayscale(1);opacity:.85;transition:.3s;white-space:nowrap}
.client-logo:hover{color:var(--ink);opacity:1}
.client-logo.serif{font-family:Georgia,'Times New Roman',serif;font-weight:600;letter-spacing:.12em;text-transform:uppercase;font-size:17px}
.client-logo img{height:34px;width:auto;filter:grayscale(1);opacity:.8;transition:.3s}
.client-logo img:hover{filter:none;opacity:1}

/* ===================== Illustrations produits (SVG animés) ===================== */
.cill{width:100%;height:190px;object-fit:contain;background:linear-gradient(160deg,#F4F9FB,#E7F1F6);
  border-radius:var(--radius-sm);padding:14px;margin-bottom:6px}
.card .cill{height:150px}
.pd-gallery .cill-main{width:100%;height:430px;object-fit:contain;background:linear-gradient(160deg,#F4F9FB,#E7F1F6);
  border-radius:var(--radius);padding:30px}

/* ===================== Bandeau téléphone / devis immédiat ===================== */
.phone-band{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;
  background:var(--ink);color:#fff;border-radius:var(--radius);padding:26px 30px}
.phone-band .pb-txt{font-size:15px;color:rgba(255,255,255,.75)}
.phone-band a.pb-num{font-family:'Jost';font-weight:800;font-size:clamp(24px,4vw,34px);color:var(--lime);
  display:inline-flex;align-items:center;gap:10px}
.phone-band a.pb-num svg{width:26px;height:26px}
.phone-band a.pb-num:hover{color:#fff}

/* ===================== Page Conseils PAO ===================== */
.pao-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:44px;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;margin-bottom:26px}
.pao-card:nth-child(even){direction:rtl}
.pao-card:nth-child(even)>*{direction:ltr}
.pao-card h3{font-size:clamp(22px,3vw,30px);margin-bottom:14px;display:flex;align-items:center;gap:12px}
.pao-card h3 svg{width:26px;height:26px;color:var(--lime-deep)}
.pao-card p{color:var(--muted);font-size:15.5px;margin-bottom:10px}
.pao-card .do-dont{display:grid;gap:8px;margin-top:14px}
.pao-card .do-dont span{font-size:14px;display:flex;gap:9px;align-items:flex-start}
.pao-card .do{color:#1B7F4D;font-weight:600}
.pao-card .dont{color:#C2453A;font-weight:600}
.pao-visual{background:linear-gradient(160deg,#F2F7F9,#E7F0F4);border-radius:var(--radius);
  padding:26px;display:grid;place-items:center;min-height:280px}
.pao-visual svg{width:100%;max-width:380px;height:auto}
@media(max-width:900px){.pao-card{grid-template-columns:1fr;padding:28px}}

/* --- Animations des schémas PAO --- */
@keyframes bleedPulse{0%,100%{opacity:.25}50%{opacity:.9}}
@keyframes cutLine{0%{stroke-dashoffset:40}100%{stroke-dashoffset:0}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes shimmer{0%{transform:translateX(-120%)}100%{transform:translateX(220%)}}
@keyframes pixelate{0%,40%{opacity:1}60%,100%{opacity:0}}


/* --- CTA : adaptation des boutons sur fond bleu foncé --- */
.cta .btn-dark{background:#fff;color:var(--ink)}
.cta .btn-dark:hover{box-shadow:0 14px 30px rgba(0,0,0,.25)}
.cta .btn-line{border-color:rgba(255,255,255,.6);color:#fff;background:transparent}
.cta .btn-line:hover{background:rgba(255,255,255,.14);color:#fff}
.cta .btn-lime{background:#fff;color:var(--blue-900)}
.cta .btn-lime:hover{box-shadow:0 14px 30px rgba(0,0,0,.25)}


/* ===================== Trust bar (remplace le marquee) ===================== */
.trustbar{background:#fff;border-bottom:1px solid var(--line)}
.trust-row{display:flex;flex-wrap:wrap;justify-content:space-between;gap:18px 28px;padding:20px 24px}
.trust-item{display:flex;align-items:center;gap:10px;font-size:14.5px;font-weight:600;color:var(--ink)}
.trust-item svg{width:20px;height:20px;color:var(--lime-deep)}
@media(max-width:760px){.trust-row{justify-content:flex-start}}

/* ===================== Grille clients ===================== */
.client-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:34px 26px;align-items:center;justify-items:center}
.client-grid .client-logo{font-size:20px;color:#9aa7ad;filter:grayscale(1);opacity:.9;transition:.3s;white-space:nowrap;font-family:'Jost',sans-serif;font-weight:600;text-align:center}
.client-grid .client-logo.serif{font-family:Georgia,'Times New Roman',serif}
.client-grid .client-logo.up{text-transform:uppercase}
.client-grid .client-logo.low{text-transform:lowercase}
.client-grid .client-logo.it{font-style:italic}
.client-grid .client-logo.sp{letter-spacing:.14em}
.client-grid .client-logo:hover{color:var(--ink);opacity:1}
@media(max-width:1000px){.client-grid{grid-template-columns:repeat(4,1fr);gap:26px 18px}.client-grid .client-logo{font-size:17px}}
@media(max-width:560px){.client-grid{grid-template-columns:repeat(2,1fr)}}


/* Logos clients (PNG noir uniforme) */
.client-grid img{height:36px;max-width:130px;width:auto;object-fit:contain;opacity:.5;transition:.3s var(--ease)}
.client-grid img:hover{opacity:1;transform:translateY(-2px)}
@media(max-width:1000px){.client-grid img{height:32px;max-width:110px}}

/* Méga-menu : ouverture pilotée en JS (hover-intent) — supprime le saut */
.has-mega.mega-open .mega{opacity:1;visibility:visible;pointer-events:auto}

/* ===================== Réseaux sociaux (footer) ===================== */
.socials{display:flex;gap:10px}
.socials a{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.7);transition:.25s var(--ease)}
.socials a:hover{background:var(--lime);color:#fff;border-color:var(--lime);transform:translateY(-2px)}
.socials svg{width:16px;height:16px}

/* ===================== Article (blog) ===================== */
.article{max-width:760px;margin:0 auto}
.article .meta{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--acc);margin-bottom:14px}
.article h2{font-size:clamp(22px,3vw,30px);margin:34px 0 12px}
.article p,.article li{color:#3a4348;font-size:16.5px;line-height:1.7;margin-bottom:14px}
.article ul{padding-left:20px;margin-bottom:14px}
.article .lead-p{font-size:19px;color:var(--ink)}
.rcard .cill{height:170px;border-radius:0;margin:0}

/* =====================================================================
   MOBILE POLISH — échelle typographique et densité affinées (téléphone)
   ===================================================================== */
@media(max-width:640px){
  /* --- Typo : tout redescend d'un cran --- */
  .hero h1{font-size:clamp(31px,8.6vw,40px)}
  .hero p.lead{font-size:15.5px;margin:18px 0 24px}
  .phero h1{font-size:clamp(27px,7.6vw,34px)}
  .phero p{font-size:15px}
  .sec-head h2{font-size:clamp(23px,6.4vw,30px)}
  .sec-head p{font-size:15px;margin-top:10px}
  .tag{font-size:11.5px;margin-bottom:9px}
  .eyebrow{font-size:11px;padding:6px 12px;margin-bottom:18px}

  /* --- Densité : sections et cartes plus compactes --- */
  .sec{padding:54px 0}
  .sec-head{margin-bottom:30px}
  .hero{padding:118px 0 56px}
  .phero{padding:108px 0 44px}
  .card{padding:18px;min-height:0}
  .card h3{font-size:18.5px;margin:14px 0 6px}
  .card p{font-size:13.5px}
  .cill{height:130px;padding:10px}
  .card .cill{height:118px}
  .pcard .pbody{padding:16px}
  .pcard h3{font-size:18px}
  .pcard p{font-size:13.5px;margin-bottom:10px}
  .value{padding:20px}
  .value h3{font-size:18px}
  .value p{font-size:13.5px}
  .step{padding:20px 18px}
  .step::before{font-size:34px;margin-bottom:8px}
  .grid,.grid-2,.grid-4,.steps,.values{gap:12px}

  /* --- Boutons : plus fins --- */
  .btn{padding:11px 18px;font-size:13.5px}
  .btn-lg{padding:13px 20px;font-size:14.5px}
  .hero-cta{gap:10px}
  .hero-cta .btn{width:100%;justify-content:center}
  .cta{padding:36px 20px}
  .cta h2{font-size:clamp(23px,6.6vw,30px)}
  .cta p{font-size:15px;margin:12px auto 22px}
  .cta .btn-row .btn{width:100%;justify-content:center}
  .pd-cta{flex-direction:column;padding:16px}
  .pd-cta .btn{width:100%;justify-content:center}

  /* --- Hero meta : 2 colonnes discrètes --- */
  .hero-meta{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px;margin-top:30px}
  .hero-meta .n{font-size:20px}
  .hero-meta .l{font-size:12px}

  /* --- Trust bar : défilement horizontal sobre --- */
  .trust-row{flex-wrap:nowrap;overflow-x:auto;gap:22px;padding:13px 20px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .trust-row::-webkit-scrollbar{display:none}
  .trust-item{font-size:12.5px;white-space:nowrap;flex-shrink:0}
  .trust-item svg{width:16px;height:16px}

  /* --- Bandeau téléphone --- */
  .phone-band{flex-direction:column;text-align:center;gap:8px;padding:20px}
  .phone-band a.pb-num{font-size:24px}
  .phone-band .pb-txt{font-size:12.5px}

  /* --- Header : plus discret --- */
  .nav{padding:12px 0}
  .brand .logo{height:24px}
  .lang button{padding:5px 10px;font-size:12px}
  .nav-right{gap:10px}

  /* --- Menu mobile : panneau soigné --- */
  .mmenu{justify-content:flex-start;padding:84px 26px 26px;gap:0}
  .mmenu::before{content:"Menu";display:block;font-size:11.5px;font-weight:700;
    letter-spacing:.14em;text-transform:uppercase;color:var(--brand-300);margin-bottom:10px}
  .mmenu a{font-size:19.5px;font-weight:600;padding:13px 2px;
    border-bottom:1px solid rgba(255,255,255,.09);display:flex;justify-content:space-between;align-items:center}
  .mmenu a::after{content:"→";font-size:15px;opacity:.35}
  .mmenu a:last-of-type{margin-top:16px;border:0;background:var(--grad-btn);color:#fff;
    border-radius:14px;padding:14px 18px;justify-content:center;font-size:16.5px}
  .mmenu a:last-of-type::after{content:""}
  .mmenu .close{top:18px;right:20px;width:40px;height:40px;border:1px solid rgba(255,255,255,.2);
    border-radius:50%;font-size:22px;line-height:1;display:grid;place-items:center}

  /* --- Avis / clients / footer --- */
  .reviews{padding:30px 18px}
  .gscore .num{font-size:38px}
  .rev{padding:18px}
  .rev p{font-size:13.5px}
  .clients{padding:36px 0}
  .client-grid{gap:20px 12px}
  .client-grid img{height:24px;max-width:88px}
  .foot-grid{gap:22px;padding-bottom:30px}
  footer{padding:46px 0 22px;margin-top:54px}
  footer ul a{font-size:13.5px}
  .foot-bottom{flex-direction:column;align-items:center;gap:12px;text-align:center}

  /* --- Fiches produits / tableaux / FAQ --- */
  .pd-gallery .cill-main{height:240px;padding:18px}
  .pd-info h1{font-size:27px}
  .pd-info .desc{font-size:15px;margin-bottom:16px}
  .pd-feats li{font-size:13.5px}
  .spec th,.spec td{padding:10px 0;font-size:13.5px}
  .qa button{font-size:16px;padding:17px 0}
  .qa .ans p{font-size:14px}

  /* --- Stats / breadcrumb / formulaires --- */
  .stats{gap:10px}
  .stat .n{font-size:30px}
  .stat .l{font-size:13px}
  .breadcrumb{font-size:12px;flex-wrap:wrap}
  .field input,.field select,.field textarea{padding:11px 13px;font-size:14.5px}
  .pao-card{padding:20px;gap:20px}
  .pao-card h3{font-size:20px}
  .pao-card p{font-size:14px}
  .pao-visual{min-height:200px;padding:14px}
  .article p,.article li{font-size:15px}
  .article h2{font-size:21px}
}

/* ===== Newsletter (footer) ===== */
.newsletter h4{color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:16px;font-family:'Inter','Jost',sans-serif;font-weight:600}
.news-form{display:flex;gap:8px}
.news-form input{flex:1;min-width:0;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);color:#fff;border-radius:10px;padding:11px 13px;font:inherit;font-size:14px}
.news-form input::placeholder{color:rgba(255,255,255,.45)}
.news-form input:focus{outline:none;border-color:var(--lime)}
.news-form button{flex-shrink:0;width:44px;border:0;border-radius:10px;background:var(--grad-btn);color:#fff;cursor:pointer;display:grid;place-items:center}
.news-form button svg{width:18px;height:18px}
.news-form button:hover{filter:brightness(1.08)}
@media(max-width:900px){.foot-grid{grid-template-columns:1fr 1fr}.newsletter{grid-column:1/-1}}

/* ===== Bandeau cookies (RGPD / Consent Mode v2) ===== */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:9999;max-width:920px;margin:0 auto;background:var(--ink-soft);color:#fff;border-radius:var(--radius-sm);box-shadow:0 20px 50px rgba(0,0,0,.35);transform:translateY(160%);transition:transform .45s cubic-bezier(.2,.8,.2,1)}
.cookie-banner.show{transform:translateY(0)}
.cookie-banner .ck-in{display:flex;align-items:center;gap:18px;padding:15px 20px;flex-wrap:wrap}
.cookie-banner .ck-txt{flex:1;min-width:240px;margin:0;font-size:13.5px;line-height:1.5;color:rgba(255,255,255,.85)}
.cookie-banner .ck-btns{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.cookie-banner .ck-refuse{background:transparent;border:1px solid rgba(255,255,255,.4);color:#fff;border-radius:30px;padding:9px 18px;font:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:.2s}
.cookie-banner .ck-refuse:hover{border-color:#fff}
.cookie-banner .ck-accept{background:var(--grad-btn);border:0;color:#fff;border-radius:30px;padding:10px 22px;font:inherit;font-size:14px;font-weight:700;cursor:pointer;transition:.2s}
.cookie-banner .ck-accept:hover{transform:translateY(-1px)}
.cookie-banner .ck-link{color:var(--lime-soft);font-size:13px;text-decoration:underline;white-space:nowrap}
@media(max-width:560px){.cookie-banner .ck-in{flex-direction:column;align-items:stretch}.cookie-banner .ck-btns{justify-content:stretch}.cookie-banner .ck-refuse,.cookie-banner .ck-accept{flex:1}}

/* ===== Chat / support en ligne (widget site) ===== */
.welye-chat-btn{position:fixed;right:20px;bottom:20px;z-index:9998;width:60px;height:60px;border-radius:50%;border:0;background:var(--grad-cta);color:#fff;box-shadow:0 14px 34px rgba(11,58,82,.4);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.25s}
.welye-chat-btn:hover{transform:translateY(-2px)}
.welye-chat-btn.hide{transform:scale(0);opacity:0;pointer-events:none}
.welye-chat-btn .wc-dot{position:absolute;top:10px;right:11px;width:13px;height:13px;border-radius:50%;background:#ff4d4f;border:2px solid #fff}
.welye-chat-panel{position:fixed;right:20px;bottom:20px;z-index:9999;width:370px;max-width:calc(100vw - 32px);height:540px;max-height:calc(100vh - 40px);background:#fff;border-radius:20px;box-shadow:0 30px 70px rgba(8,24,32,.34);display:flex;flex-direction:column;overflow:hidden;transform:translateY(20px) scale(.96);opacity:0;pointer-events:none;transition:.28s cubic-bezier(.2,.8,.2,1)}
.welye-chat-panel.show{transform:none;opacity:1;pointer-events:auto}
.welye-chat-panel .wc-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:15px 18px;background:var(--grad-cta);color:#fff}
.welye-chat-panel .wc-head b{display:block;font-size:16px}
.welye-chat-panel .wc-head span{font-size:12px;opacity:.85}
.welye-chat-panel .wc-close{background:rgba(255,255,255,.18);border:0;color:#fff;width:30px;height:30px;border-radius:50%;font-size:20px;line-height:1;cursor:pointer;flex:none}
.welye-chat-panel .wc-body{flex:1;display:flex;flex-direction:column;min-height:0}
.welye-chat-panel .wc-intro{padding:18px 18px 4px;font-size:13.5px;color:var(--muted);line-height:1.5}
.welye-chat-panel .wc-form{display:flex;flex-direction:column;gap:10px;padding:14px 18px}
.welye-chat-panel .wc-form input,.welye-chat-panel .wc-form textarea{border:1px solid var(--line);border-radius:12px;padding:11px 13px;font:inherit;font-size:14.5px;width:100%;background:#fff;color:var(--ink)}
.welye-chat-panel .wc-form textarea{resize:vertical}
.welye-chat-panel .wc-send{background:var(--grad-btn);color:#fff;border:0;border-radius:30px;padding:12px;font:inherit;font-size:15px;font-weight:700;cursor:pointer}
.welye-chat-panel .wc-rgpd{font-size:11px;color:var(--muted);text-align:center}
.welye-chat-panel .wc-stream{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:9px;background:var(--paper)}
.welye-chat-panel .wc-msg{max-width:80%;padding:9px 13px;border-radius:14px;font-size:14px;line-height:1.45}
.welye-chat-panel .wc-msg p{margin:0}
.welye-chat-panel .wc-msg.them{align-self:flex-start;background:#fff;border:1px solid var(--line);border-bottom-left-radius:4px}
.welye-chat-panel .wc-msg.me{align-self:flex-end;background:var(--grad-btn);color:#fff;border-bottom-right-radius:4px}
.welye-chat-panel .wc-reply{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--line)}
.welye-chat-panel .wc-reply input{flex:1;border:1px solid var(--line);border-radius:30px;padding:10px 15px;font:inherit;font-size:14.5px}
.welye-chat-panel .wc-reply button{flex:none;width:44px;height:44px;border:0;border-radius:50%;background:var(--grad-btn);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}
@media(max-width:560px){
  .welye-chat-btn{bottom:84px;right:16px}
  .welye-chat-panel{right:0;bottom:0;width:100vw;max-width:100vw;height:100dvh;max-height:100dvh;border-radius:0}
}
