    /* ── Programme tab ──────────────────────────────────────────────────────── */
    .prog-toolbar {
      display: flex;
      align-items: center;
      gap: 16px;
      padding: 14px 18px;
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: 10px;
      margin-bottom: 18px;
      flex-wrap: wrap;
    }
    .prog-week-nav {
      display: flex;
      align-items: center;
      gap: 8px;
    }
    .prog-week-btn {
      background: var(--surface-2);
      border: 1px solid var(--border);
      color: var(--text);
      width: 34px;
      height: 34px;
      border-radius: 6px;
      font-family: var(--font-head);
      font-size: 18px;
      font-weight: 700;
      cursor: pointer;
      transition: border-color 0.15s, color 0.15s;
    }
    .prog-week-btn:hover { border-color: var(--accent); color: var(--accent); }
    .prog-week-label {
      font-family: var(--font-head);
      font-size: 18px;
      font-weight: 700;
      color: var(--text);
      letter-spacing: 0.04em;
      min-width: 220px;
      text-align: center;
    }
    .prog-week-today {
      background: var(--surface-2);
      border: 1px solid var(--border);
      color: var(--text-dim);
      padding: 6px 12px;
      border-radius: 6px;
      font-family: var(--font-head);
      font-size: 13px;
      font-weight: 600;
      cursor: pointer;
      letter-spacing: 0.04em;
    }
    .prog-week-today:hover { border-color: var(--accent); color: var(--text); }
    .prog-legend {
      display: flex;
      gap: 14px;
      margin-left: auto;
      font-size: 13px;
      color: var(--text-dim);
      flex-wrap: wrap;
    }
    .prog-legend-item {
      display: flex;
      align-items: center;
      gap: 6px;
      font-family: var(--font-head);
      font-weight: 600;
      letter-spacing: 0.03em;
    }
    .prog-legend-swatch {
      width: 12px;
      height: 12px;
      border-radius: 3px;
    }


    .prog-layout {
      display: grid;
      grid-template-columns: 280px 1fr;
      gap: 18px;
      align-items: start;
    }


    /* Sidebar — modèle palette */
    .prog-sidebar {
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: 10px;
      padding: 14px;
      max-height: 720px;
      overflow-y: auto;
      position: sticky;
      top: 12px;
    }
    .prog-sidebar-title {
      font-family: var(--font-head);
      font-size: 13px;
      font-weight: 700;
      color: var(--text-dim);
      text-transform: uppercase;
      letter-spacing: 0.08em;
      margin-bottom: 10px;
      padding-bottom: 8px;
      border-bottom: 1px solid var(--border);
    }
    .prog-sidebar-hint {
      font-size: 12px;
      color: var(--text-dim);
      margin-bottom: 12px;
      line-height: 1.4;
      font-style: italic;
    }
    /* v45.6 — search box at top of Modèles list */
    .prog-modele-search-wrap {
      position: relative;
      margin-bottom: 10px;
    }
    .prog-modele-search {
      width: 100%;
      min-height: 36px;
      padding: 0 32px 0 12px;
      background: var(--bg);
      color: var(--text);
      border: 1px solid var(--border);
      border-radius: 6px;
      font-family: var(--font-body);
      font-size: var(--font-sm);
      outline: none;
      transition: border-color .15s;
    }
    .prog-modele-search::placeholder { color: var(--text-dim); }
    .prog-modele-search:focus { border-color: var(--accent); }
    .prog-modele-search:focus-visible {
      outline: 2px solid var(--accent);
      outline-offset: 1px;
    }
    .prog-modele-search-clear {
      position: absolute;
      right: 6px;
      top: 50%;
      transform: translateY(-50%);
      width: 24px;
      height: 24px;
      background: var(--border);
      color: var(--text);
      border: none;
      border-radius: 50%;
      cursor: pointer;
      font-size: 14px;
      line-height: 1;
      display: none;
      align-items: center;
      justify-content: center;
    }
    .prog-modele-search-clear:hover { background: var(--accent); color: #0d1117; }
    .prog-modele-search-clear.visible { display: flex; }
    .prog-modele-card {
      background: var(--surface-2);
      border: 1px solid var(--border);
      border-left: 4px solid var(--text-dim);
      border-radius: 6px;
      padding: 10px 12px;
      margin-bottom: 8px;
      cursor: grab;
      transition: border-color 0.15s, background 0.15s, transform 0.1s;
      user-select: none;
    }
    .prog-modele-card:hover { background: #1f2632; }
    .prog-modele-card:active { cursor: grabbing; }
    .prog-modele-card.dragging { opacity: 0.4; transform: scale(0.97); }
    .prog-modele-name {
      font-family: var(--font-head);
      font-size: 14px;
      font-weight: 700;
      color: var(--text);
      line-height: 1.25;
      margin-bottom: 4px;
    }
    .prog-modele-meta {
      font-size: 11px;
      color: var(--text-dim);
      font-family: var(--font-head);
      letter-spacing: 0.04em;
      text-transform: uppercase;
    }


    /* Antenne colour borders for modèle cards */
    .prog-ant-CHA { border-left-color: #f0a500; }
    .prog-ant-BRE { border-left-color: #3a9bd5; }
    .prog-ant-DZ  { border-left-color: #2ea84b; }


    /* Week grid */
    .prog-week-grid {
      display: grid;
      grid-template-columns: repeat(7, 1fr);
      gap: 8px;
      min-height: 600px;
    }
    .prog-day {
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: 8px;
      display: flex;
      flex-direction: column;
      min-height: 600px;
      transition: border-color 0.15s, background 0.15s;
    }
    .prog-day.today { border-color: var(--accent); }
    .prog-day.drop-target {
      background: #1a2536;
      border-color: var(--accent);
      border-style: dashed;
    }
    .prog-day-header {
      padding: 8px 10px;
      border-bottom: 1px solid var(--border);
      display: flex;
      justify-content: space-between;
      align-items: baseline;
    }
    .prog-day-name {
      font-family: var(--font-head);
      font-size: 13px;
      font-weight: 700;
      color: var(--text);
      text-transform: uppercase;
      letter-spacing: 0.06em;
    }
    .prog-day.today .prog-day-name { color: var(--accent); }
    .prog-day-date {
      font-family: var(--font-head);
      font-size: 12px;
      color: var(--text-dim);
      font-weight: 600;
    }
    .prog-day-body {
      flex: 1;
      padding: 6px;
      display: flex;
      flex-direction: column;
      gap: 6px;
    }
    .prog-day-empty {
      flex: 1;
      display: flex;
      align-items: center;
      justify-content: center;
      color: var(--text-dim);
      font-size: 11px;
      font-style: italic;
      opacity: 0.4;
      text-align: center;
      padding: 12px 6px;
      pointer-events: none;
    }


    /* ── Day half splits (Matin / Après-midi) ─────────────────────────────── */
    .prog-day-body {
      flex: 1;
      padding: 0;
      display: grid;
      grid-template-rows: 1fr 1fr;
      gap: 0;
      min-height: 0;
    }
    .prog-day-half {
      min-height: 0;
      display: flex;
      flex-direction: column;
      padding: 4px 5px 6px;
      transition: background 0.12s;
      position: relative;
      overflow: hidden;
    }
    .prog-day-half.am { border-bottom: 1px dashed var(--border); }
    .prog-day-half.drop-target {
      background: #1a2536;
      box-shadow: inset 0 0 0 1px var(--accent);
    }
    .prog-day-half-label {
      font-family: var(--font-head);
      font-size: 10px;
      font-weight: 700;
      color: var(--text-dim);
      text-transform: uppercase;
      letter-spacing: 0.08em;
      opacity: 0.7;
      margin-bottom: 4px;
      flex-shrink: 0;
    }
    .prog-day-half-body {
      flex: 1;
      display: flex;
      flex-direction: column;
      gap: 5px;
      min-height: 0;
      overflow-y: auto;
      overflow-x: hidden;
      position: relative;
      /* Custom scrollbar so users see they can scroll */
      scrollbar-width: thin;
      scrollbar-color: var(--border) transparent;
    }
    .prog-day-half-body::-webkit-scrollbar { width: 6px; }
    .prog-day-half-body::-webkit-scrollbar-track { background: transparent; }
    .prog-day-half-body::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }
    .prog-day-half-body::-webkit-scrollbar-thumb:hover { background: var(--text-dim); }
    .prog-day-half-empty {
      position: absolute;
      inset: 0;
      display: flex;
      align-items: center;
      justify-content: center;
      color: var(--text-dim);
      font-size: 10px;
      opacity: 0.25;
      pointer-events: none;
    }


    /* Tournée cards on the grid */
    .prog-tournee-card {
      background: var(--surface-2);
      border: 1px solid var(--border);
      border-left: 5px solid var(--text-dim);
      border-radius: 5px;
      padding: 7px 9px;
      cursor: pointer;
      transition: border-color 0.15s, background 0.15s;
    }
    .prog-tournee-card:hover { background: #1f2632; }
    .prog-tournee-card.statut-terminee  { opacity: 0.7; }
    .prog-tournee-card.statut-encours   { border-color: var(--blue); }
    .prog-tournee-name {
      font-family: var(--font-head);
      font-size: 12px;
      font-weight: 700;
      color: var(--text);
      line-height: 1.25;
      margin-bottom: 3px;
      word-break: break-word;
    }
    .prog-tournee-chauf {
      font-size: 11px;
      color: var(--text-dim);
      margin-bottom: 4px;
    }
    .prog-tournee-time {
      display: inline-block;
      font-family: var(--font-mono);
      font-size: 11px;
      font-weight: 600;
      color: var(--accent);
      margin-bottom: 4px;
    }
    .prog-tournee-statut {
      display: inline-block;
      font-family: var(--font-head);
      font-size: 10px;
      font-weight: 700;
      padding: 2px 6px;
      border-radius: 3px;
      text-transform: uppercase;
      letter-spacing: 0.04em;
    }
    .prog-statut-planif   { background: #1e2530; color: #9eb3c2; border: 1px solid #2a3140; }
    .prog-statut-encours  { background: #0d2035; color: #3a9bd5; border: 1px solid #3a9bd5; }
    .prog-statut-terminee { background: #0e2e1a; color: #2ea84b; border: 1px solid #2ea84b; }


    /* Modal — assignment + actions */
    .prog-modal-backdrop {
      display: none;
      position: fixed;
      inset: 0;
      background: rgba(13, 17, 23, 0.45);
      backdrop-filter: blur(0px);
      z-index: 10000;
      align-items: center;
      justify-content: center;
      padding: 16px;
    }
    .prog-modal-backdrop.visible { display: flex; }
    .prog-modal {
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: 12px;
      width: 100%;
      max-width: 460px;
      max-height: 92vh;
      display: flex;
      flex-direction: column;
      box-shadow: 0 8px 40px rgba(0,0,0,0.6);
      overflow: hidden;
    }
    .prog-modal-header {
      padding: 14px 18px;
      border-bottom: 1px solid var(--border);
      display: flex;
      justify-content: space-between;
      align-items: center;
    }
    .prog-modal-title {
      font-family: var(--font-head);
      font-size: 16px;
      font-weight: 700;
      color: var(--text);
      text-transform: uppercase;
      letter-spacing: 0.06em;
    }
    .prog-modal-close {
      background: none;
      border: none;
      color: var(--text-dim);
      font-size: 24px;
      cursor: pointer;
      line-height: 1;
      padding: 0 4px;
    }
    .prog-modal-close:hover { color: var(--accent); }
    .prog-modal-body { padding: 18px; flex: 1; overflow-y: auto; min-height: 0; }
    .prog-modal-row { margin-bottom: 14px; }
    .prog-modal-label {
      font-family: var(--font-head);
      font-size: 12px;
      font-weight: 700;
      color: var(--text-dim);
      text-transform: uppercase;
      letter-spacing: 0.06em;
      margin-bottom: 6px;
      display: block;
    }
    .prog-modal-value {
      font-family: var(--font-head);
      font-size: 15px;
      font-weight: 600;
      color: var(--text);
    }
    .prog-modal-select {
      width: 100%;
      background: var(--surface-2);
      border: 1px solid var(--border);
      color: var(--text);
      padding: 9px 12px;
      border-radius: 6px;
      font-family: var(--font-body);
      font-size: 14px;
      cursor: pointer;
    }
    .prog-modal-select:focus { outline: none; border-color: var(--accent); }
    .prog-modal-footer {
      padding: 14px 18px;
      border-top: 1px solid var(--border);
      display: flex;
      gap: 10px;
      justify-content: flex-end;
    }
    .prog-btn {
      font-family: var(--font-head);
      font-size: 14px;
      font-weight: 700;
      padding: 9px 18px;
      border-radius: 6px;
      cursor: pointer;
      text-transform: uppercase;
      letter-spacing: 0.05em;
      border: 1px solid transparent;
      transition: all 0.15s;
    }
    .prog-btn-primary {
      background: var(--accent);
      color: #0d1117;
    }
    .prog-btn-primary:hover { background: #ffb820; }
    .prog-btn-primary:disabled { background: var(--surface-2); color: var(--text-dim); cursor: not-allowed; }
    .prog-btn-ghost {
      background: var(--surface-2);
      color: var(--text);
      border-color: var(--border);
    }
    .prog-btn-ghost:hover { border-color: var(--accent); }
    .prog-btn-danger {
      background: #2e0d0d;
      color: #ff6b6b;
      border-color: var(--red);
    }
    .prog-btn-danger:hover { background: var(--red); color: #fff; }


    .prog-modal-error {
      background: #2e0d0d;
      border: 1px solid var(--red);
      color: #ff6b6b;
      padding: 10px 12px;
      border-radius: 6px;
      font-size: 13px;
      margin-bottom: 12px;
    }
    .prog-modal-info {
      background: #1a2536;
      border: 1px solid #3a9bd5;
      color: #9eccdc;
      padding: 10px 12px;
      border-radius: 6px;
      font-size: 13px;
      margin-bottom: 12px;
      line-height: 1.4;
    }


    /* Action menu (click an existing tournée) */
    .prog-action-list {
      display: flex;
      flex-direction: column;
      gap: 8px;
    }
    .prog-action-btn {
      width: 100%;
      text-align: left;
      background: var(--surface-2);
      border: 1px solid var(--border);
      color: var(--text);
      padding: 12px 14px;
      border-radius: 6px;
      font-family: var(--font-head);
      font-size: 14px;
      font-weight: 600;
      cursor: pointer;
      letter-spacing: 0.03em;
      transition: border-color 0.15s, background 0.15s;
    }
    .prog-action-btn:hover { border-color: var(--accent); background: #1f2632; }
    .prog-action-btn.danger { color: #ff6b6b; border-color: var(--border); }
    .prog-action-btn.danger:hover { border-color: var(--red); background: #2e0d0d; }
    .prog-action-btn:disabled { opacity: 0.4; cursor: not-allowed; }


    /* Programme — responsive */
    @media (max-width: 1100px) {
      .prog-layout { grid-template-columns: 240px 1fr; }
    }
    @media (max-width: 900px) {
      .prog-layout { grid-template-columns: 1fr; }
      .prog-sidebar { position: static; max-height: 280px; }
      .prog-week-grid { grid-template-columns: repeat(2, 1fr); }
      .prog-day { min-height: 200px; }
      /* On touch, drag-drop is unreliable — we surface a tap-to-add button via JS */
      .prog-modele-card { cursor: pointer; }
    }
    @media (max-width: 600px) {
      .prog-week-grid { grid-template-columns: 1fr; }
      .prog-toolbar { padding: 10px 12px; gap: 10px; }
      .prog-week-label { font-size: 16px !important; min-width: 0; flex: 1; }
      .prog-legend { display: none; }
    }

    /* ── Laptop breakpoint — matches base.css 1400px fix ─────────────────── */
 @media (max-width: 1800px) {
  .prog-layout          { grid-template-columns: 220px 1fr; }
  .prog-week-grid       { grid-template-columns: repeat(7, minmax(0, 1fr)); }
  .prog-tournee-name    { font-size: 11px; }
  .prog-tournee-chauf   { font-size: 10px; }
  .prog-day-name        { font-size: 11px; }
  .prog-day-date        { font-size: 11px; }
  .prog-week-label      { font-size: 15px; min-width: 180px; }
  .prog-sidebar         { max-height: 600px; }
}

