/* ============================================================
   Discord Dashboard — style.css (Pro Ticket Management)
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* Palette pro inspirée des outils de ticketing (Linear / Intercom / Zendesk) */
  --bg-primary:    #0e1117;
  --bg-secondary:  #161b22;
  --bg-tertiary:   #1c2128;
  --bg-hover:      #22272e;
  --bg-active:     #2d333b;
  --bg-elevated:   #1a1f27;

  --accent:        #5865f2;
  --accent-hover:  #4752c4;
  --accent-soft:   rgba(88, 101, 242, 0.12);
  --accent-light:  #7d89ff;

  --green:         #2da44e;
  --green-soft:    rgba(45, 164, 78, 0.15);
  --red:           #cf222e;
  --red-soft:      rgba(207, 34, 46, 0.15);
  --yellow:        #d4a72c;
  --yellow-soft:   rgba(212, 167, 44, 0.15);
  --orange:        #fb8500;
  --orange-soft:   rgba(251, 133, 0, 0.15);
  --purple:        #8957e5;
  --purple-soft:   rgba(137, 87, 229, 0.15);
  --cyan:          #1f9ed1;
  --cyan-soft:     rgba(31, 158, 209, 0.15);

  --text-normal:   #e6edf3;
  --text-muted:    #8b949e;
  --text-subtle:   #6e7681;
  --text-link:     #58a6ff;

  --border:        #30363d;
  --border-light:  #484f58;
  --border-subtle: #21262d;

  --radius-sm:     6px;
  --radius-md:     8px;
  --radius-lg:     12px;
  --radius-xl:     16px;

  --sidebar-w:     260px;
  --font:          'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;
  --font-mono:     'SF Mono', Consolas, 'Cascadia Code', monospace;

  --shadow-sm:     0 1px 2px rgba(0,0,0,0.2);
  --shadow-md:     0 4px 12px rgba(0,0,0,0.3);
  --shadow-lg:     0 12px 32px rgba(0,0,0,0.4);
}

html, body {
  height: 100%;
  font-family: var(--font);
  background: #0a0d12;
  color: var(--text-normal);
  font-size: 14px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

/* ── Décor global (orbes + grille) appliqué sur le dashboard ── */
.app-bg {
  position: fixed; inset: 0; z-index: 0;
  pointer-events: none; overflow: hidden;
}
.app-bg .orb {
  position: absolute; border-radius: 50%;
  filter: blur(90px); opacity: 0.55;
  animation: orbFloat 22s infinite ease-in-out;
}
.app-bg .orb-1 {
  width: 480px; height: 480px;
  background: radial-gradient(circle, rgba(88,101,242,0.6), transparent 70%);
  top: -150px; left: -120px;
}
.app-bg .orb-2 {
  width: 560px; height: 560px;
  background: radial-gradient(circle, rgba(137,87,229,0.55), transparent 70%);
  bottom: -200px; right: -160px;
  animation-delay: -9s;
}
.app-bg .orb-3 {
  width: 380px; height: 380px;
  background: radial-gradient(circle, rgba(31,158,209,0.45), transparent 70%);
  top: 35%; left: 40%;
  animation-delay: -15s;
}
.app-bg .grid-overlay {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(88,101,242,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(88,101,242,0.05) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse 90% 70% at 50% 50%, black 30%, transparent 85%);
}
.app-body { position: relative; }
.app-layout { position: relative; z-index: 1; }

a { color: var(--text-link); text-decoration: none; }
a:hover { text-decoration: underline; }
code { font-family: var(--font-mono); font-size: 0.9em; background: var(--bg-tertiary); padding: 1px 5px; border-radius: 4px; }

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--bg-active); border-radius: 6px; border: 2px solid var(--bg-primary); }
::-webkit-scrollbar-thumb:hover { background: var(--border-light); }

/* ── Layout ── */
.app-layout { display: flex; height: 100vh; overflow: hidden; }

/* ── Sidebar (glassmorphism) ── */
.sidebar {
  width: var(--sidebar-w);
  background: rgba(22, 27, 34, 0.78);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  display: flex; flex-direction: column; flex-shrink: 0;
  border-right: 1px solid rgba(255,255,255,0.06);
  overflow-y: auto;
  position: relative;
}
.sidebar::before {
  content: ''; position: absolute; top: 0; right: 0; width: 1px; height: 100%;
  background: linear-gradient(180deg, transparent, rgba(88,101,242,0.3), transparent);
}
.sidebar-header {
  display: flex; align-items: center; gap: 12px;
  padding: 18px 20px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  background: rgba(0,0,0,0.10);
}
.guild-icon { width: 42px; height: 42px; border-radius: var(--radius-md); object-fit: cover; box-shadow: var(--shadow-sm); }
.guild-icon-placeholder {
  width: 42px; height: 42px; border-radius: var(--radius-md);
  background: linear-gradient(135deg, var(--accent), var(--purple));
  display: flex; align-items: center; justify-content: center; font-size: 18px;
}
.guild-info { display: flex; flex-direction: column; min-width: 0; }
.guild-name { font-weight: 700; font-size: 14px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; letter-spacing: -0.01em; }
.guild-members { font-size: 11px; color: var(--text-muted); margin-top: 2px; }

.sidebar-nav { flex: 1; padding: 14px 12px; }
.nav-section {
  font-size: 10.5px; font-weight: 700; color: var(--text-subtle);
  text-transform: uppercase; letter-spacing: 1px;
  padding: 14px 10px 6px; margin-top: 4px;
}
.nav-section:first-child { margin-top: 0; padding-top: 4px; }
.nav-item {
  display: flex; align-items: center; gap: 12px;
  padding: 9px 12px; border-radius: var(--radius-md);
  cursor: pointer; font-size: 13.5px; font-weight: 500;
  color: var(--text-muted); text-decoration: none;
  transition: background 0.12s ease, color 0.12s ease;
  margin-bottom: 1px;
}
.nav-item:hover { background: var(--bg-hover); color: var(--text-normal); text-decoration: none; }
.nav-item.active { background: var(--accent-soft); color: var(--accent-light); font-weight: 600; }
.nav-item.active::before {
  content: ''; position: absolute; left: 0; width: 3px; height: 18px;
  background: var(--accent); border-radius: 0 3px 3px 0;
}
.nav-item { position: relative; }
.nav-icon { font-size: 16px; width: 20px; text-align: center; flex-shrink: 0; }

