
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --rose-pale:#FDF6F6;
  --rose-blush:#FAF0F0;
  --rose-soft:#F5E2E2;
  --rose-light:#ECC8C8;
  --rose-mid:#C9849A;
  --rose-deep:#A85470;
  --rose-dark:#7A3350;
  --sand:#F7F1E8;
  --sand-m:#EDE5D8;
  --text:#2E1E1E;
  --text-m:#6B4A4A;
  --text-s:#A08080;
  --border:rgba(168,84,112,0.11);
  --border-m:rgba(168,84,112,0.20);
  --white:#FFFFFF;
  --sh:0 2px 18px rgba(100,40,60,0.07);
  --sh-m:0 10px 40px rgba(100,40,60,0.11);
}
html{scroll-behavior:smooth}
body{background:var(--rose-pale);color:var(--text);font-family:'Jost',sans-serif;font-weight:300;line-height:1.72;overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse 800px 600px at -5% 5%,rgba(168,84,112,0.05) 0%,transparent 60%),radial-gradient(ellipse 600px 700px at 105% 85%,rgba(168,84,112,0.04) 0%,transparent 60%);pointer-events:none;z-index:0}

/* HEADER */
header{position:sticky;top:0;z-index:200;background:rgba(253,246,246,0.93);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:14px 44px;display:flex;align-items:center;justify-content:space-between}
.logo{cursor:pointer}
.logo-kap{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:500;color:var(--rose-dark);letter-spacing:5px;line-height:1}
.logo-sub{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--text-s);margin-top:2px}
nav{display:flex;align-items:center;gap:32px}
nav a{font-size:11.5px;letter-spacing:.8px;text-transform:uppercase;color:var(--text-s);text-decoration:none;transition:color .2s}
nav a:hover{color:var(--rose-deep)}
.nav-cta{padding:9px 22px;border-radius:30px;background:var(--rose-deep);border:none;color:white;font-size:12px;font-family:'Jost',sans-serif;cursor:pointer;transition:all .2s;letter-spacing:.5px}
.nav-cta:hover{background:var(--rose-dark);box-shadow:0 4px 18px rgba(168,84,112,0.3)}

/* ══ HERO ══ */
.hero{position:relative;z-index:1;min-height:100vh;display:grid;grid-template-rows:1fr auto 1fr;align-items:center;justify-items:center;text-align:center;padding:0 24px;overflow:hidden}
.hero-ring-1{position:absolute;width:460px;height:460px;border-radius:50%;border:1px solid rgba(168,84,112,0.08);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}
.hero-ring-2{position:absolute;width:720px;height:720px;border-radius:50%;border:1px solid rgba(168,84,112,0.045);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}

/* Zone haute — SEREINIA + tag spécialité */
.hero-top{grid-row:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-bottom:44px;gap:14px;position:relative;z-index:2;width:100%}
.hero-brand-name{display:flex;align-items:baseline}
.hero-brand-name span{font-family:'Cormorant Garamond',serif;font-size:clamp(60px,9vw,92px);font-weight:400;line-height:1;letter-spacing:12px}
.l-s{animation:letterFloat 3.5s ease-in-out infinite;animation-delay:0s}
.l-e{animation:letterFloat 3.5s ease-in-out infinite;animation-delay:.15s}
.l-r{animation:letterFloat 3.5s ease-in-out infinite;animation-delay:.3s}
.l-e2{animation:letterFloat 3.5s ease-in-out infinite;animation-delay:.45s}
.l-i{animation:letterFloat 3.5s ease-in-out infinite;animation-delay:.6s}
.l-n{animation:letterFloat 3.5s ease-in-out infinite;animation-delay:.75s}
.l-i2{animation:letterFloat 3.5s ease-in-out infinite;animation-delay:.9s}
.l-a{animation:letterFloat 3.5s ease-in-out infinite;animation-delay:1.05s}
.hero-brand-sante{font-family:'Jost',sans-serif;font-size:8.5px;font-weight:300;letter-spacing:6px;text-transform:uppercase;color:var(--text-s)}
.hero-brand-rule{width:1px;height:24px;background:linear-gradient(to bottom,transparent,rgba(168,84,112,0.18),transparent)}
.hero-tag{display:inline-flex;align-items:center;gap:8px;padding:5px 15px;border-radius:30px;background:transparent;border:1px solid var(--border-m);font-size:9.5px;letter-spacing:2.2px;text-transform:uppercase;color:var(--text-s)}
.hero-dot{width:5px;height:5px;background:var(--rose-mid);border-radius:50%;flex-shrink:0;animation:breathe 2.8s ease-in-out infinite}
@keyframes breathe{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(.5);opacity:.25}}

/* Zone centrale — H1, texte, boutons */
.hero-main{grid-row:2;display:flex;flex-direction:column;align-items:center;position:relative;z-index:2;width:100%}
.hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(42px,7vw,72px);font-weight:400;line-height:1.12;color:var(--text);max-width:640px;margin:0 0 22px}
.hero h1 em{font-style:italic;color:var(--rose-deep)}
.hero-accroche{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--text-s);font-weight:300;margin-bottom:22px}
.hero-p{font-size:14px;font-weight:300;color:var(--text-m);max-width:400px;line-height:1.88;margin-bottom:40px}
.hero-btns{display:flex;gap:11px;flex-wrap:wrap;justify-content:center}
.btn-p{padding:13px 30px;border-radius:32px;background:var(--rose-deep);border:none;color:white;font-size:13px;font-family:'Jost',sans-serif;cursor:pointer;transition:all .22s;box-shadow:0 6px 20px rgba(168,84,112,0.22)}
.btn-p:hover{background:var(--rose-dark);transform:translateY(-2px);box-shadow:0 10px 28px rgba(168,84,112,0.30)}
.btn-g{padding:13px 26px;border-radius:32px;background:transparent;border:1px solid var(--border-m);color:var(--text-s);font-size:13px;font-family:'Jost',sans-serif;cursor:pointer;transition:all .22s}
.btn-g:hover{border-color:var(--rose-mid);color:var(--rose-deep)}

/* Zone basse — scroll hint */
.hero-bottom{grid-row:3;display:flex;align-items:flex-end;padding-bottom:28px;position:relative;z-index:2}
.scroll-hint{display:flex;flex-direction:column;align-items:center;gap:7px;font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--text-s);opacity:.4}
.scroll-line{width:1px;height:30px;background:linear-gradient(to bottom,var(--rose-light),transparent)}

/* VÉRITÉS */
.truths{position:relative;z-index:1;background:var(--rose-dark);padding:72px 44px;overflow:hidden}
.truths-deco{position:absolute;width:360px;height:360px;border-radius:50%;background:rgba(255,255,255,0.03);right:-80px;top:-80px;pointer-events:none}
.truths-label{font-size:10px;letter-spacing:3.5px;text-transform:uppercase;color:rgba(255,255,255,0.38);text-align:center;margin-bottom:56px}
.truths-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));max-width:980px;margin:0 auto}
.truth{padding:34px 38px;border-right:1px solid rgba(255,255,255,0.08);border-bottom:1px solid rgba(255,255,255,0.08)}
.truth:nth-child(3n){border-right:none}
.t-n{font-family:'Cormorant Garamond',serif;font-size:44px;font-weight:300;color:rgba(255,255,255,0.12);line-height:1;margin-bottom:18px}
.t-txt{font-family:'Cormorant Garamond',serif;font-size:19.5px;font-style:italic;font-weight:400;color:rgba(255,255,255,0.88);line-height:1.56;margin-bottom:12px}
.t-src{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.35)}

/* ══ SUIVI HEBDOMADAIRE ══ */
.suivi-bloc{background:white;border-radius:16px;padding:18px;margin-bottom:14px;border:1px solid rgba(168,84,112,0.08)}
.suivi-dim-label{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:#A85470;margin-bottom:14px;font-weight:500}
.suivi-q{font-size:13px;color:#2E1818;line-height:1.6;margin-bottom:10px;margin-top:14px}
.suivi-q:first-of-type{margin-top:0}
.suivi-scale{margin-bottom:4px}
.suivi-scale-labels{display:flex;justify-content:space-between;font-size:10px;color:#A08080;margin-bottom:4px}
.suivi-slider{width:100%;accent-color:#A85470;cursor:pointer}
.suivi-slider-val{text-align:center;font-size:12px;font-weight:500;color:#A85470;margin-top:2px}
.suivi-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}
.suivi-chip{padding:7px 14px;border-radius:20px;border:1.5px solid rgba(168,84,112,0.2);background:white;color:#5A3A40;font-family:'Jost',sans-serif;font-size:12px;cursor:pointer;transition:all .18s}
.suivi-chip:hover{border-color:#A85470;background:#FDF5F7}
.suivi-chip.selected{border-color:#A85470;background:#FDF0F4;color:#7A3350;font-weight:500}


.section{position:relative;z-index:1;padding:80px 44px}
.section.bg-sand{background:var(--sand);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.section.bg-blush{background:var(--rose-blush);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.s-tag{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--rose-mid);margin-bottom:16px}
.s-title{font-family:'Cormorant Garamond',serif;font-size:clamp(28px,4vw,46px);font-weight:400;line-height:1.22;color:var(--text);margin-bottom:14px}
.s-title em{font-style:italic;color:var(--rose-deep)}
.s-sub{font-size:14px;color:var(--text-m);max-width:500px;line-height:1.82;margin-bottom:52px}
.inner{max-width:1060px;margin:0 auto}

/* GUIDE SITUATIONS */
.sit-intro{text-align:center;margin-bottom:52px}
.sit-intro .s-sub{margin:0 auto}
.sit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:16px;max-width:1000px;margin:0 auto}
.sit-card{background:var(--white);border:1px solid var(--border);border-radius:22px;padding:28px 26px 24px;cursor:pointer;transition:all .24s cubic-bezier(.4,0,.2,1);text-align:left;font-family:'Jost',sans-serif;position:relative;overflow:hidden}
.sit-card::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(168,84,112,0.04),rgba(168,84,112,0.08));opacity:0;transition:opacity .24s;border-radius:21px}
.sit-card:hover{transform:translateY(-3px);box-shadow:var(--sh-m);border-color:var(--rose-mid)}
.sit-card:hover::after{opacity:1}
.sit-icon{font-size:26px;margin-bottom:14px;display:block}
.sit-corner{position:absolute;top:22px;right:22px;width:30px;height:30px;border-radius:9px;background:var(--rose-soft);display:flex;align-items:center;justify-content:center;font-size:13px;transition:background .22s}
.sit-card:hover .sit-corner{background:var(--rose-light)}
.sit-title{font-size:15.5px;font-weight:500;color:var(--text);margin-bottom:8px}
.sit-desc{font-size:12.5px;color:var(--text-m);line-height:1.68;margin-bottom:16px}
.sit-cta{font-size:12px;color:var(--rose-deep);display:flex;align-items:center;gap:6px;transition:gap .2s}
.sit-card:hover .sit-cta{gap:10px}

/* PHILOSOPHIE */
.philo-wrap{max-width:680px;margin:0 auto;text-align:center}
.philo-q{font-family:'Cormorant Garamond',serif;font-size:clamp(24px,3.5vw,36px);font-style:italic;font-weight:400;color:var(--rose-deep);line-height:1.44;margin-bottom:30px}
.philo-mark{font-size:72px;font-family:'Cormorant Garamond',serif;color:var(--rose-light);line-height:.6;display:block;margin-bottom:12px}
.philo-body{font-size:14.5px;color:var(--text-m);line-height:1.88;max-width:580px;margin:0 auto}

/* TÉMOIGNAGES */
.temo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:20px;max-width:980px;margin:0 auto}
.temo-card{background:var(--white);border:1px solid var(--border);border-radius:20px;padding:30px 28px;position:relative}
.temo-card::before{content:'"';font-family:'Cormorant Garamond',serif;font-size:90px;color:var(--rose-soft);position:absolute;top:4px;left:18px;line-height:1;pointer-events:none}
.temo-txt{font-family:'Cormorant Garamond',serif;font-size:17.5px;font-style:italic;color:var(--text);line-height:1.66;margin-bottom:20px;padding-top:30px}
.temo-by{font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-s)}

/* RESSOURCES */
.res-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;max-width:980px;margin:0 auto}
.res-card{background:var(--white);border:1px solid var(--border);border-radius:18px;padding:22px 24px;text-decoration:none;display:block;transition:all .2s}
.res-card:hover{border-color:var(--rose-mid);transform:translateY(-2px);box-shadow:var(--sh)}
.res-type{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--rose-mid);margin-bottom:8px}
.res-title{font-size:14.5px;font-weight:500;color:var(--text);margin-bottom:6px}
.res-desc{font-size:12px;color:var(--text-m);line-height:1.62;margin-bottom:12px}
.res-link{font-size:12px;color:var(--rose-deep);display:flex;align-items:center;gap:5px}

/* ÉVÉNEMENTS */
.ev-list{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.ev-item{background:var(--white);border:1px solid var(--border);border-radius:18px;padding:20px 26px;display:flex;gap:20px;align-items:flex-start;transition:all .2s}
.ev-item:hover{border-color:var(--rose-mid);box-shadow:var(--sh)}
.ev-date{flex-shrink:0;background:var(--rose-soft);border-radius:14px;padding:10px 14px;text-align:center;min-width:60px}
.ev-day{font-size:24px;font-weight:500;color:var(--rose-deep);line-height:1}
.ev-month{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-s);margin-top:3px}
.ev-body{}
.ev-title{font-size:14.5px;font-weight:500;color:var(--text);margin-bottom:4px}
.ev-desc{font-size:12px;color:var(--text-m);line-height:1.58;margin-bottom:8px}
.ev-tags{display:flex;gap:6px;flex-wrap:wrap}
.etag{font-size:10px;padding:3px 10px;border-radius:20px;background:var(--rose-soft);color:var(--rose-deep)}

/* KAP IA CTA */
.kap-cta-section{position:relative;z-index:1;background:linear-gradient(135deg,var(--rose-dark) 0%,var(--rose-deep) 100%);padding:84px 44px;text-align:center;overflow:hidden}
.kap-cta-section::before{content:'';position:absolute;width:460px;height:460px;border-radius:50%;background:rgba(255,255,255,0.04);left:-130px;bottom:-130px;pointer-events:none}
.kap-cta-section::after{content:'';position:absolute;width:300px;height:300px;border-radius:50%;background:rgba(255,255,255,0.03);right:-60px;top:-60px;pointer-events:none}
.kcta-icon{width:66px;height:66px;background:rgba(255,255,255,0.13);border:1px solid rgba(255,255,255,0.22);border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 26px}
.kap-cta-section h2{font-family:'Cormorant Garamond',serif;font-size:clamp(30px,4.5vw,50px);font-weight:400;color:white;line-height:1.2;margin-bottom:16px}
.kap-cta-section h2 em{font-style:italic;opacity:.85}
.kap-cta-section p{font-size:15px;color:rgba(255,255,255,0.72);max-width:480px;margin:0 auto 40px;line-height:1.8}
.btn-white{padding:14px 36px;border-radius:32px;background:white;border:none;color:var(--rose-dark);font-size:14px;font-family:'Jost',sans-serif;font-weight:500;cursor:pointer;transition:all .22s;box-shadow:0 6px 24px rgba(0,0,0,0.12)}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(0,0,0,0.18)}

