body.portal-body .portalv2-content {
  padding-top: 1rem;
}

.no-volume-support .portal-volume-control {
  display: none !important;
}

/* When volume is hidden, let balance take full width */
.no-volume-support .portal-player-card .row > [class*="col-md-6"]:not(.portal-volume-control) {
  flex: 0 0 100%;
  max-width: 100%;
}

.portal-body .container,
.portal-body .container-fluid {
  max-width: 1440px;
}

.portal-body .text-muted,
.portal-body .small,
.portal-body .text-secondary {
  color: var(--portalv2-text-muted) !important;
}

.portal-body a {
  color: #7fe7ff;
}

.portal-body a:hover {
  color: #baf3ff;
  text-decoration: none;
}

.portal-body .breadcrumb {
  background: transparent;
  margin-bottom: 0.35rem;
}

.portal-body .breadcrumb-item,
.portal-body .breadcrumb-item a {
  color: rgba(191, 212, 232, 0.76);
}

.portal-body .breadcrumb-item + .breadcrumb-item::before {
  color: rgba(98, 133, 171, 0.72);
}

.portal-route-calls-playlists .nav-tabs {
  gap: 0.75rem;
  margin-bottom: 1rem !important;
  border-bottom: 1px solid rgba(95, 127, 160, 0.16);
}

.portal-route-calls-playlists .nav-tabs .nav-item {
  margin-bottom: 0;
}

.portal-route-calls-playlists .nav-tabs .nav-link {
  border: 1px solid transparent;
  border-radius: 16px 16px 0 0;
  padding: 0.9rem 1.35rem;
  color: #80e8ff;
  background: transparent;
  font-size: 0.98rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.portal-route-calls-playlists .nav-tabs .nav-link:hover {
  border-color: rgba(95, 127, 160, 0.16);
  background: rgba(18, 32, 48, 0.78);
  color: #b8f6ff;
}

.portal-route-calls-playlists .nav-tabs .nav-link.active {
  border-color: rgba(95, 127, 160, 0.18);
  border-bottom-color: rgba(18, 32, 48, 0.94);
  background: linear-gradient(180deg, rgba(24, 39, 58, 0.98), rgba(18, 32, 48, 0.94));
  color: #f2f8ff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

.portal-page-hero,
.portal-route-calls-home .border-bottom:first-of-type,
.portal-route-calls-playlists .w-lg-75.text-center,
.portal-route-calls-trs-console .w-lg-75.text-center,
.portal-route-calls-coverage .w-lg-75.text-center,
.portal-route-calls-status .w-lg-75.text-center,
.portal-route-calls-tg .w-lg-75.text-center,
.portal-route-calls-fid .w-lg-75.text-center,
.portal-route-calls-trs .w-lg-75.text-center,
.portal-route-calls-node .w-lg-75.text-center {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(95, 127, 160, 0.16);
  border-radius: 24px;
  background:
    radial-gradient(800px 340px at 0% 0%, rgba(57, 208, 255, 0.14), transparent 60%),
    radial-gradient(800px 360px at 100% 0%, rgba(70, 117, 255, 0.14), transparent 62%),
    linear-gradient(180deg, rgba(13, 24, 38, 0.98), rgba(8, 15, 24, 0.98));
  box-shadow: var(--portalv2-shadow);
}

.portal-page-hero::after,
.portal-route-calls-home .border-bottom:first-of-type::after,
.portal-route-calls-playlists .w-lg-75.text-center::after,
.portal-route-calls-trs-console .w-lg-75.text-center::after,
.portal-route-calls-coverage .w-lg-75.text-center::after,
.portal-route-calls-status .w-lg-75.text-center::after,
.portal-route-calls-tg .w-lg-75.text-center::after,
.portal-route-calls-fid .w-lg-75.text-center::after,
.portal-route-calls-trs .w-lg-75.text-center::after,
.portal-route-calls-node .w-lg-75.text-center::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.03), transparent);
  pointer-events: none;
}

.portal-route-calls-home .border-bottom:first-of-type {
  margin-bottom: 1rem;
  border-bottom: 1px solid rgba(95, 127, 160, 0.16) !important;
}

