/* ============================================================
   IMMERSION — Suivi de formation terrain
   Design system bleu télécom · IBM Plex
   ============================================================ */
:root{
  --blue-700:oklch(0.42 0.13 252); --blue-600:oklch(0.50 0.145 252);
  --blue-500:oklch(0.58 0.15 252); --blue-300:oklch(0.74 0.10 252);
  --blue-100:oklch(0.93 0.035 252); --blue-50:oklch(0.965 0.018 252);
  --ink:oklch(0.26 0.014 252); --ink-2:oklch(0.44 0.013 252);
  --ink-3:oklch(0.60 0.011 252); --ink-4:oklch(0.72 0.008 252);
  --line:oklch(0.905 0.007 252); --line-2:oklch(0.945 0.005 252);
  --bg:oklch(0.972 0.005 252); --bg-2:oklch(0.955 0.006 252);
  --surface:oklch(1 0 0); --surface-2:oklch(0.988 0.003 252);
  --ok:oklch(0.56 0.12 155); --ok-bg:oklch(0.95 0.04 155);
  --warn:oklch(0.66 0.13 65); --warn-bg:oklch(0.95 0.05 75);
  --bad:oklch(0.57 0.16 25); --bad-bg:oklch(0.95 0.04 25);
  --tmf:oklch(0.55 0.13 200); --tmra:oklch(0.56 0.13 300); --tmre:oklch(0.55 0.12 160);
  --radius:8px; --radius-sm:6px; --radius-lg:12px;
  --shadow-sm:0 1px 2px oklch(0.4 0.02 252/0.06),0 1px 1px oklch(0.4 0.02 252/0.04);
  --shadow-md:0 4px 16px oklch(0.4 0.02 252/0.08),0 1px 3px oklch(0.4 0.02 252/0.05);
  --shadow-lg:0 12px 40px oklch(0.35 0.03 252/0.16),0 2px 8px oklch(0.4 0.02 252/0.08);
  --sidebar-w:248px;
  --font-sans:'IBM Plex Sans',system-ui,-apple-system,sans-serif;
  --font-mono:'IBM Plex Mono',ui-monospace,'SF Mono',monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--font-sans);background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}
a{color:inherit;text-decoration:none}
::selection{background:var(--blue-100)}
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px;border:3px solid transparent;background-clip:padding-box}
*::-webkit-scrollbar-thumb:hover{background:var(--ink-4);background-clip:padding-box}
.boot{padding:60px;text-align:center;color:var(--ink-3)}
.mono{font-family:var(--font-mono)}
.muted{color:var(--ink-3)}
.spacer{flex:1}
.hidden{display:none !important}

/* ---------- LAYOUT ---------- */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;height:100vh;overflow:hidden}
.main{display:flex;flex-direction:column;overflow:hidden;min-width:0}
.content{flex:1;overflow-y:auto;padding:28px 36px 64px}
.content-inner{max-width:1180px;margin:0 auto}