.sidebar-footer {
  padding: 12px 16px;
  border-top: 1px solid rgba(255,255,255,0.06);
  display: flex; align-items: center; gap: 10px;
  background: rgba(0,0,0,0.20);
}
.user-avatar { width: 34px; height: 34px; border-radius: 50%; object-fit: cover; }
.user-info { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.user-name { font-size: 13px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.user-perm { font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px; }
.user-perm.admin     { color: #ff7b72; }
.user-perm.moderator { color: var(--orange); }
.user-perm.viewer    { color: var(--text-muted); }
.logout-btn {
  color: var(--text-muted); font-size: 18px; cursor: pointer;
  text-decoration: none; padding: 6px 8px; border-radius: 6px;
  transition: color 0.15s ease, background 0.15s ease;
}
.logout-btn:hover { color: var(--red); background: var(--red-soft); text-decoration: none; }

/* ── Main content (transparent pour laisser voir le décor) ── */
.main-content { flex: 1; overflow-y: auto; background: transparent; }
.page-content { padding: 32px 40px; max-width: 1500px; margin: 0 auto; }
@media (max-width: 768px) { .page-content { padding: 20px; } }

/* ── Page header ── */
.page-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 28px; flex-wrap: wrap; gap: 14px; padding-bottom: 18px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.page-header h1 {
  font-size: 26px; font-weight: 800; letter-spacing: -0.02em;
  background: linear-gradient(135deg, #f2f3f5 0%, #b1b8c0 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.header-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.back-btn {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--text-muted); font-size: 13px; margin-bottom: 6px;
  transition: color 0.12s;
}
.back-btn:hover { color: var(--text-normal); text-decoration: none; }

/* ── Buttons ── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 9px 16px; border-radius: var(--radius-md);
  border: 1px solid transparent; cursor: pointer;
  font-size: 13.5px; font-weight: 600; font-family: var(--font);
  transition: background 0.15s ease, border-color 0.15s ease, transform 0.05s ease;
  text-decoration: none; white-space: nowrap; line-height: 1.2;
}
.btn:hover { text-decoration: none; }
.btn:active { transform: translateY(1px); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-primary {
  background: linear-gradient(135deg, var(--accent), #4752c4);
  color: white;
  box-shadow: 0 4px 16px rgba(88,101,242,0.35);
}
.btn-primary:hover {
  box-shadow: 0 6px 24px rgba(88,101,242,0.5);
  transform: translateY(-1px);
}
.btn-secondary { background: var(--bg-tertiary); color: var(--text-normal); border-color: var(--border); }
.btn-secondary:hover { background: var(--bg-hover); border-color: var(--border-light); }
.btn-success { background: var(--green); color: white; }
.btn-success:hover { background: #218739; }
.btn-danger { background: var(--red); color: white; }
.btn-danger:hover { background: #a40e19; }
.btn-warning { background: var(--orange); color: white; }
.btn-ghost { background: transparent; color: var(--text-muted); border-color: var(--border); }
.btn-ghost:hover { background: var(--bg-hover); color: var(--text-normal); }
.btn-sm { padding: 6px 12px; font-size: 12.5px; }
.btn-xs { padding: 4px 9px; font-size: 11.5px; }
.btn-icon {
  background: none; border: none; cursor: pointer; font-size: 15px;
  padding: 6px 8px; border-radius: 6px; color: var(--text-muted);
  transition: color 0.15s ease, background 0.15s ease;
}
.btn-icon:hover { color: var(--text-normal); background: var(--bg-hover); }

/* ── Card (glassmorphism subtle) ── */
.card {
  background: rgba(22, 27, 34, 0.78);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-radius: var(--radius-lg);
  padding: 20px;
  border: 1px solid rgba(255,255,255,0.06);
  box-shadow:
    0 8px 32px rgba(0,0,0,0.3),
    0 0 0 1px rgba(255,255,255,0.02) inset;
  margin-bottom: 16px;
  transition: border-color 0.18s, transform 0.18s;
}
.card:hover { border-color: rgba(255,255,255,0.10); }
.card-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 18px; padding-bottom: 14px;
  border-bottom: 1px solid var(--border-subtle);
}
.card-header h3 { font-size: 15px; font-weight: 700; letter-spacing: -0.01em; }
.link-btn {
  font-size: 13px; color: var(--accent); font-weight: 600;
  transition: color 0.12s;
}
.link-btn:hover { color: var(--accent-light); text-decoration: none; }

/* ── Forms ── */
.form-group { margin-bottom: 18px; }
.form-row { display: flex; gap: 14px; flex-wrap: wrap; }
.form-row .form-group { flex: 1; min-width: 0; }
label {
  display: block; font-size: 12px; font-weight: 600;
  color: var(--text-muted); text-transform: uppercase;
  letter-spacing: 0.6px; margin-bottom: 7px;
}
input[type=text], input[type=url], input[type=email], input[type=password],
input[type=number], textarea, select {
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  color: var(--text-normal);
  padding: 10px 13px;
  font-size: 14px; font-family: var(--font);
  width: 100%; outline: none;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
input:focus, textarea:focus, select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}
input::placeholder, textarea::placeholder { color: var(--text-subtle); }
textarea { resize: vertical; min-height: 90px; line-height: 1.5; }
select { cursor: pointer; }
select option { background: var(--bg-secondary); }
.hint { font-size: 12px; color: var(--text-muted); margin-top: 6px; display: block; line-height: 1.5; }
.checkbox-row { display: flex; gap: 18px; flex-wrap: wrap; }
.checkbox-label {
  display: flex; align-items: center; gap: 8px;
  font-size: 13.5px; font-weight: 500; color: var(--text-normal);
  text-transform: none; letter-spacing: 0; cursor: pointer;
}
.checkbox-label input { width: auto; cursor: pointer; }
.sep { height: 1px; background: var(--border-subtle); margin: 18px 0; }

/* ── Stats ── */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px; margin-bottom: 28px;
}
.stat-card {
  background: rgba(22, 27, 34, 0.78);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-radius: var(--radius-lg);
  padding: 20px;
  display: flex; align-items: center; gap: 16px;
  border: 1px solid rgba(255,255,255,0.06);
  box-shadow: 0 8px 32px rgba(0,0,0,0.25);
  transition: border-color 0.18s, transform 0.18s;
}
.stat-card:hover {
  border-color: rgba(88,101,242,0.30);
  transform: translateY(-2px);
}
.stat-icon {
  font-size: 24px; width: 50px; height: 50px;
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.stat-icon.blue   { background: var(--accent-soft);  color: var(--accent-light); }
.stat-icon.purple { background: var(--purple-soft);  color: var(--purple); }
.stat-icon.green  { background: var(--green-soft);   color: var(--green); }
.stat-icon.orange { background: var(--orange-soft);  color: var(--orange); }
.stat-icon.red    { background: var(--red-soft);     color: var(--red); }
.stat-icon.cyan   { background: var(--cyan-soft);    color: var(--cyan); }
.stat-info { display: flex; flex-direction: column; }
.stat-value { font-size: 28px; font-weight: 800; line-height: 1; letter-spacing: -0.02em; }
.stat-label { font-size: 12.5px; color: var(--text-muted); font-weight: 500; margin-top: 6px; }

/* ── Dashboard grid ── */
.dashboard-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 900px) { .dashboard-grid { grid-template-columns: 1fr; } }

/* ── Tables ── */
.data-table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.data-table th {
  text-align: left; padding: 12px 16px;
  font-size: 11px; font-weight: 700; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: 0.6px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  background: rgba(0,0,0,0.18);
}
.data-table td {
  padding: 13px 16px; border-bottom: 1px solid rgba(255,255,255,0.04);
  vertical-align: middle;
}
.data-table tr:last-child td { border-bottom: none; }
.data-table tr:hover td { background: rgba(88,101,242,0.06); }
.data-table a { color: var(--accent-light); font-weight: 600; }

/* ── Badges ── */
.badge-status {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 10px; border-radius: 12px;
  font-size: 11px; font-weight: 700; text-transform: capitalize;
  border: 1px solid transparent;
}
.badge-status.open     { background: var(--green-soft);  color: var(--green);  border-color: rgba(45,164,78,0.3); }
.badge-status.claimed  { background: var(--yellow-soft); color: var(--yellow); border-color: rgba(212,167,44,0.3); }
.badge-status.closed   { background: var(--red-soft);    color: var(--red);    border-color: rgba(207,34,46,0.3); }
.badge-status.archived { background: var(--bg-active);   color: var(--text-muted); }
.badge-status.sent     { background: var(--green-soft);  color: var(--green); }
.badge-status.failed   { background: var(--red-soft);    color: var(--red); }
.badge-status.deleted  { background: var(--bg-active);   color: var(--text-muted); }

.priority-badge {
  display: inline-flex; padding: 2px 9px; border-radius: 4px;
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px;
}
.priority-badge.low     { background: var(--green-soft);  color: var(--green); }
.priority-badge.medium  { background: var(--cyan-soft);   color: var(--cyan); }
.priority-badge.high    { background: var(--orange-soft); color: var(--orange); }
.priority-badge.urgent  { background: var(--red-soft);    color: var(--red);
                          animation: urgentPulse 2s ease-in-out infinite; }
@keyframes urgentPulse { 0%,100%{ box-shadow:0 0 0 0 rgba(207,34,46,0.4);} 50%{box-shadow:0 0 0 4px rgba(207,34,46,0);} }

.status-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px; border-radius: 20px;
  font-size: 12.5px; font-weight: 600;
}
.status-badge.online  { background: var(--green-soft); color: var(--green); }
.status-badge.offline { background: var(--red-soft);   color: var(--red); }
.dot { width: 7px; height: 7px; border-radius: 50%; background: currentColor; animation: pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.4} }