.portal-route-calls-home .border-bottom:first-of-type .container {
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.portal-route-calls-home h1,
.portal-route-calls-playlists h3,
.portal-route-calls-trs-console h3,
.portal-route-calls-coverage h3,
.portal-route-calls-status h3,
.portal-route-calls-tg h3,
.portal-route-calls-fid h3,
.portal-route-calls-trs h3,
.portal-route-calls-node h3 {
  color: #f4fbff;
}

.portal-route-calls-home .lead,
.portal-route-calls-playlists .w-lg-75.text-center p,
.portal-route-calls-trs-console .w-lg-75.text-center p {
  color: rgba(214, 232, 247, 0.82);
}

.portal-route-calls-playlists .w-lg-75.text-center,
.portal-route-calls-trs-console .w-lg-75.text-center,
.portal-route-calls-coverage .w-lg-75.text-center,
.portal-route-calls-status .w-lg-75.text-center,
.portal-route-calls-tg .w-lg-75.text-center,
.portal-route-calls-fid .w-lg-75.text-center,
.portal-route-calls-trs .w-lg-75.text-center,
.portal-route-calls-node .w-lg-75.text-center {
  width: 100% !important;
  max-width: 100% !important;
  margin-bottom: 1rem;
  padding: 1.4rem 1.75rem !important;
}

.portal-kicker {
  display: none;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0.75rem;
  padding: 0.42rem 0.72rem;
  border-radius: 999px;
  border: 1px solid rgba(127, 231, 255, 0.14);
  background: rgba(57, 208, 255, 0.08);
  color: #90f1ff;
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.portal-kicker::before {
  content: "";
  width: 0.55rem;
  height: 0.55rem;
  border-radius: 50%;
  background: #39d0ff;
  box-shadow: 0 0 12px rgba(57, 208, 255, 0.72);
}

.calls-home-link-row .btn,
.portal-body .btn-wide {
  min-width: 170px;
}

.calls-home-link-row--portal {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.9rem;
}

.calls-home-link-row--portal .btn {
  min-width: 210px;
  padding: 0.9rem 1.35rem;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.portal-body .btn-soft-primary,
.portal-body .btn-primary {
  background: linear-gradient(135deg, #39d0ff, #92efff);
  border-color: transparent;
  color: #061019;
  box-shadow: 0 10px 22px rgba(57, 208, 255, 0.18);
}

.portal-body .btn-soft-secondary,
.portal-body .btn-outline-secondary,
.portal-body .btn-secondary {
  background: rgba(17, 31, 47, 0.9);
  border-color: rgba(95, 127, 160, 0.24);
  color: #dcecff;
}

.portal-body .btn-soft-success,
.portal-body .btn-success {
  background: linear-gradient(135deg, #81ff74, #d9ff90);
  border-color: transparent;
  color: #0c1808;
}

.portal-body .btn-warning {
  color: #221400;
}

/* Two-column grid only when the shell has both player card + controls card */
.portal-route-calls-playlists .portal-monitor-player-shell:has(.portal-player-card__controls-card) {
  display: grid;
  gap: 1rem;
  grid-template-columns: minmax(0, 1.15fr) minmax(360px, 0.95fr);
  align-items: stretch;
  margin-bottom: 1.5rem;
}

.portal-route-calls-playlists .portal-player-card,
.portal-route-calls-playlists .portal-player-card__controls-card,
.portal-route-calls-tg .portal-player-card,
.portal-route-calls-tg .portal-player-card__controls-card,
.portal-route-calls-fid .portal-player-card,
.portal-route-calls-fid .portal-player-card__controls-card,
.portal-route-calls-trs .portal-player-card,
.portal-route-calls-trs .portal-player-card__controls-card,
.portal-route-calls-node .portal-player-card,
.portal-route-calls-node .portal-player-card__controls-card {
  overflow: hidden;
  border-radius: 28px;
  background:
    radial-gradient(820px 260px at 0% 0%, rgba(57, 208, 255, 0.08), transparent 62%),
    radial-gradient(820px 300px at 100% 0%, rgba(15, 89, 178, 0.1), transparent 65%),
    linear-gradient(180deg, rgba(10, 22, 36, 0.98), rgba(5, 12, 21, 0.99));
  height: 100%;
}

/* Allow dropdown menus to overflow the controls card */
.portal-route-calls-playlists .portal-player-card__controls-card,
.portal-route-calls-trs .portal-player-card__controls-card,
.portal-route-calls-node .portal-player-card__controls-card {
  overflow: visible !important;
}

/* Elevate the entire player shell so open dropdowns paint above sibling content (lockout card, table, etc.) */
.portal-route-calls-playlists .portal-monitor-player-shell,
.portal-route-calls-trs .portal-monitor-player-shell,
.portal-route-calls-node .portal-monitor-player-shell {
  position: relative;
  z-index: 2;
}

.portal-route-calls-playlists .player-card.player-card-live,
.portal-route-calls-playlists .portal-player-card.player-card-live,
.portal-route-calls-trs-console .player-card.player-card-live,
.portal-route-calls-tg .player-card.player-card-live,
.portal-route-calls-tg .portal-player-card.player-card-live,
.portal-route-calls-fid .player-card.player-card-live,
.portal-route-calls-fid .portal-player-card.player-card-live,
.portal-route-calls-trs .player-card.player-card-live,
.portal-route-calls-trs .portal-player-card.player-card-live,
.portal-route-calls-node .player-card.player-card-live,
.portal-route-calls-node .portal-player-card.player-card-live {
  border-color: rgba(255, 146, 64, 0.78) !important;
  box-shadow: 0 0 0 1px rgba(255, 146, 64, 0.22), 0 0 28px rgba(255, 138, 52, 0.12), var(--portalv2-shadow);
}

.portal-route-calls-playlists .portal-player-card > .card-header,
.portal-route-calls-playlists .portal-player-card__controls-card > .card-header,
.portal-route-calls-tg .portal-player-card > .card-header,
.portal-route-calls-tg .portal-player-card__controls-card > .card-header,
.portal-route-calls-fid .portal-player-card > .card-header,
.portal-route-calls-fid .portal-player-card__controls-card > .card-header,
.portal-route-calls-trs .portal-player-card > .card-header,
.portal-route-calls-trs .portal-player-card__controls-card > .card-header,
.portal-route-calls-node .portal-player-card > .card-header,
.portal-route-calls-node .portal-player-card__controls-card > .card-header {
  padding: 0.75rem 1.2rem;
  border-bottom: 1px solid rgba(95, 127, 160, 0.16);
  background: linear-gradient(90deg, rgba(57, 208, 255, 0.14), rgba(57, 208, 255, 0.04)) !important;
  color: #eef8ff;
  font-size: 0.95rem;
  font-weight: 700;
}

.portal-route-calls-playlists .portal-player-card > .card-header .small,
.portal-route-calls-tg .portal-player-card > .card-header .small,
.portal-route-calls-fid .portal-player-card > .card-header .small,
.portal-route-calls-trs .portal-player-card > .card-header .small,
.portal-route-calls-node .portal-player-card > .card-header .small {
  color: rgba(195, 220, 240, 0.78) !important;
  font-size: 0.78rem;
}

.portal-route-calls-playlists .portal-player-header-bar,
.portal-route-calls-trs-console .portal-player-header-bar,
.portal-route-calls-tg .portal-player-header-bar,
.portal-route-calls-fid .portal-player-header-bar,
.portal-route-calls-trs .portal-player-header-bar,
.portal-route-calls-node .portal-player-header-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  width: 100%;
  min-width: 0;
}

.portal-route-calls-playlists .portal-player-header-title,
.portal-route-calls-trs-console .portal-player-header-title,
.portal-route-calls-tg .portal-player-header-title,
.portal-route-calls-fid .portal-player-header-title,
.portal-route-calls-trs .portal-player-header-title,
.portal-route-calls-node .portal-player-header-title {
  min-width: 0;
}

.portal-route-calls-playlists .portal-player-header-status,
.portal-route-calls-trs-console .portal-player-header-status,
.portal-route-calls-tg .portal-player-header-status,
.portal-route-calls-fid .portal-player-header-status,
.portal-route-calls-trs .portal-player-header-status,
.portal-route-calls-node .portal-player-header-status {
  margin-left: auto;
  text-align: right;
  white-space: nowrap;
  flex-shrink: 0;
}

.portal-route-calls-playlists .portal-player-card > .card-header.portal-player-header-holding,
.portal-route-calls-playlists .player-card > .card-header.portal-player-header-holding,
.portal-route-calls-trs-console .player-card > .card-header.portal-player-header-holding,
.portal-route-calls-tg .portal-player-card > .card-header.portal-player-header-holding,
.portal-route-calls-tg .player-card > .card-header.portal-player-header-holding,
.portal-route-calls-fid .portal-player-card > .card-header.portal-player-header-holding,
.portal-route-calls-fid .player-card > .card-header.portal-player-header-holding,
.portal-route-calls-trs .portal-player-card > .card-header.portal-player-header-holding,
.portal-route-calls-trs .player-card > .card-header.portal-player-header-holding,
.portal-route-calls-node .portal-player-card > .card-header.portal-player-header-holding,
.portal-route-calls-node .player-card > .card-header.portal-player-header-holding {
  background:
    linear-gradient(90deg, rgba(255, 174, 72, 0.34), rgba(255, 122, 36, 0.2)) !important;
  border-bottom-color: rgba(255, 172, 82, 0.32);
  color: #fff7df;
  box-shadow: inset 0 -1px 0 rgba(255, 198, 118, 0.08);
}

.portal-route-calls-playlists .portal-player-header-holding .portal-player-header-status,
.portal-route-calls-playlists .portal-player-header-holding .small,
.portal-route-calls-trs-console .portal-player-header-holding .portal-player-header-status,
.portal-route-calls-trs-console .portal-player-header-holding .small,
.portal-route-calls-tg .portal-player-header-holding .portal-player-header-status,
.portal-route-calls-tg .portal-player-header-holding .small,
.portal-route-calls-fid .portal-player-header-holding .portal-player-header-status,
.portal-route-calls-fid .portal-player-header-holding .small,
.portal-route-calls-trs .portal-player-header-holding .portal-player-header-status,
.portal-route-calls-trs .portal-player-header-holding .small,
.portal-route-calls-node .portal-player-header-holding .portal-player-header-status,
.portal-route-calls-node .portal-player-header-holding .small {
  color: #ffe3ad !important;
}

.portal-route-calls-playlists .portal-player-card > .card-header.portal-player-header-stopped,
.portal-route-calls-playlists .player-card > .card-header.portal-player-header-stopped,
.portal-route-calls-trs-console .player-card > .card-header.portal-player-header-stopped,
.portal-route-calls-tg .portal-player-card > .card-header.portal-player-header-stopped,
.portal-route-calls-tg .player-card > .card-header.portal-player-header-stopped,
.portal-route-calls-fid .portal-player-card > .card-header.portal-player-header-stopped,
.portal-route-calls-fid .player-card > .card-header.portal-player-header-stopped,
.portal-route-calls-trs .portal-player-card > .card-header.portal-player-header-stopped,
.portal-route-calls-trs .player-card > .card-header.portal-player-header-stopped,
.portal-route-calls-node .portal-player-card > .card-header.portal-player-header-stopped,
.portal-route-calls-node .player-card > .card-header.portal-player-header-stopped {
  background:
    linear-gradient(90deg, rgba(178, 35, 35, 0.42), rgba(126, 16, 16, 0.26)) !important;
  border-bottom-color: rgba(226, 88, 88, 0.28);
  color: #ffe9e9;
  box-shadow: inset 0 -1px 0 rgba(255, 128, 128, 0.08);
}

.portal-route-calls-playlists .portal-player-header-stopped .portal-player-header-status,
.portal-route-calls-playlists .portal-player-header-stopped .small,
.portal-route-calls-trs-console .portal-player-header-stopped .portal-player-header-status,
.portal-route-calls-trs-console .portal-player-header-stopped .small,
.portal-route-calls-tg .portal-player-header-stopped .portal-player-header-status,
.portal-route-calls-tg .portal-player-header-stopped .small,
.portal-route-calls-fid .portal-player-header-stopped .portal-player-header-status,
.portal-route-calls-fid .portal-player-header-stopped .small,
.portal-route-calls-trs .portal-player-header-stopped .portal-player-header-status,
.portal-route-calls-trs .portal-player-header-stopped .small,
.portal-route-calls-node .portal-player-header-stopped .portal-player-header-status,
.portal-route-calls-node .portal-player-header-stopped .small {
  color: #ffb0b0 !important;
}

.portal-route-calls-playlists .portal-player-card .card-body,
.portal-route-calls-tg .portal-player-card .card-body,
.portal-route-calls-fid .portal-player-card .card-body,
.portal-route-calls-trs .portal-player-card .card-body,
.portal-route-calls-node .portal-player-card .card-body {
  padding: 1rem 1.1rem 1.1rem;
}

.portal-route-calls-playlists .portal-player-card .row.mb-0,
.portal-route-calls-tg .portal-player-card .row.mb-0,
.portal-route-calls-fid .portal-player-card .row.mb-0,
.portal-route-calls-trs .portal-player-card .row.mb-0,
.portal-route-calls-node .portal-player-card .row.mb-0 {
  display: flex;
  flex-wrap: wrap;
  margin-right: -0.5rem;
  margin-left: -0.5rem;
}

.portal-route-calls-playlists .portal-player-card .row.mb-0 > [class*="col-"],
.portal-route-calls-tg .portal-player-card .row.mb-0 > [class*="col-"],
.portal-route-calls-fid .portal-player-card .row.mb-0 > [class*="col-"],
.portal-route-calls-trs .portal-player-card .row.mb-0 > [class*="col-"],
.portal-route-calls-node .portal-player-card .row.mb-0 > [class*="col-"] {
  flex: 1 1 220px;
  max-width: 100%;
  padding-right: 0.5rem;
  padding-left: 0.5rem;
}

.portal-route-calls-playlists .portal-player-card__controls-card .card-body,
.portal-route-calls-tg .portal-player-card__controls-card .card-body,
.portal-route-calls-fid .portal-player-card__controls-card .card-body,
.portal-route-calls-trs .portal-player-card__controls-card .card-body,
.portal-route-calls-node .portal-player-card__controls-card .card-body {
  padding: 1.05rem 1.1rem 1rem;
}

.portal-route-calls-playlists .portal-player-card__meta-sep {
  color: rgba(130, 170, 208, 0.6);
}

.portal-route-calls-playlists .portal-monitor-controls,
.portal-route-calls-tg .portal-monitor-controls,
.portal-route-calls-fid .portal-monitor-controls,
.portal-route-calls-trs .portal-monitor-controls,
.portal-route-calls-node .portal-monitor-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  align-items: flex-start;
}

.portal-route-calls-playlists .portal-player-card__group .btn,
.portal-route-calls-playlists .portal-player-card__dropdown .btn,
.portal-route-calls-playlists .portal-player-card__icon,
.portal-route-calls-playlists .portal-player-card__primary,
.portal-route-calls-tg .portal-player-card__group .btn,
.portal-route-calls-tg .portal-player-card__icon,
.portal-route-calls-tg .portal-player-card__primary,
.portal-route-calls-fid .portal-player-card__group .btn,
.portal-route-calls-fid .portal-player-card__icon,
.portal-route-calls-fid .portal-player-card__primary,
.portal-route-calls-trs .portal-player-card__group .btn,
.portal-route-calls-trs .portal-player-card__icon,
.portal-route-calls-trs .portal-player-card__primary,
.portal-route-calls-node .portal-player-card__group .btn,
.portal-route-calls-node .portal-player-card__icon,
.portal-route-calls-node .portal-player-card__primary {
  min-height: 3.15rem;
  padding: 0.68rem 1rem;
  border-radius: 16px;
  font-size: 0.94rem;
  font-weight: 700;
}

.portal-route-calls-playlists .portal-player-card__primary,
.portal-route-calls-tg .portal-player-card__primary,
.portal-route-calls-fid .portal-player-card__primary,
.portal-route-calls-trs .portal-player-card__primary,
.portal-route-calls-node .portal-player-card__primary {
  min-width: 8.75rem;
}

.portal-route-calls-playlists .portal-player-card__icon,
.portal-route-calls-tg .portal-player-card__icon,
.portal-route-calls-fid .portal-player-card__icon,
.portal-route-calls-trs .portal-player-card__icon,
.portal-route-calls-node .portal-player-card__icon {
  width: 3.75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.portal-route-calls-playlists .portal-player-card__dropdown .btn {
  min-width: 10.1rem;
}

.portal-route-calls-playlists .portal-player-card__group,
.portal-route-calls-tg .portal-player-card__group,
.portal-route-calls-fid .portal-player-card__group,
.portal-route-calls-trs .portal-player-card__group,
.portal-route-calls-node .portal-player-card__group {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.55rem;
  min-width: 0;
}

.portal-route-calls-playlists .portal-player-card__group .btn,
.portal-route-calls-tg .portal-player-card__group .btn,
.portal-route-calls-fid .portal-player-card__group .btn,
.portal-route-calls-trs .portal-player-card__group .btn,
.portal-route-calls-node .portal-player-card__group .btn {
  width: 3.75rem;
  justify-content: center;
}

.portal-route-calls-playlists .portal-player-card__controls-card .dropdown,
.portal-route-calls-playlists .portal-player-card__controls-card .portal-player-card__icon,
.portal-route-calls-playlists .portal-player-card__controls-card .portal-player-card__primary,
.portal-route-calls-playlists .portal-player-card__controls-card .portal-player-card__group,
.portal-route-calls-tg .portal-player-card__controls-card .dropdown,
.portal-route-calls-tg .portal-player-card__controls-card .portal-player-card__icon,
.portal-route-calls-tg .portal-player-card__controls-card .portal-player-card__primary,
.portal-route-calls-tg .portal-player-card__controls-card .portal-player-card__group,
.portal-route-calls-fid .portal-player-card__controls-card .dropdown,
.portal-route-calls-fid .portal-player-card__controls-card .portal-player-card__icon,
.portal-route-calls-fid .portal-player-card__controls-card .portal-player-card__primary,
.portal-route-calls-fid .portal-player-card__controls-card .portal-player-card__group,
.portal-route-calls-trs .portal-player-card__controls-card .dropdown,
.portal-route-calls-trs .portal-player-card__controls-card .portal-player-card__icon,
.portal-route-calls-trs .portal-player-card__controls-card .portal-player-card__primary,
.portal-route-calls-trs .portal-player-card__controls-card .portal-player-card__group,
.portal-route-calls-node .portal-player-card__controls-card .dropdown,
.portal-route-calls-node .portal-player-card__controls-card .portal-player-card__icon,
.portal-route-calls-node .portal-player-card__controls-card .portal-player-card__primary,
.portal-route-calls-node .portal-player-card__controls-card .portal-player-card__group {
  flex: 0 0 auto;
}

.portal-route-calls-playlists .portal-player-card__controls-card .btn-soft-secondary,
.portal-route-calls-playlists .portal-player-card__controls-card .btn-soft-success,
.portal-route-calls-playlists .portal-player-card__controls-card .btn-soft-info,
.portal-route-calls-tg .portal-player-card__controls-card .btn-soft-secondary,
.portal-route-calls-tg .portal-player-card__controls-card .btn-soft-success,
.portal-route-calls-fid .portal-player-card__controls-card .btn-soft-secondary,
.portal-route-calls-fid .portal-player-card__controls-card .btn-soft-success,
.portal-route-calls-trs .portal-player-card__controls-card .btn-soft-secondary,
.portal-route-calls-trs .portal-player-card__controls-card .btn-soft-success,
.portal-route-calls-node .portal-player-card__controls-card .btn-soft-secondary,
.portal-route-calls-node .portal-player-card__controls-card .btn-soft-success {
  border-color: rgba(95, 127, 160, 0.18) !important;
  background: rgba(13, 25, 39, 0.94) !important;
  color: #e9f4ff !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

.portal-route-calls-playlists .portal-player-card__controls-card .portal-player-card__primary.btn-soft-success,
.portal-route-calls-tg .portal-player-card__controls-card .portal-player-card__primary.btn-soft-success,
.portal-route-calls-fid .portal-player-card__controls-card .portal-player-card__primary.btn-soft-success,
.portal-route-calls-trs .portal-player-card__controls-card .portal-player-card__primary.btn-soft-success,
.portal-route-calls-node .portal-player-card__controls-card .portal-player-card__primary.btn-soft-success {
  background: linear-gradient(180deg, rgba(146, 244, 108, 0.98), rgba(126, 234, 93, 0.98)) !important;
  border-color: rgba(161, 248, 122, 0.82) !important;
  color: #061109 !important;
}

.portal-route-calls-playlists .portal-player-card__controls-card .portal-player-card__primary.btn-soft-danger,
.portal-route-calls-tg .portal-player-card__controls-card .portal-player-card__primary.btn-soft-danger,
.portal-route-calls-fid .portal-player-card__controls-card .portal-player-card__primary.btn-soft-danger,
.portal-route-calls-trs .portal-player-card__controls-card .portal-player-card__primary.btn-soft-danger,
.portal-route-calls-node .portal-player-card__controls-card .portal-player-card__primary.btn-soft-danger {
  background: linear-gradient(180deg, rgba(255, 118, 96, 0.98), rgba(237, 83, 63, 0.98)) !important;
  border-color: rgba(255, 141, 121, 0.82) !important;
  color: #170706 !important;
}

.portal-route-calls-playlists .portal-player-card__slider-panel,
.portal-route-calls-tg .portal-player-card__slider-panel,
.portal-route-calls-fid .portal-player-card__slider-panel,
.portal-route-calls-trs .portal-player-card__slider-panel,
.portal-route-calls-node .portal-player-card__slider-panel {
  display: block !important;
  padding-top: 0.35rem;
}

.portal-route-calls-playlists .portal-player-card__control-row,
.portal-route-calls-playlists .playlist-console-control-row,
.portal-route-calls-trs-console .playlist-console-control-row,
.portal-route-calls-tg .portal-player-card__control-row,
.portal-route-calls-fid .portal-player-card__control-row,
.portal-route-calls-trs .portal-player-card__control-row,
.portal-route-calls-node .portal-player-card__control-row {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  flex-wrap: nowrap;
}

.portal-route-calls-playlists .portal-player-card__slider-label,
.portal-route-calls-playlists .playlist-console-control-label,
.portal-route-calls-trs-console .playlist-console-control-label,
.portal-route-calls-tg .portal-player-card__slider-label,
.portal-route-calls-fid .portal-player-card__slider-label,
.portal-route-calls-trs .portal-player-card__slider-label,
.portal-route-calls-node .portal-player-card__slider-label {
  flex: 0 0 auto;
  width: 7.25rem;
  min-width: 7.25rem;
}

.portal-route-calls-playlists .playlist-console-control-input,
.portal-route-calls-trs-console .playlist-console-control-input {
  flex: 1 1 auto;
  min-width: 0;
}

.portal-route-calls-playlists .portal-player-card__slider-main,
.portal-route-calls-tg .portal-player-card__slider-main,
.portal-route-calls-fid .portal-player-card__slider-main,
.portal-route-calls-trs .portal-player-card__slider-main,
.portal-route-calls-node .portal-player-card__slider-main {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 0.85rem;
}

.portal-route-calls-playlists .portal-player-card__control-row--speed .portal-player-card__slider-main,
.portal-route-calls-tg .portal-player-card__control-row--speed .portal-player-card__slider-main,
.portal-route-calls-fid .portal-player-card__control-row--speed .portal-player-card__slider-main {
  gap: 1rem;
}

.portal-route-calls-playlists .portal-player-card__control-row--speed .portal-player-card__slider-label,
.portal-route-calls-tg .portal-player-card__control-row--speed .portal-player-card__slider-label,
.portal-route-calls-fid .portal-player-card__control-row--speed .portal-player-card__slider-label {
  white-space: nowrap;
  width: 8.75rem;
  min-width: 8.75rem;
}

.portal-route-calls-playlists .portal-player-card__slider-main input[type="range"],
.portal-route-calls-tg .portal-player-card__slider-main input[type="range"],
.portal-route-calls-fid .portal-player-card__slider-main input[type="range"],
.portal-route-calls-trs .portal-player-card__slider-main input[type="range"],
.portal-route-calls-node .portal-player-card__slider-main input[type="range"] {
  flex: 1 1 auto;
  min-width: 0;
}

.portal-route-calls-playlists .playlist-console-control-action,
.portal-route-calls-trs-console .playlist-console-control-action {
  flex: 0 0 auto;
  width: 2.6rem;
  min-width: 2.6rem;
  display: flex;
  justify-content: flex-end;
}

.portal-route-calls-playlists #volumeRow,
.portal-route-calls-playlists #pannerRow,
.portal-route-calls-tg #volumeRow,
.portal-route-calls-tg #pannerRow,
.portal-route-calls-fid #volumeRow,
.portal-route-calls-fid #pannerRow,
.portal-route-calls-trs #volumeRow,
.portal-route-calls-trs #pannerRow,
.portal-route-calls-node #volumeRow,
.portal-route-calls-node #pannerRow {
  height: 100%;
}

.portal-route-calls-playlists .portal-player-card__inline-action,
.portal-route-calls-tg .portal-player-card__inline-action,
.portal-route-calls-fid .portal-player-card__inline-action,
.portal-route-calls-trs .portal-player-card__inline-action,
.portal-route-calls-node .portal-player-card__inline-action {
  width: 2.5rem;
  height: 2.5rem;
  min-height: 2.5rem;
  padding: 0;
  border-radius: 0.8rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  background: linear-gradient(180deg, rgba(15, 29, 46, 0.96), rgba(10, 21, 33, 0.98));
  border: 1px solid rgba(88, 126, 166, 0.34);
  box-shadow: 0 10px 22px rgba(3, 11, 20, 0.32);
}

.portal-route-calls-playlists .portal-player-card__inline-spacer,
.portal-route-calls-tg .portal-player-card__inline-spacer,
.portal-route-calls-fid .portal-player-card__inline-spacer,
.portal-route-calls-trs .portal-player-card__inline-spacer,
.portal-route-calls-node .portal-player-card__inline-spacer {
  width: 2.5rem;
  min-width: 2.5rem;
  height: 2.5rem;
  flex: 0 0 auto;
  visibility: hidden;
}

.portal-route-calls-playlists .portal-player-card__slider-label,
.portal-route-calls-playlists .portal-player-card__slider-value,
.portal-route-calls-tg .portal-player-card__slider-label,
.portal-route-calls-tg .portal-player-card__slider-value,
.portal-route-calls-fid .portal-player-card__slider-label,
.portal-route-calls-fid .portal-player-card__slider-value,
.portal-route-calls-trs .portal-player-card__slider-label,
.portal-route-calls-trs .portal-player-card__slider-value,
.portal-route-calls-node .portal-player-card__slider-label,
.portal-route-calls-node .portal-player-card__slider-value {
  color: #b6cce0;
  font-size: 0.79rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
}

.portal-route-calls-playlists .portal-player-card__slider-value,
.portal-route-calls-tg .portal-player-card__slider-value,
.portal-route-calls-fid .portal-player-card__slider-value,
.portal-route-calls-trs .portal-player-card__slider-value,
.portal-route-calls-node .portal-player-card__slider-value {
  color: #f0f8ff;
  font-weight: 700;
  flex: 0 0 2rem;
  min-width: 2rem;
  text-align: right;
  white-space: nowrap;
}

.portal-route-calls-playlists .portal-player-card__control-row--speed .portal-player-card__slider-value {
  flex: 0 0 2.75rem;
  min-width: 2.75rem;
}

.portal-route-calls-playlists #callsTable_wrapper {
  padding: 1rem 1rem 1.15rem;
  border: 1px solid rgba(95, 127, 160, 0.16);
  border-radius: 28px;
  background:
    radial-gradient(900px 260px at 0% 0%, rgba(57, 208, 255, 0.08), transparent 58%),
    linear-gradient(180deg, rgba(10, 20, 31, 0.98), rgba(6, 13, 22, 0.99));
  box-shadow: var(--portalv2-shadow);
}

.portal-route-calls-playlists #callsTable_wrapper .dataTables_length,
.portal-route-calls-playlists #callsTable_wrapper .dataTables_filter,
.portal-route-calls-playlists #callsTable_wrapper .dataTables_info,
.portal-route-calls-playlists #callsTable_wrapper .dataTables_paginate {
  color: #bdd6eb !important;
}

.portal-route-calls-playlists #callsTable_wrapper .dataTables_length label,
.portal-route-calls-playlists #callsTable_wrapper .dataTables_filter label {
  color: #bdd6eb !important;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.portal-route-calls-playlists #callsTable_wrapper .dataTables_length select,
.portal-route-calls-playlists #callsTable_wrapper .dataTables_filter input {
  min-height: 2.7rem;
  border-color: rgba(95, 127, 160, 0.16);
  background: rgba(9, 18, 29, 0.96) !important;
  color: #f0f8ff !important;
}

.portal-route-calls-playlists table.dataTable,
.portal-route-calls-playlists #callsTable {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0;
  overflow: hidden;
  border-radius: 22px;
  background: transparent;
}

