:root {
  color-scheme: dark;
  --bg: #0b0c0e;
  --sidebar: #171819;
  --card: rgba(255, 255, 255, 0.055);
  --card-2: rgba(255, 255, 255, 0.075);
  --line: rgba(255, 255, 255, 0.095);
  --text: #f4f4f1;
  --muted: #8f918e;
  --orange: #ff850f;
  --orange-2: #6f350f;
  --green: #16c7a1;
  --cyan: #16a8d8;
  --purple: #8d48ce;
  --shadow: 0 20px 60px rgba(0, 0, 0, 0.42);
}

html.boot-route-restoring body:not(.employee-logged-out) .shell,
body.employee-session-ready.route-restoring:not(.employee-logged-out) .shell {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
}

html.boot-employee-logged-out body .shell {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
}

html.boot-route-restoring body:not(.employee-logged-out)::after,
body.route-restoring:not(.employee-logged-out)::after {
  content: "Restoring workspace...";
}

.asset-category-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 12px 0 16px;
}

.asset-category-filter button {
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-radius: 999px;
  padding: 8px 13px;
  background: rgba(255, 255, 255, 0.34);
  color: #3a2430;
  font-weight: 800;
  cursor: pointer;
}

.asset-category-filter button.active {
  background: linear-gradient(135deg, #fff8fb, #f1bed2);
  color: #21141b;
  box-shadow: 0 10px 24px rgba(111, 42, 70, 0.16);
}

.hub-category-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 8px 0 4px;
}

.hub-category-tags em {
  border-radius: 999px;
  padding: 4px 8px;
  background: rgba(255, 209, 228, 0.18);
  color: #ffd8e8;
  font-size: 11px;
  font-style: normal;
  font-weight: 800;
}

/* Rose editorial UI theme, inspired by soft desert/pink minimalist layouts. */
:root {
  --rose-bg: #f4b5bd;
  --rose-deep: #1d1d1c;
  --rose-ink: #202020;
  --rose-muted: #7d6f73;
  --rose-line: rgba(49, 37, 40, 0.12);
  --rose-panel: rgba(255, 255, 255, 0.74);
  --rose-glass: rgba(255, 235, 239, 0.56);
  --rose-white: rgba(255, 255, 255, 0.9);
  --rose-shadow: 0 26px 70px rgba(113, 39, 55, 0.22);
  --rose-black-shadow: 0 24px 70px rgba(26, 18, 20, 0.26);
  --rose-radius-xl: 30px;
  --rose-radius: 22px;
  --rose-radius-sm: 999px;
  --text: #241f20;
  --muted: #776b70;
  --line: var(--rose-line);
  --card: var(--rose-panel);
  --card-2: rgba(255, 255, 255, 0.82);
  --orange: #ef7386;
  --orange-2: rgba(239, 115, 134, 0.16);
  --green: #242424;
  --cyan: #e98595;
  --purple: #ca7fa0;
  --shadow: var(--rose-shadow);
}

body {
  color: var(--rose-ink);
  background:
    radial-gradient(circle at 55% 84%, rgba(231, 59, 103, 0.34) 0 11%, transparent 12%),
    radial-gradient(circle at 72% 35%, rgba(255, 255, 255, 0.78) 0 12%, transparent 13%),
    linear-gradient(180deg, rgba(177, 80, 111, 0.32), rgba(251, 209, 209, 0.44) 34%, rgba(238, 151, 159, 0.7)),
    url("./assets/digital-future-poster-lite.jpg") center/cover fixed,
    #efabb4;
  background-blend-mode: soft-light, normal, normal, multiply, normal;
  font-family: "Inter", "HarmonyOS Sans SC", "PingFang SC", "Microsoft YaHei", Arial, sans-serif;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.16), rgba(255,255,255,0.04)),
    radial-gradient(ellipse at 48% 82%, rgba(140, 55, 70, 0.23), transparent 36%);
}

body::after {
  content: "";
  position: fixed;
  left: 8%;
  right: 10%;
  bottom: -12%;
  height: 42vh;
  z-index: -1;
  pointer-events: none;
  border-radius: 50% 50% 0 0;
  background:
    radial-gradient(circle at 52% 14%, rgba(255, 91, 132, 0.4), transparent 18%),
    linear-gradient(135deg, rgba(255, 220, 224, 0.28), rgba(176, 61, 83, 0.18));
  filter: blur(1px);
}

button,
.project-card,
.new-project,
.workflow-screen,
.material-card,
.library-asset-card,
.shot-card,
.employee-login-panel,
.modal-backdrop > section,
.video-modal,
.video-history-modal {
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease, background 0.22s ease;
}

.shell {
  grid-template-columns: 232px minmax(0, 1fr);
  padding: 18px;
  gap: 18px;
}

.sidebar {
  height: calc(100vh - 36px);
  border: 1px solid rgba(255, 255, 255, 0.48);
  border-radius: var(--rose-radius-xl);
  background: rgba(255, 239, 242, 0.54);
  box-shadow: var(--rose-shadow);
  backdrop-filter: blur(26px) saturate(1.12);
  overflow: hidden;
}

.logo {
  height: 86px;
  border-bottom: 1px solid rgba(32, 24, 26, 0.08);
}

.logo-mark,
.employee-login-brand span {
  border: 0;
  border-radius: 18px;
  background: #fff;
  color: var(--rose-ink);
  box-shadow: 0 13px 28px rgba(76, 38, 48, 0.12);
}

.logo strong,
.employee-login-brand {
  color: var(--rose-ink);
  font-weight: 800;
  letter-spacing: -0.04em;
}

.nav {
  gap: 10px;
  padding: 18px 14px;
}

.nav button {
  height: 46px;
  border: 1px solid transparent;
  border-radius: 999px;
  color: rgba(32, 32, 32, 0.68);
  font-weight: 760;
}

.nav button:hover,
.nav button.active {
  background: #1f1f1f;
  color: #fff;
  transform: translateX(3px);
  box-shadow: var(--rose-black-shadow);
}

.main {
  padding: 8px 4px 58px;
}

.topbar {
  min-height: 88px;
  margin: 0 0 22px;
  padding: 8px 8px 8px 2px;
}

h1 {
  color: #1e1e1e;
  font-size: clamp(32px, 4vw, 58px);
  font-weight: 500;
  letter-spacing: -0.08em;
  line-height: 0.96;
}

h2,
.project-card h2,
.screen-head h1 {
  letter-spacing: -0.06em;
}

.topbar p,
.section-head p,
.main p,
.stats small,
.stats em,
.project-card p,
.project-meta {
  color: rgba(42, 34, 36, 0.62);
}

.workspace-tag,
.script-model-control select,
.project-tabs button,
.episode-filters button,
.ratio-tabs button,
.video-step-switch button {
  border-radius: 999px;
  border-color: rgba(30, 30, 30, 0.12);
  background: rgba(255, 255, 255, 0.54);
  color: #2a2527;
}

.stats article,
.project-card,
.new-project,
.workflow-screen,
.asset-section,
.material-card,
.library-asset-card,
.shot-card,
.smart-preview-panel,
.smart-detail-panel,
.employee-setting-card,
.points-wallet-card,
.points-package-card {
  border: 1px solid rgba(255, 255, 255, 0.56);
  border-radius: var(--rose-radius-xl);
  background: linear-gradient(145deg, rgba(255,255,255,0.78), rgba(255,226,232,0.48));
  box-shadow: var(--rose-shadow);
  backdrop-filter: blur(24px) saturate(1.08);
}

.stats article:hover,
.project-card:hover,
.new-project:hover,
.material-card:hover,
.library-asset-card:hover,
.shot-card:hover,
.points-package-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 34px 92px rgba(111, 38, 53, 0.28);
}

.stats article:nth-child(2),
.project-card.active-project,
.smart-detail-panel,
.employee-setting-card:nth-child(even) {
  background: #fff;
}

.stats article:nth-child(3),
.new-project,
.smart-preview-panel {
  background: rgba(255, 226, 233, 0.58);
}

.stat-icon,
.new-project button,
.episode-play,
.asset-thumb,
.folder-icon {
  border-radius: 999px;
  background: #1f1f1f !important;
  color: #fff !important;
  box-shadow: 0 18px 38px rgba(34, 25, 27, 0.22);
}

.stats strong {
  color: #1f1f1f;
  font-size: 34px;
  font-weight: 520;
  letter-spacing: -0.07em;
}

.project-area {
  grid-template-columns: minmax(270px, 0.9fr) minmax(320px, 1.2fr);
  gap: 18px;
}

.project-card,
.new-project {
  min-height: 232px;
  padding: 24px;
}

.project-card h2 {
  color: #1f1f1f;
  font-size: 36px;
  font-weight: 520;
}

.project-head,
.project-meta,
.shot-asset-tags,
.row-actions,
.video-actions,
.library-card-actions {
  gap: 8px;
}

.project-meta span,
.shot-asset-tags button,
.model-pill,
.status-chip,
.queue span {
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.62);
  border-color: rgba(32, 32, 32, 0.1);
  color: rgba(32, 32, 32, 0.72);
}

.primary,
.admin-primary,
.add-episode,
#generateVideos,
.employee-login-panel button,
.points-recharge-primary,
.sidebar-claim {
  border-radius: 999px !important;
  background: #1f1f1f !important;
  color: #fff !important;
  box-shadow: 0 18px 40px rgba(31, 31, 31, 0.22);
}

.primary:hover,
.admin-primary:hover,
.add-episode:hover,
#generateVideos:hover,
.employee-login-panel button:hover {
  transform: translateY(-2px);
  box-shadow: 0 25px 56px rgba(31, 31, 31, 0.32);
}

.secondary,
.asset-library-head button,
.global-asset-tools button,
.episode-actions button,
.video-actions button,
.library-card-actions button,
.sidebar-recharge,
.community-card-link {
  border: 1px solid rgba(31, 31, 31, 0.12) !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,0.68) !important;
  color: #1f1f1f !important;
}

input,
select,
textarea,
.asset-toolbar select,
.asset-library-head input,
.global-asset-tools input {
  border: 1px solid rgba(31, 31, 31, 0.1) !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.64) !important;
  color: #1f1f1f !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.7);
}

textarea {
  border-radius: 22px !important;
}

input:focus,
select:focus,
textarea:focus {
  border-color: rgba(31, 31, 31, 0.32) !important;
  box-shadow: 0 0 0 5px rgba(255,255,255,0.35) !important;
}

.episode-card,
.asset-list div,
.library-card,
.video-history-item,
.points-record-item {
  border-radius: 24px;
  border-color: rgba(31, 31, 31, 0.1);
  background: rgba(255, 255, 255, 0.62);
}

.sidebar-points-wallet,
.sidebar-community-card {
  margin: 0 12px 12px;
  border: 1px solid rgba(255,255,255,0.52);
  border-radius: 24px;
  background: rgba(255,255,255,0.5);
}

.sidebar-points-wallet > strong,
.sidebar-community-card strong {
  color: #1f1f1f;
  font-weight: 560;
  letter-spacing: -0.05em;
}

.community-card-qr,
.community-card-placeholder {
  border-radius: 22px;
  border-color: rgba(31, 31, 31, 0.1);
}

.employee-login-screen {
  background:
    radial-gradient(circle at 70% 75%, rgba(255, 87, 128, 0.36) 0 11%, transparent 12%),
    linear-gradient(180deg, rgba(245, 169, 183, 0.64), rgba(237, 148, 158, 0.84)),
    url("./assets/digital-future-poster-lite.jpg") center/cover;
}

.employee-login-panel {
  width: min(480px, 100%);
  padding: 42px;
  border: 1px solid rgba(255,255,255,0.48);
  border-radius: 32px;
  background: rgba(255, 229, 234, 0.56);
  color: #1f1f1f;
  box-shadow: var(--rose-shadow);
  backdrop-filter: blur(24px);
}

.employee-login-panel h1 {
  font-size: 36px;
  font-weight: 500;
}

.employee-login-panel input {
  height: 50px;
  padding: 0 18px;
}

.modal-backdrop,
.material-modal,
.library-drawer,
.global-asset-drawer {
  backdrop-filter: blur(18px);
}

.modal-backdrop > section,
.video-modal,
.video-history-modal,
.material-modal > section {
  border: 1px solid rgba(255,255,255,0.56);
  border-radius: 32px;
  background: rgba(255, 246, 247, 0.88);
  color: #1f1f1f;
  box-shadow: var(--rose-shadow);
}

.toast {
  border: 0;
  border-radius: 999px;
  background: #1f1f1f;
  color: #fff;
  box-shadow: var(--rose-black-shadow);
}

@media (max-width: 980px) {
  .shell {
    grid-template-columns: 82px minmax(0, 1fr);
    padding: 12px;
  }

  .project-area {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .shell {
    display: block;
    padding: 10px;
  }

  .sidebar {
    position: relative;
    height: auto;
    margin-bottom: 12px;
  }

  h1 {
    font-size: 36px;
  }
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

html,
body {
  width: 100%;
  min-height: 100%;
  margin: 0;
}

body {
  font-family: "Microsoft YaHei", "PingFang SC", Arial, sans-serif;
  background:
    radial-gradient(circle at 78% 12%, rgba(96, 36, 120, 0.18), transparent 30%),
    radial-gradient(circle at 18% 90%, rgba(20, 68, 90, 0.12), transparent 26%),
    var(--bg);
  color: var(--text);
}

button,
textarea,
input,
select {
  font: inherit;
}

select {
  color-scheme: dark;
}

select option {
  background: #1b1f27;
  color: #f4f7fb;
}

select option:disabled {
  color: #7a8290;
}

button {
  border: 0;
  cursor: pointer;
}

.shell {
  display: grid;
  grid-template-columns: 206px minmax(0, 1fr);
  min-height: 100vh;
}

.sidebar {
  position: sticky;
  top: 0;
  display: grid;
  grid-template-rows: auto 1fr auto;
  height: 100vh;
  border-right: 1px solid var(--line);
  background: var(--sidebar);
}

.sidebar-points-wallet {
  display: grid;
  gap: 9px;
  padding: 12px;
  border-top: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.018);
}

.sidebar-points-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--muted);
  font-size: 12px;
}

.sidebar-points-head button {
  padding: 3px 5px;
  background: transparent;
  color: var(--muted);
  font-size: 11px;
}

.sidebar-points-wallet > strong {
  color: #ff8a00;
  font-size: 23px;
  line-height: 1;
}

.sidebar-points-wallet > button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  width: 100%;
  height: 36px;
  border-radius: 7px;
  font-size: 12px;
  font-weight: 900;
}

.sidebar-community-card {
  display: grid;
  gap: 9px;
  padding: 12px;
  border-top: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.018);
  text-align: center;
}

.sidebar-community-card strong {
  color: #f1d985;
  font-size: 12px;
}

.community-card-body {
  display: grid;
  gap: 12px;
  align-items: center;
}

.community-card-qr {
  width: min(180px, 100%);
  aspect-ratio: 1;
  object-fit: cover;
  margin: 0 auto;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
}

.sidebar-community-card .community-card-qr {
  width: 108px;
  border-radius: 8px;
}

.community-card-placeholder {
  display: grid;
  place-items: center;
  width: min(180px, 100%);
  aspect-ratio: 1;
  margin: 0 auto;
  border: 1px dashed var(--line);
  border-radius: 10px;
  color: var(--muted);
  font-size: 12px;
}

.sidebar-community-card .community-card-placeholder {
  width: 108px;
}

.community-card-desc {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.6;
}

.community-card-link {
  width: max-content;
  margin: 0 auto;
  color: #ffb85c;
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
}

.sidebar-recharge {
  border: 1px solid rgba(255, 139, 15, 0.58);
  background: transparent;
  color: #ff9a23;
}

.sidebar-claim {
  background: linear-gradient(135deg, #ffa51f, #ff6a00);
  color: #fff;
}

.sidebar-claim:disabled {
  background: rgba(255, 255, 255, 0.08);
  color: var(--muted);
  cursor: default;
}

.logo {
  display: flex;
  align-items: center;
  gap: 12px;
  height: 74px;
  padding: 0 18px;
  border-bottom: 1px solid var(--line);
}

.logo-mark {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border: 2px solid #e8d989;
  border-radius: 12px;
  color: #e8d989;
  font-size: 22px;
  font-weight: 900;
}

.logo-mark.has-brand-image,
.employee-login-brand span.has-brand-image {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  color: transparent;
}

.script-model-control {
  display: grid;
  gap: 5px;
  min-width: 210px;
  color: #aeb7c4;
  font-size: 11px;
}

.script-model-control select {
  width: 100%;
  height: 38px;
  padding: 0 32px 0 11px;
  border: 1px solid rgba(231, 238, 248, 0.14);
  border-radius: 4px;
  background: rgba(16, 19, 24, 0.88);
  color: #f2f5f9;
}

.logo strong {
  color: #eee096;
  font-size: 18px;
  line-height: 1.2;
  white-space: nowrap;
}

.nav {
  display: grid;
  align-content: start;
  gap: 8px;
  padding: 14px 12px;
}

.nav button {
  display: flex;
  align-items: center;
  gap: 10px;
  height: 40px;
  padding: 0 12px;
  border-radius: 7px;
  background: transparent;
  color: var(--text);
  text-align: left;
  font-weight: 700;
}

.nav button.active {
  background: var(--orange-2);
  color: #ffb15f;
}

.nav span {
  width: 18px;
  color: #c7c9c6;
}

.main p,
.stats small,
.stats em,
.project-card p,
.project-meta,
.step-top em,
.analysis-grid small,
.asset-list small,
.concurrency span,
.queue em {
  color: var(--muted);
  font-size: 12px;
}

.main {
  min-width: 0;
  padding: 22px 20px 54px;
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 18px;
}

h1,
h2,
p {
  margin: 0;
}

h1 {
  font-size: 28px;
}

.topbar p,
.section-head p {
  margin-top: 6px;
}

.userbar {
  display: flex;
  align-items: center;
  gap: 10px;
}

.workspace-tag {
  display: inline-flex;
  align-items: center;
  height: 28px;
  padding: 0 10px;
  border: 1px solid rgba(255, 133, 15, 0.35);
  border-radius: 999px;
  background: rgba(255, 133, 15, 0.08);
  color: #ffb15f;
  font-size: 12px;
  font-weight: 800;
}

.stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 24px;
}

.stats article,
.project-card,
.new-project,
.workflow-screen {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: linear-gradient(135deg, var(--card), rgba(255, 255, 255, 0.025));
  box-shadow: var(--shadow);
}

.stats article {
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 6px 12px;
  min-height: 104px;
  padding: 16px;
}

.stat-icon {
  grid-row: span 3;
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 9px;
  font-weight: 900;
}

.orange {
  background: rgba(255, 133, 15, 0.16);
  color: var(--orange);
}

.purple {
  background: rgba(141, 72, 206, 0.18);
  color: #c17cff;
}

.cyan {
  background: rgba(22, 168, 216, 0.18);
  color: #45d1ff;
}

.stats strong {
  font-size: 28px;
}

.project-area {
  display: grid;
  grid-template-columns: minmax(280px, 435px) minmax(280px, 435px);
  gap: 16px;
  margin-bottom: 24px;
}

.new-project {
  display: grid;
  place-items: center;
  min-height: 196px;
  border-style: dashed;
  border-color: rgba(255, 133, 15, 0.45);
  text-align: center;
  cursor: pointer;
}

.new-project button {
  width: 52px;
  height: 52px;
  border: 1px solid rgba(255, 133, 15, 0.42);
  border-radius: 14px;
  background: rgba(255, 133, 15, 0.15);
  color: var(--orange);
  font-size: 30px;
}

.new-project span {
  color: var(--muted);
}

.project-card {
  min-height: 196px;
  padding: 16px;
  cursor: pointer;
}

.project-head,
.project-meta,
.screen-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.film-icon {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: rgba(22, 199, 161, 0.16);
  color: var(--green);
}

.project-card h2 {
  margin-top: 28px;
  font-size: 22px;
}

.project-card p {
  margin: 9px 0 24px;
}

.project-meta {
  padding-top: 14px;
  border-top: 1px solid var(--line);
}

.primary {
  height: 38px;
  padding: 0 18px;
  border-radius: 8px;
  background: linear-gradient(135deg, #ffb233, var(--orange));
  color: #251200;
  font-weight: 900;
}

#nextStoryboard {
  position: relative;
  overflow: hidden;
  min-width: 186px;
  border: 1px solid rgba(180, 92, 255, 0.62);
  background:
    radial-gradient(circle at 16% 50%, rgba(255, 255, 255, 0.18), transparent 18%),
    linear-gradient(135deg, rgba(117, 54, 176, 0.78), rgba(53, 31, 82, 0.78));
  color: #f7eaff;
  box-shadow: 0 0 18px rgba(169, 87, 255, 0.42), inset 0 0 14px rgba(255, 255, 255, 0.08);
}

#nextStoryboard::before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  margin-right: 8px;
  vertical-align: -3px;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20viewBox%3D%270%200%2024%2024%27%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%3E%3Cpath%20fill%3D%27%23000%27%20d%3D%27m19%201%201.4%203.1L23.5%205.5l-3.1%201.4L19%2010l-1.4-3.1-3.1-1.4%203.1-1.4L19%201ZM9.5%205l2.1%204.9L16.5%2012l-4.9%202.1L9.5%2019l-2.1-4.9L2.5%2012l4.9-2.1L9.5%205Zm9.5%2010%201%202.2%202.2%201-2.2%201-1%202.2-1-2.2-2.2-1%202.2-1Z%27/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg%20viewBox%3D%270%200%2024%2024%27%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%3E%3Cpath%20fill%3D%27%23000%27%20d%3D%27m19%201%201.4%203.1L23.5%205.5l-3.1%201.4L19%2010l-1.4-3.1-3.1-1.4%203.1-1.4L19%201ZM9.5%205l2.1%204.9L16.5%2012l-4.9%202.1L9.5%2019l-2.1-4.9L2.5%2012l4.9-2.1L9.5%205Zm9.5%2010%201%202.2%202.2%201-2.2%201-1%202.2-1-2.2-2.2-1%202.2-1Z%27/%3E%3C/svg%3E") center / contain no-repeat;
  animation: sparkleBlink 1.05s ease-in-out infinite;
}

@keyframes sparkleBlink {
  0%, 100% { opacity: 0.58; transform: scale(0.9) rotate(-8deg); }
  50% { opacity: 1; transform: scale(1.18) rotate(8deg); }
}

.wide {
  width: 100%;
}

textarea {
  width: 100%;
  min-height: 132px;
  margin-bottom: 12px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(5, 6, 8, 0.65);
  color: var(--text);
  line-height: 1.65;
  resize: vertical;
  outline: none;
}

input,
select {
  width: 100%;
  height: 50px;
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(5, 6, 8, 0.52);
  color: var(--text);
  outline: none;
}

.view {
  display: none;
}

.view.active-view {
  display: block;
}

.project-topbar {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 18px;
  margin-bottom: 18px;
}

.project-breadcrumb {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 46px;
  margin: -22px -20px 16px;
  padding: 0 20px;
  border-bottom: 1px solid var(--line);
  color: var(--muted);
}

.project-breadcrumb strong {
  color: var(--text);
}

.project-breadcrumb .breadcrumb-link,
.episode-breadcrumb .breadcrumb-link {
  width: auto;
  height: 30px;
  padding: 0 4px;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: rgba(255, 255, 255, 0.76);
  font-weight: 850;
  cursor: pointer;
}

.project-breadcrumb .breadcrumb-link:hover,
.episode-breadcrumb .breadcrumb-link:hover {
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
  text-decoration: underline;
  text-underline-offset: 4px;
}

.project-breadcrumb .breadcrumb-link.current,
.episode-breadcrumb .breadcrumb-link.current {
  color: #fff;
  text-decoration: none;
}

.project-breadcrumb em {
  color: #585b5a;
  font-style: normal;
}

.project-tabs {
  display: flex;
  gap: 12px;
  margin: 0 -20px 40px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--line);
}

.project-tabs button {
  height: 46px;
  padding: 0 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
  color: var(--text);
  font-weight: 800;
}

.project-tabs button.active {
  border-color: var(--orange);
  background: var(--orange);
  color: white;
}

.episode-empty {
  max-width: 680px;
}

.episode-filters {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
}

.episode-filters button {
  height: 26px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.045);
  color: var(--text);
}

.episode-filters button.active {
  border-color: var(--orange);
  background: var(--orange);
  color: white;
}

.episode-list {
  display: grid;
  gap: 14px;
  margin-bottom: 16px;
}

.episode-card {
  display: grid;
  grid-template-columns: 42px 1fr auto;
  align-items: center;
  gap: 14px;
  min-height: 82px;
  padding: 14px 18px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.055);
  color: var(--text);
  text-align: left;
}

.episode-play {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 10px;
  background: rgba(255, 133, 15, 0.16);
  color: var(--orange);
  font-size: 22px;
}

.episode-info strong,
.episode-info span {
  display: block;
}

.episode-info strong {
  margin-bottom: 8px;
}

.episode-info span {
  width: fit-content;
  padding: 2px 8px;
  border-radius: 4px;
  background: rgba(255, 76, 94, 0.18);
  color: #ff5f70;
  font-size: 12px;
  font-weight: 800;
}

.episode-actions {
  display: flex;
  gap: 14px;
  color: var(--muted);
}

.add-episode {
  width: 100%;
  height: 62px;
  border: 1px dashed rgba(255, 133, 15, 0.62);
  border-radius: 12px;
  background: transparent;
  color: var(--orange);
  font-weight: 900;
}

.empty-state {
  display: grid;
  place-items: center;
  gap: 10px;
  min-height: 260px;
  color: var(--muted);
  text-align: center;
}

.empty-state strong {
  color: var(--muted);
  font-size: 18px;
}

.folder-icon {
  color: #555;
  font-size: 54px;
}

.project-topbar p {
  margin-top: 6px;
}

.back-btn {
  height: 36px;
  padding: 0 12px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.07);
  color: var(--text);
  font-weight: 800;
}

.process-nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.process-nav button {
  display: flex;
  align-items: center;
  gap: 10px;
  height: 54px;
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.045);
  color: var(--text);
  text-align: left;
  font-weight: 900;
}

.process-nav button.active {
  border-color: rgba(255, 133, 15, 0.62);
  background: rgba(255, 133, 15, 0.12);
}

.process-nav button:disabled {
  cursor: default;
  opacity: 0.45;
}

.process-nav span {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 8px;
  background: rgba(255, 133, 15, 0.16);
  color: var(--orange);
}

.workflow-screen {
  display: none;
  max-width: 920px;
  min-height: 520px;
  padding: 18px;
}

.workflow-screen.active-step {
  display: block;
}

.screen-head {
  margin-bottom: 16px;
}

.screen-head p {
  margin-top: 6px;
}

.screen-head em {
  min-width: 84px;
  color: var(--muted);
  font-size: 12px;
  text-align: right;
}

.analysis-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 9px;
  margin-top: 12px;
}

.analysis-grid div {
  min-height: 66px;
  padding: 10px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.055);
}

.analysis-grid strong,
.analysis-grid small {
  display: block;
}

.analysis-grid strong {
  margin-top: 6px;
  font-size: 13px;
  line-height: 1.35;
}

.asset-list {
  display: grid;
  gap: 10px;
  margin-bottom: 12px;
}

.asset-list div {
  display: grid;
  grid-template-columns: 74px 1fr;
  gap: 5px 12px;
  align-items: center;
  min-height: 88px;
  padding: 9px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.055);
}

.asset-list b {
  align-self: end;
}

.asset-list small {
  align-self: start;
}

.asset-thumb {
  grid-row: span 2;
  width: 74px;
  height: 70px;
  border-radius: 8px;
  background-size: cover;
  background-position: center;
}

.asset-thumb.character {
  background:
    radial-gradient(circle at 52% 30%, #ffd3b6 0 16%, transparent 17%),
    linear-gradient(135deg, #51304f, #d15b6d 55%, #1b2638);
}

.asset-thumb.scene {
  background:
    repeating-linear-gradient(110deg, rgba(255, 255, 255, 0.18) 0 2px, transparent 2px 10px),
    linear-gradient(135deg, #17202b, #2b6b72 55%, #d08d43);
}

.asset-thumb.prop {
  background:
    linear-gradient(90deg, transparent 20%, #111 20% 78%, transparent 78%),
    linear-gradient(135deg, #75879a, #e7e2d0);
}

.asset-toolbar {
  display: flex;
  align-items: center;
  gap: 18px;
  min-height: 74px;
  margin-bottom: 18px;
  padding: 14px 18px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.055);
}

.asset-toolbar h2 {
  min-width: 112px;
}

.asset-toolbar em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
}

.asset-toolbar label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 12px;
}

.asset-toolbar select {
  height: 34px;
  min-width: 118px;
}

.outline-generate {
  margin-left: auto;
  height: 42px;
  padding: 0 18px;
  border: 1px solid rgba(255, 133, 15, 0.62);
  border-radius: 8px;
  background: rgba(255, 133, 15, 0.08);
  color: #ffb15f;
  font-weight: 900;
}

.asset-workbench {
  display: grid;
  gap: 18px;
}

.asset-section {
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.045);
}

.asset-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.asset-section-head h3 {
  margin: 0;
}

.asset-section-head div {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--muted);
  font-size: 12px;
}

.green-mini,
.brown-mini {
  height: 28px;
  padding: 0 12px;
  border-radius: 7px;
  font-weight: 900;
}

.green-mini {
  background: rgba(16, 171, 93, 0.24);
  color: #2ee27e;
}

.brown-mini {
  background: rgba(255, 133, 15, 0.18);
  color: var(--orange);
}

.asset-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(280px, 1fr));
  gap: 14px;
}

.prop-grid {
  grid-template-columns: repeat(4, minmax(220px, 1fr));
}

.material-card {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #171819;
}

.material-preview {
  display: grid;
  place-items: center;
  min-height: 190px;
  color: rgba(255, 255, 255, 0.28);
  background-position: center;
  background-size: cover;
  background:
    radial-gradient(circle at 50% 45%, rgba(255, 255, 255, 0.08), transparent 18%),
    #18191a;
}

.material-preview.has-generated-image {
  color: transparent;
  background-position: center;
  background-size: cover;
}

.generation-progress {
  margin: 0 18px 18px;
  padding: 16px 18px;
  border: 1px solid rgba(255, 255, 255, 0.52);
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(255,255,255,.72), rgba(255,229,236,.62));
  box-shadow: 0 18px 46px rgba(117, 42, 62, 0.14);
}

.generation-progress-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.generation-progress-top strong {
  color: #1f1f1f;
  font-weight: 900;
}

.generation-progress-top span {
  min-width: 52px;
  text-align: right;
  color: #ff4f86;
  font-weight: 900;
}

.generation-progress-track,
.mini-progress {
  display: block;
  overflow: hidden;
  height: 10px;
  border-radius: 999px;
  background: rgba(31,31,31,.1);
}

.generation-progress-track i,
.mini-progress i {
  display: block;
  width: 0;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #ff8d45, #ff4f86);
  transition: width .28s ease;
}

.generation-progress p {
  margin: 9px 0 0;
  color: rgba(31,31,31,.58);
  font-size: 13px;
}

.task-progress {
  margin: 14px 0 0;
  border-color: rgba(255, 255, 255, 0.62);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.82), rgba(255, 226, 235, 0.72)),
    radial-gradient(circle at 12% 12%, rgba(255, 123, 158, 0.18), transparent 34%);
}