/* ── Logs ── */
.log-list { display: flex; flex-direction: column; gap: 1px; }
.log-row {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 10px 12px; border-radius: var(--radius-sm);
  transition: background 0.12s;
}
.log-row:hover { background: var(--bg-hover); }
.log-dot {
  width: 8px; height: 8px; border-radius: 50%;
  flex-shrink: 0; margin-top: 6px;
}
.log-row.info    .log-dot { background: var(--accent); }
.log-row.success .log-dot { background: var(--green); }
.log-row.warning .log-dot { background: var(--yellow); }
.log-row.error   .log-dot { background: var(--red); }
.log-content { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.log-action { font-size: 13.5px; font-weight: 600; }
.log-details { font-size: 12px; color: var(--text-muted); }
.log-time { font-size: 11px; color: var(--text-subtle); flex-shrink: 0; }
.log-level-dot { display: inline-block; width: 9px; height: 9px; border-radius: 50%; }
.log-level-dot.info    { background: var(--accent); }
.log-level-dot.success { background: var(--green); }
.log-level-dot.warning { background: var(--yellow); }
.log-level-dot.error   { background: var(--red); }

/* ── Filter bar ── */
.filter-bar {
  display: flex; align-items: center; gap: 16px;
  margin-bottom: 20px; flex-wrap: wrap;
  background: rgba(22, 27, 34, 0.78);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  padding: 14px 16px;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255,255,255,0.06);
}
.search-form { display: flex; gap: 8px; align-items: center; flex: 1; min-width: 280px; }
.search-input { max-width: 320px; }
.status-tabs { display: flex; gap: 4px; flex-wrap: wrap; }
.status-tab {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 7px 13px; border-radius: var(--radius-md);
  font-size: 13px; font-weight: 500; color: var(--text-muted);
  text-decoration: none; border: 1px solid transparent;
  transition: all 0.12s;
}
.status-tab:hover { background: var(--bg-hover); color: var(--text-normal); text-decoration: none; }
.status-tab.active { background: var(--accent-soft); color: var(--accent-light); border-color: rgba(88,101,242,0.3); }
.count-badge {
  display: inline-flex; padding: 1px 8px; border-radius: 10px;
  font-size: 11px; font-weight: 700; background: var(--bg-active);
}
.status-tab.active .count-badge { background: rgba(88,101,242,0.25); color: var(--accent-light); }

/* ── Two-column layout ── */
.two-col-layout { display: grid; grid-template-columns: 1fr 380px; gap: 20px; align-items: start; }
.col-main { min-width: 0; }
.col-side { min-width: 0; }
@media (max-width: 1000px) { .two-col-layout { grid-template-columns: 1fr; } }

/* ── Tabs ── */
.tab-bar { display: flex; gap: 2px; margin-bottom: 16px; border-bottom: 1px solid var(--border); }
.tab-btn {
  padding: 11px 20px; background: none; border: none;
  border-bottom: 2px solid transparent; cursor: pointer;
  font-size: 13.5px; font-weight: 600; color: var(--text-muted);
  font-family: var(--font); margin-bottom: -1px;
  transition: color 0.12s, border-color 0.12s;
}
.tab-btn:hover { color: var(--text-normal); }
.tab-btn.active { color: var(--accent-light); border-bottom-color: var(--accent); }
.tab-content { display: none; }
.tab-content.active { display: block; }

/* ── Discord embed preview ── */
.discord-embed-wrap { position: relative; }
.discord-embed {
  border-left: 4px solid var(--accent);
  background: var(--bg-elevated);
  border-radius: 0 6px 6px 0; padding: 14px 16px;
  font-size: 14px;
}
.discord-embed .ep-author { font-size: 12px; font-weight: 600; color: var(--text-muted); margin-bottom: 6px; }
.discord-embed .ep-title { font-weight: 700; font-size: 15px; color: var(--accent-light); margin-bottom: 6px; }
.discord-embed .ep-desc { font-size: 13.5px; line-height: 1.55; color: var(--text-normal); }
.discord-embed .ep-fields { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-top: 12px; }
.discord-embed .ep-field { background: var(--bg-tertiary); border-radius: 4px; padding: 8px 10px; }
.discord-embed .ep-field-name { font-size: 11px; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.4px; margin-bottom: 3px; }
.discord-embed .ep-image { width: 100%; border-radius: 4px; margin-top: 12px; max-height: 220px; object-fit: cover; }
.discord-embed .ep-footer { font-size: 11px; color: var(--text-muted); margin-top: 12px; }
.ep-thumb { position: absolute; top: 14px; right: 14px; width: 72px; height: 72px; border-radius: 6px; object-fit: cover; }

/* ── Field rows ── */
.rr-entry-form, .field-row { display: flex; gap: 8px; align-items: center; margin-bottom: 8px; flex-wrap: wrap; }
.rr-entry-form input, .rr-entry-form select, .field-row input, .field-row select { flex: 1; min-width: 0; }

/* ── Reaction Roles ── */
.rr-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(360px, 1fr)); gap: 18px; }
.rr-card {
  background: var(--bg-secondary); border-radius: var(--radius-lg);
  border: 1px solid var(--border); overflow: hidden;
  transition: border-color 0.15s, transform 0.15s;
}
.rr-card:hover { border-color: var(--border-light); transform: translateY(-2px); }
.rr-card-header { display: flex; align-items: flex-start; justify-content: space-between; padding: 16px 18px; gap: 10px; }
.rr-card-header h3 { font-size: 15px; font-weight: 700; margin-bottom: 4px; }
.rr-channel { font-size: 12px; color: var(--text-muted); }
.rr-mode-badge { padding: 4px 10px; border-radius: 12px; font-size: 11px; font-weight: 700; white-space: nowrap; }
.rr-mode-badge.mode-normal  { background: var(--green-soft);  color: var(--green); }
.rr-mode-badge.mode-unique  { background: var(--accent-soft); color: var(--accent-light); }
.rr-mode-badge.mode-verify  { background: var(--yellow-soft); color: var(--yellow); }
.rr-mode-badge.mode-reverse { background: var(--red-soft);    color: var(--red); }
.rr-entries { padding: 0 18px 14px; display: flex; flex-direction: column; gap: 8px; }
.rr-entry { display: flex; align-items: center; gap: 10px; font-size: 13px; }
.rr-emoji { font-size: 18px; width: 24px; text-align: center; }
.rr-arrow { color: var(--text-subtle); }
.rr-role { font-weight: 600; color: var(--accent-light); }
.rr-desc { font-size: 12px; color: var(--text-muted); margin-left: auto; }
.rr-card-footer {
  padding: 12px 18px; border-top: 1px solid var(--border-subtle);
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px; flex-wrap: wrap; background: var(--bg-tertiary);
}
.rr-msg-id { font-size: 11px; color: var(--text-subtle); font-family: var(--font-mono); }
.rr-actions { display: flex; gap: 6px; }

/* ── Tickets ── */
.ticket-layout { display: grid; grid-template-columns: 1fr 320px; gap: 18px; align-items: start; }
@media (max-width: 900px) { .ticket-layout { grid-template-columns: 1fr; } }
.ticket-main { display: flex; flex-direction: column; gap: 14px; }
.ticket-messages {
  background: rgba(22, 27, 34, 0.78);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255,255,255,0.06);
  padding: 18px;
  max-height: 540px; overflow-y: auto;
  display: flex; flex-direction: column; gap: 16px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.25);
}
.ticket-msg { display: flex; gap: 12px; }
.msg-avatar { flex-shrink: 0; }
.msg-avatar img { width: 38px; height: 38px; border-radius: 50%; }
.msg-avatar-placeholder {
  width: 38px; height: 38px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--purple));
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 14px; color: white;
}
.msg-body { flex: 1; min-width: 0; }
.msg-header { display: flex; align-items: center; gap: 8px; margin-bottom: 5px; }
.msg-author { font-weight: 700; font-size: 14px; }
.staff-badge {
  font-size: 10px; font-weight: 700;
  background: var(--accent); color: white;
  padding: 2px 7px; border-radius: 4px;
  text-transform: uppercase; letter-spacing: 0.4px;
}
.msg-time { font-size: 11px; color: var(--text-muted); }
.msg-content {
  font-size: 14px; line-height: 1.55;
  background: var(--bg-tertiary);
  border-radius: 0 var(--radius-md) var(--radius-md) var(--radius-md);
  padding: 11px 14px; border: 1px solid var(--border-subtle);
}
.ticket-msg.staff .msg-content {
  background: var(--accent-soft);
  border-color: rgba(88,101,242,0.3);
}
.ticket-reply-box {
  background: rgba(22, 27, 34, 0.78);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255,255,255,0.06);
  box-shadow: 0 8px 32px rgba(0,0,0,0.25);
  padding: 16px;
  transition: border-color 0.15s, background 0.15s;
}
.ticket-reply-box.drag-over {
  border-color: var(--accent); background: var(--accent-soft);
  box-shadow: inset 0 0 0 2px var(--accent);
}
.ticket-reply-box.drag-over::after {
  content: "📥 Dépose tes fichiers ici"; display: block;
  text-align: center; color: var(--accent-light); font-weight: 700;
  margin-top: 6px; font-size: 13px;
}
.ticket-reply-box textarea { margin-bottom: 10px; }
.reply-actions { display: flex; align-items: center; justify-content: space-between; gap: 10px; flex-wrap: wrap; }
.ticket-sidebar { display: flex; flex-direction: column; gap: 14px; }
.info-list {
  display: grid; grid-template-columns: auto 1fr;
  gap: 8px 14px; font-size: 13px;
}
.info-list dt {
  color: var(--text-muted); font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.5px; padding-top: 2px;
}
.info-list dd { word-break: break-word; }
.action-btns { display: flex; gap: 6px; }
.ticket-link { font-weight: 700; color: var(--accent-light); }
.user-tag {
  font-family: var(--font-mono); font-size: 12px;
  background: var(--bg-active); padding: 3px 8px;
  border-radius: 4px; color: var(--text-normal);
}
.text-muted { color: var(--text-muted); }
.text-subtle { color: var(--text-subtle); }