/* ---------- SIDEBAR ---------- */
.sidebar{background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column;overflow:hidden}
.sb-brand{display:flex;align-items:center;gap:11px;padding:20px 20px 18px;border-bottom:1px solid var(--line-2)}
.sb-logo{width:34px;height:34px;border-radius:9px;background:linear-gradient(150deg,var(--blue-500),var(--blue-700));display:grid;place-items:center;flex-shrink:0;box-shadow:var(--shadow-sm);color:#fff;font-weight:700}
.sb-brand-name{font-weight:600;font-size:15.5px;letter-spacing:-0.01em}
.sb-brand-sub{font-size:11px;color:var(--ink-3);font-family:var(--font-mono);letter-spacing:0.02em}
.sb-nav{padding:14px 12px;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.sb-section-label{font-size:10.5px;text-transform:uppercase;letter-spacing:0.09em;color:var(--ink-4);font-weight:600;padding:14px 12px 6px}
.sb-item{display:flex;align-items:center;gap:11px;padding:8.5px 12px;border-radius:var(--radius-sm);color:var(--ink-2);font-size:13.5px;font-weight:500;transition:.12s;position:relative;cursor:pointer}
.sb-item:hover{background:var(--bg-2);color:var(--ink)}
.sb-item.active{background:var(--blue-50);color:var(--blue-700);font-weight:600}
.sb-item.active::before{content:'';position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:3px;height:18px;background:var(--blue-600);border-radius:0 3px 3px 0}
.sb-item svg{width:18px;height:18px;flex-shrink:0}
.sb-item .badge-count{margin-left:auto}
.sb-footer{padding:12px;border-top:1px solid var(--line-2)}
.sb-user{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--radius-sm);cursor:pointer}
.sb-user:hover{background:var(--bg-2)}
.sb-user>svg{width:18px;height:18px;flex-shrink:0;color:var(--ink-3)}
.sb-user-name{font-size:13px;font-weight:600}
.sb-user-role{font-size:11px;color:var(--ink-3)}
.avatar{border-radius:50%;background:var(--blue-100);color:var(--blue-700);display:grid;place-items:center;font-weight:600;flex-shrink:0;font-size:12px;width:32px;height:32px}
.avatar.lg{width:46px;height:46px;font-size:16px}
.avatar.xl{width:60px;height:60px;font-size:20px}

/* ---------- TOPBAR ---------- */
.topbar{height:60px;flex-shrink:0;border-bottom:1px solid var(--line);background:oklch(1 0 0/0.85);backdrop-filter:blur(8px);display:flex;align-items:center;gap:16px;padding:0 36px}
.crumbs{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-3)}
.crumbs .sep{color:var(--ink-4)}
.crumbs .cur{color:var(--ink);font-weight:600}
.crumb-link{cursor:pointer}
.crumb-link:hover{color:var(--blue-600)}
.menu-btn{display:none;width:36px;height:36px;border-radius:var(--radius-sm);place-items:center;color:var(--ink-2)}
.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:10px}

/* ---------- TYPO ---------- */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:22px;flex-wrap:wrap}
.page-title{font-size:23px;font-weight:600;letter-spacing:-0.02em}
.page-sub{color:var(--ink-3);font-size:13.5px;margin-top:3px}
.section-title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--ink-3);margin-bottom:12px}
.section-title svg{width:16px;height:16px;vertical-align:-3px;margin-right:4px}
.elig-banner svg,.back-link svg{width:16px;height:16px;flex-shrink:0}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;justify-content:center;padding:9px 15px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:600;transition:.13s;white-space:nowrap;border:1px solid transparent}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--blue-600);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--blue-700)}
.btn-ghost{background:var(--surface);color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:var(--bg-2);border-color:var(--ink-4)}
.btn-subtle{background:transparent;color:var(--ink-2)}
.btn-subtle:hover{background:var(--bg-2);color:var(--ink)}
.btn-danger{background:var(--bad-bg);color:oklch(0.47 0.16 25)}
.btn-danger:hover{background:oklch(0.92 0.05 25)}
.btn-sm{padding:6px 11px;font-size:12.5px}
.btn-sm svg{width:14px;height:14px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ---------- BADGES / TAGS ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:2.5px 9px;border-radius:100px;white-space:nowrap;line-height:1.4}
.badge .dot-i{width:6px;height:6px;border-radius:50%;background:currentColor}
.badge-ok{background:var(--ok-bg);color:oklch(0.42 0.12 155)}
.badge-warn{background:var(--warn-bg);color:oklch(0.48 0.12 65)}
.badge-bad{background:var(--bad-bg);color:oklch(0.47 0.16 25)}
.badge-info{background:var(--blue-50);color:var(--blue-700)}
.badge-neutral{background:var(--bg-2);color:var(--ink-2);border:1px solid var(--line)}
.badge-count{font-family:var(--font-mono);font-size:11px;font-weight:600;min-width:20px;height:19px;padding:0 6px;border-radius:100px;background:var(--bg-2);color:var(--ink-2);display:inline-grid;place-items:center}
.sb-item.active .badge-count{background:var(--blue-100);color:var(--blue-700)}
.fil-tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:0.03em;padding:2.5px 8px;border-radius:5px;border:1px solid;white-space:nowrap}
.fil-tmf{color:var(--tmf);border-color:oklch(0.55 0.13 200/0.3);background:oklch(0.55 0.13 200/0.07)}
.fil-tmra{color:var(--tmra);border-color:oklch(0.56 0.13 300/0.3);background:oklch(0.56 0.13 300/0.07)}
.fil-tmre{color:var(--tmre);border-color:oklch(0.55 0.12 160/0.3);background:oklch(0.55 0.12 160/0.07)}
.fil-dot{width:7px;height:7px;border-radius:2px}
.fil-dot.tmf{background:var(--tmf)}.fil-dot.tmra{background:var(--tmra)}.fil-dot.tmre{background:var(--tmre)}