.video-progress {
  margin: 0 0 18px;
}

.script-progress {
  margin-top: 18px;
}

.material-card.generating .material-preview {
  position: relative;
  gap: 10px;
  padding: 18px;
  color: #fff !important;
  background:
    radial-gradient(circle at 50% 36%, rgba(255, 126, 166, 0.22), transparent 28%),
    linear-gradient(135deg, rgba(25, 18, 22, 0.98), rgba(112, 45, 72, 0.92)) !important;
  background-image:
    radial-gradient(circle at 50% 36%, rgba(255, 126, 166, 0.22), transparent 28%),
    linear-gradient(135deg, rgba(25, 18, 22, 0.98), rgba(112, 45, 72, 0.92)) !important;
}

.material-card.generating .material-preview span,
.material-card.generating .material-preview em {
  font-style: normal;
  font-weight: 900;
}

.material-card.generating .mini-progress {
  width: min(220px, 80%);
}

.material-card.generated .material-preview {
  color: rgba(255,255,255,.62);
}

.material-card.generation-failed .material-preview {
  display: grid;
  gap: 6px;
  padding: 16px;
  color: #fff;
  background:
    linear-gradient(135deg, rgba(255, 65, 110, 0.34), rgba(26, 14, 20, 0.86));
}

.material-card.generation-failed .material-preview small {
  color: rgba(255, 240, 246, 0.78);
  font-size: 12px;
  line-height: 1.45;
}

.material-info {
  position: relative;
  padding: 12px;
  background: rgba(0, 0, 0, 0.58);
}

.material-info h4 {
  margin: 0 0 8px;
}

.material-info p,
.material-info small {
  display: block;
  color: #b8bbb8;
  font-size: 12px;
  line-height: 1.55;
}

.material-info small {
  margin-top: 8px;
  color: var(--orange);
}

.generate-mini {
  width: calc(100% - 146px);
  height: 30px;
  margin-top: 10px;
  border-radius: 7px;
  background: rgba(255, 133, 15, 0.28);
  color: var(--orange);
  font-weight: 900;
}

.library-save-mini {
  position: absolute;
  right: 82px;
  bottom: 12px;
  width: 52px;
  min-width: 52px;
  height: 30px;
  padding: 0 6px;
  border-radius: 8px;
  background: rgba(255, 138, 0, 0.18);
  color: #ff9a26;
  font-size: 12px;
  font-weight: 950;
}

.library-save-mini.saved,
.library-save-mini:disabled,
.library-save-mini.is-disabled {
  cursor: default;
  opacity: 0.72;
  background: rgba(22, 199, 161, 0.18);
  color: #16c7a1;
}

.library-save-mini.is-disabled:not(.saved) {
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.58);
}

.edit-mini {
  position: absolute;
  right: 50px;
  bottom: 12px;
  width: 32px;
  height: 32px;
  border-radius: 7px;
  display: inline-grid;
  place-items: center;
  background: rgba(255, 255, 255, 0.12);
  color: white;
}

.delete-mini {
  position: absolute;
  right: 12px;
  bottom: 12px;
  width: 32px;
  height: 32px;
  border-radius: 7px;
  display: inline-grid;
  place-items: center;
  background: rgba(255, 255, 255, 0.1);
  color: #d7d7d7;
  font-size: 0;
  transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.delete-mini::before,
.library-card-actions button:last-child::before {
  content: "";
  width: 15px;
  height: 15px;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20viewBox%3D%270%200%2024%2024%27%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%3E%3Cpath%20fill%3D%27%23000%27%20d%3D%27M9%203h6l1%202h4v2H4V5h4l1-2Zm1.2%204h3.6l-.5-1h-2.6l-.5%201ZM6%209h12l-1%2012H7L6%209Zm3%202v8h2v-8H9Zm4%200v8h2v-8h-2Z%27/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg%20viewBox%3D%270%200%2024%2024%27%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%3E%3Cpath%20fill%3D%27%23000%27%20d%3D%27M9%203h6l1%202h4v2H4V5h4l1-2Zm1.2%204h3.6l-.5-1h-2.6l-.5%201ZM6%209h12l-1%2012H7L6%209Zm3%202v8h2v-8H9Zm4%200v8h2v-8h-2Z%27/%3E%3C/svg%3E") center / contain no-repeat;
}

.delete-mini:hover,
.library-card-actions button:last-child:hover {
  background: rgba(255, 77, 77, 0.18);
  color: #ff6b6b;
  transform: translateY(-1px);
}

.material-modal {
  position: relative;
  width: min(560px, 100%);
  max-height: calc(100vh - 48px);
  overflow: auto;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #1d1d1d;
  box-shadow: var(--shadow);
}

.material-modal h2 {
  margin-bottom: 24px;
}

.material-fields {
  display: grid;
  gap: 12px;
}

.upload-box {
  display: grid;
  place-items: center;
  gap: 6px;
  width: 100%;
  min-height: 96px;
  border: 2px dashed rgba(255, 255, 255, 0.18);
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.24);
  color: var(--muted);
}

.upload-box.small {
  min-height: 56px;
}

.upload-box small {
  color: var(--muted);
}

.library-drawer {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 32;
  width: min(410px, 100vw);
  height: 100vh;
  overflow: auto;
  border-left: 1px solid var(--line);
  background: #191a1a;
  box-shadow: -24px 0 70px rgba(0, 0, 0, 0.5);
  transform: translateX(102%);
  transition: transform 0.22s ease;
}

.library-drawer.open {
  transform: translateX(0);
}

.library-drawer header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 58px;
  padding: 0 18px;
  border-bottom: 1px solid var(--line);
}

.library-drawer h2 {
  margin: 0;
  font-size: 20px;
}

.library-drawer header button {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: transparent;
  color: var(--muted);
  font-size: 24px;
}

.library-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 16px 10px;
  color: var(--muted);
}

.library-meta strong {
  color: var(--text);
}

.library-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 8px 14px 22px;
}

.library-card {
  position: relative;
  min-height: 244px;
  padding: 116px 10px 10px;
  border: 1px solid rgba(24, 199, 107, 0.35);
  border-radius: 8px;
  background:
    radial-gradient(circle at 50% 24%, rgba(255, 133, 15, 0.18), transparent 16%),
    rgba(255, 255, 255, 0.035);
}

.library-badge {
  position: absolute;
  top: 42px;
  left: 50%;
  transform: translateX(-50%);
  padding: 4px 10px;
  border-radius: 5px;
  background: #08783e;
  color: #89ffbd;
  font-size: 12px;
}

.library-card h4 {
  margin: 0 0 6px;
}

.library-card p,
.library-card small {
  display: block;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.library-card small {
  margin-top: 7px;
  color: var(--orange);
}

.library-card-actions {
  display: grid;
  grid-template-columns: 1fr 30px 30px;
  gap: 7px;
  margin-top: 10px;
}

.library-card-actions button {
  height: 30px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.1);
  color: var(--text);
}

.library-card-actions button:last-child {
  display: inline-grid;
  place-items: center;
  color: #d7d7d7;
  font-size: 0;
  transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.library-card-actions .added {
  background: rgba(16, 171, 93, 0.2);
  color: #2ee27e;
}

.concurrency label {
  display: grid;
  grid-template-columns: 1fr 2fr auto;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}

.concurrency label small {
  grid-column: 1 / -1;
  color: rgba(91, 67, 81, 0.72);
  font-size: 12px;
  line-height: 1.5;
}

input[type="range"] {
  accent-color: var(--orange);
}

.queue {
  display: grid;
  gap: 8px;
  margin-bottom: 12px;
}

.queue div {
  display: grid;
  grid-template-columns: 12px 1fr auto;
  align-items: center;
  gap: 9px;
  height: 38px;
  padding: 0 10px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.055);
}

.queue span {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #575a57;
}

.workflow-screen[data-step-screen="3"] > .screen-head,
.workflow-screen[data-step-screen="3"] > .concurrency,
.workflow-screen[data-step-screen="3"] > #generateVideos {
  display: none;
}

.video-stage {
  display: grid;
  gap: 16px;
}

.video-step-switch {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin: 0 auto 4px;
  padding: 5px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.06);
}

.video-step-switch button {
  height: 32px;
  padding: 0 14px;
  border-radius: 7px;
  background: transparent;
  color: var(--muted);
  font-weight: 800;
}

.video-step-switch .active {
  border: 1px solid rgba(255, 133, 15, 0.56);
  background: rgba(255, 133, 15, 0.14);
  color: #ffb45f;
}

.video-controlbar {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 16px;
  min-height: 78px;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.045);
}

.ratio-tabs,
.video-settings,
.video-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.ratio-tabs span,
.video-settings label {
  color: var(--muted);
  font-size: 13px;
}

.ratio-tabs button,
.video-settings select {
  height: 32px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.07);
  color: var(--text);
}

.ratio-tabs button {
  padding: 0 12px;
}

.ratio-tabs .active {
  border-color: rgba(255, 133, 15, 0.6);
  background: rgba(255, 133, 15, 0.2);
  color: var(--orange);
}

.video-settings select {
  width: auto;
  min-width: 92px;
  padding: 0 12px;
}

.video-settings label select {
  min-width: 168px;
  margin-left: 6px;
}

.video-settings strong {
  color: var(--orange);
  font-size: 13px;
}

.video-actions button {
  height: 36px;
  padding: 0 16px;
  border-radius: 9px;
  font-weight: 900;
}

.pink-line {
  border: 1px solid rgba(255, 78, 169, 0.62);
  background: rgba(255, 78, 169, 0.09);
  color: #ff80c3;
}

.purple-line {
  border: 1px solid rgba(184, 94, 255, 0.7);
  background: rgba(125, 58, 181, 0.22);
  color: #ead7ff;
  box-shadow: 0 0 16px rgba(168, 83, 255, 0.28);
}

.cyan-line {
  border: 1px solid rgba(20, 174, 202, 0.62);
  background: rgba(20, 174, 202, 0.09);
  color: #67d7e7;
}

.gold-line {
  border: 1px solid rgba(255, 189, 86, 0.66);
  background: rgba(255, 189, 86, 0.1);
  color: #ffd37d;
}

.insert-shot {
  display: grid;
  place-items: center;
  height: 28px;
  border: 1px dashed rgba(255, 255, 255, 0.13);
  border-radius: 9px;
  color: var(--muted);
  font-size: 12px;
}

.storyboard-list {
  display: grid;
  gap: 14px;
}

.shot-card {
  position: relative;
  display: grid;
  grid-template-columns: 48px minmax(230px, 0.72fr) minmax(270px, 0.75fr) minmax(340px, 1fr) minmax(320px, 1.05fr);
  min-height: 286px;
  border: 1px solid var(--line);
  border-radius: 12px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.045);
}

.shot-index {
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, rgba(255, 133, 15, 0.28), rgba(255, 133, 15, 0.05));
  color: var(--orange);
  font-size: 22px;
  font-weight: 900;
}

.shot-cell {
  min-width: 0;
  padding: 14px;
  border-left: 1px solid rgba(255, 255, 255, 0.07);
}

.shot-cell h4 {
  margin: 0 0 10px;
  color: var(--muted);
  font-size: 13px;
}

.shot-script,
.shot-prompt {
  min-height: 224px;
  padding: 12px;
  border-radius: 9px;
  background: rgba(0, 0, 0, 0.26);
  color: #d8dad8;
  font-size: 13px;
  line-height: 1.65;
  white-space: pre-wrap;
}

.shot-script-editor,
.shot-prompt-editor {
  width: 100%;
  min-height: 224px;
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 9px;
  background: rgba(0, 0, 0, 0.26);
  color: #ececef;
  font: inherit;
  font-size: 13px;
  line-height: 1.65;
  resize: vertical;
  outline: none;
}

.shot-script-editor:focus,
.shot-prompt-editor:focus {
  border-color: rgba(214, 122, 255, 0.52);
  box-shadow: 0 0 0 3px rgba(207, 115, 255, 0.11);
}

.shot-cell-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.shot-cell-title h4 {
  margin: 0;
}

.reparse-shot-script {
  height: 28px;
  padding: 0 10px;
  border: 1px solid rgba(199, 120, 255, 0.45);
  border-radius: 999px;
  background: rgba(199, 120, 255, 0.12);
  color: #e4c8ff;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
  white-space: nowrap;
}

.reparse-shot-script:disabled {
  opacity: 0.62;
  cursor: wait;
}

.shot-asset-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-bottom: 12px;
}

.shot-asset-tags:has(.smart-asset-media-grid) {
  display: grid;
}

.smart-asset-media-grid {
  max-height: 220px;
  margin-bottom: 6px;
}

.shot-asset-tags button {
  height: 28px;
  padding: 0 10px;
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.08);
  color: var(--text);
  font-size: 12px;
}

.shot-asset-tags .role-tag { border: 1px solid rgba(255, 133, 15, 0.5); color: #ffad55; }
.shot-asset-tags .scene-tag { border: 1px solid rgba(48, 157, 255, 0.5); color: #7fc1ff; }
.shot-asset-tags .prop-tag { border: 1px solid rgba(151, 83, 255, 0.5); color: #c49cff; }
.shot-asset-tags .audio-tag {
  border: 1px solid rgba(37, 221, 142, 0.56);
  color: #52e8a2;
  background: rgba(37, 221, 142, 0.09);
}

.shot-reference-cell {
  min-width: 0;
}

.shot-reference-panel {
  display: grid;
  gap: 12px;
  height: 100%;
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;
  background: #111113;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035);
}

.shot-reference-panel h4 {
  margin: 0;
  color: #f4f0f4;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.shot-asset-media-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  max-height: 250px;
  overflow: auto;
  padding-right: 2px;
}

.shot-asset-group {
  display: grid;
  gap: 6px;
}

.shot-asset-group-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: #f4f0f4;
  font-size: 11px;
  font-weight: 900;
}

.shot-asset-group-title small {
  color: #8f8b94;
  font-size: 10px;
  font-weight: 700;
}

.shot-asset-group-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.shot-asset-group.scene .shot-asset-group-grid,
.shot-asset-group.prop .shot-asset-group-grid {
  grid-template-columns: 1fr;
}

.shot-asset-tile {
  min-width: 0;
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  padding: 8px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 11px;
  background: #17171a;
}

.shot-asset-group.scene .shot-asset-tile {
  grid-template-columns: 88px minmax(0, 1fr);
}

.shot-asset-group.prop .shot-asset-tile {
  grid-template-columns: 58px minmax(0, 1fr);
}

.shot-asset-tile.matched {
  border-color: rgba(69, 214, 150, 0.22);
  background: linear-gradient(135deg, rgba(69, 214, 150, 0.08), rgba(23, 23, 26, 0.96));
}

.shot-asset-tile.missing-image {
  border-style: dashed;
  border-color: rgba(255, 178, 75, 0.26);
}

.shot-asset-thumb {
  display: grid;
  width: 58px;
  aspect-ratio: 3 / 4;
  place-items: center;
  overflow: hidden;
  border: 1px solid rgba(255, 126, 181, 0.22);
  border-radius: 9px;
  background:
    radial-gradient(circle at 50% 35%, rgba(255, 126, 181, 0.22), transparent 28%),
    rgba(10, 10, 12, 0.92);
  color: #ffc9df;
  font-weight: 900;
}

.shot-asset-thumb.has-image {
  border-color: rgba(255, 255, 255, 0.2);
}

.shot-asset-thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: rgba(255, 255, 255, 0.04);
}

.shot-asset-tile.scene .shot-asset-thumb {
  aspect-ratio: 16 / 9;
  width: 88px;
  border-color: rgba(72, 156, 255, 0.26);
  color: #9ed1ff;
}

.shot-asset-tile.prop .shot-asset-thumb {
  aspect-ratio: 1 / 1;
  border-color: rgba(169, 112, 255, 0.28);
  color: #d8c0ff;
}

.shot-asset-tile-meta {
  min-width: 0;
}

.shot-asset-tile-meta strong,
.shot-asset-tile-meta small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.shot-asset-tile-meta strong {
  color: #f4f0f4;
  font-size: 12px;
}

.shot-asset-tile-meta small {
  margin-top: 4px;
  color: #8f8b94;
  font-size: 11px;
}

.shot-asset-tile-meta em {
  display: inline-block;
  margin-top: 5px;
  padding: 2px 6px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  color: #9de7bf;
  font-size: 10px;
  font-style: normal;
}

.shot-asset-tile.missing-image .shot-asset-tile-meta em {
  color: #ffc36c;
}

.shot-asset-tags.compact,
.shot-ref-groups {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0;
}

.shot-asset-tags.compact button,
.ref-chip {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 0 10px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 750;
  line-height: 1;
  white-space: nowrap;
}

.shot-asset-tags.compact button {
  border-width: 1px;
  background: rgba(255, 255, 255, 0.045);
}

.ref-chip.role-tag,
.shot-asset-tags.compact .role-tag {
  border-color: rgba(255, 150, 61, 0.48);
  color: #ffc071;
  background: rgba(255, 137, 47, 0.13);
}

.ref-chip.scene-tag,
.shot-asset-tags.compact .scene-tag {
  border-color: rgba(72, 156, 255, 0.45);
  color: #8fc7ff;
  background: rgba(60, 132, 255, 0.12);
}

.ref-chip.prop-tag,
.shot-asset-tags.compact .prop-tag {
  border-color: rgba(169, 112, 255, 0.45);
  color: #d3b5ff;
  background: rgba(134, 78, 255, 0.13);
}

.ref-chip.audio-tag {
  border-color: rgba(37, 221, 142, 0.5);
  color: #7ef0b8;
  background: rgba(37, 221, 142, 0.11);
}

.shot-ref-groups {
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.shot-current-model {
  display: grid;
  gap: 9px;
  align-self: end;
  margin-top: auto;
}

.shot-current-model > span {
  color: #c9c2ca;
  font-size: 12px;
  font-weight: 800;
}

.shot-current-model select {
  width: 100%;
  min-width: 0;
  height: 36px;
  padding: 0 10px;
  border: 1px solid rgba(255, 255, 255, 0.11);
  border-radius: 9px;
  background: #1d1d21;
  color: #f5f2f6;
  font-size: 12px;
  outline: none;
}

.shot-current-model select:focus {
  border-color: rgba(214, 122, 255, 0.66);
  box-shadow: 0 0 0 3px rgba(207, 115, 255, 0.12);
}

.shot-setting-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.apply-shot-settings {
  height: 36px;
  border: 1px solid rgba(199, 120, 255, 0.58);
  border-radius: 10px;
  background: linear-gradient(135deg, rgba(155, 90, 255, 0.92), rgba(221, 103, 255, 0.82));
  color: #fff;
  font-size: 13px;
  font-weight: 850;
  cursor: pointer;
  box-shadow: 0 10px 22px rgba(156, 88, 255, 0.18);
}

.apply-shot-settings:hover {
  filter: brightness(1.08);
}

.shot-role-media {
  display: grid;
  gap: 10px;
}

.shot-role-mini {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  padding: 9px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.045);
}

.shot-role-thumb {
  display: grid;
  width: 58px;
  aspect-ratio: 3 / 4;
  place-items: center;
  overflow: hidden;
  border: 1px solid rgba(255, 126, 181, 0.22);
  border-radius: 10px;
  background:
    radial-gradient(circle at 50% 35%, rgba(255, 126, 181, 0.22), transparent 28%),
    rgba(10, 10, 12, 0.92);
  background-position: center;
  background-size: cover;
  color: #ffc9df;
  font-weight: 900;
}

.shot-role-thumb.has-image {
  border-color: rgba(255, 255, 255, 0.24);
}

.shot-role-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.shot-role-meta {
  min-width: 0;
}

.shot-role-meta strong,
.shot-role-meta small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.shot-role-meta strong {
  color: var(--text);
  font-size: 13px;
}

.shot-role-meta small {
  margin-top: 5px;
  color: #aeb0b8;
  font-size: 12px;
}

.shot-role-meta small.has-audio {
  color: #52e8a2;
}

.shot-role-empty {
  min-height: 112px;
  display: grid;
  place-items: center;
  border: 1px dashed rgba(255, 255, 255, 0.12);
  border-radius: 12px;
  color: var(--muted);
  font-size: 12px;
}

.audio-bound-badge {
  display: block;
  margin-top: 7px;
  color: #52e8a2;
}

.shot-asset-list {
  display: grid;
  gap: 8px;
}

.shot-asset-list div {
  padding: 10px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.045);
  color: var(--muted);
  font-size: 12px;
}

.shot-asset-list strong {
  display: block;
  margin-bottom: 3px;
  color: var(--text);
}

.shot-preview {
  display: grid;
  place-items: center;
  min-height: 224px;
  border: 1px dashed rgba(157, 88, 255, 0.35);
  border-radius: 10px;
  background:
    radial-gradient(circle at 50% 52%, rgba(142, 73, 207, 0.24), transparent 20%),
    linear-gradient(180deg, rgba(72, 43, 91, 0.28), rgba(13, 12, 16, 0.86));
  color: #bba6d4;
  text-align: center;
}

.shot-video-player {
  width: 100%;
  height: 100%;
  min-height: inherit;
  border-radius: inherit;
  object-fit: contain;
  background: #050507;
}

.shot-video-caption {
  margin-top: 8px;
  color: rgba(255, 239, 247, 0.72);
  font-size: 12px;
  line-height: 1.45;
}

.shot-preview.running {
  animation: videoPulse 1.1s ease-in-out infinite;
}

.shot-progress {
  display: grid;
  justify-items: center;
  gap: 9px;
  width: min(260px, 88%);
  padding: 18px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 18px;
  background: rgba(15, 12, 18, 0.42);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.shot-progress strong,
.shot-progress em {
  color: #fff3fa;
  font-style: normal;
  font-weight: 900;
}

.shot-progress small {
  max-width: 100%;
  color: rgba(255, 239, 247, 0.74);
  font-size: 12px;
  line-height: 1.45;
}

.shot-progress .mini-progress {
  width: 100%;
  height: 9px;
  background: rgba(255, 255, 255, 0.14);
}

@keyframes videoPulse {
  0%, 100% { box-shadow: inset 0 0 0 rgba(141, 72, 206, 0.1), 0 0 0 rgba(141, 72, 206, 0.1); }
  50% { box-shadow: inset 0 0 28px rgba(141, 72, 206, 0.26), 0 0 18px rgba(141, 72, 206, 0.18); }
}

.shot-generate {
  width: 100%;
  height: 32px;
  margin-top: 10px;
  border-radius: 8px;
  background: rgba(141, 72, 206, 0.45);
  color: #f1e5ff;
  font-weight: 900;
}

.shot-video-actions,
.smart-preview-actions {
  display: grid;
  grid-template-columns: 1fr 68px 68px 54px;
  gap: 8px;
  margin-top: 10px;
}

.shot-video-actions .shot-generate,
.smart-preview-actions .shot-generate {
  margin-top: 0;
}

.dark-pill,
.gold-pill {
  height: 32px;
  border-radius: 8px;
  font-weight: 800;
}

.dark-pill {
  background: rgba(255, 255, 255, 0.09);
  color: #d8d8d8;
}

.gold-pill {
  border: 1px solid rgba(255, 189, 86, 0.48);
  background: rgba(255, 189, 86, 0.12);
  color: #ffd37d;
}

.smart-workbench {
  display: grid;
  grid-template-columns: minmax(420px, 0.9fr) minmax(420px, 1.6fr);
  gap: 14px;
}

.smart-preview-panel,
.smart-detail-panel {
  min-width: 0;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.045);
}

.smart-pager {
  display: grid;
  grid-template-columns: 88px 1fr 88px;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}

.smart-pager button {
  height: 30px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.07);
  color: var(--muted);
}

.smart-pager strong {
  text-align: center;
}

.smart-video-preview {
  display: grid;
  place-items: center;
  min-height: 398px;
  border: 1px dashed rgba(157, 88, 255, 0.38);
  border-radius: 12px;
  background:
    radial-gradient(circle at 50% 50%, rgba(141, 72, 206, 0.24), transparent 18%),
    linear-gradient(180deg, rgba(50, 33, 65, 0.42), rgba(15, 13, 18, 0.9));
  color: #a88ac9;
  text-align: center;
}

.smart-detail-panel h4 {
  margin: 18px 0 10px;
  color: var(--muted);
}

.smart-note-strip {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 150px;
  gap: 10px;
  margin-top: 14px;
  overflow-x: auto;
  padding-bottom: 8px;
}

.smart-note-strip button {
  min-height: 92px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 9px;
  background: rgba(0, 0, 0, 0.22);
  color: var(--muted);
  text-align: left;
}

.smart-note-strip button.active {
  border-color: rgba(255, 133, 15, 0.72);
  color: var(--text);
}

.smart-note-strip span,
.smart-note-strip small {
  display: block;
}

.smart-note-strip span {
  color: var(--orange);
  font-weight: 900;
}

.video-modal,
.video-history-modal {
  position: relative;
  width: min(600px, calc(100vw - 32px));
  max-height: calc(100vh - 48px);
  overflow: auto;
  padding: 26px;
  border: 1px solid rgba(151, 83, 255, 0.48);
  border-radius: 10px;
  background: #19191a;
  box-shadow: 0 28px 80px rgba(0, 0, 0, 0.55);
}

.video-history-modal {
  width: min(900px, calc(100vw - 32px));
  min-height: 420px;
}

.video-modal h2,
.video-history-modal h2 {
  margin-bottom: 22px;
  color: #c69aff;
}

.info-box {
  margin-bottom: 16px;
  padding: 14px;
  border: 1px solid rgba(64, 151, 255, 0.36);
  border-radius: 9px;
  background: rgba(25, 86, 151, 0.18);
  color: #9ccaff;
}

.info-box p {
  margin: 7px 0 0;
  line-height: 1.6;
}

.video-upload-zone {
  min-height: 184px;
  margin-top: 14px;
  border-color: rgba(151, 83, 255, 0.42);
}

.history-list {
  display: grid;
  gap: 12px;
}

.history-video-card,
.history-empty {
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.045);
}

.history-video-card {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 14px;
  align-items: stretch;
}

.history-video-thumb {
  position: relative;
  min-height: 124px;
  overflow: hidden;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: radial-gradient(circle at 50% 40%, rgba(179, 91, 255, 0.28), rgba(8, 8, 12, 0.92));
  cursor: pointer;
}

.history-video-thumb video {
  width: 100%;
  height: 100%;
  min-height: 124px;
  object-fit: cover;
  display: block;
}

.history-play-icon {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.54);
  color: #fff;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.45);
}

.history-no-video {
  display: grid;
  place-items: center;
  min-height: 124px;
  color: var(--muted);
}

.history-video-info strong,
.history-video-info span,
.history-video-info p,
.history-video-info em,
.history-empty span,
.history-empty small {
  display: block;
}

.history-video-info span,
.history-video-info p,
.history-empty small {
  margin-top: 6px;
  color: var(--muted);
}

.history-video-info em {
  margin-top: 10px;
  color: #76f5d2;
  font-style: normal;
  font-weight: 800;
}

.history-video-info em.expired,
.video-history-player-meta .expired {
  color: #ff8c9d;
}

.history-video-actions {
  display: flex;
  gap: 10px;
  margin-top: 14px;
  align-items: center;
}

.history-video-actions button,
.history-download-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 9px;
  text-decoration: none;
  font-weight: 900;
}

.history-upscale-btn {
  border: 1px solid rgba(250, 192, 92, 0.76);
  background: linear-gradient(135deg, rgba(255, 235, 174, 0.95), rgba(245, 169, 62, 0.9));
  color: #4b2600;
  box-shadow: 0 8px 18px rgba(238, 148, 48, 0.18);
}

.history-upscale-btn:disabled {
  border-color: rgba(130, 113, 120, 0.32);
  background: rgba(255, 255, 255, 0.42);
  color: rgba(96, 81, 88, 0.62);
  box-shadow: none;
}

.video-history-player-modal {
  position: relative;
  width: min(1040px, calc(100vw - 32px));
  padding: 22px;
}

.video-history-player-modal #closeVideoHistoryPlayer {
  position: absolute;
  top: -18px;
  right: -18px;
  z-index: 20;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border: 2px solid rgba(255, 255, 255, 0.86);
  border-radius: 999px;
  background: rgba(10, 10, 12, 0.94);
  color: #fff;
  font-size: 28px;
  line-height: 1;
  box-shadow: 0 18px 50px rgba(0, 0, 0, 0.45);
}

.video-history-player-modal video {
  width: 100%;
  max-height: calc(100vh - 210px);
  border-radius: 16px;
  background: #000;
}

.video-history-player-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 12px;
  color: var(--muted);
}

.video-history-player-meta b {
  color: #76f5d2;
}

.points-payment-guide {
  margin: 14px 0;
  padding: 14px;
  border: 1px solid rgba(180, 111, 255, 0.24);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.06);
  color: #f7f1f7;
}

.points-payment-guide strong,
.points-payment-guide p,
.points-payment-guide small {
  display: block;
}

.points-payment-guide p,
.points-payment-guide small {
  margin-top: 7px;
  color: var(--muted);
  line-height: 1.6;
}

.points-payment-guide img {
  display: block;
  width: 150px;
  height: 150px;
  object-fit: cover;
  margin-top: 12px;
  border-radius: 14px;
  background: #fff;
}

.points-payment-guide dl {
  display: grid;
  grid-template-columns: 86px minmax(0, 1fr);
  gap: 8px 12px;
  margin: 12px 0 0;
}

.points-payment-guide dt {
  color: var(--muted);
}

.points-payment-guide dd {
  margin: 0;
  color: #fff;
  word-break: break-all;
}

/* Admin and workflow enhancements */
.logo strong {
  max-width: 140px;
  font-size: 17px;
  letter-spacing: 0;
  white-space: nowrap;
}

.nav button {
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 0;
}

.episode-breadcrumb {
  font-size: 14px;
  font-weight: 800;
}

.episode-breadcrumb .back-btn {
  min-width: 78px;
  padding: 0 12px;
  font-size: 15px;
  color: #fff;
}

.episode-breadcrumb strong {
  font-size: 15px;
  color: #fff;
}

.episode-progress button.complete {
  color: #11d778;
}

.episode-progress button.complete span {
  background: #12c96d;
  color: #fff;
  box-shadow: 0 0 0 5px rgba(18, 201, 109, 0.16);
}

.episode-progress i.complete {
  background: #12c96d;
}

.episode-progress button.pending span {
  background: rgba(255, 255, 255, 0.08);
  color: var(--muted);
}

.smart-workbench-pro {
  grid-template-columns: minmax(480px, 0.95fr) minmax(520px, 1.35fr);
  align-items: stretch;
}

.smart-workbench-pro .smart-preview-panel,
.smart-workbench-pro .smart-detail-panel {
  border-color: rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.052);
}

.smart-workbench-pro .smart-video-preview {
  min-height: 430px;
  border-color: rgba(144, 73, 214, 0.56);
  background:
    radial-gradient(circle at 50% 48%, rgba(133, 72, 191, 0.28), transparent 18%),
    linear-gradient(180deg, rgba(45, 30, 58, 0.68), rgba(16, 14, 19, 0.92));
}

.smart-workbench-pro .smart-preview-actions {
  grid-template-columns: 1fr 74px 74px 74px;
}

.smart-download,
.shot-download {
  border: 1px solid rgba(20, 174, 202, 0.55);
  color: #67d7e7;
  background: rgba(20, 174, 202, 0.1);
}

