:root {
    --rouge: #C0392B;
    --rouge-dark: #922B21;
    --bleu: #1A3A5C;
    --bleu-light: #2E6DA4;
    --gris: #F4F6F8;
    --gris-border: #D5D8DC;
    --blanc: #ffffff;
    --vert: #1E8449;
    --orange: #E67E22;
    --text: #2C3E50;
  }
  * { box-sizing: border-box; margin: 0; padding: 0; }
  body { font-family: 'Segoe UI', Arial, sans-serif; background: var(--gris); color: var(--text); font-size: 14px; }

  /* HEADER */
  .header {
    background: linear-gradient(135deg, var(--rouge) 0%, var(--rouge-dark) 60%, var(--bleu) 100%);
    color: white; padding: 14px 24px; display: flex; align-items: center; gap: 16px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.25); position: sticky; top: 0; z-index: 100;
  }
  .header-logo { font-size: 28px; }
  .header-title { flex: 1; }
  .header-title h1 { font-size: 17px; font-weight: 700; letter-spacing: 0.5px; }
  .header-title p { font-size: 11px; opacity: 0.85; margin-top: 2px; }
  .header-save { background: rgba(255,255,255,0.2); border: 1px solid rgba(255,255,255,0.4); color: white; padding: 7px 16px; border-radius: 6px; cursor: pointer; font-size: 12px; font-weight: 600; transition: background 0.2s; }
  .header-save:hover { background: rgba(255,255,255,0.35); }

  /* TABS */
  .tabs { display: flex; overflow-x: auto; background: var(--bleu); padding: 0 16px; gap: 2px; scrollbar-width: thin; }
  .tab { padding: 10px 16px; color: rgba(255,255,255,0.7); cursor: pointer; font-size: 12px; font-weight: 600; white-space: nowrap; border-bottom: 3px solid transparent; transition: all 0.2s; }
  .tab:hover { color: white; background: rgba(255,255,255,0.08); }
  .tab.active { color: white; border-bottom-color: var(--rouge); background: rgba(255,255,255,0.12); }

  /* PAGES */
  .page { display: none; padding: 20px; max-width: 1400px; margin: 0 auto; }
  .page.active { display: block; }

  /* CARDS */
  .card { background: white; border-radius: 10px; box-shadow: 0 1px 6px rgba(0,0,0,0.08); margin-bottom: 20px; overflow: hidden; }
  .card-header { background: var(--bleu); color: white; padding: 12px 18px; font-weight: 700; font-size: 13px; display: flex; align-items: center; gap: 8px; }
  .card-header .icon { font-size: 16px; }
  .card-body { padding: 18px; }

  /* FORM */
  .form-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 14px; }
  .form-group { display: flex; flex-direction: column; gap: 5px; }
  .form-group label { font-size: 11px; font-weight: 700; color: var(--bleu); text-transform: uppercase; letter-spacing: 0.5px; }
  .form-group input, .form-group select, .form-group textarea {
    border: 1px solid var(--gris-border); border-radius: 6px; padding: 8px 10px; font-size: 13px; color: var(--text);
    transition: border-color 0.2s; font-family: inherit; background: white;
  }
  .form-group input:focus, .form-group select:focus, .form-group textarea:focus { outline: none; border-color: var(--bleu-light); box-shadow: 0 0 0 3px rgba(46,109,164,0.1); }
  .form-group textarea { resize: vertical; min-height: 70px; }

  /* BUTTONS */
  .btn { padding: 8px 18px; border-radius: 6px; border: none; cursor: pointer; font-size: 13px; font-weight: 600; transition: all 0.2s; display: inline-flex; align-items: center; gap: 6px; }
  .btn-primary { background: var(--bleu-light); color: white; }
  .btn-primary:hover { background: var(--bleu); }
  .btn-success { background: var(--vert); color: white; }
  .btn-success:hover { background: #155D34; }
  .btn-danger { background: var(--rouge); color: white; }
  .btn-danger:hover { background: var(--rouge-dark); }
  .btn-warning { background: var(--orange); color: white; }
  .btn-warning:hover { background: #CA6F1E; }
  .btn-outline { background: white; color: var(--bleu); border: 1.5px solid var(--bleu); }
  .btn-outline:hover { background: var(--gris); }
  .btn-sm { padding: 5px 10px; font-size: 11px; }

  /* TABLES */
  .tbl { width: 100%; border-collapse: collapse; font-size: 13px; }
  .tbl th { background: var(--bleu); color: white; padding: 9px 12px; text-align: left; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px; }
  .tbl td { padding: 8px 12px; border-bottom: 1px solid var(--gris-border); vertical-align: middle; }
  .tbl tr:hover td { background: #EBF5FB; }
  .tbl tr:last-child td { border-bottom: none; }
  .tbl input[type="text"], .tbl input[type="number"], .tbl select {
    border: 1px solid var(--gris-border); border-radius: 4px; padding: 4px 7px; font-size: 12px; width: 100%; background: white;
  }
  .tbl input:focus, .tbl select:focus { outline: none; border-color: var(--bleu-light); }

  /* BADGE */
  .badge { padding: 3px 10px; border-radius: 20px; font-size: 11px; font-weight: 700; }
  .badge-green { background: #D5F5E3; color: var(--vert); }
  .badge-red { background: #FADBD8; color: var(--rouge); }
  .badge-blue { background: #D6EAF8; color: var(--bleu); }
  .badge-orange { background: #FDEBD0; color: var(--orange); }

  /* ACCUEIL */
  .accueil-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
  @media (max-width: 700px) { .accueil-grid { grid-template-columns: 1fr; } }

  .upload-zone {
    border: 2px dashed var(--gris-border); border-radius: 10px; padding: 30px 20px; text-align: center;
    cursor: pointer; transition: all 0.2s; background: var(--gris);
  }
  .upload-zone:hover, .upload-zone.drag-over { border-color: var(--bleu-light); background: #EBF5FB; }
  .upload-zone .icon { font-size: 36px; margin-bottom: 10px; }
  .upload-zone p { color: #7F8C8D; font-size: 13px; }
  .upload-zone strong { color: var(--bleu); }
  .uploaded-file { display: flex; align-items: center; gap: 10px; padding: 10px; background: #D5F5E3; border-radius: 6px; margin-top: 10px; font-size: 12px; }
  .uploaded-file .file-icon { font-size: 20px; }
  .uploaded-file .file-name { font-weight: 600; color: var(--vert); flex: 1; }
  .uploaded-file .remove-file { cursor: pointer; color: var(--rouge); font-size: 16px; }

  .stat-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 12px; margin-bottom: 20px; }
  .stat-card { background: white; border-radius: 8px; padding: 14px; text-align: center; box-shadow: 0 1px 4px rgba(0,0,0,0.07); }
  .stat-card .stat-val { font-size: 26px; font-weight: 700; color: var(--bleu); }
  .stat-card .stat-lbl { font-size: 11px; color: #7F8C8D; margin-top: 2px; }

  /* SECTIONS */
  .section-tabs { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 16px; }
  .section-tab { padding: 5px 12px; border-radius: 20px; font-size: 12px; font-weight: 600; cursor: pointer; border: 1.5px solid var(--gris-border); background: white; color: var(--text); transition: all 0.2s; }
  .section-tab.active { background: var(--bleu); color: white; border-color: var(--bleu); }
  .section-tab:hover:not(.active) { border-color: var(--bleu-light); color: var(--bleu); }

  /* RADIO page */
  .radio-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 16px; }
  .radio-card { background: white; border-radius: 8px; border: 2px solid var(--gris-border); padding: 16px; transition: border-color 0.2s; }
  .radio-card.assigned { border-color: var(--vert); }
  .radio-card .radio-num { font-size: 28px; font-weight: 700; color: var(--bleu); }
  .radio-card .radio-label { font-size: 12px; color: #7F8C8D; margin-bottom: 12px; }
  .radio-card .radio-pole { font-weight: 700; color: var(--bleu); font-size: 13px; margin-bottom: 8px; }
  .radio-card select { width: 100%; margin-bottom: 8px; }
  .radio-card input { width: 100%; }

  /* EVALUATEURS */
  .eval-sections { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 16px; }
  .eval-section { background: white; border-radius: 8px; border-left: 4px solid var(--bleu-light); padding: 14px; }
  .eval-section h4 { font-size: 13px; font-weight: 700; color: var(--bleu); margin-bottom: 10px; }

  /* BENEVOLES */
  .import-bar { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-bottom: 16px; }

  /* ORGA */
  .orga-day { background: white; border-radius: 8px; margin-bottom: 12px; overflow: hidden; border-left: 4px solid var(--bleu-light); }
  .orga-day-header { background: var(--bleu); color: white; padding: 10px 16px; font-weight: 700; font-size: 13px; }
  .orga-day-body { padding: 12px; }
  .orga-task { display: grid; grid-template-columns: 1fr 1fr auto; gap: 10px; align-items: center; padding: 6px 0; border-bottom: 1px solid var(--gris); }
  .orga-task:last-child { border-bottom: none; }

  /* AUTORITES */
  .presence-cb { width: 18px; height: 18px; cursor: pointer; accent-color: var(--vert); }
  .count-badge { background: var(--bleu); color: white; border-radius: 20px; padding: 4px 12px; font-size: 13px; font-weight: 700; }

  /* MODAL */
  .modal-bg { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 1000; display: none; align-items: center; justify-content: center; }
  .modal-bg.open { display: flex; }
  .modal { background: white; border-radius: 12px; padding: 24px; width: min(500px, 95vw); box-shadow: 0 10px 30px rgba(0,0,0,0.2); }
  .modal h3 { font-size: 16px; color: var(--bleu); margin-bottom: 16px; }
  .modal-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 20px; }

  /* TOAST */
  .toast { position: fixed; bottom: 24px; right: 24px; background: var(--vert); color: white; padding: 12px 20px; border-radius: 8px; font-weight: 600; font-size: 13px; z-index: 9999; transform: translateY(100px); opacity: 0; transition: all 0.3s; box-shadow: 0 4px 12px rgba(0,0,0,0.2); }
  .toast.show { transform: translateY(0); opacity: 1; }
  .toast.error { background: var(--rouge); }

  /* ANNUAIRE */
  .annuaire-section { margin-bottom: 20px; }
  .annuaire-section h3 { font-size: 12px; font-weight: 700; color: var(--rouge); text-transform: uppercase; letter-spacing: 0.8px; padding: 8px 0; border-bottom: 2px solid var(--rouge); margin-bottom: 8px; }

  .hidden { display: none !important; }
  .flex { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
  .mt-8 { margin-top: 8px; }
  .mt-16 { margin-top: 16px; }
  .text-muted { color: #7F8C8D; font-size: 12px; }
  .fw-bold { font-weight: 700; }
  hr { border: none; border-top: 1px solid var(--gris-border); margin: 16px 0; }

  /* ====== ONEDRIVE / CLOUD MODULE ====== */
  .cloud-status-bar {
    display: flex; align-items: center; gap: 10px; padding: 6px 20px;
    background: #0D1B2A; font-size: 12px; color: rgba(255,255,255,0.7);
  }
  .cloud-dot { width: 8px; height: 8px; border-radius: 50%; background: #666; flex-shrink: 0; transition: background 0.4s; }
  .cloud-dot.connected { background: #2ECC71; box-shadow: 0 0 7px #2ECC71; }
  .cloud-dot.syncing { background: #F39C12; animation: cpulse 1s infinite; }
  .cloud-dot.error { background: #E74C3C; }
  @keyframes cpulse { 0%,100%{opacity:1} 50%{opacity:0.25} }
  .cloud-status-label { font-size: 12px; color: rgba(255,255,255,0.75); flex: 1; }
  .cloud-status-label strong { color: white; }
  .cloud-btn-sm { background: rgba(255,255,255,0.15); border: 1px solid rgba(255,255,255,0.3); color: white; padding: 4px 12px; border-radius: 5px; cursor: pointer; font-size: 11px; font-weight: 600; transition: background 0.2s; }
  .cloud-btn-sm:hover { background: rgba(255,255,255,0.28); }

  .od-setup-box {
    background: linear-gradient(135deg, #0078D4 0%, #004578 100%);
    border-radius: 10px; padding: 26px; color: white; margin-bottom: 20px;
  }
  .od-setup-box h2 { font-size: 18px; margin-bottom: 6px; }
  .od-setup-box > p { font-size: 13px; opacity: 0.85; margin-bottom: 18px; line-height: 1.6; }
  .od-steps { display: grid; grid-template-columns: repeat(auto-fill, minmax(175px, 1fr)); gap: 12px; margin-bottom: 22px; }
  .od-step { background: rgba(255,255,255,0.12); border-radius: 8px; padding: 12px; }
  .od-step .sn { font-size: 22px; font-weight: 700; opacity: 0.55; line-height: 1; }
  .od-step p { font-size: 12px; opacity: 0.9; margin: 5px 0 0; }
  .od-field-row { display: flex; gap: 10px; align-items: flex-end; flex-wrap: wrap; }
  .od-field-row .form-group { flex: 1; min-width: 190px; }
  .od-field-row label { color: rgba(255,255,255,0.8) !important; font-size: 11px !important; }
  .od-field-row input { background: rgba(255,255,255,0.14) !important; border-color: rgba(255,255,255,0.3) !important; color: white !important; }
  .od-field-row input::placeholder { color: rgba(255,255,255,0.45) !important; }
  .od-field-row input:focus { background: rgba(255,255,255,0.22) !important; outline: none; border-color: rgba(255,255,255,0.6) !important; }

  .od-connected-box { background: white; border-radius: 10px; border: 2px solid #2ECC71; padding: 16px; margin-bottom: 20px; display: flex; align-items: center; gap: 14px; }
  .od-avatar { width: 44px; height: 44px; border-radius: 50%; background: #0078D4; color: white; display: flex; align-items: center; justify-content: center; font-size: 18px; font-weight: 700; flex-shrink: 0; }
  .od-user-info { flex: 1; }
  .od-user-info strong { display: block; font-size: 14px; color: var(--text); }
  .od-user-info span { font-size: 12px; color: #7F8C8D; }
  .od-folder-info { font-size: 12px; color: #0078D4; margin-top: 4px; font-weight: 600; }

  .sync-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(245px, 1fr)); gap: 14px; margin-bottom: 20px; }
  .sync-card { background: white; border-radius: 8px; border: 2px solid var(--gris-border); padding: 16px; transition: border-color 0.35s; }
  .sync-card h4 { font-size: 13px; font-weight: 700; color: var(--bleu); margin-bottom: 3px; }
  .sync-card .sync-meta { font-size: 11px; color: #7F8C8D; margin-bottom: 12px; min-height: 16px; }
  .sync-card .sync-actions { display: flex; gap: 7px; flex-wrap: wrap; }
  .sync-card.syncing { border-color: #F39C12; background: #FEFDF6; }
  .sync-card.synced { border-color: #2ECC71; }
  .sync-card.sync-error { border-color: #E74C3C; }
  .sync-progress { height: 3px; background: var(--gris-border); border-radius: 2px; margin-top: 10px; overflow: hidden; }
  .sync-progress-bar { height: 100%; background: #0078D4; width: 0; transition: width 0.5s; border-radius: 2px; }

  .od-log { background: #0D1117; border-radius: 8px; padding: 14px; font-family: 'Courier New', monospace; font-size: 11px; color: #8B949E; max-height: 210px; overflow-y: auto; }
  .log-line { padding: 2px 0; }
  .log-ok { color: #3FB950; }
  .log-err { color: #F85149; }
  .log-info { color: #58A6FF; }
  .log-warn { color: #E3B341; }
  .log-ts { color: #484F58; margin-right: 6px; }