/* ---------- CARDS ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}
.card-pad{padding:18px 20px}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 20px;border-bottom:1px solid var(--line-2)}
.card-head h3{font-size:14.5px;font-weight:600}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:16px 18px;box-shadow:var(--shadow-sm)}
.stat-label{font-size:12px;color:var(--ink-3);font-weight:500;display:flex;align-items:center;gap:7px}
.stat-value{font-size:30px;font-weight:600;letter-spacing:-0.02em;margin-top:9px;font-variant-numeric:tabular-nums}
.stat-value small{font-size:15px;color:var(--ink-3);font-weight:500}

/* ---------- PROGRESS / RING ---------- */
.progress{height:7px;background:var(--bg-2);border-radius:100px;overflow:hidden}
.progress>i{display:block;height:100%;border-radius:100px;background:var(--blue-500);transition:width .5s cubic-bezier(.2,.7,.3,1)}
.progress.thin{height:5px}
.progress.ok>i{background:var(--ok)} .progress.warn>i{background:var(--warn)}
.ring{transform:rotate(-90deg)}
.ring circle{fill:none;stroke-linecap:round}

/* ---------- TABLE ---------- */
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:0.05em;color:var(--ink-3);font-weight:600;padding:10px 14px;border-bottom:1px solid var(--line);white-space:nowrap;background:var(--surface-2)}
.tbl td{padding:12px 14px;border-bottom:1px solid var(--line-2);font-size:13.5px;vertical-align:middle}
.tbl tbody tr{transition:.1s;cursor:pointer}
.tbl tbody tr:hover{background:var(--blue-50)}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl .num{font-variant-numeric:tabular-nums;font-family:var(--font-mono)}
.person{display:flex;align-items:center;gap:11px}
.person-name{font-weight:600;font-size:13.5px}
.person-meta{font-size:11.5px;color:var(--ink-3)}

/* ---------- TOOLBAR / CHIPS ---------- */
.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;gap:7px;padding:7px 13px;border-radius:100px;font-size:12.5px;font-weight:600;border:1px solid var(--line);background:var(--surface);color:var(--ink-2);transition:.12s;cursor:pointer}
.chip:hover{border-color:var(--ink-4);color:var(--ink)}
.chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.chip .c{font-family:var(--font-mono);opacity:.7;font-size:11px}
.seg{display:inline-flex;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:2px}
.seg button{padding:6px 12px;border-radius:5px;font-size:12.5px;font-weight:600;color:var(--ink-3)}
.seg button.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}

/* ---------- DOSSIER CARDS ---------- */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px}
.tech-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:16px 18px;cursor:pointer;transition:.14s}
.tech-card:hover{box-shadow:var(--shadow-md);border-color:var(--blue-300)}
.tc-top{display:flex;align-items:center;gap:12px}
.tc-id{flex:1;min-width:0}
.tc-name{font-size:15.5px;font-weight:600;letter-spacing:-0.01em}
.tc-sub{display:flex;align-items:center;gap:8px;margin-top:5px}
.tc-mid{display:flex;align-items:center;justify-content:space-between;margin-top:14px;gap:12px}
.tc-prog-txt{font-size:12px;color:var(--ink-3)}
.tc-prog-txt b{color:var(--ink);font-size:13px}
.tc-foot{display:flex;align-items:center;gap:8px;margin-top:14px;padding-top:12px;border-top:1px solid var(--line-2)}
.tc-ref{font-size:11.5px;color:var(--ink-3);flex:1}