.shot-video-actions:has(.shot-download) {
  grid-template-columns: 1fr 58px 58px 46px 58px;
}

.admin-backdrop {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(0, 0, 0, 0.72);
  backdrop-filter: blur(10px);
}

.admin-backdrop.open {
  display: flex;
}

.admin-panel {
  position: relative;
  width: min(1180px, 100%);
  max-height: calc(100vh - 48px);
  overflow: auto;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 14px;
  background: #171818;
  box-shadow: 0 30px 90px rgba(0, 0, 0, 0.55);
}

.admin-close {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 2;
  width: 34px;
  height: 34px;
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.08);
  color: var(--muted);
  font-size: 22px;
}

.admin-login {
  display: grid;
  gap: 16px;
  width: min(420px, 100%);
  margin: 0 auto;
  padding: 52px 32px;
}

.admin-login h2,
.admin-console h2 {
  margin: 0;
  color: #fff;
}

.admin-login p,
.admin-console p {
  margin: 6px 0 0;
  color: var(--muted);
}

.admin-login label,
.admin-page label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 13px;
}

.admin-login input,
.admin-page input,
.admin-page select {
  height: 40px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.26);
  color: var(--text);
  padding: 0 12px;
}

.admin-primary {
  height: 40px;
  padding: 0 16px;
  border-radius: 8px;
  background: linear-gradient(135deg, #ffb233, var(--orange));
  color: #241200;
  font-weight: 900;
}

.admin-console {
  padding: 28px;
}

.admin-console header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.admin-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 18px;
}

.admin-tabs button {
  height: 34px;
  padding: 0 14px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.07);
  color: var(--muted);
  font-weight: 800;
}

.admin-tabs button.active {
  background: rgba(255, 133, 15, 0.18);
  color: var(--orange);
  border: 1px solid rgba(255, 133, 15, 0.45);
}

.admin-page {
  display: none;
}

.admin-page.active {
  display: grid;
  gap: 16px;
}

.admin-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  color: var(--muted);
}

.admin-toolbar button,
.employee-row button {
  height: 34px;
  padding: 0 12px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.08);
  color: var(--text);
}

.employee-table,
.api-grid,
.visual-admin-grid {
  display: grid;
  gap: 10px;
}

.employee-row {
  display: grid;
  grid-template-columns: 1fr 1fr 0.8fr 0.7fr 0.8fr 72px;
  gap: 10px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.045);
}

.api-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.visual-admin-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.admin-preview-card {
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.045);
}

.admin-preview-card strong,
.admin-preview-card small {
  display: block;
}

.admin-preview-card small {
  margin-top: 6px;
  color: var(--muted);
}

#styleGrid button,
#toneGrid button {
  background-image:
    linear-gradient(rgba(0,0,0,.08), rgba(0,0,0,.2)),
    var(--admin-card-bg, none);
  background-size: cover;
  background-position: center;
}

@media (max-width: 980px) {
  .smart-workbench-pro,
  .employee-row,
  .api-grid,
  .visual-admin-grid {
    grid-template-columns: 1fr;
  }
}

.project-asset-view {
  padding: 18px 10px 30px;
}

.asset-library-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.asset-library-head h2 {
  margin: 0;
  font-size: 22px;
}

.asset-library-head div {
  display: flex;
  gap: 10px;
}

.asset-library-head input,
.global-asset-tools input {
  height: 38px;
  min-width: 220px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.055);
  color: var(--text);
  padding: 0 12px;
}

.asset-library-head button,
.global-asset-tools button {
  height: 38px;
  padding: 0 14px;
  border-radius: 8px;
  background: rgba(255, 133, 15, 0.18);
  color: var(--orange);
  font-weight: 900;
}

.project-asset-grid,
.global-asset-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.library-asset-card {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.05);
}

.library-asset-cover {
  display: grid;
  place-items: center;
  height: 190px;
  background:
    radial-gradient(circle at 52% 36%, rgba(255, 255, 255, 0.18), transparent 12%),
    linear-gradient(135deg, rgba(255, 133, 15, 0.24), rgba(0, 0, 0, 0.52));
  background-size: cover;
  background-position: center;
  color: rgba(255, 255, 255, 0.72);
  font-size: 44px;
}

.library-asset-cover.scene {
  background:
    radial-gradient(circle at 60% 34%, rgba(96, 168, 255, 0.2), transparent 16%),
    linear-gradient(135deg, #18202a, #4a3822);
}

.library-asset-cover.prop {
  background:
    radial-gradient(circle at 48% 42%, rgba(55, 231, 146, 0.18), transparent 14%),
    linear-gradient(135deg, #17241e, #343026);
}

.library-asset-body {
  padding: 12px;
}

.library-asset-body h3 {
  margin: 0 0 7px;
  font-size: 15px;
}

.library-asset-body p {
  min-height: 42px;
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.55;
}

.library-asset-body small {
  display: block;
  margin-top: 7px;
  color: var(--orange);
  font-size: 12px;
}

.library-asset-body div {
  display: grid;
  grid-template-columns: 1fr 44px 44px;
  gap: 8px;
  margin-top: 10px;
}

.library-asset-body div:has(.asset-add-project) {
  grid-template-columns: 1fr 44px 44px;
}

.library-asset-body button {
  height: 30px;
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.09);
  color: var(--text);
}

.library-asset-body .asset-add-project {
  color: #2ee27e;
  background: rgba(16, 171, 93, 0.18);
}

.library-asset-body .asset-delete {
  color: #ff7b7b;
}

.global-asset-drawer {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 70;
  width: min(520px, 100vw);
  height: 100vh;
  overflow: auto;
  border-left: 1px solid var(--line);
  background: #171818;
  box-shadow: -28px 0 80px rgba(0, 0, 0, 0.5);
  transform: translateX(102%);
  transition: transform 0.22s ease;
}

.global-asset-drawer.open {
  transform: translateX(0);
}

.global-asset-drawer header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 58px;
  padding: 0 18px;
  border-bottom: 1px solid var(--line);
}

.global-asset-drawer header button {
  width: 32px;
  height: 32px;
  background: transparent;
  color: var(--muted);
  font-size: 24px;
}

.global-asset-drawer nav {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-bottom: 1px solid var(--line);
}

.global-asset-drawer nav button {
  height: 44px;
  background: transparent;
  color: var(--muted);
  font-weight: 900;
}

.global-asset-drawer nav button.active {
  color: var(--orange);
  border-bottom: 2px solid var(--orange);
  background: rgba(255, 133, 15, 0.08);
}

.global-asset-tools {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  padding: 14px;
}

.global-asset-grid {
  grid-template-columns: 1fr 1fr;
  padding: 0 14px 22px;
}

.asset-edit-modal {
  position: relative;
  width: min(560px, calc(100vw - 32px));
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #1d1d1d;
  box-shadow: var(--shadow);
}

.asset-edit-modal h2 {
  margin: 0 0 18px;
}

.asset-edit-modal label {
  display: grid;
  gap: 7px;
  margin-bottom: 12px;
  color: var(--muted);
  font-size: 13px;
}

.asset-edit-modal textarea {
  min-height: 110px;
  margin: 0;
}

@media (max-width: 1100px) {
  .project-asset-grid,
  .global-asset-grid {
    grid-template-columns: 1fr;
  }
}

.shot-delete {
  position: absolute;
  top: 12px;
  right: 12px;
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 8px;
  background: rgba(255, 77, 77, 0.12);
  color: #ff6b6b;
  font-size: 0;
}

.shot-delete::before {
  content: "";
  width: 15px;
  height: 15px;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20viewBox%3D%270%200%2024%2024%27%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%3E%3Cpath%20fill%3D%27%23000%27%20d%3D%27M9%203h6l1%202h4v2H4V5h4l1-2Zm1.2%204h3.6l-.5-1h-2.6l-.5%201ZM6%209h12l-1%2012H7L6%209Zm3%202v8h2v-8H9Zm4%200v8h2v-8h-2Z%27/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg%20viewBox%3D%270%200%2024%2024%27%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%3E%3Cpath%20fill%3D%27%23000%27%20d%3D%27M9%203h6l1%202h4v2H4V5h4l1-2Zm1.2%204h3.6l-.5-1h-2.6l-.5%201ZM6%209h12l-1%2012H7L6%209Zm3%202v8h2v-8H9Zm4%200v8h2v-8h-2Z%27/%3E%3C/svg%3E") center / contain no-repeat;
}

.queue div.running span {
  background: var(--orange);
  box-shadow: 0 0 0 4px rgba(255, 133, 15, 0.14);
}

.queue div.done span,
.queue div.complete span {
  background: var(--green);
  box-shadow: 0 0 0 4px rgba(53, 230, 161, 0.14);
}

.queue div.running em {
  color: var(--orange);
}

.queue div.done em,
.queue div.complete em {
  color: var(--green);
}

.queue div.failed span {
  background: #ff5f8d;
  box-shadow: 0 0 0 4px rgba(255, 95, 141, 0.14);
}

.queue div.failed em {
  color: #ff8cac;
}

.float-help {
  position: fixed;
  right: 18px;
  bottom: 34px;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--orange);
  color: white;
  box-shadow: var(--shadow);
}

.toast {
  position: fixed;
  right: 22px;
  bottom: 88px;
  min-width: 220px;
  padding: 12px 14px;
  border: 1px solid rgba(255, 133, 15, 0.42);
  border-radius: 8px;
  background: rgba(22, 22, 22, 0.96);
  box-shadow: var(--shadow);
  opacity: 0;
  transform: translateY(12px);
  transition: 0.2s ease;
  pointer-events: none;
}

.toast.show {
  opacity: 1;
  transform: translateY(0);
}

.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 30;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(0, 0, 0, 0.72);
}

.modal-backdrop.open {
  display: flex;
}

.create-modal {
  position: relative;
  width: min(672px, 100%);
  max-height: calc(100vh - 48px);
  overflow: auto;
  padding: 26px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #1d1d1d;
  box-shadow: var(--shadow);
}

.episode-modal {
  position: relative;
  width: min(512px, 100%);
  padding: 32px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #1d1d1d;
  box-shadow: var(--shadow);
}

.create-modal h2,
.episode-modal h2 {
  margin-bottom: 24px;
  font-size: 26px;
}

.modal-close {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: transparent;
  color: var(--muted);
  font-size: 28px;
}

.modal-grid {
  display: grid;
  gap: 16px;
}

.modal-grid.two {
  grid-template-columns: 1fr 1fr;
}

.modal-grid.three {
  grid-template-columns: 1.35fr 0.8fr 0.8fr;
}

.field {
  display: grid;
  gap: 10px;
  margin-bottom: 18px;
}

.field span {
  color: #d8d8d5;
  font-weight: 800;
}

.field b {
  color: #ff6b6b;
}

.mode-select {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.mode-select button {
  position: relative;
  min-height: 124px;
  padding: 18px;
  border: 1px solid transparent;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.065);
  color: var(--text);
  text-align: left;
}

.mode-select button.active {
  border-color: var(--green);
  background: rgba(22, 199, 161, 0.14);
}

.mode-select strong,
.mode-select small {
  display: block;
}

.mode-select strong {
  margin: 30px 0 8px;
}

.mode-select small {
  color: var(--muted);
  line-height: 1.5;
}

.mode-select em {
  position: absolute;
  top: 14px;
  right: 14px;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--green);
  color: #052018;
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
}

.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
}

.episode-modal .modal-actions {
  border-top: 0;
  padding-top: 12px;
}

.episode-desc {
  min-height: 98px;
}

.secondary {
  height: 44px;
  padding: 0 24px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.075);
  color: var(--text);
  font-weight: 800;
}

.episode-breadcrumb {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
  color: var(--muted);
}

.episode-breadcrumb em {
  color: #555;
  font-style: normal;
}

.episode-breadcrumb strong {
  color: var(--text);
}

.episode-progress {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 34px;
  min-height: 96px;
  margin-bottom: 16px;
}

.episode-progress button {
  display: grid;
  justify-items: center;
  gap: 8px;
  background: transparent;
  color: var(--muted);
  font-weight: 900;
}

.episode-progress button.active {
  color: var(--text);
}

.episode-progress button:disabled {
  cursor: default;
}

.episode-progress span {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  color: var(--muted);
  font-size: 18px;
}

.episode-progress button.active span {
  background: var(--orange);
  color: white;
  box-shadow: 0 0 0 5px rgba(255, 133, 15, 0.18);
}

.episode-progress i {
  width: 86px;
  height: 2px;
  background: rgba(255, 255, 255, 0.1);
}

.workflow-screen {
  max-width: none;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.recognize-panel,
.script-panel {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.055);
}

.recognize-panel {
  padding: 22px;
  margin-bottom: 20px;
}

.recognize-head,
.recognize-actions,
.script-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.recognize-actions {
  min-width: 520px;
}

.recognize-status {
  display: grid;
  grid-template-columns: 44px 1fr;
  align-items: center;
  gap: 12px;
  min-width: 280px;
  padding: 10px 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.025)),
    radial-gradient(circle at 20% 0%, rgba(255, 133, 15, 0.16), transparent 48%);
}

.status-mark {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 11px;
  background: linear-gradient(135deg, rgba(255, 133, 15, 0.18), rgba(255, 184, 65, 0.06));
  color: var(--orange);
  font-size: 24px;
  font-weight: 900;
}

.recognize-status em,
.recognize-status small {
  display: block;
}

.recognize-status em {
  color: var(--text);
  font-size: 14px;
  font-style: normal;
  font-weight: 900;
}

.recognize-status small {
  margin-top: 3px;
  color: var(--muted);
  font-size: 12px;
}

.style-picker {
  display: grid;
  grid-template-columns: 54px 1fr auto;
  align-items: center;
  gap: 14px;
  width: 100%;
  min-height: 84px;
  margin-top: 28px;
  padding: 14px 18px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.045);
  color: var(--text);
  text-align: left;
}

.style-icon {
  display: grid;
  place-items: center;
  width: 52px;
  height: 52px;
  border-radius: 12px;
  background: rgba(255, 133, 15, 0.14);
  color: var(--orange);
  font-size: 32px;
}

.style-picker strong,
.style-picker small {
  display: block;
}

.style-picker small {
  margin-top: 4px;
  color: var(--muted);
}

.style-picker em {
  color: var(--muted);
  font-style: normal;
  font-size: 20px;
}

.tone-picker {
  margin-top: 14px;
}

.tone-picker .style-icon {
  background: rgba(255, 184, 65, 0.14);
  color: #ffb841;
}

.script-panel {
  padding: 22px;
  border-color: rgba(255, 133, 15, 0.45);
}

.script-head {
  margin-bottom: 14px;
}

.script-head span {
  color: var(--muted);
  font-size: 12px;
}

#scriptInput {
  min-height: 350px;
}

.style-modal {
  position: relative;
  width: min(1024px, 100%);
  max-height: calc(100vh - 48px);
  overflow: auto;
  padding: 30px 26px 34px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: #1b1b1b;
  box-shadow: var(--shadow);
}

.style-modal h2 {
  margin-bottom: 8px;
  font-size: 28px;
}

.style-modal > p {
  margin-bottom: 28px;
  color: var(--muted);
}

.style-modal h3 {
  margin: 0 0 14px;
  padding-left: 10px;
  border-left: 4px solid var(--orange);
}

.style-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(130px, 1fr));
  gap: 16px;
  margin-bottom: 28px;
}

.style-grid button {
  position: relative;
  min-height: 136px;
  overflow: hidden;
  border-radius: 12px;
  background: #222;
  color: white;
  text-align: center;
}

.style-grid button.active {
  outline: 2px solid var(--orange);
  box-shadow: 0 0 0 4px rgba(255, 133, 15, 0.18), 0 14px 34px rgba(0, 0, 0, 0.35);
}

.style-grid strong,
.style-grid small {
  position: relative;
  z-index: 2;
  display: block;
}

.style-grid strong {
  margin-top: 76px;
  font-size: 14px;
}

.style-grid small {
  margin-top: 4px;
  color: rgba(255, 255, 255, 0.78);
  font-size: 12px;
}

.style-art {
  position: absolute;
  inset: 0;
  display: block;
  background-size: cover;
  background-position: center;
}

.style-grid button::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 20%, rgba(0, 0, 0, 0.76));
}

.style-grid button.active::before,
.tone-grid button.active::after {
  content: "已选择";
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 3;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(255, 133, 15, 0.92);
  color: #fff;
  font-size: 11px;
  font-weight: 900;
}