.portal-route-calls-playlists #callsTable thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  padding: 0.68rem 0.64rem !important;
  border-bottom: 1px solid rgba(95, 127, 160, 0.16) !important;
  background:
    linear-gradient(90deg, rgba(14, 34, 50, 0.98), rgba(10, 24, 35, 0.98)) !important;
  color: #f3fbff !important;
  font-size: 0.84rem;
  font-weight: 700;
}

.portal-route-calls-playlists #callsTable tbody tr {
  transition: background-color 0.2s ease, transform 0.2s ease;
}

.portal-route-calls-playlists #callsTable tbody tr:nth-child(odd) {
  background: rgba(11, 22, 35, 0.78);
}

.portal-route-calls-playlists #callsTable tbody tr:nth-child(even) {
  background: rgba(8, 17, 28, 0.72);
}

.portal-route-calls-playlists #callsTable tbody tr:hover {
  background: rgba(23, 51, 71, 0.86) !important;
}

.portal-route-calls-playlists #callsTable tbody td {
  padding: 0.46rem 0.58rem !important;
  border-top: 1px solid rgba(95, 127, 160, 0.1) !important;
  color: #deefff;
  vertical-align: middle;
  font-size: 0.92rem;
}

.portal-route-calls-playlists #callsTable.dtr-inline.collapsed > tbody > tr > td.dtr-control::before,
.portal-route-calls-playlists #callsTable.dtr-inline.collapsed > tbody > tr > th.dtr-control::before {
  top: 50%;
  left: 0.42rem;
  width: 0.9rem;
  height: 0.9rem;
  margin-top: -0.45rem;
  border: 1px solid rgba(95, 127, 160, 0.22);
  background: rgba(15, 30, 46, 0.96);
  color: #8fe4ff;
  box-shadow: none;
}

.portal-route-calls-playlists table.dataTable.dtr-inline.collapsed > tbody > tr > td.dtr-control,
.portal-route-calls-playlists table.dataTable.dtr-inline.collapsed > tbody > tr > th.dtr-control {
  padding-left: 1.7rem !important;
}

.portal-route-calls-playlists #callsTable tbody td a {
  color: #7fe7ff;
  font-weight: 550;
}

.portal-route-calls-playlists #callsTable tbody td:first-child {
  width: 52px;
  text-align: center;
}

.portal-route-calls-playlists #callsTable tbody td:last-child {
  white-space: nowrap;
}

.portal-route-calls-playlists #callsTable tbody td:last-child a + a,
.portal-route-calls-playlists #callsTable tbody td:last-child i + i,
.portal-route-calls-playlists #callsTable tbody td:last-child a + i,
.portal-route-calls-playlists #callsTable tbody td:last-child i + a {
  margin-left: 0.35rem;
}

.portal-route-calls-playlists #callsTable tbody td .fa-play {
  color: #5fe7ff;
}

.portal-route-calls-playlists #callsTable tbody td .fa-stop,
.portal-route-calls-playlists #callsTable tbody td .fa-square {
  color: #87f58e;
}

.portal-route-calls-playlists #callsTable tbody td .fa-search-plus,
.portal-route-calls-playlists #callsTable tbody td .fa-download {
  color: #b8d6ef;
}

.portal-route-calls-playlists #callsTable tbody tr.shown + tr td {
  text-align: left !important;
}

.portal-route-calls-playlists .tc-child-content {
  text-align: left;
  padding: 0.28rem 0.1rem 0.2rem 2.1rem;
  color: #b9cad8;
  font-size: 0.84rem;
  line-height: 1.35;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
  max-width: 100%;
}

.portal-route-calls-playlists .tc-child-content i {
  font-style: italic;
  white-space: inherit;
}

.portal-route-calls-playlists #callsTable .sorting,
.portal-route-calls-playlists #callsTable .sorting_asc,
.portal-route-calls-playlists #callsTable .sorting_desc {
  background-image: none !important;
}

.portal-route-calls-playlists #callsTable tbody tr.table-success,
.portal-route-calls-playlists #callsTable tbody tr.table-success > td,
.portal-route-calls-playlists #callsTable tbody tr.table-success > th,
.portal-route-calls-playlists table.dataTable tbody tr.table-success,
.portal-route-calls-playlists table.dataTable tbody tr.table-success > td,
.portal-route-calls-playlists table.dataTable tbody tr.table-success > th {
  background-color: rgba(212, 193, 123, 0.3) !important;
  background-image: none !important;
  color: #fff8dc !important;
}

.portal-route-calls-playlists #callsTable tbody tr.table-success {
  box-shadow: inset 4px 0 0 rgba(255, 224, 122, 0.95);
}

.portal-route-calls-playlists #callsTable tbody tr.table-success:hover,
.portal-route-calls-playlists #callsTable tbody tr.table-success:hover > td,
.portal-route-calls-playlists table.dataTable tbody tr.table-success:hover,
.portal-route-calls-playlists table.dataTable tbody tr.table-success:hover > td {
  background-color: rgba(222, 203, 128, 0.36) !important;
  background-image: none !important;
}

.portal-route-calls-playlists #callsTable tbody tr.table-success td a,
.portal-route-calls-playlists #callsTable tbody tr.table-success td .fa,
.portal-route-calls-playlists #callsTable tbody tr.table-success td .fas {
  color: #fff8dc !important;
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
}

.portal-route-calls-playlists #callsTable tbody tr.table-success td:first-child {
  position: static;
}

.portal-route-calls-playlists #callsTable tbody tr.table-success td:first-child .fa-play,
.portal-route-calls-playlists #callsTable tbody tr.table-success td:first-child .fa-stop,
.portal-route-calls-playlists #callsTable tbody tr.table-success td:first-child .fa-square {
  color: #ffd15b !important;
  filter: drop-shadow(0 0 8px rgba(255, 208, 88, 0.28));
}

@media (max-width: 767.98px) {
  .portal-route-calls-playlists .portal-monitor-player-shell,
  .portal-route-calls-playlists .portal-monitor-player-shell:has(.portal-player-card__controls-card) {
    grid-template-columns: 1fr;
  }

  .portal-route-calls-playlists .portal-monitor-controls {
    justify-content: flex-start;
  }

  .portal-route-calls-playlists .portalv2-content {
    padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 1.5rem);
  }

  .portal-route-calls-playlists .portal-monitor-player-shell {
    position: static;
    left: auto;
    right: auto;
    bottom: auto;
    z-index: auto;
    gap: 0.55rem;
    grid-template-columns: 1fr;
    margin-bottom: 1rem;
  }

  .portal-route-calls-playlists .portal-player-card,
  .portal-route-calls-playlists .portal-player-card__controls-card {
    border-radius: 22px;
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.48);
  }

  .portal-route-calls-playlists .portal-player-card > .card-header,
  .portal-route-calls-playlists .portal-player-card__controls-card > .card-header {
    padding: 0.65rem 0.9rem;
    font-size: 0.88rem;
  }

  .portal-route-calls-playlists .portal-player-card .card-body,
  .portal-route-calls-playlists .portal-player-card__controls-card .card-body {
    padding: 0.8rem 0.9rem;
  }

  .portal-route-calls-playlists .player-group-banner,
  .portal-route-calls-trs-console .player-group-banner {
    gap: 0.45rem;
    padding: 0.8rem;
  }

  .portal-route-calls-playlists .player-display-line,
  .portal-route-calls-trs-console .player-display-line {
    font-size: 1.18rem;
    line-height: 1.1;
  }

  .portal-route-calls-playlists .player-grouping-line,
  .portal-route-calls-playlists .player-system-line,
  .portal-route-calls-trs-console .player-grouping-line,
  .portal-route-calls-trs-console .player-system-line {
    font-size: 0.82rem;
  }

  .portal-route-calls-playlists .player-low-item,
  .portal-route-calls-trs-console .player-low-item {
    min-width: 0;
  }

  .portal-route-calls-playlists .portal-monitor-controls {
    gap: 0.5rem;
  }

  .portal-route-calls-playlists .portal-player-card__group,
  .portal-route-calls-playlists .portal-player-card__dropdown {
    flex: 1 1 auto;
  }

  .portal-route-calls-playlists .portal-player-card__group {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    width: 100%;
  }

  .portal-route-calls-playlists .portal-player-card__group .btn,
  .portal-route-calls-playlists .portal-player-card__dropdown .btn,
  .portal-route-calls-playlists .portal-player-card__icon,
  .portal-route-calls-playlists .portal-player-card__primary {
    min-height: 2.9rem;
  }

  .portal-route-calls-playlists .portal-player-card__primary {
    flex: 1 1 42%;
  }

  .portal-route-calls-playlists .portal-player-card__control-row--speed {
    align-items: center;
  }

  .portal-route-calls-playlists #callsTable tbody td {
    padding: 0.38rem 0.46rem !important;
    font-size: 0.85rem;
  }

  .portal-route-calls-playlists #callsTable thead th {
    padding: 0.56rem 0.48rem !important;
    font-size: 0.75rem;
  }

  .portal-route-calls-playlists .portal-player-card__control-row,
  .portal-route-calls-playlists .playlist-console-control-row,
  .portal-route-calls-trs-console .playlist-console-control-row {
    flex-wrap: nowrap;
  }

}

@media (max-width: 575.98px) {
  .portal-route-calls-playlists .playlist-console-mix-row,
  .portal-route-calls-trs-console .playlist-console-mix-row {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }

  .portal-route-calls-playlists .playlist-console-control-label,
  .portal-route-calls-trs-console .playlist-console-control-label {
    width: 6.6rem;
    min-width: 6.6rem;
  }
}

.portal-route-calls-home .newdash-bg {
  margin-bottom: 1rem;
  border: 1px solid rgba(95, 127, 160, 0.16);
  border-radius: 24px;
  background:
    radial-gradient(1200px 500px at 8% -10%, rgba(24, 115, 204, 0.26), transparent 60%),
    radial-gradient(900px 450px at 95% 0%, rgba(36, 190, 130, 0.16), transparent 55%),
    linear-gradient(180deg, rgba(10, 19, 31, 0.98), rgba(7, 13, 20, 0.98));
  box-shadow: var(--portalv2-shadow);
}

.metric-grid {
  display: grid;
  gap: 0.8rem;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}

.metric-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(95, 127, 160, 0.18);
  border-radius: 18px;
  padding: 0.9rem 1rem;
  background: linear-gradient(180deg, rgba(16, 29, 45, 0.98), rgba(10, 18, 29, 0.98));
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}

.metric-card::before {
  content: "";
  position: absolute;
  inset: auto auto 0 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, #39d0ff, transparent 80%);
}

