/* ====================================================
   ONI ROLEPLAY — Front CSS v1.0.0
   Charte La Tablée Onirique
   ==================================================== */

:root {
  --oni-gold:    #FFBE7A;
  --oni-gold2:   #F2A663;
  --oni-cream:   #F2E4C9;
  --oni-beige:   #CBBFA2;
  --oni-dark:    #0A131C;
  --oni-dark2:   #0D1A26;
  --oni-mid:     #1F3A4A;
  --oni-mid2:    #0D2633;
  --oni-panel:   #0D2633;
  --oni-text:    #F2E4C9;
  --oni-muted:   #CBBFA2;
  --oni-danger:  #C0392B;
  --oni-love:    #FF6B81;
  --oni-success: #27AE60;
  --oni-radius:  14px;
  --oni-shadow:  0 24px 60px rgba(0,0,0,.45);
}

/* ─── Base — alignée sur la charte Harmonia (propre & pro) ─── */
#oni-rp-app {
  position: relative;
  font-family: 'Inter', system-ui, sans-serif;
  color: var(--oni-text);
  background: radial-gradient(1200px 600px at 50% -10%, #11283a 0%, var(--oni-dark) 70%);
  min-height: 60vh;
  border: 1px solid rgba(255,190,122,.18);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,.45);
  -webkit-tap-highlight-color: transparent;
}

#oni-rp-app * { box-sizing: border-box; }

.oni-view { display: block; }
.oni-view--hidden { display: none !important; }

/* ─── Boutons ─── */
.oni-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 22px;
  background: var(--oni-cream);
  color: #152635;
  border: none; border-radius: 50px;
  font-family: inherit; font-size: .9rem; font-weight: 600;
  cursor: pointer; transition: background .2s, transform .15s;
  text-decoration: none;
}
.oni-btn:hover { background: var(--oni-gold); transform: translateY(-1px); }
.oni-btn:disabled { opacity: .5; cursor: not-allowed; transform: none; }
.oni-btn--primary { background: var(--oni-gold); color: #152635; }
.oni-btn--primary:hover { background: var(--oni-gold2); }
.oni-btn--outline { background: transparent; border: 1.5px solid var(--oni-gold); color: var(--oni-gold); }
.oni-btn--outline:hover { background: var(--oni-gold); color: #152635; }
.oni-btn--ghost { background: transparent; color: var(--oni-beige); }
.oni-btn--ghost:hover { background: rgba(255,255,255,.07); color: var(--oni-cream); }
.oni-btn--danger { background: transparent; border: 1.5px solid var(--oni-danger); color: #e74c3c; }
.oni-btn--danger:hover { background: var(--oni-danger); color: #fff; }
.oni-btn--sm { padding: 6px 14px; font-size: .82rem; }
.oni-btn--full { width: 100%; justify-content: center; }
.oni-btn-back {
  background: none; border: none; color: var(--oni-beige);
  cursor: pointer; font-size: .88rem; padding: 4px 0;
  display: inline-flex; align-items: center; gap: 4px;
}
.oni-btn-back:hover { color: var(--oni-gold); }

/* ─── Portail ─── */
.oni-auth-wrap {
  padding: 40px 20px;
  min-height: 60vh;
  display: flex; flex-direction: column; align-items: center;
  background: linear-gradient(160deg, var(--oni-dark2), var(--oni-mid2));
}
.oni-auth-card {
  background: linear-gradient(160deg, var(--oni-mid2), var(--oni-mid));
  border: 1px solid rgba(255,190,122,.2);
  border-top: 3px solid var(--oni-gold);
  border-radius: var(--oni-radius);
  box-shadow: var(--oni-shadow);
  padding: 36px 32px; width: 100%; max-width: 460px;
}
.oni-auth-card__icon { font-size: 2.5rem; text-align: center; margin-bottom: 10px; }
.oni-auth-card__title {
  font-family: 'Marcellus SC', serif;
  color: var(--oni-gold); text-align: center;
  font-size: 1.4rem; margin: 0 0 24px;
}

/* ─── Tabs ─── */
.oni-tabs {
  display: flex; flex-wrap: wrap; gap: 4px;
  background: var(--oni-dark); padding: 6px;
  border-radius: 50px; margin-bottom: 24px;
  border: 1px solid rgba(255,190,122,.1);
}
.oni-tabs--sticky {
  position: sticky; top: 0; z-index: 10;
  border-radius: 0; padding: 8px 20px;
  margin: 0 0 24px; gap: 6px;
}
.oni-tab {
  padding: 7px 18px; border-radius: 50px; border: none;
  background: transparent; color: var(--oni-beige);
  font-family: inherit; font-size: .85rem; cursor: pointer;
  transition: background .2s, color .2s; white-space: nowrap;
}
.oni-tab--active, .oni-tab:hover { background: var(--oni-gold); color: #152635; font-weight: 600; }
.oni-tab--active .iconify, .oni-tab:hover .iconify { color: #152635 !important; }
.oni-tab-content { animation: oni-fadein .25s ease; }
@keyframes oni-fadein { from { opacity:0; transform:translateY(4px); } to { opacity:1; transform:none; } }
.oni-tab-content--active { display: block; }

/* ─── Formulaires ─── */
.oni-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 18px; }
.oni-field label { color: var(--oni-beige); font-size: .85rem; font-weight: 600; }
.oni-field input, .oni-field textarea, .oni-field select {
  background: rgba(10,19,28,.7); border: 1px solid rgba(203,191,162,.28);
  color: var(--oni-text); padding: 11px 13px; border-radius: 10px;
  font-family: inherit; font-size: .92rem; outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.oni-field input:focus, .oni-field textarea:focus, .oni-field select:focus {
  border-color: var(--oni-gold);
  box-shadow: 0 0 0 3px rgba(255,190,122,.15);
}
.oni-field textarea { resize: vertical; min-height: 80px; }
.oni-field select option { background: var(--oni-mid); }
.oni-field--full { grid-column: 1 / -1; }
.oni-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 20px; }
.oni-optional { color: var(--oni-beige); font-size: .78rem; font-weight: 400; }
.oni-checkbox-label {
  display: flex; align-items: center; gap: 10px;
  cursor: pointer; padding: 12px 16px;
  background: rgba(0,0,0,.2); border-radius: 8px;
  border: 1px solid rgba(255,190,122,.15);
  transition: border-color .2s;
}
.oni-checkbox-label:hover { border-color: var(--oni-gold); }
.oni-checkbox-label input[type="checkbox"] { width: 18px; height: 18px; accent-color: var(--oni-gold); }

/* ─── Code input ─── */
.oni-code-input {
  display: flex; align-items: center;
  background: rgba(0,0,0,.35); border: 1px solid rgba(255,190,122,.25);
  border-radius: 8px; overflow: hidden; transition: border-color .2s;
}
.oni-code-input:focus-within { border-color: var(--oni-gold); }
.oni-code-prefix {
  padding: 10px 14px; background: rgba(255,190,122,.1);
  color: var(--oni-gold); font-weight: 700; border-right: 1px solid rgba(255,190,122,.2);
  font-size: .9rem; letter-spacing: 1px;
}
.oni-code-input input {
  background: none; border: none; color: var(--oni-text);
  padding: 10px 14px; font-family: monospace; font-size: 1.1rem;
  letter-spacing: 3px; width: 100%; outline: none;
}

/* ─── Dashboard ─── */
.oni-dashboard {
  background: linear-gradient(160deg, var(--oni-dark2), var(--oni-mid2));
  min-height: 60vh;
}
.oni-dashboard__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px;
  background: linear-gradient(90deg, var(--oni-mid2), var(--oni-mid));
  border-bottom: 2px solid rgba(255,190,122,.2);
  gap: 12px; flex-wrap: wrap;
}
.oni-dashboard__header-left { display: flex; align-items: center; gap: 14px; }
.oni-dashboard__icon { font-size: 2rem; }
.oni-dashboard__header h2 {
  font-family: 'Marcellus SC', serif; color: var(--oni-gold);
  margin: 0; font-size: 1.3rem;
}
.oni-dashboard__sub { color: var(--oni-beige); margin: 2px 0 0; font-size: .85rem; }
.oni-dashboard__sub2 { color: var(--oni-muted); margin: 0; font-size: .8rem; }
.oni-dashboard__content { padding: 24px; }

/* ─── Sessions grid ─── */
.oni-section-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px;
}
.oni-section-header h3, .oni-section-header h4 {
  color: var(--oni-gold); font-family: 'Marcellus SC', serif; margin: 0;
}
.oni-sessions-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px,1fr)); gap: 16px; }