/* 管理员可把这些 background 替换为 url(...) 背景图。 */
.style-art.modern { background: radial-gradient(circle at 28% 30%, rgba(255, 230, 180, 0.85), transparent 16%), linear-gradient(135deg, #3b2518, #b77a3f 45%, #14100f); }
.style-art.fantasy { background: radial-gradient(circle at 62% 25%, rgba(255, 196, 80, 0.8), transparent 17%), linear-gradient(135deg, #162238, #73542c 48%, #160c0c); }
.style-art.kstyle { background: radial-gradient(circle at 50% 25%, rgba(255, 245, 255, 0.88), transparent 18%), linear-gradient(135deg, #b9d2ff, #dc8da4 46%, #1e416d); }
.style-art.republic { background: radial-gradient(circle at 70% 22%, rgba(255, 199, 92, 0.75), transparent 14%), linear-gradient(135deg, #18110e, #a66a2d 52%, #080808); }
.style-art.ancient { background: radial-gradient(circle at 48% 28%, rgba(255, 210, 180, 0.72), transparent 15%), linear-gradient(135deg, #1d314d, #aa5b58 52%, #0d131e); }
.style-art.xianxia { background: radial-gradient(circle at 46% 22%, rgba(230, 210, 170, 0.75), transparent 16%), linear-gradient(135deg, #251713, #7d5a3e 48%, #100b09); }
.style-art.child { background: radial-gradient(circle at 32% 30%, rgba(255, 244, 110, 0.9), transparent 15%), linear-gradient(135deg, #43b8ef, #ef6e8b 45%, #ffc64d); }
.style-art.cyber { background: radial-gradient(circle at 30% 28%, rgba(48, 238, 255, 0.8), transparent 14%), linear-gradient(135deg, #101642, #dc3ea6 48%, #0fc9df); }
.style-art.suspense { background: radial-gradient(circle at 70% 30%, rgba(130, 180, 160, 0.45), transparent 16%), linear-gradient(135deg, #071312, #284a4a 48%, #060806); }
.style-art.vlog { background: radial-gradient(circle at 34% 34%, rgba(255, 240, 200, 0.78), transparent 15%), linear-gradient(135deg, #c9b28e, #5f9898 48%, #172027); }
.style-art.crime { background: radial-gradient(circle at 65% 24%, rgba(70, 120, 170, 0.6), transparent 15%), linear-gradient(135deg, #142734, #1d2944 48%, #06080b); }
.style-art.city { background: radial-gradient(circle at 40% 28%, rgba(230, 175, 110, 0.72), transparent 15%), linear-gradient(135deg, #1a2330, #745231 48%, #131518); }
.style-art.custom-admin { background: var(--custom-style-bg, radial-gradient(circle at 38% 28%, rgba(210, 110, 255, 0.72), transparent 16%), linear-gradient(135deg, #251537, #683c8a 48%, #17101f)); }

.custom-style-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.custom-style-head h3 {
  border-left-color: #c05cff;
}

.custom-style-head button {
  height: 38px;
  padding: 0 16px;
  border-radius: 8px;
  background: rgba(145, 75, 210, 0.28);
  color: #d9a6ff;
  font-weight: 900;
}

.style-select-actions {
  justify-content: flex-end;
  margin-top: 18px;
}

.intro-video-overlay {
  position: fixed;
  z-index: 0;
  inset: 0;
  display: grid;
  place-items: center;
  background: #030507;
  pointer-events: none;
}

.intro-video-overlay::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.46);
}

.intro-video-player {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

body.intro-video-active .shell {
  position: relative;
  z-index: 2;
}

body.intro-video-active .employee-login-screen {
  z-index: 9000;
}

body.intro-video-active::before {
  opacity: 0;
}

body.intro-login-pending.employee-logged-out .shell {
  opacity: 0;
  pointer-events: none;
}

body.intro-login-pending:not(.employee-logged-out) .shell {
  opacity: 1;
  pointer-events: auto;
}

body.intro-video-active .employee-login-screen,
body.intro-video-active .shell {
  transition: opacity 0.45s ease;
}

.tone-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 26px;
}

.tone-grid button {
  position: relative;
  overflow: hidden;
  min-height: 112px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.055);
  color: var(--text);
  text-align: left;
}

.tone-grid button.active {
  border-color: var(--orange);
  background: rgba(255, 133, 15, 0.12);
  box-shadow: 0 0 0 3px rgba(255, 133, 15, 0.14);
}

.tone-grid strong,
.tone-grid small {
  position: relative;
  z-index: 2;
  display: block;
}

.tone-grid strong {
  margin-bottom: 10px;
}

.tone-grid small {
  color: var(--muted);
  line-height: 1.55;
}

.tone-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 0.78;
  background: var(--tone-bg);
}

.tone-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(90deg, rgba(22, 22, 22, 0.92), rgba(22, 22, 22, 0.56));
}

/* 管理员可把 --tone-bg 替换为 url(...) 背景图。 */
.tone-bg.kdrama { --tone-bg: radial-gradient(circle at 75% 22%, rgba(255, 196, 218, 0.8), transparent 18%), linear-gradient(135deg, #3c1c2c, #a55b62 50%, #211216); }
.tone-bg.usdrama { --tone-bg: radial-gradient(circle at 72% 25%, rgba(92, 162, 255, 0.75), transparent 18%), linear-gradient(135deg, #18243a, #425a7a 48%, #101318); }
.tone-bg.shortplay { --tone-bg: radial-gradient(circle at 72% 25%, rgba(255, 184, 65, 0.9), transparent 18%), linear-gradient(135deg, #371a10, #9c4318 48%, #160b07); }
.tone-bg.mystery { --tone-bg: radial-gradient(circle at 75% 20%, rgba(110, 160, 150, 0.65), transparent 18%), linear-gradient(135deg, #071212, #263d43 48%, #060708); }
.tone-bg.healing { --tone-bg: radial-gradient(circle at 78% 28%, rgba(255, 231, 170, 0.8), transparent 18%), linear-gradient(135deg, #2a3324, #8aa078 48%, #14180f); }
.tone-bg.hkcrime { --tone-bg: radial-gradient(circle at 75% 24%, rgba(255, 80, 70, 0.74), transparent 18%), linear-gradient(135deg, #151515, #573330 48%, #050505); }
.tone-bg.custom-admin-tone { --tone-bg: radial-gradient(circle at 75% 24%, rgba(190, 90, 255, 0.7), transparent 18%), linear-gradient(135deg, #23152f, #53366d 48%, #100817); }

.custom-tone-form,
.custom-config-form {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}

.custom-config-form {
  display: grid;
  gap: 2px;
}

.custom-config-form[hidden] {
  display: none !important;
}

.custom-config-form .episode-desc {
  min-height: 86px;
}

@media (max-width: 1180px) {
  .workflow-screen {
    max-width: none;
  }

  .style-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .asset-toolbar {
    align-items: flex-start;
    flex-wrap: wrap;
  }

  .asset-card-grid,
  .prop-grid {
    grid-template-columns: 1fr;
  }

  .video-controlbar {
    grid-template-columns: 1fr;
    align-items: flex-start;
  }

  .shot-card {
    grid-template-columns: 42px 1fr;
  }

  .shot-cell {
    grid-column: 2;
  }
}

@media (max-width: 860px) {
  .shell {
    grid-template-columns: 1fr;
  }

  .sidebar {
    position: static;
    height: auto;
  }

  .stats,
  .project-area {
    grid-template-columns: 1fr;
  }

  .topbar,
  .project-topbar,
  .screen-head {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
  }

  .process-nav {
    grid-template-columns: 1fr;
  }

  .project-tabs {
    flex-wrap: wrap;
  }

  .modal-grid.two,
  .modal-grid.three,
  .mode-select {
    grid-template-columns: 1fr;
  }

  .style-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .episode-progress {
    gap: 12px;
  }

  .episode-progress i {
    width: 36px;
  }

  .recognize-head,
  .recognize-actions,
  .script-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .recognize-actions {
    min-width: 0;
    width: 100%;
  }

  .recognize-status {
    width: 100%;
  }

  .video-step-switch,
  .ratio-tabs,
  .video-settings,
  .video-actions {
    width: 100%;
  }

  .video-actions button {
    flex: 1;
  }

  .shot-card {
    grid-template-columns: 1fr;
  }

  .shot-index,
  .shot-cell {
    grid-column: auto;
  }
}

/* Project and global asset libraries */
.project-asset-view {
  padding: 24px 10px 44px;
  border-top: 1px solid var(--line);
}

.asset-library-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 18px;
}

.asset-library-head h2 {
  margin: 0;
  font-size: 22px;
  font-weight: 950;
}

.asset-library-head h2::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 18px;
  margin-right: 10px;
  border-radius: 999px;
  background: var(--orange);
  vertical-align: -3px;
}

.asset-library-head > div,
.global-asset-tools {
  display: flex;
  align-items: center;
  gap: 10px;
}

.asset-library-head input,
.global-asset-tools input,
.asset-edit-modal input,
.asset-edit-modal textarea {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(5, 5, 5, 0.72);
  color: var(--text);
  outline: none;
}

.asset-library-head input,
.global-asset-tools input {
  width: 230px;
  height: 38px;
  padding: 0 12px;
}

.asset-library-head button,
.global-asset-tools button {
  height: 38px;
  padding: 0 14px;
  border-radius: 8px;
  background: linear-gradient(135deg, #ff8b15, #ff6400);
  color: #101010;
  font-weight: 950;
  box-shadow: 0 8px 20px rgba(255, 112, 0, 0.18);
}

.project-asset-grid,
.global-asset-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
}

.library-asset-card {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(26, 26, 26, 0.96);
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.24);
}

.library-asset-cover {
  position: relative;
  display: grid;
  place-items: center;
  height: 188px;
  overflow: hidden;
  background-position: center;
  background-size: cover;
}

.library-asset-cover::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 70% 22%, rgba(255, 255, 255, 0.28), transparent 15%),
    linear-gradient(135deg, rgba(255, 139, 15, 0.36), rgba(8, 8, 8, 0.95));
}

.library-asset-cover.scene::before {
  background:
    radial-gradient(circle at 70% 22%, rgba(90, 165, 255, 0.26), transparent 15%),
    linear-gradient(135deg, rgba(40, 95, 125, 0.42), rgba(7, 8, 10, 0.95));
}

.library-asset-cover.prop::before {
  background:
    radial-gradient(circle at 70% 22%, rgba(0, 220, 140, 0.22), transparent 15%),
    linear-gradient(135deg, rgba(21, 120, 82, 0.38), rgba(7, 8, 10, 0.96));
}

.library-asset-cover[style]::before {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.05), rgba(0, 0, 0, 0.16));
}

.library-asset-cover span {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.82);
  font-size: 22px;
  backdrop-filter: blur(10px);
}

.library-asset-body {
  padding: 12px;
}

.library-asset-body h3 {
  margin: 0 0 7px;
  color: #fff;
  font-size: 15px;
  font-weight: 900;
}

.library-asset-body p {
  display: -webkit-box;
  min-height: 44px;
  margin: 0 0 8px;
  overflow: hidden;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.55;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.library-asset-body small {
  display: block;
  min-height: 18px;
  margin-bottom: 10px;
  color: var(--orange);
  font-size: 12px;
}

.library-asset-body > div {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 34px;
  gap: 8px;
}

.library-asset-card[data-global="1"] .library-asset-body > div {
  grid-template-columns: minmax(0, 1fr) 34px 34px;
}

.library-asset-body button {
  height: 30px;
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.09);
  color: var(--text);
  font-weight: 850;
}

.library-asset-body .asset-add-project {
  background: rgba(0, 200, 110, 0.18);
  color: #32d58b;
}

.library-asset-card[data-global="1"] .asset-add-project {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 78px;
  padding: 0 10px;
  background: rgba(0, 190, 96, 0.22);
  color: #27d781;
  font-size: 13px;
  font-weight: 950;
  white-space: nowrap;
}

.library-asset-card[data-global="1"] .asset-add-project:not(.added) {
  background: rgba(255, 139, 15, 0.18);
  color: #ff9b24;
}

.library-asset-card[data-global="1"] .asset-add-project.added {
  background: rgba(0, 190, 96, 0.22);
  color: #27d781;
}

.library-asset-body .asset-edit {
  font-size: 0;
}

.library-asset-body .asset-edit::before {
  content: "✎";
  font-size: 15px;
}

.library-asset-body .asset-delete {
  font-size: 0;
  color: #ff7474;
}

.library-asset-body .asset-delete::before {
  content: "";
  display: inline-block;
  width: 15px;
  height: 15px;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='24'%20height='24'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M3%206h18'/%3E%3Cpath%20d='M8%206V4c0-1%201-2%202-2h4c1%200%202%201%202%202v2'/%3E%3Cpath%20d='M19%206l-1%2014c0%201-1%202-2%202H8c-1%200-2-1-2-2L5%206'/%3E%3Cpath%20d='M10%2011v6'/%3E%3Cpath%20d='M14%2011v6'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='24'%20height='24'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='black'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M3%206h18'/%3E%3Cpath%20d='M8%206V4c0-1%201-2%202-2h4c1%200%202%201%202%202v2'/%3E%3Cpath%20d='M19%206l-1%2014c0%201-1%202-2%202H8c-1%200-2-1-2-2L5%206'/%3E%3Cpath%20d='M10%2011v6'/%3E%3Cpath%20d='M14%2011v6'/%3E%3C/svg%3E") center / contain no-repeat;
}

.global-asset-drawer {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 70;
  display: grid;
  grid-template-rows: auto auto auto 1fr;
  width: min(540px, 100vw);
  height: 100vh;
  border-left: 1px solid rgba(255, 139, 15, 0.28);
  background: rgba(20, 21, 21, 0.98);
  box-shadow: -24px 0 60px rgba(0, 0, 0, 0.42);
  transform: translateX(104%);
  transition: transform 0.22s ease;
}

.global-asset-drawer.open {
  transform: translateX(0);
}

.global-asset-drawer header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 18px 14px;
  border-bottom: 1px solid var(--line);
}

.global-asset-drawer h2 {
  margin: 0;
  font-size: 19px;
  font-weight: 950;
}

.global-asset-drawer header button {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.08);
  color: var(--muted);
  font-size: 18px;
}

.global-asset-drawer nav {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-bottom: 1px solid var(--line);
}

.global-asset-drawer nav button {
  height: 44px;
  border-bottom: 2px solid transparent;
  background: transparent;
  color: var(--muted);
  font-weight: 900;
}

.global-asset-drawer nav button.active {
  border-bottom-color: var(--orange);
  color: var(--orange);
  background: rgba(255, 139, 15, 0.08);
}

.global-asset-tools {
  padding: 14px;
}

.global-asset-tools input {
  flex: 1;
  min-width: 0;
}

.global-asset-grid {
  align-content: start;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  padding: 0 14px 18px;
  overflow: auto;
}

.global-asset-grid .library-asset-cover {
  height: 156px;
}

.asset-edit-modal {
  position: relative;
  width: min(560px, calc(100vw - 32px));
  padding: 26px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #1a1a1a;
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.5);
}

.asset-edit-modal h2 {
  margin: 0 0 18px;
  font-size: 24px;
  font-weight: 950;
}

.asset-edit-modal label {
  display: grid;
  gap: 8px;
  margin-bottom: 13px;
  color: var(--text);
  font-weight: 850;
}

.asset-edit-modal input,
.asset-edit-modal textarea {
  width: 100%;
  padding: 12px;
}

.asset-edit-modal textarea {
  min-height: 112px;
  resize: vertical;
}

@media (max-width: 860px) {
  .asset-library-head,
  .asset-library-head > div,
  .global-asset-tools {
    align-items: stretch;
    flex-direction: column;
  }

  .asset-library-head input,
  .global-asset-tools input {
    width: 100%;
  }

  .project-asset-grid,
  .global-asset-grid {
    grid-template-columns: 1fr;
  }
}

/* Direct upload form inside the global asset drawer */
.global-asset-drawer {
  grid-template-rows: auto auto auto auto 1fr;
}

.global-direct-form {
  margin: 14px 18px 12px;
  padding: 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.035);
}

.global-upload-zone {
  display: grid;
  place-items: center;
  width: 100%;
  min-height: 112px;
  margin-bottom: 12px;
  border: 1px dashed rgba(255, 139, 15, 0.7);
  border-radius: 10px;
  background:
    radial-gradient(circle at 50% 35%, rgba(255, 255, 255, 0.06), transparent 30%),
    rgba(5, 5, 5, 0.52);
  background-position: center;
  background-size: cover;
  color: var(--muted);
}

.global-upload-zone.compact {
  min-height: 42px;
  grid-template-columns: auto auto 1fr;
  justify-content: center;
  gap: 8px;
  padding: 0 12px;
  border-color: rgba(255, 255, 255, 0.28);
}

.global-upload-zone .upload-arrow {
  color: rgba(255, 255, 255, 0.42);
  font-size: 26px;
  line-height: 1;
}

.global-upload-zone.compact .upload-arrow {
  font-size: 17px;
}

.global-upload-zone strong {
  color: var(--muted);
  font-size: 14px;
  font-weight: 800;
}

.global-upload-zone small {
  overflow: hidden;
  max-width: 100%;
  color: var(--orange);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.global-direct-form input:not([type="file"]) {
  width: 100%;
  height: 38px;
  margin-bottom: 10px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(5, 5, 5, 0.72);
  color: var(--text);
  outline: none;
}

.global-direct-form input[hidden],
.global-direct-form button[hidden] {
  display: none !important;
}

.global-direct-add {
  width: 100%;
  height: 38px;
  border-radius: 8px;
  background: #74370e;
  color: #fff;
  font-size: 15px;
  font-weight: 950;
}

.global-direct-add.prop-mode {
  background: #0e6536;
}

.global-asset-tools {
  padding-top: 0;
}

.global-asset-grid {
  margin: 0 18px 18px;
  padding: 18px 14px;
  border: 1px dashed rgba(255, 139, 15, 0.58);
  border-radius: 12px;
}

.global-asset-drawer[data-type="prop"] .global-asset-grid {
  border-color: rgba(0, 210, 118, 0.58);
}

.global-asset-drawer[data-type="prop"] nav button.active {
  border-bottom-color: #19d476;
  color: #19d476;
  background: rgba(0, 210, 118, 0.08);
}

.global-asset-drawer[data-type="prop"] .global-upload-zone {
  border-color: rgba(0, 210, 118, 0.62);
}

.global-asset-grid::before {
  content: "所有项目资产集合";
  grid-column: 1 / -1;
  margin-bottom: -2px;
  color: var(--muted);
  text-align: center;
  font-size: 12px;
}

.library-asset-body em {
  display: block;
  overflow: hidden;
  margin: -2px 0 8px;
  color: #ff9a23;
  font-style: normal;
  font-size: 12px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Make global library status obvious across roles, scenes and props */
.global-asset-grid .library-asset-card {
  display: flex;
  min-height: 0;
  flex-direction: column;
}

.global-asset-grid .library-asset-cover {
  height: 122px;
  min-height: 122px;
}

.global-asset-grid .library-asset-body {
  display: flex;
  min-height: 132px;
  flex: 1;
  flex-direction: column;
}

.global-asset-grid .library-asset-body p {
  min-height: 38px;
  -webkit-line-clamp: 2;
}

.global-asset-grid .library-asset-body > div {
  margin-top: auto;
}

.asset-status-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 26px;
  padding: 0 10px;
  border-radius: 8px;
  color: #fff;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.28);
}

.asset-status-badge.added {
  background: rgba(0, 176, 93, 0.94);
}

.asset-status-badge.pending {
  background: rgba(255, 139, 15, 0.94);
}

.global-asset-grid .asset-add-project {
  border: 1px solid transparent;
}

.global-asset-grid .asset-add-project:not(.added) {
  border-color: rgba(255, 139, 15, 0.35);
}

.global-asset-grid .asset-add-project.added {
  border-color: rgba(35, 214, 129, 0.32);
}

/* Role cards follow the reference: portrait, name, base description, voice line, actions. */
.library-asset-card.role-asset-card {
  background: #161717;
}

.library-asset-card.role-asset-card .library-asset-cover {
  height: 158px;
  min-height: 158px;
  background-color: #f4f4f0;
  background-position: center top;
  background-size: cover;
}

.global-asset-grid .library-asset-card.role-asset-card .library-asset-cover {
  height: 150px;
  min-height: 150px;
}

.library-asset-card.role-asset-card .library-asset-cover::before {
  background:
    radial-gradient(circle at 70% 18%, rgba(255, 232, 194, 0.38), transparent 16%),
    linear-gradient(135deg, rgba(158, 86, 12, 0.88), rgba(26, 18, 13, 0.92));
}

.library-asset-card.role-asset-card .library-asset-cover[style]::before {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.02), rgba(0, 0, 0, 0.08));
}

.library-asset-card.role-asset-card .library-asset-body {
  min-height: 148px;
  padding: 10px 11px 12px;
}

.library-asset-card.role-asset-card .library-asset-body h3 {
  margin-bottom: 7px;
  text-align: center;
  font-size: 15px;
  line-height: 1.25;
}

.library-asset-card.role-asset-card .library-asset-body p {
  min-height: 42px;
  margin-bottom: 7px;
  color: #aeb0b4;
  font-size: 12px;
  line-height: 1.55;
  -webkit-line-clamp: 2;
}

.library-asset-card.role-asset-card .library-asset-body small {
  min-height: 18px;
  margin-bottom: 10px;
  overflow: hidden;
  color: #ff8a00;
  font-size: 12px;
  font-weight: 850;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.library-asset-card.role-asset-card .library-asset-body > div {
  grid-template-columns: minmax(82px, 1fr) 34px 34px;
  margin-top: auto;
}

.project-asset-grid .library-asset-card.role-asset-card .library-asset-body > div {
  grid-template-columns: minmax(82px, 1fr) 34px;
}

.library-asset-card.role-asset-card[data-global="0"] .asset-edit {
  font-size: 0;
}

/* Total asset drawer cards must show full asset context, not just covers. */
.global-asset-drawer .library-asset-card {
  display: flex !important;
  min-height: 286px;
  flex-direction: column;
  border-radius: 10px;
  background: #171818;
}

.global-asset-drawer .library-asset-cover {
  flex: 0 0 128px;
  height: 128px !important;
  min-height: 128px !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.global-asset-drawer .role-asset-card .library-asset-cover {
  flex-basis: 142px;
  height: 142px !important;
  min-height: 142px !important;
}

.global-asset-drawer .library-asset-body {
  display: flex !important;
  min-height: 136px;
  flex: 1;
  flex-direction: column;
  padding: 11px 12px 12px;
  background: #171818;
}

.global-asset-drawer .library-asset-body h3 {
  display: block;
  margin: 0 0 7px;
  color: #fff;
  font-size: 15px;
  font-weight: 950;
  line-height: 1.25;
}

.global-asset-drawer .role-asset-card .library-asset-body h3 {
  text-align: center;
}

.global-asset-drawer .library-asset-body p {
  display: -webkit-box !important;
  min-height: 38px;
  margin: 0 0 7px;
  overflow: hidden;
  color: #aeb0b4;
  font-size: 12px;
  line-height: 1.55;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.global-asset-drawer .library-asset-body small {
  display: block !important;
  min-height: 18px;
  margin: 0 0 10px;
  overflow: hidden;
  color: #ff8a00;
  font-size: 12px;
  font-weight: 850;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.global-asset-drawer[data-type="prop"] .library-asset-body small {
  color: #22d37c;
}

.global-asset-drawer .library-asset-body > div {
  display: grid !important;
  grid-template-columns: minmax(96px, 1fr) 34px 34px;
  gap: 8px;
  margin-top: auto;
}

.global-asset-drawer .asset-add-project {
  height: 30px;
  border-radius: 8px;
  font-size: 13px;
}

.global-asset-drawer .role-asset-card {
  min-height: 318px;
  overflow: visible;
}

.global-asset-drawer .role-asset-card .library-asset-body {
  min-height: 176px;
  padding-bottom: 14px;
}

.global-asset-drawer .role-asset-card .library-asset-body p {
  min-height: 44px;
}

.global-asset-drawer .role-asset-card .library-asset-body small {
  min-height: 20px;
  margin-bottom: 12px;
}

.global-asset-drawer .role-asset-card .library-asset-body > div {
  min-height: 32px;
}

.asset-card-variants {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  min-height: 22px;
  margin: -2px 0 9px;
}

.asset-card-variants b {
  max-width: 86px;
  overflow: hidden;
  padding: 3px 7px;
  border-radius: 999px;
  background: rgba(255, 139, 15, 0.14);
  color: #ff9a23;
  font-size: 11px;
  font-weight: 850;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.asset-variant-panel {
  margin: 12px 0 2px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.035);
}

.asset-variant-panel[hidden] {
  display: none !important;
}

.asset-variant-head {
  display: grid;
  gap: 4px;
  margin-bottom: 10px;
}

.asset-variant-head strong {
  color: #fff;
  font-size: 14px;
}

.asset-variant-head span,
.asset-empty-variants {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.55;
}

.asset-variant-list {
  display: grid;
  gap: 8px;
  max-height: 220px;
  overflow: auto;
  padding-right: 2px;
}

.asset-variant-item {
  display: grid;
  grid-template-columns: 48px 1fr 48px;
  gap: 10px;
  align-items: center;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.04);
}

.asset-variant-item div {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border-radius: 8px;
  background: rgba(255, 139, 15, 0.13);
  background-position: center;
  background-size: cover;
}

.asset-variant-item strong,
.asset-variant-item p {
  grid-column: 2;
  margin: 0;
}

.asset-variant-item p {
  display: -webkit-box;
  overflow: hidden;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.asset-variant-item button {
  grid-column: 3;
  grid-row: 1 / span 2;
  height: 30px;
  border-radius: 7px;
  background: rgba(255, 80, 80, 0.14);
  color: #ff7474;
  font-size: 12px;
}

.asset-variant-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 10px;
}

.asset-variant-form input {
  width: 100%;
  min-width: 0;
}

.asset-variant-form button {
  height: 36px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.09);
  color: var(--text);
  font-weight: 850;
}

#assetAddVariant {
  background: rgba(145, 75, 210, 0.28);
  color: #d9a6ff;
}

/* Full-site material library */
.material-hub-view {
  padding: 28px 32px 48px;
}

.material-hub-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  padding-bottom: 22px;
  border-bottom: 1px solid var(--line);
}

.material-hub-head h1 {
  margin: 0 0 8px;
  font-size: 28px;
  font-weight: 950;
}

.material-hub-head p {
  margin: 0;
  color: var(--muted);
}

.material-hub-stats {
  display: grid;
  grid-template-columns: repeat(4, 112px);
  gap: 10px;
}

.material-hub-stats article {
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.045);
}

.material-hub-stats strong {
  display: block;
  color: var(--orange);
  font-size: 24px;
}

.material-hub-stats span {
  color: var(--muted);
  font-size: 12px;
}

.material-hub-tabs {
  display: flex;
  gap: 10px;
  margin: 22px 0;
}

.material-hub-tabs button {
  height: 42px;
  padding: 0 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.055);
  color: var(--text);
  font-weight: 900;
}

.material-hub-tabs button.active {
  border-color: var(--orange);
  background: #ff7300;
  color: #111;
}

.material-hub-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 390px;
  gap: 18px;
  align-items: start;
}

.material-hub-main,
.material-hub-editor {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(22, 22, 22, 0.94);
}

.material-hub-main {
  padding: 16px;
}

.material-hub-toolbar {
  display: flex;
  gap: 10px;
  margin-bottom: 16px;
}

.material-hub-toolbar input,
.material-hub-editor input,
.material-hub-editor textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(5, 5, 5, 0.72);
  color: var(--text);
  outline: none;
}

.material-hub-toolbar input {
  height: 40px;
  padding: 0 12px;
}

.material-hub-toolbar button,
#hubSaveAsset {
  height: 40px;
  padding: 0 16px;
  border-radius: 8px;
  background: linear-gradient(135deg, #ff8b15, #ff6400);
  color: #101010;
  font-weight: 950;
  white-space: nowrap;
}

.material-hub-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 14px;
}

.hub-asset-card {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #171818;
  cursor: default;
}

.free-video-workbench {
  border: 1px solid rgba(255, 187, 214, 0.24);
  border-radius: 24px;
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 115, 181, 0.2), transparent 34%),
    linear-gradient(135deg, rgba(33, 24, 38, 0.96), rgba(18, 18, 24, 0.96));
  box-shadow: 0 28px 70px rgba(16, 6, 18, 0.34);
  padding: 22px;
}

.free-video-view {
  min-height: 100%;
  padding: 28px 32px 48px;
}

.free-video-view .free-video-workbench {
  min-height: calc(100vh - 96px);
}

.free-video-hero {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  padding: 8px 6px 22px;
}

.free-video-hero span {
  color: #ffb7d4;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.16em;
}

.free-video-hero h2 {
  margin: 8px 0;
  color: #fff;
  font-size: 30px;
  font-weight: 950;
  text-shadow: 0 0 18px rgba(255, 135, 188, 0.32);
}

.free-video-hero p {
  margin: 0;
  color: rgba(255, 239, 247, 0.72);
}

.free-video-back,
.free-video-actions button,
.free-video-reference-head button {
  border: 1px solid rgba(255, 202, 224, 0.28);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  font-weight: 900;
}

.free-video-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 18px;
}

.free-video-compose,
.free-video-results {
  border: 1px solid rgba(255, 214, 232, 0.16);
  border-radius: 22px;
  background: rgba(10, 10, 16, 0.62);
  backdrop-filter: blur(18px);
  padding: 18px;
}

.free-video-field {
  display: grid;
  gap: 10px;
}

.free-video-field span,
.free-video-controls span {
  color: #ffe8f2;
  font-size: 13px;
  font-weight: 900;
}

.free-video-field > span {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.free-template-btn {
  min-height: 30px;
  padding: 0 12px;
  border: 1px solid rgba(255, 255, 255, 0.58);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.62);
  color: #2b1b23;
  font-size: 12px;
  font-weight: 900;
  box-shadow: 0 8px 20px rgba(106, 34, 62, 0.1);
}

.free-template-btn:hover {
  background: #21141b;
  color: #fff;
}

#freeVideoPrompt {
  min-height: 210px;
  resize: vertical;
  border: 1px solid rgba(255, 206, 226, 0.22);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.075);
  color: #fff;
  padding: 18px;
  line-height: 1.7;
  outline: none;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.03);
}

.free-video-reference-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  margin: 18px 0 12px;
}

.free-video-reference-head strong,
.free-video-results header strong {
  display: block;
  color: #fff;
  font-size: 16px;
}

.free-video-reference-head small,
.free-video-results header small {
  display: block;
  color: rgba(255, 236, 245, 0.62);
  margin-top: 4px;
}

.free-video-reference-head > div:last-child {
  display: flex;
  gap: 8px;
}

.free-video-reference-head button {
  height: 36px;
  padding: 0 12px;
}

.free-video-reference-strip {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(146px, 146px));
  gap: 10px;
  align-items: start;
}

.free-ref-card,
.free-ref-add {
  position: relative;
  min-height: 142px;
  border: 1px solid rgba(255, 216, 233, 0.16);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.055);
  color: #fff;
  overflow: hidden;
}

.free-ref-add {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  cursor: pointer;
  aspect-ratio: 1 / 1;
  min-height: 0;
  width: 146px;
  text-align: center;
}

.runway-ref-drop {
  min-height: 0;
  padding: 16px 14px;
  isolation: isolate;
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.runway-ref-drop > span {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.64);
  color: #2b1b23;
  font-size: 24px;
  line-height: 1;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.78);
}

.runway-ref-drop strong {
  font-size: 15px;
  line-height: 1.25;
  color: #21141b;
}

.runway-ref-drop small,
.runway-ref-drop em {
  max-width: 118px;
  color: rgba(48, 28, 38, 0.72);
  font-style: normal;
  line-height: 1.45;
}

.runway-ref-drop em {
  font-size: 11px;
  color: rgba(48, 28, 38, 0.48);
}

.runway-ref-drop:hover,
.runway-ref-drop.menu-open,
.runway-ref-drop.dragging {
  transform: translateY(-2px);
  border-color: rgba(255, 255, 255, 0.82);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.72), rgba(255, 233, 242, 0.52)),
    rgba(255, 255, 255, 0.38);
  box-shadow: 0 18px 42px rgba(116, 43, 73, 0.16);
}

.runway-ref-drop.dragging {
  outline: 2px dashed rgba(115, 44, 72, 0.42);
  outline-offset: -8px;
}

.free-ref-menu {
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: 10px;
  z-index: 5;
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 16px;
  background: rgba(255, 248, 251, 0.92);
  box-shadow: 0 18px 42px rgba(78, 29, 50, 0.2);
  backdrop-filter: blur(18px);
}

.free-ref-menu button {
  display: grid;
  gap: 3px;
  text-align: left;
  padding: 10px 12px;
  border: 0;
  border-radius: 12px;
  background: rgba(243, 201, 219, 0.36);
  color: #2b1b23;
}

.free-ref-menu button:hover {
  background: rgba(235, 178, 202, 0.48);
}

.free-ref-menu strong {
  font-size: 13px;
}

.free-ref-menu small {
  color: rgba(43, 27, 35, 0.58);
}

.free-ref-preview {
  height: 84px;
  background: rgba(255, 255, 255, 0.07);
}

.free-ref-preview img,
.free-ref-preview video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.free-ref-audio {
  display: grid;
  place-items: center;
  height: 100%;
  color: #ffd3e6;
  font-size: 30px;
}

.free-ref-card strong,
.free-ref-card small {
  display: block;
  padding: 0 10px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.free-ref-card strong {
  margin-top: 9px;
  font-size: 13px;
}

.free-ref-card small {
  color: rgba(255, 236, 245, 0.56);
  font-size: 11px;
}

.free-ref-remove {
  position: absolute;
  z-index: 2;
  right: 7px;
  top: 7px;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.48);
  color: #fff;
}

.free-video-controls {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 16px;
}

.free-video-controls label {
  display: grid;
  gap: 8px;
}

.free-video-controls select {
  height: 42px;
  border: 1px solid rgba(255, 211, 230, 0.18);
  border-radius: 12px;
  background: rgba(0, 0, 0, 0.42);
  color: #fff;
  padding: 0 12px;
}

.free-video-actions {
  display: flex;
  gap: 10px;
  margin-top: 18px;
}

.free-video-quota {
  margin-top: 12px;
  padding: 10px 14px;
  border: 1px solid rgba(255, 255, 255, 0.52);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.38);
  color: rgba(43, 27, 35, 0.72);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.55;
}

.free-video-quota.blocked {
  border-color: rgba(198, 46, 90, 0.34);
  background: rgba(255, 226, 236, 0.66);
  color: #8a2446;
}

.free-video-actions button {
  height: 44px;
  padding: 0 18px;
}

.free-video-actions .primary,
#freeVideoGenerate {
  border-color: transparent;
  background: linear-gradient(135deg, #ff79b2, #ff4f8f);
  color: #1d0912;
}

.free-video-progress {
  margin-top: 16px;
  padding: 14px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.07);
}

.free-video-progress > div {
  display: flex;
  justify-content: space-between;
  color: #fff;
  font-weight: 900;
}

.free-video-progress i {
  display: block;
  height: 9px;
  margin: 10px 0;
  border-radius: 99px;
  background: rgba(255, 255, 255, 0.12);
  overflow: hidden;
}

.free-video-progress b {
  display: block;
  height: 100%;
  width: 0;
  border-radius: inherit;
  background: linear-gradient(90deg, #ff79b2, #ffd1e2);
}

.free-video-progress p {
  margin: 0;
  color: rgba(255, 236, 245, 0.68);
}

.free-video-results {
  max-height: 760px;
  overflow: auto;
}

.free-video-results header {
  margin-bottom: 14px;
}

.free-video-result-card {
  border: 1px solid rgba(255, 220, 236, 0.14);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.055);
  overflow: hidden;
  margin-bottom: 12px;
}

.free-video-thumb {
  aspect-ratio: 16 / 9;
  background: rgba(0, 0, 0, 0.42);
  display: grid;
  place-items: center;
  color: #ffd4e7;
  font-weight: 900;
}

.free-video-thumb video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.free-video-result-body {
  padding: 12px;
}

.free-video-result-body strong,
.free-video-result-body p,
.free-video-result-body small {
  display: block;
}

.free-video-result-body strong {
  color: #fff;
}

.free-video-result-body p {
  margin: 7px 0;
  color: rgba(255, 239, 246, 0.7);
  font-size: 12px;
  line-height: 1.55;
}

.free-video-result-body small {
  color: rgba(255, 225, 239, 0.58);
  font-size: 11px;
}

.free-video-result-body div {
  display: flex;
  gap: 8px;
  margin-top: 10px;
}

.free-video-result-body button,
.free-video-result-body a {
  flex: 1;
  height: 32px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.09);
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
}

.free-video-result-body .free-result-upscale {
  background: linear-gradient(135deg, #ffd36c, #ff9f2e);
  color: #201100;
}

.free-video-empty {
  padding: 24px;
  border: 1px dashed rgba(255, 216, 234, 0.24);
  border-radius: 16px;
  color: rgba(255, 240, 247, 0.68);
  text-align: center;
}

.free-asset-picker > section {
  width: min(920px, calc(100vw - 40px));
  max-height: min(760px, calc(100vh - 70px));
  overflow: auto;
  border-color: rgba(255, 200, 224, 0.25);
  background: rgba(24, 18, 28, 0.96);
}

.free-asset-tabs {
  display: flex;
  gap: 8px;
  margin: 14px 0;
}

.free-asset-tabs button {
  height: 36px;
  padding: 0 16px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}

.free-asset-tabs button.active {
  background: #ff79b2;
  color: #200812;
}

.free-asset-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 12px;
}

.free-asset-choice {
  min-height: 190px;
  border: 1px solid rgba(255, 218, 235, 0.16);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.065);
  color: #fff;
  overflow: hidden;
  text-align: left;
}

.free-asset-choice div {
  height: 116px;
  display: grid;
  place-items: center;
  background: rgba(255, 255, 255, 0.06);
  color: #ffd3e6;
  font-size: 28px;
}

.free-asset-choice img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.free-asset-choice strong,
.free-asset-choice small {
  display: block;
  padding: 0 12px;
}

.free-asset-choice strong {
  margin-top: 10px;
}

.free-asset-choice small {
  margin-top: 5px;
  color: rgba(255, 236, 245, 0.62);
  font-size: 12px;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Multi-reference video: pink glass theme */
.free-video-view {
  background:
    radial-gradient(circle at 18% 12%, rgba(255, 232, 241, 0.6), transparent 28%),
    linear-gradient(135deg, rgba(166, 82, 108, 0.72), rgba(222, 126, 153, 0.86));
}

.free-video-view .free-video-workbench {
  border-color: rgba(255, 255, 255, 0.38);
  background:
    linear-gradient(135deg, rgba(255, 248, 251, 0.58), rgba(248, 210, 224, 0.28)),
    radial-gradient(circle at 80% 10%, rgba(255, 255, 255, 0.58), transparent 34%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 28px 80px rgba(95, 34, 55, 0.18);
  backdrop-filter: blur(26px) saturate(1.18);
}

.free-video-view .free-video-hero span {
  color: #fff4f8;
  text-shadow: 0 1px 2px rgba(66, 20, 35, 0.36);
}

.free-video-view .free-video-hero h2 {
  color: #fff;
  font-family: "STKaiti", "KaiTi", "华文楷体", "Microsoft YaHei", sans-serif;
  font-size: 38px;
  letter-spacing: 0.02em;
  text-shadow:
    0 2px 0 rgba(37, 20, 28, 0.9),
    2px 0 0 rgba(37, 20, 28, 0.8),
    -1px 0 0 rgba(37, 20, 28, 0.72),
    0 10px 22px rgba(116, 37, 68, 0.28);
}

.free-video-view .free-video-hero p,
.free-video-view .free-video-reference-head small,
.free-video-view .free-video-results header small,
.free-video-view .free-video-progress p,
.free-video-view .free-video-result-body p,
.free-video-view .free-video-result-body small {
  color: rgba(60, 35, 48, 0.72);
}

.free-video-view .free-video-compose,
.free-video-view .free-video-results {
  border-color: rgba(255, 255, 255, 0.45);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.58), rgba(255, 233, 241, 0.28)),
    rgba(255, 244, 248, 0.36);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.7),
    0 18px 44px rgba(96, 31, 55, 0.12);
  backdrop-filter: blur(24px) saturate(1.22);
}

.free-video-view .free-video-field span,
.free-video-view .free-video-controls span,
.free-video-view .free-video-reference-head strong,
.free-video-view .free-video-results header strong,
.free-video-view .free-video-result-body strong {
  color: #2a1821;
}

.free-video-view .free-template-btn {
  color: #2b1b23;
}

.free-video-view .free-template-btn:hover {
  color: #fff;
}

.free-video-view #freeVideoPrompt {
  border-color: rgba(255, 255, 255, 0.66);
  background: rgba(255, 255, 255, 0.62);
  color: #2b1b23;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.86),
    0 12px 34px rgba(120, 44, 72, 0.08);
}

.free-video-view #freeVideoPrompt::placeholder {
  color: rgba(64, 40, 52, 0.46);
}

.free-video-view .free-video-back,
.free-video-view .free-video-actions button,
.free-video-view .free-video-reference-head button,
.free-video-view .free-video-controls select,
.free-video-view .free-video-result-body button,
.free-video-view .free-video-result-body a {
  border-color: rgba(255, 255, 255, 0.58);
  background: rgba(255, 255, 255, 0.52);
  color: #2b1b23;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 10px 24px rgba(106, 34, 62, 0.1);
}

.free-video-view .free-video-controls select {
  color: #2b1b23;
}

.free-video-view .free-video-actions .primary,
.free-video-view #freeVideoGenerate {
  background: linear-gradient(135deg, #fff7fb, #f3c8d9);
  color: #2b1b23;
  border-color: rgba(255, 255, 255, 0.76);
}

.free-video-view .free-ref-card,
.free-video-view .free-ref-add,
.free-video-view .free-video-result-card,
.free-video-view .free-video-empty {
  border-color: rgba(255, 255, 255, 0.48);
  background: rgba(255, 255, 255, 0.38);
  color: #2b1b23;
  box-shadow: 0 14px 30px rgba(105, 38, 65, 0.08);
}

.free-video-view .free-ref-preview,
.free-video-view .free-video-thumb {
  background: rgba(255, 245, 249, 0.62);
  color: #8a3c5c;
}

.free-video-view .free-ref-card strong,
.free-video-view .free-ref-card small,
.free-video-view .free-video-empty {
  color: #2b1b23;
}

.free-video-view .free-ref-remove {
  background: rgba(70, 31, 46, 0.26);
}

.free-video-view .free-video-progress {
  background: rgba(255, 255, 255, 0.38);
}

.free-video-view .free-video-progress > div {
  color: #2b1b23;
}

.free-video-view .free-video-progress i {
  background: rgba(95, 42, 61, 0.12);
}

.free-video-view .free-video-progress b {
  background: linear-gradient(90deg, #a75075, #f5c8d8);
}

.free-video-view .free-video-result-body .free-result-upscale {
  background: linear-gradient(135deg, #fff1c7, #f0b85b);
  color: #2b1b23;
}

.free-video-view .free-asset-picker > section {
  border-color: rgba(255, 255, 255, 0.5);
  background: rgba(252, 228, 238, 0.92);
  backdrop-filter: blur(24px) saturate(1.2);
}

.free-video-view .free-asset-tabs button,
.free-video-view .free-asset-choice {
  border-color: rgba(255, 255, 255, 0.48);
  background: rgba(255, 255, 255, 0.42);
  color: #2b1b23;
}

.free-video-view .free-asset-tabs button.active {
  background: rgba(255, 255, 255, 0.78);
  color: #2b1b23;
}

.free-video-view .free-asset-choice div {
  background: rgba(255, 245, 249, 0.62);
  color: #8a3c5c;
}

.free-video-view .free-asset-choice small {
  color: rgba(43, 27, 35, 0.64);
}

.free-ref-modal {
  z-index: 10020 !important;
  display: none !important;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(58, 22, 38, .34);
  backdrop-filter: blur(20px) saturate(1.16);
}

.free-ref-modal.open {
  display: flex !important;
}

.free-ref-modal > section {
  width: min(860px, calc(100vw - 36px));
  max-height: min(780px, calc(100vh - 42px));
  overflow: auto;
  border: 1px solid rgba(255,255,255,.62);
  border-radius: 34px;
  background:
    radial-gradient(circle at 84% 12%, rgba(255,255,255,.86), transparent 22%),
    linear-gradient(135deg, rgba(255,240,245,.92), rgba(234,162,184,.78));
  box-shadow: 0 30px 90px rgba(95, 31, 54, .26);
  color: #2b1b23;
}

.free-ref-modal-head {
  padding: 30px 34px 16px;
}

.free-ref-modal-head span {
  color: rgba(43,27,35,.48);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .18em;
}

.free-ref-modal-head h2 {
  margin: 8px 0;
  color: #21141b;
  font-size: 34px;
  letter-spacing: -.06em;
}

.free-ref-modal-head p {
  margin: 0;
  color: rgba(43,27,35,.62);
}

.free-ref-modal-drop {
  display: grid;
  justify-items: center;
  gap: 10px;
  margin: 8px 34px 18px;
  min-height: 220px;
  padding: 28px;
  border: 1px dashed rgba(92,42,60,.28);
  border-radius: 28px;
  background: rgba(255,255,255,.46);
  text-align: center;
  cursor: pointer;
  transition: .2s ease;
}

.free-ref-modal-drop.dragging,
.free-ref-modal-drop:hover {
  border-color: rgba(160,55,96,.42);
  background: rgba(255,255,255,.68);
  transform: translateY(-2px);
}

.free-ref-modal-drop b {
  display: grid;
  place-items: center;
  width: 58px;
  height: 58px;
  border-radius: 18px;
  background: #fff;
  color: #21141b;
  font-size: 30px;
  box-shadow: 0 16px 34px rgba(95, 31, 54, .12);
}

.free-ref-modal-drop strong {
  color: #21141b;
  font-size: 20px;
}

.free-ref-modal-drop small {
  color: rgba(43,27,35,.58);
  line-height: 1.7;
}

.free-ref-modal-drop button,
.free-ref-modal-actions button {
  border: 1px solid rgba(43,27,35,.1);
  border-radius: 999px;
  background: #21141b;
  color: #fff;
  font-weight: 900;
}

.free-ref-modal-drop button {
  height: 42px;
  padding: 0 22px;
}

.free-ref-modal-actions {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  padding: 0 34px 18px;
}

.free-ref-modal-actions button {
  min-height: 104px;
  display: grid;
  align-content: center;
  gap: 8px;
  padding: 16px;
  border-radius: 24px;
  background: rgba(255,255,255,.58);
  color: #2b1b23;
  text-align: left;
}

.free-ref-modal-actions button:hover {
  background: #21141b;
  color: #fff;
  transform: translateY(-2px);
}

.free-ref-modal-actions small {
  color: rgba(43,27,35,.55);
  line-height: 1.5;
}

.free-ref-modal-actions button:hover small {
  color: rgba(255,255,255,.72);
}

.free-ref-modal-current {
  margin: 0 34px 30px;
  padding: 16px;
  border-radius: 24px;
  background: rgba(255,255,255,.4);
}

.free-ref-modal-current > strong {
  display: block;
  margin-bottom: 12px;
  color: #21141b;
}

#freeVideoRefModalCurrent {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(126px, 1fr));
  gap: 10px;
}

#freeVideoRefModalCurrent span,
#freeVideoRefModalCurrent em {
  display: grid;
  gap: 7px;
  min-height: 96px;
  padding: 9px;
  border-radius: 18px;
  background: rgba(255,255,255,.62);
  color: rgba(43,27,35,.72);
  font-size: 12px;
  font-style: normal;
}

