/* ── Split view ── */
.split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  flex: 1;
  min-height: 0;
}
.split-media {
  background: var(--dark);
  display: flex;
  align-items: stretch;
  position: relative;
  min-height: 300px;
}
.split-media iframe {
  width: 100%;
  height: 100%;
  min-height: 300px;
  border: none;
  display: block;
}
.split-info {
  background: var(--white);
  border-left: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
}

/* ── Media placeholder ── */
.media-ph {
  aspect-ratio: 9/14;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  background: linear-gradient(160deg, #0E2A5E, #1a3a7a);
}
.media-ph a {
  width: 60px; height: 60px;
  border-radius: 50%;
  background: rgba(255,255,255,.15);
  border: 2px solid rgba(255,255,255,.35);
  display: flex; align-items: center; justify-content: center;
  text-decoration: none;
  transition: background .15s, transform .15s;
}
.media-ph a:hover { background: rgba(255,255,255,.25); transform: scale(1.06); }
.triangle {
  width: 0; height: 0;
  border-top: 11px solid transparent;
  border-bottom: 11px solid transparent;
  border-left: 18px solid rgba(255,255,255,.88);
  margin-left: 4px;
}
.media-ph p { color: rgba(255,255,255,.45); font-size: 12px; text-align: center; padding: 0 1.5rem; }

/* ── Source badges ── */
.source-badge {
  position: absolute; top: 12px; left: 12px;
  font-size: 10px; font-weight: 700;
  padding: 3px 9px; border-radius: 4px;
  color: white; z-index: 2; letter-spacing: .3px;
  backdrop-filter: blur(4px);
}
.sb-youtube { background: rgba(200,0,0,.85); }
.sb-spotify { background: rgba(20,180,80,.9); color: #000; }
.sb-vimeo   { background: rgba(26,183,234,.85); }
.sb-overig  { background: rgba(55,122,255,.85); }

.art-counter {
  position: absolute; bottom: 12px; right: 12px;
  background: rgba(0,0,0,.55);
  color: rgba(255,255,255,.9);
  font-size: 11px; font-weight: 500;
  padding: 4px 10px; border-radius: 99px;
  backdrop-filter: blur(4px);
}

/* ── Info panel ── */
.info-panel {
  padding: 16px 18px 12px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  flex-shrink: 0;
}
.info-left { flex: 1; min-width: 0; }
.art-title {
  font-family: var(--fh);
  font-size: 1.1rem;
  color: var(--dark);
  line-height: 1.4;
  margin-bottom: 7px;
}
.art-meta { display: flex; align-items: center; gap: 7px; flex-wrap: wrap; }
.cat-tag {
  font-size: 10px; font-weight: 600;
  background: rgba(141,171,127,.15);
  color: #3d5e38;
  padding: 3px 10px; border-radius: 99px;
  border: 1px solid rgba(141,171,127,.25);
}
.btn-report {
  font-size: 11px; color: var(--muted);
  padding: 4px 7px; border-radius: 4px;
  transition: color .12s, background .12s;
  flex-shrink: 0;
}
.btn-report:hover { color: var(--danger); background: rgba(192,57,43,.06); }

/* ── Experience panel ── */
.exp-panel {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 0;
  min-height: 120px;
}
.exp-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px 8px;
  flex-shrink: 0;
}
.exp-label {
  font-size: 10px; font-weight: 700;
  color: var(--blue);
  text-transform: uppercase;
  letter-spacing: .8px;
}
.exp-nav { display: flex; align-items: center; gap: 6px; }
.exp-nav-btn {
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--dark);
  font-size: 15px;
  display: flex; align-items: center; justify-content: center;
  transition: all .12s;
}
.exp-nav-btn:hover:not(:disabled) {
  border-color: var(--blue);
  color: var(--blue);
  background: rgba(55,122,255,.05);
}
.exp-nav-btn:disabled { opacity: .3; cursor: default; }
.exp-cnt { font-size: 11px; color: var(--muted); min-width: 34px; text-align: center; }