.oni-session-card {
  background: linear-gradient(160deg, var(--oni-mid2), var(--oni-mid));
  border: 1px solid rgba(255,190,122,.15);
  border-top: 3px solid var(--oni-gold);
  border-radius: var(--oni-radius);
  padding: 20px; cursor: pointer;
  transition: transform .2s, box-shadow .2s;
  box-shadow: var(--oni-shadow);
}
.oni-session-card:hover { transform: translateY(-3px); box-shadow: 0 10px 30px rgba(0,0,0,.5); }
.oni-session-card__code {
  font-family: monospace; font-size: .85rem;
  color: var(--oni-gold); letter-spacing: 2px; margin-bottom: 8px; display: block;
}
.oni-session-card__name {
  font-family: 'Marcellus SC', serif; color: var(--oni-cream);
  font-size: 1.1rem; margin: 0 0 8px;
}
.oni-session-card__meta {
  color: var(--oni-beige); font-size: .82rem; display: flex; gap: 12px; flex-wrap: wrap;
}
.oni-session-card--empty {
  border-style: dashed; opacity: .6; text-align: center;
  cursor: default; display: flex; align-items: center; justify-content: center;
  font-size: .9rem; color: var(--oni-beige); min-height: 100px;
}
.oni-session-card--empty:hover { transform: none; }

/* ─── Code badge ─── */
.oni-code-badge {
  font-family: monospace; font-size: .9rem;
  color: var(--oni-gold); background: rgba(255,190,122,.1);
  padding: 3px 10px; border-radius: 50px;
  border: 1px solid rgba(255,190,122,.3); letter-spacing: 2px;
}

/* ─── Alertes ─── */
.oni-alert {
  padding: 10px 16px; border-radius: 8px; font-size: .88rem; margin-bottom: 16px;
}
.oni-alert--error { background: rgba(192,57,43,.15); border: 1px solid rgba(192,57,43,.4); color: #e74c3c; }
.oni-alert--success { background: rgba(39,174,96,.15); border: 1px solid rgba(39,174,96,.4); color: #2ecc71; }

/* ─── Banner ─── */
.oni-banner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 20px; gap: 12px; flex-wrap: wrap;
}
.oni-banner--warning {
  background: rgba(230,126,34,.12); border-bottom: 1px solid rgba(230,126,34,.3);
  color: var(--oni-gold);
}

/* ─── Toast ─── */
.oni-toast {
  position: fixed; bottom: 24px; right: 24px; z-index: 9999;
  background: var(--oni-mid); color: var(--oni-cream);
  padding: 12px 20px; border-radius: 10px;
  border-left: 4px solid var(--oni-gold);
  box-shadow: 0 6px 24px rgba(0,0,0,.5);
  font-size: .88rem; max-width: 320px;
  animation: oni-slide-up .3s ease;
}
.oni-toast--error { border-left-color: var(--oni-danger); }
.oni-toast--success { border-left-color: var(--oni-success); }
@keyframes oni-slide-up { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:none; } }

/* ─── Fichiers ─── */
.oni-files-section { margin-bottom: 30px; padding: 20px 24px; }
.oni-files-section h4 {
  color: var(--oni-gold); font-family: 'Marcellus SC', serif;
  margin: 0 0 14px; font-size: 1rem;
}
.oni-files-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 14px; }
.oni-file-row {
  display: flex; align-items: center; gap: 10px;
  background: rgba(0,0,0,.2); border: 1px solid rgba(255,190,122,.1);
  border-radius: 8px; padding: 10px 14px;
}
.oni-file-row__icon { font-size: 1.2rem; flex-shrink: 0; }
.oni-file-row__info { flex: 1; min-width: 0; }
.oni-file-row__name { color: var(--oni-cream); font-size: .9rem; font-weight: 500; }
.oni-file-row__meta { color: var(--oni-beige); font-size: .78rem; margin-top: 2px; }
.oni-file-row__actions { display: flex; gap: 6px; flex-shrink: 0; }
.oni-file-row a { color: var(--oni-gold); text-decoration: none; font-size: .82rem; }
.oni-file-row a:hover { text-decoration: underline; }
.oni-file-btn-sm {
  background: none; border: none; cursor: pointer;
  color: var(--oni-beige); font-size: .82rem; padding: 3px 8px;
  border-radius: 4px; transition: color .2s;
}
.oni-file-btn-sm:hover { color: var(--oni-gold); }
.oni-file-btn-sm--delete:hover { color: #e74c3c; }

.oni-upload-zone {
  border: 2px dashed rgba(255,190,122,.3);
  border-radius: 10px; padding: 20px; text-align: center;
  cursor: pointer; transition: border-color .2s, background .2s;
  color: var(--oni-beige); font-size: .88rem; position: relative;
}
.oni-upload-zone:hover { border-color: var(--oni-gold); background: rgba(255,190,122,.05); }
.oni-upload-zone input[type="file"] {
  position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; height: 100%;
}
.oni-upload-zone--inline { flex: 1; padding: 10px 16px; }
.oni-upload-label-row { margin-top: 8px; }
.oni-upload-label-row input {
  width: 100%; background: rgba(0,0,0,.3); border: 1px solid rgba(255,190,122,.2);
  color: var(--oni-text); padding: 8px 12px; border-radius: 8px; font-family: inherit; font-size: .88rem;
}
.oni-field-row { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.oni-field-row input[type="text"], .oni-field-row input[type="date"] {
  flex: 1; min-width: 140px; background: rgba(0,0,0,.3); border: 1px solid rgba(255,190,122,.2);
  color: var(--oni-text); padding: 8px 12px; border-radius: 8px;
  font-family: inherit; font-size: .88rem;
}

/* ─── Séances planifiées ─── */
.oni-schedule-item {
  display: flex; align-items: center; gap: 10px;
  background: rgba(0,0,0,.2); border: 1px solid rgba(255,190,122,.1);
  padding: 8px 12px; border-radius: 8px; margin-bottom: 6px;
}
.oni-schedule-item__label { flex: 1; color: var(--oni-cream); font-size: .88rem; }
.oni-schedule-item__date { color: var(--oni-beige); font-size: .82rem; }
.oni-schedule-add { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-top: 10px; }
.oni-schedule-add input { flex: 1; min-width: 140px; color: #F2E4C9; background: #0D1A26; border: 1px solid #FFBE7A33; border-radius: 8px; padding: 7px 10px; font-size: .85rem; }
.oni-schedule-add input[type="date"], .oni-schedule-add input[type="time"], .oni-schedule-add input[type="number"] { color-scheme: dark; }

/* ─── Joueurs ─── */
.oni-players-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(230px,1fr)); gap: 14px; padding: 20px 24px; }
.oni-player-card {
  background: linear-gradient(160deg, var(--oni-mid2), var(--oni-mid));
  border: 1px solid rgba(255,190,122,.15); border-radius: var(--oni-radius);
  padding: 18px; text-align: center; position: relative;
}
.oni-player-card__avatar {
  width: 64px; height: 64px; border-radius: 50%;
  object-fit: cover; border: 2px solid var(--oni-gold);
  margin: 0 auto 10px; display: block; background: var(--oni-dark);
}
.oni-player-card__avatar-ph {
  width: 64px; height: 64px; border-radius: 50%;
  background: var(--oni-mid); border: 2px solid rgba(255,190,122,.3);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.8rem; margin: 0 auto 10px;
}
.oni-player-card__name { color: var(--oni-cream); font-weight: 600; font-size: .95rem; margin-bottom: 4px; }
.oni-player-card__char { color: var(--oni-beige); font-size: .82rem; font-style: italic; margin-bottom: 10px; }
.oni-player-card__group {
  display: inline-block; padding: 3px 10px; border-radius: 50px;
  font-size: .75rem; font-weight: 600; margin-bottom: 10px;
}
.oni-progress-wrap { margin-top: 8px; }
.oni-progress-label { font-size: .78rem; color: var(--oni-beige); margin-bottom: 4px; display: flex; justify-content: space-between; }
.oni-progress-bar {
  height: 6px; background: rgba(0,0,0,.3); border-radius: 50px; overflow: hidden;
}
.oni-progress-bar__fill { height: 100%; background: var(--oni-gold); border-radius: 50px; transition: width .3s; }
.oni-progress-input {
  width: 100%; background: rgba(0,0,0,.3); border: 1px solid rgba(255,190,122,.2);
  color: var(--oni-text); padding: 4px 8px; border-radius: 6px; font-size: .82rem;
  font-family: inherit; margin-top: 6px;
}
.oni-player-card__remove {
  position: absolute; top: 8px; right: 8px;
  background: none; border: none; color: var(--oni-beige);
  cursor: pointer; font-size: .9rem; padding: 2px 6px;
  border-radius: 4px; transition: color .2s;
}
.oni-player-card__remove:hover { color: #e74c3c; }

/* ─── Avatar joueur ─── */
.oni-player-avatar-wrap {
  position: relative; width: 62px; height: 62px; flex-shrink: 0;
}
#oni-player-avatar {
  width: 62px; height: 62px; border-radius: 50%;
  object-fit: cover; border: 2px solid var(--oni-gold);
}
.oni-player-avatar-placeholder {
  width: 62px; height: 62px; border-radius: 50%;
  background: var(--oni-mid); border: 2px solid rgba(255,190,122,.3);
  display: flex; align-items: center; justify-content: center; font-size: 2rem;
}
.oni-avatar-upload-btn {
  position: absolute; bottom: -2px; right: -2px;
  background: var(--oni-gold); color: #152635;
  width: 22px; height: 22px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: .65rem; cursor: pointer; border: 2px solid var(--oni-dark2);
}

/* ─── Groupes ─── */
.oni-groups-board { display: flex; gap: 16px; flex-wrap: wrap; padding: 0 24px 24px; }
.oni-group-form { padding: 0 24px 16px; }
.oni-group-card {
  background: linear-gradient(160deg, var(--oni-mid2), var(--oni-mid));
  border-radius: var(--oni-radius);
  border: 1px solid rgba(255,190,122,.15);
  padding: 16px; min-width: 200px; flex: 1;
}
.oni-group-card__header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 12px; padding-bottom: 10px;
  border-bottom: 2px solid transparent;
}
.oni-group-card__name {
  font-family: 'Marcellus SC', serif; font-size: 1rem;
  color: var(--oni-cream);
}
.oni-group-card__actions { display: flex; gap: 4px; }
.oni-group-card__members { display: flex; flex-direction: column; gap: 6px; min-height: 40px; }
.oni-group-member {
  display: flex; align-items: center; gap: 8px;
  background: rgba(0,0,0,.2); border-radius: 6px; padding: 6px 10px;
  font-size: .85rem; color: var(--oni-cream);
}
.oni-group-member__avatar {
  width: 28px; height: 28px; border-radius: 50%; object-fit: cover;
  background: var(--oni-dark); border: 1px solid rgba(255,190,122,.2);
}
.oni-group-unassigned { padding: 0 24px 24px; }
.oni-group-unassigned h5 { color: var(--oni-beige); font-size: .85rem; margin: 0 0 10px; }
.oni-group-player-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(0,0,0,.25); border: 1px solid rgba(255,190,122,.15);
  border-radius: 50px; padding: 5px 12px; margin: 4px;
  font-size: .82rem; color: var(--oni-cream);
}
.oni-assign-select {
  background: rgba(0,0,0,.4); border: 1px solid rgba(255,190,122,.2);
  color: var(--oni-cream); border-radius: 6px; padding: 3px 6px;
  font-family: inherit; font-size: .78rem;
}