#freeVideoRefModalCurrent img,
#freeVideoRefModalCurrent video {
  width: 100%;
  height: 68px;
  border-radius: 12px;
  object-fit: cover;
  background: rgba(255,245,249,.8);
}

#freeVideoRefModalCurrent b {
  display: grid;
  place-items: center;
  height: 68px;
  border-radius: 12px;
  background: rgba(255,245,249,.8);
  color: #8a3c5c;
  font-size: 22px;
}

#freeVideoRefModalCurrent strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: #2b1b23;
}

.free-video-view .free-video-hero h2 {
  color: #fffafc !important;
  font-family: "STXingkai", "华文行楷", "FZYaoti", "STKaiti", "KaiTi", "Microsoft YaHei", serif !important;
  font-size: clamp(40px, 5.2vw, 56px) !important;
  font-weight: 900 !important;
  letter-spacing: 0.08em !important;
  line-height: 1.04 !important;
  -webkit-text-stroke: 1px rgba(35, 24, 28, 0.88);
  text-shadow:
    0 1px 0 rgba(28, 22, 26, 0.96),
    1px 0 0 rgba(28, 22, 26, 0.9),
    -1px 0 0 rgba(28, 22, 26, 0.9),
    0 3px 0 rgba(28, 22, 26, 0.78),
    0 10px 18px rgba(87, 30, 52, 0.32) !important;
}

.free-video-view #freeVideoWorkbench .free-video-hero h2 {
  color: #fff !important;
  font-family: "STXingkai", "华文行楷", "FZYaoti", "STKaiti", "KaiTi", "Microsoft YaHei", serif !important;
  -webkit-text-stroke: 1.4px rgba(18, 14, 16, 0.96);
  text-shadow:
    0 1px 0 #111,
    1px 0 0 #111,
    -1px 0 0 #111,
    0 -1px 0 #111,
    0 3px 0 rgba(17, 17, 17, 0.86),
    0 10px 18px rgba(87, 30, 52, 0.3) !important;
}

@media (max-width: 780px) {
  .free-ref-modal-actions {
    grid-template-columns: 1fr 1fr;
  }
}

.hub-asset-card:hover {
  border-color: rgba(255, 139, 15, 0.45);
  box-shadow: 0 14px 32px rgba(0, 0, 0, 0.22);
}

.hub-card-cover {
  position: relative;
  display: grid;
  place-items: center;
  height: 150px;
  background:
    radial-gradient(circle at 70% 20%, rgba(255, 220, 180, 0.34), transparent 16%),
    linear-gradient(135deg, rgba(135, 72, 14, 0.85), rgba(12, 12, 12, 0.96));
  background-position: center;
  background-size: cover;
}

.hub-asset-card.scene .hub-card-cover {
  background:
    radial-gradient(circle at 70% 20%, rgba(110, 180, 255, 0.28), transparent 16%),
    linear-gradient(135deg, rgba(32, 89, 120, 0.78), rgba(12, 12, 12, 0.96));
}

.hub-asset-card.prop .hub-card-cover {
  background:
    radial-gradient(circle at 70% 20%, rgba(0, 210, 128, 0.28), transparent 16%),
    linear-gradient(135deg, rgba(18, 105, 72, 0.78), rgba(12, 12, 12, 0.96));
}

.hub-asset-card.voice .hub-card-cover {
  background:
    radial-gradient(circle at 70% 20%, rgba(180, 110, 255, 0.34), transparent 16%),
    linear-gradient(135deg, rgba(76, 45, 125, 0.86), rgba(12, 12, 12, 0.96));
}

.hub-card-cover span {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 13px;
  background: rgba(255, 255, 255, 0.12);
}

.hub-card-cover b {
  position: absolute;
  top: 10px;
  left: 10px;
  padding: 5px 8px;
  border-radius: 7px;
  background: rgba(0, 0, 0, 0.42);
  color: #fff;
  font-size: 12px;
}

.hub-card-body {
  padding: 12px 12px 14px;
}

.hub-card-body h3 {
  margin: 0 0 7px;
  font-size: 16px;
}

.hub-card-body p {
  display: -webkit-box;
  min-height: 42px;
  margin: 0 0 8px;
  overflow: hidden;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.55;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.hub-card-body small {
  display: block;
  overflow: hidden;
  margin-bottom: 10px;
  color: #ff8a00;
  font-size: 12px;
  font-weight: 850;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.hub-variants {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-height: 24px;
  margin-bottom: 10px;
}

.hub-variants em {
  padding: 4px 7px;
  border-radius: 999px;
  background: rgba(255, 139, 15, 0.12);
  color: #ff9a23;
  font-size: 12px;
  font-style: normal;
}

.hub-card-actions {
  display: grid;
  grid-template-columns: minmax(64px, 0.9fr) minmax(86px, 1.15fr) 34px;
  gap: 8px;
}

.hub-card-actions button {
  height: 32px;
  min-width: 0;
  padding: 0 8px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.09);
  color: var(--text);
  font-size: 13px;
  font-weight: 850;
  line-height: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.hub-card-actions .hub-add-project {
  background: rgba(0, 190, 96, 0.18);
  color: #27d781;
  font-size: 12px;
  font-weight: 950;
}

.hub-card-actions .hub-delete-card {
  color: #ff7474;
  font-size: 0;
}

.hub-card-actions .hub-delete-card::before {
  content: "🗑";
  font-size: 12px;
}

.material-hub-editor {
  position: sticky;
  top: 18px;
  padding: 18px;
}

.material-hub-editor.idle > :not(.hub-editor-idle) {
  display: none !important;
}

.hub-editor-idle {
  display: none;
  min-height: 280px;
  place-items: center;
  align-content: center;
  gap: 10px;
  padding: 28px;
  border: 1px dashed rgba(255, 139, 15, 0.45);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.035);
  text-align: center;
}

.material-hub-editor.idle .hub-editor-idle {
  display: grid;
}

.hub-editor-idle strong {
  color: #fff;
  font-size: 21px;
  font-weight: 950;
}

.hub-editor-idle p {
  max-width: 280px;
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.7;
}

.material-hub-editor h2 {
  margin: 0 0 14px;
  font-size: 21px;
}

.hub-upload-main,
.hub-upload-audio {
  display: grid;
  place-items: center;
  width: 100%;
  margin-bottom: 12px;
  border: 1px dashed rgba(255, 139, 15, 0.65);
  border-radius: 10px;
  background: rgba(5, 5, 5, 0.55);
  background-position: center;
  background-size: cover;
  color: var(--muted);
}

.hub-voice-select {
  display: grid;
  gap: 7px;
  margin-bottom: 12px;
  color: var(--text);
  font-weight: 850;
}

.hub-voice-select[hidden] {
  display: none !important;
}

.hub-voice-select select {
  width: 100%;
  height: 40px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(5, 5, 5, 0.72);
  color: var(--text);
  outline: none;
}

.voice-actions {
  grid-template-columns: 1fr 1fr 34px;
}

.voice-binding-status {
  margin: 0 0 9px;
  padding: 7px 9px;
  border: 1px solid rgba(170, 110, 255, 0.26);
  border-radius: 7px;
  background: rgba(145, 75, 210, 0.1);
  color: #cda7ff;
  font-size: 12px;
  font-weight: 800;
}

.voice-binding-status.bound {
  border-color: rgba(24, 211, 122, 0.3);
  background: rgba(24, 211, 122, 0.1);
  color: #39dc8e;
}

.voice-preview {
  width: 100%;
  height: 34px;
  margin: 0 0 10px;
}

.voice-preview-empty {
  display: grid;
  place-items: center;
  height: 34px;
  margin: 0 0 10px;
  border: 1px dashed var(--line);
  border-radius: 7px;
  color: var(--muted);
  font-size: 12px;
}

.global-voice-select {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 12px;
}

.global-voice-select[hidden],
#assetVoiceSelectWrap[hidden] {
  display: none !important;
}

.global-voice-select select,
#assetVoiceSelect,
#generatedRoleVoiceSelect {
  width: 100%;
  height: 40px;
  padding: 0 11px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #0c0d0e;
  color: var(--text);
  outline: none;
}

.generated-role-voice-field small {
  color: var(--muted);
  font-size: 12px;
}

.generated-role-library-field {
  display: grid;
  gap: 12px;
  margin: 0 0 16px;
  padding: 14px;
  border: 1px solid rgba(255, 139, 15, 0.22);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.36);
}

.generated-role-library-field .field {
  margin: 0;
}

#generatedRoleLibrarySelect,
#generatedRoleVariantSelect {
  width: 100%;
  height: 40px;
  padding: 0 11px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #0c0d0e;
  color: var(--text);
  outline: none;
}

.generated-role-resource-preview {
  display: grid;
  gap: 5px;
  min-height: 82px;
  padding: 12px;
  border: 1px dashed rgba(255, 139, 15, 0.42);
  border-radius: 9px;
  background: rgba(16, 17, 18, 0.72);
  background-position: center;
  background-size: cover;
  color: rgba(255, 255, 255, 0.72);
}

.generated-role-resource-preview strong {
  color: #fff;
  font-size: 15px;
}

.generated-role-resource-preview small,
.generated-role-resource-preview em {
  font-style: normal;
  font-size: 12px;
}

.generated-role-resource-preview {
  min-height: 0;
  aspect-ratio: 3 / 1;
  background-color: #b9b1b2;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  color: #665b61;
}

.generated-role-resource-preview strong {
  color: #ffffff;
  text-shadow: 0 1px 2px rgba(70, 60, 64, 0.28);
}

.generated-role-resource-preview small,
.generated-role-resource-preview em {
  color: #6f6268;
  font-weight: 800;
}

#roleFields .upload-box {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}

#roleFields .field:first-child .upload-box {
  min-height: 0;
  aspect-ratio: 3 / 1;
  background-color: #b9b1b2;
}

/* Employee account settings */
.employee-settings-view {
  max-width: 1120px;
  padding: 18px 6px 50px;
}

.employee-settings-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 22px;
}

.employee-settings-head h1 {
  margin: 0 0 7px;
  font-size: 27px;
}

.employee-settings-head p {
  margin: 0;
  color: var(--muted);
}

.employee-security-badge {
  padding: 8px 12px;
  border: 1px solid rgba(255, 139, 15, 0.3);
  border-radius: 8px;
  background: rgba(255, 139, 15, 0.1);
  color: #ff9b2f;
  font-size: 12px;
  font-weight: 850;
}

.employee-settings-column {
  display: grid;
  gap: 16px;
  width: min(760px, 100%);
}

.employee-setting-card {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #191a1a;
}

.employee-setting-card > header {
  display: flex;
  align-items: center;
  gap: 9px;
  height: 56px;
  padding: 0 20px;
  border-bottom: 1px solid var(--line);
  color: #fff;
}

.employee-setting-card > header span {
  color: var(--orange);
  font-size: 18px;
}

.employee-profile-row {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 20px;
}

.employee-avatar {
  display: grid;
  place-items: center;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: linear-gradient(135deg, #ff8a00, #ff6500);
  color: #fff;
  font-size: 24px;
  font-weight: 950;
}

.employee-profile-row h2 {
  margin: 0 0 5px;
  font-size: 19px;
}

.employee-profile-row p,
.employee-profile-row small,
.employee-setting-row p {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.6;
}

.employee-profile-row button,
.employee-setting-row button {
  height: 36px;
  padding: 0 14px;
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.1);
  color: var(--text);
  font-weight: 850;
}

.employee-setting-row,
.employee-about-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  min-height: 62px;
  padding: 12px 20px;
  border-bottom: 1px solid var(--line);
}

.employee-setting-row:last-child,
.employee-about-row:last-child {
  border-bottom: 0;
}

.employee-setting-row strong,
.employee-about-row strong {
  color: #f2f2f2;
  font-size: 13px;
}

.employee-about-row span {
  color: var(--muted);
  font-size: 13px;
}

.status-ok {
  padding: 5px 9px;
  border-radius: 999px;
  background: rgba(22, 199, 112, 0.13);
  color: #27d781;
  font-size: 12px;
  font-weight: 850;
}

.employee-setting-row .danger-soft {
  background: rgba(255, 74, 74, 0.14);
  color: #ff7474;
}

.employee-points-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 20px;
}

.employee-points-summary > div:first-child {
  display: grid;
  gap: 3px;
}

.employee-points-summary span,
.employee-points-summary small {
  color: var(--muted);
  font-size: 12px;
}

.employee-points-summary strong {
  color: var(--orange);
  font-size: 30px;
  line-height: 1.1;
}

.employee-points-actions {
  display: flex;
  gap: 9px;
}

.employee-points-actions button {
  height: 38px;
  padding: 0 15px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.09);
  color: var(--text);
  font-weight: 850;
}

.employee-points-actions .points-recharge-primary {
  background: linear-gradient(135deg, #ff8b15, #ff6500);
  color: #111;
}

.employee-logout {
  height: 48px;
  border: 1px solid rgba(255, 75, 75, 0.45);
  border-radius: 9px;
  background: rgba(130, 23, 23, 0.18);
  color: #ff6868;
  font-weight: 900;
}

.employee-profile-modal {
  position: relative;
  width: min(460px, calc(100vw - 30px));
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #1b1c1c;
}

.employee-profile-modal h2 {
  margin: 0 0 20px;
}

.employee-profile-modal label {
  display: grid;
  gap: 7px;
  margin-bottom: 14px;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}

.employee-profile-modal input {
  width: 100%;
  height: 42px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #0d0e0f;
  color: var(--text);
}

.points-modal {
  width: min(520px, calc(100vw - 30px));
}

.points-modal-note {
  margin: -10px 0 18px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.6;
}

.points-package-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

.points-package-grid button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 64px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.045);
  color: var(--text);
}

.points-package-grid button.active {
  border-color: #ff8b15;
  background: rgba(255, 139, 21, 0.12);
}

.points-package-grid button span {
  color: #ff9a23;
  font-weight: 900;
}

.points-package-grid button strong {
  display: grid;
  gap: 4px;
  text-align: left;
}

.points-package-grid button strong small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 650;
}

.points-channel-list {
  display: grid;
  gap: 8px;
  margin-top: 16px;
}

.points-channel-list label {
  display: flex;
  grid-template-columns: none;
  align-items: center;
  gap: 10px;
  min-height: 42px;
  margin: 0;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.035);
}

.points-channel-list input {
  width: 16px;
  height: 16px;
}

.points-record-list {
  display: grid;
  gap: 8px;
  max-height: 420px;
  overflow: auto;
}

.points-record-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.035);
}

.points-record-item div {
  display: grid;
  gap: 4px;
}

.points-record-item span,
.points-empty-record {
  color: var(--muted);
  font-size: 12px;
}

.points-order-title {
  margin: 22px 0 10px;
  font-size: 15px;
}

.points-order-list {
  display: grid;
  gap: 8px;
  max-height: 250px;
  overflow: auto;
}

.points-order-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.035);
}

.points-order-item > div {
  display: grid;
  gap: 4px;
}

.points-order-item span,
.points-order-item em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
}

.points-order-item em.paid {
  color: var(--green);
}

.points-order-item em.pending {
  color: #f2c86e;
}

.points-record-item b {
  color: #ff7373;
}

.points-record-item b.income {
  color: #28d985;
}

.points-empty-record {
  display: grid;
  place-items: center;
  min-height: 160px;
  border: 1px dashed var(--line);
  border-radius: 8px;
}

.employee-login-screen {
  position: fixed;
  z-index: 1200;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 20px;
  background:
    radial-gradient(circle at 70% 30%, rgba(255, 126, 0, 0.08), transparent 28%),
    #090a0b;
}

.employee-login-screen[hidden] {
  display: none;
}

body.employee-logged-out {
  overflow: hidden;
}

body.employee-session-restoring {
  overflow: auto;
}

body.employee-session-restoring .employee-login-screen {
  display: none !important;
}

body.employee-logged-out .shell {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
}

body.route-restoring:not(.employee-logged-out) .shell {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
}

body.route-restoring:not(.employee-logged-out)::after {
  content: "正在恢复上次工作界面...";
  position: fixed;
  left: 50%;
  top: 50%;
  z-index: 9999;
  transform: translate(-50%, -50%);
  padding: 14px 22px;
  border: 1px solid rgba(255, 255, 255, 0.52);
  border-radius: 999px;
  background: rgba(255, 238, 246, 0.78);
  color: #2b1b23;
  font-weight: 900;
  box-shadow: 0 20px 56px rgba(102, 34, 62, 0.18);
  backdrop-filter: blur(18px);
}

body.employee-logged-out .library-drawer,
body.employee-logged-out .global-asset-drawer,
body.employee-logged-out .float-help,
body.employee-logged-out .modal-backdrop:not(#employeeLoginScreen) {
  display: none !important;
}

body.employee-logged-out .employee-login-screen {
  position: fixed;
  z-index: 9000;
}

body.employee-logged-out:not(.employee-login-ready)::after {
  content: "正在加载登录界面...";
  position: fixed;
  z-index: 9001;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(7, 9, 12, 0.7);
  color: #f4f4f1;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 0.08em;
}

body.employee-auth-checking .employee-auth-tabs,
body.employee-auth-checking .employee-auth-form {
  display: none;
}

.employee-auth-checking-panel {
  display: none;
}

body.employee-auth-checking .employee-auth-checking-panel {
  display: grid;
  gap: 8px;
}

body:not(.employee-auth-checking) .employee-auth-checking-panel {
  display: none;
}

.employee-login-panel {
  width: min(430px, 100%);
  padding: 34px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #171818;
  box-shadow: 0 28px 80px rgba(0, 0, 0, 0.38);
}

.employee-login-brand {
  display: flex;
  align-items: center;
  gap: 11px;
  margin-bottom: 30px;
  color: #eee096;
}

.employee-login-brand span {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border: 2px solid #e8d989;
  border-radius: 10px;
  font-size: 19px;
  font-weight: 950;
}

.employee-login-panel h1 {
  margin: 0 0 7px;
  font-size: 28px;
}

.employee-login-panel > p,
.employee-login-panel > small {
  color: var(--muted);
}

.employee-login-panel label {
  display: grid;
  gap: 8px;
  margin-top: 18px;
  color: var(--text);
  font-size: 13px;
  font-weight: 850;
}

.employee-login-panel input {
  height: 46px;
  padding: 0 13px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #0c0d0e;
  color: var(--text);
}