.metric-k {
  margin-bottom: 0.28rem;
  color: #8ba4bc;
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.metric-v {
  color: #f0f7ff;
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.1;
}

.metric-hint,
.context-note {
  color: #98adc2;
  font-size: 0.78rem;
}

.dash-card,
.portal-body .card,
.portal-body .card-frame,
.portal-body .modal-content,
.portal-body .dropdown-menu,
.portal-body .dataTables_wrapper .dataTables_length select,
.portal-body .dataTables_wrapper .dataTables_filter input,
.portal-body .form-control,
.portal-body .custom-select {
  border-color: rgba(95, 127, 160, 0.16);
  background: linear-gradient(180deg, rgba(13, 24, 38, 0.98), rgba(8, 15, 24, 0.98));
  background-color: rgba(8, 15, 24, 0.98);
  color: var(--portalv2-text);
}

.portal-body .card {
  --cui-card-border-color: rgba(95, 127, 160, 0.16);
  --cui-card-inner-border-radius: 21px;
  overflow: hidden;
}

.portal-body .card,
.portal-body .card-frame,
.portal-body .modal-content,
.portal-body .dropdown-menu {
  border-radius: 22px;
  box-shadow: var(--portalv2-shadow);
}

.portal-body .card-header {
  border-color: rgba(95, 127, 160, 0.18) !important;
  background: transparent !important;
  color: #ebf5ff !important;
}

.portal-body a:has(> .btn) {
  text-decoration: none !important;
}

.portal-body .modal-header,
.portal-body .thead-dark th,
.portal-body .bg-rrblue {
  border-color: rgba(95, 127, 160, 0.18) !important;
  background: linear-gradient(90deg, rgba(57, 208, 255, 0.18), rgba(57, 208, 255, 0.06)) !important;
  color: #ebf5ff !important;
}

.portal-body .table,
.portal-body .table td,
.portal-body .table th {
  color: inherit;
  border-color: rgba(95, 127, 160, 0.14);
}

.portal-table-wrap {
  overflow-x: auto;
  border: 1px solid rgba(95, 127, 160, 0.14);
  border-radius: 18px;
  background: rgba(7, 13, 20, 0.66);
}

.portal-body table.table,
.portal-body table.dataTable {
  margin-bottom: 0;
}

/* Reusable portal dark data table */
.portal-body .portal-data-table {
  border-collapse: separate !important;
  border-spacing: 0;
  border-radius: 16px;
  overflow: hidden;
  background: transparent;
}

.portal-body .portal-data-table thead th {
  padding: 0.7rem 0.75rem !important;
  border-bottom: 1px solid rgba(95, 127, 160, 0.18) !important;
  background: linear-gradient(90deg, rgba(14, 34, 50, 0.98), rgba(10, 24, 35, 0.98)) !important;
  color: #f3fbff !important;
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.portal-body .portal-data-table tbody tr {
  transition: background-color 0.15s ease;
}

.portal-body .portal-data-table tbody tr:nth-child(odd) {
  background: rgba(11, 22, 35, 0.78);
}

.portal-body .portal-data-table tbody tr:nth-child(even) {
  background: rgba(8, 17, 28, 0.72);
}

.portal-body .portal-data-table tbody tr:hover {
  background: rgba(23, 51, 71, 0.86) !important;
}

.portal-body .portal-data-table tbody td {
  padding: 0.5rem 0.75rem !important;
  border-top: 1px solid rgba(95, 127, 160, 0.08) !important;
  color: #deefff;
  vertical-align: middle;
  font-size: 0.85rem;
}

.portal-body .portal-data-table tbody td a {
  color: #7fe7ff;
  font-weight: 550;
  text-decoration: none;
}

.portal-body .portal-data-table tbody td a:hover {
  color: #b8f6ff;
  text-decoration: underline;
}

.portal-body .portal-data-table tbody tr.bg-soft-warning td {
  color: rgba(255, 228, 160, 0.85);
}

/* Coverage tag-group card header */
.portal-body .portal-tag-group-card {
  border: 1px solid rgba(95, 127, 160, 0.14);
  border-radius: 12px;
  overflow: hidden;
}

.portal-body .portal-tag-group-card > .card-header {
  background: linear-gradient(90deg, rgba(57, 208, 255, 0.14), rgba(57, 208, 255, 0.03)) !important;
  border-bottom: 1px solid rgba(95, 127, 160, 0.16) !important;
  border-left: 3px solid rgba(57, 208, 255, 0.6) !important;
  padding: 0.7rem 1rem !important;
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  color: #e8f5ff !important;
}

/* Truncated table cell */
.portal-body .portal-truncate-cell {
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Shared last-seen pill badge */
.portal-body .portal-last-seen-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.18rem 0.52rem;
  border-radius: 999px;
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  white-space: nowrap;
}

/* portal-data-table DataTables controls (shared layout for all data tables) */
.portal-body .portal-data-table-controls,
.portal-body .portal-data-table-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.9rem;
  padding: 0.95rem 0.55rem 0;
  flex-wrap: wrap;
}

.portal-body .portal-data-table-controls-top {
  padding-top: 0.45rem;
  padding-bottom: 0.85rem;
  border-bottom: 1px solid rgba(95, 127, 160, 0.12);
}

.portal-body .portal-data-table-controls .dataTables_length,
.portal-body .portal-data-table-controls .dataTables_filter,
.portal-body .portal-data-table-controls .dataTables_paginate,
.portal-body .portal-data-table-footer .dataTables_info,
.portal-body .portal-data-table-footer .dataTables_paginate {
  float: none !important;
  margin: 0;
}

.portal-body .portal-data-table-controls .dataTables_length label,
.portal-body .portal-data-table-controls .dataTables_filter label,
.portal-body .portal-data-table-footer .dataTables_info {
  color: #a9bfd4;
  font-size: 0.78rem;
  font-weight: 600;
}

.portal-body .portal-data-table-controls .dataTables_filter input,
.portal-body .portal-data-table-controls .dataTables_length select {
  min-height: 2.2rem;
  padding: 0.38rem 0.72rem;
  border: 1px solid rgba(95, 127, 160, 0.18);
  background: rgba(12, 23, 36, 0.96);
  color: #edf7ff;
  box-shadow: none;
}

.portal-body .portal-data-table-controls .dataTables_filter input {
  min-width: 280px;
}

.portal-body .portal-data-table-controls .dataTables_paginate {
  margin-left: auto;
}

.portal-body .portal-data-table .sorting,
.portal-body .portal-data-table .sorting_asc,
.portal-body .portal-data-table .sorting_desc {
  background-image: none !important;
  position: relative;
  padding-right: 1.5rem !important;
  cursor: pointer;
}

.portal-body .portal-data-table .sorting::after,
.portal-body .portal-data-table .sorting_asc::after,
.portal-body .portal-data-table .sorting_desc::after {
  position: absolute;
  right: 0.5rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.65rem;
  opacity: 0.35;
}

.portal-body .portal-data-table .sorting::after {
  content: "\25B2\00a0\25BC";
}

.portal-body .portal-data-table .sorting_asc::after {
  content: "\25B2";
  opacity: 0.9;
  color: #39d0ff;
}

.portal-body .portal-data-table .sorting_desc::after {
  content: "\25BC";
  opacity: 0.9;
  color: #39d0ff;
}

@media (max-width: 767.98px) {
  .portal-body .portal-data-table-controls .dataTables_filter input {
    min-width: 0;
    width: 100%;
  }
}

.portal-body .alert {
  border-color: rgba(95, 127, 160, 0.18);
  border-radius: 18px;
}

.portal-body .alert-warning {
  background: rgba(244, 200, 106, 0.1);
  color: #f8e5b5;
}

.portal-body .alert-info {
  background: rgba(57, 208, 255, 0.1);
  color: #dbf7ff;
}

.portal-body .alert-danger {
  background: rgba(255, 104, 104, 0.12);
  color: #ffd6d6;
}

.portal-body .badge {
  border-radius: 999px;
}

.portal-body .badge-success {
  background: rgba(97, 255, 135, 0.16);
  color: #acffbf;
}

.portal-body .badge-secondary {
  background: rgba(95, 127, 160, 0.18);
  color: #d9ebff;
}

.portal-body .badge-warning {
  background: rgba(255, 200, 88, 0.16);
  color: #ffe2a6;
}

.portal-body .badge-danger {
  background: rgba(255, 104, 104, 0.16);
  color: #ffd1d1;
}

.portal-body .player-card,
.portal-body .playlist-console-col .card,
.portal-body #playlistConsoleGrid .card {
  overflow: hidden;
}

.portal-body .player-group-banner,
.portal-body .player-transcription-box,
.portal-body .tg-card,
.portal-body .playlist-console-col .card,
.portal-body #playlistConsoleGrid .card,
.portal-body #trsDashboardForm + .alert,
.portal-body #trsDashboardForm,
.portal-body .jstree-proton {
  box-shadow: var(--portalv2-shadow);
}

.portal-body .player-group-banner,
.portal-body .player-transcription-box {
  border: 1px solid rgba(95, 127, 160, 0.16);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(15, 28, 43, 0.98), rgba(10, 19, 29, 0.98));
}

.portal-playlist-listing-table {
  margin-bottom: 0;
}

.portal-playlist-listing-table td {
  padding: 0.7rem 1.15rem;
  vertical-align: middle;
  border-top: 1px solid rgba(95, 127, 160, 0.12);
  color: #dfeaf6;
  font-size: 0.9rem;
}

.portal-playlist-listing-table tr:first-child td {
  border-top: none;
}

.portal-playlist-listing-table tr:hover {
  background: linear-gradient(90deg, rgba(57, 208, 255, 0.1), rgba(57, 208, 255, 0.03));
}

.portal-playlist-listing-table td a:not(.btn) {
  font-weight: 500;
}

.portal-playlist-listing-table .fa-edit {
  font-size: 0.85rem;
}

.portal-playlist-listing-table .fa-trash {
  font-size: 0.8rem;
}

@media (min-width: 992px) {
  .portal-route-calls-playlists .col-lg-5th {
    flex: 0 0 20%;
    max-width: 20%;
  }
}

.portal-route-calls-playlists .tg-card {
  transition: background-color 0.2s ease-in-out;
  min-height: 185px;
  display: flex;
  flex-direction: column;
  overflow: visible;
}

.portal-route-calls-playlists .group-card-header {
  display: block !important;
}

.portal-route-calls-playlists .group-card-header.tg-card-holding-pulse {
  animation: portal-hold-pulse-bg 1.15s ease-in-out infinite;
}

.portal-route-calls-playlists .tg-card.tg-card-hold-active {
  animation: portal-hold-pulse-card 1.5s ease-in-out infinite;
  border-color: rgba(49, 185, 114, 0.4);
}

.portal-route-calls-playlists .tg-card-collapsed {
  min-height: auto !important;
}

.portal-route-calls-playlists .pc-listen-toggle.holding-pulse {
  animation: portal-hold-pulse-btn 1.15s ease-in-out infinite;
}

@keyframes portal-hold-pulse-card {
  0% { box-shadow: 0 0 4px rgba(49, 185, 114, 0.2), inset 0 0 0 1px rgba(49, 185, 114, 0.15); }
  50% { box-shadow: 0 0 14px rgba(49, 185, 114, 0.45), inset 0 0 0 1px rgba(49, 185, 114, 0.35); }
  100% { box-shadow: 0 0 4px rgba(49, 185, 114, 0.2), inset 0 0 0 1px rgba(49, 185, 114, 0.15); }
}

@keyframes portal-hold-pulse-bg {
  0% { background-color: rgba(24, 47, 68, 0.96); }
  50% { background-color: rgba(39, 88, 65, 0.96); }
  100% { background-color: rgba(24, 47, 68, 0.96); }
}

