    .movie-page {
      --movie-page-bg: linear-gradient(180deg, rgba(245, 247, 251, 0.75) 0%, rgba(238, 242, 250, 0.85) 100%);
      --movie-surface: rgba(255, 255, 255, 0.94);
      --movie-surface-alt: rgba(249, 251, 255, 0.9);
      --movie-border: rgba(15, 23, 42, 0.08);
      --movie-text: #0f172a;
      --movie-muted: #4b5563;
      --movie-hero-bg: var(--movie-page-bg);
      --movie-shadow: 0 4px 8px rgba(15, 23, 42, 0.06),
                      0 12px 24px rgba(15, 23, 42, 0.08),
                      0 24px 48px rgba(15, 23, 42, 0.1);
      --movie-card-shadow: 0 2px 8px rgba(15, 23, 42, 0.04),
                           0 10px 20px rgba(15, 23, 42, 0.06),
                           0 20px 40px rgba(15, 23, 42, 0.08);
      --movie-poster-shadow: 0 6px 12px rgba(15, 23, 42, 0.1),
                             0 16px 32px rgba(15, 23, 42, 0.12),
                             0 28px 56px rgba(15, 23, 42, 0.14);
      --movie-panel-gradient: linear-gradient(135deg, rgba(255, 255, 255, 0.94) 0%, rgba(249, 251, 255, 0.98) 100%);
      --movie-matrix-bg: rgba(252, 253, 255, 0.96);
      display: grid;
      grid-template-columns: minmax(0, 3.2fr) minmax(240px, 0.9fr);
      grid-template-areas: "primary secondary";
      align-items: start;
      gap: 1.1rem;
      padding: 0;
      border: none;
      border-radius: 0;
      box-shadow: none;
      background: transparent;
      backdrop-filter: none;
    }

    .season-page {
      grid-auto-flow: row;
      grid-auto-columns: 0;
    }

    .dark .movie-page {
      --movie-page-bg: linear-gradient(180deg, rgba(38, 38, 38, 0.80) 0%, rgba(18, 20, 27, 0.88) 100%);
      --movie-surface: rgba(23, 26, 36, 0.95);
      --movie-surface-alt: rgba(28, 31, 44, 0.9);
      --movie-border: rgba(255, 255, 255, 0.08);
      --movie-text: #f8fafc;
      --movie-muted: rgba(248, 250, 252, 0.7);
      --movie-hero-bg: var(--movie-page-bg);
      --movie-shadow: 0 4px 8px rgba(0, 0, 0, 0.25),
                      0 12px 20px rgba(0, 0, 0, 0.3),
                      0 24px 48px rgba(0, 0, 0, 0.35);
      --movie-card-shadow: 0 2px 6px rgba(0, 0, 0, 0.2),
                           0 10px 20px rgba(0, 0, 0, 0.28),
                           0 18px 36px rgba(0, 0, 0, 0.35);
      --movie-poster-shadow: 0 6px 12px rgba(0, 0, 0, 0.3),
                             0 16px 28px rgba(0, 0, 0, 0.35),
                             0 24px 48px rgba(0, 0, 0, 0.4);
      --movie-panel-gradient: linear-gradient(135deg, rgba(38, 38, 38, 0.95) 0%, rgba(28, 31, 44, 0.97) 100%);
      --movie-matrix-bg: rgba(33, 35, 41, 0.97);
    }

    .movie-primary-column {
      grid-area: primary;
      display: flex;
      flex-direction: column;
      gap: 1.1rem;
      min-width: 0;
      align-self: start;
    }

    .movie-primary-column > .movie-hero__wrapper,
    .movie-primary-column > .movie-main,
    .movie-secondary-column > .movie-hero__scorecard,
    .movie-secondary-column > .movie-aside-card {
      align-self: stretch;
      width: 100%;
    }

    .movie-hero__wrapper {
      grid-area: hero;
      background: var(--movie-panel-gradient);
      border-radius: 1.1rem;
      border: 1px solid var(--movie-border);
      box-shadow: var(--movie-card-shadow);
      padding: 1.25rem;
      color: var(--movie-text);
      align-self: start;
      display: flex;
      gap: 1.25rem;
      transition: box-shadow 0.3s ease;
    }

    .mobile-score-badge {
      display: none;
    }

    .movie-secondary-column {
      grid-area: secondary;
      display: flex;
      flex-direction: column;
      gap: 1.1rem;
      min-width: 0;
      align-self: start;
    }


    .movie-hero__scorecard {
      grid-area: aside;
      background: var(--movie-panel-gradient);
      border-radius: 1.25rem;
      border: 1px solid var(--movie-border);
      box-shadow: var(--movie-card-shadow);
      padding: 1.25rem;
      padding-top: 1.75rem;
      color: var(--movie-text);
      align-self: start;
      height: auto;
      position: relative;
      display: flex;
      flex-direction: column;
      gap: 1rem;
      transition: box-shadow 0.3s ease;
    }

    .movie-tabs {
      background: var(--movie-panel-gradient);
      border-radius: 1.1rem;
      border: 1px solid var(--movie-border);
      box-shadow: var(--movie-card-shadow);
      padding: 0.85rem 1rem 1.1rem;
      color: var(--movie-text);
    }

    @media (max-width: 700px) {
      .movie-tabs-row > .column {
        padding-left: 0rem !important;
        padding-right: 0rem !important;
      }
    }

    /* .movie-main .movie-tabs {
      background: transparent;
      border: none;
      box-shadow: none;
      padding: 0;
    } */

    .movie-tabs__nav {
      display: flex;
      flex-wrap: wrap;
      gap: 1.1rem;
      border-bottom: 1px solid var(--movie-border);
      padding-bottom: 0.65rem;
      margin-bottom: 0.9rem;
    }

    .movie-tabs__tab {
      border: none;
      background: transparent;
      color: var(--movie-muted);
      padding: 0.2rem 0;
      border-radius: 0;
      font-size: 0.9rem;
      font-weight: 600;
      letter-spacing: 0.02em;
      cursor: pointer;
      position: relative;
      transition: color 0.2s ease;
    }

    .movie-tabs__tab:hover {
      color: var(--movie-text);
    }

    .movie-tabs__tab.is-active {
      color: var(--movie-text);
    }

    .dark .movie-tabs__tab.is-active {
      color: #e2e8f0;
    }

    .movie-tabs__tab.is-active::after {
      content: '';
      position: absolute;
      left: 0;
      right: 0;
      bottom: -0.65rem;
      height: 2px;
      background: currentColor;
      border-radius: 999px;
    }

    .movie-tabs__panel {
      display: none;
    }

    .movie-tabs__panel.is-active {
      display: block;
    }

    .movie-tab-section {
      margin-bottom: 1.2rem;
    }

    .movie-tab-section__title {
      font-size: 0.85rem;
      font-weight: 700;
      margin-bottom: 0.4rem;
      display: flex;
      align-items: center;
      gap: 0.5rem;
    }

    .movie-tab-section__title--ai svg {
      color: #6366f1;
    }

    .dark .movie-tab-section__title--ai svg {
      color: #a5b4fc;
    }

    .movie-tab-empty {
      padding: 1rem;
      border-radius: 0.8rem;
      border: 1px dashed var(--movie-border);
      color: var(--movie-muted);
      background: var(--movie-surface-alt);
      font-size: 0.9rem;
    }

    .related-lists {
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
      margin-top: 0.35rem;
    }

    .related-list-card {
      display: grid;
      grid-template-columns: 200px minmax(0, 1fr);
      gap: 0.85rem;
      align-items: center;
      padding: 0.7rem 0.8rem;
      border-radius: 0.85rem;
      border: 1px solid var(--movie-border);
      background: #f9fafc;
      transition: transform 180ms ease, box-shadow 180ms ease;
    }

    .dark .related-list-card {
      background: linear-gradient(175deg, rgba(34, 36, 45, 0.88), rgba(19, 22, 30, 0.96));
    }

    .related-list-card:hover {
      transform: translateY(-1px);
      box-shadow: var(--movie-card-shadow);
    }

    .related-list-posters {
      position: relative;
      width: 100%;
      height: 60px;
      display: block;
      overflow: visible;
    }

    .related-list-poster {
      position: absolute;
      top: 0;
      height: 100%;
      width: auto;
      object-fit: cover;
      border-radius: 0.4rem;
      box-shadow: 0 4px 10px rgba(15, 23, 42, 0.12);
      transition: transform 160ms ease, box-shadow 160ms ease;
      will-change: transform;
    }

    .dark .related-list-poster {
      box-shadow: 0 4px 10px rgba(0, 0, 0, 0.4);
    }

    .related-list-poster--1 { left: 0%; z-index: 5; width: 24%; }
    .related-list-poster--2 { left: 16%; z-index: 4; width: 24%; }
    .related-list-poster--3 { left: 32%; z-index: 3; width: 24%; }
    .related-list-poster--4 { left: 48%; z-index: 2; width: 24%; }
    .related-list-poster--5 { left: 64%; z-index: 1; width: 24%; }

    .related-list-poster:hover {
      transform: scale(1.05);
      box-shadow: 0 6px 14px rgba(15, 23, 42, 0.2);
      z-index: 10 !important;
    }

    .dark .related-list-poster:hover {
      box-shadow: 0 6px 14px rgba(0, 0, 0, 0.55);
    }

    .related-list-meta {
      display: flex;
      flex-direction: column;
      gap: 0.35rem;
      min-width: 0;
    }

    .related-list-meta__title a {
      color: var(--movie-text);
      font-weight: 700;
      font-size: 0.95rem;
      line-height: 1.2;
      display: inline-block;
    }

    .related-list-meta__title a:hover {
      color: #2c7be5;
    }

    .related-list-meta__row {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 0.35rem;
      font-size: 0.85rem;
      color: var(--movie-muted);
    }

    .related-list-meta__user {
      color: var(--movie-text);
      font-weight: 600;
    }

    .related-list-meta__user:hover {
      color: #2c7be5;
    }

    .related-list-meta__dot {
      opacity: 0.5;
    }

    .related-list-meta__likes {
      display: inline-flex;
      align-items: center;
      gap: 0.25rem;
    }

    @media (max-width: 700px) {
      .related-list-card {
        grid-template-columns: 1fr;
        align-items: start;
        padding: 0.75rem;
      }

      .related-list-posters {
        height: 64px;
      }

      .related-list-meta__row {
        gap: 0.25rem 0.6rem;
      }
    }

    .community-reviews__header {
      display: flex;
      justify-content: space-between;
      gap: 1rem;
      align-items: flex-start;
      margin-bottom: 1rem;
    }

    .community-reviews__header h3 {
      margin: 0;
      font-size: 1.1rem;
    }

    .community-reviews__header p {
      margin: 0.3rem 0 0;
      color: var(--movie-muted);
      font-size: 0.9rem;
    }

    .community-reviews__controls {
      display: flex;
      align-items: center;
      gap: 0.8rem;
      flex-wrap: wrap;
      justify-content: flex-end;
    }

    .community-reviews__filters {
      display: inline-flex;
      gap: 0.8rem;
      align-items: center;
    }

    .community-reviews__filter {
      border: none;
      background: transparent;
      color: var(--movie-muted);
      font-weight: 600;
      font-size: 0.85rem;
      letter-spacing: 0.02em;
      cursor: pointer;
      padding: 0;
      position: relative;
    }

    .community-reviews__filter.is-active {
      color: var(--movie-text);
    }

    .community-reviews__filter.is-active::after {
      content: '';
      position: absolute;
      left: 0;
      right: 0;
      bottom: -0.35rem;
      height: 2px;
      background: currentColor;
      border-radius: 999px;
    }

    .community-reviews__count {
      font-size: 0.85rem;
      font-weight: 600;
      color: var(--movie-muted);
      background: transparent;
      border: none;
      padding: 0;
      border-radius: 0;
      white-space: nowrap;
    }

    .community-review-form {
      border: 1px solid var(--movie-border);
      background: transparent;
      border-radius: 0.85rem;
      padding: 0.85rem 0.95rem;
      margin-bottom: 1.1rem;
    }

    .community-review-form.is-hidden {
      display: none;
    }

    .community-review-cta {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 0.8rem;
      font-weight: 600;
    }

    .community-review-form__editor {
      margin-top: 0.75rem;
    }

    .community-review-form__extras {
      display: flex;
      flex-wrap: wrap;
      gap: 1rem;
      align-items: center;
      margin-top: 0.65rem;
      padding: 0.5rem 0;
      border-top: 1px solid var(--movie-border);
      border-bottom: 1px solid var(--movie-border);
    }

    .community-review-form__rating {
      display: flex;
      flex-direction: column;
      gap: 0.25rem;
    }

    .community-review-form__rating-label {
      font-size: 0.85rem;
      color: var(--movie-text);
      font-weight: 600;
    }

    .community-review-form__rating-stars {
      font-size: 1rem;
    }

    .community-review-form__rating-row {
      display: flex;
      align-items: center;
      gap: 0.6rem;
    }

    .community-review-form__rating-readout {
      font-size: 0.78rem;
      color: var(--movie-muted);
    }

    .community-review-form__watched {
      font-size: 0.85rem;
      color: var(--movie-muted);
      display: inline-flex;
      align-items: center;
      gap: 0.45rem;
    }

    .community-review-form__title {
      font-weight: 600;
      margin-bottom: 0.5rem;
    }

    .community-review-form textarea {
      width: 100%;
      border-radius: 0.75rem;
      border: 1px solid var(--movie-border);
      padding: 0.6rem 0.75rem;
      font-size: 0.95rem;
      resize: vertical;
      background: var(--movie-surface);
      color: var(--movie-text);
    }

    .community-review-form__footer {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 0.8rem;
      margin-top: 0.6rem;
    }

    .community-review-form__actions {
      display: flex;
      gap: 0.5rem;
      align-items: center;
    }

    .community-review-form__spoiler {
      font-size: 0.8rem;
      color: var(--movie-muted);
      display: flex;
      align-items: center;
      gap: 0.35rem;
      margin-right: 0.5rem;
    }

    .community-review-form__spoiler input {
      margin-right: 0.35rem;
    }

    .community-review-form__hint {
      font-size: 0.8rem;
      color: var(--movie-muted);
    }

    .community-review-form.is-guest {
      text-align: center;
      color: var(--movie-muted);
    }

    .community-review-card {
      border: none;
      background: transparent;
      border-radius: 0;
      padding: 0.9rem 0;
      border-bottom: 1px solid var(--movie-border);
      margin-bottom: 0;
      display: grid;
      grid-template-columns: 48px 1fr;
      gap: 0.85rem;
      align-items: start;
    }

    .community-review-card:last-child {
      border-bottom: none;
    }

    .community-review__header {
      display: flex;
      justify-content: space-between;
      gap: 1rem;
      align-items: flex-start;
    }

    .community-review__body {
      min-width: 0;
    }

    .community-review__avatar,
    .community-review__reply-avatar {
      width: 42px;
      height: 42px;
      border-radius: 50%;
      overflow: hidden;
      background: var(--movie-surface-alt);
      border: 1px solid var(--movie-border);
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: 700;
      color: var(--movie-text);
      flex-shrink: 0;
    }

    .community-review__avatar img,
    .community-review__reply-avatar img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

    .community-review__meta {
      display: flex;
      flex-direction: column;
      gap: 0.2rem;
    }

    .community-review__name-row {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      flex-wrap: wrap;
    }

    .community-review__name {
      font-weight: 700;
      font-size: 0.95rem;
    }

    .community-review__stars {
      display: inline-flex;
      align-items: center;
      gap: 0.15rem;
      color: rgba(15, 23, 42, 0.25);
      font-size: 0.85rem;
    }

    .dark .community-review__stars {
      color: rgba(248, 250, 252, 0.3);
    }

    .community-review__stars .icon.star.is-filled {
      color: #f6c453;
      text-shadow: 0 0 6px rgba(246, 196, 83, 0.4);
    }

    .community-review__date {
      font-size: 0.8rem;
      color: var(--movie-muted);
      white-space: nowrap;
    }

    .community-review__content {
      margin-top: 0.35rem;
      font-size: 0.95rem;
      line-height: 1.5;
      color: var(--movie-text);
    }

    .community-review__actions {
      display: flex;
      gap: 0.75rem;
      margin-top: 0.7rem;
      flex-wrap: wrap;
    }

    .community-review__action {
      background: transparent;
      border: none;
      color: var(--movie-muted);
      display: inline-flex;
      align-items: center;
      gap: 0.35rem;
      cursor: pointer;
      font-size: 0.85rem;
      padding: 0.2rem 0;
    }

    .community-review__action.is-disabled {
      opacity: 0.5;
      cursor: not-allowed;
      pointer-events: none;
    }

    .community-review__action:hover {
      color: var(--movie-text);
    }

    .community-review__replies {
      margin-top: 0.7rem;
      padding-top: 0.7rem;
      border-top: 1px solid var(--movie-border);
      display: flex;
      flex-direction: column;
      gap: 0.6rem;
    }

    .community-review__reply {
      display: flex;
      gap: 0.6rem;
      align-items: flex-start;
    }

    .community-review__reply-body {
      background: transparent;
      border: 1px solid var(--movie-border);
      border-radius: 0.8rem;
      padding: 0.55rem 0.7rem;
      flex: 1;
    }

    .community-review__reply-actions {
      display: flex;
      gap: 0.6rem;
      margin-top: 0.4rem;
    }

    .community-review__reply-edit-form {
      margin-top: 0.6rem;
      border: 1px solid var(--movie-border);
      border-radius: 0.8rem;
      padding: 0.5rem;
      background: transparent;
    }

    .community-review__reply-edit-form textarea {
      width: 100%;
      border-radius: 0.6rem;
      border: 1px solid var(--movie-border);
      padding: 0.4rem 0.55rem;
      font-size: 0.85rem;
      resize: vertical;
      background: var(--movie-surface);
      color: var(--movie-text);
    }

    .community-review__reply-edit-actions {
      display: flex;
      justify-content: flex-end;
      gap: 0.4rem;
      margin-top: 0.4rem;
    }

    @media (max-width: 700px) {
      /* Review cards: smaller avatar column, tighter padding */
      .community-review-card {
        grid-template-columns: 34px 1fr;
        padding: 0.7rem 0;
        gap: 0.55rem;
        border-radius: 0;
      }

      .community-review__avatar,
      .community-review__reply-avatar {
        width: 34px;
        height: 34px;
        font-size: 0.8rem;
      }

      /* Header: stack name/date vertically */
      .community-review__header {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.25rem;
      }

      .community-review__name {
        font-size: 0.9rem;
      }

      .community-review__content {
        font-size: 0.9rem;
      }

      /* Action buttons: larger touch targets on mobile */
      .community-review__actions,
      .community-review__reply-actions {
        flex-wrap: wrap;
        gap: 0.15rem 0.6rem;
      }

      .community-review__action {
        font-size: 0.85rem;
        padding: 0.4rem 0;
        min-height: 36px;
        display: inline-flex;
        align-items: center;
      }

      /* Main review form: full-width, bigger textarea */
      .community-review-form {
        padding: 0.7rem;
        border-radius: 0.75rem;
      }

      .community-review-cta {
        gap: 0.5rem;
        font-size: 0.9rem;
      }

      .community-review-form textarea {
        font-size: 1rem;
        padding: 0.7rem;
        min-height: 120px;
        border-radius: 0.6rem;
      }

      /* Form footer: stack hint and actions vertically */
      .community-review-form__footer {
        flex-direction: column;
        align-items: stretch;
        gap: 0.6rem;
      }

      .community-review-form__actions {
        flex-wrap: wrap;
        justify-content: space-between;
        gap: 0.5rem;
        width: 100%;
      }

      .community-review-form__actions .ui.button {
        flex: 1;
        min-width: 0;
        text-align: center;
      }

      .community-review-form__spoiler {
        font-size: 0.82rem;
        margin-right: 0;
      }

      .community-review-form__hint {
        font-size: 0.78rem;
      }

      /* Edit form: bigger textarea, stacked buttons */
      .community-review__edit-form,
      .community-review__reply-edit-form,
      .community-review__reply-form {
        padding: 0.55rem;
        border-radius: 0.6rem;
      }

      .community-review__edit-form textarea {
        font-size: 0.95rem;
        padding: 0.6rem;
        min-height: 100px;
      }

      .community-review__edit-actions {
        flex-wrap: wrap;
        justify-content: space-between;
        gap: 0.4rem;
      }

      .community-review__edit-actions .community-review-form__spoiler {
        width: 100%;
        margin-bottom: 0.2rem;
      }

      /* Reply form: bigger textarea */
      .community-review__reply-form textarea {
        font-size: 0.9rem;
        padding: 0.6rem;
        min-height: 80px;
      }

      .community-review__reply-edit-form textarea {
        font-size: 0.9rem;
        padding: 0.5rem;
        min-height: 70px;
      }

      .community-review__reply-edit-actions {
        flex-wrap: wrap;
        justify-content: space-between;
        gap: 0.4rem;
      }

      .community-review__reply-edit-actions .community-review-form__spoiler {
        width: 100%;
        margin-bottom: 0.2rem;
      }

      /* Reply actions: stacked layout with full-width buttons */
      .community-review__reply-actions {
        flex-wrap: wrap;
        justify-content: space-between;
        gap: 0.4rem;
      }

      .community-review__reply-actions .community-review-form__spoiler {
        width: 100%;
        margin-bottom: 0.2rem;
      }

      /* Replies section */
      .community-review__reply {
        gap: 0.45rem;
      }

      .community-review__reply-body {
        padding: 0.5rem 0.6rem;
        border-radius: 0.6rem;
      }

      .community-review__reply-text {
        font-size: 0.85rem;
      }

      .community-review__reply-meta {
        font-size: 0.73rem;
      }

      /* Ensure all buttons have good touch targets */
      .community-review__edit-actions .ui.button,
      .community-review__reply-actions .ui.button,
      .community-review__reply-edit-actions .ui.button {
        min-height: 34px;
        padding-left: 0.8rem;
        padding-right: 0.8rem;
      }

      /* Load more button full width */
      .community-review-more .ui.button {
        width: 100%;
      }
    }

    .community-review__reply-meta {
      display: flex;
      justify-content: space-between;
      font-size: 0.75rem;
      color: var(--movie-muted);
      margin-bottom: 0.3rem;
    }

    .community-review__reply-name {
      font-weight: 600;
      color: var(--movie-text);
    }

    .community-review__reply-text {
      font-size: 0.85rem;
      line-height: 1.4;
    }

    .community-review__reply-form {
      margin-top: 0.8rem;
      border: 1px solid var(--movie-border);
      border-radius: 0.8rem;
      padding: 0.6rem;
      background: var(--movie-surface-alt);
    }

    .community-review__edit-form {
      margin-top: 0.8rem;
      border: 1px solid var(--movie-border);
      border-radius: 0.8rem;
      padding: 0.6rem;
      background: var(--movie-surface-alt);
    }

    .community-review__edit-form textarea {
      width: 100%;
      border-radius: 0.6rem;
      border: 1px solid var(--movie-border);
      padding: 0.45rem 0.6rem;
      font-size: 0.9rem;
      resize: vertical;
      background: var(--movie-surface);
      color: var(--movie-text);
    }

    .community-review__edit-actions {
      display: flex;
      justify-content: flex-end;
      gap: 0.4rem;
      margin-top: 0.5rem;
    }

    .community-review-card.is-spoiler-hidden .community-review__content,
    .community-review-card.is-spoiler-hidden .community-review__actions,
    .community-review-card.is-spoiler-hidden .community-review__replies,
    .community-review__reply.is-spoiler-hidden .community-review__reply-text {
      filter: blur(8px);
      user-select: none;
      pointer-events: none;
    }

    .spoiler-cover {
      margin-top: 0.4rem;
      padding: 0.35rem 0.6rem;
      border-radius: 0.6rem;
      border: 1px dashed var(--movie-border);
      background: var(--movie-surface-alt);
      color: var(--movie-muted);
      font-size: 0.8rem;
      text-align: center;
      cursor: pointer;
    }

    .spoiler-cover::after {
      content: attr(data-label);
    }

    .community-review__reply-form textarea {
      width: 100%;
      border-radius: 0.6rem;
      border: 1px solid var(--movie-border);
      padding: 0.45rem 0.6rem;
      font-size: 0.85rem;
      resize: vertical;
      background: var(--movie-surface);
      color: var(--movie-text);
    }

    .community-review__reply-actions {
      display: flex;
      justify-content: flex-end;
      gap: 0.4rem;
      margin-top: 0.5rem;
    }

    /* "Replying to X" chip above the reply textarea */
    .community-review__replying-to {
      font-size: 0.78rem;
      color: var(--movie-muted);
      margin-bottom: 0.35rem;
      display: flex;
      align-items: center;
      gap: 0.3rem;
    }

    .community-review__replying-to strong {
      color: var(--movie-text);
    }

    .community-review__replying-to-clear {
      background: none;
      border: none;
      cursor: pointer;
      font-size: 0.7rem;
      color: var(--movie-muted);
      padding: 0 0.1rem;
      line-height: 1;
    }

    .community-review__replying-to-clear:hover {
      color: var(--movie-text);
    }

    /* Parent reply reference (↩ in reply to) */
    .community-review__reply-parent {
      font-size: 0.75rem;
      color: var(--movie-muted);
      margin-bottom: 0.2rem;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .community-review__reply-parent a {
      color: var(--movie-muted);
      font-weight: 600;
      text-decoration: none;
    }

    .community-review__reply-parent-snippet {
      opacity: 0.75;
    }

    /* Like + Reply inline row on individual replies */
    .community-review__reply-actions-row {
      display: flex;
      align-items: center;
      gap: 0.6rem;
      margin-top: 0.25rem;
    }

    .community-review__reply-like {
      background: none;
      border: none;
      padding: 0;
      cursor: pointer;
      font-size: 0.8rem;
      color: var(--movie-muted);
      display: inline-flex;
      align-items: center;
      gap: 0.15rem;
    }

    .community-review__reply-like:hover,
    .community-review__reply-like.liked {
      color: #2185d0;
    }

    .community-review__reply-like.is-disabled {
      opacity: 0.4;
      cursor: default;
    }

    .community-review__reply.is-child-reply {
      margin-left: 1.5rem;
      border-left: 2px solid var(--movie-border);
      padding-left: 0.75rem;
    }

    .community-review-empty {
      padding: 1rem;
      border-radius: 0.8rem;
      border: 1px dashed var(--movie-border);
      color: var(--movie-muted);
      text-align: center;
      background: var(--movie-surface-alt);
    }

    .community-review-more {
      display: flex;
      justify-content: center;
      margin-top: 0.8rem;
    }

    .community-review-thirdparty {
      margin-top: 1.2rem;
    }

    /* ── Mobile Review Modal (Letterboxd-style fullscreen editor) ── */
    .mobile-review-modal {
      display: none;
      position: fixed;
      inset: 0;
      z-index: 1100;
    }

    .mobile-review-modal.is-active {
      display: flex;
    }

    .mobile-review-modal__sheet {
      position: relative;
      display: flex;
      flex-direction: column;
      width: 100%;
      height: 100%;
      background: #ffffff;
      color: #1a1a2e;
    }

    .dark .mobile-review-modal__sheet {
      background: #14141e;
      color: #e8eaed;
    }

    /* ── Top bar: title + X close ── */
    .mobile-review-modal__topbar {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 0.85rem 1rem;
      border-bottom: 1px solid rgba(0, 0, 0, 0.08);
      flex-shrink: 0;
    }

    .dark .mobile-review-modal__topbar {
      border-bottom-color: rgba(255, 255, 255, 0.08);
    }

    .mobile-review-modal__title {
      font-weight: 700;
      font-size: 1.05rem;
    }

    .mobile-review-modal__done {
      margin-left: auto;
      margin-right: 0.25rem;
      background: none;
      border: none;
      color: #0f172a;
      font-weight: 600;
      font-size: 0.95rem;
      padding: 0.25rem 0.5rem;
      cursor: pointer;
    }

    .dark .mobile-review-modal__done {
      color: #e2e8f0;
    }

    .mobile-review-modal__close {
      background: none;
      border: none;
      color: #64748b;
      font-size: 1.25rem;
      cursor: pointer;
      padding: 0.25rem;
      line-height: 1;
      display: flex;
      align-items: center;
      justify-content: center;
      width: 36px;
      height: 36px;
      border-radius: 50%;
      transition: background 0.15s;
    }

    .mobile-review-modal__close:hover,
    .mobile-review-modal__close:active {
      background: rgba(0, 0, 0, 0.06);
    }

    .dark .mobile-review-modal__close {
      color: #94a3b8;
    }

    .dark .mobile-review-modal__close:hover,
    .dark .mobile-review-modal__close:active {
      background: rgba(255, 255, 255, 0.08);
    }

    /* ── Movie info row: poster + title/year ── */
    .mobile-review-modal__movie {
      display: flex;
      align-items: center;
      gap: 0.75rem;
      padding: 0.85rem 1rem;
      border-bottom: 1px solid rgba(0, 0, 0, 0.06);
      flex-shrink: 0;
    }

    .dark .mobile-review-modal__movie {
      border-bottom-color: rgba(255, 255, 255, 0.06);
    }

    .mobile-review-modal__poster {
      width: 40px;
      height: 60px;
      object-fit: cover;
      border-radius: 4px;
      flex-shrink: 0;
      box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
    }

    .mobile-review-modal__movie-info {
      min-width: 0;
    }

    .mobile-review-modal__movie-title {
      font-weight: 700;
      font-size: 0.95rem;
      line-height: 1.3;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }

    .mobile-review-modal__movie-year {
      font-size: 0.82rem;
      color: #64748b;
      margin-top: 0.1rem;
    }

    .dark .mobile-review-modal__movie-year {
      color: #94a3b8;
    }

    /* ── Body: textarea fills remaining space ── */
    .mobile-review-modal__body {
      flex: 1;
      display: flex;
      flex-direction: column;
      overflow-y: auto;
      min-height: 0;
    }

    .mobile-review-modal__input {
      flex: 1;
      width: 100%;
      border: none;
      outline: none;
      resize: none;
      padding: 1rem;
      font-size: 1.05rem;
      line-height: 1.65;
      font-family: inherit;
      background: transparent;
      color: inherit;
      min-height: 180px;
    }

    .mobile-review-modal__input::placeholder {
      color: #94a3b8;
    }

    .dark .mobile-review-modal__input::placeholder {
      color: #5a6577;
    }

    /* ── Bottom bar: spoiler + hint + action buttons ── */
    .mobile-review-modal__bottom {
      flex-shrink: 0;
      border-top: 1px solid rgba(0, 0, 0, 0.08);
      padding: 0.75rem 1rem;
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
    }

    .dark .mobile-review-modal__bottom {
      border-top-color: rgba(255, 255, 255, 0.08);
    }

    .mobile-review-modal__options {
      display: flex;
      align-items: center;
      justify-content: space-between;
      flex-wrap: wrap;
      gap: 0.65rem;
    }

    .mobile-review-modal__rating {
      display: flex;
      flex-direction: column;
      gap: 0.25rem;
    }

    .mobile-review-modal__rating-label {
      font-size: 0.88rem;
      color: var(--movie-text);
      font-weight: 600;
    }

    .mobile-review-modal__stars {
      font-size: 1.05rem;
    }

    .mobile-review-modal__rating-readout {
      font-size: 0.8rem;
      color: var(--movie-muted);
    }

    .mobile-review-modal__watched {
      font-size: 0.88rem;
      color: var(--movie-muted);
      display: inline-flex;
      align-items: center;
      gap: 0.45rem;
    }

    .mobile-review-modal__spoiler {
      font-size: 0.88rem;
      color: #475569;
      display: flex;
      align-items: center;
      gap: 0.45rem;
      cursor: pointer;
    }

    .dark .mobile-review-modal__spoiler {
      color: #94a3b8;
    }

    .mobile-review-modal__spoiler input {
      margin: 0;
      width: 18px;
      height: 18px;
    }

    .mobile-review-modal__hint {
      font-size: 0.8rem;
      color: #94a3b8;
    }

    .dark .mobile-review-modal__hint {
      color: #5a6577;
    }

    .mobile-review-modal__actions {
      display: flex;
      gap: 0.6rem;
    }

    .mobile-review-modal__cancel {
      flex: 1;
      padding: 0.8rem;
      border-radius: 10px;
      border: 1px solid rgba(0, 0, 0, 0.12);
      background: transparent;
      color: #475569;
      font-size: 0.95rem;
      font-weight: 600;
      cursor: pointer;
      transition: background 0.15s;
    }

    .mobile-review-modal__cancel:active {
      background: rgba(0, 0, 0, 0.04);
    }

    .dark .mobile-review-modal__cancel {
      border-color: rgba(255, 255, 255, 0.12);
      color: #94a3b8;
    }

    .dark .mobile-review-modal__cancel:active {
      background: rgba(255, 255, 255, 0.06);
    }

    .mobile-review-modal__submit {
      flex: 2;
      padding: 0.8rem;
      border-radius: 10px;
      border: none;
      background: #2563eb;
      color: #fff;
      font-size: 0.95rem;
      font-weight: 700;
      cursor: pointer;
      transition: background 0.15s;
    }

    .mobile-review-modal__submit:active {
      background: #1d4ed8;
    }

    @supports (padding-bottom: env(safe-area-inset-bottom)) {
      .mobile-review-modal__bottom {
        padding-bottom: calc(0.75rem + env(safe-area-inset-bottom));
      }
    }


    .movie-hero__poster {
      position: relative;
      flex-shrink: 0;
      overflow: hidden;
      box-shadow: none;
      transition: box-shadow 0.3s ease;
    }

    .movie-hero__details {
      flex: 1;
      box-shadow: none;
      transition: box-shadow 0.3s ease;
    }

    .movie-hero__poster img {
      max-width: 200px !important;
      width: auto !important;
      height: auto;
      object-fit: contain;
      border-radius: 1rem;
      box-shadow: var(--movie-poster-shadow);
      transition: box-shadow 0.3s ease;
    }

    .movie-page .poster-card {
      box-shadow: 0 12px 32px rgba(0, 0, 0, 0.25);
      transition: transform 180ms ease, box-shadow 180ms ease;
      will-change: transform;
    }

    .movie-page .poster-card:hover {
      transform: scale(1.015);
      box-shadow: 0 18px 36px rgba(0, 0, 0, 0.3);
    }

    .movie-credits-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 1rem;
      margin-bottom: 0.8rem;
    }

    .movie-section-card {
      margin: 0 1rem 1rem;
    }

    .movie-main > .movie-section-card {
      margin: 0 0 1.25rem;
    }

    .movie-credits-title {
      color: var(--movie-text);
      font-size: 0.95rem;
      font-weight: 800;
      line-height: 1.2;
    }

    .movie-credits-count {
      color: var(--movie-muted);
      font-size: 0.78rem;
      line-height: 1.3;
      margin-top: 0.1rem;
    }

    .movie-credit-filters {
      display: inline-flex;
      align-items: center;
      gap: 0.25rem;
      padding: 0.2rem;
      border: 1px solid var(--movie-border);
      border-radius: 0.55rem;
      background: rgba(128, 128, 128, 0.08);
    }

    .movie-credit-subfilters {
      display: inline-flex;
      flex-wrap: nowrap;
      align-items: center;
      gap: 0.25rem;
      padding: 0.2rem;
      margin: 0 0 0.8rem;
      max-width: 100%;
      overflow-x: auto;
      overflow-y: hidden;
      border: 1px solid var(--movie-border);
      border-radius: 0.55rem;
      background: rgba(128, 128, 128, 0.08);
      scrollbar-width: thin;
    }

    .movie-person-credits .movie-credit-subfilters {
      box-sizing: border-box;
      display: flex;
      width: fit-content;
      margin-left: auto;
      margin-right: 12px;
      max-width: calc(100% - 24px);
    }

    .movie-credit-subfilters .movie-credit-filter {
      color: var(--movie-muted);
      flex: 0 0 auto;
    }

    .movie-credit-subfilters .movie-credit-filter:hover,
    .movie-credit-subfilters .movie-credit-filter.is-active {
      background: var(--movie-surface);
      color: var(--movie-text);
    }

    .movie-credit-filter {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 0.3rem;
      white-space: nowrap;
      border: 0;
      border-radius: 0.4rem;
      background: transparent;
      color: var(--movie-muted);
      cursor: pointer;
      font-size: 0.78rem;
      font-weight: 700;
      line-height: 1;
      padding: 0.45rem 0.6rem;
      transition: background 0.16s ease, color 0.16s ease;
    }

    .movie-credit-filter:hover,
    .movie-credit-filter.is-active {
      background: var(--movie-surface);
      color: var(--movie-text);
    }

    .movie-credit-filter--director {
      --credit-accent: #4c8fd8;
    }

    .movie-credit-filter--cast {
      --credit-accent: #4fa36b;
    }

    .movie-credit-filter--guest {
      --credit-accent: #c58b31;
    }

    .movie-credit-filter--writer {
      --credit-accent: #9b6bbf;
    }

    .movie-credit-filter--producer {
      --credit-accent: #d47f3a;
    }

    .movie-credit-filter--editor {
      --credit-accent: #3aa8a8;
    }

    .movie-credit-filter--camera {
      --credit-accent: #5b8fd4;
    }

    .movie-credit-filter--sound {
      --credit-accent: #4dab7a;
    }

    .movie-credit-filter--art {
      --credit-accent: #c26060;
    }

    .movie-credit-filter--costume {
      --credit-accent: #b07ec9;
    }

    .movie-credit-filter--vfx {
      --credit-accent: #3abbd4;
    }

    .movie-credit-filter--lighting {
      --credit-accent: #c9b03a;
    }

    .movie-credit-filter--crew {
      --credit-accent: #7a8a9a;
    }

    .movie-credit-filter--director,
    .movie-credit-filter--cast,
    .movie-credit-filter--guest,
    .movie-credit-filter--writer,
    .movie-credit-filter--producer,
    .movie-credit-filter--editor,
    .movie-credit-filter--camera,
    .movie-credit-filter--sound,
    .movie-credit-filter--art,
    .movie-credit-filter--costume,
    .movie-credit-filter--vfx,
    .movie-credit-filter--lighting,
    .movie-credit-filter--crew {
      color: var(--credit-accent);
    }

    .movie-credit-filter--director:hover,
    .movie-credit-filter--director.is-active,
    .movie-credit-filter--cast:hover,
    .movie-credit-filter--cast.is-active,
    .movie-credit-filter--guest:hover,
    .movie-credit-filter--guest.is-active,
    .movie-credit-filter--writer:hover,
    .movie-credit-filter--writer.is-active,
    .movie-credit-filter--producer:hover,
    .movie-credit-filter--producer.is-active,
    .movie-credit-filter--editor:hover,
    .movie-credit-filter--editor.is-active,
    .movie-credit-filter--camera:hover,
    .movie-credit-filter--camera.is-active,
    .movie-credit-filter--sound:hover,
    .movie-credit-filter--sound.is-active,
    .movie-credit-filter--art:hover,
    .movie-credit-filter--art.is-active,
    .movie-credit-filter--costume:hover,
    .movie-credit-filter--costume.is-active,
    .movie-credit-filter--vfx:hover,
    .movie-credit-filter--vfx.is-active,
    .movie-credit-filter--lighting:hover,
    .movie-credit-filter--lighting.is-active,
    .movie-credit-filter--crew:hover,
    .movie-credit-filter--crew.is-active {
      background: color-mix(in srgb, var(--credit-accent) 16%, transparent);
      color: var(--movie-text);
    }

    .movie-credit-subfilters .movie-credit-filter-count {
      flex-shrink: 0;
    }

    .movie-credit-filter-count {
      display: inline-flex;
      flex: 0 0 auto;
      align-items: center;
      justify-content: center;
      min-width: 1.45em;
      margin-left: 0;
      padding: 0.13rem 0.38rem;
      border-radius: 999px;
      background: color-mix(in srgb, var(--credit-accent, var(--movie-muted)) 24%, transparent);
      color: var(--movie-text);
      font-size: 0.72rem;
      line-height: 1;
    }

    .movie-credit-filter--plain {
      color: #2c7be5;
    }

    .movie-credit-filter.loading {
      cursor: progress;
      opacity: 0.72;
    }

    .movie-credit-filter.is-error {
      color: #db2828;
    }

    .movie-credit-rail-wrap {
      position: relative;
      margin: 0;
      padding: 0 4px;
    }

    .movie-person-credits .movie-credit-rail-wrap {
      padding: 0 12px;
    }

    .movie-person-credits .movie-credits-header {
      padding: 0 12px;
    }

    .movie-credit-rail-wrap::after {
      display: none;
    }

    .dark .movie-credit-rail-wrap::after {
      background: linear-gradient(90deg, rgba(23, 26, 36, 0), var(--movie-surface));
    }

    .movie-credit-rail-wrap.is-expanded::after {
      display: none;
    }

    .movie-credit-rail {
      display: grid;
      grid-template-columns: repeat(10, minmax(0, 1fr));
      align-items: flex-start;
      column-gap: 4px;
      row-gap: 0.65rem;
      overflow: hidden;
      padding: 0.1rem 0 0;
    }

    .movie-credit-rail.is-expanded {
      grid-template-columns: repeat(auto-fill, minmax(75px, 1fr));
      overflow: visible;
    }

    .movie-person-credits .movie-credit-rail {
      grid-template-columns: repeat(10, minmax(0, 1fr));
      column-gap: 4px;
      row-gap: 0.65rem;
      justify-content: start;
    }

    .movie-person-credits .movie-credit-rail.is-expanded {
      grid-template-columns: repeat(auto-fill, minmax(75px, 1fr));
    }

    .movie-credit-card {
      min-width: 0;
      width: 100%;
      border-top: 2px solid transparent;
      border-radius: 0.45rem 0.45rem 0 0;
      padding-top: 2px;
    }

    .movie-credit-card--director {
      border-top-color: rgba(76, 143, 216, 0.65);
    }

    .movie-credit-card--cast {
      border-top-color: rgba(79, 163, 107, 0.65);
    }

    .movie-credit-card--guest {
      border-top-color: rgba(197, 139, 49, 0.7);
    }

    .movie-credit-card--director > .ui.card {
      background: linear-gradient(180deg, rgba(76, 143, 216, 0.08), transparent 38%) !important;
    }

    .movie-credit-card--cast > .ui.card {
      background: linear-gradient(180deg, rgba(79, 163, 107, 0.08), transparent 38%) !important;
    }

    .movie-credit-card--guest > .ui.card {
      background: linear-gradient(180deg, rgba(197, 139, 49, 0.09), transparent 38%) !important;
    }

    .movie-credit-group-break {
      grid-column: 1 / -1;
      display: flex;
      align-items: center;
      gap: 0.6rem;
      margin: 0.35rem 0 0.15rem;
      color: var(--movie-muted);
      font-size: 0.76rem;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: 0;
    }

    .movie-credit-group-break::after {
      content: "";
      height: 1px;
      flex: 1;
      background: var(--movie-border);
    }

    .movie-credit-group-break--director {
      color: #4c8fd8;
    }

    .movie-credit-group-break--cast {
      color: #4fa36b;
    }

    .movie-credit-group-break--guest {
      color: #c58b31;
    }

    .movie-credit-group-break--director::after {
      background: rgba(76, 143, 216, 0.45);
    }

    .movie-credit-group-break--cast::after {
      background: rgba(79, 163, 107, 0.45);
    }

    .movie-credit-group-break--guest::after {
      background: rgba(197, 139, 49, 0.45);
    }

    .movie-credit-card > .ui.card {
      position: relative;
      width: 100% !important;
      min-width: 0 !important;
      max-width: none !important;
      margin: 0 !important;
    }

    .movie-credit-age-trigger {
      position: absolute;
      top: 7px;
      right: 7px;
      z-index: 2;
      width: 24px;
      height: 24px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border: 0;
      border-radius: 50%;
      background: rgba(0, 0, 0, 0.72);
      color: #fff;
      box-shadow: 0 1px 5px rgba(0, 0, 0, 0.35);
      cursor: pointer;
      opacity: 0.88;
      padding: 0;
    }

    .movie-credit-age-trigger--mobile {
      display: none;
    }

    .movie-credit-age-trigger:hover,
    .movie-credit-age-trigger:focus {
      opacity: 1;
      outline: none;
    }

    .movie-credit-age-trigger .icon {
      width: auto;
      height: auto;
      margin: 0 !important;
      font-size: 0.76rem;
      line-height: 1;
    }

    @media (hover: none), (pointer: coarse) {
      .movie-credit-age-trigger--mobile {
        display: inline-flex;
      }
    }

    .movie-credit-card .ui.image {
      aspect-ratio: 2 / 2.7;
      overflow: hidden;
      border-radius: 0.45rem;
    }

    .movie-credit-card .ui.image img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

    .movie-credit-count-badge {
      color: var(--movie-muted);
      font-size: 10px;
      line-height: 1.2;
    }

    .movie-credit-card.is-filtered {
      display: none;
    }

    .movie-credit-card.is-compact-hidden {
      display: none;
    }

    @media (max-width: 700px) {
      .movie-credits-header {
        align-items: flex-start;
        flex-direction: column;
        gap: 0.65rem;
      }

      .movie-credit-filters,
      .movie-credit-subfilters {
        max-width: 100%;
        overflow-x: auto;
      }

      .movie-section-card {
        margin: 0 0 1rem;
      }

      .movie-credit-rail {
        display: flex;
        gap: 0.4rem;
        overflow-x: auto;
        padding-bottom: 0.65rem;
        scrollbar-width: thin;
      }

      .movie-person-credits .movie-credits-header {
        padding: 0 0px;
      
      }
      
      .movie-person-credits .movie-credit-rail-wrap {
        padding: 0;
      }

      .movie-credit-rail.is-expanded {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(75px, 1fr));
        overflow: visible;
        padding-bottom: 0.1rem;
      }

      .movie-credit-card {
        flex: 0 0 75px;
      }
    }

    .dark .movie-page .poster-card:hover {
      box-shadow: 0 18px 36px rgba(0, 0, 0, 0.45);
    }

    .movie-hero__poster .floating.ui.mrating {
      position: absolute;
      top: 0;
      right: 0;
      margin: 0 !important;
      z-index: 3;
    }

    .movie-hero__title {
      margin: 0;
      font-size: 2.1rem;
      line-height: 1.2;
      color: var(--movie-text);
    }

    .movie-hero__label {
      display: flex;
      flex-wrap: wrap;
      gap: 0.5rem;
      margin-bottom: 0.75rem;
    }

    .movie-hero__description {
      margin-top: 0.9rem;
      color: var(--movie-muted);
      line-height: 1.5;
    }

    .movie-hero__meta {
      display: flex;
      flex-wrap: wrap;
      gap: 0.65rem;
      margin-top: 1rem;
    }

    .movie-hero__longform {
      margin-top: 1rem;
    }

    .movie-awards-line {
      color: var(--movie-text);
    }

    .movie-awards-line .trophy.icon {
      color: #c99a2e;
      margin-right: 0.4rem;
    }

    .dark .movie-awards-line .trophy.icon {
      color: #e6c15f;
    }

    .movie-pill {
      padding: 0.35rem 0.85rem;
      border-radius: 999px;
      background: var(--movie-surface-alt);
      border: 1px solid var(--movie-border);
      font-size: 0.85rem;
      color: var(--movie-text);
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      transition: background 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
    }

    .movie-pill--interactive {
      cursor: pointer;
    }

    .movie-pill--interactive:hover,
    .movie-pill--interactive:focus-visible {
      background: var(--movie-panel-gradient);
      box-shadow: 0 4px 12px rgba(15, 23, 42, 0.12);
      color: var(--movie-text);
      outline: none;
    }

    .dark .movie-pill--interactive:hover,
    .dark .movie-pill--interactive:focus-visible {
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
    }

    .movie-pill--fresh img {
      width: 14px;
      height: 14px;
      display: block;
    }

    .movie-pill--ai svg {
      width: 16px;
      height: 16px;
      color: #6366f1;
      flex-shrink: 0;
    }

    .dark .movie-pill--ai svg {
      color: #a5b4fc;
    }

    .movie-hero__ai-toggle {
      margin-top: 0.85rem;
    }

    .movie-hero__ai-panel {
      margin-top: 0.75rem;
      padding: 1rem;
      border-radius: 1rem;
      border: 1px solid var(--movie-border);
      background: var(--movie-panel-gradient);
      color: var(--movie-text);
      display: none;
      line-height: 1.55;
      font-size: 0.9rem;
    }

    .movie-hero__ai-panel.is-visible {
      display: block;
    }

    .movie-hero__scorecard .movie-score {
      position: relative;
      margin-top: -0.5rem;
      height: 60px;
      display: flex;
      justify-content: center;
      align-items: center;
      margin-bottom: 0.5rem;
    }

    .movie-hero__scorecard .idscore {
      position: absolute !important;
      left: 50% !important;
      top: 5px !important;
      right: auto !important;
      margin: 0 !important;
      transform: translateX(-80%);
    }

    .movie-hero__scorecard .idscoreavg {
      position: absolute !important;
      left: 50% !important;
      top: 28px !important;
      right: auto !important;
      margin: 0 !important;
      transform: translateX(5%);
    }

    .movie-hero__scorecard .ui.grid {
      margin: 0 !important;
      padding: 0 !important;
      font-size: 0.8rem;
      line-height: 0.85;
      min-height: auto !important;
    }

    .movie-hero__scorecard .ui.grid .column {
      padding: 0.01rem 0.2rem !important;
      line-height: 0.55;
    }

    /* Compact histogram for scorecard */
    .movie-hero__scorecard .mdblist-ratings-section {
      margin-top: 12px !important;
      padding-top: 12px !important;
      border-top-color: var(--movie-border) !important;
    }

    .movie-hero__scorecard .mdblist-ratings-section .rating-histogram {
      height: 55px !important;
    }

    /* Light/Dark mode text colors for histogram */
    .movie-hero__scorecard .mdblist-label {
      color: var(--movie-muted);
    }

    .movie-hero__scorecard .mdblist-rating {
      color: var(--movie-text);
    }

    .movie-hero__scorecard .mdblist-votes {
      color: var(--movie-muted);
      opacity: 0.8;
    }

    .movie-hero__scorecard .rating-label {
      color: var(--movie-muted) !important;
      opacity: 0.7;
    }

    /* Mobile optimizations */
    @media (max-width: 700px) {
      .movie-hero__scorecard .movie-score {
        height: 55px;
        margin-bottom: 0.3rem;
      }

      .movie-hero__scorecard .idscore {
        top: 3px !important;
      }

      .movie-hero__scorecard .idscoreavg {
        top: 24px !important;
      }

      .movie-hero__scorecard .ui.grid .column {
        padding: 0 0.15rem !important;
        line-height: 0.5;
      }

      .movie-hero__scorecard .mdblist-ratings-section {
        margin-top: 6px !important;
        padding-top: 6px !important;
      }

      .movie-hero__scorecard .mdblist-ratings-section .rating-histogram {
        height: 35px !important;
      }

      .movie-hero__scorecard .mdblist-ratings-section > div:first-child {
        margin-bottom: 4px !important;
      }
    }

    .movie-hero__scorecard .ui.grid > .row {
      padding: 0 !important;
      margin: 0 !important;
    }

    .movie-main {
      grid-area: main;
      background: var(--movie-panel-gradient);
      border-radius: 1.25rem;
      border: 1px solid var(--movie-border);
      padding: 1.25rem;
      box-shadow: var(--movie-card-shadow);
      align-self: start;
      color: var(--movie-text);
      transition: box-shadow 0.3s ease;
    }

    .movie-aside-card {
      background: var(--movie-panel-gradient);
      border-radius: 1.25rem;
      border: 1px solid var(--movie-border);
      padding: 1.25rem;
      box-shadow: var(--movie-card-shadow);
      align-self: start;
      color: var(--movie-text);
      transition: box-shadow 0.3s ease;
    }

    .movie-hero__wrapper:hover,
    .movie-hero__scorecard:hover,
    .movie-main:hover,
    .movie-aside-card:hover {
      box-shadow: 0 6px 12px rgba(15, 23, 42, 0.08),
                  0 16px 32px rgba(15, 23, 42, 0.1),
                  0 28px 56px rgba(15, 23, 42, 0.12);
    }

    .dark .movie-hero__wrapper:hover,
    .dark .movie-hero__scorecard:hover,
    .dark .movie-main:hover,
    .dark .movie-aside-card:hover {
      box-shadow: 0 4px 10px rgba(0, 0, 0, 0.28),
                  0 14px 24px rgba(0, 0, 0, 0.35),
                  0 22px 44px rgba(0, 0, 0, 0.42);
    }


    .movie-aside-card {
      grid-area: aside-bottom;
    }

    /* Aside Card Components */
    .aside-trailer-link {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 0.5rem;
      padding: 0.75rem;
      background: linear-gradient(135deg, #3a7aaa 0%, #4a8ec2 100%);
      color: white !important;
      border-radius: 0.75rem;
      text-decoration: none;
      font-size: 0.9rem;
      font-weight: 600;
      transition: all 0.2s ease;
      margin-bottom: 1rem;
    }

    .aside-trailer-link:hover {
      transform: translateY(-2px);
      box-shadow: 0 4px 12px rgba(58, 122, 170, 0.5);
    }

    .aside-trailer-link i {
      font-size: 1.2rem;
    }

    .mobile-trailer-link {
      display: none;
    }

    .aside-info-grid {
      display: flex;
      flex-direction: column;
      gap: 0.4rem;
      margin-bottom: 1rem;
      padding-bottom: 1rem;
      border-bottom: 1px solid var(--movie-border);
    }

    .aside-info-item {
      display: flex;
      align-items: center;
      gap: 0.6rem;
      font-size: 0.85rem;
      line-height: 1.3;
      color: var(--movie-text);
    }

    .aside-info-item i.icon {
      font-size: 1rem;
      color: var(--movie-text-secondary);
      opacity: 0.7;
      min-width: 1rem;
      flex-shrink: 0;
    }

    .aside-info-item span {
      flex: 1;
      word-break: break-word;
    }

    .aside-footer {
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
    }

    .aside-refresh-link {
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      padding: 0.5rem 0.75rem;
      background: var(--movie-panel-gradient);
      border: 1px solid var(--movie-border);
      border-radius: 0.5rem;
      color: var(--movie-text) !important;
      text-decoration: none;
      font-size: 0.8rem;
      font-weight: 500;
      transition: all 0.2s ease;
      align-self: flex-start;
    }

    .aside-refresh-link:hover {
      background: var(--movie-border);
      transform: translateX(2px);
    }

    .aside-refresh-link i {
      font-size: 0.9rem;
    }

    .aside-meta {
      display: flex;
      flex-direction: column;
      gap: 0.35rem;
      font-size: 0.75rem;
      color: var(--movie-text-secondary);
      opacity: 0.6;
      line-height: 1.3;
    }

    .dark .aside-trailer-link {
      background: linear-gradient(135deg, #3a7aaa 0%, #4a8ec2 100%);
    }

    .movie-main .ui.segment,
    .movie-main .ui.grid,
    .movie-main .row {
      background: transparent !important;
    }

    /* Hide JustWatch widget on iPad/tablet view (768px to 992px) */
    @media (min-width: 768px) and (max-width: 992px) {
      .justwatch-widget-container {
        display: none;
      }
    }

    @media (max-width: 992px) {
      .movie-page {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        grid-template-areas:
          "poster aside aside-bottom"
          "details details details"
          "main main main";
        align-items: stretch;
      }

      .movie-primary-column,
      .movie-secondary-column {
        display: contents;
      }

      .movie-hero__wrapper {
        display: contents;
      }

      .movie-hero__poster {
        grid-area: poster;
        background: var(--movie-panel-gradient);
        border-radius: 1.15rem;
        border: 1px solid var(--movie-border);
        box-shadow: var(--movie-card-shadow);
        padding: 0.5rem;
        display: flex;
        justify-content: center;
        align-items: flex-start;
        transition: box-shadow 0.3s ease;
        height: 100%;
      }

      .movie-hero__poster img {
        width: 100% !important;
        max-width: 180px;
      }

      .movie-hero__details {
        grid-area: details;
        background: var(--movie-panel-gradient);
        border-radius: 1.25rem;
        border: 1px solid var(--movie-border);
        box-shadow: var(--movie-card-shadow);
        padding: 1.25rem;
      }

      .movie-hero__scorecard {
        grid-area: aside;
        margin-bottom: 0;
        height: 100%;
        position: relative;
        padding-top: 4.0rem;
      }

      .movie-aside-card {
        grid-area: aside-bottom;
        margin-top: 0;
        height: 100%;
      }

      .movie-hero__scorecard .ui.grid,
      .movie-hero__scorecard .movie-score {
        max-width: 200px;
        margin-left: 0;
        margin-right: 0;
      }

      .movie-hero__scorecard .movie-score {
        margin-top: 0;
      }
    }

    @media (max-width: 700px) {
      .mobile-trailer-link {
        display: flex;
        margin-bottom: 0.5rem;
      }

      #content-desktop-4 .aside-trailer-link:not(.mobile-trailer-link),
      .season-aside-card .aside-trailer-link:not(.mobile-trailer-link) {
        display: none;
      }

      .movie-page {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        grid-template-areas:
          "poster scorecard"
          "details details"
          "main main"
          "aside-bottom aside-bottom";
        row-gap: 0.25rem;
        column-gap: 0.25rem;
        padding: 0.25rem 0 0;
      }

      .movie-primary-column,
      .movie-secondary-column {
        display: contents;
      }

      .movie-hero__wrapper {
        display: contents;
      }

      .movie-hero__poster {
        grid-area: poster;
        position: relative;
        background: linear-gradient(135deg, rgba(255, 255, 255, 0.88) 0%, rgba(249, 251, 255, 0.96) 100%);
        border-radius: 1.15rem;
        border: 1px solid var(--movie-border);
        box-shadow: var(--movie-card-shadow);
        padding: 0;
        margin-bottom: 0;
        height: 100%;
        width: 100%;
        max-width: none;
        display: flex;
        justify-content: center;
        align-items: flex-start;
        overflow: hidden;
        transition: box-shadow 0.3s ease;
      }

      .season-page .movie-hero__poster {
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start;
        gap: 0.5rem;
      }

      .season-page .movie-hero__poster img {
        margin-bottom: 0;
      }

      .season-page .movie-hero__poster .season-progress {
        width: 100%;
        margin-top: 0.1rem;
      }

      .dark .movie-hero__poster {
        background: linear-gradient(135deg, rgba(38, 38, 38, 0.92) 0%, rgba(23, 26, 36, 0.98) 100%);
      }

      .movie-hero__poster img {
        width: 100% !important;
        max-width: none;
        height: 100%;
        object-fit: cover;
        object-position: center;
        border-radius: inherit;
        box-shadow: none;
      }

      .movie-hero__details {
        grid-area: details;
        background: var(--movie-panel-gradient);
        border-radius: 1.25rem;
        border: 1px solid var(--movie-border);
        box-shadow: var(--movie-card-shadow);
        padding: 1.25rem;
      }

      .movie-hero__scorecard {
        grid-area: scorecard;
        border-radius: 1.25rem;
        border: 1px solid var(--movie-border);
        margin-top: 0;
        height: 100%;
        background: var(--movie-panel-gradient);
        box-shadow: var(--movie-card-shadow);
        padding: 1.25rem;
        display: flex;
        flex-direction: column;
        gap: 1rem;
        position: relative;
        padding-top: 4.6rem;
      }

      .season-page .movie-hero__scorecard {
        padding-top: 5.15rem;
      }

      .movie-hero__poster .floating.ui.mrating {
        top: 6px;
        right: 6px;
      }

      .movie-hero__scorecard .movie-score {
        margin-top: 0;
      }

      .ui.container[role="main"] {
        margin-left: 0.25rem !important;
        margin-right: 0.25rem !important;
      }

      .movie-hero__poster:hover {
        box-shadow: 0 6px 12px rgba(15, 23, 42, 0.08),
                    0 16px 32px rgba(15, 23, 42, 0.1),
                    0 28px 56px rgba(15, 23, 42, 0.12);
      }

      .dark .movie-hero__poster:hover {
        box-shadow: 0 4px 10px rgba(0, 0, 0, 0.28),
                    0 14px 24px rgba(0, 0, 0, 0.35),
                    0 22px 44px rgba(0, 0, 0, 0.42);
      }
    }

    /* Mobile Action Buttons - larger touch targets */
    @media (max-width: 700px) {
      /* Mobile rating button on poster */
      .movie-hero__poster .mobile-rating-btn {
        position: absolute;
        top: 6px;
        right: 6px;
        min-width: 30px;
        min-height: 30px;
        display: flex;
        align-items: center;
        justify-content: center;
        background: rgba(0, 0, 0, 0.55);
        border-radius: 4px;
        color: #fff;
        font-weight: 600;
        font-size: 1rem;
        cursor: pointer;
        z-index: 10;
        /* border: 1px solid rgba(255, 255, 255, 0.35); */
      }

      .movie-hero__poster .mobile-score-badge {
        position: absolute;
        top: 8px;
        left: 8px;
        min-width: 44px;
        height: 44px;
        padding: 0 0.65rem;
        display: flex;
        align-items: center;
        justify-content: center;
        border-radius: 999px;
        color: #fff;
        font-weight: 700;
        font-size: 1.35rem;
        line-height: 1;
        box-shadow: 0 8px 18px rgba(15, 23, 42, 0.22);
        z-index: 10;
      }

      .dark .movie-hero__poster .mobile-score-badge {
        box-shadow: 0 8px 18px rgba(0, 0, 0, 0.35);
      }

      .movie-hero__poster .mobile-rating-btn:not(.has-rating) {
        opacity: 1;
        transform: none;
        box-shadow: none;
      }

      .movie-hero__poster .mobile-rating-btn.has-rating {
        background: rgba(219, 40, 40, 0.9);
        color: #fff;
        border-color: transparent;
      }

      .dark .movie-hero__poster .mobile-rating-btn:not(.has-rating) {
        background: rgba(0, 0, 0, 0.45);
        color: #fff;
        border-color: rgba(255, 255, 255, 0.35);
      }

      .movie-hero__poster .mobile-rating-btn:active {
        transform: scale(0.95);
      }

      /* Hide desktop rating label on mobile */
      .movie-hero__poster .floating.ui.mrating.label {
        display: none !important;
      }

      .movie-hero__scorecard .movie-score {
        display: none;
      }
    }

    /* Desktop: hide mobile wrappers */
    @media (min-width: 701px) {
      .movie-hero__poster .mobile-rating-btn {
        display: none !important;
      }
    }

    /* Mobile: Convert standard modals to bottom sheets */
    @media (max-width: 700px) {
      .ui.modal.rate,
      .ui.modal.lists {
        position: fixed !important;
        bottom: 0 !important;
        top: auto !important;
        left: 0 !important;
        right: 0 !important;
        margin: 0 !important;
        border-radius: 16px 16px 0 0 !important;
        max-height: 85vh;
        width: 100% !important;
        transform: translateY(100%);
        transition: transform 0.3s cubic-bezier(0.32, 0.72, 0, 1);
      }

      .ui.modal.rate.visible.active,
      .ui.modal.lists.visible.active {
        transform: translateY(0);
      }

      .ui.modal.rate > .header,
      .ui.modal.lists > .header {
        border-radius: 16px 16px 0 0 !important;
        text-align: center;
        padding: 1.25rem 1rem !important;
        font-size: 1.1rem;
        position: relative;
      }

      .ui.modal.rate > .header::before,
      .ui.modal.lists > .header::before {
        content: '';
        position: absolute;
        top: 8px;
        left: 50%;
        transform: translateX(-50%);
        width: 36px;
        height: 4px;
        background: rgba(128, 128, 128, 0.4);
        border-radius: 2px;
      }

      .ui.modal.rate > .content,
      .ui.modal.lists > .content {
        padding: 1rem 1.25rem 1.5rem !important;
      }

      .ui.modal.rate > .actions,
      .ui.modal.lists > .actions {
        display: flex;
        flex-direction: column;
        gap: 0.75rem;
        padding: 0 1.25rem 1.5rem !important;
        background: transparent !important;
        border-top: none !important;
      }

      .ui.modal.rate > .actions .button,
      .ui.modal.lists > .actions .button {
        margin: 0 !important;
        padding: 1rem !important;
        font-size: 1rem;
        border-radius: 12px !important;
        width: 100%;
      }

      .ui.modal.rate > .actions .positive.button,
      .ui.modal.lists > .actions .positive.button {
        order: -1;
      }

      /* Rating modal specific */
      .ui.modal.rate .ui.rating {
        font-size: 1.5rem !important;
      }

      .ui.modal.rate .rating-readout {
        font-size: 1rem !important;
        margin-top: 0.75rem !important;
      }

      /* Lists modal specific - improve dropdown usability */
      .ui.modal.lists .ui.dropdown {
        font-size: 1rem;
      }

      .ui.modal.lists .ui.dropdown .menu {
        max-height: 40vh;
      }

      .ui.modal.lists .added-lists {
        margin-top: 1rem;
      }

      .ui.modal.lists .added-lists .ui.label {
        margin: 0.25rem;
        padding: 0.6rem 0.8rem;
        font-size: 0.9rem;
      }

      /* Safe area for iOS */
      @supports (padding-bottom: env(safe-area-inset-bottom)) {
        .ui.modal.rate > .actions,
        .ui.modal.lists > .actions {
          padding-bottom: calc(1.5rem + env(safe-area-inset-bottom)) !important;
        }
      }

      /* Dark mode */
      .dark .ui.modal.rate,
      .dark .ui.modal.lists {
        background: var(--movie-surface) !important;
      }

      .dark .ui.modal.rate > .header,
      .dark .ui.modal.lists > .header {
        background: var(--movie-surface) !important;
        color: var(--movie-text) !important;
      }

      .dark .ui.modal.rate > .content,
      .dark .ui.modal.lists > .content {
        background: var(--movie-surface) !important;
        color: var(--movie-text) !important;
      }
    }

    /* ── Episode Rating Matrix ─────────────────────────────────────────── */

    .ep-matrix-thumb {
      cursor: pointer;
      line-height: 0;
    }

    .ep-matrix-thumb img {
      filter: grayscale(1);
      transition: filter 0.2s ease;
    }

    .ep-matrix-thumb:hover img {
      filter: grayscale(0);
    }

    /* Matrix full view — hidden until ep-matrix-mode is active */
    .ep-matrix-view {
      display: none;
    }

    .movie-main.ep-matrix-mode > *:not(.ep-matrix-view) {
      display: none !important;
    }

    .movie-main.ep-matrix-mode .ep-matrix-view {
      display: block;
    }

    .ep-matrix__header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      margin-bottom: 10px;
    }

    .ep-matrix__title {
      font-size: 0.9rem;
      font-weight: 700;
      color: var(--movie-text);
    }

    .ep-matrix__back {
      background: transparent;
      border: 1px solid var(--movie-border);
      color: var(--movie-muted);
      border-radius: 6px;
      padding: 3px 10px;
      font-size: 0.78rem;
      cursor: pointer;
      transition: color 0.15s ease, border-color 0.15s ease;
      font-family: inherit;
    }

    .ep-matrix__back:hover {
      color: var(--movie-text);
      border-color: var(--movie-text);
    }

    .ep-matrix__header-end {
      display: flex;
      align-items: center;
      gap: 6px;
    }

    .ep-matrix__download {
      display: inline-flex;
      align-items: center;
      gap: 4px;
      background: transparent;
      border: 1px solid var(--movie-border);
      color: var(--movie-muted);
      border-radius: 6px;
      padding: 3px 10px;
      font-size: 0.78rem;
      cursor: pointer;
      transition: color 0.15s ease, border-color 0.15s ease;
      font-family: inherit;
    }

    .ep-matrix__download:hover {
      color: var(--movie-text);
      border-color: var(--movie-text);
    }

    .ep-matrix__legend {
      display: flex;
      flex-wrap: wrap;
      gap: 5px 10px;
      margin-top: 10px;
    }

    .ep-matrix__legend-item {
      display: flex;
      align-items: center;
      gap: 4px;
      font-size: 9px;
      color: var(--movie-muted);
      font-weight: 600;
      letter-spacing: 0.03em;
    }

    .ep-matrix__legend-dot {
      width: 10px;
      height: 10px;
      border-radius: 2px;
      flex-shrink: 0;
    }

    /* Outer wrapper: holds the scroll area + right-edge gradient overlay */
    .ep-matrix__scroll-outer {
      position: relative;
      border-bottom: 1px solid var(--movie-border);
    }

    .ep-matrix__left-shadow {
      position: absolute;
      top: 0;
      left: var(--ep-label-width, 36px);
      bottom: 0;
      width: 40px;
      background: linear-gradient(to right, var(--movie-matrix-bg), transparent);
      pointer-events: none;
      opacity: 0;
      transition: opacity 0.25s ease;
      z-index: 5;
    }

    .ep-matrix__scroll-outer.show-left-shadow .ep-matrix__left-shadow {
      opacity: 1;
    }

    .ep-matrix__scroll-outer::after {
      content: '';
      position: absolute;
      top: 0;
      right: 0;
      bottom: 0;
      width: 60px;
      background: linear-gradient(to right, transparent, var(--movie-matrix-bg));
      pointer-events: none;
      opacity: 0;
      transition: opacity 0.25s ease;
      z-index: 4;
    }

    .ep-matrix__scroll-outer.show-gradient::after {
      opacity: 1;
    }

    .ep-matrix__scroll {
      overflow-x: auto;
      -webkit-overflow-scrolling: touch;
      padding-bottom: 10px;
      scroll-snap-type: x mandatory;
    }

    .ep-matrix__table {
      border-collapse: separate;
      border-spacing: 3px;
      font-size: 11px;
      margin: 0 auto;
      min-width: 80%;
    }

    /* Sticky: season label column (left) */
    .ep-matrix__corner {
      position: sticky;
      left: 0;
      z-index: 3;
      background: transparent;
    }

    .ep-matrix__season-label {
      position: sticky;
      left: 0;
      z-index: 2;
      background: var(--movie-matrix-bg);
      border-right: 2px solid var(--movie-border);
      font-weight: 700;
      color: var(--movie-muted);
      font-size: 10px;
      padding-right: 6px;
      white-space: nowrap;
      vertical-align: middle;
    }

    .dark .ep-matrix__season-label {
      color: var(--movie-muted);
    }

    .ep-matrix__ep-header {
      color: var(--movie-muted);
      font-size: 9px;
      text-align: center;
      padding: 0 1px 4px;
      font-weight: 600;
      white-space: nowrap;
      scroll-snap-align: start;
    }

    /* Sticky: AVG column (right) */
    .ep-matrix__avg-header {
      position: sticky;
      right: 0;
      z-index: 3;
      background: transparent;
      padding-left: 6px;
      scroll-snap-align: none;
    }

    .ep-matrix__cell {
      min-width: 34px;
      height: 24px;
      line-height: 24px;
      border-radius: 4px;
      text-align: center;
      font-size: 10px;
      font-weight: 700;
      vertical-align: middle;
      white-space: nowrap;
    }

    .ep-matrix__cell--empty {
      background: var(--movie-surface-alt) !important;
      color: var(--movie-muted) !important;
      opacity: 0.5;
    }

    .ep-matrix__cell--absent {
      background: transparent !important;
      border: none;
      pointer-events: none;
    }

    .ep-matrix__cell--avg {
      position: sticky;
      right: 0;
      z-index: 2;
      background: var(--movie-matrix-bg) !important;
      border-left: 2px solid var(--movie-border);
      padding-left: 3px;
      padding-right: 6px;
      color: var(--movie-text) !important;
      font-weight: 700;
    }

    /* Large shows (>20 max eps): compact cells */
    .ep-matrix__scroll--large .ep-matrix__cell {
      min-width: 28px;
      height: 22px;
      line-height: 22px;
      font-size: 9px;
    }

    @media (max-width: 700px) {
      .ep-matrix-thumb {
        margin-top: 6px;
      }
      .ep-matrix__cell {
        min-width: 28px;
        height: 22px;
        line-height: 22px;
        font-size: 9px;
      }
    }

    /* ── Top Action Bar ── */
    .movie-action-topbar {
      display: none;
    }

    .movie-hero__scorecard:has(.movie-action-block) {
      padding-top: 1.25rem;
    }

    .movie-action-block {
      margin: auto -1.25rem 0;
      border-top: 1px solid var(--movie-border);
      border-bottom-left-radius: calc(1.25rem - 1px);
      border-bottom-right-radius: calc(1.25rem - 1px);
      overflow: hidden;
      background: rgba(128, 128, 128, 0.035);
    }

    .movie-action-topbar:has(.mobile-top-btn) {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
      gap: 0;
      margin: 0;
      border-bottom: 1px solid var(--movie-border);
      overflow: hidden;
    }

    .movie-action-topbar .mobile-top-btn {
      display: flex;
      align-items: center;
      justify-content: center;
      min-height: 34px;
      padding: 0.45rem 0.5rem;
      cursor: pointer;
      transition: background 0.18s ease;
      user-select: none;
      -webkit-tap-highlight-color: transparent;
    }

    .movie-action-topbar .mobile-top-btn + .mobile-top-btn {
      position: relative;
    }

    .movie-action-topbar .mobile-top-btn + .mobile-top-btn::before {
      content: '';
      position: absolute;
      left: 0;
      top: 50%;
      transform: translateY(-50%);
      width: 1px;
      height: 55%;
      background: var(--movie-border);
    }

    .movie-action-topbar .mobile-top-btn:hover {
      background: rgba(128, 128, 128, 0.15);
    }

    .movie-action-topbar .mobile-top-btn:active {
      filter: brightness(0.82);
    }

    .movie-action-topbar .mobile-top-btn i.icon {
      font-size: 0.95rem;
      margin: 0 !important;
      line-height: 1;
      filter: grayscale(1);
      opacity: 0.45;
      transition: filter 0.15s ease, opacity 0.15s ease;
    }

    .movie-action-topbar .mobile-top-btn img {
      width: 16px;
      height: 16px;
      object-fit: contain;
      filter: grayscale(1);
      opacity: 0.45;
      transition: filter 0.15s ease, opacity 0.15s ease;
    }

    .movie-action-topbar .mobile-top-btn.is-active i.icon {
      filter: grayscale(0.3);
      opacity: 0.8;
    }

    .movie-action-topbar .mobile-top-btn.is-active img {
      filter: grayscale(0.3);
      opacity: 0.8;
    }

    .movie-action-topbar .mobile-top-btn:hover i.icon {
      filter: none;
      opacity: 1;
    }

    .movie-action-topbar .mobile-top-btn:hover img {
      filter: none;
      opacity: 1;
    }

    .movie-action-topbar .mobile-top-btn.is-disabled i.icon,
    .movie-action-topbar .mobile-top-btn.is-disabled img {
      filter: grayscale(1);
      opacity: 0.25;
    }

    .movie-action-topbar .mobile-top-btn.is-disabled:hover i.icon,
    .movie-action-topbar .mobile-top-btn.is-disabled:hover img {
      filter: grayscale(1);
      opacity: 0.25;
    }

    .movie-action-topbar .mobile-top-btn.is-disabled {
      cursor: default;
      color: #9ca3af !important;
    }

    .movie-action-topbar .mobile-top-btn.is-disabled {
      background: transparent;
    }

    .movie-action-topbar .mobile-top-btn.is-disabled:hover {
      background: transparent;
    }

    .movie-action-topbar .mobile-top-btn.is-disabled:active {
      filter: none;
    }

    .dark .movie-action-topbar .mobile-top-btn.is-disabled {
      color: rgba(148, 163, 184, 0.9) !important;
    }

    @media (max-width: 700px) {
      .movie-hero__scorecard .movie-action-block {
        position: relative;
        left: auto;
        right: auto;
        bottom: auto;
        margin: auto -1.25rem 0;
      }

      .movie-action-topbar .mobile-top-btn {
        min-height: 38px;
      }
    }

    /* ── Bottom Action Tab Bar ── */
    .movie-hero__scorecard:has(.mobile-action-bar) {
      padding-bottom: 0;
    }

    .mobile-action-bar {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 0;
      margin: 0;
      overflow: hidden;
    }

    .movie-hero__scorecard > .mobile-action-bar {
      margin: auto -1.25rem 0;
      border-top: 1px solid var(--movie-border);
      border-bottom-left-radius: calc(1.25rem - 1px);
      border-bottom-right-radius: calc(1.25rem - 1px);
      background: rgba(128, 128, 128, 0.035);
    }

    .mobile-action-bar .mobile-tab-btn {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      padding: 0.75rem 0.25rem 0.85rem;
      gap: 0.35rem;
      cursor: pointer;
      transition: background 0.18s ease;
      text-align: center;
      user-select: none;
      -webkit-tap-highlight-color: transparent;
    }

    .mobile-action-bar .mobile-tab-btn + .mobile-tab-btn {
      border-left: 1px solid var(--movie-border);
    }

    .mobile-action-bar .mobile-tab-btn:hover {
      background: rgba(128, 128, 128, 0.15);
    }

    .mobile-action-bar .mobile-tab-btn:has(i.purple):hover {
      background: rgba(149, 91, 165, 0.22);
    }

    .mobile-action-bar .mobile-tab-btn:has(i.blue):hover {
      background: rgba(33, 133, 208, 0.2);
    }

    .mobile-action-bar .mobile-tab-btn:has(i.orange):hover {
      background: rgba(242, 113, 28, 0.2);
    }

    .mobile-action-bar .mobile-tab-btn:has(i.teal):hover {
      background: rgba(0, 181, 173, 0.2);
    }

    .mobile-action-bar .mobile-tab-btn:active {
      filter: brightness(0.82);
    }

    .mobile-action-bar .mobile-tab-btn i.icon {
      font-size: 1.3rem;
      margin: 0 !important;
      line-height: 1;
    }

    .mobile-action-bar .mobile-tab-btn span {
      font-size: 0.68rem;
      font-weight: 500;
      color: var(--movie-muted);
      line-height: 1.2;
      white-space: nowrap;
    }

    @media (max-width: 700px) {
      .movie-hero__scorecard:has(.mobile-action-bar) {
        padding-top: 1.25rem;
      }

      .season-page .movie-hero__scorecard:has(.mobile-action-bar) {
        padding-top: 4rem;
      }
    }