/* ── Settings ── */
.settings-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(360px, 1fr)); gap: 18px; }

/* ── Users ── */
.perm-select {
  background: var(--bg-primary); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text-normal);
  padding: 5px 10px; font-size: 12.5px; cursor: pointer;
}
.perm-legend { display: flex; flex-direction: column; gap: 10px; margin-top: 10px; }
.perm-item { display: flex; align-items: center; gap: 12px; font-size: 13px; }
.perm-badge {
  padding: 3px 10px; border-radius: 12px;
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.4px;
}
.perm-badge.viewer    { background: var(--bg-active);    color: var(--text-muted); }
.perm-badge.moderator { background: var(--orange-soft);  color: var(--orange); }
.perm-badge.admin     { background: var(--red-soft);     color: #ff7b72; }

/* ── Role Permissions ── */
.role-perm-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(440px, 1fr));
  gap: 18px;
}
.role-perm-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 18px 20px;
  display: flex; flex-direction: column; gap: 16px;
  transition: border-color 0.15s;
}
.role-perm-card:hover { border-color: var(--border-light); }
.role-perm-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 12px;
}
.role-name { font-size: 16px; font-weight: 700; letter-spacing: -0.01em; }
.role-id {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--text-subtle); margin-top: 4px;
  background: var(--bg-tertiary); padding: 2px 7px;
  border-radius: 4px; display: inline-block;
}
.badge-default {
  display: inline-block; margin-left: 8px;
  padding: 2px 8px; border-radius: 10px;
  background: var(--accent-soft); color: var(--accent-light);
  font-size: 10px; font-weight: 700; letter-spacing: 0.5px;
  vertical-align: middle;
}
.perm-level-select {
  background: var(--bg-primary); border: 1px solid var(--border);
  border-radius: var(--radius-md); color: var(--text-normal);
  padding: 6px 10px; font-size: 12.5px; font-weight: 600;
  cursor: pointer;
}
.cap-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px 14px;
  padding: 12px 0; border-top: 1px solid var(--border-subtle);
  border-bottom: 1px solid var(--border-subtle);
}
.cap-row {
  display: flex; align-items: center; gap: 9px;
  cursor: pointer; padding: 4px 0;
  font-size: 13px; color: var(--text-normal);
  text-transform: none; letter-spacing: 0; font-weight: 500;
  margin: 0;
}
.cap-row input { width: auto; cursor: pointer; accent-color: var(--accent); }
.cap-row:hover span { color: var(--accent-light); }
.role-perm-foot {
  display: flex; justify-content: flex-end; gap: 8px;
}

/* ── Modals (revamped) ── */
.modal-overlay {
  position: fixed; inset: 0;
  background: radial-gradient(ellipse at center, rgba(8,10,16,0.78) 0%, rgba(0,0,0,0.88) 100%);
  -webkit-backdrop-filter: blur(8px) saturate(140%);
          backdrop-filter: blur(8px) saturate(140%);
  display: none; align-items: center; justify-content: center;
  z-index: 1000; padding: 24px;
  animation: modalFadeIn 0.22s cubic-bezier(0.16, 1, 0.3, 1);
}
.modal-overlay[style*="flex"] { display: flex !important; }
.modal {
  position: relative;
  background: linear-gradient(180deg, rgba(28, 33, 42, 0.97) 0%, rgba(22, 27, 34, 0.97) 100%);
  -webkit-backdrop-filter: blur(28px) saturate(140%);
          backdrop-filter: blur(28px) saturate(140%);
  border-radius: 18px;
  padding: 0;
  max-width: 600px; width: 100%;
  max-height: 90vh;
  display: flex; flex-direction: column;
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 40px 100px -20px rgba(0,0,0,0.7),
    0 0 0 1px rgba(255,255,255,0.04) inset,
    0 1px 0 rgba(255,255,255,0.05) inset;
  animation: modalIn 0.32s cubic-bezier(0.16, 1, 0.3, 1);
  overflow: hidden;
}
/* Halo dégradé subtil sur le bord supérieur */
.modal::before {
  content: ''; position: absolute; inset: 0;
  border-radius: inherit; pointer-events: none;
  background: linear-gradient(135deg, rgba(88,101,242,0.18), transparent 35%, transparent 65%, rgba(137,87,229,0.12));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  padding: 1px;
}
.modal-sm { max-width: 420px; }
.modal-md { max-width: 560px; }
.modal-lg { max-width: 760px; }

.modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 24px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  flex-shrink: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0.025) 0%, transparent 100%);
}
.modal-header h2 {
  font-size: 17px; font-weight: 700; letter-spacing: -0.01em;
  background: linear-gradient(180deg, #fff 0%, #c9d1d9 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.modal-close {
  background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.06);
  cursor: pointer; font-size: 14px; color: var(--text-muted);
  width: 30px; height: 30px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 8px;
  transition: color 0.15s, background 0.15s, border-color 0.15s, transform 0.15s;
}
.modal-close:hover { color: var(--text-normal); background: var(--red-soft); border-color: rgba(207,34,46,0.4); transform: rotate(90deg); }

/* Corps de la modale (scrollable) */
.modal-body {
  padding: 20px 24px 8px;
  overflow-y: auto; flex: 1 1 auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,0.15) transparent;
}
.modal-body::-webkit-scrollbar { width: 8px; }
.modal-body::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.12); border-radius: 4px; }
.modal-body::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.25); }
.modal-body .form-group:last-child { margin-bottom: 0; }

/* Compat : modales sans .modal-body — on rétro-applique des marges latérales */
.modal > .form-group,
.modal > .form-row,
.modal > .alert,
.modal > p,
.modal > h3,
.modal > .checkbox-row {
  margin-left: 24px; margin-right: 24px;
}
.modal > .modal-header + .form-group,
.modal > .modal-header + .form-row,
.modal > .modal-header + .alert,
.modal > .modal-header + p,
.modal > .modal-header + h3 { margin-top: 18px; }

.modal-footer {
  display: flex; justify-content: flex-end; gap: 10px;
  padding: 14px 24px 18px;
  border-top: 1px solid rgba(255,255,255,0.06);
  flex-shrink: 0;
  background: linear-gradient(0deg, rgba(0,0,0,0.18) 0%, transparent 100%);
}

@keyframes modalFadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes fadeIn      { from { opacity: 0; } to { opacity: 1; } }
@keyframes modalIn {
  from { opacity: 0; transform: translateY(14px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0)    scale(1); }
}

