/* ============================================================
   City Challenge Admin — style.css
   ============================================================ */

*{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#ffffff;
  --bg2:#f5f6f8;
  --bg3:#eef0f3;
  --txt:#1a1a2e;
  --txt2:#5a6478;
  --txt3:#9aa0ae;
  --border:#e2e5ea;
  --border2:#c8cdd6;
  --blue:#2563eb;
  --blue-light:#eff6ff;
  --blue-mid:#bfdbfe;
  --green:#16a34a;
  --green-light:#f0fdf4;
  --green-mid:#bbf7d0;
  --amber:#d97706;
  --amber-light:#fffbeb;
  --amber-mid:#fde68a;
  --red:#dc2626;
  --red-light:#fef2f2;
  --red-mid:#fecaca;
  --purple:#7c3aed;
  --purple-light:#f5f3ff;
  --purple-mid:#ddd6fe;
  --teal:#0d9488;
  --teal-light:#f0fdfa;
  --teal-mid:#99f6e4;
  --radius:8px;
  --radius-lg:12px;
  --shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.05);
}

body{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  background:var(--bg2);
  color:var(--txt);
  font-size:13px;
  min-height:100vh;
}

/* ── APP SHELL ─────────────────────────────────────────────── */
.app{display:flex;height:100vh;overflow:hidden}

/* ── SIDEBAR ───────────────────────────────────────────────── */
.sidebar{
  width:224px;
  background:var(--bg);
  border-right:1px solid var(--border);
  display:flex;
  flex-direction:column;
  flex-shrink:0;
}
.sidebar-logo{
  padding:16px;
  border-bottom:1px solid var(--border);
  font-weight:700;
  font-size:15px;
  color:var(--txt);
  display:flex;
  align-items:center;
  gap:10px;
}
.logo-icon{
  width:30px;height:30px;
  background:var(--blue);
  border-radius:7px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.logo-icon svg{width:16px;height:16px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.logo-sub{font-size:11px;font-weight:400;color:var(--txt3)}
.sidebar-nav{flex:1;padding:8px;overflow-y:auto}
.nav-section{
  font-size:10px;font-weight:600;color:var(--txt3);
  letter-spacing:.8px;text-transform:uppercase;
  padding:12px 8px 4px;
}
.nav-item{
  display:flex;align-items:center;gap:8px;
  padding:7px 8px;border-radius:var(--radius);
  cursor:pointer;color:var(--txt2);
  transition:all .15s;font-size:12px;font-weight:500;
}
.nav-item:hover{background:var(--bg2);color:var(--txt)}
.nav-item.active{background:var(--blue-light);color:var(--blue)}
.nav-item svg{width:14px;height:14px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.sidebar-footer{
  padding:12px;
  border-top:1px solid var(--border);
}
.user-badge{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--txt2)}
.user-avatar{
  width:28px;height:28px;border-radius:50%;
  background:var(--blue);color:#fff;
  font-weight:700;font-size:11px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}

/* ── MAIN ──────────────────────────────────────────────────── */
.main{flex:1;overflow:hidden;display:flex;flex-direction:column}

/* ── TOPBAR ────────────────────────────────────────────────── */
.topbar{
  background:var(--bg);
  border-bottom:1px solid var(--border);
  padding:0 20px;height:52px;
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;
  position:relative;z-index:151;
}
.topbar-left{display:flex;align-items:center;gap:12px}
.page-title{font-size:15px;font-weight:600;color:var(--txt)}
.topbar-actions{display:flex;gap:8px}

/* ── BUTTONS ───────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;border-radius:var(--radius);
  font-size:12px;font-weight:500;cursor:pointer;
  border:1px solid var(--border2);
  background:var(--bg);color:var(--txt);
  transition:all .15s;line-height:1;
}
.btn:hover{background:var(--bg2)}
.btn.primary{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn.primary:hover{background:#1d4ed8}
.btn.success{background:var(--green);color:#fff;border-color:var(--green)}
.btn.success:hover{background:#15803d}
.btn.danger{background:var(--red-light);color:var(--red);border-color:var(--red-mid)}
.btn.danger:hover{background:var(--red-mid)}
.btn.secondary{background:var(--bg2);color:var(--txt2);border-color:var(--border)}
.btn.secondary:hover{background:var(--border);color:var(--txt)}
.btn.sm{padding:4px 10px;font-size:11px}
.btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round}

/* ── CONTENT ───────────────────────────────────────────────── */
.content{flex:1;overflow-y:auto;padding:20px}
.panel{display:none}
.panel.active{display:block}

/* ── STATS ─────────────────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.stats-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.stat-card{
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:14px 16px;
}
.stat-label{font-size:11px;color:var(--txt3);font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.stat-val{font-size:24px;font-weight:700;color:var(--txt);line-height:1}
.stat-sub{font-size:11px;color:var(--txt3);margin-top:4px}

/* ── CARDS ─────────────────────────────────────────────────── */
.card{
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--radius-lg);overflow:hidden;margin-bottom:16px;
}
.card-header{
  padding:12px 16px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}
.card-title{font-size:13px;font-weight:600;color:var(--txt)}
.card-body{padding:16px}

/* ── TABLES ────────────────────────────────────────────────── */
table{width:100%;border-collapse:collapse}
thead th{
  background:var(--bg2);padding:8px 14px;
  text-align:left;font-size:11px;font-weight:600;
  color:var(--txt2);text-transform:uppercase;letter-spacing:.5px;
  border-bottom:1px solid var(--border);
}
tbody tr{border-bottom:1px solid var(--border);transition:background .1s;cursor:pointer}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:var(--bg2)}
tbody td{padding:10px 14px;font-size:12px;color:var(--txt)}

