/* ═══════════════════════════════════════════
   KINEPLAN v5.0 — MODERN DESIGN SYSTEM
   Inspired by 2026 SaaS trends & Stitch render
   ═══════════════════════════════════════════ */
:root {
  --bg:#F0EDE8;--surface:#FFFFFF;--surface2:#E8E5E0;--border:rgba(0,0,0,.08);
  --text:#1A1A1A;--muted:#8A8680;
  --accent:#2E6B56;--accent-l:#EAF4EF;--accent-d:#1f5040;--accent-glow:rgba(46,107,86,.15);
  --orange:#D4723C;--orange-l:#FDF2EA;
  --red:#D94444;--red-l:#FDF0F0;
  --gold:#B8922B;--gold-l:#FDF8EC;
  --r:16px;--r-sm:10px;--r-lg:20px;
  --sh:0 1px 3px rgba(0,0,0,.04),0 4px 16px rgba(0,0,0,.06);
  --sh-lg:0 8px 40px rgba(0,0,0,.12);
  --sh-card:0 1px 2px rgba(0,0,0,.03),0 4px 20px rgba(0,0,0,.05);
  --sb-w:272px;
  --transition:all .2s cubic-bezier(.4,0,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter','Segoe UI',sans-serif;background:var(--bg);color:var(--text);height:100vh;overflow:hidden;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
#app{display:flex;height:100vh}
button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:inherit}

/* ── SIDEBAR ─────────────────────── */
#sb{width:var(--sb-w);background:#1B1F1E;display:flex;flex-direction:column;flex-shrink:0;border-right:1px solid rgba(255,255,255,.04)}
#sb-top{padding:28px 20px 20px;flex-shrink:0}
.logo{font-family:'Fraunces',serif;font-size:24px;font-weight:600;color:#fff;letter-spacing:-.5px;display:flex;align-items:center;gap:0}
.logo em{color:#4ADE80;font-style:italic;font-weight:700}
.logo-ver{font-size:9px;color:rgba(255,255,255,.2);margin-left:6px;font-family:'Inter',sans-serif;font-weight:500;background:rgba(255,255,255,.06);padding:2px 6px;border-radius:4px}
.logo-sub{font-size:10px;color:rgba(255,255,255,.25);text-transform:uppercase;letter-spacing:1.2px;margin-top:4px;font-weight:500}
#sb-search{padding:12px 14px 6px;flex-shrink:0}
#sb-search input{width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);border-radius:var(--r-sm);color:#fff;padding:10px 12px 10px 36px;font-size:13px;outline:none;transition:var(--transition);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='rgba(255,255,255,0.3)' stroke-width='2' stroke-linecap='round'%3E%3Ccircle cx='7' cy='7' r='5'/%3E%3Cpath d='M11 11l3 3'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:12px center}
#sb-search input::placeholder{color:rgba(255,255,255,.25)}
#sb-search input:focus{border-color:var(--accent);background:rgba(255,255,255,.1)}
#sb-list{flex:1;overflow-y:auto;padding:6px 10px;min-height:0;border-top:1px solid rgba(255,255,255,.04);margin-top:6px}
#sb-list::-webkit-scrollbar{width:2px}
#sb-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:2px}
.pt-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-sm);cursor:pointer;transition:var(--transition);margin-bottom:2px;user-select:none;border:1px solid transparent}
.pt-item:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.04)}
.pt-item.on{background:rgba(46,107,86,.3);border-color:rgba(74,222,128,.2);box-shadow:0 0 0 1px rgba(74,222,128,.08)}
.pt-av{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-size:11.5px;font-weight:700;color:rgba(255,255,255,.7);flex-shrink:0;font-family:'Inter',sans-serif;letter-spacing:.5px}
.pt-item.on .pt-av{background:var(--accent);color:#fff}
.pt-inf{overflow:hidden;flex:1;min-width:0}
.pt-name{font-size:12.5px;font-weight:500;color:rgba(255,255,255,.85);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pt-sub{font-size:10.5px;color:rgba(255,255,255,.35);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pt-dot{width:7px;height:7px;background:var(--orange);border-radius:50%;flex-shrink:0}
#sb-bottom{padding:12px 14px 16px;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0;display:flex;flex-direction:column;gap:6px}
.sb-btn{background:var(--accent);color:#fff;border:none;border-radius:var(--r-sm);padding:11px;font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:7px;transition:var(--transition);width:100%}
.sb-btn:hover{background:var(--accent-d);transform:translateY(-1px);box-shadow:0 4px 12px rgba(46,107,86,.3)}
.sb-btn-ghost{background:transparent;color:rgba(255,255,255,.45);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-sm);padding:9px;font-size:12px;display:flex;align-items:center;justify-content:center;gap:6px;transition:var(--transition);width:100%}
.sb-btn-ghost:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.7)}

/* ── MAIN ────────────────────────── */
#main{flex:1;overflow:hidden;display:flex;flex-direction:column;min-width:0}
#empty{flex:1;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:16px;color:var(--muted)}
#empty svg{opacity:.1}
#empty h2{font-family:'Fraunces',serif;font-size:34px;opacity:.18;font-weight:300;letter-spacing:-.5px}
#empty p{font-size:14px;opacity:.35}

/* ── PATIENT HEADER ──────────────── */
#pv{display:none;flex-direction:column;flex:1;overflow:hidden}
#ph{background:#fff;border-bottom:1px solid var(--border);padding:22px 32px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;gap:16px}
#ph-l{display:flex;align-items:center;gap:16px;min-width:0}
#ph-av{width:48px;height:48px;border-radius:12px;color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Inter',sans-serif;font-size:16px;font-weight:700;flex-shrink:0;letter-spacing:.5px;box-shadow:0 2px 8px rgba(0,0,0,.12)}
#ph-name{font-family:'Fraunces',serif;font-size:28px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.4px}
#ph-meta{font-size:12px;color:var(--muted);margin-top:5px;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
#ph-meta span{padding:4px 12px;background:var(--surface2);border-radius:20px;font-weight:500;font-size:11px;transition:var(--transition)}
#ph-meta span:hover{background:var(--border)}
.ph-actions{display:flex;gap:4px;flex-shrink:0}
.ph-actions .btn{border-radius:50%;width:38px;height:38px;padding:0;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.ph-actions .btn:hover{transform:scale(1.08)}

/* ── TABS ────────────────────────── */
#tabs{background:#fff;border-bottom:1px solid var(--border);padding:0 32px;display:flex;gap:0;flex-shrink:0;overflow-x:auto}
#tabs::-webkit-scrollbar{height:0}
.tb{padding:14px 20px;border:none;background:none;font-size:11.5px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-1px;transition:var(--transition);display:flex;align-items:center;gap:6px;white-space:nowrap;flex-shrink:0;text-transform:uppercase;letter-spacing:.8px;border-radius:0}
.tb:hover{color:var(--text);background:rgba(0,0,0,.02)}
.tb.on{color:var(--accent);border-bottom-color:var(--accent);background:transparent}
.tb-badge{background:var(--orange);color:#fff;font-size:9px;font-weight:700;padding:2px 7px;border-radius:20px;min-width:18px;text-align:center;margin-left:2px}

/* ── CONTENT ─────────────────────── */
#content{flex:1;overflow-y:auto;padding:30px 36px}
#content::-webkit-scrollbar{width:3px}
#content::-webkit-scrollbar-thumb{background:rgba(0,0,0,.06);border-radius:4px}
#content::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.12)}
.tab-p{display:none}
.tab-p.on{display:block}

/* ── LAYOUT ──────────────────────── */
.pg-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:12px;flex-wrap:wrap}
.pg-title h2{font-family:'Fraunces',serif;font-size:22px;font-weight:600;letter-spacing:-.2px}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--r);margin-bottom:18px;overflow:hidden;box-shadow:var(--sh-card);transition:var(--transition)}
.card:hover{box-shadow:var(--sh)}
.card-hd{padding:16px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:rgba(0,0,0,.015)}
.card-hd-title{font-family:'Fraunces',serif;font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px;letter-spacing:-.1px}
.card-bd{padding:24px}
.brow{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}
hr{border:none;border-top:1px solid var(--border);margin:18px 0}