.employee-login-panel button {
  width: 100%;
  height: 46px;
  margin: 22px 0 14px;
  border-radius: 8px;
  background: linear-gradient(135deg, #ff8b15, #ff6500);
  color: #111;
  font-weight: 950;
}

@media (max-width: 760px) {
  .employee-profile-row {
    grid-template-columns: 56px 1fr;
  }

  .employee-profile-row button {
    grid-column: 1 / -1;
  }

  .employee-settings-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .employee-points-summary {
    align-items: stretch;
    flex-direction: column;
  }

  .employee-points-actions button {
    flex: 1;
  }
}

/* 2026 workbench redesign */
:root {
  --bg: #0b0d0f;
  --sidebar: #111417;
  --panel: #15191c;
  --panel-2: #191e22;
  --line: #2a3035;
  --text: #f2f4f5;
  --muted: #8e989f;
  --orange: #ff8a1c;
  --orange-2: rgba(255, 138, 28, 0.12);
  --green: #22c983;
  --blue: #55a7ff;
  --danger: #ff6868;
}

* {
  scrollbar-width: thin;
  scrollbar-color: #3a4248 transparent;
}

body {
  background: #0b0d0f;
  letter-spacing: 0;
}

.shell {
  grid-template-columns: 190px minmax(0, 1fr);
}

.sidebar {
  z-index: 30;
  border-right-color: #24292d;
  background: #111417;
}

.logo {
  height: 64px;
  padding: 0 15px;
}

.logo-mark {
  width: 32px;
  height: 32px;
  border-width: 1px;
  border-radius: 8px;
  font-size: 17px;
}

.logo strong {
  color: #f2dc82;
  font-size: 15px;
}

.nav {
  gap: 4px;
  padding: 14px 10px;
}

.nav button {
  position: relative;
  height: 42px;
  padding: 0 11px;
  border: 1px solid transparent;
  border-radius: 7px;
  color: #b8c0c5;
  font-size: 13px;
  font-weight: 750;
}

.nav button:hover {
  background: rgba(255, 255, 255, 0.045);
  color: #fff;
}

.nav button.active {
  border-color: rgba(255, 138, 28, 0.2);
  background: rgba(255, 138, 28, 0.11);
  color: #ffac57;
}

.nav button.active::before {
  position: absolute;
  left: -10px;
  width: 3px;
  height: 22px;
  border-radius: 0 4px 4px 0;
  background: #ff8a1c;
  content: "";
}

.nav span {
  width: 18px;
  color: currentColor;
  opacity: 0.82;
}

.main {
  width: 100%;
  max-width: 1540px;
  min-height: 100vh;
  margin: 0 auto;
  padding: 26px clamp(22px, 3vw, 44px) 64px;
}

.topbar {
  margin-bottom: 22px;
}

.topbar h1,
.material-hub-head h1,
.employee-settings-head h1 {
  margin: 0 0 6px;
  color: #f7f8f8;
  font-size: 25px;
  font-weight: 850;
}

.topbar p,
.material-hub-head p,
.employee-settings-head p {
  color: #889198;
  font-size: 12px;
}

.userbar {
  display: flex;
  align-items: center;
  gap: 11px;
  color: #dce0e2;
  font-size: 13px;
}

.workspace-tag,
.employee-security-badge {
  padding: 5px 9px;
  border: 1px solid rgba(34, 201, 131, 0.25);
  border-radius: 6px;
  background: rgba(34, 201, 131, 0.08);
  color: #5edba5;
  font-size: 11px;
}

.stats {
  gap: 12px;
  margin-bottom: 20px;
}

.stats article {
  min-height: 112px;
  padding: 16px;
  border-color: #293036;
  border-radius: 8px;
  background: #15191c;
  box-shadow: none;
}

.stats article:hover {
  border-color: #3a4349;
  background: #181d20;
}

.stats strong {
  font-size: 27px;
}

.stat-icon {
  width: 34px;
  height: 34px;
  border-radius: 7px;
}

.project-area {
  grid-template-columns: minmax(280px, 0.72fr) minmax(360px, 1.28fr);
  gap: 14px;
}

.new-project,
.project-card {
  min-height: 206px;
  border-radius: 8px;
  background: #15191c;
  box-shadow: none;
}

.new-project {
  border-color: rgba(255, 138, 28, 0.34);
}

.new-project:hover {
  border-color: #ff8a1c;
  background: #181b1e;
}

.new-project > button {
  border-radius: 8px;
}

.project-card {
  border: 1px solid #293036;
}

.project-card:hover {
  border-color: #3b454c;
  transform: translateY(-1px);
}

.project-card h2 {
  font-size: 21px;
}

.sidebar-points-wallet {
  gap: 8px;
  padding: 12px 10px;
  border-top-color: #252b2f;
  background: #111417;
}

.sidebar-points-wallet > strong {
  font-size: 21px;
}

.sidebar-points-wallet > button {
  height: 34px;
  border-radius: 6px;
}

.sidebar-claim {
  background: #ff8a1c;
  color: #17191a;
}

.sidebar-recharge {
  border-color: #465058;
  background: #181c1f;
  color: #e9ecee;
}

.project-breadcrumb,
.episode-breadcrumb {
  min-height: 48px;
  margin: -26px calc(clamp(22px, 3vw, 44px) * -1) 0;
  padding: 0 clamp(22px, 3vw, 44px);
  border-bottom: 1px solid #242a2e;
  background: rgba(15, 18, 20, 0.94);
}

.project-tabs {
  gap: 7px;
  margin: 18px 0;
  padding-bottom: 14px;
  border-bottom: 1px solid #242a2e;
}

.project-tabs button,
.material-hub-tabs button {
  height: 38px;
  padding: 0 14px;
  border-color: #30373c;
  border-radius: 6px;
  background: #171b1e;
  color: #aeb6bb;
  font-size: 13px;
}

.project-tabs button.active,
.material-hub-tabs button.active {
  border-color: rgba(255, 138, 28, 0.28);
  background: rgba(255, 138, 28, 0.13);
  color: #ffad5c;
}

.episode-progress {
  margin: 24px auto 28px;
}

.episode-progress button span {
  box-shadow: none;
}

.episode-progress button.complete span {
  background: #1eba78;
}

.episode-progress button.active span {
  background: #ff8613;
}

.step-card,
.asset-section,
.video-toolbar,
.batch-workbench,
.smart-workbench,
.material-hub-main,
.material-hub-editor,
.employee-setting-card {
  border-color: #293036;
  border-radius: 8px;
  background: #15191c;
  box-shadow: none;
}

.step-card:hover,
.asset-section:hover {
  border-color: #353e44;
}

input,
textarea,
select {
  border-color: #30373c;
  border-radius: 6px;
  background: #0f1214;
}

input:focus,
textarea:focus,
select:focus {
  border-color: rgba(255, 138, 28, 0.7);
  box-shadow: 0 0 0 3px rgba(255, 138, 28, 0.08);
}

.primary,
#hubSaveAsset,
.material-hub-toolbar button,
.global-direct-add {
  border-radius: 6px;
  background: #ff8a1c;
  color: #17191a;
  box-shadow: none;
}

.secondary,
.hub-card-actions button,
.asset-edit-modal button,
.employee-profile-row button,
.employee-setting-row button {
  border-radius: 6px;
}

.modal-backdrop {
  background: rgba(4, 6, 7, 0.78);
  backdrop-filter: blur(5px);
}

.modal,
.asset-edit-modal,
.employee-profile-modal,
.material-modal,
.project-modal,
.style-modal,
.tone-modal {
  border-color: #343c42;
  border-radius: 10px;
  background: #171b1e;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.5);
}

.material-hub-view {
  padding: 0 0 48px;
}

.material-hub-head {
  padding-bottom: 18px;
}

.material-hub-stats {
  grid-template-columns: repeat(4, 98px);
}

.material-hub-stats article {
  padding: 11px 12px;
  border-color: #293036;
  border-radius: 7px;
  background: #15191c;
}

.material-hub-stats strong {
  font-size: 20px;
}

.material-hub-tabs {
  margin: 17px 0;
}

.material-hub-layout {
  grid-template-columns: minmax(0, 1fr) 350px;
  gap: 14px;
}

.material-hub-main,
.material-hub-editor {
  padding: 14px;
}

.material-hub-grid {
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 11px;
}

.hub-asset-card {
  border-color: #293036;
  border-radius: 7px;
  background: #15191c;
}

.hub-asset-card:hover {
  border-color: #465159;
  box-shadow: none;
}

.hub-card-cover {
  height: 132px;
  background:
    radial-gradient(circle at 70% 24%, rgba(255, 159, 70, 0.14), transparent 18%),
    linear-gradient(145deg, #27221e, #15191c);
}

.hub-asset-card.scene .hub-card-cover {
  background:
    radial-gradient(circle at 70% 24%, rgba(85, 167, 255, 0.18), transparent 18%),
    linear-gradient(145deg, #1b2932, #14191c);
}

.hub-asset-card.prop .hub-card-cover {
  background:
    radial-gradient(circle at 70% 24%, rgba(34, 201, 131, 0.17), transparent 18%),
    linear-gradient(145deg, #183028, #14191c);
}

.hub-asset-card.voice .hub-card-cover {
  background:
    radial-gradient(circle at 70% 24%, rgba(185, 125, 255, 0.17), transparent 18%),
    linear-gradient(145deg, #292136, #14191c);
}

.hub-card-body {
  padding: 11px;
}

.hub-card-body h3 {
  font-size: 14px;
}

.hub-card-actions {
  grid-template-columns: minmax(58px, 0.8fr) minmax(92px, 1.2fr) 32px;
  gap: 6px;
}

.hub-card-actions button {
  height: 31px;
  border-radius: 6px;
  font-size: 12px;
}

.hub-card-actions .hub-add-project {
  background: rgba(34, 201, 131, 0.12);
  color: #55d99f;
}

.employee-settings-view {
  max-width: 900px;
  padding: 0 0 50px;
}

.employee-settings-column {
  width: min(720px, 100%);
  gap: 12px;
}

.employee-setting-card > header {
  height: 48px;
  padding: 0 16px;
}

.employee-profile-row,
.employee-setting-row,
.employee-about-row {
  padding-right: 16px;
  padding-left: 16px;
}

.employee-login-panel {
  border-radius: 10px;
  background: #15191c;
}

@media (max-width: 980px) {
  .shell {
    grid-template-columns: 168px minmax(0, 1fr);
  }

  .logo strong {
    font-size: 13px;
  }

  .main {
    padding-right: 20px;
    padding-left: 20px;
  }

  .material-hub-layout {
    grid-template-columns: 1fr;
  }

  .material-hub-editor {
    position: static;
  }
}

@media (max-width: 720px) {
  .shell {
    display: block;
  }

  .sidebar {
    position: sticky;
    grid-template-columns: auto 1fr;
    grid-template-rows: 56px auto;
    width: 100%;
    height: auto;
  }

  .logo {
    height: 56px;
    border-bottom: 0;
  }

  .nav {
    display: flex;
    overflow-x: auto;
    padding: 7px 10px;
    border-bottom: 1px solid #252b2f;
  }

  .nav button {
    flex: 0 0 auto;
  }

  .nav button.active::before {
    display: none;
  }

  .sidebar-points-wallet {
    grid-column: 1 / -1;
    grid-template-columns: 1fr auto auto;
    align-items: center;
  }

  .sidebar-points-wallet > strong {
    display: none;
  }

  .sidebar-points-head {
    justify-content: flex-start;
    gap: 8px;
  }

  .main {
    min-height: calc(100vh - 120px);
    padding: 20px 14px 46px;
  }

  .stats,
  .project-area {
    grid-template-columns: 1fr;
  }

  .project-breadcrumb,
  .episode-breadcrumb {
    margin: -20px -14px 0;
    padding: 0 14px;
    overflow-x: auto;
    white-space: nowrap;
  }

  .material-hub-head {
    flex-direction: column;
  }

  .material-hub-stats {
    width: 100%;
    grid-template-columns: repeat(2, 1fr);
  }

  .material-hub-tabs,
  .project-tabs {
    overflow-x: auto;
  }
}

/* Digital Future poster theme */
:root {
  --bg: #101318;
  --sidebar: rgba(20, 23, 29, 0.88);
  --panel: rgba(31, 35, 43, 0.76);
  --panel-2: rgba(42, 47, 57, 0.8);
  --line: rgba(229, 235, 244, 0.18);
  --text: #f5f7fb;
  --muted: #aab2c0;
  --orange: #edf3fb;
  --orange-2: rgba(229, 236, 247, 0.12);
  --green: #8fe2c5;
  --blue: #b9d9ff;
  --danger: #ff8e9d;
  --site-background-image: url("./assets/digital-future-poster-lite.jpg");
}

body {
  position: relative;
  background: #11141a;
  color: #f5f7fb;
}

body::before {
  position: fixed;
  z-index: -2;
  inset: 0;
  background-image: var(--site-background-image);
  background-position: center top;
  background-size: cover;
  content: "";
  opacity: 0.2;
  filter: saturate(0.62) contrast(0.92);
}

body::after {
  position: fixed;
  z-index: -1;
  inset: 0;
  background: rgba(10, 12, 17, 0.75);
  content: "";
}

.sidebar {
  border-right-color: rgba(235, 240, 248, 0.16);
  background: rgba(15, 18, 23, 0.9);
  backdrop-filter: blur(24px) saturate(0.82);
}

.logo {
  border-bottom-color: rgba(238, 243, 250, 0.14);
}

.logo-mark {
  border-color: rgba(248, 250, 255, 0.82);
  color: #fff;
  box-shadow: 0 0 20px rgba(222, 234, 250, 0.18);
}

.logo strong {
  color: #f6f8fc;
  text-shadow: 0 0 18px rgba(255, 255, 255, 0.18);
}

.nav button {
  color: #aeb7c4;
}

.nav button:hover {
  border-color: rgba(231, 237, 247, 0.1);
  background: rgba(237, 242, 250, 0.07);
}

.nav button.active {
  border-color: rgba(243, 247, 253, 0.42);
  background: rgba(230, 236, 247, 0.13);
  color: #fff;
  box-shadow:
    inset 0 0 18px rgba(236, 242, 250, 0.04),
    0 0 20px rgba(218, 230, 248, 0.05);
}

.nav button.active::before {
  background: #f5f8fd;
  box-shadow: 0 0 10px rgba(238, 245, 255, 0.8);
}

.main {
  background: rgba(8, 11, 15, 0.26);
  backdrop-filter: blur(3px);
}

.topbar h1,
.material-hub-head h1,
.employee-settings-head h1 {
  color: #fff;
  font-weight: 720;
  text-shadow: 0 0 22px rgba(255, 255, 255, 0.16);
}

.workspace-tag,
.employee-security-badge {
  border-color: rgba(215, 232, 247, 0.32);
  background: rgba(218, 233, 247, 0.1);
  color: #dcecff;
}

.stats article,
.new-project,
.project-card,
.step-card,
.asset-section,
.video-toolbar,
.batch-workbench,
.smart-workbench,
.material-hub-main,
.material-hub-editor,
.employee-setting-card {
  border-color: rgba(229, 235, 244, 0.18);
  background: rgba(25, 29, 36, 0.73);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 18px 50px rgba(3, 6, 10, 0.15);
  backdrop-filter: blur(20px) saturate(0.75);
}

.stats article:hover,
.project-card:hover,
.step-card:hover,
.asset-section:hover {
  border-color: rgba(241, 245, 251, 0.34);
  background: rgba(38, 43, 52, 0.78);
}

.stat-icon {
  border: 1px solid rgba(237, 243, 251, 0.15);
  background: rgba(231, 238, 248, 0.1) !important;
  color: #eaf2fc !important;
}

.stats strong,
.material-hub-stats strong,
.sidebar-points-wallet > strong {
  color: #fff;
  text-shadow: 0 0 18px rgba(225, 236, 250, 0.24);
}

.new-project {
  border-color: rgba(239, 243, 249, 0.25);
  background: rgba(25, 29, 36, 0.64);
}

.new-project:hover {
  border-color: rgba(255, 255, 255, 0.62);
  background: rgba(45, 50, 59, 0.72);
}

.new-project > button {
  border-color: rgba(247, 249, 253, 0.42);
  background: rgba(239, 244, 251, 0.11);
  color: #fff;
  box-shadow: 0 0 28px rgba(231, 239, 251, 0.1);
}

.film-icon,
.project-head b {
  color: #e8f1fc;
}

.project-breadcrumb,
.episode-breadcrumb {
  border-bottom-color: rgba(232, 238, 247, 0.13);
  background: rgba(17, 20, 26, 0.74);
  backdrop-filter: blur(18px);
}

.project-tabs,
.material-hub-tabs {
  border-color: rgba(230, 236, 246, 0.12);
}

.project-tabs button,
.material-hub-tabs button {
  border-color: rgba(229, 235, 244, 0.16);
  background: rgba(35, 39, 47, 0.7);
  color: #aeb7c4;
}

.project-tabs button:hover,
.material-hub-tabs button:hover {
  border-color: rgba(240, 245, 252, 0.3);
  color: #fff;
}

.project-tabs button.active,
.material-hub-tabs button.active {
  border-color: rgba(248, 250, 254, 0.54);
  background: rgba(229, 236, 247, 0.14);
  color: #fff;
  box-shadow: 0 0 18px rgba(230, 239, 252, 0.06);
}

.episode-progress button.active span {
  border-color: rgba(255, 255, 255, 0.65);
  background: #eaf1fa;
  color: #15191f;
  box-shadow: 0 0 22px rgba(232, 241, 253, 0.3);
}

.episode-progress button.complete span {
  background: #a8dfce;
  color: #101519;
}

.episode-progress i {
  background: rgba(226, 234, 245, 0.2);
}

input,
textarea,
select {
  border-color: rgba(230, 236, 246, 0.18);
  background: rgba(11, 14, 19, 0.7);
  color: #f4f7fb;
}

input::placeholder,
textarea::placeholder {
  color: #717b89;
}

input:focus,
textarea:focus,
select:focus {
  border-color: rgba(236, 243, 252, 0.58);
  box-shadow: 0 0 0 3px rgba(223, 235, 250, 0.08);
}

.primary,
#hubSaveAsset,
.material-hub-toolbar button,
.global-direct-add,
.employee-login-panel button,
.sidebar-claim {
  border: 1px solid rgba(255, 255, 255, 0.46);
  background: #edf2f8;
  color: #161a20;
  box-shadow: 0 0 24px rgba(225, 236, 249, 0.1);
}

.primary:hover,
#hubSaveAsset:hover,
.material-hub-toolbar button:hover,
.global-direct-add:hover {
  background: #fff;
}

.secondary,
.hub-card-actions button,
.employee-profile-row button,
.employee-setting-row button {
  border: 1px solid rgba(230, 236, 246, 0.14);
  background: rgba(235, 240, 248, 0.08);
  color: #e9edf3;
}

.sidebar-points-wallet {
  border-top-color: rgba(231, 237, 246, 0.13);
  background: rgba(12, 15, 20, 0.48);
  text-align: center;
}

.sidebar-points-head {
  position: relative;
  justify-content: center;
  width: 100%;
}

.sidebar-points-head button {
  position: absolute;
  right: 0;
}

.sidebar-points-wallet > strong {
  width: 100%;
  text-align: center;
}

.sidebar-recharge {
  border-color: rgba(238, 243, 251, 0.3);
  background: rgba(231, 238, 248, 0.06);
  color: #f0f4fa;
}

.sidebar-claim:disabled {
  background: rgba(233, 239, 248, 0.07);
  color: #828b98;
}

.modal-backdrop {
  background: rgba(8, 10, 15, 0.7);
  backdrop-filter: blur(14px) saturate(0.65);
}

.modal,
.asset-edit-modal,
.employee-profile-modal,
.material-modal,
.project-modal,
.style-modal,
.tone-modal {
  border-color: rgba(237, 242, 250, 0.24);
  background: rgba(27, 31, 38, 0.92);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 30px 100px rgba(0, 0, 0, 0.48);
  backdrop-filter: blur(26px);
}

.material-hub-stats article {
  border-color: rgba(230, 236, 246, 0.18);
  background: rgba(32, 36, 44, 0.7);
}

.hub-asset-card {
  border-color: rgba(228, 235, 245, 0.15);
  background: rgba(25, 29, 36, 0.82);
}

.hub-asset-card:hover {
  border-color: rgba(245, 248, 253, 0.38);
}

.hub-card-cover,
.hub-asset-card.scene .hub-card-cover,
.hub-asset-card.prop .hub-card-cover,
.hub-asset-card.voice .hub-card-cover {
  background:
    radial-gradient(circle at 70% 24%, rgba(242, 246, 252, 0.18), transparent 18%),
    linear-gradient(145deg, rgba(88, 96, 109, 0.62), rgba(24, 28, 35, 0.92));
}

.hub-card-cover span {
  border: 1px solid rgba(242, 246, 252, 0.15);
  background: rgba(240, 245, 252, 0.1);
}

.hub-card-actions .hub-add-project {
  background: rgba(159, 221, 203, 0.12);
  color: #abe4d1;
}

.hub-card-body small,
.library-asset-body small,
.material-info small,
.role-card-tone,
.asset-extra {
  color: #c7d7ea !important;
}

.hub-variants em,
.asset-card-variants b {
  background: rgba(225, 233, 245, 0.1);
  color: #dbe5f3;
}

.employee-avatar {
  border: 1px solid rgba(255, 255, 255, 0.46);
  background: linear-gradient(145deg, #f6f8fb, #9da6b4);
  color: #1b2027;
  box-shadow: 0 0 30px rgba(229, 238, 250, 0.16);
}

.status-ok {
  background: rgba(143, 226, 197, 0.1);
  color: #9de5cc;
}

.employee-setting-row .danger-soft {
  background: rgba(255, 142, 157, 0.1);
  color: #ffabb7;
}

.employee-logout {
  border-color: rgba(255, 152, 166, 0.36);
  background: rgba(113, 37, 48, 0.16);
  color: #ffabb6;
}

.employee-login-screen {
  background:
    linear-gradient(rgba(11, 14, 19, 0.55), rgba(11, 14, 19, 0.82)),
    var(--site-background-image) center / cover;
}

.admin-background-tools {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
}

.admin-background-tools button {
  height: 38px;
  padding: 0 14px;
  border: 1px solid rgba(235, 241, 250, 0.2);
  border-radius: 6px;
  background: rgba(235, 241, 250, 0.08);
  color: #edf2f8;
  font-weight: 800;
}

.admin-background-preview {
  display: grid;
  align-content: end;
  min-height: 220px;
  overflow: hidden;
  background-position: center;
  background-size: cover;
  box-shadow: inset 0 -90px 70px rgba(8, 10, 14, 0.62);
}

.admin-background-preview strong {
  color: #fff;
  font-size: 22px;
  text-shadow: 0 2px 18px rgba(0, 0, 0, 0.8);
}

.admin-background-preview small {
  color: #d6deea;
}

.employee-login-panel {
  border-color: rgba(240, 244, 251, 0.28);
  background: rgba(24, 28, 35, 0.76);
  backdrop-filter: blur(28px);
}

.employee-auth-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  margin: 24px 0 20px;
  padding: 4px;
  border: 1px solid rgba(238, 243, 250, 0.12);
  background: rgba(5, 8, 12, 0.36);
}

.employee-auth-tabs button {
  height: 40px;
  border: 0;
  border-radius: 3px;
  background: transparent;
  color: #8792a2;
  font-weight: 800;
}

.employee-auth-tabs button.active {
  background: rgba(239, 244, 250, 0.12);
  color: #fff;
}

.employee-auth-form {
  display: none;
}

.employee-auth-form.active {
  display: block;
}

.employee-auth-form h1 {
  margin-top: 0;
}

.employee-auth-form > button {
  width: 100%;
}

.employee-auth-form > small {
  display: block;
  margin-top: 14px;
  text-align: center;
}

.employee-login-brand {
  color: #fff;
}

.employee-login-brand span {
  border-color: rgba(255, 255, 255, 0.78);
}

.points-package-grid button.active {
  border-color: rgba(250, 252, 255, 0.68);
  background: rgba(229, 237, 248, 0.14);
}

.points-package-grid button span {
  color: #eef4fc;
}

.floating-ai {
  border: 1px solid rgba(255, 255, 255, 0.42);
  background: rgba(222, 232, 246, 0.16);
  color: #fff;
  box-shadow: 0 0 26px rgba(222, 235, 252, 0.14);
  backdrop-filter: blur(14px);
}

@media (max-width: 720px) {
  body::before {
    background-position: 57% top;
    opacity: 0.12;
  }

  .sidebar {
    background: rgba(15, 18, 23, 0.96);
  }
}

.hub-upload-main {
  min-height: 150px;
}

.hub-upload-audio {
  min-height: 44px;
  grid-template-columns: auto auto 1fr;
  gap: 8px;
  padding: 0 12px;
}

.material-hub-editor input,
.material-hub-editor textarea {
  margin-bottom: 10px;
  padding: 11px 12px;
}

.material-hub-editor textarea {
  min-height: 92px;
  resize: vertical;
}

.hub-variant-panel {
  margin-top: 4px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}

.hub-variant-panel > div:first-child {
  display: grid;
  gap: 3px;
  margin-bottom: 10px;
}

.hub-variant-panel span,
.hub-empty-variants {
  color: var(--muted);
  font-size: 12px;
}

.hub-variant-list {
  display: grid;
  gap: 8px;
  margin-bottom: 10px;
}

.hub-variant-item {
  display: grid;
  grid-template-columns: 52px 1fr 52px;
  gap: 10px;
  align-items: center;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.04);
}

.hub-variant-item div {
  display: grid;
  place-items: center;
  width: 52px;
  height: 52px;
  border-radius: 8px;
  background: rgba(255, 139, 15, 0.13);
  background-position: center;
  background-size: cover;
}

.hub-variant-item strong,
.hub-variant-item p {
  grid-column: 2;
  margin: 0;
}

.hub-variant-item p {
  color: var(--muted);
  font-size: 12px;
}

.hub-variant-item button {
  grid-column: 3;
  grid-row: 1 / span 2;
  height: 30px;
  border-radius: 7px;
  background: rgba(255, 80, 80, 0.14);
  color: #ff7474;
}

.hub-variant-form {
  display: grid;
  gap: 8px;
}

.hub-variant-form button,
#hubClearEditor {
  height: 36px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.09);
  color: var(--text);
  font-weight: 850;
}

#hubAddVariant {
  background: rgba(145, 75, 210, 0.28);
  color: #d9a6ff;
}

.hub-editor-actions {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 10px;
  margin-top: 14px;
}

@media (max-width: 1180px) {
  .material-hub-layout {
    grid-template-columns: 1fr;
  }

  .material-hub-editor {
    position: static;
  }
}

/* Unified dark console theme: align employee UI with admin operation feel. */
:root {
  color-scheme: dark;
  --bg: #080b10;
  --sidebar: rgba(10, 13, 18, 0.92);
  --card: rgba(18, 23, 31, 0.88);
  --card-2: rgba(25, 31, 41, 0.92);
  --line: rgba(230, 238, 250, 0.13);
  --text: #f3f6fb;
  --muted: #98a4b3;
  --orange: #e6b56c;
  --orange-2: rgba(230, 181, 108, 0.14);
  --green: #38d996;
  --cyan: #61c6ff;
  --purple: #b28cff;
  --danger: #ff6b7a;
  --shadow: 0 24px 70px rgba(0, 0, 0, 0.46);
  --console-radius: 16px;
  --console-radius-lg: 22px;
}

html,
body {
  background: #080b10 !important;
  color: var(--text) !important;
  font-family: "Microsoft YaHei", "PingFang SC", "Segoe UI", Arial, sans-serif !important;
}

body {
  background:
    linear-gradient(90deg, rgba(7, 9, 13, 0.98), rgba(12, 15, 21, 0.88)),
    var(--site-background-image),
    url("./assets/digital-future-poster-lite.jpg") center / cover fixed !important;
  background-blend-mode: normal, multiply, normal !important;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  background:
    radial-gradient(circle at 76% 18%, rgba(111, 139, 178, 0.16), transparent 31%),
    radial-gradient(circle at 12% 82%, rgba(230, 181, 108, 0.12), transparent 28%),
    rgba(6, 8, 12, 0.44) !important;
  opacity: 1 !important;
}

body::after {
  display: none !important;
}

.shell {
  display: grid !important;
  grid-template-columns: 232px minmax(0, 1fr) !important;
  gap: 18px !important;
  min-height: 100vh !important;
  padding: 18px !important;
}

.sidebar {
  position: sticky !important;
  top: 18px !important;
  height: calc(100vh - 36px) !important;
  border: 1px solid var(--line) !important;
  border-radius: var(--console-radius-lg) !important;
  background: rgba(10, 13, 18, 0.86) !important;
  box-shadow: var(--shadow) !important;
  backdrop-filter: blur(24px) !important;
  overflow: hidden !important;
}

.logo {
  height: 82px !important;
  border-bottom: 1px solid var(--line) !important;
}

.logo-mark,
.employee-login-brand span {
  border: 1px solid rgba(238, 243, 250, 0.22) !important;
  border-radius: 12px !important;
  background: rgba(238, 243, 250, 0.08) !important;
  color: #fff !important;
  box-shadow: none !important;
}

.logo strong,
.employee-login-brand {
  color: #f4f7fb !important;
  letter-spacing: 0 !important;
}

.nav {
  gap: 8px !important;
  padding: 16px 12px !important;
}

.nav button {
  height: 46px !important;
  border: 1px solid transparent !important;
  border-radius: 10px !important;
  background: transparent !important;
  color: #99a5b5 !important;
  font-weight: 800 !important;
}

.nav button:hover,
.nav button.active {
  border-color: rgba(238, 243, 250, 0.14) !important;
  background: rgba(238, 243, 250, 0.08) !important;
  color: #fff !important;
  transform: translateX(2px) !important;
  box-shadow: none !important;
}

.main {
  min-width: 0 !important;
  padding: 10px 6px 56px !important;
}

.topbar {
  min-height: 86px !important;
  margin: 0 0 18px !important;
  padding: 0 4px !important;
  border: 0 !important;
}

h1,
.topbar h1,
.screen-head h1 {
  color: #fff !important;
  font-size: clamp(26px, 2.6vw, 38px) !important;
  font-weight: 900 !important;
  letter-spacing: -0.04em !important;
  line-height: 1.1 !important;
}

h2,
.project-card h2 {
  color: #f4f7fb !important;
  letter-spacing: -0.03em !important;
}

.topbar p,
.section-head p,
.main p,
.stats small,
.stats em,
.project-card p,
.project-meta,
.step-top em,
.asset-list small,
.community-card-desc {
  color: var(--muted) !important;
}

.workspace-tag,
.project-meta span,
.shot-asset-tags button,
.model-pill,
.status-chip,
.queue span {
  border: 1px solid rgba(238, 243, 250, 0.14) !important;
  border-radius: 999px !important;
  background: rgba(238, 243, 250, 0.07) !important;
  color: #d8e0ea !important;
}

.stats {
  gap: 14px !important;
}

.stats article,
.project-card,
.new-project,
.workflow-screen,
.asset-section,
.material-card,
.library-asset-card,
.shot-card,
.smart-preview-panel,
.smart-detail-panel,
.employee-setting-card,
.points-wallet-card,
.points-package-card,
.episode-card,
.library-card,
.video-history-item,
.points-record-item {
  border: 1px solid var(--line) !important;
  border-radius: var(--console-radius) !important;
  background: linear-gradient(145deg, rgba(20, 25, 33, 0.92), rgba(12, 16, 23, 0.86)) !important;
  color: var(--text) !important;
  box-shadow: var(--shadow) !important;
  backdrop-filter: blur(18px) !important;
}

.stats article:nth-child(2),
.stats article:nth-child(3),
.project-card.active-project,
.new-project,
.smart-preview-panel,
.smart-detail-panel,
.employee-setting-card:nth-child(even) {
  background: linear-gradient(145deg, rgba(22, 28, 38, 0.94), rgba(13, 17, 24, 0.88)) !important;
}

.stats article:hover,
.project-card:hover,
.new-project:hover,
.material-card:hover,
.library-asset-card:hover,
.shot-card:hover,
.points-package-card:hover {
  transform: translateY(-3px) !important;
  border-color: rgba(238, 243, 250, 0.24) !important;
  box-shadow: 0 30px 84px rgba(0, 0, 0, 0.56) !important;
}

.stats strong,
.project-card h2,
.sidebar-points-wallet > strong,
.sidebar-community-card strong {
  color: #fff !important;
}

.stats strong {
  font-size: 30px !important;
  font-weight: 900 !important;
  letter-spacing: -0.03em !important;
}

.stat-icon,
.new-project button,
.episode-play,
.asset-thumb,
.folder-icon {
  border: 1px solid rgba(238, 243, 250, 0.16) !important;
  border-radius: 12px !important;
  background: rgba(238, 243, 250, 0.08) !important;
  color: #eef4fc !important;
  box-shadow: none !important;
}

.orange { color: #e6b56c !important; }
.purple { color: #b28cff !important; }
.cyan { color: #61c6ff !important; }

.project-area {
  grid-template-columns: minmax(300px, 0.8fr) minmax(420px, 1.42fr) !important;
  gap: 16px !important;
}

.project-card,
.new-project {
  min-height: 214px !important;
  padding: 22px !important;
}

.new-project {
  border-style: dashed !important;
  border-color: rgba(238, 243, 250, 0.22) !important;
}

.project-card h2 {
  font-size: 28px !important;
  font-weight: 900 !important;
}

.primary,
.admin-primary,
.add-episode,
#generateVideos,
.employee-login-panel button,
.points-recharge-primary,
.sidebar-claim {
  border: 1px solid rgba(238, 243, 250, 0.2) !important;
  border-radius: 10px !important;
  background: #eef3fa !important;
  color: #11161d !important;
  box-shadow: 0 16px 44px rgba(238, 243, 250, 0.12) !important;
  font-weight: 900 !important;
}

.primary:hover,
.admin-primary:hover,
.add-episode:hover,
#generateVideos:hover,
.employee-login-panel button:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 24px 58px rgba(238, 243, 250, 0.16) !important;
}

.secondary,
.asset-library-head button,
.global-asset-tools button,
.episode-actions button,
.video-actions button,
.library-card-actions button,
.sidebar-recharge,
.community-card-link,
.process-nav button,
.project-tabs button,
.episode-filters button,
.ratio-tabs button,
.video-step-switch button {
  border: 1px solid rgba(238, 243, 250, 0.15) !important;
  border-radius: 10px !important;
  background: rgba(238, 243, 250, 0.07) !important;
  color: #dce5f1 !important;
  box-shadow: none !important;
}

.project-tabs button.active,
.episode-filters button.active,
.ratio-tabs button.active,
.video-step-switch button.active,
.process-nav button.active {
  border-color: rgba(238, 243, 250, 0.28) !important;
  background: rgba(238, 243, 250, 0.13) !important;
  color: #fff !important;
}

input,
select,
textarea,
.asset-toolbar select,
.asset-library-head input,
.global-asset-tools input {
  border: 1px solid rgba(238, 243, 250, 0.14) !important;
  border-radius: 10px !important;
  background: rgba(5, 8, 12, 0.55) !important;
  color: #f4f7fb !important;
  box-shadow: none !important;
}

textarea {
  border-radius: 12px !important;
}

input::placeholder,
textarea::placeholder {
  color: #687485 !important;
}

input:focus,
select:focus,
textarea:focus {
  border-color: rgba(238, 243, 250, 0.42) !important;
  box-shadow: 0 0 0 3px rgba(238, 243, 250, 0.07) !important;
}

.sidebar-points-wallet,
.sidebar-community-card {
  margin: 0 12px 12px !important;
  border: 1px solid var(--line) !important;
  border-radius: 14px !important;
  background: rgba(238, 243, 250, 0.04) !important;
}

.sidebar-points-head,
.sidebar-points-head button {
  color: var(--muted) !important;
}

.sidebar-points-wallet > button {
  border-radius: 10px !important;
}

.sidebar-claim:disabled {
  background: rgba(238, 243, 250, 0.08) !important;
  color: #788495 !important;
}

.community-card-qr,
.community-card-placeholder {
  border: 1px solid rgba(238, 243, 250, 0.16) !important;
  border-radius: 12px !important;
  background: rgba(5, 8, 12, 0.36) !important;
  color: var(--muted) !important;
}

.employee-login-screen {
  background:
    linear-gradient(rgba(7, 9, 13, 0.65), rgba(7, 9, 13, 0.86)),
    var(--site-background-image),
    url("./assets/digital-future-poster-lite.jpg") center / cover !important;
}

.employee-login-panel {
  width: min(460px, 100%) !important;
  padding: 36px !important;
  border: 1px solid rgba(238, 243, 250, 0.2) !important;
  border-radius: 18px !important;
  background: rgba(18, 23, 31, 0.84) !important;
  color: #f4f7fb !important;
  box-shadow: 0 32px 100px rgba(0, 0, 0, 0.56) !important;
  backdrop-filter: blur(28px) !important;
}

.employee-login-panel h1 {
  color: #fff !important;
  font-size: 30px !important;
  font-weight: 900 !important;
}

.employee-login-panel > p,
.employee-login-panel > small,
.employee-login-panel label {
  color: #a6b2c2 !important;
}

.employee-auth-tabs {
  border-radius: 12px !important;
  border: 1px solid rgba(238, 243, 250, 0.12) !important;
  background: rgba(5, 8, 12, 0.42) !important;
}

.employee-auth-tabs button {
  border-radius: 8px !important;
  color: #8793a3 !important;
}

.employee-auth-tabs button.active {
  background: rgba(238, 243, 250, 0.12) !important;
  color: #fff !important;
}

.modal-backdrop,
.material-modal,
.library-drawer,
.global-asset-drawer {
  background: rgba(3, 5, 8, 0.76) !important;
  backdrop-filter: blur(14px) !important;
}

.modal-backdrop > section,
.video-modal,
.video-history-modal,
.material-modal > section {
  border: 1px solid rgba(238, 243, 250, 0.16) !important;
  border-radius: 18px !important;
  background: rgba(18, 23, 31, 0.96) !important;
  color: #f4f7fb !important;
  box-shadow: 0 35px 100px rgba(0, 0, 0, 0.66) !important;
}

.toast {
  border: 1px solid rgba(238, 243, 250, 0.16) !important;
  border-radius: 12px !important;
  background: #eef3fa !important;
  color: #11161d !important;
  box-shadow: 0 20px 70px rgba(0, 0, 0, 0.4) !important;
}

@media (max-width: 980px) {
  .shell {
    grid-template-columns: 84px minmax(0, 1fr) !important;
    padding: 12px !important;
  }

  .sidebar {
    top: 12px !important;
    height: calc(100vh - 24px) !important;
  }

  .project-area {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 640px) {
  .shell {
    display: block !important;
    padding: 10px !important;
  }

  .sidebar {
    position: relative !important;
    top: 0 !important;
    height: auto !important;
    margin-bottom: 12px !important;
  }

  h1,
  .topbar h1 {
    font-size: 28px !important;
  }
}

/* Rose V2: pink commercial UI with fixed contrast and admin-like operation feel. */
:root {
  color-scheme: light;
  --bg: #efabb4;
  --sidebar: rgba(255, 239, 242, 0.62);
  --card: rgba(255, 247, 249, 0.82);
  --card-2: rgba(255, 255, 255, 0.9);
  --line: rgba(55, 35, 41, 0.13);
  --text: #221d1f;
  --muted: #685c61;
  --orange: #e95f7f;
  --orange-2: rgba(233, 95, 127, 0.14);
  --green: #1f1f1f;
  --cyan: #b95f83;
  --purple: #a56c98;
  --danger: #d84860;
  --shadow: 0 26px 80px rgba(118, 39, 58, 0.22);
  --rose-v2-radius: 26px;
}

html,
body {
  color: var(--text) !important;
  background:
    radial-gradient(circle at 58% 82%, rgba(231, 59, 103, 0.32) 0 11%, transparent 12%),
    radial-gradient(circle at 74% 32%, rgba(255, 255, 255, 0.8) 0 12%, transparent 13%),
    linear-gradient(180deg, rgba(177, 80, 111, 0.32), rgba(251, 209, 209, 0.48) 36%, rgba(238, 151, 159, 0.76)),
    var(--site-background-image),
    url("./assets/digital-future-poster-lite.jpg") center / cover fixed,
    #efabb4 !important;
  background-blend-mode: soft-light, normal, normal, multiply, multiply, normal !important;
  font-family: "Inter", "HarmonyOS Sans SC", "PingFang SC", "Microsoft YaHei", Arial, sans-serif !important;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.05)),
    radial-gradient(ellipse at 48% 86%, rgba(140, 55, 70, 0.18), transparent 38%) !important;
  opacity: 1 !important;
}

body::after {
  content: "";
  display: block !important;
  position: fixed;
  left: 8%;
  right: 10%;
  bottom: -13%;
  height: 42vh;
  z-index: -1;
  pointer-events: none;
  border-radius: 50% 50% 0 0;
  background:
    radial-gradient(circle at 52% 14%, rgba(255, 91, 132, 0.34), transparent 18%),
    linear-gradient(135deg, rgba(255, 220, 224, 0.22), rgba(176, 61, 83, 0.14));
}

.shell {
  grid-template-columns: 232px minmax(0, 1fr) !important;
  gap: 18px !important;
  padding: 18px !important;
}

.sidebar {
  top: 18px !important;
  height: calc(100vh - 36px) !important;
  border: 1px solid rgba(255, 255, 255, 0.52) !important;
  border-radius: 30px !important;
  background: rgba(255, 239, 242, 0.62) !important;
  box-shadow: var(--shadow) !important;
  backdrop-filter: blur(26px) saturate(1.1) !important;
}

.logo {
  border-bottom: 1px solid rgba(34, 29, 31, 0.08) !important;
}

.logo strong,
.employee-login-brand,
.sidebar-points-wallet > strong,
.sidebar-community-card strong {
  color: #211f20 !important;
}

.logo-mark,
.employee-login-brand span,
.stat-icon,
.new-project button,
.episode-play,
.asset-thumb,
.folder-icon {
  border: 0 !important;
  border-radius: 16px !important;
  background: #fff !important;
  color: #211f20 !important;
  box-shadow: 0 13px 28px rgba(76, 38, 48, 0.12) !important;
}

.nav button {
  border-radius: 999px !important;
  color: rgba(32, 32, 32, 0.66) !important;
}

.nav button:hover,
.nav button.active {
  border-color: transparent !important;
  background: #1f1f1f !important;
  color: #fff !important;
  box-shadow: 0 22px 55px rgba(31, 31, 31, 0.22) !important;
}

h1,
.topbar h1,
.screen-head h1 {
  color: #1f1f1f !important;
  font-size: clamp(30px, 3.4vw, 52px) !important;
  font-weight: 560 !important;
  letter-spacing: -0.075em !important;
}

h2,
.project-card h2 {
  color: #1f1f1f !important;
}

.topbar p,
.section-head p,
.main p,
.stats small,
.stats em,
.project-card p,
.project-meta,
.step-top em,
.asset-list small,
.community-card-desc {
  color: rgba(34, 29, 31, 0.64) !important;
}

.workspace-tag,
.project-meta span,
.shot-asset-tags button,
.model-pill,
.status-chip,
.queue span {
  border: 1px solid rgba(31, 31, 31, 0.1) !important;
  background: rgba(255, 255, 255, 0.58) !important;
  color: rgba(31, 31, 31, 0.72) !important;
}

.stats article,
.project-card,
.new-project,
.workflow-screen,
.asset-section,
.material-card,
.library-asset-card,
.shot-card,
.smart-preview-panel,
.smart-detail-panel,
.employee-setting-card,
.points-wallet-card,
.points-package-card,
.episode-card,
.library-card,
.video-history-item,
.points-record-item {
  border: 1px solid rgba(255, 255, 255, 0.58) !important;
  border-radius: var(--rose-v2-radius) !important;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.82), rgba(255, 226, 232, 0.56)) !important;
  color: #211f20 !important;
  box-shadow: var(--shadow) !important;
  backdrop-filter: blur(24px) saturate(1.08) !important;
}