@keyframes portal-hold-pulse-btn {
  0% { background-color: #1f9e61; color: #f5fff8; box-shadow: 0 0 0 0 rgba(49, 185, 114, 0.32); }
  50% { background-color: #39d0ff; color: #061019; box-shadow: 0 0 0 7px rgba(57, 208, 255, 0); }
  100% { background-color: #1f9e61; color: #f5fff8; box-shadow: 0 0 0 0 rgba(49, 185, 114, 0.32); }
}

.portal-route-calls-playlists .tg-display {
  font-weight: 600;
  line-height: 1.15;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: block;
  min-width: 0;
}

.portal-route-calls-playlists .group-card-meta-line {
  font-size: 0.76rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.portal-route-calls-playlists .group-transcription-wrap {
  margin-bottom: 0.25rem;
  min-height: 0.82rem;
  border-radius: 0.2rem;
  padding: 0.03rem 0;
  position: relative;
}

.portal-route-calls-playlists .group-transcription-viewport {
  margin: 0 0.38rem;
  overflow: hidden;
}

.portal-route-calls-playlists .group-transcription-text {
  display: inline-block;
  white-space: nowrap;
  will-change: transform;
  transform: translateX(0);
  font-size: 0.62rem;
  line-height: 1.1;
  font-style: italic;
  min-width: max-content;
}

.portal-route-calls-playlists .group-state-line {
  min-height: 0;
  margin-top: 0.2rem !important;
}

.portal-route-calls-playlists .tg-card.tg-card-no-transcription .card-body {
  padding-bottom: 0.78rem;
}

.portal-route-calls-playlists .tg-card.tg-card-no-transcription .group-state-line {
  margin-top: 0.18rem !important;
}

.portal-route-calls-playlists .card-frame > .card-header,
.portal-route-calls-playlists .card:not(.portal-player-card):not(.portal-player-card__controls-card) > .card-header,
.portal-route-calls-trs-console .card-frame > .card-header,
.portal-route-calls-trs-console .card:not(.portal-player-card):not(.portal-player-card__controls-card) > .card-header {
  background: transparent !important;
}

.portal-route-calls-playlists .player-group-banner,
.portal-route-calls-trs-console .player-group-banner,
.portal-route-calls-tg .player-group-banner,
.portal-route-calls-fid .player-group-banner,
.portal-route-calls-trs .player-group-banner,
.portal-route-calls-node .player-group-banner {
  min-height: 6.35rem;
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-template-areas:
    "v v v v v v b b b b b b"
    "d d d d d d d d d d d d"
    "g g g g g g s s s s s s"
    "src src src src fr fr fr fr nd nd nd nd";
  grid-row-gap: 0.18rem;
  align-items: center;
  padding: 0.4rem 0.5rem 0.45rem 0.5rem;
  overflow: hidden;
  transition: opacity 0.35s ease, filter 0.35s ease, background-color 0.35s ease, border-color 0.35s ease;
}

.portal-route-calls-playlists .player-group-banner.player-last-call-stale,
.portal-route-calls-trs-console .player-group-banner.player-last-call-stale,
.portal-route-calls-tg .player-group-banner.player-last-call-stale,
.portal-route-calls-fid .player-group-banner.player-last-call-stale,
.portal-route-calls-trs .player-group-banner.player-last-call-stale,
.portal-route-calls-node .player-group-banner.player-last-call-stale {
  opacity: 1;
  filter: none;
}

.portal-route-calls-playlists .player-group-banner.player-last-call-stale .player-display-line,
.portal-route-calls-playlists .player-group-banner.player-last-call-stale .player-grouping-line,
.portal-route-calls-playlists .player-group-banner.player-last-call-stale .player-system-line,
.portal-route-calls-playlists .player-group-banner.player-last-call-stale .player-low-value,
.portal-route-calls-trs-console .player-group-banner.player-last-call-stale .player-display-line,
.portal-route-calls-trs-console .player-group-banner.player-last-call-stale .player-grouping-line,
.portal-route-calls-trs-console .player-group-banner.player-last-call-stale .player-system-line,
.portal-route-calls-trs-console .player-group-banner.player-last-call-stale .player-low-value,
.portal-route-calls-tg .player-group-banner.player-last-call-stale .player-display-line,
.portal-route-calls-tg .player-group-banner.player-last-call-stale .player-grouping-line,
.portal-route-calls-tg .player-group-banner.player-last-call-stale .player-system-line,
.portal-route-calls-tg .player-group-banner.player-last-call-stale .player-low-value,
.portal-route-calls-fid .player-group-banner.player-last-call-stale .player-display-line,
.portal-route-calls-fid .player-group-banner.player-last-call-stale .player-grouping-line,
.portal-route-calls-fid .player-group-banner.player-last-call-stale .player-system-line,
.portal-route-calls-fid .player-group-banner.player-last-call-stale .player-low-value,
.portal-route-calls-trs .player-group-banner.player-last-call-stale .player-display-line,
.portal-route-calls-trs .player-group-banner.player-last-call-stale .player-grouping-line,
.portal-route-calls-trs .player-group-banner.player-last-call-stale .player-system-line,
.portal-route-calls-trs .player-group-banner.player-last-call-stale .player-low-value,
.portal-route-calls-node .player-group-banner.player-last-call-stale .player-display-line,
.portal-route-calls-node .player-group-banner.player-last-call-stale .player-grouping-line,
.portal-route-calls-node .player-group-banner.player-last-call-stale .player-system-line,
.portal-route-calls-node .player-group-banner.player-last-call-stale .player-low-value {
  color: #6c757d !important;
}

.portal-route-calls-playlists .player-group-banner.player-last-call-stale .player-low-label,
.portal-route-calls-trs-console .player-group-banner.player-last-call-stale .player-low-label,
.portal-route-calls-tg .player-group-banner.player-last-call-stale .player-low-label,
.portal-route-calls-fid .player-group-banner.player-last-call-stale .player-low-label,
.portal-route-calls-trs .player-group-banner.player-last-call-stale .player-low-label,
.portal-route-calls-node .player-group-banner.player-last-call-stale .player-low-label {
  color: #515861 !important;
}

.portal-route-calls-playlists .player-stat,
.portal-route-calls-trs-console .player-stat,
.portal-route-calls-tg .player-stat,
.portal-route-calls-fid .player-stat,
.portal-route-calls-trs .player-stat,
.portal-route-calls-node .player-stat {
  display: flex;
  align-items: baseline;
  gap: 0.32rem;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.portal-route-calls-playlists .player-stat-label,
.portal-route-calls-trs-console .player-stat-label,
.portal-route-calls-tg .player-stat-label,
.portal-route-calls-fid .player-stat-label,
.portal-route-calls-trs .player-stat-label,
.portal-route-calls-node .player-stat-label {
  color: #77d4ff;
  font-size: 0.62rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-weight: 600;
}

.portal-route-calls-playlists .player-stat-value,
.portal-route-calls-trs-console .player-stat-value,
.portal-route-calls-tg .player-stat-value,
.portal-route-calls-fid .player-stat-value,
.portal-route-calls-trs .player-stat-value,
.portal-route-calls-node .player-stat-value {
  color: #f7fff8;
  font-size: 0.72rem;
  font-weight: 700;
}

.portal-route-calls-playlists .player-vol-stat,
.portal-route-calls-trs-console .player-vol-stat,
.portal-route-calls-tg .player-vol-stat,
.portal-route-calls-fid .player-vol-stat,
.portal-route-calls-trs .player-vol-stat,
.portal-route-calls-node .player-vol-stat { grid-area: v; justify-self: start; }
.portal-route-calls-playlists .player-bal-stat,
.portal-route-calls-trs-console .player-bal-stat,
.portal-route-calls-tg .player-bal-stat,
.portal-route-calls-fid .player-bal-stat,
.portal-route-calls-trs .player-bal-stat,
.portal-route-calls-node .player-bal-stat { grid-area: b; justify-self: end; }

.portal-route-calls-playlists .player-display-line,
.portal-route-calls-trs-console .player-display-line,
.portal-route-calls-tg .player-display-line,
.portal-route-calls-fid .player-display-line,
.portal-route-calls-trs .player-display-line,
.portal-route-calls-node .player-display-line {
  grid-area: d;
  color: #ffd400;
  font-size: 1.42rem;
  line-height: 1.05;
  letter-spacing: 0.01em;
  font-weight: 800;
  text-align: center;
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  overflow-wrap: anywhere;
}

/* Clamp display to 2 lines only on playlist console cards (tight space) */
.portal-route-calls-playlists .player-display-line {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.portal-route-calls-playlists .player-grouping-line,
.portal-route-calls-trs-console .player-grouping-line,
.portal-route-calls-tg .player-grouping-line,
.portal-route-calls-fid .player-grouping-line,
.portal-route-calls-trs .player-grouping-line,
.portal-route-calls-node .player-grouping-line {
  grid-area: g;
  color: #ffffff;
  font-size: 0.74rem;
  line-height: 1.05;
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.portal-route-calls-playlists .player-system-line,
.portal-route-calls-trs-console .player-system-line,
.portal-route-calls-tg .player-system-line,
.portal-route-calls-fid .player-system-line,
.portal-route-calls-trs .player-system-line,
.portal-route-calls-node .player-system-line {
  grid-area: s;
  color: #89f7b0;
  font-size: 0.72rem;
  line-height: 1.05;
  text-align: right;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.portal-route-calls-playlists .player-low-item,
.portal-route-calls-trs-console .player-low-item,
.portal-route-calls-tg .player-low-item,
.portal-route-calls-fid .player-low-item,
.portal-route-calls-trs .player-low-item,
.portal-route-calls-node .player-low-item {
  min-width: 0;
  display: flex;
  align-items: baseline;
  gap: 0.22rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.portal-route-calls-playlists .player-low-label,
.portal-route-calls-trs-console .player-low-label,
.portal-route-calls-tg .player-low-label,
.portal-route-calls-fid .player-low-label,
.portal-route-calls-trs .player-low-label,
.portal-route-calls-node .player-low-label {
  color: #87929f;
  font-size: 0.58rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-weight: 600;
  flex-shrink: 0;
}

.portal-route-calls-playlists .player-low-value,
.portal-route-calls-trs-console .player-low-value,
.portal-route-calls-tg .player-low-value,
.portal-route-calls-fid .player-low-value,
.portal-route-calls-trs .player-low-value,
.portal-route-calls-node .player-low-value {
  color: #ced7df;
  font-size: 0.67rem;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  overflow: hidden;
  text-overflow: ellipsis;
}

.portal-route-calls-playlists .player-card > .card-header,
.portal-route-calls-trs-console .player-card > .card-header {
  padding: 0.38rem 0.75rem;
  line-height: 1.1;
  font-size: 0.92rem;
}

.portal-route-calls-playlists .player-card > .card-header .small,
.portal-route-calls-trs-console .player-card > .card-header .small {
  font-size: 0.72rem;
}

.portal-route-calls-playlists .player-src-item,
.portal-route-calls-trs-console .player-src-item,
.portal-route-calls-tg .player-src-item,
.portal-route-calls-fid .player-src-item,
.portal-route-calls-trs .player-src-item,
.portal-route-calls-node .player-src-item { grid-area: src; }
.portal-route-calls-playlists .portal-player-card__source-meta,
.portal-route-calls-tg .portal-player-card__source-meta,
.portal-route-calls-fid .portal-player-card__source-meta {
  display: contents;
}

.portal-route-calls-playlists .portal-player-card__source-meta:not([style*="display: none"]),
.portal-route-calls-tg .portal-player-card__source-meta:not([style*="display: none"]),
.portal-route-calls-fid .portal-player-card__source-meta:not([style*="display: none"]) {
  display: contents !important;
}

.portal-route-calls-playlists .player-freq-item,
.portal-route-calls-trs-console .player-freq-item,
.portal-route-calls-tg .player-freq-item,
.portal-route-calls-fid .player-freq-item,
.portal-route-calls-trs .player-freq-item,
.portal-route-calls-node .player-freq-item { grid-area: fr; justify-self: center; }

.portal-route-calls-playlists .player-node-item,
.portal-route-calls-trs-console .player-node-item,
.portal-route-calls-tg .player-node-item,
.portal-route-calls-fid .player-node-item,
.portal-route-calls-trs .player-node-item,
.portal-route-calls-node .player-node-item { grid-area: nd; justify-self: end; }

.portal-route-calls-playlists .player-transcription-box,
.portal-route-calls-trs-console .player-transcription-box {
  padding: 0.35rem 0.5rem;
  font-size: 0.8rem;
  line-height: 1.25;
  min-height: 2.1rem;
  max-height: 2.1rem;
  overflow: hidden;
  max-width: 100%;
  transition: opacity 0.35s ease, background-color 0.35s ease, border-color 0.35s ease, color 0.35s ease;
}

.portal-route-calls-playlists .player-transcription-box.player-last-call-stale,
.portal-route-calls-trs-console .player-transcription-box.player-last-call-stale {
  opacity: 1;
  color: #6c757d;
}

.portal-route-calls-playlists .player-transcription-viewport,
.portal-route-calls-trs-console .player-transcription-viewport {
  white-space: nowrap;
  overflow: hidden;
  width: 100%;
  min-width: 0;
}

.portal-route-calls-playlists .player-transcription-text,
.portal-route-calls-trs-console .player-transcription-text {
  display: inline-block;
  white-space: nowrap;
  transform: translateX(0);
  will-change: transform;
  min-width: max-content;
}

.portal-route-calls-playlists .player-mute-icon-btn,
.portal-route-calls-trs-console .player-mute-icon-btn {
  width: 2rem;
  height: 2rem;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.portal-route-calls-playlists .playlist-console-control-label,
.portal-route-calls-trs-console .playlist-console-control-label {
  color: #b6cce0;
  font-size: 0.79rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
  white-space: nowrap;
}

.portal-route-calls-playlists .playlist-console-control-input input[type="range"],
.portal-route-calls-trs-console .playlist-console-control-input input[type="range"] {
  width: 100%;
}

.portal-route-calls-playlists .playlist-console-control-action .btn,
.portal-route-calls-trs-console .playlist-console-control-action .btn {
  width: 2.5rem;
  height: 2.5rem;
  min-height: 2.5rem;
  border-radius: 0.8rem;
}

.portal-route-calls-playlists .pc-route-btn {
  min-width: 0;
  white-space: nowrap;
}

.portal-route-calls-playlists .pc-listen-toggle,
.portal-route-calls-playlists .pc-route-btn,
.portal-route-calls-playlists .pc-hold-toggle {
  font-size: 0.66rem;
}

.portal-route-calls-playlists .pc-listen-toggle,
.portal-route-calls-playlists .pc-route-btn {
  padding: 0.16rem 0.42rem;
  white-space: nowrap;
}

.portal-route-calls-playlists .group-card-control-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.25rem 0.4rem;
}

.portal-route-calls-playlists .group-card-route-dropdown {
  margin-left: auto;
  display: inline-flex;
  justify-content: flex-end;
  position: relative;
}

.portal-route-calls-playlists .playlist-console-col,
.portal-route-calls-playlists .playlist-console-col .dropdown,
.portal-route-calls-playlists .playlist-console-col .dropdown-menu {
  overflow: visible;
}

.portal-route-calls-playlists .playlist-console-col {
  position: relative;
  z-index: 1;
}

.portal-route-calls-playlists .playlist-console-col:has(.group-card-route-dropdown.show),
.portal-route-calls-playlists .playlist-console-col:has(.group-card-route-dropdown .dropdown-menu.show),
.portal-route-calls-playlists .playlist-console-col:has(.pc-route-btn[aria-expanded="true"]) {
  z-index: 1200;
}

.portal-route-calls-playlists .playlist-console-col .dropdown {
  position: relative;
}

.portal-route-calls-playlists .playlist-console-col .group-card-route-dropdown.show,
.portal-route-calls-playlists .playlist-console-col .group-card-route-dropdown.show .pc-route-btn,
.portal-route-calls-playlists .playlist-console-col .group-card-route-dropdown.show .dropdown-menu,
.portal-route-calls-playlists .playlist-console-col .pc-route-btn[aria-expanded="true"],
.portal-route-calls-playlists .playlist-console-col .pc-route-btn[aria-expanded="true"] + .dropdown-menu {
  z-index: 1210;
}

.portal-route-calls-playlists .playlist-console-col .dropdown-menu {
  z-index: 1205;
}

.portal-route-calls-playlists .pc-route-choice {
  display: inline-block;
  min-width: 0.7rem;
  text-align: center;
}

.portal-route-calls-playlists .pc-priority-pill {
  display: inline-block;
  margin-left: 0.25rem;
  padding: 0.02rem 0.3rem;
  border-radius: 0.2rem;
  font-size: 0.66rem;
  font-weight: 700;
  line-height: 1.2;
  vertical-align: middle;
}

.portal-route-calls-playlists .pc-priority-high {
  background: #ffd54f;
  color: #1f2328;
}

.portal-route-calls-playlists .pc-priority-standard {
  background: #eef2f6;
  color: #495057;
}

.portal-route-calls-playlists .pc-priority-low {
  background: #5f6770;
  color: #ffffff;
}

.portal-route-calls-playlists .tg-card {
  border: 1px solid rgba(95, 127, 160, 0.2) !important;
  background: linear-gradient(180deg, rgba(16, 31, 46, 0.98), rgba(9, 18, 28, 0.98)) !important;
  box-shadow: 0 18px 34px rgba(3, 9, 15, 0.42), inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

.portal-body.portal-route-calls-playlists #playlistConsoleGrid .card,
.portal-body.portal-route-calls-playlists .playlist-console-col .card,
.portal-body.portal-route-calls-playlists .tg-card {
  overflow: visible !important;
}

.portal-route-calls-playlists .group-card-header {
  border-bottom: 1px solid rgba(95, 127, 160, 0.18) !important;
  background: linear-gradient(135deg, rgba(24, 47, 68, 0.96), rgba(14, 27, 40, 0.96)) !important;
  color: #edf7ff !important;
  border-top-left-radius: 18px;
  border-top-right-radius: 18px;
  overflow: hidden;
  background-clip: padding-box;
}

.portal-route-calls-playlists .group-card-header .tg-display,
.portal-route-calls-playlists .group-card-header .group-card-meta-line,
.portal-route-calls-playlists .tg-card .card-footer,
.portal-route-calls-playlists .tg-card .group-state-line {
  color: #d9ebff !important;
}

.portal-route-calls-playlists .tg-card .card-footer {
  border-top: 1px solid rgba(95, 127, 160, 0.14);
  background: rgba(8, 14, 22, 0.72);
  font-size: 0.72rem;
  line-height: 1.15;
}

.portal-route-calls-playlists .tg-card-active {
  border-color: rgba(255, 224, 122, 0.74) !important;
  background:
    radial-gradient(260px 120px at 12% 0%, rgba(255, 224, 122, 0.18), transparent 72%),
    linear-gradient(180deg, rgba(92, 79, 20, 0.98), rgba(45, 37, 10, 0.99)) !important;
  box-shadow: 0 20px 42px rgba(25, 21, 4, 0.52), 0 0 0 1px rgba(255, 224, 122, 0.22), 0 0 24px rgba(255, 220, 105, 0.16);
}

.portal-route-calls-playlists .group-card-header.tg-card-active {
  border-bottom-color: rgba(255, 224, 122, 0.48) !important;
  background:
    radial-gradient(260px 96px at 10% 0%, rgba(255, 226, 128, 0.18), transparent 70%),
    linear-gradient(135deg, rgba(119, 103, 28, 0.98), rgba(61, 49, 12, 0.98)) !important;
}

.portal-route-calls-playlists .tg-card-playing {
  border-color: rgba(255, 146, 64, 0.78) !important;
  background:
    radial-gradient(220px 120px at 12% 0%, rgba(255, 147, 73, 0.18), transparent 72%),
    linear-gradient(180deg, rgba(96, 45, 13, 0.98), rgba(46, 22, 9, 0.99)) !important;
  box-shadow: 0 22px 46px rgba(24, 9, 3, 0.54), 0 0 0 1px rgba(255, 146, 64, 0.26), 0 0 26px rgba(255, 138, 52, 0.16);
}

.portal-route-calls-playlists .group-card-header.tg-card-playing {
  border-bottom-color: rgba(255, 146, 64, 0.5) !important;
  background:
    radial-gradient(240px 90px at 10% 0%, rgba(255, 176, 108, 0.18), transparent 70%),
    linear-gradient(135deg, rgba(129, 60, 18, 0.98), rgba(72, 32, 10, 0.98)) !important;
}

.portal-route-calls-playlists .tg-card-playing .tg-display,
.portal-route-calls-playlists .tg-card-active .tg-display {
  color: #f4fbff !important;
}

.portal-route-calls-playlists .tg-card-playing .group-card-meta-line,
.portal-route-calls-playlists .tg-card-active .group-card-meta-line {
  color: rgba(207, 232, 249, 0.82) !important;
}

.portal-route-calls-playlists .tg-card-active .card-footer,
.portal-route-calls-playlists .tg-card-active .group-state-line {
  color: rgba(255, 244, 188, 0.9) !important;
}

.portal-route-calls-playlists .tg-card-playing .card-footer,
.portal-route-calls-playlists .tg-card-playing .group-state-line {
  color: rgba(255, 228, 196, 0.9) !important;
}

.portal-route-calls-playlists .tg-card-playing .handle,
.portal-route-calls-playlists .tg-card-active .handle,
.portal-route-calls-playlists .tg-card-playing .pc-hold-toggle,
.portal-route-calls-playlists .tg-card-active .pc-hold-toggle {
  color: #a9e9ff !important;
}

.portal-route-calls-playlists .group-card-footer-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
}

.portal-route-calls-playlists .group-card-status-dot {
  width: 0.58rem;
  height: 0.58rem;
  border-radius: 999px;
  display: inline-block;
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.06);
}

.portal-route-calls-playlists .group-card-status-dot-on {
  background: radial-gradient(circle at 35% 35%, #8ff7b7, #1fcf6d 68%, #0e7d40 100%);
  box-shadow: 0 0 0 1px rgba(40, 205, 111, 0.22), 0 0 8px rgba(32, 208, 108, 0.18);
}

.portal-route-calls-playlists .group-card-status-dot-off {
  background: radial-gradient(circle at 35% 35%, #7c8a98, #42515f 70%, #27313b 100%);
  box-shadow: 0 0 0 1px rgba(129, 149, 168, 0.12);
}

.portal-route-calls-playlists .group-card-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.portal-route-calls-playlists .playlist-console-mix-row,
.portal-route-calls-trs-console .playlist-console-mix-row {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(0, 0.95fr);
  gap: 1.15rem;
  margin-bottom: 0 !important;
}

.no-volume-support .portal-route-calls-playlists .playlist-console-mix-row,
.no-volume-support .portal-route-calls-trs-console .playlist-console-mix-row {
  grid-template-columns: 1fr;
}

.portal-route-calls-playlists .playlist-console-mix-col,
.portal-route-calls-trs-console .playlist-console-mix-col {
  min-width: 0;
  display: flex;
  align-items: center;
}

.portal-route-calls-playlists .playlist-console-mix-col:first-child .playlist-console-control-label,
.portal-route-calls-trs-console .playlist-console-mix-col:first-child .playlist-console-control-label {
  width: 6.6rem;
  min-width: 6.6rem;
}

.portal-route-calls-playlists .playlist-console-mix-col:last-child .playlist-console-control-label,
.portal-route-calls-trs-console .playlist-console-mix-col:last-child .playlist-console-control-label {
  width: 5.4rem;
  min-width: 5.4rem;
}

.portal-route-calls-playlists .playlist-console-mix-col:last-child .playlist-console-control-input,
.portal-route-calls-trs-console .playlist-console-mix-col:last-child .playlist-console-control-input {
  max-width: 12rem;
}

.portal-route-calls-playlists .playlist-console-mix-col:last-child .playlist-console-control-row,
.portal-route-calls-trs-console .playlist-console-mix-col:last-child .playlist-console-control-row {
  align-items: center;
}

.portal-route-calls-playlists .playlist-console-control-row,
.portal-route-calls-trs-console .playlist-console-control-row {
  min-width: 0;
}

.playlist-console-start-audio-prompt {
  position: absolute;
  z-index: 1020;
  max-width: 280px;
  display: none;
  pointer-events: auto;
}

.playlist-console-start-audio-prompt.is-visible {
  display: block;
}

body.portalv2-sidebar-open-mobile .playlist-console-start-audio-prompt {
  display: none !important;
}

body.portalv2-sidebar-open-mobile .portal-route-calls-playlists .playlist-console-col,
body.portalv2-sidebar-open-mobile .portal-route-calls-playlists .playlist-console-col .dropdown,
body.portalv2-sidebar-open-mobile .portal-route-calls-playlists .playlist-console-col .dropdown-menu,
body.portalv2-sidebar-open-mobile .portal-route-calls-playlists .portal-monitor-player-shell {
  z-index: 1030 !important;
}

body.portalv2-sidebar-open-mobile .portal-route-calls-playlists .dropdown.show .dropdown-menu {
  display: none !important;
}

.playlist-console-start-audio-prompt__inner {
  position: relative;
}

.playlist-console-start-audio-prompt__body {
  padding: 0.75rem 2rem 0.75rem 0.8rem;
  border: 1px solid rgba(255, 184, 72, 0.78);
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255, 151, 49, 0.98), rgba(255, 116, 28, 0.98));
  color: #2a1203;
  font-size: 0.8rem;
  font-weight: 800;
  line-height: 1.25;
  box-shadow: 0 12px 28px rgba(66, 22, 2, 0.32);
}

.playlist-console-start-audio-prompt__dismiss {
  position: absolute;
  top: 0.28rem;
  right: 0.35rem;
  width: 1.2rem;
  height: 1.2rem;
  border: 0;
  border-radius: 999px;
  background: rgba(76, 26, 4, 0.22);
  color: #522005;
  font-size: 0.95rem;
  font-weight: 900;
  line-height: 1;
  cursor: pointer;
}

.playlist-console-start-audio-prompt__dismiss:hover,
.playlist-console-start-audio-prompt__dismiss:focus {
  background: rgba(76, 26, 4, 0.32);
  color: #2a1203;
  outline: 0;
}

.playlist-console-start-audio-prompt__arrow {
  width: 0;
  height: 0;
  margin: 0 auto;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-bottom: 8px solid rgba(255, 126, 34, 0.98);
}

.playlist-console-tooltip-critical .tooltip-inner,
.portal-route-calls-playlists .playlist-console-tooltip-critical .tooltip-inner {
  max-width: 280px;
  padding: 0.7rem 0.8rem;
  border: 1px solid rgba(255, 184, 72, 0.78);
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255, 151, 49, 0.98), rgba(255, 116, 28, 0.98));
  color: #2a1203;
  font-size: 0.8rem;
  font-weight: 800;
  line-height: 1.25;
  box-shadow: 0 12px 28px rgba(66, 22, 2, 0.32);
}

.playlist-console-tooltip-critical.bs-tooltip-bottom .arrow::before,
.playlist-console-tooltip-critical.bs-tooltip-auto[x-placement^="bottom"] .arrow::before,
.playlist-console-tooltip-critical.bs-tooltip-bottom .tooltip-arrow::before,
.playlist-console-tooltip-critical[data-popper-placement^="bottom"] .tooltip-arrow::before,
.portal-route-calls-playlists .playlist-console-tooltip-critical.bs-tooltip-bottom .arrow::before,
.portal-route-calls-playlists .playlist-console-tooltip-critical.bs-tooltip-auto[x-placement^="bottom"] .arrow::before,
.portal-route-calls-playlists .playlist-console-tooltip-critical.bs-tooltip-bottom .tooltip-arrow::before,
.portal-route-calls-playlists .playlist-console-tooltip-critical[data-popper-placement^="bottom"] .tooltip-arrow::before {
  border-bottom-color: rgba(255, 126, 34, 0.98) !important;
}

.playlist-console-tooltip-critical.bs-tooltip-top .arrow::before,
.playlist-console-tooltip-critical.bs-tooltip-auto[x-placement^="top"] .arrow::before,
.playlist-console-tooltip-critical.bs-tooltip-top .tooltip-arrow::before,
.playlist-console-tooltip-critical[data-popper-placement^="top"] .tooltip-arrow::before,
.portal-route-calls-playlists .playlist-console-tooltip-critical.bs-tooltip-top .arrow::before,
.portal-route-calls-playlists .playlist-console-tooltip-critical.bs-tooltip-auto[x-placement^="top"] .arrow::before,
.portal-route-calls-playlists .playlist-console-tooltip-critical.bs-tooltip-top .tooltip-arrow::before,
.portal-route-calls-playlists .playlist-console-tooltip-critical[data-popper-placement^="top"] .tooltip-arrow::before {
  border-top-color: rgba(255, 126, 34, 0.98) !important;
}

.portal-route-calls-playlists .group-transcription-wrap {
  background: rgba(4, 11, 18, 0.42) !important;
  border: 1px solid rgba(95, 127, 160, 0.16);
}

.portal-route-calls-playlists .pc-route-header,
.portal-route-calls-playlists .pc-priority-header {
  margin: 0.2rem 0.6rem 0.35rem;
  padding: 0.45rem 0 0.4rem;
  background: transparent !important;
  color: #9fdcff !important;
  border-bottom: 1px solid rgba(83, 141, 183, 0.26) !important;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.portal-route-calls-playlists .playlist-console-col .dropdown-menu {
  min-width: 16rem;
  padding: 0.45rem 0;
  border: 1px solid rgba(82, 133, 170, 0.26);
  background:
    radial-gradient(260px 120px at 0% 0%, rgba(39, 141, 210, 0.08), transparent 72%),
    linear-gradient(180deg, rgba(7, 16, 28, 0.985), rgba(4, 11, 20, 0.99)) !important;
  box-shadow: 0 20px 40px rgba(3, 10, 18, 0.56), 0 0 0 1px rgba(102, 180, 222, 0.08);
}

.portal-route-calls-playlists .playlist-console-settings-menu {
  min-width: 14rem;
  padding: 0.45rem 0;
  border: 1px solid rgba(82, 133, 170, 0.26);
  background:
    radial-gradient(260px 120px at 0% 0%, rgba(39, 141, 210, 0.08), transparent 72%),
    linear-gradient(180deg, rgba(7, 16, 28, 0.985), rgba(4, 11, 20, 0.99)) !important;
  box-shadow: 0 20px 40px rgba(3, 10, 18, 0.56), 0 0 0 1px rgba(102, 180, 222, 0.08);
}

.portal-route-calls-playlists .playlist-console-col .dropdown-item {
  margin: 0.08rem 0.45rem;
  width: auto;
  border-radius: 12px;
  padding: 0.62rem 0.85rem;
  color: #eaf5ff !important;
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.15;
}

.portal-route-calls-playlists .playlist-console-settings-menu .dropdown-item {
  margin: 0.08rem 0.45rem;
  width: auto;
  border-radius: 12px;
  padding: 0.62rem 0.85rem;
  color: #eaf5ff !important;
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.15;
}

.portal-route-calls-playlists .playlist-console-col .dropdown-item:hover,
.portal-route-calls-playlists .playlist-console-col .dropdown-item:focus {
  background: linear-gradient(90deg, rgba(74, 205, 255, 0.18), rgba(74, 205, 255, 0.06)) !important;
  color: #ffffff !important;
}

.portal-route-calls-playlists .playlist-console-settings-menu .dropdown-item:hover,
.portal-route-calls-playlists .playlist-console-settings-menu .dropdown-item:focus {
  background: linear-gradient(90deg, rgba(74, 205, 255, 0.18), rgba(74, 205, 255, 0.06)) !important;
  color: #ffffff !important;
}

.portal-route-calls-playlists .playlist-console-col .dropdown-item.pc-priority[data-priority="high"] {
  color: #ffd88a !important;
}

.portal-route-calls-playlists .playlist-console-col .dropdown-item.pc-priority[data-priority="standard"] {
  color: #dcecff !important;
}

.portal-route-calls-playlists .playlist-console-col .dropdown-item.pc-priority[data-priority="low"] {
  color: #b8d2e8 !important;
}

.portal-body:not(.portal-route-calls-playlists):not(.portal-route-calls-trs-console):not(.portal-route-calls-tg):not(.portal-route-calls-fid):not(.portal-route-calls-trs):not(.portal-route-calls-node) .player-display-line {
  color: #f4fbff;
}

.portal-body:not(.portal-route-calls-playlists):not(.portal-route-calls-trs-console):not(.portal-route-calls-tg):not(.portal-route-calls-fid):not(.portal-route-calls-trs):not(.portal-route-calls-node) .player-grouping-line,
.portal-body:not(.portal-route-calls-playlists):not(.portal-route-calls-trs-console):not(.portal-route-calls-tg):not(.portal-route-calls-fid):not(.portal-route-calls-trs):not(.portal-route-calls-node) .player-system-line,
.portal-body:not(.portal-route-calls-playlists):not(.portal-route-calls-trs-console):not(.portal-route-calls-tg):not(.portal-route-calls-fid):not(.portal-route-calls-trs):not(.portal-route-calls-node) .player-low-label {
  color: rgba(188, 210, 229, 0.72);
}

.portal-body:not(.portal-route-calls-playlists):not(.portal-route-calls-tg):not(.portal-route-calls-fid):not(.portal-route-calls-trs):not(.portal-route-calls-node) .player-stat-value,
.portal-body:not(.portal-route-calls-playlists):not(.portal-route-calls-tg):not(.portal-route-calls-fid):not(.portal-route-calls-trs):not(.portal-route-calls-node) .player-low-value {
  color: #9becff;
}

.portal-body .player-transcription-text {
  color: #dceeff;
}

.portal-body .custom-range::-webkit-slider-thumb {
  background: #39d0ff;
}

.portal-body .custom-range::-moz-range-thumb {
  background: #39d0ff;
}

.portal-body .card-deck {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  margin-bottom: 1rem;
}

.portal-body .card-deck .card {
  width: 100%;
  min-width: 0 !important;
  max-width: none !important;
  max-height: none !important;
  margin: 0;
}

.portal-route-calls-playlists .row > [class*='col-'],
.portal-route-calls-status .row > [class*='col-'],
.portal-route-calls-coverage .row > [class*='col-'] {
  display: flex;
  flex-direction: column;
}

.portal-route-calls-playlists .row > [class*='col-'] > .card,
.portal-route-calls-status .row > [class*='col-'] > .card,
.portal-route-calls-coverage .row > [class*='col-'] > .card {
  width: 100%;
}

.portal-body .dropdown-menu {
  min-width: 220px;
}

.portal-body .modal-footer,
.portal-body .modal-header {
  border-color: rgba(95, 127, 160, 0.16);
}

.portal-body .modal-backdrop {
  z-index: 2000 !important;
}

.portal-body .modal {
  z-index: 2010 !important;
}

.portal-body .modal-dialog {
  margin-top: 2rem;
  margin-bottom: 2rem;
}

.portal-body .portal-modal-shell {
  overflow: hidden;
  position: relative;
  z-index: 2011;
}

.portal-body .portal-modal-shell .modal-header {
  padding: 0.95rem 1.15rem;
}

.portal-body .portal-modal-shell .modal-title {
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.portal-body .portal-modal-shell .modal-body {
  padding: 1rem 1.15rem 1.15rem;
}

.portal-body .portal-modal-shell .btn-close {
  opacity: 0.88;
  box-shadow: none;
}

.portal-body .portal-modal-shell .table {
  margin-bottom: 1rem;
}

.portal-body .portal-modal-shell .table th {
  color: #8dcff1;
  font-weight: 700;
}

.portal-body .portal-modal-shell .table td {
  color: #dcecff;
}

.portal-body .portal-modal-shell .table td a {
  color: #7fe7ff;
}

.portal-body .xdsoft_datetimepicker,
.portal-body .xdsoft_datetimepicker .xdsoft_select,
.portal-body .xdsoft_datetimepicker .xdsoft_select.xdsoft_monthselect,
.portal-body .xdsoft_datetimepicker .xdsoft_select.xdsoft_yearselect {
  z-index: 1100 !important;
}

.portal-archive-picker-card .xdsoft_datetimepicker.xdsoft_inline {
  width: 310px !important;
}

.portal-group-detail-section-title {
  color: #ebf5ff;
  font-size: 1.02rem;
  font-weight: 800;
  letter-spacing: 0.01em;
}

.portal-group-detail-table {
  border: 1px solid rgba(95, 127, 160, 0.14);
  border-radius: 18px;
  overflow: hidden;
  background: rgba(16, 28, 42, 0.72);
  max-width: 600px;
}

.portal-group-detail-table th,
.portal-group-detail-table td {
  padding: 0.72rem 0.85rem !important;
  vertical-align: middle;
}

.portal-group-detail-table--summary th {
  width: auto;
  color: #9fdfff;
  font-weight: 700;
  white-space: nowrap;
  padding-right: 1.5rem;
}

.portal-group-detail-table--summary td {
  color: #f0f6ff;
}

.portal-group-detail-table--nodes thead th {
  font-size: 0.83rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.portal-group-detail-table--nodes tbody tr.table-success,
.portal-group-detail-table--nodes tbody tr.table-success > td,
.portal-group-detail-table--nodes tbody tr.table-success > th {
  background: rgba(151, 214, 171, 0.18) !important;
  color: #effff3 !important;
}

.portal-group-detail-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  align-items: center;
}

.portal-group-detail-actions .btn {
  min-height: 2.8rem;
  padding: 0.7rem 1.1rem;
  border-radius: 14px;
  font-weight: 700;
}

.portal-call-detail-table th {
  width: 34%;
}

.portal-call-detail-table td {
  word-break: break-word;
}

.portal-call-detail-transcription {
  white-space: pre-wrap;
}

.portal-call-detail-actions .btn {
  min-width: 220px;
}

.portal-group-detail-playlists {
  border-top: 1px solid rgba(95, 127, 160, 0.16);
  padding-top: 1rem;
}

.portal-body .dataTables_wrapper .dataTables_filter input,
.portal-body .dataTables_wrapper .dataTables_length select,
.portal-body .form-control,
.portal-body .custom-select {
  border-radius: 12px;
}

/* Form controls inside cards — more visible borders */
.portal-body .card .form-control,
.portal-body .card .custom-select {
  border-color: rgba(95, 127, 160, 0.35);
  background: rgba(10, 19, 30, 0.7);
}

.portal-body .card .form-control:focus {
  border-color: rgba(57, 208, 255, 0.5);
  box-shadow: 0 0 0 2px rgba(57, 208, 255, 0.1);
}

.portal-body .dataTables_wrapper .dataTables_length label,
.portal-body .dataTables_wrapper .dataTables_filter label,
.portal-body .dataTables_wrapper .dataTables_info {
  color: var(--portalv2-text);
}

.portal-body .dataTables_wrapper .dataTables_length,
.portal-body .dataTables_wrapper .dataTables_filter {
  margin-bottom: 0.75rem;
}

.portal-body .dataTables_wrapper .dataTables_paginate .paginate_button {
  border-radius: 12px !important;
  border: 1px solid rgba(95, 127, 160, 0.14) !important;
  background: rgba(12, 21, 33, 0.95) !important;
  color: #d9ecff !important;
}

.portal-body .dataTables_wrapper .dataTables_paginate .paginate_button.current {
  background: linear-gradient(135deg, #39d0ff, #92efff) !important;
  color: #08111b !important;
  border-color: transparent !important;
}

.portal-route-calls-trs-console #trsDashboardForm,
.portal-route-calls-playlists #playlistConsoleGrid,
.portal-route-calls-playlists .playlist-console-col,
.portal-route-calls-playlists .playlist-console-grid {
  border-radius: 22px;
}

.portal-route-calls-playlists .playlist-console-statusbar,
.portal-route-calls-playlists .playlist-console-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.9rem;
  flex-wrap: nowrap;
}

.portal-route-calls-playlists .playlist-console-statusbar__items,
.portal-route-calls-playlists .playlist-console-toolbar__items {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  flex-wrap: nowrap;
  min-width: 0;
}

.portal-route-calls-status .status-table-card {
  overflow: hidden;
  border: 1px solid rgba(95, 127, 160, 0.18);
  background:
    radial-gradient(420px 220px at 0% 0%, rgba(57, 208, 255, 0.08), transparent 72%),
    linear-gradient(180deg, rgba(9, 17, 28, 0.98), rgba(6, 12, 20, 0.98));
}

.portal-route-calls-status .status-table-card .card-header {
  padding: 1.25rem 1.15rem 1.1rem;
}

.portal-route-calls-status .status-table-card .card-body {
  padding: 0.75rem 1.15rem 1.15rem;
}

.portal-route-calls-status .status-table-card .card-header h4 {
  font-size: 1.5rem;
}

.portal-route-calls-status .status-table-count {
  font-size: 0.76rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #d8edff;
}

.portal-route-calls-status .portal-table-wrap {
  border-radius: 20px;
  background: rgba(5, 11, 18, 0.86);
}

.portal-route-calls-status .dataTables_wrapper {
  min-height: 640px;
}

.portal-route-calls-status .dataTables_wrapper.is-loading {
  opacity: 0.98;
}

.portal-route-calls-status .portal-status-table {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0;
}

.portal-route-calls-status .portal-status-table thead th {
  padding: 0.72rem 0.74rem;
  border-bottom: 1px solid rgba(95, 127, 160, 0.22) !important;
  color: #eff7ff !important;
  font-size: 0.79rem;
  font-weight: 700;
  letter-spacing: 0.015em;
}

.portal-route-calls-status .portal-status-table tbody td {
  padding: 0.54rem 0.74rem;
  vertical-align: middle;
  border-top: 1px solid rgba(95, 127, 160, 0.12) !important;
  color: #dfeaf6;
  font-size: 0.89rem;
}

.portal-route-calls-status .portal-status-table tbody tr {
  background: rgba(8, 15, 24, 0.72);
}

.portal-route-calls-status .portal-status-table tbody tr:nth-child(even) {
  background: rgba(10, 19, 30, 0.9);
}

.portal-route-calls-status .portal-status-table tbody tr:hover {
  background: linear-gradient(90deg, rgba(57, 208, 255, 0.12), rgba(57, 208, 255, 0.04)) !important;
}

.portal-route-calls-status .status-table-col-id {
  width: 64px;
  font-weight: 700;
  color: #8fe4ff;
}

.portal-route-calls-status .status-table-col-lastseen {
  width: 150px;
}

.portal-route-calls-status .status-table-col-links {
  width: 96px;
  text-align: right;
}

.portal-route-calls-status .status-table-node-name {
  color: #dfeaf6;
  font-weight: 450;
}

.portal-route-calls-status .status-table-last-seen {
  display: inline-flex;
  align-items: center;
  padding: 0.18rem 0.42rem;
  border-radius: 999px;
  font-size: 0.71rem;
  font-family: inherit;
  letter-spacing: 0.01em;
}

.portal-route-calls-status .status-table-links {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.45rem;
}

.portal-route-calls-status .status-table-links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.8rem;
  height: 1.8rem;
  border-radius: 999px;
  background: rgba(17, 31, 48, 0.92);
  border: 1px solid rgba(95, 127, 160, 0.16);
  text-decoration: none !important;
}

.portal-route-calls-status .status-table-links a:hover {
  background: rgba(25, 46, 70, 0.96);
  border-color: rgba(57, 208, 255, 0.28);
  text-decoration: none !important;
}

.portal-route-calls-status .portal-status-table-controls,
.portal-route-calls-status .portal-status-table-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.9rem;
  padding: 0.95rem 0.55rem 0;
  flex-wrap: wrap;
}

.portal-route-calls-status .portal-status-table-controls-top {
  padding-top: 0.45rem;
  padding-bottom: 0.85rem;
  border-bottom: 1px solid rgba(95, 127, 160, 0.12);
}

.portal-route-calls-status .portal-status-table-controls .dataTables_length,
.portal-route-calls-status .portal-status-table-controls .dataTables_filter,
.portal-route-calls-status .portal-status-table-controls .dataTables_paginate,
.portal-route-calls-status .portal-status-table-footer .dataTables_info,
.portal-route-calls-status .portal-status-table-footer .dataTables_paginate {
  float: none !important;
  margin: 0;
}

.portal-route-calls-status .portal-status-table-controls .dataTables_length label,
.portal-route-calls-status .portal-status-table-controls .dataTables_filter label,
.portal-route-calls-status .portal-status-table-footer .dataTables_info {
  color: #a9bfd4;
  font-size: 0.78rem;
  font-weight: 600;
}

.portal-route-calls-status .portal-status-table-controls .dataTables_filter input,
.portal-route-calls-status .portal-status-table-controls .dataTables_length select {
  min-height: 2.2rem;
  padding: 0.38rem 0.72rem;
  border: 1px solid rgba(95, 127, 160, 0.18);
  background: rgba(12, 23, 36, 0.96);
  color: #edf7ff;
  box-shadow: none;
}

.portal-route-calls-status .portal-status-table-controls .dataTables_filter input {
  min-width: 280px;
}

.portal-route-calls-status .portal-status-table-controls .dataTables_paginate {
  margin-left: auto;
}

.portal-route-calls-status .portal-status-table .sorting,
.portal-route-calls-status .portal-status-table .sorting_asc,
.portal-route-calls-status .portal-status-table .sorting_desc {
  background-image: none !important;
}

.portal-route-calls-status .dataTables_wrapper .dataTables_processing {
  border: 1px solid rgba(95, 127, 160, 0.18);
  border-radius: 16px;
  background: rgba(7, 15, 24, 0.98);
  color: #ebf7ff;
  box-shadow: var(--portalv2-shadow);
}

@media (max-width: 767.98px) {
  .portal-route-calls-status .portal-status-table-controls .dataTables_filter input {
    min-width: 0;
    width: 100%;
  }

  .portal-route-calls-status .status-table-card .card-header,
  .portal-route-calls-status .status-table-card .card-body {
    padding-left: 0.85rem;
    padding-right: 0.85rem;
  }
}

.portal-route-calls-manage .manage-table-card {
  overflow: hidden;
}

.portal-route-calls-manage .portal-manage-table {
  width: 100%;
  margin-bottom: 0;
  border-collapse: separate;
  border-spacing: 0;
  table-layout: fixed;
}

.portal-route-calls-manage .portal-manage-table thead th {
  padding: 0.72rem 0.74rem;
  border-bottom: 1px solid rgba(95, 127, 160, 0.22) !important;
  color: #eff7ff !important;
  font-size: 0.79rem;
  font-weight: 700;
  letter-spacing: 0.015em;
}

.portal-route-calls-manage .portal-manage-table tbody td {
  padding: 0.54rem 0.74rem;
  vertical-align: middle;
  border-top: 1px solid rgba(95, 127, 160, 0.12) !important;
  color: #dfeaf6;
  font-size: 0.89rem;
  background: rgba(8, 15, 24, 0.72);
}

.portal-route-calls-manage .portal-manage-table thead th:nth-child(1),
.portal-route-calls-manage .portal-manage-table tbody td:nth-child(1) {
  width: 46%;
}

.portal-route-calls-manage .portal-manage-table thead th:nth-child(2),
.portal-route-calls-manage .portal-manage-table tbody td:nth-child(2) {
  width: 28%;
}

.portal-route-calls-manage .portal-manage-table thead th:nth-child(3),
.portal-route-calls-manage .portal-manage-table tbody td:nth-child(3) {
  width: 14%;
}

.portal-route-calls-manage .portal-manage-table thead th:nth-child(4),
.portal-route-calls-manage .portal-manage-table tbody td:nth-child(4) {
  width: 12%;
}

.portal-route-calls-manage .portal-manage-table tbody tr:nth-child(even) td {
  background: rgba(10, 19, 30, 0.9);
}

.portal-route-calls-manage .portal-manage-table tbody tr:hover td {
  background: linear-gradient(90deg, rgba(57, 208, 255, 0.12), rgba(57, 208, 255, 0.04)) !important;
}

.portal-route-calls-manage .portal-manage-table .status-table-node-name {
  color: #dfeaf6;
  font-weight: 450;
  white-space: nowrap;
  overflow: hidden;
}

.portal-route-calls-manage .portal-manage-table .status-table-node-name-text {
  display: inline-block;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: middle;
}

.portal-route-calls-manage .portal-manage-table .status-table-links {
  white-space: nowrap;
}

.portal-route-calls-manage .portal-manage-table .status-table-links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.8rem;
  height: 1.8rem;
  border-radius: 999px;
  background: rgba(17, 31, 48, 0.92);
  border: 1px solid rgba(95, 127, 160, 0.16);
  text-decoration: none !important;
}

.portal-route-calls-manage .portal-manage-table .status-table-links a:hover {
  background: rgba(25, 46, 70, 0.96);
  border-color: rgba(57, 208, 255, 0.28);
  text-decoration: none !important;
}

@media (max-width: 767.98px) {
  .portal-route-calls-manage .manage-col-type {
    display: none;
  }
}

/* --- Detail / key-value tables (manage node, etc.) --- */
.portal-detail-table {
  border-collapse: separate;
  border-spacing: 0;
}

.portal-detail-table th {
  padding: 0.65rem 1rem;
  white-space: nowrap;
  color: rgba(180, 200, 220, 0.72);
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  border-top: 1px solid rgba(95, 127, 160, 0.10);
  width: 1%;
  vertical-align: middle;
}

.portal-detail-table td {
  padding: 0.65rem 1rem;
  color: #dfeaf6;
  font-size: 0.89rem;
  border-top: 1px solid rgba(95, 127, 160, 0.10);
  vertical-align: middle;
}

.portal-detail-table tr:first-child th,
.portal-detail-table tr:first-child td {
  border-top: none;
}

.portal-detail-table .form-control {
  background: rgba(8, 15, 24, 0.6);
  border-color: rgba(95, 127, 160, 0.22);
  color: #dfeaf6;
}

.portal-detail-status-pill {
  display: inline-block;
  padding: 0.15rem 0.55rem;
  border-radius: 4px;
  font-size: 0.84rem;
}

.portal-supported-apps-table thead th {
  padding: 0.75rem 1.15rem;
  border-bottom: 1px solid rgba(95, 127, 160, 0.22);
  color: #eff7ff;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.015em;
  border-top: none;
}

.portal-supported-apps-table tbody td {
  padding: 0.8rem 1.15rem;
  vertical-align: middle;
  border-top: 1px solid rgba(95, 127, 160, 0.12);
  color: #dfeaf6;
  font-size: 0.9rem;
}

.portal-supported-apps-table tbody tr:hover {
  background: linear-gradient(90deg, rgba(57, 208, 255, 0.1), rgba(57, 208, 255, 0.03));
}

.portal-route-calls-playlists .playlist-console-statusbar__label,
.portal-route-calls-playlists .playlist-console-statusbar__item,
.portal-route-calls-playlists .playlist-console-toolbar__toggle {
  white-space: nowrap;
}

.portal-route-calls-playlists .playlist-console-statusbar__action,
.portal-route-calls-playlists .playlist-console-toolbar__settings {
  margin-left: auto;
  flex-shrink: 0;
}

.portal-route-calls-playlists .playlist-console-statusbar__action {
  font-family: inherit !important;
  letter-spacing: normal;
}

.portal-route-calls-playlists #pcStartAudioBtn.btn-warning {
  background: linear-gradient(180deg, rgba(255, 156, 53, 0.98), rgba(255, 115, 31, 0.98)) !important;
  border-color: rgba(255, 176, 77, 0.82) !important;
  color: #2a1203 !important;
  box-shadow: 0 10px 24px rgba(66, 22, 2, 0.24);
}

.portal-route-calls-playlists .playlist-console-toolbar .custom-control {
  margin-right: 0;
  margin-left: 0;
}

.portal-route-calls-playlists .playlist-console-toolbar .btn,
.portal-route-calls-playlists .playlist-console-statusbar .btn {
  flex-shrink: 0;
}

.portal-route-calls-trs-console #trsDashboardForm {
  padding: 0;
}

.portal-route-calls-trs-console #dashboardStatus,
.portal-route-calls-trs-console .text-monospace,
.portal-route-calls-tg .text-monospace,
.portal-route-calls-fid .text-monospace,
.portal-route-calls-src .text-monospace,
.portal-route-calls-node .text-monospace,
.portal-route-calls-trs .text-monospace {
  color: #d7ebff !important;
}

.portal-route-calls-coverage .jstree-proton,
.portal-route-calls-coverage #locTree {
  padding: 0.9rem;
  border-radius: 18px;
  background: rgba(8, 15, 24, 0.92);
}

.portal-route-calls-src table.w-50,
.portal-route-calls-node table.table-borderless,
.portal-route-calls-fid table.table-borderless,
.portal-route-calls-tg table.table-borderless {
  width: 100% !important;
}

.portal-route-calls-tg .portal-player-card,
.portal-route-calls-tg .portal-player-card__controls-card,
.portal-route-calls-tg .portal-tg-live-table-card,
.portal-route-calls-tg .portal-tg-chart-card,
.portal-route-calls-fid .portal-player-card,
.portal-route-calls-fid .portal-player-card__controls-card,
.portal-route-calls-fid .portal-monitor-table-card,
.portal-route-calls-fid .portal-monitor-chart-card,
.portal-route-calls-tg .portal-monitor-table-card,
.portal-route-calls-tg .portal-monitor-chart-card,
.portal-route-calls-tg .portal-archive-picker-card,
.portal-route-calls-fid .portal-archive-picker-card,
.portal-route-calls-trs .portal-player-card,
.portal-route-calls-trs .portal-player-card__controls-card,
.portal-route-calls-node .portal-player-card,
.portal-route-calls-node .portal-player-card__controls-card {
  border: 1px solid rgba(95, 127, 160, 0.16);
  border-radius: 24px;
  box-shadow: var(--portalv2-shadow);
  overflow: hidden;
}

/* Controls card needs overflow: visible so dropdown menus can escape */
.portal-route-calls-playlists .portal-player-card__controls-card,
.portal-route-calls-trs .portal-player-card__controls-card,
.portal-route-calls-node .portal-player-card__controls-card {
  overflow: visible;
}

.portal-route-calls-tg .portal-player-card > .card-header,
.portal-route-calls-tg .portal-player-card__controls-card > .card-header,
.portal-route-calls-tg .portal-tg-live-table-card > .card-header,
.portal-route-calls-tg .portal-tg-chart-card > .card-header,
.portal-route-calls-fid .portal-player-card > .card-header,
.portal-route-calls-fid .portal-player-card__controls-card > .card-header,
.portal-route-calls-fid .portal-monitor-table-card > .card-header,
.portal-route-calls-fid .portal-monitor-chart-card > .card-header,
.portal-route-calls-tg .portal-monitor-table-card > .card-header,
.portal-route-calls-fid .portal-archive-picker-card > .card-header,
.portal-route-calls-tg .portal-archive-picker-card > .card-header,
.portal-route-calls-trs .portal-player-card > .card-header,
.portal-route-calls-trs .portal-player-card__controls-card > .card-header,
.portal-route-calls-node .portal-player-card > .card-header,
.portal-route-calls-node .portal-player-card__controls-card > .card-header {
  padding: 0.7rem 1rem;
}

.portal-route-calls-tg .portal-player-card .card-body,
.portal-route-calls-tg .portal-player-card__controls-card .card-body,
.portal-route-calls-tg .portal-tg-live-table-card .card-body,
.portal-route-calls-tg .portal-tg-chart-card .card-body,
.portal-route-calls-fid .portal-player-card .card-body,
.portal-route-calls-fid .portal-player-card__controls-card .card-body,
.portal-route-calls-fid .portal-monitor-table-card .card-body,
.portal-route-calls-fid .portal-monitor-chart-card .card-body,
.portal-route-calls-tg .portal-monitor-table-card .card-body,
.portal-route-calls-fid .portal-archive-picker-card .card-body,
.portal-route-calls-tg .portal-archive-picker-card .card-body,
.portal-route-calls-trs .portal-player-card .card-body,
.portal-route-calls-trs .portal-player-card__controls-card .card-body,
.portal-route-calls-node .portal-player-card .card-body,
.portal-route-calls-node .portal-player-card__controls-card .card-body {
  padding: 1rem;
}

.portal-route-calls-tg .portal-monitor-grid,
.portal-route-calls-fid .portal-monitor-grid {
  align-items: stretch;
}

.portal-route-calls-tg .portal-monitor-player-shell,
.portal-route-calls-fid .portal-monitor-player-shell,
.portal-route-calls-trs .portal-monitor-player-shell,
.portal-route-calls-node .portal-monitor-player-shell {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.portal-route-calls-tg #volumeRow,
.portal-route-calls-tg #pannerRow,
.portal-route-calls-fid #volumeRow,
.portal-route-calls-fid #pannerRow {
  height: 100%;
}

.portal-route-calls-tg .portal-monitor-controls,
.portal-route-calls-fid .portal-monitor-controls {
  display: grid;
  grid-template-columns: minmax(10rem, auto) auto auto auto;
  align-items: center;
  gap: 0.75rem;
  justify-content: start;
}

.portal-route-calls-tg .portal-monitor-controls .portal-player-card__primary,
.portal-route-calls-fid .portal-monitor-controls .portal-player-card__primary {
  min-width: 10rem;
}

.portal-route-calls-tg .portal-monitor-controls .portal-player-card__group,
.portal-route-calls-fid .portal-monitor-controls .portal-player-card__group {
  display: inline-grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.65rem;
  min-width: 0;
}

.portal-route-calls-tg .portal-monitor-controls .portal-player-card__group .btn,
.portal-route-calls-tg .portal-monitor-controls .portal-player-card__icon,
.portal-route-calls-tg .portal-monitor-controls .portal-player-card__primary,
.portal-route-calls-fid .portal-monitor-controls .portal-player-card__group .btn,
.portal-route-calls-fid .portal-monitor-controls .portal-player-card__icon,
.portal-route-calls-fid .portal-monitor-controls .portal-player-card__primary {
  min-height: 3rem;
}

.portal-route-calls-tg .portal-monitor-controls .portal-player-card__icon,
.portal-route-calls-fid .portal-monitor-controls .portal-player-card__icon {
  width: 3rem;
  min-width: 3rem;
  padding: 0;
}

.portal-route-calls-tg .portal-monitor-table-card #callsTable,
.portal-route-calls-fid .portal-monitor-table-card #callsTable {
  width: 100% !important;
  table-layout: auto !important;
  border-collapse: separate !important;
  border-spacing: 0;
  margin-bottom: 0 !important;
}

.portal-route-calls-tg .portal-monitor-table-card .card-body,
.portal-route-calls-fid .portal-monitor-table-card .card-body {
  padding: 0.4rem 0.55rem 0.55rem;
}

.portal-route-calls-tg .portal-monitor-table-card #callsTable thead th,
.portal-route-calls-fid .portal-monitor-table-card #callsTable thead th {
  border: 0;
  padding: 0.54rem 0.68rem !important;
  font-size: 0.79rem;
  font-weight: 700;
  background: linear-gradient(90deg, rgba(14, 44, 65, 0.94), rgba(8, 25, 38, 0.96)) !important;
  color: #edf7ff;
}

