/*  Calendrier & méthode des J (§4)                                      */
/* ===================================================================== */
.cal-head-l { min-width: 0; }
/* Barre d'outils */
.cal-bar { display: flex; align-items: center; justify-content: space-between; gap: 12px 16px; flex-wrap: wrap; margin-bottom: 14px; }
.cal-bar-nav { display: flex; align-items: center; gap: 6px; }
.cal-mois { font-family: var(--serif); font-variant-numeric: tabular-nums; font-size: 18px; color: var(--ink); min-width: 9.5ch; text-align: center; text-transform: capitalize; }
.cal-auj { margin-left: 4px; padding: 6px 12px; font-size: 13px; }
.cal-bar-act { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.cal-vues { display: inline-flex; border: 1px solid var(--hairline); border-radius: 9px; overflow: hidden; background: var(--card-2); }
.cal-vue { border: none; border-radius: 0; padding: 7px 14px; font-size: 13px; color: var(--ink-soft); background: transparent; }
.cal-vue + .cal-vue { border-left: 1px solid var(--hairline); }
.cal-vue.is-on { background: var(--c-surface); color: var(--c-on); }
.cal-add { padding: 8px 14px; }
/* Grille du mois */
.cal-grid { display: flex; flex-direction: column; border: 1px solid var(--hairline); border-radius: 14px; overflow: hidden; box-shadow: var(--shadow); background: var(--card); }
.cal-row { display: grid; grid-template-columns: repeat(7, 1fr); }
.cal-row-head { background: var(--card-2); border-bottom: 1px solid var(--hairline); }
.cal-dow { padding: 8px 6px; text-align: center; font-family: var(--sans); font-size: 11.5px; font-weight: 600; letter-spacing: .03em; color: var(--ink-soft); text-transform: uppercase; }
.cal-cell { position: relative; min-height: 96px; padding: 5px 6px 7px; border-right: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); display: flex; flex-direction: column; gap: 3px; cursor: pointer; background: var(--card); transition: background .12s; text-align: left; }
.cal-row .cal-cell:last-child { border-right: none; }
.cal-grid .cal-row:last-child .cal-cell { border-bottom: none; }
.cal-cell:hover { background: color-mix(in srgb, var(--c-c) 5%, var(--card)); }
.cal-cell:focus-visible { outline: 2px solid var(--c-c); outline-offset: -2px; z-index: 1; }
.cal-hors { background: var(--paper-2); cursor: default; }
.cal-hors .cal-num { opacity: .45; }
.cal-hors:hover { background: var(--paper-2); }
.cal-auj-cell { background: color-mix(in srgb, var(--c-c) 8%, var(--card)); }
.cal-auj-cell .cal-num { background: var(--c-surface); color: var(--c-on); }
.cal-cell-h { display: flex; align-items: center; justify-content: space-between; gap: 4px; }
.cal-num { font-family: var(--sans); font-variant-numeric: tabular-nums; font-size: 12.5px; font-weight: 600; color: var(--ink); min-width: 21px; height: 21px; display: inline-grid; place-items: center; border-radius: 50%; }
.cal-fait { color: var(--c-c); font-size: 12px; font-weight: 700; }
.cal-cell-b { display: flex; flex-direction: column; gap: 2px; min-height: 0; }
.cal-past { display: block; width: 100%; text-align: left; border: none; border-radius: 5px; padding: 2px 6px; font-family: var(--sans); font-size: 11.5px; line-height: 1.35; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; cursor: pointer; }
.cal-past:hover { filter: brightness(1.06) saturate(1.05); }
.cal-past-fait { opacity: .6; text-decoration: line-through; }
.cal-past-j { font-weight: 700; }
.cal-plus { align-self: flex-start; border: none; background: transparent; color: var(--ink-soft); font-family: var(--sans); font-size: 11px; padding: 1px 4px; cursor: pointer; }
.cal-plus:hover { color: var(--ink); text-decoration: underline; }
.cal-sem { position: absolute; top: 6px; left: 6px; display: flex; gap: 3px; pointer-events: none; opacity: .6; }
.cal-sem-dot { width: 5px; height: 5px; border-radius: 50%; display: inline-block; }
.cal-chips { display: flex; flex-wrap: wrap; gap: 4px; margin-top: auto; padding-top: 2px; }
.cal-chip { border: 1px solid var(--hairline); background: var(--card-2); border-radius: 20px; padding: 1px 7px; font-family: var(--sans); font-size: 10.5px; font-variant-numeric: tabular-nums; color: var(--ink-soft); cursor: pointer; line-height: 1.5; }
.cal-chip:hover { border-color: currentColor; }
.cal-chip-dev { color: var(--danger); }
.cal-chip-fc { color: var(--c-c); }
/* Vue agenda */
.cal-agenda { display: flex; flex-direction: column; gap: 4px; max-width: 720px; }
.cal-vide { text-align: center; padding: 26px 14px; }
.cal-ag-jour { display: grid; grid-template-columns: 124px 1fr; gap: 10px; padding: 8px 0; border-top: 1px solid var(--hairline); }
.cal-ag-jour:first-child { border-top: none; }
.cal-ag-date { font-family: var(--sans); font-size: 13.5px; padding-top: 4px; }
.cal-ag-date.is-today b { color: var(--c-c); }
.cal-ag-items { display: flex; flex-direction: column; gap: 5px; min-width: 0; }
.cal-ag-item { display: flex; align-items: stretch; gap: 9px; text-align: left; background: var(--card); border: 1px solid var(--hairline); border-radius: 10px; padding: 8px 11px; cursor: pointer; transition: border-color .12s; }
.cal-ag-item:hover { border-color: var(--c-c); }
.cal-ag-bar { flex: 0 0 4px; border-radius: 3px; }
.cal-ag-b { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.cal-ag-b b { font-family: var(--serif); font-size: 14.5px; color: var(--ink); }
.cal-ag-b span { font-size: 12px; }
@media (max-width: 560px) {
  .cal-ag-jour { grid-template-columns: 1fr; gap: 4px; }
  .cal-cell { min-height: 78px; }
}
/* Dialog (éditeur d'événement) */
.cal-dialog { width: min(560px, 94vw); border: 1px solid var(--hairline); border-radius: 16px; padding: 0; background: var(--card); color: var(--ink); box-shadow: 0 18px 50px rgba(0,0,0,.28); }
.cal-dialog::backdrop { background: rgba(20,16,12,.42); backdrop-filter: blur(2px); }
.cal-dialog-mini { width: min(420px, 92vw); }
.cal-dlg-h { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 16px 18px 8px; }
.cal-dlg-h h2 { margin: 0; font-size: 18px; }
.cal-x { font-size: 20px; line-height: 1; color: var(--ink-soft); }
.cal-x:hover { color: var(--ink); }
.cal-form { display: flex; flex-direction: column; gap: 11px; padding: 0 18px 18px; }
.cal-form .field { gap: 4px; }
.cal-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 11px; }
.cal-f-duree, .cal-f-inter { max-width: 110px; }
.cal-f-unite { font-size: 12.5px; }
.cal-rec { display: flex; flex-direction: column; gap: 8px; }
.cal-rec-det { display: flex; flex-direction: column; gap: 7px; }
.cal-rec-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; font-family: var(--sans); font-size: 13px; }
.cal-rec-row .input { max-width: 160px; }
.cal-err { color: var(--danger); font-size: 12.5px; }
.cal-err p { margin: 0; }
.cal-dlg-f { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: 4px; }
.cal-del { color: var(--danger); }
.cal-del:hover { border-color: var(--danger); background: color-mix(in srgb, var(--danger) 8%, var(--card)); }
/* Couleurs (palette + libre) */
.cal-swatchs { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.cal-swatch { width: 26px; height: 26px; border-radius: 50%; border: 2px solid transparent; box-shadow: 0 0 0 1px var(--hairline) inset; cursor: pointer; padding: 0; }
.cal-swatch.is-on { border-color: var(--ink); }
.cal-swatch-libre { width: 30px; height: 28px; padding: 0; border: 1px solid var(--hairline); border-radius: 7px; background: var(--card); cursor: pointer; }
/* Dialog « +N » du jour + export */
.cal-jour-list { display: flex; flex-direction: column; gap: 6px; padding: 0 18px; max-height: 50vh; overflow: auto; }
.cal-dialog-jour .cal-dlg-f { padding: 14px 18px 18px; }
.cal-expo-act { display: flex; gap: 9px; padding: 4px 18px 18px; flex-wrap: wrap; }
.cal-dialog-mini .cal-leg-t { margin: 6px 18px 0; }
.cal-imp-body { padding: 0 18px; max-height: 46vh; overflow-y: auto; }
.cal-imp-liste { display: flex; flex-direction: column; gap: 4px; }
.cal-imp-row { display: flex; align-items: flex-start; gap: 9px; padding: 7px 9px; border: 1px solid var(--hairline); border-radius: 8px; cursor: pointer; }
.cal-imp-row input { margin-top: 2px; width: 16px; height: 16px; flex: 0 0 auto; accent-color: var(--c-c); }
.cal-imp-b { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.cal-imp-b b { font-family: var(--sans); font-size: 13px; }
.cal-imp-b span { font-size: 11.5px; font-variant-numeric: tabular-nums; }
/* Légende / filtres / superpositions */
.cal-legende { margin-top: 16px; }
.cal-legende > summary { font-family: var(--sans); font-size: 13px; color: var(--ink-soft); cursor: pointer; }
.cal-legende[open] > summary { color: var(--ink); margin-bottom: 12px; }
.cal-leg-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; }
.cal-leg-bloc { display: flex; flex-direction: column; gap: 8px; }
.cal-leg-t { font-family: var(--sans); font-size: 11.5px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--ink-soft); }
.cal-filtres { display: flex; flex-wrap: wrap; gap: 6px; }
.cal-fil { display: inline-flex; align-items: center; gap: 6px; border: 1px solid var(--hairline); background: var(--card-2); border-radius: 20px; padding: 4px 11px; font-family: var(--sans); font-size: 12.5px; color: var(--ink); cursor: pointer; }
.cal-fil-dot { width: 11px; height: 11px; border-radius: 50%; flex: 0 0 auto; }
.cal-fil.is-off { opacity: .42; text-decoration: line-through; }
.cal-overlays { display: flex; flex-direction: column; gap: 7px; }
.cal-ov { display: flex; align-items: center; gap: 8px; font-family: var(--sans); font-size: 13px; color: var(--ink); cursor: pointer; }
.cal-ov input { width: 16px; height: 16px; accent-color: var(--c-c); }
.cal-delest-l { display: flex; gap: 8px; font-family: var(--sans); font-size: 12.5px; }
.cal-delest-l b { flex: 0 0 84px; }
.cal-delest-lien { font-family: var(--sans); font-size: 12.5px; color: var(--c-c); text-decoration: none; }
.cal-delest-lien:hover { text-decoration: underline; }
.cal-reglages { border-top: 1px solid var(--hairline); padding-top: 12px; margin-top: 12px; }
.cal-rgl-row { display: flex; align-items: center; gap: 10px; }
.cal-rgl-row .input { max-width: 150px; }
.cal-rgl-rappels { flex-wrap: wrap; }
.cal-rgl-note { flex-basis: 100%; font-size: 11px; line-height: 1.4; }
@media (prefers-reduced-motion: reduce) { .cal-cell { transition: none; } }
/* Vues semaine / jour — grille horaire */
.cal-tg { --tg-gut: 48px; border: 1px solid var(--hairline); border-radius: 14px; overflow: hidden; box-shadow: var(--shadow); background: var(--card); }
.cal-tg-head, .cal-tg-allday, .cal-tg-cols { display: grid; }
.cal-tg-head { border-bottom: 1px solid var(--hairline); background: var(--card-2); }
.cal-tg-gut { width: var(--tg-gut); }
.cal-tg-gut-l { display: flex; align-items: center; justify-content: flex-end; padding-right: 6px; font-family: var(--sans); font-size: 10px; color: var(--ink-soft); }
.cal-tg-dow { display: flex; flex-direction: column; align-items: center; gap: 1px; padding: 7px 4px; border-left: 1px solid var(--hairline); background: transparent; cursor: pointer; }
.cal-tg-dow:hover { background: color-mix(in srgb, var(--c-c) 6%, transparent); }
.cal-tg-dow-d { font-family: var(--sans); font-size: 11px; text-transform: uppercase; letter-spacing: .03em; color: var(--ink-soft); }
.cal-tg-dow-n { font-family: var(--sans); font-variant-numeric: tabular-nums; font-size: 16px; font-weight: 600; color: var(--ink); width: 26px; height: 26px; display: grid; place-items: center; border-radius: 50%; }
.cal-tg-dow.is-today .cal-tg-dow-n { background: var(--c-surface); color: var(--c-on); }
.cal-tg-dow.is-today .cal-tg-dow-d { color: var(--c-c); }
.cal-tg-allday { border-bottom: 1px solid var(--hairline); min-height: 30px; }
.cal-tg-ad { border-left: 1px solid var(--hairline); padding: 3px; display: flex; flex-direction: column; gap: 3px; cursor: pointer; min-width: 0; }
.cal-tg-ad .cal-past { font-size: 11px; }
.cal-tg-body { max-height: 64vh; overflow-y: auto; }
.cal-tg-cols { position: relative; }
.cal-tg-axe { position: relative; }
.cal-tg-hlab { position: absolute; right: 5px; transform: translateY(-50%); font-family: var(--sans); font-variant-numeric: tabular-nums; font-size: 10.5px; color: var(--ink-soft); white-space: nowrap; }
.cal-tg-col { position: relative; border-left: 1px solid var(--hairline); cursor: pointer;
  background-image: repeating-linear-gradient(to bottom, var(--hairline), var(--hairline) 1px, transparent 1px, transparent var(--tg-hh)); }