/* ── Alerts ── */
.alert {
  padding: 14px 16px; border-radius: var(--radius-md);
  font-size: 13.5px; margin-bottom: 18px;
  border: 1px solid transparent;
  display: flex; align-items: flex-start; gap: 10px;
}
.alert-success { background: var(--green-soft);  border-color: rgba(45,164,78,0.3);  color: var(--green); }
.alert-error   { background: var(--red-soft);    border-color: rgba(207,34,46,0.3);  color: #ff7b72; }
.alert-info    { background: var(--accent-soft); border-color: rgba(88,101,242,0.3); color: var(--accent-light); }
.alert-warning { background: var(--yellow-soft); border-color: rgba(212,167,44,0.3); color: var(--yellow); }
.alert code { background: rgba(0,0,0,0.25); }

/* ── Toast ── */
#toast-container {
  position: fixed; bottom: 24px; right: 24px;
  z-index: 9999; display: flex; flex-direction: column; gap: 10px;
  pointer-events: none;
}
.toast {
  padding: 13px 18px; border-radius: var(--radius-md);
  font-size: 13.5px; font-weight: 600;
  pointer-events: all; animation: toastIn 0.3s cubic-bezier(0.4,0,0.2,1);
  border: 1px solid transparent; max-width: 360px;
  box-shadow: var(--shadow-md);
  display: flex; align-items: center; gap: 10px;
}
.toast.success { background: #143523; border-color: rgba(45,164,78,0.5);  color: var(--green); }
.toast.error   { background: #361616; border-color: rgba(207,34,46,0.5);  color: #ff7b72; }
.toast.info    { background: #1a1f3d; border-color: rgba(88,101,242,0.5); color: var(--accent-light); }
@keyframes toastIn { from { transform: translateX(110%); opacity: 0; } to { transform: translateX(0); opacity: 1; } }

/* ── Empty states ── */
.empty-state { text-align: center; padding: 60px 20px; }
.empty-icon { font-size: 56px; margin-bottom: 16px; opacity: 0.6; }
.empty-state h3 { font-size: 18px; margin-bottom: 8px; }
.empty-state p { color: var(--text-muted); font-size: 14px; margin-bottom: 24px; }
.empty-msg { color: var(--text-muted); font-size: 13px; font-style: italic; padding: 14px 0; text-align: center; }

/* ── Category rows ── */
.cat-row {
  display: flex; align-items: center; gap: 12px;
  padding: 11px 14px; background: var(--bg-tertiary);
  border-radius: var(--radius-md); margin-bottom: 8px;
  border: 1px solid var(--border-subtle);
}
.cat-emoji { font-size: 20px; }
.cat-name { flex: 1; font-size: 14px; font-weight: 600; }
.cat-enabled {
  font-size: 11px; font-weight: 700;
  padding: 2px 9px; border-radius: 12px;
  text-transform: uppercase; letter-spacing: 0.4px;
}
.cat-enabled.on  { background: var(--green-soft);  color: var(--green); }
.cat-enabled.off { background: var(--bg-active);   color: var(--text-muted); }

/* ── Login page (premium) ── */
.login-body {
  display: flex; align-items: center; justify-content: center;
  min-height: 100vh; background: #0a0d12;
  position: relative; overflow: hidden;
}
.login-bg {
  position: fixed; inset: 0; z-index: 0;
  pointer-events: none;
}
.login-bg .orb {
  position: absolute; border-radius: 50%;
  filter: blur(80px); opacity: 0.7;
  animation: orbFloat 20s infinite ease-in-out;
}
.login-bg .orb-1 {
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(88,101,242,0.55), transparent 70%);
  top: -120px; left: -100px;
}
.login-bg .orb-2 {
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(137,87,229,0.5), transparent 70%);
  bottom: -180px; right: -120px;
  animation-delay: -8s;
}
.login-bg .orb-3 {
  width: 350px; height: 350px;
  background: radial-gradient(circle, rgba(31,158,209,0.4), transparent 70%);
  top: 40%; right: 30%;
  animation-delay: -14s;
}
@keyframes orbFloat {
  0%,100% { transform: translate(0,0) scale(1); }
  33%     { transform: translate(40px,-30px) scale(1.06); }
  66%     { transform: translate(-30px,40px) scale(0.96); }
}
.login-bg .grid-overlay {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(88,101,242,0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(88,101,242,0.07) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 50%, black 30%, transparent 80%);
}

.login-container {
  position: relative; z-index: 1;
  width: 100%; max-width: 460px;
  padding: 20px;
  animation: loginEnter 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
@keyframes loginEnter {
  from { opacity: 0; transform: translateY(20px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

.login-card {
  background: rgba(22, 27, 34, 0.85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-radius: 20px;
  padding: 48px 44px 36px; text-align: center;
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 30px 80px rgba(0,0,0,0.6),
    0 0 0 1px rgba(255,255,255,0.03) inset;
  position: relative;
}
.login-card::before {
  content: ''; position: absolute; inset: 0;
  border-radius: 20px;
  padding: 1px;
  background: linear-gradient(135deg, rgba(88,101,242,0.4), rgba(137,87,229,0.2), transparent 50%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
}

.login-logo-wrap {
  position: relative; display: inline-block;
  margin-bottom: 24px;
}
.login-logo-glow {
  position: absolute; inset: -20px;
  background: radial-gradient(circle, rgba(88,101,242,0.6), transparent 60%);
  filter: blur(20px); animation: pulseLogo 3s ease-in-out infinite;
}
@keyframes pulseLogo {
  0%,100% { opacity: 0.6; transform: scale(1); }
  50%     { opacity: 1;   transform: scale(1.1); }
}
.login-logo-svg { position: relative; z-index: 1; }

.login-card h1 {
  font-size: 28px; font-weight: 800; margin-bottom: 8px;
  letter-spacing: -0.02em;
  background: linear-gradient(135deg, #f2f3f5, #b1b8c0);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.login-subtitle { color: var(--text-muted); font-size: 14px; margin-bottom: 28px; }

.btn-discord-login {
  display: flex; align-items: center; justify-content: center; gap: 12px;
  width: 100%;
  padding: 14px 24px;
  background: linear-gradient(135deg, var(--accent), #4752c4);
  color: white;
  border-radius: var(--radius-md);
  font-size: 15px; font-weight: 700;
  text-decoration: none;
  box-shadow: 0 8px 24px rgba(88,101,242,0.45);
  transition: transform 0.18s, box-shadow 0.18s;
  position: relative; overflow: hidden;
}
.btn-discord-login::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,0.18), transparent);
  transform: translateX(-100%); transition: transform 0.6s;
}
.btn-discord-login:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 36px rgba(88,101,242,0.6);
  text-decoration: none;
}
.btn-discord-login:hover::after { transform: translateX(100%); }
.btn-discord-login:active { transform: translateY(0); }

.login-features {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 8px; margin-top: 28px; padding-top: 22px;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.lf-item {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  font-size: 11.5px; color: var(--text-muted); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.5px;
}
.lf-item span { font-size: 22px; filter: grayscale(0.2); }

.login-note {
  font-size: 12px; color: var(--text-subtle);
  margin-top: 18px; line-height: 1.6;
}

.login-footer {
  text-align: center; margin-top: 18px; font-size: 11px; color: var(--text-subtle);
}
.login-footer a { color: var(--text-muted); }

/* ── Pages d'erreur (style login) ── */
.error-card {
  position: relative;
  padding-top: 60px !important;
}
.error-card .error-code {
  position: absolute;
  top: -40px; left: 50%; transform: translateX(-50%);
  font-size: 96px; font-weight: 900; line-height: 1;
  letter-spacing: -0.04em;
  background: linear-gradient(180deg, rgba(88,101,242,0.85), rgba(137,87,229,0.4));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  text-shadow: 0 4px 30px rgba(88,101,242,0.4);
  pointer-events: none;
  user-select: none;
}
.error-card .error-emoji {
  font-size: 48px; margin: 4px 0 16px;
  filter: drop-shadow(0 4px 20px rgba(88,101,242,0.45));
  animation: errorBounce 2.4s ease-in-out infinite;
}
@keyframes errorBounce {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}
.error-actions {
  display: flex; gap: 10px; margin: 20px 0 6px;
  flex-wrap: wrap;
}
.error-actions .btn { flex: 1; min-width: 120px; justify-content: center; }
@media (max-width: 480px) {
  .error-card .error-code { font-size: 72px; top: -30px; }
  .error-card .error-emoji { font-size: 40px; }
}

/* ============================================================
   📱 RESPONSIVE — Tablette & Mobile
   ============================================================ */

/* Hamburger menu — caché sur desktop */
.menu-toggle {
  display: none;
  width: 40px; height: 40px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  cursor: pointer;
  flex-direction: column; align-items: center; justify-content: center;
  gap: 4px; padding: 0;
  transition: background 0.15s, border-color 0.15s;
}
.menu-toggle:hover { background: var(--bg-hover); border-color: var(--border-light); }
.menu-toggle span {
  width: 18px; height: 2px;
  background: var(--text-normal);
  border-radius: 2px;
  transition: transform 0.25s, opacity 0.2s;
}
.menu-toggle.open span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.menu-toggle.open span:nth-child(2) { opacity: 0; }
.menu-toggle.open span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

.topbar-title-mobile {
  display: none;
  font-size: 15px; font-weight: 700;
  color: var(--text-normal);
  margin-left: 12px;
  flex: 1; min-width: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* Backdrop pour fermer le menu en cliquant à côté */
.sidebar-backdrop {
  display: none;
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.5);
  backdrop-filter: blur(2px);
  z-index: 99;
  opacity: 0; transition: opacity 0.25s;
}
.sidebar-backdrop.active { display: block; opacity: 1; }

/* ── ≤ 1024px : tablette ── */
@media (max-width: 1024px) {
  :root { --sidebar-w: 230px; }
  .page-content { padding: 24px 22px; }
  .stats-grid { grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 12px; }
  .dashboard-grid { grid-template-columns: 1fr; }
  .two-col-layout { grid-template-columns: 1fr; }
  .ticket-layout { grid-template-columns: 1fr; }
  .settings-grid { grid-template-columns: 1fr; }
  .role-perm-grid { grid-template-columns: 1fr; }
  .rr-grid { grid-template-columns: 1fr; }

  .data-table { font-size: 13px; }
  .data-table th, .data-table td { padding: 10px 12px; }
}

/* ── ≤ 768px : mobile (sidebar en drawer) ── */
@media (max-width: 768px) {
  .menu-toggle { display: flex; }
  .topbar-title-mobile { display: block; }
  .topbar { padding: 10px 14px; gap: 10px; }

  .app-layout { display: block; }
  .sidebar {
    position: fixed; top: 0; left: 0;
    width: 280px; height: 100vh; z-index: 100;
    transform: translateX(-100%);
    transition: transform 0.28s cubic-bezier(0.4,0,0.2,1);
    box-shadow: 18px 0 60px rgba(0,0,0,0.5);
  }
  .sidebar.open { transform: translateX(0); }

  .main-content { margin-left: 0; width: 100%; }
  .page-content { padding: 18px 14px; }

  /* Page header empile */
  .page-header { flex-direction: column; align-items: stretch; gap: 12px; padding-bottom: 14px; }
  .page-header h1 { font-size: 22px; }
  .header-actions { width: 100%; }
  .header-actions .btn { flex: 1; min-width: 0; }

  /* Stats sur 2 colonnes */
  .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .stat-card { padding: 14px; gap: 12px; }
  .stat-icon { width: 40px; height: 40px; font-size: 20px; }
  .stat-value { font-size: 22px; }

  /* Tableau scrollable horizontalement (sans déformer) */
  .card { padding: 16px; }
  .card[style*="padding:0"] .data-table,
  .card .data-table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .data-table thead, .data-table tbody, .data-table tr { display: table; width: 100%; table-layout: fixed; }
  .data-table th, .data-table td {
    padding: 10px 12px; font-size: 12.5px;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }

  /* Filtres */
  .filter-bar { flex-direction: column; align-items: stretch; padding: 12px; gap: 10px; }
  .search-form { flex-wrap: wrap; min-width: 0; }
  .search-form .search-input { max-width: 100%; flex: 1 1 100%; }
  .status-tabs { width: 100%; overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; padding-bottom: 4px; }
  .status-tab { white-space: nowrap; }

  /* Formulaires */
  .form-row { flex-direction: column; gap: 14px; }

  /* Modales en quasi plein écran */
  .modal-overlay { padding: 12px; align-items: flex-end; }
  .modal {
    max-width: 100%; max-height: 92vh;
    border-radius: 18px 18px var(--radius-md) var(--radius-md);
    padding: 20px;
    animation: modalSlideUp 0.28s cubic-bezier(0.16,1,0.3,1);
  }
  @keyframes modalSlideUp { from { transform: translateY(40px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

  /* Notif panel full width */
  .notif-panel {
    position: fixed; top: 60px; right: 8px; left: 8px;
    width: auto; max-height: calc(100vh - 80px);
  }

  /* Tickets */
  .ticket-messages { max-height: 60vh; padding: 14px; }
  .msg-content { font-size: 13.5px; padding: 9px 11px; }
  .msg-img { max-width: 100%; max-height: 220px; }

  /* Embed preview */
  .dp-thumb { width: 60px; height: 60px; }
  .dp-fields { grid-template-columns: 1fr !important; }

  /* Pagination */
  .pagination { flex-wrap: wrap; gap: 4px; }
  .page-info { width: 100%; text-align: center; margin: 8px 0 0; }

  /* Empêche le scroll de la page quand le menu est ouvert */
  body.menu-open { overflow: hidden; }

  /* Sidebar nav un peu plus aérée pour le toucher */
  .nav-item { padding: 11px 12px; font-size: 14px; }

  /* Page-header sub-text */
  .page-header p { font-size: 12.5px !important; }

  /* Actions row buttons (tickets) */
  .action-btns { flex-wrap: wrap; gap: 4px; }

  /* Reaction roles cards */
  .rr-card-header { flex-direction: column; align-items: flex-start; }
  .rr-card-footer { flex-direction: column; align-items: stretch; }
  .rr-actions { width: 100%; flex-wrap: wrap; }

  /* Login plus aéré */
  .login-card { padding: 32px 22px 26px; }
  .login-features { grid-template-columns: repeat(2, 1fr); gap: 6px; }
  .lf-item { font-size: 11px; }
}

/* ── ≤ 480px : très petits écrans ── */
@media (max-width: 480px) {
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .stat-icon { width: 36px; height: 36px; font-size: 17px; }
  .stat-value { font-size: 19px; }
  .stat-label { font-size: 11px; }
  .topbar-title-mobile { font-size: 14px; }
  .page-header h1 { font-size: 19px; }
  .btn { font-size: 13px; padding: 8px 14px; }
  .login-card h1 { font-size: 22px; }
  .btn-discord-login { padding: 12px 16px; font-size: 14px; }

  /* Mode "cards" pour les tableaux : chaque ligne devient une carte empilée.
     On ne casse pas la structure HTML — on change juste le rendu en mobile. */
  .data-table thead { display: none; }
  .data-table, .data-table tbody, .data-table tr, .data-table td { display: block; width: 100%; }
  .data-table tr {
    background: rgba(255,255,255,0.02);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: var(--radius-md);
    margin-bottom: 10px; padding: 10px 12px;
  }
  .data-table tr:hover td { background: transparent; }
  .data-table td {
    border-bottom: 1px dashed rgba(255,255,255,0.05);
    white-space: normal; overflow: visible; text-overflow: clip;
    padding: 7px 0; font-size: 13px;
  }
  .data-table td:last-child { border-bottom: none; }
  .data-table td::before {
    content: attr(data-label);
    display: block;
    font-size: 10.5px; font-weight: 700;
    color: var(--text-muted);
    text-transform: uppercase; letter-spacing: 0.5px;
    margin-bottom: 3px;
  }
  /* Si pas de data-label : on cache l'étiquette */
  .data-table td:not([data-label])::before { display: none; }
}

/* ── Topbar + Notifications ── */
.topbar {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 32px;
  background: rgba(22, 27, 34, 0.72);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.topbar-spacer { flex: 1; }
.topbar-actions { display: flex; align-items: center; gap: 12px; }
.notif-wrap { position: relative; }
.notif-btn {
  position: relative; background: var(--bg-tertiary); border: 1px solid var(--border);
  width: 38px; height: 38px; border-radius: 50%; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 17px; transition: background 0.15s, border-color 0.15s;
}
.notif-btn:hover { background: var(--bg-hover); border-color: var(--border-light); }
.notif-badge {
  position: absolute; top: -3px; right: -3px;
  min-width: 18px; height: 18px; padding: 0 5px;
  background: var(--red); color: white;
  font-size: 10.5px; font-weight: 700;
  border-radius: 9px; display: flex; align-items: center; justify-content: center;
  border: 2px solid var(--bg-secondary);
}
.notif-panel {
  position: absolute; top: 48px; right: 0; width: 380px; max-height: 500px;
  background: rgba(22, 27, 34, 0.92);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: var(--radius-lg);
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
  overflow: hidden; display: none; flex-direction: column;
  animation: modalIn 0.18s ease;
}
.notif-panel.open { display: flex; }
.notif-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px; border-bottom: 1px solid var(--border-subtle);
  font-size: 14px; font-weight: 700;
}
.notif-list {
  overflow-y: auto; max-height: 440px;
}
.notif-item {
  display: flex; gap: 11px; padding: 12px 16px;
  border-bottom: 1px solid var(--border-subtle); cursor: pointer;
  transition: background 0.12s; text-decoration: none; color: var(--text-normal);
}
.notif-item:hover { background: var(--bg-hover); text-decoration: none; }
.notif-item.unread { background: var(--accent-soft); }
.notif-item.unread:hover { background: rgba(88,101,242,0.18); }
.notif-icon {
  width: 32px; height: 32px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-size: 14px;
}
.notif-icon.ticket_created { background: var(--green-soft); color: var(--green); }
.notif-icon.ticket_reply   { background: var(--accent-soft); color: var(--accent-light); }
.notif-icon.ticket_closed  { background: var(--red-soft); color: var(--red); }
.notif-icon.ticket_claimed { background: var(--yellow-soft); color: var(--yellow); }
.notif-icon.ticket_dm      { background: var(--purple-soft); color: var(--purple); }
.notif-body { flex: 1; min-width: 0; }
.notif-title { font-size: 13px; font-weight: 600; margin-bottom: 2px; }
.notif-text  { font-size: 12.5px; color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.notif-time  { font-size: 11px; color: var(--text-subtle); margin-top: 4px; }
.notif-empty { padding: 30px 20px; text-align: center; color: var(--text-muted); font-size: 13px; }
.notif-foot {
  padding: 10px 16px; border-top: 1px solid var(--border-subtle);
  text-align: center; background: var(--bg-tertiary);
}

/* Liste pleine page */
.notif-fullist { display: flex; flex-direction: column; }
.notif-fullitem {
  display: flex; gap: 14px; padding: 16px 22px;
  border-bottom: 1px solid var(--border-subtle);
  cursor: pointer; text-decoration: none; color: var(--text-normal);
  transition: background 0.12s;
}
.notif-fullitem:hover { background: var(--bg-hover); text-decoration: none; }
.notif-fullitem.unread { background: var(--accent-soft); }
.notif-fullitem.unread:hover { background: rgba(88,101,242,0.18); }
.notif-fullitem .notif-icon { width: 40px; height: 40px; font-size: 17px; }
.notif-fullitem .notif-title { font-size: 14.5px; font-weight: 700; }
.unread-dot {
  align-self: center; width: 9px; height: 9px;
  background: var(--accent); border-radius: 50%;
  flex-shrink: 0;
}

/* ── Section blocs (mes tickets / à prendre / autres) ── */
.section-block { margin-bottom: 28px; }
.section-title {
  font-size: 13px; font-weight: 700; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: 0.7px;
  margin-bottom: 12px; display: flex; align-items: center; gap: 10px;
}
.section-title .count {
  background: var(--bg-active); color: var(--text-muted);
  padding: 1px 8px; border-radius: 10px; font-size: 11px;
}

/* ── Mine ticket row highlighted ── */
.data-table tr.row-mine td { background: rgba(88,101,242,0.06); }
.data-table tr.row-mine:hover td { background: rgba(88,101,242,0.12); }

/* Ligne avec notifs non lues : bordure latérale rouge */
.data-table tr.row-unread td:first-child {
  position: relative;
  padding-left: 24px;
}
.data-table tr.row-unread td:first-child::before {
  content: ''; position: absolute; left: 0; top: 6px; bottom: 6px;
  width: 4px; border-radius: 2px; background: var(--red);
  box-shadow: 0 0 8px var(--red);
}

/* Badge "1" / "2" à côté du # de ticket */
.ticket-unread {
  display: inline-flex; align-items: center; justify-content: center;
  margin-left: 8px;
  min-width: 20px; height: 20px; padding: 0 6px;
  background: var(--red); color: white;
  font-size: 11px; font-weight: 700;
  border-radius: 10px;
  box-shadow: 0 2px 6px rgba(207,34,46,0.5);
  vertical-align: middle;
}

/* ── Pièces jointes & images dans les messages ── */
.msg-attachments {
  display: flex; flex-wrap: wrap; gap: 10px;
  margin-top: 10px;
}
.msg-img-link {
  display: inline-block; max-width: 100%;
  border-radius: var(--radius-md); overflow: hidden;
  transition: transform 0.15s, box-shadow 0.15s;
  text-decoration: none;
}
.msg-img-link:hover { transform: scale(1.01); box-shadow: var(--shadow-md); text-decoration: none; }
.msg-img {
  display: block;
  max-width: 380px; max-height: 280px;
  width: auto; height: auto;
  border-radius: var(--radius-md);
  background: var(--bg-tertiary);
  border: 1px solid var(--border-subtle);
  object-fit: cover;
}
.msg-file {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 13px; border-radius: var(--radius-md);
  background: var(--bg-tertiary); border: 1px solid var(--border-subtle);
  color: var(--text-normal); text-decoration: none;
  font-size: 13px; font-weight: 600;
  transition: background 0.12s, border-color 0.12s;
}
.msg-file:hover { background: var(--bg-hover); border-color: var(--border-light); text-decoration: none; }
.msg-file span { font-size: 16px; }

/* Bouton joindre */
.upload-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 12px; background: var(--bg-tertiary);
  border: 1px solid var(--border); border-radius: var(--radius-md);
  font-size: 13px; font-weight: 600; color: var(--text-normal);
  cursor: pointer; transition: background 0.12s, border-color 0.12s;
}
.upload-btn:hover { background: var(--bg-hover); border-color: var(--border-light); }

/* Aperçu des fichiers à envoyer */
.attach-preview {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-bottom: 12px; padding: 10px;
  background: var(--bg-primary); border-radius: var(--radius-md);
  border: 1px dashed var(--border);
}
.attach-chip {
  position: relative; display: flex; align-items: center; gap: 8px;
  padding: 6px 28px 6px 8px;
  background: var(--bg-tertiary); border: 1px solid var(--border);
  border-radius: var(--radius-md); font-size: 12px;
  max-width: 220px;
}
.attach-chip img {
  width: 32px; height: 32px; border-radius: 4px; object-fit: cover;
  background: var(--bg-active);
}
.attach-chip span {
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  flex: 1; min-width: 0;
}
.attach-chip button {
  position: absolute; top: 50%; right: 6px; transform: translateY(-50%);
  background: none; border: none; color: var(--text-muted);
  cursor: pointer; font-size: 14px; padding: 2px 6px;
  border-radius: 4px; transition: color 0.12s, background 0.12s;
}
.attach-chip button:hover { color: var(--red); background: var(--red-soft); }

/* Badge origine d'un message (DM / Dashboard) */
.origin-badge {
  font-size: 10px; font-weight: 700;
  padding: 2px 7px; border-radius: 3px;
  background: var(--purple-soft); color: var(--purple);
  text-transform: uppercase; letter-spacing: 0.4px;
}

/* Toast notifications déjà stylé. Indicateur "live" */
.live-indicator {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 600;
  color: var(--green); padding: 3px 8px;
  border-radius: 10px; background: var(--green-soft);
}
.live-indicator::before {
  content: ''; width: 6px; height: 6px;
  border-radius: 50%; background: var(--green);
  animation: pulse 1.5s infinite;
}

/* Toast d'arrivée d'un nouveau message en haut */
.new-msg-banner {
  position: sticky; top: 0; z-index: 5;
  background: var(--accent); color: white;
  padding: 8px 14px; border-radius: var(--radius-md);
  text-align: center; font-size: 13px; font-weight: 600;
  cursor: pointer; margin-bottom: 12px;
  animation: slideDown 0.3s ease;
}
@keyframes slideDown { from{transform:translateY(-100%);opacity:0} to{transform:translateY(0);opacity:1} }

/* ── Aperçu Discord ULTRA fidèle ── */
.discord-preview {
  background: #313338; /* Discord bg */
  padding: 16px; border-radius: var(--radius-md);
  font-family: 'gg sans', 'Inter', system-ui, sans-serif;
  color: #dbdee1;
}
.dp-bot-row { display: flex; gap: 14px; }
.dp-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--purple));
  display: flex; align-items: center; justify-content: center;
  font-size: 19px; flex-shrink: 0;
}
.dp-msg { flex: 1; min-width: 0; font-size: 14px; line-height: 1.4; }
.dp-author { display: flex; align-items: center; gap: 6px; margin-bottom: 4px; flex-wrap: wrap; font-size: 14px; font-weight: 600; color: #f2f3f5; }
.dp-bot-tag { background: var(--accent); color: white; font-size: 10px; padding: 1px 5px; border-radius: 3px; font-weight: 700; }
.dp-time { color: #949ba4; font-size: 12px; font-weight: 400; }
.dp-content { color: #dbdee1; font-size: 14px; word-wrap: break-word; }
.dp-content code { background: #2b2d31; padding: 1px 4px; border-radius: 3px; font-size: 12.8px; }
.dp-content a { color: #00aff4; text-decoration: none; }
.dp-content a:hover { text-decoration: underline; }
.dp-spoiler { background: #2b2d31; color: transparent; border-radius: 3px; padding: 0 2px; cursor: pointer; }
.dp-spoiler:hover { color: inherit; background: rgba(46,48,54,0.7); }

.dp-embed {
  position: relative;
  display: grid; grid-template-columns: 1fr auto;
  gap: 16px;
  margin-top: 8px;
  background: #2b2d31;
  border-left: 4px solid var(--accent);
  border-radius: 4px;
  padding: 8px 16px 16px 12px;
  max-width: 520px;
}
.dp-embed-content { min-width: 0; }
.dp-author-line { display: flex; align-items: center; gap: 8px; margin: 8px 0 4px; font-size: 13.8px; font-weight: 600; }
.dp-author-icon { width: 24px; height: 24px; border-radius: 50%; }
.dp-author-name { color: #f2f3f5; text-decoration: none; }
a.dp-author-name:hover { text-decoration: underline; }
.dp-title { display: inline-block; margin: 4px 0; font-size: 16px; font-weight: 600; color: #00aff4; text-decoration: none; }
.dp-title.plain { color: #f2f3f5; }
.dp-title:hover { text-decoration: underline; }
.dp-desc { font-size: 14px; color: #dbdee1; margin: 4px 0 0; word-wrap: break-word; line-height: 1.4; }
.dp-fields { display: grid; grid-template-columns: 1fr; gap: 8px; margin-top: 8px; }
.dp-field.inline { grid-column: span 1; }
.dp-fields:has(.inline) { grid-template-columns: repeat(3, 1fr); }
.dp-field-name { font-size: 13.8px; font-weight: 600; color: #f2f3f5; margin-bottom: 2px; }
.dp-field-value { font-size: 13.8px; color: #dbdee1; word-wrap: break-word; line-height: 1.4; }
.dp-image { max-width: 100%; max-height: 300px; border-radius: 4px; margin-top: 12px; object-fit: cover; }
.dp-thumb { width: 80px; height: 80px; object-fit: cover; border-radius: 4px; align-self: start; }
.dp-footer-line { display: flex; align-items: center; gap: 8px; margin-top: 12px; }
.dp-footer-icon { width: 20px; height: 20px; border-radius: 50%; }
.dp-footer { font-size: 12px; color: #949ba4; }

/* Backwards-compat (anciennes classes) */
.discord-embed-preview { background: var(--bg-tertiary); padding: 14px; border-radius: var(--radius-md); }

/* Embed field row mieux arrangé */
.embed-field-row { background: var(--bg-tertiary); border: 1px solid var(--border); border-radius: var(--radius-md); padding: 10px; }

/* Bandeau "X derniers messages affichés" */
.msg-older-info {
  text-align: center; font-size: 12px; color: var(--text-muted);
  padding: 8px 12px; background: rgba(255,255,255,0.03);
  border-radius: var(--radius-md); margin-bottom: 6px;
}

/* ── Pagination ── */
.pagination {
  display: flex; align-items: center; gap: 6px;
  margin: 18px 0 8px; flex-wrap: wrap;
}
.page-btn {
  display: inline-flex; align-items: center;
  padding: 7px 12px; border-radius: var(--radius-md);
  border: 1px solid var(--border); background: var(--bg-secondary);
  color: var(--text-normal); font-size: 13px; font-weight: 600;
  text-decoration: none; transition: background 0.12s, border-color 0.12s;
  min-width: 36px; justify-content: center;
}
.page-btn:hover { background: var(--bg-hover); border-color: var(--border-light); text-decoration: none; }
.page-btn.active { background: var(--accent); color: white; border-color: var(--accent); }
.page-btn.disabled { opacity: 0.4; pointer-events: none; }
.page-ellipsis { color: var(--text-muted); padding: 0 6px; }
.page-info {
  margin-left: auto; font-size: 12px; color: var(--text-muted);
  white-space: nowrap;
}

/* Filter chips for tickets */
.user-filter-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px; background: var(--accent-soft);
  color: var(--accent-light); border-radius: 14px;
  font-size: 12.5px; font-weight: 600;
  border: 1px solid rgba(88,101,242,0.3);
}
.user-filter-chip .remove {
  cursor: pointer; opacity: 0.7;
  transition: opacity 0.12s;
}
.user-filter-chip .remove:hover { opacity: 1; }

/* ──────────────────────────────────────────────────────────────
   Catégories de tickets
   ────────────────────────────────────────────────────────────── */

/* Filter row au-dessus du tableau */
.cat-filter-row {
  display: flex; flex-wrap: wrap; align-items: center;
  gap: 8px; margin: 4px 0 14px;
  padding: 10px 14px;
  background: rgba(22, 27, 34, 0.55);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  backdrop-filter: blur(8px);
}
.cat-filter-label {
  font-size: 12.5px; font-weight: 700;
  color: var(--text-muted); text-transform: uppercase;
  letter-spacing: 0.5px; margin-right: 6px;
}
.cat-tab.status-tab {
  display: inline-flex; align-items: center; gap: 6px;
}
.cat-tab.status-tab.active {
  border-color: var(--cat-color, var(--accent));
  background: color-mix(in srgb, var(--cat-color, var(--accent)) 15%, transparent);
  color: var(--text-normal);
}
.cat-dot {
  width: 9px; height: 9px; border-radius: 50%;
  flex-shrink: 0; box-shadow: 0 0 0 2px rgba(0,0,0,0.18);
}

/* Pill (read-only) */
.cat-pill {
  display: inline-flex; align-items: center;
  gap: 5px; padding: 3px 10px;
  font-size: 11.5px; font-weight: 700;
  border-radius: 11px;
  background: color-mix(in srgb, var(--cat-color, var(--accent)) 18%, transparent);
  color: var(--cat-color, var(--accent-light));
  border: 1px solid color-mix(in srgb, var(--cat-color, var(--accent)) 35%, transparent);
  white-space: nowrap;
}

/* Mini-select dans le tableau */
.cat-mini-select {
  width: 100%; max-width: 180px;
  padding: 5px 8px; font-size: 12px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border-subtle);
  border-radius: 7px;
  color: var(--text-normal);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.cat-mini-select:hover  { border-color: var(--border-light); background: rgba(255,255,255,0.07); }
.cat-mini-select:focus  { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.cat-mini-select:disabled { opacity: 0.5; cursor: progress; }

/* Page de gestion des catégories */
.cat-grid {
  display: grid; gap: 14px;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
}
.cat-card {
  display: flex; flex-direction: column;
  gap: 12px; padding: 16px 18px;
  transition: border-color 0.15s, transform 0.15s;
}
.cat-card:hover { transform: translateY(-2px); }
.cat-card-head {
  display: flex; align-items: flex-start;
  justify-content: space-between; gap: 12px;
}
.cat-card-title { display: flex; gap: 12px; align-items: center; min-width: 0; }
.cat-emoji-big {
  width: 40px; height: 40px;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-tertiary);
  border-radius: var(--radius-md);
  font-size: 20px; flex-shrink: 0;
  border: 1px solid var(--border-subtle);
}
.cat-name-big {
  font-size: 15px; font-weight: 700;
  color: var(--text-normal);
  letter-spacing: -0.01em;
}
.cat-meta {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding-top: 8px;
  border-top: 1px dashed rgba(255,255,255,0.05);
}
.cat-meta-chip {
  font-size: 11.5px;
  padding: 4px 9px; border-radius: 10px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border-subtle);
  color: var(--text-muted);
}
.cat-card-foot {
  display: flex; gap: 8px;
  margin-top: auto;
}

/* Sélecteur catégorie dans la sidebar du ticket */
.ticket-sidebar select#category-select { width: 100%; }