/* ── BADGES ────────────────────────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 8px;border-radius:50px;
  font-size:10px;font-weight:600;
}
.badge-green{background:var(--green-light);color:var(--green)}
.badge-amber{background:var(--amber-light);color:var(--amber)}
.badge-red{background:var(--red-light);color:var(--red)}
.badge-blue{background:var(--blue-light);color:var(--blue)}
.badge-purple{background:var(--purple-light);color:var(--purple)}
.badge-gray{background:var(--bg3);color:var(--txt2)}

/* ── FORMS ─────────────────────────────────────────────────── */
.field{margin-bottom:12px}
.field label{
  display:block;font-size:11px;font-weight:600;
  color:var(--txt2);margin-bottom:4px;
  text-transform:uppercase;letter-spacing:.4px;
}
.field input,.field select,.field textarea{
  width:100%;padding:7px 10px;
  border:1px solid var(--border2);border-radius:var(--radius);
  font-size:12px;color:var(--txt);background:var(--bg);
  outline:none;transition:border-color .15s;
  font-family:inherit;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--blue)}
.field textarea{resize:vertical;min-height:60px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.field-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.field input[type=color]{height:34px;padding:3px 6px;cursor:pointer}

/* ── GAME EDITOR LAYOUT — resizable ────────────────────────── */
/* ── ÉDITEUR — layout flex avec séparateur redimensionnable ── */
.editor-layout{
  display:flex;
  gap:0;
  align-items:stretch; /* tous les enfants s'étirent à la même hauteur */
}

#editor-left-panel{
  width:320px;
  flex-shrink:0;
  display:flex;flex-direction:column;gap:16px;
  min-width:200px;max-width:560px;
}