.stats article:nth-child(2),
.project-card.active-project,
.smart-detail-panel {
  background: rgba(255, 255, 255, 0.9) !important;
}

.stats article:hover,
.project-card:hover,
.new-project:hover,
.material-card:hover,
.library-asset-card:hover,
.shot-card:hover,
.points-package-card:hover {
  transform: translateY(-4px) !important;
  border-color: rgba(255, 255, 255, 0.78) !important;
  box-shadow: 0 34px 92px rgba(111, 38, 53, 0.28) !important;
}

.stats strong,
.project-card h2 {
  color: #1f1f1f !important;
  font-weight: 620 !important;
}

.project-area {
  grid-template-columns: minmax(300px, 0.86fr) minmax(420px, 1.36fr) !important;
  gap: 16px !important;
}

.project-card,
.new-project {
  min-height: 224px !important;
  padding: 24px !important;
}

.new-project {
  border-style: dashed !important;
  border-color: rgba(31, 31, 31, 0.16) !important;
}

.primary,
.admin-primary,
.add-episode,
#generateVideos,
.employee-login-panel button,
.points-recharge-primary,
.sidebar-claim {
  border: 0 !important;
  border-radius: 999px !important;
  background: #1f1f1f !important;
  color: #fff !important;
  box-shadow: 0 18px 45px rgba(31, 31, 31, 0.2) !important;
}

.secondary,
.asset-library-head button,
.global-asset-tools button,
.episode-actions button,
.video-actions button,
.library-card-actions button,
.sidebar-recharge,
.community-card-link,
.process-nav button,
.project-tabs button,
.episode-filters button,
.ratio-tabs button,
.video-step-switch button {
  border: 1px solid rgba(31, 31, 31, 0.12) !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.66) !important;
  color: #1f1f1f !important;
}

.project-tabs button.active,
.episode-filters button.active,
.ratio-tabs button.active,
.video-step-switch button.active,
.process-nav button.active {
  background: #1f1f1f !important;
  color: #fff !important;
}

input,
select,
textarea,
.asset-toolbar select,
.asset-library-head input,
.global-asset-tools input {
  border: 1px solid rgba(31, 31, 31, 0.11) !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.68) !important;
  color: #1f1f1f !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72) !important;
}

textarea {
  border-radius: 22px !important;
}

input::placeholder,
textarea::placeholder {
  color: rgba(31, 31, 31, 0.4) !important;
}

input:focus,
select:focus,
textarea:focus {
  border-color: rgba(31, 31, 31, 0.34) !important;
  box-shadow: 0 0 0 5px rgba(255, 255, 255, 0.35) !important;
}

.sidebar-points-wallet,
.sidebar-community-card {
  border: 1px solid rgba(255, 255, 255, 0.54) !important;
  border-radius: 22px !important;
  background: rgba(255, 255, 255, 0.5) !important;
}

.community-card-qr,
.community-card-placeholder {
  border: 1px solid rgba(31, 31, 31, 0.1) !important;
  border-radius: 18px !important;
  background: #fff !important;
  color: rgba(31, 31, 31, 0.56) !important;
}

.employee-login-screen {
  background:
    radial-gradient(circle at 70% 75%, rgba(255, 87, 128, 0.34) 0 11%, transparent 12%),
    linear-gradient(180deg, rgba(245, 169, 183, 0.62), rgba(237, 148, 158, 0.86)),
    var(--site-background-image),
    url("./assets/digital-future-poster-lite.jpg") center / cover !important;
}

.employee-login-panel {
  border: 1px solid rgba(255, 255, 255, 0.54) !important;
  border-radius: 32px !important;
  background: rgba(255, 229, 234, 0.64) !important;
  color: #1f1f1f !important;
  box-shadow: var(--shadow) !important;
}

.employee-login-panel h1,
.employee-login-panel label {
  color: #1f1f1f !important;
}

.employee-login-panel > p,
.employee-login-panel > small {
  color: rgba(31, 31, 31, 0.58) !important;
}

.employee-auth-tabs {
  border-radius: 999px !important;
  border: 1px solid rgba(31, 31, 31, 0.1) !important;
  background: rgba(255, 255, 255, 0.48) !important;
}

.employee-auth-tabs button {
  border-radius: 999px !important;
  color: rgba(31, 31, 31, 0.58) !important;
}

.employee-auth-tabs button.active {
  background: #1f1f1f !important;
  color: #fff !important;
}

.modal-backdrop,
.material-modal,
.library-drawer,
.global-asset-drawer {
  background: rgba(116, 54, 67, 0.34) !important;
}

.modal-backdrop > section,
.video-modal,
.video-history-modal,
.material-modal > section {
  border: 1px solid rgba(255, 255, 255, 0.58) !important;
  border-radius: 30px !important;
  background: rgba(255, 246, 247, 0.92) !important;
  color: #1f1f1f !important;
}

.toast {
  border: 0 !important;
  border-radius: 999px !important;
  background: #1f1f1f !important;
  color: #fff !important;
}

@media (max-width: 980px) {
  .shell {
    grid-template-columns: 84px minmax(0, 1fr) !important;
    padding: 12px !important;
  }

  .sidebar {
    top: 12px !important;
    height: calc(100vh - 24px) !important;
  }

  .project-area {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 640px) {
  .shell {
    display: block !important;
    padding: 10px !important;
  }

  .sidebar {
    position: relative !important;
    top: 0 !important;
    height: auto !important;
    margin-bottom: 12px !important;
  }
}

/* Rose V2 frontend readability pass. */
body {
  --readable-card: rgba(255, 250, 251, 0.92);
  --readable-card-soft: rgba(255, 238, 242, 0.84);
  --readable-ink: #1d1a1b;
  --readable-muted: #62565b;
}

.main {
  position: relative !important;
  max-width: 1540px !important;
  min-height: calc(100vh - 36px) !important;
  margin: 0 auto !important;
  padding: 28px 30px 70px !important;
  border: 1px solid rgba(255, 255, 255, 0.24) !important;
  border-radius: 0 !important;
  background: linear-gradient(90deg, rgba(94, 40, 56, 0.18), rgba(255, 214, 221, 0.12)) !important;
  backdrop-filter: blur(2px) !important;
}

.topbar {
  min-height: 102px !important;
  margin-bottom: 12px !important;
  padding: 0 6px !important;
}

h1,
.topbar h1,
.screen-head h1 {
  color: #1b1719 !important;
  text-shadow: 0 1px 18px rgba(255, 236, 239, 0.32) !important;
}

.topbar p {
  color: rgba(29, 24, 26, 0.72) !important;
  font-weight: 650 !important;
}

.userbar strong,
.project-head b,
.new-project strong,
.episode-info strong,
.asset-section-head h3,
.screen-head h2,
.material-card h3,
.library-asset-body h3,
.shot-card h3 {
  color: var(--readable-ink) !important;
  font-weight: 900 !important;
}

.workspace-tag {
  background: rgba(255, 255, 255, 0.72) !important;
  color: #211f20 !important;
  font-weight: 900 !important;
}

.stats {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 16px !important;
  margin-bottom: 18px !important;
}

.stats article {
  min-height: 118px !important;
  padding: 20px 24px !important;
  background: linear-gradient(145deg, var(--readable-card), rgba(255, 235, 239, 0.88)) !important;
}

.stats article:nth-child(3) {
  background: linear-gradient(145deg, rgba(28, 32, 42, 0.94), rgba(12, 15, 22, 0.92)) !important;
  border-color: rgba(255, 255, 255, 0.28) !important;
}

.stats article:nth-child(3) small,
.stats article:nth-child(3) em {
  color: rgba(255, 255, 255, 0.68) !important;
}

.stats article:nth-child(3) strong {
  color: #fff !important;
}

.stats small {
  color: var(--readable-muted) !important;
  font-weight: 760 !important;
}

.stats em {
  color: rgba(29, 24, 26, 0.62) !important;
  font-weight: 650 !important;
}

.stats strong {
  color: #1f1f1f !important;
  font-size: 34px !important;
  line-height: 1 !important;
}

.project-area {
  grid-template-columns: minmax(360px, 0.82fr) minmax(560px, 1.42fr) !important;
  gap: 18px !important;
  align-items: stretch !important;
}

.new-project,
.project-card {
  min-height: 236px !important;
  padding: 26px !important;
}

.new-project {
  background: linear-gradient(145deg, rgba(255, 244, 247, 0.82), rgba(255, 226, 232, 0.72)) !important;
}

.project-card {
  position: relative !important;
  background: linear-gradient(145deg, var(--readable-card), rgba(255, 238, 242, 0.9)) !important;
}

.project-delete {
  position: relative;
  z-index: 5;
  height: 34px;
  margin-left: 8px;
  padding: 0 11px;
  border: 1px solid rgba(255, 74, 118, 0.22) !important;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.58) !important;
  color: #c92d5b !important;
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  box-shadow: 0 8px 18px rgba(117, 42, 62, 0.09);
}

.project-delete:hover {
  border-color: rgba(255, 74, 118, 0.68) !important;
  background: linear-gradient(135deg, #ff5f8d, #ff8aac) !important;
  color: #fff !important;
  transform: translateY(-1px);
}

.project-card.active-project {
  min-height: 236px !important;
}

.project-card h2 {
  color: #1b1719 !important;
  font-size: 30px !important;
  font-weight: 900 !important;
  line-height: 1.15 !important;
}

.project-card p,
.new-project span {
  color: var(--readable-muted) !important;
  font-size: 14px !important;
  font-weight: 650 !important;
  line-height: 1.75 !important;
}

.project-meta {
  border-top: 1px solid rgba(31, 31, 31, 0.08) !important;
  color: var(--readable-muted) !important;
}

.project-meta span {
  background: rgba(255, 255, 255, 0.76) !important;
  color: #4b4246 !important;
  font-weight: 760 !important;
}

.project-card .project-head,
.material-card header,
.library-asset-body {
  color: var(--readable-ink) !important;
}

.project-card .project-head {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}

.project-card .project-head b {
  margin-left: auto !important;
}

.film-icon,
.project-head span:not(.film-icon) {
  color: #1f1f1f !important;
}

.new-project button {
  width: 54px !important;
  height: 54px !important;
  border-radius: 16px !important;
  color: #1f1f1f !important;
  font-size: 28px !important;
}

.sidebar {
  background: rgba(255, 239, 242, 0.72) !important;
}

.sidebar-points-wallet,
.sidebar-community-card {
  background: rgba(255, 250, 251, 0.68) !important;
}

.sidebar-points-head,
.sidebar-points-head button,
.community-card-desc {
  color: rgba(31, 31, 31, 0.62) !important;
}

.sidebar-points-wallet > button,
.sidebar-claim,
.sidebar-recharge {
  font-weight: 900 !important;
}

.view,
.active-view {
  color: var(--readable-ink) !important;
}

.project-card * {
  text-shadow: none !important;
}

@media (max-width: 1180px) {
  .project-area {
    grid-template-columns: 1fr !important;
  }

  .main {
    padding: 22px !important;
  }
}

/* Frontend title typography polish. */
:root {
  --display-font: "HarmonyOS Sans SC", "MiSans", "PingFang SC", "Microsoft YaHei UI", "Microsoft YaHei", "Noto Sans CJK SC", sans-serif;
  --body-font: "PingFang SC", "Microsoft YaHei UI", "Microsoft YaHei", "Segoe UI", Arial, sans-serif;
}

body,
button,
input,
select,
textarea {
  font-family: var(--body-font) !important;
}

h1,
.topbar h1,
.screen-head h1,
.asset-library-head h2,
.employee-settings-head h1,
.material-hub-head h1 {
  font-family: var(--display-font) !important;
  color: #231b1f !important;
  font-size: clamp(34px, 3.2vw, 50px) !important;
  font-weight: 720 !important;
  letter-spacing: -0.035em !important;
  line-height: 1.08 !important;
  text-wrap: balance;
  text-shadow:
    0 1px 0 rgba(255, 245, 247, 0.42),
    0 18px 48px rgba(92, 36, 50, 0.18) !important;
}

.topbar p,
.screen-head p,
.asset-library-head p,
.employee-settings-head p,
.material-hub-head p {
  max-width: 760px;
  margin-top: 10px !important;
  color: rgba(35, 27, 31, 0.68) !important;
  font-size: 14px !important;
  font-weight: 560 !important;
  letter-spacing: 0.01em !important;
  line-height: 1.65 !important;
}

.topbar,
.screen-head,
.asset-library-head,
.employee-settings-head,
.material-hub-head {
  border-color: rgba(35, 27, 31, 0.08) !important;
}

.userbar strong,
.workspace-tag {
  font-family: var(--body-font) !important;
}

.project-card h2,
.new-project strong,
.project-head b,
.asset-section-head h3,
.employee-setting-card h3,
.library-asset-body h3,
.material-card h3,
.shot-card h3 {
  font-family: var(--display-font) !important;
  font-weight: 680 !important;
  letter-spacing: -0.025em !important;
}

@media (max-width: 760px) {
  h1,
  .topbar h1,
  .screen-head h1,
  .asset-library-head h2,
  .employee-settings-head h1,
  .material-hub-head h1 {
    font-size: 32px !important;
    letter-spacing: -0.025em !important;
  }
}

/* Frontend background cleanup and artistic outlined headings. */
html,
body {
  background:
    linear-gradient(90deg, rgba(92, 33, 49, 0.7), rgba(219, 122, 138, 0.46)),
    var(--site-background-image) center / cover fixed,
    #d88c9a !important;
  background-blend-mode: normal, normal, normal !important;
}

body::before {
  background:
    linear-gradient(180deg, rgba(80, 26, 43, 0.18), rgba(238, 139, 153, 0.34)),
    radial-gradient(circle at 67% 44%, rgba(255, 238, 241, 0.3), transparent 17%) !important;
  opacity: 1 !important;
}

body::after {
  display: none !important;
}

.main {
  background: rgba(255, 197, 207, 0.08) !important;
  backdrop-filter: none !important;
}

h1,
.topbar h1,
.screen-head h1,
.asset-library-head h2,
.employee-settings-head h1,
.material-hub-head h1 {
  color: #fff8fb !important;
  font-family: "STKaiti", "KaiTi", "FZYaoti", "华文行楷", "HarmonyOS Sans SC", "Microsoft YaHei", serif !important;
  font-weight: 800 !important;
  letter-spacing: -0.015em !important;
  -webkit-text-stroke: 1.6px rgba(18, 14, 17, 0.94);
  paint-order: stroke fill;
  text-shadow:
    2px 2px 0 rgba(18, 14, 17, 0.88),
    4px 7px 18px rgba(49, 13, 25, 0.32),
    0 0 1px rgba(18, 14, 17, 0.8) !important;
}

.topbar p,
.screen-head p,
.asset-library-head p,
.employee-settings-head p,
.material-hub-head p {
  color: rgba(32, 23, 27, 0.76) !important;
  font-weight: 680 !important;
  text-shadow: 0 1px 0 rgba(255, 238, 242, 0.28) !important;
}

/* Login typography: white fill with black outline. */
.employee-auth-tabs button,
.employee-auth-form h1 {
  color: #fff8fb !important;
  font-family: "STKaiti", "KaiTi", "FZYaoti", "华文行楷", "HarmonyOS Sans SC", "Microsoft YaHei", serif !important;
  font-weight: 850 !important;
  letter-spacing: 0.01em !important;
  -webkit-text-stroke: 1.15px rgba(12, 10, 12, 0.96);
  paint-order: stroke fill;
  text-shadow:
    1.5px 1.5px 0 rgba(12, 10, 12, 0.92),
    0 8px 20px rgba(48, 11, 24, 0.28) !important;
}

.employee-auth-tabs button {
  font-size: 18px !important;
}

.employee-auth-form h1 {
  font-size: 38px !important;
}

.employee-auth-tabs button.active {
  color: #fff !important;
}

/* Login tab proportion refinement. */
.employee-auth-tabs {
  width: min(390px, 100%) !important;
  margin: 22px auto 20px !important;
  padding: 6px !important;
  gap: 6px !important;
  border-radius: 28px !important;
  background: rgba(255, 255, 255, 0.42) !important;
}

.employee-auth-tabs button {
  height: 40px !important;
  min-width: 0 !important;
  padding: 0 26px !important;
  border-radius: 22px !important;
  font-size: 16px !important;
  line-height: 1 !important;
  -webkit-text-stroke: 0.85px rgba(12, 10, 12, 0.96) !important;
  text-shadow:
    1px 1px 0 rgba(12, 10, 12, 0.92),
    0 6px 14px rgba(48, 11, 24, 0.22) !important;
}

.employee-auth-form h1 {
  font-size: 34px !important;
  -webkit-text-stroke: 0.95px rgba(12, 10, 12, 0.94) !important;
  text-shadow:
    1.2px 1.2px 0 rgba(12, 10, 12, 0.9),
    0 8px 18px rgba(48, 11, 24, 0.24) !important;
}

/* Tone modal readability override. Keep tone cards legible on dark image backgrounds. */
#toneModal .tone-grid button,
#toneGrid button.tone-bg {
  isolation: isolate !important;
  color: #fff !important;
  background-image: none !important;
}

#toneModal .tone-bg::before {
  opacity: 0.72 !important;
  filter: saturate(1.06) brightness(0.82) !important;
}

#toneModal .tone-bg::after {
  background:
    linear-gradient(90deg, rgba(9, 10, 14, 0.9), rgba(9, 10, 14, 0.56) 46%, rgba(9, 10, 14, 0.28)),
    radial-gradient(circle at 12% 18%, rgba(0, 0, 0, 0.42), transparent 38%) !important;
}

#toneModal .tone-grid strong,
#toneModal .tone-grid small,
#toneGrid button.tone-bg strong,
#toneGrid button.tone-bg small {
  position: relative !important;
  z-index: 3 !important;
  color: #fff !important;
  opacity: 1 !important;
  text-shadow:
    0 1px 2px rgba(0, 0, 0, 0.92),
    0 6px 18px rgba(0, 0, 0, 0.55) !important;
}

#toneModal .tone-grid strong,
#toneGrid button.tone-bg strong {
  font-size: 16px !important;
  font-weight: 900 !important;
  letter-spacing: 0.01em !important;
}

#toneModal .tone-grid small,
#toneGrid button.tone-bg small {
  max-width: 88% !important;
  color: rgba(255, 255, 255, 0.86) !important;
  font-size: 13px !important;
  font-weight: 650 !important;
}

#toneModal .tone-grid button.active,
#toneGrid button.tone-bg.active {
  border-color: rgba(255, 119, 154, 0.95) !important;
  box-shadow:
    0 0 0 3px rgba(255, 119, 154, 0.24),
    0 14px 34px rgba(42, 10, 18, 0.28) !important;
}

#toneModal .tone-grid button.active::after,
#toneGrid button.tone-bg.active::after {
  background:
    linear-gradient(90deg, rgba(9, 10, 14, 0.86), rgba(9, 10, 14, 0.5) 45%, rgba(255, 119, 154, 0.12)),
    radial-gradient(circle at 10% 18%, rgba(0, 0, 0, 0.36), transparent 38%) !important;
}

.employee-visual-panel {
  margin-top: 18px;
  padding: 0;
  border: 0;
  border-top: 1px solid rgba(92, 50, 64, 0.12);
  background: transparent;
}

.employee-visual-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 18px 0 12px;
}

/* Selection modals must not be stretched by long admin text. */
#styleModal .style-modal,
#toneModal .style-modal {
  display: flex !important;
  width: min(920px, calc(100vw - 44px)) !important;
  max-height: min(760px, calc(100vh - 36px)) !important;
  overflow: hidden !important;
  flex-direction: column !important;
  padding: 24px 24px 22px !important;
}

#styleModal .style-modal > p,
#toneModal .style-modal > p {
  flex: 0 0 auto !important;
  margin-bottom: 16px !important;
  line-height: 1.55 !important;
}

#styleModal .style-grid,
#toneModal .tone-grid {
  overflow-y: auto !important;
  overscroll-behavior: contain !important;
  padding: 2px 8px 10px 0 !important;
  min-height: 0 !important;
}

#styleModal .style-grid {
  grid-template-columns: repeat(4, minmax(140px, 1fr)) !important;
}

#toneModal .tone-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  align-items: stretch !important;
}

#styleModal .style-grid button,
#toneModal .tone-grid button,
#toneGrid button.tone-bg {
  min-height: 0 !important;
  height: 168px !important;
  max-height: 168px !important;
  overflow: hidden !important;
  contain: layout paint !important;
}

#toneModal .tone-grid button,
#toneGrid button.tone-bg {
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  padding: 18px !important;
}

#toneModal .tone-grid strong,
#toneGrid button.tone-bg strong {
  flex: 0 0 auto !important;
  margin: 0 0 8px !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

#toneModal .tone-grid small,
#toneGrid button.tone-bg small {
  display: -webkit-box !important;
  overflow: hidden !important;
  max-width: 100% !important;
  max-height: 78px !important;
  line-height: 1.45 !important;
  -webkit-box-orient: vertical !important;
  -webkit-line-clamp: 4 !important;
}

#toneModal .tone-grid button:hover small,
#toneGrid button.tone-bg:hover small,
#toneModal .tone-grid button:focus-visible small,
#toneGrid button.tone-bg:focus-visible small {
  display: block !important;
  overflow-y: auto !important;
  -webkit-line-clamp: unset !important;
}

#styleModal .style-select-actions,
#toneModal .style-select-actions {
  flex: 0 0 auto !important;
  margin-top: 14px !important;
}

@media (max-width: 820px) {
  #styleModal .style-grid,
  #toneModal .tone-grid {
    grid-template-columns: 1fr !important;
  }
}

.employee-visual-head h3 {
  margin: 0;
  color: #1f1c1d;
}

.employee-visual-head p,
.employee-visual-list p {
  margin: 4px 0 0;
  color: rgba(31, 28, 29, 0.62);
  font-size: 12px;
}

.employee-visual-create-card {
  min-width: 150px;
  height: 54px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 1px solid rgba(92, 50, 64, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.68);
  color: #1f1c1d;
  font-weight: 850;
}

.employee-visual-create-card span {
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: #1f1c1d;
  color: #fff;
}

.employee-visual-form {
  display: grid;
  gap: 9px;
}

.employee-visual-bg-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
}

.employee-visual-form input,
.employee-visual-form textarea {
  width: 100%;
  min-height: 42px;
  border: 1px solid rgba(92, 50, 64, 0.18);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.72);
  color: #201c1d;
  padding: 10px 12px;
}

.employee-visual-form textarea {
  min-height: 74px;
  resize: vertical;
}

.employee-visual-actions,
.employee-visual-item,
.employee-visual-item > div:last-child {
  display: flex;
  align-items: center;
  gap: 8px;
}

.employee-visual-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.employee-visual-item {
  justify-content: space-between;
  padding: 10px 12px;
  border: 1px solid rgba(92, 50, 64, 0.14);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.52);
}

.employee-visual-item strong,
.employee-visual-item small {
  display: block;
}

.employee-visual-item small {
  margin-top: 3px;
  color: rgba(31, 28, 29, 0.62);
}

.employee-visual-item .danger {
  color: #b4233c;
}

.employee-visual-editor-backdrop.open {
  display: flex;
}

.employee-visual-editor {
  width: min(720px, calc(100vw - 40px));
  max-height: min(86vh, 820px);
  overflow: auto;
  position: relative;
  padding: 34px;
  border-radius: 28px;
  background: rgba(255, 246, 249, 0.94);
  box-shadow: 0 28px 90px rgba(48, 16, 28, 0.34);
}

.employee-visual-editor .editor-kicker {
  display: block;
  margin-bottom: 10px;
  color: rgba(31, 28, 29, 0.48);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 4px;
}

.employee-visual-editor h2 {
  margin: 0;
  color: #1f1c1d;
  font-size: 28px;
}

.employee-visual-editor > p {
  margin: 8px 0 22px;
  color: rgba(31, 28, 29, 0.62);
}

.employee-visual-editor .employee-visual-form {
  padding-top: 4px;
}

@media (max-width: 720px) {
  .employee-visual-head,
  .employee-visual-item {
    align-items: stretch;
    flex-direction: column;
  }

  .employee-visual-bg-row {
    grid-template-columns: 1fr;
  }

  .employee-visual-create-card {
    width: 100%;
  }

  .employee-visual-editor {
    width: calc(100vw - 20px);
    padding: 24px;
    border-radius: 22px;
  }
}

/* Project asset cards: reference-sheet ratio, matching the commercial role library. */
.asset-card-grid {
  grid-template-columns: repeat(2, minmax(420px, 1fr)) !important;
  gap: 16px !important;
}

.prop-grid {
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)) !important;
}

.material-card {
  display: flex !important;
  min-height: auto !important;
  flex-direction: column !important;
  overflow: hidden !important;
  border: 1px solid rgba(255, 139, 15, 0.22) !important;
  border-radius: 9px !important;
  background: #101010 !important;
}

.prop-grid .material-card {
  min-height: auto !important;
}

.material-preview {
  width: 100% !important;
  min-height: 0 !important;
  flex: 0 0 auto !important;
  aspect-ratio: 16 / 9 !important;
  padding: 0 !important;
  border-right: 0 !important;
  border-bottom: 0 !important;
  background-color: #f8f8f6 !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  background-size: cover !important;
  color: rgba(31, 31, 31, 0.36) !important;
}

.character-section .material-preview {
  aspect-ratio: 16 / 9 !important;
  background-position: center center !important;
  background-size: contain !important;
  background-color: #f4f1ec !important;
  background-blend-mode: normal !important;
  background-repeat: no-repeat !important;
}

.scene-section .material-preview {
  aspect-ratio: 16 / 8.3 !important;
  background-position: center !important;
}

.prop-grid .material-preview {
  min-height: 0 !important;
  flex-basis: auto !important;
  aspect-ratio: 16 / 8.2 !important;
  border-right: 0 !important;
  border-bottom: 0 !important;
}

.material-preview.has-generated-image {
  color: transparent !important;
  background-color: #f8f8f6 !important;
  background-blend-mode: normal !important;
  background-size: cover !important;
}

.character-section .material-preview.has-generated-image,
.character-section .material-preview[style*="background-image"] {
  background-size: contain !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
  background-color: #f4f1ec !important;
  background-blend-mode: normal !important;
}

.material-info {
  position: relative !important;
  display: flex !important;
  min-height: 124px !important;
  flex: 1 1 auto !important;
  flex-direction: column !important;
  padding: 14px 12px 12px !important;
  background: #101010 !important;
  color: #fff !important;
}

.prop-grid .material-info {
  min-height: 112px !important;
}

.material-info h4 {
  margin: 0 0 7px !important;
  color: #fff !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
}

.material-info p,
.material-info small {
  display: block !important;
  overflow: hidden !important;
  font-size: 12px !important;
  line-height: 1.58 !important;
  text-overflow: ellipsis !important;
  white-space: normal !important;
  display: -webkit-box !important;
  -webkit-box-orient: vertical !important;
}

.material-info p {
  margin: 0 0 6px !important;
  color: rgba(255, 255, 255, 0.76) !important;
  -webkit-line-clamp: 2 !important;
}

.material-info small {
  margin: 0 92px 10px 0 !important;
  color: #ff8a00 !important;
  font-weight: 850 !important;
  -webkit-line-clamp: 1 !important;
}

.generate-mini,
.library-save-mini,
.edit-mini,
.delete-mini {
  position: static !important;
}

.material-info .generate-mini {
  width: auto !important;
  min-width: 0 !important;
  flex: 1 !important;
  height: 32px !important;
  margin: 0 !important;
  border-radius: 9px !important;
  background: #512609 !important;
  color: #ff8a00 !important;
  font-weight: 950 !important;
}

.material-info .generate-mini:disabled,
.material-info .generate-mini.is-busy {
  cursor: wait !important;
  opacity: 0.82 !important;
  background: linear-gradient(90deg, #6d3008, #7c2144) !important;
  color: #ffd9a8 !important;
}

#materialModal .material-modal {
  width: min(760px, calc(100vw - 40px)) !important;
}

#materialModal .field {
  gap: 8px !important;
}

#materialModal .field span {
  color: #2a2025 !important;
  font-weight: 900 !important;
}

#roleFields .field:first-child .upload-box {
  min-height: 0 !important;
  aspect-ratio: 3 / 1 !important;
  background-color: #b9b1b2 !important;
  background-size: contain !important;
}

#roleFields .field:nth-of-type(2) .upload-box {
  min-height: 0 !important;
  aspect-ratio: 3 / 1 !important;
  background-color: #b9b1b2 !important;
  background-size: contain !important;
}

#materialModal .upload-box {
  color: #70646a !important;
}

#materialModal .upload-box small {
  color: #6b6066 !important;
  font-weight: 800 !important;
}

#materialModal #roleFields .upload-box {
  border-color: rgba(255, 255, 255, 0.22) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.24) !important;
}

#materialModal .generated-role-resource-preview {
  min-height: 0 !important;
  aspect-ratio: 3 / 1 !important;
  background-color: #b9b1b2 !important;
  color: #6b6066 !important;
}

#materialModal textarea.episode-desc {
  min-height: 88px !important;
  max-height: 132px !important;
  margin-bottom: 8px !important;
  border: 1px solid rgba(255, 139, 15, 0.32) !important;
  border-radius: 14px !important;
  background: rgba(255, 255, 255, 0.76) !important;
  color: #241a1f !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
}

#materialModal textarea.episode-desc::placeholder {
  color: rgba(36, 26, 31, 0.48) !important;
}

.material-info .edit-mini,
.material-info .delete-mini {
  display: inline-grid !important;
  width: 32px !important;
  height: 32px !important;
  place-items: center !important;
  border-radius: 9px !important;
  background: rgba(255, 255, 255, 0.12) !important;
  color: #fff !important;
}

.material-info .delete-mini {
  color: #fff !important;
}

.material-info > button:first-of-type {
  margin-top: auto !important;
}

