/* ═══════════════════════════════════════════════════════════════════════
   FUNSQUAD DASHBOARD — COMPOSANTS
   Utilise les tokens de theme.css. Clair/sombre automatique.
═══════════════════════════════════════════════════════════════════════ */

/* ═══════════════ ANIMATIONS ═══════════════ */
@keyframes fadeUp   { from { opacity:0; transform:translateY(8px);  } to { opacity:1; transform:none; } }
@keyframes fadeIn   { from { opacity:0; } to { opacity:1; } }
@keyframes pop      { from { opacity:0; transform:scale(.96); } to { opacity:1; transform:none; } }
@keyframes spin     { to { transform: rotate(360deg); } }
@keyframes shimmer  { 0%{background-position:-400px 0;} 100%{background-position:400px 0;} }

/* ═══════════════ ICÔNES (Lucide) ═══════════════ */
.ic { display:inline-block; vertical-align:-.18em; flex-shrink:0; width:18px; height:18px; }
.ic-sm { width:15px; height:15px; }
.ic-lg { width:22px; height:22px; }
.ic-xl { width:26px; height:26px; }
/* icône dans un contexte coloré (cartes, pastilles) hérite de la couleur du parent */
.icon-badge { display:inline-flex; align-items:center; justify-content:center; }

/* ═══════════════ LOGIN ═══════════════ */
.login-body { display:flex; align-items:center; justify-content:center; min-height:100vh; position:relative; overflow:hidden; }
.login-bg { position:absolute; inset:0; z-index:0; }
.login-blob { position:absolute; border-radius:50%; filter:blur(90px); opacity:.5; }
.login-blob.b1 { width:480px; height:480px; background:var(--accent); top:-120px; left:-80px; }
.login-blob.b2 { width:420px; height:420px; background:var(--purple); bottom:-140px; right:-60px; opacity:.35; }
.login-card {
  position:relative; z-index:1; background:var(--surface); border:1px solid var(--border-2);
  border-radius:var(--radius-xl); padding:46px 40px; width:410px; max-width:92vw;
  box-shadow:var(--shadow-lg); text-align:center; animation:fadeUp .4s var(--ease) both;
}
.login-icon { font-size:54px; display:block; margin-bottom:14px; line-height:1; }
.login-icon.has-img { font-size:0; }
.login-icon img { width:82px; height:82px; border-radius:24px; object-fit:cover; box-shadow:0 8px 24px var(--accent-glow); }
.login-logo h1 { font-size:25px; font-weight:800; letter-spacing:-.5px; }
.login-logo p { color:var(--text-muted); font-size:14px; margin:6px 0 30px; }
.btn-discord {
  display:flex; align-items:center; justify-content:center; gap:10px;
  background:var(--accent); color:var(--on-accent); padding:13px 24px;
  border-radius:var(--radius-sm); font-size:15px; font-weight:700; text-decoration:none;
  transition:all var(--t) var(--ease); box-shadow:0 6px 20px var(--accent-glow);
}
.btn-discord:hover { filter:brightness(1.08); transform:translateY(-1px); }
.login-note { color:var(--text-muted); font-size:12px; margin-top:22px; }
.alert { padding:11px 14px; border-radius:var(--radius-sm); font-size:13px; margin-bottom:18px; }
.alert-error { background:var(--red-dim); color:var(--red); border:1px solid var(--red); }

/* ═══════════════ SCREENS ═══════════════ */
.screen { min-height:100vh; animation:fadeIn .3s var(--ease); }

/* ═══════════════ SERVER SELECTOR ═══════════════ */
.servers-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 28px; border-bottom:1px solid var(--border); position:sticky; top:0;
  background:color-mix(in srgb, var(--bg) 85%, transparent); backdrop-filter:blur(12px); z-index:10;
}
.servers-logo { font-size:19px; font-weight:800; display:flex; align-items:center; gap:9px; letter-spacing:-.3px; }
.servers-main { max-width:1000px; margin:0 auto; padding:44px 28px 80px; }
.servers-title h1 { font-size:30px; font-weight:800; letter-spacing:-.6px; }
.servers-title p { color:var(--text-muted); margin:8px 0 36px; font-size:15px; }
.guild-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(240px, 1fr)); gap:18px; }
.guild-card {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:24px; cursor:pointer; transition:all var(--t) var(--ease); animation:fadeUp .4s var(--ease) both;
}
.guild-card:hover { border-color:var(--accent-border); transform:translateY(-3px); box-shadow:var(--shadow), 0 0 0 1px var(--accent-border); }
.guild-icon {
  width:60px; height:60px; border-radius:18px; display:flex; align-items:center; justify-content:center;
  font-size:22px; font-weight:800; color:#fff; overflow:hidden; margin-bottom:14px;
}
.guild-icon img { width:100%; height:100%; object-fit:cover; }
.guild-card h3 { font-size:16px; font-weight:700; }
.guild-manage { color:var(--accent-text); font-size:13px; font-weight:600; margin-top:6px; }
.guild-skeleton { height:140px; border-radius:var(--radius-lg); background:linear-gradient(90deg, var(--surface) 25%, var(--surface-2) 50%, var(--surface) 75%); background-size:800px 100%; animation:shimmer 1.4s infinite linear; }
.no-guilds { text-align:center; color:var(--text-muted); padding:60px 0; font-size:15px; }

/* ═══════════════ USER PILL ═══════════════ */
.user-pill { display:flex; align-items:center; gap:9px; background:var(--surface); border:1px solid var(--border); padding:5px 12px 5px 6px; border-radius:30px; font-size:13px; font-weight:600; }
.user-pill img { width:28px; height:28px; border-radius:50%; }
.user-avatar-placeholder { width:28px; height:28px; border-radius:50%; background:var(--accent); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; }