/* FOOTER */
footer{position:relative;z-index:1;border-top:1px solid var(--border);padding:36px 44px 28px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;background:var(--rose-pale)}
.ft-logo{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:500;color:var(--rose-dark);letter-spacing:4px}
.ft-links{display:flex;gap:22px}
.ft-links a{font-size:11px;letter-spacing:.8px;text-transform:uppercase;color:var(--text-s);text-decoration:none;transition:color .2s}
.ft-links a:hover{color:var(--rose-deep)}
.ft-copy{font-size:11px;color:var(--text-s)}

/* ════════════════════════
   OVERLAY KAP IA
════════════════════════ */
.overlay{position:fixed;inset:0;z-index:1000;background:rgba(46,30,30,0.58);backdrop-filter:blur(10px);display:none;align-items:flex-end;justify-content:center;padding:16px}
.overlay.open{display:flex}
.panel{background:var(--rose-pale);border-radius:28px 28px 22px 22px;width:100%;max-width:610px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 -12px 60px rgba(100,40,60,0.22);animation:slideUp .38s cubic-bezier(.4,0,.2,1)}
@keyframes slideUp{from{transform:translateY(44px);opacity:0}to{transform:translateY(0);opacity:1}}

/* Panel header */
.p-head{padding:16px 22px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;flex-shrink:0;background:var(--white)}
.p-av{width:40px;height:40px;background:linear-gradient(135deg,var(--rose-dark),var(--rose-deep));border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.p-info{flex:1}
.p-name{font-size:14px;font-weight:500;color:var(--text)}
.p-status{font-size:11px;color:var(--rose-mid);margin-top:1px}
.p-close{width:32px;height:32px;border-radius:9px;background:var(--rose-soft);border:none;cursor:pointer;font-size:16px;color:var(--text-m);display:flex;align-items:center;justify-content:center;transition:background .2s}
.p-close:hover{background:var(--rose-light)}

/* Situation bar */
.sit-bar{padding:14px 20px;border-bottom:1px solid var(--border);background:var(--rose-blush);flex-shrink:0}
.sit-bar-label{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--text-s);margin-bottom:10px}
.sit-bar-btns{display:flex;flex-wrap:wrap;gap:7px}
.s-btn{padding:6px 14px;border-radius:20px;border:1.5px solid var(--border-m);background:var(--white);font-size:12px;color:var(--text-m);cursor:pointer;font-family:'Jost',sans-serif;transition:all .18s}
.s-btn:hover{border-color:var(--rose-mid);color:var(--rose-deep);background:var(--rose-soft)}
.s-btn.on{border-color:var(--rose-deep);background:var(--rose-soft);color:var(--rose-deep);font-weight:500}

/* Messages */
.msgs{flex:1;overflow-y:auto;padding:20px 20px 0;display:flex;flex-direction:column;gap:16px;position:relative;}
.msgs::-webkit-scrollbar{width:3px}
.msgs::-webkit-scrollbar-thumb{background:var(--rose-light);border-radius:3px}
.mrow{animation:fadeUp .3s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(9px)}to{opacity:1;transform:translateY(0)}}
.mkap{display:flex;gap:10px;align-items:flex-start}
.kav{width:34px;height:34px;background:linear-gradient(135deg,var(--rose-dark),var(--rose-deep));border-radius:11px;flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;font-size:14px;box-shadow:0 3px 10px rgba(168,84,112,0.2)}
.bk{background:var(--white);border:1px solid var(--border);border-radius:4px 20px 20px 20px;padding:18px 20px;max-width:85%;font-size:13.5px;line-height:1.85;color:var(--text);box-shadow:var(--sh)}
.bk .sndr{font-size:9px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--rose-mid);margin-bottom:6px}
.bk strong{color:var(--rose-dark);font-weight:500}
.musr{display:flex;justify-content:flex-end}
.bu{background:linear-gradient(135deg,var(--rose-dark),var(--rose-deep));border-radius:17px 17px 4px 17px;padding:12px 17px;max-width:72%;font-size:13.5px;line-height:1.65;color:white;box-shadow:0 3px 14px rgba(168,84,112,0.24)}
.resources{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px}
.rpill{display:flex;align-items:center;gap:6px;padding:6px 13px;background:var(--rose-soft);border:1px solid var(--border-m);border-radius:22px;font-size:11.5px;color:var(--rose-deep);text-decoration:none;transition:all .18s;font-family:'Jost',sans-serif}
.rpill:hover{background:var(--rose-light);border-color:var(--rose-mid);transform:translateY(-1px)}
.typ{display:flex;gap:10px;align-items:center}
.tdots{background:var(--white);border:1px solid var(--border);border-radius:4px 17px 17px 17px;padding:12px 16px;display:flex;gap:5px;box-shadow:var(--sh)}
.tdots span{width:6px;height:6px;background:var(--rose-mid);border-radius:50%;animation:bounce 1.2s ease infinite;opacity:.4}
.tdots span:nth-child(2){animation-delay:.15s}
.tdots span:nth-child(3){animation-delay:.3s}
@keyframes bounce{0%,60%,100%{transform:translateY(0);opacity:.35}30%{transform:translateY(-5px);opacity:1}}
#anc{height:14px}

/* Zone saisie */
.izone{padding:14px 18px 17px;border-top:1px solid var(--border);background:var(--white);flex-shrink:0}
.disc{background:rgba(168,84,112,0.07);border:1px solid rgba(168,84,112,0.18);border-radius:8px;padding:7px 13px;font-size:11px;color:var(--rose-deep);margin-bottom:9px;display:none;line-height:1.5}
.disc.on{display:block}
.ibox{display:flex;align-items:flex-end;gap:9px;background:var(--rose-blush);border:1.5px solid var(--border-m);border-radius:17px;padding:10px 10px 10px 18px;transition:border-color .2s,box-shadow .2s}
.ibox:focus-within{border-color:var(--rose-mid);box-shadow:0 0 0 3px rgba(168,84,112,0.08)}
textarea{flex:1;background:transparent;border:none;outline:none;font-family:'Jost',sans-serif;font-size:13.5px;color:var(--text);line-height:1.5;resize:none;min-height:22px;max-height:90px}
textarea::placeholder{color:var(--text-s)}
.snd{width:37px;height:37px;border-radius:11px;background:linear-gradient(135deg,var(--rose-dark),var(--rose-deep));border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;opacity:.28;pointer-events:none}
.snd.on{opacity:1;pointer-events:all}
.snd.on:hover{transform:scale(1.07);box-shadow:0 4px 14px rgba(168,84,112,0.34)}
.snd svg{width:15px;height:15px;fill:white}
.ift{text-align:center;font-size:10px;color:var(--text-s);margin-top:8px;opacity:.6}

/* RESPONSIVE */
@media(max-width:680px){
  header{padding:13px 20px}
  nav{display:none}
  .hero{padding:70px 20px 60px}
  .section,.truths,.kap-cta-section{padding-left:20px;padding-right:20px}
  footer{padding:28px 20px 22px;flex-direction:column;text-align:center}
  .ft-links{flex-wrap:wrap;justify-content:center}
  .truth{border-right:none}
  .hero h1{font-size:clamp(38px,11vw,60px)}
}


/* Déclenche tout en une fois — pas de classes JS */
/* États d'animation */

#rgpd-banner.visible{transform:translateY(0)}
.rgpd-text{font-size:12px;color:rgba(255,255,255,0.75);line-height:1.6;max-width:700px;font-family:'Jost',sans-serif;font-weight:300}
.rgpd-text a{color:var(--rose-mid);text-decoration:underline;text-underline-offset:2px}
.rgpd-btns{display:flex;gap:10px;flex-shrink:0}
.rgpd-btn-ok{padding:9px 22px;border-radius:20px;background:var(--rose-deep);border:none;color:white;font-size:12px;font-family:'Jost',sans-serif;cursor:pointer;transition:all .2s;font-weight:400}
.rgpd-btn-ok:hover{background:var(--rose-dark)}
.rgpd-btn-info{padding:9px 18px;border-radius:20px;background:transparent;border:1px solid rgba(255,255,255,0.2);color:rgba(255,255,255,0.6);font-size:12px;font-family:'Jost',sans-serif;cursor:pointer;transition:all .2s}
.rgpd-btn-info:hover{border-color:rgba(255,255,255,0.4);color:rgba(255,255,255,0.85)}

