/* ════════════════════════════════════════════════════════════════
   Pawa Radio Cloud — Frontend Dashboard CSS
   ════════════════════════════════════════════════════════════════ */

:root {
  /* ── Sidebar indigo sombre */
  --prc-dark:      #1e1b4b;
  --prc-dark-2:    #2d2a6e;
  --prc-dark-3:    #3730a3;
  --prc-nav-hover: rgba(255,255,255,.07);
  --prc-nav-act:   rgba(99,102,241,.22);
  /* ── Accent indigo — cohérent avec les formulaires */
  --prc-accent:    #6366f1;
  --prc-accent-h:  #4f46e5;
  --prc-accent-lt: #eef2ff;
  --prc-accent-bd: #c7d2fe;
  --prc-grad:      linear-gradient(135deg,#6366f1,#7c3aed);
  /* ── États */
  --prc-success:   #22c55e;
  --prc-danger:    #ef4444;
  --prc-warning:   #f59e0b;
  /* ── Surface claire */
  --prc-bg:        #f5f5fb;
  --prc-surface:   #ffffff;
  --prc-border:    #e8e8f3;
  --prc-text:      #1e1b4b;
  --prc-muted:     #6b7280;
  --prc-radius:    10px;
  --prc-shadow:    0 1px 4px rgba(99,102,241,.07), 0 1px 2px rgba(0,0,0,.04);
  --prc-shadow-md: 0 4px 20px rgba(99,102,241,.12), 0 2px 8px rgba(0,0,0,.06);
  --sidebar-w:     260px;
  --topbar-h:      58px;
}

/* ── Reset ─────────────────────────────────────────────────────── */
.prc-fe-wrap *, .prc-fe-wrap *::before, .prc-fe-wrap *::after { box-sizing: border-box; }
.prc-fe-wrap a { text-decoration: none; }
.prc-fe-wrap button { cursor: pointer; font-family: inherit; }
.prc-fe-wrap input, .prc-fe-wrap textarea, .prc-fe-wrap select { font-family: inherit; }

/* ── App shell ─────────────────────────────────────────────────── */
.prc-fe-wrap {
  display: flex;
  min-height: 100vh;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  font-size: 14px;
  color: var(--prc-text);
  background: var(--prc-bg);
}

/* ── Sidebar ───────────────────────────────────────────────────── */
.prc-fe-sidebar {
  width: var(--sidebar-w);
  background: var(--prc-dark);
  color: rgba(255,255,255,.85);
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0;
  left: 0;
  height: 100vh;
  z-index: 100;
  overflow-y: auto;
  transition: transform .25s ease;
}
.prc-fe-sidebar-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 18px 16px 16px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.prc-fe-brand-logo { width: 40px; height: 40px; border-radius: 8px; object-fit: cover; flex-shrink: 0; }
.prc-fe-brand-logo-ph { width: 40px; height: 40px; border-radius: 8px; background: var(--prc-grad); display:flex; align-items:center; justify-content:center; color:#fff; font-size:18px; flex-shrink:0; }
.prc-fe-brand-text { display: flex; flex-direction: column; }
.prc-fe-brand-name { font-size: 13px; font-weight: 700; color: #fff; line-height: 1.2; }
.prc-fe-brand-tagline { font-size: 10px; color: rgba(255,255,255,.45); margin-top: 2px; }

/* Nav */
.prc-fe-nav { flex: 1; padding: 8px 0; }
.prc-fe-nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  color: rgba(255,255,255,.7);
  font-size: 13px;
  font-weight: 500;
  border-radius: 6px;
  margin: 1px 8px;
  transition: background .15s, color .15s;
  position: relative;
}
.prc-fe-nav-item:hover { background: var(--prc-nav-hover); color: #fff; }
.prc-fe-nav-active    { background: var(--prc-nav-act) !important; color: #a5b4fc !important; }
.prc-fe-nav-active::before {
  content: '';
  position: absolute;
  left: -8px;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 60%;
  background: #a5b4fc;
  border-radius: 0 2px 2px 0;
}
.prc-fe-nav-item i { width: 18px; text-align: center; font-size: 14px; }
.prc-fe-nav-item span { flex: 1; }
.prc-fe-nav-arrow { font-size: 10px; color: rgba(255,255,255,.3); margin-left: auto; }

/* Sidebar footer */
.prc-fe-sidebar-footer { padding: 12px 14px; border-top: 1px solid rgba(255,255,255,.08); }
.prc-fe-sub-badge {
  background: rgba(99,102,241,.18);
  border: 1px solid rgba(99,102,241,.35);
  border-radius: 8px;
  padding: 8px 12px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
}
.prc-fe-sub-badge span { color: #fff; font-weight: 600; }
.prc-fe-sub-badge small { color: rgba(255,255,255,.55); }

/* ── Main content area ─────────────────────────────────────────── */
.prc-fe-main {
  /* Remplace flex:1 — la sidebar étant fixed, elle ne pousse rien */
  margin-left: var(--sidebar-w);
  width: calc(100% - var(--sidebar-w));
  min-width: 0;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

@media (max-width: 768px) {
  .prc-fe-main {
    margin-left: 0;
    width: 100%; /* ajouter cette ligne */
  }
}

/* ── Topbar ────────────────────────────────────────────────────── */
.prc-fe-topbar {
  height: var(--topbar-h);
  background: var(--prc-surface);
  border-bottom: 1px solid var(--prc-border);
  display: flex;
  align-items: center;
  padding: 0 20px;
  gap: 14px;
  position: sticky;
  top: 0;
  z-index: 50;
  box-shadow: var(--prc-shadow);
}
.prc-fe-sidebar-toggle {
  background: none;
  border: none;
  font-size: 16px;
  color: var(--prc-muted);
  padding: 6px;
  border-radius: 6px;
  display: none;
}
.prc-fe-topbar-station { display: flex; align-items: center; gap: 10px; flex: 1; }
.prc-fe-topbar-logo { width: 28px; height: 28px; border-radius: 6px; object-fit: cover; }
.prc-fe-topbar-right { display: flex; align-items: center; gap: 14px; }
.prc-fe-topbar-lang { color: var(--prc-muted); font-size: 13px; cursor: pointer; display: flex; align-items: center; gap: 4px; }

/* User dropdown */
.prc-fe-topbar-user {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  position: relative;
  padding: 4px 8px;
  border-radius: 8px;
  transition: background .15s;
}
.prc-fe-topbar-user:hover { background: var(--prc-accent-lt); }
.prc-fe-avatar { border-radius: 50%; }
.prc-fe-topbar-user span { font-size: 13px; font-weight: 500; }
.prc-fe-user-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  background: var(--prc-surface);
  border: 1px solid var(--prc-border);
  border-radius: 10px;
  box-shadow: var(--prc-shadow-md);
  min-width: 180px;
  z-index: 200;
  padding: 6px 0;
}
.prc-fe-topbar-user:hover .prc-fe-user-dropdown { display: block; }
.prc-fe-user-dropdown a {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  color: var(--prc-text);
  font-size: 13px;
}
.prc-fe-user-dropdown a:hover { background: var(--prc-accent-lt); color: var(--prc-accent); }
.prc-fe-user-dropdown hr { border: none; border-top: 1px solid var(--prc-border); margin: 4px 0; }

/* ── Content ───────────────────────────────────────────────────── */
.prc-fe-content { flex: 1; padding: 20px; }
.prc-fe-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.prc-fe-section-header h2 { margin: 0; font-size: 20px; font-weight: 700; display: flex; align-items: center; gap: 10px; }

/* ── Cards ─────────────────────────────────────────────────────── */
.prc-fe-card {
  background: var(--prc-surface);
  border: 1px solid var(--prc-border);
  border-radius: var(--prc-radius);
  box-shadow: var(--prc-shadow);
  padding: 16px 18px;
}
.prc-fe-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--prc-border);
}
.prc-fe-card-header h3 { margin: 0; font-size: 15px; font-weight: 600; display: flex; align-items: center; gap: 8px; }
.prc-fe-card-header-inline { display: flex; align-items: center; justify-content: space-between; }

/* ── Dashboard layout ──────────────────────────────────────────── */
.prc-fe-dash-top {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}
.prc-fe-dash-mid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}
.prc-fe-dash-bottom {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

/* Player card */
.prc-fe-player-header { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.prc-fe-player-logo { width: 50px; height: 50px; border-radius: 10px; object-fit: cover; }
.prc-fe-player-logo-ph { width: 50px; height: 50px; border-radius: 10px; background: #e2e8f0; display: flex; align-items: center; justify-content: center; font-size: 22px; }
.prc-fe-station-title { font-size: 18px; font-weight: 700; margin: 0 0 4px 0; }
.prc-fe-onair-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #dcfce7;
  color: #166534;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
}
.prc-fe-onair-badge.prc-fe-onair-off { background: #fef2f2; color: #b91c1c; }
.prc-fe-onair-badge.prc-fe-onair-off .prc-fe-onair-dot { animation: none; opacity: .5; }
.prc-fe-onair-dot { width: 8px; height: 8px; background: currentColor; border-radius: 50%; display: inline-block; animation: prc-pulse 1.5s ease-in-out infinite; }
@keyframes prc-pulse { 0%,100% { opacity: 1; } 50% { opacity: .4; } }

/* Mini player */
.prc-fe-mini-player {
  background: var(--prc-dark);
  border-radius: 8px;
  padding: 12px 14px;
  display: flex;
  align-items: center;
  gap: 12px;
  color: #fff;
  margin-bottom: 12px;
}
.prc-fe-play-btn {
  width: 40px; height: 40px;
  background: var(--prc-grad);
  border: none; border-radius: 50%;
  color: #fff; font-size: 14px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: background .15s;
}
.prc-fe-play-btn:hover { background: var(--prc-accent-h); }
.prc-fe-mini-player-info { flex: 1; min-width: 0; }
.prc-fe-np-artist-title { font-size: 13px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; display: block; margin-bottom: 6px; }
.prc-fe-mini-waveform { display: flex; align-items: center; gap: 8px; }
.prc-fe-player-controls { display: flex; gap: 6px; }
.prc-fe-player-controls button { background: rgba(255,255,255,.1); border: none; color: #fff; width: 30px; height: 30px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 12px; }
.prc-fe-player-controls button:hover { background: rgba(255,255,255,.2); }

/* Stream URL row */
.prc-fe-stream-url-row {
  display: flex;
  align-items: center;
  gap: 8px;
  background: #f8fafc;
  border: 1px solid var(--prc-border);
  border-radius: 6px;
  padding: 8px 12px;
  font-size: 12px;
}
.prc-fe-url-icon { color: var(--prc-muted); flex-shrink: 0; }
.prc-fe-stream-url-text { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--prc-muted); }
.prc-fe-copy-btn {
  background: var(--prc-grad);
  color: #fff; border: none;
  padding: 6px 14px; border-radius: 6px;
  font-size: 12px; white-space: nowrap;
  display: flex; align-items: center; gap: 6px;
  flex-shrink: 0;
}
.prc-fe-copy-btn:hover { filter: brightness(1.1); }

/* Listeners card */
.prc-fe-listeners-card { }
.prc-fe-listeners-badge {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 24px;
  font-weight: 700;
  color: var(--prc-accent);
}
.prc-fe-listeners-chart { margin-top: 12px; }

/* Resources card */
.prc-fe-resource-item { }
.prc-fe-resource-label { display: flex; justify-content: space-between; font-size: 12px; margin-bottom: 6px; color: var(--prc-muted); }
.prc-fe-resource-label strong { color: var(--prc-text); font-size: 13px; }
.prc-fe-gauge-wrap { position: relative; width: 90px; height: 70px; margin: 8px auto 0; }
.prc-fe-gauge-pct { position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); font-size: 16px; font-weight: 700; }

/* Progress bars */
.prc-fe-progress-track { height: 8px; background: #e2e8f0; border-radius: 4px; overflow: hidden; }
.prc-fe-progress-fill { height: 100%; border-radius: 4px; transition: width .4s ease; }
.prc-fe-progress-blue    { background: var(--prc-accent); }
.prc-fe-progress-danger  { background: var(--prc-danger); }
.prc-fe-progress-bar { flex: 1; height: 4px; background: rgba(255,255,255,.2); border-radius: 2px; overflow: hidden; }
.prc-fe-progress-bar .prc-fe-progress-fill { background: #fff; }

/* History */
.prc-fe-history-row { display: flex; align-items: center; gap: 10px; padding: 7px 0; border-bottom: 1px solid #f1f5f9; font-size: 13px; }
.prc-fe-history-row:last-child { border-bottom: none; }
.prc-fe-history-icon { color: var(--prc-accent); font-size: 12px; flex-shrink: 0; }
.prc-fe-history-title { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.prc-fe-history-time { color: var(--prc-muted); font-size: 12px; white-space: nowrap; }

/* Schedule */
.prc-fe-sched-row { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px solid #f1f5f9; font-size: 13px; }
.prc-fe-sched-row:last-child { border-bottom: none; }
.prc-fe-sched-name { flex: 1; font-weight: 500; }
.prc-fe-sched-time { color: var(--prc-muted); font-size: 12px; display: flex; align-items: center; gap: 4px; }
.prc-fe-live-badge { background: #fee2e2; color: #b91c1c; padding: 2px 8px; border-radius: 10px; font-size: 11px; font-weight: 600; }
.prc-fe-info-icon { color: var(--prc-accent); }

/* Quick config */
.prc-fe-quick-btns { display: flex; flex-direction: column; gap: 8px; }
.prc-fe-quick-btn {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; border: none; border-radius: 8px;
  font-size: 13px; font-weight: 600; color: #fff;
  transition: opacity .15s, transform .1s;
}
.prc-fe-quick-btn:active { transform: scale(.98); }
.prc-fe-quick-stop    { background: #ef4444; }
.prc-fe-quick-restart { background: var(--prc-grad); }
.prc-fe-quick-playlist{ background: #22c55e; }

/* See more */
.prc-fe-see-more { display: block; text-align: center; font-size: 13px; color: var(--prc-accent); margin-top: 10px; padding-top: 8px; border-top: 1px solid #f1f5f9; }
.prc-fe-see-more:hover { text-decoration: underline; }

/* Stats tabs */
.prc-fe-stats-tabs { display: flex; gap: 2px; background: #f1f5f9; border-radius: 8px; padding: 3px; width: fit-content; margin-bottom: 14px; }
.prc-fe-stats-tab { background: none; border: none; padding: 5px 12px; border-radius: 6px; font-size: 12px; color: var(--prc-muted); font-weight: 500; }
.prc-fe-stats-active { background: var(--prc-surface) !important; color: var(--prc-text) !important; box-shadow: 0 1px 3px rgba(0,0,0,.1); }

/* ── Tables ────────────────────────────────────────────────────── */
.prc-fe-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.prc-fe-table th { text-align: left; padding: 8px 12px; font-size: 11px; font-weight: 600; color: var(--prc-muted); text-transform: uppercase; letter-spacing: .04em; border-bottom: 2px solid var(--prc-border); background: #f8f8fd; }
.prc-fe-table td { padding: 10px 10px; border-bottom: 1px solid #f8fafc; vertical-align: middle; }
.prc-fe-table tbody tr:hover { background: #f5f5fb; }
.prc-fe-table tbody tr:last-child td { border-bottom: none; }
.prc-fe-loading-cell { text-align: center; color: var(--prc-muted); padding: 24px !important; }
.prc-fe-empty { text-align: center; color: var(--prc-muted); padding: 30px 0; font-size: 13px; }
.prc-fe-playlists-mini td:first-child { max-width: 140px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ── Buttons ───────────────────────────────────────────────────── */
.prc-fe-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-radius: 7px;
  font-size: 13px; font-weight: 500;
  border: none; cursor: pointer;
  text-decoration: none; white-space: nowrap;
  transition: background .15s, box-shadow .15s;
}
.prc-fe-btn:disabled { opacity: .6; cursor: not-allowed; }
.prc-fe-btn-primary  { background: var(--prc-grad); color: #fff; box-shadow: 0 2px 8px rgba(99,102,241,.25); }
.prc-fe-btn-primary:hover { filter: brightness(1.08); color: #fff; }
.prc-fe-btn-outline  { background: transparent; color: var(--prc-accent); border: 1px solid var(--prc-accent); }
.prc-fe-btn-outline:hover { background: var(--prc-accent-lt); color: var(--prc-accent); }
.prc-fe-btn-secondary{ background: #f1f5f9; color: var(--prc-text); border: 1px solid var(--prc-border); }
.prc-fe-btn-danger   { background: var(--prc-danger); color: #fff; }
.prc-fe-btn-sm  { padding: 5px 12px; font-size: 12px; }
.prc-fe-btn-xs  { padding: 3px 8px; font-size: 11px; }
.prc-fe-btn-full { width: 100%; justify-content: center; }
.prc-fe-icon-btn { background: none; border: none; padding: 5px; color: var(--prc-muted); border-radius: 5px; }
.prc-fe-icon-btn:hover { background: #f1f5f9; color: var(--prc-text); }
.prc-fe-icon-btn.prc-fe-danger:hover { color: var(--prc-danger); background: #fef2f2; }

/* ── Badges ────────────────────────────────────────────────────── */
.prc-fe-badge { display: inline-block; padding: 2px 8px; border-radius: 20px; font-size: 11px; font-weight: 600; }
.prc-fe-badge-green { background: #dcfce7; color: #166534; }
.prc-fe-badge-blue  { background: var(--prc-accent-lt); color: var(--prc-accent); }
.prc-fe-badge-grey  { background: #f1f5f9; color: #475569; }
.prc-fe-badge-red   { background: #fee2e2; color: #b91c1c; }

/* ── Alerts ────────────────────────────────────────────────────── */
.prc-fe-alert { display: flex; align-items: flex-start; gap: 12px; padding: 14px 16px; border-radius: 8px; margin-bottom: 14px; }
.prc-fe-alert-danger { background: #fef2f2; border: 1px solid #fecaca; color: #991b1b; }
.prc-fe-alert-icon { font-size: 20px; flex-shrink: 0; }
.prc-fe-alert-inline {
  padding: 10px 14px; border-radius: 6px; font-size: 13px;
  margin-bottom: 12px; border-left: 4px solid transparent;
}
.prc-fe-alert-inline.prc-fe-ok  { background: #f0fdf4; border-color: var(--prc-success); color: #166534; }
.prc-fe-alert-inline.prc-fe-err { background: #fef2f2; border-color: var(--prc-danger);  color: #991b1b; }
.prc-fe-info-banner { background: #eef2ff; border: 1px solid #c7d2fe; border-radius: 8px; padding: 10px 14px; font-size: 13px; margin-bottom: 14px; }

/* ── Modal ─────────────────────────────────────────────────────── */
.prc-fe-modal { position: fixed; inset: 0; z-index: 9999; display: flex; align-items: flex-start; justify-content: center; padding: 60px 16px; }
.prc-fe-modal-overlay { position: fixed; inset: 0; background: rgba(30,27,75,.45); backdrop-filter: blur(2px); }
.prc-fe-modal-box {
  position: relative; z-index: 1;
  background: var(--prc-surface);
  border-radius: 12px;
  box-shadow: 0 20px 50px rgba(0,0,0,.25);
  width: 100%; max-width: 520px;
  max-height: 85vh; overflow-y: auto;
}
.prc-fe-modal-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 20px; border-bottom: 1px solid var(--prc-border);
}
.prc-fe-modal-header h3 { margin: 0; font-size: 16px; }
.prc-fe-modal-close { background: none; border: none; font-size: 16px; color: var(--prc-muted); padding: 4px 8px; border-radius: 4px; }
.prc-fe-modal-close:hover { background: #f1f5f9; }
.prc-fe-modal-body { padding: 20px; }
.prc-fe-modal-footer { display: flex; gap: 8px; padding-top: 16px; border-top: 1px solid var(--prc-border); margin-top: 16px; }

/* ── Forms ─────────────────────────────────────────────────────── */
.prc-fe-form-group { display: flex; flex-direction: column; gap: 5px; margin-bottom: 14px; }
.prc-fe-form-group label { font-size: 13px; font-weight: 500; }
.prc-fe-form-group small { font-size: 11px; color: var(--prc-muted); }
.prc-fe-input {
  border: 1px solid var(--prc-border); border-radius: 7px;
  padding: 8px 12px; font-size: 13px; width: 100%;
  transition: border-color .15s;
  background: var(--prc-surface);
}
.prc-fe-input:focus { outline: none; border-color: var(--prc-accent); box-shadow: 0 0 0 3px rgba(99,102,241,.1); }
.prc-fe-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 20px; }
.prc-fe-col-2 { grid-column: span 2; }
.prc-fe-form-footer { padding-top: 14px; border-top: 1px solid var(--prc-border); margin-top: 4px; }
.prc-fe-toolbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; padding: 10px 14px; gap: 10px; flex-wrap: wrap; }
.prc-fe-toolbar-right { display: flex; gap: 8px; }
.prc-fe-breadcrumb { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--prc-muted); }
.prc-fe-bread-item { cursor: pointer; color: var(--prc-accent); }
.prc-fe-bread-item:hover { text-decoration: underline; }
.prc-fe-select-sm { border: 1px solid var(--prc-border); border-radius: 6px; padding: 5px 8px; font-size: 13px; }
.prc-fe-upload-label { cursor: pointer; }

/* ── Media ─────────────────────────────────────────────────────── */
.prc-fe-media-name { max-width: 220px; }
.prc-fe-music-icon { color: var(--prc-accent); }
.prc-fe-folder-icon { color: #f59e0b; }
.prc-fe-media-dir { cursor: pointer; }
.prc-fe-media-dir:hover { background: #fff9e6; }
.prc-fe-action-row { display: flex; gap: 4px; }
.prc-fe-storage-bar-card { padding: 14px 18px; margin-bottom: 10px; }
.prc-fe-storage-info { display: flex; justify-content: space-between; font-size: 13px; }
.prc-fe-storage-limit { color: var(--prc-muted); font-size: 12px; }
.prc-fe-upload-progress { padding: 12px 16px; margin-bottom: 10px; }
.prc-fe-upload-row { display: flex; align-items: center; gap: 10px; margin-bottom: 6px; font-size: 12px; }
.prc-fe-upload-name { min-width: 120px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.prc-fe-upload-bar-wrap { flex: 1; }
.prc-fe-upload-fill { height: 6px; border-radius: 3px; }
.prc-fe-upload-status { width: 32px; text-align: right; font-size: 11px; }
.prc-fe-bulk-bar { position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%); background: var(--prc-dark); color: #fff; padding: 12px 20px; border-radius: 30px; display: flex; align-items: center; gap: 12px; font-size: 13px; box-shadow: 0 4px 20px rgba(0,0,0,.3); z-index: 99; }

/* ── Playlists grid ────────────────────────────────────────────── */
.prc-fe-playlists-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 14px; }
.prc-fe-pl-card { background: var(--prc-surface); border: 1px solid var(--prc-border); border-radius: 10px; padding: 16px; box-shadow: var(--prc-shadow); }
.prc-fe-pl-card-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.prc-fe-pl-title { display: flex; align-items: center; gap: 8px; font-size: 14px; }
.prc-fe-pl-meta { display: flex; gap: 12px; font-size: 12px; color: var(--prc-muted); margin-bottom: 12px; }
.prc-fe-pl-actions { display: flex; gap: 6px; padding-top: 10px; border-top: 1px solid var(--prc-border); }

/* ── DJs ───────────────────────────────────────────────────────── */
.prc-fe-djs-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 14px; }
.prc-fe-dj-card {
  background: var(--prc-surface); border: 1px solid var(--prc-border);
  border-radius: 10px; padding: 16px; box-shadow: var(--prc-shadow);
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: 8px;
}
.prc-fe-dj-avatar { width: 54px; height: 54px; background: var(--prc-dark); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 20px; color: #fff; }
.prc-fe-dj-info { display: flex; flex-direction: column; gap: 2px; }
.prc-fe-dj-info strong { font-size: 14px; }
.prc-fe-dj-info code { font-size: 11px; background: #f1f5f9; padding: 1px 6px; border-radius: 4px; }
.prc-fe-dj-info small { color: var(--prc-muted); font-size: 11px; }
.prc-fe-dj-actions { display: flex; gap: 6px; margin-top: 6px; }

/* ── Schedule week ─────────────────────────────────────────────── */
.prc-fe-week-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
.prc-fe-week-col { min-height: 80px; }
.prc-fe-week-day { font-size: 11px; font-weight: 700; color: var(--prc-muted); text-transform: uppercase; text-align: center; margin-bottom: 4px; }
.prc-fe-week-event { font-size: 11px; padding: 4px 6px; border-radius: 4px; margin-bottom: 3px; }
.prc-fe-event-pl { background: var(--prc-accent-lt); color: var(--prc-accent); }
.prc-fe-event-dj { background: #fce7f3; color: #9d174d; }

/* ── Reports ───────────────────────────────────────────────────── */
.prc-fe-reports-tabs { display: flex; gap: 2px; background: #f1f5f9; border-radius: 8px; padding: 3px; width: fit-content; margin-bottom: 14px; }
.prc-fe-chart-wrap { position: relative; }

/* ── Stats mini cards ──────────────────────────────────────────── */
.prc-fe-stats-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 14px; }
.prc-fe-stat-mini-card { background: var(--prc-surface); border: 1px solid var(--prc-border); border-radius: 10px; padding: 16px; text-align: center; }
.prc-fe-stat-mini-card i { font-size: 18px; color: var(--prc-accent); margin-bottom: 6px; display: block; }
.prc-fe-stat-mini-value { font-size: 22px; font-weight: 700; margin-bottom: 4px; }
.prc-fe-stat-mini-label { font-size: 11px; color: var(--prc-muted); }
.prc-fe-stats-period-btns { display: flex; gap: 4px; }

/* ── Config actions ────────────────────────────────────────────── */
.prc-fe-config-actions { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.prc-fe-action-card {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 8px; padding: 18px 12px;
  background: #f8fafc; border: 1px solid var(--prc-border); border-radius: 10px;
  font-size: 13px; font-weight: 500; color: var(--prc-text);
  transition: background .15s, border-color .15s;
}
.prc-fe-action-card i { font-size: 20px; color: var(--prc-accent); }
.prc-fe-action-card:hover { background: var(--prc-accent-lt); border-color: var(--prc-accent); }
.prc-fe-action-stop i { color: var(--prc-danger); }
.prc-fe-action-stop:hover { background: #fef2f2; border-color: var(--prc-danger); }

/* ── Profile ───────────────────────────────────────────────────── */
.prc-fe-profile-header { display: flex; align-items: center; gap: 16px; padding-bottom: 16px; border-bottom: 1px solid var(--prc-border); }
.prc-fe-profile-avatar { width: 80px; height: 80px; border-radius: 50%; }

/* ── Subscription ──────────────────────────────────────────────── */
.prc-fe-sub-card { }
.prc-fe-sub-active { display: flex; flex-direction: column; gap: 10px; }
.prc-fe-sub-plan-name { font-size: 22px; font-weight: 700; }
.prc-fe-sub-dates { display: flex; gap: 20px; flex-wrap: wrap; font-size: 13px; }
.prc-fe-sub-limits { display: flex; gap: 12px; flex-wrap: wrap; font-size: 13px; color: var(--prc-muted); }
.prc-fe-sub-limits span { display: flex; align-items: center; gap: 5px; }
.prc-fe-sub-expired { text-align: center; padding: 20px; }
.prc-fe-plans-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 14px; margin-bottom: 20px; }
.prc-fe-plan-card { background: var(--prc-surface); border: 2px solid var(--prc-border); border-radius: 12px; padding: 20px; position: relative; }
.prc-fe-plan-current { border-color: var(--prc-accent); }
.prc-fe-plan-current-badge { background: var(--prc-grad); color: #fff; font-size: 11px; font-weight: 600; padding: 2px 10px; border-radius: 0 8px 0 8px; position: absolute; top: 0; right: 0; }
.prc-fe-plan-price { font-size: 22px; font-weight: 700; color: var(--prc-accent); margin: 8px 0; }
.prc-fe-plan-price small { font-size: 13px; font-weight: 400; color: var(--prc-muted); }
.prc-fe-plan-features { list-style: none; padding: 0; margin: 0; font-size: 13px; }
.prc-fe-plan-features li { display: flex; align-items: center; gap: 7px; padding: 4px 0; }
.prc-fe-plan-features li i { color: var(--prc-success); font-size: 11px; }
.prc-fe-plan-contact { font-size: 12px; color: var(--prc-muted); margin-top: 10px; display: flex; align-items: center; gap: 5px; }

/* ── WebRadio ──────────────────────────────────────────────────── */
.prc-fe-webradio-url-row { display: flex; align-items: center; gap: 10px; padding: 12px 0; border-bottom: 1px solid var(--prc-border); margin-bottom: 12px; font-size: 13px; }
.prc-fe-streams-list { display: flex; flex-direction: column; gap: 10px; }
.prc-fe-stream-row { display: flex; align-items: center; gap: 10px; }
.prc-fe-stream-type { min-width: 60px; font-weight: 600; font-size: 12px; }
.prc-fe-stream-row code { flex: 1; background: #f1f5f9; padding: 4px 10px; border-radius: 6px; font-size: 12px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.prc-fe-pub-player { max-width: 400px; margin: 0 auto; text-align: center; }
.prc-fe-pub-logo { width: 80px; height: 80px; border-radius: 12px; margin-bottom: 10px; }
.prc-fe-pub-audio { width: 100%; }

/* ── Diffusion grid ────────────────────────────────────────────── */
.prc-fe-diffusion-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.prc-fe-mount-row { display: flex; align-items: center; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid #f1f5f9; }
.prc-fe-mount-info { display: flex; flex-direction: column; }
.prc-fe-mount-info strong { font-size: 13px; }
.prc-fe-mount-info small { color: var(--prc-muted); font-size: 11px; }

/* ── Misc ──────────────────────────────────────────────────────── */
.prc-fe-link { font-size: 12px; color: var(--prc-accent); display: flex; align-items: center; gap: 4px; }
.prc-fe-loading { padding: 30px; text-align: center; color: var(--prc-muted); }
.prc-fe-text-muted { color: var(--prc-muted); }
.prc-fe-login-required, .prc-fe-no-station { text-align: center; padding: 40px; }
.prc-fe-btn-loading { opacity: .7; }
.prc-fe-skeleton-rows::after { content: ''; display: block; padding: 24px; color: var(--prc-muted); text-align: center; }

/* ── Public player ─────────────────────────────────────────────── */
.prc-pub-player-wrap { max-width: 500px; margin: 0 auto; font-family: inherit; }
.prc-pub-player { background: var(--prc-dark); color: #fff; border-radius: 16px; padding: 24px; }
.prc-pub-header { display: flex; align-items: center; gap: 14px; margin-bottom: 16px; }
.prc-pub-logo { width: 64px; height: 64px; border-radius: 10px; object-fit: cover; }
.prc-pub-info h2 { margin: 0 0 4px; font-size: 18px; }
.prc-pub-now-playing { margin: 0; font-size: 12px; opacity: .7; }
.prc-pub-live-badge { display: flex; align-items: center; gap: 6px; background: rgba(34,197,94,.25); padding: 4px 12px; border-radius: 20px; font-size: 12px; font-weight: 600; color: #4ade80; margin-left: auto; }
.prc-pub-live-dot { width: 8px; height: 8px; background: #4ade80; border-radius: 50%; animation: prc-pulse 1.5s infinite; }
.prc-pub-audio { border-radius: 8px; background: rgba(255,255,255,.1); }
.prc-pub-description { font-size: 12px; opacity: .6; margin: 10px 0 0; }

/* ── Responsive ────────────────────────────────────────────────── */
@media (max-width: 1100px) {
  .prc-fe-dash-top  { grid-template-columns: 1fr 1fr; }
  .prc-fe-dash-top .prc-fe-player-card { grid-column: span 2; }
  .prc-fe-dash-mid  { grid-template-columns: 1fr 1fr; }
  .prc-fe-dash-mid .prc-fe-quick-config { grid-column: span 2; }
  .prc-fe-stats-cards { grid-template-columns: repeat(2, 1fr); }
  .prc-fe-diffusion-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .prc-fe-sidebar { transform: translateX(-100%); }
  .prc-fe-sidebar.prc-fe-sidebar-open { transform: translateX(0); }
  .prc-fe-main { margin-left: 0; }
  .prc-fe-sidebar-toggle { display: flex; }
  .prc-fe-dash-top, .prc-fe-dash-mid, .prc-fe-dash-bottom { grid-template-columns: 1fr; }
  .prc-fe-dash-top .prc-fe-player-card { grid-column: span 1; }
  .prc-fe-dash-mid .prc-fe-quick-config { grid-column: span 1; }
  .prc-fe-form-grid, .prc-fe-form-grid-2 { grid-template-columns: 1fr; }
  .prc-fe-col-2 { grid-column: span 1; }
  .prc-fe-config-actions { grid-template-columns: 1fr; }
  .prc-fe-stats-cards { grid-template-columns: repeat(2, 1fr); }
}

/* ── WebRadio Public ─────────────────────────────────────────────────────── */
.prc-fe-webradio-url-block,
.prc-fe-webradio-no-page { padding: 4px 0 8px; }

.prc-fe-webradio-url-row {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    padding: 12px 14px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
}
.prc-fe-webradio-url {
    flex: 1;
    font-family: monospace;
    font-size: 13px;
    color: #1e1b4b;
    word-break: break-all;
    background: none;
    border: none;
    padding: 0;
}
.prc-fe-webradio-url-actions {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
}
.prc-fe-webradio-hint {
    font-size: 12px;
    color: #64748b;
    margin: 10px 0 0;
    display: flex;
    align-items: center;
    gap: 6px;
}

.prc-fe-webradio-missing {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 16px;
    background: #fffbeb;
    border: 1px solid #fde68a;
    border-radius: 8px;
    margin-bottom: 14px;
}
.prc-fe-webradio-missing strong { display: block; margin-bottom: 4px; }
.prc-fe-webradio-missing p { margin: 0; font-size: 13px; color: #64748b; }
.prc-fe-webradio-missing code { font-size: 12px; color: #1e1b4b; }

.prc-fe-streams-list { display: flex; flex-direction: column; gap: 10px; padding: 4px 0; }
.prc-fe-stream-row {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 14px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
}
.prc-fe-stream-badge {
    font-size: 11px; font-weight: 700;
    padding: 2px 10px; border-radius: 20px;
    flex-shrink: 0;
}
.prc-fe-stream-code {
    flex: 1; font-size: 12px;
    font-family: monospace; color: #1e1b4b;
    word-break: break-all;
}

.prc-fe-pub-player-preview {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 20px;
    background: #f8fafc;
    border-radius: 8px;
    gap: 12px;
}
.prc-fe-pub-logo { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; }
.prc-fe-pub-logo-ph {
    width: 80px; height: 80px; border-radius: 50%;
    background: #e2e8f0; display: flex; align-items: center; justify-content: center;
    font-size: 28px; color: #94a3b8;
}
.prc-fe-pub-preview-info { text-align: center; }
.prc-fe-pub-preview-info strong { display: block; font-size: 16px; margin-bottom: 4px; }
.prc-fe-pub-audio { width: 100%; max-width: 400px; }

/* ════════════════════════════════════════════════════════════════
   PAWA RADIO CLOUD — Extensions CSS v2.0
   Playlists, DJs, Média, Schedule
   ════════════════════════════════════════════════════════════════ */

/* ── Utility ──────────────────────────────────────────────────── */
.prc-req { color: var(--prc-danger); }
.prc-fe-form-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 640px) { .prc-fe-form-row-2 { grid-template-columns: 1fr; } }

.prc-fe-form-checks { display: flex; flex-direction: column; gap: 10px; padding: 4px 0; }
.prc-fe-check-label { display: flex; align-items: center; gap: 10px; cursor: pointer; font-size: 13px; }
.prc-fe-check-label input[type=checkbox] { width: 16px; height: 16px; accent-color: var(--prc-accent); flex-shrink: 0; }
.prc-fe-input-group { display: flex; gap: 8px; align-items: center; }
.prc-fe-input-group .prc-fe-input { flex: 1; }
.prc-fe-input-sm { padding: 6px 10px; font-size: 12px; border-radius: 6px; border: 1px solid var(--prc-border); }

/* ── Playlist Cards ─────────────────────────────────────────────── */
.prc-fe-playlists-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 14px;
}
.prc-fe-pl-card {
  background: var(--prc-surface);
  border: 1px solid var(--prc-border);
  border-radius: var(--prc-radius);
  box-shadow: var(--prc-shadow);
  overflow: hidden;
  transition: box-shadow .2s, transform .15s;
}
.prc-fe-pl-card:hover { box-shadow: var(--prc-shadow-md); transform: translateY(-1px); }
.prc-fe-pl-card-top {
  display: flex; align-items: center; gap: 12px; padding: 16px;
  border-bottom: 1px solid var(--prc-border);
}
.prc-fe-pl-card-top:hover { background: #f8fafc; }
.prc-fe-pl-icon-wrap {
  width: 44px; height: 44px; border-radius: 10px;
  background: var(--prc-grad);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 18px; flex-shrink: 0;
}
.prc-fe-pl-info { flex: 1; min-width: 0; }
.prc-fe-pl-name { display: block; font-size: 14px; font-weight: 600; margin-bottom: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.prc-fe-pl-meta { display: flex; flex-wrap: wrap; gap: 10px; font-size: 11px; color: var(--prc-muted); }
.prc-fe-pl-meta span { display: flex; align-items: center; gap: 4px; }
.prc-fe-pl-actions { display: flex; gap: 6px; padding: 10px 12px; flex-wrap: wrap; }

/* Weight slider */
.prc-pl-weight-slider { flex: 1; accent-color: var(--prc-accent); height: 6px; }
.prc-pl-weight-val {
  min-width: 32px; height: 32px; background: var(--prc-grad); color: #fff;
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 13px; flex-shrink: 0;
}

/* ── Playlist Detail Tabs ──────────────────────────────────────── */
.prc-pl-tabs {
  display: flex; gap: 2px; border-bottom: 2px solid var(--prc-border);
  margin-bottom: 16px; padding: 0 2px;
}
.prc-pl-tab {
  background: none; border: none; padding: 10px 18px; font-size: 13px;
  color: var(--prc-muted); border-bottom: 2px solid transparent;
  margin-bottom: -2px; cursor: pointer; display: flex; align-items: center; gap: 7px;
  transition: color .15s, border-color .15s; border-radius: 6px 6px 0 0;
}
.prc-pl-tab:hover { color: var(--prc-text); background: #f1f5f9; }
.prc-pl-tab-active { color: var(--prc-accent) !important; border-bottom-color: var(--prc-accent) !important; font-weight: 600; }
.prc-pl-tab-count {
  background: var(--prc-grad); color: #fff; font-size: 10px;
  padding: 1px 6px; border-radius: 12px; font-weight: 700;
}

/* ── Modal large ──────────────────────────────────────────────── */
.prc-fe-modal-lg { max-width: 680px !important; }

/* Modal inner tabs */
.prc-pl-modal-tabs { display: flex; gap: 2px; border-bottom: 1px solid var(--prc-border); margin-bottom: 20px; }
.prc-pl-modal-tab {
  background: none; border: none; padding: 8px 16px; font-size: 12px; font-weight: 500;
  color: var(--prc-muted); border-bottom: 2px solid transparent; margin-bottom: -1px;
  cursor: pointer; border-radius: 4px 4px 0 0; transition: color .15s;
}
.prc-pl-modal-tab:hover { color: var(--prc-text); }
.prc-pl-modal-tab-active { color: var(--prc-accent) !important; border-bottom-color: var(--prc-accent) !important; }

/* ── Playlist Songs Table ──────────────────────────────────────── */
.prc-pl-songs-table .prc-fe-table { margin: 0; }
.prc-pl-song-num { color: var(--prc-muted); width: 36px; font-size: 12px; }
.prc-pl-song-title { max-width: 260px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ── Upload Zone ────────────────────────────────────────────────── */
.prc-pl-upload-zone {
  border: 2px dashed var(--prc-border); border-radius: 12px;
  padding: 40px 24px; text-align: center; color: var(--prc-muted);
  transition: border-color .2s, background .2s; margin: 16px;
  cursor: pointer;
}
.prc-pl-upload-zone:hover,
.prc-pl-drag-over { border-color: var(--prc-accent); background: var(--prc-accent-lt); color: var(--prc-accent); }
.prc-pl-upload-zone i { display: block; margin-bottom: 12px; color: var(--prc-accent); }
.prc-pl-upload-zone p { margin: 0 0 16px; font-size: 14px; }

.prc-pl-upload-progress-list { padding: 12px 16px; display: flex; flex-direction: column; gap: 8px; }
.prc-pl-up-row {
  display: flex; align-items: center; gap: 10px; font-size: 12px;
  background: #f8fafc; padding: 8px 12px; border-radius: 8px;
}
.prc-pl-up-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.prc-pl-up-bar { flex: 1; max-width: 200px; }
.prc-pl-up-status { min-width: 28px; text-align: right; font-weight: 600; }

/* ── Library / Assign ───────────────────────────────────────────── */
.prc-lib-list { max-height: 400px; overflow-y: auto; }
.prc-lib-item {
  display: flex; align-items: center; gap: 10px; padding: 9px 14px;
  border-bottom: 1px solid var(--prc-border); font-size: 13px;
}
.prc-lib-item:hover { background: #f8fafc; }
.prc-lib-item.prc-lib-in-playlist { background: #f0fdf4; }
.prc-lib-title { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 500; }
.prc-lib-artist { min-width: 120px; overflow: hidden; text-overflow: ellipsis; font-size: 11px; }
.prc-lib-dur { min-width: 42px; text-align: right; color: var(--prc-muted); font-size: 11px; }

/* ── Schedule Items ─────────────────────────────────────────────── */
.prc-sched-list { padding: 8px 0; }
.prc-sched-item {
  display: flex; align-items: center; gap: 14px; padding: 12px 16px;
  border-bottom: 1px solid var(--prc-border); flex-wrap: wrap;
}
.prc-sched-item:hover { background: #f8fafc; }
.prc-sched-time { font-weight: 600; font-size: 14px; color: var(--prc-accent); min-width: 150px; }
.prc-sched-days { font-size: 12px; color: var(--prc-muted); flex: 1; }
.prc-sched-date { font-size: 11px; }

/* Days grid (schedule form) */
.prc-pl-days-grid { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 6px; }
.prc-pl-day-label { display: flex; flex-direction: column; align-items: center; gap: 4px; cursor: pointer; }
.prc-pl-day-label input[type=checkbox] { display: none; }
.prc-pl-day-label span {
  display: flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: 50%;
  border: 2px solid var(--prc-border); font-size: 11px; font-weight: 600;
  transition: background .15s, border-color .15s, color .15s;
}
.prc-pl-day-label input:checked + span { background: var(--prc-accent); border-color: var(--prc-accent); color: #fff; }

/* ── DJ Cards ───────────────────────────────────────────────────── */
.prc-fe-djs-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(280px,1fr)); gap: 14px; }
.prc-fe-dj-card {
  background: var(--prc-surface); border: 1px solid var(--prc-border);
  border-radius: var(--prc-radius); padding: 16px; display: flex;
  align-items: flex-start; gap: 14px; box-shadow: var(--prc-shadow);
}
.prc-fe-dj-avatar {
  width: 48px; height: 48px; border-radius: 12px; flex-shrink: 0;
  background: linear-gradient(135deg, #8b5cf6, #6366f1);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 20px;
}
.prc-fe-dj-info { flex: 1; min-width: 0; }
.prc-fe-dj-info strong { display: block; font-size: 14px; font-weight: 600; }
.prc-fe-dj-info code { font-size: 11px; color: var(--prc-muted); background: #f1f5f9; padding: 1px 5px; border-radius: 4px; }
.prc-fe-dj-info small { display: block; font-size: 11px; color: var(--prc-muted); margin-top: 4px; }
.prc-dj-conn-mini { font-size: 10px; color: var(--prc-muted); margin-top: 4px; }
.prc-fe-dj-status { flex-shrink: 0; }
.prc-fe-dj-actions { display: flex; gap: 6px; flex-direction: column; }

/* DJ Connection Card */
.prc-dj-connection-card .prc-fe-card-body { padding: 0 16px 16px; }
.prc-dj-conn-grid { display: flex; flex-direction: column; gap: 0; padding: 4px 0; }
.prc-dj-conn-row {
  display: flex; align-items: center; gap: 12px; padding: 10px 16px;
  border-bottom: 1px solid var(--prc-border); font-size: 13px;
}
.prc-dj-conn-row strong { min-width: 80px; color: var(--prc-muted); font-size: 11px; text-transform: uppercase; letter-spacing: .5px; }
.prc-dj-conn-row code { flex: 1; background: #f1f5f9; padding: 3px 8px; border-radius: 5px; font-size: 12px; }
.prc-dj-sw-list { padding-top: 12px; border-top: 1px solid var(--prc-border); margin-top: 8px; }
.prc-dj-sw-row { display: flex; align-items: center; gap: 10px; padding: 6px 0; font-size: 12px; color: var(--prc-muted); }
.prc-dj-sw-logo { width: 24px; height: 24px; object-fit: contain; }
.prc-dj-sw-icon { font-size: 18px; width: 24px; text-align: center; }

/* ── Week Calendar ───────────────────────────────────────────────── */
.prc-fe-week-grid { display: grid; grid-template-columns: repeat(7,1fr); gap: 0; border: 1px solid var(--prc-border); border-radius: 8px; overflow: hidden; }
.prc-fe-week-col { border-right: 1px solid var(--prc-border); min-height: 120px; }
.prc-fe-week-col:last-child { border-right: none; }
.prc-fe-week-day { padding: 8px; font-size: 11px; font-weight: 700; text-align: center; background: #f8fafc; border-bottom: 1px solid var(--prc-border); color: var(--prc-muted); text-transform: uppercase; letter-spacing: .5px; }
.prc-fe-week-empty { padding: 8px; text-align: center; color: var(--prc-border); font-size: 18px; }
.prc-fe-week-event { margin: 4px; padding: 4px 6px; border-radius: 5px; font-size: 10px; line-height: 1.3; word-break: break-word; }
.prc-fe-event-pl { background: var(--prc-accent-lt); color: var(--prc-accent); }
.prc-fe-event-dj { background: #fce7f3; color: #9d174d; }

/* ── Info Banner ─────────────────────────────────────────────────── */
.prc-fe-info-banner {
  background: #eef2ff; border: 1px solid #c7d2fe; border-radius: 8px;
  padding: 12px 16px; font-size: 13px; color: #4338ca; margin-bottom: 14px;
  display: flex; align-items: center; gap: 10px;
}

/* ── Large empty state ───────────────────────────────────────────── */
.prc-fe-empty {
  text-align: center; padding: 40px 20px; color: var(--prc-muted);
  font-size: 14px; line-height: 1.7;
}
.prc-fe-empty i { display: block; font-size: 32px; margin-bottom: 10px; opacity: .4; }

/* ── Badge blue ───────────────────────────────────────────────────── */
.prc-fe-badge-blue { background: #e0e7ff; color: #4338ca; }

/* ── Button sizes ─────────────────────────────────────────────────── */
.prc-fe-btn-xs { padding: 3px 8px; font-size: 11px; }

/* ── Card body padding ────────────────────────────────────────────── */
.prc-fe-card-body { padding: 12px 16px; }

/* ── Media table improvements ──────────────────────────────────── */
.prc-fe-media-table th, .prc-fe-media-table td { padding: 10px 12px; }
.prc-fe-music-icon { color: var(--prc-accent); margin-right: 6px; }
.prc-fe-folder-icon { color: var(--prc-warning); margin-right: 6px; }

/* ── Upload progress (media) ─────────────────────────────────────── */
.prc-fe-upload-progress { padding: 12px 16px; }
.prc-fe-upload-row { display: flex; align-items: center; gap: 10px; font-size: 12px; margin-bottom: 6px; }
.prc-fe-upload-name { flex: 1; overflow: hidden; text-overflow: ellipsis; }
.prc-fe-upload-bar-wrap { flex: 1; max-width: 200px; }
.prc-fe-upload-status { min-width: 32px; text-align: right; font-weight: 600; }

/* Responsive adjustments */
@media (max-width: 768px) {
  .prc-fe-playlists-grid { grid-template-columns: 1fr; }
  .prc-fe-djs-grid { grid-template-columns: 1fr; }
  .prc-fe-week-grid { grid-template-columns: repeat(4,1fr); }
  .prc-fe-week-col:nth-child(n+5) { display: none; }
  .prc-pl-tabs { overflow-x: auto; }
}

/* ═══════════════════════════════════════════════════════════════
   NOW PLAYING WIDGET
═══════════════════════════════════════════════════════════════ */
.prc-np-widget {
  margin-top: 16px;
  border-top: 1px solid var(--prc-border, #e2e8f0);
  padding-top: 14px;
}

/* — Current track — */
.prc-np-current {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.prc-np-art-wrap {
  flex-shrink: 0;
  width: 54px;
  height: 54px;
  border-radius: 8px;
  overflow: hidden;
  background: var(--prc-grad);
  display: flex;
  align-items: center;
  justify-content: center;
}
.prc-np-art { width: 54px; height: 54px; object-fit: cover; border-radius: 8px; }
.prc-np-art-ph { color: #fff; font-size: 20px; }

.prc-np-info { flex: 1; min-width: 0; }

.prc-np-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #22c55e;
  margin-bottom: 3px;
}
.prc-np-dot-live {
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #22c55e;
  animation: prc-blink 1.4s ease-in-out infinite;
}
@keyframes prc-blink { 0%,100%{opacity:1} 50%{opacity:.3} }

.prc-np-song-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--prc-text, #1e1b4b);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}
.prc-np-song-artist {
  font-size: 12px;
  color: var(--prc-muted, #64748b);
  margin-bottom: 6px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.prc-np-progress-wrap { margin-top: 4px; }
.prc-np-progress-bar {
  height: 4px;
  background: #e2e8f0;
  border-radius: 4px;
  overflow: hidden;
  margin-bottom: 3px;
}
.prc-np-progress-fill {
  height: 100%;
  background: var(--prc-grad);
  border-radius: 4px;
  transition: width .8s linear;
  width: 0%;
}
.prc-np-times {
  display: flex;
  justify-content: space-between;
  font-size: 10px;
  color: var(--prc-muted, #94a3b8);
}

/* — Skip button — */
.prc-np-skip-btn {
  flex-shrink: 0;
  background: #f1f5f9;
  border: none;
  border-radius: 50%;
  width: 38px; height: 38px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  color: #475569;
  font-size: 15px;
  transition: background .2s, color .2s, transform .15s;
  margin-top: 4px;
}
.prc-np-skip-btn:hover { background: var(--prc-accent); color: #fff; transform: scale(1.08); }
.prc-np-skip-btn:active { transform: scale(.95); }
.prc-np-skip-btn:disabled { opacity: .5; cursor: not-allowed; }

/* — Queue — */
.prc-np-queue-wrap {
  margin-top: 14px;
  border-top: 1px solid #f1f5f9;
  padding-top: 10px;
}
.prc-np-queue-header {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--prc-muted, #94a3b8);
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.prc-np-queue-list { display: flex; flex-direction: column; gap: 4px; }

.prc-np-queue-item {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 6px 8px;
  border-radius: 7px;
  background: #f8fafc;
  transition: background .15s;
}
.prc-np-queue-item:first-child { background: var(--prc-accent-lt); }
.prc-np-queue-item:hover { background: #f1f5f9; }

.prc-np-queue-num {
  font-size: 11px;
  font-weight: 700;
  color: #cbd5e1;
  width: 16px;
  text-align: center;
  flex-shrink: 0;
}
.prc-np-queue-item:first-child .prc-np-queue-num { color: var(--prc-accent); }

.prc-np-queue-art {
  width: 30px; height: 30px;
  border-radius: 5px;
  object-fit: cover;
  flex-shrink: 0;
}
.prc-np-queue-art-ph {
  width: 30px; height: 30px;
  border-radius: 5px;
  background: linear-gradient(135deg,var(--prc-accent-lt),#ede9fe);
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; color: var(--prc-accent-bd);
  flex-shrink: 0;
}

.prc-np-queue-info {
  flex: 1; min-width: 0;
  display: flex; flex-direction: column; gap: 1px;
}
.prc-np-queue-title {
  font-size: 12px; font-weight: 600;
  color: var(--prc-text,#1e1b4b);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.prc-np-queue-artist {
  font-size: 10px; color: var(--prc-muted,#94a3b8);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.prc-np-queue-dur {
  font-size: 10px; color: #94a3b8; flex-shrink: 0;
}

.prc-np-queue-empty {
  font-size: 12px; color: #94a3b8;
  text-align: center; padding: 10px 0;
}

/* ── Storage badge ────────────────────────────────────────────── */
.prc-media-storage-badge {
  display: flex; align-items: center; gap: 6px;
  background: #f8fafc; border: 1px solid #e2e8f0;
  border-radius: 20px; padding: 4px 12px;
  font-size: 12px; font-weight: 600; color: #475569;
}
.prc-media-storage-card { padding: 14px 20px; }
.prc-media-storage-row { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 4px; }
.prc-media-storage-limit { font-size: 12px; color: #94a3b8; }

/* ── Dropzone ─────────────────────────────────────────────────── */
.prc-media-dropzone {
  border: 2px dashed #cbd5e1; border-radius: 12px;
  background: #f8fafc; margin-bottom: 16px;
  transition: border-color .2s, background .2s;
  cursor: pointer;
}
.prc-media-dropzone:hover, .prc-media-dropzone-active {
  border-color: var(--prc-accent); background: var(--prc-accent-lt);
}
.prc-media-dropzone-inner {
  display: flex; flex-direction: column; align-items: center;
  gap: 8px; padding: 28px 20px;
}
.prc-media-dropzone-icon { font-size: 36px; color: #a5b4fc; }
.prc-media-dropzone-active .prc-media-dropzone-icon { color: var(--prc-accent); }
.prc-media-dropzone-text {
  display: flex; align-items: center; gap: 10px;
  font-size: 14px; font-weight: 600; color: #475569; flex-wrap: wrap; justify-content: center;
}
.prc-media-dropzone-text span { font-weight: 400; color: #94a3b8; }
.prc-media-dropzone-hint { font-size: 11px; color: #94a3b8; }

/* ── Upload progress ──────────────────────────────────────────── */
.prc-media-upload-progress { margin-bottom: 16px; }
.prc-media-upload-header {
  font-size: 13px; font-weight: 700; color: #475569;
  margin-bottom: 10px; display: flex; justify-content: space-between; align-items: center;
}
.prc-media-up-row {
  display: flex; align-items: center; gap: 10px;
  padding: 6px 0; border-bottom: 1px solid #f1f5f9;
}
.prc-media-up-row:last-child { border-bottom: none; }
.prc-media-up-icon { color: #6366f1; flex-shrink: 0; }
.prc-media-up-info { flex: 1; min-width: 0; }
.prc-media-up-name { display: block; font-size: 12px; font-weight: 600; color: #334155; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 3px; }
.prc-media-up-bar { height: 4px !important; border-radius: 4px; }
.prc-media-up-status { font-size: 11px; font-weight: 700; flex-shrink: 0; min-width: 28px; text-align: right; }

/* ── Toolbar ──────────────────────────────────────────────────── */
.prc-media-toolbar { padding-bottom: 12px; }
.prc-media-toolbar-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; flex-wrap: wrap; gap: 8px; }
.prc-media-search-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.prc-media-search-wrap { position: relative; flex: 1; min-width: 200px; }
.prc-media-search-icon { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: #94a3b8; font-size: 12px; pointer-events: none; }
.prc-media-search-input { padding-left: 30px !important; }

/* ── View toggle ──────────────────────────────────────────────── */
.prc-media-view-toggle { display: flex; gap: 2px; background: #f1f5f9; border-radius: 8px; padding: 2px; }
.prc-media-view-btn {
  background: none; border: none; border-radius: 6px;
  width: 30px; height: 28px; cursor: pointer;
  color: #94a3b8; font-size: 13px; display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s;
}
.prc-media-view-btn.prc-media-view-active { background: #fff; color: #6366f1; box-shadow: 0 1px 3px rgba(0,0,0,.08); }

/* ── List info ────────────────────────────────────────────────── */
.prc-media-list-info { font-size: 12px; color: #94a3b8; padding: 6px 0 10px; border-bottom: 1px solid #f1f5f9; margin-bottom: 4px; }

/* ── Table médias ─────────────────────────────────────────────── */
.prc-fe-media-table td { vertical-align: middle; }
.prc-fe-media-name { display: flex; align-items: center; gap: 10px; max-width: 340px; }
.prc-fe-music-icon { color: #6366f1; font-size: 14px; flex-shrink: 0; }
.prc-media-file-info { display: flex; flex-direction: column; min-width: 0; }
.prc-media-file-title { font-size: 13px; font-weight: 600; color: #1e1b4b; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 260px; }
.prc-media-file-artist { font-size: 11px; color: #64748b; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.prc-media-file-path { font-size: 10px; color: #94a3b8; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 260px; }

.prc-media-pl-cell { max-width: 200px; }
.prc-media-pl-badge {
  display: inline-block; background: var(--prc-accent-lt); color: var(--prc-accent);
  border: 1px solid var(--prc-accent-bd); border-radius: 4px;
  font-size: 10px; font-weight: 600; padding: 1px 6px; margin: 1px 2px 1px 0;
  white-space: nowrap; max-width: 120px; overflow: hidden; text-overflow: ellipsis;
}
.prc-media-no-pl { color: #cbd5e1; font-size: 12px; }

/* ── Vue grille ───────────────────────────────────────────────── */
.prc-media-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 12px; padding: 4px;
}
.prc-media-grid-folder {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 20px 12px; border-radius: 10px; background: #f8fafc;
  border: 1px solid #e2e8f0; cursor: pointer; font-size: 12px;
  font-weight: 600; color: #475569; text-align: center;
  transition: background .15s;
}
.prc-media-grid-folder:hover { background: #eef2ff; border-color: #a5b4fc; }
.prc-media-grid-folder i { font-size: 28px; color: #fbbf24; }
.prc-media-grid-card {
  position: relative; border-radius: 10px; background: #fff;
  border: 1px solid #e2e8f0; overflow: hidden; padding: 10px;
  transition: box-shadow .15s, border-color .15s;
}
.prc-media-grid-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,.08); border-color: #a5b4fc; }
.prc-media-grid-art {
  height: 80px; background: linear-gradient(135deg,var(--prc-accent-lt),#ede9fe);
  border-radius: 8px; display: flex; align-items: center; justify-content: center;
  font-size: 28px; color: var(--prc-accent-bd); margin-bottom: 8px;
}
.prc-media-grid-info { padding: 0 2px; }
.prc-media-grid-title { font-size: 12px; font-weight: 700; color: #1e1b4b; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 2px; }
.prc-media-grid-artist { font-size: 10px; color: #64748b; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.prc-media-grid-dur { font-size: 10px; color: #94a3b8; margin-top: 4px; }
.prc-media-grid-actions {
  display: flex; gap: 4px; margin-top: 8px; padding-top: 8px;
  border-top: 1px solid #f1f5f9; justify-content: flex-end;
}

/* ── Pagination ───────────────────────────────────────────────── */
.prc-media-pagination {
  display: flex; align-items: center; justify-content: center;
  gap: 12px; padding: 12px 0 4px;
  border-top: 1px solid #f1f5f9; margin-top: 8px;
}
#prc-media-page-info { font-size: 13px; color: #64748b; font-weight: 600; }

/* ── Bulk bar ─────────────────────────────────────────────────── */
.prc-media-bulk-bar {
  position: sticky; bottom: 16px; z-index: 50;
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 10px;
  background: #1e1b4b; color: #fff; border-radius: 12px;
  padding: 12px 20px; box-shadow: 0 8px 24px rgba(0,0,0,.25);
  margin-top: 12px; animation: prc-slideup .2s ease;
}
@keyframes prc-slideup { from{transform:translateY(10px);opacity:0} to{transform:translateY(0);opacity:1} }
.prc-media-bulk-left { display: flex; align-items: center; gap: 10px; font-size: 13px; font-weight: 600; }
.prc-media-bulk-deselect {
  background: rgba(255,255,255,.15); border: none; color: #fff;
  border-radius: 6px; padding: 3px 10px; font-size: 11px; cursor: pointer;
  transition: background .15s;
}
.prc-media-bulk-deselect:hover { background: rgba(255,255,255,.25); }
.prc-media-bulk-right { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.prc-media-bulk-right .prc-fe-select-sm { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.2); color: #fff; }

/* ── Modal assignation ────────────────────────────────────────── */
.prc-assign-file-info {
  background: #f8fafc; border-radius: 8px; padding: 10px 14px;
  margin-bottom: 14px; border: 1px solid #e2e8f0;
}
.prc-assign-file-name { font-size: 13px; font-weight: 600; color: #334155; display: flex; align-items: center; gap: 8px; }
.prc-assign-pl-items { display: flex; flex-direction: column; gap: 6px; max-height: 320px; overflow-y: auto; }
.prc-assign-pl-item {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 10px 12px; border-radius: 8px; background: #f8fafc; border: 1px solid #e2e8f0;
  transition: background .15s;
}
.prc-assign-pl-item:hover { background: #f1f5f9; }
.prc-assign-pl-name { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; color: #334155; flex: 1; min-width: 0; }
.prc-assign-pl-name i { color: #6366f1; flex-shrink: 0; }
.prc-assign-toggle-btn {
  flex-shrink: 0; border: none; border-radius: 6px;
  padding: 5px 12px; font-size: 12px; font-weight: 600;
  cursor: pointer; display: flex; align-items: center; gap: 5px; transition: background .15s, color .15s;
}
.prc-assign-in { background: #fee2e2; color: #dc2626; }
.prc-assign-in:hover { background: #fca5a5; }
.prc-assign-out { background: #dcfce7; color: #16a34a; }
.prc-assign-out:hover { background: #86efac; }
.prc-assign-toggle-btn:disabled { opacity: .6; cursor: not-allowed; }

/* ── Responsive ───────────────────────────────────────────────── */
@media (max-width: 640px) {
  .prc-media-search-row { flex-direction: column; }
  .prc-media-search-wrap { min-width: 100%; }
  .prc-media-bulk-bar { flex-direction: column; align-items: flex-start; }
  .prc-media-grid { grid-template-columns: repeat(auto-fill, minmax(130px,1fr)); }
  .prc-media-file-title, .prc-media-file-path { max-width: 160px; }
}
/* ═══════════════════════════════════════════════════════════════
   WIDGET PLANIFIÉ (dashboard) — classes prc-dsched-*
   Séparées des classes prc-sched-* de la section Playlists
═══════════════════════════════════════════════════════════════ */
.prc-dsched-card { margin-top:16px }

.prc-dsched-legend {
  display:flex;gap:16px;align-items:center;flex-wrap:wrap;
  padding:8px 12px;background:#f8fafc;
  border-radius:8px;border:1px solid #f1f5f9;margin-bottom:14px;
}
.prc-dsched-legend-item {
  display:flex;align-items:center;gap:5px;
  font-size:11px;color:#64748b;font-weight:600;
}
.prc-dsched-dot { width:10px;height:10px;border-radius:50%;flex-shrink:0 }
.prc-dsched-dot-active { background:#22c55e }

/* Grille 7 colonnes */
.prc-dsched-grid {
  display:grid;grid-template-columns:repeat(7,1fr);gap:6px;min-height:100px;
}
.prc-dsched-col {
  display:flex;flex-direction:column;border-radius:10px;
  border:1px solid #f1f5f9;background:#fafafa;min-height:90px;overflow:hidden;
}
.prc-dsched-col-today { border-color:var(--prc-accent-bd);background:var(--prc-accent-lt) }
.prc-dsched-col-header {
  padding:5px 6px;background:#f1f5f9;border-bottom:1px solid #e2e8f0;text-align:center;
}
.prc-dsched-col-today .prc-dsched-col-header { background:var(--prc-accent-lt);border-color:var(--prc-accent-bd) }
.prc-dsched-day-label {
  font-size:11px;font-weight:700;color:#64748b;
  display:flex;align-items:center;justify-content:center;gap:4px;
}
.prc-dsched-today-label { color:var(--prc-accent) }
.prc-dsched-today-dot { width:5px;height:5px;border-radius:50%;background:var(--prc-accent);display:inline-block }
.prc-dsched-col-items { flex:1;padding:4px;display:flex;flex-direction:column;gap:3px }
.prc-dsched-col-empty {
  text-align:center;color:#e2e8f0;font-size:16px;
  flex:1;display:flex;align-items:center;justify-content:center;
}

/* Item */
.prc-dsched-item {
  border-radius:6px;padding:4px 6px;
  border-left:3px solid var(--prc-accent);
  background:var(--prc-accent-lt);
  cursor:default;transition:opacity .15s;
}
.prc-dsched-item.prc-dsched-type-dj {
  border-left-color:#8b5cf6;background:#f5f3ff;
}
.prc-dsched-item.prc-dsched-now {
  border-left-width:4px;box-shadow:0 1px 6px rgba(99,102,241,.22);
}
.prc-dsched-item.prc-dsched-inactive { opacity:.45 }
.prc-dsched-item-top { display:flex;align-items:flex-start;gap:3px;margin-bottom:2px }
.prc-dsched-item-icon { font-size:9px;margin-top:2px;flex-shrink:0;color:#6366f1 }
.prc-dsched-item.prc-dsched-type-dj .prc-dsched-item-icon { color:#8b5cf6 }
.prc-dsched-item-name {
  font-size:10px;font-weight:700;color:#1e1b4b;line-height:1.3;
  overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
}
.prc-dsched-item-time { font-size:9px;color:#64748b;font-weight:600 }
.prc-dsched-now-badge {
  display:inline-flex;align-items:center;gap:2px;
  background:#22c55e;color:#fff;font-size:8px;font-weight:700;
  padding:1px 4px;border-radius:3px;margin-top:2px;
  animation:dsched-pulse 1.4s ease-in-out infinite;
}
@keyframes dsched-pulse { 0%,100%{opacity:1} 50%{opacity:.6} }
.prc-dsched-inactive-badge { font-size:9px;color:#94a3b8;font-weight:600;margin-top:1px;display:block }

/* Vue liste */
.prc-dsched-list-inner { display:flex;flex-direction:column;gap:5px }
.prc-dsched-list-row {
  display:flex;align-items:center;gap:10px;
  padding:8px 12px;border-radius:8px;
  background:#f8fafc;border:1px solid #f1f5f9;
}
.prc-dsched-list-row.prc-dsched-now { background:#f0fdf4;border-color:#bbf7d0 }
.prc-dsched-list-row.prc-dsched-inactive { opacity:.5 }
.prc-dsched-list-color { width:3px;border-radius:2px;align-self:stretch;flex-shrink:0 }
.prc-dsched-list-icon { flex-shrink:0;width:18px;text-align:center }
.prc-dsched-list-info { flex:1;min-width:0 }
.prc-dsched-list-name { font-size:13px;font-weight:600;color:#1e1b4b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis }
.prc-dsched-list-meta { font-size:11px;color:#94a3b8;margin-top:1px }
.prc-dsched-list-time { font-size:11px;font-weight:600;color:#475569;text-align:right;line-height:1.5;flex-shrink:0;min-width:44px }
.prc-dsched-list-status { flex-shrink:0 }

/* Toggle */
.prc-dsched-view-btn {
  background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;
  padding:5px 14px;font-size:12px;font-weight:600;color:#64748b;cursor:pointer;
  display:inline-flex;align-items:center;gap:5px;transition:background .15s,color .15s;
}
.prc-dsched-view-btn:hover { background:#e2e8f0 }
.prc-dsched-view-active { background:var(--prc-accent)!important;color:#fff!important;border-color:var(--prc-accent)!important }

/* Vide / chargement */
.prc-dsched-loading,.prc-dsched-empty {
  text-align:center;padding:20px;color:#94a3b8;font-size:13px;line-height:1.6;
}

/* Responsive */
@media (max-width:900px) {
  .prc-dsched-grid { grid-template-columns:repeat(4,1fr) }
}
@media (max-width:600px) {
  .prc-dsched-grid { display:none }
}