.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody tr,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody tr {
  background: rgba(29, 38, 53, 0.9);
}

.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody tr:nth-child(even),
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody tr:nth-child(even) {
  background: rgba(25, 34, 49, 0.92);
}

.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody td,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody td {
  padding: 0.46rem 0.68rem !important;
  border-top: 1px solid rgba(95, 127, 160, 0.12);
  vertical-align: middle;
}

.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody td a,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody td a {
  color: #7fe7ff;
  font-weight: 550;
}

.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody td:first-child,
.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody td:last-child,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody td:first-child,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody td:last-child {
  white-space: nowrap;
}

.portal-route-calls-tg .portal-monitor-table-card #callsTable thead th:first-child,
.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody td:first-child,
.portal-route-calls-fid .portal-monitor-table-card #callsTable thead th:first-child,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody td:first-child,
.portal-route-calls-tg .portal-monitor-table-card #callsTable thead th:nth-child(3),
.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody td:nth-child(3),
.portal-route-calls-fid .portal-monitor-table-card #callsTable thead th:nth-child(3),
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody td:nth-child(3),
.portal-route-calls-tg .portal-monitor-table-card #callsTable thead th:nth-child(4),
.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody td:nth-child(4),
.portal-route-calls-fid .portal-monitor-table-card #callsTable thead th:nth-child(4),
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody td:nth-child(4),
.portal-route-calls-tg .portal-monitor-table-card #callsTable thead th:last-child,
.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody td:last-child,
.portal-route-calls-fid .portal-monitor-table-card #callsTable thead th:last-child,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody td:last-child {
  width: 1%;
}