.cal-tg-col:hover { background-color: color-mix(in srgb, var(--c-c) 3%, transparent); }
.cal-tg-ev { position: absolute; border: none; border-radius: 6px; padding: 2px 6px; overflow: hidden; text-align: left; cursor: pointer; display: flex; flex-direction: column; gap: 0; line-height: 1.2; box-shadow: 0 1px 2px rgba(0,0,0,.12); }
.cal-tg-ev:hover { filter: brightness(1.05) saturate(1.05); z-index: 3; }
.cal-tg-ev-h { font-family: var(--sans); font-variant-numeric: tabular-nums; font-size: 10px; opacity: .85; }
.cal-tg-ev-t { font-family: var(--sans); font-size: 11.5px; font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cal-tg-sem { position: absolute; left: 2px; right: 2px; border-radius: 5px; border-left: 3px solid var(--sc); background: color-mix(in srgb, var(--sc) 12%, transparent); pointer-events: none; overflow: hidden; padding: 1px 5px; }
.cal-tg-sem span { font-family: var(--sans); font-size: 10px; color: var(--ink-soft); opacity: .85; }
.cal-tg-now { position: absolute; left: 0; right: 0; height: 0; border-top: 2px solid var(--danger); z-index: 4; pointer-events: none; }
.cal-tg-now::before { content: ''; position: absolute; left: -3px; top: -4px; width: 7px; height: 7px; border-radius: 50%; background: var(--danger); }
@media (max-width: 560px) { .cal-tg { --tg-gut: 38px; } .cal-tg-ev-h { display: none; } }
/* Glisser-déposer (replanification) */
.cal-past[draggable="true"], .cal-tg-ev[draggable="true"] { cursor: grab; }
.cal-dragging { opacity: .45; }
.cal-cell.cal-drop, .cal-tg-col.cal-drop, .cal-tg-ad.cal-drop { background: color-mix(in srgb, var(--c-c) 14%, var(--card)) !important; outline: 2px dashed var(--c-c); outline-offset: -2px; }
/* Méthode des J — séries de réactivation */
.cal-j-intro { margin: 0 18px 10px; line-height: 1.5; }
.cal-j-body { padding: 0 18px; max-height: 52vh; overflow: auto; }
.cal-series { display: flex; flex-direction: column; gap: 8px; }
.cal-serie-l { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 9px 0; border-top: 1px solid var(--hairline); }
.cal-serie-l:first-child { border-top: none; }
.cal-serie-b { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.cal-serie-b b { font-family: var(--serif); font-size: 14.5px; }
.cal-serie-b span { font-size: 12px; }
.cal-serie-ech { font-family: var(--sans); font-variant-numeric: tabular-nums; color: var(--ink-soft); letter-spacing: .02em; }
.cal-serie-a { display: flex; gap: 5px; flex: 0 0 auto; }
.cal-j-ech { display: flex; flex-direction: column; gap: 7px; }
.cal-j-apercu { margin: 2px 0 0; font-size: 12px; line-height: 1.4; }
/* Réactivation (fait / report / ponts) */
.cal-dialog-react { width: min(480px, 94vw); }
.cal-react-body { padding: 0 18px 18px; display: flex; flex-direction: column; gap: 10px; }
.cal-react-meta { font-family: var(--sans); font-size: 13.5px; margin: 0; }
.cal-react-retard { color: var(--react-text); font-weight: 600; }
.cal-react-jf { display: inline-flex; align-items: center; gap: 8px; font-family: var(--sans); font-size: 13px; color: var(--ink); cursor: pointer; }
.cal-react-jf input { width: 16px; height: 16px; accent-color: var(--c-c); }
.cal-react-act { display: flex; gap: 8px; flex-wrap: wrap; }
.cal-react-notes { margin: 2px 0; }
/* série FSRS : 4 boutons de note (réutilise .fc-notes) */
.cal-react-fsrs-h { margin: 0 0 2px; font-size: 12.5px; }
.cal-react-pont-t { font-family: var(--sans); font-size: 11.5px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--ink-soft); margin: 6px 0 0; }
.cal-ponts { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.cal-pont { display: flex; flex-direction: column; align-items: flex-start; gap: 0; text-align: left; padding: 9px 12px; }
.cal-pont b { font-family: var(--sans); font-size: 13px; }
.cal-pont span { font-size: 11px; }
@media (max-width: 460px) { .cal-ponts { grid-template-columns: 1fr; } }
/*  Assistant IA du calendrier                                           */
/* ===================================================================== */
.cal-assist { color: var(--method); border-color: color-mix(in srgb, var(--method) 45%, var(--hairline)); background: color-mix(in srgb, var(--method) 7%, var(--card)); }
.cal-assist:hover { border-color: var(--method); background: color-mix(in srgb, var(--method) 12%, var(--card)); }
.cal-assist svg { width: 17px; height: 17px; }
.cal-dialog-ia { width: min(600px, 95vw); }
.cal-ia-ic { width: 20px; height: 20px; color: var(--method); vertical-align: -4px; margin-right: 4px; }
.cal-ia-note { margin: 0 18px 8px; }
.cal-ia-body { display: flex; flex-direction: column; gap: 11px; padding: 0 18px 18px; }
.cal-ia-nokey { display: flex; flex-direction: column; gap: 10px; align-items: flex-start; }
.cal-ia-nokey p { margin: 0; }
.cal-ia-sugg { display: flex; flex-wrap: wrap; gap: 6px; }
.cal-ia-chip { border: 1px solid var(--hairline); background: var(--card-2); border-radius: 18px; padding: 5px 11px; font-family: var(--sans); font-size: 12px; color: var(--ink); cursor: pointer; transition: border-color .12s; }
.cal-ia-chip:hover { border-color: var(--method); color: var(--method); }
.cal-ia-fil { display: flex; flex-direction: column; gap: 9px; max-height: 42vh; overflow-y: auto; padding: 2px; }
.cal-ia-fil:empty { display: none; }
.cal-ia-bulle { max-width: 92%; font-family: var(--sans); font-size: 13.5px; line-height: 1.5; }
.cal-ia-bulle p { margin: 0; }
.cal-ia-moi { align-self: flex-end; background: var(--c-surface); color: var(--c-on); border-radius: 13px 13px 4px 13px; padding: 8px 12px; }
.cal-ia-ia { align-self: flex-start; background: var(--card-2); border: 1px solid var(--hairline); border-radius: 13px 13px 13px 4px; padding: 10px 13px; width: 100%; }
.cal-ia-sys { align-self: center; }
.cal-ia-msg { margin: 0 0 8px !important; color: var(--ink); }
.cal-ia-err { color: var(--danger); display: flex; flex-direction: column; gap: 8px; align-items: flex-start; }
.cal-ia-err p { margin: 0; }
.cal-ia-ops { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
.cal-ia-op { display: flex; align-items: flex-start; gap: 9px; padding: 8px 10px; border: 1px solid var(--hairline); border-left-width: 3px; border-radius: 8px; cursor: pointer; background: var(--card); }
.cal-ia-op input { margin-top: 2px; width: 16px; height: 16px; flex: 0 0 auto; accent-color: var(--method); }
.cal-ia-op-d { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.cal-ia-op-d b { font-family: var(--sans); font-size: 13px; font-weight: 600; }
.cal-ia-op-d span { font-size: 11.5px; line-height: 1.4; }
.cal-ia-op-creer { border-left-color: var(--c-c); }
.cal-ia-op-modifier { border-left-color: var(--method); }
.cal-ia-op-supprimer { border-left-color: var(--danger); }
.cal-ia-op-serie { border-left-color: var(--gold); }
.cal-ia-actions { justify-content: flex-end; }
.cal-ia-undo { font-family: var(--sans); font-size: 12.5px; color: var(--ink-soft); display: flex; align-items: center; gap: 6px; }
.cal-ia-saisie { display: flex; flex-direction: column; gap: 7px; border-top: 1px solid var(--hairline); padding-top: 10px; }
.cal-ia-champ { width: 100%; resize: vertical; font-family: var(--sans); line-height: 1.45; }
.cal-ia-saisie-b { display: flex; align-items: center; gap: 8px; }
.cal-ia-spacer { flex: 1 1 auto; }
.cal-ia-img { display: inline-flex; align-items: center; gap: 4px; font-family: var(--sans); font-size: 12px; color: var(--ink-soft); }
.cal-ia-imgx { border: none; background: transparent; color: var(--ink-soft); cursor: pointer; font-size: 15px; line-height: 1; padding: 0 2px; }
.cal-ia-imgx:hover { color: var(--danger); }


/* ===== Lot 9 : le calendrier raffiné ===== */
/* Le marqueur des récurrents (agenda) : dessiné, discret */
.cal-ag-rec { display: inline-flex; margin-left: 6px; color: var(--ink-soft); vertical-align: -2px; }
.cal-ag-rec svg { width: 12px; height: 12px; }
/* La chip de cartes dues d'AUJOURD'HUI prime sur celles du futur */
.cal-auj-cell .cal-chip-fc { font-weight: 700; border-color: var(--c-line); }
/* Le dialog rejoint l'échelle d'élévation commune */
.cal-dialog { box-shadow: var(--elev-2); }