/* ── FORMS ────────────────────────── */
.fg{display:flex;flex-direction:column;gap:6px}
.fg{position:relative}
.mic-btn{position:absolute;bottom:8px;right:8px;width:30px;height:30px;border-radius:50%;border:1px solid var(--border);background:#fff;color:var(--muted);display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;transition:var(--transition);z-index:2}
.mic-btn:hover{background:var(--accent-l);color:var(--accent);border-color:var(--accent)}
.mic-btn.on{background:var(--red);color:#fff;border-color:var(--red);animation:mic-pulse 1.2s infinite}
.day-picker{display:flex;gap:6px;flex-wrap:wrap}
.day-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:#fff;color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:var(--transition)}
.day-btn:hover{border-color:var(--accent)}
.day-btn.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.proto-cat{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);margin:18px 0 8px}
.proto-cat:first-child{margin-top:0}
.proto-row{border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 14px;margin-bottom:8px;cursor:pointer;transition:var(--transition)}
.proto-row:hover{border-color:var(--accent);background:var(--accent-l)}
.proto-row-title{font-weight:600;font-size:13.5px;margin-bottom:4px}
.proto-row-meta{font-size:11.5px;color:var(--muted)}
.ai-textarea{width:100%;min-height:110px;border:1px solid var(--border);border-radius:var(--r-sm);padding:12px;font-family:inherit;font-size:13.5px;resize:vertical}
.ai-loading{text-align:center;padding:32px 16px;color:var(--muted);font-size:13.5px}
.ai-spinner-big{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 0.8s linear infinite;margin:0 auto 14px}
@keyframes spin{to{transform:rotate(360deg)}}
.ai-preview-seance{border:1px solid var(--border);border-radius:var(--r-sm);padding:10px 12px;margin-bottom:8px;font-size:13px}
.ai-preview-seance b{font-size:12px;color:var(--accent)}
@keyframes mic-pulse{0%,100%{box-shadow:0 0 0 0 rgba(217,68,68,.5)}50%{box-shadow:0 0 0 8px rgba(217,68,68,0)}}
.fg label{font-size:10.5px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.8px}
input[type="text"],input[type="number"],input[type="date"],input:not([type]),select,textarea{
  border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 14px;font-size:13.5px;color:var(--text);
  background:#FAFAF8;outline:none;transition:var(--transition);width:100%}
input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);background:#fff}
textarea{resize:vertical;min-height:76px;line-height:1.65}
.grid{display:grid;gap:16px}
.g2{grid-template-columns:1fr 1fr}.g3{grid-template-columns:1fr 1fr 1fr}.g1{grid-template-columns:1fr}
.s2{grid-column:span 2}.s3{grid-column:span 3}
.field-err{font-size:12px;color:var(--red);margin-top:3px}

/* ── BUTTONS ─────────────────────── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--r-sm);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:var(--transition);white-space:nowrap}
.btn-p{background:var(--accent);color:#fff}.btn-p:hover{background:var(--accent-d);transform:translateY(-1px);box-shadow:0 4px 12px rgba(46,107,86,.25)}
.btn-s{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-s:hover{background:var(--surface2)}
.btn-o{background:var(--orange);color:#fff}.btn-o:hover{opacity:.9;transform:translateY(-1px)}
.btn-d{background:var(--red-l);color:var(--red);border:1px solid rgba(217,68,68,.15)}.btn-d:hover{background:#fde0e0}
.btn-g{background:var(--gold-l);color:var(--gold);border:1px solid rgba(184,146,43,.15)}.btn-g:hover{background:#f8ecc0}
.btn-sm{padding:7px 13px;font-size:12px}.btn-xs{padding:4px 9px;font-size:11px}

/* ── BADGES ──────────────────────── */
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}
.badge-ok{background:var(--accent-l);color:var(--accent)}
.badge-mid{background:var(--gold-l);color:var(--gold)}
.badge-bad{background:var(--red-l);color:var(--red)}
.badge-gray{background:var(--surface2);color:var(--muted)}
.cycle-sb{font-size:10px;font-weight:700;padding:4px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}
.s-encours{background:var(--accent-l);color:var(--accent)}
.s-termine{background:var(--surface2);color:var(--muted)}
.s-avenir{background:var(--gold-l);color:var(--gold)}
.tag{font-size:10px;font-weight:700;padding:3px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.3px}
.tag-s{background:var(--accent-l);color:var(--accent)}
.tag-e{background:var(--orange-l);color:var(--orange)}

