/* ============================================================
   MODAL — Signatories list
   ============================================================ */
.modal {
  position: fixed; inset: 0; z-index: 200;
  background: color-mix(in oklab, var(--void) 85%, transparent);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: none;
  align-items: flex-start; justify-content: center;
  padding: 80px 20px;
  overflow-y: auto;
}
.modal.open { display: flex; animation: fadein .4s var(--ease-out); }
@keyframes fadein { from { opacity: 0; } to { opacity: 1; } }

.modal-panel {
  background: var(--bg-2);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-xl);
  max-width: 880px; width: 100%;
  padding: 44px;
  position: relative;
  box-shadow: 0 40px 120px -30px rgba(0,0,0,0.8);
}
@media (max-width: 680px) { .modal-panel { padding: 28px; } }

.modal-close {
  position: absolute; top: 16px; right: 16px;
  width: 40px; height: 40px;
  background: transparent;
  border: 1px solid var(--line-strong);
  border-radius: 50%;
  color: var(--ink-dim);
  cursor: pointer;
  display: grid; place-items: center;
  transition: all .2s var(--ease-out);
}
.modal-close:hover { color: var(--r-red); border-color: var(--r-red); }
.modal-close svg { width: 16px; height: 16px; }

.sig-filters {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin: 20px 0 28px;
}
.sig-filter-btn {
  padding: 8px 14px;
  background: transparent;
  border: 1px solid var(--line-strong);
  color: var(--ink-dim);
  border-radius: 999px;
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all .2s var(--ease-out);
}
.sig-filter-btn:hover { color: var(--ink); border-color: var(--r-yellow); }
.sig-filter-btn.active {
  background: color-mix(in oklab, var(--r-orange) 22%, transparent);
  color: var(--r-yellow);
  border-color: var(--r-orange);
}

.sig-list {
  max-height: 60vh;
  overflow-y: auto;
  padding-right: 8px;
  margin-right: -8px;
}
.sig-list::-webkit-scrollbar { width: 6px; }
.sig-list::-webkit-scrollbar-track { background: transparent; }
.sig-list::-webkit-scrollbar-thumb { background: var(--line-strong); border-radius: 3px; }

.sig-row {
  padding: 16px 18px;
  border-top: 1px solid var(--line);
  transition: background .2s var(--ease-out);
}
.sig-row:first-child { border-top: none; }
.sig-row:hover { background: color-mix(in oklab, var(--surface) 60%, transparent); }
.sig-row-name {
  font-family: var(--font-display);
  font-size: 17px;
  color: var(--ink);
  margin-bottom: 4px;
}
.sig-row-meta {
  font-size: 13px;
  color: var(--ink-dim);
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.sig-row-flag { font-size: 16px; }
.sig-row-cat {
  display: inline-flex;
  padding: 3px 10px;
  border-radius: 999px;
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.sig-row-cat.cat-dj       { background: color-mix(in oklab, var(--r-orange) 16%, transparent); color: var(--r-orange); }
.sig-row-cat.cat-festival { background: color-mix(in oklab, var(--r-green) 16%, transparent);  color: var(--r-green); }
.sig-row-cat.cat-producer { background: color-mix(in oklab, var(--r-yellow) 16%, transparent); color: var(--r-yellow); }
.sig-row-cat.cat-dancer   { background: color-mix(in oklab, var(--r-cyan) 16%, transparent);   color: var(--r-cyan); }
.sig-row-why {
  margin-top: 8px;
  font-style: italic;
  color: var(--ink);
  font-size: 14px;
  line-height: 1.5;
  opacity: 0.9;
  white-space: pre-line;
}

.name-ribbon {
  display: grid;
  gap: 8px;
  overflow: hidden;
  padding: 14px 0 16px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  margin-top: 32px;
  font-family: var(--font-display);
  font-size: 20px;
  color: var(--ink-dim);
}
.name-ribbon-track {
  display: flex;
  align-items: center;
  gap: 18px;
  white-space: nowrap;
  animation: ribbon 180s linear infinite;
  will-change: transform;
}
.name-ribbon-track.is-reverse {
  animation-direction: reverse;
}
.name-ribbon-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 700;
  color: var(--ink-dim);
}
.name-ribbon-item.is-accent {
  color: color-mix(in oklab, var(--r-orange) 72%, var(--ink));
}
.name-ribbon-sep {
  color: color-mix(in oklab, var(--r-orange) 50%, var(--ink-soft));
}
@keyframes ribbon { to { transform: translateX(-50%); } }
