/* ==========================================================================
   FILM DETAIL — Performance node full-page layout.
   Single column: player, title, access, anchor nav, content sections.
   ========================================================================== */

/* ---------- VIDEO PLAYER AREA ---------- */

.otb-film__player {
  background: var(--color-dark);
  margin-top: var(--spacing-lg);
  margin-bottom: var(--spacing-lg);
}

/* ---------- TITLE BLOCK ---------- */

.otb-film__header {
  margin-bottom: var(--spacing-md);
}

.otb-film__title {
  font-size: var(--font-size-2xl);
  margin: 0 0 var(--space-2) 0;
}

.otb-film__artist {
  font-size: var(--font-size-lg);
  color: var(--color-primary);
  margin: 0 0 var(--space-2) 0;
}

.otb-film__artist a {
  color: inherit;
}

.otb-film__subtitle {
  font-size: var(--font-size-md);
  color: var(--color-gray-600);
  font-style: italic;
  margin: 0;
}

/* ---------- ACCESS / PURCHASE SECTION ---------- */

.otb-film__access {
  margin-bottom: var(--spacing-lg);
}

.otb-film__purchase {
  background: var(--color-bg-surface);
  border-radius: var(--border-radius-md);
  padding: var(--spacing-md);
}

.otb-film__purchase-options {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
}

.otb-film__purchase-option {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg-card);
  border-radius: var(--border-radius-sm);
  border: var(--border-width-thin) solid var(--border-color-default);
}

.otb-film__purchase-label {
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-xs);
}

.otb-film__purchase-price {
  color: var(--color-primary);
  font-weight: var(--font-weight-bold);
}

.otb-film__subscribe-btn {
  white-space: nowrap;
}

.otb-film__access-info {
  font-size: var(--font-size-xs);
  color: var(--color-gray-600);
  margin: var(--space-3) 0 0;
}

/* Educational access banner */
.otb-film__edu-access {
  background: var(--color-status-info-bg);
  border: 1px solid var(--color-status-info-border);
  border-radius: var(--border-radius-md);
  padding: var(--spacing-md);
  font-size: var(--font-size-sm);
  color: var(--color-status-info-text);
}

.otb-film__edu-access strong {
  display: block;
  margin-bottom: var(--space-1);
}

/* Subscriber access banner */
.otb-film__sub-access {
  background: var(--color-status-success-bg);
  border: 1px solid var(--color-status-success-border);
  border-radius: var(--border-radius-md);
  padding: var(--spacing-md);
  font-size: var(--font-size-sm);
  color: var(--color-status-success-text);
}

.otb-film__sub-access strong {
  display: block;
  margin-bottom: var(--space-1);
}

@media (max-width: 670px) {
  .otb-film__purchase-options {
    flex-direction: column;
    align-items: stretch;
  }
}

/* ---------- FILM / TRAILER TOGGLE (authorized users) ---------- */

.otb-film__viewer-toggle {
  display: flex;
  gap: 0;
  border-radius: var(--border-radius-md);
  overflow: hidden;
  border: var(--border-width-thin) solid var(--border-color-default);
  width: fit-content;
}

.otb-film__toggle-btn {
  padding: var(--space-3) var(--spacing-md);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border: none;
  cursor: pointer;
  background: var(--color-bg-surface);
  color: var(--color-gray-600);
  transition: background 0.15s ease, color 0.15s ease;
}

.otb-film__toggle-btn:hover {
  background: var(--color-gray-200);
  color: var(--color-text-heading);
}

.otb-film__toggle-btn.is-active {
  background: var(--color-primary-btn);
  color: var(--color-white);
}

/* ---------- ANCHOR NAVIGATION ---------- */

.otb-film__nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2) var(--spacing-sm);
  padding-bottom: var(--spacing-md);
  border-bottom: var(--border-width-thin) solid var(--border-color-default);
  margin-bottom: var(--spacing-lg);
}

.otb-film__nav a {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
  text-decoration: none;
}

.otb-film__nav a:hover {
  color: var(--color-primary);
}

/* ---------- CONTENT SECTIONS ---------- */

.otb-film__section {
  margin-bottom: var(--spacing-xl);
  padding-top: var(--spacing-lg);
  border-top: var(--border-width-thin) solid var(--border-color-default);
}

.otb-film__section:first-of-type {
  border-top: none;
  padding-top: 0;
}

