/* PASS/LAS Quiz Player — BébéProf-style
 * Tokens copied from src/features/quiz-player/components/QuizPlayer/styles.ts:
 *   #007FFF accent, #2ea44f success, #CE1126 error, 2px+4px double border
 */
:root{
  --pp-accent:#007FFF;
  --pp-accent-dark:#0066CC;
  --pp-success:#2ea44f;
  --pp-success-dark:#1a7f37;
  --pp-success-light:#e6f4ea;
  --pp-error:#CE1126;
  --pp-error-dark:#A50E1F;
  --pp-error-light:#FFE8EC;
  --pp-surface:#ffffff;
  --pp-surface-soft:#f1f5f9;
  --pp-border:#e2e8f0;
  --pp-border-strong:#d1d5db;
  --pp-text-primary:#0f172a;
  --pp-text-secondary:#475569;
  --pp-text-muted:#94a3b8;
}

/* ─── Modal root ─────────────────────────────────────────────────────── */
.pp-modal-root{position:fixed;inset:0;background:rgba(10,14,30,.75);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);display:none;align-items:flex-start;justify-content:center;padding:32px 16px;z-index:9999;overflow-y:auto}
.pp-modal-root.open{display:flex}
.pp-modal{position:relative;background:var(--pp-surface);border-radius:24px;max-width:720px;width:100%;box-shadow:0 40px 120px rgba(10,14,30,.4),0 0 0 1px rgba(0,0,0,.04);overflow:hidden;font-family:'Inter',system-ui,sans-serif;color:var(--pp-text-primary);animation:ppModalIn .35s cubic-bezier(.18,.89,.32,1.28)}
@keyframes ppModalIn{from{transform:translateY(30px) scale(.95);opacity:0}to{transform:none;opacity:1}}
.pp-modal-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;border:none;background:var(--pp-surface-soft);color:var(--pp-text-primary);font-size:22px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;transition:all .15s;border:2px solid var(--pp-border)}
.pp-modal-close:hover{background:var(--pp-border);transform:rotate(90deg)}