/* ---------- COMPETENCY GRID ---------- */
.skill-domain{border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--surface);margin-bottom:14px;box-shadow:var(--shadow-sm)}
.skill-domain-head{display:flex;align-items:center;gap:12px;padding:13px 18px;background:var(--surface-2);border-bottom:1px solid var(--line-2);cursor:pointer}
.skill-domain-head h4{font-size:14px;font-weight:600;flex:1}
.skill-domain-idx{font-family:var(--font-mono);font-size:12px;color:var(--ink-4);font-weight:600}
.sd-prog{display:flex;align-items:center;gap:8px;width:160px}
.sd-prog .progress{flex:1}
.sd-prog .pct{font-family:var(--font-mono);font-size:12px;color:var(--ink-2);font-weight:600;width:38px;text-align:right}
.skill-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:16px;padding:12px 18px;border-bottom:1px solid var(--line-2)}
.skill-row:last-child{border-bottom:none}
.skill-name{font-size:13.5px;font-weight:500}
.skill-name .star{color:var(--warn);font-weight:700}
.skill-name-sub{font-size:11.5px;color:var(--ink-3);margin-top:1px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.obl-tag{display:inline-block;background:var(--warn-bg);color:oklch(0.48 0.12 65);border-radius:100px;padding:0 7px;font-size:10px;font-weight:700}
.ctrl-tag{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--ok);font-weight:600}
/* échelle statuts (Non vu / Abordé / Pratiqué / Maîtrisé) */
.levels{display:flex;gap:4px;align-items:center}
.lvl{min-width:34px;height:30px;padding:0 8px;border-radius:var(--radius-sm);border:1px solid var(--line);display:grid;place-items:center;font-size:11.5px;font-weight:600;font-family:var(--font-mono);color:var(--ink-4);background:var(--surface);transition:.12s;cursor:pointer}
.lvl:hover{border-color:var(--blue-300)}
.lvl.filled{color:#fff;border-color:transparent}
.lvl.l1.filled{background:oklch(0.66 0.10 65)}
.lvl.l2.filled{background:oklch(0.60 0.12 120)}
.lvl.l3.filled{background:var(--blue-600)}
.lvl.ro{cursor:default}
.lvl-legend{display:flex;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--ink-2);align-items:center}
.lvl-legend span{display:inline-flex;align-items:center;gap:7px}
.lvl-legend i{width:12px;height:12px;border-radius:3px}

/* ---------- FORMS ---------- */
.field{margin-bottom:16px}
.field-label{display:block;font-size:12.5px;font-weight:600;color:var(--ink-2);margin-bottom:6px}
.field-label .req{color:var(--bad);margin-left:2px}
.field-hint{font-size:11.5px;color:var(--ink-3);margin-top:5px}
.input,.select,.textarea{width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);font-size:13.5px;transition:.13s;outline:none}
.input:focus,.select:focus,.textarea:focus{border-color:var(--blue-300);box-shadow:0 0 0 3px var(--blue-50)}
.input::placeholder,.textarea::placeholder{color:var(--ink-4)}
.textarea{resize:vertical;min-height:84px;line-height:1.55}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23667' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;padding-right:34px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.radio-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.radio-card{border:1.5px solid var(--line);border-radius:var(--radius);padding:13px 14px;cursor:pointer;transition:.13s;position:relative}
.radio-card:hover{border-color:var(--ink-4)}
.radio-card.sel{border-color:var(--blue-500);background:var(--blue-50)}
.radio-card .rc-code{font-family:var(--font-mono);font-weight:600;font-size:13px}
.radio-card .rc-label{font-size:11.5px;color:var(--ink-3);margin-top:2px}