/* ══ PAGE MENTIONS LÉGALES ══ */
#page-mentions{
  display:none;
  position:fixed;inset:0;z-index:88888;
  background:var(--rose-pale);
  overflow-y:auto;
  padding:60px 40px;
}
#page-mentions.open{display:block}
.mentions-inner{max-width:720px;margin:0 auto}
.mentions-close{position:fixed;top:20px;right:28px;width:36px;height:36px;border-radius:10px;background:var(--rose-soft);border:none;cursor:pointer;font-size:18px;color:var(--text-m);display:flex;align-items:center;justify-content:center;transition:background .2s}
.mentions-close:hover{background:var(--rose-light)}
.mentions-title{font-family:'Cormorant Garamond',serif;font-size:38px;font-weight:400;color:var(--text);margin-bottom:8px}
.mentions-date{font-size:12px;color:var(--text-s);margin-bottom:48px;letter-spacing:.5px}
.mentions-section{margin-bottom:36px}
.mentions-section h2{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:500;color:var(--rose-dark);margin-bottom:12px}
.mentions-section p{font-size:14px;color:var(--text-m);line-height:1.82;margin-bottom:8px}
.mentions-section strong{color:var(--text);font-weight:500}
.mentions-highlight{background:var(--rose-soft);border-left:3px solid var(--rose-mid);border-radius:0 10px 10px 0;padding:14px 18px;margin:12px 0;font-size:13px;color:var(--text-m);line-height:1.7}
@media(max-width:600px){#rgpd-banner{padding:16px 20px}#page-mentions{padding:40px 20px}}

/* ══ QUESTIONNAIRE OVERLAY ══ */
#q-overlay{
  position:fixed;inset:0;z-index:88888;
  background:rgba(46,30,30,0.6);
  backdrop-filter:blur(8px);
  display:none;align-items:flex-end;justify-content:center;
  padding:16px;
}
#q-overlay.open{display:flex}
#q-panel{
  background:var(--rose-pale);
  border-radius:28px 28px 22px 22px;
  width:100%;max-width:640px;
  max-height:88vh;overflow-y:auto;
  box-shadow:0 -8px 48px rgba(100,40,60,0.18);
  animation:slideUp .35s cubic-bezier(.4,0,.2,1);
}
@keyframes slideUp{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}
#q-panel::-webkit-scrollbar{width:3px}
#q-panel::-webkit-scrollbar-thumb{background:var(--rose-light);border-radius:3px}
.qp-header{padding:18px 24px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--white);border-radius:28px 28px 0 0;z-index:2}
.qp-title{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:500;color:var(--text)}
.qp-title em{font-style:italic;color:var(--rose-deep)}
.qp-close{width:32px;height:32px;border-radius:9px;background:var(--rose-soft);border:none;cursor:pointer;font-size:15px;color:var(--text-m);display:flex;align-items:center;justify-content:center;transition:background .2s}
.qp-close:hover{background:var(--rose-light)}
.qp-body{padding:24px}
.qp-consent{background:var(--rose-soft);border-radius:14px;padding:16px 18px;margin-bottom:24px;font-size:13px;color:var(--text-m);line-height:1.7}
.qp-consent strong{color:var(--text)}
.qp-consent-check{display:flex;align-items:flex-start;gap:10px;margin-top:12px;cursor:pointer}
.qp-cbox{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--border-m);flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;transition:all .15s;background:var(--white)}
.qp-cbox.on{background:var(--rose-deep);border-color:var(--rose-deep);color:white;font-size:10px}
.qp-clbl{font-size:12px;color:var(--text-m)}
.qp-section{margin-bottom:22px}
.qp-slabel{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--rose-mid);margin-bottom:14px}
.qp-q{font-size:14px;font-weight:400;color:var(--text);margin-bottom:12px;line-height:1.5}
.qp-q-sub{font-size:11px;color:var(--text-s);margin-bottom:10px;font-style:italic}
.qp-scale{display:flex;gap:6px}
.qp-scale-lbl{display:flex;justify-content:space-between;font-size:10px;color:var(--text-s);margin-top:5px}
.qp-sbtn{flex:1;padding:9px 4px;border-radius:9px;border:1.5px solid var(--border);background:var(--white);font-size:13px;color:var(--text-m);cursor:pointer;font-family:'Jost',sans-serif;transition:all .18s;text-align:center}
.qp-sbtn:hover{border-color:var(--rose-mid);color:var(--rose-deep);background:var(--rose-soft)}
.qp-sbtn.on{border-color:var(--rose-deep);background:var(--rose-deep);color:white;font-weight:500}
.qp-yn{display:flex;gap:8px;flex-wrap:wrap}
.qp-yn-btn{padding:9px 14px;border-radius:22px;border:1.5px solid var(--border);background:var(--white);font-size:13px;color:var(--text-m);cursor:pointer;font-family:'Jost',sans-serif;transition:all .18s}
.qp-yn-btn:hover{border-color:var(--rose-mid);color:var(--rose-deep);background:var(--rose-soft)}
.qp-yn-btn.on{border-color:var(--rose-deep);background:var(--rose-deep);color:white}
.qp-nps{display:flex;gap:4px;flex-wrap:wrap}
.qp-nps-btn{width:40px;height:40px;border-radius:9px;border:1.5px solid var(--border);background:var(--white);font-size:12px;color:var(--text-m);cursor:pointer;font-family:'Jost',sans-serif;transition:all .18s;display:flex;align-items:center;justify-content:center}
.qp-nps-btn:hover{border-color:var(--rose-mid);background:var(--rose-soft)}
.qp-nps-btn.on{border-color:var(--rose-deep);background:var(--rose-deep);color:white;font-weight:500}
.qp-nps-lbl{display:flex;justify-content:space-between;font-size:10px;color:var(--text-s);margin-top:5px}
.qp-textarea{width:100%;border:1.5px solid var(--border);border-radius:12px;padding:12px 16px;font-size:13px;font-family:'Jost',sans-serif;color:var(--text);background:var(--white);resize:none;min-height:80px;outline:none;transition:border-color .2s;line-height:1.6}
.qp-textarea:focus{border-color:var(--rose-mid)}
.qp-textarea::placeholder{color:var(--text-s)}
.qp-submit{width:100%;padding:13px;border-radius:14px;background:linear-gradient(135deg,var(--rose-dark),var(--rose-deep));border:none;color:white;font-size:14px;font-family:'Jost',sans-serif;cursor:pointer;transition:all .2s;margin-top:8px}
.qp-submit:hover{box-shadow:0 4px 16px rgba(168,84,112,0.3);transform:translateY(-1px)}
.qp-submit:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none}
.qp-note{text-align:center;font-size:11px;color:var(--text-s);margin-top:8px}
.qp-confirm{text-align:center;padding:40px 24px}
.qp-confirm-icon{font-size:40px;margin-bottom:16px}
.qp-confirm h3{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:400;margin-bottom:10px}
.qp-confirm h3 em{font-style:italic;color:var(--rose-deep)}
.qp-confirm p{font-size:13px;color:var(--text-m);line-height:1.75}

/* Bouton questionnaire flottant */
#q-float-btn{
  display:none;
  margin:12px 0 0;
  padding:9px 18px;border-radius:22px;
  background:var(--rose-soft);border:1px solid var(--border-m);
  color:var(--rose-deep);font-size:12px;font-family:'Jost',sans-serif;
  cursor:pointer;transition:all .2s;align-self:flex-start;
}
#q-float-btn:hover{background:var(--rose-light);border-color:var(--rose-mid)}

/* ── ÉQUIPE SOIGNANTE ── */
.eq-section{position:relative;z-index:1;padding:80px 44px;background:var(--sand);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.eq-inner{max-width:980px;margin:0 auto}
.eq-pro{padding:32px 18px 28px;border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;text-align:center;transition:background .2s;position:relative}
.eq-pro:hover{background:var(--rose-blush)}
.eq-pro::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(to right,var(--rose-deep),var(--rose-mid));transform:scaleX(0);transform-origin:left;transition:transform .28s ease}
.eq-pro:hover::before{transform:scaleX(1)}
.eq-num{font-family:'Cormorant Garamond',serif;font-size:10px;letter-spacing:3px;color:var(--text-s);margin-bottom:18px;align-self:flex-start}
.eq-icon{width:30px;height:30px;margin-bottom:16px;color:var(--rose-mid);transition:color .2s}
.eq-pro:hover .eq-icon{color:var(--rose-deep)}
.eq-icon svg{width:30px;height:30px}
.eq-title{font-family:'Cormorant Garamond',serif;font-size:14px;font-weight:500;color:var(--text);margin-bottom:8px}
.eq-desc{font-size:11px;font-weight:300;color:var(--text-s);line-height:1.65;flex:1}
@media(max-width:900px){.eq-grid{grid-template-columns:repeat(3,1fr)!important}.eq-pro:nth-child(3){border-right:none}.eq-pro:nth-child(n+4){border-top:1px solid var(--border)}}
@media(max-width:600px){.eq-section{padding:60px 20px}.eq-grid{grid-template-columns:repeat(2,1fr)!important}.eq-pro:nth-child(even){border-right:none}.eq-pro:nth-child(odd){border-right:1px solid var(--border)}}

/* ══ PANNEAU LATÉRAL CONTEXTUEL ══ */
#ctx-panel{
  position:fixed;left:-380px;top:50%;transform:translateY(-50%);
  width:360px;max-height:85vh;overflow-y:auto;z-index:1100;pointer-events:none;
  display:flex;flex-direction:column;gap:12px;padding:16px;
  transition:left 1.2s cubic-bezier(.4,0,.2,1);
}
#ctx-panel.open{left:12px;pointer-events:all}
#ctx-panel::-webkit-scrollbar{width:3px}
#ctx-panel::-webkit-scrollbar-thumb{background:var(--rose-light);border-radius:3px}
.ctx-close{
  position:absolute;top:8px;right:8px;
  width:24px;height:24px;border-radius:7px;
  background:var(--rose-soft);border:none;
  cursor:pointer;font-size:12px;color:var(--text-m);
  display:flex;align-items:center;justify-content:center;transition:background .2s;
}
.ctx-close:hover{background:var(--rose-light)}
.ctx-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:16px;padding:18px 20px;position:relative;
  animation:ctxIn .6s cubic-bezier(.4,0,.2,1) both;
}
.ctx-card:nth-child(2){animation-delay:.2s}
.ctx-card:nth-child(3){animation-delay:.4s}
.ctx-card:nth-child(4){animation-delay:.6s}
@keyframes ctxIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
.ctx-card::before{content:'';position:absolute;top:0;left:16px;right:16px;height:2px;border-radius:0 0 2px 2px;}
.ctx-card.card-stats::before{background:linear-gradient(to right,var(--rose-deep),var(--rose-mid))}
.ctx-card.card-kine::before{background:linear-gradient(to right,var(--rose-mid),var(--rose-light))}
.ctx-card.card-link::before{background:linear-gradient(to right,var(--rose-light),transparent)}
.ctx-card-label{font-size:8.5px;letter-spacing:2.5px;text-transform:uppercase;color:var(--rose-mid);margin-bottom:12px;font-weight:400;}
.ctx-card-title{font-family:'Cormorant Garamond',serif;font-size:15px;font-weight:500;color:var(--text);margin-bottom:10px;line-height:1.3;}
.ctx-stats{display:flex;flex-direction:column;gap:10px}
.ctx-stat{display:flex;align-items:flex-start;gap:10px}
.ctx-stat-num{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:500;color:var(--rose-deep);line-height:1;flex-shrink:0;min-width:52px;}
.ctx-stat-label{font-size:11.5px;color:var(--text-m);line-height:1.5;padding-top:4px}
.ctx-kine-list{display:flex;flex-direction:column;gap:8px}
.ctx-kine-item{display:flex;align-items:flex-start;gap:9px;font-size:12px;color:var(--text-m);line-height:1.5;}
.ctx-kine-bullet{width:6px;height:6px;background:var(--rose-mid);border-radius:50%;flex-shrink:0;margin-top:5px;}
.ctx-link{
  display:flex;align-items:center;gap:10px;text-decoration:none;
  padding:10px 14px;border-radius:10px;
  background:var(--rose-soft);border:1px solid var(--border-m);transition:all .2s;margin-top:4px;
}
.ctx-link:hover{background:var(--rose-light);transform:translateX(3px)}
.ctx-link-icon{font-size:18px;flex-shrink:0}
.ctx-link-text{display:flex;flex-direction:column;gap:2px}
.ctx-link-name{font-size:13px;font-weight:400;color:var(--text)}
.ctx-link-url{font-size:10px;color:var(--text-s)}
#ctx-toggle{
  position:fixed;right:12px;top:50%;transform:translateY(-50%);
  width:36px;height:80px;border-radius:10px 0 0 10px;
  background:var(--rose-deep);border:none;cursor:pointer;
  display:none;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  z-index:1099;transition:all .2s;box-shadow:-3px 0 14px rgba(168,84,112,0.2);
}
#ctx-toggle.visible{display:flex}
#ctx-toggle:hover{background:var(--rose-dark)}
#ctx-toggle span{font-size:9px;letter-spacing:1px;text-transform:uppercase;color:white;writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);font-family:'Jost',sans-serif;font-weight:300;}
@media(max-width:900px){
  #ctx-panel{right:auto;left:0;bottom:-300px;top:auto;transform:none;width:100%;max-height:280px;flex-direction:row;overflow-x:auto;overflow-y:hidden;padding:12px;border-top:1px solid var(--border);background:var(--rose-pale);transition:bottom .4s cubic-bezier(.4,0,.2,1);}
  #ctx-panel.open{bottom:0;right:auto}
  #ctx-panel::-webkit-scrollbar{height:3px}
  .ctx-card{min-width:260px;flex-shrink:0}
  #ctx-toggle{right:auto;left:50%;transform:translateX(-50%);top:auto;bottom:0;width:80px;height:36px;border-radius:10px 10px 0 0;flex-direction:row;}
  #ctx-toggle span{writing-mode:horizontal-tb;transform:none}
}