.portal-route-calls-tg .portal-monitor-table-card #callsTable thead th:nth-child(2),
.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody td:nth-child(2),
.portal-route-calls-fid .portal-monitor-table-card #callsTable thead th:nth-child(2),
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody td:nth-child(2) {
  width: auto;
}

.portal-route-calls-tg .portal-monitor-table-card #callsTable thead th:last-child,
.portal-route-calls-fid .portal-monitor-table-card #callsTable thead th:last-child,
.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody td:last-child,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody td:last-child {
  min-width: 2.4rem;
  max-width: 2.4rem;
  padding-left: 0.35rem !important;
  padding-right: 0.35rem !important;
  text-align: right;
}

.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody td:last-child .small,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody td:last-child .small {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.3rem;
  white-space: nowrap;
}

.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody td:last-child a,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody td:last-child a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
}

.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody tr.table-success,
.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody tr.table-success > td,
.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody tr.table-success > th,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody tr.table-success,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody tr.table-success > td,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody tr.table-success > th {
  background-color: rgba(212, 193, 123, 0.3) !important;
  color: #fff8dc !important;
}

.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody tr.table-success td a,
.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody tr.table-success td .fa,
.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody tr.table-success td .fas,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody tr.table-success td a,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody tr.table-success td .fa,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody tr.table-success td .fas {
  color: #fff8dc !important;
  background: transparent !important;
  box-shadow: none !important;
}