/* ── RESIZE HANDLE — flex item normal, toujours visible ── */
.editor-resize-handle{
  flex-shrink:0;
  width:14px;
  min-height:400px;   /* visible même si le contenu est court */
  cursor:col-resize;
  user-select:none;
  background:#e2e8f0;
  border-left:2px solid #cbd5e1;
  border-right:2px solid #cbd5e1;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .12s, border-color .12s;
  position:relative;
  z-index:5;
}
.editor-resize-handle::after{
  content:'⋮';
  font-size:18px;
  color:#94a3b8;
  line-height:1;
  pointer-events:none;
  letter-spacing:-2px;
}
.editor-resize-handle:hover{
  background:#bfdbfe;
  border-color:#60a5fa;
}
.editor-resize-handle:hover::after{ color:#2563eb; }
.editor-resize-handle.dragging{
  background:#bfdbfe;
  border-color:#2563eb;
}
.editor-resize-handle.dragging::after{ color:#2563eb; }

/* Right panel */
.editor-right{ flex:1; min-width:0; padding-left:12px; }

.game-meta-card{
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:16px;
}
.card-section-title{
  font-size:12px;font-weight:600;color:var(--txt);
  margin-bottom:14px;
  display:flex;align-items:center;justify-content:space-between;
}

/* ── LOCATIONS GRID ────────────────────────────────────────── */
.locations-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:12px;
}
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.loc-chip{
  padding:6px 9px;border-radius:8px;
  cursor:pointer;border:2px solid transparent;
  transition:all .15s;
  /* min-width supprimé — la grille 1fr 1fr impose l'égalité */
  position:relative;user-select:none;
  box-sizing:border-box;width:100%;
}
.loc-chip:hover{filter:brightness(.92)}
.loc-chip.selected{
  border-color:#fff;
  box-shadow:0 0 0 3px var(--blue), 0 3px 10px rgba(37,99,235,.35);
  transform:scale(1.04);
  z-index:1;
  position:relative;
  animation:chip-pulse 2s ease-in-out infinite;
}
@keyframes chip-pulse{
  0%,100%{box-shadow:0 0 0 3px var(--blue), 0 3px 10px rgba(37,99,235,.35)}
  50%     {box-shadow:0 0 0 4px var(--blue), 0 3px 14px rgba(37,99,235,.55)}
}
.loc-chip-id{font-size:10px;font-weight:700;opacity:.7;display:flex;justify-content:space-between;align-items:center;gap:4px}
.loc-chip-pts{font-size:9px;font-weight:800;opacity:.85;background:rgba(0,0,0,.18);border-radius:3px;padding:1px 4px;white-space:nowrap;letter-spacing:.3px}
.loc-chip-name{font-size:11px;font-weight:600;line-height:1.3;margin-top:1px}
.loc-chip-badges{display:flex;gap:3px;flex-wrap:wrap;margin-top:4px}
.lbadge{
  width:14px;height:14px;border-radius:3px;
  font-size:8px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  color:#fff;
}
.lb-Q{background:rgba(37,99,235,.7)}
.lb-P{background:rgba(22,163,74,.7)}
.lb-V{background:rgba(124,58,237,.7)}
.lb-I{background:rgba(217,119,6,.7)}
.lb-H{background:rgba(0,0,0,.4)}
.loc-chip.loc-hidden{opacity:.4}
.loc-chip.loc-end{outline:3px solid var(--red);outline-offset:1px}
.loc-chip.loc-start{outline:3px solid var(--blue);outline-offset:1px}
.loc-chip.loc-bonus{
  outline:3px solid #f59e0b;
  outline-offset:1px;
  position:relative;
}
.loc-chip.loc-bonus::after{
  content:'★';
  position:absolute;top:-7px;right:-7px;
  font-size:11px;line-height:1;
  color:#f59e0b;
  text-shadow:0 0 4px rgba(245,158,11,.4);
}

/* ── LOCATION DETAIL ───────────────────────────────────────── */
.loc-detail{
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:16px;
}
.loc-detail-header{
  display:flex;align-items:flex-start;justify-content:space-between;
  margin-bottom:14px;padding-bottom:12px;
  border-bottom:1px solid var(--border);
}
.section-sub{
  font-size:11px;font-weight:600;color:var(--txt3);
  text-transform:uppercase;letter-spacing:.5px;
  margin-bottom:8px;margin-top:14px;
  display:flex;align-items:center;justify-content:space-between;
}

/* ── ACTIONS LIST ──────────────────────────────────────────── */
.actions-list{display:flex;flex-direction:column;gap:8px;margin-top:4px}
/* ── ACTION CARDS (modern) ──────────────────────────────────── */
.action-item{
  background:var(--bg);
  border:none;
  border-radius:10px;
  box-shadow:0 1px 4px rgba(0,0,0,.07),0 0 0 1px rgba(0,0,0,.05);
  overflow:hidden;
  margin-bottom:8px;
  position:relative;
  transition:box-shadow .15s;
}
.action-item:hover{box-shadow:0 4px 14px rgba(0,0,0,.1),0 0 0 1px rgba(0,0,0,.07);}

/* Couleur de fond par type — header teinté, body très subtil */
.t-question .action-header{background:var(--blue-mid)}
.t-open     .action-header{background:var(--teal-mid)}
.t-photo    .action-header{background:var(--green-mid)}
.t-video    .action-header{background:var(--purple-mid)}
.t-info     .action-header{background:var(--amber-mid)}

.t-question .action-header:hover{background:#93c5fd}
.t-open     .action-header:hover{background:#5eead4}
.t-photo    .action-header:hover{background:#86efac}
.t-video    .action-header:hover{background:#c4b5fd}
.t-info     .action-header:hover{background:#fcd34d}

/* Fond très léger sur le body */
.t-question .action-body{background:rgba(37,99,235,.07)}
.t-open     .action-body{background:rgba(13,148,136,.07)}
.t-photo    .action-body{background:rgba(22,163,74,.07)}
.t-video    .action-body{background:rgba(124,58,237,.07)}
.t-info     .action-body{background:rgba(217,119,6,.07)}

/* Bande colorée gauche — toujours présente */
.action-item::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:4px;
}
.t-question::before{background:var(--blue)}
.t-open::before    {background:var(--teal)}
.t-photo::before   {background:var(--green)}
.t-video::before   {background:var(--purple)}
.t-info::before    {background:var(--amber)}

.action-header{
  padding:12px 14px 12px 20px;
  display:flex;align-items:center;gap:10px;
  cursor:pointer;user-select:none;
  background:var(--bg);
  transition:background .12s;
}
.action-header:hover{background:var(--bg2)}

.action-type-badge{
  padding:4px 11px;border-radius:50px;
  font-size:10px;font-weight:800;
  text-transform:uppercase;letter-spacing:.6px;flex-shrink:0;
}
.at-question{background:var(--blue);color:#fff}
.at-photo   {background:var(--green);color:#fff}
.at-video   {background:var(--purple);color:#fff}
.at-info    {background:var(--amber);color:#fff}
.at-open    {background:var(--teal);color:#fff}


/* ── BOUTONS AJOUT D'ACTION ─────────────────────────────────────── */
.action-add-btn{
  padding:7px 15px;
  font-size:12px;font-weight:700;
  border-radius:8px;border:none;
  cursor:pointer;letter-spacing:.3px;
  transition:filter .15s, transform .1s;
  color:#fff;
}
.action-add-btn:hover{filter:brightness(1.12);transform:translateY(-1px);}
.action-add-btn:active{transform:translateY(0);}
.action-add-question{background:var(--blue);}
.action-add-open    {background:var(--teal);}
.action-add-photo   {background:var(--green);}
.action-add-video   {background:var(--purple);}
.action-add-info    {background:var(--amber);}

.action-label{flex:1;font-size:12px;font-weight:500;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.action-pts-badge{
  background:var(--bg2);border:1px solid var(--border);
  padding:2px 9px;border-radius:50px;
  font-size:11px;font-weight:700;color:var(--txt2);flex-shrink:0;
}

.action-chevron{
  font-size:9px;color:var(--txt3);flex-shrink:0;
  transition:transform .2s ease;
  transform:rotate(0deg);
  line-height:1;margin-right:2px;
}
.action-chevron.open{transform:rotate(90deg);}

.action-body{
  display:none;
  border-top:2px solid rgba(0,0,0,.06);
  animation:slideDown .18s ease;
}
.action-body.open{display:block}
@keyframes slideDown{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}

/* Sections internes */
.af-section{padding:12px 18px 8px;border-bottom:1px solid var(--border)}
.af-section:last-child{border-bottom:none;padding-bottom:14px}
.af-section-title{
  font-size:9px;font-weight:800;color:var(--txt3);
  text-transform:uppercase;letter-spacing:1px;
  display:flex;align-items:center;gap:8px;
  margin-bottom:10px;
}
.af-section-title::after{content:'';flex:1;height:1px;background:var(--border)}

/* Champs compacts en ligne */
.af-inline{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.af-inline .af{flex:1;min-width:70px;margin-bottom:0}
.af-inline input[type=number]{width:100%}

/* Question choices */
.question-choices{display:flex;flex-direction:column;gap:5px;margin-top:6px}
.choice-row{display:flex;align-items:center;gap:8px}
.choice-row input[type=radio]{flex-shrink:0;accent-color:var(--green);cursor:pointer}
.choice-row input[type=text]{
  flex:1;padding:5px 8px;
  border:1px solid var(--border2);border-radius:5px;
  font-size:11px;color:var(--txt);background:var(--bg);
  outline:none;
}
.choice-row input[type=text]:focus{border-color:var(--blue)}
.choice-correct{border-color:var(--green)!important;background:var(--green-light)!important}
.choice-del-btn{
  flex-shrink:0;
  background:none;border:none;cursor:pointer;
  color:#94a3b8;font-size:14px;line-height:1;padding:0 4px;
  border-radius:4px;transition:color .12s,background .12s;
}
.choice-del-btn:hover{color:#dc2626;background:#fee2e2;}

.choice-add-btn{
  margin-top:6px;
  background:none;border:1px dashed #94a3b8;color:#475569;
  padding:5px 12px;border-radius:6px;font-size:11px;font-weight:600;
  cursor:pointer;width:100%;transition:border-color .12s,color .12s,background .12s;
}
.choice-add-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light);}

.choice-hint{font-size:10px;color:var(--txt3);margin-top:4px}

/* GPS field */
.gps-field{display:flex;gap:8px;align-items:center}
.gps-field input{
  flex:1;padding:6px 10px;
  border:1px solid var(--border2);border-radius:var(--radius);
  font-size:11px;color:var(--txt);background:var(--bg);outline:none;
}
.gps-field input:focus{border-color:var(--blue)}
.gps-tag{font-size:10px;color:var(--txt3);font-weight:600;min-width:24px}

/* Visibility rule */
.vis-rule-box{
  display:flex;align-items:flex-start;gap:8px;
  padding:8px 10px;background:var(--amber-light);
  border:1px solid var(--amber-mid);border-radius:var(--radius);
  font-size:11px;color:var(--amber);margin-top:6px;
}
.vis-rule-box svg{width:14px;height:14px;flex-shrink:0;margin-top:1px}

/* Color preview */
.color-preview{width:22px;height:22px;border-radius:4px;border:1px solid var(--border2);flex-shrink:0}

/* ── SESSIONS ──────────────────────────────────────────────── */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}
.team-card{
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--radius);padding:12px;
}
.team-card-name{font-weight:600;font-size:12px;color:var(--txt);margin-bottom:4px}
.team-card-score{font-size:20px;font-weight:700;color:var(--blue);line-height:1.2;transition:color .2s}
@keyframes score-bump{0%{transform:scale(1)}40%{transform:scale(1.25);color:#16a34a}100%{transform:scale(1)}}
.team-card-score.bumped{animation:score-bump .5s ease-out;display:inline-block}
.team-progress{height:4px;background:var(--bg3);border-radius:2px;margin-top:6px;overflow:hidden}
.team-bar{height:100%;background:var(--blue);border-radius:2px;transition:width .3s}
.live-feed-item{
  display:flex;gap:10px;padding:9px 0;
  border-bottom:1px solid var(--border);font-size:12px;
}
.live-feed-item:last-child{border-bottom:none}
.live-time{color:var(--txt3);font-variant-numeric:tabular-nums;flex-shrink:0}

/* ── REPORTS ───────────────────────────────────────────────── */
.report-row{
  display:grid;grid-template-columns:1fr 110px 70px 65px 65px 80px;
  gap:10px;align-items:center;padding:10px 14px;
  border-bottom:1px solid var(--border);font-size:12px;
  transition:background .15s;
}
.report-row:hover{background:var(--bg2);}
.report-header{
  display:grid;grid-template-columns:1fr 110px 70px 65px 65px 80px;
  gap:10px;padding:8px 14px;background:var(--bg2);
  border-bottom:1px solid var(--border);
  font-size:10px;font-weight:600;color:var(--txt2);
  text-transform:uppercase;letter-spacing:.5px;
}

/* Détail équipe (accordéon) */
.report-detail{
  background:var(--bg);border-bottom:2px solid var(--border);
  padding:0 14px 10px;
}
.report-step-block{
  margin:10px 0 0;border:1px solid var(--border);border-radius:8px;overflow:hidden;
}
.report-step-head{
  display:flex;align-items:center;gap:8px;
  padding:8px 12px;background:var(--bg2);font-size:12px;
}
.report-step-pts{margin-left:auto;font-weight:700;color:var(--blue);white-space:nowrap;}
.report-step-time{color:var(--txt3);font-size:11px;white-space:nowrap;margin-left:8px;}
.report-actions-list{padding:6px 12px 8px;}
.report-action-line{
  display:flex;align-items:center;gap:6px;
  padding:4px 0;border-bottom:1px solid var(--border);font-size:11px;
}
.report-action-line:last-child{border-bottom:none;}
.ra-ok{color:var(--green);font-weight:700;flex-shrink:0;}
.ra-err{color:var(--red);font-weight:700;flex-shrink:0;}
.ra-label{color:var(--txt2);white-space:nowrap;}
.ra-answer{color:var(--txt);font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:260px;}
.ra-tries{background:#e0e7ff;color:#4338ca;border-radius:4px;padding:1px 5px;font-size:10px;font-weight:600;white-space:nowrap;flex-shrink:0;}
.ra-wrong-pts{color:var(--red);font-size:10px;font-weight:600;white-space:nowrap;flex-shrink:0;opacity:.8;}
.ra-pts{margin-left:auto;font-weight:600;color:var(--green);white-space:nowrap;flex-shrink:0;}
.ra-pts.neg{color:var(--red);}

/* ── SETTINGS TOGGLES ──────────────────────────────────────── */
.toggle-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:9px 0;border-bottom:1px solid var(--border);
  font-size:12px;color:var(--txt);
}
.toggle-row:last-child{border-bottom:none}
.toggle{
  width:30px;height:17px;background:var(--border2);
  border-radius:9px;position:relative;cursor:pointer;
  transition:background .2s;flex-shrink:0;
}
.toggle.on{background:var(--blue)}
.toggle::after{
  content:'';position:absolute;top:2px;left:2px;
  width:13px;height:13px;border-radius:50%;background:#fff;
  transition:transform .2s;box-shadow:0 1px 2px rgba(0,0,0,.2);
}
.toggle.on::after{transform:translateX(13px)}

/* ── MODALS ────────────────────────────────────────────────── */
.modal-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.45);z-index:100;
  align-items:center;justify-content:center;
}
.modal-overlay.open{display:flex}
.modal{
  background:var(--bg);border-radius:var(--radius-lg);
  width:480px;max-width:calc(100vw - 32px);
  max-height:85vh;overflow-y:auto;
  box-shadow:0 20px 60px rgba(0,0,0,.2);
}
.modal.modal-lg{width:580px}
.modal-header{
  padding:16px 20px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;background:var(--bg);z-index:1;
}
.modal-title{font-size:14px;font-weight:600;color:var(--txt)}
.modal-close{
  cursor:pointer;color:var(--txt3);font-size:20px;
  line-height:1;padding:2px 6px;border-radius:4px;
}
.modal-close:hover{background:var(--bg2);color:var(--txt)}
.modal-body{padding:20px}
.modal-footer{
  padding:14px 20px;border-top:1px solid var(--border);
  display:flex;justify-content:flex-end;gap:8px;
  position:sticky;bottom:0;background:var(--bg);
}

/* ── MISC ──────────────────────────────────────────────────── */
.empty-state{text-align:center;padding:48px 20px;color:var(--txt3)}
.empty-state svg{width:40px;height:40px;margin:0 auto 12px;stroke:var(--border2);fill:none;stroke-width:1.5;display:block}
.empty-state p{font-size:13px;font-weight:500;color:var(--txt2);margin-bottom:4px}
.empty-state span{font-size:12px}

.dot-live{
  width:7px;height:7px;border-radius:50%;
  background:var(--green);display:inline-block;
  animation:pulse 1.5s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.search-bar{
  display:flex;align-items:center;gap:8px;
  padding:7px 12px;border:1px solid var(--border2);
  border-radius:var(--radius);background:var(--bg);
  font-size:12px;color:var(--txt);
}
.search-bar input{
  border:none;outline:none;background:transparent;
  font-size:12px;color:var(--txt);width:180px;
}
.search-bar svg{width:13px;height:13px;stroke:var(--txt3);flex-shrink:0}

.type-badge{
  display:inline-flex;padding:2px 8px;border-radius:50px;
  font-size:10px;font-weight:600;
}
.type-evjf{background:#fdf4ff;color:#a21caf}
.type-evg{background:#fff1f2;color:#be123c}
.type-tb{background:#eff6ff;color:#1d4ed8}
.type-tour{background:#f0fdf4;color:#15803d}
.type-corp{background:#fafaf9;color:#57534e}

.divider{height:1px;background:var(--border);margin:16px 0}

.tag{
  display:inline-flex;padding:2px 7px;
  border-radius:4px;font-size:10px;font-weight:600;
  background:var(--bg3);color:var(--txt2);
}

/* Filter tabs */
.filter-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:16px}
.filter-tab{
  padding:8px 14px;font-size:12px;font-weight:500;
  color:var(--txt2);cursor:pointer;
  border-bottom:2px solid transparent;margin-bottom:-1px;
  transition:all .15s;
}
.filter-tab:hover{color:var(--txt)}
.filter-tab.active{color:var(--blue);border-bottom-color:var(--blue)}

/* Drag indicator */
.drag-handle{color:var(--txt3);cursor:grab;font-size:14px;padding:0 4px}
.drag-handle:active{cursor:grabbing}

/* Scrollbar */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--txt3)}

/* ── ACTION FORM FIELDS ─────────────────────────────────────── */
.af{margin-bottom:10px}
.af label{display:block;font-size:10px;font-weight:700;color:var(--txt2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}
.af input[type=text],.af input[type=number],.af textarea,.af select{
  width:100%;padding:6px 9px;
  border:1px solid var(--border2);border-radius:var(--radius);
  font-size:12px;color:var(--txt);background:var(--bg);
  outline:none;font-family:inherit;transition:border-color .15s;
}
.af input[type=text]:focus,.af input[type=number]:focus,.af textarea:focus{border-color:var(--blue)}
.af textarea{resize:vertical;min-height:52px}
.af input[type=number]{width:80px}
.af-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.af-row .af{flex:1;min-width:80px;margin-bottom:0}

/* Language checkboxes — pilules modernes */
.lang-checks{display:flex;gap:6px;margin-top:3px;flex-wrap:wrap}
.lang-check{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 12px;border-radius:50px;
  border:1.5px solid var(--border2);
  background:var(--bg2);
  font-size:11px;font-weight:600;color:var(--txt2);
  cursor:pointer;text-transform:none;letter-spacing:0;
  transition:all .12s;
}
.lang-check.active{background:var(--blue-light);border-color:var(--blue);color:var(--blue)}
.lang-check input[type=checkbox]{display:none}

/* Media picker */
.media-picker-row{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);padding:8px 10px;
}
.media-filename{font-size:11px;color:var(--txt3);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:160px}
.media-thumb{max-height:44px;max-width:72px;border-radius:6px;border:1px solid var(--border);object-fit:cover;display:block;}

/* ── HTML preview for text fields ── */
.html-preview-wrap{
  margin-top:6px;
  margin-bottom:4px;
  border:2px solid #93c5fd;
  border-radius:6px;
  background:#eff6ff;
  overflow:hidden;
}
.html-preview-label{
  display:block;
  font-size:9px;
  font-weight:800;
  letter-spacing:.8px;
  text-transform:uppercase;
  color:#3b82f6;
  background:#dbeafe;
  padding:3px 10px;
  border-bottom:1px solid #93c5fd;
}
.html-preview{
  padding:8px 12px 10px;
  min-height:22px;
  font-size:12.5px;
  font-weight:normal;
  color:#1e293b;
  line-height:1.6;
  word-break:break-word;
}
.html-preview b,.html-preview strong{font-weight:700}
.html-preview i,.html-preview em{font-style:italic}
.html-preview u{text-decoration:underline}
.html-preview ul,.html-preview ol{padding-left:20px;margin:4px 0}
.html-preview li{margin:3px 0}
.html-preview p{margin:4px 0}
.html-preview a{color:#3b82f6;text-decoration:underline}

/* ── Icon picker ── */
.icon-picker-wrap{position:relative;display:flex;align-items:center;gap:8px}
.icon-picker-btn{
  font-size:22px;line-height:1;padding:4px 8px;
  border:2px solid var(--border2,#dbe1ea);border-radius:8px;
  background:var(--bg,#fff);cursor:pointer;
  transition:border-color .15s;
}
.icon-picker-btn:hover{border-color:#93c5fd;}
.icon-picker-hint{font-size:10px;color:var(--txt3,#94a3b8);font-style:italic}
.icon-picker-grid{
  position:absolute;top:44px;left:0;z-index:200;
  display:grid;grid-template-columns:repeat(9,1fr);gap:2px;
  background:#fff;border:1.5px solid #93c5fd;
  border-radius:10px;padding:8px;
  box-shadow:0 8px 24px rgba(0,0,0,.12);
  width:320px;
}
.icon-opt{
  font-size:20px;padding:4px;border-radius:6px;cursor:pointer;
  text-align:center;transition:background .1s;
}
.icon-opt:hover{background:#dbeafe;}
.icon-opt[data-sel="1"]{background:#bfdbfe;outline:2px solid #3b82f6;}

/* Icon upload from disk */
.icon-picker-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.icon-picker-btn{
  min-width:40px;min-height:40px;padding:4px 8px;
  border:2px solid var(--border2,#dbe1ea);border-radius:8px;
  background:var(--bg,#fff);cursor:pointer;
  font-size:22px;line-height:1;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .15s;
}
.icon-picker-btn:hover{border-color:#93c5fd;}
.icon-picker-btn img{width:28px;height:28px;object-fit:contain;border-radius:4px;}
.icon-upload-label{
  display:inline-flex;align-items:center;gap:4px;
  font-size:11px;font-weight:600;color:#3b82f6;
  padding:4px 10px;border:1.5px solid #93c5fd;border-radius:6px;
  background:#eff6ff;cursor:pointer;
  transition:background .15s;white-space:nowrap;
}
.icon-upload-label:hover{background:#dbeafe;}

/* ── Icon picker panel (panel + sections) ── */
.icon-picker-panel{
  position:absolute;top:48px;left:0;z-index:200;
  background:#fff;border:1.5px solid #93c5fd;
  border-radius:10px;padding:10px 10px 8px;
  box-shadow:0 8px 24px rgba(0,0,0,.13);
  width:330px;min-width:220px;
  height:340px;min-height:180px;
  overflow:auto;
  resize:both;
}
.icon-picker-section-title{
  font-size:9px;font-weight:800;text-transform:uppercase;
  letter-spacing:.8px;color:#3b82f6;
  margin-bottom:5px;
}
.icon-picker-emoji-grid{
  display:grid;grid-template-columns:repeat(9,1fr);gap:2px;
  margin-bottom:4px;
}
.icon-opt-img img{width:28px;height:28px;object-fit:contain;border-radius:3px;}

/* ── Mini éditeur HTML (RTE) ──────────────────────────────────── */
.rte-wrap{display:flex;flex-direction:column;}
.rte-toolbar{
  display:flex;gap:2px;padding:4px 6px;
  background:var(--bg2);
  border:1px solid var(--border2);
  border-bottom:none;
  border-radius:6px 6px 0 0;
}
.rte-btn{
  padding:2px 9px;
  border:1px solid var(--border2);
  border-radius:4px;
  background:var(--bg);
  color:var(--txt);
  font-size:11px;cursor:pointer;
  line-height:1.6;
  transition:background .1s, border-color .1s;
}
.rte-btn:hover{background:var(--blue-light);border-color:var(--blue);color:var(--blue);}
.rte-btn b{font-weight:800;font-size:12px;}
.rte-btn.rte-italic i{font-style:italic;font-size:12px;}
.rte-wrap textarea{
  border-top-left-radius:0 \!important;
  border-top-right-radius:0 \!important;
  border-top:none \!important;
}

/* ── Choix de réponse bilingue ──────────────────────────────── */
.question-choices-bilingual{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:6px;
}
.choices-col{display:flex;flex-direction:column;gap:5px;}
.choices-col-header{
  font-size:10px;font-weight:800;text-transform:uppercase;
  letter-spacing:.6px;color:var(--txt3);
  padding:3px 6px;background:var(--bg2);
  border-radius:4px;margin-bottom:2px;
  text-align:center;
}
.choice-row-en{padding-left:0;}
.choice-row-en input[type=text]{margin-left:0;}

/* ── Titre éditable dans le header d'action ─────────────────── */
.action-title-input{
  flex:1;
  font-size:12px;font-weight:500;
  color:var(--txt);
  background:transparent;
  border:1px solid transparent;
  border-radius:4px;
  padding:2px 6px;
  min-width:0;
  outline:none;
  cursor:text;
  transition:border-color .15s, background .15s;
  font-family:inherit;
}
.action-title-input::placeholder{color:var(--txt3);font-style:italic;}
.action-title-input:hover{border-color:rgba(0,0,0,.15);background:rgba(255,255,255,.5);}
.action-title-input:focus{border-color:var(--blue);background:#fff;color:var(--txt);}

/* ── FIELD ROW (2 colonnes) ─────────────────────────────────── */
.field-row{display:flex;gap:14px}
.field-row .field{flex:1;min-width:0}
.btn.danger{background:#fee2e2;color:#dc2626;border:1px solid #fca5a5}
.btn.danger:hover{background:#fecaca}

/* ── Paramètres jeu — sections ──────────────────────────────── */
.params-section-label{
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;
  color:var(--txt3);margin:14px 0 8px;padding-bottom:4px;
  border-bottom:1px solid var(--border);
}
.params-section-label:first-of-type{margin-top:8px}

/* ── Options grid (checkboxes) ──────────────────────────────── */
.options-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:5px 12px;
  margin-bottom:4px;
}
.opt-row{
  display:flex;align-items:center;gap:7px;
  font-size:11.5px;color:var(--txt);font-weight:400;
  cursor:pointer;padding:3px 6px;border-radius:5px;
  transition:background .12s;
  text-transform:none;letter-spacing:0;
}
.opt-row:hover{background:var(--bg2)}
.opt-row input[type=checkbox]{margin:0;cursor:pointer;accent-color:var(--blue)}

/* ── Sound picker rows ──────────────────────────────────────── */
.sound-row{
  display:flex;align-items:center;gap:10px;
  padding:8px 10px;background:var(--bg2);border:1px solid var(--border);
  border-radius:9px;margin-bottom:7px;
}
.sound-row-label{
  font-size:12px;font-weight:600;color:var(--txt);white-space:nowrap;min-width:90px;
}
.sound-file-display{
  flex:1;font-size:11px;color:var(--txt3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  padding:4px 8px;background:var(--bg);border-radius:6px;border:1px solid var(--border);
}
.sound-file-display.loaded{color:var(--blue);font-weight:500;}

/* ── SIDEBAR MOBILE ──────────────────────────────────────────
   Hamburger visible uniquement sur écrans ≤ 768px.
   La sidebar sort par la gauche en slide-in.
   Un overlay semi-transparent ferme la sidebar au tap extérieur.
──────────────────────────────────────────────────────────── */
.hamburger{
  display:none;
  align-items:center;justify-content:center;
  width:36px;height:36px;
  background:none;border:none;
  color:var(--txt);cursor:pointer;
  border-radius:var(--radius);
  flex-shrink:0;
}
.hamburger:hover{background:var(--bg2);}

.sidebar-overlay{
  display:none;
  position:fixed;inset:0;
  background:rgba(0,0,0,.45);
  z-index:149;
  cursor:pointer;
}

@media (max-width:768px){
  /* Hamburger visible */
  .hamburger{display:flex;}

  /* Sidebar : position fixe hors écran à gauche */
  .sidebar{
    position:fixed;
    top:0;left:0;bottom:0;
    z-index:150;
    transform:translateX(-100%);
    transition:transform .25s ease;
    width:240px;
    box-shadow:4px 0 24px rgba(0,0,0,.35);
  }
  .sidebar.open{transform:translateX(0);}

  /* Overlay actif quand sidebar ouverte */
  .sidebar.open ~ .sidebar-overlay,
  .sidebar-overlay.open{display:block;}

  /* Le .main prend toute la largeur (pas de marge sidebar) */
  .main{margin-left:0 !important;}

  /* Topbar : réduire padding, empêcher overflow sur petits écrans */
  .topbar{padding:0 12px;}
  .topbar-actions .btn span,
  .topbar-actions .btn > *:not(svg){display:none;}  /* masquer texte des boutons topbar */
  .topbar-actions .btn{padding:6px 10px;}

  /* Contenu : réduire padding */
  .content{padding:12px !important;}

  /* Stats grid : 2 colonnes au lieu de 4 */
  .stats-grid{grid-template-columns:repeat(2,1fr) !important;}

  /* Tables : scroll horizontal */
  .table-wrap,.card{overflow-x:auto;}
  table{min-width:500px;}

  /* Boutons d'action en sessions : agrandir zone de touch */
  .action-btn{min-width:44px;min-height:44px;}
}
