* {box-sizing: border-box;}
:root { --timeline-footer-height: 145px; }

body {
  font-family: Inter, "Segoe UI", Roboto, Arial, sans-serif;
  margin: 0;
  color: #eef2ff;
  background: radial-gradient(circle at 20% 20%, #243b77 0%, #141a2e 35%, #0b0f19 100%);
  min-height: 100vh;
}

body::before {
  content: "";
  position: fixed;
  inset: -30vmax;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(circle at 25% 15%, rgba(90, 161, 255, 0.28), transparent 40%),
    radial-gradient(circle at 80% 85%, rgba(80, 216, 177, 0.22), transparent 40%);
  animation: float-bg 18s ease-in-out infinite alternate;
}

@keyframes float-bg {
  from {transform: translate3d(-2%, -2%, 0) scale(1);}
  to {transform: translate3d(2%, 2%, 0) scale(1.08);}
}

.container {max-width: 1240px; margin: 0 auto; padding: 1.25rem;}
.container.small {max-width: 420px;}
a {color: #9dd1ff;}
label {display:block; margin-bottom: .75rem;}
input,
select {
  width: 100%;
  padding: .65rem .75rem;
  margin-top: .25rem;
  border: 1px solid #31405f;
  border-radius: 10px;
  background: #0e1323;
  color: #f4f7ff;
}

input.input-invalid {
  border-color: rgba(255, 124, 124, 0.95);
  box-shadow: 0 0 0 1px rgba(255, 124, 124, 0.55);
}

.field-error {
  min-height: 1.05rem;
  margin: .35rem 0 0;
  font-size: .82rem;
  color: #ffb4b4;
}
button {padding: .6rem 1rem; margin-right: .5rem;}
.error {background: #5a1616; color: #ffd7d7; padding: .8rem; margin-bottom:1rem; border-radius: 6px;}
.notice {background: #1a4f2a; color: #d7ffe4; padding: .8rem; margin-bottom:1rem; border-radius: 6px;}
video {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 0;
  background: #000;
  border-radius: 16px;
  object-fit: contain;
}
.controls {margin-bottom: 1rem; display: grid; gap: .75rem;}
.settings-dialog {max-width: 700px; width: min(92vw, 700px); border: 1px solid #2f4b8d; border-radius: 12px; background: #0f1a33; color: #fff; padding: 1rem 1.2rem;}
.settings-dialog::backdrop {background: rgba(0, 0, 0, 0.7);}
.dialog-close-row {display: flex; justify-content: flex-end; margin-bottom: .5rem;}
.dialog-actions {margin-top: 1rem; display: flex; justify-content: flex-end;}

.mini.meta-text,
.meta-text {color: #a7b9e3;}


.app-shell {
  display: grid;
  grid-template-columns: clamp(220px, 18vw, 290px) minmax(0, 1fr);
  gap: clamp(.9rem, 1.6vw, 1.5rem);
  width: 100%;
  margin: 0 auto;
  padding: 1rem 1rem .7rem;
  height: calc(100vh - var(--timeline-footer-height));
  overflow: hidden;
}

.app-sidebar {
  border: 1px solid rgba(83, 124, 212, 0.35);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(6, 22, 45, 0.85), rgba(3, 14, 30, 0.95));
  padding: 1.3rem;
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
  overflow: hidden;
}

.sidebar-brand { font-size: 2rem; font-weight: 800; display: flex; gap: .65rem; align-items: center; }
.sidebar-brand span { font-size: 2.1rem; }
.sidebar-nav { margin-top: 1.2rem; display: grid; gap: .8rem; }
.sidebar-link--anchor { text-align: center; display: block; text-decoration: none; }
.sidebar-link.sidebar-link--admin {
  color: #ffe2e2;
  border-color: rgba(239, 68, 68, 0.55);
  background: linear-gradient(145deg, rgba(153, 27, 27, 0.72), rgba(127, 29, 29, 0.58));
}
.sidebar-link.sidebar-link--admin:hover { filter: brightness(1.08); }
.sidebar-link {
  margin: 0;
  border: 1px solid rgba(70, 103, 177, 0.45);
  border-radius: 12px;
  color: #dce9ff;
  background: rgba(6, 26, 53, 0.66);
  text-align: left;
  padding: .85rem 1rem;
  font: inherit;
  font-size: 1rem;
  line-height: 1.2;
}
.sidebar-link.is-active { background: rgba(33, 73, 162, 0.45); color: #fff; }
.sidebar-timezone {
  margin-top: auto;
  border: 1px solid rgba(70, 103, 177, 0.45);
  border-radius: 12px;
  padding: .85rem 1rem;
  color: #acc2ed;
  font-size: .95rem;
}

.watch-main {
  border: 1px solid rgba(99, 131, 202, 0.3);
  border-radius: 16px;
  background: rgba(4, 14, 30, 0.82);
  padding: clamp(.95rem, 1.5vw, 1.25rem);
  height: 100%;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.watch-panel { display: none; }
.watch-panel.is-active {
  display: flex;
  flex-direction: column;
  min-height: 0;
  height: 100%;
}
.settings-list {
  display: grid;
  gap: .75rem;
  max-width: 680px;
}
.settings-toggle {
  margin: 0;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: start;
  gap: .75rem;
  padding: .8rem .9rem;
  border: 1px solid rgba(70, 103, 177, 0.45);
  border-radius: 10px;
  background: rgba(6, 26, 53, 0.45);
}
.settings-toggle input[type="checkbox"] {
  width: 1.05rem;
  height: 1.05rem;
  margin: .2rem 0 0;
}
.settings-toggle strong { display: block; color: #e4eeff; font-size: .97rem; }
.settings-toggle small { color: #b8caef; font-size: .86rem; }
.watch-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; }
.watch-main h1 { margin: 0 0 .35rem; font-weight: 800; }
.subtitle { margin: 0 0 1rem; color: #b8caef; }
.header-actions { display: inline-flex; align-items: center; gap: .75rem; }
.grid-controls-toggle { display: none; }
.live-indicator { border: 1px solid rgba(68, 201, 125, 0.65); color: #54dc95; border-radius: 10px; padding: .62rem .95rem; font-weight: 700; }

.watch-main .controls {
  border: 1px solid rgba(70, 103, 177, 0.45);
  border-radius: 12px;
  padding: .95rem 1rem;
  margin-bottom: .6rem;
  grid-template-columns: repeat(4, minmax(150px, 1fr));
  grid-template-areas: "season stream start end" "actions actions actions actions";
  column-gap: .75rem;
  row-gap: .35rem;
}

.watch-main .field:nth-child(1) { grid-area: season; }
.watch-main .field:nth-child(2) { grid-area: stream; }
.watch-main .field:nth-child(3) { grid-area: start; }
.watch-main .field:nth-child(4) { grid-area: end; }
.watch-main .field { display: flex; flex-direction: column; justify-content: flex-start; }
.watch-main .field label { margin: 0 0 .4rem; font-size: .92rem; color: #d8e4ff; line-height: 1.2; }
.watch-main .controls .field-error {
  min-height: 0;
  margin: .15rem 0 0;
}
.watch-main .controls .field-error:empty { display: none; }
.watch-main .field:nth-child(1) select,
.watch-main .field:nth-child(2) .custom-select__trigger,
.watch-main .field:nth-child(3) input,
.watch-main .field:nth-child(4) input {
  min-height: 3rem;
  margin-top: 0;
}
.watch-main button { margin: 0; }

.custom-select,.back-dropdown { position: relative; }
.custom-select__trigger {
  width: 100%; margin: 0; padding: .68rem .75rem; border-radius: 10px; border: 1px solid #31405f; background: #0e1323; color: #f4f7ff;
  display: flex; justify-content: space-between; align-items: center;
}
.custom-select__arrow,.back-dropdown__arrow { color: #93a7d9; margin-left: .5rem; }
.custom-select__menu,.back-dropdown__menu {
  position: absolute; top: calc(100% + .35rem); left: 0; min-width: 160px; right: 0; max-height: 260px; overflow: auto;
  background: #0d1831; border: 1px solid #314f90; border-radius: 10px; padding: .3rem; margin: 0; list-style: none; z-index: 20; display: none;
}
.custom-select.is-open .custom-select__menu,.back-dropdown.is-open .back-dropdown__menu { display: block; }
.custom-select__option,.back-dropdown__option { padding: .58rem .65rem; border-radius: 8px; cursor: pointer; }
.custom-select__option:hover,.custom-select__option[aria-selected="true"],.back-dropdown__option:hover { background: rgba(76, 126, 255, 0.22); }

.actions { grid-area: actions; display: flex; gap: .65rem; align-items: center; flex-wrap: wrap; justify-content: center; margin-top: .1rem; }
.btn { border: none; border-radius: 11px; color: #fff; font-weight: 600; cursor: pointer; transition: transform .2s ease, filter .2s ease, box-shadow .25s ease; box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2); }
.btn:hover { transform: translateY(-1px); filter: brightness(1.06); }
.btn:active { transform: translateY(1px); }
.btn-live { background: linear-gradient(145deg, #1ca767, #168953); }
.btn-playback { background: linear-gradient(145deg, #3158d5, #2a48b3); }
.btn-share { background: linear-gradient(145deg, #8b5cf6, #6d28d9); }
.btn-download { background: linear-gradient(145deg, #ef4444, #c0392b); }
.btn-back { background: linear-gradient(145deg, #64748b, #475569); }
.btn[disabled] { opacity: .55; cursor: not-allowed; transform: none; filter: none; }

.player-shell {
  display: flex;
  flex: 1;
  min-height: 0;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(144, 175, 255, 0.25);
  width: 100%;
  position: relative;
  isolation: isolate;
}
.grid-shell { display: none; flex-direction: column; gap: .7rem; flex: 1; min-height: 0; }
.watch-layout[data-layout-mode="grid"] .player-shell { display: none; }
.watch-layout[data-layout-mode="grid"] .grid-shell { display: flex; }
.watch-layout[data-layout-mode="grid"] .grid-controls-toggle { display: inline-flex; }
.watch-layout[data-layout-mode="grid"] .controls.is-grid-overlay {
  position: absolute;
  top: 74px;
  right: 18px;
  z-index: 40;
  max-width: 780px;
  width: min(92vw, 780px);
  background: rgba(5, 16, 33, 0.97);
  box-shadow: 0 18px 40px rgba(0,0,0,.45);
  display: none;
}
.watch-layout[data-layout-mode="grid"] .controls.is-grid-overlay.is-grid-overlay-open { display: grid; }
.grid-shell__header { display: flex; justify-content: space-between; align-items: center; }
.grid-shell__header h2 { margin: 0; font-size: 1rem; color: #cadcff; }
.grid-status { color: #9eb8ea; font-size: .85rem; min-height: 1.1rem; }
.grid-tiles {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(215px, 1fr));
  gap: .3rem;
  overflow: auto;
  padding-right: .1rem;
}
.grid-tile {
  border: 1px solid rgba(87, 117, 182, 0.45);
  border-radius: 8px;
  background: #020910;
  display: grid;
  grid-template-rows: 1fr;
  min-height: 150px;
  position: relative;
  overflow: hidden;
}

.grid-tile__head { position:absolute; top:0; left:0; right:0; z-index:2; display:flex; justify-content:space-between; padding:.3rem .45rem; font-size:.72rem; background:linear-gradient(180deg,rgba(0,0,0,.65),rgba(0,0,0,0)); }
.grid-tile__badge { color: #7cf2ad; font-size: .68rem; }
.grid-tile video { border-radius: 0; object-fit: contain; background: #000; width:100%; height:100%; display:block; }
.grid-tile__empty { display:flex; align-items:center; justify-content:center; color:#9fb5e3; font-size:.78rem; padding:.75rem; }
.grid-tile--focused { grid-column: 1 / -1; width: min(100%, calc((100vh - 260px) * 16 / 9)); max-width: 100%; aspect-ratio: 16 / 9; justify-self: center; align-self: start; min-height: 0; }
@media (max-width: 1400px) { .grid-tiles { grid-template-columns: repeat(4, minmax(0, 1fr)); } }
@media (max-width: 1024px) { .grid-tiles { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
@media (max-width: 760px) { .grid-tiles { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
.player-overlay-message {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  text-align: center;
  font-size: clamp(1rem, 2vw, 1.5rem);
  font-weight: 700;
  letter-spacing: 0.01em;
  color: #dbeafe;
  background: rgba(2, 6, 23, 0.58);
  text-shadow: 0 2px 14px rgba(0, 0, 0, 0.7);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s ease;
  z-index: 4;
}
.player-overlay-message.visible {
  opacity: 1;
  visibility: visible;
}
.player-overlay-message__content {
  display: grid;
  gap: 0.9rem;
  justify-items: center;
}
.player-overlay-message__text {
  margin: 0;
}
.player-overlay-message__actions {
  display: none;
  gap: 0.65rem;
  justify-content: center;
}
.player-overlay-message__actions.visible {
  display: flex;
}
.player-overlay-message__button {
  min-width: 120px;
}
video-player > *,
video-skin,
video-skin > * {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 0;
}
.watch-layout {
  display: flex;
  flex-direction: column;
  height: 100vh;
  overflow: hidden;
}

.timeline-footer {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 80;
  padding: .6rem 1rem .9rem;
  background: rgba(5, 12, 25, 0.96);
  border-top: 1px solid rgba(103, 137, 218, 0.28);
  backdrop-filter: blur(8px);
  min-height: var(--timeline-footer-height);
}
.timeline-viewing-time {
  display: flex;
  justify-content: center;
  margin-bottom: .35rem;
  font-size: .9rem;
  font-weight: 600;
  color: #dce9ff;
}
.timeline-footer__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #c5d7ff;
  font-size: .82rem;
  margin-bottom: .4rem;
  gap: .75rem;
  flex-wrap: wrap;
}
.timeline-zoom-controls {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
}
.timeline-zoom-btn {
  margin: 0;
  padding: .16rem .56rem;
  border-radius: 8px;
  border: 1px solid rgba(113, 150, 230, 0.6);
  background: rgba(23, 45, 84, 0.85);
  color: #dce9ff;
  font-weight: 700;
}

.timeline-current-display {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .1rem;
  min-width: 220px;
  text-align: center;
}
.timeline-date-input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 1px;
  height: 1px;
  padding: 0;
  border: 0;
}
.timeline-track.is-dragging {
  cursor: grabbing;
}
.timeline-track-wrap { position: relative; }
.timeline-day-markers {
  position: relative;
  min-height: 18px;
  margin-top: .38rem;
}
.timeline-track {
  position: relative;
  width: 100%;
  height: 22px;
  border-radius: 999px;
  background: rgba(27, 38, 64, 0.88);
  border: 1px solid rgba(98, 127, 201, 0.35);
  overflow: hidden;
  cursor: crosshair;
}
.timeline-track:focus-visible {
  outline: 2px solid rgba(109, 177, 255, 0.95);
  outline-offset: 2px;
}
.timeline-track__interval {
  position: absolute;
  top: 0;
  bottom: 0;
  background: linear-gradient(90deg, rgba(45, 181, 96, 0.92), rgba(82, 226, 140, 0.92));
}
.timeline-track__playhead {
  position: absolute;
  top: 1px;
  bottom: 1px;
  width: 3px;
  border-radius: 999px;
  background: #f59e0b;
  box-shadow: 0 0 0 1px rgba(245, 158, 11, 0.4), 0 0 8px rgba(245, 158, 11, 0.45);
  pointer-events: none;
}
.timeline-hover-popup {
  position: absolute;
  bottom: calc(100% + .35rem);
  transform: translateX(-50%);
  background: rgba(7, 19, 41, 0.98);
  border: 1px solid rgba(113, 153, 240, 0.6);
  border-radius: 8px;
  padding: .24rem .48rem;
  font-size: .74rem;
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity .12s ease;
}
.timeline-hover-popup.visible {
  opacity: 1;
  visibility: visible;
}
.timeline-scale {
  position: relative;
  height: 24px;
  margin-top: .34rem;
  overflow: visible;
}
.timeline-scale__tick {
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  font-size: .68rem;
  color: #a9bee9;
  white-space: nowrap;
}
.timeline-scale__tick::before {
  content: "";
  display: block;
  width: 1px;
  height: 6px;
  background: rgba(127, 162, 235, 0.7);
  margin: 0 auto .2rem;
}
.timeline-scale__day-marker {
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  font-size: .68rem;
  color: #b8caef;
  white-space: nowrap;
  padding-top: .04rem;
  pointer-events: none;
}

.watch-toast-dock {
  margin-top: 1rem;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: .5rem;
}
.status-toast {
  width: 100%; padding: .85rem 1rem; border-radius: 12px; background: rgba(15, 21, 38, 0.96); border: 1px solid rgba(99, 137, 232, 0.5);
  color: #f1f5ff; box-shadow: 0 12px 28px rgba(0, 0, 0, 0.4); opacity: 0; transform: translateY(14px); visibility: hidden; pointer-events: none;
  transition: opacity .26s ease, transform .26s ease;
}
.status-toast.visible { opacity: 1; transform: translateY(0); visibility: visible; pointer-events: auto; }
.status-toast[data-state="error"] { border-color: rgba(255, 124, 124, 0.75); }
.status-toast[data-state="ok"] { border-color: rgba(104, 222, 160, 0.75); }

.share-status-toast {
  display: flex;
  align-items: center;
  gap: .45rem;
  white-space: normal;
  overflow-wrap: anywhere;
}
.share-status-toast__text {
  flex: 1;
  min-width: 0;
}
.share-status-toast__icon-btn {
  border: 1px solid rgba(134, 162, 230, 0.6);
  background: rgba(41, 61, 110, 0.65);
  color: #e8efff;
  border-radius: 8px;
  width: 1.65rem;
  height: 1.65rem;
  padding: 0;
  line-height: 1;
  cursor: pointer;
}
.status-toast--action button { margin-left: .65rem; }
.stream-status-toast[data-state="stream-online"] { border-color: rgba(82, 224, 143, 0.78); }
.stream-status-toast[data-state="stream-offline"] { border-color: rgba(255, 132, 132, 0.82); }

.clips-table-wrap {
  border: 1px solid rgba(99, 131, 202, 0.3);
  border-radius: 12px;
  background: rgba(9, 20, 42, 0.7);
  overflow-x: auto;
}
.clips-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 560px;
}
.clips-table th,
.clips-table td {
  padding: .75rem .85rem;
  border-bottom: 1px solid rgba(99, 131, 202, 0.22);
  text-align: left;
}
.clips-table th {
  color: #d7e6ff;
  font-size: .82rem;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.clips-table td { color: #f3f7ff; }
.clips-table__empty td {
  text-align: center;
  color: #b8caef;
  padding: 1.15rem;
}
.clips-table__action { white-space: nowrap; width: 1%; }
.clip-status {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  border-radius: 999px;
  padding: .24rem .6rem;
  font-size: .84rem;
  border: 1px solid transparent;
}
.clip-status--ready {
  color: #8bf3b7;
  border-color: rgba(108, 242, 167, 0.4);
  background: rgba(17, 89, 55, 0.38);
}
.clip-status--failed {
  color: #ffb1b1;
  border-color: rgba(255, 118, 118, 0.45);
  background: rgba(102, 24, 24, 0.38);
}
.clip-status--processing {
  color: #b9d1ff;
  border-color: rgba(105, 144, 233, 0.45);
  background: rgba(24, 45, 88, 0.35);
}
.clip-status--deleted {
  color: #ffd38d;
  border-color: rgba(255, 183, 92, 0.45);
  background: rgba(87, 56, 17, 0.35);
}
.clip-spinner {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 2px solid rgba(185, 209, 255, 0.25);
  border-top-color: rgba(185, 209, 255, 0.95);
  animation: clip-spin .75s linear infinite;
}
@keyframes clip-spin {
  to { transform: rotate(360deg); }
}
.btn-download-link { margin: 0; padding: .32rem .75rem; border-radius: 999px; font-size: .85rem; background: linear-gradient(145deg, #34d399, #10b981); }

.watch-layout.live-mode media-time-range,
.watch-layout.live-mode media-seek-backward-button,
.watch-layout.live-mode media-seek-forward-button,
.watch-layout.live-mode media-playback-rate-button,
.watch-layout.live-mode media-speed-menu,
.watch-layout.live-mode [aria-label="Seek"],
.watch-layout.live-mode [aria-label="seek"],
.watch-layout.live-mode [aria-label*="10"] {
  display: none !important;
}

/* Admin dashboard */
.admin-dashboard {
  width: 100%;
  max-width: 1840px;
  margin: 0 auto;
  padding: 24px 32px;
}
.container.admin-dashboard { max-width: 1840px; }
.admin-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.2rem;
}
.admin-header h1 { margin: 0 0 .25rem; }
.admin-subnav {
  display: flex;
  gap: 10px;
  margin-bottom: 14px;
}
.admin-subnav__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(113, 145, 216, 0.45);
  border-radius: 999px;
  padding: .4rem .8rem;
  text-decoration: none;
  background: rgba(10, 25, 54, 0.45);
}
.admin-subnav__link.is-active {
  background: linear-gradient(140deg, #335ddf, #2f4fbf);
  border-color: rgba(133, 160, 255, 0.5);
}
.admin-link {
  display: inline-flex;
  align-items: center;
  border-radius: 10px;
  border: 1px solid rgba(120, 151, 219, 0.32);
  background: rgba(15, 36, 74, 0.65);
  padding: .45rem .9rem;
  text-decoration: none;
}

.admin-grid {
  display: grid;
  gap: 16px;
  margin-bottom: 16px;
}
.admin-grid--top { grid-template-columns: repeat(3, minmax(0, 1fr)); align-items: start; }
.admin-grid--debug { grid-template-columns: 1fr; }
.admin-grid--bottom { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.admin-main-grid {
  display: grid;
  grid-template-columns: minmax(0, 2.2fr) minmax(420px, 0.8fr);
  gap: 20px;
  align-items: start;
  margin-bottom: 16px;
}

.admin-panel,
.admin-card {
  border-radius: 14px;
  border: 1px solid rgba(92, 122, 191, 0.35);
  padding: 16px;
  background: linear-gradient(180deg, rgba(8, 25, 52, 0.84), rgba(6, 18, 38, 0.92));
}
.admin-panel h2,
.admin-card h3,
.canonical-summary h3 { margin: 0; font-size: 1.55rem; line-height: 1.2; }
.admin-card h3 { font-size: 1.35rem; margin-bottom: .85rem; }
.admin-card pre {
  margin: 0;
  max-height: 300px;
  overflow: auto;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  word-break: break-word;
  background: rgba(5, 14, 32, 0.9);
  border: 1px solid rgba(80, 118, 200, 0.4);
  border-radius: 8px;
  color: #9ec17d;
  padding: 8px;
}

.admin-form--stack { display: grid; gap: .45rem; }

.table-wrap,
.table-card {overflow-x: auto;}

.table-card table,
.mini-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}
.table-card th,
.table-card td,
.mini-table td,
.mini-table th {
  text-align: left;
  border-bottom: 1px solid rgba(129, 154, 210, 0.28);
  padding: 6px;
  color: #dbe8ff;
  vertical-align: top;
}
.actions-cell { white-space: nowrap; width: 1%; }
.primary-cell,
.status-cell { white-space: nowrap; width: 1%; }
.inline-form { display:inline-flex; gap:8px; align-items:center; margin-right:8px; }

@media (max-width: 840px) {
  :root { --timeline-footer-height: 190px; }
  .watch-main .controls {
    grid-template-columns: 1fr;
    grid-template-areas:
      "season"
      "stream"
      "start"
      "end"
      "actions";
  }

  .actions { justify-content: center; flex-wrap: wrap; }
  .app-shell {
    grid-template-columns: 1fr;
    gap: 1rem;
    padding-inline: .85rem;
    overflow-y: auto;
    height: calc(100vh - var(--timeline-footer-height));
  }
  .app-sidebar { min-height: auto; padding: 1rem; gap: .9rem; }
  .sidebar-brand { font-size: 1.35rem; }
  .sidebar-brand span { font-size: 1.8rem; }
  .sidebar-nav { margin-top: 0; grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .sidebar-timezone { margin-top: 0; }
  .btn { flex: 1; min-width: 140px; }
  .timeline-footer__header { font-size: .76rem; }
  .timeline-scale { height: 22px; }
  .timeline-scale__tick { font-size: .64rem; }
  video { min-height: clamp(260px, 40vh, 420px); height: auto; }
}

@media (max-width: 560px) {
  .timeline-zoom-controls { width: 100%; justify-content: space-between; }
  .timeline-scale { height: 20px; }
  .timeline-scale__tick { font-size: .6rem; }
  .watch-main .controls { padding: .85rem .8rem; column-gap: .6rem; row-gap: .3rem; }
  .actions { gap: .5rem; margin-top: .05rem; }
  .sidebar-nav { grid-template-columns: 1fr; }
  video { min-height: clamp(220px, 35vh, 320px); }
}

.panel-head { margin-bottom: 12px; }

.btn-primary,
.btn-secondary,
.btn-ghost,
.btn-danger,
.btn-icon {
  border: 1px solid transparent;
  border-radius: 9px;
  color: #ecf3ff;
  padding: .56rem .82rem;
  margin: 0;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
}
.btn-primary { background: linear-gradient(140deg, #335ddf, #2f4fbf); border-color: rgba(133, 160, 255, 0.5); }
.btn-secondary { background: rgba(24, 52, 102, 0.82); border-color: rgba(113, 145, 216, 0.48); }
.btn-ghost { background: rgba(10, 25, 54, 0.45); border-color: rgba(113, 145, 216, 0.45); }
.btn-danger { background: rgba(117, 30, 47, 0.58); border-color: rgba(247, 124, 146, 0.5); }
.btn-icon {
  width: 34px;
  height: 34px;
  padding: 0;
  background: rgba(13, 35, 71, 0.8);
  border-color: rgba(113, 145, 216, 0.46);
}
.btn-block { width: 100%; }

.badge {
  display: inline-flex;
  align-items: center;
  padding: .25rem .55rem;
  border-radius: 999px;
  font-size: .8rem;
  font-weight: 700;
  border: 1px solid transparent;
}
.badge-online,
.badge-live { color: #7ef2ac; border-color: rgba(69, 192, 118, 0.5); background: rgba(20, 73, 45, 0.55); }
.badge-offline { color: #c3d0ec; border-color: rgba(112, 131, 173, 0.45); background: rgba(38, 49, 77, 0.58); }
.badge-operational { color: #9af5b9; border-color: rgba(65, 187, 115, 0.5); background: rgba(20, 73, 45, 0.55); }
.badge-warning { color: #ffd591; border-color: rgba(238, 170, 78, 0.5); background: rgba(98, 63, 14, 0.5); }
.badge-error { color: #ffbac8; border-color: rgba(226, 101, 129, 0.52); background: rgba(103, 20, 41, 0.5); }
.badge-primary { color: #c2d9ff; border-color: rgba(111, 146, 220, 0.53); background: rgba(24, 50, 101, 0.58); }

.status-pill {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  margin-top: .7rem;
  border-radius: 999px;
  padding: .45rem .85rem;
  border: 1px solid rgba(70, 176, 117, 0.45);
}
.dot { width: 8px; height: 8px; background: currentColor; border-radius: 50%; display: inline-block; }

.queue-list { display: grid; gap: 8px; margin: 12px 0; }
.queue-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  border: 1px solid rgba(90, 117, 178, 0.42);
  border-radius: 9px;
  padding: 8px 9px;
  background: rgba(7, 20, 43, 0.8);
}

.canonical-list { display: grid; gap: 12px; margin-bottom: 12px; }
.canonical-card {
  border: 1px solid rgba(93, 123, 191, 0.35);
  border-radius: 12px;
  background: rgba(5, 18, 39, 0.85);
  overflow: hidden;
}
.canonical-summary {
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  padding: 12px 14px;
  cursor: pointer;
}
.canonical-summary::-webkit-details-marker { display: none; }
.canonical-summary h3 { font-size: 1.2rem; margin-bottom: .35rem; }
.canonical-badges { display: inline-flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.expander-icon { opacity: .75; font-size: 1.1rem; }
.canonical-card[open] .expander-icon { transform: rotate(180deg); }

.canonical-body {
  border-top: 1px solid rgba(90, 117, 178, 0.3);
  padding: 12px;
  display: grid;
  grid-template-columns: minmax(760px, 1fr) 320px;
  gap: 16px;
}
.action-rail {
  min-width: 300px;
  border: 1px solid rgba(90, 117, 178, 0.3);
  border-radius: 10px;
  background: rgba(8, 22, 47, 0.82);
  padding: 10px;
  display: grid;
  gap: 10px;
  align-content: start;
}
.action-rail h4 { margin: 0; }
.action-rail .inline-form { margin: 0; width: 100%; }

.dashboard-table {
  table-layout: auto;
  width: 100%;
  border-collapse: collapse;
}
.dashboard-table th,
.dashboard-table td {
  padding: 8px;
  border-bottom: 1px solid rgba(123, 147, 201, 0.28);
  text-align: left;
  color: #d9e6ff;
  vertical-align: top;
  overflow-wrap: normal;
}
.dashboard-table th { color: #a9c2ec; font-size: .82rem; text-transform: uppercase; letter-spacing: .03em; }
.compact-table th,
.compact-table td { font-size: .86rem; }
.table-actions { display: flex; flex-wrap: nowrap; gap: 8px; align-items: center; }
.table-wrap { overflow-x: auto; max-width: 100%; }
.alias-table { min-width: 860px; table-layout: auto; width: 100%; }
.alias-table th,
.alias-table td { white-space: normal; word-break: normal; overflow-wrap: normal; }
.alias-table th { white-space: nowrap; }
.table-actions button,
.alias-table button { white-space: nowrap; min-width: max-content; }
.truncate {
  max-width: 280px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  display: inline-block;
  vertical-align: bottom;
}
.loading-skeleton { opacity: .7; }

.suggested-matches-card {
  border: 1px solid rgba(90, 117, 178, 0.33);
  border-radius: 10px;
  background: rgba(5, 18, 39, 0.75);
  padding: 12px;
}
.suggested-matches-card h3 { margin: 0 0 8px; font-size: 1.08rem; }
.suggested-group { margin-bottom: 10px; }
.suggested-group h4 { margin: 0 0 6px; font-size: .95rem; color: #cad9fa; }
.suggested-items { display: grid; gap: 6px; }
.suggested-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  border: 1px solid rgba(90, 117, 178, 0.3);
  border-radius: 8px;
  padding: 7px 8px;
}

.action-menu { position: relative; }
.action-menu > summary { list-style: none; }
.action-menu > summary::-webkit-details-marker { display: none; }
.action-menu-popover {
  position: absolute;
  right: 0;
  top: calc(100% + 6px);
  z-index: 30;
  width: 180px;
  border: 1px solid rgba(101, 132, 198, 0.45);
  border-radius: 10px;
  padding: 8px;
  background: rgba(6, 21, 45, 0.98);
  display: grid;
  gap: 6px;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.35);
}

.admin-card pre {
  max-height: 210px;
  font-size: .82rem;
}

@media (max-width: 1180px) {
  .admin-main-grid,
  .admin-grid--top,
  .admin-grid--debug,
  .admin-grid--bottom { grid-template-columns: 1fr; }
  .canonical-body { grid-template-columns: 1fr; }
}

@media (max-width: 900px) {
  .admin-dashboard { padding: 16px; }
}

.admin-page .admin-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh;background:radial-gradient(circle at 20% 20%,#132f68,#0a1736 45%,#070f25)}
.admin-sidebar{padding:1.25rem;border-right:1px solid rgba(86,122,190,.3);background:rgba(5,13,35,.85)}
.admin-sidebar__brand strong{display:block;font-size:2rem}.admin-sidebar__brand span{color:#9fb7e8}
.admin-sidebar__nav{display:grid;gap:.5rem;margin-top:1.5rem}.admin-sidebar__link{padding:.65rem .8rem;border-radius:10px;color:#cad9ff;text-decoration:none}.admin-sidebar__link.is-active{background:linear-gradient(135deg,#3b82f6,#4f46e5);color:#fff}.admin-sidebar__link.is-disabled{opacity:.5}
.admin-content{padding:1.25rem}.admin-topbar{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.admin-logout{border:1px solid #2a4d84;padding:.5rem .8rem;border-radius:10px;text-decoration:none}
.admin-page .admin-panel,.admin-page .admin-card{background:linear-gradient(145deg,rgba(11,31,66,.72),rgba(11,24,55,.8));border:1px solid rgba(78,124,199,.35);border-radius:14px}
.segments-filter-grid{display:grid;grid-template-columns:repeat(6,minmax(120px,1fr));gap:.6rem;align-items:end}.segments-filter-actions{display:flex;gap:.5rem}
.segments-refresh{display:flex;gap:1rem;align-items:center;margin-top:.8rem}.segments-bulk{display:flex;gap:.5rem;align-items:center;margin-bottom:.7rem;flex-wrap:wrap}
.segments-badge{padding:.2rem .55rem;border-radius:999px;background:rgba(56,139,253,.2);border:1px solid rgba(96,165,250,.4)}
.segments-modal[hidden]{display:none}.segments-modal{position:fixed;inset:0;z-index:120}.segments-modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55)}.segments-modal__card{position:relative;max-width:900px;margin:5vh auto;padding:1rem;background:#081a3c;border:1px solid #345e9e;border-radius:14px}.segments-modal__close{position:absolute;right:.5rem;top:.5rem}

/* Admin segments redesign */
.admin-page .admin-content{max-width:none}
.admin-page .segments-page-head h2{margin:0 0 .35rem;font-size:2rem}
.admin-page .segments-filters-card,.admin-page .admin-panel{padding:1rem 1.1rem}
.admin-page .segments-filter-grid{display:grid;grid-template-columns:minmax(280px,2fr) repeat(3,minmax(140px,1fr)) auto;gap:.75rem;align-items:end}
.admin-page .segments-date-range-inputs{display:grid;grid-template-columns:1fr auto 1fr;gap:.5rem;align-items:center}
.admin-page .segments-filter-actions{display:flex;gap:.5rem}
.admin-page .segments-refresh-row{margin-top:.9rem;padding-top:.8rem;border-top:1px solid rgba(100,136,201,.35);display:flex;justify-content:space-between;gap:1rem;align-items:center}
.admin-page .segments-live-dot{display:inline-block;width:9px;height:9px;border-radius:999px;background:#31d17c;box-shadow:0 0 8px #31d17c}
.admin-page .segments-live-dot.is-paused{background:#6b7b9e;box-shadow:none}
.admin-page .segments-refresh-controls{display:flex;gap:.6rem;align-items:center}
.admin-page .segments-bulk-toolbar{display:flex;justify-content:space-between;align-items:center;gap:.7rem;margin-bottom:.75rem}
.admin-page .segments-bulk-left{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap}
.admin-page .segments-toolbar-menu{position:relative}.admin-page .segments-toolbar-menu>summary{list-style:none;cursor:pointer}.admin-page .segments-toolbar-menu>summary::-webkit-details-marker{display:none}
.admin-page .segments-toolbar-menu>div{position:absolute;top:calc(100% + 4px);left:0;z-index:20;display:flex;gap:.35rem;background:#091a3a;border:1px solid rgba(106,145,219,.45);padding:.5rem;border-radius:10px;min-width:220px}
.admin-page .segments-row-actions{display:flex;gap:.4rem}
.admin-page .btn-icon{padding:.42rem .55rem;border-radius:8px;border:1px solid rgba(103,143,215,.55);background:rgba(17,39,76,.75);color:#dbe7ff;cursor:pointer}
.admin-page .btn-danger-lite{border-color:rgba(223,82,82,.45);color:#ffc7c7}
.admin-page .segments-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:.8rem;gap:.8rem;flex-wrap:wrap}
.admin-page .segments-pagination-controls{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}
.admin-page .segments-preview[hidden]{display:none}.admin-page .segments-preview{position:fixed;inset:0;z-index:130}
.admin-page .segments-preview__backdrop{position:absolute;inset:0;background:rgba(3,8,20,.35)}
.admin-page .segments-preview__card{position:absolute;right:1rem;bottom:1rem;width:min(620px,calc(100vw - 2rem));padding:1rem;background:linear-gradient(145deg,rgba(8,24,51,.95),rgba(4,13,33,.96));border:1px solid rgba(87,128,204,.55);border-radius:14px;box-shadow:0 14px 40px rgba(0,0,0,.45)}
.admin-page .segments-preview__close{position:absolute;top:.5rem;right:.55rem;border:none;background:transparent;color:#dce8ff;font-size:1.2rem;cursor:pointer}
.admin-page .segments-preview__meta{display:grid;grid-template-columns:repeat(4,minmax(90px,1fr));gap:.6rem;margin:.7rem 0}.admin-page .segments-preview__meta small{display:block;color:#9eb4df}.admin-page .segments-preview__meta strong{display:block}
.admin-page .segments-preview__actions{display:flex;justify-content:space-between;gap:.6rem}
.admin-page .admin-identity-card-body{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:24px}
.admin-page .admin-identity-table-wrap{min-width:0}
@media (max-width:1100px){.admin-page .admin-identity-card-body{grid-template-columns:1fr}}
@media (max-width:1200px){.admin-page .segments-filter-grid{grid-template-columns:1fr 1fr}.admin-page .segments-filter-actions{grid-column:1/-1}}

.watch-layout[data-layout-mode="grid"] .player-shell {
  margin: 0;
}

.watch-layout[data-layout-mode="grid"] .controls:not(.is-grid-overlay-open) {
  display: none;
}

.watch-layout[data-layout-mode="grid"] .controls.is-grid-overlay {
  top: 64px;
  right: 12px;
  max-width: 760px;
}

.watch-layout[data-layout-mode="grid"] .field:nth-child(2) {
  display: none;
}

.grid-shell {
  gap: .35rem;
  position: relative;
}

.grid-return-btn {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 8;
}

.grid-tiles {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 6px;
  align-content: start;
  overflow: hidden;
}

.grid-tile {
  position: relative;
  aspect-ratio: 16 / 9;
  min-height: 0;
  border-radius: 6px;
  border: 1px solid rgba(87, 117, 182, 0.25);
  overflow: hidden;
  background: #000;
}

.grid-tile video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  border-radius: 0;
  background: #000;
}
.grid-tile video::-webkit-media-controls { display: none !important; }
.grid-tile__focus-hitbox {
  position: absolute;
  inset: 0;
  z-index: 15;
  cursor: pointer;
  background: transparent;
}

.grid-shell.is-grid-focused .grid-tile__focus-hitbox {
  display: none;
  pointer-events: none;
}

.grid-tile__head,
.grid-tile__playback-overlay,
.grid-tile__empty { pointer-events: none; }

.grid-tile__empty {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #9fb5e3;
  font-size: .78rem;
  padding: .75rem;
  background: rgba(0, 0, 0, 0.3);
}

.grid-tile__head {
  padding: .2rem .35rem;
  font-size: .66rem;
}

.grid-tile__playback-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  opacity: 0;
  transform: scale(.92);
  transition: opacity .22s ease, transform .22s ease;
  z-index: 3;
  color: #fff;
  font-size: clamp(1.3rem, 3vw, 2.1rem);
  font-weight: 800;
  text-shadow: 0 3px 16px rgba(0,0,0,.8);
}
.grid-tile__playback-overlay::before {
  content: '';
  position: absolute;
  width: clamp(2.6rem, 5vw, 4rem);
  aspect-ratio: 1;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.45);
}
.grid-tile__playback-overlay.is-visible {
  opacity: 1;
  transform: scale(1);
}

.grid-shell.is-grid-focused .grid-tiles {
  display: none !important;
}

.grid-focus-player-shell[hidden] { display: none !important; }
.grid-shell.is-grid-focused .grid-focus-player-shell { display: block; }
.grid-focus-player-shell {
  width: min(100%, calc((100vh - 260px) * 16 / 9));
  max-width: 100%;
  aspect-ratio: 16 / 9;
  margin: 0 auto;
  background: #000;
}
.grid-focus-player-shell video,
.grid-focus-player-shell video-player,
.grid-focus-player-shell video-skin {
  width: 100%;
  height: 100%;
}

.grid-focus-player-shell video::-webkit-media-controls {
  display: none !important;
}

.grid-focus-player-shell video::-webkit-media-controls-enclosure {
  display: none !important;
}

.grid-focus-player-shell video {
  pointer-events: auto;
}

.timeline-grid-play-btn {
  margin: 0 .6rem 0 0;
  width: 2rem;
  height: 2rem;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(82, 117, 199, 0.5);
  border-radius: 999px;
  background: rgba(20, 36, 70, 0.9);
  color: #dce9ff;
  cursor: pointer;
  font-size: .95rem;
  line-height: 1;
}

.timeline-grid-play-btn.is-disabled { opacity: .5; cursor: not-allowed; }
.btn-ai { background:#7c3aed; color:#fff; border:1px solid #6d28d9; }
.btn-ai:disabled { opacity:.5; cursor:not-allowed; }
.ai-overview-modal { position:fixed; inset:0; background:rgba(0,0,0,.55); display:flex; align-items:center; justify-content:center; z-index:1200; }
.ai-overview-modal[hidden] { display:none !important; pointer-events:none !important; }
.ai-overview-modal__content { width:min(640px,95vw); background:#111827; color:#fff; border:1px solid #374151; border-radius:10px; padding:1rem; }
.ai-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;display:inline-block;animation:spin 0.8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.ai-overview-drawer{position:fixed;right:0;top:0;height:100vh;width:min(420px,90vw);background:rgba(15,23,42,.88);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;border-left:1px solid rgba(148,163,184,.35);z-index:1140;transform:translateX(105%);opacity:0;pointer-events:none;transition:transform .25s ease,opacity .25s ease;display:flex;flex-direction:column;}
.ai-overview-drawer.is-open{transform:translateX(0);opacity:1;pointer-events:auto;}
.ai-overview-drawer.ai-overview-drawer--left{left:0;right:auto;border-left:0;border-right:1px solid rgba(148,163,184,.35);transform:translateX(-105%);}
.ai-overview-drawer.ai-overview-drawer--left.is-open{transform:translateX(0);}
.ai-overview-drawer__header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #334155;}
.ai-overview-drawer__body{padding:1rem;white-space:pre-wrap;line-height:1.45;overflow:auto;}
.ai-overview-summary-text{white-space:pre-wrap;line-height:1.45;}
.ai-overview-loading-text{margin:0;color:#dbeafe;}
.ai-overview-error-text{margin:0;color:#fecaca;}
.ai-overview-entities{margin-top:.9rem;border:1px solid rgba(148,163,184,.35);background:rgba(15,23,42,.55);border-radius:10px;padding:.65rem .75rem;}
.ai-overview-entities__title{text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;color:#93c5fd;margin-bottom:.5rem;font-weight:600;}
.ai-overview-entities__row{display:flex;justify-content:space-between;gap:.75rem;padding:.2rem 0;white-space:normal;}
.ai-overview-entities__row span{color:#cbd5e1;}
.ai-overview-entities__row strong{color:#f8fafc;text-align:right;word-break:break-word;}
.ai-tooltip-wrap{position:relative;display:inline-flex;align-items:center;}
.ai-tooltip{position:absolute;right:0;top:calc(100% + .5rem);min-width:220px;max-width:260px;padding:.5rem .65rem;border-radius:8px;border:1px solid rgba(125,211,252,.5);background:rgba(12,23,46,.95);color:#dbeafe;font-size:.8rem;line-height:1.3;opacity:0;transform:translateY(-4px);pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:50;}
.ai-tooltip-wrap:hover .ai-tooltip,.ai-tooltip-wrap:focus-within .ai-tooltip{opacity:1;transform:translateY(0);}

/* AI Overview admin redesign */
.admin-page .ai-admin-grid{display:grid;grid-template-columns:minmax(360px,.9fr) minmax(520px,1.6fr);gap:1rem;align-items:stretch}
.admin-page .ai-card{padding:1.1rem}
.admin-page .ai-card__head h2{margin:0 0 .25rem;font-size:2rem}
.admin-page .ai-card__head p{margin:0 0 .75rem;color:#9db2dc}
.admin-page .ai-settings-form{display:grid;gap:.55rem}
.admin-page .ai-field-row{display:grid;grid-template-columns:minmax(130px,1fr) minmax(180px,1fr);gap:.7rem;align-items:center}
.admin-page .ai-field-row label{margin:0;color:#d9e6ff}
.admin-page .ai-help{display:inline-flex;width:17px;height:17px;border-radius:50%;justify-content:center;align-items:center;border:1px solid rgba(112,149,218,.7);font-size:.75rem;color:#9ec1ff;margin-left:.35rem}
.admin-page .ai-field-row input,.admin-page .ai-field-row select,.admin-page .ai-advanced input,.admin-page .ai-advanced textarea{background:rgba(8,15,34,.9);border:1px solid rgba(78,124,199,.35);margin-top:0}
.admin-page .ai-api-wrap{display:grid;grid-template-columns:1fr auto;gap:.45rem}
.admin-page .ai-save-btn{width:100%;margin-top:.25rem;background:linear-gradient(135deg,#3b82f6,#4f46e5);border:none;border-radius:10px;padding:.72rem .9rem;font-weight:700}
.admin-page .ai-advanced{margin-top:.45rem;border:1px solid rgba(78,124,199,.28);border-radius:10px;padding:.2rem .6rem;background:rgba(11,24,55,.52)}
.admin-page .ai-advanced summary{cursor:pointer;padding:.45rem 0;color:#cfddff}
.admin-page .ai-advanced__body{display:grid;gap:.55rem;padding-bottom:.5rem}
.admin-page .ai-about-grid{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin:.7rem 0}
.admin-page .ai-about-subcard{border:1px solid rgba(78,124,199,.26);border-radius:12px;padding:.85rem;background:rgba(11,29,60,.42)}
.admin-page .ai-about-subcard h3{margin:0 0 .55rem}
.admin-page .ai-about-subcard ol{padding-left:1.1rem;margin:.35rem 0 0;display:grid;gap:.42rem}
.admin-page .ai-note{border:1px solid rgba(78,124,199,.28);background:rgba(23,57,105,.27);border-radius:12px;padding:.7rem .8rem;color:#cad7f4}
.admin-page .ai-entities-head{display:flex;justify-content:space-between;align-items:center;gap:.8rem;margin-bottom:.75rem}
.admin-page .ai-entities-head h2{margin:0 0 .35rem}
.admin-page .ai-entities-head p{margin:0;color:#9fb6df}
.admin-page #newEntityPanel{margin:.65rem 0;border:1px solid rgba(78,124,199,.3);border-radius:12px;padding:.2rem .8rem}
.admin-page .ai-new-entity-form{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:.6rem;padding:.6rem 0}
.admin-page .ai-new-entity-form label:last-of-type,.admin-page .ai-new-entity-form button{grid-column:1/-1}
.admin-page .ai-table-wrap{overflow:auto;border:1px solid rgba(78,124,199,.24);border-radius:12px}
.admin-page .ai-entity-table{width:100%;border-collapse:collapse}
.admin-page .ai-entity-table th{font-size:.78rem;letter-spacing:.05em;color:#9eb2d6;text-align:left;padding:.72rem .85rem;border-bottom:1px solid rgba(78,124,199,.2)}
.admin-page .ai-entity-table td{padding:.72rem .85rem;border-bottom:1px solid rgba(78,124,199,.14)}
.admin-page .ai-entity-table tbody tr:hover{background:rgba(52,95,169,.12)}
.admin-page .ai-type-badge{padding:.35rem .6rem;border-radius:9px;font-weight:600;display:inline-block}
.admin-page .ai-type-badge--person{background:rgba(124,58,237,.35)} .admin-page .ai-type-badge--room{background:rgba(37,99,235,.35)} .admin-page .ai-type-badge--object{background:rgba(22,163,74,.35)} .admin-page .ai-type-badge--other{background:rgba(100,116,139,.35)}
.admin-page .ai-images{display:flex;gap:.35rem;align-items:center}
.admin-page .ai-images img{width:40px;height:40px;object-fit:cover;border-radius:8px;border:1px solid rgba(96,132,202,.4)}
.admin-page .ai-more{padding:.28rem .46rem;background:rgba(13,21,38,.95);border:1px solid rgba(85,113,172,.4);border-radius:8px}
.admin-page .ai-empty-inline,.admin-page .ai-empty{color:#8ea3ca}
.admin-page .ai-actions{display:flex;gap:.4rem}
.admin-page .ai-table-footer{display:flex;justify-content:space-between;align-items:center;padding:.8rem 0 .2rem;color:#a8bce2}
.admin-page .ai-pagination button{background:rgba(8,15,34,.9);border:1px solid rgba(78,124,199,.35);color:#d5e4ff;border-radius:8px;padding:.3rem .55rem}
@media (max-width:1200px){.admin-page .ai-admin-grid{grid-template-columns:1fr}.admin-page .ai-about-grid{grid-template-columns:1fr}}
@media (max-width:760px){.admin-page .ai-field-row{grid-template-columns:1fr}.admin-page .ai-new-entity-form{grid-template-columns:1fr}}

body.episodes-layout { height: 100vh; overflow: hidden; }
.episodes-layout .app-shell { height: 100vh; padding-bottom: 1rem; }
.episodes-layout .episodes-main { display:flex; flex-direction:column; min-height:0; height:100%; overflow:auto; padding:1.1rem 1.2rem; gap:1rem; }
.episodes-page-header h1{margin:0;color:#f8fafc;font-size:3rem;font-weight:800;line-height:1}
.episodes-page-header p{margin:.35rem 0 0;color:#a9b8d0;font-size:1.2rem}
.episodes-filter-bar{display:flex;gap:1rem;align-items:flex-end;background:rgba(5,14,30,.72);border:1px solid rgba(96,165,250,.22);box-shadow:inset 0 0 20px rgba(59,130,246,.08);border-radius:18px;padding:1rem;flex-wrap:wrap}
.episodes-field{display:flex;flex-direction:column;gap:.45rem}.episodes-field>span{color:#a9b8d0;font-size:.9rem}
.episodes-field select,.segment-btn,.search-input-wrap input{height:48px;border-radius:12px;border:1px solid rgba(96,165,250,.25);background:rgba(2,10,22,.85);color:#f8fafc;padding:0 .95rem;font-size:1.02rem}
.episodes-field select{min-width:220px;appearance:none}
.segment-control{display:flex;gap:.55rem}.segment-btn{min-width:96px;background:transparent;cursor:pointer}.segment-btn.is-active{background:linear-gradient(135deg,#2563eb,#3b82f6);border-color:transparent}
.episodes-search{margin-left:auto;min-width:min(420px,100%)} .search-input-wrap{display:flex;align-items:center;gap:.55rem;border:1px solid rgba(96,165,250,.25);background:rgba(2,10,22,.9);border-radius:12px;padding:0 .8rem}.search-input-wrap input{border:0;background:transparent;flex:1;padding:0}
.media-section{border:1px solid rgba(96,165,250,.2);background:rgba(5,14,30,.46);border-radius:16px;padding:.6rem}
.media-section-head{display:flex;justify-content:space-between;align-items:center;margin:.15rem .25rem .6rem}.media-section-head h2{margin:0;color:#f8fafc}.media-head-actions{display:flex;align-items:center;gap:.45rem}.media-head-actions a{color:#2f7cf6;text-decoration:none}.media-section[data-section-type="digest"] .media-head-actions a{color:#a855f7}
.carousel-arrow{width:38px;height:38px;border-radius:999px;border:1px solid rgba(96,165,250,.35);background:rgba(8,18,36,.82);color:#7fb0ff}.media-section[data-section-type="digest"] .carousel-arrow{border-color:rgba(168,85,247,.35);color:#bd8dff}
.media-carousel{display:flex;gap:.8rem;overflow:auto;padding:.2rem;scrollbar-width:none}.media-carousel::-webkit-scrollbar{display:none}
.media-card{flex:0 0 clamp(280px,23vw,320px);background:rgba(8,18,36,.82);border:1px solid rgba(96,165,250,.24);border-radius:14px;overflow:hidden;cursor:pointer;display:flex;flex-direction:column}.media-section[data-section-type="digest"] .media-card{border-color:rgba(168,85,247,.26)}
.media-thumb{aspect-ratio:16/9;background:linear-gradient(135deg,#0c1a33,#152646);position:relative}.media-thumb img{width:100%;height:100%;object-fit:cover}
.entry-badge{position:absolute;top:10px;left:10px;padding:.28rem .6rem;border-radius:999px;font-size:.82rem;font-weight:700;color:#fff}.entry-badge--episode{background:#1f6feb}.entry-badge--digest{background:#7c3aed}
.media-card-body{padding:.8rem .9rem .5rem}.media-card h3{margin:0 0 .25rem;color:#f8fafc}.media-ep{margin:0 0 .3rem;color:#cbd8ee}.media-desc{margin:0;color:#a9b8d0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.4em}
.media-watch-btn{margin:.7rem .8rem .8rem;border:1px solid currentColor;border-radius:11px;padding:.62rem;text-align:center;text-decoration:none;font-weight:700;background:rgba(4,12,24,.8)}
.media-watch-btn.entry-badge--episode{color:#2f7cf6}.media-watch-btn.entry-badge--digest{color:#a855f7}
.media-empty{border:1px dashed rgba(96,165,250,.3);border-radius:12px;padding:1rem;color:#a9b8d0;margin:.2rem}
.episode-watch-view{display:flex;flex-direction:column;height:100%;min-height:0;gap:.85rem}.episode-watch-top{display:flex;justify-content:space-between;align-items:center;gap:1rem}.episode-back-link{color:#2f7cf6;text-decoration:none;font-weight:700}
.episode-watch-header h1{margin:.2rem 0 .5rem;font-size:3.1rem;color:#f8fafc}.episode-meta-row{display:flex;gap:1rem;align-items:center;color:#a9b8d0;flex-wrap:wrap}.episode-meta-row .entry-badge{position:static}
.episode-watch-actions{display:flex;gap:.6rem}.episode-ai-btn{border:0;border-radius:12px;padding:.75rem 1rem;background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;font-weight:700;box-shadow:0 0 24px rgba(168,85,247,.3)}.episode-fs-btn{width:46px;height:46px;border-radius:12px;border:1px solid rgba(96,165,250,.32);background:rgba(8,18,36,.72);color:#f8fafc}
.episode-watch-player-wrap{flex:1 1 auto;min-height:0;display:flex;align-items:center;justify-content:center}.episode-watch-player-shell{width:100%;max-width:1400px;max-height:calc(100vh - 260px);aspect-ratio:16/9;border-radius:18px;overflow:hidden;background:#000;border:1px solid rgba(96,165,250,.28);position:relative}
.episode-videojs-shell,.episode-watch-player-shell video-player,.episode-watch-player-shell video-skin,.episode-watch-player-shell video{width:100%;height:100%;display:block}.episode-watch-player-shell video{object-fit:contain;background:#000}
.episode-watch-player-shell video::-webkit-media-controls,.episode-watch-player-shell video::-webkit-media-controls-enclosure{display:none!important}
.episode-play-overlay{position:absolute;left:1rem;bottom:1rem;z-index:6;background:rgba(15,23,42,.9);border:1px solid rgba(147,197,253,.6);border-radius:10px;color:#e5efff;padding:.6rem .85rem}
@media (max-width:1000px){.episodes-search{margin-left:0;min-width:100%}.episode-watch-header h1,.episodes-page-header h1{font-size:2.2rem}}
.episodes-admin-table .entry-badge{font-size:.7rem}
.admin-inline-form{display:flex;gap:.5rem;margin:1rem 0}
.admin-form-grid{display:grid;gap:.6rem;max-width:720px}