.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody tr.table-success td:first-child .fa-play,
.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody tr.table-success td:first-child .fa-stop,
.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody tr.table-success td:first-child .fa-square,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody tr.table-success td:first-child .fa-play,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody tr.table-success td:first-child .fa-stop,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody tr.table-success td:first-child .fa-square {
  color: #ffd15b !important;
}

.portal-route-calls-tg .portal-monitor-chart-card,
.portal-route-calls-fid .portal-monitor-chart-card,
.portal-route-calls-tg .portal-archive-picker-card,
.portal-route-calls-fid .portal-archive-picker-card {
  background:
    radial-gradient(720px 260px at 0% 0%, rgba(57, 208, 255, 0.1), transparent 60%),
    linear-gradient(180deg, rgba(10, 20, 31, 0.98), rgba(6, 13, 22, 0.99));
}

.portal-route-calls-tg .portal-monitor-chart-card .card-body,
.portal-route-calls-fid .portal-monitor-chart-card .card-body {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.8rem 1rem 1rem;
  background: transparent;
}

.portal-route-calls-tg .portal-monitor-chart-card canvas,
.portal-route-calls-fid .portal-monitor-chart-card canvas {
  width: 100% !important;
  max-width: 100%;
  display: block;
  background: transparent !important;
  border-radius: 0 !important;
}

.portal-route-calls-tg .portal-monitor-controls .portal-player-card__icon i,
.portal-route-calls-fid .portal-monitor-controls .portal-player-card__icon i {
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.portal-route-calls-tg .portal-monitor-table-card .dataTables_wrapper,
.portal-route-calls-fid .portal-monitor-table-card .dataTables_wrapper {
  margin: 0;
  padding: 0;
}

.portal-route-calls-tg .portal-monitor-table-card .table,
.portal-route-calls-fid .portal-monitor-table-card .table {
  margin-bottom: 0;
}

.portal-route-calls-tg .portal-monitor-table-card .dataTables_wrapper .dataTables_length,
.portal-route-calls-tg .portal-monitor-table-card .dataTables_wrapper .dataTables_filter,
.portal-route-calls-tg .portal-monitor-table-card .dataTables_wrapper .dataTables_info,
.portal-route-calls-tg .portal-monitor-table-card .dataTables_wrapper .dataTables_paginate,
.portal-route-calls-fid .portal-monitor-table-card .dataTables_wrapper .dataTables_length,
.portal-route-calls-fid .portal-monitor-table-card .dataTables_wrapper .dataTables_filter,
.portal-route-calls-fid .portal-monitor-table-card .dataTables_wrapper .dataTables_info,
.portal-route-calls-fid .portal-monitor-table-card .dataTables_wrapper .dataTables_paginate {
  margin: 0;
}

.portal-route-calls-tg .portal-monitor-controls .portal-player-card__icon,
.portal-route-calls-fid .portal-monitor-controls .portal-player-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody tr.archive-focus,
.portal-route-calls-tg .portal-monitor-table-card #callsTable tbody tr.archive-focus > td,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody tr.archive-focus,
.portal-route-calls-fid .portal-monitor-table-card #callsTable tbody tr.archive-focus > td {
  background-color: rgba(212, 193, 123, 0.22) !important;
}

.portal-route-calls-src .container,
.portal-route-calls-node .container,
.portal-route-calls-fid .container,
.portal-route-calls-tg .container,
.portal-route-calls-trs .container {
  max-width: 100%;
}

.portal-body hr {
  border-color: rgba(95, 127, 160, 0.14);
}

@media (max-width: 991.98px) {
  .portal-route-calls-home .border-bottom:first-of-type .container,
  .portal-route-calls-playlists .w-lg-75.text-center,
  .portal-route-calls-trs-console .w-lg-75.text-center,
  .portal-route-calls-coverage .w-lg-75.text-center,
  .portal-route-calls-status .w-lg-75.text-center,
  .portal-route-calls-tg .w-lg-75.text-center,
  .portal-route-calls-fid .w-lg-75.text-center,
  .portal-route-calls-trs .w-lg-75.text-center,
  .portal-route-calls-node .w-lg-75.text-center {
    padding: 1.15rem !important;
  }

  .portal-body .card-deck {
    grid-template-columns: 1fr;
  }

  .portal-route-calls-playlists .playlist-console-statusbar,
  .portal-route-calls-playlists .playlist-console-toolbar {
    flex-wrap: wrap;
    align-items: flex-start;
  }

  .portal-route-calls-playlists .playlist-console-statusbar__items,
  .portal-route-calls-playlists .playlist-console-toolbar__items {
    flex-wrap: wrap;
  }

  .portal-route-calls-playlists .playlist-console-statusbar__action,
  .portal-route-calls-playlists .playlist-console-toolbar__settings {
    margin-left: 0;
  }

  .portal-route-calls-tg .player-group-banner {
    grid-template-columns: 1fr;
    grid-template-areas:
      "v"
      "b"
      "d"
      "g"
      "s"
      "src"
      "fr"
      "nd";
  }

  .portal-route-calls-tg .player-system-line,
  .portal-route-calls-tg .player-freq-item,
  .portal-route-calls-tg .player-node-item {
    justify-self: start;
    text-align: left;
  }

  .portal-route-calls-tg .portal-tg-live-controls .portal-player-card__group {
    width: 100%;
  }

  .portal-route-calls-tg .portal-monitor-controls,
  .portal-route-calls-fid .portal-monitor-controls {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .portal-route-calls-tg .portal-monitor-controls .portal-player-card__primary,
  .portal-route-calls-fid .portal-monitor-controls .portal-player-card__primary,
  .portal-route-calls-tg .portal-monitor-controls .portal-player-card__group,
  .portal-route-calls-fid .portal-monitor-controls .portal-player-card__group {
    width: 100%;
  }

  .portal-route-calls-fid .player-group-banner {
    grid-template-columns: 1fr;
    grid-template-areas:
      "v"
      "b"
      "d"
      "g"
      "s"
      "src"
      "fr"
      "nd";
  }

  .portal-route-calls-fid .player-system-line,
  .portal-route-calls-fid .player-freq-item,
  .portal-route-calls-fid .player-node-item {
    justify-self: start;
    text-align: left;
  }

  .portal-route-calls-fid .portal-monitor-controls .portal-player-card__group {
    width: 100%;
  }
}