.material-info > .generate-mini,
.material-info > .library-save-mini,
.material-info > .edit-mini,
.material-info > .delete-mini {
  align-self: stretch !important;
}

.material-info {
  gap: 0 !important;
}

.material-info .generate-mini {
  grid-column: 1 !important;
}

.material-info > .generate-mini,
.material-info > .library-save-mini,
.material-info > .edit-mini,
.material-info > .delete-mini {
  display: inline-grid !important;
}

.material-info > .generate-mini {
  width: calc(100% - 146px) !important;
}

.material-info > .library-save-mini {
  position: absolute !important;
  right: 82px !important;
  bottom: 12px !important;
  width: 52px !important;
  min-width: 52px !important;
  height: 30px !important;
  padding: 0 6px !important;
  border-radius: 8px !important;
  font-size: 12px !important;
}

.material-info > .edit-mini {
  position: absolute !important;
  right: 52px !important;
  bottom: 12px !important;
}

.material-info > .delete-mini {
  position: absolute !important;
  right: 12px !important;
  bottom: 12px !important;
}

@media (max-width: 860px) {
  .asset-card-grid,
  .prop-grid {
    grid-template-columns: 1fr !important;
  }

  .material-card {
    min-height: auto !important;
  }

  .material-preview {
    min-height: 0 !important;
    flex-basis: auto !important;
    aspect-ratio: 16 / 9 !important;
    border-right: 0 !important;
    border-bottom: 0 !important;
  }
}

/* Full workbench layout: the episode workspace should use the whole canvas. */
body:has(#episodeView.active-view) {
  background:
    linear-gradient(90deg, rgba(92, 33, 49, 0.7), rgba(219, 122, 138, 0.46)),
    var(--site-background-image) center / cover fixed,
    #d88c9a !important;
  background-blend-mode: normal, normal, normal !important;
}

body:has(#episodeView.active-view)::before {
  display: block !important;
  background:
    linear-gradient(180deg, rgba(80, 26, 43, 0.18), rgba(238, 139, 153, 0.34)),
    radial-gradient(circle at 67% 44%, rgba(255, 238, 241, 0.3), transparent 17%) !important;
  opacity: 1 !important;
}

body:has(#episodeView.active-view) .shell {
  display: grid !important;
  grid-template-columns: 64px minmax(0, 1fr) !important;
  gap: 0 !important;
  width: 100vw !important;
  min-height: 100vh !important;
  padding: 0 !important;
  overflow-x: hidden !important;
  background: transparent !important;
}

body:has(#episodeView.active-view) .sidebar {
  position: sticky !important;
  top: 0 !important;
  z-index: 40 !important;
  width: 64px !important;
  height: 100vh !important;
  padding: 0 !important;
  border: 0 !important;
  border-right: 1px solid rgba(255, 255, 255, 0.42) !important;
  border-radius: 0 !important;
  background: rgba(255, 239, 242, 0.58) !important;
  box-shadow: 14px 0 42px rgba(92, 33, 49, 0.16) !important;
  backdrop-filter: blur(24px) saturate(1.1) !important;
}

body:has(#episodeView.active-view) .logo {
  display: grid !important;
  height: 70px !important;
  place-items: center !important;
  padding: 0 !important;
  border-bottom: 1px solid rgba(34, 29, 31, 0.08) !important;
}

body:has(#episodeView.active-view) .logo-mark {
  width: 42px !important;
  height: 42px !important;
  border-radius: 14px !important;
  background: rgba(255, 255, 255, 0.72) !important;
  color: #211f20 !important;
  box-shadow: none !important;
  font-size: 22px !important;
}

body:has(#episodeView.active-view) .logo strong,
body:has(#episodeView.active-view) .nav button:not(.active)::after,
body:has(#episodeView.active-view) .sidebar-points-wallet,
body:has(#episodeView.active-view) .sidebar-community-card {
  display: none !important;
}

body:has(#episodeView.active-view) .nav {
  display: grid !important;
  gap: 14px !important;
  padding: 18px 10px !important;
}

body:has(#episodeView.active-view) .nav button {
  display: grid !important;
  width: 44px !important;
  height: 44px !important;
  place-items: center !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 12px !important;
  background: transparent !important;
  color: rgba(32, 32, 32, 0.62) !important;
  font-size: 0 !important;
  box-shadow: none !important;
  transform: none !important;
}

body:has(#episodeView.active-view) .nav button span {
  font-size: 18px !important;
}

body:has(#episodeView.active-view) .nav button.active {
  background: #1f1f1f !important;
  color: #fff !important;
}

body:has(#episodeView.active-view) .main {
  width: calc(100vw - 64px) !important;
  max-width: none !important;
  min-width: 0 !important;
  min-height: 100vh !important;
  margin: 0 !important;
  padding: 0 24px 28px 18px !important;
  border: 0 !important;
  background: rgba(255, 197, 207, 0.08) !important;
  backdrop-filter: none !important;
  color: #f3f3f3 !important;
}

body:has(#episodeView.active-view) #episodeView {
  display: grid !important;
  gap: 18px !important;
  max-width: none !important;
  width: 100% !important;
}

body:has(#episodeView.active-view) .episode-breadcrumb {
  min-height: 52px !important;
  margin: 0 -24px 0 -18px !important;
  padding: 0 24px 0 18px !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.28) !important;
  background: rgba(78, 31, 45, 0.18) !important;
  color: rgba(255, 248, 251, 0.78) !important;
  backdrop-filter: blur(16px) !important;
}

body:has(#episodeView.active-view) .episode-breadcrumb .back-btn {
  height: 30px !important;
  padding: 0 12px !important;
  border-radius: 8px !important;
  background: #1a1a1c !important;
  color: #d8d8dc !important;
}

body:has(#episodeView.active-view) .episode-progress {
  min-height: 128px !important;
  margin: 0 !important;
  padding: 22px 0 16px !important;
  gap: 32px !important;
}

body:has(#episodeView.active-view) .episode-progress button {
  min-width: 122px !important;
  color: #8d8d92 !important;
  font-size: 14px !important;
}

body:has(#episodeView.active-view) .episode-progress span {
  width: 42px !important;
  height: 42px !important;
  background: #27272a !important;
  color: #9a9aa0 !important;
  box-shadow: 0 0 0 5px rgba(255, 255, 255, 0.03) !important;
}

body:has(#episodeView.active-view) .episode-progress button.complete {
  color: #15d76c !important;
}

body:has(#episodeView.active-view) .episode-progress button.complete span {
  background: #09c866 !important;
  color: transparent !important;
}

body:has(#episodeView.active-view) .episode-progress button.complete span::before {
  content: "✓";
  color: #fff;
  font-size: 22px;
}

body:has(#episodeView.active-view) .episode-progress button.active {
  color: #fff !important;
}

body:has(#episodeView.active-view) .episode-progress button.active span {
  background: #ff7a00 !important;
  color: #fff !important;
  box-shadow: 0 0 0 5px rgba(255, 122, 0, 0.18) !important;
}

body:has(#episodeView.active-view) .episode-progress i {
  width: 96px !important;
  height: 2px !important;
  background: #29292c !important;
}

body:has(#episodeView.active-view) .episode-progress button.complete + i {
  background: #08b95f !important;
}

body:has(#episodeView.active-view) .workflow-screen {
  max-width: none !important;
  width: 100% !important;
  min-height: calc(100vh - 210px) !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

body:has(#episodeView.active-view) .asset-toolbar,
body:has(#episodeView.active-view) .video-controlbar {
  min-height: 64px !important;
  margin: 0 !important;
  padding: 12px 14px !important;
  border: 1px solid #242424 !important;
  border-radius: 12px !important;
  background: #181819 !important;
}

body:has(#episodeView.active-view) .asset-toolbar {
  display: grid !important;
  grid-template-columns: auto auto auto auto 1fr auto !important;
  gap: 14px !important;
  align-items: center !important;
}

body:has(#episodeView.active-view) .asset-toolbar h2 {
  color: #f5f5f6 !important;
  font-size: 20px !important;
  -webkit-text-stroke: 0 !important;
  text-shadow: none !important;
}

body:has(#episodeView.active-view) .asset-toolbar label,
body:has(#episodeView.active-view) .video-settings label,
body:has(#episodeView.active-view) .ratio-tabs span {
  color: #9a9aa0 !important;
  font-size: 12px !important;
}

body:has(#episodeView.active-view) .asset-toolbar select,
body:has(#episodeView.active-view) .video-settings select {
  height: 30px !important;
  min-width: 98px !important;
  border: 1px solid #303033 !important;
  border-radius: 8px !important;
  background: #242426 !important;
  color: #d8d8dc !important;
}

body:has(#episodeView.active-view) .asset-workbench {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
  gap: 18px !important;
  margin-top: 18px !important;
}

body:has(#episodeView.active-view) .asset-section {
  min-width: 0 !important;
  padding: 14px !important;
  border: 1px solid #242424 !important;
  border-radius: 12px !important;
  background: #181819 !important;
  box-shadow: none !important;
}

body:has(#episodeView.active-view) .asset-section.prop-section {
  grid-column: 1 / -1 !important;
}

body:has(#episodeView.active-view) .asset-section-head {
  min-height: 34px !important;
  margin-bottom: 12px !important;
  color: #f5f5f6 !important;
}

body:has(#episodeView.active-view) .asset-section-head h3 {
  color: #f5f5f6 !important;
  font-size: 17px !important;
  -webkit-text-stroke: 0 !important;
  text-shadow: none !important;
}

body:has(#episodeView.active-view) .asset-card-grid {
  grid-template-columns: repeat(2, minmax(260px, 1fr)) !important;
  gap: 12px !important;
}

body:has(#episodeView.active-view) .scene-section .asset-card-grid {
  grid-template-columns: repeat(2, minmax(280px, 1fr)) !important;
}

body:has(#episodeView.active-view) .prop-grid {
  grid-template-columns: repeat(4, minmax(220px, 1fr)) !important;
}

body:has(#episodeView.active-view) .material-card {
  border-color: #282828 !important;
  border-radius: 8px !important;
  background: #101010 !important;
  box-shadow: none !important;
}

body:has(#episodeView.active-view) .material-card:hover {
  transform: translateY(-2px) !important;
  border-color: rgba(255, 122, 0, 0.45) !important;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.32) !important;
}

body:has(#episodeView.active-view) .material-info {
  min-height: 112px !important;
  padding: 10px !important;
}

body:has(#episodeView.active-view) .material-info p {
  -webkit-line-clamp: 2 !important;
}

body:has(#episodeView.active-view) .material-info small {
  margin-right: 80px !important;
}

body:has(#episodeView.active-view) .video-stage {
  display: grid !important;
  gap: 14px !important;
}

body:has(#episodeView.active-view) .video-step-switch {
  width: max-content !important;
  margin: 0 auto 18px !important;
  position: relative !important;
  z-index: 12 !important;
  padding: 4px !important;
  border: 1px solid rgba(255, 255, 255, 0.42) !important;
  border-radius: 999px !important;
  background: rgba(255, 239, 244, 0.38) !important;
  box-shadow: 0 12px 32px rgba(120, 39, 69, 0.16) !important;
  backdrop-filter: blur(18px) saturate(1.12) !important;
}

body:has(#episodeView.active-view) .video-step-switch button {
  height: 34px !important;
  padding: 0 18px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: transparent !important;
  color: #5f3145 !important;
  font-weight: 900 !important;
  box-shadow: none !important;
}

body:has(#episodeView.active-view) .video-step-switch button.active {
  background: linear-gradient(135deg, #ffffff, #ffe8f0) !important;
  color: #1d171b !important;
  box-shadow: 0 8px 20px rgba(93, 32, 58, 0.2) !important;
}

body:has(#episodeView.active-view) .video-controlbar {
  display: grid !important;
  grid-template-columns: 1fr auto auto !important;
  gap: 16px !important;
}

body:has(#episodeView.active-view) .storyboard-list {
  display: grid !important;
  gap: 14px !important;
}

body:has(#episodeView.active-view) .insert-shot[hidden],
body:has(#episodeView.active-view) .storyboard-list[hidden],
body:has(#episodeView.active-view) .smart-workbench[hidden],
body:has(#episodeView.active-view) .smart-workbench-pro[hidden] {
  display: none !important;
}

body:has(#episodeView.active-view) .shot-card {
  display: grid !important;
  grid-template-columns: 46px minmax(330px, 0.82fr) minmax(360px, 0.9fr) minmax(470px, 1.22fr) minmax(380px, 0.95fr) !important;
  min-height: 330px !important;
  border-color: #2b2b2c !important;
  border-radius: 12px !important;
  background: #181819 !important;
}

body:has(#episodeView.active-view) .shot-cell {
  padding: 12px !important;
  border-left-color: #29292b !important;
}

body:has(#episodeView.active-view) .shot-role-media {
  max-height: 272px !important;
  overflow: auto !important;
  padding-right: 2px !important;
}

body:has(#episodeView.active-view) .shot-role-mini {
  background: #101011 !important;
  border-color: #29292b !important;
}

body:has(#episodeView.active-view) .shot-script,
body:has(#episodeView.active-view) .shot-prompt,
body:has(#episodeView.active-view) .shot-script-editor,
body:has(#episodeView.active-view) .shot-prompt-editor {
  min-height: 260px !important;
  background: #101011 !important;
  color: #e1e1e4 !important;
}

body:has(#episodeView.active-view) .shot-preview {
  aspect-ratio: 16 / 9 !important;
  width: 100% !important;
  min-height: 0 !important;
  background:
    radial-gradient(circle at 50% 50%, rgba(120, 64, 190, 0.24), transparent 17%),
    linear-gradient(180deg, rgba(48, 37, 62, 0.86), rgba(25, 18, 30, 0.96)) !important;
}

body:has(#episodeView.active-view) .video-stage.is-vertical-ratio .shot-preview {
  aspect-ratio: 9 / 16 !important;
  width: min(100%, 240px) !important;
  justify-self: center !important;
}

body:has(#episodeView.active-view) .video-stage.is-vertical-ratio .smart-video-preview {
  aspect-ratio: 9 / 16 !important;
  width: min(100%, 320px) !important;
  min-height: 0 !important;
  justify-self: center !important;
}

body:has(#episodeView.active-view) .video-stage.is-horizontal-ratio .shot-preview {
  aspect-ratio: 16 / 9 !important;
}

body:has(#episodeView.active-view) .video-stage.is-horizontal-ratio .smart-video-preview {
  aspect-ratio: 16 / 9 !important;
  width: 100% !important;
}

body:has(#episodeView.active-view) .smart-workbench,
body:has(#episodeView.active-view) .smart-workbench-pro {
  display: grid !important;
  grid-template-columns: minmax(520px, 0.9fr) minmax(0, 1.65fr) !important;
  gap: 14px !important;
}

body:has(#episodeView.active-view) .smart-preview-panel,
body:has(#episodeView.active-view) .smart-detail-panel {
  border-color: #2b2b2c !important;
  background: #181819 !important;
}

body:has(#episodeView.active-view) .smart-video-preview {
  min-height: 360px !important;
}

body:has(#episodeView.active-view) .video-stage.is-smart-mode,
body:has(#episodeView.active-view) .video-stage:has(#smartWorkbench:not([hidden])) {
  grid-template-columns: minmax(0, 1fr) !important;
  grid-template-areas:
    "switch"
    "control"
    "smart";
  overflow: hidden !important;
}

body:has(#episodeView.active-view) .video-stage.is-smart-mode > .insert-shot,
body:has(#episodeView.active-view) .video-stage.is-smart-mode > #storyboardList {
  display: none !important;
}

body:has(#episodeView.active-view) .video-stage.is-smart-mode > #smartWorkbench {
  display: grid !important;
}

body:has(#episodeView.active-view) .video-stage.is-batch-mode > #smartWorkbench {
  display: none !important;
}

body:has(#episodeView.active-view) .video-stage.is-smart-mode .video-step-switch,
body:has(#episodeView.active-view) .video-stage:has(#smartWorkbench:not([hidden])) .video-step-switch {
  grid-area: switch !important;
}

body:has(#episodeView.active-view) .video-stage.is-smart-mode .video-controlbar,
body:has(#episodeView.active-view) .video-stage:has(#smartWorkbench:not([hidden])) .video-controlbar {
  grid-area: control !important;
}

body:has(#episodeView.active-view) .smart-workbench-pro {
  grid-area: smart !important;
  display: grid !important;
  grid-template-columns: minmax(430px, 0.58fr) minmax(0, 1fr) !important;
  grid-template-areas:
    "preview detail"
    "strip strip" !important;
  gap: 14px !important;
  align-items: stretch !important;
  min-width: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
}

body:has(#episodeView.active-view) .smart-workbench-pro .smart-preview-panel {
  grid-area: preview !important;
  display: grid !important;
  grid-template-rows: auto minmax(390px, 1fr) auto !important;
  min-height: 520px !important;
  min-width: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

body:has(#episodeView.active-view) .smart-workbench-pro .smart-pager {
  grid-template-columns: 92px 1fr 92px !important;
  min-height: 34px !important;
  margin: 0 0 8px !important;
}

body:has(#episodeView.active-view) .smart-workbench-pro .smart-pager strong {
  color: #fff !important;
  font-size: 15px !important;
}

body:has(#episodeView.active-view) .smart-workbench-pro .smart-video-preview {
  min-height: 450px !important;
  border: 1px solid rgba(157, 88, 255, 0.35) !important;
  border-radius: 10px !important;
  background:
    radial-gradient(circle at 50% 50%, rgba(120, 64, 190, 0.24), transparent 15%),
    linear-gradient(180deg, rgba(42, 32, 54, 0.92), rgba(28, 20, 34, 0.98)) !important;
}

body:has(#episodeView.active-view) .smart-workbench-pro .smart-preview-actions {
  grid-template-columns: 1fr 96px 78px 70px 78px !important;
  gap: 8px !important;
  margin-top: 10px !important;
}

body:has(#episodeView.active-view) .smart-workbench-pro .smart-detail-panel {
  grid-area: detail !important;
  min-height: 520px !important;
  min-width: 0 !important;
  padding: 12px !important;
  border: 1px solid #2b2b2c !important;
  border-radius: 12px !important;
  background: #181819 !important;
  overflow: hidden !important;
}

body:has(#episodeView.active-view) .smart-workbench-pro #smartAssetTags {
  min-height: 48px !important;
  margin: 0 0 12px !important;
  padding: 8px !important;
  border: 1px solid #2b2b2c !important;
  border-radius: 10px !important;
  background: #181819 !important;
}

body:has(#episodeView.active-view) .smart-workbench-pro .smart-detail-panel h4 {
  margin: 0 0 8px !important;
  color: #9c9ca2 !important;
}

body:has(#episodeView.active-view) .smart-workbench-pro #smartPrompt {
  min-height: 430px !important;
  max-height: 58vh !important;
  overflow: auto !important;
  padding: 14px !important;
  border: 1px solid #333 !important;
  border-radius: 10px !important;
  background: #242424 !important;
  color: #ececef !important;
  font-size: 13px !important;
  line-height: 1.62 !important;
}

body:has(#episodeView.active-view) .smart-shot-strip {
  grid-area: strip !important;
  min-width: 0 !important;
  padding: 16px !important;
  border: 1px solid #2b2b2c !important;
  border-radius: 14px !important;
  background: #181819 !important;
  overflow: hidden !important;
}

body:has(#episodeView.active-view) .smart-shot-strip-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  margin-bottom: 12px !important;
}

body:has(#episodeView.active-view) .smart-shot-strip-head h4 {
  margin: 0 !important;
  color: #d8eaff !important;
  font-size: 13px !important;
}

body:has(#episodeView.active-view) .smart-shot-strip-head div {
  display: flex !important;
  gap: 8px !important;
}

body:has(#episodeView.active-view) .smart-shot-strip-head button {
  width: 28px !important;
  height: 28px !important;
  border: 0 !important;
  border-radius: 9px !important;
  background: #242428 !important;
  color: #d8d8df !important;
  font-weight: 900 !important;
}

body:has(#episodeView.active-view) .smart-shot-strip-list {
  display: grid !important;
  grid-auto-flow: column !important;
  grid-auto-columns: minmax(150px, 190px) !important;
  gap: 18px !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  padding: 0 0 8px !important;
  scrollbar-color: #3a3a3d #111 !important;
}

body:has(#episodeView.active-view) .smart-shot-thumb {
  position: relative !important;
  display: grid !important;
  grid-template-rows: 86px auto auto auto !important;
  gap: 6px !important;
  min-height: 170px !important;
  padding: 8px !important;
  border: 1px solid #313136 !important;
  border-radius: 10px !important;
  background: #101011 !important;
  color: #bfc8d2 !important;
  text-align: left !important;
  cursor: pointer !important;
}

body:has(#episodeView.active-view) .smart-shot-thumb.active {
  border-color: rgba(255, 139, 15, 0.88) !important;
  box-shadow: 0 0 0 1px rgba(255, 139, 15, 0.28) inset !important;
}

body:has(#episodeView.active-view) .smart-shot-thumb > span {
  position: absolute !important;
  top: 7px !important;
  left: 7px !important;
  z-index: 2 !important;
  min-width: 20px !important;
  height: 20px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 6px !important;
  background: #08090a !important;
  color: #dcecff !important;
  font-size: 11px !important;
  font-weight: 900 !important;
}

body:has(#episodeView.active-view) .smart-shot-thumb b {
  display: grid !important;
  place-items: center !important;
  border-radius: 7px !important;
  background:
    linear-gradient(rgba(255,255,255,0.02), rgba(255,255,255,0.02)),
    #0b0b0c !important;
}

body:has(#episodeView.active-view) .smart-shot-thumb b::before {
  content: "▧" !important;
  color: #414147 !important;
  font-size: 24px !important;
}

body:has(#episodeView.active-view) .smart-shot-thumb strong {
  overflow: hidden !important;
  color: #9bd0ff !important;
  font-size: 11px !important;
  line-height: 1.35 !important;
  white-space: nowrap !important;
  text-overflow: ellipsis !important;
}

body:has(#episodeView.active-view) .smart-shot-thumb small {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  color: #c8d0d8 !important;
  font-size: 11px !important;
  line-height: 1.45 !important;
}

body:has(#episodeView.active-view) .smart-shot-thumb em {
  color: #7d8088 !important;
  font-size: 10px !important;
  font-style: normal !important;
}

@media (min-width: 1760px) {
  body:has(#episodeView.active-view) .asset-card-grid {
    grid-template-columns: repeat(2, minmax(360px, 1fr)) !important;
  }

  body:has(#episodeView.active-view) .prop-grid {
    grid-template-columns: repeat(4, minmax(260px, 1fr)) !important;
  }
}

@media (max-width: 1300px) {
  body:has(#episodeView.active-view) .asset-workbench,
  body:has(#episodeView.active-view) .smart-workbench,
  body:has(#episodeView.active-view) .smart-workbench-pro {
    grid-template-columns: 1fr !important;
    grid-template-areas:
      "preview"
      "detail" !important;
  }

  body:has(#episodeView.active-view) .shot-card {
    grid-template-columns: 42px 1fr !important;
  }

  body:has(#episodeView.active-view) .shot-cell {
    border-top: 1px solid #29292b !important;
  }
}

html.boot-route-restoring body:not(.employee-logged-out) .shell,
body.employee-session-ready.route-restoring:not(.employee-logged-out) .shell {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
}

html.boot-employee-logged-out body .shell {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
}

html.boot-route-restoring body:not(.employee-logged-out)::after,
body.route-restoring:not(.employee-logged-out)::after {
  content: "正在恢复上次工作界面...";
}

/* Final boot restore guard. Keep ASCII text to avoid legacy encoding glitches. */
html.boot-route-restoring body:not(.employee-logged-out) .shell,
body.employee-session-ready.route-restoring:not(.employee-logged-out) .shell {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
}

html.boot-employee-logged-out body .shell {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
}

html.boot-route-restoring body:not(.employee-logged-out)::after,
body.route-restoring:not(.employee-logged-out)::after {
  content: "Restoring workspace...";
}

/* Asset category filters for scene/prop library. */
.asset-category-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 12px 0 16px;
}
.asset-category-filter button {
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-radius: 999px;
  padding: 8px 13px;
  background: rgba(255, 255, 255, 0.34);
  color: #3a2430;
  font-weight: 800;
  cursor: pointer;
}
.asset-category-filter button.active {
  background: linear-gradient(135deg, #fff8fb, #f1bed2);
  color: #21141b;
  box-shadow: 0 10px 24px rgba(111, 42, 70, 0.16);
}
.hub-category-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 8px 0 4px;
}
.hub-category-tags em {
  border-radius: 999px;
  padding: 4px 8px;
  background: rgba(255, 209, 228, 0.18);
  color: #ffd8e8;
  font-size: 11px;
  font-style: normal;
  font-weight: 800;
}
/* Voice asset cards: show role context without forcing voice binding. */
.hub-asset-card.voice .voice-cover {
  background-size:cover;
  background-position:center top;
}

.voice-role-context {
  display:grid;
  gap:5px;
  margin:8px 0;
  padding:10px 12px;
  border:1px solid rgba(31,31,31,.08);
  border-radius:16px;
  background:rgba(255,255,255,.5);
}

.voice-role-context b {
  color:rgba(31,31,31,.86);
  font-size:12px;
}

.voice-role-context span {
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  color:rgba(34,29,31,.64);
  font-size:12px;
  line-height:1.55;
}

/* Material library image cards: large commercial preview, like a portfolio tile. */
.material-hub-grid {
  grid-template-columns: repeat(auto-fill, minmax(520px, 1fr));
  align-items: start;
}

.hub-asset-card.role,
.hub-asset-card.scene,
.hub-asset-card.prop {
  overflow: hidden;
  border: 1px solid rgba(255, 178, 92, .32);
  border-radius: 10px;
  background: #070706;
  box-shadow: 0 18px 40px rgba(28, 13, 18, .2);
}

.hub-asset-card.role .hub-card-cover,
.hub-asset-card.scene .hub-card-cover,
.hub-asset-card.prop .hub-card-cover {
  height: clamp(260px, 32vw, 360px);
  border-radius: 0;
  background-repeat: no-repeat, no-repeat, no-repeat !important;
  background-position: center center, center center, center center !important;
  background-size: cover, cover, cover !important;
  background-color: #eac8d1 !important;
  background-blend-mode: normal, normal, normal;
}

.hub-asset-card.role .hub-card-cover:not([style]),
.hub-asset-card.scene .hub-card-cover:not([style]),
.hub-asset-card.prop .hub-card-cover:not([style]) {
  background-size: cover !important;
}

.hub-asset-card.role .hub-card-body,
.hub-asset-card.scene .hub-card-body,
.hub-asset-card.prop .hub-card-body {
  padding: 12px 12px 10px;
  background: #070706;
  color: #fff;
}

.hub-asset-card.role .hub-card-body h3,
.hub-asset-card.scene .hub-card-body h3,
.hub-asset-card.prop .hub-card-body h3 {
  margin: 0 0 7px;
  color: #fff;
  font-size: 18px;
  line-height: 1.25;
}

.hub-asset-card.role .hub-card-body p,
.hub-asset-card.scene .hub-card-body p,
.hub-asset-card.prop .hub-card-body p {
  display: -webkit-box;
  min-height: auto;
  margin: 0 0 6px;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  color: rgba(255,255,255,.86);
  font-size: 13px;
  line-height: 1.6;
}

.hub-asset-card.role .hub-card-body small,
.hub-asset-card.scene .hub-card-body small,
.hub-asset-card.prop .hub-card-body small {
  display: -webkit-box;
  margin: 0 0 8px;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
  color: #ffa51d !important;
  font-weight: 800;
}

.hub-asset-card.role .hub-card-actions,
.hub-asset-card.scene .hub-card-actions,
.hub-asset-card.prop .hub-card-actions {
  grid-template-columns: minmax(110px, 1fr) minmax(170px, 2fr) 42px;
  gap: 10px;
  margin-top: 8px;
}

.hub-asset-card.role .hub-card-actions button,
.hub-asset-card.scene .hub-card-actions button,
.hub-asset-card.prop .hub-card-actions button {
  height: 38px;
  border-radius: 10px;
  border-color: rgba(255, 170, 72, .18);
  background: rgba(255, 255, 255, .08);
  color: #fff;
}

.hub-asset-card.role .hub-card-actions .hub-add-project,
.hub-asset-card.scene .hub-card-actions .hub-add-project,
.hub-asset-card.prop .hub-card-actions .hub-add-project {
  background: #733707;
  color: #ffa51d;
  font-size: 16px;
  font-weight: 900;
}

.hub-asset-card.role .hub-card-actions .hub-delete-card,
.hub-asset-card.scene .hub-card-actions .hub-delete-card,
.hub-asset-card.prop .hub-card-actions .hub-delete-card {
  color: #fff;
  background: rgba(255,255,255,.1);
}

.hub-asset-card.role .hub-card-cover span,
.hub-asset-card.scene .hub-card-cover span,
.hub-asset-card.prop .hub-card-cover span {
  width: 40px;
  height: 40px;
  background: rgba(255,255,255,.52);
  color: rgba(31,31,31,.64);
}

.hub-asset-card.role .hub-card-cover[style] span,
.hub-asset-card.scene .hub-card-cover[style] span,
.hub-asset-card.prop .hub-card-cover[style] span {
  opacity: .18;
}

.hub-asset-card.role .hub-card-cover b,
.hub-asset-card.scene .hub-card-cover b,
.hub-asset-card.prop .hub-card-cover b {
  background: rgba(18, 15, 17, .68);
  color: #fff;
  box-shadow: 0 8px 18px rgba(31,31,31,.14);
}

@media (max-width: 760px) {
  .material-hub-grid {
    grid-template-columns: 1fr;
  }
  .hub-asset-card.role .hub-card-cover,
  .hub-asset-card.scene .hub-card-cover,
  .hub-asset-card.prop .hub-card-cover {
    height: 58vw;
    min-height: 220px;
  }
}

/* Storyboard asset index source badges. */
.shot-asset-tile.from-temp.matched {
  border-color: rgba(77, 218, 255, 0.32) !important;
  background: linear-gradient(135deg, rgba(77, 218, 255, 0.11), rgba(23, 23, 26, 0.96)) !important;
}

.shot-asset-tile.from-library.matched {
  border-color: rgba(255, 184, 83, 0.28) !important;
  background: linear-gradient(135deg, rgba(255, 184, 83, 0.1), rgba(23, 23, 26, 0.96)) !important;
}

.shot-asset-tile.from-temp .shot-asset-tile-meta em {
  color: #8feaff !important;
  background: rgba(77, 218, 255, 0.1) !important;
}

.shot-asset-tile.from-library .shot-asset-tile-meta em {
  color: #ffc16b !important;
  background: rgba(255, 184, 83, 0.1) !important;
}

.free-video-player-modal section{
  width:min(920px,92vw);
  padding:24px;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.68);
  background:linear-gradient(145deg,rgba(255,242,247,.96),rgba(246,205,221,.94));
  box-shadow:0 24px 70px rgba(117,46,74,.28);
}
.free-video-player-modal h2{
  margin:0 46px 16px 0;
  color:#1f1f1f;
  font-size:24px;
}
.free-video-player-modal video{
  width:100%;
  max-height:70vh;
  border-radius:20px;
  background:#111;
  display:block;
}
.free-video-player-modal p{
  margin:14px 0 0;
  color:rgba(34,29,31,.68);
  font-size:13px;
}