/* ══ KAP-TRACE CSS ══ */
#trace-overlay{
  position:fixed;inset:0;z-index:9000;
  background:rgba(46,30,30,0.55);
  backdrop-filter:blur(12px);
  display:none;align-items:center;justify-content:center;
  padding:20px 16px max(20px, env(safe-area-inset-bottom, 20px)) 16px;
  animation:fadeIn .3s ease;
}
#trace-overlay.open{display:flex;}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
#trace-panel{
  background:var(--white);
  border-radius:28px;
  width:100%;max-width:560px;
  max-height:92vh;
  display:flex;flex-direction:column;
  overflow:hidden;
  box-shadow:0 12px 40px rgba(100,40,60,0.13);
  animation:traceSlideUp .4s cubic-bezier(.4,0,.2,1);
}
@keyframes traceSlideUp{from{transform:translateY(32px);opacity:0}to{transform:translateY(0);opacity:1}}
.tp-header{
  padding:18px 24px 16px;
  border-bottom:1px solid rgba(168,84,112,0.11);
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;background:var(--white);
}
.tp-brand{display:flex;align-items:center;gap:10px}
.tp-icon{
  width:36px;height:36px;
  background:linear-gradient(135deg,#7A3350,#A85470);
  border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:16px;
}
.tp-title{font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:500;color:#2E1E1E}
.tp-sub{font-size:10px;color:#C9849A;letter-spacing:.5px;margin-top:1px}
.tp-close{
  width:32px;height:32px;border-radius:9px;background:#F5E2E2;
  border:none;cursor:pointer;font-size:15px;color:#6B4A4A;
  display:flex;align-items:center;justify-content:center;transition:background .2s;
}
.tp-close:hover{background:#ECC8C8}
.tp-progress{
  padding:14px 24px 12px;
  border-bottom:1px solid rgba(168,84,112,0.11);
  flex-shrink:0;background:#FAF0F0;
}
.tp-steps{display:flex;align-items:center;gap:0;margin-bottom:8px}
.tp-step{display:flex;align-items:center;gap:0;flex:1}
.tp-step-dot{
  width:26px;height:26px;border-radius:50%;
  border:2px solid rgba(168,84,112,0.20);background:#FFFFFF;
  display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:500;color:#A08080;
  transition:all .3s;flex-shrink:0;
}
.tp-step-dot.active{background:#A85470;border-color:#A85470;color:white}
.tp-step-dot.done{background:#C9849A;border-color:#C9849A;color:white;font-size:12px}
.tp-step-line{flex:1;height:2px;background:rgba(168,84,112,0.11);transition:background .3s}
.tp-step-line.done{background:#C9849A}
.tp-step:last-child .tp-step-line{display:none}
/* Barre linéaire — mode approfondi */
.tp-linear-bar{display:none;margin-bottom:8px}
.tp-linear-track{background:rgba(168,84,112,0.1);border-radius:8px;height:5px;overflow:hidden}
.tp-linear-fill{height:100%;background:linear-gradient(to right,#7A3350,#A85470);border-radius:8px;transition:width .5s cubic-bezier(.4,0,.2,1)}
.tp-progress-label{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:#A08080;text-align:center}
.tp-progress-meta{display:flex;justify-content:space-between;font-size:10px;color:#A08080;margin-bottom:6px}
.tp-progress-step-name{font-size:11.5px;color:#6B4A4A;font-weight:500;text-align:left}
.tp-progress-step-count{font-size:11px;color:#C9849A;font-weight:400}
.tp-body{flex:1;overflow-y:auto;padding:28px 28px 20px}
.tp-body::-webkit-scrollbar{width:3px}
.tp-body::-webkit-scrollbar-thumb{background:#ECC8C8;border-radius:3px}
.tp-step-content{display:none;animation:stepIn .35s cubic-bezier(.4,0,.2,1)}
.tp-step-content.active{display:block}
@keyframes stepIn{from{opacity:0;transform:translateX(18px)}to{opacity:1;transform:translateX(0)}}
.tp-step-num{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:#C9849A;margin-bottom:8px}
.tp-step-q{font-family:'Cormorant Garamond',serif;font-size:clamp(20px,3vw,26px);font-weight:400;color:#2E1E1E;line-height:1.36;margin-bottom:22px}
.tp-step-q em{font-style:italic;color:#A85470}
.eva-wrap{margin-bottom:8px}
.eva-slider{
  -webkit-appearance:none;appearance:none;
  width:100%;height:6px;border-radius:6px;outline:none;cursor:pointer;
  background:linear-gradient(to right,#A85470 0%,#A85470 var(--val,50%),#F5E2E2 var(--val,50%),#F5E2E2 100%);
  margin:16px 0;
}
.eva-slider::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:24px;height:24px;border-radius:50%;
  background:#A85470;cursor:pointer;
  box-shadow:0 2px 8px rgba(168,84,112,0.3);transition:transform .15s;
}
.eva-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}
.eva-labels{display:flex;justify-content:space-between;font-size:11px;color:#A08080}
.eva-value{text-align:center;margin:16px 0;font-family:'Cormorant Garamond',serif;font-size:52px;font-weight:400;color:#A85470;line-height:1}
.eva-desc{text-align:center;font-size:13px;color:#6B4A4A;font-style:italic;min-height:20px}
.tp-chips{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:16px}
.tp-chip{
  padding:9px 16px;border-radius:22px;
  border:1.5px solid rgba(168,84,112,0.20);background:#FFFFFF;
  font-size:12.5px;color:#6B4A4A;cursor:pointer;
  font-family:'Jost',sans-serif;font-weight:300;
  transition:all .18s;display:flex;align-items:center;gap:7px;
}
.tp-chip.on,.tp-chip.selected{background:#A85470;color:white;border-color:#A85470;font-weight:500}
.tp-chip.on::before,.tp-chip.selected::before{content:"✓ ";font-size:10px}
.tp-chip:hover{border-color:#C9849A;color:#A85470;background:#F5E2E2}
.tp-chip.selected{border-color:#A85470;background:#F5E2E2;color:#A85470;font-weight:500}
.tp-chip-icon{font-size:16px}
.tp-textarea{
  width:100%;border:1.5px solid rgba(168,84,112,0.20);border-radius:14px;
  padding:14px 16px;font-family:'Jost',sans-serif;font-size:13.5px;
  color:#2E1E1E;background:#FAF0F0;resize:none;
  outline:none;transition:border-color .2s;min-height:90px;line-height:1.6;
}
.tp-textarea:focus{border-color:#C9849A;background:#FFFFFF}
.tp-textarea::placeholder{color:#A08080}
.tp-progress-opts{display:flex;gap:10px;margin-bottom:16px}
.tp-progress-opt{
  flex:1;padding:14px 10px;border-radius:14px;
  border:1.5px solid rgba(168,84,112,0.20);background:#FFFFFF;
  text-align:center;cursor:pointer;transition:all .2s;
}
.tp-progress-opt:hover{border-color:#C9849A;background:#F5E2E2}
.tp-progress-opt.selected{border-color:#A85470;background:#A85470;color:white}
.tp-progress-opt.selected .tp-progress-opt-label{color:white}
.tp-progress-opt.selected .tp-progress-opt-sub{color:rgba(255,255,255,.8)}
.tp-progress-opt.selected .tp-progress-opt-icon{filter:brightness(1.2)}
.tp-progress-opt-icon{font-size:22px;display:block;margin-bottom:6px}
.tp-progress-opt-label{font-size:11.5px;color:#6B4A4A}
.tp-footer{
  padding:16px 24px 20px;
  padding-bottom:max(20px, env(safe-area-inset-bottom, 20px));
  border-top:1px solid rgba(168,84,112,0.11);
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;background:#FFFFFF;
}
.tp-btn-back{
  padding:10px 20px;border-radius:22px;border:1px solid rgba(168,84,112,0.20);
  background:transparent;color:#A08080;font-family:'Jost',sans-serif;
  font-size:13px;cursor:pointer;transition:all .2s;
}
.tp-btn-back:hover{border-color:#C9849A;color:#A85470}
.tp-btn-next{
  padding:12px 28px;border-radius:22px;
  background:#A85470;border:none;color:white;
  font-family:'Jost',sans-serif;font-size:13px;cursor:pointer;
  transition:all .22s;box-shadow:0 4px 16px rgba(168,84,112,0.22);
}
.tp-btn-next:hover{background:#7A3350;transform:translateY(-1px)}
.tp-btn-next:disabled{opacity:.35;pointer-events:none;transform:none}
#trace-result{display:none;position:relative;}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.prenom-welcome-block{animation:slideUp .5s cubic-bezier(.4,0,.2,1) both}
#prenom-selector{animation:fadeIn .3s ease both}
.prenom-card{transition:all .18s cubic-bezier(.4,0,.2,1)}
#chat-transition-overlay{position:fixed;inset:0;background:#A85470;z-index:99999;opacity:0;pointer-events:none;transition:opacity .6s ease}
.tr-header{padding:20px 24px 16px;border-bottom:1px solid rgba(168,84,112,0.11);display:flex;align-items:center;gap:12px}
.tr-icon{width:40px;height:40px;background:linear-gradient(135deg,#7A3350,#A85470);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px}
.tr-title{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:500;color:#2E1E1E}
.tr-sub{font-size:11px;color:#C9849A;margin-top:1px}
.tr-body{padding:22px 24px;overflow-y:auto;flex:1}
.tr-body::-webkit-scrollbar{width:3px}
.tr-body::-webkit-scrollbar-thumb{background:#ECC8C8;border-radius:3px}
.tr-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}
.tr-card{background:#FAF0F0;border:1px solid rgba(168,84,112,0.11);border-radius:16px;padding:16px;position:relative;overflow:hidden}
.tr-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.tr-card:nth-child(1)::before{background:linear-gradient(to right,#7A3350,#A85470)}
.tr-card:nth-child(2)::before{background:linear-gradient(to right,#A85470,#C9849A)}
.tr-card:nth-child(3)::before{background:linear-gradient(to right,#C9849A,#ECC8C8)}
.tr-card:nth-child(4)::before{background:linear-gradient(to right,#ECC8C8,rgba(236,200,200,0))}
.tr-card-label{font-size:8.5px;letter-spacing:2px;text-transform:uppercase;color:#C9849A;margin-bottom:8px}
.tr-card-value{font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:500;color:#2E1E1E;line-height:1.4}
.tr-card-sub{font-size:11px;color:#A08080;margin-top:4px;font-style:italic}
.tr-ia{background:#FFFFFF;border:1px solid rgba(168,84,112,0.11);border-radius:16px;padding:18px 20px}
.tr-ia-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.tr-ia-av{width:32px;height:32px;background:linear-gradient(135deg,#7A3350,#A85470);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.tr-ia-name{font-size:12px;font-weight:500;color:#2E1E1E}
.tr-ia-text{font-size:13.5px;color:#6B4A4A;line-height:1.76}
.tr-ia-text strong{color:#7A3350;font-weight:500}
.tr-footer{padding:14px 24px 20px;border-top:1px solid rgba(168,84,112,0.11);display:flex;gap:10px}
.tr-btn-redo{padding:11px 20px;border-radius:22px;border:1px solid rgba(168,84,112,0.20);background:transparent;color:#A08080;font-family:'Jost',sans-serif;font-size:12px;cursor:pointer;transition:all .2s}
.tr-btn-redo:hover{border-color:#C9849A;color:#A85470}
.tr-btn-chat{flex:1;padding:12px 20px;border-radius:22px;background:#A85470;border:none;color:white;font-family:'Jost',sans-serif;font-size:13px;cursor:pointer;transition:all .22s;box-shadow:0 4px 16px rgba(168,84,112,0.22)}
.tr-btn-chat:hover{background:#7A3350}
@media(max-width:500px){.tr-cards{grid-template-columns:1fr}.tp-progress-opts{flex-direction:column}#trace-panel{border-radius:20px 20px 0 0;max-height:96vh}}

/* ══ DOUBLE BILAN ══ */















.bc-badge{display:inline-block;background:var(--rose-deep);color:white;font-size:9px;letter-spacing:1px;padding:2px 7px;border-radius:20px;text-transform:uppercase;margin-bottom:6px;}
@media(max-width:480px){}


/* ══ BILAN CHOICE — NOUVEAU VISUEL ══ */
#bilan-choice{
  display:none;flex-direction:column;align-items:center;
  justify-content:center;flex:1;padding:28px 24px;gap:20px;text-align:center;
}
.bc-header-tag{
  font-size:10px;letter-spacing:3px;text-transform:uppercase;
  color:var(--rose-dark);font-weight:500;margin-bottom:2px;
}
.bc-header-title{
  font-family:'Cormorant Garamond',serif;
  font-size:22px;font-weight:300;color:var(--text);
  line-height:1.3;margin-bottom:6px;
}
.bc-header-title em{font-style:italic;color:var(--rose-dark);}
.bc-header-sub{
  font-size:12.5px;color:var(--text-s);line-height:1.65;
  max-width:320px;margin:0 auto;
}
.bc-cards{
  display:grid;grid-template-columns:1fr 1fr;
  gap:14px;width:100%;
}
.bc-card{
  border-radius:16px;padding:22px 18px;
  cursor:pointer;transition:all .22s cubic-bezier(.4,0,.2,1);
  text-align:left;border:1.5px solid transparent;
  position:relative;
}
.bc-card.rapide{
  background:var(--rose-pale);
  border-color:var(--border-m);
}
.bc-card.rapide:hover{
  border-color:var(--rose-dark);
  box-shadow:0 4px 16px rgba(168,84,112,0.12);
  transform:translateY(-2px);
}
.bc-card.approfondi{
  background:white;
  border-color:var(--rose-dark);
  box-shadow:0 2px 12px rgba(168,84,112,0.1);
}
.bc-card.approfondi:hover{
  box-shadow:0 6px 24px rgba(168,84,112,0.18);
  transform:translateY(-2px);
}
.bc-badge{
  position:absolute;top:-10px;left:50%;
  transform:translateX(-50%);
  background:var(--rose-dark);color:white;
  font-size:9px;letter-spacing:1.5px;text-transform:uppercase;
  padding:3px 12px;border-radius:20px;font-weight:500;
  white-space:nowrap;
}
.bc-icon-wrap{
  width:38px;height:38px;border-radius:50%;
  background:rgba(168,84,112,0.08);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:12px;
}
.bc-icon-wrap svg{stroke:var(--rose-dark);fill:none;stroke-width:1.8;}
.bc-name{
  font-size:15px;font-weight:500;
  color:var(--text);margin-bottom:4px;
}
.bc-card.approfondi .bc-name{color:var(--rose-deep);}
.bc-pills{
  display:flex;align-items:center;gap:6px;margin-bottom:8px;
}
.bc-pill-time{
  font-size:11px;background:rgba(168,84,112,0.1);
  color:var(--rose-dark);padding:2px 10px;
  border-radius:20px;font-weight:500;
}
.bc-pill-steps{
  font-size:11px;color:var(--text-s);
}
.bc-desc{
  font-size:12px;color:var(--text-s);line-height:1.6;margin-bottom:12px;
}
.bc-cta{
  font-size:12px;color:var(--rose-dark);
  display:flex;align-items:center;gap:4px;font-weight:500;
}
.bc-cta svg{stroke:currentColor;fill:none;stroke-width:1.8;transition:transform .2s;}
.bc-card:hover .bc-cta svg{transform:translateX(3px);}
.bc-footer{
  border-top:1px solid var(--border);
  padding-top:14px;width:100%;
  display:flex;align-items:flex-start;gap:10px;
}
.bc-footer-icon svg{stroke:var(--rose-mid);fill:none;stroke-width:1.5;flex-shrink:0;margin-top:1px;}
.bc-footer-text{
  font-size:11px;color:var(--text-s);line-height:1.6;text-align:left;
}
@media(max-width:440px){.bc-cards{grid-template-columns:1fr;}}


.msg-disclaimer{font-size:11px;color:rgba(168,84,112,0.4);font-style:italic;margin-top:8px;padding-top:6px;border-top:1px solid rgba(168,84,112,0.08);line-height:1.5;}

/* ══ WATERMARK PHILOSOPHIE ══ */
.chat-watermark{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(20px,4vw,40px);
  font-weight:300;
  font-style:italic;
  color:rgba(168,84,112,0.08);
  text-align:center;
  white-space:normal;
  width:90%;
  pointer-events:none;
  user-select:none;
  line-height:1.5;
  z-index:0;
  letter-spacing:2px;
}
.chat-watermark span{display:block;}


/* ══ CONSENTEMENT ÉTUDE CLINIQUE ══ */
#study-overlay{
  position:fixed;inset:0;z-index:9998;
  background:rgba(26,22,17,0.88);
  backdrop-filter:blur(10px);
  display:none;align-items:center;justify-content:center;
  padding:20px;
}
#study-overlay.show{display:flex;}
#study-panel{
  background:#FAF7F2;
  border-radius:20px;
  padding:40px 36px;
  max-width:520px;width:100%;
  position:relative;
}
.sp-badge{
  display:inline-block;
  background:rgba(26,90,118,0.1);
  color:#1A5276;
  font-size:9px;letter-spacing:2.5px;text-transform:uppercase;
  padding:4px 12px;border-radius:20px;font-weight:500;
  margin-bottom:16px;
}
.sp-title{
  font-family:'Cormorant Garamond',serif;
  font-size:26px;font-weight:300;color:#1A1611;
  line-height:1.3;margin-bottom:10px;
}
.sp-title em{font-style:italic;color:#1A5276;}
.sp-text{
  font-size:13px;color:#5A4E3A;line-height:1.8;
  margin-bottom:18px;
}
.sp-items{
  background:rgba(26,90,118,0.05);
  border:1px solid rgba(26,90,118,0.15);
  border-radius:12px;
  padding:16px 18px;
  margin-bottom:18px;
}
.sp-item{
  font-size:12px;color:#2C2417;line-height:1.8;
  display:flex;gap:8px;
}
.sp-item::before{content:'◦';color:#1A5276;flex-shrink:0;}
.sp-btns{display:flex;gap:10px;margin-top:20px;}
.sp-btn-yes{
  flex:1;padding:13px;border-radius:30px;
  background:linear-gradient(135deg,#0E4D72,#1A5276,#2471A3);
  border:none;color:white;
  font-family:'Jost',sans-serif;font-size:13px;font-weight:500;
  cursor:pointer;transition:all .22s;
  box-shadow:0 4px 16px rgba(26,90,118,0.25);
}
.sp-btn-yes:hover{box-shadow:0 6px 24px rgba(26,90,118,0.35);transform:translateY(-1px);}
.sp-btn-no{
  flex:1;padding:13px;border-radius:30px;
  background:transparent;
  border:1px solid rgba(44,36,23,0.15);
  color:#7A6E5F;
  font-family:'Jost',sans-serif;font-size:13px;
  cursor:pointer;transition:all .2s;
}
.sp-btn-no:hover{border-color:rgba(44,36,23,0.3);color:#2C2417;}
.sp-footer{
  margin-top:14px;font-size:10px;color:#A89880;
  text-align:center;line-height:1.6;
}


/* ══ UPLOAD DOCUMENT ══ */
.upload-btn{width:32px;height:32px;border-radius:50%;background:transparent;border:1.5px solid rgba(168,84,112,0.2);color:rgba(168,84,112,0.5);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .18s;flex-shrink:0;margin-right:4px;}
.upload-btn:hover{background:rgba(168,84,112,0.08);border-color:rgba(168,84,112,0.4);color:#A85470;}
.upload-btn svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;}
#file-input-doc{display:none;}
.doc-preview{display:none;align-items:center;gap:8px;padding:8px 12px;background:rgba(168,84,112,0.06);border:1px solid rgba(168,84,112,0.2);border-radius:10px;margin-bottom:8px;font-size:12px;color:rgba(168,84,112,0.8);font-family:'Jost',sans-serif;}
.doc-preview.show{display:flex;}
.doc-preview-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.doc-remove{background:none;border:none;color:rgba(168,84,112,0.5);cursor:pointer;font-size:16px;padding:0 2px;line-height:1;}

.mrow{position:relative;z-index:1;}

/* ══ SCENE-B ══ */
#scene-b{
  position:fixed;inset:0;z-index:99999;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;padding:40px 24px;
  background:#FAF0F2;
  transition:opacity .9s ease;
}
#scene-b.out{opacity:0;pointer-events:none;}
.sc-circle-wrap{
  position:relative;width:340px;height:340px;
  margin-bottom:28px;flex-shrink:0;
}
.sc-r1{
  position:absolute;inset:0;border-radius:50%;
  border:1px solid rgba(168,84,112,0.12);
}
.sc-r2{
  position:absolute;top:24px;left:24px;right:24px;bottom:24px;
  border-radius:50%;border:1px solid rgba(168,84,112,0.07);
}
.sc-inner{
  position:absolute;inset:0;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:20px;
}
.sc-ser-letters{
  font-family:'Cormorant Garamond',serif;
  font-size:20px;font-weight:300;letter-spacing:10px;line-height:1;
  background:linear-gradient(to right,#7A3350,#A85470,#CC5C88);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  opacity:0;transform:translateY(-14px);
  transition:opacity 1.2s ease 3.2s,transform 1.2s ease 3.2s;
}
.sc-phrase{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  opacity:0;filter:blur(16px);transform:scale(1.06);
  transition:opacity 1.8s ease 0.3s,filter 1.8s ease 0.3s,transform 1.8s ease 0.3s;
}
.sc-l1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(28px,5vw,38px);font-weight:300;
  color:#2C2417;line-height:1.25;display:block;
}
.sc-l2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(28px,5vw,38px);font-weight:400;
  color:#A85470;font-style:italic;line-height:1.25;display:block;
}
.sc-tags{
  display:flex;align-items:center;gap:8px;
  font-family:'Jost',sans-serif;font-size:10px;
  letter-spacing:2.5px;text-transform:uppercase;color:#B0A090;
  margin-bottom:28px;
  opacity:0;transform:translateY(10px);
  transition:opacity 1s ease 2s,transform 1s ease 2s;
}
.sc-td{color:#C9849A;}
.sc-btn-wrap{
  opacity:0;transform:translateY(10px);
  transition:opacity .9s ease 4.4s,transform .9s ease 4.4s;
}
.sc-enter-btn{
  padding:13px 44px;border-radius:40px;background:transparent;
  border:1.5px solid rgba(168,84,112,0.25);color:#7A6E5F;
  font-family:'Jost',sans-serif;font-size:10px;
  letter-spacing:3px;text-transform:uppercase;cursor:pointer;transition:all .25s;
}
.sc-enter-btn:hover{border-color:rgba(168,84,112,0.5);color:#A85470;}
#scene-b.go .sc-phrase{opacity:1;filter:blur(0);transform:scale(1);}
#scene-b.go .sc-tags{opacity:1;transform:translateY(0);}
#scene-b.go .sc-ser-letters{opacity:1;transform:translateY(0);}
#scene-b.go .sc-btn-wrap{opacity:1;transform:translateY(0);}

/* ══ PARCOURS 3 ÉTAPES ══ */
#parcours-overlay{position:fixed;inset:0;z-index:1001;background:rgba(46,24,30,0.62);backdrop-filter:blur(12px);display:none;align-items:flex-end;justify-content:center;padding:8px}
#parcours-overlay.open{display:flex}
#parcours-panel{background:#FAF0F2;border-radius:28px 28px 22px 22px;width:100%;max-width:610px;max-height:96vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 -12px 60px rgba(100,40,60,0.22);animation:slideUp .38s cubic-bezier(.4,0,.2,1)}
.par-head{padding:18px 20px 14px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(168,84,112,0.1);flex-shrink:0}
.par-steps{display:flex;align-items:center;gap:8px}
.par-step-dot{width:8px;height:8px;border-radius:50%;background:rgba(168,84,112,0.2);transition:all .3s}
.par-step-dot.active{background:#A85470;width:24px;border-radius:4px}
.par-step-dot.done{background:rgba(168,84,112,0.5)}
.par-step-label{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:#A85470;font-family:'Jost',sans-serif}
.par-close{width:28px;height:28px;border-radius:50%;background:#F0E0E4;border:none;cursor:pointer;font-size:14px;color:#A85470;display:flex;align-items:center;justify-content:center;transition:background .2s}
.par-close:hover{background:#EAD0D8}
.par-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:24px 22px}
.par-title{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:400;color:#2E1818;line-height:1.3;margin-bottom:8px}
.par-sub{font-size:13px;color:#8A7070;line-height:1.72;margin-bottom:22px}
.par-anchors{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}
.par-anchor{padding:14px 16px;background:white;border:1.5px solid rgba(168,84,112,0.15);border-radius:14px;cursor:pointer;text-align:left;transition:all .2s;font-family:'Jost',sans-serif}
.par-anchor:hover{border-color:#A85470;background:#FDF5F7;transform:translateY(-1px)}
.par-anchor.selected{border-color:#A85470;background:#FDF0F4;box-shadow:0 0 0 3px rgba(168,84,112,0.1)}
.par-anchor-icon{font-size:20px;margin-bottom:6px;display:block}
.par-anchor-label{font-size:12.5px;font-weight:500;color:#2E1818;line-height:1.4}
.par-anchor-desc{font-size:11px;color:#A08080;margin-top:3px;line-height:1.4}
.par-footer{padding:14px 22px 20px;padding-bottom:max(20px, env(safe-area-inset-bottom, 20px));border-top:1px solid rgba(168,84,112,0.08);flex-shrink:0;display:flex;gap:10px;background:#FAF0F2}
.par-btn-next{flex:1;padding:14px;border-radius:20px;background:#A85470;border:none;color:white;font-family:'Jost',sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .22s;box-shadow:0 4px 16px rgba(168,84,112,0.22)}
.par-btn-next:hover{background:#8A3A58;transform:translateY(-1px)}
.par-btn-next:disabled{opacity:.4;pointer-events:none;transform:none}
.par-btn-skip{padding:14px 18px;border-radius:20px;background:transparent;border:1px solid rgba(168,84,112,0.2);color:#A08080;font-family:'Jost',sans-serif;font-size:12px;cursor:pointer;transition:all .2s}
.par-btn-skip:hover{border-color:#A85470;color:#A85470}
.par-score-reveal{background:linear-gradient(135deg,#7A3350,#A85470);border-radius:16px;padding:22px;text-align:center;margin-bottom:18px}
.par-score-num{font-family:'Cormorant Garamond',serif;font-size:64px;font-weight:300;color:white;line-height:1}
.par-score-label{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.6);margin-top:4px}
.par-dim-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.par-dim-name{font-size:11.5px;color:#5A3A40;width:140px;flex-shrink:0}
.par-dim-bar{flex:1;height:6px;background:rgba(168,84,112,0.12);border-radius:3px;overflow:hidden}
.par-dim-fill{height:100%;border-radius:3px;transition:width 1s cubic-bezier(.4,0,.2,1)}
.par-dim-val{font-size:11px;font-weight:600;width:32px;text-align:right;flex-shrink:0}
.proto-save-btn{display:inline-flex;align-items:center;gap:5px;margin-top:10px;padding:5px 12px;border-radius:16px;border:1px solid var(--border-m);background:transparent;color:var(--text-s);font-size:10px;letter-spacing:.5px;font-family:'Jost',sans-serif;cursor:pointer;transition:all .18s;}
.proto-save-btn:hover{border-color:var(--rose-mid);color:var(--rose-deep);background:var(--rose-soft)}
.proto-save-btn.saved{border-color:var(--rose-mid);color:var(--rose-deep);pointer-events:none}
.proto-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(60px);background:var(--rose-dark);color:white;padding:12px 20px;border-radius:12px;font-size:12px;font-family:'Jost',sans-serif;z-index:99999;transition:transform .3s,opacity .3s;opacity:0;pointer-events:none;white-space:nowrap;box-shadow:0 8px 32px rgba(100,40,60,0.22);}
.proto-toast.show{transform:translateX(-50%) translateY(0);opacity:1}
#proto-overlay{display:none;position:fixed;inset:0;z-index:99998;background:rgba(46,30,30,0.55);backdrop-filter:blur(10px);align-items:center;justify-content:center;padding:20px;}
#proto-overlay.open{display:flex}
#proto-panel{background:var(--rose-pale);border:1px solid var(--border);border-radius:22px;width:100%;max-width:560px;max-height:88vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(100,40,60,0.2);animation:protoIn .3s ease}
@keyframes protoIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.proto-ph{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--white);flex-shrink:0;}
.proto-ph-num{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:400;color:var(--rose-deep)}
.proto-ph-meta{font-size:11px;color:var(--text-s);margin-top:2px}
.proto-ph-x{width:30px;height:30px;border-radius:8px;background:var(--rose-soft);border:none;cursor:pointer;font-size:14px;color:var(--text-m);display:flex;align-items:center;justify-content:center}
.proto-pb{flex:1;overflow-y:auto;padding:20px;font-size:13px;color:var(--text);line-height:1.76}
.proto-pb::-webkit-scrollbar{width:3px}
.proto-pb::-webkit-scrollbar-thumb{background:var(--rose-light);border-radius:3px}
.proto-pb strong{color:var(--rose-dark)}
.proto-pf{padding:12px 20px;border-top:1px solid var(--border);display:flex;gap:8px;flex-shrink:0;background:var(--white)}
.proto-pf-btn{flex:1;padding:9px;border-radius:20px;border:1px solid var(--border-m);background:transparent;color:var(--text-s);font-family:'Jost',sans-serif;font-size:12px;cursor:pointer;transition:all .2s}
.proto-pf-btn:hover{border-color:var(--rose-mid);color:var(--rose-deep)}
.proto-empty{text-align:center;padding:40px 20px;font-size:13px;color:var(--text-s)}
.proto-search-wrap{position:relative;display:flex;align-items:center}
.proto-search-input{width:110px;padding:6px 30px 6px 11px;border:1px solid var(--border-m);border-radius:20px;background:transparent;font-family:'Jost',sans-serif;font-size:11px;color:var(--text);outline:none;transition:all .2s;}
.proto-search-input::placeholder{color:var(--text-s)}
.proto-search-input:focus{border-color:var(--rose-mid);width:140px}
.proto-search-btn{position:absolute;right:8px;background:none;border:none;cursor:pointer;color:var(--text-s);padding:0;display:flex;transition:color .18s}
.proto-search-btn:hover{color:var(--rose-deep)}
@media(max-width:700px){.proto-search-input{width:80px}.proto-search-input:focus{width:110px}}


/* ── CLOSE CHAT BUTTON ── */
.chat-close-bar{
  display:flex;flex-direction:column;align-items:center;
  gap:6px;padding:10px 16px 4px;
  border-top:1px solid rgba(168,84,112,0.08);
  margin-top:4px;
}
.chat-close-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 22px;border-radius:22px;
  border:1.5px solid rgba(168,84,112,0.25);
  background:transparent;
  color:#A85470;font-family:'Jost',sans-serif;font-size:12px;
  font-weight:400;letter-spacing:.3px;
  cursor:pointer;transition:all .22s;
  text-decoration:none;
}
.chat-close-btn:hover{
  background:#F5E2E2;border-color:#A85470;
  transform:translateY(-1px);
}
.chat-close-btn svg{width:14px;height:14px;fill:#A85470;flex-shrink:0}
.chat-close-label{
  font-size:10px;color:#A08080;text-align:center;
  line-height:1.5;letter-spacing:.2px;font-style:italic;
}


/* ── TÉLÉCHARGEMENT ── */
.tr-dl-bar{
  padding:10px 20px 4px;
  display:flex;gap:8px;flex-shrink:0;
  border-top:1px solid rgba(168,84,112,0.08);
  background:#FAF0F2;
}
.tr-dl-btn{
  display:flex;align-items:center;justify-content:center;gap:6px;
  padding:8px 0;flex:1;border-radius:18px;
  font-family:'Jost',sans-serif;font-size:11.5px;cursor:pointer;
  transition:all .2s;border:1.5px solid rgba(168,84,112,0.25);
  background:white;color:#A85470;font-weight:400;
}
.tr-dl-btn:hover{background:#F5E2E2;border-color:#A85470;}
.tr-dl-btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;flex-shrink:0}


/* ── TÉMOIGNAGES SEREINIA ── */
.temo-section{padding:52px 20px;background:linear-gradient(180deg,#FAF0F2 0%,#FDF5F7 100%)}
.temo-tag{font-size:9.5px;letter-spacing:3px;text-transform:uppercase;color:#C9849A;text-align:center;margin-bottom:10px}
.temo-title{font-family:'Cormorant Garamond',serif;font-size:28px;color:#2E1E1E;text-align:center;margin-bottom:6px;font-weight:300}
.temo-sub{font-size:13px;color:#A08080;text-align:center;margin-bottom:32px;line-height:1.6}
.temo-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:720px;margin:0 auto 32px}
.temo-card{background:white;border-radius:16px;padding:18px 20px;border:1px solid rgba(168,84,112,0.1);position:relative}
.temo-card::before{content:'"';font-family:'Cormorant Garamond',serif;font-size:48px;color:rgba(168,84,112,0.12);position:absolute;top:8px;left:14px;line-height:1}
.temo-text{font-size:13px;color:#2E1E1E;line-height:1.72;font-style:italic;padding-top:14px;position:relative}
.temo-author{font-size:10px;color:#A08080;margin-top:10px;letter-spacing:0.5px}
.temo-empty{text-align:center;color:#C9849A;font-style:italic;font-size:13px;padding:20px;grid-column:1/-1}
.temo-form-wrap{max-width:480px;margin:0 auto;background:white;border-radius:18px;padding:22px 24px;border:1px solid rgba(168,84,112,0.12)}
.temo-form-title{font-size:13px;font-weight:500;color:#2E1E1E;margin-bottom:4px}
.temo-form-sub{font-size:11.5px;color:#A08080;margin-bottom:14px;line-height:1.5}
.temo-textarea{width:100%;box-sizing:border-box;border:1.5px solid rgba(168,84,112,0.2);border-radius:12px;padding:12px 14px;font-family:'Jost',sans-serif;font-size:13px;color:#2E1E1E;resize:none;outline:none;min-height:90px;background:#FAF0F2}
.temo-textarea:focus{border-color:#A85470;background:white}
.temo-submit{width:100%;margin-top:10px;padding:12px;border-radius:22px;background:#A85470;border:none;color:white;font-family:'Jost',sans-serif;font-size:13px;cursor:pointer;transition:background .2s}
.temo-submit:hover{background:#7A3350}
.temo-confirm{display:none;text-align:center;padding:14px;font-size:13px;color:#2D6A4F;background:#E8F5EE;border-radius:12px;margin-top:10px;line-height:1.6}
@media(max-width:500px){.temo-grid{grid-template-columns:1fr}}


/* ── RAPPORT KINÉ SEIN ── */
.btn-kine-pro{padding:9px 15px;border-radius:22px;border:1.5px solid rgba(168,84,112,0.3);background:transparent;color:#A85470;font-family:'Jost',sans-serif;font-size:11.5px;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:all .2s;white-space:nowrap}
.btn-kine-pro:hover{background:rgba(168,84,112,0.07);border-color:#A85470}
#kine-view-panel{display:none;position:absolute;inset:0;background:#FAF0F2;border-radius:inherit;flex-direction:column;z-index:20;overflow:hidden}
#kine-view-panel.open{display:flex}
.kine-hdr{padding:12px 18px;border-bottom:1px solid rgba(168,84,112,0.12);display:flex;align-items:center;gap:10px;flex-shrink:0;background:#FAF0F2}
.prenom-card{padding:9px 8px;border:1.5px solid rgba(168,84,112,0.18);border-radius:12px;cursor:pointer;text-align:center;transition:all .2s;background:white}
.prenom-card:hover{border-color:#A85470;background:#FDF0F4}
.prenom-card.selected{border-color:#A85470;background:#FDF0F4;box-shadow:0 0 0 2px rgba(168,84,112,0.2)}
.prenom-card-name{font-family:'Cormorant Garamond',serif;font-size:15px;font-weight:500;color:#2E1818;margin-bottom:2px}
.prenom-card-phrase{font-size:9.5px;color:#A85470;line-height:1.4;font-style:italic}
.kine-back{background:none;border:none;cursor:pointer;font-size:18px;color:#C9849A;padding:0 4px}
.kr-s{margin-bottom:14px}
.kr-st{font-size:8px;letter-spacing:2.5px;text-transform:uppercase;color:#A85470;margin-bottom:7px;padding-bottom:5px;border-bottom:2px solid rgba(168,84,112,0.15);display:flex;align-items:center;gap:6px;font-weight:500}
.kr-r{display:flex;gap:8px;padding:5px 0;border-bottom:1px solid rgba(168,84,112,0.06);font-size:11.5px;line-height:1.5}
.kr-l{color:#8A7070;min-width:42%;flex-shrink:0;font-size:11px}
.kr-v{color:#2E1818;flex:1}
.kr-bar{display:flex;align-items:center;gap:8px;margin-top:3px}
.kr-bt{flex:1;height:5px;background:#EEE;border-radius:3px;overflow:hidden}
.kr-bf{height:100%;border-radius:3px;transition:width .5s}
.kr-flag{display:flex;gap:8px;padding:8px 10px;border-radius:0 8px 8px 0;margin-bottom:6px;font-size:11.5px;line-height:1.5;border-left-width:3px;border-left-style:solid}
/* ══ BETA SEREINIA ══ */
#ser-beta{position:fixed;inset:0;z-index:9000;background:rgba(122,51,80,0.60);backdrop-filter:blur(12px);display:none;align-items:center;justify-content:center;padding:24px;overflow-y:auto}
#ser-beta::-webkit-scrollbar{display:none}
#ser-beta.open{display:flex}
#ser-beta.hide{opacity:0;pointer-events:none;transition:opacity .5s ease}
.sbp{background:#FDF6F6;border-radius:24px;padding:32px 28px;max-width:420px;width:100%;box-shadow:0 20px 60px rgba(122,51,80,0.18);overflow:visible}
.sbp-badge{display:inline-block;font-size:10px;letter-spacing:2px;text-transform:uppercase;padding:4px 14px;border-radius:20px;background:#FAF0F0;border:1px solid #ECC8C8;color:#A85470;margin-bottom:16px}
.sbp-tag{font-size:10px;letter-spacing:4px;text-transform:uppercase;color:#C9849A;margin-bottom:6px}
.sbp h2{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:400;color:#2E1E1E;line-height:1.28;margin:0 0 8px}
.sbp h2 em{font-style:italic;color:#A85470}
.sbp-sub{font-size:13px;color:#6B4A4A;line-height:1.7;margin:0 0 18px}
.sbp-context{background:#FAF0F0;border:1px solid #ECC8C8;border-radius:12px;padding:14px 16px;margin-bottom:20px;font-size:12.5px;color:#7A3350;line-height:1.65}
.sbp-context strong{font-weight:500;color:#5A2840}
.sbp-label{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:#A08080;display:block;margin-bottom:6px}
.sbp-input{width:100%;padding:10px 14px;border-radius:10px;border:1px solid rgba(168,84,112,0.20);font-family:'Jost',sans-serif;font-size:13.5px;color:#2E1E1E;background:#FFFFFF;box-sizing:border-box;margin-bottom:16px;outline:none}
.sbp-input:focus{border-color:rgba(168,84,112,0.45)}
.sbp-profiles{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px}
.sbp-profile{padding:10px 12px;border-radius:10px;border:1px solid rgba(168,84,112,0.18);background:#FFFFFF;font-size:12.5px;color:#6B4A4A;text-align:center;cursor:pointer;transition:all .18s;font-family:'Jost',sans-serif}
.sbp-profile:hover{border-color:#C9849A;color:#A85470;background:#FAF0F0}
.sbp-profile.selected{border-color:#A85470;background:#F5E2E2;color:#7A3350;font-weight:500}
.sbp-check{display:flex;align-items:flex-start;gap:10px;margin-bottom:22px}
.sbp-check input{margin-top:3px;flex-shrink:0;accent-color:#A85470}
.sbp-check label{font-size:12px;color:#6B4A4A;line-height:1.65}
.sbp-check label strong{font-weight:500;color:#2E1E1E}
.sbp-btn{width:100%;padding:13px;border-radius:30px;background:rgba(168,84,112,0.3);border:none;color:white;font-size:13.5px;font-family:'Jost',sans-serif;cursor:not-allowed;transition:all .22s;letter-spacing:.3px}
.sbp-btn.on{background:#A85470;cursor:pointer;box-shadow:0 6px 20px rgba(168,84,112,0.25)}
.sbp-btn.on:hover{background:#7A3350;transform:translateY(-1px)}
.sbp-footer{text-align:center;margin-top:16px;font-size:11px;color:#A08080;line-height:1.6}
/* ══ OVERLAY CGU ══ */
#cgu-overlay{position:fixed;inset:0;z-index:99999;background:var(--rose-pale);display:none;overflow-y:auto;padding:60px 40px}
#cgu-overlay.open{display:block}
.cgu-inner{max-width:720px;margin:0 auto}
.cgu-close{position:fixed;top:20px;right:28px;width:36px;height:36px;border-radius:10px;background:var(--rose-soft);border:none;cursor:pointer;font-size:18px;color:var(--text-m);display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:100000}
.cgu-close:hover{background:var(--rose-light)}
.cgu-title{font-family:'Cormorant Garamond',serif;font-size:38px;font-weight:400;color:var(--text);margin-bottom:8px}
.cgu-date{font-size:12px;color:var(--text-s);margin-bottom:48px;letter-spacing:.5px}
.cgu-section{margin-bottom:36px}
.cgu-section h2{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:500;color:var(--rose-dark);margin-bottom:12px}
.cgu-section p{font-size:14px;color:var(--text-m);line-height:1.82;margin-bottom:8px}
.cgu-section strong{color:var(--text);font-weight:500}
.cgu-highlight{background:var(--rose-soft);border-left:3px solid var(--rose-mid);border-radius:0 10px 10px 0;padding:14px 18px;margin:12px 0;font-size:13px;color:var(--text-m);line-height:1.7}
@media(max-width:600px){#cgu-overlay{padding:40px 20px}}

/* ══ SUIVI HEBDOMADAIRE + PWA ══ */
.suivi-bloc{background:white;border-radius:16px;padding:18px;margin-bottom:14px;border:1px solid rgba(168,84,112,0.08)}
.suivi-dim-label{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:#A85470;margin-bottom:14px;font-weight:500}
.suivi-q{font-size:13px;color:#2E1818;line-height:1.6;margin-bottom:10px;margin-top:14px}
.suivi-scale{margin-bottom:4px}
.suivi-scale-labels{display:flex;justify-content:space-between;font-size:10px;color:#A08080;margin-bottom:4px}
.suivi-slider{width:100%;accent-color:#A85470;cursor:pointer}
.suivi-slider-val{text-align:center;font-size:12px;font-weight:500;color:#A85470;margin-top:2px}
.suivi-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}
.suivi-chip{padding:7px 14px;border-radius:20px;border:1.5px solid rgba(168,84,112,0.2);background:white;color:#5A3A40;font-family:'Jost',sans-serif;font-size:12px;cursor:pointer;transition:all .18s}
.suivi-chip:hover{border-color:#A85470;background:#FDF5F7}
.suivi-chip.selected{border-color:#A85470;background:#FDF0F4;color:#7A3350;font-weight:500}
.notif-chip{padding:8px 12px;border-radius:12px;border:1.5px solid rgba(168,84,112,0.2);background:white;color:#5A3A40;font-family:'Jost',sans-serif;font-size:12px;cursor:pointer;text-align:center;transition:all .18s}
.notif-chip:hover{border-color:#A85470;background:#FDF5F7}
.notif-chip.selected{border-color:#A85470;background:#FDF0F4;color:#7A3350;font-weight:500}


/* ═══════════════════════════════════════════════════════════════════
   SEREINIA VISION D · STYLES (intégrés 22/04/2026)
   Tous les sélecteurs préfixés .serV2- pour isolation complète
   du CSS existant. Aucun risque de conflit.
   ═══════════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════════
   SEREINIA VISION D · CSS isolé
   Tous les sélecteurs préfixés .serV2- pour éviter conflit avec CSS existant
   À inclure dans kap-sereinia.css
   ═══════════════════════════════════════════════════════════════════ */

.serV2-app {
  font-family: 'DM Sans', system-ui, sans-serif;
  background: var(--paper, #FDF8F3);
  min-height: 100vh;
  position: relative;
  padding-bottom: 80px;
  color: #3A2A28;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}
.serV2-app::before {
  content: '';
  position: absolute; inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(168,84,112,0.015) 1px, transparent 0);
  background-size: 22px 22px;
  pointer-events: none;
  z-index: 0;
}
.serV2-page-wrap { position: relative; z-index: 1; }

/* ═══ TABS DU HAUT (sticky) ═══ */
.serV2-tabs {
  display: flex;
  overflow-x: auto;
  padding: 14px 22px;
  gap: 20px;
  border-bottom: 1px solid rgba(168,84,112,0.08);
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  position: sticky; top: 0; z-index: 10;
  background: rgba(253, 248, 243, 0.96);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.serV2-tabs::-webkit-scrollbar { display: none; }
.serV2-tab {
  font-family: 'Cormorant Garamond', serif;
  font-size: 15px;
  color: #8A7070;
  padding: 4px 2px;
  border: none;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  cursor: pointer;
  letter-spacing: 0.3px;
  transition: color 0.25s, border-color 0.25s;
  background: none;
  font-weight: 400;
}
.serV2-tab:hover { color: #A85470; }
.serV2-tab.serV2-active {
  color: #7A3350;
  border-bottom-color: #7A3350;
  font-weight: 500;
}

/* ═══ PAGE / SECTION ═══ */
.serV2-page { display: none; padding: 24px 22px 20px; position: relative; }
.serV2-page.serV2-active { display: block; animation: serV2-fadeIn 0.35s ease-out; }
@keyframes serV2-fadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

.serV2-page-num {
  position: absolute; top: 24px; right: 28px;
  font-family: 'Cormorant Garamond', serif;
  font-style: italic; font-size: 11px;
  color: #A85470; letter-spacing: 2px;
}
.serV2-page-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 26px; font-weight: 400;
  color: #2A1F1C; line-height: 1.2;
  margin-bottom: 4px;
}
.serV2-page-title em { font-style: italic; color: #7A3350; }
.serV2-page-sub {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  color: #A85470; font-size: 14px;
  margin-bottom: 22px;
  padding-bottom: 14px;
  border-bottom: 1px dashed rgba(168,84,112,0.15);
}

/* ═══ ALERTE ═══ */
.serV2-alert {
  background: #FEF6E8;
  border-left: 3px solid #E8A348;
  padding: 14px 16px;
  border-radius: 0 12px 12px 0;
  display: flex; gap: 12px;
  margin-bottom: 22px;
}
.serV2-alert-icon { color: #E8A348; font-size: 18px; flex-shrink: 0; line-height: 1.3; }
.serV2-alert-label {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 11px; letter-spacing: 1px; text-transform: uppercase;
  color: #7A5F2A; font-weight: 600; margin-bottom: 3px;
}
.serV2-alert-text { font-size: 12.5px; color: #5A4828; line-height: 1.55; }
.serV2-alert-text em { font-style: italic; color: #7A5F2A; }
.serV2-alert-link {
  display: inline-block; margin-top: 6px;
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 12px; color: #7A3350;
  text-decoration: underline; text-underline-offset: 3px;
  cursor: pointer;
}

/* ═══ SCORE GLOBAL ═══ */
.serV2-dim-global {
  background: linear-gradient(135deg, #FFF8F3 0%, #F5E2DA 100%);
  border-radius: 18px;
  padding: 22px 22px 20px;
  text-align: center;
  margin-bottom: 18px;
  position: relative; overflow: hidden;
}
.serV2-dim-global::after {
  content: ''; position: absolute;
  top: -40px; right: -40px;
  width: 100px; height: 100px;
  border: 1px solid rgba(168,84,112,0.08);
  border-radius: 50%;
}
.serV2-dim-global-label {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 12px; letter-spacing: 2px;
  color: #A85470; text-transform: uppercase;
  margin-bottom: 8px;
}
.serV2-dim-global-score {
  font-family: 'Cormorant Garamond', serif;
  font-size: 56px; font-weight: 400;
  color: #2A1F1C; line-height: 1;
  letter-spacing: -1px;
  position: relative; z-index: 1;
}
.serV2-dim-global-score small { font-size: 20px; color: #8A7070; }
.serV2-dim-global-trend {
  margin-top: 8px;
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 13px; color: #7A3350;
}

.serV2-dims-intro {
  font-size: 13.5px; line-height: 1.75;
  color: #3A2A28;
  margin-bottom: 18px;
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
}
.serV2-dims-intro em { font-style: italic; color: #7A3350; }

/* ═══ CARTES DIMENSIONS ═══ */
.serV2-dims-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.serV2-dim-card {
  background: white;
  border: 1px solid rgba(168,84,112,0.08);
  border-radius: 14px;
  padding: 14px 14px 12px;
  cursor: pointer;
  transition: all 0.25s;
  text-align: left;
  width: 100%;
  font-family: inherit;
}
.serV2-dim-card:hover { border-color: rgba(168,84,112,0.15); transform: translateY(-1px); }
.serV2-dim-card:active { transform: scale(0.98); }
.serV2-dim-card-head {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 6px;
}
.serV2-dim-card-label {
  font-family: 'Cormorant Garamond', serif;
  font-size: 14px; color: #7A3350;
  font-weight: 500;
}
.serV2-dim-card-score {
  font-family: 'Cormorant Garamond', serif;
  font-size: 24px; font-weight: 500;
  color: #2A1F1C; line-height: 1;
}
.serV2-dim-card-score small { font-size: 11px; color: #8A7070; font-weight: normal; }
.serV2-dim-card-text {
  font-size: 11.5px; color: #8A7070;
  line-height: 1.5; font-style: italic;
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
}
.serV2-dim-bar {
  height: 3px; background: rgba(168,84,112,0.08);
  border-radius: 2px; overflow: hidden;
  margin: 8px 0 8px;
}
.serV2-dim-bar-fill { height: 100%; border-radius: 2px; }

/* ═══ QUOTE & SIGNATURE ═══ */
.serV2-quote {
  margin: 26px 6px;
  padding: 14px 20px 14px 26px;
  border-left: 3px solid #C4796A;
  font-family: 'Cormorant Garamond', serif;
  font-style: italic; font-size: 15px;
  color: #7A3350; line-height: 1.6;
  position: relative;
}
.serV2-quote::before {
  content: '"';
  position: absolute; left: 6px; top: 0;
  font-family: 'Cormorant Garamond', serif;
  font-size: 38px;
  color: #C4796A; opacity: 0.4; line-height: 1;
}
.serV2-signature {
  margin-top: 28px; padding-top: 20px;
  border-top: 1px dashed rgba(168,84,112,0.15);
  text-align: center;
}
.serV2-sig-name {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 17px;
  color: #7A3350;
}
.serV2-sig-title {
  font-size: 10px; letter-spacing: 2px; text-transform: uppercase;
  color: #8A7070; margin-top: 4px;
}

/* ═══ AUJOURD'HUI CARD ═══ */
.serV2-today-card {
  background: linear-gradient(135deg, #2A1F1C 0%, #3A2A28 100%);
  color: white;
  border-radius: 18px;
  padding: 22px 22px 20px;
  position: relative; overflow: hidden;
  margin-bottom: 22px;
}
.serV2-today-card::before {
  content: '';
  position: absolute;
  top: -30px; right: -30px;
  width: 140px; height: 140px;
  background: radial-gradient(circle, rgba(196, 121, 106, 0.35) 0%, transparent 70%);
}
.serV2-today-date {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 12px;
  color: rgba(245, 226, 218, 0.7);
  margin-bottom: 4px;
  position: relative; z-index: 1;
}
.serV2-today-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 26px; font-weight: 400;
  line-height: 1.15; margin-bottom: 14px;
  position: relative; z-index: 1;
}
.serV2-today-meta {
  display: flex; gap: 6px; flex-wrap: wrap;
  margin-bottom: 18px;
  position: relative; z-index: 1;
}
.serV2-meta-chip {
  background: rgba(245, 226, 218, 0.15);
  padding: 4px 10px; border-radius: 12px;
  font-size: 11px;
  color: rgba(245, 226, 218, 0.9);
  letter-spacing: 0.3px;
}
.serV2-today-cta {
  background: white; color: #2A1F1C;
  padding: 13px 24px; border-radius: 14px;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px; font-weight: 600;
  border: none; cursor: pointer; letter-spacing: 0.3px;
  display: inline-flex; align-items: center; gap: 8px;
  transition: transform 0.2s;
  position: relative; z-index: 1;
}
.serV2-today-cta:hover { transform: translateX(2px); }

/* ═══ WEEK GRID ═══ */
.serV2-week-label {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 13px; color: #A85470;
  margin-bottom: 12px;
}
.serV2-week-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
  margin-bottom: 22px;
}
.serV2-day-btn {
  background: white;
  border: 1px solid rgba(168,84,112,0.08);
  border-radius: 12px;
  padding: 10px 2px 8px;
  text-align: center;
  cursor: pointer;
  transition: all 0.25s;
  position: relative;
  font-family: inherit;
}
.serV2-day-btn:hover { border-color: rgba(168,84,112,0.15); }
.serV2-day-btn:active { transform: scale(0.95); }
.serV2-day-btn.today {
  background: #7A3350;
  border-color: #7A3350;
  color: white;
  box-shadow: 0 4px 18px rgba(122, 51, 80, 0.25);
}
.serV2-day-btn.done { background: #C8D4C6; border-color: transparent; }
.serV2-day-btn.rest { background: #F5E2DA; border-color: transparent; opacity: 0.85; }
.serV2-day-btn.future { opacity: 0.5; }
.serV2-day-btn.serV2-selected {
  border-color: #7A3350;
  border-width: 2px;
  transform: translateY(-2px);
}
.serV2-day-name {
  font-family: 'DM Sans', sans-serif;
  font-size: 9px; letter-spacing: 0.8px; text-transform: uppercase;
  opacity: 0.7; margin-bottom: 3px;
  font-weight: 500;
}
.serV2-day-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px; font-weight: 500; line-height: 1;
}
.serV2-day-dot {
  position: absolute; top: 5px; right: 5px;
  width: 5px; height: 5px; border-radius: 50%; background: #C4796A;
}
.serV2-day-btn.today .serV2-day-dot { background: white; }
.serV2-day-btn.done .serV2-day-dot { background: #8A9E8C; }

/* ═══ DAY DETAIL ═══ */
.serV2-day-detail {
  background: white;
  border: 1px solid rgba(168,84,112,0.08);
  border-radius: 16px;
  padding: 20px 20px 18px;
  margin-bottom: 22px;
}
.serV2-day-detail-label {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 12px; letter-spacing: 1px;
  color: #A85470; text-transform: uppercase;
  margin-bottom: 4px;
}
.serV2-day-detail-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px; font-weight: 500;
  color: #2A1F1C; margin-bottom: 14px;
  line-height: 1.2;
}
.serV2-exercise-row {
  display: flex; gap: 12px; padding: 12px 0;
  border-top: 1px solid rgba(168,84,112,0.08);
  align-items: center;
}
.serV2-exercise-row:first-of-type { border-top: none; padding-top: 0; }
.serV2-ex-num {
  width: 30px; height: 30px; border-radius: 50%;
  background: #F5E2DA;
  color: #7A3350; font-family: 'Cormorant Garamond', serif;
  font-size: 15px; font-weight: 500;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.serV2-ex-body { flex: 1; min-width: 0; }
.serV2-ex-title {
  font-size: 13px; font-weight: 500; color: #2A1F1C;
  line-height: 1.35;
}
.serV2-ex-meta {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 11.5px; color: #8A7070;
  margin-top: 2px;
}
.serV2-ex-duration {
  font-family: 'Cormorant Garamond', serif;
  font-size: 16px; color: #7A3350; font-weight: 500;
}

/* ═══ GOLDEN RULE ═══ */
.serV2-golden {
  background: linear-gradient(135deg, #FEF6E8 0%, #FAE8D0 100%);
  border-radius: 14px;
  padding: 16px 18px;
  margin-bottom: 22px;
}
.serV2-golden-head {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 11px; color: #8B6F40;
  letter-spacing: 1.5px; text-transform: uppercase;
  margin-bottom: 6px;
}
.serV2-golden-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: 15px; color: #5A4828;
  line-height: 1.55; font-weight: 400;
}
.serV2-golden-text em { font-style: italic; color: #7A5F2A; }

/* ═══ FILTRES EXERCICES ═══ */
.serV2-filter-pills {
  display: flex; gap: 8px; overflow-x: auto;
  margin-bottom: 20px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding-bottom: 4px;
}
.serV2-filter-pills::-webkit-scrollbar { display: none; }
.serV2-filter-pill {
  font-family: 'Cormorant Garamond', serif;
  padding: 6px 14px; border-radius: 16px;
  background: white; color: #8A7070;
  border: 1px solid rgba(168,84,112,0.08);
  cursor: pointer; white-space: nowrap;
  font-size: 13px;
  transition: all 0.2s;
}
.serV2-filter-pill:hover { color: #7A3350; border-color: rgba(168,84,112,0.15); }
.serV2-filter-pill.serV2-active {
  background: #7A3350; color: white;
  border-color: #7A3350;
}
.serV2-exercise-card {
  background: white;
  border: 1px solid rgba(168,84,112,0.08);
  border-radius: 14px;
  padding: 16px 18px;
  margin-bottom: 10px;
  cursor: pointer;
  transition: all 0.2s;
}
.serV2-exercise-card:hover { border-color: rgba(168,84,112,0.15); transform: translateY(-1px); }
.serV2-exc-head {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 4px;
}
.serV2-exc-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 17px; font-weight: 500;
  color: #2A1F1C; line-height: 1.2;
  padding-right: 8px;
}
.serV2-exc-duration {
  font-family: 'Cormorant Garamond', serif;
  font-size: 15px; color: #A85470;
  flex-shrink: 0;
}
.serV2-exc-meta {
  display: flex; gap: 6px; flex-wrap: wrap;
  margin-top: 8px;
}
.serV2-exc-tag {
  font-size: 10px; letter-spacing: 0.5px;
  background: #F5E2DA; color: #7A3350;
  padding: 3px 8px; border-radius: 10px;
}

/* ═══ CONSEILS ═══ */
.serV2-article-card {
  background: white;
  border: 1px solid rgba(168,84,112,0.08);
  border-radius: 14px;
  padding: 18px 20px;
  margin-bottom: 10px;
  cursor: pointer;
  transition: all 0.25s;
}
.serV2-article-card:hover { border-color: rgba(168,84,112,0.15); transform: translateY(-1px); }
.serV2-article-category {
  font-size: 9px; letter-spacing: 2px; text-transform: uppercase;
  color: #A85470; font-weight: 600; margin-bottom: 6px;
}
.serV2-article-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 19px; font-weight: 500;
  color: #2A1F1C; line-height: 1.25;
  margin-bottom: 8px;
}
.serV2-article-excerpt {
  font-size: 13px; color: #8A7070;
  line-height: 1.6;
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
}
.serV2-article-foot {
  margin-top: 10px; font-size: 11px; color: #A85470;
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
}

/* ═══ MARC / CONTACT ═══ */
.serV2-contact-hero {
  background: linear-gradient(135deg, #FFF8F3 0%, #F5E2DA 100%);
  border-radius: 18px;
  padding: 26px 24px 24px;
  text-align: center;
  margin-bottom: 22px;
}
.serV2-contact-avatar {
  width: 68px; height: 68px; border-radius: 50%;
  background: linear-gradient(135deg, #C4796A 0%, #A85848 100%);
  color: white;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: 'Cormorant Garamond', serif;
  font-size: 26px; font-weight: 500;
  margin-bottom: 14px;
}
.serV2-contact-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px; font-weight: 500;
  color: #2A1F1C; margin-bottom: 4px;
}
.serV2-contact-title {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 13px; color: #8A7070;
  margin-bottom: 16px;
}
.serV2-contact-quote {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 14px; color: #7A3350;
  line-height: 1.5;
  max-width: 320px; margin: 0 auto;
}
.serV2-contact-channels {
  display: flex; flex-direction: column; gap: 10px;
  margin-bottom: 24px;
}
.serV2-channel {
  background: white;
  border: 1px solid rgba(168,84,112,0.08);
  border-radius: 14px;
  padding: 14px 16px;
  display: flex; align-items: center; gap: 14px;
  cursor: pointer;
  transition: all 0.2s;
  text-decoration: none;
  color: inherit;
  font-family: inherit;
  width: 100%;
  text-align: left;
}
.serV2-channel:hover { border-color: rgba(168,84,112,0.15); transform: translateY(-1px); }
.serV2-channel-icon {
  width: 40px; height: 40px; border-radius: 50%;
  background: #F5E2DA;
  display: flex; align-items: center; justify-content: center;
  color: #7A3350; font-size: 16px;
  flex-shrink: 0;
}
.serV2-channel-icon.serV2-channel-wa { background: #25D366; color: white; }
.serV2-channel-body { flex: 1; }
.serV2-channel-title {
  font-size: 13.5px; font-weight: 500; color: #2A1F1C;
  margin-bottom: 2px;
}
.serV2-channel-sub {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 12px; color: #8A7070;
}
.serV2-channel-arrow {
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px; color: #A85470;
}

.serV2-message-history { margin-top: 20px; }
.serV2-msg-label {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 12px; color: #A85470;
  letter-spacing: 1px; text-transform: uppercase;
  margin-bottom: 12px;
}
.serV2-msg {
  background: white;
  border: 1px solid rgba(168,84,112,0.08);
  border-radius: 14px;
  padding: 14px 16px;
  margin-bottom: 10px;
}
.serV2-msg-from {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 6px;
}
.serV2-msg-sender {
  font-family: 'Cormorant Garamond', serif;
  font-size: 13px; font-weight: 500;
  color: #7A3350;
}
.serV2-msg-time {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 11px; color: #8A7070;
}
.serV2-msg-body {
  font-size: 13px; color: #3A2A28; line-height: 1.55;
}

/* ═══ TAB BAR BAS ═══ */
.serV2-tabbar {
  position: fixed;
  bottom: 0; left: 50%;
  transform: translateX(-50%);
  width: 100%; max-width: 430px;
  background: rgba(253, 248, 243, 0.96);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-top: 1px solid rgba(168,84,112,0.15);
  padding: 10px 0 18px;
  display: grid; grid-template-columns: repeat(5, 1fr);
  z-index: 100;
}
.serV2-tabbar-item {
  display: flex; flex-direction: column; align-items: center;
  gap: 3px; cursor: pointer; color: #8A7070;
  font-family: 'Cormorant Garamond', serif;
  font-size: 10.5px; letter-spacing: 0.3px;
  background: none; border: none;
  padding: 4px 2px;
  transition: color 0.2s;
}
.serV2-tabbar-item.serV2-active {
  color: #7A3350;
  font-weight: 500;
}
.serV2-tabbar-icon {
  font-size: 18px;
  font-family: 'Cormorant Garamond', serif;
  line-height: 1;
  width: 24px; height: 24px;
  display: flex; align-items: center; justify-content: center;
}
.serV2-tabbar-item.serV2-active .serV2-tabbar-icon {
  border-bottom: 1.5px solid #7A3350;
}

/* ═══ MODAL ═══ */
.serV2-modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(42, 31, 28, 0.6);
  backdrop-filter: blur(6px);
  z-index: 200;
  display: none;
  align-items: flex-end; justify-content: center;
}
.serV2-modal-backdrop.serV2-open { display: flex; animation: serV2-fadeIn 0.25s; }
.serV2-modal {
  background: #FDF8F3;
  border-radius: 24px 24px 0 0;
  width: 100%; max-width: 430px;
  max-height: 88vh;
  overflow-y: auto;
  animation: serV2-slideUp 0.3s cubic-bezier(.4,0,.2,1);
  position: relative;
}
@keyframes serV2-slideUp {
  from { transform: translateY(20px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
.serV2-modal-close {
  position: absolute; top: 16px; right: 20px;
  width: 34px; height: 34px; border-radius: 50%;
  background: #F5E2DA; color: #7A3350;
  border: none; cursor: pointer;
  font-size: 18px; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  z-index: 10;
}
.serV2-modal-content { padding: 30px 26px 30px; }
.serV2-modal-eyebrow {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 12px; letter-spacing: 2px;
  color: #A85470; text-transform: uppercase;
  margin-bottom: 8px;
}
.serV2-modal-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 28px; font-weight: 400;
  color: #2A1F1C; line-height: 1.2;
  margin-bottom: 16px;
}
.serV2-modal-title em { font-style: italic; color: #7A3350; }
.serV2-modal-score {
  font-family: 'Cormorant Garamond', serif;
  font-size: 42px; font-weight: 500;
  color: #2A1F1C;
  margin-bottom: 14px;
  display: flex; align-items: baseline; gap: 8px;
}
.serV2-modal-score small { font-size: 14px; color: #8A7070; font-weight: 400; }
.serV2-modal-score .serV2-trend {
  font-size: 13px; font-weight: 500;
  margin-left: auto;
  font-family: 'DM Sans';
}
.serV2-modal-prose {
  font-size: 14px; line-height: 1.75;
  color: #3A2A28;
  margin-bottom: 20px;
}
.serV2-modal-prose p { margin-bottom: 14px; }
.serV2-modal-prose em { font-style: italic; color: #7A3350; }
.serV2-modal-dimension-bar {
  height: 4px; background: rgba(168,84,112,0.08);
  border-radius: 2px; overflow: hidden;
  margin-bottom: 20px;
}
.serV2-modal-dimension-fill {
  height: 100%; border-radius: 2px;
  transition: width 0.6s cubic-bezier(.4,0,.2,1);
}


/* ═══ BOUTON RETOUR AU CHAT (Vision D) ═══ */
.serV2-back-btn {
  position: fixed;
  top: 14px; left: 14px;
  z-index: 150;
  width: 38px; height: 38px;
  border-radius: 50%;
  background: rgba(253, 248, 243, 0.92);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(168, 84, 112, 0.18);
  color: #7A3350;
  font-size: 18px;
  font-family: 'Cormorant Garamond', serif;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  line-height: 1;
  transition: all 0.2s;
  box-shadow: 0 2px 10px rgba(122, 51, 80, 0.08);
}
.serV2-back-btn:hover {
  background: rgba(245, 226, 218, 1);
  transform: translateX(-1px);
}
.serV2-back-btn:active { transform: scale(0.95); }
