/* ═══════════════════════════════════════════════════════════════════
   SalaireScope NEUF — public/styles.css
   Extrait fidèle de salairescope_v3_clean/public/index.html (3 blocs <style>)
   Aucune valeur métier hardcodée — design system uniquement.
   ═══════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

/* ── Bloc 1 : design system principal (L11-932 v3_clean) ── */
:root{--bg:#faf8f6;--surface:#fff;--surface2:#f5f1ed;--border:#e8e0d8;--text:#1a1a1a;--text2:#5a5a5a;--muted:#9a9a9a;--pri:#F26522;--pri-l:#FEF0E8;--pri-d:#c74e15;--grn:#059669;--grn-l:#DCFCE7;--red:#DC2626;--red-l:#FEE2E2;--ora:#D97706;--ora-l:#FEF3C7;--blu:#2563EB;--blu-l:#DBEAFE;--pur:#7C3AED;--pur-l:#EDE9FE;--navy:#1e293b;--navy2:#334155;--mono:'JetBrains Mono',monospace}
*{box-sizing:border-box;margin:0;padding:0}body{font-family:'DM Sans','Plus Jakarta Sans',system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}

/* État initial : header et main masqués jusqu'à enterApp() (anciennement style="display:none" inline) */
#app-hdr,#app-main{display:none}
#app-hdr.show{display:flex}
#app-main.show{display:block}
/* Toast root positionnement (anciennement inline dans index.html) */
#toast-root{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:10000;display:flex;flex-direction:column;gap:8px;pointer-events:none}

/* HEADER */
.hdr{background:var(--navy);color:#fff;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100001;box-shadow:0 4px 20px rgba(30,41,59,.4)}
.hdr-eye{width:44px;height:24px;position:relative;background:radial-gradient(ellipse,#fff 60%,#e8d5c4 100%);border-radius:50%;border:2px solid rgba(255,255,255,.6);box-shadow:0 0 8px rgba(0,0,0,.3),inset 0 0 6px rgba(0,0,0,.1);overflow:hidden;transition:all .3s;cursor:pointer}
.hdr-eye-ball{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.hdr-eye-iris{width:16px;height:16px;background:radial-gradient(circle at 40% 40%,#4a90d9 0%,#2563eb 40%,#1e3a5f 80%,#0f172a 100%);border-radius:50%;position:relative;transition:width .4s ease,height .4s ease;box-shadow:0 0 3px rgba(0,0,0,.4)}
.hdr-eye-iris::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:6px;height:6px;background:radial-gradient(circle,#000 60%,#1a1a2e 100%);border-radius:50%;transition:width .4s ease,height .4s ease}
.hdr-eye-iris::before{content:'';position:absolute;top:3px;left:5px;width:4px;height:3px;background:rgba(255,255,255,.7);border-radius:50%;transform:rotate(-30deg)}
.hdr-eye-lid{position:absolute;top:-26px;left:-3px;right:-3px;height:26px;background:var(--navy);border-radius:0 0 50% 50%;transition:top .15s ease-in-out}
#hdr-eye-wrap:hover .hdr-eye{border-color:#93c5fd;box-shadow:0 0 12px rgba(59,130,246,.5),inset 0 0 6px rgba(0,0,0,.1)}
#hdr-eye-wrap:hover .hdr-eye-iris{width:18px;height:18px}
#hdr-eye-wrap:hover .hdr-eye-iris::after{width:4px;height:4px}
#hdr-eye-wrap:hover .hdr-eye-lid{animation:_eyeBlink 2.5s ease-in-out infinite}
@keyframes _eyeBlink{0%,15%,25%,100%{top:-26px}18%,22%{top:0}}
#hdr-eye-tooltip{position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%);background:#1e293b;color:#fff;padding:7px 14px;border-radius:8px;font-size:.78rem;font-weight:600;white-space:nowrap;box-shadow:0 4px 12px rgba(0,0,0,.3);pointer-events:none;opacity:0;transition:opacity .3s;z-index:101}
#hdr-eye-tooltip::before{content:'';position:absolute;top:-6px;left:50%;transform:translateX(-50%);border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid #1e293b}
#hdr-eye-wrap:hover #hdr-eye-tooltip{opacity:1}
.hdr-logo{display:flex;align-items:center;gap:12px}.hdr-icon{width:42px;height:42px;background:var(--pri);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px}
.hdr h1{font-size:1rem;font-weight:700;letter-spacing:.02em}.hdr .sub{font-size:.68rem;opacity:.45;letter-spacing:.08em;font-weight:500}
.hdr-badge{background:rgba(255,255,255,.18);padding:5px 14px;border-radius:20px;font-size:.72rem;font-weight:600}
.main{max-width:1100px;margin:0 auto;padding:20px}

/* TABS */
.tabs{display:flex;gap:4px;margin-bottom:20px;background:var(--surface);padding:5px;border-radius:14px;border:1px solid var(--border);overflow-x:auto}
.tbtn{flex:1;min-width:100px;padding:10px 14px;border:none;border-radius:10px;font-family:inherit;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .18s;background:transparent;color:var(--text2);white-space:nowrap}
.tbtn:hover{background:var(--surface2)}.tbtn.on{background:var(--pri);color:#fff;box-shadow:0 2px 8px rgba(242,101,34,.35)}

/* CARD */
.card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:22px;margin-bottom:18px;box-shadow:0 1px 3px rgba(0,0,0,.05)}
.ctitle{display:flex;align-items:center;gap:10px;font-size:.8rem;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:18px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.ctitle .ic{width:28px;height:28px;background:var(--pri-l);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0}

/* FORMS */
.fg{display:grid;grid-template-columns:1fr 1fr;gap:14px}.fd{display:flex;flex-direction:column;gap:5px}.fd.full{grid-column:1/-1}
.fd label{font-size:.7rem;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.06em}
.fd select,.fd input,.fd textarea{font-family:inherit;font-size:.9rem;padding:9px 11px;border:1.5px solid var(--border);border-radius:8px;background:#fff;color:var(--text);transition:all .15s;width:100%}
.fd select:focus,.fd input:focus,.fd textarea:focus{outline:none;border-color:var(--pri);box-shadow:0 0 0 3px rgba(242,101,34,.12)}
.fd textarea{resize:vertical;min-height:70px}

/* BUTTONS */
.bp{width:100%;padding:12px;background:var(--pri);color:#fff;border:none;border-radius:10px;font-family:inherit;font-size:.92rem;font-weight:700;cursor:pointer;margin-top:18px;transition:all .15s;box-shadow:0 2px 8px rgba(242,101,34,.3)}
.bp:hover{background:var(--pri-d);transform:translateY(-1px)}.bp:disabled{opacity:.5;cursor:not-allowed;transform:none}
.bs{padding:7px 16px;background:#fff;color:var(--pri);border:1.5px solid var(--pri);border-radius:8px;font-family:inherit;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s}.bs:hover{background:var(--pri-l)}
.bsm{padding:4px 10px;font-size:.72rem;border-radius:6px;border:none;cursor:pointer;font-family:inherit;font-weight:600;transition:all .15s}
.bg{background:var(--grn-l);color:var(--grn)}.bg:hover{background:var(--grn);color:#fff}
.br{background:var(--red-l);color:var(--red)}.br:hover{background:var(--red);color:#fff}
.bo{background:var(--ora-l);color:var(--ora)}.bo:hover{background:var(--ora);color:#fff}

/* NOTICE/ALERT */
.notice{background:var(--pri-l);border:1px solid rgba(242,101,34,.15);border-radius:10px;padding:12px 16px;font-size:.83rem;color:var(--text2);margin-bottom:18px;line-height:1.55}
.alr{padding:14px 18px;border-radius:10px;font-size:.9rem;font-weight:700;margin-top:10px;animation:fi .3s;text-align:center}
#galert{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:10000;min-width:300px;box-shadow:0 4px 20px rgba(0,0,0,.3)}
.alr-s{background:var(--pri);color:#fff}
.alr-e{background:var(--red-l);color:var(--red)}.alr-i{background:#eff6ff;color:#1e40af;border-color:#bfdbfe}.alr-w{background:var(--ora-l);color:var(--ora)}
@keyframes fi{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* PROMO */
.promo{background:linear-gradient(135deg,#1D4ED8,#7C3AED);border-radius:14px;padding:22px 26px;color:#fff;margin-bottom:20px;position:relative;overflow:hidden;cursor:pointer;transition:all .2s;box-shadow:0 6px 24px rgba(29,78,216,.3)}
.promo:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(29,78,216,.4)}
.promo::before{content:'';position:absolute;top:-40px;right:-40px;width:160px;height:160px;background:rgba(255,255,255,.08);border-radius:50%}
.promo .pf{display:flex;align-items:center;gap:18px;position:relative;z-index:1}
.promo .pi{font-size:2.5rem;flex-shrink:0}.promo h3{font-size:1rem;font-weight:800;margin-bottom:3px}.promo p{font-size:.82rem;opacity:.9;line-height:1.5}
.promo .pa{font-size:1.3rem;margin-left:auto;opacity:.7}
.pstats{display:flex;gap:16px;margin-top:12px;position:relative;z-index:1}
.pst{background:rgba(255,255,255,.15);border-radius:10px;padding:8px 14px;text-align:center}
.pst .pn{font-size:1.2rem;font-weight:800}.pst .pl{font-size:.65rem;opacity:.8;text-transform:uppercase}

/* LOCK OVERLAY */
.lock-overlay{background:linear-gradient(180deg,transparent 0%,rgba(253,246,242,.97) 15%,var(--bg) 100%);position:relative;padding:40px 0 30px;text-align:center;margin-top:-60px;border-radius:14px}
.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:1000;display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.visible{display:flex}
.modal-box{background:transparent;width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:0}
.modal-box>div{width:100vw;height:100vh;max-width:none;max-height:none;background:#fff;border-radius:0;overflow:hidden;display:flex;flex-direction:column;box-shadow:none}
@media (min-width:1100px){.modal-box>div{width:96vw;height:96vh;max-width:1400px;border-radius:14px;box-shadow:0 20px 60px rgba(0,0,0,.35)}}
.lock-inner{width:100%;margin:0 auto;background:#fff;border:2px solid var(--pri);border-radius:18px;padding:36px 32px;color:var(--text);box-shadow:0 8px 40px rgba(242,101,34,.15);position:relative;overflow:hidden}
.lock-inner::before{content:'';position:absolute;top:-60px;right:-60px;width:200px;height:200px;background:radial-gradient(circle,rgba(242,101,34,.06),transparent 70%);border-radius:50%}
.lock-inner>*{position:relative;z-index:1}
.lock-headline{display:flex;align-items:center;justify-content:center;gap:10px;font-size:1.35rem;font-weight:800;margin-bottom:22px;letter-spacing:-.01em;color:var(--pri)}
.lock-headline .zap{font-size:1.5rem}
.lock-features{display:flex;flex-direction:column;gap:12px;text-align:left;margin-bottom:26px}
.lock-feat{display:flex;align-items:flex-start;gap:12px;background:var(--pri-l);border-radius:12px;padding:14px 18px;border:1px solid rgba(242,101,34,.1)}
.lock-feat .lf-icon{font-size:1.25rem;flex-shrink:0;margin-top:1px}
.lock-feat .lf-check{color:var(--grn);font-size:1rem;flex-shrink:0;margin-top:2px}
.lock-feat .lf-text{font-size:1rem;line-height:1.5;color:var(--text2)}
.lock-feat .lf-text strong{color:var(--pri);font-size:1.02rem}
.lock-cta{display:inline-flex;align-items:center;gap:10px;padding:16px 44px;background:linear-gradient(135deg,#F26522,#D4521A);color:#fff;border:none;border-radius:14px;font-family:inherit;font-size:1.1rem;font-weight:800;cursor:pointer;box-shadow:0 4px 20px rgba(242,101,34,.35);transition:all .2s;margin-bottom:16px;width:100%;justify-content:center;max-width:520px}
.lock-cta:hover{transform:translateY(-2px) scale(1.01);box-shadow:0 8px 32px rgba(242,101,34,.45)}
.lock-footer{font-size:.88rem;color:var(--muted);line-height:1.5;font-style:italic}
@media(max-width:640px){.lock-inner{padding:24px 16px}.lock-headline{font-size:1.15rem}.lock-feat{padding:12px 14px}.lock-feat .lf-text{font-size:.92rem}}

/* STAT GRID */
.sg{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:18px 0}
.sc{background:#fff;border:1px solid var(--border);border-radius:12px;padding:12px;text-align:center}
.sc .sl{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:3px}
.sc .sv{font-size:1.1rem;font-weight:800}

/* HERO */
.hero{background:linear-gradient(135deg,#F26522,#1D4ED8);border-radius:14px;padding:24px;color:#fff;display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center;box-shadow:0 6px 24px rgba(242,101,34,.35);margin-bottom:18px}
.hero .ht{font-size:1.15rem;font-weight:800;margin-bottom:4px}.hero .hs{font-size:.85rem;opacity:.85}
.pbox{text-align:center;background:rgba(255,255,255,.18);border-radius:12px;padding:14px 22px}
.pbox .pn{font-size:2.5rem;font-weight:800;line-height:1}.pbox .pl{font-size:.68rem;opacity:.8;text-transform:uppercase;letter-spacing:.1em;margin-top:3px}

/* TABLE */
.dt{width:100%;border-collapse:separate;border-spacing:0;font-size:.8rem;margin-right:70px}
.dt th{background:var(--surface2);padding:9px 10px;text-align:left;font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text2);border-bottom:2px solid var(--border)}
.dt td{padding:9px 10px;border-bottom:1px solid var(--border);vertical-align:middle}
.dt tr:hover td{background:var(--pri-l)}

/* SUB TABS */
.stabs{display:flex;gap:4px;margin-bottom:18px;flex-wrap:wrap}
.stab{padding:6px 14px;border:1.5px solid var(--border);border-radius:8px;background:#fff;font-family:inherit;font-size:.75rem;font-weight:600;cursor:pointer;color:var(--text2);transition:all .15s}
.stab.on{background:var(--pri);color:#fff;border-color:var(--pri)}.stab:hover:not(.on){background:var(--surface2)}

/* BADGE */
.badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:.7rem;font-weight:700}
.bdg{background:var(--grn-l);color:var(--grn)}.bdo{background:var(--ora-l);color:var(--ora)}.bdr{background:var(--red-l);color:var(--red)}.bdb{background:var(--blu-l);color:var(--blu)}.bdp{background:var(--pur-l);color:var(--pur)}

/* PAGINATION */
.pag{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:14px;font-size:.8rem;color:var(--text2)}
.pag button{padding:5px 12px;border:1px solid var(--border);border-radius:6px;background:#fff;cursor:pointer;font-family:inherit;font-size:.76rem;font-weight:600}
.pag button:disabled{opacity:.4;cursor:not-allowed}

/* CONFIG */
.cfg-g{display:grid;grid-template-columns:180px 1fr;gap:10px;align-items:start}
.cfg-l{font-size:.76rem;font-weight:700;color:var(--text2);padding-top:9px}
.cfg-i{font-family:inherit;font-size:.86rem;padding:8px 11px;border:1.5px solid var(--border);border-radius:8px;width:100%;transition:all .15s}
.cfg-i:focus{outline:none;border-color:var(--pri);box-shadow:0 0 0 3px rgba(242,101,34,.12)}

/* MODAL */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:stretch;justify-content:center;z-index:200000;padding:0}
.modal.hidden{display:none}
.mbox{background:#fff;border-radius:16px;padding:24px;max-width:560px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.25)}

/* SIMULATOR */
.sim-card{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #93c5fd;border-radius:14px;padding:20px;margin-bottom:18px}
.sim-card h4{color:var(--blu);font-size:.88rem;font-weight:800;margin-bottom:12px}
.sim-row{display:flex;gap:12px;align-items:end;flex-wrap:wrap;margin-bottom:12px}
.sim-result{background:#fff;border-radius:10px;padding:14px;border:1px solid #93c5fd}
.sim-result .sr-big{font-size:1.3rem;font-weight:800;color:var(--blu)}

/* FIELD CONFIG */
.fc-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid #f3f3f3}
.fc-row:last-child{border:none}
.fc-name{flex:1;font-size:.82rem;font-weight:600}
.fc-sel{padding:4px 8px;border:1px solid var(--border);border-radius:6px;font-family:inherit;font-size:.75rem;font-weight:600}

/* METALLURGY */
.met-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}
.met-item{display:flex;flex-direction:column;gap:3px}
.met-item label{font-size:.68rem;font-weight:700;color:var(--muted);text-transform:uppercase}
.met-item input{font-family:inherit;font-size:.82rem;padding:6px 8px;border:1.5px solid var(--border);border-radius:6px;width:100%}
.met-item input:focus{outline:none;border-color:var(--pri)}

.empty{text-align:center;padding:40px 20px;color:var(--muted)}.empty .em{font-size:2.2rem;margin-bottom:10px}
.loading{position:fixed;inset:0;background:rgba(0,0,0,.4);display:none;align-items:center;justify-content:center;z-index:1000}
.loading.hidden{display:none!important;visibility:hidden!important;opacity:0!important;pointer-events:none!important}
.lbox{background:#fff;padding:28px 44px;border-radius:16px;text-align:center}
.spin{width:36px;height:36px;border:4px solid var(--border);border-top-color:var(--pri);border-radius:50%;animation:sp .8s linear infinite;margin:0 auto 14px}
@keyframes sp{to{transform:rotate(360deg)}}

.live-c{display:flex;align-items:center;gap:8px;padding:9px 14px;background:var(--grn-l);border:1px solid rgba(22,163,74,.2);border-radius:10px;margin-bottom:14px;font-size:.8rem;font-weight:600;color:var(--grn)}
.live-d{width:8px;height:8px;background:var(--grn);border-radius:50%;animation:pu 2s infinite}
@keyframes pu{0%,100%{opacity:1}50%{opacity:.3}}

.tag{display:inline-block;padding:2px 9px;border-radius:20px;font-size:.7rem;font-weight:600;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);color:#fff;margin-right:3px}
.ci{display:inline-block;padding:2px 7px;border-radius:6px;font-size:.66rem;font-weight:700;margin-left:4px}
.ci-nc{background:#E0F2FE;color:#0369A1}.ci-c{background:#F3E8FF;color:#7C3AED}
.panel{display:none}.panel.on{display:block}.hidden{display:none!important}
.abar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px;align-items:center}

@media(max-width:640px){.fg{grid-template-columns:1fr}.sg{grid-template-columns:repeat(2,1fr)}.hero{grid-template-columns:1fr;text-align:center}.cfg-g{grid-template-columns:1fr}.tabs{gap:2px;padding:4px}.tbtn{min-width:70px;padding:8px;font-size:.72rem}.promo .pf{flex-direction:column;text-align:center}.pstats{flex-direction:column;gap:6px}.promo .pa{display:none}.sim-row{flex-direction:column}}

/* CHART BARS */
.cb{display:flex;flex-direction:column;gap:5px}
.cbr{display:flex;align-items:center;gap:8px}
.cbl{width:48px;font-size:.7rem;font-weight:700;color:var(--text2);text-align:right;flex-shrink:0}
.cbt{flex:1;height:22px;background:var(--surface2);border-radius:8px;overflow:hidden}
.cbf{height:100%;border-radius:8px;transition:width .7s ease}
.cbv{margin-left:8px;font-size:.76rem;font-weight:700;width:78px;flex-shrink:0}

/* TOGGLE BUTTONS */
.toggle-group{display:flex;gap:0;border:1.5px solid var(--border);border-radius:10px;overflow:hidden;background:var(--surface)}
.toggle-btn{flex:1;padding:10px 16px;border:none;background:transparent;font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .18s;color:var(--text2);display:flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap}
.toggle-btn:not(:last-child){border-right:1px solid var(--border)}
.toggle-btn.on{background:var(--pri);color:#fff;box-shadow:inset 0 0 0 1px var(--pri)}
.toggle-btn .t-dot{width:8px;height:8px;border-radius:50%;border:2px solid currentColor;flex-shrink:0}
.toggle-btn.on .t-dot{background:currentColor}

/* TAUX INPUT ROW */
.taux-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.taux-input-wrap{display:flex;align-items:center;gap:4px}
.taux-input-wrap label{font-size:.82rem;font-weight:700;color:var(--text2)}
.taux-input{width:70px;padding:8px 10px;border:1.5px solid var(--border);border-radius:8px;font-family:inherit;font-size:1rem;font-weight:700;text-align:center;color:var(--text)}
.taux-input:focus{outline:none;border-color:var(--pri);box-shadow:0 0 0 3px rgba(242,101,34,.12)}
.taux-pct{font-size:.92rem;font-weight:700;color:var(--text2)}
.taux-quick{display:flex;gap:4px}
.taux-qbtn{padding:6px 14px;border:1.5px solid var(--border);border-radius:8px;background:#fff;font-family:inherit;font-size:.8rem;font-weight:600;cursor:pointer;color:var(--text2);transition:all .15s}
.taux-qbtn:hover{background:var(--pri-l);border-color:var(--pri);color:var(--pri)}
.taux-qbtn.on{background:var(--pri);color:#fff;border-color:var(--pri)}

/* CALCULATED BAR */
.calc-bar{background:var(--text);color:#fff;border-radius:8px;padding:10px 14px;font-size:.88rem;font-weight:700;margin-top:8px;display:flex;align-items:center;justify-content:space-between}
.calc-bar .cb-label{font-size:.72rem;font-weight:600;opacity:.7;text-transform:uppercase}

/* OUI/NON CARD */
.yn-card{background:linear-gradient(135deg,var(--pri-l),#fff5ee);border:1.5px solid rgba(242,101,34,.2);border-radius:12px;padding:16px 18px;margin-top:8px}
.yn-card h5{font-size:.82rem;font-weight:700;color:var(--text);margin-bottom:3px;display:flex;align-items:center;gap:6px}
.yn-card h5 .yn-ic{font-size:1rem}
.yn-card p{font-size:.78rem;color:var(--text2);margin-bottom:10px}
.yn-toggle{display:flex;gap:0;border-radius:10px;overflow:hidden;border:1.5px solid var(--border)}
.yn-btn{flex:1;padding:10px 16px;border:none;font-family:inherit;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .18s;display:flex;align-items:center;justify-content:center;gap:6px}
.yn-btn.yn-oui{background:#fff;color:var(--grn)}
.yn-btn.yn-non{background:#fff;color:var(--red);border-left:1px solid var(--border)}
.yn-btn.yn-oui.on{background:var(--grn);color:#fff}
.yn-btn.yn-non.on{background:var(--pri);color:#fff}
.yn-note{font-size:.72rem;color:var(--ora);margin-top:8px;display:flex;align-items:center;gap:4px}
.yn-amount{margin-top:10px;display:none}
.yn-amount.show{display:block}

/* POSITIONNEMENT - GRILLE DE STATS */
.pos-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:16px 0}
.pos-stats-grid .stat-box{background:#fff;border-radius:12px;padding:16px;text-align:center;box-shadow:0 2px 8px rgba(0,0,0,.06);border:1px solid var(--border)}
.pos-stats-grid .stat-label{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.pos-stats-grid .stat-value{font-size:1.3rem;font-weight:800;color:var(--dark)}
@media(max-width:600px){.pos-stats-grid{grid-template-columns:repeat(2,1fr)}}

/* POSITIONNEMENT - JAUGE */
.pos-gauge-container{position:relative;margin:20px 0 10px}
.pos-gauge-bar{height:24px;background:linear-gradient(90deg,#fecaca 0%,#fde68a 25%,#bbf7d0 50%,#fde68a 75%,#fecaca 100%);border-radius:12px;position:relative}
.pos-gauge-markers{position:absolute;top:0;left:0;right:0;height:24px}
.pos-gauge-marker{position:absolute;top:-8px;transform:translateX(-50%);text-align:center}
.pos-gauge-marker-line{width:2px;height:40px;background:var(--dark);margin:0 auto}
.pos-gauge-marker-dot{width:16px;height:16px;background:#dc2626;border:3px solid #fff;border-radius:50%;box-shadow:0 2px 6px rgba(0,0,0,.3);margin:-38px auto 0;position:relative}
.pos-gauge-marker-label{font-size:.75rem;font-weight:700;color:#dc2626;margin-top:4px;white-space:nowrap}
.pos-gauge-labels{position:relative;display:flex;justify-content:space-between;margin-top:8px;font-size:.72rem;color:var(--muted);height:30px}
.pos-gauge-labels span{text-align:center}
.pos-gauge-labels .med{color:var(--grn);font-weight:700}

/* SEARCH AUTOCOMPLETE */
.search-wrap{position:relative}
.search-results{position:absolute;top:100%;left:0;right:0;background:#fff;border:1.5px solid var(--pri);border-top:none;border-radius:0 0 10px 10px;max-height:200px;overflow-y:auto;z-index:50;box-shadow:0 8px 24px rgba(0,0,0,.12);display:none}
.search-results.show{display:block}
.search-item{padding:8px 12px;font-size:.82rem;cursor:pointer;border-bottom:1px solid #f5f5f5;transition:background .1s}
.search-item:hover{background:var(--pri-l)}
.search-item:last-child{border:none}

/* SUBMIT GRADIENT */
.bp-gradient{width:100%;padding:14px;background:linear-gradient(135deg,#F59E0B,#F26522);color:#fff;border:none;border-radius:12px;font-family:inherit;font-size:1rem;font-weight:800;cursor:pointer;margin-top:20px;transition:all .15s;box-shadow:0 4px 16px rgba(242,101,34,.35);display:flex;align-items:center;justify-content:center;gap:8px}
.bp-gradient:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(242,101,34,.45)}
.bp-gradient:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* PILOT CARD */
.pilot-card{background:linear-gradient(135deg,#fffbf5,#fff5ee);border:2px solid var(--pri);border-radius:18px;padding:28px;position:relative;overflow:hidden;box-shadow:0 4px 24px rgba(242,101,34,.1);margin-top:24px}
.pilot-card::before{content:'';position:absolute;top:-50px;right:-50px;width:180px;height:180px;background:radial-gradient(circle,rgba(242,101,34,.06),transparent 70%);border-radius:50%}
.pilot-card>*{position:relative;z-index:1}
.pilot-head{display:flex;align-items:flex-start;gap:16px;margin-bottom:22px}
.pilot-rocket{font-size:2.5rem;flex-shrink:0;margin-top:-2px}
.pilot-head h3{font-size:1.1rem;font-weight:800;color:var(--pri);margin-bottom:6px;line-height:1.3}
.pilot-head p{font-size:.9rem;color:var(--text2);line-height:1.6}
.pilot-card h4{font-size:1rem;font-weight:800;color:var(--text);margin-bottom:16px}
.pilot-features{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}
.pilot-feat{display:flex;align-items:flex-start;gap:14px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px;transition:all .2s;box-shadow:0 1px 3px rgba(0,0,0,.03)}
.pilot-feat:hover{border-color:var(--pri);box-shadow:0 4px 16px rgba(242,101,34,.08);transform:translateY(-1px)}
.pilot-feat .pf-ic{font-size:1.5rem;flex-shrink:0;margin-top:2px}
.pilot-feat strong{font-size:.92rem;color:var(--text);display:inline}
.pilot-feat span{font-size:.86rem;color:var(--text2);line-height:1.5}
.pilot-cta{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px;background:linear-gradient(135deg,#F26522,#D4521A);color:#fff;border:none;border-radius:14px;font-family:inherit;font-size:1.08rem;font-weight:800;cursor:pointer;box-shadow:0 4px 20px rgba(242,101,34,.35);transition:all .2s;margin-bottom:16px}
.pilot-cta:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(242,101,34,.45)}
.pilot-footer{text-align:center;font-size:.84rem;color:var(--muted);line-height:1.6}
.pilot-footer em{color:var(--text2);font-weight:600}
@media(max-width:640px){.pilot-head{flex-direction:column;align-items:center;text-align:center}.pilot-rocket{font-size:2rem}.pilot-card{padding:20px}}
.blink-cta{animation:blink-glow 1.8s ease-in-out infinite}

/* BLINKING CTA */
@keyframes blink-glow{0%,100%{box-shadow:0 4px 16px rgba(249,115,22,.3)}50%{box-shadow:0 4px 28px rgba(249,115,22,.6),0 0 40px rgba(249,115,22,.2)}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}}

/* STEPPER */
.stepper{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:28px}
.step{display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;min-width:80px}
.step-circle{width:36px;height:36px;border-radius:50%;border:3px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.88rem;font-weight:800;color:var(--muted);background:#fff;transition:all .3s;z-index:1}
.step.active .step-circle{border-color:var(--pri);color:#fff;background:var(--pri)}
.step.done .step-circle{border-color:var(--grn);color:#fff;background:var(--grn)}
.step-label{font-size:.7rem;font-weight:600;color:var(--muted);text-align:center}
.step.active .step-label{color:var(--pri);font-weight:700}
.step.done .step-label{color:var(--grn)}
.step-line{width:60px;height:3px;background:var(--border);margin-bottom:18px}
.step-line.done{background:var(--grn)}

/* INSCRIPTION CARD */
.insc-card{max-width:1100px;margin:0 auto;background:#fff;border:1px solid var(--border);border-radius:18px;padding:32px 28px;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.insc-card .insc-icon{font-size:2rem;text-align:center;margin-bottom:8px}
.insc-card h2{font-size:1.15rem;font-weight:800;text-align:center;margin-bottom:4px}
.insc-card .insc-sub{font-size:.84rem;color:var(--text2);text-align:center;margin-bottom:24px;line-height:1.5}
.insc-card .fd+.fd{margin-top:14px}
.insc-card .fd-hint{font-size:.72rem;color:var(--muted);margin-top:3px}
.insc-link{text-align:center;margin-top:16px;font-size:.84rem;color:var(--text2)}
.insc-link a{color:var(--pri);font-weight:700;cursor:pointer;text-decoration:none}
.insc-link a:hover{text-decoration:underline}

/* PASSWORD STRENGTH */
.pwd-bar{height:4px;border-radius:2px;background:var(--border);margin-top:6px;overflow:hidden}
.pwd-fill{height:100%;border-radius:2px;transition:width .3s,background .3s}
.pwd-hint{font-size:.7rem;margin-top:3px;font-weight:600}

/* MON ESPACE TABS */
.espace-tab{display:inline-block;padding:4px 12px;border-radius:6px;font-size:.72rem;font-weight:700;cursor:default}
.espace-tab.connected{background:var(--grn-l);color:var(--grn)}

/* ESPACE PREMIUM SECTIONS */
.esp-section{margin-bottom:20px}
.esp-section .esp-title{display:flex;align-items:center;gap:10px;font-size:.92rem;font-weight:800;color:var(--text);margin-bottom:14px}
.esp-section .esp-title .esp-num{width:30px;height:30px;background:var(--pri);color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:800;flex-shrink:0}

/* GAUGE CARD */
.gauge-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px;text-align:center;position:relative}
.gauge-card .gauge-title{font-size:.72rem;font-weight:700;text-transform:uppercase;color:var(--muted);margin-bottom:10px;letter-spacing:.06em}
.gauge-ring{width:120px;height:120px;border-radius:50%;margin:0 auto 10px;position:relative;display:flex;align-items:center;justify-content:center}
.gauge-ring .gauge-val{font-size:1.6rem;font-weight:800;z-index:1}
.gauge-ring .gauge-lbl{font-size:.7rem;color:var(--muted);display:block}
.gauge-card .gauge-desc{font-size:.82rem;color:var(--text2);margin-top:6px;line-height:1.4}

/* HISTORY BARS */
.hist-row{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid #f5f5f5}
.hist-row:last-child{border:none}
.hist-year{width:40px;font-size:.78rem;font-weight:700;color:var(--text2)}
.hist-bar-track{flex:1;height:22px;background:var(--surface2);border-radius:8px;overflow:hidden;position:relative}
.hist-bar-fill{height:100%;border-radius:8px;transition:width .6s ease;position:relative}
.hist-bar-fill.salary{background:linear-gradient(90deg,#fdba74,var(--pri))}
.hist-bar-fill.inflation{background:linear-gradient(90deg,#fca5a5,var(--red));position:absolute;top:0;height:100%;opacity:.3;border-radius:8px}
.hist-val{width:80px;font-size:.78rem;font-weight:700;text-align:right}
.hist-legend{display:flex;gap:16px;margin-top:10px;justify-content:center;font-size:.72rem;color:var(--muted);font-weight:600}
.hist-legend span::before{content:'';display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:5px;vertical-align:middle}
.hist-legend .hl-sal::before{background:var(--pri)}
.hist-legend .hl-inf::before{background:var(--red);opacity:.4}

/* ALERT CARDS */
.alert-card{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:12px;margin-bottom:10px;font-size:.86rem;line-height:1.5}
.alert-card .ac-ic{font-size:1.3rem;flex-shrink:0}
.alert-card.ac-danger{background:var(--red-l);border:1px solid rgba(220,38,38,.15)}
.alert-card.ac-danger strong{color:var(--red)}
.alert-card.ac-warning{background:var(--ora-l);border:1px solid rgba(217,119,6,.15)}
.alert-card.ac-warning strong{color:var(--ora)}
.alert-card.ac-success{background:var(--grn-l);border:1px solid rgba(22,163,74,.15)}
.alert-card.ac-success strong{color:var(--grn)}
.alert-card.ac-info{background:var(--blu-l);border:1px solid rgba(37,99,235,.15)}
.alert-card.ac-info strong{color:var(--blu)}

/* PDF BUTTON */
.pdf-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px;background:linear-gradient(135deg,#1D4ED8,#2563EB);color:#fff;border:none;border-radius:12px;font-family:inherit;font-size:1rem;font-weight:700;cursor:pointer;box-shadow:0 4px 16px rgba(37,99,235,.3);transition:all .2s}
.pdf-btn:hover{transform:translateY(-1px);box-shadow:0 6px 24px rgba(37,99,235,.4)}

/* MINI STAT BARS */
.mstat{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.mstat-label{width:100px;font-size:.78rem;font-weight:600;color:var(--text2)}
.mstat-track{flex:1;height:14px;background:var(--surface2);border-radius:7px;overflow:hidden;position:relative}
.mstat-fill{height:100%;border-radius:7px;transition:width .5s}
.mstat-marker{position:absolute;top:-2px;width:4px;height:18px;background:var(--text);border-radius:2px;transform:translateX(-50%)}
.mstat-val{width:70px;font-size:.78rem;font-weight:700;text-align:right}

/* STEP SEPARATOR */
.step-sep{display:flex;align-items:center;gap:14px;margin:28px 0;font-size:.85rem;font-weight:700;color:var(--pri)}
.step-sep::before,.step-sep::after{content:'';flex:1;height:2px;background:linear-gradient(90deg,var(--pri),transparent)}
.step-sep::before{background:linear-gradient(90deg,transparent,var(--pri))}
.step-sep .ss-num{width:36px;height:36px;background:var(--pri);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:800;flex-shrink:0}

/* ══════ LANDING PAGE ══════ */
.landing{min-height:100vh;background:var(--bg);color:var(--text);position:relative;overflow:hidden}
.landing::before{content:'';position:absolute;top:-120px;right:-120px;width:500px;height:500px;background:radial-gradient(circle,rgba(242,101,34,.06),transparent 70%);border-radius:50%}
.landing::after{content:'';position:absolute;bottom:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(30,41,59,.05),transparent 70%);border-radius:50%}
.land-hdr{padding:20px 30px;display:flex;align-items:center;justify-content:space-between;position:relative;z-index:2}
.land-hdr .l-logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1rem;color:var(--pri)}
.land-hdr .l-logo .l-ic{width:38px;height:38px;background:var(--pri);color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px}
.land-hdr .l-badge{font-size:.7rem;color:var(--muted);font-weight:500}
.land-content{max-width:780px;margin:0 auto;padding:20px 24px 50px;position:relative;z-index:2}

.land-hero{text-align:center;margin:0 -24px 36px;padding:48px 24px 40px;color:#fff;background:linear-gradient(180deg,#0f172a,#1e293b);position:relative;overflow:hidden}
.land-hero::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:40px;background:linear-gradient(180deg,transparent,var(--bg))}
.land-hero .rocket{font-size:2.5rem;margin-bottom:10px;display:block}
.land-hero h1{font-size:1.9rem;font-weight:800;letter-spacing:-.02em;margin-bottom:8px;line-height:1.2;color:#fff}
.land-hero h1 span{color:var(--pri)}
.land-hero .tagline{font-size:1rem;color:rgba(255,255,255,.75);margin-bottom:20px;line-height:1.6}
.land-directive{display:inline-block;background:#fff;border:2px solid var(--pri);border-radius:10px;padding:10px 20px;font-size:.85rem;font-weight:700;color:var(--pri)}

.land-section{margin-bottom:28px}
.land-section h2{font-size:1.1rem;font-weight:800;margin-bottom:10px;display:flex;align-items:center;gap:8px;color:var(--text)}
.land-section p{font-size:.9rem;line-height:1.65;color:var(--text2);margin-bottom:14px}

.land-steps{display:flex;flex-direction:column;gap:10px;margin-top:14px}
.land-step{display:flex;align-items:flex-start;gap:14px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px 18px;transition:all .2s;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.land-step:hover{border-color:var(--pri);box-shadow:0 4px 16px rgba(242,101,34,.1);transform:translateY(-1px)}
.land-step-num{width:36px;height:36px;background:linear-gradient(135deg,#F26522,#F59E0B);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:800;flex-shrink:0;color:#fff}
.land-step-text{flex:1}
.land-step-text strong{display:block;font-size:.9rem;margin-bottom:2px;color:var(--text)}
.land-step-text span{font-size:.82rem;color:var(--text2);line-height:1.45}

.land-anon{background:#fff;border:2px solid var(--pri);border-radius:14px;padding:20px 22px;margin-bottom:28px;display:flex;align-items:flex-start;gap:14px;box-shadow:0 2px 8px rgba(242,101,34,.08)}
.land-anon .la-ic{font-size:1.8rem;flex-shrink:0}
.land-anon h3{font-size:.95rem;font-weight:800;margin-bottom:4px;color:var(--pri)}
.land-anon p{font-size:.84rem;color:var(--text2);line-height:1.55}

/* PROFIL SELECTOR */
.land-profil{display:flex;gap:0;margin-bottom:24px;border-radius:14px;overflow:hidden;border:2px solid var(--border);background:#fff}
.land-profil-btn{flex:1;padding:14px 20px;border:none;background:#fff;font-family:inherit;font-size:.88rem;font-weight:700;cursor:pointer;color:var(--muted);transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}
.land-profil-btn:first-child{border-right:1px solid var(--border)}
.land-profil-btn.on{background:var(--pri);color:#fff}
.land-profil-btn .lp-dot{width:10px;height:10px;border-radius:50%;border:2px solid currentColor}
.land-profil-btn.on .lp-dot{background:currentColor}

.land-targeted{background:#fff;border:1px solid var(--border);border-radius:14px;padding:22px;margin-bottom:24px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.land-targeted h3{font-size:1rem;font-weight:800;margin-bottom:8px;display:flex;align-items:center;gap:8px;color:var(--pri)}
.land-targeted p{font-size:.86rem;color:var(--text2);line-height:1.55;margin-bottom:12px}
.land-targeted ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.land-targeted li{display:flex;align-items:flex-start;gap:10px;font-size:.85rem;line-height:1.5;color:var(--text2)}
.land-targeted li::before{content:'';flex-shrink:0;margin-top:1px}
.land-targeted li strong{color:var(--text)}
.land-targeted .lt-footer{margin-top:16px;padding:14px 16px;font-size:.82rem;color:#1e3a5f;background:linear-gradient(135deg,#f0f9ff 0%,#e0f2fe 100%);border-radius:10px;border-left:4px solid #0ea5e9;line-height:1.5;font-style:normal}

.land-cta{text-align:center;margin-top:10px}
.land-cta-btn{display:inline-flex;align-items:center;gap:10px;padding:18px 48px;background:linear-gradient(135deg,#F26522,#D4521A);color:#fff;border:none;border-radius:14px;font-family:inherit;font-size:1.1rem;font-weight:800;cursor:pointer;box-shadow:0 6px 30px rgba(242,101,34,.35);transition:all .2s;letter-spacing:-.01em}
.land-cta-btn:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 10px 40px rgba(242,101,34,.45)}
.land-cta-btn:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;box-shadow:none;transform:none}
.land-cta-sub{margin-top:10px;font-size:.76rem;color:var(--muted)}

/* ══════ ENQUÊTE LANDING ══════ */
/* ═══════════════════════════════════════════════════════════════════════
   ENQUÊTE LANDING — Design premium
═══════════════════════════════════════════════════════════════════════ */
.land-enquete{
  background: #064e3b;
  border: none;
  border-radius: 20px;
  padding: 0;
  margin-bottom: 28px;
  position: relative;
  overflow: hidden;
}
.land-enquete::before{
  content:'';
  position:absolute;
  top:-60px;right:-60px;
  width:200px;height:200px;
  background:rgba(255,255,255,.06);
  border-radius:50%;
  pointer-events:none;
}
.land-enquete::after{
  content:'';
  position:absolute;
  bottom:-40px;right:80px;
  width:130px;height:130px;
  background:rgba(242,101,34,.15);
  border-radius:50%;
  pointer-events:none;
}
@keyframes leq-fadein{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.land-enquete-q-body{display:block}
.land-enquete-inner{padding:24px 20px 20px}
.land-enquete-header{
  padding:22px 20px 18px;
  position:relative;z-index:1;
  background:linear-gradient(135deg,#064e3b 0%,#0d7a55 45%,#c05200 80%,#F26522 100%);
}
.land-enquete-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.28);
  color:#fff;
  font-size:.72rem;font-weight:700;
  padding:5px 14px;border-radius:20px;
  letter-spacing:.04em;text-transform:uppercase;
  margin-bottom:10px;
}
.land-enquete-title{flex:1}
.land-enquete-title h3{
  font-size:1.1rem;font-weight:700;
  color:#fff;
  margin-bottom:4px;line-height:1.3;
}
.land-enquete-title span{
  font-size:.8rem;color:rgba(255,255,255,.75);font-weight:500;
}
.land-enquete-progress{
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.25);
  border-radius:20px;padding:4px 12px;
  font-size:.78rem;font-weight:700;color:#fff;
  white-space:nowrap;transition:all .3s;
  min-width:52px;text-align:center;
}
.land-enquete-progress.done{
  background:rgba(34,197,94,.3);border-color:rgba(34,197,94,.5);
}
.land-enq-pbar-wrap{
  height:5px;background:rgba(255,255,255,.2);
  margin:12px 0 0;border-radius:10px;overflow:hidden;
}
.land-enq-pbar-fill{
  height:100%;background:#F26522;border-radius:10px;
  width:0%;transition:width .45s cubic-bezier(.4,0,.2,1);
}
.land-enq-questions-wrap{
  background:#fff;
  border-radius:0 0 20px 20px;
  padding:20px 16px 16px;
}
.land-enquete-q{
  background:#fff;
  border:1.5px solid #f1f5f9;
  border-radius:14px;
  padding:16px 14px;
  margin-bottom:12px;
  transition:all .22s;
  animation:leq-fadein .3s ease both;
}
.land-enquete-q:nth-child(1){animation-delay:.03s}
.land-enquete-q:nth-child(2){animation-delay:.08s}
.land-enquete-q:nth-child(3){animation-delay:.13s}
.land-enquete-q:nth-child(4){animation-delay:.18s}
.land-enquete-q:last-of-type{margin-bottom:8px}
.land-enquete-q:hover{
  border-color:rgba(5,150,105,.25);
  box-shadow:0 3px 14px rgba(5,150,105,.08);
  transform:translateY(-1px);
}
.land-enquete-q-header{
  display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;
}
.land-enquete-check{
  width:26px;height:26px;
  border:2px solid #d1d5db;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;color:#fff;
  transition:all .3s;flex-shrink:0;
  margin-top:1px;background:#f8fafc;
}
.land-enquete-check.done{
  background:linear-gradient(135deg,#22c55e,#16a34a);
  border-color:#16a34a;
  box-shadow:0 0 0 4px rgba(34,197,94,.15);
}
.land-enquete-check.done::after{content:'';font-size:.75rem}
.land-enquete-q-label{
  font-size:.88rem;font-weight:700;
  color:#1e293b;line-height:1.45;
}
.land-enquete-opts{display:flex;flex-direction:column;gap:8px}
.land-enquete-opts.horizontal{
  flex-direction:row;flex-wrap:wrap;
  justify-content:center;gap:8px;
}
.land-enquete-opt{
  padding:10px 18px;
  border:1.5px solid #e2e8f0;border-radius:10px;
  background:#f8fafc;font-size:.84rem;
  cursor:pointer;text-align:center;
  color:#334155;transition:all .18s;
  font-family:inherit;font-weight:600;
}
.land-enquete-opt:hover{
  border-color:#059669;background:#ecfdf5;
  color:#065f46;transform:translateY(-2px);
  box-shadow:0 4px 12px rgba(5,150,105,.12);
}
.land-enquete-opt.selected{
  border:2px solid #059669;
  background:linear-gradient(135deg,#ecfdf5,#d1fae5);
  color:#065f46;
  box-shadow:0 4px 14px rgba(5,150,105,.2);
  font-weight:700;
}
.land-enquete-opt-compact{padding:9px 16px;border-radius:20px;font-size:.82rem}
.land-enquete-emoji-row{
  display:flex;flex-wrap:wrap;justify-content:center;gap:10px;
}
.land-enquete-emoji-btn{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:14px 10px;
  border:1.5px solid #e2e8f0;border-radius:14px;
  background:#f8fafc;cursor:pointer;min-width:68px;
  transition:all .2s;font-family:inherit;
}
.land-enquete-emoji-btn span:first-child{font-size:1.9rem}
.land-enquete-emoji-btn span:last-child{
  font-size:.63rem;font-weight:700;color:#64748b;text-align:center;
}
.land-enquete-emoji-btn:hover{
  transform:scale(1.08) translateY(-3px);
  box-shadow:0 8px 20px rgba(0,0,0,.1);
  border-color:#059669;background:#ecfdf5;
}
.land-enquete-emoji-btn.selected{
  border:2px solid #059669;
  background:linear-gradient(135deg,#ecfdf5,#d1fae5);
  box-shadow:0 6px 18px rgba(5,150,105,.2);
}
.land-enquete-slider{display:flex;align-items:center;gap:12px;}
.land-enquete-slider input[type=range]{flex:1;height:6px;accent-color:#059669;}
.land-enquete-slider-val{
  min-width:52px;background:#059669;color:#fff;
  border-radius:20px;padding:4px 12px;
  font-weight:700;font-size:.85rem;text-align:center;
  opacity:0;transition:opacity .3s;
}
.land-enquete-slider-val.active{opacity:1}
.land-enquete-slider-info{
  font-size:.72rem;color:#94a3b8;margin-top:6px;
  text-align:center;font-style:italic;
}
.land-enquete-textarea{
  width:100%;min-height:80px;padding:12px 14px;
  border:1.5px solid #e2e8f0;border-radius:10px;
  font-family:inherit;font-size:.87rem;resize:vertical;
  background:#f8fafc;color:var(--text);
  transition:border .2s;box-sizing:border-box;
}
.land-enquete-textarea:focus{
  outline:none;border-color:#059669;background:#fff;
  box-shadow:0 0 0 3px rgba(5,150,105,.1);
}
.land-enquete-hint{
  font-size:.72rem;color:#94a3b8;margin-top:6px;font-style:italic;
}
.land-enquete-bar-wrap{
  background:#f1f5f9;border-radius:20px;
  height:6px;margin:14px 0 18px;overflow:hidden;
}
.land-enquete-bar{
  height:100%;background:linear-gradient(90deg,#059669,#F26522);
  border-radius:20px;width:0%;
  transition:width .5s cubic-bezier(.4,0,.2,1);
}
.land-enquete-bar-fill{
  height:100%;background:linear-gradient(90deg,#059669,#F26522);
  border-radius:20px;width:0%;
  transition:width .5s cubic-bezier(.4,0,.2,1);
}
.land-enquete-echelle-row{
  display:flex;gap:6px;flex-wrap:wrap;
  justify-content:center;padding:4px 0 8px;
}
.land-enquete-echelle-btn{
  display:flex;flex-direction:column;align-items:center;gap:5px;
  padding:12px 8px;
  border:1.5px solid #e2e8f0;border-radius:12px;
  background:#f8fafc;cursor:pointer;
  min-width:56px;flex:1;max-width:78px;
  transition:all .2s;font-family:inherit;
}
.land-enquete-echelle-btn:hover{
  transform:translateY(-3px);
  box-shadow:0 6px 16px rgba(5,150,105,.12);
  border-color:#059669;background:#ecfdf5;
}
.land-enquete-echelle-btn.selected{
  border:2px solid #059669;
  background:linear-gradient(135deg,#ecfdf5,#d1fae5);
  transform:translateY(-3px);
  box-shadow:0 6px 18px rgba(5,150,105,.2);
}
.land-echelle-num{
  font-size:1.4rem;font-weight:900;color:#374151;line-height:1;
}
.land-echelle-lbl{
  font-size:.58rem;font-weight:700;color:#94a3b8;
  text-align:center;line-height:1.2;max-width:70px;
}
.land-enquete-echelle-btn.selected .land-echelle-num{color:#059669}
.land-enquete-echelle-btn.selected .land-echelle-lbl{color:#065f46}

.land-cta-btn{padding:16px 32px;font-size:1rem}.land-step{padding:12px 14px}}

/* ══════ MODULE CONTRIBUTION V2 - ÉPURÉ ══════ */
.contrib-form{background:var(--surface);border-radius:16px;box-shadow:0 4px 24px rgba(0,0,0,.06);overflow:hidden}
.contrib-header{padding:20px 24px;background:linear-gradient(135deg,var(--pri-l),#fff5ee);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px}
.contrib-header-icon{width:48px;height:48px;background:var(--pri);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}
.contrib-header h2{font-size:1.1rem;font-weight:800;color:var(--text);margin-bottom:2px}
.contrib-header span{font-size:.82rem;color:var(--text2)}
.contrib-body{padding:24px}
.contrib-section{margin-bottom:24px}
.contrib-section:last-child{margin-bottom:0}
.contrib-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--pri);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.contrib-section-title::after{content:'';flex:1;height:1px;background:var(--border)}
.contrib-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.contrib-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:600px){.contrib-row,.contrib-row-2{grid-template-columns:1fr}}
.contrib-field{display:flex;flex-direction:column;gap:6px}
.contrib-field.full{grid-column:1/-1}
.contrib-field label{font-size:.75rem;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.03em}
.contrib-field label .opt{font-weight:400;color:var(--muted);text-transform:none;font-size:.7rem}
.contrib-field input,.contrib-field select{width:100%;padding:12px 14px;font-family:inherit;font-size:.95rem;border:2px solid var(--border);border-radius:10px;background:#fff;color:var(--text);transition:all .2s}
.contrib-field input:focus,.contrib-field select:focus{outline:none;border-color:var(--pri);box-shadow:0 0 0 3px rgba(242,101,34,.1)}
.contrib-field input::placeholder{color:var(--muted)}
.contrib-field select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:36px;-webkit-appearance:none}
.contrib-field .hint{font-size:.72rem;color:var(--muted);margin-top:2px}
.contrib-sal-wrap{position:relative}
.contrib-sal-input{font-size:1.3rem!important;font-weight:700!important;padding-right:45px!important}
.contrib-sal-suffix{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-size:1rem;font-weight:600;color:var(--text2)}
.contrib-toggle{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface2);border-radius:10px;cursor:pointer;transition:all .2s}
.contrib-toggle:hover{background:#F3F4F6}
.contrib-toggle-switch{width:40px;height:22px;background:var(--border);border-radius:11px;position:relative;transition:all .3s;flex-shrink:0}
.contrib-toggle-switch::after{content:'';position:absolute;width:16px;height:16px;background:#fff;border-radius:50%;top:3px;left:3px;transition:all .3s;box-shadow:0 2px 4px rgba(0,0,0,.2)}
.contrib-toggle.active .contrib-toggle-switch{background:var(--pri)}
.contrib-toggle.active .contrib-toggle-switch::after{left:21px}
.contrib-toggle-label{font-size:.9rem;font-weight:500;color:var(--text)}
.contrib-reveal{max-height:0;overflow:hidden;transition:all .4s ease;opacity:0}
.contrib-reveal.open{max-height:200px;opacity:1;margin-top:12px}
.contrib-chips{display:flex;gap:8px;flex-wrap:wrap}
.contrib-chip{padding:8px 14px;background:#fff;border:2px solid var(--border);border-radius:20px;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s}
.contrib-chip:hover{border-color:var(--pri);background:var(--pri-l)}
.contrib-chip.on{background:var(--pri);border-color:var(--pri);color:#fff}
.contrib-yn{display:flex;gap:10px}
.contrib-yn-btn{flex:1;padding:14px;border:2px solid var(--border);border-radius:10px;background:#fff;font-family:inherit;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}
.contrib-yn-btn:hover{border-color:var(--text2)}
.contrib-yn-btn.sel-yes{background:var(--grn-l);border-color:var(--grn);color:#059669}
.contrib-yn-btn.sel-no{background:var(--red-l);border-color:var(--red);color:#DC2626}
.contrib-prime-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px}
@media(max-width:500px){.contrib-prime-grid{grid-template-columns:repeat(2,1fr)}}
.contrib-prime-btn{padding:12px;border:2px solid var(--border);border-radius:10px;background:#fff;font-family:inherit;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s;text-align:center}
.contrib-prime-btn:hover{border-color:var(--ora);background:var(--ora-l)}
.contrib-prime-btn.on{background:var(--ora);border-color:var(--ora);color:#fff}
.contrib-divider{height:1px;background:var(--border);margin:20px 0}
.contrib-recap{background:linear-gradient(135deg,var(--grn-l),var(--blu-l));border-radius:12px;padding:18px}
.contrib-recap-title{font-size:.82rem;font-weight:700;color:var(--grn);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.contrib-recap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(max-width:500px){.contrib-recap-grid{grid-template-columns:repeat(2,1fr)}}
.contrib-recap-item .r-label{font-size:.7rem;color:var(--text2);text-transform:uppercase}
.contrib-recap-item .r-value{font-size:.88rem;font-weight:700;color:var(--text)}
.contrib-live{display:none;align-items:center;gap:10px;padding:12px 14px;background:var(--grn-l);border-radius:10px;margin-top:12px}
.contrib-live.visible{display:flex}
.contrib-live-dot{width:8px;height:8px;background:var(--grn);border-radius:50%;animation:pulse 1.5s infinite}
.contrib-live-text{font-size:.88rem;font-weight:600}
.contrib-live-text strong{color:var(--grn)}
.contrib-footer{text-align:center;padding:16px;font-size:.78rem;color:var(--muted);border-top:1px solid var(--border)}
.contrib-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:700;margin-left:8px}
.contrib-badge.nc{background:var(--blu-l);color:var(--blu)}
.contrib-badge.ca{background:var(--pur-l);color:var(--pur)}

/* ═══════ TDB REFONTE V2 ═══════ */
.tdb-profil{background:linear-gradient(135deg,#f97316 0%,#ea580c 100%);border-radius:16px;padding:20px;color:#fff;margin-bottom:18px}
.tdb-profil-head{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.tdb-profil-avatar{width:48px;height:48px;background:rgba(255,255,255,.2);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}
.tdb-profil-title{font-size:1.2rem;font-weight:800}
.tdb-profil-sub{font-size:.9rem;opacity:.9}
.tdb-profil-badges{display:flex;flex-wrap:wrap;gap:10px}
.tdb-profil-badge{background:rgba(255,255,255,.15);backdrop-filter:blur(4px);border-radius:10px;padding:10px 16px;text-align:center;min-width:100px;flex:1}
.tdb-profil-badge-label{font-size:.65rem;text-transform:uppercase;opacity:.8;margin-bottom:4px;letter-spacing:.5px}
.tdb-profil-badge-value{font-size:1rem;font-weight:700}
.tdb-profil-badge.highlight{background:rgba(255,255,255,.25)}

.tdb-position{background:#fff;border-radius:20px;padding:28px;box-shadow:0 4px 24px rgba(0,0,0,.06);margin-bottom:20px}
.tdb-position-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}
.tdb-position-title{display:flex;align-items:center;gap:12px;font-size:1.1rem;font-weight:700;color:#1e293b}
.tdb-position-title .ic{width:36px;height:36px;background:linear-gradient(135deg,#f97316,#fb923c);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#fff}
.tdb-position-sub{font-size:.82rem;color:#64748b;margin-top:4px}
.tdb-position-pct{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;padding:10px 20px;border-radius:30px;font-size:.9rem;font-weight:700;box-shadow:0 4px 12px rgba(249,115,22,.3)}

.tdb-graph-section{background:#fafafa;border-radius:14px;padding:20px;margin-bottom:16px}
.tdb-graph-section:last-child{margin-bottom:0}
.tdb-graph-header{display:flex;align-items:center;gap:8px;font-size:.9rem;font-weight:700;color:#374151;margin-bottom:16px}
.tdb-graph-icon{font-size:1.1rem}
.tdb-graph-site{background:#e0f2fe;color:#0369a1;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:600;margin-left:8px}
.tdb-graph-badge{background:#dbeafe;color:#1d4ed8;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:600;margin-left:8px}
.tdb-graph{padding:10px 0}

.tdb-timeline{position:relative;padding:0 20px}
.tdb-timeline-track{height:6px;background:linear-gradient(90deg,#fde68a 0%,#86efac 50%,#93c5fd 100%);border-radius:3px;position:relative;margin:60px 0 80px}
.tdb-timeline-progress{position:absolute;left:0;top:0;height:100%;background:linear-gradient(90deg,#f97316,#fb923c);border-radius:3px;transition:width .8s ease}
.tdb-timeline-point{position:absolute;top:50%;transform:translate(-50%,-50%);text-align:center}
.tdb-timeline-dot{width:18px;height:18px;border-radius:50%;border:3px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.15);transition:transform .3s}
.tdb-timeline-dot:hover{transform:scale(1.2)}
.tdb-timeline-label{position:absolute;bottom:100%;left:50%;transform:translateX(-50%);margin-bottom:12px;white-space:nowrap}
.tdb-timeline-icon{font-size:1.2rem;margin-bottom:4px}
.tdb-timeline-name{font-size:.7rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.tdb-timeline-value{position:absolute;top:100%;left:50%;transform:translateX(-50%);margin-top:12px;font-size:.85rem;font-weight:700;white-space:nowrap}
.tdb-timeline-point.vous .tdb-timeline-dot{width:28px;height:28px;background:linear-gradient(135deg,#f97316,#ea580c);box-shadow:0 4px 16px rgba(249,115,22,.4)}
.tdb-timeline-point.vous .tdb-timeline-value{background:linear-gradient(135deg,#fff7ed,#ffedd5);border:2px solid #f97316;padding:8px 16px;border-radius:10px;color:#ea580c}
.tdb-timeline-point.smh .tdb-timeline-dot{background:#fbbf24}
.tdb-timeline-point.smh .tdb-timeline-value{color:#b45309}
.tdb-timeline-point.med .tdb-timeline-dot{background:#10b981}
.tdb-timeline-point.med .tdb-timeline-value{color:#059669}
.tdb-timeline-point.max .tdb-timeline-dot{background:#3b82f6}
.tdb-timeline-point.max .tdb-timeline-value{color:#2563eb}

.tdb-timeline-gap{position:absolute;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center}
.tdb-timeline-gap-line{height:2px;background:repeating-linear-gradient(90deg,#cbd5e1,#cbd5e1 4px,transparent 4px,transparent 8px);flex:1}
.tdb-timeline-gap-badge{background:#f1f5f9;padding:4px 10px;border-radius:20px;font-size:.7rem;font-weight:600;white-space:nowrap}
.tdb-timeline-gap-badge.positive{background:#dcfce7;color:#16a34a}
.tdb-timeline-gap-badge.negative{background:#fee2e2;color:#dc2626}

.tdb-objective{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2px solid #86efac;border-radius:14px;padding:18px 24px;margin-top:10px;display:flex;align-items:center;gap:16px}
.tdb-objective-icon{font-size:1.8rem}
.tdb-objective-text{flex:1}
.tdb-objective-title{font-size:.9rem;font-weight:700;color:#166534;margin-bottom:4px}
.tdb-objective-desc{font-size:.82rem;color:#15803d}

/* Timeline Premium */
.tl-container{padding:10px 0}
.tl-icon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 6px;font-size:1.2rem;box-shadow:0 4px 12px rgba(0,0,0,.1)}
.tl-icon.smh{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b}
.tl-icon.vous{background:linear-gradient(135deg,#fed7aa,#fdba74);border:3px solid #f97316;width:52px;height:52px;font-size:1.4rem;box-shadow:0 6px 20px rgba(249,115,22,.3);position:relative;top:-4px}
.tl-icon.med{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:2px solid #10b981}
.tl-icon.max{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border:2px solid #6366f1}
.tl-label{font-size:.65rem;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.tl-label.vous{color:#ea580c;font-size:.7rem}
.tl-label.med{color:#059669}
.tl-value{font-size:.85rem;font-weight:800;margin-top:2px}
.tl-value.smh{color:#d97706}
.tl-value.vous{color:#ea580c;font-size:.95rem}
.tl-value.med{color:#059669}
.tl-value.max{color:#4f46e5}

.tl-track{position:relative;height:10px;background:#e5e7eb;border-radius:5px;margin:15px 0 25px}
.tl-progress{position:absolute;left:0;top:0;height:100%;border-radius:5px}
.tl-dot{position:absolute;top:50%;transform:translate(-50%,-50%);width:16px;height:16px;border-radius:50%;border:3px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.tl-dot.smh{background:#f59e0b}
.tl-dot.vous{background:#f97316;width:24px;height:24px;z-index:10;box-shadow:0 4px 12px rgba(249,115,22,.4)}
.tl-dot.med{background:#10b981}
.tl-dot.max{background:#6366f1}

.tl-gaps{display:flex;justify-content:space-around;margin:15px 0;gap:10px}
.tl-gap{text-align:center;flex:1;padding:8px;background:#f9fafb;border-radius:8px}
.tl-gap-line{font-size:.65rem;color:#9ca3af;margin-bottom:4px;font-weight:500}
.tl-gap-value{font-size:.9rem;font-weight:700;padding:2px 10px;border-radius:12px;display:inline-block}
.tl-gap-value.positive{background:#dcfce7;color:#16a34a}
.tl-gap-value.negative{background:#fee2e2;color:#dc2626}

.tl-objective{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fcd34d;border-radius:12px;padding:14px 18px;display:flex;align-items:center;gap:12px;margin-top:15px}
.tl-objective-icon{font-size:1.4rem}
.tl-objective-text{font-size:.88rem;color:#92400e;line-height:1.4}
.tl-objective-text strong{color:#b45309}

.tdb-analysis{background:linear-gradient(135deg,#fffbeb 0%,#fef3c7 100%);border:1px solid #fcd34d;border-radius:16px;padding:20px;margin-bottom:18px}
.tdb-analysis-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.tdb-analysis-head .ic{font-size:1.3rem}
.tdb-analysis-title{font-size:1rem;font-weight:700;color:#b45309}
.tdb-analysis-text{font-size:.9rem;color:#92400e;line-height:1.6}
.tdb-analysis-text strong{color:#78350f}
.tdb-analysis-item{margin-top:12px;padding-left:20px;position:relative}
.tdb-analysis-item::before{content:'';position:absolute;left:0;top:6px;width:8px;height:8px;background:#f59e0b;border-radius:2px}

/* COMPARAISONS TDB */
.tdb-comparisons{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 24px rgba(0,0,0,.06);margin-bottom:18px}
.tdb-comparisons-title{display:flex;align-items:center;gap:10px;font-size:1.1rem;font-weight:700;color:#1e293b;margin-bottom:20px}
.tdb-comparisons-title .ic{width:36px;height:36px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.tdb-comp-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:16px;margin-bottom:12px}
.tdb-comp-item:last-child{margin-bottom:0}
.tdb-comp-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.tdb-comp-label{display:flex;align-items:center;gap:8px;font-size:.88rem;font-weight:700;color:#334155}
.tdb-comp-label .comp-ic{font-size:1rem}
.tdb-comp-count{background:#e0e7ff;color:#4338ca;padding:4px 10px;border-radius:20px;font-size:.72rem;font-weight:700}
.tdb-comp-bar{position:relative;height:8px;background:linear-gradient(90deg,#fecaca 0%,#fde68a 25%,#bbf7d0 50%,#fde68a 75%,#fecaca 100%);border-radius:4px;margin:16px 0}
.tdb-comp-marker{position:absolute;top:50%;transform:translate(-50%,-50%)}
.tdb-comp-dot{width:20px;height:20px;border-radius:50%;border:3px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.tdb-comp-dot.vous{background:linear-gradient(135deg,#f97316,#ea580c);width:26px;height:26px;z-index:10}
.tdb-comp-values{display:flex;justify-content:space-between;font-size:.75rem;color:#64748b;font-weight:600;margin-bottom:8px}
.tdb-comp-vous{display:flex;align-items:center;gap:6px;margin-top:8px}
.tdb-comp-vous-label{font-size:.82rem;font-weight:700;color:#ea580c}
.tdb-comp-vous-val{font-size:.95rem;font-weight:800;color:#ea580c}
.tdb-comp-ecart{font-size:.82rem;font-weight:600;padding:6px 12px;border-radius:8px;margin-top:8px;display:inline-block}
.tdb-comp-ecart.above{background:#dcfce7;color:#16a34a}
.tdb-comp-ecart.below{background:#fee2e2;color:#dc2626}

/* ÉCART H/F */
.tdb-gap{background:linear-gradient(135deg,#fdf2f8,#fce7f3);border:1px solid #fbcfe8;border-radius:12px;padding:16px;margin-bottom:12px}
.tdb-gap-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.tdb-gap-title{font-size:.88rem;font-weight:700;color:#9d174d;display:flex;align-items:center;gap:8px}
.tdb-gap-scope{background:#fce7f3;color:#be185d;padding:4px 10px;border-radius:20px;font-size:.72rem;font-weight:700}
.tdb-gap-bars{display:flex;flex-direction:column;gap:8px}
.tdb-gap-row{display:flex;align-items:center;gap:12px}
.tdb-gap-label{width:30px;font-size:.82rem;font-weight:700}
.tdb-gap-label.h{color:#2563eb}
.tdb-gap-label.f{color:#db2777}
.tdb-gap-track{flex:1;height:20px;background:rgba(255,255,255,.6);border-radius:10px;overflow:hidden}
.tdb-gap-fill{height:100%;border-radius:10px}
.tdb-gap-fill.h{background:linear-gradient(90deg,#93c5fd,#2563eb)}
.tdb-gap-fill.f{background:linear-gradient(90deg,#fbcfe8,#db2777)}
.tdb-gap-val{width:80px;font-size:.82rem;font-weight:700;text-align:right}
.tdb-gap-val.h{color:#2563eb}
.tdb-gap-val.f{color:#db2777}
.tdb-gap-diff{text-align:center;margin-top:10px;font-size:.82rem;font-weight:700;padding:8px 16px;border-radius:8px;display:inline-block}
.tdb-gap-diff.high{background:#fee2e2;color:#dc2626}
.tdb-gap-diff.low{background:#dcfce7;color:#16a34a}

/* GROUPES DE COMPARAISONS */
.tdb-comp-group{margin-bottom:20px}
.tdb-comp-group-title{display:flex;align-items:center;gap:8px;font-size:.9rem;font-weight:700;color:#475569;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #e2e8f0}
.tdb-comp-group-title .grp-ic{font-size:1.1rem}
.tdb-comp-group-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:12px}
@media(max-width:700px){.tdb-comp-group-grid{grid-template-columns:1fr}}
.tdb-comp-empty{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:12px;padding:20px;text-align:center;color:#64748b;font-size:.85rem}

.tdb-profil-thanks{margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.25);font-size:1rem;font-weight:700;color:#fff;text-align:center;line-height:1.5}

/* ── Enquête Échelle 1-5 ─────────────────────────────────────────────── */
.land-enquete-echelle-row{
  display:flex;gap:6px;flex-wrap:wrap;
  justify-content:center;padding:6px 0;
}
.land-enquete-echelle-btn{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:10px 12px;
  border:1.5px solid #e2e8f0;border-radius:12px;
  background:#f8fafc;cursor:pointer;min-width:60px;
  transition:all .2s;font-family:inherit;
}
.land-enquete-echelle-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 4px 12px rgba(30,64,175,.1);
  border-color:#059669;background:#ecfdf5;
}
.land-enquete-echelle-btn.selected{
  transform:translateY(-2px);
  box-shadow:0 4px 14px rgba(30,64,175,.2);
  border-color:#059669;
  background:linear-gradient(135deg,#ecfdf5,#d1fae5);
}
.land-echelle-num{font-size:1.35rem;font-weight:800;line-height:1;}
.land-echelle-lbl{
  font-size:.6rem;font-weight:600;color:#64748b;
  text-align:center;max-width:64px;line-height:1.2;
}

/* ── Bloc 2 : système d'icônes SVG inline (L935-977 v3_clean) ── */
/* Icônes SVG professionnelles — SalaireScope CFDT — classe unique sans espace */
[class^=ic-]{display:inline-block;width:16px;height:16px;vertical-align:middle;background-size:contain;background-repeat:no-repeat;background-position:center;flex-shrink:0;margin:0 1px}
.ic-ok{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2316a34a' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E")}
.ic-err{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23dc2626' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cline x1='15' y1='9' x2='9' y2='15'/%3E%3Cline x1='9' y1='9' x2='15' y2='15'/%3E%3C/svg%3E")}
.ic-warn{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23d97706' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M10.29 3.86L1.82 18a2 2 0 001.71 3h16.94a2 2 0 001.71-3L13.71 3.86a2 2 0 00-3.42 0z'/%3E%3Cline x1='12' y1='9' x2='12' y2='13'/%3E%3Cline x1='12' y1='17' x2='12.01' y2='17'/%3E%3C/svg%3E")}
.ic-chart{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='20' x2='18' y2='10'/%3E%3Cline x1='12' y1='20' x2='12' y2='4'/%3E%3Cline x1='6' y1='20' x2='6' y2='14'/%3E%3C/svg%3E")}
.ic-list{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='8' y1='6' x2='21' y2='6'/%3E%3Cline x1='8' y1='12' x2='21' y2='12'/%3E%3Cline x1='8' y1='18' x2='21' y2='18'/%3E%3Cline x1='3' y1='6' x2='3.01' y2='6'/%3E%3C/svg%3E")}
.ic-edit{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M11 4H4a2 2 0 00-2 2v14a2 2 0 002 2h14a2 2 0 002-2v-7'/%3E%3Cpath d='M18.5 2.5a2.121 2.121 0 013 3L12 15l-4 1 1-4 9.5-9.5z'/%3E%3C/svg%3E")}
.ic-money{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='12' y1='1' x2='12' y2='23'/%3E%3Cpath d='M17 5H9.5a3.5 3.5 0 000 7h5a3.5 3.5 0 010 7H6'/%3E%3C/svg%3E")}
.ic-target{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Ccircle cx='12' cy='12' r='6'/%3E%3Ccircle cx='12' cy='12' r='2'/%3E%3C/svg%3E")}
.ic-clock{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23d97706' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpolyline points='12 6 12 12 16 14'/%3E%3C/svg%3E")}
.ic-dl{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 01-2 2H5a2 2 0 01-2-2v-4'/%3E%3Cpolyline points='7 10 12 15 17 10'/%3E%3Cline x1='12' y1='15' x2='12' y2='3'/%3E%3C/svg%3E")}
.ic-scale{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='12' y1='3' x2='12' y2='21'/%3E%3Cpath d='M3 9l9-7 9 7'/%3E%3Cpath d='M5 9l-2 9h18l-2-9'/%3E%3C/svg%3E")}
.ic-trend{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='23 6 13.5 15.5 8.5 10.5 1 18'/%3E%3Cpolyline points='17 6 23 6 23 12'/%3E%3C/svg%3E")}
.ic-robot{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='11' width='18' height='10' rx='2'/%3E%3Ccircle cx='12' cy='5' r='2'/%3E%3Cpath d='M12 7v4'/%3E%3C/svg%3E")}
.ic-lock{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='11' width='18' height='11' rx='2'/%3E%3Cpath d='M7 11V7a5 5 0 0110 0v4'/%3E%3C/svg%3E")}
.ic-save{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M19 21H5a2 2 0 01-2-2V5a2 2 0 012-2h11l5 5v11a2 2 0 01-2 2z'/%3E%3Cpolyline points='17 21 17 13 7 13 7 21'/%3E%3C/svg%3E")}
.ic-doc{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 2H6a2 2 0 00-2 2v16a2 2 0 002 2h12a2 2 0 002-2V8z'/%3E%3Cpolyline points='14 2 14 8 20 8'/%3E%3C/svg%3E")}
.ic-eye{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M1 12s4-8 11-8 11 8 11 8-4 8-11 8-11-8-11-8z'/%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3C/svg%3E")}
.ic-eye-off{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M17.94 17.94A10.07 10.07 0 0112 20c-7 0-11-8-11-8a18.45 18.45 0 015.06-5.94M9.9 4.24A9.12 9.12 0 0112 4c7 0 11 8 11 8a18.5 18.5 0 01-2.16 3.19m-6.72-1.07a3 3 0 11-4.24-4.24'/%3E%3Cline x1='1' y1='1' x2='23' y2='23'/%3E%3C/svg%3E")}
.ic-trash{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23dc2626' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='3 6 5 6 21 6'/%3E%3Cpath d='M19 6v14a2 2 0 01-2 2H7a2 2 0 01-2-2V6m3 0V4a1 1 0 011-1h4a1 1 0 011 1v2'/%3E%3C/svg%3E")}
.ic-users{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M17 21v-2a4 4 0 00-4-4H5a4 4 0 00-4 4v2'/%3E%3Ccircle cx='9' cy='7' r='4'/%3E%3Cpath d='M23 21v-2a4 4 0 00-3-3.87'/%3E%3C/svg%3E")}
.ic-user{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21v-2a4 4 0 00-4-4H8a4 4 0 00-4 4v2'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E")}
.ic-refresh{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='23 4 23 10 17 10'/%3E%3Cpolyline points='1 20 1 14 7 14'/%3E%3Cpath d='M3.51 9a9 9 0 0114.85-3.36L23 10M1 14l4.64 4.36A9 9 0 0020.49 15'/%3E%3C/svg%3E")}
.ic-pin{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0118 0z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E")}
.ic-search{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E")}
.ic-chat{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15a2 2 0 01-2 2H7l-4 4V5a2 2 0 012-2h14a2 2 0 012 2z'/%3E%3C/svg%3E")}
.ic-bulb{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23d97706' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='9' y1='18' x2='15' y2='18'/%3E%3Cline x1='10' y1='22' x2='14' y2='22'/%3E%3Cpath d='M15.09 14c.18-.98.65-1.74 1.41-2.5A4.65 4.65 0 0018 8 6 6 0 006 8c0 1 .23 2.23 1.5 3.5A4.61 4.61 0 018.91 14'/%3E%3C/svg%3E")}
.ic-ul{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 01-2 2H5a2 2 0 01-2-2v-4'/%3E%3Cpolyline points='17 8 12 3 7 8'/%3E%3Cline x1='12' y1='3' x2='12' y2='15'/%3E%3C/svg%3E")}
.ic-star{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23d97706' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='12 2 15.09 8.26 22 9.27 17 14.14 18.18 21.02 12 17.77 5.82 21.02 7 14.14 2 9.27 8.91 8.26 12 2'/%3E%3C/svg%3E")}
.ic-alert{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23dc2626' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cline x1='12' y1='8' x2='12' y2='12'/%3E%3Cline x1='12' y1='16' x2='12.01' y2='16'/%3E%3C/svg%3E")}
.ic-cal{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E")}
.ic-gear{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3Cpath d='M19.4 15a1.65 1.65 0 00.33 1.82l.06.06a2 2 0 010 2.83 2 2 0 01-2.83 0l-.06-.06a1.65 1.65 0 00-1.82-.33 1.65 1.65 0 00-1 1.51V21a2 2 0 01-4 0v-.09A1.65 1.65 0 009 19.4a1.65 1.65 0 00-1.82.33l-.06.06a2 2 0 01-2.83-2.83l.06-.06A1.65 1.65 0 004.68 15a1.65 1.65 0 00-1.51-1H3a2 2 0 010-4h.09A1.65 1.65 0 004.6 9a1.65 1.65 0 00-.33-1.82l-.06-.06a2 2 0 012.83-2.83l.06.06A1.65 1.65 0 009 4.68a1.65 1.65 0 001-1.51V3a2 2 0 014 0v.09a1.65 1.65 0 001 1.51 1.65 1.65 0 001.82-.33l.06-.06a2 2 0 012.83 2.83l-.06.06A1.65 1.65 0 0019.4 9a1.65 1.65 0 001.51 1H21a2 2 0 010 4h-.09a1.65 1.65 0 00-1.51 1z'/%3E%3C/svg%3E")}
.ic-factory{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M2 20a2 2 0 002 2h16a2 2 0 002-2V8l-7 5V8l-7 5V4a2 2 0 00-2-2H4a2 2 0 00-2 2z'/%3E%3C/svg%3E")}
.ic-bank{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='3' y1='22' x2='21' y2='22'/%3E%3Cline x1='6' y1='18' x2='6' y2='11'/%3E%3Cline x1='10' y1='18' x2='10' y2='11'/%3E%3Cline x1='14' y1='18' x2='14' y2='11'/%3E%3Cline x1='18' y1='18' x2='18' y2='11'/%3E%3Cpolygon points='12 2 20 7 4 7'/%3E%3C/svg%3E")}
.ic-euro{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 10h12M4 14h12M19 5a7 7 0 100 14'/%3E%3C/svg%3E")}
.ic-mail{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 4h16c1.1 0 2 .9 2 2v12c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2V6c0-1.1.9-2 2-2z'/%3E%3Cpolyline points='22,6 12,13 2,6'/%3E%3C/svg%3E")}
.ic-announce{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='11 5 6 9 2 9 2 15 6 15 11 19 11 5'/%3E%3C/svg%3E")}
.ic-home{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 9l9-7 9 7v11a2 2 0 01-2 2H5a2 2 0 01-2-2z'/%3E%3Cpolyline points='9 22 9 12 15 12 15 22'/%3E%3C/svg%3E")}
.ic-plus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='12' y1='5' x2='12' y2='19'/%3E%3Cline x1='5' y1='12' x2='19' y2='12'/%3E%3C/svg%3E")}
.ic-book{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 19.5A2.5 2.5 0 016.5 17H20'/%3E%3Cpath d='M6.5 2H20v20H6.5A2.5 2.5 0 014 19.5v-15A2.5 2.5 0 016.5 2z'/%3E%3C/svg%3E")}
.ic-help{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpath d='M9.09 9a3 3 0 015.83 1c0 2-3 3-3 3'/%3E%3Cline x1='12' y1='17' x2='12.01' y2='17'/%3E%3C/svg%3E")}
.ic-sword{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='14.5 17.5 3 6 3 3 6 3 17.5 14.5'/%3E%3Cline x1='13' y1='19' x2='19' y2='13'/%3E%3C/svg%3E")}

/* ── Bloc 3 : curseur clignotant CFDT (L979 v3_clean, contenu inline) ── */
.cfdt-cursor{display:inline-block;animation:cfdt-blink 1s step-end infinite;color:#F26522;font-weight:bold}
@keyframes cfdt-blink{0%,100%{opacity:1}50%{opacity:0}}

/* ── Bloc 4 : chatbot bulle (L23619-23643 v3_clean) ── */
#chatbot-bubble{display:none!important}
#chatbot-bubble:hover{transform:scale(1.1)}
@keyframes _cbPulse{0%,100%{box-shadow:0 4px 20px rgba(242,101,34,.4)}50%{box-shadow:0 4px 30px rgba(242,101,34,.7),0 0 0 8px rgba(242,101,34,.15)}}
#chatbot-badge{position:absolute;top:-2px;right:-2px;width:16px;height:16px;background:#16a34a;border-radius:50%;border:2px solid #fff;animation:_cbBlink 1.5s infinite}
@keyframes _cbBlink{0%,100%{opacity:1}50%{opacity:.3}}
#chatbot-tooltip{position:absolute;right:76px;top:50%;transform:translateY(-50%);background:#1e293b;color:#fff;padding:8px 14px;border-radius:10px;font-size:.82rem;font-weight:600;white-space:nowrap;box-shadow:0 4px 12px rgba(0,0,0,.2);pointer-events:none;opacity:0;transition:opacity .3s}
#chatbot-tooltip::after{content:'';position:absolute;right:-6px;top:50%;transform:translateY(-50%);border:6px solid transparent;border-left-color:#1e293b}
#chatbot-bubble:hover #chatbot-tooltip{opacity:1}
#chatbot-panel{position:fixed;top:56px;right:calc(50% - 190px);z-index:9998;width:380px;max-width:calc(100vw - 24px);height:520px;max-height:calc(100vh - 80px);background:#fff;border-radius:16px;box-shadow:0 8px 40px rgba(0,0,0,.2);display:none;flex-direction:column;overflow:hidden;border:2px solid #f97316}
#chatbot-panel.open{display:flex}
#cb-header{background:linear-gradient(135deg,#F26522,#d97706);padding:14px 16px;display:flex;align-items:center;gap:10px}
#cb-messages{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px;background:#fafafa}
#cb-input-wrap{padding:10px;border-top:1px solid #e5e7eb;background:#fff;display:flex;gap:8px}
#cb-input{flex:1;padding:10px 14px;border:2px solid #e5e7eb;border-radius:10px;font-size:.88rem;outline:none;font-family:inherit;resize:none}
#cb-input:focus{border-color:#f97316}
#cb-send{width:42px;height:42px;border-radius:10px;background:#F26522;color:#fff;border:none;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
#cb-send:hover{background:#d97706}
.cb-msg{max-width:85%;padding:10px 14px;border-radius:12px;font-size:.85rem;line-height:1.6;word-break:break-word}
.cb-msg.user{align-self:flex-end;background:#F26522;color:#fff;border-bottom-right-radius:4px}
.cb-msg.bot{align-self:flex-start;background:#fff;color:#1e293b;border:1px solid #e5e7eb;border-bottom-left-radius:4px}
.cb-msg.bot .cb-sources{margin-top:8px;padding-top:8px;border-top:1px solid #f0f0f0;font-size:.75rem;color:#64748b}
.cb-suggest{display:flex;flex-wrap:wrap;gap:6px;padding:10px 14px}
.cb-suggest button{padding:6px 12px;background:#fff7ed;color:#c2410c;border:1px solid #fed7aa;border-radius:8px;font-size:.78rem;cursor:pointer;text-align:left;transition:background .2s}
.cb-suggest button:hover{background:#ffedd5}
@media(max-width:500px){#chatbot-panel{width:calc(100vw - 16px);right:8px;top:56px;height:calc(100vh - 70px)}}

/* ─── IMPRESSION TDB ──────────────────────────────────────────────────── */
@media print {
  @page { size: A4; margin: 14mm 12mm; }
  body { background: #fff !important; color: #000 !important; font-size: 11pt; }
  #app-hdr, #tabs, #landing-page, #toast-root, #modal-root, #loading-overlay, #galert,
  .tdb-no-print, #chatbot-panel, #chatbot-fab, #cookie-banner, #popup-enquete { display: none !important; }
  #app-main { padding: 0 !important; max-width: 100% !important; }
  .panel { display: none !important; }
  #p-tdb { display: block !important; }
  #tdb-locked, #tdb-apercu { display: none !important; }
  #tdb-complet { display: block !important; }
  .tdb-print-block, .card, .tdb-profil, .tdb-comparisons, .tdb-analysis {
    page-break-inside: avoid; break-inside: avoid;
    box-shadow: none !important; border: 0.5pt solid #cbd5e1 !important;
    margin-bottom: 8mm !important;
  }
  .tdb-print-block { background: #fff !important; }
  /* Forcer les couleurs pour graphiques */
  svg, svg * { -webkit-print-color-adjust: exact !important; print-color-adjust: exact !important; color-adjust: exact !important; }
  * { -webkit-print-color-adjust: exact !important; print-color-adjust: exact !important; }
  a[href]:after { content: "" !important; }
}

/* ═══════════════════════════════════════════════════════════════════
   RESPONSIVE MOBILE & TABLETTE — [2026-05-16 jfn]
   Couche additive : ne s'active que sur petits écrans. PC & impression
   inchangés. Corrige le scroll horizontal et les largeurs fixes inline
   du HTML généré serveur (public ET admin).
   ═══════════════════════════════════════════════════════════════════ */
@media (max-width:768px){
  html,body{overflow-x:hidden;max-width:100%}
  .main{padding:14px 12px}
  .hdr{padding:10px 14px}
  .card{padding:16px 14px}
  img,svg,canvas,video{max-width:100%;height:auto}
  table{max-width:100%}
  /* Largeurs fixes inline trop grandes → fluides (le tableau scrolle
     dans son conteneur, plus la page entière) */
  [style*="min-width:1200"],[style*="min-width:1100"],[style*="min-width:1080"],
  [style*="min-width:1000"],[style*="min-width:960"],[style*="min-width:900"],
  [style*="min-width:860"],[style*="min-width:800"],[style*="min-width:760"],
  [style*="min-width:720"],[style*="min-width:700"]{min-width:0 !important}
}
@media (max-width:640px){
  /* Grilles multi-colonnes (inline ou classes) → 1 colonne */
  [style*="grid-template-columns"],.fg,.sg,.cfg-g,.hero,.met-grid{grid-template-columns:1fr !important}
  /* 16px sur les champs = pas de zoom automatique iOS à la saisie */
  input,select,textarea{font-size:16px !important;max-width:100%}
  table{font-size:.74rem}
  .ctitle{font-size:.72rem}
  /* Conteneurs scrollables : scroll tactile fluide */
  [style*="overflow-x:auto"],[style*="overflow:auto"]{-webkit-overflow-scrolling:touch}
  /* Boutons : ne débordent pas */
  button,a{max-width:100%}
  .bp,.lock-cta{font-size:.95rem;padding:13px}
}
@media (max-width:480px){
  .main{padding:10px 8px}
  .card{padding:12px 10px}
  table{font-size:.66rem}
  table td,table th{padding:5px 6px !important}
}

/* ═══════════════════════════════════════════════════════════════════════
   IA UNIFIED LOADER — 3 points clignotants
   Usage : <span class="ia-dots"><i></i><i></i><i></i></span>
   ou via JS : iaWait(btn) / iaStop(btn) (cf. app.js)
   ═══════════════════════════════════════════════════════════════════════ */
.ia-dots{display:inline-flex;align-items:center;gap:4px;vertical-align:middle;margin-left:8px}
.ia-dots i{display:inline-block;width:6px;height:6px;border-radius:50%;background:#a855f7;animation:ia-pulse 1.2s infinite ease-in-out both}
.ia-dots i:nth-child(1){animation-delay:-.32s}
.ia-dots i:nth-child(2){animation-delay:-.16s}
.ia-dots i:nth-child(3){animation-delay:0s}
@keyframes ia-pulse{0%,80%,100%{opacity:.25;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}
.ia-busy{opacity:.65;pointer-events:none;cursor:wait!important;position:relative}
.ia-banner{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background:linear-gradient(90deg,#f3e8ff,#ede9fe);border:1px solid #c4b5fd;border-radius:20px;color:#6d28d9;font-size:.82rem;font-weight:600}
.ia-banner .ia-dots i{background:#7c3aed}
/* Overlay global flottant — actif pendant tout fetch IA en cours (user ET admin).
   Garantit que l'utilisateur ET l'admin voient toujours que l'IA travaille. */
.ia-global-overlay{position:fixed;bottom:20px;right:20px;z-index:99999;display:none;align-items:center;gap:10px;padding:10px 18px;background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;border-radius:24px;font-size:.86rem;font-weight:700;box-shadow:0 6px 20px rgba(124,58,237,.4);animation:ia-overlay-in .25s ease-out}
.ia-global-overlay .ia-global-txt{letter-spacing:.2px}
.ia-global-overlay .ia-dots i{background:#fff}
@keyframes ia-overlay-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:520px){.ia-global-overlay{bottom:14px;right:14px;left:14px;justify-content:center;font-size:.82rem}}