/* ─── PDF Editor ─── */
.oni-pdfs-list { margin: 0 0 10px; display: flex; flex-direction: column; gap: 8px; }
.oni-pdf-item {
  display: flex; align-items: center; gap: 10px;
  background: rgba(0,0,0,.2); border: 1px solid rgba(255,190,122,.1);
  border-radius: 8px; padding: 12px 16px;
}
.oni-pdf-item__name { flex: 1; color: var(--oni-cream); font-size: .9rem; }
.oni-pdf-item__actions { display: flex; gap: 6px; }

.oni-pdf-toolbar {
  padding: 12px 24px; background: rgba(0,0,0,.2);
  border-bottom: 1px solid rgba(255,190,122,.1);
  display: flex; gap: 16px; align-items: center; flex-wrap: wrap;
}
.oni-pdf-field-types { display: flex; gap: 8px; align-items: center; font-size: .88rem; color: var(--oni-beige); }
.oni-pdf-field-types select {
  background: rgba(0,0,0,.3); border: 1px solid rgba(255,190,122,.2);
  color: var(--oni-text); padding: 6px 10px; border-radius: 6px; font-family: inherit;
}
.oni-pdf-pages { display: flex; gap: 8px; align-items: center; font-size: .88rem; color: var(--oni-beige); }

.oni-pdf-container {
  display: flex; gap: 0; overflow: hidden;
}
.oni-pdf-canvas-wrap {
  overflow: auto; flex: 1;
  display: flex; justify-content: center; align-items: flex-start;
  padding: 20px; background: #1a1a1a;
}
#oni-pdf-canvas-inner {
  position: relative; display: inline-block; line-height: 0;
  box-shadow: 0 4px 20px rgba(0,0,0,.5);
}
#oni-pdf-canvas { display: block; }
.oni-pdf-fields-layer {
  position: absolute; top: 0; left: 0;
  width: 100%; height: 100%;
  pointer-events: none;
}
.oni-pdf-field {
  position: absolute; pointer-events: all;
  border: 2px dashed rgba(255,190,122,.7);
  background: rgba(255,190,122,.08);
  border-radius: 4px; cursor: move;
  min-width: 40px; min-height: 20px;
  box-sizing: border-box;
}
.oni-pdf-field:hover { border-color: var(--oni-gold); background: rgba(255,190,122,.15); }
.oni-pdf-field__label {
  position: absolute; top: 1px; left: 3px;
  font-size: .65rem; color: var(--oni-gold); pointer-events: none;
  white-space: nowrap; overflow: hidden; max-width: calc(100% - 18px);
  text-overflow: ellipsis; line-height: 1.2;
}
.oni-pdf-field input, .oni-pdf-field textarea {
  width: 100%; height: 100%; background: rgba(255,255,255,.85);
  border: none; padding: 4px; font-size: .82rem; color: #000;
  border-radius: 2px; box-sizing: border-box;
}