/* ─── Generating (fake "Amélie generates questions" animation) ──────── */
.pp-generating{padding:60px 40px;text-align:center;animation:ppFade .3s ease}
.pp-generating-orb{position:relative;width:92px;height:92px;margin:0 auto 26px}
.pp-generating-orb img{width:92px;height:92px;border-radius:50%;object-fit:cover;border:3px solid #fff;box-shadow:0 12px 32px rgba(168,85,247,.4);background:linear-gradient(135deg,#a855f7,#ec4899)}
.pp-generating-ring{position:absolute;inset:-8px;border-radius:50%;border:3px solid transparent;border-top-color:#a855f7;border-right-color:#ec4899;animation:ppSpin 1.3s linear infinite}
.pp-generating-text{font-size:17px;font-weight:800;color:#0f172a;margin-bottom:8px;letter-spacing:-.01em;min-height:24px}
.pp-generating-sub{font-size:13px;color:#64748b;line-height:1.5;max-width:380px;margin:0 auto}

/* ─── Loading / error ────────────────────────────────────────────────── */
.pp-loading{padding:80px 40px;text-align:center}
.pp-spinner{width:48px;height:48px;border:3px solid var(--pp-border);border-top-color:var(--pp-accent);border-radius:50%;animation:ppSpin 1s linear infinite;margin:0 auto 20px}
@keyframes ppSpin{to{transform:rotate(360deg)}}
.pp-loading-text{font-size:15px;color:var(--pp-text-secondary);font-weight:500}
.pp-error{padding:60px 40px;text-align:center}
.pp-error-icon{font-size:52px;margin-bottom:18px}
.pp-error-msg{font-size:16px;color:var(--pp-text-primary);margin-bottom:22px}

/* ─── Player header ──────────────────────────────────────────────────── */
.pp-player{padding:28px 32px 28px}
.pp-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 52px 18px 0;border-bottom:1px solid var(--pp-border);margin-bottom:22px}
.pp-subject{display:inline-flex;align-items:center;gap:10px;padding:8px 14px;background:color-mix(in srgb, var(--pp-accent,#007FFF) 10%, transparent);border-radius:999px;font-weight:800;font-size:13px;color:var(--pp-accent,#007FFF);letter-spacing:-.005em;border:2px solid color-mix(in srgb, var(--pp-accent,#007FFF) 22%, transparent);border-bottom-width:3px}
.pp-subject-emoji{font-size:16px;line-height:1}
.pp-progress-wrap{flex:1;max-width:280px;display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.pp-progress-text{font-size:12px;font-weight:800;color:var(--pp-text-secondary);letter-spacing:.02em}
.pp-progress-bar{width:100%;height:8px;background:var(--pp-surface-soft);border-radius:4px;overflow:hidden}
.pp-progress-fill{height:100%;border-radius:4px;transition:width .4s cubic-bezier(.4,0,.2,1);box-shadow:0 0 8px currentColor}

/* ─── Compact image + thumbnail zoom ─────────────────────────────────── */
.pp-image-wrap{display:flex;justify-content:center;margin:0 0 18px}
.pp-img-thumb{position:relative;display:block;padding:0;border:2px solid var(--pp-border);border-bottom-width:4px;border-bottom-color:var(--pp-border-strong);background:var(--pp-surface-soft);border-radius:14px;overflow:hidden;cursor:pointer;max-width:280px;max-height:170px;transition:all .25s ease-out}
.pp-img-thumb:hover{transform:translateY(-2px);border-color:var(--pp-accent);border-bottom-color:var(--pp-accent-dark)}
.pp-img-thumb img{display:block;max-width:100%;max-height:170px;object-fit:contain}
.pp-img-zoom{position:absolute;top:8px;right:8px;width:34px;height:34px;border-radius:10px;background:rgba(15,23,42,.82);color:#fff;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(6px);box-shadow:0 4px 12px rgba(0,0,0,.25);transition:all .2s}
.pp-img-thumb:hover .pp-img-zoom{background:var(--pp-accent);transform:scale(1.08)}

/* ─── Lightbox ───────────────────────────────────────────────────────── */
.pp-lightbox{position:fixed;inset:0;background:rgba(5,8,20,.95);display:none;align-items:center;justify-content:center;padding:32px;z-index:10003;cursor:zoom-out;animation:ppFade .2s ease}
.pp-lightbox.open{display:flex}
.pp-lightbox img{max-width:100%;max-height:100%;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.6)}
.pp-lightbox-close{position:fixed;top:20px;right:20px;width:46px;height:46px;border-radius:50%;border:2px solid rgba(255,255,255,.24);background:rgba(255,255,255,.12);backdrop-filter:blur(8px);color:#fff;font-size:26px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;z-index:10004}
.pp-lightbox-close:hover{background:rgba(255,255,255,.26)}
@keyframes ppFade{from{opacity:0}to{opacity:1}}

/* ─── Question body ──────────────────────────────────────────────────── */
.pp-qbody{font-size:17px;line-height:1.6;color:var(--pp-text-primary);margin-bottom:22px;font-weight:500;letter-spacing:-.005em}
.pp-qbody p{margin:0 0 8px}
.pp-qbody p:last-child{margin-bottom:0}

/* ═══ Options — BébéProf pattern ═══════════════════════════════════════
 * Default : 2px border + 4px border-bottom (darker) + white bg
 * Selected : blue bg rgba(0,127,255,0.06) + blue borders + translateY(-1px)
 * Correct  : green borders + green badge with ✓
 * Wrong    : red borders + red badge with ✗
 * Distractors after check : opacity 0.3 fade
 */
.pp-opts{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:22px;width:100%}
.pp-opt{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:16px;background:var(--pp-surface);border:2px solid var(--pp-border);border-bottom:4px solid var(--pp-border-strong);cursor:pointer;transition:all .25s ease-out;transform:translateY(0);text-align:left;font-family:inherit}
.pp-opt:hover:not(.pp-opt-correct):not(.pp-opt-wrong):not(.pp-opt-neutral){border-color:#cbd5e1;border-bottom-color:#94a3b8;transform:translateY(-1px)}
.pp-opt input{position:absolute;opacity:0;pointer-events:none}
.pp-opt-letter{flex-shrink:0;width:32px;height:32px;border-radius:10px;background:var(--pp-surface-soft);color:var(--pp-text-secondary);border:2px solid var(--pp-border);font-weight:800;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .12s ease-out}
.pp-opt-text{flex:1;font-size:15px;line-height:1.45;color:var(--pp-text-primary);font-weight:500}
.pp-opt-text p{margin:0}

/* Selected (pre-check) */
.pp-opt-selected{background:rgba(0,127,255,.06);border-color:var(--pp-accent)!important;border-bottom-color:var(--pp-accent-dark)!important;transform:translateY(-1px)}
.pp-opt-selected .pp-opt-letter{background:var(--pp-accent);color:#fff;border-color:var(--pp-accent)}

/* Correct answer (post-check) */
.pp-opt-correct{border-color:var(--pp-success)!important;border-bottom-color:var(--pp-success-dark)!important;color:var(--pp-success-dark)}
.pp-opt-correct .pp-opt-letter{background:var(--pp-success);color:#fff;border-color:var(--pp-success)}
.pp-opt-correct .pp-opt-text{color:var(--pp-success-dark)}

/* Wrong selected (post-check) */
.pp-opt-wrong{border-color:var(--pp-error)!important;border-bottom-color:var(--pp-error-dark)!important;color:var(--pp-error-dark)}
.pp-opt-wrong .pp-opt-letter{background:var(--pp-error);color:#fff;border-color:var(--pp-error)}
.pp-opt-wrong .pp-opt-text{color:var(--pp-error-dark)}

/* Unselected distractor after check — fade */
.pp-opt-neutral{opacity:.3}

/* ─── Feedback bar with mascot (BébéProf FeedbackBar style) ─────────── */
.pp-feedback{margin-bottom:22px}
.pp-feedback:empty{display:none}
.pp-verdict{display:flex;align-items:center;gap:18px;padding:18px 24px;border-radius:20px;margin-bottom:14px;animation:ppFadeSlideIn .35s ease-out;position:relative;overflow:hidden}
@keyframes ppFadeSlideIn{from{transform:translateY(-10px);opacity:0}to{transform:none;opacity:1}}
.pp-verdict.ok{background:linear-gradient(135deg,rgba(220,252,231,.95) 0%, rgba(254,249,195,.85) 100%)}
.pp-verdict.ko{background:linear-gradient(135deg,rgba(254,226,226,.95) 0%, rgba(255,237,213,.85) 100%)}
.pp-verdict-mascot{flex-shrink:0;width:80px;height:80px;border-radius:20px;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(15,23,42,.12)}
.pp-verdict.ok .pp-verdict-mascot{background:linear-gradient(135deg,#bae6fd,#e0f2fe)}
.pp-verdict.ko .pp-verdict-mascot{background:linear-gradient(135deg,#fecaca,#fee2e2)}
.pp-verdict-mascot svg{width:56px;height:56px}
.pp-verdict-body{flex:1;min-width:0}
.pp-verdict-title{font-size:18px;font-weight:900;letter-spacing:-.015em;line-height:1.25;margin-bottom:4px}
.pp-verdict.ok .pp-verdict-title{color:var(--pp-success-dark)}
.pp-verdict.ko .pp-verdict-title{color:var(--pp-error-dark)}
.pp-verdict-sub{font-size:13px;font-weight:500;color:var(--pp-text-secondary);line-height:1.45}
.pp-explain{padding:18px 22px;background:var(--pp-surface-soft);border-radius:14px;border:1px solid var(--pp-border);font-size:14px;line-height:1.65;color:var(--pp-text-secondary)}
.pp-explain p{margin:0 0 8px}
.pp-explain p:last-child{margin-bottom:0}
.pp-explain strong{color:var(--pp-text-primary)}

/* ─── Actions (buttons) ──────────────────────────────────────────────── */
.pp-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;align-items:center}
.pp-btn{padding:13px 22px;border-radius:14px;font-size:14px;font-weight:800;cursor:pointer;border:none;transition:all .2s ease-out;font-family:inherit;display:inline-flex;align-items:center;gap:8px;white-space:nowrap;letter-spacing:.01em}
.pp-btn:disabled{opacity:.45;cursor:not-allowed}
.pp-btn-lg{padding:15px 28px;font-size:15px}
.pp-btn-primary{background:linear-gradient(135deg,var(--pp-accent,#007FFF),var(--pp-accent-dark,#0066CC));color:#fff;box-shadow:0 8px 20px rgba(0,127,255,.35),inset 0 -3px 0 rgba(0,0,0,.14)}
.pp-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 28px rgba(0,127,255,.45),inset 0 -3px 0 rgba(0,0,0,.14)}
.pp-btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 4px 12px rgba(0,127,255,.3),inset 0 -1px 0 rgba(0,0,0,.14)}
.pp-btn-ghost{background:var(--pp-surface-soft);color:var(--pp-accent-dark);border:2px solid var(--pp-border);border-bottom-width:3px;padding:12px 18px}
.pp-btn-ghost:hover:not(:disabled){background:rgba(0,127,255,.08);border-color:var(--pp-accent)}
.pp-amelie-mini{width:22px;height:22px;border-radius:50%;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;font-weight:800;font-size:11px;flex-shrink:0}
.pp-amelie-mini img{width:100%;height:100%;object-fit:cover}

/* ─── Bilan ──────────────────────────────────────────────────────────── */
.pp-bilan{padding:32px 36px;max-height:86vh;overflow-y:auto}
.pp-bilan-title{margin:0 0 24px;font-size:24px;font-weight:900;color:var(--pp-text-primary);text-align:center;letter-spacing:-.02em}
.pp-bilan-header{text-align:center;padding:32px;background:linear-gradient(135deg,#f8fafc,var(--pp-surface-soft));border-radius:20px;margin-bottom:24px;border:2px solid var(--pp-border);border-bottom-width:4px;border-bottom-color:var(--pp-border-strong)}
.pp-bilan-score{font-size:52px;font-weight:900;line-height:1;letter-spacing:-.03em}
.pp-bilan-pct{margin-top:12px;font-size:14px;color:var(--pp-text-secondary);font-weight:600}
.pp-bilan-list{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.pp-bilan-item{display:flex;align-items:flex-start;gap:14px;padding:16px 18px;border-radius:16px;background:var(--pp-surface);border:2px solid var(--pp-border);border-bottom-width:4px;border-bottom-color:var(--pp-border-strong)}
.pp-bilan-item.ok{background:var(--pp-success-light);border-color:var(--pp-success);border-bottom-color:var(--pp-success-dark)}
.pp-bilan-item.ko{background:var(--pp-error-light);border-color:var(--pp-error);border-bottom-color:var(--pp-error-dark)}
.pp-bilan-num{font-weight:800;font-size:12px;color:var(--pp-text-secondary);min-width:30px}
.pp-bilan-body{flex:1;font-size:13px;line-height:1.55}
.pp-bilan-q{font-weight:600;color:var(--pp-text-primary);margin-bottom:6px}
.pp-bilan-exp{color:var(--pp-text-secondary);font-size:12px}
.pp-bilan-flag{font-size:22px;font-weight:800;line-height:1}
.pp-bilan-item.ok .pp-bilan-flag{color:var(--pp-success-dark)}
.pp-bilan-item.ko .pp-bilan-flag{color:var(--pp-error-dark)}

/* ─── Picker (cities / subjects) ─────────────────────────────────────── */
.pp-picker{padding:32px 36px}
.pp-picker-head{margin-bottom:22px}
.pp-picker-head h2{margin:8px 0 6px;font-size:22px;font-weight:900;color:var(--pp-text-primary);letter-spacing:-.02em}
.pp-picker-head p{margin:0;font-size:14px;color:var(--pp-text-secondary)}
.pp-back{background:none;border:none;color:var(--pp-accent-dark);font-size:13px;font-weight:700;cursor:pointer;padding:0 0 6px}
.pp-back:hover{text-decoration:underline}
.pp-pick-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.pp-pick-card{padding:20px 18px;border-radius:16px;background:var(--pp-surface);border:2px solid var(--pp-border);border-bottom:4px solid var(--pp-border-strong);text-align:left;cursor:pointer;transition:all .25s ease-out;font-family:inherit;display:flex;flex-direction:column;gap:6px;transform:translateY(0)}
.pp-pick-card:hover{border-color:var(--pp-accent,#007FFF);border-bottom-color:var(--pp-accent-dark,#0066CC);transform:translateY(-2px)}
.pp-pick-emoji{font-size:30px;line-height:1;margin-bottom:4px}
.pp-pick-label{font-size:15px;font-weight:800;color:var(--pp-text-primary);letter-spacing:-.01em}
.pp-pick-meta{font-size:12px;color:var(--pp-text-secondary);font-weight:500}
.pp-pick-empty{grid-column:1/-1;padding:30px 20px;text-align:center;color:var(--pp-text-secondary);font-size:14px}
.pp-picker-note{margin-top:22px;font-size:12px;color:var(--pp-text-muted);text-align:center;font-style:italic}

/* ─── Quiz grid (JS-rendered on city pages) ─────────────────────────── */
.pp-quiz-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;max-width:980px;margin:0 auto;padding:0 16px}
.pp-quiz-card{padding:22px 20px;border-radius:18px;background:var(--pp-surface);border:2px solid var(--pp-border);border-bottom:4px solid var(--pp-border-strong);text-align:left;cursor:pointer;transition:all .2s ease-out;font-family:inherit;display:flex;flex-direction:column;gap:8px;min-height:180px;position:relative;overflow:hidden}
.pp-quiz-card:hover{border-color:var(--pp-accent,#007FFF);border-bottom-color:color-mix(in srgb, var(--pp-accent,#007FFF) 85%, #000);transform:translateY(-3px);box-shadow:0 18px 40px rgba(15,23,42,.08)}
.pp-quiz-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--pp-accent,#007FFF);opacity:.7}
.pp-quiz-emoji{font-size:30px;line-height:1;margin-bottom:4px}
.pp-quiz-label{font-size:16px;font-weight:900;color:var(--pp-text-primary);letter-spacing:-.015em}
.pp-quiz-desc{font-size:13px;color:var(--pp-text-secondary);line-height:1.45;flex:1;font-weight:500}
.pp-quiz-foot{display:flex;justify-content:space-between;align-items:center;margin-top:4px;padding-top:10px;border-top:1px solid var(--pp-border)}
.pp-quiz-stat{font-size:12px;font-weight:800;color:var(--pp-text-secondary);text-transform:uppercase;letter-spacing:.03em}
.pp-quiz-cta{font-size:13px;font-weight:800;color:var(--pp-accent,#007FFF)}
@media (max-width:640px){
  .pp-quiz-grid{grid-template-columns:1fr 1fr;gap:10px;padding:0 8px}
  .pp-quiz-card{padding:14px 12px;min-height:140px;border-radius:14px}
  .pp-quiz-emoji{font-size:24px}
  .pp-quiz-label{font-size:14px}
  .pp-quiz-desc{font-size:11px}
  .pp-quiz-stat,.pp-quiz-cta{font-size:11px}
}

/* Session size selector pills */
.pp-size-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:0 0 18px;padding:12px 14px;background:var(--pp-surface-soft);border-radius:14px;border:1px solid var(--pp-border)}
.pp-size-label{font-size:12px;font-weight:700;color:var(--pp-text-secondary);margin-right:4px}
.pp-size-pill{padding:7px 16px;border-radius:10px;border:2px solid var(--pp-border);border-bottom-width:3px;background:#fff;color:var(--pp-text-secondary);font-size:13px;font-weight:800;cursor:pointer;font-family:inherit;transition:all .18s}
.pp-size-pill:hover{border-color:#cbd5e1;transform:translateY(-1px)}
.pp-size-pill.active{background:var(--pp-accent);color:#fff;border-color:var(--pp-accent);border-bottom-color:var(--pp-accent-dark);box-shadow:0 6px 14px rgba(0,127,255,.28)}

/* ═══ Floating Amélie ═══════════════════════════════════════════════ */
.pp-amelie-root{position:fixed;right:24px;bottom:24px;z-index:10002;display:none;pointer-events:none;font-family:'Inter',system-ui,sans-serif}
.pp-amelie-root.open{display:flex;flex-direction:column;align-items:flex-end;gap:12px;pointer-events:auto}
.pp-amelie-root.collapsed .pp-amelie-speech{display:none}

.pp-amelie-head{position:relative;width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#a855f7,#ec4899);padding:3px;cursor:pointer;box-shadow:0 16px 40px rgba(168,85,247,.45),0 0 0 2px rgba(255,255,255,.5);transition:transform .25s cubic-bezier(.18,.89,.32,1.28);animation:ppAmelieIn .5s cubic-bezier(.18,.89,.32,1.28)}
.pp-amelie-head:hover{transform:scale(1.08)}
.pp-amelie-head img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block;background:#fff}
.pp-amelie-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%;border-radius:50%;background:#fff;color:#a855f7;font-weight:900;font-size:28px}
@keyframes ppAmelieIn{from{transform:translateY(80px) scale(.3);opacity:0}to{transform:none;opacity:1}}

.pp-amelie-pulse{position:absolute;inset:-6px;border-radius:50%;border:2px solid #a855f7;opacity:0;pointer-events:none}
.pp-amelie-head.thinking .pp-amelie-pulse{animation:ppPulse 1.6s ease-out infinite}
@keyframes ppPulse{0%{transform:scale(.85);opacity:.8}100%{transform:scale(1.45);opacity:0}}

.pp-amelie-speech{background:#fff;border-radius:22px 22px 6px 22px;width:380px;max-width:calc(100vw - 48px);max-height:min(560px, calc(100vh - 140px));box-shadow:0 30px 80px rgba(10,14,30,.3),0 0 0 1px var(--pp-border);display:flex;flex-direction:column;overflow:hidden;animation:ppBubbleIn .35s cubic-bezier(.18,.89,.32,1.28)}
@keyframes ppBubbleIn{from{transform:translateY(20px) scale(.92);opacity:0}to{transform:none;opacity:1}}

.pp-amelie-head-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 18px;background:linear-gradient(135deg,#a855f7,#7c3aed);color:#fff;flex-shrink:0}
.pp-amelie-name{display:flex;flex-direction:column;gap:1px;line-height:1.2}
.pp-amelie-name strong{font-size:15px;font-weight:800;letter-spacing:-.01em}
.pp-amelie-tag{font-size:11px;opacity:.9;display:flex;align-items:center;gap:5px}
.pp-amelie-tag::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:#4ade80;box-shadow:0 0 0 2px rgba(74,222,128,.35)}
.pp-amelie-close{width:30px;height:30px;border-radius:50%;border:none;background:rgba(255,255,255,.18);color:#fff;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}
.pp-amelie-close:hover{background:rgba(255,255,255,.3)}

.pp-amelie-msgs{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px;background:var(--pp-surface-soft)}
.pp-amelie-msgs::-webkit-scrollbar{width:6px}
.pp-amelie-msgs::-webkit-scrollbar-thumb{background:rgba(15,23,42,.14);border-radius:3px}

.pp-amsg{padding:12px 16px;border-radius:18px;font-size:14px;line-height:1.6;max-width:88%;word-wrap:break-word;overflow-wrap:break-word}
.pp-amsg p{margin:0 0 6px}
.pp-amsg p:last-child{margin-bottom:0}
.pp-amsg code{background:rgba(15,23,42,.08);padding:1px 5px;border-radius:4px;font-size:12px}
.pp-amsg pre{background:rgba(15,23,42,.06);padding:10px 12px;border-radius:10px;overflow-x:auto;font-size:12px;margin:6px 0}
.pp-amsg table{font-size:12px;border-collapse:collapse;margin:6px 0;width:100%}
.pp-amsg th,.pp-amsg td{border:1px solid rgba(15,23,42,.1);padding:4px 8px;text-align:left}
.pp-amsg-assistant{align-self:flex-start;background:#fff;color:var(--pp-text-primary);border:1px solid var(--pp-border);border-bottom-left-radius:5px;box-shadow:0 2px 10px rgba(15,23,42,.04)}
/* Markdown links inside Amélie messages render as chunky action buttons.
   The welcome agent uses them to redirect to /tutorat, /pass-las/<ville>, etc. */
.pp-amsg-assistant a{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;margin:4px 4px 4px 0;background:linear-gradient(135deg,#a855f7,#7c3aed);color:#fff!important;text-decoration:none;border-radius:10px;font-size:13px;font-weight:700;border:1px solid transparent;border-bottom:2px solid rgba(0,0,0,.18);transition:all .15s}
.pp-amsg-assistant a:hover{transform:translateY(-1px);text-decoration:none;box-shadow:0 6px 16px rgba(168,85,247,.35)}
.pp-amsg-user{align-self:flex-end;background:linear-gradient(135deg,#a855f7,#7c3aed);color:#fff;border-bottom-right-radius:5px}
.pp-amsg.pending{min-width:58px}
.pp-dots{display:inline-flex;gap:4px;align-items:center;padding:2px 0}
.pp-dots span{width:6px;height:6px;border-radius:50%;background:var(--pp-text-muted);animation:ppDot 1.2s infinite ease-in-out}
.pp-dots span:nth-child(2){animation-delay:.2s}
.pp-dots span:nth-child(3){animation-delay:.4s}
@keyframes ppDot{0%,80%,100%{transform:scale(.55);opacity:.5}40%{transform:scale(1);opacity:1}}

.pp-amelie-form{display:flex;align-items:flex-end;gap:8px;padding:12px 14px;border-top:1px solid var(--pp-border);background:#fff;flex-shrink:0}
.pp-amelie-input{flex:1;resize:none;border:2px solid var(--pp-border);border-radius:14px;padding:10px 14px;font-size:16px;font-family:inherit;line-height:1.4;max-height:120px;outline:none;transition:border-color .15s;background:var(--pp-surface-soft);color:var(--pp-text-primary);-webkit-appearance:none}
.pp-amelie-input:focus{border-color:#a855f7;background:#fff}
.pp-amelie-send{width:38px;height:38px;border-radius:50%;border:none;background:linear-gradient(135deg,#a855f7,#7c3aed);color:#fff;cursor:pointer;flex-shrink:0;box-shadow:0 6px 16px rgba(168,85,247,.3);transition:all .15s;display:flex;align-items:center;justify-content:center}
.pp-amelie-send:hover{transform:translateY(-1px) rotate(-10deg)}

/* ═══ Persistent launcher orb (bottom-right, opens welcome Amélie) ═══ */
.pp-amelie-launcher{position:fixed;right:20px;bottom:20px;z-index:9995;width:64px;height:64px;border-radius:50%;border:none;padding:3px;background:linear-gradient(135deg,#a855f7,#ec4899);cursor:pointer;box-shadow:0 12px 32px rgba(168,85,247,.4),0 0 0 2px rgba(255,255,255,.5);transition:all .25s cubic-bezier(.18,.89,.32,1.28);animation:ppLauncherIn .6s cubic-bezier(.18,.89,.32,1.28) .4s both;font-family:'Inter',system-ui,sans-serif}
.pp-amelie-launcher:hover{transform:scale(1.08) translateY(-2px);box-shadow:0 18px 38px rgba(168,85,247,.5)}
.pp-amelie-launcher img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block;background:#fff}
.pp-amelie-launcher-fallback{position:absolute;inset:3px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#fff;color:#a855f7;font-weight:900;font-size:24px}
.pp-amelie-launcher::after{content:"";position:absolute;top:-3px;right:-3px;width:14px;height:14px;border-radius:50%;background:#4ade80;border:3px solid #fff;box-shadow:0 0 0 2px rgba(74,222,128,.3)}
.pp-amelie-launcher-bubble{position:absolute;right:76px;bottom:12px;background:#fff;color:#0f172a;padding:10px 14px;border-radius:16px 16px 4px 16px;font-size:13px;font-weight:700;white-space:nowrap;box-shadow:0 12px 30px rgba(15,23,42,.18),0 0 0 1px rgba(168,85,247,.18);animation:ppLauncherBubbleIn .6s cubic-bezier(.18,.89,.32,1.28) 1s both;pointer-events:none}
.pp-amelie-launcher.settled .pp-amelie-launcher-bubble{opacity:0;transform:translateX(10px);transition:opacity .4s,transform .4s}
.pp-amelie-launcher:hover .pp-amelie-launcher-bubble{opacity:1;transform:none;transition:opacity .2s,transform .2s}
@keyframes ppLauncherIn{from{transform:translateY(80px) scale(.3);opacity:0}to{transform:none;opacity:1}}
@keyframes ppLauncherBubbleIn{from{transform:translateX(10px);opacity:0}to{transform:none;opacity:1}}
/* Hide the launcher when a chat is open (pp-amelie-root.open) to avoid overlap */
body:has(.pp-amelie-root.open) .pp-amelie-launcher{opacity:0;pointer-events:none;transform:scale(.5)}
body.pp-chat-open .pp-amelie-launcher{opacity:0;pointer-events:none;transform:scale(.5)}
/* On mobile when the chat is open, body scroll is locked so the iOS keyboard
   doesn't push the whole page up and hide the input. */
@media (max-width:640px){
  body.pp-chat-open{overflow:hidden;position:fixed;inset:0;width:100%}
}

/* ─── Responsive ─────────────────────────────────────────────────────── */
@media (max-width:640px){
  .pp-amelie-launcher{width:58px;height:58px;right:14px;bottom:14px}
  .pp-amelie-launcher-bubble{display:none}
  .pp-modal-root{padding:16px 8px}
  .pp-modal{border-radius:20px}
  .pp-player{padding:22px 18px 18px}
  .pp-bilan{padding:22px 18px}
  .pp-picker{padding:22px 18px}
  .pp-header{flex-direction:column;align-items:stretch;gap:12px}
  .pp-progress-wrap{max-width:none;align-items:stretch}
  .pp-progress-text{text-align:right}
  .pp-qbody{font-size:16px}
  .pp-opt{padding:12px 14px;gap:10px}
  .pp-opt-letter{width:30px;height:30px;font-size:13px;border-radius:9px}
  .pp-opt-text{font-size:14px}
  .pp-img-thumb{max-width:240px;max-height:140px}
  .pp-img-thumb img{max-height:140px}
  .pp-actions .pp-btn{flex:1;min-width:140px;justify-content:center}
  .pp-pick-grid{grid-template-columns:1fr 1fr}
  .pp-pick-card{padding:16px 14px}
  .pp-pick-label{font-size:14px}
  .pp-bilan-score{font-size:42px}
  /* Mobile : the chat goes full-screen when opened so the keyboard can't
     break the layout. We use 100dvh (dynamic viewport, iOS 15.4+) with a
     fallback to 100vh, and fixed-positioning to keep it locked regardless
     of body scroll. The floating head is hidden while the chat is open. */
  .pp-amelie-root{right:12px;left:12px;bottom:12px;align-items:stretch}
  .pp-amelie-root.open{position:fixed;inset:0;right:0;left:0;top:0;bottom:0;width:100%;height:100vh;height:100dvh;flex-direction:column;pointer-events:auto}
  .pp-amelie-root.open .pp-amelie-head{display:none}
  .pp-amelie-speech{width:100%;max-width:none;height:100vh;height:100dvh;max-height:none;border-radius:0;box-shadow:none}
}