/* ── PAIN / RPE ──────────────────── */
.pain-scale{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:4px}
.pb{width:36px;height:36px;border:2px solid var(--border);border-radius:var(--r-sm);background:#FAFAF8;font-size:12px;font-weight:700;transition:var(--transition);display:flex;align-items:center;justify-content:center;padding:0}
.pb:hover{border-color:var(--accent);transform:scale(1.05)}
.pb.on{background:var(--accent);border-color:var(--accent);color:#fff;transform:scale(1.08);box-shadow:0 2px 8px var(--accent-glow)}
.pb[data-v="7"].on,.pb[data-v="8"].on,.pb[data-v="9"].on,.pb[data-v="10"].on{background:var(--red);border-color:var(--red);box-shadow:0 2px 8px rgba(217,68,68,.25)}
.rpe-bar{display:flex;gap:3px;flex-wrap:wrap}
.rpe-btn{width:28px;height:28px;border:1.5px solid var(--border);border-radius:6px;background:#FAFAF8;font-size:10px;font-weight:700;transition:var(--transition);display:flex;align-items:center;justify-content:center;padding:0}
.rpe-btn:hover{border-color:var(--accent);transform:scale(1.05)}
.rpe-btn.on{background:var(--accent);border-color:var(--accent);color:#fff}
.rpe-btn[data-r="8"].on,.rpe-btn[data-r="9"].on,.rpe-btn[data-r="10"].on{background:var(--red);border-color:var(--red)}

/* ── PROGRESS ────────────────────── */
.prog-wrap{margin-bottom:14px}
.prog-lbl{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-bottom:6px;font-weight:500}
.prog-track{height:5px;background:var(--surface2);border-radius:3px;overflow:hidden}
.prog-fill{height:100%;border-radius:3px;transition:width .5s cubic-bezier(.4,0,.2,1)}

/* ── DASHBOARD — BENTO GRID ─────── */
.dash-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
.dc{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:22px 24px;box-shadow:var(--sh-card);transition:var(--transition);position:relative;overflow:hidden}
.dc:hover{box-shadow:var(--sh);transform:translateY(-1px)}
.dc-span2{grid-column:span 2}
.dc-span3{grid-column:span 3}
.dc-lbl{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px}
.dc-val{font-family:'Fraunces',serif;font-size:42px;font-weight:600;color:var(--text);line-height:1;letter-spacing:-1px}
.dc-val.g{color:var(--accent)}.dc-val.o{color:var(--orange)}
.dc-sub{font-size:12px;color:var(--muted);margin-top:6px;font-weight:500}
/* Carte sombre (style notes cliniques) */
.dc-dark{background:#1B1F1E;color:#fff;border-color:transparent}
.dc-dark .dc-lbl{color:rgba(255,255,255,.4)}
.dc-dark .dc-val{color:#fff}
.dc-dark .dc-sub{color:rgba(255,255,255,.5)}
/* Cercle de progression */
.dc-ring{width:100px;height:100px;margin:8px auto 6px}
.dc-ring-text{font-family:'Fraunces',serif;font-size:28px;font-weight:700}

/* ── CYCLES ──────────────────────── */
.cycle-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);margin-bottom:20px;overflow:hidden;box-shadow:var(--sh-card)}
.cycle-hd{padding:18px 24px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);gap:12px}
.cc-title{font-family:'Fraunces',serif;font-size:17px;font-weight:600;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.cc-meta{font-size:12px;color:var(--muted);display:flex;gap:14px;margin-top:4px;flex-wrap:wrap}
.cycle-bd{padding:20px 24px}

/* ── SEANCE ITEMS ────────────────── */
.seance-item{display:flex;align-items:center;gap:12px;padding:11px 16px;background:#FAFAF8;border:1px solid var(--border);border-radius:var(--r);transition:var(--transition);cursor:pointer;margin-bottom:6px;user-select:none}
.seance-item:hover{border-color:var(--accent);background:#fff;box-shadow:var(--sh);transform:translateY(-1px)}
.seance-item.done{opacity:.65}
.seance-item.eval-due{border-color:var(--orange);background:var(--orange-l)}
.seance-item.today-s{border-color:var(--accent);background:var(--accent-l)}
.sn{width:28px;height:28px;border-radius:50%;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--muted);flex-shrink:0}
.seance-item.done .sn{background:var(--accent);color:#fff}
.seance-item.today-s .sn{background:var(--accent);color:#fff}
.s-date{font-size:12px;color:var(--muted);min-width:88px;flex-shrink:0;font-weight:500}
.s-label{flex:1;font-size:13px;font-weight:500;min-width:0}
.s-note-prev{font-size:11.5px;color:var(--muted);font-style:italic;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;max-width:180px}
.s-badges{display:flex;gap:5px;align-items:center;flex-shrink:0;flex-wrap:wrap}

/* ── CALENDAR ────────────────────── */
.cal-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:10px;flex-wrap:wrap}
#cal-title{font-family:'Fraunces',serif;font-size:20px;font-weight:600;letter-spacing:-.2px}
.view-toggle{display:flex;background:var(--surface2);border-radius:var(--r-sm);padding:3px;gap:2px}
.vt-btn{padding:7px 16px;border:none;background:none;border-radius:8px;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;transition:var(--transition)}
.vt-btn.on{background:#fff;color:var(--accent);box-shadow:var(--sh)}
.cal-nav{display:flex;gap:4px}
.cal-nav-btn{width:34px;height:34px;border:1px solid var(--border);background:#fff;border-radius:var(--r-sm);font-size:16px;display:flex;align-items:center;justify-content:center;color:var(--text);transition:var(--transition)}
.cal-nav-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.cal-dow-row{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px}
.cal-dow-cell{text-align:center;font-size:10px;font-weight:700;color:var(--muted);padding:6px 0;text-transform:uppercase;letter-spacing:.6px}
.cal-grid-m{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-day{min-height:88px;background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:8px;transition:var(--transition);box-shadow:var(--sh-card)}
.cal-day:hover{border-color:var(--accent)}
.cal-day.other-m{background:var(--bg);opacity:.35;box-shadow:none}
.cal-day.today-c{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
.cal-day-num{font-size:11px;font-weight:700;color:var(--muted);margin-bottom:4px}
.cal-day.today-c .cal-day-num{color:var(--accent)}
.cal-ev{border-radius:5px;padding:2px 6px;font-size:10px;font-weight:600;margin-bottom:2px;cursor:pointer;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;transition:var(--transition)}
.cal-ev:hover{opacity:.75;transform:scale(1.02)}
.wk-grid{display:grid;grid-template-columns:50px repeat(7,1fr);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-card)}
.wk-hd{background:var(--surface);border-bottom:1px solid var(--border);padding:10px 6px;text-align:center;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.wk-hd.today-wh{color:var(--accent);background:var(--accent-l)}
.wk-slot-lbl{background:var(--surface);border-right:1px solid var(--border);padding:6px 5px;text-align:right;font-size:10px;color:var(--muted);min-height:56px;display:flex;align-items:flex-start;justify-content:flex-end}
.wk-cell{border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:4px;min-height:56px}
.wk-cell:last-child{border-right:none}
.wk-ev{border-radius:6px;padding:4px 7px;font-size:11px;cursor:pointer;margin-bottom:2px;transition:var(--transition)}
.wk-ev:hover{opacity:.8}

/* ── EVALUATIONS ─────────────────── */
.ev-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:0;margin-bottom:16px;overflow:hidden;box-shadow:var(--sh-card)}
.ev-card-hd{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;gap:8px;flex-wrap:wrap;border-bottom:1px solid var(--border)}
.ev-card-title{font-weight:600;font-size:14px;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.ev-fields{padding:4px 0}
.ev-field{display:flex;gap:0;border-bottom:1px solid var(--border)}
.ev-field:last-child{border-bottom:none}
.ev-field-lbl{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:12px 16px;min-width:130px;flex-shrink:0;border-right:1px solid var(--border);display:flex;align-items:flex-start;padding-top:14px}
.ev-field-val{font-size:13px;color:var(--text);line-height:1.6;padding:12px 16px;flex:1;white-space:pre-wrap;word-break:break-word}
.ev-field-val.italic{color:var(--muted);font-style:italic}
.ev-compare-bar{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);padding:14px 18px;margin-bottom:16px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.ev-compare-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.ev-compare-btn{padding:6px 13px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:#fff;color:var(--text);transition:var(--transition)}
.ev-compare-btn:hover{border-color:var(--accent);color:var(--accent)}
.ev-compare-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.ev-compare-panel{background:#fff;border:2px solid var(--accent);border-radius:var(--r-lg);margin-bottom:18px;overflow:hidden;box-shadow:0 0 0 4px var(--accent-glow)}
.ev-compare-panel-hd{background:var(--accent-l);padding:12px 18px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}
.ev-compare-panel-title{font-size:13px;font-weight:700;color:var(--accent)}
.ev-compare-row{display:grid;grid-template-columns:120px 1fr 1fr;border-bottom:1px solid var(--border)}
.ev-compare-row:last-child{border-bottom:none}
.ev-compare-row-lbl{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;padding:11px 14px;border-right:1px solid var(--border);display:flex;align-items:flex-start;background:var(--surface)}
.ev-compare-cell{font-size:12.5px;padding:11px 14px;line-height:1.5;white-space:pre-wrap;word-break:break-word;border-right:1px solid var(--border)}
.ev-compare-cell:last-child{border-right:none}
.ev-compare-cell.better{background:#f0f8f4;color:var(--accent)}
.ev-compare-cell.worse{background:var(--red-l);color:var(--red)}
.ev-compare-cell.neutral{background:var(--surface)}
.ev-compare-date{font-size:11px;font-weight:600;color:var(--muted);text-align:center;padding:7px 12px;background:var(--surface);border-bottom:1px solid var(--border)}
.ev-metrics{display:none}.ev-m{display:none}
.ev-m-lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:2px;font-weight:600}
.ev-m-val{font-size:14px;font-weight:600}
.ev-notes{font-size:12.5px;color:var(--muted);line-height:1.6;font-style:italic;padding-top:8px;border-top:1px solid var(--border)}
.ev-type-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 8px;border-radius:5px}
.et-init{background:var(--accent-l);color:var(--accent)}
.et-inter{background:var(--gold-l);color:var(--gold)}
.et-final{background:var(--orange-l);color:var(--orange)}
.alert-bar{background:var(--orange-l);border:1px solid rgba(212,114,60,.15);border-radius:var(--r);padding:14px 18px;display:flex;align-items:center;gap:12px;margin-bottom:18px;font-size:13px;flex-wrap:wrap}
.alert-bar strong{color:var(--orange)}

/* ── SEANCE MODAL EXERCISES ──────── */
.exo-table{width:100%;border-collapse:collapse}
.exo-table th{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:4px 8px 8px;text-align:left;border-bottom:2px solid var(--border)}
.exo-table td{padding:4px 5px;vertical-align:top}
.exo-table td input{font-size:12.5px;padding:7px 9px;min-width:0}
.exo-row-del{width:28px;height:28px;background:var(--red-l);border:none;border-radius:7px;color:var(--red);display:flex;align-items:center;justify-content:center;font-size:13px;transition:var(--transition)}
.exo-row-del:hover{background:#fde0e0;transform:scale(1.08)}
.exo-rpe-select{width:64px;padding:8px 5px;font-size:13px;font-weight:600;border:1px solid var(--border);border-radius:8px;background:#FAFAF8;color:var(--text);cursor:pointer;text-align:center;transition:var(--transition)}
.exo-rpe-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);background:#fff;outline:none}
.exo-rpe-select.rpe-hi{border-color:var(--red);color:var(--red);background:var(--red-l)}
.exo-rpe-select.rpe-mid{border-color:var(--orange);color:var(--orange);background:var(--orange-l)}

/* ── COLOR PICKER ────────────────── */
.color-picker{display:flex;gap:7px;flex-wrap:wrap;margin-top:4px}
.cp-sw{width:28px;height:28px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:var(--transition)}
.cp-sw.on{border-color:var(--text);transform:scale(1.15)}

/* ── EXAM SUBSECTIONS ────────────── */
.exam-subsection{padding:18px 0;border-bottom:1px solid var(--border);margin-bottom:4px}
.exam-subsection:last-child{border-bottom:none}
.exam-subsection-title{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:14px;display:flex;align-items:center;gap:7px}

/* ── BIBLIOTHÈQUE ────────────────── */
.lib-toolbar{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap;align-items:center}
.lib-search-wrap{flex:1;min-width:140px}
.lib-search-wrap input{width:100%}
.lib-region-tabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:10px}
.lib-rtab{padding:6px 12px;border-radius:8px;font-size:11px;font-weight:600;cursor:pointer;border:1.5px solid var(--border);background:#fff;color:var(--muted);transition:var(--transition);white-space:nowrap}
.lib-rtab:hover{border-color:var(--accent);color:var(--accent)}
.lib-rtab.on{color:#fff;border-color:transparent}
.lib-type-filters{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:10px}
.lib-tfilt{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;cursor:pointer;border:1.5px solid var(--border);background:#fff;color:var(--muted);transition:var(--transition)}
.lib-tfilt:hover{border-color:var(--accent);color:var(--accent)}
.lib-tfilt.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.lib-exo-list{max-height:340px;overflow-y:auto}
.lib-exo-list::-webkit-scrollbar{width:4px}
.lib-exo-list::-webkit-scrollbar-thumb{background:rgba(0,0,0,.08);border-radius:2px}
.lib-exo-row{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--r-sm);margin-bottom:4px;border:1px solid var(--border);background:#fff;transition:var(--transition);cursor:pointer}
.lib-exo-row:hover{border-color:var(--accent);background:var(--accent-l);transform:translateY(-1px)}
.lib-exo-color{width:4px;height:32px;border-radius:2px;flex-shrink:0}
.lib-exo-info{flex:1;min-width:0}
.lib-exo-fr{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lib-exo-en{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.lib-exo-badges{display:flex;gap:3px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}
.lib-badge{font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}
.lib-add-btn{padding:5px 11px;border-radius:7px;font-size:11px;font-weight:600;border:1.5px solid var(--accent);background:transparent;color:var(--accent);cursor:pointer;transition:var(--transition);flex-shrink:0}
.lib-add-btn:hover{background:var(--accent);color:#fff}
.lib-count{font-size:11.5px;color:var(--muted);margin-left:auto;padding:2px 0}

/* ── BLOCS D'EXERCICES ───────────── */
.bloc-wrap{margin-bottom:20px;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);box-shadow:var(--sh-card);transition:var(--transition)}
.bloc-wrap:hover{box-shadow:var(--sh)}
.bloc-header{display:flex;flex-direction:column;gap:0;padding:0;border-bottom:1px solid var(--border)}
.bloc-header-top{display:flex;align-items:center;gap:10px;padding:14px 18px}
.bloc-header-bottom{display:flex;align-items:center;gap:5px;padding:6px 18px 12px;flex-wrap:nowrap;overflow-x:auto}
.bloc-color-strip{width:5px;height:32px;border-radius:3px;flex-shrink:0}
.bloc-name-input{flex:1;background:transparent;border:none;font-size:16px;font-weight:600;color:var(--text);outline:none;padding:2px 0;min-width:80px;font-family:'Inter',sans-serif;letter-spacing:-.2px}
.bloc-name-input::placeholder{color:var(--muted);font-weight:400}
.bloc-name-input:focus{color:var(--accent)}
.bloc-actions{display:flex;gap:6px;margin-left:auto;flex-shrink:0;align-items:center}
.bloc-format-wrap{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.bloc-fmt-btn{padding:5px 10px;border-radius:7px;font-size:11px;font-weight:700;cursor:pointer;border:1.5px solid transparent;background:rgba(0,0,0,.05);color:rgba(0,0,0,.4);transition:var(--transition);letter-spacing:.3px;white-space:nowrap;line-height:1.4}
.bloc-fmt-btn:hover{background:rgba(0,0,0,.1)}
.bloc-fmt-btn.on{background:var(--text);color:#fff;border-color:var(--text)}
.bloc-fmt-btn.on.fmt-ss{background:#3A6FA8;border-color:#3A6FA8}
.bloc-fmt-btn.on.fmt-circuit{background:#2E6B56;border-color:#2E6B56}
.bloc-fmt-btn.on.fmt-amrap{background:#D4723C;border-color:#D4723C}
.bloc-fmt-btn.on.fmt-emom{background:#8A3A8A;border-color:#8A3A8A}
.bloc-tours-input{width:46px;font-size:12px;padding:4px 6px;border:1.5px solid var(--border);border-radius:7px;background:#fff;text-align:center;color:var(--text);outline:none;font-weight:600}
.bloc-tours-input:focus{border-color:var(--accent)}
.bloc-tours-label{font-size:11px;font-weight:600;color:rgba(0,0,0,.35);white-space:nowrap}
.fmt-badge{font-size:9px;font-weight:700;padding:3px 7px;border-radius:5px;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}
.fmt-badge-ss{background:#EBF3FB;color:#3A6FA8}
.fmt-badge-circuit{background:#EAF4EF;color:#2E6B56}
.fmt-badge-amrap{background:#FDF2EA;color:#D4723C}
.fmt-badge-emom{background:#F3EEF8;color:#8A3A8A}
.bloc-del-btn{width:26px;height:26px;background:var(--red-l);border:none;border-radius:7px;color:var(--red);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.bloc-del-btn:hover{background:#fde0e0;transform:scale(1.08)}
.bloc-add-exo-btn{padding:5px 12px;background:transparent;border:1px solid var(--border);border-radius:7px;font-size:11.5px;font-weight:600;color:var(--muted);cursor:pointer;transition:var(--transition);white-space:nowrap}
.bloc-add-exo-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-l)}
.order-btn{width:24px;height:24px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:var(--transition);padding:0;flex-shrink:0}
.order-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.order-btn:disabled{opacity:.2;cursor:default}
.drag-handle{width:20px;cursor:grab;color:var(--muted);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;user-select:none;opacity:.3;transition:var(--transition)}
.drag-handle:hover{opacity:.7;color:var(--accent)}
.drag-handle:active{cursor:grabbing}
.bloc-wrap.dragging{opacity:.4;border-style:dashed}
.bloc-wrap.drag-over{border-color:var(--accent);border-width:2px;background:var(--accent-l)}
.exo-tr.dragging{opacity:.4}
.exo-tr.drag-over td{background:var(--accent-l)}
.col-handle{width:24px;padding:2px 3px!important;vertical-align:middle}
.bloc-table-wrap{padding:14px 20px 18px}
.bloc-table{width:100%;border-collapse:collapse}
.bloc-table th{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.7px;padding:6px 8px 10px;text-align:left;border-bottom:1.5px solid var(--border)}
.bloc-table td{padding:5px 5px;vertical-align:middle}
.bloc-table td input{font-size:13px;padding:8px 10px;min-width:0;border-radius:8px}
.bloc-empty{font-size:13px;color:var(--muted);font-style:italic;padding:14px 0 8px;text-align:center}
.bloc-color-picker{display:flex;gap:6px}
.bcp-sw{width:22px;height:22px;border-radius:50%;cursor:pointer;border:2.5px solid transparent;transition:var(--transition);flex-shrink:0}
.bcp-sw:hover{transform:scale(1.12)}
.bcp-sw.on{border-color:var(--text);transform:scale(1.2)}
.add-bloc-row{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap;align-items:center}

/* ── SETTINGS ────────────────────── */
.settings-section{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:22px 24px;margin-bottom:18px;box-shadow:var(--sh-card)}
.settings-section h3{font-family:'Fraunces',serif;font-size:16px;font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--border);gap:12px;flex-wrap:wrap}
.settings-row:last-child{border-bottom:none}
.settings-row-info{flex:1;min-width:0}
.settings-row-info strong{font-size:13.5px;display:block;margin-bottom:2px}
.settings-row-info span{font-size:12px;color:var(--muted)}
.storage-bar{height:5px;background:var(--surface2);border-radius:3px;overflow:hidden;margin-top:6px;max-width:260px}
.storage-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .4s}
.storage-fill.warn{background:var(--orange)}
.storage-fill.crit{background:var(--red)}

/* ── MODAL ────────────────────────── */
#mo{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1000;display:none;align-items:center;justify-content:center;padding:16px}
#mo.open{display:flex}
.modal{background:#fff;border-radius:var(--r-lg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 80px rgba(0,0,0,.2)}
.modal-xl{max-width:840px}.modal-lg{max-width:680px}
.mo-hd{padding:22px 28px 16px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;position:sticky;top:0;background:#fff;z-index:2;border-radius:var(--r-lg) var(--r-lg) 0 0}
.mo-title{font-family:'Fraunces',serif;font-size:21px;font-weight:600;letter-spacing:-.3px}
.mo-sub{font-size:12px;color:var(--muted);margin-top:4px}
.mo-close{width:34px;height:34px;background:var(--surface2);border:none;border-radius:50%;font-size:15px;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:var(--transition);flex-shrink:0;margin-top:2px}
.mo-close:hover{background:var(--border);color:var(--text);transform:rotate(90deg)}
.mo-bd{padding:24px 28px}
.mo-ft{padding:16px 28px 24px;display:flex;gap:8px;justify-content:flex-end;border-top:1px solid var(--border);flex-wrap:wrap}

/* ── CONFIRM DIALOG ──────────────── */
#confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:2000;display:none;align-items:center;justify-content:center;padding:20px}
#confirm-overlay.open{display:flex}
.confirm-box{background:#fff;border-radius:var(--r-lg);padding:26px 28px;max-width:400px;width:100%;box-shadow:var(--sh-lg)}
.confirm-title{font-family:'Fraunces',serif;font-size:18px;font-weight:600;margin-bottom:10px}
.confirm-msg{font-size:13.5px;color:var(--muted);line-height:1.6;margin-bottom:22px}
.confirm-actions{display:flex;gap:10px;justify-content:flex-end}
#tour-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:2500;display:none;align-items:center;justify-content:center;padding:20px}
#tour-overlay.open{display:flex}
.tour-modal{background:#fff;border-radius:var(--r-lg);max-width:440px;width:100%;padding:28px;box-shadow:0 24px 80px rgba(0,0,0,.25);text-align:center}
.tour-title{font-family:'Fraunces',serif;font-size:21px;font-weight:600;margin-bottom:12px;color:var(--text)}
.tour-body{font-size:13.5px;color:var(--muted);line-height:1.65;margin-bottom:22px}
.tour-dots{display:flex;justify-content:center;gap:6px;margin-bottom:22px}
.tour-dot{width:7px;height:7px;border-radius:50%;background:var(--border);transition:var(--transition)}
.tour-dot.on{background:var(--accent);width:18px;border-radius:4px}
.tour-actions{display:flex;gap:8px;justify-content:space-between}

/* ── TOAST ────────────────────────── */
#toast{position:fixed;bottom:24px;right:24px;background:var(--text);color:#fff;padding:12px 18px;border-radius:var(--r);font-size:13px;font-weight:500;z-index:3000;opacity:0;transition:opacity .25s;pointer-events:none;max-width:320px;box-shadow:var(--sh-lg)}
#toast.err{background:var(--red)}
#toast.ok{background:var(--accent)}

/* ── EMPTY STATE ─────────────────── */
.empty-list{text-align:center;padding:36px 16px;color:var(--muted);font-size:13.5px}
.empty-list svg{opacity:.2;margin-bottom:10px;display:block;margin-left:auto;margin-right:auto}

/* ── MOBILE TOPBAR ────────────────── */
#mobile-topbar{display:none;align-items:center;gap:14px;background:#1B1F1E;padding:14px 18px;flex-shrink:0}
#mobile-topbar .logo{font-size:18px}
#mobile-menu-btn{background:rgba(255,255,255,.08);border:none;border-radius:var(--r-sm);width:38px;height:38px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}
#sb-overlay{display:none}

/* ── RESPONSIVE — MOBILE/TABLET ──── */
@media (max-width:880px){
  #mobile-topbar{display:flex}
  body{display:flex;flex-direction:column;height:100dvh;overflow:hidden}
  #app{height:auto;flex:1;min-height:0}
  #sb{position:fixed;top:0;left:0;height:100dvh;z-index:500;transform:translateX(-100%);transition:transform .25s ease;box-shadow:var(--sh-lg);width:min(var(--sb-w),82vw)}
  #sb.open{transform:translateX(0)}
  #sb-overlay.open{display:block;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:499}
  #main{width:100%}
  #ph{padding:16px 18px;flex-wrap:wrap}
  #ph-name{font-size:22px}
  #tabs{padding:0 12px}
  #content{padding:18px;padding-bottom:calc(18px + env(safe-area-inset-bottom) + 20px)}
   .dash-grid{grid-template-columns:1fr}
  .dc-span2,.dc-span3{grid-column:span 1}
   .seance-item{flex-wrap:wrap;align-items:flex-start;row-gap:6px}
  .s-label{order:2;flex:1 1 auto;min-width:140px}
  .s-note-prev{order:3;flex:1 1 100%;max-width:none}
  .s-badges{order:4;flex:1 1 100%}
   .cal-day{min-height:64px;padding:4px}
  .cal-day-num{font-size:10px;margin-bottom:2px}
  .cal-ev{font-size:9px;padding:1px 4px}
  .cal-dow-cell{font-size:9px;padding:4px 0}
   .cal-toolbar{flex-direction:column;align-items:stretch}
  .cal-toolbar>div{width:100%;justify-content:space-between}
  .cal-toolbar>div+div{margin-top:8px}
   .cal-grid-m{grid-template-columns:repeat(7,minmax(0,1fr))}
  .cal-day{min-width:0;overflow:hidden}
  #cal-title{font-size:18px}
   #mo{padding:0}
  .modal{max-width:100%;width:100%;height:100%;max-height:100dvh;border-radius:0}
  .mo-hd{padding:16px 18px 12px;border-radius:0}
  .mo-bd{padding:16px 18px}
  .mo-ft{padding:12px 18px calc(16px + env(safe-area-inset-bottom))}
  .g2,.g3{grid-template-columns:1fr}
   
}

/* ── PRINT ────────────────────────── */
@media print{
  #sb,#ph .ph-actions,#tabs,button,#toast,#mo,#confirm-overlay{display:none!important}
  body,#app,#main,#pv,#content{overflow:visible!important;height:auto!important}
  .tab-p{display:block!important}
  .cycle-card,.ev-card{page-break-inside:avoid}
  #app{display:block}
  #content{padding:0}
}