/* ═══════════════ APP HEADER (barre supérieure) ═══════════════ */
.app-header {
  height:var(--header-h); display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:0 18px; background:var(--header-bg); border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:60;
}
.app-header-left { display:flex; align-items:center; gap:14px; }
.app-header-right { display:flex; align-items:center; gap:10px; }
.app-logo { display:flex; align-items:center; gap:9px; font-size:17px; font-weight:800; letter-spacing:-.4px; }
.app-logo > span:last-child { color:var(--text); }
.logo-mark { width:30px; height:30px; border-radius:9px; display:flex; align-items:center; justify-content:center; background:var(--accent); color:var(--on-accent); flex-shrink:0; overflow:hidden; }
.logo-mark:has(img) { background:#000; }
.logo-mark img { width:100%; height:100%; object-fit:cover; display:block; }

/* Déclencheur de recherche (header) */
.search-trigger { flex:1; max-width:420px; display:flex; align-items:center; gap:9px; background:var(--surface-2); border:1px solid var(--border); border-radius:var(--radius-sm); padding:8px 12px; color:var(--text-muted); cursor:pointer; font-size:13px; transition:all var(--t); margin:0 8px; }
.search-trigger:hover { background:var(--surface-hover); border-color:var(--border-2); }
.search-trigger .st-label { flex:1; text-align:left; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.search-trigger kbd, .cmdk-input-row kbd { font-family:var(--mono); font-size:10.5px; font-weight:700; background:var(--surface-3); border:1px solid var(--border-2); border-radius:5px; padding:2px 6px; color:var(--text-muted); }

.icon-btn { width:36px; height:36px; border-radius:50%; background:var(--surface-2); border:1px solid var(--border); color:var(--text-2); cursor:pointer; transition:all var(--t); display:inline-flex; align-items:center; justify-content:center; }
.icon-btn:hover { background:var(--surface-hover); color:var(--text); }
.header-user { display:flex; align-items:center; gap:7px; cursor:pointer; padding:3px 6px 3px 3px; border-radius:30px; border:1px solid var(--border); background:var(--surface-2); }
.header-user img, .header-user .ua { width:30px; height:30px; border-radius:50%; object-fit:cover; }
.header-user .ua { background:var(--accent); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:13px; }
.header-user .chev { color:var(--text-muted); font-size:11px; }
.menu-toggle { display:none; background:none; border:none; color:var(--text); font-size:22px; cursor:pointer; padding:4px; }

/* ═══════════════ APP BODY (sidebar + contenu) ═══════════════ */
.app-body { display:grid; grid-template-columns:var(--sidebar-w) 1fr; min-height:calc(100vh - var(--header-h)); }

/* ── Sidebar ── */
.sidebar {
  background:var(--surface); border-right:1px solid var(--border); display:flex; flex-direction:column;
  padding:14px 10px; position:sticky; top:var(--header-h); height:calc(100vh - var(--header-h)); overflow-y:auto; z-index:40;
}
.server-card {
  display:flex; align-items:center; gap:11px; width:100%; background:var(--surface-2); border:1px solid var(--border-2);
  border-radius:var(--radius); padding:9px 11px; cursor:pointer; transition:all var(--t); margin-bottom:8px;
}
.server-card:hover { background:var(--surface-hover); border-color:var(--border-3); }
.server-card-icon { width:34px; height:34px; border-radius:9px; overflow:hidden; display:flex; align-items:center; justify-content:center; font-weight:800; color:#fff; background:var(--accent); flex-shrink:0; font-size:14px; }
.server-card-icon img { width:100%; height:100%; object-fit:cover; }
.server-card-name { flex:1; text-align:left; font-weight:700; font-size:14px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.server-card-chevron { color:var(--text-muted); font-size:13px; }

.sidebar-nav { display:flex; flex-direction:column; gap:1px; }
.nav-section-head {
  display:flex; align-items:center; gap:6px; width:100%; background:none; border:none; cursor:pointer;
  font-size:10.5px; font-weight:800; text-transform:uppercase; letter-spacing:.09em; color:var(--text-faint);
  padding:14px 10px 6px; transition:color var(--t);
}
.nav-section-head:hover { color:var(--text-muted); }
.nav-section-head .ns-chev { margin-left:auto; font-size:11px; transition:transform var(--t); }
.nav-section.collapsed .ns-chev { transform:rotate(-90deg); }
.nav-section.collapsed .nav-item { display:none; }

.nav-item {
  display:flex; align-items:center; gap:10px; width:100%; background:none; border:none;
  color:var(--text-2); font-size:13.5px; font-weight:600; padding:8px 10px; border-radius:var(--radius-sm);
  cursor:pointer; transition:all var(--t); text-align:left; position:relative;
}
.nav-item:hover { background:var(--surface-2); color:var(--text); }
.nav-item.active { background:var(--accent-dim); color:var(--accent-text); }
.nav-item.active::before { content:''; position:absolute; left:-10px; top:50%; transform:translateY(-50%); width:3px; height:18px; background:var(--accent); border-radius:0 3px 3px 0; }
.nav-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; background:var(--text-faint); }
.nav-item .nav-icon { font-size:15px; width:18px; text-align:center; flex-shrink:0; }
.nav-item .nav-label { flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

.sidebar-footer { margin-top:auto; padding-top:14px; border-top:1px solid var(--border); display:flex; flex-direction:column; gap:10px; }
.bot-status { display:flex; align-items:center; gap:8px; font-size:12px; color:var(--text-muted); padding:0 8px; }
.status-dot { width:8px; height:8px; border-radius:50%; background:var(--text-faint); }
.status-dot.online { background:var(--green); box-shadow:0 0 8px var(--green); }

/* ── Content ── */
.app-content { min-width:0; }
.page-header { padding:24px 28px 0; display:flex; align-items:center; gap:14px; }
.ph-icon { width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--accent); background:var(--accent-dim); }
.ph-text { flex:1; min-width:0; }
.page-header h1 { font-size:22px; font-weight:800; letter-spacing:-.5px; }
.page-header p { color:var(--text-muted); font-size:13.5px; margin-top:2px; }
.ph-actions { display:flex; align-items:center; gap:10px; flex-shrink:0; }
.app-content.home .page-header { display:none; }

/* Bascule Simple / Avancé */
.mode-switch { display:flex; background:var(--surface-2); border:1px solid var(--border); border-radius:30px; padding:3px; }
.mode-switch button { background:none; border:none; cursor:pointer; padding:6px 14px; border-radius:30px; font-size:12.5px; font-weight:700; color:var(--text-muted); transition:all var(--t); }
.mode-switch button.active { background:var(--accent); color:var(--on-accent); box-shadow:0 2px 8px var(--accent-glow); }
body[data-mode="simple"] [data-advanced] { display:none !important; }

/* ═══════════════ HOME (hero + cartes de modules) ═══════════════ */
.home-wrap { padding:24px 28px 60px; max-width:var(--maxw); animation:fadeUp .3s var(--ease); }

.hero {
  position:relative; border-radius:var(--radius-xl); padding:40px 44px; margin-bottom:36px; overflow:hidden;
  background:
    radial-gradient(120% 140% at 85% 10%, color-mix(in srgb, var(--accent) 55%, transparent) 0%, transparent 55%),
    radial-gradient(100% 120% at 0% 100%, color-mix(in srgb, var(--purple) 40%, transparent) 0%, transparent 50%),
    var(--surface);
  border:1px solid var(--border-2); display:grid; grid-template-columns:1fr auto; gap:30px; align-items:center;
}
.hero-content { max-width:520px; z-index:1; }
.hero h1 { font-size:30px; font-weight:800; letter-spacing:-.7px; line-height:1.15; }
.hero h1 .accent { background:linear-gradient(90deg, var(--accent-text), var(--purple)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.hero p { color:var(--text-2); font-size:14.5px; margin:14px 0 22px; line-height:1.6; }
.hero-cta { display:inline-flex; align-items:center; gap:8px; background:linear-gradient(90deg, var(--accent), var(--purple)); color:#fff; font-weight:800; font-size:14px; padding:12px 22px; border-radius:var(--radius-sm); border:none; cursor:pointer; box-shadow:0 8px 24px var(--accent-glow); transition:all var(--t); }
.hero-cta:hover { transform:translateY(-2px); filter:brightness(1.08); }
.hero-card { background:color-mix(in srgb, #000 28%, var(--surface)); border:1px solid var(--border-2); border-radius:var(--radius); padding:14px; width:300px; max-width:38vw; z-index:1; }
.hero-card-bubble { display:flex; gap:10px; }
.hero-card-bubble .dp-avatar { width:34px; height:34px; font-size:14px; }
.hero-card-name { font-size:13px; font-weight:700; display:flex; align-items:center; gap:6px; }
.hero-card-text { font-size:12px; color:var(--text-2); margin-top:5px; line-height:1.5; background:var(--inset); border-radius:8px; padding:9px 11px; }
.hero-dots { position:absolute; bottom:16px; right:24px; display:flex; gap:6px; }
.hero-dot { width:7px; height:7px; border-radius:50%; background:rgba(255,255,255,.25); }
.hero-dot.active { background:#fff; }

.modules-head { font-size:22px; font-weight:800; letter-spacing:-.5px; margin-bottom:14px; }
.module-tabs { display:flex; gap:4px; overflow-x:auto; border-bottom:1px solid var(--border); margin-bottom:26px; padding-bottom:1px; }
.module-tab { background:none; border:none; color:var(--text-muted); font-size:13.5px; font-weight:600; padding:11px 14px; cursor:pointer; white-space:nowrap; border-bottom:2px solid transparent; transition:all var(--t); }
.module-tab:hover { color:var(--text); }
.module-tab.active { color:var(--text); border-bottom-color:var(--accent); }

.cards-group-label { font-size:15px; font-weight:800; margin:6px 0 16px; position:relative; padding-bottom:8px; }
.cards-group-label::after { content:''; position:absolute; left:0; bottom:0; width:34px; height:2px; background:var(--accent); border-radius:2px; }
.module-cards { display:grid; grid-template-columns:repeat(auto-fill, minmax(240px, 1fr)); gap:18px; margin-bottom:30px; }
.module-card {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); padding:20px;
  display:flex; flex-direction:column; cursor:pointer; transition:all var(--t); position:relative; animation:fadeUp .35s var(--ease) both;
}
.module-card:hover { border-color:var(--accent-border); transform:translateY(-3px); box-shadow:var(--shadow); }
.module-card-icon { width:52px; height:52px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:24px; margin-bottom:14px; }
.module-card h3 { font-size:15.5px; font-weight:700; margin-bottom:6px; }
.module-card p { color:var(--text-muted); font-size:12.5px; line-height:1.5; flex:1; margin-bottom:16px; }
.module-card-btn { display:inline-flex; align-items:center; justify-content:center; gap:7px; background:var(--surface-2); border:1px solid var(--border-2); color:var(--text); font-size:13px; font-weight:700; padding:9px; border-radius:var(--radius-sm); transition:all var(--t); }
.module-card:hover .module-card-btn { background:var(--accent); border-color:transparent; color:var(--on-accent); }

/* Save indicator */
.save-indicator { display:flex; align-items:center; gap:7px; font-size:12px; font-weight:600; color:var(--text-muted); padding:6px 11px; border-radius:30px; border:1px solid var(--border); transition:all var(--t); }
.save-indicator .si-dot { width:7px; height:7px; border-radius:50%; background:var(--text-faint); transition:all var(--t); }
.save-indicator.saving { color:var(--yellow); border-color:var(--yellow); }
.save-indicator.saving .si-dot { background:var(--yellow); animation:spin 1s linear infinite; box-shadow:none; border-top:1px solid transparent; }
.save-indicator.saved { color:var(--green); border-color:color-mix(in srgb, var(--green) 40%, transparent); }
.save-indicator.saved .si-dot { background:var(--green); box-shadow:0 0 8px var(--green); }

/* Theme controls */
.theme-toggle { display:flex; background:var(--surface-2); border:1px solid var(--border); border-radius:30px; padding:3px; gap:2px; }
.theme-toggle button { background:none; border:none; cursor:pointer; padding:6px 9px; border-radius:30px; color:var(--text-muted); transition:all var(--t); display:inline-flex; align-items:center; }
.theme-toggle button.active { background:var(--surface); color:var(--text); box-shadow:var(--shadow-sm); }
.accent-pop { position:relative; }
.accent-trigger { width:34px; height:34px; border-radius:50%; border:2px solid var(--border-2); background:var(--accent); cursor:pointer; transition:transform var(--t); }
.accent-trigger:hover { transform:scale(1.08); }
.accent-menu { position:absolute; right:0; top:44px; background:var(--elevated); border:1px solid var(--border-2); border-radius:var(--radius); padding:14px; box-shadow:var(--shadow-lg); z-index:50; width:210px; animation:pop .16s var(--ease); }
.accent-menu-title { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--text-faint); margin-bottom:10px; }
.accent-swatches { display:grid; grid-template-columns:repeat(6, 1fr); gap:8px; margin-bottom:12px; }
.accent-swatch { width:26px; height:26px; border-radius:50%; cursor:pointer; border:2px solid transparent; transition:transform var(--t); }
.accent-swatch:hover { transform:scale(1.15); }
.accent-swatch.active { border-color:var(--text); }
.accent-custom { display:flex; align-items:center; gap:8px; font-size:12px; color:var(--text-muted); }
.accent-custom input[type=color] { width:30px; height:30px; border:none; background:none; border-radius:8px; cursor:pointer; padding:0; }

/* ═══════════════ MODULE LAYOUT ═══════════════ */
.module { padding:26px 24px 60px; animation:fadeUp .25s var(--ease); }
.module-split { display:grid; grid-template-columns:1fr var(--preview-w); gap:26px; align-items:start; }
.module-intro { color:var(--text-muted); font-size:13.5px; margin-bottom:22px; line-height:1.6; max-width:760px; }
.module-intro code { background:var(--surface-2); padding:1px 6px; border-radius:5px; font-family:var(--mono); font-size:12px; color:var(--accent-text); }

/* ── Cards ── */
.card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); padding:20px; margin-bottom:18px; transition:border-color var(--t); }
.card:hover { border-color:var(--border-2); }
.card-head { display:flex; align-items:center; gap:9px; font-size:14px; font-weight:800; margin-bottom:16px; letter-spacing:-.2px; }
.card-head .ch-sub { font-weight:400; font-size:12px; color:var(--text-faint); letter-spacing:0; }
.card-head .ch-icon { font-size:17px; }

/* ── Journal d'audit ───────────────────────────────────────────────── */
.audit-actions { margin-left:auto; display:inline-flex; gap:8px; }
.audit-list { display:flex; flex-direction:column; }
.audit-item { display:flex; gap:12px; align-items:flex-start; padding:11px 10px; border-radius:10px; transition:background var(--t); }
.audit-item:hover { background:var(--surface-2); }
.audit-item + .audit-item { border-top:1px solid var(--border); }
.audit-av { width:34px; height:34px; border-radius:50%; flex-shrink:0; overflow:hidden; background:var(--surface-3); display:flex; align-items:center; justify-content:center; }
.audit-av img { width:100%; height:100%; object-fit:cover; }
.audit-av-ph { font-weight:700; font-size:14px; color:var(--text-2); }
.audit-body { flex:1; min-width:0; }
.audit-line { font-size:13.5px; color:var(--text); line-height:1.45; word-break:break-word; }
.audit-meta { display:flex; align-items:center; gap:8px; margin-top:3px; }
.audit-chip { font-size:11px; font-weight:600; padding:1px 8px; border-radius:20px; background:color-mix(in srgb, var(--accent) 16%, transparent); color:var(--accent); }
.audit-time { font-size:11.5px; color:var(--text-faint); }
.audit-empty { text-align:center; padding:38px 20px; color:var(--text-muted); }
.audit-empty p { margin:8px 0 0; }
.audit-empty .hint { font-size:12px; max-width:420px; margin-inline:auto; }
.audit-loading { padding:22px; text-align:center; color:var(--text-faint); font-size:13px; }

/* ── Salons vocaux : stats + aperçu ──────────────────────────────────── */
.vc-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.vc-stat { background:var(--surface-2); border:1px solid var(--border); border-radius:var(--radius-sm); padding:14px 10px; text-align:center; }
.vc-stat-n { font-size:22px; font-weight:800; color:var(--text); letter-spacing:-.5px; }
.vc-stat-l { font-size:11.5px; color:var(--text-muted); margin-top:3px; }
.vc-prev-chan { display:flex; align-items:center; gap:7px; background:var(--surface-2); border:1px solid var(--border); border-radius:8px; padding:8px 11px; font-weight:600; color:var(--text-2); font-size:14px; }
.vc-prev-chan span:first-of-type { flex:1; }
.vc-prev-limit { font-size:11px; font-weight:700; color:var(--text-faint); background:var(--surface-3); padding:1px 7px; border-radius:10px; }
.vc-creator-chips { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:8px; }
.vc-chip { display:inline-flex; align-items:center; gap:6px; background:color-mix(in srgb, var(--accent) 14%, transparent); color:var(--accent); border:1px solid color-mix(in srgb, var(--accent) 30%, transparent); border-radius:20px; padding:3px 6px 3px 10px; font-size:12.5px; font-weight:600; }
.vc-chip-x { display:inline-flex; align-items:center; justify-content:center; width:16px; height:16px; border:none; border-radius:50%; background:color-mix(in srgb, var(--accent) 25%, transparent); color:var(--accent); cursor:pointer; font-size:10px; line-height:1; padding:0; }
.vc-chip-x:hover { background:var(--danger,#f23f43); color:#fff; }
.vc-chip-empty { font-size:12.5px; color:var(--text-faint); font-style:italic; }
.welcome-card-preview { width:100%; border-radius:10px; border:1px solid var(--border); display:block; background:var(--surface-2); aspect-ratio:1024/400; object-fit:cover; }
.char-count { text-align:right; font-size:11px; color:var(--text-faint); margin-top:4px; }
.range { width:100%; accent-color:var(--accent); height:6px; cursor:pointer; }

/* ── Profil du bot (style « Bot Personnalisé ») ──────────────────────── */
.bp-grid { display:grid; grid-template-columns:170px 1fr 300px; gap:26px; align-items:start; }
@media (max-width:1080px) { .bp-grid { grid-template-columns:1fr; } }
.bp-col { min-width:0; }
.bp-label { font-size:12px; font-weight:600; color:var(--text-muted); margin-bottom:8px; }
.bp-icon { width:130px; height:130px; border-radius:14px; border:1px solid var(--border); background:var(--surface-2); position:relative; cursor:pointer; overflow:hidden; padding:0; display:block; }
.bp-icon img { width:100%; height:100%; object-fit:cover; display:block; }
.bp-icon-edit { position:absolute; right:6px; bottom:6px; background:rgba(0,0,0,.6); color:#fff; border-radius:8px; padding:3px 5px; display:inline-flex; }
.bp-banner { width:100%; aspect-ratio:5/2; border-radius:12px; border:1px dashed var(--border-2); background:var(--surface-2) center/cover no-repeat; cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--text-faint); font-size:12px; padding:0; text-align:center; }
.bp-banner.has-img { border-style:solid; }
.bp-banner.has-img .bp-banner-hint { display:none; }
.bp-banner-hint { display:inline-flex; align-items:center; gap:6px; padding:0 10px; }
.bp-prev-member { display:flex; gap:10px; align-items:center; background:var(--surface-2); border:1px solid var(--border); border-radius:10px; padding:10px 12px; }
.bp-pm-av { position:relative; width:40px; height:40px; border-radius:50%; flex-shrink:0; background:var(--accent); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; }
.bp-pm-av img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.bp-pm-dot { position:absolute; right:-1px; bottom:-1px; width:13px; height:13px; border-radius:50%; border:2px solid var(--surface-2); }
.bp-pm-name { font-weight:700; font-size:14px; color:var(--text); display:flex; align-items:center; gap:6px; }
.bp-pm-act { font-size:12px; color:var(--text-muted); }
.bp-prev-profile { background:var(--surface-2); border:1px solid var(--border); border-radius:12px; overflow:hidden; }
.bp-pp-banner { height:92px; background:linear-gradient(120deg,var(--accent),#1a1b26) center/cover no-repeat; }
.bp-pp-av { width:76px; height:76px; border-radius:50%; margin:-38px 0 0 16px; border:5px solid var(--surface-2); position:relative; background:var(--accent); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:800; font-size:26px; }
.bp-pp-av img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.bp-pp-dot { position:absolute; right:2px; bottom:2px; width:16px; height:16px; border-radius:50%; border:3px solid var(--surface-2); }
.bp-pp-info { padding:8px 16px 16px; }
.bp-pp-name { font-weight:800; font-size:16px; color:var(--text); display:flex; align-items:center; gap:6px; }
.bp-pp-tag { font-size:12px; color:var(--text-muted); margin-bottom:10px; }
.bp-pp-actbox { background:var(--surface-3); border-radius:8px; padding:8px 10px; }
.bp-pp-actverb { font-size:10.5px; color:var(--text-muted); text-transform:uppercase; font-weight:700; letter-spacing:.4px; }
.bp-pp-acttext { font-size:13px; color:var(--text); font-weight:600; }

/* ── Émojis ──────────────────────────────────────────────────────────── */
.emoji-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(150px, 1fr)); gap:10px; margin-top:14px; }
.emoji-card { position:relative; display:flex; align-items:center; gap:10px; background:var(--surface-2); border:1px solid var(--border); border-radius:10px; padding:10px; }
.emoji-card img { width:36px; height:36px; object-fit:contain; flex-shrink:0; }
.emoji-info { min-width:0; flex:1; display:flex; flex-direction:column; gap:2px; }
.emoji-name { font-size:12.5px; font-weight:600; color:var(--text); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.emoji-badge { font-size:9.5px; font-weight:700; color:var(--accent); letter-spacing:.3px; }
.emoji-del { position:absolute; top:6px; right:6px; width:20px; height:20px; border:none; border-radius:50%; background:var(--surface-3); color:var(--text-muted); cursor:pointer; font-size:11px; line-height:1; opacity:0; transition:opacity var(--t),background var(--t),color var(--t); }
.emoji-card:hover .emoji-del { opacity:1; }
.emoji-del:hover { background:var(--danger,#f23f43); color:#fff; }
.emoji-del:disabled { opacity:.4; cursor:default; }
.emoji-empty { grid-column:1/-1; text-align:center; padding:30px; color:var(--text-faint); font-size:13px; }

.section-label { font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.1em; color:var(--text-faint); margin:4px 0 10px; display:flex; align-items:center; gap:8px; }
.section-label::after { content:''; flex:1; height:1px; background:var(--border); }
hr.divider { border:none; border-top:1px solid var(--border); margin:16px 0; }

/* ── Form ── */
.row { display:flex; flex-direction:column; gap:6px; margin-bottom:15px; }
.row:last-child { margin-bottom:0; }
.row > label { font-size:12.5px; font-weight:700; color:var(--text-2); display:flex; align-items:center; gap:6px; }
.hint { font-weight:400; color:var(--text-faint); font-size:11.5px; }
.row-inline { display:flex; gap:12px; }
.row-emoji { width:92px; flex-shrink:0; }

.input, .textarea, .select {
  width:100%; background:var(--inset); border:1px solid var(--border-2); color:var(--text);
  padding:10px 12px; border-radius:var(--radius-sm); font-size:14px; font-family:inherit;
  transition:all var(--t); outline:none;
}
.input::placeholder, .textarea::placeholder { color:var(--text-faint); }
.input:focus, .textarea:focus, .select:focus { border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-dim); }
.input.sm { padding:9px 10px; text-align:center; }
.textarea { resize:vertical; min-height:64px; line-height:1.5; }
.select { cursor:pointer; appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2379849a' stroke-width='3'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 12px center; padding-right:34px; }
.input.invalid { border-color:var(--red); box-shadow:0 0 0 3px var(--red-dim); }
.field-error { color:var(--red); font-size:11.5px; font-weight:600; }

/* ── Color picker ── */
.color-row { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.color-pick { width:42px; height:42px; border:1px solid var(--border-2); border-radius:var(--radius-sm); background:none; cursor:pointer; padding:3px; flex-shrink:0; }
.color-presets { display:flex; gap:7px; flex-wrap:wrap; }
.color-dot { width:24px; height:24px; border-radius:50%; border:2px solid transparent; cursor:pointer; transition:transform var(--t); }
.color-dot:hover { transform:scale(1.15); }
.color-dot.active { border-color:var(--text); }

/* ── Toggle ── */
.toggle-row { display:flex; align-items:center; justify-content:space-between; gap:14px; padding:4px 0; }
.toggle-row .tr-text { font-size:13.5px; font-weight:600; }
.toggle-row .tr-text .hint { display:block; font-weight:400; margin-top:2px; }
.switch { position:relative; width:42px; height:24px; flex-shrink:0; }
.switch input { opacity:0; width:0; height:0; }
.switch .track { position:absolute; inset:0; background:var(--surface-3); border:1px solid var(--border-2); border-radius:30px; transition:all var(--t); }
.switch .track::before { content:''; position:absolute; width:18px; height:18px; border-radius:50%; background:var(--text-muted); left:3px; top:2px; transition:all var(--t); }
.switch input:checked + .track { background:var(--accent); border-color:transparent; }
.switch input:checked + .track::before { transform:translateX(18px); background:#fff; }

/* ── Checkbox ── */
.check-row { display:flex; align-items:flex-start; gap:10px; cursor:pointer; font-size:13.5px; font-weight:600; }
.check-row input { width:18px; height:18px; accent-color:var(--accent); margin-top:1px; cursor:pointer; flex-shrink:0; }

/* ═══════════════ BUTTONS ═══════════════ */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; border:1px solid transparent; border-radius:var(--radius-sm); padding:10px 16px; font-size:14px; font-weight:700; cursor:pointer; transition:all var(--t); white-space:nowrap; }
.btn-primary { background:var(--accent); color:var(--on-accent); box-shadow:0 4px 14px var(--accent-glow); }
.btn-primary:hover { filter:brightness(1.08); transform:translateY(-1px); }
.btn-ghost { background:var(--surface-2); color:var(--text-2); border-color:var(--border-2); }
.btn-ghost:hover { background:var(--surface-hover); color:var(--text); }
.btn-danger { background:var(--red-dim); color:var(--red); border-color:var(--red); }
.btn-danger:hover { background:var(--red); color:#fff; }
.btn-sm { padding:6px 12px; font-size:12.5px; }
.btn-icon { padding:7px; background:var(--surface-2); border:1px solid var(--border); border-radius:var(--radius-sm); cursor:pointer; font-size:14px; line-height:1; transition:all var(--t); }
.btn-icon:hover { background:var(--surface-hover); }
.btn-icon.danger:hover { background:var(--red); }
.btn.loading { pointer-events:none; opacity:.7; }
.btn.loading::after { content:''; width:14px; height:14px; border:2px solid currentColor; border-top-color:transparent; border-radius:50%; animation:spin .7s linear infinite; }

/* ═══════════════ BADGES / PILLS ═══════════════ */
.badge { font-size:10.5px; font-weight:800; padding:3px 8px; border-radius:30px; text-transform:uppercase; letter-spacing:.03em; }
.badge-blue { background:var(--blue-dim); color:var(--blue); }
.badge-yellow { background:var(--yellow-dim); color:var(--yellow); }
.badge-purple { background:var(--purple-dim); color:var(--purple); }
.badge-green { background:var(--green-dim); color:var(--green); }
.badge-red { background:var(--red-dim); color:var(--red); }
.badge-muted { background:var(--surface-3); color:var(--text-muted); }
.req-badge { background:var(--accent-dim); color:var(--accent-text); font-size:9.5px; font-weight:800; padding:2px 6px; border-radius:4px; letter-spacing:.04em; }

/* ═══════════════ CATEGORIES / LISTS ═══════════════ */
.list-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.cat-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); margin-bottom:14px; overflow:hidden; transition:border-color var(--t); }
.cat-card.disabled { opacity:.6; }
.cat-head { display:flex; align-items:center; gap:12px; padding:14px 16px; cursor:grab; }
.cat-head:active { cursor:grabbing; }
.drag-handle { color:var(--text-faint); font-size:15px; cursor:grab; }
.cat-emoji { font-size:21px; width:30px; text-align:center; }
.cat-info { flex:1; min-width:0; }
.cat-name { font-weight:700; font-size:15px; }
.cat-meta { font-size:11.5px; color:var(--text-muted); margin-top:1px; }
.cat-desc-preview { font-size:11px; color:var(--text-faint); font-style:italic; margin-top:2px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:300px; }
.cat-actions { display:flex; gap:6px; }
.opts-wrap { padding:0 16px 14px; }
.opts-list { display:flex; flex-direction:column; gap:7px; margin-bottom:10px; }
.opt-row { display:flex; align-items:center; gap:11px; background:var(--surface-2); border:1px solid var(--border); border-radius:var(--radius-sm); padding:9px 12px; }
.opt-color-dot { width:9px; height:9px; border-radius:50%; flex-shrink:0; }
.opt-emoji { font-size:16px; width:22px; text-align:center; }
.opt-info { flex:1; min-width:0; }
.opt-label { font-weight:600; font-size:13.5px; }
.opt-desc { font-size:11.5px; color:var(--text-muted); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.opt-meta { display:flex; align-items:center; gap:7px; }
.opt-actions { display:flex; gap:5px; }
.role-pill { font-size:11px; font-weight:700; padding:3px 9px; border-radius:30px; background:var(--accent-dim); color:var(--accent-text); }
.role-pill.unset { background:var(--yellow-dim); color:var(--yellow); }
.add-btn { width:100%; background:none; border:1.5px dashed var(--border-3); color:var(--text-muted); padding:9px; border-radius:var(--radius-sm); font-size:13px; font-weight:600; cursor:pointer; transition:all var(--t); }
.add-btn:hover { border-color:var(--accent); color:var(--accent-text); background:var(--accent-dim); }
.sortable-ghost { opacity:.4; }
.sortable-drag { box-shadow:var(--shadow-lg); }

/* ═══════════════ UPLOAD ═══════════════ */
.img-tabs { display:flex; gap:4px; background:var(--inset); padding:4px; border-radius:var(--radius-sm); margin-bottom:14px; }
.img-tab { flex:1; background:none; border:none; color:var(--text-muted); padding:7px; border-radius:var(--radius-xs); font-size:13px; font-weight:600; cursor:pointer; transition:all var(--t); }
.img-tab.active { background:var(--surface); color:var(--text); box-shadow:var(--shadow-sm); }
.upload-zone { border:1.5px dashed var(--border-3); border-radius:var(--radius); padding:26px; text-align:center; cursor:pointer; transition:all var(--t); }
.upload-zone:hover, .upload-zone.drag-over { border-color:var(--accent); background:var(--accent-dim); }
.upload-zone-icon { font-size:30px; display:block; margin-bottom:8px; }
.upload-zone-text { font-size:13px; color:var(--text-2); }
.upload-zone-text strong { color:var(--accent-text); cursor:pointer; }
.upload-zone-hint { font-size:11px; color:var(--text-faint); margin-top:4px; }
.upload-progress { height:5px; background:var(--surface-3); border-radius:3px; margin-top:12px; overflow:hidden; }
.upload-progress-bar { height:100%; width:0; background:var(--accent); border-radius:3px; transition:width .3s var(--ease); }
.thumb-preview { margin-top:12px; height:120px; border-radius:var(--radius-sm); background-size:cover; background-position:center; position:relative; border:1px solid var(--border-2); }
.thumb-clear { position:absolute; top:8px; right:8px; width:26px; height:26px; border-radius:50%; background:var(--scrim); color:#fff; border:none; cursor:pointer; font-size:13px; }

/* ═══════════════ DISCORD PREVIEW ═══════════════ */
.app-content:not(.home) #moduleContainer { padding:18px 28px 60px; }
.preview-sticky { position:sticky; top:calc(var(--header-h) + 22px); }
.preview-label { font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.1em; color:var(--text-faint); margin-bottom:10px; display:flex; align-items:center; gap:8px; }
.preview-label .lp-dot { width:7px; height:7px; border-radius:50%; background:var(--green); box-shadow:0 0 8px var(--green); }
.discord-preview { background:#313338; border-radius:var(--radius); padding:16px; border:1px solid rgba(0,0,0,.3); min-height:120px; }
:root[data-theme="light"] .discord-preview { box-shadow:var(--shadow); }

.dp-message { display:flex; gap:14px; }
.dp-avatar { width:40px; height:40px; border-radius:50%; background:var(--accent); display:flex; align-items:center; justify-content:center; font-weight:800; font-size:16px; color:#fff; flex-shrink:0; overflow:hidden; }
.dp-avatar img { width:100%; height:100%; object-fit:cover; }
.dp-content { flex:1; min-width:0; }
.dp-author { display:flex; align-items:center; gap:7px; font-weight:600; font-size:15px; color:#f2f3f5; margin-bottom:4px; }
.dp-author .dp-ts { font-size:11px; color:#949ba4; font-weight:400; }
.dp-badge { background:var(--accent); font-size:10px; font-weight:700; padding:1px 5px; border-radius:3px; color:#fff; text-transform:uppercase; }
.dp-text { font-size:14px; color:#dbdee1; line-height:1.5; white-space:pre-wrap; word-break:break-word; }
.dp-text .mention { background:color-mix(in srgb, var(--accent) 30%, transparent); color:var(--accent-text); border-radius:4px; padding:0 2px; font-weight:500; }

/* Embed */
.dp-embed { display:flex; background:#2b2d31; border-radius:4px; margin-top:6px; overflow:hidden; max-width:440px; }
.dp-embed-bar { width:4px; flex-shrink:0; background:var(--accent); }
.dp-embed-body { padding:12px 16px 14px; flex:1; min-width:0; }
.dp-embed-author { font-size:12px; font-weight:600; color:#f2f3f5; margin-bottom:6px; }
.dp-embed-title { font-weight:700; font-size:15px; color:#f2f3f5; margin-bottom:6px; }
.dp-embed-desc { font-size:13.5px; color:#dbdee1; line-height:1.5; white-space:pre-wrap; word-break:break-word; }
.dp-embed-img { margin-top:10px; border-radius:4px; max-width:100%; max-height:160px; object-fit:cover; display:block; }
.dp-embed-thumb { width:72px; height:72px; border-radius:6px; object-fit:cover; margin:12px 12px 0 0; flex-shrink:0; }
.dp-embed-footer { font-size:11.5px; color:#949ba4; margin-top:9px; display:flex; align-items:center; gap:6px; }
.dp-embed-row { display:flex; }
.dp-embed-fields { display:flex; flex-wrap:wrap; gap:8px 16px; margin-top:9px; }
.dp-embed-field { min-width:100%; }
.dp-embed-field.inline { min-width:30%; flex:1; }
.dp-field-name { font-size:12.5px; font-weight:700; color:#f2f3f5; margin-bottom:2px; }
.dp-field-value { font-size:13px; color:#dbdee1; line-height:1.4; white-space:pre-wrap; word-break:break-word; }

/* ═══════════════ TABLEAU PARTICIPANTS (Événements) ═══════════════ */
.ev-table { display:flex; flex-direction:column; gap:3px; margin-top:8px; }
.ev-trow { display:grid; grid-template-columns:1.4fr 1.6fr 1fr 1.3fr 0.8fr 0.4fr; gap:10px; align-items:center; padding:8px 12px; border-radius:9px; background:var(--surface-2); font-size:13px; }
.ev-trow > div { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.ev-thead { background:transparent; padding:2px 12px; font-size:10.5px; text-transform:uppercase; letter-spacing:.04em; color:var(--text-faint); font-weight:800; }
.ev-mono { font-family:var(--mono); font-size:11.5px; color:var(--text-muted); }
.select.sm { padding:6px 8px; font-size:12.5px; padding-right:26px; background-position:right 8px center; }
.btn-icon.on-green { background:var(--green-dim); color:var(--green); }
.btn-icon.on-red { background:var(--red-dim); color:var(--red); }

/* ═══════════════ STATISTIQUES (Événements) ═══════════════ */
.stat-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:12px; margin-bottom:16px; }
.stat-card { background:var(--surface-2); border:1px solid var(--border); border-radius:12px; padding:16px 18px; }
.stat-num { font-size:28px; font-weight:800; color:var(--text); line-height:1; }
.stat-label { font-size:12.5px; color:var(--text-muted); margin-top:7px; }
.bar-row { display:grid; grid-template-columns:140px 1fr 52px; gap:10px; align-items:center; margin:8px 0; font-size:13px; }
.bar-label { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:var(--text); }
.bar-track { background:var(--surface-3); border-radius:6px; height:14px; overflow:hidden; }
.bar-fill { height:100%; border-radius:6px; min-width:2px; transition:width .45s ease; }
.bar-val { text-align:right; font-weight:700; font-size:12px; color:var(--text-muted); }
.stats-empty { padding:22px; text-align:center; color:var(--text-muted); font-size:13px; }

/* Components V2 container */
.dp-cv2 { background:#2b2d31; border-radius:6px; overflow:hidden; margin-top:4px; border-left:4px solid var(--accent); max-width:480px; }
.dp-cv2.no-accent { border-left:none; }
.dp-cv2-banner img { width:100%; max-height:150px; object-fit:cover; display:block; }
.dp-cv2-body { padding:12px 14px; display:flex; gap:12px; align-items:flex-start; }
.dp-cv2-thumb { width:68px; height:68px; border-radius:8px; object-fit:cover; flex-shrink:0; }
.dp-cv2-sep { height:1px; background:rgba(255,255,255,.08); margin:2px 14px; }
.dp-cv2-section { padding:4px 14px; }
.dp-cv2-section .s-title { font-size:13.5px; font-weight:700; color:#f2f3f5; }
.dp-cv2-section .s-sub { font-size:11.5px; color:#949ba4; }

/* Buttons */
.dp-buttons { display:flex; gap:8px; padding:10px 14px 14px; flex-wrap:wrap; }
.dp-btn { padding:8px 16px; border-radius:4px; font-size:13.5px; font-weight:600; color:#fff; cursor:default; display:inline-flex; align-items:center; gap:6px; }
.dp-btn-primary { background:#5865f2; }
.dp-btn-secondary { background:#4e5058; color:#dbdee1; }
.dp-btn-success { background:#248046; }
.dp-btn-danger { background:#da373c; }

/* Select menu */
.dp-select { background:#1e1f22; border:1px solid #1e1f22; border-radius:4px; padding:9px 12px; margin:4px 14px; display:flex; align-items:center; justify-content:space-between; color:#b5bac1; font-size:13.5px; }
.dp-select .dp-sel-arrow { color:#949ba4; }

/* Role pill / channel mention in previews */
.dp-role { display:inline-flex; align-items:center; gap:5px; font-size:13px; font-weight:500; padding:1px 7px; border-radius:30px; }
.dp-role .dp-role-dot { width:9px; height:9px; border-radius:50%; }
.dp-channel { color:var(--accent-text); background:color-mix(in srgb, var(--accent) 28%, transparent); border-radius:4px; padding:0 4px; font-weight:500; }

.dp-empty { padding:20px 14px; font-size:12.5px; color:#949ba4; font-style:italic; text-align:center; }

/* Presence (profil bot) */
.dp-presence { display:flex; align-items:center; gap:12px; }
.dp-presence-dot { position:absolute; bottom:-2px; right:-2px; width:14px; height:14px; border-radius:50%; border:3px solid #313338; }
.dp-presence-act { font-size:12.5px; color:#b5bac1; margin-top:2px; }
.dp-presence-act b { color:#f2f3f5; }

/* ═══════════════ MODALS ═══════════════ */
.modal-overlay { position:fixed; inset:0; background:var(--scrim); backdrop-filter:blur(4px); display:flex; align-items:center; justify-content:center; z-index:100; padding:20px; animation:fadeIn .15s var(--ease); }
.modal { background:var(--elevated); border:1px solid var(--border-2); border-radius:var(--radius-lg); width:560px; max-width:100%; max-height:90vh; overflow-y:auto; box-shadow:var(--shadow-lg); animation:pop .2s var(--ease); }
.modal.wide { width:680px; }
.modal-header { display:flex; align-items:center; justify-content:space-between; padding:20px 22px; border-bottom:1px solid var(--border); position:sticky; top:0; background:var(--elevated); z-index:2; }
.modal-header h3 { font-size:17px; font-weight:800; }
.modal-close { background:none; border:none; color:var(--text-muted); font-size:20px; cursor:pointer; line-height:1; padding:2px; transition:color var(--t); }
.modal-close:hover { color:var(--text); }
.modal-body { padding:22px; }
.modal-footer { display:flex; justify-content:flex-end; gap:10px; padding:16px 22px; border-top:1px solid var(--border); position:sticky; bottom:0; background:var(--elevated); }

/* Live preview card inside option modal */
.preview-card { background:var(--inset); border:1px solid var(--border-2); border-radius:var(--radius-sm); padding:14px; margin-bottom:18px; display:flex; align-items:center; gap:12px; position:relative; }
.preview-card .pc-bar { position:absolute; left:0; top:0; bottom:0; width:4px; border-radius:4px 0 0 4px; background:var(--accent); }
.preview-card .pc-emoji { font-size:22px; }

/* Variable chips */
.var-chips { display:flex; flex-wrap:wrap; gap:6px; margin-top:7px; }
.var-chip { font-size:11px; font-family:var(--mono); background:var(--surface-2); border:1px solid var(--border-2); color:var(--accent-text); padding:3px 8px; border-radius:5px; cursor:pointer; transition:all var(--t); }
.var-chip:hover { background:var(--accent-dim); border-color:var(--accent); }

/* ═══════════════ BARRE DE SAUVEGARDE ═══════════════ */
.save-bar {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 90;
  display: flex; justify-content: center; padding: 0 18px 18px;
  transform: translateY(140%); transition: transform .3s var(--ease);
  pointer-events: none;
}
.save-bar.show { transform: translateY(0); }
.save-bar-inner {
  pointer-events: auto;
  display: flex; align-items: center; justify-content: space-between; gap: 20px;
  width: 100%; max-width: 760px;
  background: var(--elevated); border: 1px solid var(--border-3);
  border-radius: var(--radius); padding: 12px 14px 12px 18px;
  box-shadow: var(--shadow-lg);
  animation: sbPulse .4s var(--ease);
}
.save-bar-text { font-size: 13.5px; font-weight: 600; color: var(--text); display: flex; align-items: center; gap: 9px; }
.save-bar-text .sb-icon { filter: saturate(1.3); }
.save-bar-actions { display: flex; gap: 9px; flex-shrink: 0; }
@keyframes sbPulse { from { transform: translateY(8px); opacity: .6; } to { transform: none; opacity: 1; } }

@media (max-width: 560px) {
  .save-bar { padding: 0 10px 10px; }
  .save-bar-inner { padding: 10px 12px; gap: 10px; }
  .save-bar-text { font-size: 12px; }
  .save-bar-text .save-bar-long { display: none; }
}

/* ═══════════════ PALETTE DE COMMANDES (⌘K) ═══════════════ */
.cmdk { position:fixed; inset:0; z-index:200; background:var(--scrim); backdrop-filter:blur(4px); display:flex; align-items:flex-start; justify-content:center; padding-top:12vh; animation:fadeIn .12s var(--ease); }
.cmdk-box { width:600px; max-width:92vw; background:var(--elevated); border:1px solid var(--border-2); border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); overflow:hidden; animation:pop .16s var(--ease); }
.cmdk-input-row { display:flex; align-items:center; gap:11px; padding:15px 18px; border-bottom:1px solid var(--border); color:var(--text-muted); }
.cmdk-input-row input { flex:1; background:none; border:none; outline:none; color:var(--text); font-size:15.5px; font-family:inherit; }
.cmdk-input-row input::placeholder { color:var(--text-faint); }
.cmdk-results { max-height:50vh; overflow-y:auto; padding:8px; }
.cmdk-group-label { font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.09em; color:var(--text-faint); padding:10px 12px 5px; }
.cmdk-item { display:flex; align-items:center; gap:12px; padding:10px 12px; border-radius:var(--radius-sm); cursor:pointer; color:var(--text-2); }
.cmdk-item .cmdk-ic { width:32px; height:32px; border-radius:9px; display:flex; align-items:center; justify-content:center; background:var(--surface-2); color:var(--text-muted); flex-shrink:0; }
.cmdk-item .cmdk-main { flex:1; min-width:0; }
.cmdk-item .cmdk-title { font-size:14px; font-weight:600; color:var(--text); }
.cmdk-item .cmdk-sub { font-size:11.5px; color:var(--text-muted); }
.cmdk-item.active, .cmdk-item:hover { background:var(--accent-dim); color:var(--text); }
.cmdk-item.active .cmdk-ic { background:var(--accent); color:var(--on-accent); }
.cmdk-empty { padding:30px; text-align:center; color:var(--text-muted); font-size:13px; }

/* ═══════════════ TOASTS ═══════════════ */
.toast-container { position:fixed; bottom:24px; right:24px; z-index:300; display:flex; flex-direction:column; gap:9px; pointer-events:none; }
.toast { display:flex; align-items:center; gap:9px; background:var(--elevated); border:1px solid var(--border-2); padding:12px 16px; border-radius:var(--radius-sm); font-size:13.5px; font-weight:600; box-shadow:var(--shadow-lg); transform:translateX(120%); transition:transform .25s var(--ease); pointer-events:auto; max-width:340px; }
.toast.show { transform:none; }
.toast.success { border-left:3px solid var(--green); }
.toast.error { border-left:3px solid var(--red); }
.toast.info { border-left:3px solid var(--accent); }
.toast-ic { display:inline-flex; align-items:center; }
.toast.success .toast-ic { color:var(--green); }
.toast.error .toast-ic { color:var(--red); }
.toast.info .toast-ic { color:var(--accent); }

/* ═══════════════ DOCS / EXAMPLES ═══════════════ */
.doc-box { background:var(--surface-2); border:1px solid var(--border); border-left:3px solid var(--accent); border-radius:var(--radius-sm); padding:13px 15px; font-size:12.5px; color:var(--text-2); line-height:1.6; }
.doc-box b { color:var(--text); }

/* ═══════════════ MOBILE BACKDROP ═══════════════ */
.sidebar-backdrop { display:none; position:fixed; inset:0; background:var(--scrim); z-index:35; }

/* ═══════════════ RESPONSIVE ═══════════════ */
@media (max-width:1180px) {
  .module-split { grid-template-columns:1fr; }
  .preview-sticky { position:static; }
  :root { --preview-w:1fr; }
  .hero { grid-template-columns:1fr; }
  .hero-card { display:none; }
}
@media (max-width:900px) {
  .app-body { grid-template-columns:1fr; }
  .sidebar { position:fixed; left:0; top:0; height:100vh; width:268px; transform:translateX(-100%); transition:transform var(--t-lg) var(--ease); z-index:70; }
  .sidebar.open { transform:none; box-shadow:var(--shadow-lg); }
  .sidebar-backdrop.show { display:block; }
  .menu-toggle { display:block; }
}
@media (max-width:560px) {
  .home-wrap { padding:18px 14px 50px; }
  .app-content:not(.home) #moduleContainer { padding:14px 14px 50px; }
  .page-header { padding:18px 16px 0; }
  .hero { padding:28px 22px; }
  .hero h1 { font-size:24px; }
  .servers-main { padding:28px 16px 60px; }
  .row-inline { flex-direction:column; }
  .row-emoji { width:100%; }
  .modal { border-radius:var(--radius-lg) var(--radius-lg) 0 0; align-self:flex-end; }
  .modal-overlay { padding:0; align-items:flex-end; }
  .theme-toggle, .save-indicator span { display:none; }
  .save-indicator { padding:6px; }
  .app-header { padding:0 12px; gap:8px; }
  .app-header-right { gap:6px; }
}

/* ═══════════════ ACCESSIBILITÉ & RAFFINEMENTS PREMIUM ═══════════════ */
/* Anneau de focus clavier net et cohérent (souris non impactée) */
a:focus-visible, button:focus-visible, [tabindex]:focus-visible {
  outline:none; box-shadow:var(--ring); border-radius:var(--radius-xs);
}
.input:focus-visible, .textarea:focus-visible, .select:focus-visible {
  border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-dim);
}
/* Lift cohérent au survol des surfaces */
.card { transition:border-color var(--t) var(--ease), box-shadow var(--t) var(--ease), transform var(--t) var(--ease); }

/* Respect des préférences de mouvement réduit */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration:.001ms !important; animation-iteration-count:1 !important;
    transition-duration:.001ms !important; scroll-behavior:auto !important;
  }
}

/* ═══════════════ RESPONSIVE — TABLEAUX & PETITS ÉCRANS ═══════════════ */
@media (max-width:640px) {
  /* Tableaux de données larges → défilement horizontal plutôt qu'écrasement */
  .ev-table { overflow-x:auto; -webkit-overflow-scrolling:touch; padding-bottom:4px; }
  .ev-trow { min-width:560px; }
  .bar-row { grid-template-columns:92px 1fr 42px; gap:8px; }
  .card { padding:16px; }
  .stat-grid { grid-template-columns:repeat(2,1fr); }
  .vc-stats { gap:8px; }
  .list-head { flex-wrap:wrap; gap:10px; }
  .list-head > div { width:100%; display:flex; gap:8px; }
  .list-head .btn { flex:1; }
}
@media (max-width:420px) {
  .page-header h1 { font-size:19px; }
  .modules-head { font-size:19px; }
  .ph-icon { width:38px; height:38px; }
  .btn { padding:9px 13px; font-size:13.5px; }
  .stat-grid { grid-template-columns:1fr; }
  .vc-stats { grid-template-columns:repeat(3,1fr); }
}