/* ---------- MODAL ---------- */
.overlay{position:fixed;inset:0;background:oklch(0.3 0.02 252/0.4);backdrop-filter:blur(3px);display:grid;place-items:center;z-index:100;padding:24px;animation:fade .18s ease}
.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:540px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:pop .2s cubic-bezier(.2,.8,.3,1)}
.modal-head{padding:20px 24px 16px;border-bottom:1px solid var(--line-2);display:flex;align-items:flex-start;justify-content:space-between}
.modal-title{font-size:17px;font-weight:600;letter-spacing:-0.01em}
.modal-sub{font-size:12.5px;color:var(--ink-3);margin-top:3px}
.modal-body{padding:20px 24px;overflow-y:auto}
.modal-foot{padding:14px 24px;border-top:1px solid var(--line-2);display:flex;justify-content:flex-end;gap:10px;background:var(--surface-2)}
.x-btn{width:30px;height:30px;border-radius:var(--radius-sm);display:grid;place-items:center;color:var(--ink-3)}
.x-btn:hover{background:var(--bg-2);color:var(--ink)}
@keyframes fade{from{opacity:0}}
@keyframes pop{from{opacity:0;transform:scale(0.97) translateY(8px)}}

/* ---------- TABS ---------- */
.tabs{display:flex;gap:2px;border-bottom:1px solid var(--line);margin-bottom:22px;flex-wrap:wrap}
.tab{padding:11px 16px;font-size:13.5px;font-weight:600;color:var(--ink-3);border-bottom:2px solid transparent;margin-bottom:-1px;transition:.12s;cursor:pointer}
.tab:hover{color:var(--ink)}
.tab.active{color:var(--blue-700);border-bottom-color:var(--blue-600)}
.tab .badge-count{margin-left:7px}

/* ---------- MISC ---------- */
.meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:2px 20px}
.meta-item{padding:9px 0;border-bottom:1px solid var(--line-2)}
.meta-k{font-size:11.5px;color:var(--ink-3);font-weight:500}
.meta-v{font-size:13.5px;font-weight:600;margin-top:2px}
.empty{text-align:center;padding:48px 20px;color:var(--ink-3)}
.divider{height:1px;background:var(--line-2);margin:20px 0}
.row{display:flex;align-items:center;gap:10px}
.grid-2{display:grid;grid-template-columns:1.6fr 1fr;gap:20px;align-items:start}
.grid-2-eq{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}
.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--ink-3);font-size:13px;font-weight:600;cursor:pointer;margin-bottom:14px}
.back-link:hover{color:var(--blue-600)}

/* ---------- ELIGIBILITÉ ---------- */
.elig-banner{display:inline-flex;align-items:center;gap:8px;border-radius:100px;padding:6px 16px;font-weight:700;font-size:13px}
.elig-banner.ok{background:var(--ok-bg);color:oklch(0.42 0.12 155)}
.elig-banner.ko{background:var(--bad-bg);color:oklch(0.47 0.16 25)}
.cond-list{list-style:none}
.cond-list li{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line-2)}
.cond-list li:last-child{border-bottom:none}
.cond-badge{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-weight:700;color:#fff;flex-shrink:0}
.cond-badge.ok{background:var(--ok)} .cond-badge.ko{background:var(--bad)}
.cond-k{font-weight:600}
.cond-d{font-size:12px;color:var(--ink-3)}
.form-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line-2)}
.form-row:last-child{border-bottom:none}
.form-row .lib{flex:1}