.oni-pdf-sidebar {
  width: 240px; border-left: 1px solid rgba(255,190,122,.1);
  padding: 16px; background: var(--oni-dark2); overflow-y: auto;
}
.oni-pdf-sidebar h4 { color: var(--oni-gold); font-family: 'Marcellus SC', serif; margin: 0 0 12px; }
.oni-pdf-field-item {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 8px; background: rgba(0,0,0,.2);
  border-radius: 6px; margin-bottom: 6px; font-size: .82rem; color: var(--oni-cream);
}
.oni-pdf-field-item__del {
  margin-left: auto; background: none; border: none; color: var(--oni-beige);
  cursor: pointer; padding: 2px 4px;
}
.oni-pdf-field-item__del:hover { color: #e74c3c; }

/* ─── Fiches joueur ─── */
.oni-pdfs-list-player { display: flex; flex-direction: column; gap: 10px; }
.oni-pdf-player-item {
  background: rgba(0,0,0,.2); border: 1px solid rgba(255,190,122,.1);
  border-radius: 8px; padding: 14px 16px;
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
}
.oni-pdf-player-item__name { flex: 1; color: var(--oni-cream); font-size: .9rem; }

/* ─── Session details ─── */
.oni-session-details { padding: 24px; }
.oni-session-details__block { margin-bottom: 20px; }
.oni-session-details__label {
  color: var(--oni-gold); font-size: .8rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px;
}
.oni-session-details__value { color: var(--oni-cream); font-size: .92rem; line-height: 1.6; }
.oni-oni-saga-badge {
  display: inline-flex; gap: 6px; align-items: center;
  background: rgba(255,190,122,.1); border: 1px solid rgba(255,190,122,.3);
  color: var(--oni-gold); padding: 6px 14px; border-radius: 50px; font-size: .85rem;
}

/* ─── Groupe info joueur ─── */
.oni-group-info {
  padding: 16px 24px; background: rgba(0,0,0,.2);
  border-bottom: 1px solid rgba(255,190,122,.1);
}
.oni-group-info h4 { margin: 0 0 6px; color: var(--oni-gold); font-family: 'Marcellus SC', serif; }
.oni-group-info p { margin: 0; color: var(--oni-beige); font-size: .88rem; }

/* ─── Modal ─── */
.oni-modal { position: fixed; inset: 0; z-index: 9000; display: flex; align-items: center; justify-content: center; }
.oni-modal__overlay { position: absolute; inset: 0; background: rgba(0,0,0,.7); }
.oni-modal__box {
  position: relative; z-index: 1;
  background: linear-gradient(160deg, var(--oni-mid2), var(--oni-mid));
  border: 1px solid rgba(255,190,122,.25); border-top: 3px solid var(--oni-gold);
  border-radius: var(--oni-radius); box-shadow: var(--oni-shadow);
  padding: 32px; width: 90%; max-width: 440px;
}
.oni-modal__box h3 {
  font-family: 'Marcellus SC', serif; color: var(--oni-gold);
  margin: 0 0 8px; font-size: 1.3rem;
}
.oni-modal__box p { color: var(--oni-beige); font-size: .88rem; margin: 0 0 20px; line-height: 1.6; }
.oni-modal__actions { display: flex; gap: 10px; margin-top: 20px; }

/* ─── Helper text ─── */
.oni-helper-text { color: var(--oni-beige); font-size: .84rem; margin: 0 0 12px; line-height: 1.6; }

/* ─── Responsive ─── */
@media (max-width: 640px) {
  .oni-portal__cards { flex-direction: column; align-items: center; }
  .oni-portal__card { max-width: 100%; }
  .oni-form-grid { grid-template-columns: 1fr; }
  .oni-players-grid { grid-template-columns: 1fr 1fr; }
  .oni-sessions-grid { grid-template-columns: 1fr; }
  .oni-pdf-container { flex-direction: column; }
  .oni-pdf-sidebar { width: 100%; border-left: none; border-top: 1px solid rgba(255,190,122,.1); }
  .oni-dashboard__header { padding: 14px 16px; }
  .oni-files-section, .oni-players-grid, .oni-groups-board, .oni-group-unassigned { padding-left: 16px; padding-right: 16px; }
  .oni-tabs--sticky { padding: 6px 12px; }
  .oni-auth-card { padding: 24px 18px; }
}

@media (max-width: 400px) {
  .oni-players-grid { grid-template-columns: 1fr; }
}

/* ─── Tooltips ─── */
.oni-tooltip-trigger {
    display: inline-flex; align-items: center; justify-content: center;
    width: 16px; height: 16px; border-radius: 50%;
    background: #FFBE7A33; border: 1px solid #FFBE7A88;
    color: #FFBE7A; font-size: .65rem; font-weight: 700;
    cursor: help; margin-left: 6px; vertical-align: middle;
    font-family: Inter, sans-serif; flex-shrink: 0;
}
.oni-tooltip-bubble {
    position: fixed; z-index: 9999;
    background: #0D1A26; border: 1px solid #FFBE7A55;
    color: #F2E4C9; padding: 10px 14px; border-radius: 8px;
    font-size: .8rem; line-height: 1.5; max-width: 280px;
    box-shadow: 0 4px 16px rgba(0,0,0,.5); pointer-events: none;
}
.oni-tooltip-bubble strong { color: #FFBE7A; display: block; margin-bottom: 4px; }

/* ─── Titres onglets réduits ─── */
.oni-session-tab-infos h4,
.oni-session-tab-files h5,
.oni-session-tab-groups h5,
.oni-session-tab-pdfs h5,
.oni-tab-content h5 {
    font-size: .85rem; font-weight: 600; letter-spacing: .03em;
    color: #FFBE7A; margin: 0 0 12px; font-family: 'Marcellus SC', serif;
}
.oni-section-header h5 { margin: 0; }

/* ─── Drag & drop groupes ─── */
.oni-groups-hint { font-size:.75rem; color:var(--oni-beige); margin:0 0 12px; font-style:italic; }
.oni-drop-zone {
    min-height: 60px; padding: 8px;
    border: 2px dashed transparent;
    border-radius: 8px; transition: border-color .2s, background .2s;
}
.oni-drop-zone--over { border-color: #FFBE7A; background: #FFBE7A11; }
.oni-player-chip {
    display: inline-flex; align-items: center; gap: 6px;
    background: #1F3A4A; border: 1px solid #FFBE7A33;
    border-radius: 20px; padding: 5px 10px 5px 6px;
    font-size: .78rem; color: #F2E4C9; cursor: grab;
    margin: 3px; transition: opacity .2s, box-shadow .2s;
}
.oni-player-chip:active { cursor: grabbing; }
.oni-player-chip.oni-chip--dragging { opacity: .4; }
.oni-player-chip .oni-group-member__avatar,
.oni-player-chip .oni-group-member__avatar--ph {
    width: 22px; height: 22px; border-radius: 50%;
    object-fit: cover; flex-shrink: 0;
    background: #0D2633; display: flex; align-items: center; justify-content: center; font-size: .7rem;
}
.oni-group-card--unassigned { border-color: #CBBFA255; }
.oni-group-card--unassigned .oni-group-card__name { color: #CBBFA2; }

/* ─── Lien billetterie séances ─── */
.oni-ticket-link {
    display: inline-block; padding: 2px 8px;
    background: #FFBE7A22; border: 1px solid #FFBE7A55;
    color: #FFBE7A; border-radius: 20px; font-size: .72rem;
    text-decoration: none; margin-left: 8px; transition: background .2s;
}
.oni-ticket-link:hover { background: #FFBE7A44; }

/* ─── Notifications joueur ─── */
#oni-player-notifications {
    background: #1F3A4A; border: 1px solid #FFBE7A55;
    border-radius: 10px; padding: 10px 14px; margin-bottom: 16px;
    display: none;
}
.oni-notif-bar {
    background: #1F3A4A; border: 1px solid #FFBE7A55;
    border-radius: 10px; padding: 8px 12px; margin-bottom: 14px;
}
.oni-notif-item {
    display: flex; align-items: center; gap: 8px;
    padding: 6px 0; border-bottom: 1px solid #FFBE7A22; font-size: .82rem; color: #F2E4C9;
}
.oni-notif-item:last-child { border-bottom: none; }
.oni-notif-item small { color: #CBBFA2; font-size: .72rem; margin-left: auto; }
.oni-notif-read {
    background: #FFBE7A22; border: 1px solid #FFBE7A55; color: #FFBE7A;
    border-radius: 20px; padding: 2px 8px; font-size: .7rem; cursor: pointer;
    white-space: nowrap;
}

/* ─── MJ lecture fiches joueurs ─── */
.oni-pdf-player-sheets {
    margin-top: 24px; border: 1px solid #FFBE7A33;
    border-radius: 12px; padding: 18px; background: #0D2633;
}
.oni-player-sheets-tabs { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 16px; }
.oni-sheet-tab {
    padding: 6px 12px; border-radius: 20px; font-size: .78rem;
    background: #1F3A4A; border: 1px solid #CBBFA233;
    color: #F2E4C9; cursor: pointer; transition: all .2s;
}
.oni-sheet-tab--active, .oni-sheet-tab:hover {
    background: #FFBE7A22; border-color: #FFBE7A; color: #FFBE7A;
}
.oni-sheet-viewer { display: flex; flex-direction: column; gap: 12px; }
.oni-sheet-fields { display: flex; flex-direction: column; gap: 8px; }
.oni-sheet-field-row label { display: block; font-size: .75rem; color: #CBBFA2; margin-bottom: 3px; }
.oni-sheet-field-row input[type="text"],
.oni-sheet-field-row textarea {
    width: 100%; background: #0D1A26; border: 1px solid #FFBE7A33;
    color: #F2E4C9; border-radius: 6px; padding: 6px 10px; font-size: .82rem;
    box-sizing: border-box;
}
.oni-sheet-gm-note-edit label { font-size: .8rem; color: #CBBFA2; display: block; margin-bottom: 6px; }
.oni-sheet-gm-note-edit textarea {
    width: 100%; min-height: 80px; background: #0D1A26;
    border: 1px solid #FFBE7A55; color: #F2E4C9; border-radius: 6px;
    padding: 8px 10px; font-size: .82rem; box-sizing: border-box;
}
.oni-gm-note {
    background: #FFBE7A11; border: 1px solid #FFBE7A44;
    border-radius: 8px; padding: 10px 14px; font-size: .82rem; color: #FFBE7A;
}

/* ─── Tooltip admin WP ─── */
.oni-rp-admin .oni-tip-cell textarea { width: 100%; }

/* ─── Classe / Niveau personnage (MJ) ─── */
.oni-char-info-row {
    display: flex; gap: 6px; margin: 6px 0;
}
.oni-char-class-input {
    flex: 1; background: #0D1A26; border: 1px solid #FFBE7A33;
    color: #F2E4C9; border-radius: 6px; padding: 4px 8px;
    font-size: .75rem; min-width: 0;
}
.oni-char-level-input {
    width: 52px; background: #0D1A26; border: 1px solid #FFBE7A33;
    color: #F2E4C9; border-radius: 6px; padding: 4px 6px;
    font-size: .75rem; text-align: center;
}
.oni-char-class-input:focus, .oni-char-level-input:focus {
    outline: none; border-color: #FFBE7A88;
}
.oni-char-class-input::placeholder, .oni-char-level-input::placeholder { color: #CBBFA2; }

/* ─── PDF field resize handle ─── */
.oni-pdf-field {
    cursor: move;
    user-select: none;
}
.oni-pdf-field__resize-handle {
    position: absolute;
    bottom: 0; right: 0;
    width: 14px; height: 14px;
    cursor: se-resize;
    background: linear-gradient(135deg, transparent 50%, #FFBE7A 50%);
    border-radius: 0 0 3px 0;
    opacity: .8;
    z-index: 2;
}
.oni-pdf-field__resize-handle:hover { opacity: 1; }
.oni-pdf-field__label {
    pointer-events: none; /* le label ne bloque pas le drag */
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    display: block; max-width: calc(100% - 16px);
}

/* ─── Upload zone états ─── */
.oni-upload-zone--uploading {
    border-color: #FFBE7A !important;
    background: #FFBE7A11 !important;
    animation: oni-pulse 1s ease-in-out infinite alternate;
}
@keyframes oni-pulse {
    from { opacity: .7; }
    to   { opacity: 1; }
}

/* ─── Lien "Fiches" dans les cartes joueur MJ ─── */
.oni-btn-link {
    background: none; border: none; padding: 0 0 0 6px;
    color: var(--oni-gold); font-size: .72rem; cursor: pointer;
    text-decoration: underline; vertical-align: middle;
}
.oni-btn-link:hover { color: var(--oni-cream); }

/* ─── Badge "Vous" dans la grille joueurs ─── */
.oni-me-badge {
    display: inline-block; background: #FFBE7A33; border: 1px solid #FFBE7A55;
    color: var(--oni-gold); font-size: .6rem; border-radius: 10px;
    padding: 1px 6px; margin-left: 4px; vertical-align: middle;
}
.oni-player-card--me { border-color: #FFBE7A55 !important; }

/* ─── Classe/niveau/progression visible côté joueur ─── */
.oni-player-char-meta {
    font-size: .75rem; color: var(--oni-beige); margin: 3px 0;
    font-style: italic;
}
.oni-progress-mini { margin-top: 6px; }
.oni-progress-mini__label {
    display: flex; justify-content: space-between;
    font-size: .7rem; color: var(--oni-beige); margin-bottom: 2px;
}

/* ─── Sélecteur de template PDF dans le panel fiches MJ ─── */
.oni-pdf-tpl-sel-wrap {
    margin-bottom: 10px; font-size: .82rem; color: var(--oni-beige);
}
.oni-pdf-template-sel {
    background: #0D1A26; border: 1px solid #FFBE7A33; color: var(--oni-cream);
    border-radius: 6px; padding: 4px 8px; font-size: .82rem; margin-left: 6px;
}

/* ─── Sidebar PDF — item avec type ─── */
.oni-pdf-field-item__info { display: flex; flex-direction: column; flex: 1; min-width: 0; }
.oni-pdf-field-item__name { font-size: .82rem; color: var(--oni-cream); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.oni-pdf-field-item__type { font-size: .68rem; color: var(--oni-beige); margin-top: 1px; }

/* ─── Prévisualisation checkbox dans l'éditeur PDF MJ ─── */
.oni-pdf-field__checkbox-prev {
    display: inline-block; width: 14px; height: 14px;
    border: 2px solid var(--oni-gold); border-radius: 3px;
    background: rgba(255,190,122,.1); flex-shrink: 0;
    position: absolute; bottom: 4px; left: 4px;
}

/* ─── Titres h5 côté joueur ─── */
#oni-view-player-dashboard h5 {
    font-size: .85rem; font-weight: 600; letter-spacing: .03em;
    color: var(--oni-gold); margin: 0 0 10px;
    font-family: 'Marcellus SC', serif;
}

/* ─── Modale large fiches personnage ─── */
.oni-modal__box--wide {
    max-width: 700px; width: 95vw; max-height: 88vh;
    overflow-y: auto; padding: 24px;
}
.oni-modal__header {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 16px; gap: 10px;
}
.oni-modal__header h3 { margin: 0; font-size: 1rem; color: var(--oni-gold); font-family: 'Marcellus SC', serif; }

/* ─── Groupe label côté joueur (remplace h4) ─── */
.oni-group-label {
    font-size: .9rem; font-family: 'Marcellus SC', serif;
    margin: 0 0 12px; font-weight: normal;
}

/* ─── PORTAIL ─── */
.oni-portal {
    max-width:880px; margin:0 auto; padding:36px 20px 60px;
}
.oni-portal__logo { display:flex; justify-content:center; align-items:center; margin-bottom:14px; }
.oni-portal__logo svg { width:60px; height:60px; }
.oni-portal__title {
    text-align:center; font-family:'Marcellus SC',serif;
    font-size:clamp(1.5rem,4.5vw,2.5rem); color:#FFBE7A;
    margin:0 0 8px; letter-spacing:.03em;
}
.oni-portal__sub { text-align:center; color:#CBBFA2; font-size:.88rem; margin:0 0 32px; }

/* Stats */
.oni-portal__stats {
    display:flex; align-items:center; justify-content:center;
    gap:0; background:#0D2633; border:1px solid #FFBE7A22;
    border-radius:14px; padding:18px 28px; margin-bottom:24px; flex-wrap:wrap;
}
.oni-portal__stat { display:flex; flex-direction:column; align-items:center; gap:4px; padding:0 24px; flex:1; min-width:80px; }
.oni-portal__stat-sep { width:1px; height:40px; background:#FFBE7A22; flex-shrink:0; }
.oni-portal__stat-num {
    font-size:2rem; font-weight:700; color:#FFBE7A;
    font-family:'Marcellus SC',serif; line-height:1; min-width:36px; text-align:center;
}
.oni-portal__stat-lbl { font-size:.68rem; color:#CBBFA2; text-transform:uppercase; letter-spacing:.08em; text-align:center; }
.oni-stat-loader {
    display:inline-block; width:24px; height:4px; border-radius:4px;
    background:linear-gradient(90deg,#FFBE7A33,#FFBE7A88,#FFBE7A33);
    background-size:200% 100%; animation:oni-shimmer 1.2s ease infinite;
}
@keyframes oni-shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* Prochaine séance */
.oni-portal__next {
    background:linear-gradient(135deg,#0D2633,#1F3A4A);
    border:1px solid #FFBE7A33; border-radius:14px;
    padding:18px 24px; margin-bottom:28px;
}
.oni-portal__next-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.oni-portal__next-label { font-size:.68rem; text-transform:uppercase; letter-spacing:.12em; color:#CBBFA2; }
.oni-portal__next-hint { font-size:.75rem; color:#FFBE7A; font-weight:600; }
.oni-portal__next-name { font-family:'Marcellus SC',serif; font-size:1rem; color:#F2E4C9; margin-bottom:2px; }
.oni-portal__next-date { font-size:.8rem; color:#CBBFA2; margin-bottom:12px; }
.oni-portal__next-bar-wrap { background:#0D1A26; border-radius:20px; height:6px; overflow:hidden; }
.oni-portal__next-bar {
    height:100%; border-radius:20px;
    background:linear-gradient(90deg,#F2A663,#FFBE7A);
    transition:width .8s cubic-bezier(.4,0,.2,1);
}

/* Cards */
.oni-portal__cards { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.oni-portal__card {
    position: relative;
    background:linear-gradient(155deg, rgba(31,58,74,.55), rgba(13,38,51,.65));
    border:1px solid rgba(255,190,122,.22); border-radius:14px;
    padding:28px 24px; cursor:pointer;
    transition:border-color .2s,transform .18s,box-shadow .18s;
    display:flex; flex-direction:column; gap:14px;
    outline:none; user-select:none;
    box-shadow:0 18px 40px rgba(0,0,0,.35);
}
.oni-portal__card::before {
    content:""; position:absolute; left:18%; right:18%; top:-1px; height:2px;
    background:linear-gradient(90deg,transparent,var(--oni-gold),transparent);
    border-radius:2px;
}
.oni-portal__card * { pointer-events:none; }
.oni-portal__card:hover, .oni-portal__card:focus {
    border-color:rgba(255,190,122,.5); transform:translateY(-4px);
    box-shadow:0 22px 50px rgba(0,0,0,.5);
}
.oni-portal__card-icon { font-size:40px; color:#FFBE7A; line-height:1; }
.oni-portal__card-body { flex:1; }
.oni-portal__card-body h2 {
    font-family:'Marcellus SC',serif; font-size:1.1rem; color:#FFBE7A; margin:0 0 8px;
}
.oni-portal__card-body p { color:#CBBFA2; font-size:.84rem; line-height:1.55; margin:0; }
.oni-portal__card-cta {
    font-size:.78rem; color:#FFBE7A88; font-weight:600;
    letter-spacing:.06em; transition:color .15s;
}
.oni-portal__card:hover .oni-portal__card-cta { color:#FFBE7A; }

/* ─── AUTH PAGES sans float ─── */
.oni-auth-page {
    display:flex; flex-direction:column; align-items:center;
    padding:30px 16px; min-height:400px;
}
.oni-auth-page .oni-btn-back { align-self:flex-start; margin-bottom:20px; }
.oni-auth-card {
    background:linear-gradient(145deg,#0D2633,#1F3A4A);
    border:1px solid #FFBE7A33; border-radius:16px;
    padding:32px 28px; width:100%; max-width:420px;
}
.oni-auth-card__header { display:flex; align-items:center; gap:12px; margin-bottom:22px; }
.oni-auth-card__svg { width:32px; height:32px; flex-shrink:0; }
.oni-auth-card__title { font-family:'Marcellus SC',serif; font-size:1.1rem; color:#FFBE7A; margin:0; }

/* ─── Sessions cards avec image ─── */
.oni-session-card {
    background-size:cover; background-position:center;
    position:relative; overflow:hidden;
}
.oni-session-card--has-img .oni-session-card__overlay {
    position:absolute; inset:0;
    background:linear-gradient(135deg,rgba(13,26,38,.92),rgba(13,38,51,.85));
}
.oni-session-card__content { position:relative; z-index:1; }

/* ─── Image upload session ─── */
.oni-upload-zone--img {
    display:flex; flex-direction:column; align-items:center;
    gap:8px; padding:16px; cursor:pointer;
}

/* ─── Invitation email ─── */
.oni-invite-section { margin-bottom:20px; padding-bottom:16px; border-bottom:1px solid #FFBE7A22; }
.oni-invite-section h5 { margin-bottom:10px; }
.oni-invite-row { display:flex; gap:8px; flex-wrap:wrap; }
.oni-invite-row input { flex:1; min-width:140px; }

/* ─── Fichier masqué MJ ─── */
.oni-file-row--hidden { opacity:.7; }
.oni-file-btn-sm--hidden { color:#CBBFA2; }
.oni-file-dl { font-size:.78rem; color:var(--oni-gold); text-decoration:none; }
.oni-file-dl:hover { text-decoration:underline; }

/* ─── Dashboard svg icon ─── */
.oni-dashboard__svg-icon { width:28px; height:28px; flex-shrink:0; }

@media (max-width:560px) {
    .oni-portal__cards { grid-template-columns:1fr; }
    .oni-portal__stats { gap:18px; padding:16px 18px; }
    .oni-portal__stat-num { font-size:1.5rem; }
}

/* ─── Responsive portail ─── */
@media (max-width: 600px) {
    .oni-portal__cards { grid-template-columns: 1fr; }
    .oni-portal__stat-sep { display:none; }
    .oni-portal__stats { gap:12px; }
    .oni-portal__stat { padding:0 12px; }
}

/* ─── Session hero image (joueur) ─── */
.oni-session-hero {
    position: relative; border-radius: 14px; overflow: hidden;
    margin-bottom: 20px; max-height: 180px;
}
.oni-session-hero__img {
    width: 100%; height: 180px; object-fit: cover;
    display: block; filter: brightness(.65);
}
.oni-session-hero__overlay {
    position: absolute; bottom: 0; left: 0; right: 0;
    padding: 14px 18px;
    background: linear-gradient(transparent, rgba(0,0,0,.75));
    display: flex; flex-direction: column; gap: 4px;
}
.oni-session-hero__overlay .oni-code-badge {
    align-self: flex-start; font-size: .68rem;
}
.oni-session-hero__overlay h3 {
    margin: 0; font-family: 'Marcellus SC', serif;
    font-size: 1.1rem; color: #F2E4C9;
}

/* ─── Switcher de session ─── */
.oni-header-actions {
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.oni-session-switcher {
    display: flex; align-items: center; gap: 6px;
}
.oni-session-switcher__label {
    font-size: .72rem; color: #CBBFA2; white-space: nowrap;
}
.oni-session-switcher__select {
    background: #0D1A26; border: 1px solid #FFBE7A33;
    color: #F2E4C9; border-radius: 8px; padding: 5px 10px;
    font-size: .78rem; cursor: pointer; max-width: 160px;
}
.oni-session-switcher__select:focus {
    outline: none; border-color: #FFBE7A66;
}

/* ─── Bloc image session éditeur ─── */
.oni-session-img-block { display: flex; flex-direction: column; gap: 10px; }
#oni-session-img-preview-wrap {
    background: #0D1A26; border: 1px solid #FFBE7A33;
    border-radius: 10px; padding: 12px;
    display: flex; flex-direction: column; align-items: flex-start; gap: 8px;
}

/* ─── Slider progression : 0→100% correct ─── */
.oni-progress-input {
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
    height: 6px;
    background: linear-gradient(
        to right,
        #FFBE7A 0%,
        #FFBE7A calc(var(--pct, 50%) ),
        #1F3A4A calc(var(--pct, 50%)),
        #1F3A4A 100%
    );
    border-radius: 20px;
    outline: none;
    border: none;
    cursor: pointer;
    margin-top: 6px;
    padding: 0;
}
.oni-progress-input::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 16px; height: 16px;
    border-radius: 50%;
    background: #FFBE7A;
    border: 2px solid #0D1A26;
    cursor: pointer;
    box-shadow: 0 0 6px rgba(255,190,122,.5);
}
.oni-progress-input::-moz-range-thumb {
    width: 16px; height: 16px;
    border-radius: 50%;
    background: #FFBE7A;
    border: 2px solid #0D1A26;
    cursor: pointer;
}

/* ─── Couleur contour session ─── */
.oni-color-pick-row {
    display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.oni-color-input {
    width: 44px; height: 36px;
    border: 1px solid #FFBE7A33; border-radius: 8px;
    background: #0D1A26; cursor: pointer; padding: 2px;
}
.oni-color-hint { font-size: .75rem; color: #CBBFA2; }

/* ─── Cards session avec dates ─── */
.oni-session-card__dates {
    margin-top: 8px; display: flex; flex-direction: column; gap: 3px;
}
.oni-session-card__date-item {
    font-size: .72rem; color: #FFBE7A; opacity: .85;
}

/* ─── Invitation stylisée ─── */
.oni-invite-form {
    background: #0D1A26; border: 1px solid #FFBE7A22;
    border-radius: 12px; padding: 16px 18px;
    display: flex; flex-direction: column; gap: 12px;
}
.oni-invite-form .oni-input {
    width: 100%; background: #1F3A4A; border: 1px solid #FFBE7A33;
    color: #F2E4C9; border-radius: 8px; padding: 8px 12px;
    font-size: .85rem; box-sizing: border-box;
}
.oni-invite-form .oni-input:focus {
    outline: none; border-color: #FFBE7A66;
}

/* ─── PDF editor header actions ─── */
.oni-pdf-header-actions {
    display: flex; align-items: center; gap: 8px;
}

/* ─── Actions PDF dans la modale fiches ─── */
.oni-sheet-pdf-actions {
    display: flex; gap: 10px; margin-bottom: 16px; flex-wrap: wrap;
}
.oni-sheet-gm-note-edit {
    margin-top: 16px; padding-top: 16px;
    border-top: 1px solid #FFBE7A22;
}
.oni-sheet-gm-note-edit label {
    display: block; font-size: .8rem; color: var(--oni-beige); margin-bottom: 6px;
}
.oni-sheet-gm-note-edit textarea {
    width: 100%; min-height: 80px; background: #0D1A26;
    border: 1px solid #FFBE7A33; color: #F2E4C9;
    border-radius: 8px; padding: 8px; font-size: .83rem;
    resize: vertical; box-sizing: border-box;
}

/* ─── Liste fiches remplies inline (onglet PDF MJ) ─── */
.oni-pdf-item {
    margin-bottom: 20px;
    border: 1px solid #FFBE7A22;
    border-radius: 12px;
    overflow: hidden;
    background: #0D1A26;
}

/* Header du template : nom + boutons sur DEUX lignes distinctes */
.oni-pdf-item__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 16px;
    background: linear-gradient(90deg, #0D2633, #1F3A4A);
    border-bottom: 1px solid #FFBE7A22;
    flex-wrap: wrap;
}
.oni-pdf-item__name {
    font-family: 'Marcellus SC', serif;
    font-size: .92rem;
    color: #FFBE7A;
    flex: 1;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.oni-pdf-item__actions {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
}

/* Fiches des joueurs */
.oni-pdf-entries { padding: 0; }
.oni-pdf-entries--loading { padding: 12px 16px; color: #CBBFA2; font-size: .8rem; }
.oni-pdf-entries__empty { padding: 12px 16px; font-size: .8rem; color: #CBBFA2; font-style: italic; }

.oni-pdf-entry-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 14px 16px;
    border-top: 1px solid #FFBE7A11;
    flex-wrap: wrap;
}
.oni-pdf-entry-row:first-child { border-top: none; }

.oni-pdf-entry-row__info {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
    min-width: 200px;
}
.oni-pdf-entry-row__player {
    font-size: .9rem;
    color: #F2E4C9;
    font-weight: 500;
    line-height: 1.4;
}
.oni-pdf-entry-row__player em {
    color: #FFBE7A;
    font-style: normal;
    font-weight: normal;
}
.oni-pdf-entry-row__date {
    font-size: .73rem;
    color: #CBBFA2;
}
.oni-pdf-entry-row__actions {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
    align-items: center;
    flex-wrap: wrap;
}

/* ─── Nom de fiche joueur dans l'éditeur PDF ─── */
.oni-pdf-sheet-name-wrap {
    display: flex; align-items: center; gap: 8px; margin-top: 10px;
    padding-top: 10px; border-top: 1px solid #FFBE7A22;
}
.oni-pdf-sheet-name-wrap label { font-size: .78rem; color: #CBBFA2; white-space: nowrap; }
.oni-pdf-sheet-name-wrap input {
    flex: 1; background: #0D1A26; border: 1px solid #FFBE7A33;
    color: #F2E4C9; border-radius: 8px; padding: 5px 10px;
    font-size: .83rem;
}

/* ═══════════════════════════════════════
   FICHES PDF MJ — redesign propre
   ═══════════════════════════════════════ */
.oni-pdf-card {
    background: #0D1A26;
    border: 1px solid #FFBE7A22;
    border-radius: 12px;
    overflow: hidden;
    margin-bottom: 16px;
}

/* Header : nom du template + boutons */
.oni-pdf-card__header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 18px;
    background: linear-gradient(90deg, #0D2633, #1F3A4A);
    border-bottom: 1px solid #FFBE7A22;
    flex-wrap: wrap;
}
.oni-pdf-card__title {
    font-family: 'Marcellus SC', serif;
    font-size: .95rem;
    color: #FFBE7A;
    flex: 1;
    min-width: 120px;
}
.oni-pdf-card__btns {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
    flex-wrap: wrap;
}

/* Corps : liste des fiches */
.oni-pdf-card__body { padding: 0; }
.oni-pdf-card__empty {
    padding: 14px 18px;
    font-size: .82rem;
    color: #CBBFA2;
    font-style: italic;
}

/* Ligne fiche joueur */
.oni-pdf-entry {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 14px 18px;
    border-top: 1px solid #FFBE7A0F;
    flex-wrap: wrap;
}
.oni-pdf-entry__left {
    flex: 1;
    min-width: 160px;
    display: flex;
    flex-direction: column;
    gap: 3px;
}
.oni-pdf-entry__who {
    font-size: .88rem;
    color: #F2E4C9;
    line-height: 1.45;
}
.oni-pdf-entry__who strong { color: #F2E4C9; }
.oni-pdf-entry__who em { color: #FFBE7A; font-style: normal; }
.oni-pdf-entry__when {
    font-size: .72rem;
    color: #CBBFA2;
}
.oni-pdf-entry__actions {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
    flex-wrap: wrap;
    align-items: center;
}

/* Modale visibilité */
.oni-vis-players-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    max-height: 280px;
    overflow-y: auto;
    padding: 4px 0;
}
.oni-vis-player-label {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    background: #0D1A26;
    border: 1px solid #FFBE7A22;
    border-radius: 8px;
    font-size: .85rem;
    color: #F2E4C9;
    cursor: pointer;
    transition: border-color .15s;
}
.oni-vis-player-label:hover { border-color: #FFBE7A55; }
.oni-vis-player-label--disabled {
    opacity: .5;
    cursor: not-allowed;
}

/* ─── Notifications redesign ─── */
.oni-notif-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 8px 14px 6px;
    border-bottom: 1px solid #FFBE7A22;
    margin-bottom: 4px;
}
.oni-notif-count { font-size: .78rem; color: #CBBFA2; }
.oni-notif-item {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 14px;
    border-bottom: 1px solid #FFBE7A0A;
}
.oni-notif-msg { flex: 1; font-size: .83rem; color: #F2E4C9; }
.oni-notif-date { font-size: .7rem; color: #CBBFA2; white-space: nowrap; }
.oni-notif-read, .oni-notif-close-one {
    background: none; border: 1px solid #FFBE7A33;
    color: #CBBFA2; border-radius: 6px;
    padding: 2px 8px; font-size: .75rem; cursor: pointer;
    white-space: nowrap; flex-shrink: 0;
}
.oni-notif-read:hover, .oni-notif-close-one:hover { border-color: #FFBE7A; color: #FFBE7A; }

/* ─── Note MJ affichée côté joueur ─── */
.oni-player-pdf-item__header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 12px 0; gap: 10px; flex-wrap: wrap;
}
.oni-player-gm-note {
    background: linear-gradient(135deg, #1F2A1A, #1A2820);
    border: 1px solid #FFBE7A44;
    border-left: 3px solid #FFBE7A;
    border-radius: 8px;
    padding: 12px 14px;
    margin-top: 6px;
}
.oni-player-gm-note__header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 8px;
}
.oni-player-gm-note__header span {
    font-size: .78rem; font-weight: 600;
    color: #FFBE7A; text-transform: uppercase; letter-spacing: .06em;
}
.oni-player-gm-note__close {
    background: none; border: none; color: #CBBFA2;
    cursor: pointer; font-size: .9rem; padding: 0 4px;
}
.oni-player-gm-note__close:hover { color: #FFBE7A; }
.oni-player-gm-note__text {
    font-size: .87rem; color: #F2E4C9;
    line-height: 1.55; white-space: pre-wrap;
}

/* ─── Logo portail (icône Iconify grande) ─── */
.oni-portal__logo-icon { font-size: 64px; line-height: 1; display: flex !important; justify-content: center; align-items: center; }

/* ─── Prochaines séances portail ─── */
.oni-portal__upcoming {
    margin-top: 28px;
}
.oni-portal__upcoming-title {
    font-family: 'Marcellus SC', serif;
    font-size: .9rem; color: #FFBE7A;
    margin: 0 0 12px; display: flex; align-items: center; gap: 8px;
    text-transform: uppercase; letter-spacing: .08em;
}
.oni-portal__upcoming-list { display: flex; flex-direction: column; gap: 10px; }
.oni-upcoming-item {
    background: linear-gradient(135deg, #0D2633, #1F3A4A);
    border: 1px solid #FFBE7A22; border-radius: 12px;
    padding: 14px 18px;
}
.oni-upcoming-item__top {
    display: flex; justify-content: space-between; align-items: flex-start;
    gap: 12px; margin-bottom: 10px;
}
.oni-upcoming-item__info { display: flex; flex-direction: column; gap: 3px; flex: 1; }
.oni-upcoming-item__session {
    font-family: 'Marcellus SC', serif; font-size: .95rem; color: #F2E4C9;
}
.oni-upcoming-item__meta { font-size: .75rem; color: #CBBFA2; }
.oni-upcoming-item__hint {
    font-size: .75rem; color: #FFBE7A; font-weight: 600;
    white-space: nowrap; flex-shrink: 0;
}
.oni-upcoming-item__bar-wrap {
    background: #0D1A26; border-radius: 20px; height: 5px; overflow: hidden;
}
.oni-upcoming-item__bar {
    height: 100%; border-radius: 20px;
    background: linear-gradient(90deg, #F2A663, #FFBE7A);
    transition: width .6s ease;
}

/* ─── Champ heure et durée dans l'ajout de séance ─── */
#oni-schedule-time, #oni-schedule-duration {
    width: 100px;
}

/* ─── Couleur de session (custom property injectée dynamiquement) ─── */
.oni-session-themed {
    --session-color: #FFBE7A;
}

/* Onglets actifs : couleur session */
.oni-session-themed .oni-tab--active,
.oni-session-themed .oni-tab:hover {
    background: var(--session-color) !important;
    color: #152635 !important;
}

/* Code badge de la session */
.oni-session-themed .oni-code-badge {
    background: color-mix(in srgb, var(--session-color) 15%, transparent) !important;
    color: var(--session-color) !important;
    border-color: color-mix(in srgb, var(--session-color) 40%, transparent) !important;
}

/* Bordure haute colorée sur le premier cadre du dashboard */
.oni-session-themed .oni-dashboard__header {
    border-top: 4px solid var(--session-color);
    padding-left: 0;
}

/* Titre de la session dans l'éditeur */
.oni-session-themed #oni-session-editor-title {
    color: var(--session-color);
}

/* ─── Champs séance avec tooltip ─── */
.oni-schedule-field {
    position: relative;
    display: flex;
    align-items: center;
    gap: 4px;
    flex: 1;
    min-width: 120px;
}
.oni-schedule-field input {
    width: 100%;
    color: #F2E4C9 !important;
    background: #0D1A26 !important;
    border: 1px solid #FFBE7A33 !important;
    border-radius: 8px;
    padding: 7px 10px;
    font-size: .85rem;
    color-scheme: dark;
}
.oni-field-tooltip {
    cursor: help;
    flex-shrink: 0;
    position: relative;
}
.oni-field-tooltip::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: calc(100% + 6px);
    left: 50%;
    transform: translateX(-50%);
    background: #0D2633;
    border: 1px solid #FFBE7A44;
    color: #F2E4C9;
    font-size: .72rem;
    padding: 6px 12px;
    border-radius: 6px;
    pointer-events: none;
    opacity: 0;
    transition: opacity .15s;
    z-index: 100;
    width: max-content;
    max-width: 200px;
    white-space: normal;
    word-break: keep-all;
    text-align: center;
    line-height: 1.4;
}
.oni-field-tooltip:hover::after { opacity: 1; }

/* ─── Couleur session — bandelette ─── */
.oni-session-color-strip {
    height: 4px;
    border-radius: 0;
    margin: 0;
    opacity: 0.85;
    position: sticky;
    top: 0;
    z-index: 10;
    transition: background .3s ease;
}

/* ─── Cartes séances détaillées (dashboard joueur) ─── */
.oni-sched-card {
    background: linear-gradient(135deg, #0D2633, #1A3345);
    border: 1px solid #FFBE7A22;
    border-radius: 10px;
    padding: 12px 14px;
    margin-bottom: 10px;
}
.oni-sched-card__top {
    display: flex; justify-content: space-between;
    align-items: flex-start; gap: 12px; margin-bottom: 10px;
}
.oni-sched-card__left { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.oni-sched-card__label { font-family: 'Marcellus SC', serif; font-size: .88rem; color: #FFBE7A; }
.oni-sched-card__date { font-size: .8rem; color: #F2E4C9; display: flex; align-items: center; gap: 5px; }
.oni-sched-card__gm { font-size: .75rem; color: #CBBFA2; display: flex; align-items: center; gap: 5px; margin-top: 2px; }
.oni-sched-card__right { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; flex-shrink: 0; }
.oni-sched-pill {
    background: #FFBE7A18; color: #FFBE7A;
    border: 1px solid #FFBE7A33; border-radius: 20px;
    padding: 2px 8px; font-size: .72rem;
    display: flex; align-items: center; gap: 4px;
}
.oni-sched-card__hint {
    font-size: .73rem; font-weight: 600; color: #FFBE7A;
    background: #FFBE7A15; border-radius: 20px;
    padding: 2px 9px; white-space: nowrap;
}
.oni-sched-card__hint--now {
    color: #4CAF50; background: #4CAF5015;
}
.oni-sched-bar-wrap {
    background: #0D1A26; border-radius: 20px; height: 5px; overflow: hidden;
}
.oni-sched-bar {
    height: 100%; border-radius: 20px;
    background: #FFBE7A;
    transition: width .6s ease;
}

/* Hint "en cours" sur le portail */
.oni-upcoming-item__hint--now { color: #4CAF50 !important; }
