/* ═══════════════════════════════════════════════════════════
   modals.css — overlays, pop-ups et chat widget
   V1 : chat-widget WhatsApp + popup générique + delay-popup
   V4 : rs-modal Comprendre (bad/good/tip) + rs-note-modal
   Dépend de base.css.
   ═══════════════════════════════════════════════════════════ */

/* ─── Modale lecteur vidéo (YouTube / Vimeo embed) ─── */
.rs-modal-overlay .video-modal{background:#000;border-radius:14px;padding:0;max-width:920px;width:92vw;position:relative;overflow:visible}
.video-modal-wrap{position:relative;width:100%;padding-bottom:56.25%;background:#000;border-radius:14px;overflow:hidden}
.video-modal-wrap iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}
.video-modal-close{position:absolute;top:-44px;right:0;background:rgba(255,255,255,.15);color:#fff;border:1.5px solid rgba(255,255,255,.4);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;cursor:pointer;backdrop-filter:blur(8px);transition:all .15s;z-index:10}
.video-modal-close:hover{background:rgba(255,255,255,.3);border-color:#fff;transform:scale(1.05)}

/* ─── chat-widget (bouton WhatsApp flottant + speech bubble) ─── */
/* ── CHAT WIDGET ── */
.chat-widget{position:fixed;bottom:1.4rem;right:1.4rem;z-index:500;display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.chat-speech{background:var(--white);border:2px solid var(--border);border-radius:14px 14px 4px 14px;padding:.6rem 1rem;font-size:11.5px;font-weight:500;color:var(--ink2);box-shadow:var(--sh2);max-width:200px;line-height:1.5;animation:chatIn .5s ease .8s backwards}
@keyframes chatIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.chat-btn{width:52px;height:52px;border-radius:50%;background:#25D366;border:3px solid #fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 16px rgba(34,197,94,.4);position:relative;transition:transform .2s}
.chat-btn:hover{transform:scale(1.08)}
.chat-ava{width:42px;height:42px;border-radius:50%;object-fit:cover;object-position:top}
.chat-dot{position:absolute;bottom:1px;right:1px;width:12px;height:12px;background:#22c55e;border-radius:50%;border:2px solid #fff;animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.4)}50%{box-shadow:0 0 0 6px rgba(34,197,94,0)}}

/* ─── popup V1 — onboarding hours/delay/générique (popup-overlay + delay-popup-overlay) ─── */
/* ── POPUP ── */
.popup-overlay{position:fixed;inset:0;background:rgba(15,23,42,.5);backdrop-filter:blur(5px);z-index:600;display:none;align-items:center;justify-content:center;padding:1.5rem}
.popup-overlay.on{display:flex}
.popup-card{background:var(--white);border-radius:24px;padding:1.75rem;max-width:400px;width:100%;box-shadow:var(--sh3);text-align:center;position:relative}
.popup-close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:18px;color:var(--ink4);cursor:pointer}
.popup-prog-wrap{margin-bottom:.9rem}
.popup-prog-label{display:flex;justify-content:space-between;font-size:11px;margin-bottom:5px}
.popup-prog-bg{height:6px;background:var(--bg);border-radius:3px;overflow:hidden}
.popup-prog-fill{height:6px;border-radius:3px;transition:width .6s ease}
.popup-icon{font-size:1.75rem;margin-bottom:.5rem}
.popup-title{font-family:'Outfit',sans-serif;font-size:1.05rem;font-weight:800;margin-bottom:.5rem;line-height:1.3}
.popup-text{font-size:12px;color:var(--ink3);line-height:1.65;margin-bottom:1rem;text-align:left}
.popup-text strong{color:var(--ink)}
.popup-text em{font-style:normal;font-weight:600;color:var(--ink2)}
.popup-cta{width:100%;background:var(--active);color:#fff;border:none;border-radius:12px;padding:12px;font-family:'Outfit',sans-serif;font-size:.9rem;font-weight:800;cursor:pointer;transition:opacity .15s}
.popup-cta:hover{opacity:.9}
.popup-reassure{font-size:10px;color:var(--ink4);text-align:center;margin-top:.6rem}
/* Delay popup */
.delay-popup-overlay{position:fixed;inset:0;background:rgba(15,23,42,.5);backdrop-filter:blur(5px);z-index:600;display:none;align-items:center;justify-content:center;padding:1.5rem}
.delay-popup-overlay.on{display:flex}
.delay-card{background:var(--white);border-radius:24px;padding:1.75rem;max-width:360px;width:100%;box-shadow:var(--sh3);text-align:center;position:relative}
.delay-close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:18px;color:var(--ink4);cursor:pointer}

/* ─── hours-popup V7 — pill buttons 5/10/15/20 ─── */
.hours-opts{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.hours-opt{background:var(--rs-bg-soft);border:2px solid var(--rs-border);border-radius:12px;padding:14px 20px;font-family:'Outfit',sans-serif;font-size:1.1rem;font-weight:800;color:var(--rs-ink);cursor:pointer;transition:all .15s;min-width:72px}
.hours-opt:hover{border-color:var(--rs-violet-m);background:var(--rs-violet-l)}
.hours-opt.sel{background:var(--rs-violet);color:#fff;border-color:var(--rs-violet);transform:translateY(-1px);box-shadow:0 4px 14px rgba(124,58,237,.35)}
#hours-popup-confirm:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}

/* ─── modals V4 — Comprendre / Note (rs-modal-overlay, rs-modal, rs-note-modal) ─── */
/* ═══ MODALS Comprendre / Note ═══ */
.rs-modal-overlay{position:fixed;inset:0;z-index:1500;display:none;align-items:center;justify-content:center;padding:1.5rem;background:rgba(15,23,42,.55);backdrop-filter:blur(6px);animation:rsFadeIn .2s ease}
.rs-modal-overlay.on{display:flex}
@keyframes rsFadeIn{from{opacity:0}to{opacity:1}}
.rs-modal{background:#fff;border-radius:20px;padding:1.85rem 2rem 1.75rem;max-width:600px;width:100%;max-height:88vh;overflow-y:auto;position:relative;box-shadow:0 28px 70px rgba(15,23,42,.3);animation:rsPopIn .24s cubic-bezier(.34,1.56,.64,1)}
@keyframes rsPopIn{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.rs-modal-close{position:absolute;top:14px;right:14px;background:none;border:none;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--rs-ink3);cursor:pointer;transition:background .15s,color .15s;font-size:18px;line-height:1}
.rs-modal-close:hover{background:var(--rs-bg-soft);color:var(--rs-ink)}
.rs-modal .rp-task-pill{display:inline-flex;background:var(--pil-light);color:var(--pil-color)}
.rs-modal .rp-task-title{font-size:1.35rem;margin-bottom:.85rem}
.rs-modal .rp-task-badges{margin-bottom:1.15rem}
.rs-modal .rp-task-desc{font-size:13.5px;color:var(--rs-ink2);line-height:1.65;margin-bottom:1.1rem}
.rs-modal .rp-block{font-size:13px;padding:.95rem 1.1rem;margin-bottom:10px}
.rs-modal .rp-block-p{font-size:12.5px}
.rs-modal .rp-block-h{font-size:12px}
.rs-modal .rp-wix-link{font-size:13px;padding:.85rem 1.1rem}

/* Note modal spécifique */
.rs-note-modal{max-width:500px}
.rs-note-modal .rs-note-h{font-family:'Outfit',sans-serif;font-size:1.15rem;font-weight:800;color:var(--rs-ink);letter-spacing:-.01em;margin-bottom:.3rem;display:flex;align-items:center;gap:8px}
.rs-note-modal .rs-note-sub{font-size:12.5px;color:var(--rs-ink3);line-height:1.55;margin-bottom:1.1rem}
.rs-note-modal .rs-note-sub strong{color:var(--rs-ink);font-weight:700}
.rs-note-modal textarea{width:100%;min-height:140px;background:var(--rs-bg-soft);border:1.5px solid var(--rs-border);border-radius:10px;padding:12px 14px;font-size:13px;font-family:'Poppins',sans-serif;outline:none;resize:vertical;color:var(--rs-ink);line-height:1.55;transition:border-color .15s,background .15s}
.rs-note-modal textarea:focus{border-color:var(--rs-violet);background:#fff}
.rs-note-modal .rs-note-help{font-size:11.5px;color:var(--rs-ink4);margin-top:.5rem;line-height:1.4}
.rs-note-modal .rs-note-actions{display:flex;gap:10px;margin-top:1.25rem;justify-content:flex-end}
.rs-note-modal .rs-note-btn{border-radius:10px;padding:10px 18px;font-size:12.5px;font-weight:700;cursor:pointer;font-family:'Poppins',sans-serif;transition:opacity .15s,background .15s}
.rs-note-modal .rs-note-btn.cancel{background:none;border:1.5px solid var(--rs-border);color:var(--rs-ink3)}
.rs-note-modal .rs-note-btn.cancel:hover{border-color:var(--rs-ink);color:var(--rs-ink)}
.rs-note-modal .rs-note-btn.save{background:var(--rs-ink);color:#fff;border:none;display:inline-flex;align-items:center;gap:6px}
.rs-note-modal .rs-note-btn.save:hover{opacity:.88}

/* Modale de connexion + setup password */
.login-modal,.setup-pw-modal{max-width:460px;text-align:center}
.login-modal-ico{font-size:34px;line-height:1;margin-bottom:.4rem}
.login-modal-h{font-family:'Outfit',sans-serif;font-size:1.2rem;font-weight:800;color:var(--rs-ink);margin-bottom:.35rem;letter-spacing:-.01em}
.login-modal-sub{font-size:13px;color:var(--rs-ink3);line-height:1.55;margin-bottom:1.25rem}
.login-modal-field{text-align:left;margin-bottom:.85rem}
.login-modal-label{display:block;font-size:11.5px;font-weight:700;color:var(--rs-ink);text-transform:uppercase;letter-spacing:.04em;margin-bottom:5px}
.login-modal-input{width:100%;background:var(--rs-bg-soft);border:1.5px solid var(--rs-border);border-radius:10px;padding:11px 13px;font-size:13.5px;font-family:'Poppins',sans-serif;color:var(--rs-ink);outline:none;transition:border-color .15s,background .15s;box-sizing:border-box}
.login-modal-input:focus{border-color:var(--rs-violet,#7c3aed);background:#fff}
.login-modal-msg{font-size:12.5px;min-height:18px;color:var(--rs-ink3);margin-bottom:.8rem;text-align:left;line-height:1.45}
.login-modal-msg.err{color:#dc2626;font-weight:600}
.login-modal-msg.ok{color:#059669;font-weight:600}
.login-modal-msg.loading{color:var(--rs-violet,#7c3aed);font-weight:600}
.login-modal-actions{display:flex;flex-direction:column;gap:8px;margin-bottom:1rem}
.login-modal-primary{width:100%;background:var(--rs-violet,#7c3aed);color:#fff;border:none;border-radius:10px;padding:12px;font-family:'Outfit',sans-serif;font-size:14px;font-weight:800;cursor:pointer;transition:background .15s}
.login-modal-primary:hover{background:#6d28d9}
.login-modal-ghost{width:100%;background:none;border:1.5px solid var(--rs-border);color:var(--rs-ink3);border-radius:10px;padding:11px;font-family:'Poppins',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:border-color .15s,color .15s}
.login-modal-ghost:hover{border-color:var(--rs-ink);color:var(--rs-ink)}
.login-modal-sep{font-size:11.5px;color:var(--rs-ink4);text-align:center;margin:.75rem 0 .5rem;position:relative}
.login-modal-link{display:block;margin:0 auto;background:none;border:none;color:var(--rs-violet,#7c3aed);font-family:'Poppins',sans-serif;font-size:12.5px;font-weight:600;cursor:pointer;text-decoration:underline;padding:6px 10px}
.login-modal-link:hover{color:#6d28d9}


/* ─── Nuage de questions (modale Google Suggest) ─────────────── */
.qc-modal{max-width:780px;width:92vw;max-height:85vh;overflow-y:auto;padding:1.6rem 1.6rem 1.4rem}
.qc-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:1rem}
.qc-ico{font-size:30px;line-height:1}
.qc-h{font-family:'Outfit',sans-serif;font-size:1.25rem;font-weight:800;color:var(--rs-ink);letter-spacing:-.01em;margin-bottom:3px}
.qc-sub{font-size:12.5px;color:var(--rs-ink3);line-height:1.5}
.qc-form{display:flex;gap:8px;margin-bottom:1.1rem}
.qc-input{flex:1;background:var(--rs-bg-soft);border:1.5px solid var(--rs-border);border-radius:10px;padding:11px 14px;font-size:13.5px;font-family:'Poppins',sans-serif;color:var(--rs-ink);outline:none;transition:border-color .15s,background .15s}
.qc-input:focus{border-color:#7c3aed;background:#fff}
.qc-launch{background:#7c3aed;color:#fff;border:none;border-radius:10px;padding:11px 22px;font-family:'Outfit',sans-serif;font-size:13.5px;font-weight:800;cursor:pointer;transition:background .15s;white-space:nowrap}
.qc-launch:hover{background:#6d28d9}
.qc-launch:disabled{opacity:.6;cursor:wait}
.qc-body{min-height:120px}

/* Spinner utilisé dans seo.js (rafraîchir, suggestions, nuage) */
.seo-spin{display:inline-block;animation:seoSpin 1s linear infinite}
@keyframes seoSpin{to{transform:rotate(360deg)}}

/* ─── Modales ajout mots-clés (local 3 steps / national 1 step) ─ */
.kw-modal{max-width:640px;width:92vw;max-height:85vh;overflow-y:auto;padding:1.8rem 1.8rem 1.5rem}
.kw-modal-step-label{font-size:11px;font-weight:800;color:#7c3aed;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.kw-modal-h{font-family:'Outfit',sans-serif;font-size:1.25rem;font-weight:800;color:var(--rs-ink);letter-spacing:-.01em;margin-bottom:6px}
.kw-modal-sub{font-size:13px;color:var(--rs-ink3);line-height:1.55;margin-bottom:1.1rem}
.kw-modal-sub strong{color:var(--rs-ink)}
.kw-modal-textarea{width:100%;background:var(--rs-bg-soft);border:1.5px solid var(--rs-border);border-radius:10px;padding:12px 14px;font-size:13.5px;font-family:'Poppins',sans-serif;color:var(--rs-ink);outline:none;min-height:140px;resize:vertical;box-sizing:border-box;line-height:1.55;margin-bottom:1rem}
.kw-modal-textarea:focus{border-color:#7c3aed;background:#fff}
.kw-modal-input{width:100%;background:var(--rs-bg-soft);border:1.5px solid var(--rs-border);border-radius:10px;padding:12px 14px;font-size:14px;font-family:'Poppins',sans-serif;color:var(--rs-ink);outline:none;box-sizing:border-box;margin-bottom:1rem}
.kw-modal-input:focus{border-color:#7c3aed;background:#fff}
.kw-modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:.5rem}
.kw-modal-btn-primary{background:#7c3aed;color:#fff;border:none;border-radius:10px;padding:10px 22px;font-family:'Outfit',sans-serif;font-size:13px;font-weight:800;cursor:pointer;transition:background .15s}
.kw-modal-btn-primary:hover:not(:disabled){background:#6d28d9}
.kw-modal-btn-primary:disabled{opacity:.6;cursor:wait}
.kw-modal-btn-ghost{background:#fff;border:1.5px solid var(--rs-border);color:var(--rs-ink3);border-radius:10px;padding:10px 18px;font-family:'Poppins',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}
.kw-modal-btn-ghost:hover{border-color:var(--rs-ink);color:var(--rs-ink)}
.kw-cities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px;margin-bottom:1rem}
.kw-city-card{background:var(--rs-bg-soft);border:1.5px solid var(--rs-border);border-radius:10px;padding:.8rem .9rem;cursor:pointer;transition:all .15s;position:relative}
.kw-city-card:hover:not(.disabled){border-color:#7c3aed;background:#fff}
.kw-city-card.selected{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border-color:#7c3aed;border-width:2px;padding:calc(.8rem - 1px) calc(.9rem - 1px)}
.kw-city-card.disabled{opacity:.4;cursor:not-allowed}
.kw-city-head{display:flex;align-items:flex-start;justify-content:space-between;gap:6px;margin-bottom:4px}
.kw-city-name{font-family:'Outfit',sans-serif;font-size:13.5px;font-weight:800;color:var(--rs-ink);letter-spacing:-.005em}
.kw-city-check{color:#7c3aed;font-weight:800;font-size:15px;line-height:1}
.kw-city-meta{display:flex;gap:10px;font-size:11px;color:var(--rs-ink3);margin-bottom:5px}
.kw-city-reason{font-size:11px;color:#7c3aed;font-weight:700;font-style:italic}
.kw-city-warn{font-size:10.5px;color:#dc2626;margin-top:4px}
.kw-cities-empty{padding:1rem;text-align:center;color:var(--rs-ink3);font-size:12.5px;background:var(--rs-bg-soft);border-radius:10px}

/* Modale analyseur IA d'activité */
.activity-analyzer-modal{max-width:780px;width:92vw;max-height:88vh;overflow-y:auto;padding:1.6rem 1.5rem 1.4rem}
.activity-analyzer-modal .tbx-activity-card{background:#fff;border:none;padding:0;margin:0}