/* ---------- CR HEBDO — document (Quill) ---------- */
.crh-doc{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}
.crh-banner{background:linear-gradient(135deg,var(--blue-700),oklch(0.46 0.15 262));color:#fff;padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.crh-banner .lbl{font-size:11px;text-transform:uppercase;letter-spacing:0.12em;opacity:.82;font-weight:600;font-family:var(--font-mono)}
.crh-banner h1{font-size:20px;font-weight:600;letter-spacing:-0.02em;margin-top:4px}
.crh-banner-meta{display:flex;align-items:center;gap:10px;margin-top:10px;font-size:12.5px;opacity:.92}
.crh-banner-meta .fil-tag{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.3);color:#fff}
.crh-banner-meta .fil-dot{background:#fff}
.crh-pdf{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.28)}
.crh-pdf:hover{background:rgba(255,255,255,.24)}
.crh-weeks{display:flex;align-items:center;gap:12px;padding:11px 16px;background:var(--surface-2);border-bottom:1px solid var(--line)}
.crh-weeks-lbl{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--ink-3);flex-shrink:0}
.crh-weeks-strip{display:flex;flex-wrap:wrap;gap:5px}
.wk{position:relative;padding:4px 9px;border-radius:6px;background:var(--surface);border:1px solid var(--line);cursor:pointer;font-size:11.5px;font-weight:600;color:var(--ink-3);font-family:var(--font-mono);transition:.12s}
.wk:hover{border-color:var(--ink-4);color:var(--ink)}
.wk.has{color:var(--blue-700);border-color:oklch(0.74 0.10 252/0.5);background:var(--blue-50)}
.wk.has::after{content:"";position:absolute;top:3px;right:3px;width:5px;height:5px;border-radius:50%;background:var(--blue-600)}
.wk.on{background:var(--blue-600);color:#fff;border-color:transparent}
.wk.on::after{background:#fff}
.crh-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;border-top:1px solid var(--line);background:var(--surface-2);font-size:12px;color:var(--ink-3);flex-wrap:wrap}
.crh-foot svg{width:14px;height:14px;vertical-align:-2px;margin-right:2px}
.save-state{font-size:12px;color:var(--ink-3);font-weight:600}

/* Thème Quill aligné au design system */
.ql-toolbar.ql-snow{border:none;border-bottom:1px solid var(--line);background:var(--surface-2);padding:8px 12px;font-family:var(--font-sans)}
.ql-container.ql-snow{border:none;font-family:var(--font-sans);font-size:14px}
.ql-editor{min-height:460px;padding:24px 28px;line-height:1.65;color:var(--ink)}
.ql-editor.ql-blank::before{color:var(--ink-4);font-style:normal;left:28px;right:28px}
.ql-editor h2{color:var(--blue-700);font-size:19px;font-weight:600;border-bottom:1px solid var(--line);padding-bottom:5px;margin:18px 0 10px}
.ql-editor h3{color:var(--blue-600);font-size:15.5px;font-weight:600;margin:14px 0 6px}
.ql-editor p{margin:7px 0}
.ql-editor img{max-width:100%;height:auto;border-radius:10px;border:1px solid var(--line);margin:8px 0;box-shadow:var(--shadow-sm)}
.ql-snow.ql-toolbar button,.ql-snow .ql-toolbar button{width:30px;height:28px;border-radius:6px}
.ql-snow.ql-toolbar button:hover,.ql-snow.ql-toolbar .ql-picker-label:hover{background:var(--bg-2)}
.ql-snow .ql-stroke{stroke:var(--ink-2)}
.ql-snow .ql-fill{fill:var(--ink-2)}
.ql-snow .ql-picker{color:var(--ink-2)}
.ql-snow.ql-toolbar button.ql-active{background:var(--blue-50)}
.ql-snow.ql-toolbar button.ql-active .ql-stroke{stroke:var(--blue-700)}
.ql-snow.ql-toolbar button.ql-active .ql-fill{fill:var(--blue-700)}
.ql-snow .ql-picker.ql-expanded .ql-picker-label,.ql-snow .ql-picker-label.ql-active{color:var(--blue-700);border-color:var(--line)}
.ql-snow .ql-picker.ql-header{width:120px}
.ql-snow .ql-picker-options{border-radius:var(--radius-sm);box-shadow:var(--shadow-md);border-color:var(--line);padding:4px}
.ql-snow .ql-picker.ql-header .ql-picker-label::before,.ql-snow .ql-picker.ql-header .ql-picker-item::before{content:"Texte"}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]::before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]::before{content:"Titre (jour)";font-weight:600;color:var(--blue-700)}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]::before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]::before{content:"Sous-titre";font-weight:600;color:var(--blue-600)}