.otb-film__section-title {
  font-size: var(--font-size-lg);
  text-transform: uppercase;
  color: var(--color-text-heading);
  margin: 0 0 var(--spacing-md) 0;
}

/* ---------- METADATA ---------- */

.otb-film__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-sm) var(--spacing-lg);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  margin-bottom: var(--spacing-md);
}

.otb-film__meta dt {
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.otb-film__meta dd {
  margin: 0;
}

/* ---------- CAST & CREDITS TABLE ---------- */

.otb-film__section table {
  width: 100%;
  border-collapse: collapse;
}

.otb-film__section table th,
.otb-film__section table td {
  padding: var(--space-2) var(--space-3);
  font-size: var(--font-size-xs);
  vertical-align: top;
  border-bottom: var(--border-width-thin) solid var(--border-color-default);
}

.otb-film__section table th {
  text-align: left;
  font-weight: var(--font-weight-medium);
  color: var(--color-text-muted);
  white-space: nowrap;
  width: 1%;
}

.otb-film__section table td {
  text-align: right;
  color: var(--color-text-heading);
}

@media (max-width: 768px) {
  .otb-film__section table,
  .otb-film__section table thead,
  .otb-film__section table tbody,
  .otb-film__section table tr,
  .otb-film__section table th,
  .otb-film__section table td {
    display: block;
  }

  .otb-film__section table th {
    text-align: left;
    width: auto;
    padding-bottom: 0;
    border-bottom: none;
    color: var(--color-text-muted);
  }

  .otb-film__section table td {
    text-align: left;
    padding-top: 0;
    padding-bottom: var(--spacing-sm);
  }
}

/* ---------- CATEGORIES ---------- */

.otb-film__categories {
  font-size: var(--font-size-xs);
  color: var(--color-gray-600);
  margin-bottom: var(--spacing-lg);
}

/* ---------- ABOUT THE ARTIST ---------- */

.otb-film__artist-content {
  overflow: hidden;
}

.otb-film__artist-portrait {
  float: right;
  width: 200px;
  margin: 0 0 var(--spacing-sm) var(--spacing-lg);
  border-radius: var(--border-radius-sm);
  overflow: hidden;
}

.otb-film__artist-portrait img {
  display: block;
  width: 100%;
  height: auto;
}

.otb-film__artist-text h3 {
  margin-top: 0;
  color: var(--color-primary);
}

.otb-film__artist-text h3 a {
  color: inherit;
}

@media (max-width: 480px) {
  .otb-film__artist-portrait {
    float: none;
    width: 100%;
    max-width: 250px;
    margin: 0 0 var(--spacing-sm) 0;
  }
}

/* ---------- EXTRAS ---------- */

.otb-extras__player {
  position: relative;
  background: var(--color-dark);
  border-radius: var(--border-radius-sm);
  overflow: hidden;
  aspect-ratio: 16 / 9;
}

.otb-extras__player mux-player {
  display: block;
  width: 100%;
  height: 100%;
}

/* Audio overlay — visible only when the active extra is audio */
.otb-extras__audio-overlay {
  position: absolute;
  inset: 0 0 48px 0; /* leave room for Mux controls bar at bottom */
  display: none;
  align-items: center;
  justify-content: center;
  color: var(--color-gray-600);
  pointer-events: none;
}

.otb-extras--audio .otb-extras__audio-overlay {
  display: flex;
}

/* Tab list */
.otb-extras__tabs {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: var(--space-2);
}

.otb-extras__tab {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  text-align: left;
  border: none;
  border-bottom: var(--border-width-thin) solid var(--border-color-default);
  cursor: pointer;
  background: transparent;
  color: var(--color-text-muted);
  transition: background 0.15s ease, color 0.15s ease;
}

.otb-extras__tab:last-child {
  border-bottom: none;
}

.otb-extras__tab:hover {
  background: var(--color-bg-surface);
  color: var(--color-text-heading);
}

.otb-extras__tab.is-active {
  background: var(--color-bg-surface);
  color: var(--color-primary);
}

.otb-extras__tab-icon {
  flex-shrink: 0;
  opacity: 0.6;
}

.otb-extras__tab.is-active .otb-extras__tab-icon {
  opacity: 1;
}

/* ---------- RELATED FILMS ---------- */

.otb-film__related .otb-grid {
  margin-top: var(--spacing-md);
  margin-bottom: var(--spacing-lg);
}