.exp-body { padding: 4px 18px 14px; flex: 1; }
.exp-quote {
  font-family: var(--fh);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--text);
  line-height: 1.7;
  border-left: 3px solid var(--sage);
  padding: 8px 0 8px 14px;
  position: relative;
}
.exp-author { font-size: 11px; color: var(--muted); margin-top: 9px; padding-left: 17px; }
.btn-exp-report {
  font-size: 10px; color: var(--muted);
  padding: 3px 0 0 17px;
  display: block; transition: color .12s;
}
.btn-exp-report:hover { color: var(--danger); }

.dots { display: flex; gap: 5px; padding: 4px 18px 12px; }
.dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--border);
  transition: background .15s, transform .15s;
}
.dot.on { background: var(--blue); transform: scale(1.25); }

.no-exp {
  padding: 0 18px 16px;
  color: var(--muted);
  font-size: 13px;
  font-style: italic;
  line-height: 1.6;
}

/* ── States ── */
.loading-state {
  flex: 1; display: flex;
  align-items: center; justify-content: center; padding: 3rem;
}
.spinner {
  width: 32px; height: 32px;
  border: 3px solid var(--border);
  border-top-color: var(--blue);
  border-radius: 50%;
  animation: spin .7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

.empty-state {
  flex: 1; display: flex;
  flex-direction: column;
  align-items: center; justify-content: center;
  padding: 4rem 2rem; text-align: center; gap: 14px;
}
.empty-icon { font-size: 42px; opacity: .7; }
.empty-state h3 {
  font-family: var(--fh);
  color: var(--dark);
  font-size: 1.25rem;
}
.empty-state p { color: var(--muted); font-size: 13px; line-height: 1.65; max-width: 28ch; }

/* ── Config banner ── */
.cfg-banner {
  margin: 12px 16px;
  background: rgba(55,122,255,.06);
  border: 1px solid rgba(55,122,255,.16);
  border-radius: var(--r-md);
  padding: 10px 14px;
  font-size: 12px; color: var(--dark); line-height: 1.6;
}
.cfg-banner code {
  background: rgba(55,122,255,.1);
  padding: 1px 5px; border-radius: 3px;
  font-size: 11px; font-family: monospace;
}

/* ── Spotify player ── */
.media-spotify-wrap {
  width: 100%;
  height: 100%;
  min-height: 300px;
  background: #111;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2.5rem 1.5rem;
}
.media-spotify-wrap iframe {
  width: 100%;
  max-width: 500px;
  border-radius: 12px;
}

/* ════════════════════════════════════════
   RESPONSIVE — content
════════════════════════════════════════ */

/* Mobile (<768px) */
@media (max-width: 767px) {
  .split            { display: flex; flex-direction: column; }
  .split-media      { min-height: 0; }
  .split-media iframe { aspect-ratio: 9/14; height: auto; min-height: 0; }
  .split-info       { border-left: none; border-top: 1px solid var(--border); }
  .media-ph         { aspect-ratio: 9/14; }
}

/* Tablet (768–1023px) */
@media (min-width: 768px) and (max-width: 1023px) {
  .split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    flex: 1;
  }
  .split-media iframe { aspect-ratio: auto; height: 100%; min-height: 400px; }
  .media-ph           { aspect-ratio: 16/9; min-height: 400px; }
}

/* Desktop (≥1024px) */
@media (min-width: 1024px) {
  .split {
    display: grid;
    grid-template-columns: 1fr minmax(300px, 400px);
    flex: 1;
  }
  .split-media iframe { aspect-ratio: auto; height: 100%; min-height: 500px; }
  .media-ph           { aspect-ratio: auto; min-height: 500px; }
  .split-info {
    max-height: calc(100dvh - 130px);
    overflow-y: auto;
  }
}