/* ---------- PARCOURS ---------- */
.parc-temps{font-weight:700;color:var(--blue-700);font-family:var(--font-mono)}

/* ---------- LOGIN ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(160deg,var(--blue-50),var(--bg))}
.login-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:400px;padding:32px 30px}
.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.login-brand .sb-logo{width:40px;height:40px}
.login-title{font-size:20px;font-weight:600;letter-spacing:-0.01em}
.login-sub{color:var(--ink-3);font-size:12.5px;margin:4px 0 22px}
.login-err{background:var(--bad-bg);color:oklch(0.47 0.16 25);border-radius:var(--radius-sm);padding:9px 12px;font-size:12.5px;font-weight:600;margin-bottom:14px}

/* ---------- ABRÉVIATIONS / AIDE ---------- */
abbr[title]{text-decoration:underline dotted var(--ink-4);text-underline-offset:2px;cursor:help}
.aide-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.aide-list li{padding-left:18px;position:relative;font-size:13.5px;line-height:1.55}
.aide-list li:before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:var(--blue-500)}
.aide-list li.muted:before{background:var(--ink-4)}
.help-box{background:var(--blue-50);border:1px solid oklch(0.58 0.15 252/0.2);border-radius:var(--radius);padding:10px 14px;margin-bottom:18px}
.help-box>summary{cursor:pointer;font-weight:600;font-size:13px;color:var(--blue-700);display:flex;align-items:center;gap:8px;list-style:none}
.help-box>summary::-webkit-details-marker{display:none}
.help-box>summary svg{width:16px;height:16px}
.help-box[open]>summary{margin-bottom:8px}
.help-box ol{margin:0;padding-left:22px;display:flex;flex-direction:column;gap:5px}
.help-box li{font-size:13px;line-height:1.5;color:var(--ink-2)}
.aide-steps{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:8px;counter-reset:none}
.aide-steps li{font-size:13.5px;line-height:1.55;color:var(--ink-2);padding-left:4px}
.aide-steps li::marker{color:var(--blue-600);font-weight:700;font-family:var(--font-mono)}
.gloss-grid{display:grid;grid-template-columns:max-content 1fr;gap:8px 18px;align-items:baseline}
.gloss-t{font-family:var(--font-mono);font-weight:600;color:var(--blue-700);font-size:13px}
.gloss-d{color:var(--ink-2);font-size:13px}
@media(max-width:560px){.gloss-grid{grid-template-columns:1fr;gap:2px 0}.gloss-t{margin-top:8px}}

/* ---------- TOAST ---------- */
.toast-wrap{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:300;display:flex;flex-direction:column;gap:8px;align-items:center}
.toast{background:var(--ink);color:#fff;padding:11px 18px;border-radius:var(--radius);font-size:13px;box-shadow:var(--shadow-lg);animation:slideup .25s ease}
@keyframes slideup{from{opacity:0;transform:translateY(12px)}}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1080px){.stat-grid{grid-template-columns:repeat(2,1fr)}.grid-2,.grid-2-eq{grid-template-columns:1fr}}
@media(max-width:860px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;inset:0 auto 0 0;width:270px;z-index:200;transform:translateX(-100%);transition:transform .25s cubic-bezier(.3,.7,.3,1);box-shadow:var(--shadow-lg)}
  .sidebar.open{transform:translateX(0)}
  .scrim{position:fixed;inset:0;background:oklch(0.3 0.02 252/0.4);z-index:150;animation:fade .2s}
  .menu-btn{display:grid}
  .topbar{padding:0 18px}
  .content{padding:20px 18px 56px}
  .radio-cards,.field-row{grid-template-columns:1fr}
  .skill-row{grid-template-columns:1fr;gap:10px}
  .sd-prog{width:auto}
}
@media print{.sidebar,.topbar,.ql-toolbar,.crh-weeks,.crh-foot,.menu-btn{display:none !important}.app{display:block;height:auto}.content{overflow:visible;padding:0}}
