/* ===== CSS 变量 ===== */
:root {
  --bg: #f5f6f8;
  --bg-primary: #ffffff;
  --bg-secondary: #ffffff;
  --bg-sidebar: #f1f3f6;
  --bg-panel: #ffffff;
  --text: #17181d;
  --text-secondary: #667085;
  --text-muted: #98a2b3;
  --primary: #eb645b;
  --primary-hover: #dd554c;
  --primary-light: rgba(235, 100, 91, 0.16);
  --danger: #f04438;
  --success: #12b76a;
  --warning: #f79009;
  --divider: rgba(16,24,40,0.1);
  --border: rgba(16,24,40,0.12);
  --radius: 10px;
  --radius-sm: 8px;
  --shadow: 0 1px 2px rgba(16,24,40,0.05), 0 4px 12px rgba(16,24,40,0.08);
  --shadow-lg: 0 10px 30px rgba(16,24,40,0.12);
  --font: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;
  --upload-tile-size: 56px;
  --ui-surface: var(--bg-panel);
  --ui-surface-strong: var(--bg-panel);
  --ui-surface-soft: var(--bg-secondary);
  --ui-field: var(--bg-secondary);
  --ui-border: var(--divider);
  --ui-border-strong: var(--border);
  --ui-shadow-soft: var(--shadow);
  --ui-shadow-card: var(--shadow);
  --ui-accent-glow: 0 10px 24px rgba(235, 100, 91, 0.12);
}

body.theme-dark {
  --primary: #eb645b;
  --primary-hover: #f0746b;
  --primary-light: rgba(235, 100, 91, 0.18);
}

body.theme-dark {
  --bg: #111821;
  --bg-primary: #1b252f;
  --bg-secondary: #222d37;
  --bg-sidebar: #111821;
  --bg-panel: #1b252f;
  --text: #fff8f2;
  --text-secondary: rgba(255, 248, 242, 0.74);
  --text-muted: rgba(255, 248, 242, 0.50);
  --primary: #eb645b;
  --primary-hover: #f0746b;
  --primary-light: rgba(235, 100, 91, 0.18);
  --danger: #ff5a5f;
  --success: #22c55e;
  --warning: #f59e0b;
  --divider: rgba(255,255,255,0.10);
  --border: rgba(255,255,255,0.13);
  --shadow: 0 1px 3px rgba(0,0,0,0.18), 0 1px 2px rgba(0,0,0,0.12);
  --shadow-lg: 0 18px 52px rgba(0,0,0,0.26);
  --ui-surface: var(--bg-panel);
  --ui-surface-strong: var(--bg-secondary);
  --ui-surface-soft: rgba(255,255,255,0.06);
  --ui-field: rgba(255,255,255,0.07);
  --ui-border: var(--divider);
  --ui-border-strong: var(--border);
  --ui-shadow-soft: var(--shadow);
  --ui-shadow-card: var(--shadow);
  --ui-accent-glow: 0 14px 34px rgba(235, 100, 91, 0.16);
}

/* ===== 基础重置 ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: var(--font);
  font-size: 14px;
  color: var(--text);
  background: var(--bg);
  overflow: hidden;
  user-select: none;
  -webkit-user-select: none;
  height: 100vh;
}

.security-locked #sidebar-modules,
.security-locked #sidebar-footer,
.security-locked #content-header-billing,
.security-locked #floating-billing-link {
  pointer-events: none;
  opacity: 0.38;
}

.security-lock-panel {
  width: min(520px, calc(100% - 32px));
  margin: clamp(56px, 12vh, 120px) auto 0;
  padding: 34px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 24px;
  color: var(--text);
  background:
    radial-gradient(circle at 12% 0%, rgba(235, 100, 91, 0.24), transparent 42%),
    radial-gradient(circle at 92% 12%, rgba(120, 232, 255, 0.14), transparent 40%),
    rgba(15, 21, 30, 0.86);
  box-shadow: 0 28px 90px rgba(0, 0, 0, 0.32), inset 0 1px 0 rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(18px);
  text-align: center;
}

.security-lock-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  margin-bottom: 16px;
  border-radius: 999px;
  color: #2b1210;
  background: linear-gradient(135deg, #fff2bd, #ff7566);
  box-shadow: 0 18px 44px rgba(235, 100, 91, 0.35);
  font-size: 22px;
  font-weight: 950;
}

.security-lock-panel h3 {
  margin: 0 0 10px;
  font-size: 22px;
  font-weight: 900;
}

.security-lock-panel p {
  margin: 0 0 22px;
  color: var(--text-muted);
  font-size: 14px;
  line-height: 1.8;
}

body:not(.theme-dark) .security-lock-panel {
  color: #17202b;
  background:
    radial-gradient(circle at 12% 0%, rgba(235, 100, 91, 0.18), transparent 42%),
    radial-gradient(circle at 92% 12%, rgba(120, 232, 255, 0.2), transparent 40%),
    rgba(255, 255, 255, 0.86);
  border-color: rgba(45, 54, 64, 0.14);
  box-shadow: 0 24px 70px rgba(70, 52, 42, 0.14);
}

.hidden { display: none !important; }

/* ===== 顶栏 ===== */
#topbar {
  height: 38px;
  background: transparent;
  border-bottom: 0;
  -webkit-app-region: drag;
  position: relative;
  flex-shrink: 0;
}

.topbar-brand {
  display: none;
}

.topbar-status-cluster {
  display: contents;
}

.client-update-topbar-download {
  position: absolute;
  left: 108px;
  top: 6px;
  z-index: 3;
  width: 26px;
  height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 0;
  border-radius: 999px;
  color: #43d783;
  background: transparent;
  box-shadow: none;
  cursor: pointer;
  opacity: 0.94;
  -webkit-app-region: no-drag;
  transition:
    transform 0.08s ease,
    color 0.14s ease,
    opacity 0.14s ease,
    background 0.14s ease;
}

.client-update-topbar-download:hover {
  color: #5be394;
  opacity: 1;
  background: rgba(67, 215, 131, 0.08);
}

.client-update-topbar-download:active {
  transform: translateY(1px) scale(0.98);
}

.client-update-topbar-download:focus-visible {
  outline: 2px solid rgba(91, 227, 148, 0.46);
  outline-offset: 3px;
}

.client-update-topbar-download svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.35;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.client-broadcast-bar {
  position: absolute;
  left: 50%;
  top: 7px;
  transform: translateX(-50%);
  width: min(52vw, 660px);
  max-width: calc(100vw - 420px);
  height: 24px;
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  padding: 0 10px;
  border: 0;
  border-bottom: 0;
  border-radius: 999px;
  background: transparent;
  color: rgba(255, 244, 238, 0.9);
  box-shadow: none;
  font-size: 12px;
  font-weight: 720;
  line-height: 1;
  white-space: nowrap;
  overflow: hidden;
  -webkit-app-region: no-drag;
}

.client-broadcast-dot {
  flex: 0 0 auto;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: #ff7f73;
  box-shadow: 0 0 14px rgba(255, 127, 115, 0.72);
}

.client-broadcast-viewport {
  display: block;
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
}

.client-broadcast-content {
  display: inline-block;
  max-width: none;
  will-change: transform;
}

.client-broadcast-content[data-broadcast-link] {
  cursor: pointer;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
  text-decoration-color: rgba(255, 127, 115, 0.42);
}

.client-broadcast-content[data-broadcast-link]:focus-visible {
  outline: 2px solid rgba(255, 127, 115, 0.45);
  outline-offset: 3px;
  border-radius: 6px;
}

.client-broadcast-bar.is-marquee .client-broadcast-content {
  animation: client-broadcast-marquee var(--broadcast-duration, 14s) linear forwards;
}

@keyframes client-broadcast-marquee {
  from { transform: translateX(0); }
  to { transform: translateX(calc(-1 * var(--broadcast-distance, 320px))); }
}

@media (max-width: 920px) {
  .client-broadcast-bar {
    width: min(52vw, 460px);
    max-width: calc(100vw - 300px);
  }
}

.platform-win #topbar {
  display: block;
  height: 38px;
  padding: 0 150px 0 0;
  -webkit-app-region: drag;
}

.platform-win .topbar-brand {
  position: absolute;
  left: 12px;
  top: 0;
  height: 38px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  color: rgba(255, 248, 242, 0.94);
  font-size: 13px;
  font-weight: 760;
  line-height: 1;
  pointer-events: none;
}

.platform-win .topbar-brand img {
  width: 18px;
  height: 18px;
  border-radius: 5px;
  object-fit: cover;
  box-shadow: 0 0 10px rgba(255, 127, 115, 0.18);
}

.platform-win .topbar-status-cluster {
  position: absolute;
  right: 150px;
  top: 0;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  max-width: calc(100vw - 720px);
  -webkit-app-region: no-drag;
}

.platform-win .client-update-topbar-download {
  position: static;
  flex: 0 0 auto;
}

.platform-win .client-broadcast-bar {
  top: 7px;
  width: min(36vw, 520px);
  max-width: calc(100vw - 760px);
}

.trial-countdown {
  position: fixed;
  top: 8px;
  right: 18px;
  left: auto;
  z-index: 5200;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  height: 24px;
  padding: 0 12px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  background:
    linear-gradient(135deg, rgba(255, 118, 91, 0.28), rgba(92, 216, 239, 0.16)),
    rgba(18, 26, 36, 0.58);
  box-shadow: 0 10px 26px rgba(255, 105, 86, 0.12), inset 0 1px 0 rgba(255,255,255,0.18);
  color: rgba(255, 244, 238, 0.94);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.02em;
  -webkit-app-region: no-drag;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.trial-countdown::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: #ff7661;
  box-shadow: 0 0 14px rgba(255, 118, 97, 0.82);
}

.trial-countdown.is-expired {
  background: rgba(34, 28, 31, 0.76);
  color: rgba(255, 214, 204, 0.92);
}

.platform-win .trial-countdown {
  position: static;
  left: auto;
  right: auto;
  top: auto;
  flex: 0 0 auto;
}

body:not(.theme-dark) .trial-countdown {
  border-color: rgba(235, 100, 91, 0.22);
  background:
    linear-gradient(135deg, rgba(255, 133, 104, 0.26), rgba(106, 218, 236, 0.18)),
    rgba(255, 250, 244, 0.78);
  color: #7a3b34;
  box-shadow: 0 10px 28px rgba(235, 100, 91, 0.14), inset 0 1px 0 rgba(255,255,255,0.78);
}

.topbar-spacer {
  width: 1px;
  height: 1px;
}

.topbar-spacer-right {
  justify-self: end;
}

.sidebar-logo {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 0 0 14px;
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font: inherit;
  position: relative;
  overflow: visible;
  isolation: isolate;
  -webkit-app-region: no-drag;
  appearance: none;
  -webkit-appearance: none;
}

.sidebar-logo:hover #app-logo,
.sidebar-logo:focus-visible #app-logo {
  filter:
    drop-shadow(0 0 16px rgba(255, 118, 103, 0.52))
    drop-shadow(0 0 26px rgba(124, 236, 255, 0.25))
    brightness(1.12);
}

.sidebar-logo:focus-visible {
  outline: 2px solid rgba(235, 100, 91, 0.42);
  outline-offset: 5px;
  border-radius: 14px;
}

.sidebar-logo::before {
  content: "";
  position: absolute;
  width: 94px;
  height: 34px;
  border-radius: 999px;
  background: linear-gradient(100deg, transparent 12%, rgba(255, 244, 199, 0.22) 42%, rgba(124, 236, 255, 0.18) 58%, transparent 86%);
  filter: blur(10px);
  opacity: 0;
  transform: translateX(-70px) skewX(-18deg);
  animation: nalaLogoSweep 5.4s ease-in-out infinite;
  pointer-events: none;
  z-index: 0;
}

#app-logo {
  height: 24px;
  width: auto;
  object-fit: contain;
  -webkit-app-region: no-drag;
  filter:
    drop-shadow(0 0 10px rgba(255, 118, 103, 0.38))
    drop-shadow(0 0 18px rgba(124, 236, 255, 0.16));
  animation: nalaLogoGlow 5.4s ease-in-out infinite;
  position: relative;
  z-index: 1;
  transition: height 0.18s ease, filter 0.18s ease;
}

@keyframes nalaLogoGlow {
  0%, 100% {
    filter:
      drop-shadow(0 0 10px rgba(255, 118, 103, 0.34))
      drop-shadow(0 0 18px rgba(124, 236, 255, 0.14))
      brightness(1) saturate(1.02);
  }
  46% {
    filter:
      drop-shadow(0 0 15px rgba(255, 118, 103, 0.52))
      drop-shadow(0 0 24px rgba(124, 236, 255, 0.28))
      brightness(1.18) saturate(1.2);
  }
}

@keyframes nalaLogoSweep {
  0%, 14%, 100% {
    opacity: 0;
    transform: translateX(-70px) skewX(-18deg);
  }
  34% {
    opacity: 0.82;
  }
  64% {
    opacity: 0.3;
    transform: translateX(70px) skewX(-18deg);
  }
}

@media (prefers-reduced-motion: reduce) {
  .sidebar-logo::before,
  #app-logo {
    animation: none;
  }
}

#sidebar.sidebar-collapsed .sidebar-logo {
  padding-bottom: 10px;
}

#sidebar.sidebar-collapsed #app-logo {
  height: 16px;
}

.topbar-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.5px;
}

#btn-settings {
  -webkit-app-region: no-drag;
}

/* ===== 布局 ===== */
#app {
  display: flex;
  height: calc(100vh - 38px);
  background: transparent;
}

.platform-win #app {
  height: calc(100vh - 38px);
}

/* ===== 侧边栏 ===== */
#sidebar {
  width: 300px;
  min-width: 300px;
  background: transparent;
  border-right: 0;
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  transition: width 0.18s ease, min-width 0.18s ease;
}

#sidebar.sidebar-collapsed {
  width: 68px;
  min-width: 68px;
}

.sidebar-module {
  padding: 8px 0;
}

#sidebar-modules {
  flex: 1;
  overflow-y: auto;
}

.sidebar-footer {
  padding: 14px 18px 16px;
  border-top: 1px solid var(--divider);
}

.sidebar-footer-actions {
  display: flex;
  gap: 10px;
}

.sidebar-action {
  flex: 1;
  min-height: 44px;
  justify-content: center;
  border-radius: 14px;
  background: var(--bg-panel);
  padding: 0;
}

.sidebar-action .theme-toggle-label {
  display: block;
  font-size: 13px;
}

.sidebar-action .theme-toggle-icon {
  display: none;
}

#sidebar.sidebar-collapsed .sidebar-footer-actions {
  flex-direction: column;
  gap: 8px;
  align-items: center;
}

#sidebar.sidebar-collapsed .sidebar-action {
  width: 44px;
  min-width: 44px;
  flex: none;
}

#sidebar.sidebar-collapsed .sidebar-action .theme-toggle-label {
  display: none;
}

#sidebar.sidebar-collapsed .sidebar-action .theme-toggle-icon {
  display: block;
  font-size: 15px;
}

.theme-toggle {
  width: 100%;
  min-height: 44px;
  border-radius: 14px;
  border: 1px solid var(--divider);
  background: var(--bg-panel);
  color: var(--text);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  font-size: 13px;
}

.theme-toggle-icon {
  font-size: 16px;
}

.theme-toggle:hover {
  background: var(--primary-light);
  border-color: var(--primary);
}

.auth-sidebar-action {
  position: relative;
  overflow: hidden;
}

.auth-sidebar-action.is-logged-in {
  color: #fff;
  background: linear-gradient(135deg, rgba(235,100,91,0.78), rgba(158,233,242,0.34));
  box-shadow: 0 16px 36px rgba(235,100,91,0.18);
}

.auth-sidebar-action.is-logged-in::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, transparent 0%, rgba(255,255,255,0.24) 46%, transparent 58%);
  transform: translateX(-120%);
  animation: auth-action-shine 4s ease-in-out infinite;
  pointer-events: none;
}

@keyframes auth-action-shine {
  0%, 45% { transform: translateX(-120%); }
  75%, 100% { transform: translateX(120%); }
}

.sidebar-module-header {
  display: none;
}

.module-icon { font-size: 16px; }

.sidebar-service {
  padding: 9px 14px 9px 18px;
  cursor: pointer;
  font-size: 13px;
  color: var(--text);
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: background 0.12s, color 0.12s;
  border-left: 3px solid transparent;
  gap: 8px;
}

.sidebar-service-icon {
  display: none;
  width: 22px;
  min-width: 22px;
  text-align: center;
  font-size: 14px;
  color: var(--text-secondary);
}

.sidebar-service-text {
  flex: 1;
  min-width: 0;
}

#sidebar.sidebar-collapsed .sidebar-service {
  justify-content: center;
  padding: 10px 0;
  border-left-width: 0;
}

#sidebar.sidebar-collapsed .sidebar-service .sidebar-service-text,
#sidebar.sidebar-collapsed .sidebar-service .service-tag {
  display: none;
}

#sidebar.sidebar-collapsed .sidebar-service .sidebar-service-icon {
  display: block;
}

#sidebar.sidebar-collapsed .sidebar-service.active .sidebar-service-icon {
  color: var(--primary);
}

.sidebar-service:hover { background: var(--primary-light); }

.sidebar-service.active {
  background: var(--primary-light);
  color: var(--primary);
  font-weight: 600;
  border-left-color: var(--primary);
}

.sidebar-service-child {
  padding-left: 34px;
}

.sidebar-service-child .sidebar-service-text {
  font-size: 12px;
}

.service-tag {
  font-size: 10px;
  padding: 2px 6px;
  border-radius: 4px;
  background: var(--divider);
  color: var(--text-secondary);
  flex-shrink: 0;
}

.sidebar-service.active .service-tag {
  background: var(--primary);
  color: #ffffff;
}

/* ===== 主内容区 ===== */
#content {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  overflow-x: hidden;
  background: transparent;
  scrollbar-width: thin;
  scrollbar-color: rgba(120, 128, 148, 0.28) transparent;
}

#content.content-custom-app-layout {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto 1fr;
  overflow: hidden;
  position: relative;
}

#content.content-custom-app-layout.content-custom-app-split {
  grid-template-columns: 1fr 250px !important;
  grid-template-rows: 1fr !important;
}
#content.content-custom-app-layout.content-custom-app-split #content-result .history-shell {
  width: 100%;
  padding: 0 12px;
  box-sizing: border-box;
}

#content.content-custom-app-layout.content-custom-app-split #content-header {
  display: none !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app {
  position: relative !important;
  grid-column: 1;
  grid-row: 1;
  bottom: auto !important;
  left: auto !important;
  right: auto !important;
  max-height: none !important;
  height: 100%;
  min-height: 0;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: hidden;
  padding: 20px;
  border-right: 1px solid var(--divider);
}

#content.content-custom-app-layout.content-custom-app-split #content-result {
  grid-column: 2;
  grid-row: 1;
  border-left: none;
  padding: 20px;
  overflow-y: auto;
  overflow-x: hidden;
}

#content.content-custom-app-layout.content-custom-app-split #content-result .history-shell {
  width: 210px;
  margin: 0 auto;
}

#content.content-custom-app-layout.content-custom-app-split #content-result .history-grid-image {
  gap: 12px 2px;
}
#content.content-custom-app-layout.content-custom-app-split #content-result .history-row {
  flex-direction: column;
  gap: 4px;
}
#content.content-custom-app-layout.content-custom-app-split #content-result .history-tile-image {
  width: 100% !important;
  height: 120px;
  flex: 0 0 auto;
}
#content.content-custom-app-layout.content-custom-app-split #content-result .history-tile-image-media img {
  object-fit: cover;
}

#content.content-custom-app-layout #content-header {
  grid-column: 1;
  grid-row: 1;
  z-index: 3;
  pointer-events: none;
}

#content.content-custom-app-layout #content-header > * {
  pointer-events: auto;
}

#content.content-custom-app-layout:has(#content-panel.content-panel-image-create:not(.content-panel-custom-app)) #content-header {
  display: none;
}

#sidebar-toggle {
  width: 18px;
  min-width: 18px;
  border: none;
  border-left: 1px solid var(--divider);
  background: transparent;
  color: var(--text-secondary);
  padding: 0;
  align-self: stretch;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  -webkit-app-region: no-drag;
}

#sidebar-toggle:hover {
  background: transparent;
  color: var(--primary);
}

#content-header {
  padding: 8px 20px 0;
  flex-shrink: 0;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
}

.content-header-copy {
  min-width: 0;
}

#content-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--text);
}

.content-subtitle {
  margin-top: 6px;
  font-size: 13px;
  font-weight: 300;
  color: var(--text-muted);
}

.content-header-billing {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 0 14px;
  margin-bottom: 4px;
  border-radius: 12px;
  border: 1px solid var(--divider);
  background: transparent;
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
}

.content-header-billing:hover {
  color: var(--text);
  border-color: rgba(99, 102, 241, 0.22);
  background: rgba(99, 102, 241, 0.04);
}

#content-panel {
  flex: 1 1 auto;
  min-height: 0;
  overflow: visible;
  padding: 8px 20px 0;
  background: var(--bg);
}

#content-panel.content-panel-image-create {
  flex: 0 0 auto;
  padding-top: 8px;
  padding-bottom: 8px;
}

#content-panel.content-panel-translate {
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding-bottom: 20px;
}

#content-panel.content-panel-custom-app {
  height: 243px;
  min-height: 243px;
  max-height: 243px;
  overflow: hidden;
}

#content-panel.content-panel-video-apps {
  flex: 1 1 auto;
  height: auto;
  min-height: 0;
  max-height: none;
  overflow: visible;
  padding-top: 0;
  background: transparent;
}

#content.content-custom-app-layout #content-panel.content-panel-video-apps.is-gallery {
  top: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

#content.content-custom-app-layout #content-panel.content-panel-custom-app {
  position: absolute;
  bottom: 20px;
  left: 20px;
  right: 20px;
  z-index: 2;
  height: auto;
  min-height: 0;
  max-height: calc(100% - 84px);
  overflow: visible;
  padding: 0;
  background: transparent;
  border-radius: 16px;
  box-shadow: var(--shadow-lg);
  transition: bottom 0.18s ease;
}

#content.content-custom-app-layout #content-panel.content-panel-custom-app.is-gallery {
  background: transparent;
  border-radius: 0;
  box-shadow: none;
  overflow: visible;
}

#content-panel.content-panel-video-apps .video-app-gallery-shell {
  height: auto;
  width: 100%;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

#content-panel.content-panel-video-apps .video-app-gallery-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-rows: auto;
  gap: 22px 18px;
  background: transparent;
}

#content-panel.content-panel-video-apps .video-app-card {
  height: auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 22px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
}

#content-panel.content-panel-video-apps .video-app-card:hover {
  transform: none;
  border-color: transparent;
  box-shadow: none;
}

#content-panel.content-panel-video-apps .video-app-card-cover {
  position: relative;
  width: 100%;
  height: 180px;
  border: 1px solid rgba(255, 178, 155, 0.34);
  border-radius: 22px;
  background:
    radial-gradient(circle at 18% 18%, rgba(255,255,255,0.36), transparent 24%),
    radial-gradient(circle at 84% 8%, rgba(255, 227, 170, 0.26), transparent 30%),
    linear-gradient(135deg, rgba(255, 143, 132, 0.88), rgba(238, 92, 88, 0.78) 48%, rgba(255, 181, 134, 0.72));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.24),
    0 20px 54px rgba(235,100,91,0.16),
    0 0 0 1px rgba(255,255,255,0.05);
  overflow: hidden;
}

#content-panel.content-panel-video-apps .video-app-card-cover::before {
  content: '';
  position: absolute;
  inset: -40%;
  background: linear-gradient(115deg, transparent 34%, rgba(255,255,255,0.56) 47%, rgba(255,246,211,0.38) 53%, transparent 66%);
  transform: translateX(-48%) rotate(8deg);
  animation: video-card-shine 4.8s ease-in-out infinite;
  pointer-events: none;
}

#content-panel.content-panel-video-apps .video-app-card-cover::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.18), transparent 22%, transparent 78%, rgba(255,255,255,0.14)),
    radial-gradient(circle at 50% 110%, rgba(255,255,255,0.24), transparent 42%);
  pointer-events: none;
}

#content-panel.content-panel-video-apps .video-app-card:hover .video-app-card-cover {
  transform: translateY(-2px);
  border-color: rgba(255, 218, 190, 0.48);
  box-shadow:
    0 0 34px rgba(255, 155, 117, 0.22),
    0 24px 70px rgba(235, 100, 91, 0.22),
    inset 0 1px 0 rgba(255,255,255,0.28);
}

#content-panel.content-panel-video-apps .video-app-card-title {
  display: block;
  padding: 0 4px;
  color: var(--text);
  font-size: 20px;
  font-weight: 800;
  line-height: 1.35;
  text-align: center;
}

#content-panel.content-panel-video-apps .video-app-card-hint {
  display: block;
  margin-top: -12px;
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 600;
  text-align: center;
}

#content-panel.content-panel-video-apps .video-app-card.is-disabled,
.custom-app-card.is-disabled {
  cursor: default;
  opacity: 0.58;
}

#content-panel.content-panel-video-apps .video-app-card.is-disabled:hover,
.custom-app-card.is-disabled:hover {
  transform: none;
  box-shadow: none;
  border-color: var(--ui-border);
}

#content-panel.content-panel-video-apps .video-app-card.is-disabled .video-app-card-cover {
  filter: grayscale(0.35) saturate(0.62);
}

#content-panel.content-panel-video-apps .custom-app-card-mark {
  font-size: 24px;
  position: relative;
  z-index: 1;
  color: rgba(255,255,255,0.92);
  text-shadow: 0 0 18px rgba(255,255,255,0.45);
}

@keyframes video-card-shine {
  0%, 18% { transform: translateX(-58%) rotate(8deg); opacity: 0; }
  34% { opacity: 0.9; }
  58%, 100% { transform: translateX(58%) rotate(8deg); opacity: 0; }
}

#content-result.hidden {
  display: none !important;
}

#content-result {
  flex: 0 0 auto;
  min-height: 0;
  border-top: 1px solid var(--divider);
  padding: 10px 18px 12px;
  overflow: visible;
  background: var(--bg);
}

#content.content-custom-app-layout #content-result {
  grid-column: 1;
  grid-row: 1 / -1;
  border-top: none;
  border-left: none;
  padding: 16px 20px 20px;
  overflow-y: scroll;
  overflow-x: hidden;
  z-index: 1;
}

#content-panel.content-panel-image-create + #content-result {
  flex: 0 0 auto;
}

#content-panel.content-panel-image-create {
  display: flex;
  flex-direction: column;
}

#content-panel.content-panel-image-create + #content-result {
  border-top-width: 1px;
}

#content.content-custom-app-layout #content-panel.content-panel-image-create:not(.content-panel-custom-app) {
  position: absolute;
  bottom: 20px;
  left: 20px;
  right: 20px;
  z-index: 2;
  min-height: 0;
  max-height: calc(100% - 84px);
  overflow-y: auto;
  background: transparent;
  border-radius: 16px;
  box-shadow: var(--shadow-lg);
  padding: 0;
  transition: bottom 0.18s ease;
}

#content.content-custom-app-layout #content-panel.content-panel-image-create:not(.content-panel-custom-app).has-floating-popup-open {
  overflow: visible;
}

#content.content-custom-app-layout #content-panel.content-panel-image-create:not(.content-panel-custom-app) .image-create-shell {
  max-height: none;
  overflow: visible;
}

::-webkit-scrollbar,
body *::-webkit-scrollbar {
  width: 2px !important;
  height: 2px !important;
}

::-webkit-scrollbar-track {
  background: transparent !important;
}

::-webkit-scrollbar-thumb {
  background: rgba(120, 128, 148, 0.24) !important;
  border-radius: 999px !important;
}

body.theme-dark ::-webkit-scrollbar-thumb {
  background: rgba(146, 156, 182, 0.22) !important;
}

#content-result {
  overflow-x: hidden;
}

/* ===== 面板 ===== */
.panel-service-name {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 4px;
}

.panel-service-desc {
  color: var(--text-secondary);
  font-size: 13px;
  margin-bottom: 24px;
}

/* ===== 表单 ===== */
#service-form {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-bottom: 0;
}

.creator-shell {
  background: var(--bg-panel);
  border: 1px solid var(--divider);
  border-radius: 16px;
  padding: 14px 16px 16px;
  box-shadow: none;
}

#content-panel.content-panel-image-create .creator-shell {
  transition: padding 0.18s ease, border-radius 0.18s ease;
}

#content-panel.content-panel-image-create.is-collapsed .creator-shell {
  padding-top: 10px;
  padding-bottom: 10px;
}

#content.content-custom-app-layout #content-panel.content-panel-custom-app .custom-app-gallery-shell {
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
  box-shadow: none;
}

#content-panel.content-panel-custom-app .creator-shell {
  height: 100%;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

#content.content-custom-app-layout #content-panel.content-panel-custom-app .creator-shell {
  height: auto;
  max-height: 100%;
  overflow-y: auto;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .creator-shell {
  height: 100%;
  max-height: 100%;
  overflow-y: auto;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .creator-body {
  overflow: visible;
  flex: 1 0 auto;
}

#content.content-custom-app-layout .custom-app-gallery-shell {
  position: relative;
  height: auto;
  max-height: 100%;
  overflow: visible;
  filter: drop-shadow(0 8px 28px rgba(16, 24, 40, 0.14));
}

.custom-app-panel-title {
  margin: 0 0 12px 0;
  font-size: 17px;
  font-weight: 700;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex-shrink: 0;
}

.creator-head {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  margin-bottom: 14px;
}

.creator-body {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

#content-panel.content-panel-custom-app .creator-body {
  flex: 1 1 auto;
  min-height: 0;
  overflow: auto;
  padding-right: 4px;
}

#content-panel.content-panel-custom-app .creator-footer {
  flex-shrink: 0;
}

.section-row {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.section-row-images {
  margin-top: 2px;
}

.section-row-prompt {
  margin-top: 2px;
}

.section-row-controls {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.section-row-other {
  margin-top: 2px;
}

.creator-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-top: 12px;
}

.creator-head-billing {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 10px;
  background: #eb645b;
  border: 1px solid #eb645b;
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
  margin-left: auto;
  transition: opacity 0.15s;
}

.creator-head-billing:hover {
  opacity: 0.88;
}

.translate-shell {
  display: flex;
  flex: 1 1 auto;
  min-height: 0;
  flex-direction: column;
  gap: 18px;
  padding: 24px;
  border-radius: 28px;
  background: linear-gradient(145deg, rgba(235,100,91,0.10), rgba(255,255,255,0.025) 36%, rgba(255,255,255,0.04));
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 22px 60px rgba(0,0,0,0.20);
}

.translate-body {
  display: flex;
  flex: 1 1 auto;
  min-height: 0;
  flex-direction: column;
  gap: 18px;
}

.translate-language-bar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 48px minmax(0, 1fr);
  align-items: center;
  column-gap: 12px;
}

.translate-language-card {
  position: relative;
  min-width: 0;
  padding: 16px 48px 16px 18px;
  border-radius: 18px;
  background: rgba(255,255,255,0.045);
  border: 1px solid rgba(255,255,255,0.08);
  cursor: pointer;
  overflow: visible;
  transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}

.translate-language-card::after {
  content: "";
  position: absolute;
  right: 20px;
  top: 50%;
  z-index: 5;
  width: 8px;
  height: 8px;
  border-right: 2px solid rgba(255, 214, 205, 0.78);
  border-bottom: 2px solid rgba(255, 214, 205, 0.78);
  transform: translateY(-62%) rotate(45deg);
  pointer-events: none;
}

.translate-language-card:hover,
.translate-language-card:focus-within {
  border-color: rgba(235, 100, 91, 0.32);
  background: rgba(255,255,255,0.065);
  box-shadow: 0 16px 36px rgba(5, 10, 20, 0.16);
}

.translate-language-kicker {
  font-size: 12px;
  color: var(--text-muted);
  margin-bottom: 6px;
}

.translate-language-value {
  font-size: 20px;
  font-weight: 700;
  color: var(--text);
}

.translate-language-control {
  position: absolute;
  inset: 0;
  z-index: 4;
}

.translate-language-control .compact-control {
  position: static;
  width: 100%;
  height: 100%;
  min-width: 0;
}

.translate-language-control .compact-control > label {
  display: none;
}

.translate-language-control .compact-control-input {
  position: static;
  width: 100%;
  height: 100%;
}

.translate-language-control .nala-select {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
}

.translate-language-control .nala-select-trigger {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 18px !important;
  background: transparent !important;
  box-shadow: none !important;
}

.translate-language-control .nala-select-trigger .nala-select-value,
.translate-language-control .nala-select-trigger .nala-select-icon {
  opacity: 0 !important;
}

.translate-language-control .nala-select-menu {
  left: 0 !important;
  right: auto !important;
  top: calc(100% + 10px) !important;
  width: max(100%, 220px) !important;
  max-height: min(300px, 48vh) !important;
  z-index: 140 !important;
}

.translate-language-bar .translate-language-card:last-child .nala-select-menu {
  left: auto !important;
  right: 0 !important;
}

.translate-language-control .compact-control,
.translate-language-control .compact-control-input,
.translate-language-control select {
  width: 100%;
  height: 100%;
  cursor: pointer;
}

.translate-controls-row {
  margin-top: 0;
}

.translate-workspace {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 16px;
  flex: 1 1 auto;
  min-height: 0;
  align-items: stretch;
  margin-top: 0;
}

.translate-workspace-with-swap {
  position: relative;
  column-gap: 24px;
}

.translate-panel {
  min-width: 0;
  min-height: 0;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 22px;
  background: rgba(17, 19, 24, 0.30);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  overflow: hidden;
}

.translate-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
}

.translate-panel-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.translate-required {
  color: var(--danger);
}

.translate-panel-body {
  display: flex;
  flex: 1 1 auto;
  min-height: 0;
}

.translate-textarea,
.translate-output {
  width: 100%;
  flex: 1 1 auto;
  min-height: 260px;
  height: auto;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  background: rgba(255,255,255,0.035);
  padding: 18px;
  font-size: 14px;
  line-height: 1.7;
  color: var(--text);
}

.translate-textarea {
  resize: none;
  font-family: var(--font);
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.translate-textarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--primary-light);
}

.translate-textarea::placeholder {
  color: var(--text-muted);
}

.translate-output-meta {
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 500;
}

.translate-output {
  white-space: pre-wrap;
  word-break: break-word;
}

.translate-output.is-placeholder {
  color: var(--text-muted);
}

.translate-output.is-loading {
  color: var(--text-secondary);
}

.translate-output.has-error {
  color: var(--danger);
}

.translate-swap-chip,
.translate-swap-float,
.translate-panel-icon {
  width: 34px;
  height: 34px;
  min-width: 34px;
  min-height: 34px;
  padding: 0;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.045);
  color: var(--text-secondary);
  border-radius: 999px;
  box-shadow: none;
}

.translate-swap-chip.btn-icon,
.translate-swap-float.btn-icon,
.translate-panel-icon.btn-icon {
  width: 34px;
  height: 34px;
  min-width: 34px;
  min-height: 34px;
  padding: 0;
  border-radius: 999px;
}

.translate-swap-chip {
  justify-self: center;
}

.translate-swap-chip:hover:not(:disabled),
.translate-swap-float:hover:not(:disabled),
.translate-panel-icon:hover:not(:disabled) {
  color: var(--text);
  background: rgba(255,255,255,0.08);
}

.translate-swap-chip svg,
.translate-swap-float svg,
.translate-panel-icon svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.translate-panel-icon svg rect {
  fill: none;
}

.translate-swap-float {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
}

.translate-workspace-with-swap .translate-panel-input,
.translate-workspace-with-swap .translate-panel-output,
.translate-workspace-with-swap .translate-panel-input .translate-textarea,
.translate-workspace-with-swap .translate-panel-output .translate-output {
  border-radius: var(--radius-sm);
}

.translate-footer {
  flex-shrink: 0;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  padding: 12px 20px;
  min-height: 54px;
  border-radius: 18px;
  background: rgba(255,255,255,0.035);
  border: 1px solid rgba(255,255,255,0.06);
}

.translate-footer-note {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  flex: 1 1 auto;
  min-width: 0;
}

.translate-footer-action {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex: 0 0 44px;
  width: 44px;
  min-width: 44px;
  min-height: 44px;
}

.translate-footer-action-placeholder {
  visibility: hidden;
}

.translate-auto-toggle {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  color: var(--text);
  font-size: 14px;
  font-weight: 600;
}

.translate-auto-toggle input {
  width: 14px;
  height: 14px;
  margin: 0;
  accent-color: #eb645b;
}

.translate-usage {
  font-size: 13px;
  color: var(--text-secondary);
  font-weight: 500;
}

.translate-quota-warning {
  font-size: 13px;
  color: var(--text-secondary);
  font-weight: 500;
  white-space: nowrap;
}

.translate-quota-tutorial-link {
  color: #eb645b;
  text-decoration: none;
  cursor: pointer;
  font-weight: 700;
  white-space: nowrap;
}

body:not(.theme-dark) .translate-shell {
  background: linear-gradient(145deg, rgba(235,100,91,0.12), rgba(255,255,255,0.92) 34%, rgba(255,255,255,0.98));
  border-color: rgba(235,100,91,0.12);
  box-shadow: 0 24px 70px rgba(16,24,40,0.10);
}

body:not(.theme-dark) .translate-language-card,
body:not(.theme-dark) .translate-panel,
body:not(.theme-dark) .translate-footer {
  background: rgba(255,255,255,0.78);
  border-color: rgba(16,24,40,0.08);
  box-shadow: 0 12px 34px rgba(16,24,40,0.06);
}

body:not(.theme-dark) .translate-textarea,
body:not(.theme-dark) .translate-output {
  background: #ffffff;
  border-color: rgba(16,24,40,0.09);
  color: #17181d;
}

body:not(.theme-dark) .translate-output.is-placeholder,
body:not(.theme-dark) .translate-textarea::placeholder {
  color: #98a2b3;
}

body:not(.theme-dark) .translate-swap-chip,
body:not(.theme-dark) .translate-panel-icon {
  background: rgba(255,255,255,0.82);
  border-color: rgba(16,24,40,0.10);
  color: #667085;
}

body:not(.theme-dark) .translate-swap-chip:hover:not(:disabled),
body:not(.theme-dark) .translate-panel-icon:hover:not(:disabled) {
  background: #ffffff;
  color: #17181d;
}

.translate-generate {
  width: 44px !important;
  height: 44px;
  min-width: 44px !important;
  min-height: 44px;
  padding: 0 !important;
  border-radius: 50%;
  font-size: 24px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 44px;
}

.translate-generate .spinner {
  width: 18px;
  height: 18px;
  border-color: rgba(255, 255, 255, 0.35);
  border-top-color: #ffffff;
}

@media (max-width: 860px) {
  .translate-workspace {
    grid-template-columns: minmax(0, 1fr);
  }
}


.model-selector {
  position: relative;
  width: 100%;
  max-width: 440px;
}

.model-selector-trigger {
  width: 100%;
  min-height: 54px;
  border: 1px solid var(--divider);
  border-radius: 14px;
  background: var(--bg-panel);
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  justify-content: flex-start;
}

.model-selector-brand,
.model-option-icon {
  width: 34px;
  height: 34px;
  border-radius: 12px;
  background: var(--bg-sidebar);
  color: var(--primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
  border: 1px solid var(--divider);
}

.custom-app-gallery-shell {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
  overflow: visible;
}

.custom-app-gallery-carousel {
  display: flex;
  align-items: center;
  gap: 6px;
  min-height: 0;
}

.custom-app-gallery-viewport {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  border-radius: 12px;
  padding-top: 4px;
}

.custom-app-gallery-track {
  display: flex;
  gap: 8px;
  transition: transform 0.28s ease;
}

.custom-app-gallery-track .custom-app-card {
  flex: 0 0 calc(50% - 8px);
  min-width: 0;
}

#floating-billing-link {
  position: absolute;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 10px;
  background: #eb645b;
  border: 1px solid #eb645b;
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
  transition: top 0.18s ease, right 0.18s ease, opacity 0.15s;
}

#floating-billing-link:hover {
  opacity: 0.88;
}

.custom-app-gallery-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-rows: 90px;
  gap: 8px;
  align-content: start;
  min-height: 0;
}

.custom-app-gallery-arrow {
  flex: 0 0 auto;
  width: 32px;
  height: 32px;
  padding: 0;
  border: 1px solid var(--divider);
  border-radius: 999px;
  background: var(--bg-panel);
  color: var(--text-secondary);
  font-size: 16px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease, opacity 0.15s ease;
  line-height: 1;
}

.custom-app-gallery-arrow:hover:not(:disabled) {
  background: var(--bg-secondary);
  color: var(--text);
}

.custom-app-gallery-arrow:disabled {
  opacity: 0;
  pointer-events: none;
}

.custom-app-card {
  height: 90px;
  padding: 0;
  border: 1px solid rgba(235, 100, 91, 0.2);
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(235, 100, 91, 0.5), rgba(235, 100, 91, 0.85));
  overflow: hidden;
  text-align: left;
  box-shadow: var(--shadow);
  display: grid;
  grid-template-columns: 88px minmax(0, 1fr);
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

.custom-app-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
  border-color: var(--primary);
}

.custom-app-card-cover {
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  min-width: 0;
  height: 100%;
  padding: 8px;
  color: #ffffff;
  background: linear-gradient(135deg, rgba(235, 100, 91, 0.96), rgba(164, 54, 47, 0.9));
}

.custom-app-card-cover-2 {
  background: linear-gradient(135deg, rgba(235, 100, 91, 0.94), rgba(197, 82, 74, 0.88));
}

.custom-app-card-badge {
  position: absolute;
  top: 8px;
  left: 8px;
  width: 24px;
  height: 24px;
  border-radius: 8px;
  background: rgba(255,255,255,0.16);
  border: 1px solid rgba(255,255,255,0.22);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 11px;
}

.custom-app-card-mark {
  font-size: 18px;
  line-height: 1;
  opacity: 0.8;
}

.custom-app-card-body {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 3px;
  min-width: 0;
  padding: 8px 10px;
}

.custom-app-card-name {
  font-size: 12px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.custom-app-card-desc {
  font-size: 10px;
  font-weight: 300;
  color: var(--text-muted);
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* 视频应用卡片 */
.video-app-cards-section {
  padding: 24px 20px;
  max-width: 520px;
  margin: 0 auto;
}
.video-app-cards-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-muted);
  margin-bottom: 20px;
  padding-left: 4px;
}
.video-app-card {
  display: flex;
  gap: 20px;
  padding: 24px;
  margin-bottom: 16px;
  background: var(--bg-panel);
  border: 1px solid var(--divider);
  border-radius: 16px;
  cursor: pointer;
  transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s;
  align-items: center;
}
.video-app-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.08);
  border-color: var(--accent);
}
.video-app-card:last-child {
  margin-bottom: 0;
}
.video-app-card-cover {
  flex-shrink: 0;
  width: 80px;
  height: 80px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(235,100,91,0.12) 0%, rgba(235,100,91,0.04) 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
}
.video-app-card-num {
  font-size: 20px;
  font-weight: 800;
  color: var(--accent);
  line-height: 1;
}
.video-app-card-icon {
  font-size: 18px;
}
.video-app-card-body {
  flex: 1;
  min-width: 0;
}
.video-app-card-name {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 6px;
}
.video-app-card-desc {
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.5;
  margin: 0 0 10px;
}
.video-app-card-cta {
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
}

.custom-app-key-selector {
  position: relative;
  width: auto;
  min-width: 0;
}

.custom-app-key-trigger {
  min-height: 40px;
  border: 1px solid var(--divider);
  border-radius: 12px;
  background: var(--bg-panel);
  color: var(--text);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  max-width: 260px;
}

.custom-app-key-trigger-icon {
  width: 28px;
  height: 28px;
  border-radius: 10px;
  background: var(--bg-sidebar);
  color: var(--primary);
  border: 1px solid var(--divider);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
}

.custom-app-key-trigger-copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  min-width: 0;
}

.custom-app-key-trigger-label {
  font-size: 11px;
  color: var(--text-muted);
  line-height: 1.1;
}

.custom-app-key-trigger-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.custom-app-key-trigger-arrow {
  font-size: 16px;
  color: var(--text-secondary);
  margin-left: auto;
}

.custom-app-key-menu {
  position: absolute;
  left: 0;
  top: calc(100% + 8px);
  width: min(320px, 80vw);
  background: var(--bg);
  border: 1px solid var(--divider);
  border-radius: 18px;
  box-shadow: var(--shadow-lg);
  padding: 10px;
  z-index: 22;
}

.custom-app-back {
  margin-left: auto;
  padding: 8px 12px;
  border-radius: 999px;
  background: var(--primary-light);
  color: var(--primary);
  border: 1px solid transparent;
  font-size: 12px;
  font-weight: 600;
}

.model-selector-copy,
.model-option-copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  min-width: 0;
  flex: 1;
}

.model-selector-label,
.model-option-meta {
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.1;
}

.model-selector-name,
.model-option-name {
  width: 100%;
  text-align: left;
  font-size: 15px;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.model-selector-arrow {
  font-size: 20px;
  color: var(--text-secondary);
  margin-left: auto;
}

.model-selector-menu {
  position: absolute;
  left: 0;
  bottom: calc(100% + 10px);
  width: min(320px, 100%);
  max-height: 280px;
  overflow-y: auto;
  background: var(--bg);
  border: 1px solid var(--divider);
  border-radius: 18px;
  box-shadow: var(--shadow-lg);
  padding: 10px;
  z-index: 22;
}

.model-selector-menu-title {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted);
  padding: 4px 8px 8px;
}

.model-option {
  width: 100%;
  border-radius: 14px;
  background: transparent;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px;
  justify-content: flex-start;
}

.model-option:hover {
  background: var(--bg-secondary);
}

.model-option.active {
  background: var(--primary-light);
  border: 1px solid var(--primary);
}

.form-section {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.form-section-prompt {
  margin-top: 4px;
}

.form-section-controls {
  margin-top: 2px;
}

.control-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.form-group-image {
  margin-bottom: 2px;
}

.form-group label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}

.form-hint {
  font-size: 12px;
  color: var(--text-muted);
}

.form-hint a {
  color: #eb645b;
  text-decoration: none;
}

.form-hint a:hover {
  text-decoration: underline;
}

.field-restore-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  padding: 0;
  margin-left: 4px;
  border: none;
  border-radius: 50%;
  background: transparent;
  color: var(--text-muted);
  font-size: 12px;
  line-height: 1;
  cursor: pointer;
  opacity: 0.4;
  transition: opacity 0.15s, color 0.15s, background 0.15s;
  vertical-align: middle;
}

.field-restore-btn:hover {
  opacity: 1;
  color: var(--primary);
  background: rgba(99, 102, 241, 0.1);
}

textarea, input[type="text"], input[type="number"], input[type="password"], input[type="email"], select {
  width: 100%;
  padding: 10px 14px;
  font-size: 14px;
  font-family: var(--font);
  border: 1px solid var(--divider);
  border-radius: var(--radius-sm);
  background: var(--bg);
  color: var(--text);
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}

textarea:focus, input:focus, select:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--primary-light);
}

textarea {
  resize: none;
  min-height: 80px;
  padding-top: 10px;
  line-height: 1.5;
  width: 100%;
  overflow: hidden;
}

select {
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%236b7280'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 32px;
}

/* ===== 按钮 ===== */
button {
  font-family: var(--font);
  font-size: 14px;
  cursor: pointer;
  border: none;
  border-radius: var(--radius-sm);
  padding: 10px 20px;
  font-weight: 600;
  transition: background 0.12s, opacity 0.12s;
}

button:disabled { opacity: 0.6; cursor: not-allowed; }

.btn-primary {
  background: var(--primary);
  color: #fff;
}

.btn-primary:hover:not(:disabled) { background: var(--primary-hover); }

.btn-secondary {
  background: var(--bg-secondary);
  color: var(--text);
  border: 1px solid var(--divider);
}

.btn-secondary:hover { background: var(--divider); }


.btn-generate {
  width: 100%;
  padding: 14px;
  font-size: 16px;
  font-weight: 700;
  border-radius: 999px;
  background: var(--primary);
  color: #ffffff;
  box-shadow: none;
}

.btn-generate:hover:not(:disabled) { background: var(--primary-hover); }

.button-hint {
  margin-top: 8px;
  font-size: 12px;
  color: var(--text-muted);
  text-align: center;
}

.button-hint a {
  color: var(--primary);
  text-decoration: none;
}

.button-hint a:hover { text-decoration: underline; }

.btn-icon {
  width: 36px;
  height: 36px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  color: var(--text-secondary);
  font-size: 18px;
  border-radius: var(--radius-sm);
}

.btn-icon:hover {
  background: var(--bg-secondary);
  color: var(--text);
}

/* ===== 上传区域 ===== */
.upload-area {
  border: none;
  border-radius: 0;
  padding: 0;
  text-align: left;
  transition: none;
  color: var(--text-secondary);
}

.upload-area.multi {
  min-height: auto;
}

.upload-area.has-image {
  border-style: none;
  border-color: transparent;
  padding: 0;
}

.upload-area.is-dragover {
  color: var(--primary);
}

.sidebar-service[data-service-id="music-create"] {
  opacity: 0.92;
}

.upload-placeholder.hidden,
.upload-thumbnails.hidden {
  display: none;
}

.upload-placeholder {
  position: relative;
  padding: 0;
  border: 1px solid var(--divider);
  background: var(--bg-secondary);
  color: var(--text-secondary);
  appearance: none;
  -webkit-appearance: none;
}

.upload-placeholder:hover .upload-thumb-add-plus,
.upload-placeholder:hover .upload-thumb-add-label {
  color: var(--primary);
}

.upload-thumbnails {
  display: flex;
  flex-wrap: nowrap;
  gap: 4px;
  margin-top: 0;
  justify-content: flex-start;
  align-items: flex-start;
  max-width: 100%;
  min-width: 0;
}

.upload-thumb-wrap {
  position: relative;
  width: var(--upload-tile-size);
  min-width: var(--upload-tile-size);
  height: var(--upload-tile-size);
  aspect-ratio: 1 / 1;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid var(--divider);
  background: var(--bg-secondary);
  cursor: grab;
  flex: 0 0 auto;
  max-width: var(--upload-tile-size);
}

.upload-thumb-wrap-audio {
  width: min(220px, calc(var(--upload-tile-size) * 1.9));
  min-width: min(220px, calc(var(--upload-tile-size) * 1.9));
  max-width: min(220px, calc(var(--upload-tile-size) * 1.9));
}

.upload-thumb-wrap:active {
  cursor: grabbing;
}

.upload-thumb-wrap.is-dragging {
  opacity: 0.55;
}

.upload-thumb-loading {
  cursor: default;
  background: var(--bg-secondary);
}

.upload-thumb-loading-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  height: 100%;
  color: var(--text-muted);
  font-size: 12px;
}

.upload-thumb-loading-spin {
  width: 24px;
  height: 24px;
  border: 2px solid var(--divider);
  border-top-color: var(--primary);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

.upload-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  cursor: zoom-in;
  display: block;
}

.upload-thumb-audio {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  width: 100%;
  height: 100%;
  padding: 10px;
  background: linear-gradient(180deg, rgba(99, 102, 241, 0.08), rgba(99, 102, 241, 0.02));
}

.upload-thumb-audio-icon {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(99, 102, 241, 0.12);
  color: var(--primary);
  font-size: 16px;
  line-height: 1;
}

.upload-thumb-audio-name {
  width: 100%;
  font-size: 11px;
  line-height: 1.35;
  color: var(--text-secondary);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  word-break: break-all;
}

.upload-thumb-wrap-video {
  width: min(220px, calc(var(--upload-tile-size) * 1.9));
  min-width: min(220px, calc(var(--upload-tile-size) * 1.9));
  max-width: min(220px, calc(var(--upload-tile-size) * 1.9));
}

.upload-thumb-video {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  width: 100%;
  height: 100%;
  padding: 10px;
  background: linear-gradient(180deg, rgba(245, 158, 11, 0.08), rgba(245, 158, 11, 0.02));
}

.upload-thumb-video-icon {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(245, 158, 11, 0.12);
  color: var(--warning, #f59e0b);
  font-size: 14px;
  line-height: 1;
}

.upload-thumb-video-name {
  width: 100%;
  font-size: 11px;
  line-height: 1.35;
  color: var(--text-secondary);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  word-break: break-all;
}

.upload-thumb-remove {
  position: absolute;
  top: 3px;
  right: 3px;
  width: 18px;
  height: 18px;
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: 50%;
  background: rgba(35, 37, 43, 0.86);
  color: rgba(255,255,255,0.92);
  font-size: 13px;
  line-height: 1;
  cursor: pointer;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  backdrop-filter: blur(4px);
}

.upload-thumb-remove:hover {
  background: rgba(24, 25, 29, 0.96);
  color: #fff;
}

.upload-thumb-remove svg {
  width: 14px;
  height: 14px;
  stroke: currentColor;
  stroke-width: 1.5;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.upload-thumb-add {
  border: 1px solid var(--divider);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  background: var(--bg-secondary);
  gap: 4px;
}

.upload-thumb-add:hover {
  border-color: var(--primary);
  background: var(--primary-light);
}

.upload-thumb-add-plus {
  font-size: 18px;
  color: var(--text-muted);
  line-height: 1;
  pointer-events: none;
}

.upload-thumb-add-label {
  font-size: 10px;
  color: var(--text-muted);
  line-height: 1;
  pointer-events: none;
}

.upload-thumb-add:hover .upload-thumb-add-plus,
.upload-thumb-add:hover .upload-thumb-add-label {
  color: var(--primary);
}

.image-create-shell {
  --image-create-head-space: 112px;
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 0;
  gap: 6px;
  margin-bottom: 0;
  box-shadow: none;
  transition: gap 0.18s ease;
}

#content-panel.content-panel-image-create.is-collapsed .image-create-shell {
  gap: 0;
}


.image-create-editor {
  width: 100%;
  min-height: 0;
}

.image-create-panel-head {
  position: absolute;
  top: 10px;
  right: 12px;
  z-index: 2;
  display: flex;
  justify-content: flex-end;
  margin-bottom: 0;
  transition: opacity 0.18s ease;
}

#content-panel.content-panel-image-create.is-collapsed .image-create-panel-head {
  opacity: 0;
  pointer-events: none;
}

.image-create-billing-link {
  min-height: 30px;
  padding: 0 10px;
  margin-bottom: 0;
  border-radius: 10px;
  font-size: 12px;
}

.image-create-upload-area {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  width: 100%;
  min-width: 0;
  flex-shrink: 0;
  box-sizing: border-box;
  transition: opacity 0.18s ease, max-height 0.18s ease, margin 0.18s ease;
}

.image-create-upload-area.has-image {
}

#content-panel.content-panel-image-create.is-collapsed .image-create-upload-area {
  opacity: 0;
  max-height: 0;
  margin: 0;
  overflow: hidden;
  pointer-events: none;
}

.image-create-upload-rail {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  min-height: var(--upload-tile-size);
  width: 100%;
  max-width: 100%;
  min-width: 0;
  flex: 1 1 auto;
  overflow: hidden;
}

.image-create-upload-area .upload-thumbnails {
  flex-wrap: nowrap;
  gap: 6px;
  flex: 1;
  min-width: 0;
  overflow: hidden;
}

.image-create-prompt-wrap {
  width: 100%;
  flex: 0 0 auto;
  min-height: 80px;
  overflow: hidden;
  box-sizing: border-box;
}

.image-create-prompt-wrap textarea,
.image-create-prompt-wrap .prompt-editor,
.section-row-prompt textarea,
.section-row-prompt .prompt-editor {
  width: 100%;
  min-height: 56px;
  border: none;
  background: transparent;
  border-radius: 0;
  padding: 2px 0;
  font-size: 14px;
  line-height: 1.45;
  box-shadow: none;
  resize: none;
}

.image-create-prompt-wrap .prompt-editor,
.section-row-prompt .prompt-editor {
  outline: none;
  font-family: var(--font);
  color: var(--text);
  overflow-y: auto;
  word-wrap: break-word;
  white-space: pre-wrap;
}

.image-create-prompt-wrap .prompt-editor:empty::before,
.section-row-prompt .prompt-editor:empty::before {
  content: attr(data-placeholder);
  color: var(--text-tertiary);
  pointer-events: none;
}

.prompt-editor .mention {
  color: #eb645b;
}

#content-panel.content-panel-image-create.is-collapsed .image-create-prompt-wrap {
  opacity: 0;
  min-height: 0;
  max-height: 0;
  margin: 0;
  overflow: hidden;
  pointer-events: none;
  transition: opacity 0.18s ease, min-height 0.18s ease, max-height 0.18s ease, margin 0.18s ease;
}

.image-create-prompt-wrap .form-group {
  gap: 0;
  height: 100%;
  min-height: 0;
}

.image-create-prompt-wrap label,
.image-create-prompt-wrap .form-hint {
  display: none;
}

#content-panel.content-panel-custom-app .image-create-prompt-wrap {
  overflow: visible;
}
#content-panel.content-panel-custom-app .image-create-prompt-wrap .form-group {
  height: auto;
  min-height: auto;
}
#content-panel.content-panel-custom-app .image-create-prompt-wrap .prompt-editor,
#content-panel.content-panel-custom-app .image-create-prompt-wrap textarea {
  overflow-y: visible;
  border: 1px solid var(--divider);
  border-radius: 10px;
  padding: 10px 12px;
  min-height: 80px;
  background: var(--bg-input, rgba(118, 118, 128, 0.06));
  color: var(--text);
  font-size: 14px;
  line-height: 1.5;
}
#content-panel.content-panel-custom-app .image-create-prompt-wrap label {
  display: block;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-secondary);
  margin-bottom: 4px;
}

#content-panel.content-panel-custom-app .image-create-prompt-wrap .form-hint {
  display: block;
  font-size: 11px;
  color: var(--text-tertiary, #8e8e93);
  margin-bottom: 6px;
}

#content-panel.content-panel-custom-app .section-row .form-group textarea,
#content-panel.content-panel-custom-app .section-row .form-group input[type="text"],
#content-panel.content-panel-custom-app .section-row .form-group input[type="number"] {
  border: 1px solid var(--divider);
  border-radius: 10px;
  padding: 10px 12px;
  min-height: 42px;
  background: var(--bg-input, rgba(118, 118, 128, 0.06));
  color: var(--text);
  font-size: 14px;
}

.image-create-prompt-wrap textarea:focus,
.image-create-prompt-wrap .prompt-editor:focus {
  border: none;
  box-shadow: none;
}

.image-create-dock {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 6px;
  border-top: 1px solid var(--divider);
  margin-top: 0;
  padding: 10px 0 2px;
  flex-shrink: 0;
  transition: padding 0.18s ease, border-color 0.18s ease;
}

#content-panel.content-panel-image-create.is-collapsed .image-create-dock {
  padding-top: 0;
  border-top-color: transparent;
}

.image-create-dock-left {
  display: flex;
  align-items: center;
  gap: 6px;
  flex: 1;
  min-width: 0;
  flex-wrap: nowrap;
}

.image-create-variants {
  flex: 0 1 auto;
  width: 52%;
  min-width: 0;
}

.image-create-variants .model-selector {
  max-width: none;
  width: 100%;
}

.image-create-variants .model-selector-trigger {
  min-height: 42px;
  border-radius: 14px;
  padding: 7px 10px;
  background: transparent;
  gap: 6px;
}

.image-create-variants .model-selector-brand,
.image-create-variants .model-option-icon {
  width: 22px;
  height: 22px;
  border-radius: 7px;
  font-size: 12px;
}

.image-create-variants .model-selector-name,
.image-create-variants .model-option-name {
  font-size: 12px;
}

.image-create-variants .model-selector-label,
.image-create-variants .model-option-meta {
  font-size: 10px;
}

.image-create-size-trigger {
  min-height: 42px;
  min-width: 88px;
  border-radius: 14px;
  padding: 0 7px;
  border: 1px solid var(--divider);
  background: transparent;
  color: var(--text);
  display: inline-flex;
  align-items: center;
  gap: 5px;
  flex: 0 1 112px;
  margin-left: 0;
}

.image-create-size-icon {
  width: 14px;
  height: 10px;
  border: 1.5px solid currentColor;
  border-radius: 3px;
  opacity: 0.8;
}

.image-create-size-value {
  font-size: 12px;
  font-weight: 600;
}

.image-create-controls {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.image-create-controls .compact-control,
.section-row-controls .compact-control {
  min-width: 144px;
}

.image-create-controls .compact-control label {
  display: none;
}

#content-panel.content-panel-custom-app .image-create-controls .compact-control label {
  display: block;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-secondary);
  margin-bottom: 4px;
}

.image-create-controls .compact-control-input select,
.image-create-controls .compact-control-input input,
.section-row-controls .compact-control-input select,
.section-row-controls .compact-control-input input {
  min-height: 42px;
  border-radius: 14px;
  font-size: 13px;
  padding: 0 12px;
  background: transparent;
}

.image-create-dock-right {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.image-create-generate {
  min-height: 42px;
  padding: 0 6px 0 16px;
  border-radius: 14px;
  font-size: 14px;
  line-height: 1;
  background: var(--primary);
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: auto;
  border: none;
  cursor: pointer;
  transition: opacity 0.15s;
}

.image-create-generate:hover:not(:disabled) {
  opacity: 0.9;
}

.image-create-generate-price {
  font-size: 14px;
  font-weight: 600;
  white-space: nowrap;
  letter-spacing: 0.02em;
}

.image-create-generate-icon {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.18);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
}

.image-create-generate.is-loading .image-create-generate-icon {
  font-size: 0;
}

.image-create-generate.is-loading .image-create-generate-icon::before {
  content: '';
  display: block;
  width: 14px;
  height: 14px;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-top-color: #ffffff;
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
}

.at-mention-menu {
  position: fixed;
  z-index: 999;
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
  display: flex;
  flex-direction: row;
  gap: 3px;
  max-width: calc(100vw - 40px);
  overflow-x: auto;
  box-shadow: none;
}

.at-mention-item {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border-radius: 6px;
  border: none;
  background: transparent;
  cursor: pointer;
  transition: opacity 0.15s;
  line-height: 0;
}

.at-mention-item:hover {
  opacity: 0.8;
}

.at-mention-thumb {
  width: 56px;
  height: auto;
  max-height: 72px;
  border-radius: 6px;
  object-fit: contain;
  display: block;
}

.image-create-prompt-wrap textarea.drag-over,
.image-create-prompt-wrap .prompt-editor.drag-over {
  border-color: var(--primary);
  box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.25);
}

.image-create-inline-refs {
  display: flex;
  flex-direction: row;
  gap: 4px;
  padding: 4px 0 0;
  flex-wrap: wrap;
}

.inline-ref-item {
  display: inline-flex;
  border-radius: 6px;
  overflow: hidden;
  line-height: 0;
}

.inline-ref-thumb {
  width: 30px;
  height: 30px;
  object-fit: cover;
  display: block;
}

.image-create-size-panel {
  position: absolute;
  left: 0;
  bottom: calc(100% + 6px);
  width: min(540px, 100%);
  max-width: calc(100vw - 260px);
  max-height: min(220px, 34vh);
  overflow-y: auto;
  overflow-x: hidden;
  border: 1px solid var(--divider);
  background: var(--bg-panel);
  border-radius: 18px;
  padding: 9px;
  box-shadow: var(--shadow-lg);
  z-index: 21;
}

.image-create-size-columns {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 1px 104px;
  gap: 8px;
  align-items: start;
}

.image-create-size-column {
  min-width: 0;
}

.image-create-size-divider {
  width: 1px;
  align-self: stretch;
  background: var(--divider);
}

.image-create-size-title {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-secondary);
  margin-bottom: 6px;
}

#image-create-quick-action-panel .image-create-size-columns {
  grid-template-columns: 1fr;
}

#image-create-quick-action-panel .image-create-size-grid {
  grid-template-columns: repeat(2, 1fr);
}

.image-create-size-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}

.image-create-size-option,
.image-create-resolution-option {
  min-height: 36px;
  border-radius: 11px;
  border: 1px solid var(--divider);
  background: rgba(120, 128, 148, 0.08);
  color: var(--text);
  font-size: 11px;
  font-weight: 600;
}

.image-create-size-option:disabled {
  opacity: 0.35;
  cursor: default;
}

.image-create-size-option:hover,
.image-create-resolution-option:hover,
.image-create-size-trigger:hover,
.image-create-size-option.active,
.image-create-resolution-option.active {
  border-color: var(--primary);
  background: var(--primary-light);
}

.image-create-resolution-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
}

.image-create-resolution-option {
  min-height: 38px;
}

@media (max-width: 820px) {
  .image-create-editor {
    min-height: 260px;
  }

  .image-create-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .image-create-kicker {
    font-size: 20px;
  }

  .image-create-bill-link {
    width: 100%;
  }

  .image-create-upload-area {
    flex-direction: column;
  }

  .image-create-upload-rail {
    flex-wrap: nowrap;
  }

  .image-create-prompt-wrap textarea,
  .image-create-prompt-wrap .prompt-editor {
    min-height: 180px;
  }

  .image-create-dock {
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
  }

  .image-create-dock-left {
    width: 100%;
    flex-wrap: wrap;
    flex: 1 1 100%;
  }

  .image-create-variants {
    flex: 1 1 100%;
    min-width: 0;
  }

  .image-create-size-trigger {
    min-width: 104px;
    flex: 0 0 auto;
  }

  .image-create-size-panel {
    width: min(300px, 100%);
    max-width: calc(100vw - 72px);
    left: 0;
  }

  .image-create-size-columns {
    grid-template-columns: 1fr;
  }

  .image-create-size-divider {
    display: none;
  }

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

  .image-create-resolution-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .model-selector-menu {
    width: min(240px, calc(100vw - 72px));
    left: 0;
  }

  .image-create-dock-right {
    margin-left: auto;
  }
}

/* ===== 设置 ===== */
.input-with-action {
  display: flex;
  align-items: center;
  gap: 8px;
}

.input-with-action > input {
  flex: 1;
}

.input-action {
  flex-shrink: 0;
}

#toggle-consumer-api-key,
#toggle-shared-api-key,
#toggle-google-translate-api-key,
#toggle-llm-api-key,
#toggle-feishu-app-secret {
  color: var(--text-secondary);
  background: var(--bg-secondary);
  border: 1px solid var(--divider);
  padding: 0;
  width: 38px;
  height: 38px;
  border-radius: 12px;
}

#toggle-consumer-api-key svg,
#toggle-shared-api-key svg,
#toggle-google-translate-api-key svg,
#toggle-llm-api-key svg,
#toggle-feishu-app-secret svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

#toggle-consumer-api-key:hover,
#toggle-shared-api-key:hover,
#toggle-google-translate-api-key:hover,
#toggle-llm-api-key:hover,
#toggle-feishu-app-secret:hover {
  background: var(--bg-secondary);
  color: var(--text);
  border-color: var(--primary);
}

#toggle-consumer-api-key:focus-visible,
#toggle-shared-api-key:focus-visible,
#toggle-google-translate-api-key:focus-visible,
#toggle-llm-api-key:focus-visible,
#toggle-feishu-app-secret:focus-visible,
.custom-app-card:focus-visible,
.custom-app-back:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.google-translate-key-help {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.google-translate-key-help .form-hint {
  margin: 0;
}

.google-translate-key-help-trigger {
  min-width: 112px;
  padding: 8px 14px;
  font-size: 12px;
}

/* ===== 弹窗 ===== */
.modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.4);
  backdrop-filter: blur(4px);
}

#image-preview-modal .modal-backdrop {
  background: rgba(0, 0, 0, 0.62);
  backdrop-filter: blur(18px) saturate(0.72);
  -webkit-backdrop-filter: blur(18px) saturate(0.72);
}

.modal-content {
  position: relative;
  background: var(--bg);
  border-radius: var(--radius);
  padding: 28px;
  width: 440px;
  max-width: 90vw;
  box-shadow: var(--shadow-lg);
  z-index: 1;
}

.modal-content h3 {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 20px;
}

.modal-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 24px;
}

.settings-content > .modal-actions {
  justify-content: space-between;
}

.modal-actions-main {
  display: flex;
  align-items: center;
  gap: 10px;
}


.settings-content {
  max-height: calc(100vh - 80px);
  overflow-y: auto;
}

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

.modal-header h3 {
  margin: 0;
}

.modal-header-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}

.modal-close-btn {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  padding: 0;
  border-radius: 6px;
  border: none;
  background: transparent;
  color: var(--text-secondary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s;
}

.modal-close-btn:hover {
  background: var(--bg-tertiary);
  color: var(--text);
}

.modal-close-btn svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
}

.settings-content .form-group {
  margin-bottom: 14px;
}

.google-translate-tutorial-content {
  width: min(560px, 92vw);
  max-height: calc(100vh - 80px);
  overflow-y: auto;
}

.google-translate-tutorial-intro {
  margin-bottom: 10px;
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-secondary);
}

.google-translate-tutorial-steps {
  margin: 0;
  padding-left: 20px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  color: var(--text);
  font-size: 13px;
  line-height: 1.6;
}

.google-translate-tutorial-tip {
  margin-top: 12px;
  padding: 10px 14px;
  border: 1px solid var(--divider);
  border-radius: 12px;
  background: var(--bg-secondary);
}

.google-translate-tutorial-tip strong {
  display: block;
  margin-bottom: 6px;
  font-size: 13px;
}

.google-translate-tutorial-tip ul {
  margin: 0;
  padding-left: 18px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  color: var(--text-secondary);
  font-size: 12px;
  line-height: 1.55;
}

.google-translate-tutorial-inline-link {
  color: var(--primary);
  font-weight: 700;
  text-decoration: none;
}

.google-translate-tutorial-inline-link:hover {
  text-decoration: underline;
}

/* ===== 历史素材选择弹窗 ===== */
.history-file-picker-content {
  width: min(640px, 92vw);
  max-height: calc(100vh - 80px);
  overflow-y: auto;
}

.history-file-picker-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  max-height: 380px;
  overflow-y: auto;
  padding: 2px;
}

.history-file-picker-item {
  position: relative;
  aspect-ratio: 1;
  border-radius: 10px;
  overflow: hidden;
  border: 2px solid transparent;
  background: var(--bg-secondary);
  cursor: pointer;
  transition: border-color 0.15s, opacity 0.15s;
}

.history-file-picker-item:hover {
  border-color: var(--primary);
}

.history-file-picker-item.selected {
  border-color: var(--primary);
  box-shadow: 0 0 0 2px var(--primary-light);
}

.history-file-picker-item.unsupported {
  opacity: 0.45;
  cursor: not-allowed;
}

.history-file-picker-item.unsupported:hover {
  border-color: transparent;
}

.history-file-picker-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.history-file-picker-badge {
  position: absolute;
  bottom: 6px;
  left: 6px;
  padding: 2px 6px;
  border-radius: 4px;
  background: rgba(0,0,0,0.6);
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  line-height: 1.4;
}

.history-file-picker-unsupported-tag {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.35);
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  pointer-events: none;
}

.history-file-picker-check {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--primary);
  color: #fff;
  font-size: 12px;
  display: none;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.history-file-picker-item.selected .history-file-picker-check {
  display: flex;
}

/* ===== 设置-虚拟数字人上传 ===== */
.settings-digital-human-upload {
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 4;
  max-height: 173px;
  border: 2px dashed var(--divider);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  overflow: hidden;
  background: var(--bg-secondary);
  transition: border-color 0.15s;
}

.settings-digital-human-upload:hover {
  border-color: var(--primary);
}

.settings-digital-human-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  color: var(--text-muted);
  pointer-events: none;
}

.settings-digital-human-placeholder-icon {
  font-size: 32px;
  font-weight: 200;
  line-height: 1;
  color: var(--text-muted);
}

.settings-digital-human-placeholder-text {
  font-size: 13px;
}

.settings-digital-human-thumb {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: var(--bg-secondary);
}

.settings-digital-human-remove {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 22px;
  height: 22px;
  padding: 0;
  font-size: 12px;
  line-height: 1;
  background: rgba(0,0,0,0.55);
  color: #fff;
  border: none;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  transition: background 0.15s;
}

.settings-digital-human-remove:hover {
  background: rgba(0,0,0,0.78);
}

/* ===== 图片预览弹窗 ===== */
.image-preview-content {
  position: relative;
  z-index: 1;
  width: min(96vw, 1440px);
  height: min(92vh, 860px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 360px);
  gap: 20px;
  align-items: stretch;
}

.image-preview-stage {
  position: relative;
  min-width: 0;
  min-height: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.image-preview-media-frame {
  width: 100%;
  height: 100%;
  min-width: 0;
  min-height: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.image-preview-content img,
.image-preview-content video {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border-radius: 20px;
  box-shadow: var(--shadow-lg);
  background: #fff;
  transform-origin: center center;
  will-change: transform;
}

.image-preview-content img.grab {
  cursor: grab;
}

.image-preview-content img.grabbing {
  cursor: grabbing;
}

.image-preview-audio-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(720px, 100%);
  max-width: 100%;
  min-height: 360px;
  padding: 60px 40px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.08), rgba(99, 102, 241, 0.02));
  box-shadow: var(--shadow-lg);
}
.image-preview-audio-wrap audio {
  width: 100%;
  max-width: 560px;
}
.image-preview-audio-wrap.hidden {
  display: none;
}

.image-preview-cost {
  color: rgba(255, 255, 255, 0.96);
}

.image-preview-side-panel {
  min-width: 0;
  min-height: 0;
  max-height: min(88vh, 860px);
  align-self: center;
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 16px 28px 28px;
  border-radius: 20px;
  background: rgba(17, 19, 24, 0.92);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: var(--shadow-lg);
  color: rgba(255, 255, 255, 0.88);
  overflow: hidden;
}

.image-preview-side-actions {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  min-height: 28px;
}

.image-preview-action-spacer {
  flex: 1 1 auto;
}

.image-preview-side-actions button {
  width: 28px;
  height: 28px;
  padding: 0;
  font-size: 15px;
  line-height: 1;
  background: transparent;
  color: rgba(255,255,255,0.72);
  border: none;
  border-radius: 8px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, color 0.15s;
}

.image-preview-side-actions button:hover,
.image-preview-use-prompt:hover {
  background: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.96);
}

.image-preview-side-actions button svg {
  width: 17px;
  height: 17px;
  stroke: currentColor;
  stroke-width: 1.5;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.image-preview-side-divider {
  height: 1px;
  background: rgba(255,255,255,0.1);
}

.image-preview-side-section {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

#image-preview-prompt-section {
  flex: 1 1 auto;
  min-height: 0;
}

.image-preview-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.image-preview-section-title {
  color: rgba(255,255,255,0.44);
  font-size: 14px;
  font-weight: 600;
}

.image-preview-use-prompt {
  min-height: 28px;
  padding: 0 10px;
  border: none;
  border-radius: 8px;
  background: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.68);
  cursor: pointer;
  font-size: 12px;
}

.image-preview-prompt-text {
  min-height: 0;
  max-height: 420px;
  overflow-y: auto;
  padding-right: 6px;
  color: rgba(255,255,255,0.78);
  font-size: 14px;
  line-height: 1.65;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.image-preview-info {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 16px;
  border-radius: 14px;
  background: rgba(255,255,255,0.035);
  color: rgba(255, 255, 255, 0.76);
  font-size: 13px;
  line-height: 1.45;
}

.image-preview-meta-line {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 12px;
}

.image-preview-meta-line span {
  color: rgba(255,255,255,0.42);
}

.image-preview-meta-line strong {
  min-width: 0;
  color: rgba(255,255,255,0.82);
  font-weight: 500;
  overflow-wrap: anywhere;
}

#image-preview-badge {
  color: #eb645b;
}

.image-preview-close,
.image-preview-nav {
  position: absolute;
  border: none;
  cursor: pointer;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  color: rgba(255, 255, 255, 0.96);
  background: rgba(17, 19, 24, 0.48);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.18);
  transition: background 0.15s ease, transform 0.15s ease, opacity 0.15s ease;
}

.image-preview-close:hover,
.image-preview-nav:hover {
  background: rgba(255, 255, 255, 0.14);
}

.image-preview-nav:hover {
  transform: translateY(calc(-50% - 1px));
}

.image-preview-close svg,
.image-preview-nav svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.image-preview-close {
  position: static;
  width: 34px;
  height: 34px;
  border-radius: 999px;
}

.image-preview-nav {
  top: 50%;
  transform: translateY(-50%);
  width: 46px;
  height: 46px;
  border-radius: 999px;
}

.image-preview-nav:hover {
  transform: translateY(calc(-50% - 1px));
}

#image-preview-prev {
  left: 18px;
}

#image-preview-next {
  right: 18px;
}

.image-preview-reference-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.image-preview-reference-grid img {
  width: 36px;
  height: 36px;
  object-fit: cover;
  border-radius: 4px;
  box-shadow: none;
  background: var(--bg-secondary);
}

@media (max-width: 860px) {
  .image-preview-content {
    grid-template-columns: minmax(0, 1fr) 300px;
    gap: 12px;
  }
  .image-preview-side-panel {
    padding: 20px;
  }
}

/* ===== 结果展示 ===== */
.history-shell {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

#content.content-custom-app-layout #content-result .history-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

#content.content-custom-app-layout #content-panel.content-panel-image-create + #content-result {
  overflow-y: scroll;
}

#content.content-custom-app-layout #content-panel.content-panel-image-create + #content-result .history-shell {
  display: flex;
  flex-direction: column;
  min-height: 0;
}

#content.content-custom-app-layout #content-panel.content-panel-image-create + #content-result .history-scroll-spacer {
  flex: none;
  height: 0;
}

.history-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.history-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
}

.history-subtitle {
  margin-top: 2px;
  font-size: 11px;
  color: var(--text-muted);
}

.history-toolbar {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.history-toolbar-btn {
  padding: 6px 10px;
  font-size: 11px;
  background: var(--bg-secondary);
  border: 1px solid var(--divider);
  color: var(--text);
}

.history-toolbar-btn.danger {
  background: rgba(239, 68, 68, 0.08);
  border-color: rgba(239, 68, 68, 0.2);
  color: var(--danger);
}

.history-toolbar-btn:disabled {
  opacity: 0.45;
}

.history-status {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 14px;
  background: var(--bg);
  border: 1px solid var(--divider);
  color: var(--text-secondary);
}

.history-status.running {
  background: rgba(99, 102, 241, 0.06);
  border-color: rgba(99, 102, 241, 0.18);
}

.history-status.error {
  background: rgba(239, 68, 68, 0.06);
  border-color: rgba(239, 68, 68, 0.18);
  color: var(--danger);
}

.history-empty {
  padding: 32px 0;
  text-align: center;
  color: var(--text-muted);
  font-size: 14px;
}

.history-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  align-items: start;
}

.history-grid-image {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.history-row {
  display: flex;
  flex-wrap: nowrap;
  gap: 4px;
}

#content-result .history-grid:last-child {
  margin-bottom: 0;
}

.history-grid-running {
  margin-bottom: 0;
}

.history-tile-image {
  position: relative;
  height: 160px;
  flex: 0 0 auto;
  border-radius: 10px;
  overflow: hidden;
  background: var(--bg-secondary);
  box-shadow: var(--shadow);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.history-tile-image:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

.history-tile-image.selected {
  box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.18), var(--shadow-lg);
}

.history-tile-image-media {
  position: relative;
  height: 100%;
  width: 100%;
  background: var(--bg-secondary);
}

.history-tile-image-media img,
.history-tile-image-video {
  height: 100%;
  width: 100%;
  object-fit: cover;
  display: block;
  cursor: grab;
  background: linear-gradient(110deg,
    var(--bg-secondary) 25%,
    rgba(235, 100, 91, 0.18) 45%,
    rgba(235, 100, 91, 0.09) 55%,
    var(--bg-secondary) 75%);
  background-size: 200% 100%;
  animation: history-shimmer 2s ease-in-out infinite;
}

.history-tile-image-media img.img-loaded,
.history-tile-image-video.img-loaded {
  background: transparent;
  animation: none;
}

.history-tile-image-media img.is-dragging,
.history-card-media img.is-dragging {
  cursor: grabbing;
  opacity: 0.6;
}

.history-tile-image-file {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  height: 100%;
  padding: 16px;
  text-align: center;
}

.history-tile-image:has(.is-audio),
.history-card:has(.is-audio) {
  box-shadow: none !important;
}

.history-tile-image-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 14px;
  background: linear-gradient(180deg, rgba(17, 19, 24, 0.64) 0%, rgba(17, 19, 24, 0.16) 36%, rgba(17, 19, 24, 0.82) 100%);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.18s ease;
}

.history-tile-image:hover .history-tile-image-overlay,
.history-tile-image:focus-within .history-tile-image-overlay {
  opacity: 1;
}

.history-tile-image .history-card-cost {
  opacity: 0;
  transition: opacity 0.18s ease;
}

.history-tile-image:hover .history-card-cost,
.history-tile-image:focus-within .history-card-cost,
.history-tile-image .history-select-toggle {
  opacity: 1;
}

.history-tile-image-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
  margin-left: auto;
  max-width: 100%;
  pointer-events: auto;
}

.history-tile-image-actions button {
  flex: 0 0 auto;
  width: 24px;
  height: 24px;
  padding: 0;
  font-size: 12px;
  font-weight: 300;
  line-height: 1;
  background: rgba(255,255,255,0.92);
  color: #111827;
  border-radius: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.history-tile-image-actions button svg {
  width: 14px;
  height: 14px;
  stroke: currentColor;
  stroke-width: 1.5;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.history-tile-image-info {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  max-width: 100%;
  color: rgba(255, 255, 255, 0.96);
  pointer-events: none;
}

.history-tile-image-line {
  max-width: 100%;
  font-size: 12px;
  line-height: 1.35;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.38);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  word-break: break-word;
}


.history-tile-image-running {
  border: 1px dashed rgba(245, 158, 11, 0.3);
}

.history-tile-image-running.is-error {
  border-color: rgba(239, 68, 68, 0.28);
}

.history-tile-image-running .history-card-cost,
.history-tile-image-running .history-select-toggle,
.history-tile-image-running .history-tile-image-overlay,
.history-tile-image-running .history-tile-image-info {
  display: none !important;
}

.history-tile-image-running-media {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  background: linear-gradient(180deg, rgba(251, 191, 36, 0.18), rgba(245, 158, 11, 0.08) 52%, rgba(245, 158, 11, 0.03) 100%);
  position: relative;
}

.history-cancel-btn {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 24px;
  height: 24px;
  padding: 0;
  border: none;
  border-radius: 6px;
  background: rgba(0,0,0,0.45);
  color: rgba(255,255,255,0.9);
  font-size: 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  transition: background 0.15s;
}

.history-cancel-btn:hover {
  background: rgba(239, 68, 68, 0.7);
}

.history-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  border: 1px solid var(--divider);
  border-radius: 18px;
  overflow: hidden;
  background: var(--bg);
  box-shadow: var(--shadow);
  grid-column: span 2;
}

.history-card.selected {
  border-color: var(--primary);
  box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.12);
}

.history-card-media {
  position: relative;
  aspect-ratio: 16 / 9;
  background: var(--bg-secondary);
}

.history-card-running {
  border-style: dashed;
}

.history-card-running.is-error {
  border-color: rgba(239, 68, 68, 0.28);
}

.history-card-running-media {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px;
  background: linear-gradient(180deg, rgba(99, 102, 241, 0.08), rgba(99, 102, 241, 0.02));
}

.history-running-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  width: 100%;
  height: 100%;
  text-align: center;
}

.history-running-status {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-secondary);
}

.history-running-icon {
  width: 42px;
  height: 42px;
  border-radius: 999px;
  background: rgba(239, 68, 68, 0.1);
  color: var(--danger);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  line-height: 1;
}

.history-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  cursor: grab;
  display: block;
  background: linear-gradient(110deg,
    var(--bg-secondary) 25%,
    rgba(235, 100, 91, 0.18) 45%,
    rgba(235, 100, 91, 0.09) 55%,
    var(--bg-secondary) 75%);
  background-size: 200% 100%;
  animation: history-shimmer 2s ease-in-out infinite;
}

.history-card-media img.img-loaded {
  background: transparent;
  animation: none;
}

@keyframes history-shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

.history-card-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  background: #000;
}

.history-card-video-badge {
  position: absolute;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
  width: 36px;
  height: 36px;
  border-radius: 999px;
  background: rgba(17, 19, 24, 0.66);
  color: rgba(255, 255, 255, 0.96);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  line-height: 1;
  pointer-events: none;
}

.history-card-file {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  height: 100%;
  padding: 12px;
  text-align: center;
  background: var(--bg-secondary);
}

.history-card-file-icon {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(99, 102, 241, 0.12);
  color: var(--primary);
  font-size: 18px;
}

.history-card-file-label {
  width: 100%;
  font-size: 11px;
  line-height: 1.35;
  color: var(--text-secondary);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  word-break: break-all;
}

.history-card-overlay {
  position: absolute;
  inset: 0 0 auto 0;
  display: flex;
  justify-content: flex-end;
  gap: 6px;
  padding: 10px;
  background: linear-gradient(rgba(17, 19, 24, 0.56), transparent);
  opacity: 0;
  transition: opacity 0.15s;
}

.history-card-cost {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  max-width: calc(100% - 20px);
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(17, 19, 24, 0.68);
  color: rgba(255, 255, 255, 0.98);
  font-size: 10px;
  font-weight: 600;
  line-height: 1;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.history-card-media-info {
  position: absolute;
  left: 10px;
  bottom: 10px;
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 3px;
  max-width: calc(100% - 20px);
  z-index: 1;
  pointer-events: none;
}

.history-card-media-meta,
.history-card-media-time {
  font-size: 10px;
  line-height: 1.2;
  color: rgba(255, 255, 255, 0.96);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

.history-card:hover .history-card-overlay {
  opacity: 1;
}

.history-card-overlay button {
  flex: 0 0 auto;
  padding: 4px 7px;
  font-size: 10px;
  font-weight: 300;
  background: rgba(255,255,255,0.92);
  color: #111827;
}

.history-card-overlay button.btn-sending {
  opacity: 0.7;
}

.btn-sending-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--primary, #eb645b);
  margin-left: 4px;
  animation: btn-dot-pulse 0.8s ease-in-out infinite;
  vertical-align: middle;
}

@keyframes btn-dot-pulse {
  0%, 100% { opacity: 0.3; transform: scale(0.8); }
  50% { opacity: 1; transform: scale(1.2); }
}

.history-card-meta {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 6px 10px 5px;
}

.history-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  min-width: 0;
}

.history-card-badge {
  flex: 1 1 auto;
  min-width: 0;
  font-size: 10px;
  color: var(--primary);
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.history-card-prompt-row {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  min-width: 0;
}

.history-card-prompt {
  flex: 1 1 auto;
  min-width: 0;
  font-size: 11px;
  color: var(--text);
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.history-card-prompt-action {
  flex: 0 0 auto;
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  border: 1px solid var(--divider);
  background: var(--bg-secondary);
  color: var(--text-secondary);
  font-size: 9px;
  font-weight: 600;
  white-space: nowrap;
}

.history-card-prompt-action:hover,
.history-card-prompt-action:focus-visible {
  border-color: rgba(99, 102, 241, 0.24);
  color: var(--text);
  background: rgba(99, 102, 241, 0.06);
}

.history-card-info {
  font-size: 11px;
  color: var(--text-muted);
}

.history-select-toggle {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
  width: 28px;
  height: 28px;
  padding: 0;
  border-radius: 999px;
  background: rgba(255,255,255,0.92);
  color: var(--text-secondary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.history-select-toggle.selected {
  background: var(--primary);
  color: #fff;
}

.result-empty {
  text-align: center;
  color: var(--text-muted);
  padding: 32px 0;
  font-size: 14px;
}

.result-status {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 24px 0;
  color: var(--text-secondary);
}

.result-images {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.result-image-wrapper {
  position: relative;
  width: 140px;
  height: 140px;
  border-radius: var(--radius-sm);
  overflow: hidden;
  border: 1px solid var(--divider);
  background: #fff;
}

.result-image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  cursor: zoom-in;
}

.result-image-actions {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 6px;
  background: linear-gradient(transparent, rgba(0,0,0,0.6));
  display: flex;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.15s;
}

.result-image-wrapper:hover .result-image-actions {
  opacity: 1;
}

.result-image-actions button {
  padding: 4px 12px;
  font-size: 12px;
  background: #fff;
  color: var(--text);
  border: none;
  border-radius: 4px;
  cursor: pointer;
  font-weight: 600;
}

.result-image-actions button:hover {
  background: var(--primary);
  color: #fff;
}

/* ===== Toast ===== */
.toast {
  position: fixed;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(0,0,0,0.8);
  color: #fff;
  padding: 10px 24px;
  border-radius: 20px;
  font-size: 13px;
  z-index: 2000;
  pointer-events: none;
  transition: opacity 0.2s;
}

.creator-footer .btn-generate {
  width: auto;
  min-width: 180px;
  padding: 14px 24px;
}

@media (max-width: 1100px) {
  .creator-footer {
    flex-direction: column;
    align-items: stretch;
  }

  .creator-footer .btn-generate {
    width: 100%;
  }

  .translate-footer {
    flex-direction: row;
    align-items: center;
  }

  .translate-footer-action {
    margin-left: auto;
  }

  .translate-footer .translate-generate {
    width: 44px !important;
    min-width: 44px !important;
  }

  .control-grid {
    grid-template-columns: 1fr;
  }

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

  .history-card-overlay,
  .history-tile-image-actions {
    flex-wrap: wrap;
  }

  .history-card-prompt-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
}

@media (max-width: 920px) {
  .history-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

}

@media (max-width: 720px) {
  .history-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* ===== Spinner ===== */
.spinner {
  width: 20px;
  height: 20px;
  border: 2px solid var(--divider);
  border-top-color: var(--primary);
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
  display: inline-block;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* ===== 常用链接页面 ===== */
#content-panel.content-panel-quick-links {
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding-bottom: 20px;
  overflow-y: auto;
}

.quick-links-page {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.quick-links-section {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.quick-links-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.quick-links-section-title {
  margin: 0;
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.3;
}

.quick-link-add-btn {
  padding: 4px 10px;
  border: 1px solid var(--divider);
  border-radius: 6px;
  background: var(--bg-secondary);
  color: var(--text-secondary);
  font-size: 12px;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
  line-height: 1.4;
}

.quick-link-add-btn:hover {
  background: var(--primary-light);
  color: var(--primary);
  border-color: var(--primary);
}

/* 3 列卡片网格 */
.quick-links-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.quick-links-empty {
  grid-column: 1 / -1;
  padding: 18px 0;
  text-align: center;
  color: var(--text-muted);
  font-size: 12px;
}

/* 链接卡片 — 与自建应用卡片风格一致 */
.quick-link-card {
  height: 62px;
  padding: 0;
  border: 1px solid rgba(235, 100, 91, 0.2);
  border-radius: 10px;
  background: linear-gradient(135deg, rgba(235, 100, 91, 0.3), rgba(235, 100, 91, 0.55));
  overflow: hidden;
  text-align: left;
  box-shadow: var(--shadow);
  display: grid;
  grid-template-columns: 60px minmax(0, 1fr);
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
  text-decoration: none;
  cursor: pointer;
  position: relative;
}

.quick-link-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
  border-color: var(--primary);
}

.quick-link-card:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.quick-link-card-user {
  grid-template-columns: 60px minmax(0, 1fr) auto;
}

/* 推荐链接用另一种色调区分 */
.quick-link-card-rec {
  background: linear-gradient(135deg, rgba(124, 100, 235, 0.3), rgba(124, 100, 235, 0.55));
  border-color: rgba(124, 100, 235, 0.2);
}

/* 封面区域 */
.quick-link-card-cover {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  height: 100%;
  background: linear-gradient(135deg, rgba(235, 100, 91, 0.96), rgba(164, 54, 47, 0.9));
  color: #ffffff;
}

.quick-link-card-rec .quick-link-card-cover {
  background: linear-gradient(135deg, rgba(124, 100, 235, 0.94), rgba(88, 68, 197, 0.88));
}

.quick-link-card-cover-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.quick-link-card-cover-empty {
  font-size: 16px;
  opacity: 0.8;
}

.quick-link-card-body {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 2px;
  min-width: 0;
  padding: 8px 10px;
}

.quick-link-card-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.quick-link-card-desc {
  font-size: 10px;
  font-weight: 300;
  color: var(--text-muted);
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* 编辑/删除按钮（hover 显示） */
.quick-link-card-actions {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
  opacity: 0;
  transition: opacity 0.15s;
}

.quick-link-card:hover .quick-link-card-actions {
  opacity: 1;
}

.quick-link-edit-btn,
.quick-link-delete-btn {
  width: 24px;
  height: 24px;
  padding: 0;
  border: none;
  border-radius: 6px;
  background: transparent;
  color: var(--text-muted);
  font-size: 12px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, color 0.15s;
  line-height: 1;
}

.quick-link-edit-btn:hover {
  background: var(--primary-light);
  color: var(--primary);
}

.quick-link-delete-btn:hover {
  background: rgba(240, 68, 56, 0.12);
  color: var(--danger);
}

/* 内联添加/编辑表单 */
.quick-link-inline-form {
  margin-top: 4px;
}

.quick-link-form-card {
  padding: 10px;
  border: 1px solid var(--primary);
  border-radius: 10px;
  background: var(--bg-secondary);
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.quick-link-form-row {
  display: flex;
  gap: 8px;
}

/* 封面上传 */
.quick-link-form-cover {
  width: 60px;
  height: 60px;
  min-width: 60px;
  border: 1px dashed var(--divider);
  border-radius: 6px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  cursor: pointer;
  overflow: hidden;
  transition: border-color 0.15s, background 0.15s;
  position: relative;
}

.quick-link-form-cover:hover {
  border-color: var(--primary);
  background: rgba(235, 100, 91, 0.04);
}

.quick-link-form-cover-placeholder {
  font-size: 16px;
  color: var(--text-muted);
  line-height: 1;
}

.quick-link-form-cover-label {
  font-size: 9px;
  color: var(--text-muted);
}

.quick-link-form-cover-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.quick-link-form-fields {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.quick-link-form-input {
  flex: 1;
  min-width: 0;
  padding: 6px 8px;
  border: 1px solid var(--divider);
  border-radius: 6px;
  background: var(--bg);
  color: var(--text);
  font-size: 12px;
  font-family: var(--font);
  outline: none;
  transition: border-color 0.15s;
}

.quick-link-form-input:focus {
  border-color: var(--primary);
}

.quick-link-form-actions {
  display: flex;
  gap: 6px;
  justify-content: flex-end;
}

.quick-link-form-submit {
  padding: 5px 14px;
  border: none;
  border-radius: 6px;
  background: var(--primary);
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.15s;
  line-height: 1.4;
}

.quick-link-form-submit:hover {
  opacity: 0.88;
}

.quick-link-form-cancel {
  padding: 5px 14px;
  border: 1px solid var(--divider);
  border-radius: 6px;
  background: transparent;
  color: var(--text-secondary);
  font-size: 12px;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
  line-height: 1.4;
}

.quick-link-form-cancel:hover {
  background: var(--bg);
  color: var(--text);
}

/* ===== 音乐创作面板（扁平化设计） ===== */
#content-panel.content-panel-music-create {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: auto;
  overflow: visible;
  padding-bottom: 20px;
}

.music-create-shell {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.music-create-bottom {
  display: flex;
  gap: 20px;
  min-height: 480px;
  min-width: 0;
}

.music-create-bottom > .music-lyrics-panel,
.music-create-bottom > .music-melody-panel {
  flex: 1 1 50%;
}

/* 顶部灵感区（卡片容器） */
.music-create-top {
  display: flex;
  gap: 12px;
  flex: 1;
  min-width: 0;
  padding: 12px;
  background: var(--bg-panel);
  border: 1px solid var(--divider);
  border-radius: 10px;
}

.music-create-top-row {
  display: flex;
  gap: 12px;
}

/* 流程状态栏 */
.music-status-bar {
  padding: 48px 0 8px;
  flex-shrink: 0;
}

.music-model-row {
  display: flex;
  justify-content: center;
  padding: 30px 0 8px;
}
.music-model-row .music-model-picker,
.music-model-row .music-model-empty {
  margin-left: 0;
}
.music-status-steps {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin: 0 auto;
}
.music-status-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 4px 6px;
  border: none;
  border-radius: var(--radius-sm);
  background: transparent;
  cursor: pointer;
  transition: background 0.15s;
}
.music-status-step:hover {
  background: var(--bg-secondary);
}
.music-status-step.disabled {
  cursor: not-allowed;
  opacity: 0.45;
  pointer-events: auto;
}
.music-status-step.disabled:hover {
  background: transparent;
}
.music-status-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--divider);
  transition: background 0.3s, box-shadow 0.3s;
}
.music-status-step.done .music-status-dot {
  background: var(--success);
  box-shadow: 0 0 8px rgba(18, 183, 106, 0.4);
}
.music-status-step.disabled .music-status-dot {
  background: var(--divider);
  box-shadow: none;
}
.music-status-step.disabled .music-status-label {
  color: var(--text-muted);
}
.music-status-step.active .music-status-dot {
  background: var(--primary);
  box-shadow: 0 0 12px rgba(235, 100, 91, 0.6);
  animation: status-pulse 0.8s ease-in-out infinite;
}
.music-status-label {
  font-size: 10px;
  color: var(--text-muted);
  transition: color 0.3s;
  white-space: nowrap;
}
.music-status-step.done .music-status-label {
  color: var(--text-secondary);
}
.music-status-step.active .music-status-label {
  color: var(--primary);
  font-weight: 600;
}
.music-status-line {
  width: 36px;
  height: 1.5px;
  background: var(--divider);
  margin: 0 1px;
  transition: background 0.3s;
  flex-shrink: 0;
  transform: translateY(-10px);
}
.music-status-line.complete {
  background: var(--success);
}

@keyframes status-pulse {
  0%, 100% { transform: scale(1); box-shadow: 0 0 8px rgba(235, 100, 91, 0.5); }
  50% { transform: scale(1.35); box-shadow: 0 0 20px rgba(235, 100, 91, 0.8); }
}

/* 谱曲分组框（风格 + 演唱） */
.music-status-melody-group {
  display: flex;
  position: relative;
  align-items: center;
  gap: 0;
  border: 2px solid transparent;
  border-radius: var(--radius-md, 10px);
  padding: 6px 6px 2px;
  transition: border-color 0.3s, box-shadow 0.3s;
}

/* 谱曲分组框有内容后显示边框 */
.music-status-melody-group.visible {
  border-color: var(--divider);
}

/* 谱曲标签 */
.music-status-melody-label {
  display: none;
  position: absolute;
  top: -9px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 10px;
  font-weight: 600;
  padding: 0 4px;
  color: var(--text-muted);
  background: var(--bg-primary, #1a1a2e);
  transition: color 0.3s;
  white-space: nowrap;
}

/* 有内容后显示标签 */
.music-status-melody-group.visible .music-status-melody-label,
.music-status-melody-group.active .music-status-melody-label,
.music-status-melody-group.done .music-status-melody-label {
  display: block;
}

/* 谱曲任一项执行中 → 红色边框闪烁，标签红色 */
.music-status-melody-group.active {
  border-color: var(--primary);
  animation: melody-border-pulse 0.8s ease-in-out infinite;
}
.music-status-melody-group.active .music-status-melody-label {
  color: var(--primary);
}

/* 谱曲两项均完成 → 绿色边框，标签绿色 */
.music-status-melody-group.done {
  border-color: var(--success);
  box-shadow: 0 0 8px rgba(18, 183, 106, 0.2);
}
.music-status-melody-group.done .music-status-melody-label {
  color: var(--success);
}

@keyframes melody-border-pulse {
  0%, 100% { border-color: var(--primary); box-shadow: 0 0 8px rgba(235, 100, 91, 0.3); }
  50% { border-color: rgba(235, 100, 91, 0.4); box-shadow: 0 0 16px rgba(235, 100, 91, 0.5); }
}

/* ===== 成曲方式选择浮层（hover 成曲按钮时显示） ===== */
.music-song-mode-popup {
  position: fixed;
  z-index: 99999;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.45);
  opacity: 0;
  transform: translateY(4px) scale(0.95);
  transition: opacity 0.2s ease, transform 0.2s ease;
  pointer-events: none;
}
.music-song-mode-popup.show {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}
.music-song-auto-open {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  color: var(--text-muted);
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
}
.music-song-auto-open[hidden] {
  display: none !important;
}
.music-song-auto-open input {
  position: relative;
  flex: 0 0 14px;
  width: 14px;
  height: 14px;
  border: 1px solid rgba(226, 232, 240, 0.42);
  border-radius: 5px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.04)),
    rgba(255, 255, 255, 0.08);
  accent-color: var(--primary);
  cursor: pointer;
  margin: 0;
  appearance: none;
  -webkit-appearance: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
}
.music-song-auto-open input:checked {
  border-color: rgba(235, 100, 91, 0.92);
  background: linear-gradient(135deg, #ff7f73, #eb645b);
  box-shadow: 0 0 0 3px rgba(235, 100, 91, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.24);
}
.music-song-auto-open input:checked::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 1px;
  width: 4px;
  height: 8px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.music-song-exec-count {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: var(--text-muted);
  user-select: none;
  white-space: nowrap;
}
.music-song-exec-count input {
  width: 48px;
  height: 22px;
  text-align: center;
  font-size: 12px;
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--text-primary);
  -moz-appearance: textfield;
}
.music-song-exec-count input::-webkit-outer-spin-button,
.music-song-exec-count input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* ===== 成曲缩略图样式已全部移至 app.js 内联 ===== */

/* 卡片外的右侧按钮列，与卡片内边距对齐 */
.music-create-top-row > .music-create-top-side {
  padding: 12px 0;
}

.music-create-top-spacer {
  flex: 1;
}

.music-create-top-side {
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex-shrink: 0;
  width: 130px;
}

.music-create-top-side > button {
  box-sizing: border-box;
  width: 100%;
  text-align: center;
}

.btn-generate-inspiration {
  padding: 10px 18px;
  border: 1px solid var(--primary);
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--primary);
  font-size: 13px;
  font-weight: 500;
  font-family: var(--font);
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  align-self: flex-start;
  transition: background 0.15s;
}

.btn-generate-inspiration:hover {
  background: var(--primary-light);
}

.btn-generate-inspiration.loading {
  opacity: 0.6;
  cursor: wait;
}

.music-inspiration-result {
  flex: 1;
  min-height: 80px;
  max-height: 160px;
  width: 100%;
  padding: 10px;
  border: 1px solid var(--divider);
  border-radius: var(--radius-sm);
  background: var(--bg);
  color: var(--text);
  font-size: 13px;
  font-family: var(--font);
  line-height: 1.6;
  resize: vertical;
  outline: none;
  box-sizing: border-box;
  overflow-y: auto;
}

.music-inspiration-result:focus {
  border-color: var(--primary);
}

/* 底部两栏 */
/* 左栏 - 完整歌词 */
.music-lyrics-panel {
  flex: 1 1 50%;
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.music-lyrics-header {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.music-lyrics-header-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}

.music-model-picker {
  position: relative;
  width: min(520px, 100%);
  margin: 0 auto;
  z-index: 12;
}

.music-model-trigger {
  width: 100%;
  min-height: 58px;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border: 1px solid rgba(235, 100, 91, 0.42);
  border-radius: 999px;
  background:
    linear-gradient(135deg, rgba(235, 100, 91, 0.2), rgba(79, 195, 199, 0.08)),
    rgba(20, 28, 36, 0.74);
  color: var(--text);
  box-shadow: 0 18px 42px rgba(235, 100, 91, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(18px);
}

.music-model-trigger:hover,
.music-model-trigger[aria-expanded="true"] {
  border-color: rgba(235, 100, 91, 0.7);
  box-shadow: 0 20px 48px rgba(235, 100, 91, 0.2), 0 0 0 1px rgba(255, 255, 255, 0.05) inset;
}

.music-model-sigil,
.music-model-option-mark {
  width: 34px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 34px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, rgba(255, 244, 198, 0.95), rgba(235, 100, 91, 0.9) 42%, rgba(71, 200, 210, 0.42));
  color: #101820;
  font-weight: 900;
  box-shadow: 0 0 22px rgba(235, 100, 91, 0.35);
}

.music-model-current,
.music-model-option-copy {
  min-width: 0;
  display: flex;
  flex: 1;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
}

.music-model-kicker,
.music-model-option-meta {
  color: var(--text-muted);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.music-model-name,
.music-model-option-name {
  max-width: 100%;
  overflow: hidden;
  color: var(--text);
  font-size: 16px;
  font-weight: 850;
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.music-model-live,
.music-model-option-badge {
  flex: 0 0 auto;
  padding: 5px 9px;
  border-radius: 999px;
  background: rgba(235, 100, 91, 0.16);
  color: var(--primary);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.08em;
}

.music-model-chevron {
  color: var(--text-muted);
  font-size: 18px;
  font-weight: 900;
}

.music-model-menu {
  position: absolute;
  left: 50%;
  top: calc(100% + 10px);
  width: min(560px, calc(100vw - 48px));
  max-height: 340px;
  overflow-y: auto;
  padding: 12px;
  border: 1px solid rgba(235, 100, 91, 0.24);
  border-radius: 24px;
  background:
    radial-gradient(circle at 15% 0%, rgba(235, 100, 91, 0.2), transparent 34%),
    radial-gradient(circle at 88% 18%, rgba(79, 195, 199, 0.16), transparent 38%),
    rgba(19, 27, 35, 0.96);
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.34), 0 0 34px rgba(235, 100, 91, 0.14);
  transform: translateX(-50%);
  backdrop-filter: blur(22px);
  z-index: 80;
}

.music-model-menu-title {
  padding: 4px 10px 10px;
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 850;
}

.music-model-option {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 10px;
  border: 1px solid transparent;
  border-radius: 18px;
  background: transparent;
  color: var(--text);
  text-align: left;
}

.music-model-option:hover {
  border-color: rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.06);
}

.music-model-option.active {
  border-color: rgba(235, 100, 91, 0.5);
  background: linear-gradient(135deg, rgba(235, 100, 91, 0.18), rgba(79, 195, 199, 0.08));
}

.music-model-empty {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  border: 1px solid rgba(235, 100, 91, 0.24);
  border-radius: 999px;
  background: rgba(235, 100, 91, 0.08);
  color: var(--text-muted);
  font-size: 13px;
  font-weight: 700;
}

.music-model-empty a {
  color: var(--primary);
  text-decoration: none;
}

.music-lyrics-textarea {
  flex: 1;
  min-height: 480px;
  width: 100%;
  padding: 10px;
  border: 1px solid var(--divider);
  border-radius: var(--radius-sm);
  background: var(--bg-panel);
  color: var(--text);
  font-size: 13px;
  font-family: var(--font);
  line-height: 1.6;
  resize: none;
  outline: none;
  box-sizing: border-box;
  overflow-y: auto;
}

.music-lyrics-textarea:focus {
  border-color: var(--primary);
}

/* 修词诊断图标容器 — 润色按钮正上方，独立于按钮 */
.music-status-step-wrapper {
  position: relative;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  padding-top: 30px;
  margin-top: -30px;
}
/* 修词诊断按钮 — 润色按钮上方，hover 时才显示 */
.music-repair-icon {
  position: absolute;
  top: 4px;
  left: 50%;
  transform: translateX(-50%);
  padding: 2px 10px;
  border-radius: 4px;
  background: transparent;
  color: var(--primary);
  border: 1px solid var(--primary);
  font-size: 11px;
  cursor: pointer;
  z-index: 2;
  white-space: nowrap;
  opacity: 0;
  transition: opacity 0.15s;
  pointer-events: none;
}
.music-status-step-wrapper:hover .music-repair-icon {
  opacity: 1;
  pointer-events: auto;
}

/* 修词诊断面板 */
.music-repair-diagnosis {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--divider);
  border-radius: var(--radius-sm);
  background: var(--bg-panel);
  overflow: hidden;
  flex-shrink: 0;
  max-height: min(600px, 80vh);
  margin: 0 0 8px 0;
  transition: max-height 0.25s ease;
}
.music-repair-diagnosis.collapsed {
  max-height: 36px;
}

.music-repair-diagnosis-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 10px;
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--divider);
  flex-shrink: 0;
  min-height: 24px;
}
.music-repair-diagnosis-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
}
.music-repair-diagnosis-toggle {
  padding: 2px 8px;
  border: 1px solid var(--divider);
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--text-muted);
  font-size: 11px;
  font-family: var(--font);
  cursor: pointer;
  transition: color 0.15s;
}
.music-repair-diagnosis-toggle:hover {
  color: var(--primary);
}

.music-repair-diagnosis-body {
  flex: 1;
  overflow: hidden auto;
  padding: 0;
  min-height: 0;
}
.music-repair-diagnosis.collapsed .music-repair-diagnosis-body {
  overflow: hidden;
}

.music-repair-diagnosis-content {
  margin: 0;
  padding: 10px 14px;
  font-size: 13px;
  font-family: var(--font);
  line-height: 1.7;
  color: var(--text-secondary);
  word-break: break-word;
  overflow-wrap: break-word;
  background: transparent;
}

/* Markdown 渲染样式 */
.music-repair-diagnosis-content h1,
.music-repair-diagnosis-content h2,
.music-repair-diagnosis-content h3,
.music-repair-diagnosis-content h4 { font-size: 14px; font-weight: 600; color: var(--text); margin: 12px 0 4px; }
.music-repair-diagnosis-content h1:first-child,
.music-repair-diagnosis-content h2:first-child,
.music-repair-diagnosis-content h3:first-child { margin-top: 0; }
.music-repair-diagnosis-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 8px 0 12px;
  font-size: 12px;
  table-layout: auto;
  overflow-wrap: anywhere;
}
.music-repair-diagnosis-content th {
  text-align: left;
  padding: 6px 10px;
  background: var(--bg-secondary);
  color: var(--text-muted);
  font-weight: 500;
  font-size: 11px;
  border-bottom: 1px solid var(--divider);
}
.music-repair-diagnosis-content td {
  padding: 6px 10px;
  border-bottom: 1px solid var(--divider);
  vertical-align: top;
  font-size: 12px;
}
.music-repair-diagnosis-content ul,
.music-repair-diagnosis-content ol { padding-left: 18px; margin: 4px 0; }
.music-repair-diagnosis-content li { margin: 2px 0; }
.music-repair-diagnosis-content strong { color: var(--text); font-weight: 600; }
.music-repair-diagnosis-content code {
  background: var(--bg-secondary);
  padding: 1px 5px;
  border-radius: 3px;
  font-size: 12px;
  font-family: var(--font-mono, monospace);
}
.music-repair-diagnosis-content p { margin: 4px 0; }
.music-repair-diagnosis-content hr { border: none; border-top: 1px solid var(--divider); margin: 10px 0; }
.music-repair-diagnosis-content pre {
  overflow-x: auto;
  white-space: pre-wrap;
  word-break: break-word;
  background: var(--bg-secondary);
  padding: 8px 10px;
  border-radius: 4px;
  font-size: 12px;
  margin: 6px 0;
}
.music-repair-diagnosis-content blockquote {
  border-left: 3px solid var(--primary);
  margin: 6px 0;
  padding: 4px 10px;
  color: var(--text-muted);
}

/* 右栏 - 谱曲（卡片容器） */
.music-melody-panel {
  flex: 1 1 50%;
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
  min-height: 0;
}

.music-melody-section {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
  min-height: 0;
}

.music-melody-section-header {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.music-reset-btn {
  width: 26px;
  height: 26px;
  min-width: 26px;
  min-height: 26px;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--text-muted);
  border-radius: 4px;
  transition: color 0.15s, background 0.15s;
}
.music-reset-btn svg {
  width: 15px;
  height: 15px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.music-reset-btn:hover {
  color: var(--danger);
  background: var(--bg-secondary);
}

.music-copy-btn {
  width: 26px;
  height: 26px;
  min-width: 26px;
  min-height: 26px;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--text-muted);
  border-radius: 4px;
  flex-shrink: 0;
  transition: color 0.15s, background 0.15s;
}
.music-copy-btn svg {
  width: 15px;
  height: 15px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.6;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.music-copy-btn:hover {
  color: var(--text);
  background: var(--bg-secondary);
}
.music-copy-btn.copied {
  color: var(--success);
}

.music-revert-btn {
  width: 26px;
  height: 26px;
  min-width: 26px;
  min-height: 26px;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--text-muted);
  border-radius: 4px;
  flex-shrink: 0;
  transition: color 0.15s, background 0.15s;
}
.music-revert-btn svg {
  width: 15px;
  height: 15px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.6;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.music-revert-btn:hover {
  color: var(--text);
  background: var(--bg-secondary);
}

.music-billing-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 24px;
  padding: 0 8px;
  border-radius: 8px;
  background: #eb645b;
  border: 1px solid #eb645b;
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
  margin-left: auto;
  margin-bottom: 4px;
  transition: opacity 0.15s;
}
.music-billing-link:hover {
  opacity: 0.88;
}

.music-section-header {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.music-section-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  flex-shrink: 0;
}
#music-song-title {
  font-size: 12px;
  font-weight: 400;
  color: var(--primary);
  flex: 1;
  min-width: 40px;
  border: none;
  border-radius: 0;
  background: transparent;
  font-family: var(--font);
  outline: none;
  padding: 0 0 2px;
  margin: 0;
  box-shadow: none;
  cursor: text;
  text-align: center;
}
#music-song-title:hover {
  border-bottom: 2px solid #4a90d9;
}
#music-song-title:focus {
  box-shadow: none;
  border-bottom: 2px solid #4a90d9;
}

/* 歌名编辑提示图标 */
.music-edit-hint {
  font-size: 11px;
  color: var(--text-muted);
  flex-shrink: 0;
  margin-left: 6px;
  margin-right: 2px;
}
.music-melody-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-shrink: 0;
  padding-top: 4px;
}

.music-melody-section-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}

.music-melody-textarea {
  flex: 1;
  min-height: 180px;
  width: 100%;
  padding: 10px;
  border: 1px solid var(--divider);
  border-radius: var(--radius-sm);
  background: var(--bg-panel);
  color: var(--text);
  font-size: 13px;
  font-family: var(--font);
  line-height: 1.6;
  resize: none;
  outline: none;
  box-sizing: border-box;
  overflow-y: auto;
}

#music-result-singing {
  min-height: 540px;
}

.music-melody-textarea:focus {
  border-color: var(--primary);
}

.btn-generate-cover {
  padding: 10px 18px;
  border: 1px solid var(--primary);
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--primary);
  font-size: 13px;
  font-weight: 500;
  font-family: var(--font);
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s;
}

.btn-generate-cover:hover {
  background: var(--primary-light);
}

.btn-generate-music {
  padding: 7px 20px;
  border: 1px solid var(--primary);
  border-radius: var(--radius-sm);
  background: var(--primary);
  color: #fff;
  font-size: 13px;
  font-weight: 500;
  font-family: var(--font);
  cursor: not-allowed;
  opacity: 0.5;
  white-space: nowrap;
}

/* 行/字计数器 */
.music-char-counter {
  font-size: 12px;
  color: var(--text-muted);
  flex-shrink: 0;
}

.music-lyrics-actions {
  display: flex;
  align-items: center;
  gap: 2px;
  margin-left: auto;
  flex-shrink: 0;
}

.music-section-header .music-copy-btn {
  margin-left: 0;
}

.music-melody-section .music-section-header .music-copy-btn {
  margin-left: auto;
}

.music-char-counter.over-limit {
  color: var(--danger);
  font-weight: 600;
}

.music-char-counter.retrying {
  color: var(--primary);
  font-weight: 600;
  font-size: 10px;
  animation: retry-pulse 1.5s ease-in-out infinite;
}

@keyframes retry-pulse {
  0%, 100% { opacity: 0.5; }
  50% { opacity: 1; }
}

.music-section-error {
  font-size: 12px;
  color: var(--danger);
  font-weight: 600;
  flex-shrink: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 280px;
}

/* 灵感弹窗 chip */
.music-inspiration-modal-content {
  box-sizing: border-box;
  width: min(740px, calc(100vw - 48px));
  max-width: calc(100vw - 48px);
  max-height: calc(100vh - 48px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  padding: 22px 28px 0;
}

.music-inspiration-modal-content .modal-header {
  flex: 0 0 auto;
  margin-bottom: 12px;
}

.music-inspiration-modal-body {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  padding-right: 4px;
  display: flex;
  flex-direction: column;
}

/* 结果查看弹窗 */
.music-result-modal-content {
  width: 680px;
  max-width: 92vw;
  max-height: 85vh;
  overflow-y: auto;
}
.music-result-viewer {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.music-result-viewer-header {
  display: flex;
  align-items: center;
  gap: 8px;
}
.music-result-viewer-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}
.music-result-viewer-textarea {
  width: 100%;
  min-height: 200px;
  padding: 10px;
  border: 1px solid var(--divider);
  border-radius: var(--radius-sm);
  background: var(--bg-panel);
  color: var(--text);
  font-size: 13px;
  font-family: var(--font);
  line-height: 1.6;
  resize: vertical;
  outline: none;
  box-sizing: border-box;
  overflow-y: auto;
}
.music-result-viewer-textarea:focus {
  border-color: var(--primary);
}

.music-inspiration-rough-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 6px;
}

.music-inspiration-rough-input {
  width: 100%;
  min-height: 96px;
  max-height: 132px;
  padding: 10px;
  border: 1px solid var(--divider);
  border-radius: var(--radius-sm);
  background: var(--bg-panel);
  color: var(--text);
  font-size: 13px;
  font-family: var(--font);
  line-height: 1.6;
  resize: none;
  outline: none;
  box-sizing: border-box;
  margin-bottom: 12px;
}

.music-inspiration-rough-input:focus {
  border-color: var(--primary);
}

.music-workflow-options,
.full-auto-workflow-options {
  display: grid;
  grid-template-columns: minmax(150px, 0.95fr) minmax(140px, 0.85fr) minmax(230px, 1.3fr);
  gap: 9px 14px;
  align-items: center;
  margin: 0 0 12px;
}

.music-workflow-options .music-song-auto-open,
.full-auto-workflow-options .music-song-auto-open {
  min-width: 0;
  gap: 8px;
  font-size: 12px;
  line-height: 1.35;
}

.music-workflow-options .music-song-auto-open span,
.full-auto-workflow-options .music-song-auto-open span {
  min-width: 0;
  white-space: nowrap;
  overflow: visible;
  text-overflow: clip;
}

.music-workflow-options.is-auto-open-hidden,
.full-auto-workflow-options.is-auto-open-hidden {
  grid-template-columns: minmax(170px, 0.95fr) minmax(246px, 1.35fr);
}

.music-inspiration-modal-body > .modal-actions {
  position: sticky;
  bottom: 0;
  z-index: 2;
  flex: 0 0 auto;
  justify-content: flex-end;
  gap: 12px;
  margin: 14px 0 0;
  padding: 16px 0 14px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  background: transparent;
}

.music-inspiration-modal-body > .modal-actions button {
  min-height: 40px;
}

.music-inspiration-modal-body > .modal-actions #btn-music-inspiration-reset {
  width: 44px;
  height: 44px;
  min-width: 44px;
  min-height: 44px;
  margin: 0;
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: 999px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03)),
    rgba(255, 255, 255, 0.045);
  color: rgba(255, 248, 242, 0.72);
}

.music-inspiration-modal-body > .modal-actions #btn-music-inspiration-reset:hover {
  border-color: rgba(235, 100, 91, 0.42);
  background: rgba(235, 100, 91, 0.14);
  color: #fff;
}

.music-inspiration-modal-body > .modal-actions [hidden],
.music-inspiration-modal-body > .modal-actions .is-hidden {
  display: none !important;
}

@media (max-width: 780px) {
  .music-workflow-options,
  .full-auto-workflow-options {
    grid-template-columns: minmax(140px, 0.95fr) minmax(132px, 0.85fr) minmax(218px, 1.3fr);
  }
}

/* 3 个灵感选项 */
.music-inspiration-options {
  margin-top: 12px;
}

.music-inspiration-options-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.music-inspiration-option-card {
  padding: 12px;
  border: 1px solid var(--divider);
  border-radius: var(--radius-sm);
  background: var(--bg-panel);
  cursor: pointer;
  transition: border-color 0.15s;
}

.music-inspiration-option-card:hover {
  border-color: var(--primary);
}

.music-inspiration-option-card.selected {
  border-color: var(--primary);
  background: var(--primary-light);
}

.music-inspiration-option-card .option-number {
  font-size: 12px;
  font-weight: 600;
  color: var(--primary);
  margin-bottom: 4px;
}

.music-inspiration-option-card .option-text {
  font-size: 13px;
  color: var(--text);
  line-height: 1.6;
}

.music-inspiration-option-card .option-textarea {
  width: 100%;
  min-height: 140px;
  padding: 8px;
  border: none;
  border-radius: var(--radius-sm);
  background: var(--bg);
  color: var(--text);
  font-size: 13px;
  font-family: var(--font);
  line-height: 1.6;
  resize: vertical;
  outline: none;
  box-sizing: border-box;
  overflow-y: auto;
}

.music-inspiration-option-card .option-textarea:focus {
  background: var(--bg);
  box-shadow: 0 0 0 1px var(--primary);
}

.music-inspiration-option-card.selected .option-textarea:focus {
  box-shadow: 0 0 0 1px var(--primary);
}

.music-inspiration-option-card.loading-card {
  cursor: default;
  animation: music-card-pulse 1.5s ease-in-out infinite;
}

.music-inspiration-option-card.loading-card:hover {
  border-color: var(--divider);
}

.music-inspiration-option-card.loading-card .option-text {
  color: var(--text-muted);
}

@keyframes music-card-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

/* 页面底部最终灵感 */
.music-inspiration-final {
  padding: 12px;
  background: var(--bg-panel);
  border: 1px solid var(--divider);
  border-radius: 10px;
  flex-shrink: 0;
}

.music-inspiration-final-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}

.music-inspiration-final-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}

.btn-save-inspiration {
  padding: 5px 16px;
  border: 1px solid var(--primary);
  border-radius: var(--radius-sm);
  background: var(--primary);
  color: #fff;
  font-size: 12px;
  font-weight: 500;
  font-family: var(--font);
  cursor: pointer;
  transition: background 0.15s;
}

.btn-save-inspiration:hover {
  background: var(--primary-hover);
}

.music-inspiration-final-textarea {
  width: 100%;
  min-height: 200px;
  padding: 10px;
  border: 1px solid var(--divider);
  border-radius: var(--radius-sm);
  background: var(--bg);
  color: var(--text);
  font-size: 13px;
  font-family: var(--font);
  line-height: 1.6;
  resize: vertical;
  outline: none;
  box-sizing: border-box;
  overflow-y: auto;
}

.music-inspiration-final-textarea:focus {
  border-color: var(--primary);
}

/* 弹窗内的最终灵感区 */
.music-inspiration-modal-final {
  margin-top: 12px;
  padding: 12px;
  background: var(--bg-panel);
  border: 1px solid var(--divider);
  border-radius: 10px;
}

.music-inspiration-chips-container {
  padding: 12px 0 4px;
}

.music-inspiration-chips-container .music-chip-row {
  display: flex;
  align-items: flex-start;
  gap: 4px;
  margin-bottom: 18px;
}

.music-inspiration-chips-container .music-chip-row:last-child {
  margin-bottom: 0;
}

.music-inspiration-chips-container .music-chip-label {
  display: flex;
  flex-direction: column;
  gap: 3px;
  line-height: 1.35;
  color: var(--text);
  white-space: normal;
  width: 64px;
  min-width: 64px;
  flex-shrink: 0;
  padding-top: 5px;
}

.music-inspiration-chips-container .music-chip-label-title {
  font-size: 13px;
  font-weight: 700;
}

.music-inspiration-chips-container .music-inspiration-select-field {
  flex: 1 1 auto;
  min-width: 0;
}

.music-inspiration-chips-container .music-inspiration-select-control {
  width: 100%;
}

.music-inspiration-chips-container .music-chip-label-limit {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted);
}

.music-inspiration-chips-container .music-chip-group {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  min-width: 0;
  max-width: 100%;
}

.music-inspiration-chips-container .music-chip {
  min-height: 34px;
  max-width: 100%;
  padding: 7px 14px;
  border: 1px solid var(--ui-border, var(--divider));
  border-radius: 999px;
  background: var(--ui-field, var(--bg-panel));
  color: var(--text-secondary);
  font-size: 13px;
  font-family: var(--font);
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s, box-shadow 0.15s, transform 0.15s;
  white-space: normal;
  overflow-wrap: break-word;
  text-align: left;
  line-height: 1.35;
}

.music-inspiration-chips-container .music-chip:hover {
  border-color: rgba(235, 100, 91, 0.48);
  color: var(--primary);
  background: var(--primary-light);
  transform: translateY(-1px);
}

.music-inspiration-chips-container .music-chip.selected {
  background: linear-gradient(135deg, rgba(235, 100, 91, 0.95), rgba(221, 85, 76, 0.92));
  border-color: rgba(235, 100, 91, 0.95);
  color: #fff;
  font-weight: 700;
  box-shadow: 0 8px 22px rgba(235, 100, 91, 0.24);
}

/* 窄屏适配 */
@media (max-width: 860px) {
  .music-create-top-row {
    flex-direction: column;
  }

  .music-create-top-side {
    flex-direction: row;
  }

  .btn-generate-inspiration {
    flex: 1;
  }

  .music-create-bottom {
    flex-direction: column;
  }

  .music-lyrics-panel,
  .music-melody-panel {
    flex: 1 1 auto;
    min-height: 300px;
  }
}

/* 封面缩略图（hover 显示） */
.music-cover-thumb {
  position: fixed;
  width: 100px;
  height: 100px;
  border-radius: 8px;
  object-fit: cover;
  cursor: pointer;
  border: 2px solid var(--success);
  box-shadow: 0 4px 20px rgba(0,0,0,0.35);
  z-index: 100;
  display: none;
}

/* =====================================================
   Mode Selector
   ===================================================== */
.music-mode-bar {
  display: flex;
  justify-content: center;
  padding: 12px 0 8px;
  flex-shrink: 0;
}
.music-mode-segment {
  display: inline-flex;
  border-radius: 8px;
  overflow: hidden;
  background: var(--bg-secondary);
}
.music-mode-btn {
  padding: 6px 16px;
  font-size: 13px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
  white-space: nowrap;
}
.music-mode-btn:hover {
  background: var(--bg-tertiary);
}
.music-mode-btn.active {
  background: var(--primary-light);
  color: var(--primary);
}

/* =====================================================
   Disabled Step States
   ===================================================== */
/* =====================================================
   Inspiration Choice Popover
   ===================================================== */
.music-inspiration-choice-popover {
  position: fixed;
  z-index: 1500;
  background: var(--bg-primary, #fff);
  border: 1px solid var(--border, rgba(16,24,40,0.12));
  border-radius: 10px;
  box-shadow: 0 8px 28px rgba(0,0,0,0.2);
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 150px;
}
.music-choice-btn {
  padding: 8px 14px;
  font-size: 13px;
  border: 1px solid var(--border, rgba(16,24,40,0.12));
  border-radius: 6px;
  background: var(--bg-secondary, #fff);
  color: var(--text, #17181d);
  cursor: pointer;
  text-align: left;
  transition: background 0.15s, border-color 0.15s;
}
.music-choice-btn:hover {
  background: var(--primary-light);
  border-color: var(--primary);
}
.music-choice-btn.primary-choice {
  background: var(--primary);
  color: #fff;
  border-color: var(--primary);
}
.music-choice-btn.primary-choice:hover {
  opacity: 0.9;
}

/* =====================================================
   Full-Auto Dialog
   ===================================================== */
.full-auto-inspiration-dialog {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
}
.full-auto-dialog-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
}
.full-auto-dialog-content {
  position: relative;
  background: var(--bg-primary, #fff);
  border: 1px solid var(--border, rgba(16,24,40,0.12));
  border-radius: 12px;
  padding: 28px 24px 20px;
  width: 480px;
  max-width: 90vw;
  box-shadow: 0 12px 48px rgba(0,0,0,0.25);
}
.full-auto-dialog-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}
.full-auto-dialog-title {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  color: var(--text, #17181d);
}
.full-auto-dialog-close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  padding: 0;
  border: none;
  border-radius: 6px;
  background: transparent;
  color: var(--text-secondary, #667085);
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
  flex-shrink: 0;
}
.full-auto-dialog-close:hover {
  background: var(--divider, rgba(16,24,40,0.1));
  color: var(--text, #17181d);
}
.full-auto-dialog-desc {
  margin: 0 0 16px;
  font-size: 13px;
  color: var(--text-secondary, #667085);
  line-height: 1.5;
}
.full-auto-inspiration-input {
  width: 100%;
  padding: 10px 12px;
  font-size: 14px;
  border: 1px solid var(--border, rgba(16,24,40,0.15));
  border-radius: 8px;
  background: var(--bg-secondary, #f5f6f8);
  color: var(--text, #17181d);
  resize: vertical;
  outline: none;
  font-family: inherit;
  line-height: 1.6;
  box-sizing: border-box;
}
.full-auto-inspiration-input:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 2px var(--primary-light);
}
.full-auto-dialog-config {
  margin-top: 12px;
  padding: 12px;
  border: 1px solid var(--border, rgba(16,24,40,0.12));
  border-radius: 8px;
  background: var(--bg-secondary, #f5f6f8);
}
.full-auto-dialog-config-label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary, #667085);
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.full-auto-dialog-config .music-song-auto-open {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  margin-bottom: 8px;
  cursor: pointer;
}
.full-auto-dialog-config .music-song-exec-count {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
}
.full-auto-dialog-config .music-auto-open-row.hidden,
.full-auto-dialog-config .music-auto-open-row[hidden] {
  display: none !important;
}
.full-auto-song-settings-row {
  display: grid;
  grid-template-columns: minmax(158px, 0.95fr) minmax(190px, 1.15fr) minmax(118px, auto);
  align-items: center;
  gap: 14px;
  margin: 0 0 8px;
}
.full-auto-song-settings-row .music-song-auto-open,
.full-auto-song-settings-row .music-song-exec-count {
  margin-bottom: 0;
  min-width: 0;
}
.full-auto-song-settings-row .music-song-auto-open span,
.full-auto-song-settings-row .music-song-exec-count span {
  min-width: 0;
  overflow: visible;
  text-overflow: clip;
  white-space: nowrap;
}
.full-auto-song-settings-row .music-song-exec-count {
  justify-content: flex-end;
}
.full-auto-song-settings-row .music-song-exec-count input {
  flex: 0 0 48px;
}
.full-auto-storyboard-ratio,
.music-storyboard-ratio-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 8px 0 10px 22px;
}
.music-storyboard-ratio-grid {
  margin: 14px 0 4px;
}
.full-auto-storyboard-ratio.disabled {
  opacity: 0.42;
  pointer-events: none;
}
.music-storyboard-ratio-option {
  min-width: 0;
  padding: 11px 12px;
  border: 1px solid rgba(146,156,182,0.24);
  border-radius: 14px;
  background: rgba(255,255,255,0.08);
  color: var(--text);
  cursor: pointer;
  text-align: left;
  font-family: var(--font);
  transition: border-color 0.16s ease, background 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease;
}
.music-storyboard-ratio-option strong,
.music-storyboard-ratio-option span {
  display: block;
  letter-spacing: 0;
}
.music-storyboard-ratio-option strong {
  font-size: 15px;
  font-weight: 800;
  line-height: 1.15;
}
.music-storyboard-ratio-option span {
  margin-top: 4px;
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 700;
}
.music-storyboard-ratio-option:hover {
  border-color: rgba(235,100,91,0.48);
  background: rgba(235,100,91,0.10);
  transform: translateY(-1px);
}
.music-storyboard-ratio-option.selected {
  border-color: rgba(235,100,91,0.74);
  background:
    radial-gradient(circle at 18% 0%, rgba(255,142,109,0.22), transparent 44%),
    rgba(235,100,91,0.14);
  box-shadow: 0 12px 28px rgba(235,100,91,0.16), inset 0 1px 0 rgba(255,255,255,0.16);
}
.music-storyboard-aspect-dialog {
  max-width: 460px;
}
.full-auto-dialog-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 16px;
}

/* 流水线取消按钮 */
.music-cancel-row {
  display: flex;
  justify-content: center;
  padding: 6px 0 2px;
}
.music-cancel-btn {
  padding: 5px 24px;
  font-size: 12px;
  font-weight: 500;
  font-family: var(--font);
  color: var(--danger, #f04438);
  background: transparent;
  border: 1px solid var(--danger, #f04438);
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.15s;
}
.music-cancel-btn:hover:not(:disabled) {
  background: rgba(240, 68, 56, 0.08);
}
.music-cancel-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* 确认弹窗 */
.music-confirm-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
}
.music-confirm-dialog {
  background: var(--bg-primary);
  border: 1px solid var(--divider);
  border-radius: 12px;
  padding: 24px;
  max-width: 400px;
  width: calc(100% - 40px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}
.music-confirm-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 12px;
}
.music-confirm-message {
  font-size: 14px;
  line-height: 1.7;
  color: var(--text-secondary);
  margin-bottom: 24px;
  white-space: pre-line;
}
.music-confirm-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}
.music-confirm-cancel {
  padding: 8px 18px;
  border: 1px solid var(--divider);
  border-radius: 8px;
  background: var(--bg-secondary);
  color: var(--text-secondary);
  font-size: 14px;
  cursor: pointer;
  transition: background 0.15s;
}
.music-confirm-cancel:hover {
  background: var(--divider);
}
.music-confirm-ok {
  padding: 8px 18px;
  border: none;
  border-radius: 8px;
  background: var(--primary);
  color: #fff;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: opacity 0.15s;
}
.music-confirm-ok:hover {
  opacity: 0.85;
}

/* ===== 全局外壳视觉刷新 ===== */
body:not(.theme-dark) {
  background:
    radial-gradient(circle at 18% 16%, rgba(235,100,91,0.10), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,0.62), rgba(245,247,251,0.84));
}

body.theme-dark {
  background:
    radial-gradient(circle at 18% 16%, rgba(235,100,91,0.08), transparent 34%),
    radial-gradient(circle at 82% 8%, rgba(255,255,255,0.04), transparent 30%),
    linear-gradient(135deg, #111821 0%, #18232d 52%, #10141b 100%);
}

body:not(.theme-dark) #topbar {
  background: transparent;
  border-bottom-color: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

body:not(.theme-dark) .client-broadcast-bar {
  background: transparent;
  color: #6e3d38;
  box-shadow: none;
}

body:not(.theme-dark) .client-broadcast-content[data-broadcast-link] {
  text-decoration-color: rgba(217, 79, 72, 0.38);
}

body:not(.theme-dark) .client-update-topbar-download {
  color: #168f50;
  background: transparent;
  box-shadow: none;
}

body:not(.theme-dark) .client-update-topbar-download:hover {
  color: #0f7f45;
  background: rgba(22, 143, 80, 0.08);
}

body.theme-dark #topbar {
  background: transparent;
  border-bottom-color: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

body:not(.theme-dark) #sidebar {
  background: transparent;
  border-right-color: transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

body.theme-dark #sidebar {
  background: transparent;
  border-right-color: transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

#content {
  background: transparent;
}

body:not(.theme-dark) #content {
  background: transparent;
}

.sidebar-service {
  margin: 3px 8px;
  padding: 10px 10px 10px 14px;
  border-left: none;
  border-radius: 14px;
  transition: background 0.16s, color 0.16s, box-shadow 0.16s, transform 0.16s;
}

.sidebar-service:hover {
  background: rgba(235,100,91,0.10);
}

.sidebar-service.active {
  background: linear-gradient(135deg, rgba(235,100,91,0.22), rgba(235,100,91,0.10));
  color: var(--primary);
  border-left-color: transparent;
  box-shadow: none;
}

body.theme-dark .sidebar-service.active {
  background: linear-gradient(135deg, rgba(235,100,91,0.24), rgba(235,100,91,0.12));
}

.service-tag {
  padding: 4px 9px;
  border-radius: 9px;
  background: rgba(120,128,148,0.16);
  font-size: 11px;
  font-weight: 600;
}

.sidebar-service.active .service-tag {
  background: var(--primary);
  color: #fff;
  box-shadow: 0 8px 18px rgba(235,100,91,0.22);
}

.sidebar-footer {
  padding: 10px 10px 16px;
  border-top-color: transparent;
}

.sidebar-footer-actions {
  display: grid;
  grid-template-columns: repeat(3, 36px);
  justify-content: center;
  align-items: center;
  gap: 4px;
  padding: 5px;
  width: min-content;
  max-width: 100%;
  margin: 0 auto;
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 999px;
  background:
    radial-gradient(circle at 18% 12%, rgba(235,100,91,0.13), transparent 42%),
    rgba(12,18,27,0.28);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
}

.sidebar-action,
.theme-toggle {
  min-width: 0;
  width: 36px;
  max-width: 36px;
  min-height: 36px;
  height: 36px;
  flex: 0 0 36px;
  padding: 0;
  border-radius: 999px;
  border-color: transparent;
  box-shadow: none;
  gap: 0;
  flex-direction: row;
}

.sidebar-action .theme-toggle-label {
  display: none;
}

.sidebar-action .theme-toggle-icon {
  display: grid;
  place-items: center;
  width: 20px;
  height: 20px;
  color: rgba(255,255,255,0.84);
  font-size: 15px;
  line-height: 1;
}

.sidebar-action .theme-toggle-icon svg {
  width: 18px;
  height: 18px;
  display: block;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.05;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.auth-user-icon svg {
  filter: drop-shadow(0 0 8px rgba(255,255,255,0.12));
}

body:not(.theme-dark) .sidebar-action,
body:not(.theme-dark) .theme-toggle {
  background: rgba(255,255,255,0.58);
  color: rgba(32,37,45,0.84);
}

body.theme-dark .sidebar-action,
body.theme-dark .theme-toggle {
  background: rgba(255,255,255,0.055);
  color: rgba(255,255,255,0.86);
}

body:not(.theme-dark) .sidebar-footer-actions {
  border-color: rgba(20,30,45,0.08);
  background:
    radial-gradient(circle at 20% 0%, rgba(235,100,91,0.12), transparent 44%),
    rgba(255,255,255,0.52);
}

body:not(.theme-dark) .sidebar-action .theme-toggle-icon {
  color: rgba(35,43,54,0.72);
}

.sidebar-action:hover,
.theme-toggle:hover {
  transform: translateY(-1px);
  border-color: rgba(235,100,91,0.34);
  background: rgba(235,100,91,0.16);
}

#sidebar.sidebar-collapsed .sidebar-footer {
  padding-inline: 9px;
}

#sidebar.sidebar-collapsed .sidebar-footer-actions {
  display: grid;
  grid-template-columns: 36px;
  gap: 6px;
  padding: 5px;
  border-radius: 999px;
  width: fit-content;
  max-width: none;
}

#sidebar.sidebar-collapsed .sidebar-action {
  width: 36px;
  min-width: 36px;
  max-width: 36px;
  min-height: 36px;
}

#sidebar.sidebar-collapsed .sidebar-action .theme-toggle-label {
  display: none;
}

.auth-content {
  width: min(440px, calc(100vw - 36px));
}

.auth-subtitle {
  margin: 5px 0 0;
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 500;
}

.auth-tabs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  padding: 6px;
  margin: 6px 0 18px;
  border: 1px solid var(--divider);
  border-radius: 18px;
  background: rgba(255,255,255,0.06);
}

.auth-tab {
  min-height: 40px;
  border: 0;
  border-radius: 14px;
  background: transparent;
  color: var(--text-secondary);
  font-family: var(--font);
  font-size: 14px;
  font-weight: 750;
  cursor: pointer;
}

.auth-tab.active {
  color: #fff;
  background: linear-gradient(135deg, rgba(235,100,91,0.88), rgba(235,100,91,0.62));
  box-shadow: 0 14px 30px rgba(235,100,91,0.22);
}

.auth-pane {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.auth-pane.hidden {
  display: none;
}

.auth-pane .form-group {
  gap: 9px;
}

.auth-pane .form-group label {
  padding-left: 4px;
  color: rgba(237,244,248,0.78);
  font-size: 13px;
  font-weight: 850;
  letter-spacing: 0.02em;
}

.auth-pane .form-group input[type="email"],
.auth-pane .form-group input[type="password"],
.auth-pane .form-group input[type="text"],
.auth-change-panel .form-group input[type="password"] {
  width: 100%;
  min-height: 56px;
  padding: 0 18px;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.04)),
    rgba(15,23,32,0.42);
  color: var(--text);
  font-family: var(--font);
  font-size: 15px;
  font-weight: 750;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 16px 30px rgba(7,12,18,0.12);
  caret-color: #eb645b;
  appearance: none;
  -webkit-appearance: none;
}

.auth-pane .form-group input::placeholder {
  color: rgba(237,244,248,0.34);
  font-weight: 650;
}

.auth-pane .form-group input:focus,
.auth-change-panel .form-group input:focus {
  border-color: rgba(235,100,91,0.6);
  box-shadow:
    0 0 0 4px rgba(235,100,91,0.13),
    0 0 34px rgba(158,233,242,0.1),
    inset 0 1px 0 rgba(255,255,255,0.1);
}

.auth-pane .input-with-action {
  align-items: stretch;
  gap: 10px;
}

.auth-pane .input-with-action > input {
  min-width: 0;
}

.auth-pane .input-action {
  min-height: 56px;
  padding-inline: 16px;
  border-radius: 20px;
}

.auth-pane .form-group input:-webkit-autofill,
.auth-pane .form-group input:-webkit-autofill:hover,
.auth-pane .form-group input:-webkit-autofill:focus,
.auth-pane .form-group input:-webkit-autofill:active,
.auth-change-panel .form-group input:-webkit-autofill,
.auth-change-panel .form-group input:-webkit-autofill:hover,
.auth-change-panel .form-group input:-webkit-autofill:focus,
.auth-change-panel .form-group input:-webkit-autofill:active {
  -webkit-text-fill-color: var(--text) !important;
  caret-color: #eb645b !important;
  box-shadow: 0 0 0 1000px #263340 inset !important;
  transition: background-color 99999s ease-in-out 0s;
}

.auth-user-panel {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--divider);
  border-radius: 22px;
  background:
    radial-gradient(circle at 0% 0%, rgba(235,100,91,0.16), transparent 42%),
    rgba(255,255,255,0.07);
}

.auth-user-summary {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
}

.auth-user-avatar {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  color: #fff;
  font-size: 20px;
  font-weight: 900;
  background: linear-gradient(135deg, #eb645b, #9ee9f2);
  box-shadow: 0 18px 34px rgba(235,100,91,0.22);
}

.auth-user-name {
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.auth-user-caption {
  margin-top: 4px;
  color: var(--text-secondary);
  font-size: 12px;
}

#auth-user-membership {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 3px 8px;
  border-radius: 999px;
  color: rgba(255,255,255,0.86);
  background: linear-gradient(135deg, rgba(235,100,91,0.56), rgba(158,233,242,0.22));
  font-size: 11px;
  font-weight: 850;
}

.auth-change-panel {
  display: grid;
  gap: 12px;
  padding-top: 2px;
}

.auth-change-panel .form-group {
  margin: 0;
  gap: 9px;
}

.auth-change-panel .form-group label {
  padding-left: 4px;
  color: rgba(237,244,248,0.78);
  font-size: 13px;
  font-weight: 850;
  letter-spacing: 0.02em;
}

.auth-change-panel .btn-primary,
.auth-user-actions .btn-secondary {
  width: 100%;
  min-height: 46px;
  border-radius: 999px;
}

.auth-user-actions {
  display: grid;
  gap: 10px;
}

body:not(.theme-dark) .auth-tabs,
body:not(.theme-dark) .auth-user-panel {
  background: rgba(255,255,255,0.68);
}

body:not(.theme-dark) .auth-pane .form-group label,
body:not(.theme-dark) .auth-change-panel .form-group label {
  color: rgba(36,43,52,0.72);
}

body:not(.theme-dark) .auth-pane .form-group input[type="email"],
body:not(.theme-dark) .auth-pane .form-group input[type="password"],
body:not(.theme-dark) .auth-pane .form-group input[type="text"],
body:not(.theme-dark) .auth-change-panel .form-group input[type="password"] {
  border-color: rgba(43,55,68,0.1);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.9), rgba(255,255,255,0.68)),
    rgba(255,248,241,0.72);
  color: #202832;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.9),
    0 16px 32px rgba(133,98,78,0.12);
}

body:not(.theme-dark) .auth-pane .form-group input::placeholder {
  color: rgba(32,40,50,0.36);
}

body:not(.theme-dark) .auth-pane .form-group input:-webkit-autofill,
body:not(.theme-dark) .auth-pane .form-group input:-webkit-autofill:hover,
body:not(.theme-dark) .auth-pane .form-group input:-webkit-autofill:focus,
body:not(.theme-dark) .auth-pane .form-group input:-webkit-autofill:active {
  -webkit-text-fill-color: #202832 !important;
  box-shadow: 0 0 0 1000px #fff6ef inset !important;
}

#sidebar-toggle {
  background: transparent;
  border-left-color: transparent;
  font-weight: 700;
}

body:not(.theme-dark) #content-header,
body.theme-dark #content-header {
  padding-top: 12px;
}

/* 外壳清理：隐藏侧栏类别标签，避免服务名换行 */
#sidebar .service-tag {
  display: none !important;
}

#sidebar .sidebar-service {
  justify-content: flex-start;
  gap: 0;
}

#sidebar .sidebar-service-text {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

#sidebar:not(.sidebar-collapsed) {
  width: 296px;
  min-width: 296px;
}

#sidebar .sidebar-service {
  font-size: 15px;
  font-weight: 650;
}

#sidebar.sidebar-collapsed {
  width: 0;
  min-width: 0;
  border-right: none;
  box-shadow: none;
}

#sidebar.sidebar-collapsed > * {
  opacity: 0;
  pointer-events: none;
}

#sidebar-toggle {
  width: 30px;
  min-width: 30px;
  height: 72px;
  min-height: 72px;
  overflow: visible;
  color: rgba(154,163,184,0.86);
  background: rgba(255,255,255,0.045);
  border: 1px solid rgba(120,128,148,0.12);
  border-radius: 999px;
  align-self: center;
  margin-left: -15px;
  margin-right: -15px;
  position: relative;
  z-index: 20;
  box-shadow: 0 12px 30px rgba(0,0,0,0.12);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

#sidebar-toggle::before {
  content: none;
  display: none;
}

#sidebar-toggle:hover {
  background: rgba(235,100,91,0.12);
  border-color: rgba(235,100,91,0.22);
  color: var(--primary);
}

body.sidebar-hidden #sidebar-toggle {
  width: 34px;
  min-width: 34px;
  height: 72px;
  min-height: 72px;
  background: rgba(255,255,255,0.045);
}

body:not(.theme-dark) #sidebar-toggle {
  background: rgba(255,255,255,0.72);
  border-color: rgba(16,24,40,0.08);
  box-shadow: 0 14px 34px rgba(16,24,40,0.10);
}

body.theme-dark #sidebar-toggle {
  background: rgba(255,255,255,0.045);
}

#content.content-custom-app-layout #content-panel.content-panel-image-create:not(.content-panel-custom-app) {
  box-shadow: none;
}

#content-panel.content-panel-image-create .creator-shell {
  border-color: transparent;
  box-shadow: none;
}

#content-panel.content-panel-image-create .image-create-dock {
  border-top-color: transparent;
}

#content-panel.content-panel-image-create .image-create-size-trigger,
#content-panel.content-panel-image-create .model-selector-trigger,
#content-panel.content-panel-image-create .compact-control-input select,
#content-panel.content-panel-image-create .compact-control-input input {
  border-color: transparent;
  background: rgba(255,255,255,0.035);
}

body:not(.theme-dark) #content-panel.content-panel-image-create .image-create-size-trigger,
body:not(.theme-dark) #content-panel.content-panel-image-create .model-selector-trigger,
body:not(.theme-dark) #content-panel.content-panel-image-create .compact-control-input select,
body:not(.theme-dark) #content-panel.content-panel-image-create .compact-control-input input {
  background: rgba(16,24,40,0.035);
}

#app {
  position: relative;
}

body.sidebar-hidden #sidebar-toggle {
  position: absolute;
  left: 10px;
  top: 50%;
  bottom: auto;
  width: 34px;
  min-width: 34px;
  height: 72px;
  min-height: 72px;
  align-self: auto;
  margin: 0;
  transform: translateY(-50%);
}

#app::before,
#app::after {
  content: none !important;
  display: none !important;
}

body:not(.theme-dark) #app,
body.theme-dark #app {
  background: transparent;
}

@media (max-width: 0px) and (min-width: 1px) {
/* Retired: this broad internal restyle changed approved layouts and light-mode readability. */
/* ===== 全页面新设计语言统一 ===== */
:root {
  --ui-surface: rgba(255,255,255,0.68);
  --ui-surface-strong: rgba(255,255,255,0.82);
  --ui-surface-soft: rgba(16,24,40,0.035);
  --ui-field: rgba(16,24,40,0.045);
  --ui-border: rgba(16,24,40,0.075);
  --ui-border-strong: rgba(16,24,40,0.115);
  --ui-shadow-soft: 0 18px 48px rgba(16,24,40,0.075);
  --ui-shadow-card: 0 12px 32px rgba(16,24,40,0.075);
  --ui-accent-glow: 0 18px 44px rgba(235,100,91,0.12);
}

body.theme-dark {
  --ui-surface: rgba(34, 45, 55, 0.70);
  --ui-surface-strong: rgba(40, 52, 62, 0.84);
  --ui-surface-soft: rgba(255,255,255,0.060);
  --ui-field: rgba(255,255,255,0.070);
  --ui-border: rgba(255,255,255,0.105);
  --ui-border-strong: rgba(255,255,255,0.155);
  --ui-shadow-soft: 0 22px 64px rgba(0,0,0,0.16), 0 0 54px rgba(120,232,255,0.04);
  --ui-shadow-card: 0 16px 38px rgba(0,0,0,0.14);
  --ui-accent-glow: 0 20px 58px rgba(235,100,91,0.16), 0 0 38px rgba(120,232,255,0.07);
}

#content:not(.content-custom-app-layout) {
  padding: 0 8px 8px;
}

#content-panel.content-panel-quick-links,
#content-panel.content-panel-music-create,
#content-panel:not(.content-panel-image-create):not(.content-panel-translate):not(.content-panel-custom-app) {
  padding: 22px 26px 28px;
}

#content-header {
  padding: 14px 28px 0;
}

#content-title {
  font-size: 22px;
  letter-spacing: -0.02em;
}

.content-subtitle,
.panel-service-desc,
.form-hint {
  color: var(--text-muted);
}

body:not(.theme-dark) #content {
  background:
    radial-gradient(circle at 12% 10%, rgba(235,100,91,0.10), transparent 30%),
    linear-gradient(135deg, rgba(255,255,255,0.84), rgba(244,246,250,0.92));
}

body.theme-dark #content {
  background:
    radial-gradient(circle at 12% 10%, rgba(255, 116, 91, 0.18), transparent 34%),
    radial-gradient(circle at 86% 8%, rgba(120, 232, 255, 0.13), transparent 32%),
    radial-gradient(circle at 62% 92%, rgba(255, 194, 111, 0.08), transparent 36%),
    linear-gradient(135deg, rgba(18, 25, 34, 0.97), rgba(25, 36, 45, 0.95) 52%, rgba(15, 19, 27, 0.98));
}

.creator-shell,
.quick-links-section,
.music-create-top,
.music-status-bar,
.music-inspiration-final,
.music-lyrics-panel,
.music-melody-panel,
.music-repair-diagnosis,
.custom-app-key-menu,
.model-selector-menu,
.history-file-picker-content,
.modal-content {
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  box-shadow: var(--ui-shadow-soft);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.creator-shell,
.quick-links-section,
.music-create-top,
.music-inspiration-final,
.music-lyrics-panel,
.music-melody-panel {
  border-radius: 26px;
}

#content-panel.content-panel-custom-app .creator-shell,
#content.content-custom-app-layout #content-panel.content-panel-custom-app .creator-shell {
  background: var(--ui-surface);
  border: 1px solid var(--ui-border);
  border-radius: 26px;
  padding: 18px;
  box-shadow: var(--ui-shadow-soft);
}

#content.content-custom-app-layout #content-panel.content-panel-custom-app.is-gallery,
#content.content-custom-app-layout #content-panel.content-panel-custom-app.is-gallery .custom-app-gallery-shell {
  filter: none;
}

.quick-links-page,
.music-create-shell {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
}

.quick-links-page {
  gap: 18px;
}

.quick-links-section {
  gap: 14px;
  padding: 18px;
}

.quick-links-section-title,
.custom-app-panel-title,
.music-section-label,
.music-lyrics-header-label,
.music-melody-section-label,
.music-inspiration-final-label,
.music-repair-diagnosis-title,
.form-group label {
  letter-spacing: -0.01em;
}

.quick-links-section-title,
.custom-app-panel-title {
  font-size: 16px;
  font-weight: 750;
}

.quick-links-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.quick-link-card,
.custom-app-card,
.history-tile-image,
.result-image-wrapper,
.history-file-picker-item,
.music-inspiration-option-card {
  background: var(--ui-surface-strong);
  border: 1px solid var(--ui-border);
  box-shadow: var(--ui-shadow-card);
}

.history-card {
  background: var(--ui-surface-strong);
  border: 1px solid var(--ui-border);
  box-shadow: var(--ui-shadow-card);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.quick-link-card,
.custom-app-card {
  border-radius: 20px;
  overflow: hidden;
}

.quick-link-card {
  height: 76px;
  grid-template-columns: 74px minmax(0, 1fr);
}

.quick-link-card-user {
  grid-template-columns: 74px minmax(0, 1fr) auto;
}

.quick-link-card-rec,
.quick-link-card {
  background: linear-gradient(135deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02)), var(--ui-surface-strong);
}

body:not(.theme-dark) .quick-link-card-rec,
body:not(.theme-dark) .quick-link-card {
  background: linear-gradient(135deg, rgba(235,100,91,0.055), rgba(255,255,255,0.86)), var(--ui-surface-strong);
}

.quick-link-card-cover,
.custom-app-card-cover {
  background: linear-gradient(135deg, rgba(235,100,91,0.92), rgba(168,58,52,0.82));
}

.quick-link-card-rec .quick-link-card-cover {
  background: linear-gradient(135deg, rgba(235,100,91,0.84), rgba(124,100,235,0.68));
}

.quick-link-card-name,
.custom-app-card-name {
  font-size: 14px;
  font-weight: 750;
}

.quick-link-card-desc,
.custom-app-card-desc {
  font-size: 11px;
  line-height: 1.45;
}

.quick-link-card:hover,
.custom-app-card:hover,
.history-card:hover,
.history-tile-image:hover,
.history-file-picker-item:hover {
  transform: translateY(-2px);
  border-color: rgba(235,100,91,0.24);
  box-shadow: var(--ui-accent-glow), var(--ui-shadow-card);
}

.quick-link-card-empty {
  cursor: default;
  border-color: rgba(148, 163, 184, 0.22);
  background: linear-gradient(135deg, rgba(255,255,255,0.035), rgba(255,255,255,0.015)), var(--ui-surface-strong);
}

body:not(.theme-dark) .quick-link-card-empty {
  background: linear-gradient(135deg, rgba(148,163,184,0.08), rgba(255,255,255,0.88)), var(--ui-surface-strong);
}

.quick-link-card-empty:hover {
  transform: none;
  border-color: rgba(235,100,91,0.18);
  box-shadow: var(--ui-shadow-card);
}

.quick-link-card-empty .quick-link-card-cover {
  opacity: 0.76;
  filter: saturate(0.78);
}

.quick-link-card-empty .quick-link-card-name,
.quick-link-card-empty .quick-link-card-desc {
  color: var(--text-muted);
}

.custom-app-gallery-grid {
  grid-auto-rows: 108px;
  gap: 12px;
}

.custom-app-gallery-track {
  gap: 16px;
  padding-top: 3px;
}

.custom-app-gallery-viewport {
  border-radius: 22px;
}

.custom-app-card {
  height: 108px;
  grid-template-columns: 108px minmax(0, 1fr);
}

.custom-app-gallery-arrow,
.quick-link-add-btn,
.quick-link-form-submit,
.quick-link-form-cancel,
.btn-secondary,
.btn-primary,
.btn-generate,
.btn-generate-inspiration,
.btn-generate-cover,
.btn-generate-music,
.btn-save-inspiration,
.music-copy-btn,
.music-reset-btn,
.music-revert-btn,
.music-repair-icon,
.music-repair-diagnosis-toggle,
.history-toolbar-btn,
.history-cancel-btn,
.result-image-actions button,
.custom-app-back,
.custom-app-key-trigger,
.model-selector-trigger,
.image-create-generate,
.translate-generate,
#floating-billing-link,
.creator-head-billing,
.music-billing-link,
.content-header-billing {
  border-radius: 999px;
}

.btn-primary,
.btn-generate,
.btn-generate-music,
.btn-save-inspiration,
.quick-link-form-submit,
.image-create-generate,
.translate-generate,
#floating-billing-link,
.creator-head-billing,
.music-billing-link,
.content-header-billing {
  background: linear-gradient(135deg, #f4776f, #eb645b);
  border-color: transparent;
  color: #fff;
  box-shadow: 0 14px 32px rgba(235,100,91,0.24);
}

.btn-secondary,
.quick-link-add-btn,
.quick-link-form-cancel,
.custom-app-gallery-arrow,
.history-toolbar-btn,
.custom-app-back,
.custom-app-key-trigger,
.model-selector-trigger {
  background: var(--ui-field);
  border: 1px solid var(--ui-border);
  color: var(--text);
}

.quick-link-form-card,
.quick-link-form-cover,
.upload-placeholder,
.upload-thumb-wrap,
.upload-thumb-add,
.settings-digital-human-upload {
  background: var(--ui-field);
  border-color: var(--ui-border);
  border-radius: 18px;
  box-shadow: none !important;
}

textarea,
input[type="number"],
input[type="password"],
input[type="url"],
input[type="text"]:not(#music-song-title),
select,
.quick-link-form-input,
.music-inspiration-result,
.music-lyrics-textarea,
.music-melody-textarea,
.music-result-viewer-textarea,
.music-inspiration-rough-input,
.music-inspiration-final-textarea,
.music-inspiration-option-card .option-textarea,
.translate-textarea,
.translate-output,
#content-panel.content-panel-custom-app .image-create-prompt-wrap .prompt-editor,
#content-panel.content-panel-custom-app .image-create-prompt-wrap textarea,
#content-panel.content-panel-custom-app .section-row .form-group textarea,
#content-panel.content-panel-custom-app .section-row .form-group input[type="text"],
#content-panel.content-panel-custom-app .section-row .form-group input[type="number"] {
  background: var(--ui-field);
  border-color: transparent;
  border-radius: 18px;
  box-shadow: inset 0 0 0 1px var(--ui-border);
}

textarea:focus,
input:focus,
select:focus,
.quick-link-form-input:focus,
.music-inspiration-result:focus,
.music-lyrics-textarea:focus,
.music-melody-textarea:focus,
.music-result-viewer-textarea:focus,
.music-inspiration-rough-input:focus,
.music-inspiration-final-textarea:focus,
.translate-textarea:focus {
  border-color: transparent;
  box-shadow: inset 0 0 0 1px rgba(235,100,91,0.42), 0 0 0 4px rgba(235,100,91,0.10);
}

.modal-content {
  border-radius: 28px;
  background: var(--ui-surface-strong);
}

.settings-content {
  width: min(760px, 92vw);
  max-height: calc(100vh - 70px);
}

.settings-content .form-group {
  padding: 14px;
  border-radius: 18px;
  background: var(--ui-surface-soft);
  border: 1px solid var(--ui-border);
}

.modal-header {
  margin-bottom: 16px;
}

.modal-actions {
  padding-top: 8px;
}

.history-shell {
  border-radius: 26px;
}

.history-card,
.history-tile-image,
.result-image-wrapper,
.history-file-picker-item {
  border-radius: 22px;
}

.history-card-overlay,
.history-tile-image-overlay,
.result-image-actions {
  background: linear-gradient(180deg, transparent, rgba(0,0,0,0.62));
}

.result-empty,
.history-empty,
.quick-links-empty {
  border-radius: 22px;
  background: var(--ui-surface-soft);
  color: var(--text-muted);
}

.music-create-shell {
  gap: 16px;
}

#content-panel.content-panel-music-create {
  overflow-y: auto;
}

.music-status-bar {
  padding: 14px 18px;
  border-radius: 24px;
}

.music-model-row {
  padding: 14px 0 4px;
}

.music-status-step {
  min-width: 62px;
  padding: 8px 10px;
  border-radius: 16px;
}

.music-status-step:hover {
  background: var(--ui-field);
}

.music-status-dot {
  width: 9px;
  height: 9px;
}

.music-status-line {
  opacity: 0.45;
}

.music-create-top {
  padding: 18px;
  border-radius: 24px;
}

.music-create-bottom {
  gap: 16px;
}

.music-lyrics-panel,
.music-melody-panel {
  padding: 18px;
  min-height: 0;
}

.music-lyrics-header,
.music-section-header,
.music-melody-section-header {
  min-height: 34px;
}

.music-lyrics-textarea,
.music-melody-textarea {
  padding: 16px;
}

.music-inspiration-final {
  padding: 16px;
}

.music-repair-diagnosis {
  border-radius: 20px;
}

.music-repair-diagnosis-header {
  background: var(--ui-surface-soft);
  border-bottom-color: var(--ui-border);
}

.music-inspiration-option-card {
  border-radius: 20px;
}

.music-chip,
.music-choice-btn {
  border-radius: 999px;
}

.toast {
  border-radius: 999px;
  background: rgba(17,19,24,0.82);
  box-shadow: 0 18px 48px rgba(0,0,0,0.22);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

body:not(.theme-dark) .toast {
  background: rgba(31,34,41,0.84);
}

/* Retired: this tightening layer broke the established music workspace. */
@media (max-width: 0px) and (min-width: 1px) {
/* ===== 音乐创作页专项收紧 ===== */
#content-panel.content-panel-music-create {
  height: auto;
  min-height: 100%;
  padding: 12px 22px 28px;
  overflow: visible !important;
}

#content:has(#content-panel.content-panel-music-create) {
  overflow-y: auto;
  overflow-x: hidden;
}

#content-panel.content-panel-music-create .music-create-shell {
  height: auto;
  min-height: max-content;
  width: 100%;
  max-width: none;
  gap: 12px;
  justify-content: flex-start;
  padding-bottom: 18px;
  margin-left: 0;
  margin-right: 0;
}

#content-panel.content-panel-music-create .music-status-bar {
  padding: 10px 14px;
  border-radius: 22px;
  background: rgba(255,255,255,0.025);
  box-shadow: none;
}

#content-panel.content-panel-music-create .music-status-step {
  min-width: 48px;
  padding: 5px 6px;
  gap: 3px;
}

#content-panel.content-panel-music-create .music-status-label {
  font-size: 9px;
}

#content-panel.content-panel-music-create .music-status-dot {
  width: 7px;
  height: 7px;
}

#content-panel.content-panel-music-create .music-status-line {
  transform: translateY(-8px);
  max-width: none;
  min-width: 8px;
}

#content-panel.content-panel-music-create .music-mode-bar {
  padding: 4px 0 2px;
}

#content-panel.content-panel-music-create .music-mode-segment {
  background: var(--ui-field);
  border: 1px solid var(--ui-border);
  border-radius: 999px;
  padding: 3px;
}

#content-panel.content-panel-music-create .music-mode-btn {
  min-height: 30px;
  padding: 0 22px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
}

#content-panel.content-panel-music-create .music-mode-btn.active {
  background: rgba(235,100,91,0.22);
  color: var(--primary);
}

#content-panel.content-panel-music-create .music-model-row {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 6px 0 4px;
}

#content-panel.content-panel-music-create .music-model-picker {
  width: clamp(260px, 24vw, 330px) !important;
  max-width: calc(100% - 48px) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

#content-panel.content-panel-music-create .music-model-trigger {
  min-height: 36px;
  gap: 8px;
  padding: 5px 10px;
  border-color: rgba(235, 100, 91, 0.34);
  box-shadow: 0 8px 20px rgba(235, 100, 91, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.07);
}

#content-panel.content-panel-music-create .music-model-sigil {
  width: 22px;
  height: 22px;
  flex-basis: 22px;
  font-size: 12px;
  box-shadow: 0 0 14px rgba(235, 100, 91, 0.28);
}

#content-panel.content-panel-music-create .music-model-kicker {
  font-size: 8px;
  letter-spacing: 0.06em;
}

#content-panel.content-panel-music-create .music-model-name {
  font-size: 12px;
}

#content-panel.content-panel-music-create .music-model-live {
  padding: 3px 6px;
  font-size: 8px;
}

#content-panel.content-panel-music-create .music-model-chevron {
  font-size: 12px;
}

body:not(.theme-dark) .music-model-trigger {
  border-color: rgba(235, 100, 91, 0.24);
  background:
    radial-gradient(circle at 9% 28%, rgba(255, 132, 103, 0.18), transparent 28%),
    radial-gradient(circle at 92% 18%, rgba(117, 222, 238, 0.16), transparent 31%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(255, 246, 241, 0.86));
  color: #17202b;
  box-shadow:
    0 16px 36px rgba(235, 100, 91, 0.13),
    0 10px 26px rgba(16, 24, 40, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

body:not(.theme-dark) #content-panel.content-panel-music-create .music-model-trigger {
  border-color: rgba(235, 100, 91, 0.22);
  box-shadow:
    0 14px 34px rgba(235, 100, 91, 0.12),
    0 10px 24px rgba(16, 24, 40, 0.07),
    inset 0 1px 0 rgba(255, 255, 255, 0.94);
}

body:not(.theme-dark) .music-model-trigger:hover,
body:not(.theme-dark) .music-model-trigger[aria-expanded="true"] {
  border-color: rgba(235, 100, 91, 0.42);
  background:
    radial-gradient(circle at 9% 28%, rgba(255, 132, 103, 0.24), transparent 30%),
    radial-gradient(circle at 92% 18%, rgba(117, 222, 238, 0.20), transparent 32%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(255, 244, 238, 0.92));
  box-shadow:
    0 18px 42px rgba(235, 100, 91, 0.17),
    0 12px 28px rgba(16, 24, 40, 0.09),
    inset 0 1px 0 rgba(255, 255, 255, 0.96);
}

body:not(.theme-dark) .music-model-sigil,
body:not(.theme-dark) .music-model-option-mark {
  background:
    radial-gradient(circle at 34% 28%, #fff6bd 0%, #ff9d78 42%, #eb645b 68%, #8eeeff 128%);
  color: #17202b;
  box-shadow:
    0 0 20px rgba(235, 100, 91, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.55);
}

body:not(.theme-dark) #content-panel.content-panel-music-create .music-model-sigil {
  box-shadow:
    0 0 16px rgba(235, 100, 91, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.55);
}

body:not(.theme-dark) .music-model-kicker,
body:not(.theme-dark) .music-model-option-meta {
  color: rgba(102, 112, 133, 0.86);
}

body:not(.theme-dark) .music-model-name,
body:not(.theme-dark) .music-model-option-name {
  color: #17181d;
}

body:not(.theme-dark) .music-model-live,
body:not(.theme-dark) .music-model-option-badge {
  border: 1px solid rgba(235, 100, 91, 0.18);
  background:
    linear-gradient(135deg, rgba(255, 245, 239, 0.92), rgba(255, 222, 210, 0.72));
  color: #d84f47;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

body:not(.theme-dark) .music-model-chevron {
  color: rgba(102, 112, 133, 0.78);
}

body:not(.theme-dark) .music-model-menu {
  border-color: rgba(235, 100, 91, 0.18);
  background:
    radial-gradient(circle at 14% 0%, rgba(255, 132, 103, 0.16), transparent 33%),
    radial-gradient(circle at 88% 18%, rgba(117, 222, 238, 0.14), transparent 38%),
    rgba(255, 252, 248, 0.96);
  box-shadow:
    0 24px 70px rgba(16, 24, 40, 0.14),
    0 0 30px rgba(235, 100, 91, 0.10);
}

body:not(.theme-dark) .music-model-option:hover {
  border-color: rgba(235, 100, 91, 0.16);
  background: rgba(235, 100, 91, 0.08);
}

body:not(.theme-dark) .music-model-option.active {
  border-color: rgba(235, 100, 91, 0.30);
  background:
    linear-gradient(135deg, rgba(235, 100, 91, 0.14), rgba(117, 222, 238, 0.08)),
    rgba(255, 255, 255, 0.62);
}

#content-panel.content-panel-music-create .music-create-top-row {
  gap: 12px;
  align-items: stretch;
}

#content-panel.content-panel-music-create .music-create-top {
  min-height: 116px;
  padding: 14px;
  border-radius: 22px;
  flex: 1 1 auto;
}

#content-panel.content-panel-music-create .music-create-top-side {
  width: 112px;
}

#content-panel.content-panel-music-create .music-output-toolbar {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  min-height: 34px;
  margin: 0 0 2px;
}

#content-panel.content-panel-music-create .music-output-toolbar .music-billing-link {
  position: static;
  margin-left: auto;
  margin-bottom: 0;
}

#content-panel.content-panel-music-create .music-create-bottom {
  min-height: 840px;
  height: 840px;
  gap: 14px;
}

#content-panel.content-panel-music-create .music-lyrics-panel,
#content-panel.content-panel-music-create .music-melody-panel {
  height: 100%;
  min-height: 0;
  padding: 14px;
  border-radius: 22px;
  overflow: hidden;
}

#content-panel.content-panel-music-create .music-lyrics-textarea,
#content-panel.content-panel-music-create .music-melody-textarea,
#content-panel.content-panel-music-create #music-result-singing {
  min-height: 0;
  flex: 1 1 auto;
  padding: 14px;
}

#content-panel.content-panel-music-create .music-melody-panel {
  overflow-y: auto;
  overflow-x: hidden;
  gap: 8px;
}

#content-panel.content-panel-music-create .music-melody-section {
  min-height: 0;
  flex: 1 1 0;
  gap: 6px;
}

#content-panel.content-panel-music-create .music-melody-section:has(#music-result-storyboard) {
  flex: 1.12 1 0;
}

#content-panel.content-panel-music-create #music-result-style,
#content-panel.content-panel-music-create #music-result-singing,
#content-panel.content-panel-music-create #music-result-storyboard {
  min-height: 74px;
}

#content-panel.content-panel-music-create .music-section-header,
#content-panel.content-panel-music-create .music-lyrics-header,
#content-panel.content-panel-music-create .music-melody-section-header {
  min-height: 28px;
  margin-bottom: 4px;
}

#content-panel.content-panel-music-create .music-section-label,
#content-panel.content-panel-music-create .music-lyrics-header-label,
#content-panel.content-panel-music-create .music-melody-section-label {
  font-size: 13px;
}

#content-panel.content-panel-music-create .music-inspiration-result {
  max-height: 130px;
  min-height: 70px;
}

#content-panel.content-panel-music-create .music-inspiration-final {
  padding: 12px;
  border-radius: 20px;
}
}

/* ===== Nala macOS client inner UI redesign 2026-06-02 ===== */
:root {
  --nala-glass: rgba(255, 255, 255, 0.72);
  --nala-glass-strong: rgba(255, 255, 255, 0.86);
  --nala-glass-soft: rgba(255, 255, 255, 0.52);
  --nala-field: rgba(255, 255, 255, 0.68);
  --nala-line: rgba(35, 45, 58, 0.12);
  --nala-line-strong: rgba(35, 45, 58, 0.18);
  --nala-coral: #eb645b;
  --nala-coral-2: #ff8376;
  --nala-cyan: #69d7e5;
  --nala-cream: #fff8f1;
  --nala-text: #17181d;
  --nala-muted: rgba(38, 48, 58, 0.62);
  --nala-shadow: 0 24px 70px rgba(16, 24, 40, 0.12);
  --nala-shadow-soft: 0 14px 34px rgba(16, 24, 40, 0.08);
  --nala-glow: 0 20px 58px rgba(235, 100, 91, 0.18);
}

body.theme-dark {
  --nala-glass: rgba(31, 43, 55, 0.72);
  --nala-glass-strong: rgba(38, 52, 64, 0.86);
  --nala-glass-soft: rgba(255, 255, 255, 0.06);
  --nala-field: rgba(255, 255, 255, 0.075);
  --nala-line: rgba(255, 255, 255, 0.115);
  --nala-line-strong: rgba(255, 255, 255, 0.17);
  --nala-text: #fff8f2;
  --nala-muted: rgba(255, 248, 242, 0.58);
  --nala-shadow: 0 28px 86px rgba(0, 0, 0, 0.28);
  --nala-shadow-soft: 0 18px 42px rgba(0, 0, 0, 0.18);
  --nala-glow: 0 22px 62px rgba(235, 100, 91, 0.22), 0 0 42px rgba(105, 215, 229, 0.08);
}

#content {
  background: transparent !important;
}

body:not(.theme-dark) {
  background:
    radial-gradient(circle at 12% 10%, rgba(235, 100, 91, 0.12), transparent 33%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.10), transparent 32%),
    linear-gradient(135deg, rgba(255, 252, 248, 0.96), rgba(239, 245, 248, 0.96)) !important;
}

body.theme-dark {
  background:
    radial-gradient(circle at 12% 10%, rgba(255, 118, 97, 0.20), transparent 34%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.15), transparent 32%),
    radial-gradient(circle at 62% 92%, rgba(255, 202, 132, 0.08), transparent 38%),
    linear-gradient(135deg, rgba(15, 22, 31, 0.99), rgba(24, 36, 46, 0.98) 52%, rgba(12, 17, 25, 0.99)) !important;
}

body.theme-dark #content {
  background: transparent !important;
}

#content-title {
  color: var(--text);
  font-weight: 860;
  letter-spacing: 0;
}

.content-subtitle,
.panel-service-desc,
.form-hint {
  color: var(--text-muted);
}

#content-panel.content-panel-music-create,
#content-panel.content-panel-quick-links,
#content-panel.content-panel-translate {
  background: transparent !important;
}

.creator-shell,
.translate-shell,
.quick-links-section,
.music-status-bar,
.music-create-top,
.music-lyrics-panel,
.music-melody-panel,
.music-inspiration-final,
.music-repair-diagnosis,
.history-shell,
.history-card,
.history-tile-image,
.history-file-picker-item,
.result-image-wrapper,
.modal-content {
  border: 1px solid var(--nala-line) !important;
  background:
    radial-gradient(circle at 10% 0%, rgba(235, 100, 91, 0.09), transparent 34%),
    radial-gradient(circle at 90% 5%, rgba(105, 215, 229, 0.08), transparent 34%),
    var(--nala-glass) !important;
  box-shadow: var(--nala-shadow-soft) !important;
  backdrop-filter: blur(20px) saturate(135%);
  -webkit-backdrop-filter: blur(20px) saturate(135%);
}

.creator-shell,
.translate-shell,
.quick-links-section,
.music-status-bar,
.music-create-top,
.music-lyrics-panel,
.music-melody-panel,
.music-inspiration-final,
.music-repair-diagnosis {
  border-radius: 24px !important;
}

textarea,
input[type="number"],
input[type="password"],
input[type="url"],
input[type="email"],
input[type="text"]:not(#music-song-title),
select,
.prompt-editor,
.quick-link-form-input,
.translate-textarea,
.translate-output,
.music-inspiration-result,
.music-lyrics-textarea,
.music-melody-textarea,
.music-result-viewer-textarea,
.music-inspiration-rough-input,
.music-inspiration-final-textarea,
.music-inspiration-option-card .option-textarea,
#content-panel.content-panel-custom-app .image-create-prompt-wrap .prompt-editor,
#content-panel.content-panel-custom-app .image-create-prompt-wrap textarea,
#content-panel.content-panel-custom-app .section-row .form-group textarea,
#content-panel.content-panel-custom-app .section-row .form-group input[type="text"],
#content-panel.content-panel-custom-app .section-row .form-group input[type="number"] {
  border: 1px solid var(--nala-line) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.10), rgba(255, 255, 255, 0.035)),
    var(--nala-field) !important;
  color: var(--text) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

textarea:focus,
input:focus,
select:focus,
.prompt-editor:focus,
.quick-link-form-input:focus,
.translate-textarea:focus,
.translate-output:focus,
.music-inspiration-result:focus,
.music-lyrics-textarea:focus,
.music-melody-textarea:focus,
.music-result-viewer-textarea:focus,
.music-inspiration-rough-input:focus,
.music-inspiration-final-textarea:focus {
  border-color: rgba(235, 100, 91, 0.48) !important;
  box-shadow:
    0 0 0 4px rgba(235, 100, 91, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
  outline: none !important;
}

textarea::placeholder,
input::placeholder,
.prompt-editor:empty::before {
  color: var(--nala-muted) !important;
}

.btn-primary,
.btn-generate,
.btn-generate-music,
.btn-generate-inspiration,
.btn-generate-cover,
.btn-save-inspiration,
.quick-link-form-submit,
.image-create-generate,
.translate-generate {
  border: 0 !important;
  border-radius: 999px !important;
  background:
    radial-gradient(circle at 22% 16%, rgba(255, 244, 194, 0.40), transparent 28%),
    linear-gradient(135deg, var(--nala-coral-2), var(--nala-coral) 58%, #d94f48) !important;
  color: #fff !important;
  font-weight: 820 !important;
  box-shadow:
    0 18px 42px rgba(235, 100, 91, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.24) !important;
}

.btn-primary:hover:not(:disabled),
.btn-generate:hover:not(:disabled),
.btn-generate-music:hover:not(:disabled),
.btn-generate-inspiration:hover:not(:disabled),
.btn-generate-cover:hover:not(:disabled),
.quick-link-form-submit:hover,
.image-create-generate:hover:not(:disabled),
.translate-generate:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow:
    0 22px 54px rgba(235, 100, 91, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.28) !important;
}

.btn-secondary,
.quick-link-add-btn,
.quick-link-form-cancel,
.custom-app-gallery-arrow,
.history-toolbar-btn,
.history-cancel-btn,
.custom-app-back,
.custom-app-key-trigger,
.model-selector-trigger,
.image-create-size-trigger,
.compact-control-input select,
.compact-control-input input,
.settings-content .input-action,
.settings-content .btn-secondary,
.music-mode-segment,
.music-model-trigger {
  border: 1px solid var(--nala-line) !important;
  border-radius: 999px !important;
  background:
    radial-gradient(circle at 12% 12%, rgba(235, 100, 91, 0.08), transparent 34%),
    var(--nala-field) !important;
  color: var(--text) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.075) !important;
}

.btn-secondary:hover:not(:disabled),
.quick-link-add-btn:hover,
.quick-link-form-cancel:hover,
.custom-app-gallery-arrow:hover:not(:disabled),
.history-toolbar-btn:hover,
.custom-app-back:hover,
.custom-app-key-trigger:hover,
.model-selector-trigger:hover,
.image-create-size-trigger:hover,
.settings-content .input-action:hover,
.settings-content .btn-secondary:hover {
  border-color: rgba(235, 100, 91, 0.34) !important;
  background: rgba(235, 100, 91, 0.12) !important;
  color: var(--text) !important;
}

/* Settings */
#settings-modal {
  z-index: 2400;
  padding: 24px;
}

#settings-modal .modal-backdrop {
  background: rgba(7, 10, 14, 0.58);
  backdrop-filter: blur(18px) saturate(0.85);
  -webkit-backdrop-filter: blur(18px) saturate(0.85);
}

#settings-modal .settings-content {
  width: min(920px, calc(100vw - 64px)) !important;
  max-width: min(920px, calc(100vw - 64px)) !important;
  max-height: calc(100vh - 56px) !important;
  padding: 24px 28px 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  border-radius: 28px !important;
  background:
    radial-gradient(circle at 14% 0%, rgba(235, 100, 91, 0.13), transparent 34%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.10), transparent 32%),
    var(--nala-glass-strong) !important;
  box-shadow: var(--nala-shadow) !important;
}

#settings-modal .modal-header {
  position: sticky;
  top: -24px;
  z-index: 3;
  margin: -24px -28px 18px !important;
  padding: 22px 28px 16px !important;
  border-bottom: 1px solid var(--nala-line);
  background: rgba(38, 52, 64, 0.82);
  backdrop-filter: blur(20px) saturate(135%);
  -webkit-backdrop-filter: blur(20px) saturate(135%);
}

#settings-modal .modal-header h3 {
  margin: 0 !important;
  font-size: 22px !important;
  font-weight: 880 !important;
  line-height: 1.2;
}

#settings-modal .modal-close-btn {
  width: 34px !important;
  height: 34px !important;
  border-radius: 999px !important;
}

#settings-modal .settings-content .form-group {
  margin: 0 0 16px !important;
  padding: 0 0 16px !important;
  border: 0 !important;
  border-bottom: 1px solid var(--nala-line) !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

#settings-modal .settings-content .form-group > label,
#settings-modal .settings-section-heading label {
  margin: 0 0 8px !important;
  color: var(--text) !important;
  font-size: 14px !important;
  font-weight: 780 !important;
}

#settings-modal .settings-content input[type="text"],
#settings-modal .settings-content input[type="password"],
#settings-modal .settings-content input[type="url"],
#settings-modal .settings-content input[type="number"],
#settings-modal .settings-content input[type="email"],
#settings-modal .settings-content input:not([type]),
#settings-modal .settings-content textarea,
#settings-modal .settings-content select {
  min-height: 44px !important;
  padding: 10px 13px !important;
  font-size: 13px !important;
}

#settings-modal .settings-digital-human-upload {
  width: 100% !important;
  min-height: 132px !important;
  max-height: 186px !important;
  aspect-ratio: 16 / 5 !important;
  border-width: 1px !important;
  border-style: dashed !important;
  border-radius: 20px !important;
  background:
    radial-gradient(circle at 14% 16%, rgba(235, 100, 91, 0.10), transparent 34%),
    var(--nala-field) !important;
}

#settings-modal .settings-digital-human-thumb {
  object-fit: contain !important;
}

#settings-modal .settings-model-chip-panel,
#settings-modal .settings-feishu-section {
  padding: 14px !important;
  border: 1px solid var(--nala-line) !important;
  border-radius: 20px !important;
  background:
    linear-gradient(135deg, rgba(235, 100, 91, 0.07), rgba(105, 215, 229, 0.05)),
    var(--nala-glass-soft) !important;
  box-shadow: none !important;
}

#settings-modal .settings-feishu-quick-guide {
  border-color: rgba(105, 215, 229, 0.22) !important;
  background: rgba(105, 215, 229, 0.08) !important;
}

#settings-modal .modal-actions {
  position: sticky;
  bottom: 0;
  z-index: 3;
  margin: 4px -28px 0 !important;
  padding: 14px 28px 18px !important;
  border-top: 1px solid var(--nala-line);
  background: rgba(38, 52, 64, 0.84);
  backdrop-filter: blur(20px) saturate(135%);
  -webkit-backdrop-filter: blur(20px) saturate(135%);
}

/* AI music */
#content:has(#content-panel.content-panel-music-create) {
  overflow: hidden !important;
}

#content-panel.content-panel-music-create {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  height: 100% !important;
  padding: 18px 24px 24px !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
}

#content-panel.content-panel-music-create .music-create-shell {
  width: min(1360px, 100%) !important;
  min-height: 100%;
  margin: 0 auto !important;
  display: flex;
  flex-direction: column;
  gap: 14px !important;
}

#content-panel.content-panel-music-create .music-status-bar {
  padding: 12px 16px !important;
  overflow-x: auto;
  overflow-y: hidden;
}

#content-panel.content-panel-music-create .music-status-steps {
  min-width: min-content;
  justify-content: center;
}

#content-panel.content-panel-music-create .music-status-step {
  min-width: 58px !important;
  padding: 8px 9px !important;
  border: 1px solid transparent !important;
  border-radius: 16px !important;
  background: transparent !important;
}

#content-panel.content-panel-music-create .music-status-step:hover,
#content-panel.content-panel-music-create .music-status-step.active {
  border-color: rgba(235, 100, 91, 0.24) !important;
  background: rgba(235, 100, 91, 0.11) !important;
}

#content-panel.content-panel-music-create .music-status-dot {
  width: 10px !important;
  height: 10px !important;
}

#content-panel.content-panel-music-create .music-status-line {
  flex: 1 1 28px;
  min-width: 12px;
  max-width: 62px;
  height: 2px !important;
  border-radius: 999px;
  opacity: 0.55;
  background: linear-gradient(90deg, rgba(235, 100, 91, 0.22), rgba(105, 215, 229, 0.18)) !important;
}

#content-panel.content-panel-music-create .music-mode-bar {
  display: flex;
  justify-content: center;
  padding: 0 !important;
}

#content-panel.content-panel-music-create .music-mode-segment {
  display: inline-flex;
  gap: 4px;
  padding: 5px !important;
}

#content-panel.content-panel-music-create .music-mode-btn {
  min-height: 34px !important;
  padding: 0 22px !important;
  border-radius: 999px !important;
  color: var(--text-secondary) !important;
  font-weight: 780 !important;
}

#content-panel.content-panel-music-create .music-mode-btn.active {
  background: linear-gradient(135deg, rgba(235, 100, 91, 0.95), rgba(211, 75, 68, 0.82)) !important;
  color: #fff !important;
  box-shadow: 0 12px 28px rgba(235, 100, 91, 0.24) !important;
}

#content-panel.content-panel-music-create .music-model-row {
  padding: 0 0 8px !important;
}

#content-panel.content-panel-music-create .music-model-picker {
  width: min(440px, 100%) !important;
}

#content-panel.content-panel-music-create .music-model-trigger {
  min-height: 48px !important;
  padding: 8px 13px !important;
}

#content-panel.content-panel-music-create .music-model-sigil,
.model-selector-brand,
.model-option-icon,
.music-model-option-mark {
  background:
    radial-gradient(circle at 30% 22%, #fff6bf, #ff8f77 42%, #eb645b 66%, #7be8ff 130%) !important;
  color: #18202a !important;
}

#content-panel.content-panel-music-create .music-create-top-row {
  width: 100%;
  gap: 12px !important;
  align-items: stretch;
}

#content-panel.content-panel-music-create .music-create-top {
  min-height: 118px;
  padding: 16px !important;
}

#content-panel.content-panel-music-create .music-create-top-side {
  width: 128px;
  padding: 0 !important;
}

#content-panel.content-panel-music-create .music-create-bottom {
  display: grid !important;
  grid-template-columns: minmax(0, 1.14fr) minmax(360px, 0.86fr);
  gap: 16px !important;
  min-height: 640px !important;
  align-items: stretch;
}

#content-panel.content-panel-music-create .music-lyrics-panel,
#content-panel.content-panel-music-create .music-melody-panel {
  min-height: 0;
  padding: 18px !important;
  overflow: hidden;
}

#content-panel.content-panel-music-create .music-lyrics-panel {
  display: flex;
  flex-direction: column;
}

#content-panel.content-panel-music-create .music-melody-panel {
  display: flex;
  flex-direction: column;
  gap: 14px !important;
  overflow-y: auto;
}

#content-panel.content-panel-music-create .music-melody-section {
  display: flex;
  flex: 1 1 0;
  flex-direction: column;
  min-height: 150px;
}

#content-panel.content-panel-music-create .music-melody-section:has(#music-result-singing) {
  flex: 1.25 1 0;
  min-height: 220px;
}

#content-panel.content-panel-music-create .music-section-header,
#content-panel.content-panel-music-create .music-lyrics-header,
#content-panel.content-panel-music-create .music-melody-section-header {
  min-height: 32px;
  margin-bottom: 6px;
}

#content-panel.content-panel-music-create .music-section-label,
#content-panel.content-panel-music-create .music-lyrics-header-label,
#content-panel.content-panel-music-create .music-melody-section-label {
  color: var(--text) !important;
  font-size: 13px;
  font-weight: 820;
}

#content-panel.content-panel-music-create .music-lyrics-textarea,
#content-panel.content-panel-music-create .music-melody-textarea,
#content-panel.content-panel-music-create #music-result-style,
#content-panel.content-panel-music-create #music-result-singing,
#content-panel.content-panel-music-create #music-result-storyboard {
  flex: 1 1 auto;
  min-height: 0 !important;
  padding: 15px !important;
  resize: none;
  overflow-y: auto !important;
}

#content-panel.content-panel-music-create .music-lyrics-textarea {
  min-height: 520px !important;
}

#content-panel.content-panel-music-create .music-copy-btn,
#content-panel.content-panel-music-create .music-revert-btn,
#content-panel.content-panel-music-create .music-reset-btn {
  border-radius: 999px !important;
}

/* Image, AI app, AI video */
#content.content-custom-app-layout {
  background:
    radial-gradient(circle at 12% 10%, rgba(235, 100, 91, 0.12), transparent 33%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.10), transparent 32%),
    linear-gradient(135deg, rgba(255, 252, 248, 0.96), rgba(239, 245, 248, 0.96)) !important;
}

body.theme-dark #content.content-custom-app-layout {
  background:
    radial-gradient(circle at 12% 10%, rgba(255, 118, 97, 0.20), transparent 34%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.15), transparent 32%),
    radial-gradient(circle at 62% 92%, rgba(255, 202, 132, 0.08), transparent 38%),
    linear-gradient(135deg, rgba(15, 22, 31, 0.99), rgba(24, 36, 46, 0.98) 52%, rgba(12, 17, 25, 0.99)) !important;
}

#content.content-custom-app-layout.content-custom-app-split {
  grid-template-columns: minmax(0, 1fr) clamp(360px, 32vw, 480px) !important;
  grid-template-rows: minmax(0, 1fr) !important;
  gap: 0 !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-result {
  grid-column: 1 !important;
  grid-row: 1 !important;
  min-height: 0 !important;
  padding: 24px !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  border-left: 0 !important;
  border-right: 1px solid var(--nala-line) !important;
  background: transparent !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app {
  position: relative !important;
  inset: auto !important;
  grid-column: 2 !important;
  grid-row: 1 !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
  padding: 24px 22px !important;
  overflow: hidden !important;
  border-right: 0 !important;
  border-left: 1px solid rgba(255, 255, 255, 0.06) !important;
  box-shadow: none !important;
  background: transparent !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .creator-shell {
  width: 100% !important;
  max-width: none !important;
  height: 100% !important;
  max-height: 100% !important;
  margin: 0 !important;
  overflow-y: auto !important;
  padding: 18px !important;
  border-radius: 26px !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .creator-body {
  flex: 1 1 auto;
  min-height: 0;
  overflow: visible;
}

#content.content-custom-app-layout.content-custom-app-split #content-result .history-shell {
  width: 100% !important;
  max-width: none !important;
}

#content.content-custom-app-layout #content-panel.content-panel-custom-app.is-gallery,
#content.content-custom-app-layout #content-panel.content-panel-video-apps.is-gallery {
  position: relative !important;
  inset: auto !important;
  grid-column: 1 !important;
  grid-row: 1 / -1 !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 28px !important;
  overflow: visible !important;
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}

#content.content-custom-app-layout #content-panel.content-panel-custom-app.is-gallery .custom-app-gallery-shell,
#content-panel.content-panel-video-apps .video-app-gallery-shell {
  width: min(1120px, 100%) !important;
  max-width: 1120px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  filter: none !important;
}

.custom-app-gallery-track {
  gap: 18px !important;
}

.custom-app-card,
.quick-link-card,
#content-panel.content-panel-video-apps .video-app-card {
  border: 1px solid var(--nala-line) !important;
  background:
    radial-gradient(circle at 10% 0%, rgba(235, 100, 91, 0.08), transparent 34%),
    var(--nala-glass-strong) !important;
  box-shadow: var(--nala-shadow-soft) !important;
  transition: transform 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease;
}

.custom-app-card:hover,
.quick-link-card:hover,
#content-panel.content-panel-video-apps .video-app-card:hover {
  transform: translateY(-2px);
  border-color: rgba(235, 100, 91, 0.34) !important;
  box-shadow: var(--nala-glow), var(--nala-shadow-soft) !important;
}

.custom-app-card {
  height: 146px !important;
  grid-template-columns: 146px minmax(0, 1fr) !important;
  border-radius: 24px !important;
  overflow: hidden;
  transform: perspective(1200px) rotateX(var(--card-tilt-x, 0deg)) rotateY(var(--card-tilt-y, 0deg)) translateY(0);
  transform-style: preserve-3d;
}

.custom-app-card-cover {
  position: relative;
  border-radius: 20px !important;
  background:
    radial-gradient(circle at 26% 22%, rgba(255, 246, 188, 0.36), transparent 30%),
    linear-gradient(135deg, rgba(235, 100, 91, 0.96), rgba(105, 215, 229, 0.58)) !important;
}

.custom-app-card-cover::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at var(--card-glow-x, 50%) var(--card-glow-y, 50%), rgba(255,255,255,0.28), transparent 32%);
  opacity: var(--card-glow-opacity, 0);
  transition: opacity 0.16s ease;
  pointer-events: none;
}

#content-panel.content-panel-video-apps .video-app-gallery-grid {
  width: 100%;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 28px !important;
}

#content-panel.content-panel-video-apps .video-app-card {
  gap: 14px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

#content-panel.content-panel-video-apps .video-app-card-cover {
  width: 100%;
  height: auto !important;
  aspect-ratio: 16 / 9 !important;
  border-radius: 26px !important;
  overflow: hidden;
  background-size: cover !important;
  background-position: center !important;
  box-shadow: var(--nala-shadow-soft), 0 0 34px rgba(235, 100, 91, 0.13) !important;
}

#content-panel.content-panel-video-apps .video-app-card-cover-img {
  width: 100%;
  height: 100%;
  object-fit: cover !important;
  object-position: center !important;
}

#content-panel.content-panel-video-apps .video-app-card-title {
  color: var(--text) !important;
  font-size: 20px !important;
  font-weight: 860 !important;
}

#content.content-custom-app-layout #content-panel.content-panel-image-create:not(.content-panel-custom-app) {
  border-radius: 28px !important;
  box-shadow: var(--nala-shadow) !important;
}

#content-panel.content-panel-image-create .creator-shell,
#content-panel.content-panel-image-create .image-create-prompt-wrap,
#content-panel.content-panel-image-create .image-create-dock {
  border-color: var(--nala-line) !important;
  background:
    radial-gradient(circle at 12% 0%, rgba(235, 100, 91, 0.08), transparent 34%),
    var(--nala-glass) !important;
}

/* Translate */
#content:has(#content-panel.content-panel-translate) {
  overflow: hidden !important;
}

#content-panel.content-panel-translate {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  padding: 24px !important;
  overflow-y: auto !important;
}

#content-panel.content-panel-translate .translate-shell {
  width: min(1200px, 100%) !important;
  min-height: min(720px, calc(100vh - 96px));
  margin: 0 auto !important;
  padding: 20px !important;
}

.translate-panel {
  border: 1px solid var(--nala-line) !important;
  border-radius: 24px !important;
  background: var(--nala-glass-soft) !important;
}

/* Quick links */
#content:has(#content-panel.content-panel-quick-links) {
  overflow: hidden !important;
}

#content-panel.content-panel-quick-links {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  padding: 24px !important;
  overflow-y: auto !important;
}

.quick-links-page {
  width: min(1180px, 100%) !important;
  margin: 0 auto !important;
  gap: 18px !important;
}

.quick-links-section {
  padding: 18px !important;
}

.quick-links-section-title {
  color: var(--text);
  font-size: 16px !important;
  font-weight: 860 !important;
}

.quick-links-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

.quick-link-card {
  min-height: 92px !important;
  height: auto !important;
  grid-template-columns: 88px minmax(0, 1fr) !important;
  border-radius: 22px !important;
  overflow: hidden;
}

.quick-link-card-user {
  grid-template-columns: 88px minmax(0, 1fr) auto !important;
}

.quick-link-card-cover {
  border-radius: 18px !important;
}

.quick-link-card-name {
  color: var(--text) !important;
  font-size: 14px !important;
  font-weight: 820 !important;
}

.quick-link-card-desc {
  color: var(--text-muted) !important;
  font-size: 12px !important;
  line-height: 1.5 !important;
}

.quick-link-form-card {
  border: 1px solid var(--nala-line) !important;
  border-radius: 24px !important;
  background: var(--nala-glass-soft) !important;
}

@media (max-width: 1180px) {
  .quick-links-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  #content-panel.content-panel-music-create .music-create-bottom {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 860px) {
  #settings-modal {
    padding: 14px;
  }

  #settings-modal .settings-content {
    width: calc(100vw - 28px) !important;
    max-width: calc(100vw - 28px) !important;
    max-height: calc(100vh - 28px) !important;
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  #settings-modal .modal-header,
  #settings-modal .modal-actions {
    margin-left: -18px !important;
    margin-right: -18px !important;
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  #content.content-custom-app-layout.content-custom-app-split {
    grid-template-columns: 1fr !important;
    grid-template-rows: minmax(0, 1fr) minmax(320px, 42vh) !important;
  }

  #content.content-custom-app-layout.content-custom-app-split #content-result {
    grid-column: 1 !important;
    grid-row: 1 !important;
    border-right: 0 !important;
    border-bottom: 1px solid var(--nala-line) !important;
  }

  #content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app {
    grid-column: 1 !important;
    grid-row: 2 !important;
    border-left: 0 !important;
  }

  .quick-links-grid,
  #content-panel.content-panel-video-apps .video-app-gallery-grid {
    grid-template-columns: 1fr !important;
  }
}

#content-panel.content-panel-quick-links {
  padding-top: 16px;
}

.quick-link-card-actions {
  align-self: center;
  margin-right: 8px;
  padding: 4px;
  border-radius: 999px;
  background: var(--ui-field);
}

.quick-link-edit-btn,
.quick-link-delete-btn {
  border-radius: 999px;
}

.quick-link-form-card {
  padding: 14px;
  border-color: var(--ui-border);
  border-radius: 22px;
  background: var(--ui-surface-soft);
}

.quick-link-form-row {
  align-items: stretch;
}

.quick-link-form-cover {
  width: 76px;
  height: 76px;
  min-width: 76px;
  border-style: solid;
}

.settings-content .input-with-action {
  align-items: center;
}

.settings-content .input-with-action > input {
  min-height: 42px;
}

.settings-content .btn-secondary,
.settings-content .input-action {
  min-height: 38px;
  border-radius: 999px;
}

.settings-content .form-hint {
  line-height: 1.6;
}

.settings-help-links,
.settings-feishu-quick-guide {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.settings-feishu-quick-guide {
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px;
  border: 1px solid rgba(79, 195, 199, 0.18);
  border-radius: 16px;
  background: rgba(79, 195, 199, 0.06);
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.5;
}

.settings-feishu-quick-guide > span {
  min-width: 220px;
  flex: 1;
}

.settings-feishu-guide-actions {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.settings-help-links a,
.settings-feishu-guide-actions a,
.settings-guide-link {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 5px 10px;
  border: 1px solid rgba(235, 100, 91, 0.24);
  border-radius: 999px;
  background: rgba(235, 100, 91, 0.08);
  color: var(--primary);
  font-size: 12px;
  font-weight: 750;
  text-decoration: none;
  cursor: pointer;
}

.settings-global-guide-link {
  min-height: 34px;
  padding: 7px 14px;
  background: rgba(79, 195, 199, 0.08);
  border-color: rgba(79, 195, 199, 0.24);
  color: var(--text-secondary);
}

.settings-help-links a:hover,
.settings-feishu-guide-actions a:hover,
.settings-guide-link:hover {
  border-color: rgba(235, 100, 91, 0.46);
  background: rgba(235, 100, 91, 0.14);
  color: var(--text);
  text-decoration: none;
}

.settings-global-guide-link:hover {
  background: rgba(79, 195, 199, 0.14);
  border-color: rgba(79, 195, 199, 0.42);
  color: var(--text);
}

.settings-model-chip-panel {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--ui-border, var(--divider));
  border-radius: 18px;
  background: var(--ui-surface-soft, var(--bg-secondary));
}

.settings-model-chip-group {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  max-height: 168px;
  overflow-y: auto;
  padding-right: 2px;
}

.settings-model-chip {
  min-height: 34px;
  padding: 7px 14px;
  border: 1px solid var(--ui-border, var(--divider));
  border-radius: 999px;
  background: var(--ui-field, var(--bg-panel));
  color: var(--text-secondary);
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 13px;
  font-weight: 650;
  line-height: 1.25;
  white-space: nowrap;
  transition: background 0.15s, border-color 0.15s, color 0.15s, box-shadow 0.15s, transform 0.15s;
}

.settings-model-chip:hover {
  border-color: rgba(235, 100, 91, 0.48);
  color: var(--primary);
  background: var(--primary-light);
  transform: translateY(-1px);
}

.settings-model-chip.selected {
  border-color: rgba(235, 100, 91, 0.95);
  background: linear-gradient(135deg, rgba(235, 100, 91, 0.95), rgba(221, 85, 76, 0.92));
  color: #fff;
  box-shadow: 0 8px 22px rgba(235, 100, 91, 0.22);
}

.settings-model-chip-badge {
  padding: 2px 6px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.18);
  color: currentColor;
  font-size: 10px;
  font-weight: 700;
  line-height: 1.2;
}

.settings-model-custom-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
}

.settings-model-custom-row input {
  min-height: 40px;
}

.settings-section-heading {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.settings-section-heading label {
  margin-bottom: 5px;
}

.settings-inline-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  padding: 6px 12px;
  border: 1px solid rgba(235, 100, 91, 0.24);
  border-radius: 999px;
  background: rgba(235, 100, 91, 0.08);
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 700;
  white-space: nowrap;
}

.settings-inline-toggle input {
  accent-color: var(--primary);
}

.settings-feishu-section {
  padding: 16px;
  border: 1px solid rgba(235, 100, 91, 0.2);
  border-radius: 20px;
  background:
    linear-gradient(135deg, rgba(235, 100, 91, 0.09), rgba(79, 195, 199, 0.05)),
    var(--ui-surface-soft, var(--bg-secondary));
}

.settings-feishu-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}

.settings-feishu-url-input {
  grid-column: 1 / -1;
}

@media (max-width: 720px) {
  .settings-section-heading,
  .settings-feishu-grid {
    grid-template-columns: 1fr;
  }

  .settings-section-heading {
    flex-direction: column;
  }
}

.settings-model-custom-row .btn-secondary {
  min-width: 76px;
}

#content-panel.content-panel-music-create,
.music-create-shell,
.music-create-top-row,
.music-create-top,
.music-create-bottom,
.music-lyrics-panel,
.music-melody-panel,
.music-melody-section,
.music-inspiration-final {
  min-width: 0;
  max-width: 100%;
}

#content-panel.content-panel-music-create,
.music-create-shell {
  overflow-x: hidden;
}

.music-create-top-row,
.music-create-bottom {
  width: 100%;
}

.music-status-bar {
  max-width: 100%;
  overflow: hidden;
}

.music-status-steps {
  width: 100%;
  min-width: 0;
  justify-content: space-between;
}

.music-status-line {
  flex: 1 1 24px;
  min-width: 10px;
  max-width: 58px;
}
}

/* Retired: this global shell layer broke established client workspace layouts. */
@media (max-width: 0px) and (min-width: 1px) {
/* ===== 最终统一：外壳、页面壳层与滚动条 ===== */
:root {
  --shell-sidebar-width: 148px;
  --shell-page-max-width: 1180px;
  --shell-page-x: 24px;
  --shell-page-y: 18px;
}

::-webkit-scrollbar,
body *::-webkit-scrollbar {
  width: 3px !important;
  height: 3px !important;
}

::-webkit-scrollbar-track,
body *::-webkit-scrollbar-track {
  background: transparent !important;
}

::-webkit-scrollbar-thumb,
body *::-webkit-scrollbar-thumb {
  background: rgba(146,156,182,0.30) !important;
  border: none !important;
  border-radius: 999px !important;
}

body:not(.theme-dark) ::-webkit-scrollbar-thumb,
body:not(.theme-dark) body *::-webkit-scrollbar-thumb {
  background: rgba(120,128,148,0.30) !important;
}

body,
body * {
  scrollbar-width: thin;
  scrollbar-color: rgba(146,156,182,0.30) transparent;
}

body:not(.theme-dark),
body:not(.theme-dark) * {
  scrollbar-color: rgba(120,128,148,0.30) transparent;
}

#app {
  position: relative;
}

#app::after,
#sidebar::before,
#sidebar::after,
#sidebar-toggle::before,
#sidebar-toggle::after,
#content::before,
#content::after {
  content: none !important;
  display: none !important;
  background: transparent !important;
  box-shadow: none !important;
}

#app::before {
  content: none !important;
  display: none !important;
  position: absolute !important;
  left: var(--shell-sidebar-width);
  top: 0;
  bottom: 0;
  width: 8px !important;
  pointer-events: none;
  z-index: 4;
  background: transparent !important;
  box-shadow: none !important;
}

body.sidebar-hidden #app::before {
  left: 0;
  opacity: 0;
}

#sidebar {
  width: var(--shell-sidebar-width) !important;
  min-width: var(--shell-sidebar-width) !important;
  border-right: none !important;
  box-shadow: none !important;
}

#sidebar.sidebar-collapsed {
  width: 0 !important;
  min-width: 0 !important;
  border-right: none !important;
  box-shadow: none !important;
}

#sidebar .service-tag {
  display: none !important;
}

#sidebar .sidebar-service {
  justify-content: flex-start;
  gap: 0;
}

#sidebar .sidebar-service-text {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

#sidebar-toggle {
  width: 30px !important;
  min-width: 30px !important;
  height: 72px !important;
  min-height: 72px !important;
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  z-index: 6;
  border: 1px solid var(--ui-border) !important;
  border-radius: 999px;
  box-shadow: 0 10px 24px rgba(0,0,0,0.10) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

body:not(.sidebar-hidden) #sidebar-toggle {
  left: calc(var(--shell-sidebar-width) - 15px);
  margin: 0 !important;
}

body.sidebar-hidden #sidebar-toggle {
  left: 10px;
  bottom: auto;
  width: 34px !important;
  min-width: 34px !important;
  margin: 0 !important;
}

#content {
  border-left: none !important;
  box-shadow: none !important;
}

#content:not(.content-custom-app-layout) {
  padding: 0 !important;
}

#content:has(#content-panel.content-panel-translate) #content-header {
  display: none !important;
}

#content-header {
  padding: 16px var(--shell-page-x) 0 !important;
}

#content:has(#content-panel.content-panel-translate),
#content:has(#content-panel.content-panel-quick-links),
#content:has(#content-panel.content-panel-music-create) {
  overflow: hidden !important;
}

#content-panel.content-panel-translate,
#content-panel.content-panel-quick-links,
#content-panel.content-panel-music-create {
  flex: 1 1 auto;
  min-height: 0;
  padding: var(--shell-page-y) var(--shell-page-x) var(--shell-page-x) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  background: transparent !important;
}

#content-panel.content-panel-translate .translate-shell,
#content-panel.content-panel-quick-links .quick-links-page,
#content-panel.content-panel-music-create .music-create-shell {
  width: min(var(--shell-page-max-width), 100%) !important;
  max-width: var(--shell-page-max-width) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

#content.content-custom-app-layout:not(.content-custom-app-split) #content-result {
  padding: var(--shell-page-y) var(--shell-page-x) var(--shell-page-x);
  background: transparent !important;
  scrollbar-width: thin !important;
  scrollbar-color: rgba(146,156,182,0.30) transparent !important;
}


body:not(.theme-dark) #content.content-custom-app-layout:not(.content-custom-app-split) #content-result {
  scrollbar-color: rgba(120,128,148,0.30) transparent !important;
}

#content.content-custom-app-layout:not(.content-custom-app-split) #content-result::-webkit-scrollbar {
  width: 3px !important;
  height: 3px !important;
}

#content.content-custom-app-layout:not(.content-custom-app-split) #content-result::-webkit-scrollbar-track {
  background: transparent !important;
}

#content.content-custom-app-layout:not(.content-custom-app-split) #content-result::-webkit-scrollbar-thumb {
  background: rgba(146,156,182,0.30) !important;
  border: none !important;
  border-radius: 999px !important;
}

body:not(.theme-dark) #content.content-custom-app-layout:not(.content-custom-app-split) #content-result::-webkit-scrollbar-thumb {
  background: rgba(120,128,148,0.30) !important;
}

@media (max-width: 0px) and (min-width: 1px) {
/* Retired: fixed inner music sizing changed the established workspace layout. */
#content-panel.content-panel-music-create .music-create-bottom {
  height: 840px !important;
  min-height: 840px !important;
  align-items: stretch;
}

#content-panel.content-panel-music-create .music-melody-panel {
  display: grid !important;
  grid-template-rows: auto 0.42fr auto 1.55fr auto 0.42fr !important;
  row-gap: 8px !important;
  overflow: hidden !important;
}

#content-panel.content-panel-music-create .music-melody-section {
  display: contents !important;
}

#content-panel.content-panel-music-create .music-melody-section-header {
  min-height: 28px !important;
  margin: 0 !important;
}

#content-panel.content-panel-music-create #music-result-style,
#content-panel.content-panel-music-create #music-result-storyboard,
#content-panel.content-panel-music-create #music-result-singing {
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  flex: none !important;
}

#content-panel.content-panel-music-create .music-lyrics-panel,
#content-panel.content-panel-music-create .music-melody-panel {
  height: 840px !important;
}

#content-panel.content-panel-music-create .music-lyrics-textarea {
  height: auto !important;
  min-height: 0 !important;
}

#content.content-custom-app-layout {
  background:
    radial-gradient(circle at 13% 8%, rgba(235,100,91,0.13), transparent 31%),
    linear-gradient(135deg, rgba(255,255,255,0.84), rgba(244,246,250,0.92)) !important;
}

body.theme-dark #content.content-custom-app-layout {
  background:
    radial-gradient(circle at 12% 10%, rgba(255, 116, 91, 0.18), transparent 34%),
    radial-gradient(circle at 86% 8%, rgba(120, 232, 255, 0.13), transparent 32%),
    radial-gradient(circle at 62% 92%, rgba(255, 194, 111, 0.08), transparent 36%),
    linear-gradient(135deg, rgba(18, 25, 34, 0.97), rgba(25, 36, 45, 0.95) 52%, rgba(15, 19, 27, 0.98)) !important;
}

#content-panel.content-panel-music-create .music-status-step {
  min-width: 62px !important;
  padding: 8px 10px !important;
  gap: 5px !important;
}

#content-panel.content-panel-music-create .music-status-dot {
  width: 14px !important;
  height: 14px !important;
  box-shadow: inset 0 0 0 3px rgba(255,255,255,0.06);
}

#content-panel.content-panel-music-create .music-status-label {
  font-size: 10px !important;
}
}
}

/* ===== Nala macOS client inner UI relaunch final locks 2026-06-02 ===== */
#content,
#content.content-custom-app-layout {
  color: var(--nala-v2-text) !important;
  background:
    radial-gradient(circle at 12% 10%, rgba(235, 100, 91, 0.12), transparent 33%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.11), transparent 32%),
    linear-gradient(135deg, rgba(255, 252, 248, 0.96), rgba(239, 245, 248, 0.96)) !important;
}

body.theme-dark #content,
body.theme-dark #content.content-custom-app-layout {
  background:
    radial-gradient(circle at 12% 10%, rgba(255, 118, 97, 0.20), transparent 34%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.15), transparent 32%),
    radial-gradient(circle at 62% 92%, rgba(255, 202, 132, 0.08), transparent 38%),
    linear-gradient(135deg, rgba(15, 22, 31, 0.99), rgba(24, 36, 46, 0.98) 52%, rgba(12, 17, 25, 0.99)) !important;
}

#settings-modal .settings-content {
  width: min(860px, calc(100vw - 96px)) !important;
  max-width: min(860px, calc(100vw - 96px)) !important;
  max-height: calc(100vh - 56px) !important;
  border-radius: 28px !important;
  background:
    radial-gradient(circle at 14% 0%, rgba(235, 100, 91, 0.14), transparent 34%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.11), transparent 32%),
    var(--nala-v2-surface-strong) !important;
  box-shadow: var(--nala-v2-shadow) !important;
}

#settings-modal .settings-content > .form-group,
#settings-modal .settings-content > .settings-feishu-section {
  margin: 0 24px !important;
  padding: 16px 0 !important;
  border: 0 !important;
  border-bottom: 1px solid var(--nala-v2-line) !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

#settings-modal .modal-header,
#settings-modal .modal-actions {
  margin: 0 !important;
  border-color: var(--nala-v2-line) !important;
}

#content-panel.content-panel-music-create .music-create-shell {
  width: min(1380px, 100%) !important;
  margin: 0 auto !important;
  gap: 14px !important;
}

#content-panel.content-panel-music-create .music-status-bar {
  padding: 16px 18px 4px !important;
  overflow: hidden !important;
  scrollbar-width: none !important;
}

#content-panel.content-panel-music-create .music-status-bar::-webkit-scrollbar {
  display: none !important;
}

#content-panel.content-panel-music-create .music-status-steps {
  width: 100% !important;
  min-width: 0 !important;
  justify-content: space-between !important;
  gap: 0 !important;
}

#content-panel.content-panel-music-create .music-status-step {
  min-width: 78px !important;
  padding: 12px 10px 10px !important;
  gap: 8px !important;
  border-radius: 18px !important;
}

#content-panel.content-panel-music-create .music-status-dot {
  width: 12px !important;
  height: 12px !important;
}

#content-panel.content-panel-music-create .music-status-label {
  font-size: 13px !important;
  font-weight: 800 !important;
}

#content-panel.content-panel-music-create .music-status-line {
  flex: 1 1 20px !important;
  min-width: 18px !important;
  max-width: 52px !important;
}

#content-panel.content-panel-music-create .music-status-melody-group {
  padding: 8px 8px 6px !important;
  border-radius: 18px !important;
}

#content-panel.content-panel-music-create .music-model-row {
  display: flex !important;
  justify-content: center !important;
  padding: 4px 0 8px !important;
}

#content-panel.content-panel-music-create .music-model-picker {
  width: min(560px, 100%) !important;
}

#content-panel.content-panel-music-create .music-model-trigger {
  min-height: 76px !important;
  padding: 14px 18px !important;
  gap: 14px !important;
  border-radius: 32px !important;
  border: 1px solid rgba(235, 100, 91, 0.22) !important;
  background:
    radial-gradient(circle at 12% 0%, rgba(255, 163, 137, 0.18), transparent 36%),
    radial-gradient(circle at 88% 10%, rgba(105, 215, 229, 0.10), transparent 32%),
    rgba(32, 43, 55, 0.82) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 18px 42px rgba(0, 0, 0, 0.16) !important;
}

body:not(.theme-dark) #content-panel.content-panel-music-create .music-model-trigger {
  background:
    radial-gradient(circle at 12% 0%, rgba(255, 163, 137, 0.18), transparent 36%),
    radial-gradient(circle at 88% 10%, rgba(105, 215, 229, 0.12), transparent 32%),
    rgba(255, 255, 255, 0.82) !important;
  border-color: rgba(38, 48, 58, 0.12) !important;
}

#content-panel.content-panel-music-create .music-model-sigil {
  width: 44px !important;
  height: 44px !important;
  flex: 0 0 44px !important;
}

#content-panel.content-panel-music-create .music-model-current {
  gap: 4px !important;
}

#content-panel.content-panel-music-create .music-model-kicker {
  font-size: 11px !important;
  font-weight: 850 !important;
  letter-spacing: 0.12em !important;
}

#content-panel.content-panel-music-create .music-model-name {
  font-size: 22px !important;
  font-weight: 860 !important;
  line-height: 1.1 !important;
}

#content-panel.content-panel-music-create .music-model-live {
  min-height: 34px !important;
  padding: 0 14px !important;
  font-size: 12px !important;
  font-weight: 900 !important;
}

#content-panel.content-panel-music-create .music-model-chevron {
  font-size: 24px !important;
  font-weight: 900 !important;
}

#content-panel.content-panel-music-create .music-create-bottom {
  display: grid !important;
  grid-template-columns: minmax(0, 0.98fr) minmax(420px, 0.92fr) !important;
  gap: 18px !important;
  min-height: clamp(680px, 72vh, 920px) !important;
  align-items: stretch !important;
}

#content-panel.content-panel-music-create .music-create-bottom > .music-lyrics-panel,
#content-panel.content-panel-music-create .music-create-bottom > .music-melody-panel {
  width: auto !important;
  flex: none !important;
}

#content-panel.content-panel-music-create .music-lyrics-panel,
#content-panel.content-panel-music-create .music-melody-panel {
  min-height: 0 !important;
  overflow: hidden !important;
  border-radius: 26px !important;
}

#content-panel.content-panel-music-create .music-lyrics-panel {
  grid-column: 1 !important;
  display: flex !important;
  flex-direction: column !important;
}

#content-panel.content-panel-music-create .music-lyrics-textarea {
  min-height: 0 !important;
  height: 100% !important;
  flex: 1 1 auto !important;
}

#content-panel.content-panel-music-create .music-melody-panel {
  grid-column: 2 !important;
  display: grid !important;
  grid-template-rows: minmax(0, 0.82fr) minmax(0, 1.14fr) minmax(0, 1.04fr) !important;
  gap: 16px !important;
  overflow: hidden !important;
}

#content-panel.content-panel-music-create .music-melody-section {
  min-height: 0 !important;
  display: flex !important;
  flex-direction: column !important;
}

#content-panel.content-panel-music-create .music-melody-textarea,
#content-panel.content-panel-music-create #music-result-style,
#content-panel.content-panel-music-create #music-result-singing,
#content-panel.content-panel-music-create #music-result-storyboard {
  min-height: 0 !important;
  height: 100% !important;
  flex: 1 1 auto !important;
  overflow-y: auto !important;
}

#content.content-custom-app-layout.content-custom-app-split {
  grid-template-columns: minmax(0, 1fr) clamp(360px, 32vw, 480px) !important;
  grid-template-rows: minmax(0, 1fr) !important;
  overflow: hidden !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail {
  grid-template-columns: minmax(0, 1fr) clamp(320px, 26vw, 388px) !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-result {
  grid-column: 1 !important;
  grid-row: 1 !important;
  max-width: none !important;
  padding: 24px !important;
  border-right: 1px solid var(--nala-v2-line) !important;
  border-left: 0 !important;
  background: transparent !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-result .history-shell {
  width: 100% !important;
  max-width: none !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-result {
  padding: 24px 28px !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-result .history-shell {
  display: flex !important;
  flex-direction: column !important;
  gap: 18px !important;
  min-height: 100% !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app {
  position: relative !important;
  inset: auto !important;
  grid-column: 2 !important;
  grid-row: 1 !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
  padding: 24px 22px !important;
  border-left: 1px solid var(--nala-v2-line) !important;
  border-right: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app {
  padding: 18px 18px 20px !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .creator-shell {
  width: 100% !important;
  max-width: none !important;
  height: 100% !important;
  max-height: 100% !important;
  margin: 0 !important;
  overflow-y: auto !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .creator-shell {
  border-radius: 30px !important;
  padding: 18px !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .creator-head {
  gap: 10px !important;
  margin-bottom: 16px !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .custom-app-panel-title {
  margin-bottom: 14px !important;
  font-size: 24px !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .creator-body {
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .image-create-dock,
#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .image-create-upload-area,
#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .section-row,
#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .image-create-prompt-wrap {
  border-radius: 24px !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .section-row,
#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .image-create-prompt-wrap {
  padding: 14px 16px !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .creator-footer {
  padding-top: 16px !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .creator-footer .btn-generate {
  min-height: 48px !important;
  border-radius: 999px !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .upload-thumb-wrap,
#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .upload-thumb-add,
#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .upload-placeholder {
  border-radius: 22px !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .upload-thumb-wrap-video,
#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .upload-thumb-wrap-audio {
  border-radius: 22px !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .upload-thumb,
#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .upload-thumb-video,
#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .upload-thumb-audio {
  border-radius: 20px !important;
}

.video-app-detail-hero {
  display: grid !important;
  grid-template-columns: minmax(320px, 1.05fr) minmax(0, 0.95fr) !important;
  align-items: center !important;
  gap: 22px !important;
  padding: 22px !important;
  border: 1px solid var(--nala-v2-line) !important;
  border-radius: 32px !important;
  background:
    radial-gradient(circle at 12% 0%, rgba(235, 100, 91, 0.12), transparent 32%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.11), transparent 34%),
    var(--nala-v2-surface) !important;
  box-shadow: var(--nala-v2-shadow-soft) !important;
}

.video-app-detail-cover {
  position: relative !important;
  overflow: hidden !important;
  border-radius: 30px !important;
  aspect-ratio: 16 / 9 !important;
  min-height: 0 !important;
  background:
    radial-gradient(circle at 26% 20%, rgba(255, 244, 191, 0.34), transparent 30%),
    linear-gradient(135deg, rgba(235, 100, 91, 0.92), rgba(105, 215, 229, 0.58)) !important;
  box-shadow:
    0 26px 56px rgba(8, 15, 24, 0.18),
    0 0 0 1px rgba(255, 255, 255, 0.04) inset !important;
}

.video-app-detail-cover img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

.video-app-detail-cover.is-placeholder {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.video-app-detail-mark {
  font-size: 48px !important;
  color: rgba(255, 255, 255, 0.86) !important;
}

.video-app-detail-copy {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  min-width: 0 !important;
}

.video-app-detail-kicker {
  font-size: 11px !important;
  font-weight: 800 !important;
  color: var(--text-secondary) !important;
}

.video-app-detail-title {
  margin: 0 !important;
  font-size: clamp(28px, 3vw, 38px) !important;
  line-height: 1.08 !important;
  color: var(--text) !important;
}

.video-app-detail-desc {
  margin: 0 !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
  color: var(--text-secondary) !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-result .history-empty {
  margin-top: 0 !important;
  min-height: 160px !important;
  border-radius: 24px !important;
}

#content.content-custom-app-layout:not(.content-custom-app-split) #content-panel.content-panel-custom-app.is-gallery {
  position: relative !important;
  inset: auto !important;
  grid-column: 1 !important;
  grid-row: 2 !important;
  align-self: center !important;
  justify-self: stretch !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
  padding: 28px !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#content.content-custom-app-layout:not(.content-custom-app-split) #content-panel.content-panel-custom-app.is-gallery .custom-app-gallery-shell {
  width: min(1120px, 100%) !important;
  max-width: 1120px !important;
  margin: 0 auto !important;
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
  filter: none !important;
}

#content.content-custom-app-layout:not(.content-custom-app-split) #content-panel.content-panel-custom-app.is-gallery .custom-app-gallery-carousel {
  min-height: 0 !important;
  align-items: center !important;
}

#content.content-custom-app-layout:not(.content-custom-app-split) #content-panel.content-panel-custom-app.is-gallery .custom-app-gallery-viewport {
  overflow: visible !important;
  padding-top: 0 !important;
}

#content.content-custom-app-layout #content-panel.content-panel-custom-app.is-gallery,
#content.content-custom-app-layout #content-panel.content-panel-video-apps.is-gallery {
  position: relative !important;
  inset: auto !important;
  grid-column: 1 !important;
  grid-row: 1 / -1 !important;
  height: 100% !important;
  max-height: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 28px !important;
  background: transparent !important;
  box-shadow: none !important;
}

#content-panel.content-panel-video-apps .video-app-gallery-shell,
#content.content-custom-app-layout #content-panel.content-panel-custom-app.is-gallery .custom-app-gallery-shell {
  width: min(1120px, 100%) !important;
  max-width: 1120px !important;
  margin: 0 auto !important;
}

#content-panel.content-panel-video-apps .video-app-gallery-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 28px !important;
}

#content-panel.content-panel-video-apps .video-app-card-cover {
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 16 / 9 !important;
  border-radius: 26px !important;
  background-size: cover !important;
  background-position: center !important;
}

#content-panel.content-panel-video-apps .video-app-card-cover-img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
}

.quick-links-page {
  width: min(1180px, 100%) !important;
  margin: 0 auto !important;
}

.quick-links-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

.quick-link-card {
  min-height: 92px !important;
  height: auto !important;
  grid-template-columns: 88px minmax(0, 1fr) !important;
  border-radius: 22px !important;
}

.quick-link-card-user {
  grid-template-columns: 88px minmax(0, 1fr) auto !important;
}

.creator-shell,
.translate-shell,
.quick-links-section,
.music-status-bar,
.music-create-top,
.music-lyrics-panel,
.music-melody-panel,
.history-shell,
.history-card,
.quick-link-card,
.custom-app-card,
.modal-content,
.music-confirm-dialog,
.full-auto-dialog-content {
  border-color: var(--nala-v2-line) !important;
  background:
    radial-gradient(circle at 10% 0%, rgba(235, 100, 91, 0.09), transparent 34%),
    radial-gradient(circle at 90% 5%, rgba(105, 215, 229, 0.08), transparent 34%),
    var(--nala-v2-surface) !important;
  box-shadow: var(--nala-v2-shadow-soft) !important;
}

@media (max-width: 1180px) {
  .quick-links-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  #content-panel.content-panel-music-create .music-create-bottom {
    grid-template-columns: 1fr !important;
  }

  #content-panel.content-panel-music-create .music-melody-panel {
    grid-column: 1 !important;
    grid-template-rows: repeat(3, minmax(220px, auto)) !important;
  }
}

@media (max-width: 860px) {
  #content.content-custom-app-layout.content-custom-app-split {
    grid-template-columns: 1fr !important;
    grid-template-rows: minmax(0, 1fr) minmax(320px, 42vh) !important;
  }

  #content.content-custom-app-layout.content-custom-app-split #content-result,
  #content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app {
    grid-column: 1 !important;
  }

  #content.content-custom-app-layout.content-custom-app-split #content-result {
    grid-row: 1 !important;
    border-right: 0 !important;
    border-bottom: 1px solid var(--nala-v2-line) !important;
  }

  #content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app {
    grid-row: 2 !important;
    border-left: 0 !important;
  }

  .quick-links-grid,
  #content-panel.content-panel-video-apps .video-app-gallery-grid {
    grid-template-columns: 1fr !important;
  }

  .video-app-detail-hero {
    grid-template-columns: 1fr !important;
  }
}

/* Unified inner page background follows the AI music gradient canvas. */
:root {
  --nala-v2-page-bg-light:
    radial-gradient(circle at 12% 10%, rgba(235, 100, 91, 0.12), transparent 33%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.11), transparent 32%),
    linear-gradient(135deg, rgba(255, 252, 248, 0.96), rgba(239, 245, 248, 0.96));
  --nala-v2-page-bg-dark:
    radial-gradient(circle at 12% 10%, rgba(255, 118, 97, 0.20), transparent 34%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.15), transparent 32%),
    radial-gradient(circle at 62% 92%, rgba(255, 202, 132, 0.08), transparent 38%),
    linear-gradient(135deg, rgba(15, 22, 31, 0.99), rgba(24, 36, 46, 0.98) 52%, rgba(12, 17, 25, 0.99));
  --nala-v2-page-bg: var(--nala-v2-page-bg-light);
}

body.theme-dark {
  --nala-v2-page-bg: var(--nala-v2-page-bg-dark);
}

body.theme-light,
body:not(.theme-dark),
body.theme-dark {
  background: var(--nala-v2-page-bg) !important;
}

#content,
#content.content-custom-app-layout,
#content-panel,
#content-result,
#content-panel.content-panel-image-create,
#content-panel.content-panel-translate,
#content-panel.content-panel-quick-links,
#content-panel.content-panel-music-create,
#content-panel.content-panel-custom-app,
#content-panel.content-panel-video-apps,
#content.content-custom-app-layout #content-panel.content-panel-custom-app.is-gallery,
#content.content-custom-app-layout #content-panel.content-panel-video-apps.is-gallery,
#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app,
#content.content-custom-app-layout.content-custom-app-split #content-result {
  background: var(--nala-v2-page-bg) !important;
}

/* ===== Nala macOS client inner UI relaunch v2 2026-06-02 ===== */
:root {
  --nala-v2-coral: #eb645b;
  --nala-v2-coral-hot: #ff7f73;
  --nala-v2-coral-deep: #d94f48;
  --nala-v2-cyan: #69d7e5;
  --nala-v2-cream: #fff8f1;
  --nala-v2-text: #18202a;
  --nala-v2-muted: rgba(38, 48, 58, 0.62);
  --nala-v2-line: rgba(38, 48, 58, 0.12);
  --nala-v2-line-strong: rgba(38, 48, 58, 0.18);
  --nala-v2-surface: rgba(255, 255, 255, 0.74);
  --nala-v2-surface-strong: rgba(255, 255, 255, 0.9);
  --nala-v2-surface-soft: rgba(255, 255, 255, 0.5);
  --nala-v2-field: rgba(255, 255, 255, 0.68);
  --nala-v2-shadow: 0 24px 70px rgba(16, 24, 40, 0.12);
  --nala-v2-shadow-soft: 0 14px 38px rgba(16, 24, 40, 0.08);
  --nala-v2-glow: 0 22px 62px rgba(235, 100, 91, 0.18);
}

body.theme-dark {
  --nala-v2-text: #fff8f2;
  --nala-v2-muted: rgba(255, 248, 242, 0.62);
  --nala-v2-line: rgba(255, 255, 255, 0.11);
  --nala-v2-line-strong: rgba(255, 255, 255, 0.17);
  --nala-v2-surface: rgba(31, 43, 55, 0.72);
  --nala-v2-surface-strong: rgba(37, 51, 63, 0.88);
  --nala-v2-surface-soft: rgba(255, 255, 255, 0.065);
  --nala-v2-field: rgba(255, 255, 255, 0.075);
  --nala-v2-shadow: 0 28px 90px rgba(0, 0, 0, 0.28);
  --nala-v2-shadow-soft: 0 18px 46px rgba(0, 0, 0, 0.18);
  --nala-v2-glow: 0 22px 62px rgba(235, 100, 91, 0.23), 0 0 42px rgba(105, 215, 229, 0.08);
}

body {
  color: var(--nala-v2-text);
}

body.theme-light,
body:not(.theme-dark) {
  background:
    radial-gradient(circle at 14% 8%, rgba(235, 100, 91, 0.12), transparent 32%),
    radial-gradient(circle at 92% 4%, rgba(105, 215, 229, 0.16), transparent 30%),
    linear-gradient(135deg, #fffaf5 0%, #edf4f7 100%) !important;
}

body.theme-dark {
  background:
    radial-gradient(circle at 14% 8%, rgba(235, 100, 91, 0.24), transparent 34%),
    radial-gradient(circle at 90% 6%, rgba(105, 215, 229, 0.15), transparent 32%),
    linear-gradient(135deg, #101721 0%, #1b2732 54%, #0c121b 100%) !important;
}

#content,
#content.content-custom-app-layout {
  color: var(--nala-v2-text) !important;
  background:
    radial-gradient(circle at 12% 10%, rgba(235, 100, 91, 0.12), transparent 33%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.11), transparent 32%),
    linear-gradient(135deg, rgba(255, 252, 248, 0.96), rgba(239, 245, 248, 0.96)) !important;
}

body.theme-dark #content,
body.theme-dark #content.content-custom-app-layout {
  background:
    radial-gradient(circle at 12% 10%, rgba(255, 118, 97, 0.20), transparent 34%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.15), transparent 32%),
    radial-gradient(circle at 62% 92%, rgba(255, 202, 132, 0.08), transparent 38%),
    linear-gradient(135deg, rgba(15, 22, 31, 0.99), rgba(24, 36, 46, 0.98) 52%, rgba(12, 17, 25, 0.99)) !important;
}

#content-title,
.custom-app-panel-title,
.quick-links-section-title,
.history-title,
.music-section-label,
.music-lyrics-header-label,
.music-melody-section-label,
.form-group label,
.translate-panel-head,
.translate-language-value,
.music-confirm-title,
.full-auto-dialog-title {
  color: var(--nala-v2-text) !important;
  font-weight: 850 !important;
  letter-spacing: 0 !important;
}

.content-subtitle,
.panel-service-desc,
.form-hint,
.history-subtitle,
.quick-link-card-desc,
.custom-app-card-desc,
.video-app-card-hint,
.music-status-label,
.music-char-counter,
.translate-output-meta,
.translate-usage,
.translate-quota-warning,
.music-confirm-message,
.full-auto-dialog-desc {
  color: var(--nala-v2-muted) !important;
}

#content-panel.content-panel-music-create,
#content-panel.content-panel-quick-links,
#content-panel.content-panel-translate,
#content-panel.content-panel-video-apps,
#content-panel.content-panel-custom-app,
#content-panel.content-panel-image-create {
  background: transparent !important;
}

#content:has(#content-panel.content-panel-music-create),
#content:has(#content-panel.content-panel-quick-links),
#content:has(#content-panel.content-panel-translate) {
  overflow: hidden !important;
}

#content-panel.content-panel-music-create,
#content-panel.content-panel-quick-links,
#content-panel.content-panel-translate {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  padding: 20px 24px 24px !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
}

.creator-shell,
.translate-shell,
.quick-links-section,
.music-status-bar,
.music-create-top,
.music-lyrics-panel,
.music-melody-panel,
.music-inspiration-final,
.music-repair-diagnosis,
.history-shell,
.history-card,
.history-tile-image,
.history-file-picker-item,
.result-image-wrapper,
.modal-content,
.music-confirm-dialog,
.full-auto-dialog-content,
.music-inspiration-option-card,
.music-inspiration-modal-final,
.translate-panel,
.translate-language-card,
.translate-footer,
.quick-link-form-card,
.settings-model-chip-panel,
.settings-feishu-section {
  border: 1px solid var(--nala-v2-line) !important;
  background:
    radial-gradient(circle at 10% 0%, rgba(235, 100, 91, 0.09), transparent 34%),
    radial-gradient(circle at 90% 5%, rgba(105, 215, 229, 0.08), transparent 34%),
    var(--nala-v2-surface) !important;
  box-shadow: var(--nala-v2-shadow-soft) !important;
  backdrop-filter: blur(20px) saturate(135%);
  -webkit-backdrop-filter: blur(20px) saturate(135%);
}

.creator-shell,
.translate-shell,
.quick-links-section,
.music-status-bar,
.music-create-top,
.music-lyrics-panel,
.music-melody-panel,
.music-inspiration-final,
.music-repair-diagnosis,
.modal-content,
.music-confirm-dialog,
.full-auto-dialog-content {
  border-radius: 26px !important;
}

textarea,
input[type="number"],
input[type="password"],
input[type="url"],
input[type="email"],
input[type="text"]:not(#music-song-title),
select,
.prompt-editor,
.quick-link-form-input,
.translate-textarea,
.translate-output,
.music-inspiration-result,
.music-lyrics-textarea,
.music-melody-textarea,
.music-result-viewer-textarea,
.music-inspiration-rough-input,
.music-inspiration-final-textarea,
.music-inspiration-option-card .option-textarea,
.full-auto-inspiration-input,
#content-panel.content-panel-custom-app .image-create-prompt-wrap .prompt-editor,
#content-panel.content-panel-custom-app .image-create-prompt-wrap textarea,
#content-panel.content-panel-custom-app .section-row .form-group textarea,
#content-panel.content-panel-custom-app .section-row .form-group input[type="text"],
#content-panel.content-panel-custom-app .section-row .form-group input[type="number"] {
  border: 1px solid var(--nala-v2-line) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.10), rgba(255, 255, 255, 0.035)),
    var(--nala-v2-field) !important;
  color: var(--nala-v2-text) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

body:not(.theme-dark) textarea,
body:not(.theme-dark) input[type="number"],
body:not(.theme-dark) input[type="password"],
body:not(.theme-dark) input[type="url"],
body:not(.theme-dark) input[type="email"],
body:not(.theme-dark) input[type="text"]:not(#music-song-title),
body:not(.theme-dark) select,
body:not(.theme-dark) .prompt-editor,
body:not(.theme-dark) .quick-link-form-input,
body:not(.theme-dark) .translate-textarea,
body:not(.theme-dark) .translate-output,
body:not(.theme-dark) .music-inspiration-result,
body:not(.theme-dark) .music-lyrics-textarea,
body:not(.theme-dark) .music-melody-textarea,
body:not(.theme-dark) .music-result-viewer-textarea,
body:not(.theme-dark) .music-inspiration-rough-input,
body:not(.theme-dark) .music-inspiration-final-textarea,
body:not(.theme-dark) .music-inspiration-option-card .option-textarea,
body:not(.theme-dark) .full-auto-inspiration-input,
body:not(.theme-dark) #content-panel.content-panel-custom-app .image-create-prompt-wrap .prompt-editor,
body:not(.theme-dark) #content-panel.content-panel-custom-app .image-create-prompt-wrap textarea,
body:not(.theme-dark) #content-panel.content-panel-custom-app .section-row .form-group textarea,
body:not(.theme-dark) #content-panel.content-panel-custom-app .section-row .form-group input[type="text"],
body:not(.theme-dark) #content-panel.content-panel-custom-app .section-row .form-group input[type="number"] {
  background: rgba(255, 255, 255, 0.68) !important;
  color: #17181d !important;
}

textarea:focus,
input:focus,
select:focus,
.prompt-editor:focus,
.quick-link-form-input:focus,
.translate-textarea:focus,
.translate-output:focus,
.music-inspiration-result:focus,
.music-lyrics-textarea:focus,
.music-melody-textarea:focus,
.music-result-viewer-textarea:focus,
.music-inspiration-rough-input:focus,
.music-inspiration-final-textarea:focus,
.full-auto-inspiration-input:focus {
  border-color: rgba(235, 100, 91, 0.48) !important;
  box-shadow:
    0 0 0 4px rgba(235, 100, 91, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
  outline: none !important;
}

textarea::placeholder,
input::placeholder,
.prompt-editor:empty::before {
  color: var(--nala-v2-muted) !important;
}

.btn-primary,
.btn-generate,
.btn-generate-music,
.btn-generate-inspiration,
.btn-generate-cover,
.btn-save-inspiration,
.quick-link-form-submit,
.image-create-generate,
.translate-generate,
.music-confirm-ok,
.full-auto-dialog-actions .btn-primary {
  border: 0 !important;
  border-radius: 999px !important;
  background:
    radial-gradient(circle at 22% 16%, rgba(255, 244, 194, 0.40), transparent 28%),
    linear-gradient(135deg, var(--nala-v2-coral-hot), var(--nala-v2-coral) 58%, var(--nala-v2-coral-deep)) !important;
  color: #fff !important;
  font-weight: 840 !important;
  box-shadow:
    0 18px 42px rgba(235, 100, 91, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.24) !important;
}

.btn-primary:hover:not(:disabled),
.btn-generate:hover:not(:disabled),
.btn-generate-music:hover:not(:disabled),
.btn-generate-inspiration:hover:not(:disabled),
.btn-generate-cover:hover:not(:disabled),
.btn-save-inspiration:hover:not(:disabled),
.quick-link-form-submit:hover,
.image-create-generate:hover:not(:disabled),
.translate-generate:hover:not(:disabled),
.music-confirm-ok:hover {
  transform: translateY(-1px);
  box-shadow:
    0 22px 54px rgba(235, 100, 91, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.28) !important;
  opacity: 1 !important;
}

.btn-secondary,
.quick-link-add-btn,
.quick-link-form-cancel,
.custom-app-gallery-arrow,
.history-toolbar-btn,
.history-cancel-btn,
.custom-app-back,
.custom-app-key-trigger,
.model-selector-trigger,
.image-create-size-trigger,
.compact-control-input select,
.compact-control-input input,
.settings-content .input-action,
.settings-content .btn-secondary,
.music-mode-segment,
.music-model-trigger,
.music-confirm-cancel,
.music-storyboard-ratio-option,
.music-choice-btn,
.full-auto-dialog-close {
  border: 1px solid var(--nala-v2-line) !important;
  border-radius: 999px !important;
  background:
    radial-gradient(circle at 12% 12%, rgba(235, 100, 91, 0.08), transparent 34%),
    var(--nala-v2-field) !important;
  color: var(--nala-v2-text) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.075) !important;
}

.btn-secondary:hover:not(:disabled),
.quick-link-add-btn:hover,
.quick-link-form-cancel:hover,
.custom-app-gallery-arrow:hover:not(:disabled),
.history-toolbar-btn:hover,
.custom-app-back:hover,
.custom-app-key-trigger:hover,
.model-selector-trigger:hover,
.image-create-size-trigger:hover,
.settings-content .input-action:hover,
.settings-content .btn-secondary:hover,
.music-confirm-cancel:hover,
.music-storyboard-ratio-option:hover,
.music-choice-btn:hover {
  border-color: rgba(235, 100, 91, 0.36) !important;
  background: rgba(235, 100, 91, 0.12) !important;
  color: var(--nala-v2-text) !important;
}

.modal-backdrop,
.music-confirm-overlay,
.full-auto-dialog-backdrop {
  background: rgba(7, 10, 14, 0.58) !important;
  backdrop-filter: blur(18px) saturate(0.85) !important;
  -webkit-backdrop-filter: blur(18px) saturate(0.85) !important;
}

/* Settings: premium but practical */
#settings-modal {
  z-index: 2400;
  padding: 24px;
}

#google-translate-tutorial-modal,
#lora-tutorial-modal,
#google-translate-quota-modal {
  z-index: 2600 !important;
}

#google-translate-tutorial-modal .modal-backdrop,
#lora-tutorial-modal .modal-backdrop,
#google-translate-quota-modal .modal-backdrop {
  background: rgba(7, 10, 14, 0.68) !important;
  backdrop-filter: blur(22px) saturate(0.9) !important;
  -webkit-backdrop-filter: blur(22px) saturate(0.9) !important;
}

/* Final settings layout fix */
#settings-modal .settings-content {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  width: min(860px, calc(100vw - 96px)) !important;
  max-width: min(860px, calc(100vw - 96px)) !important;
}

#settings-modal .modal-header {
  flex: 0 0 auto !important;
}

#settings-modal .settings-content .form-group,
#settings-modal .settings-content .settings-feishu-section {
  width: auto !important;
  min-width: 0 !important;
}

#settings-modal .settings-content .form-group {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}

#settings-modal .settings-content .form-group > label,
#settings-modal .settings-section-heading label {
  position: static !important;
  display: block !important;
  white-space: normal !important;
}

#settings-modal .settings-content .form-hint {
  display: block !important;
  margin: 0 !important;
  font-size: 12px !important;
  line-height: 1.65 !important;
  white-space: normal !important;
}

#settings-modal .settings-content .input-with-action {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 10px !important;
}

#settings-modal .settings-content .input-with-action > input,
#settings-modal .settings-content .input-with-action > textarea,
#settings-modal .settings-content .input-with-action > select {
  min-width: 0 !important;
}

#settings-modal .settings-model-chip-panel {
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  overflow: hidden !important;
}

#settings-modal .settings-model-chip-group {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: flex-start !important;
  gap: 10px !important;
  max-height: none !important;
  overflow: visible !important;
  padding-right: 0 !important;
}

#settings-modal .settings-model-chip {
  max-width: 100% !important;
}

#settings-modal .settings-model-custom-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 10px !important;
}

#settings-modal .settings-model-custom-row .btn-secondary {
  min-width: 88px !important;
}

#settings-modal .settings-feishu-section {
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
}

#settings-modal .settings-section-heading {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: start !important;
  gap: 14px !important;
}

#settings-modal .settings-section-heading > div {
  min-width: 0 !important;
}

#settings-modal .settings-inline-toggle {
  align-self: start !important;
}

#settings-modal .settings-feishu-quick-guide {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  justify-content: flex-start !important;
  gap: 10px !important;
}

#settings-modal .settings-feishu-quick-guide > span {
  min-width: 0 !important;
  flex: 0 0 auto !important;
  white-space: normal !important;
}

#settings-modal .settings-feishu-guide-actions {
  justify-content: flex-start !important;
}

#settings-modal .settings-feishu-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 10px !important;
}

#settings-modal .settings-feishu-grid > * {
  min-width: 0 !important;
}

#settings-modal .settings-feishu-grid .input-with-action {
  grid-template-columns: minmax(0, 1fr) auto !important;
}

#settings-modal .modal-actions {
  flex: 0 0 auto !important;
  display: grid !important;
  grid-template-columns: auto 1fr !important;
  align-items: center !important;
  gap: 14px !important;
}

#settings-modal .modal-actions-main {
  justify-self: end !important;
}

@media (max-width: 900px) {
  #settings-modal .settings-content {
    width: calc(100vw - 32px) !important;
    max-width: calc(100vw - 32px) !important;
  }

  #settings-modal .settings-section-heading,
  #settings-modal .modal-actions,
  #settings-modal .settings-model-custom-row {
    grid-template-columns: 1fr !important;
  }

  #settings-modal .modal-actions-main {
    justify-self: stretch !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
  }
}

#settings-modal .settings-content {
  width: min(980px, calc(100vw - 64px)) !important;
  max-width: min(980px, calc(100vw - 64px)) !important;
  max-height: calc(100vh - 56px) !important;
  padding: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  border-radius: 28px !important;
  background:
    radial-gradient(circle at 14% 0%, rgba(235, 100, 91, 0.14), transparent 34%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.11), transparent 32%),
    var(--nala-v2-surface-strong) !important;
  box-shadow: var(--nala-v2-shadow) !important;
}

#settings-modal .modal-header {
  position: sticky;
  top: 0;
  z-index: 4;
  margin: 0 !important;
  padding: 22px 28px 16px !important;
  border-bottom: 1px solid var(--nala-v2-line);
  background: rgba(37, 51, 63, 0.86);
  backdrop-filter: blur(20px) saturate(135%);
  -webkit-backdrop-filter: blur(20px) saturate(135%);
}

body:not(.theme-dark) #settings-modal .modal-header {
  background: rgba(255, 252, 248, 0.88);
}

#settings-modal .modal-header h3 {
  margin: 0 !important;
  font-size: 22px !important;
  font-weight: 880 !important;
  line-height: 1.2;
}

#settings-modal .modal-close-btn {
  width: 34px !important;
  height: 34px !important;
  border-radius: 999px !important;
}

#settings-modal .settings-content > .form-group,
#settings-modal .settings-content > .settings-feishu-section {
  margin: 0 28px 0 !important;
  padding: 16px 0 !important;
  border: 0 !important;
  border-bottom: 1px solid var(--nala-v2-line) !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

#settings-modal .settings-content > .form-group > label,
#settings-modal .settings-section-heading label {
  margin: 0 0 8px !important;
  color: var(--nala-v2-text) !important;
  font-size: 14px !important;
  font-weight: 800 !important;
}

#settings-modal .settings-key-tier {
  display: inline-flex !important;
  align-items: center !important;
  padding: 2px 8px !important;
  border-radius: 999px !important;
  font-size: 0.92em !important;
  line-height: 1.2 !important;
}

#settings-modal .settings-key-tier-consumer {
  background: rgba(235, 100, 91, 0.14) !important;
  color: #ff8d80 !important;
  box-shadow: inset 0 0 0 1px rgba(235, 100, 91, 0.22) !important;
}

#settings-modal .settings-key-tier-shared {
  background: rgba(105, 215, 229, 0.14) !important;
  color: #8ce9f5 !important;
  box-shadow: inset 0 0 0 1px rgba(105, 215, 229, 0.22) !important;
}

#settings-modal .settings-inline-link {
  color: var(--nala-v2-coral-hot) !important;
  font-weight: 760 !important;
  text-decoration: none !important;
  margin-left: 8px !important;
}

#settings-modal .settings-inline-link:hover {
  color: var(--nala-v2-coral) !important;
  text-decoration: underline !important;
}

#settings-modal .settings-content input[type="text"],
#settings-modal .settings-content input[type="password"],
#settings-modal .settings-content input[type="url"],
#settings-modal .settings-content input[type="number"],
#settings-modal .settings-content input[type="email"],
#settings-modal .settings-content input:not([type]),
#settings-modal .settings-content textarea,
#settings-modal .settings-content select {
  min-height: 44px !important;
  padding: 10px 13px !important;
  font-size: 13px !important;
}

#settings-modal .settings-digital-human-upload {
  width: 100% !important;
  min-height: 132px !important;
  max-height: 190px !important;
  aspect-ratio: 16 / 5 !important;
  border-width: 1px !important;
  border-style: dashed !important;
  border-radius: 20px !important;
  background:
    radial-gradient(circle at 14% 16%, rgba(235, 100, 91, 0.10), transparent 34%),
    var(--nala-v2-field) !important;
}

#settings-modal .settings-digital-human-thumb {
  object-fit: contain !important;
}

#settings-modal .settings-model-chip-panel,
#settings-modal .settings-feishu-section {
  padding: 14px !important;
  border: 1px solid var(--nala-v2-line) !important;
  border-radius: 20px !important;
  background:
    linear-gradient(135deg, rgba(235, 100, 91, 0.07), rgba(105, 215, 229, 0.05)),
    var(--nala-v2-surface-soft) !important;
}

#settings-modal .settings-feishu-quick-guide {
  border-color: rgba(105, 215, 229, 0.24) !important;
  background: rgba(105, 215, 229, 0.08) !important;
}

#settings-modal .modal-actions {
  position: sticky;
  bottom: 0;
  z-index: 4;
  margin: 0 !important;
  padding: 14px 28px 18px !important;
  border-top: 1px solid var(--nala-v2-line);
  background: rgba(37, 51, 63, 0.88);
  backdrop-filter: blur(20px) saturate(135%);
  -webkit-backdrop-filter: blur(20px) saturate(135%);
}

body:not(.theme-dark) #settings-modal .modal-actions {
  background: rgba(255, 252, 248, 0.9);
}

/* AI music: keep original workflow, upgrade the shell */
#content-panel.content-panel-music-create .music-create-shell {
  width: min(1380px, 100%) !important;
  min-height: 100%;
  margin: 0 auto !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
}

#content-panel.content-panel-music-create .music-status-bar {
  padding: 12px 16px !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
}

#content-panel.content-panel-music-create .music-status-steps {
  min-width: min-content !important;
  justify-content: center !important;
}

#content-panel.content-panel-music-create .music-status-step {
  min-width: 58px !important;
  padding: 8px 9px !important;
  border: 1px solid transparent !important;
  border-radius: 16px !important;
  background: transparent !important;
}

#content-panel.content-panel-music-create .music-status-step:hover,
#content-panel.content-panel-music-create .music-status-step.active {
  border-color: rgba(235, 100, 91, 0.24) !important;
  background: rgba(235, 100, 91, 0.11) !important;
}

#content-panel.content-panel-music-create .music-status-dot {
  width: 10px !important;
  height: 10px !important;
  background: rgba(146, 156, 182, 0.36) !important;
}

#content-panel.content-panel-music-create .music-status-step.active .music-status-dot {
  background: var(--nala-v2-coral) !important;
  box-shadow: 0 0 18px rgba(235, 100, 91, 0.62) !important;
}

#content-panel.content-panel-music-create .music-status-step.done .music-status-dot {
  background: var(--nala-v2-cyan) !important;
  box-shadow: 0 0 18px rgba(105, 215, 229, 0.42) !important;
}

#content-panel.content-panel-music-create .music-status-line {
  flex: 1 1 28px !important;
  min-width: 12px !important;
  max-width: 62px !important;
  height: 2px !important;
  border-radius: 999px !important;
  opacity: 0.62;
  background: linear-gradient(90deg, rgba(235, 100, 91, 0.25), rgba(105, 215, 229, 0.20)) !important;
}

#content-panel.content-panel-music-create .music-mode-bar {
  display: flex !important;
  justify-content: center !important;
  padding: 0 !important;
}

#content-panel.content-panel-music-create .music-mode-segment {
  display: inline-flex !important;
  gap: 4px;
  padding: 5px !important;
}

#content-panel.content-panel-music-create .music-mode-btn {
  min-height: 34px !important;
  padding: 0 22px !important;
  border-radius: 999px !important;
  color: var(--nala-v2-muted) !important;
  font-weight: 780 !important;
}

#content-panel.content-panel-music-create .music-mode-btn.active {
  background: linear-gradient(135deg, rgba(235, 100, 91, 0.95), rgba(211, 75, 68, 0.82)) !important;
  color: #fff !important;
  box-shadow: 0 12px 28px rgba(235, 100, 91, 0.24) !important;
}

#content-panel.content-panel-music-create .music-model-row {
  padding: 0 0 8px !important;
}

#content-panel.content-panel-music-create .music-model-picker {
  width: min(440px, 100%) !important;
}

#content-panel.content-panel-music-create .music-model-trigger {
  min-height: 48px !important;
  padding: 8px 13px !important;
}

#content-panel.content-panel-music-create .music-model-sigil,
.model-selector-brand,
.model-option-icon,
.music-model-option-mark {
  background:
    radial-gradient(circle at 30% 22%, #fff6bf, #ff8f77 42%, #eb645b 66%, #7be8ff 130%) !important;
  color: #18202a !important;
}

#content-panel.content-panel-music-create .music-create-top-row {
  width: 100% !important;
  gap: 12px !important;
  align-items: stretch !important;
}

#content-panel.content-panel-music-create .music-create-top {
  min-height: 118px;
  padding: 16px !important;
}

#content-panel.content-panel-music-create .music-create-top-side {
  width: 128px;
  padding: 0 !important;
}

#content-panel.content-panel-music-create .music-create-bottom {
  display: grid !important;
  grid-template-columns: minmax(0, 1.12fr) minmax(360px, 0.88fr) !important;
  gap: 16px !important;
  min-height: 640px !important;
  align-items: stretch !important;
}

#content-panel.content-panel-music-create .music-lyrics-panel,
#content-panel.content-panel-music-create .music-melody-panel {
  min-height: 0 !important;
  padding: 18px !important;
  overflow: hidden !important;
}

#content-panel.content-panel-music-create .music-lyrics-panel {
  display: flex !important;
  flex-direction: column !important;
}

#content-panel.content-panel-music-create .music-melody-panel {
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  overflow-y: auto !important;
}

#content-panel.content-panel-music-create .music-melody-section {
  display: flex !important;
  flex: 1 1 0 !important;
  flex-direction: column !important;
  min-height: 150px !important;
}

#content-panel.content-panel-music-create .music-melody-section:has(#music-result-singing) {
  flex: 1.22 1 0 !important;
  min-height: 220px !important;
}

#content-panel.content-panel-music-create .music-section-header,
#content-panel.content-panel-music-create .music-lyrics-header,
#content-panel.content-panel-music-create .music-melody-section-header {
  min-height: 32px;
  margin-bottom: 6px;
}

#content-panel.content-panel-music-create .music-lyrics-textarea,
#content-panel.content-panel-music-create .music-melody-textarea,
#content-panel.content-panel-music-create #music-result-style,
#content-panel.content-panel-music-create #music-result-singing,
#content-panel.content-panel-music-create #music-result-storyboard {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  padding: 15px !important;
  resize: none !important;
  overflow-y: auto !important;
}

#content-panel.content-panel-music-create .music-lyrics-textarea {
  min-height: 520px !important;
}

#content-panel.content-panel-music-create .music-copy-btn,
#content-panel.content-panel-music-create .music-revert-btn,
#content-panel.content-panel-music-create .music-reset-btn {
  border-radius: 999px !important;
}

/* AI app / AI video detail: result left, generation form right */
#content.content-custom-app-layout.content-custom-app-split {
  grid-template-columns: minmax(0, 1fr) clamp(360px, 32vw, 480px) !important;
  grid-template-rows: minmax(0, 1fr) !important;
  gap: 0 !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-result {
  grid-column: 1 !important;
  grid-row: 1 !important;
  min-height: 0 !important;
  padding: 24px !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  border-left: 0 !important;
  border-right: 1px solid var(--nala-v2-line) !important;
  background: transparent !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app {
  position: relative !important;
  inset: auto !important;
  grid-column: 2 !important;
  grid-row: 1 !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
  padding: 24px 22px !important;
  overflow: hidden !important;
  border-right: 0 !important;
  border-left: 1px solid rgba(255, 255, 255, 0.06) !important;
  box-shadow: none !important;
  background: transparent !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .creator-shell {
  width: 100% !important;
  max-width: none !important;
  height: 100% !important;
  max-height: 100% !important;
  margin: 0 !important;
  overflow-y: auto !important;
  padding: 18px !important;
  border-radius: 26px !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .creator-body {
  flex: 1 1 auto;
  min-height: 0;
  overflow: visible;
}

#content.content-custom-app-layout.content-custom-app-split #content-result .history-shell {
  width: 100% !important;
  max-width: none !important;
}

#content.content-custom-app-layout #content-panel.content-panel-custom-app.is-gallery,
#content.content-custom-app-layout #content-panel.content-panel-video-apps.is-gallery {
  position: relative !important;
  inset: auto !important;
  grid-column: 1 !important;
  grid-row: 1 / -1 !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 28px !important;
  overflow: visible !important;
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}

#content.content-custom-app-layout #content-panel.content-panel-custom-app.is-gallery .custom-app-gallery-shell,
#content-panel.content-panel-video-apps .video-app-gallery-shell {
  width: min(1120px, 100%) !important;
  max-width: 1120px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  filter: none !important;
}

.custom-app-gallery-track {
  gap: 18px !important;
}

.custom-app-card,
.quick-link-card,
#content-panel.content-panel-video-apps .video-app-card {
  border: 1px solid var(--nala-v2-line) !important;
  background:
    radial-gradient(circle at 10% 0%, rgba(235, 100, 91, 0.08), transparent 34%),
    var(--nala-v2-surface-strong) !important;
  box-shadow: var(--nala-v2-shadow-soft) !important;
  transition: transform 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease;
}

.custom-app-card:hover,
.quick-link-card:hover,
#content-panel.content-panel-video-apps .video-app-card:hover {
  transform: translateY(-2px);
  border-color: rgba(235, 100, 91, 0.34) !important;
  box-shadow: var(--nala-v2-glow), var(--nala-v2-shadow-soft) !important;
}

.custom-app-card {
  height: 146px !important;
  grid-template-columns: 146px minmax(0, 1fr) !important;
  border-radius: 24px !important;
  overflow: hidden;
}

.custom-app-card-cover {
  border-radius: 20px !important;
  background:
    radial-gradient(circle at 26% 22%, rgba(255, 246, 188, 0.36), transparent 30%),
    linear-gradient(135deg, rgba(235, 100, 91, 0.96), rgba(105, 215, 229, 0.58)) !important;
}

#content-panel.content-panel-video-apps .video-app-gallery-grid {
  width: 100%;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 28px !important;
}

#content-panel.content-panel-video-apps .video-app-card {
  gap: 14px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

#content-panel.content-panel-video-apps .video-app-card-cover {
  width: 100%;
  height: auto !important;
  aspect-ratio: 16 / 9 !important;
  border-radius: 26px !important;
  overflow: hidden;
  background-size: cover !important;
  background-position: center !important;
  box-shadow: var(--nala-v2-shadow-soft), 0 0 34px rgba(235, 100, 91, 0.13) !important;
}

#content-panel.content-panel-video-apps .video-app-card-cover-img {
  width: 100%;
  height: 100%;
  object-fit: cover !important;
  object-position: center !important;
}

#content-panel.content-panel-video-apps .video-app-card-title {
  color: var(--nala-v2-text) !important;
  font-size: 20px !important;
  font-weight: 860 !important;
}

#content.content-custom-app-layout #content-panel.content-panel-image-create:not(.content-panel-custom-app) {
  border-radius: 28px !important;
  box-shadow: var(--nala-v2-shadow) !important;
}

#content-panel.content-panel-image-create .creator-shell,
#content-panel.content-panel-image-create .image-create-prompt-wrap,
#content-panel.content-panel-image-create .image-create-dock {
  border-color: var(--nala-v2-line) !important;
  background:
    radial-gradient(circle at 12% 0%, rgba(235, 100, 91, 0.08), transparent 34%),
    var(--nala-v2-surface) !important;
}

/* Translate */
#content-panel.content-panel-translate .translate-shell {
  width: min(1200px, 100%) !important;
  min-height: min(720px, calc(100vh - 96px));
  margin: 0 auto !important;
  padding: 20px !important;
}

/* Quick links: separated sections, three columns */
#content-panel.content-panel-quick-links {
  padding: 24px !important;
}

.quick-links-page {
  width: min(1180px, 100%) !important;
  margin: 0 auto !important;
  gap: 18px !important;
}

.quick-links-section {
  padding: 18px !important;
}

.quick-links-section-title {
  color: var(--nala-v2-text) !important;
  font-size: 16px !important;
  font-weight: 860 !important;
}

.quick-links-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

.quick-link-card {
  min-height: 92px !important;
  height: auto !important;
  grid-template-columns: 88px minmax(0, 1fr) !important;
  border-radius: 22px !important;
  overflow: hidden;
}

.quick-link-card-user {
  grid-template-columns: 88px minmax(0, 1fr) auto !important;
}

.quick-link-card-cover {
  border-radius: 18px !important;
}

.quick-link-card-name {
  color: var(--nala-v2-text) !important;
  font-size: 14px !important;
  font-weight: 820 !important;
}

.quick-link-card-desc {
  color: var(--nala-v2-muted) !important;
  font-size: 12px !important;
  line-height: 1.5 !important;
}

.quick-link-card-actions {
  align-self: center !important;
  margin-right: 8px !important;
  padding: 4px !important;
  border-radius: 999px !important;
  background: var(--nala-v2-field) !important;
}

.quick-link-edit-btn,
.quick-link-delete-btn {
  border-radius: 999px !important;
}

.quick-link-form-cover {
  width: 76px !important;
  height: 76px !important;
  min-width: 76px !important;
  border-style: solid !important;
}

/* Internal music dialogs */
.music-inspiration-choice-popover,
.music-confirm-dialog,
.full-auto-dialog-content,
.music-inspiration-modal-content,
.music-result-modal-content {
  border-radius: 26px !important;
}

.music-confirm-overlay,
.full-auto-inspiration-dialog {
  backdrop-filter: blur(18px) saturate(0.85);
  -webkit-backdrop-filter: blur(18px) saturate(0.85);
}

.music-inspiration-option-card,
.music-storyboard-ratio-option {
  border-radius: 18px !important;
}

.music-storyboard-ratio-option.selected,
.music-inspiration-option-card.selected,
.music-inspiration-chips-container .music-chip.selected,
.settings-model-chip.selected {
  border-color: rgba(235, 100, 91, 0.68) !important;
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 142, 109, 0.24), transparent 44%),
    rgba(235, 100, 91, 0.14) !important;
  color: var(--nala-v2-text) !important;
  box-shadow: 0 14px 32px rgba(235, 100, 91, 0.18) !important;
}

.music-inspiration-chips-container .music-chip,
.settings-model-chip,
.settings-help-links a,
.settings-feishu-guide-actions a,
.settings-guide-link {
  border-radius: 999px !important;
  border: 1px solid var(--nala-v2-line) !important;
  background: var(--nala-v2-field) !important;
  color: var(--nala-v2-text) !important;
}

.music-inspiration-chips-container .music-chip:hover,
.settings-model-chip:hover,
.settings-help-links a:hover,
.settings-feishu-guide-actions a:hover,
.settings-guide-link:hover {
  border-color: rgba(235, 100, 91, 0.38) !important;
  background: rgba(235, 100, 91, 0.12) !important;
  color: var(--nala-v2-text) !important;
}

@media (max-width: 1180px) {
  .quick-links-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  #content-panel.content-panel-music-create .music-create-bottom {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 860px) {
  #settings-modal {
    padding: 14px;
  }

  #settings-modal .settings-content {
    width: calc(100vw - 28px) !important;
    max-width: calc(100vw - 28px) !important;
    max-height: calc(100vh - 28px) !important;
  }

  #settings-modal .modal-header,
  #settings-modal .modal-actions {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  #settings-modal .settings-content > .form-group,
  #settings-modal .settings-content > .settings-feishu-section {
    margin-left: 18px !important;
    margin-right: 18px !important;
  }

  #content.content-custom-app-layout.content-custom-app-split {
    grid-template-columns: 1fr !important;
    grid-template-rows: minmax(0, 1fr) minmax(320px, 42vh) !important;
  }

  #content.content-custom-app-layout.content-custom-app-split #content-result {
    grid-column: 1 !important;
    grid-row: 1 !important;
    border-right: 0 !important;
    border-bottom: 1px solid var(--nala-v2-line) !important;
  }

  #content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app {
    grid-column: 1 !important;
    grid-row: 2 !important;
    border-left: 0 !important;
  }

  .quick-links-grid,
  #content-panel.content-panel-video-apps .video-app-gallery-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Client update dialog: user-facing product update notice */
.settings-client-update-section .settings-section-heading {
  align-items: center !important;
}

.settings-update-check-btn {
  min-height: 34px !important;
  padding: 0 14px !important;
  white-space: nowrap !important;
}

#client-update-modal {
  z-index: 2550;
  padding: 24px;
}

#client-update-modal .modal-backdrop {
  background: rgba(7, 10, 14, 0.62) !important;
  backdrop-filter: blur(20px) saturate(0.9) !important;
  -webkit-backdrop-filter: blur(20px) saturate(0.9) !important;
}

#client-update-modal .client-update-content {
  position: relative !important;
  width: min(500px, calc(100vw - 56px)) !important;
  max-width: min(500px, calc(100vw - 56px)) !important;
  max-height: calc(100vh - 56px) !important;
  padding: 28px !important;
  overflow: hidden !important;
  border: 1px solid var(--nala-v2-line) !important;
  border-radius: 30px !important;
  background:
    radial-gradient(circle at 12% 0%, rgba(235, 100, 91, 0.22), transparent 36%),
    radial-gradient(circle at 96% 4%, rgba(105, 215, 229, 0.16), transparent 34%),
    linear-gradient(145deg, rgba(38, 52, 65, 0.94), rgba(26, 36, 48, 0.94)) !important;
  box-shadow:
    0 34px 110px rgba(0, 0, 0, 0.42),
    0 0 0 1px rgba(255, 255, 255, 0.03) inset,
    inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
  backdrop-filter: blur(28px) saturate(128%) !important;
  -webkit-backdrop-filter: blur(28px) saturate(128%) !important;
}

#client-update-modal .client-update-content::before {
  content: "";
  position: absolute;
  right: -72px;
  bottom: -90px;
  width: 220px;
  height: 220px;
  border-radius: 999px;
  background:
    radial-gradient(circle, rgba(235, 100, 91, 0.25), rgba(235, 100, 91, 0) 66%);
  pointer-events: none;
}

#client-update-modal .modal-header {
  position: relative !important;
  z-index: 1 !important;
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 18px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

#client-update-modal .modal-header h3 {
  margin: 0 !important;
  color: var(--nala-v2-text) !important;
  font-size: 24px !important;
  font-weight: 880 !important;
  line-height: 1.18 !important;
  letter-spacing: 0 !important;
}

#client-update-modal .client-update-subtitle {
  max-width: 370px !important;
  margin: 9px 0 0 !important;
  color: var(--nala-v2-muted) !important;
  font-size: 13.5px !important;
  line-height: 1.6 !important;
  font-weight: 700 !important;
}

#client-update-modal .modal-close-btn {
  flex: 0 0 auto !important;
  width: 34px !important;
  height: 34px !important;
  min-height: 34px !important;
  margin-top: -2px !important;
  padding: 0 !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.07) !important;
}

#client-update-modal .client-update-body {
  position: relative !important;
  z-index: 1 !important;
  padding: 20px 0 0 !important;
}

#client-update-modal .client-update-version-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 10px !important;
  align-items: center !important;
  margin: 0 !important;
  padding: 12px !important;
  border: 1px solid rgba(255, 255, 255, 0.10) !important;
  border-radius: 22px !important;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.035)) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

#client-update-modal .client-update-version-row span,
#client-update-modal .client-update-version-row strong {
  display: inline-flex !important;
  align-items: center !important;
  min-width: 0 !important;
  min-height: 34px !important;
  padding: 7px 13px !important;
  border-radius: 999px !important;
  font-size: 12.5px !important;
  font-weight: 850 !important;
  line-height: 1.2 !important;
  white-space: nowrap !important;
}

#client-update-modal .client-update-version-row span {
  color: rgba(247, 242, 235, 0.70) !important;
}

#client-update-modal .client-update-version-row strong {
  justify-self: end !important;
  color: #fff8f2 !important;
  border: 1px solid rgba(255, 255, 255, 0.16) !important;
  background:
    radial-gradient(circle at 86% 10%, rgba(105, 215, 229, 0.22), transparent 46%),
    linear-gradient(135deg, rgba(255, 127, 115, 0.98), rgba(217, 79, 72, 0.94)) !important;
  box-shadow:
    0 14px 32px rgba(235, 100, 91, 0.26),
    inset 0 1px 0 rgba(255, 255, 255, 0.20) !important;
}

#client-update-modal .client-update-notes {
  max-height: min(220px, 34vh) !important;
  overflow-y: auto !important;
  margin-top: 14px !important;
  padding: 14px 16px !important;
  border: 1px solid rgba(255, 255, 255, 0.10) !important;
  border-radius: 20px !important;
  background:
    radial-gradient(circle at 0% 0%, rgba(235, 100, 91, 0.11), transparent 40%),
    rgba(255, 255, 255, 0.055) !important;
  color: var(--nala-v2-text) !important;
}

#client-update-modal .client-update-notes[hidden] {
  display: none !important;
}

#client-update-modal .client-update-notes p {
  margin: 0 0 8px !important;
  color: rgba(247, 242, 235, 0.84) !important;
  font-size: 13px !important;
  line-height: 1.65 !important;
  font-weight: 680 !important;
}

#client-update-modal .client-update-notes p:last-child {
  margin-bottom: 0 !important;
}

#client-update-modal .modal-actions {
  position: relative !important;
  z-index: 1 !important;
  display: flex !important;
  justify-content: flex-end !important;
  gap: 12px !important;
  margin: 0 !important;
  padding: 20px 0 0 !important;
  border: 0 !important;
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

#client-update-modal .modal-actions .btn-secondary,
#client-update-modal .modal-actions .btn-primary {
  min-width: 118px !important;
  min-height: 44px !important;
  padding: 0 20px !important;
  border-radius: 999px !important;
  font-size: 14px !important;
  font-weight: 880 !important;
}

#client-update-modal .modal-actions .btn-primary {
  min-width: 136px !important;
}

#client-update-modal .modal-actions [hidden],
#client-update-modal .modal-header [hidden] {
  display: none !important;
}

body:not(.theme-dark) #client-update-modal .client-update-content {
  background:
    radial-gradient(circle at 12% 0%, rgba(235, 100, 91, 0.14), transparent 36%),
    radial-gradient(circle at 96% 4%, rgba(79, 195, 199, 0.12), transparent 34%),
    linear-gradient(145deg, rgba(255, 252, 248, 0.96), rgba(238, 244, 247, 0.92)) !important;
}

body:not(.theme-dark) #client-update-modal .modal-header,
body:not(.theme-dark) #client-update-modal .modal-actions {
  background: transparent !important;
}

body:not(.theme-dark) #client-update-modal .client-update-subtitle,
body:not(.theme-dark) #client-update-modal .client-update-version-row span,
body:not(.theme-dark) #client-update-modal .client-update-notes p {
  color: rgba(31, 40, 50, 0.68) !important;
}

body:not(.theme-dark) #client-update-modal .client-update-version-row,
body:not(.theme-dark) #client-update-modal .client-update-notes {
  border-color: rgba(43, 55, 68, 0.10) !important;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.64), rgba(255, 255, 255, 0.36)) !important;
}

body:not(.theme-dark) #client-update-modal .client-update-version-row strong {
  color: #fff !important;
}

@media (max-width: 620px) {
  #client-update-modal .client-update-version-row {
    grid-template-columns: 1fr;
  }

  #client-update-modal .client-update-version-row strong {
    justify-self: stretch;
  }
}

/* ===== Final macOS video gallery vertical centering restore ===== */
#content.content-custom-app-layout:has(#content-panel.content-panel-video-apps.is-gallery) {
  grid-template-rows: minmax(0, 1fr) !important;
}

#content.content-custom-app-layout:has(#content-panel.content-panel-video-apps.is-gallery) #content-panel.content-panel-video-apps.is-gallery {
  position: absolute !important;
  inset: 0 !important;
  display: grid !important;
  place-items: center !important;
  align-content: center !important;
  justify-items: stretch !important;
  padding: 24px 28px !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
}

#content.content-custom-app-layout:has(#content-panel.content-panel-video-apps.is-gallery) #content-panel.content-panel-video-apps .video-app-gallery-shell {
  width: min(1120px, 100%) !important;
  margin: 0 auto !important;
}

/* ===== macOS client background cleanup 2026-06-02 ===== */
#content-panel.content-panel-image-create + #content-result,
#content-panel.content-panel-image-create + #content-result .history-shell,
#content-panel.content-panel-image-create + #content-result .history-grid,
#content-panel.content-panel-image-create + #content-result .history-row,
#content-panel.content-panel-image-create + #content-result .history-grid-image,
#content-panel.content-panel-image-create + #content-result .history-empty,
#content.content-custom-app-layout #content-result,
#content.content-custom-app-layout #content-result .history-shell,
#content.content-custom-app-layout #content-result .history-grid,
#content.content-custom-app-layout #content-result .history-row,
#content.content-custom-app-layout #content-result .history-grid-image,
#content.content-custom-app-layout #content-result .history-empty,
#content.content-custom-app-layout:not(.content-custom-app-split) #content-panel.content-panel-custom-app.is-gallery,
#content.content-custom-app-layout:not(.content-custom-app-split) #content-panel.content-panel-custom-app.is-gallery .custom-app-gallery-shell,
#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .creator-shell,
#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .creator-body,
#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .image-create-upload-area,
#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .upload-area,
#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .upload-thumbnails,
#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail .video-app-detail-hero,
#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail .video-app-detail-meta {
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* ===== macOS client custom-app detail left/right restore 2026-06-02 ===== */
#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) {
  grid-template-columns: minmax(0, 1fr) clamp(320px, 24vw, 388px) !important;
  grid-template-rows: minmax(0, 1fr) !important;
  overflow: hidden !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-result {
  grid-column: 1 !important;
  grid-row: 1 !important;
  padding: 24px 28px !important;
  border-right: 1px solid var(--nala-v2-line) !important;
  border-left: 0 !important;
  background: transparent !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-result .history-shell {
  display: flex !important;
  flex-direction: column !important;
  gap: 18px !important;
  width: 100% !important;
  max-width: none !important;
  min-height: 100% !important;
  padding: 0 !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app {
  grid-column: 2 !important;
  grid-row: 1 !important;
  position: relative !important;
  inset: auto !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
  padding: 18px 18px 20px !important;
  border-left: 1px solid var(--nala-v2-line) !important;
  border-right: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app .creator-shell {
  width: 100% !important;
  max-width: none !important;
  height: 100% !important;
  max-height: 100% !important;
  margin: 0 !important;
  overflow-y: auto !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app .creator-body {
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app .creator-footer {
  padding-top: 16px !important;
}

.custom-app-inline-result {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 0;
  padding-top: 8px;
}

.custom-app-inline-result-head {
  font-size: 13px;
  font-weight: 800;
  color: var(--text-secondary);
}

.custom-app-inline-result-grid {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-height: 0;
}

.custom-app-inline-result-grid .history-tile-image {
  width: 100% !important;
  height: 180px;
}

.custom-app-inline-result-empty {
  padding: 16px 18px;
  border-radius: 18px;
  color: var(--text-secondary);
  background: rgba(255, 255, 255, 0.03);
}

/* ===== macOS client image-create collapse fix 2026-06-02 ===== */
#content.content-custom-app-layout #content-panel.content-panel-image-create:not(.content-panel-custom-app).is-collapsed {
  max-height: none !important;
  overflow: visible !important;
}

#content-panel.content-panel-image-create.is-collapsed .image-create-editor {
  gap: 0 !important;
}

#content-panel.content-panel-image-create.is-collapsed .creator-shell {
  padding-top: 8px !important;
  padding-bottom: 8px !important;
}

#content-panel.content-panel-image-create.is-collapsed .image-create-composer-shell {
  min-height: 0 !important;
  height: 0 !important;
  padding: 0 !important;
  border-width: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
  box-shadow: none !important;
}

#content-panel.content-panel-image-create.is-collapsed .image-create-prompt-wrap,
#content-panel.content-panel-image-create.is-collapsed .image-create-upload-area,
#content-panel.content-panel-image-create.is-collapsed .image-create-inline-refs {
  display: none !important;
}

#content-panel.content-panel-image-create.is-collapsed .image-create-dock {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  border-top-width: 0 !important;
  margin-top: 0 !important;
}

/* ===== macOS client image-create original layout restore 2026-06-02 ===== */
#content-panel.content-panel-image-create .creator-shell.image-create-editor {
  padding: 18px 22px 16px !important;
  border-radius: 30px !important;
}

#content-panel.content-panel-image-create .image-create-composer-shell {
  display: grid !important;
  grid-template-columns: 94px minmax(0, 1fr) !important;
  align-items: start !important;
  gap: 0 !important;
  min-height: 168px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: visible !important;
}

#content-panel.content-panel-image-create .image-create-upload-area {
  order: 1 !important;
  align-self: start !important;
  margin-top: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-top: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

#content-panel.content-panel-image-create .image-create-upload-rail {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 10px !important;
  min-height: 0 !important;
  overflow: visible !important;
}

#content-panel.content-panel-image-create .image-create-upload-area .upload-thumbnails {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 10px !important;
  width: auto !important;
  flex: 0 1 auto !important;
}

#content-panel.content-panel-image-create .image-create-upload-area .upload-placeholder,
#content-panel.content-panel-image-create .image-create-upload-area .upload-thumb-add,
#content-panel.content-panel-image-create .image-create-upload-area .upload-thumb-wrap {
  width: 72px !important;
  min-width: 72px !important;
  height: 72px !important;
  border-radius: 24px !important;
}

#content-panel.content-panel-image-create .image-create-upload-area .upload-thumb {
  border-radius: 22px !important;
}

#content-panel.content-panel-image-create .image-create-prompt-wrap {
  order: 2 !important;
  min-height: 168px !important;
  padding: 2px 0 0 18px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: hidden !important;
}

#content-panel.content-panel-image-create .image-create-prompt-wrap .form-group {
  min-height: 100% !important;
  height: 100% !important;
}

#content-panel.content-panel-image-create .image-create-prompt-wrap .prompt-editor,
#content-panel.content-panel-image-create .image-create-prompt-wrap textarea {
  min-height: 126px !important;
  height: 100% !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  font-size: 16px !important;
  line-height: 1.7 !important;
}

#content-panel.content-panel-image-create .image-create-prompt-wrap .prompt-editor:empty::before,
#content-panel.content-panel-image-create .image-create-prompt-wrap textarea::placeholder {
  color: rgba(255, 248, 242, 0.52) !important;
}

body:not(.theme-dark) #content-panel.content-panel-image-create .image-create-prompt-wrap .prompt-editor:empty::before,
body:not(.theme-dark) #content-panel.content-panel-image-create .image-create-prompt-wrap textarea::placeholder {
  color: rgba(38, 48, 58, 0.42) !important;
}

#content-panel.content-panel-image-create .image-create-inline-refs {
  margin-top: 0 !important;
}

/* AI app gallery restore */
#content.content-custom-app-layout:not(.content-custom-app-split) #content-panel.content-panel-custom-app.is-gallery {
  position: absolute !important;
  left: 20px !important;
  right: 20px !important;
  bottom: 20px !important;
  top: auto !important;
  inset: auto 20px 20px 20px !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: calc(100% - 84px) !important;
  display: block !important;
  padding: 0 !important;
  overflow: visible !important;
  background: transparent !important;
  box-shadow: none !important;
}

#content.content-custom-app-layout:not(.content-custom-app-split) #content-panel.content-panel-custom-app.is-gallery .custom-app-gallery-shell {
  width: min(1120px, 100%) !important;
  max-width: 1120px !important;
  margin: 0 auto !important;
}

/* ===== macOS client workspace restore 2026-06-02 ===== */
#content-panel.content-panel-image-create .image-create-editor {
  --upload-tile-size: 68px;
  gap: 14px !important;
  padding: 0 !important;
}

#content-panel.content-panel-image-create .image-create-composer-shell {
  display: flex;
  flex-direction: column;
  gap: 0;
  min-height: 214px;
  padding: 18px 18px 14px;
  border: 1px solid var(--nala-v2-line);
  border-radius: 28px;
  background:
    radial-gradient(circle at 12% 0%, rgba(235, 100, 91, 0.10), transparent 34%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.08), transparent 34%),
    var(--nala-v2-surface);
  box-shadow: var(--nala-v2-shadow-soft);
  overflow: hidden;
}

 #content-panel.content-panel-image-create.is-collapsed .image-create-composer-shell {
  min-height: 0;
  padding-top: 0;
  padding-bottom: 0;
  border-color: transparent;
  background: transparent;
  box-shadow: none;
}

body:not(.theme-dark) #content-panel.content-panel-image-create .image-create-composer-shell {
  background:
    radial-gradient(circle at 12% 0%, rgba(235, 100, 91, 0.08), transparent 34%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.08), transparent 34%),
    rgba(255, 252, 248, 0.84);
}

#content-panel.content-panel-image-create .image-create-prompt-wrap {
  flex: 1 1 auto;
  min-height: 150px;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: visible !important;
}

#content-panel.content-panel-image-create .image-create-prompt-wrap .form-group {
  display: flex !important;
  flex-direction: column !important;
  min-height: 150px !important;
  height: 100% !important;
}

#content-panel.content-panel-image-create .image-create-prompt-wrap .prompt-editor,
#content-panel.content-panel-image-create .image-create-prompt-wrap textarea {
  min-height: 118px !important;
  height: 100% !important;
  padding: 0 !important;
  background: transparent !important;
}

#content-panel.content-panel-image-create .image-create-inline-refs {
  margin-top: 10px !important;
}

#content-panel.content-panel-image-create .image-create-upload-area {
  margin-top: auto !important;
  padding: 12px 0 0 !important;
  border: 0 !important;
  border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

body:not(.theme-dark) #content-panel.content-panel-image-create .image-create-upload-area {
  border-top-color: rgba(33, 44, 58, 0.08) !important;
}

#content-panel.content-panel-image-create .image-create-upload-rail {
  align-items: center !important;
  gap: 10px !important;
  min-height: var(--upload-tile-size) !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  scrollbar-width: none;
}

#content-panel.content-panel-image-create .image-create-upload-rail::-webkit-scrollbar {
  display: none;
}

#content-panel.content-panel-image-create .image-create-upload-area .upload-thumbnails {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex: 0 1 auto !important;
  overflow: visible !important;
}

#content-panel.content-panel-image-create .image-create-upload-area .upload-placeholder,
#content-panel.content-panel-image-create .image-create-upload-area .upload-thumb-add,
#content-panel.content-panel-image-create .image-create-upload-area .upload-thumb-wrap {
  border-radius: 22px !important;
}

#content-panel.content-panel-image-create .image-create-upload-area .upload-placeholder,
#content-panel.content-panel-image-create .image-create-upload-area .upload-thumb-add {
  width: var(--upload-tile-size) !important;
  min-width: var(--upload-tile-size) !important;
  height: var(--upload-tile-size) !important;
  border: 1px dashed rgba(235, 100, 91, 0.22) !important;
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 166, 145, 0.16), transparent 34%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02)) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

body:not(.theme-dark) #content-panel.content-panel-image-create .image-create-upload-area .upload-placeholder,
body:not(.theme-dark) #content-panel.content-panel-image-create .image-create-upload-area .upload-thumb-add {
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 166, 145, 0.14), transparent 34%),
    rgba(255, 255, 255, 0.68) !important;
}

#content-panel.content-panel-image-create .image-create-upload-area .upload-thumb-wrap {
  width: var(--upload-tile-size) !important;
  min-width: var(--upload-tile-size) !important;
  height: var(--upload-tile-size) !important;
  max-width: var(--upload-tile-size) !important;
}

#content-panel.content-panel-image-create .image-create-upload-area .upload-thumb {
  border-radius: 20px !important;
}

#content-panel.content-panel-image-create .image-create-dock {
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

#content.content-custom-app-layout:not(.content-custom-app-split) #content-panel.content-panel-custom-app.is-gallery {
  grid-row: 1 / -1 !important;
  align-self: stretch !important;
  justify-self: stretch !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 24px !important;
}

#content.content-custom-app-layout:not(.content-custom-app-split) #content-panel.content-panel-custom-app.is-gallery .custom-app-gallery-shell {
  width: min(1120px, 100%) !important;
  margin: 0 auto !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) {
  grid-template-columns: minmax(0, 1fr) clamp(316px, 25vw, 380px) !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail {
  grid-template-columns: minmax(0, 1fr) clamp(300px, 23vw, 356px) !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-result {
  padding: 20px 24px 24px !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app {
  padding: 18px 16px 20px !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .creator-shell {
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .creator-body {
  gap: 12px !important;
  padding-right: 0 !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .image-create-prompt-wrap,
#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .section-row,
#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .image-create-dock {
  border-radius: 22px !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app .upload-area,
#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app .upload-thumbnails,
#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app .image-create-upload-area {
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app .upload-thumb-wrap,
#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app .upload-thumb-add,
#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app .upload-placeholder {
  border-radius: 22px !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-result .history-shell {
  gap: 20px !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.video-app-detail-hero {
  grid-template-columns: 1fr !important;
  gap: 18px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.video-app-detail-cover {
  border-radius: 28px !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .upload-thumb-wrap,
#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .upload-thumb-add,
#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .upload-placeholder {
  border-radius: 24px !important;
}

#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .upload-thumb,
#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .upload-thumb-video,
#content.content-custom-app-layout.content-custom-app-split.content-video-app-detail #content-panel.content-panel-custom-app .upload-thumb-audio {
  border-radius: 22px !important;
}

#settings-modal .settings-content {
  width: min(840px, calc(100vw - 56px)) !important;
  max-width: min(840px, calc(100vw - 56px)) !important;
}

#settings-modal .settings-content > .form-group,
#settings-modal .settings-content > .settings-feishu-section {
  margin: 0 24px !important;
  padding: 16px 0 !important;
}

#settings-modal .settings-content .form-hint {
  font-size: 12px !important;
  line-height: 1.7 !important;
}

#settings-modal .google-translate-key-help {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
}

#settings-modal .google-translate-key-help .form-hint {
  flex: 1 1 280px !important;
}

#settings-modal .google-translate-key-help-trigger,
#settings-modal .settings-global-guide-link {
  flex: 0 0 auto !important;
}

#settings-modal .settings-model-chip-panel,
#settings-modal .settings-feishu-section {
  padding: 16px !important;
}

#settings-modal .settings-feishu-grid {
  grid-template-columns: minmax(0, 1.25fr) minmax(0, 0.8fr) minmax(0, 1fr) !important;
  gap: 12px !important;
}

#settings-modal .settings-feishu-grid .input-with-action {
  grid-template-columns: minmax(0, 1fr) auto !important;
}

#settings-modal .settings-feishu-quick-guide {
  align-items: flex-start !important;
}

#settings-modal .settings-feishu-guide-actions {
  justify-content: flex-start !important;
}

@media (max-width: 920px) {
  #settings-modal .settings-content {
    width: calc(100vw - 28px) !important;
    max-width: calc(100vw - 28px) !important;
  }

  #settings-modal .settings-feishu-grid {
    grid-template-columns: 1fr !important;
  }
}


/* Final custom-app detail restore */
#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) {
  grid-template-columns: minmax(0, 1fr) clamp(320px, 24vw, 388px) !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-result {
  padding: 18px 18px 20px 22px !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-result .history-shell {
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app {
  padding: 18px 16px 20px !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app .creator-shell {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app .creator-body {
  gap: 14px !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app .video-app-detail-hero {
  margin-bottom: 4px !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app .image-create-upload-area,
#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app .image-create-dock {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app .image-create-dock {
  padding: 0 !important;
  margin: 0 !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app .upload-area,
#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-panel.content-panel-custom-app .upload-thumbnails {
  background: transparent !important;
  box-shadow: none !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-result .history-header {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 12px !important;
  padding: 2px 2px 0 !important;
}

#content.content-custom-app-layout.content-custom-app-split:not(.content-video-app-detail) #content-result .history-empty {
  margin-top: 4px !important;
}

/* ===== 全局消耗查询按钮 ===== */
#global-billing-btn {
  position: fixed;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1000;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 10px 7px;
  background: linear-gradient(135deg, rgba(244,119,111,0.55), rgba(235,100,91,0.50));
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  font-family: var(--font);
  line-height: 1.6;
  border-radius: 8px 0 0 8px;
  text-decoration: none;
  box-shadow: -4px 0 20px rgba(235,100,91,0.10);
  transition: opacity 0.15s, box-shadow 0.15s;
  cursor: pointer;
}

@media (max-width: 0px) and (min-width: 1px) {
/* Retired: extra floating shell made the image workspace feel boxed-in. */
/* ===== 图片创作输入区悬浮感 ===== */
#content.content-custom-app-layout #content-panel.content-panel-image-create:not(.content-panel-custom-app) {
  box-shadow: 0 8px 40px rgba(16,24,40,0.14), 0 2px 8px rgba(16,24,40,0.06) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

body.theme-dark #content.content-custom-app-layout #content-panel.content-panel-image-create:not(.content-panel-custom-app) {
  box-shadow: 0 8px 40px rgba(0,0,0,0.28), 0 2px 8px rgba(0,0,0,0.14) !important;
}
}

/* ===== 自建应用卡片区域透明 ===== */
#content.content-custom-app-layout #content-panel.content-panel-custom-app.is-gallery .custom-app-gallery-shell,
.custom-app-gallery-grid,
.custom-app-gallery-viewport {
  background: transparent !important;
}

.custom-app-gallery-viewport {
  border-radius: 0 !important;
  overflow: visible !important;
  padding: 4px 4px 40px 4px;
  margin: -4px -4px -40px -4px;
}

.custom-app-gallery-track {
  gap: 16px;
}

[data-gallery-arrow="next"] {
  margin-left: 8px;
}


#global-billing-btn:hover {
  opacity: 0.85;
  box-shadow: -4px 0 28px rgba(235,100,91,0.18);
}

/* AI 视频列表页：按右侧内容框居中 */
#content.content-custom-app-layout #content-panel.content-panel-custom-app.content-panel-video-apps.is-gallery {
  position: absolute !important;
  top: 0 !important;
  bottom: auto !important;
  left: 0 !important;
  right: 0 !important;
  transform: none !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 28px !important;
  background: transparent !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

#content-panel.content-panel-video-apps .video-app-gallery-shell {
  width: min(100%, 1540px) !important;
  margin: 0 auto !important;
}

#content-panel.content-panel-video-apps .video-app-gallery-grid {
  align-items: start !important;
}

#content-panel.content-panel-video-apps .video-app-card-cover {
  aspect-ratio: 16 / 9 !important;
  height: auto !important;
  min-height: 0 !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
}

#content-panel.content-panel-video-apps .video-app-card-cover-img {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

#content-panel.content-panel-video-apps .video-app-card-cover::before,
#content-panel.content-panel-video-apps .video-app-card-cover::after {
  z-index: 1;
}

#content-panel.content-panel-video-apps .video-app-card-cover .custom-app-card-mark {
  z-index: 2;
}


/* ===== Toast 通知堆叠系统 ===== */
#toast-container {
  position: fixed;
  top: 52px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3000;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  pointer-events: none;
}

.toast-item {
  position: relative;
  width: fit-content;
  max-width: calc(100vw - 220px);
  padding: 14px 20px 14px 38px;
  background: linear-gradient(135deg, rgba(244,119,111,0.62), rgba(235,100,91,0.56));
  border: 1px solid rgba(255,255,255,0.22);
  border-radius: 26px;
  color: #fff;
  font-size: 14px;
  font-weight: 650;
  font-family: var(--font);
  line-height: 1.5;
  box-shadow: 0 18px 44px rgba(235,100,91,0.26), inset 0 1px 0 rgba(255,255,255,0.16);
  backdrop-filter: blur(24px) saturate(150%);
  -webkit-backdrop-filter: blur(24px) saturate(150%);
  pointer-events: auto;
  white-space: nowrap;
  text-shadow: 0 1px 2px rgba(0,0,0,0.08);
  overflow: hidden;
  animation: toast-in 0.28s cubic-bezier(0.16, 1, 0.3, 1);
}

body:not(.theme-dark) .toast-item {
  background: linear-gradient(135deg, rgba(244,119,111,0.55), rgba(235,100,91,0.48));
  border-color: rgba(255,255,255,0.22);
  box-shadow: 0 18px 44px rgba(235,100,91,0.16), inset 0 1px 0 rgba(255,255,255,0.18);
  text-shadow: 0 1px 1px rgba(0,0,0,0.06);
}

.toast-item.toast-out {
  animation: toast-out 0.28s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.toast-close {
  position: absolute;
  top: 50%;
  left: 10px;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  padding: 0;
  border: none;
  background: rgba(255,255,255,0.14);
  color: #fff;
  border-radius: 50%;
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  opacity: 0.7;
  transition: opacity 0.15s, background 0.15s;
}

.toast-close:hover {
  opacity: 1;
  background: rgba(255,255,255,0.28);
}

/* 流光扫过 */
.toast-item::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 50%;
  height: 100%;
  background: linear-gradient(105deg, transparent 0%, rgba(255,255,255,0.28) 45%, rgba(255,255,255,0.45) 50%, rgba(255,255,255,0.28) 55%, transparent 100%);
  animation: toast-shine 3s ease-in-out infinite;
  pointer-events: none;
}

@keyframes toast-shine {
  0%   { left: -100%; }
  40%  { left: 120%; }
  100% { left: 120%; }
}

@keyframes toast-in {
  from { opacity: 0; transform: translateY(-14px) scale(0.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes toast-out {
  from { opacity: 1; transform: translateY(0) scale(1); }
  to   { opacity: 0; transform: translateY(-10px) scale(0.96); }
}

/* Auth dialog viewport guard */
#auth-modal {
  align-items: center;
  justify-content: center;
  padding: 24px;
  overflow: hidden;
}

#auth-modal .auth-content {
  width: min(520px, calc(100vw - 32px));
  max-width: calc(100vw - 32px);
  max-height: calc(100vh - 48px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

#auth-modal .auth-content .modal-header {
  flex: 0 0 auto;
  margin-bottom: 14px;
}

#auth-modal #auth-form-panel,
#auth-modal #auth-user-panel {
  min-height: 0;
}

#auth-modal #auth-form-panel {
  display: flex;
  flex: 1 1 auto;
  min-height: 0;
  flex-direction: column;
  overflow: hidden;
}

#auth-modal #auth-form-panel.hidden {
  display: none !important;
}

#auth-modal .auth-tabs {
  flex: 0 0 auto;
  margin: 0 0 14px;
}

#auth-modal .auth-pane {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding: 0 4px 2px;
  scrollbar-width: thin;
}

#auth-modal .auth-pane.hidden {
  display: none;
}

#auth-modal .auth-pane .form-group {
  margin-bottom: 0;
}

#auth-modal .auth-pane .modal-actions {
  position: sticky;
  bottom: 0;
  z-index: 1;
  margin-top: 12px;
  padding-top: 12px;
  background: linear-gradient(180deg, transparent, var(--ui-surface-strong, var(--bg)) 38%);
}

body:not(.theme-dark) #auth-modal .auth-pane .modal-actions,
html[data-theme="light"] body #auth-modal .auth-pane .modal-actions {
  background: linear-gradient(180deg, transparent, rgba(255, 252, 248, 0.96) 38%);
}

@media (max-height: 760px) {
  #auth-modal {
    padding: 12px;
  }

  #auth-modal .auth-content {
    width: min(500px, calc(100vw - 24px));
    max-width: calc(100vw - 24px);
    max-height: calc(100vh - 24px);
    padding: 18px;
  }

  #auth-modal .auth-content .modal-header,
  #auth-modal .auth-tabs {
    margin-bottom: 10px;
  }

  #auth-modal .auth-pane {
    gap: 10px;
  }

  #auth-modal .auth-pane .form-group {
    gap: 7px;
  }

  #auth-modal .auth-pane .form-group input[type="email"],
  #auth-modal .auth-pane .form-group input[type="password"],
  #auth-modal .auth-pane .form-group input[type="text"],
  #auth-modal .auth-pane .input-action {
    min-height: 46px;
    border-radius: 18px;
  }

  #auth-modal .auth-pane .modal-actions {
    margin-top: 8px;
    padding-top: 10px;
  }
}

/* Final quick-link cover override */
.quick-link-card-cover-placeholder,
.quick-link-card-rec .quick-link-card-cover-placeholder,
.quick-link-form-cover:has(.quick-link-form-cover-empty) {
  isolation: isolate;
  overflow: hidden;
  background:
    radial-gradient(circle at 18% 20%, rgba(255, 117, 102, 0.42), transparent 35%),
    radial-gradient(circle at 86% 18%, rgba(120, 232, 255, 0.28), transparent 34%),
    linear-gradient(145deg, rgba(37, 49, 61, 0.96), rgba(16, 24, 34, 0.98)) !important;
  opacity: 1 !important;
  filter: none !important;
}

.quick-link-card-cover-placeholder::before,
.quick-link-form-cover:has(.quick-link-form-cover-empty)::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.055) 1px, transparent 1px);
  background-size: 16px 16px;
  opacity: 0.4;
}

.quick-link-card-cover-placeholder::after,
.quick-link-form-cover:has(.quick-link-form-cover-empty)::after {
  content: "";
  position: absolute;
  inset: -42% -70%;
  z-index: -1;
  background: linear-gradient(110deg, transparent 28%, rgba(255, 242, 194, 0.22) 42%, rgba(255, 117, 102, 0.34) 50%, rgba(120, 232, 255, 0.2) 58%, transparent 72%);
  transform: rotate(-14deg);
  opacity: 0.72;
}

.quick-link-card-cover-empty,
.quick-link-form-cover-empty {
  position: relative;
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  overflow: hidden;
  color: rgba(255, 248, 242, 0.92);
  opacity: 1 !important;
}

.quick-link-cover-orbit {
  position: absolute;
  width: 50px;
  height: 50px;
  border: 1px solid rgba(255, 242, 194, 0.35);
  border-radius: 999px;
  box-shadow:
    inset 0 0 18px rgba(120, 232, 255, 0.12),
    0 0 22px rgba(255, 117, 102, 0.2);
}

.quick-link-cover-orbit::before,
.quick-link-cover-orbit::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
}

.quick-link-cover-orbit::before {
  inset: 10px;
  border: 1px solid rgba(120, 232, 255, 0.18);
}

.quick-link-cover-orbit::after {
  width: 8px;
  height: 8px;
  right: 4px;
  top: 9px;
  background: #ff7566;
  box-shadow: 0 0 16px rgba(255, 117, 102, 0.78);
}

.quick-link-cover-logo {
  position: absolute;
  left: 8px;
  bottom: 8px;
  color: rgba(255, 248, 242, 0.5);
  font-size: 9px;
  font-weight: 900;
  letter-spacing: 0.16em;
  line-height: 1;
}

.quick-link-cover-mark,
.quick-link-form-cover-empty .quick-link-form-cover-label {
  position: relative;
  z-index: 1;
  max-width: calc(100% - 16px);
  padding: 3px 8px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.14);
  color: rgba(255, 248, 242, 0.92);
  font-size: 10px;
  font-weight: 850;
  letter-spacing: 0.02em;
  line-height: 1.2;
  overflow: hidden;
  text-align: center;
  text-overflow: ellipsis;
  white-space: nowrap;
}

body:not(.theme-dark) .quick-link-card-cover-placeholder,
body:not(.theme-dark) .quick-link-card-rec .quick-link-card-cover-placeholder,
body:not(.theme-dark) .quick-link-form-cover:has(.quick-link-form-cover-empty) {
  background:
    radial-gradient(circle at 18% 20%, rgba(255, 117, 102, 0.24), transparent 35%),
    radial-gradient(circle at 86% 18%, rgba(120, 232, 255, 0.28), transparent 34%),
    linear-gradient(145deg, rgba(255, 248, 242, 0.96), rgba(226, 236, 240, 0.96)) !important;
}

body:not(.theme-dark) .quick-link-cover-logo,
body:not(.theme-dark) .quick-link-cover-mark,
body:not(.theme-dark) .quick-link-form-cover-empty .quick-link-form-cover-label {
  color: rgba(38, 48, 58, 0.68);
}

body:not(.theme-dark) .quick-link-cover-mark,
body:not(.theme-dark) .quick-link-form-cover-empty .quick-link-form-cover-label {
  border-color: rgba(45, 54, 64, 0.12);
  background: rgba(255, 255, 255, 0.45);
}

@media (max-width: 0px) and (min-width: 1px) {
/* Retired: this broad visual overlay changed approved inner layouts. */
/* Retired: this broad inner workspace restyle overrode client page structure. */
@media (max-width: 0px) and (min-width: 1px) {
/* Final inner workspace aesthetic system */
#content-panel.content-panel-music-create,
#content-panel.content-panel-image-create,
#content-panel.content-panel-custom-app:not(.is-gallery),
#content-panel.content-panel-translate {
  color: var(--text);
}

#content-panel.content-panel-music-create .music-create-shell,
#content-panel.content-panel-image-create .image-create-shell,
#content-panel.content-panel-custom-app:not(.is-gallery) .creator-shell,
#content-panel.content-panel-translate .translate-shell {
  isolation: isolate;
  position: relative;
}

#content-panel.content-panel-music-create .music-status-bar,
#content-panel.content-panel-music-create .music-create-top,
#content-panel.content-panel-music-create .music-lyrics-panel,
#content-panel.content-panel-music-create .music-melody-panel,
#content-panel.content-panel-music-create .music-inspiration-final,
#content-panel.content-panel-image-create .image-create-editor,
#content-panel.content-panel-image-create .image-create-prompt-wrap,
#content-panel.content-panel-image-create .image-create-dock,
#content-panel.content-panel-custom-app:not(.is-gallery) .creator-shell,
#content-panel.content-panel-custom-app:not(.is-gallery) .image-create-dock,
#content-panel.content-panel-custom-app:not(.is-gallery) .section-row,
#content-panel.content-panel-custom-app:not(.is-gallery) .image-create-prompt-wrap,
#content-panel.content-panel-translate .translate-shell,
.modal-content,
.settings-content .form-group,
.history-shell,
.history-card,
.history-tile-image,
.history-file-picker-item,
.result-image-wrapper {
  border: 1px solid rgba(255, 255, 255, 0.11) !important;
  background:
    radial-gradient(circle at 10% 0%, rgba(235, 100, 91, 0.10), transparent 32%),
    radial-gradient(circle at 88% 8%, rgba(120, 232, 255, 0.07), transparent 34%),
    linear-gradient(145deg, rgba(35, 47, 59, 0.78), rgba(20, 28, 38, 0.82)) !important;
  box-shadow:
    0 24px 70px rgba(0, 0, 0, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.075) !important;
  backdrop-filter: blur(22px) saturate(140%);
  -webkit-backdrop-filter: blur(22px) saturate(140%);
}

#content-panel.content-panel-music-create .music-status-bar,
#content-panel.content-panel-music-create .music-create-top,
#content-panel.content-panel-music-create .music-lyrics-panel,
#content-panel.content-panel-music-create .music-melody-panel,
#content-panel.content-panel-image-create .image-create-editor,
#content-panel.content-panel-image-create .image-create-prompt-wrap,
#content-panel.content-panel-image-create .image-create-dock,
#content-panel.content-panel-custom-app:not(.is-gallery) .creator-shell,
#content-panel.content-panel-custom-app:not(.is-gallery) .section-row,
#content-panel.content-panel-translate .translate-shell,
.modal-content {
  border-radius: 28px !important;
}

#content-panel.content-panel-image-create .image-create-editor {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 18px;
  overflow: hidden;
}

#content-panel.content-panel-image-create .image-create-editor {
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

#content-panel.content-panel-image-create .image-create-prompt-wrap,
#content-panel.content-panel-image-create .image-create-dock,
#content-panel.content-panel-custom-app:not(.is-gallery) .image-create-prompt-wrap,
#content-panel.content-panel-custom-app:not(.is-gallery) .image-create-dock {
  border-radius: 24px !important;
  padding: 14px !important;
}

#content-panel.content-panel-image-create .image-create-dock,
#content-panel.content-panel-custom-app:not(.is-gallery) .image-create-dock {
  border-top: 1px solid rgba(255, 255, 255, 0.11) !important;
  margin-top: 0 !important;
}

#content-panel.content-panel-image-create .image-create-upload-area,
#content-panel.content-panel-custom-app:not(.is-gallery) .image-create-upload-area,
.section-row-images,
.image-create-upload-rail,
.upload-thumbnails {
  gap: 10px !important;
}

.upload-area,
.upload-thumb-wrap,
.upload-thumb-add,
.quick-link-form-cover,
.settings-digital-human-upload {
  border: 1px solid rgba(255, 255, 255, 0.13) !important;
  border-radius: 22px !important;
  background:
    radial-gradient(circle at 28% 16%, rgba(235, 100, 91, 0.12), transparent 32%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.025)) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

.upload-area:hover,
.upload-thumb-add:hover,
.settings-digital-human-upload:hover,
.quick-link-form-cover:hover {
  border-color: rgba(235, 100, 91, 0.34) !important;
  box-shadow:
    0 18px 46px rgba(235, 100, 91, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.11) !important;
}

#content-panel.content-panel-image-create .image-create-prompt-wrap textarea,
#content-panel.content-panel-image-create .image-create-prompt-wrap .prompt-editor,
#content-panel.content-panel-custom-app:not(.is-gallery) .image-create-prompt-wrap textarea,
#content-panel.content-panel-custom-app:not(.is-gallery) .image-create-prompt-wrap .prompt-editor,
#content-panel.content-panel-custom-app:not(.is-gallery) .section-row .form-group textarea,
#content-panel.content-panel-custom-app:not(.is-gallery) .section-row .form-group input[type="text"],
#content-panel.content-panel-custom-app:not(.is-gallery) .section-row .form-group input[type="number"],
.music-lyrics-textarea,
.music-melody-textarea,
#music-result-style,
#music-result-storyboard,
#music-result-singing,
.music-inspiration-result,
.translate-textarea,
.translate-output,
.quick-link-form-input,
.settings-content input[type="text"],
.settings-content input[type="url"],
.settings-content input[type="password"],
.settings-content input[type="number"],
.settings-content input[type="email"],
.settings-content input:not([type]),
.settings-content textarea,
.settings-content select {
  border: 1px solid rgba(255, 255, 255, 0.10) !important;
  border-radius: 22px !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.028)) !important;
  color: var(--text) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.06),
    inset 0 0 0 1px rgba(255, 255, 255, 0.015) !important;
}

#content-panel.content-panel-image-create .image-create-prompt-wrap textarea:focus,
#content-panel.content-panel-image-create .image-create-prompt-wrap .prompt-editor:focus,
#content-panel.content-panel-custom-app:not(.is-gallery) .image-create-prompt-wrap textarea:focus,
#content-panel.content-panel-custom-app:not(.is-gallery) .image-create-prompt-wrap .prompt-editor:focus,
#content-panel.content-panel-custom-app:not(.is-gallery) .section-row .form-group textarea:focus,
#content-panel.content-panel-custom-app:not(.is-gallery) .section-row .form-group input:focus,
.music-lyrics-textarea:focus,
.music-melody-textarea:focus,
#music-result-style:focus,
#music-result-storyboard:focus,
#music-result-singing:focus,
.music-inspiration-result:focus,
.translate-textarea:focus,
.translate-output:focus,
.quick-link-form-input:focus,
.settings-content input[type="text"]:focus,
.settings-content input[type="url"]:focus,
.settings-content input[type="password"]:focus,
.settings-content input[type="number"]:focus,
.settings-content input[type="email"]:focus,
.settings-content input:not([type]):focus,
.settings-content textarea:focus,
.settings-content select:focus {
  border-color: rgba(235, 100, 91, 0.44) !important;
  box-shadow:
    0 0 0 4px rgba(235, 100, 91, 0.11),
    0 16px 44px rgba(235, 100, 91, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
  outline: none !important;
}

#content-panel.content-panel-image-create .image-create-prompt-wrap .prompt-editor:empty::before,
#content-panel.content-panel-custom-app:not(.is-gallery) .image-create-prompt-wrap .prompt-editor:empty::before,
textarea::placeholder,
input::placeholder {
  color: rgba(255, 248, 242, 0.42) !important;
}

.image-create-size-trigger,
.image-create-variants .model-selector-trigger,
.compact-control-input select,
.compact-control-input input,
.model-selector-trigger,
.custom-app-key-trigger,
.music-model-trigger,
.music-mode-segment,
.quick-link-add-btn,
.quick-link-form-submit,
.quick-link-form-cancel,
.btn-secondary,
.btn-primary,
.btn-generate,
.btn-generate-inspiration,
.btn-generate-cover,
.btn-generate-music,
.image-create-generate,
.translate-generate,
.history-toolbar-btn,
.history-cancel-btn,
.custom-app-back,
.settings-content .input-action,
.settings-content .btn-secondary {
  border-radius: 999px !important;
}

.image-create-size-trigger,
.image-create-variants .model-selector-trigger,
.compact-control-input select,
.compact-control-input input,
.model-selector-trigger,
.custom-app-key-trigger,
.music-model-trigger,
.music-mode-segment,
.settings-content .input-action,
.settings-content .btn-secondary {
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  background:
    radial-gradient(circle at 12% 12%, rgba(235, 100, 91, 0.10), transparent 34%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.085), rgba(255, 255, 255, 0.030)) !important;
  color: var(--text) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.075) !important;
}

.btn-primary,
.btn-generate,
.btn-generate-music,
.btn-generate-inspiration,
.btn-generate-cover,
.quick-link-form-submit,
.image-create-generate,
.translate-generate {
  border: 0 !important;
  background:
    radial-gradient(circle at 22% 16%, rgba(255, 244, 194, 0.36), transparent 28%),
    linear-gradient(135deg, #ff7f73, #eb645b 58%, #d94f48) !important;
  color: #fff !important;
  box-shadow:
    0 20px 46px rgba(235, 100, 91, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.22) !important;
}

.btn-primary:hover:not(:disabled),
.btn-generate:hover:not(:disabled),
.btn-generate-music:hover:not(:disabled),
.btn-generate-inspiration:hover:not(:disabled),
.btn-generate-cover:hover:not(:disabled),
.quick-link-form-submit:hover,
.image-create-generate:hover:not(:disabled),
.translate-generate:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow:
    0 24px 58px rgba(235, 100, 91, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.28) !important;
}

.image-create-generate,
.btn-generate,
.btn-generate-music,
.btn-generate-inspiration,
.btn-generate-cover {
  font-weight: 850 !important;
}

#content-panel.content-panel-music-create .music-status-bar {
  padding: 18px 22px !important;
}

#content-panel.content-panel-music-create .music-status-step {
  border: 1px solid transparent !important;
  background: transparent !important;
}

#content-panel.content-panel-music-create .music-status-step.active,
#content-panel.content-panel-music-create .music-status-step:hover {
  border-color: rgba(235, 100, 91, 0.22) !important;
  background: rgba(235, 100, 91, 0.10) !important;
}

#content-panel.content-panel-music-create .music-status-dot {
  background: rgba(255, 255, 255, 0.12) !important;
  box-shadow:
    inset 0 0 0 4px rgba(255, 255, 255, 0.035),
    0 0 0 1px rgba(255, 255, 255, 0.08) !important;
}

#content-panel.content-panel-music-create .music-status-step.active .music-status-dot {
  background: var(--primary) !important;
  box-shadow:
    0 0 24px rgba(235, 100, 91, 0.65),
    inset 0 0 0 4px rgba(255, 255, 255, 0.16) !important;
}

#content-panel.content-panel-music-create .music-status-step.done .music-status-dot {
  background: #4fc3c7 !important;
  box-shadow:
    0 0 22px rgba(79, 195, 199, 0.38),
    inset 0 0 0 4px rgba(255, 255, 255, 0.12) !important;
}

#content-panel.content-panel-music-create .music-status-line {
  height: 2px !important;
  border-radius: 999px !important;
  background: linear-gradient(90deg, rgba(255,255,255,0.09), rgba(120,232,255,0.12)) !important;
}

#content-panel.content-panel-music-create .music-mode-segment {
  padding: 5px !important;
}

#content-panel.content-panel-music-create .music-mode-btn {
  border-radius: 999px !important;
  color: var(--text-secondary) !important;
  font-weight: 850 !important;
}

#content-panel.content-panel-music-create .music-mode-btn.active {
  background:
    linear-gradient(135deg, rgba(235, 100, 91, 0.88), rgba(211, 75, 68, 0.72)) !important;
  color: #fff !important;
  box-shadow: 0 12px 30px rgba(235, 100, 91, 0.24) !important;
}

#content-panel.content-panel-music-create .music-model-trigger {
  min-height: 46px !important;
  padding: 8px 14px !important;
  border-color: rgba(235, 100, 91, 0.34) !important;
}

#content-panel.content-panel-music-create .music-model-sigil,
.model-selector-brand,
.model-option-icon {
  background:
    radial-gradient(circle at 30% 22%, #fff6bf, #ff8f77 42%, #eb645b 66%, #7be8ff 130%) !important;
  color: #18202a !important;
}

#content-panel.content-panel-music-create .music-create-bottom {
  gap: 18px !important;
}

#content-panel.content-panel-music-create .music-lyrics-panel,
#content-panel.content-panel-music-create .music-melody-panel {
  padding: 18px !important;
}

#content-panel.content-panel-music-create .music-section-label,
#content-panel.content-panel-music-create .music-lyrics-header-label,
#content-panel.content-panel-music-create .music-melody-section-label,
#content-panel.content-panel-custom-app:not(.is-gallery) .form-group label,
.settings-content .form-group label {
  color: rgba(255, 248, 242, 0.92) !important;
  font-weight: 850 !important;
}

.history-card,
.history-tile-image,
.history-file-picker-item,
.result-image-wrapper {
  overflow: hidden;
}

.history-card:hover,
.history-tile-image:hover,
.history-file-picker-item:hover,
.result-image-wrapper:hover {
  border-color: rgba(235, 100, 91, 0.30) !important;
  box-shadow:
    0 24px 62px rgba(235, 100, 91, 0.14),
    0 18px 52px rgba(0, 0, 0, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.10) !important;
}

body:not(.theme-dark) #content-panel.content-panel-music-create .music-status-bar,
body:not(.theme-dark) #content-panel.content-panel-music-create .music-create-top,
body:not(.theme-dark) #content-panel.content-panel-music-create .music-lyrics-panel,
body:not(.theme-dark) #content-panel.content-panel-music-create .music-melody-panel,
body:not(.theme-dark) #content-panel.content-panel-music-create .music-inspiration-final,
body:not(.theme-dark) #content-panel.content-panel-image-create .image-create-editor,
body:not(.theme-dark) #content-panel.content-panel-image-create .image-create-prompt-wrap,
body:not(.theme-dark) #content-panel.content-panel-image-create .image-create-dock,
body:not(.theme-dark) #content-panel.content-panel-custom-app:not(.is-gallery) .creator-shell,
body:not(.theme-dark) #content-panel.content-panel-custom-app:not(.is-gallery) .image-create-dock,
body:not(.theme-dark) #content-panel.content-panel-custom-app:not(.is-gallery) .section-row,
body:not(.theme-dark) #content-panel.content-panel-custom-app:not(.is-gallery) .image-create-prompt-wrap,
body:not(.theme-dark) #content-panel.content-panel-translate .translate-shell,
body:not(.theme-dark) .modal-content,
body:not(.theme-dark) .settings-content .form-group,
body:not(.theme-dark) .history-shell,
body:not(.theme-dark) .history-card,
body:not(.theme-dark) .history-tile-image,
body:not(.theme-dark) .history-file-picker-item,
body:not(.theme-dark) .result-image-wrapper {
  border-color: rgba(33, 44, 58, 0.11) !important;
  background:
    radial-gradient(circle at 10% 0%, rgba(235, 100, 91, 0.085), transparent 32%),
    radial-gradient(circle at 88% 8%, rgba(79, 195, 199, 0.075), transparent 34%),
    linear-gradient(145deg, rgba(255, 252, 248, 0.86), rgba(238, 244, 247, 0.82)) !important;
  box-shadow:
    0 22px 62px rgba(16, 24, 40, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 0.82) !important;
}

body:not(.theme-dark) #content-panel.content-panel-image-create .image-create-prompt-wrap textarea,
body:not(.theme-dark) #content-panel.content-panel-image-create .image-create-prompt-wrap .prompt-editor,
body:not(.theme-dark) #content-panel.content-panel-custom-app:not(.is-gallery) .image-create-prompt-wrap textarea,
body:not(.theme-dark) #content-panel.content-panel-custom-app:not(.is-gallery) .image-create-prompt-wrap .prompt-editor,
body:not(.theme-dark) #content-panel.content-panel-custom-app:not(.is-gallery) .section-row .form-group textarea,
body:not(.theme-dark) #content-panel.content-panel-custom-app:not(.is-gallery) .section-row .form-group input[type="text"],
body:not(.theme-dark) #content-panel.content-panel-custom-app:not(.is-gallery) .section-row .form-group input[type="number"],
body:not(.theme-dark) .music-lyrics-textarea,
body:not(.theme-dark) .music-melody-textarea,
body:not(.theme-dark) #music-result-style,
body:not(.theme-dark) #music-result-storyboard,
body:not(.theme-dark) #music-result-singing,
body:not(.theme-dark) .music-inspiration-result,
body:not(.theme-dark) .translate-textarea,
body:not(.theme-dark) .translate-output,
body:not(.theme-dark) .quick-link-form-input,
body:not(.theme-dark) .settings-content input[type="text"],
body:not(.theme-dark) .settings-content input[type="url"],
body:not(.theme-dark) .settings-content input[type="password"],
body:not(.theme-dark) .settings-content input[type="number"],
body:not(.theme-dark) .settings-content input[type="email"],
body:not(.theme-dark) .settings-content input:not([type]),
body:not(.theme-dark) .settings-content textarea,
body:not(.theme-dark) .settings-content select {
  border-color: rgba(33, 44, 58, 0.10) !important;
  background: rgba(255, 255, 255, 0.56) !important;
  color: #17181d !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.78),
    inset 0 0 0 1px rgba(33, 44, 58, 0.018) !important;
}

body:not(.theme-dark) #content-panel.content-panel-image-create .image-create-prompt-wrap .prompt-editor:empty::before,
body:not(.theme-dark) #content-panel.content-panel-custom-app:not(.is-gallery) .image-create-prompt-wrap .prompt-editor:empty::before,
body:not(.theme-dark) textarea::placeholder,
body:not(.theme-dark) input::placeholder {
  color: rgba(38, 48, 58, 0.42) !important;
}

body:not(.theme-dark) #content-panel.content-panel-music-create .music-section-label,
body:not(.theme-dark) #content-panel.content-panel-music-create .music-lyrics-header-label,
body:not(.theme-dark) #content-panel.content-panel-music-create .music-melody-section-label,
body:not(.theme-dark) #content-panel.content-panel-custom-app:not(.is-gallery) .form-group label,
body:not(.theme-dark) .settings-content .form-group label {
  color: #17181d !important;
}

/* Final custom app inner layout guard */
#content.content-custom-app-layout.content-custom-app-split {
  grid-template-columns: minmax(420px, 1fr) clamp(220px, 28vw, 380px) !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app {
  padding: clamp(14px, 2.4vw, 28px) !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-result {
  padding: clamp(14px, 2.2vw, 26px) !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-result .history-shell {
  width: 100% !important;
  max-width: 360px !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .creator-shell {
  width: 100% !important;
  max-width: 760px !important;
  margin: 0 auto !important;
}

@media (max-width: 960px) {
  #content.content-custom-app-layout.content-custom-app-split {
    grid-template-columns: 1fr !important;
    grid-template-rows: minmax(0, auto) minmax(180px, 34vh) !important;
    overflow-y: auto !important;
  }

  #content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app,
  #content.content-custom-app-layout.content-custom-app-split #content-result {
    grid-column: 1 !important;
    height: auto !important;
    min-height: 0 !important;
  }

  #content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app {
    grid-row: 1 !important;
    border-right: 0 !important;
    border-bottom: 1px solid var(--divider) !important;
  }

  #content.content-custom-app-layout.content-custom-app-split #content-result {
    grid-row: 2 !important;
  }
}
}
}

/* ===== Nala macOS client inner UI relaunch end locks 2026-06-02 ===== */
#content,
#content.content-custom-app-layout {
  color: var(--nala-v2-text) !important;
  background:
    radial-gradient(circle at 12% 10%, rgba(235, 100, 91, 0.12), transparent 33%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.11), transparent 32%),
    linear-gradient(135deg, rgba(255, 252, 248, 0.96), rgba(239, 245, 248, 0.96)) !important;
}

body.theme-dark #content,
body.theme-dark #content.content-custom-app-layout {
  background:
    radial-gradient(circle at 12% 10%, rgba(255, 118, 97, 0.20), transparent 34%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.15), transparent 32%),
    radial-gradient(circle at 62% 92%, rgba(255, 202, 132, 0.08), transparent 38%),
    linear-gradient(135deg, rgba(15, 22, 31, 0.99), rgba(24, 36, 46, 0.98) 52%, rgba(12, 17, 25, 0.99)) !important;
}

#settings-modal .settings-content {
  width: min(980px, calc(100vw - 64px)) !important;
  max-width: min(980px, calc(100vw - 64px)) !important;
  max-height: calc(100vh - 56px) !important;
  border-radius: 28px !important;
  background:
    radial-gradient(circle at 14% 0%, rgba(235, 100, 91, 0.14), transparent 34%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.11), transparent 32%),
    var(--nala-v2-surface-strong) !important;
  box-shadow: var(--nala-v2-shadow) !important;
}

#settings-modal .settings-content > .form-group,
#settings-modal .settings-content > .settings-feishu-section {
  margin: 0 28px !important;
  padding: 16px 0 !important;
  border: 0 !important;
  border-bottom: 1px solid var(--nala-v2-line) !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

#content-panel.content-panel-music-create {
  padding: 14px 16px 28px !important;
}

#content-panel.content-panel-music-create .music-create-shell {
  width: min(1360px, 100%) !important;
  margin: 0 auto !important;
  gap: 12px !important;
  padding-bottom: 16px !important;
}

#content-panel.content-panel-music-create .music-status-bar {
  padding: 30px 18px 26px !important;
  overflow: hidden !important;
  scrollbar-width: none !important;
}

#content-panel.content-panel-music-create .music-status-bar::-webkit-scrollbar {
  display: none !important;
}

#content-panel.content-panel-music-create .music-status-steps {
  display: flex !important;
  align-items: center !important;
  width: 100% !important;
  min-width: 0 !important;
  justify-content: space-between !important;
  gap: 0 !important;
}

#content-panel.content-panel-music-create .music-status-step {
  min-width: 58px !important;
  padding: 9px 8px 8px !important;
  gap: 10px !important;
  border-radius: 16px !important;
  flex: 0 0 auto !important;
}

#content-panel.content-panel-music-create .music-status-dot {
  width: 11px !important;
  height: 11px !important;
}

#content-panel.content-panel-music-create .music-status-label {
  font-size: 12px !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
}

#content-panel.content-panel-music-create .music-status-line {
  flex: 1 1 0 !important;
  min-width: 16px !important;
  max-width: none !important;
  margin: 0 4px !important;
}

#content-panel.content-panel-music-create .music-status-melody-group {
  display: flex !important;
  align-items: center !important;
  flex: 0 0 auto !important;
  padding: 6px 6px 4px !important;
  border-radius: 16px !important;
}

#content-panel.content-panel-music-create .music-status-step-wrapper {
  padding-top: 24px !important;
  margin-top: -24px !important;
  flex: 0 0 auto !important;
}

#content-panel.content-panel-music-create .music-repair-icon {
  top: 2px !important;
  padding: 2px 8px !important;
  font-size: 10px !important;
}

#content-panel.content-panel-music-create .music-mode-bar {
  padding: 4px 0 8px !important;
  margin-bottom: 12px !important;
}

#content-panel.content-panel-music-create .music-model-row {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  width: 100% !important;
  padding: 0 !important;
  margin-top: -22px !important;
}

#content-panel.content-panel-music-create .music-model-picker {
  width: 220px !important;
  max-width: 220px !important;
  flex: 0 0 220px !important;
  margin: 0 auto !important;
}

#content-panel.content-panel-music-create .music-model-trigger {
  width: 100% !important;
  min-height: 40px !important;
  padding: 4px 7px !important;
  gap: 4px !important;
  border-radius: 20px !important;
  border: 1px solid rgba(235, 100, 91, 0.20) !important;
  background:
    radial-gradient(circle at 14% 0%, rgba(255, 158, 128, 0.18), transparent 36%),
    radial-gradient(circle at 88% 12%, rgba(105, 215, 229, 0.10), transparent 32%),
    rgba(35, 47, 59, 0.84) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 18px 42px rgba(0, 0, 0, 0.16) !important;
}

#content-panel.content-panel-music-create .music-model-menu {
  width: min(400px, calc(100vw - 44px)) !important;
  max-height: min(320px, calc(100vh - 180px)) !important;
  padding: 10px !important;
  border-radius: 22px !important;
}

#content-panel.content-panel-music-create .music-model-menu-title {
  padding: 2px 8px 8px !important;
  font-size: 11px !important;
}

#content-panel.content-panel-music-create .music-model-option {
  gap: 10px !important;
  padding: 9px !important;
  border-radius: 16px !important;
}

#content-panel.content-panel-music-create .music-model-option-mark {
  width: 28px !important;
  height: 28px !important;
  flex: 0 0 28px !important;
  font-size: 12px !important;
}

#content-panel.content-panel-music-create .music-model-option-name {
  font-size: 14px !important;
}

#content-panel.content-panel-music-create .music-model-option-meta {
  font-size: 10px !important;
}

#content-panel.content-panel-music-create .music-model-option-badge {
  font-size: 9px !important;
  padding: 4px 7px !important;
}

body:not(.theme-dark) #content-panel.content-panel-music-create .music-model-trigger {
  background:
    radial-gradient(circle at 14% 0%, rgba(255, 158, 128, 0.16), transparent 36%),
    radial-gradient(circle at 88% 12%, rgba(105, 215, 229, 0.12), transparent 32%),
    rgba(255, 255, 255, 0.84) !important;
  border-color: rgba(38, 48, 58, 0.12) !important;
}

#content-panel.content-panel-music-create .music-model-sigil {
  width: 18px !important;
  height: 18px !important;
  flex: 0 0 18px !important;
  font-size: 10px !important;
}

#content-panel.content-panel-music-create .music-model-current {
  gap: 2px !important;
  min-width: 0 !important;
  flex: 1 1 auto !important;
}

#content-panel.content-panel-music-create .music-model-kicker {
  font-size: 8px !important;
  font-weight: 820 !important;
  letter-spacing: 0.08em !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

#content-panel.content-panel-music-create .music-model-name {
  font-size: 12px !important;
  font-weight: 840 !important;
  line-height: 1.08 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

#content-panel.content-panel-music-create .music-model-live {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 20px !important;
  min-width: 50px !important;
  padding: 0 4px !important;
  font-size: 8px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-align: center !important;
}

#content-panel.content-panel-music-create .music-model-chevron {
  font-size: 13px !important;
  font-weight: 900 !important;
}

#content-panel.content-panel-music-create .music-create-bottom {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 20px !important;
  min-height: clamp(780px, 80vh, 1140px) !important;
  align-items: stretch !important;
  margin-top: 0 !important;
  padding-bottom: 12px !important;
}

#content-panel.content-panel-music-create .music-lyrics-panel,
#content-panel.content-panel-music-create .music-melody-panel {
  min-height: 0 !important;
  height: 100% !important;
  overflow: hidden !important;
  border-radius: 24px !important;
  padding: 18px !important;
}

#content-panel.content-panel-music-create .music-lyrics-panel {
  grid-column: 1 !important;
  display: flex !important;
  flex-direction: column !important;
}

#content-panel.content-panel-music-create .music-lyrics-textarea {
  min-height: 0 !important;
  height: 100% !important;
  flex: 1 1 auto !important;
}

#content-panel.content-panel-music-create .music-melody-panel {
  grid-column: 2 !important;
  display: grid !important;
  grid-template-rows: 182px minmax(0, 1fr) 198px !important;
  gap: 16px !important;
  align-items: stretch !important;
  overflow: hidden !important;
}

#content-panel.content-panel-music-create .music-melody-section {
  min-height: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  overflow: hidden !important;
}

#content-panel.content-panel-music-create .music-melody-section:has(#music-result-style) {
  min-height: 0 !important;
}

#content-panel.content-panel-music-create .music-melody-section:has(#music-result-storyboard) {
  min-height: 0 !important;
}

#content-panel.content-panel-music-create .music-melody-section:has(#music-result-singing) {
  min-height: 0 !important;
}

#content-panel.content-panel-music-create .music-section-header {
  gap: 8px !important;
  min-height: 34px !important;
  margin-bottom: 6px !important;
}

#content-panel.content-panel-music-create .music-section-label {
  font-size: 13px !important;
  line-height: 1.2 !important;
}

#content-panel.content-panel-music-create .music-section-error {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  max-width: none !important;
}

#content-panel.content-panel-music-create .music-copy-btn,
#content-panel.content-panel-music-create .music-revert-btn,
#content-panel.content-panel-music-create .music-reset-btn {
  width: 24px !important;
  height: 24px !important;
  min-width: 24px !important;
  min-height: 24px !important;
}

#content-panel.content-panel-music-create .music-melody-textarea,
#content-panel.content-panel-music-create #music-result-style,
#content-panel.content-panel-music-create #music-result-singing,
#content-panel.content-panel-music-create #music-result-storyboard {
  min-height: 0 !important;
  height: 100% !important;
  flex: 1 1 auto !important;
  overflow-y: auto !important;
  padding: 12px !important;
  font-size: 12px !important;
  line-height: 1.55 !important;
}

#content-panel.content-panel-music-create .music-lyrics-textarea {
  min-height: 0 !important;
  padding: 12px !important;
  font-size: 12px !important;
  line-height: 1.58 !important;
}

#content.content-custom-app-layout.content-custom-app-split {
  grid-template-columns: minmax(0, 1fr) clamp(360px, 32vw, 480px) !important;
  grid-template-rows: minmax(0, 1fr) !important;
  overflow: hidden !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-result {
  grid-column: 1 !important;
  grid-row: 1 !important;
  max-width: none !important;
  padding: 24px !important;
  border-right: 1px solid var(--nala-v2-line) !important;
  border-left: 0 !important;
  background: transparent !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-result .history-shell {
  width: 100% !important;
  max-width: none !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app {
  position: relative !important;
  inset: auto !important;
  grid-column: 2 !important;
  grid-row: 1 !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
  padding: 24px 22px !important;
  border-left: 1px solid var(--nala-v2-line) !important;
  border-right: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

#content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app .creator-shell {
  width: 100% !important;
  max-width: none !important;
  height: 100% !important;
  max-height: 100% !important;
  margin: 0 !important;
  overflow-y: auto !important;
}

#content.content-custom-app-layout #content-panel.content-panel-custom-app.is-gallery,
#content.content-custom-app-layout #content-panel.content-panel-video-apps.is-gallery {
  position: relative !important;
  inset: auto !important;
  grid-column: 1 !important;
  grid-row: 1 / -1 !important;
  height: 100% !important;
  max-height: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 28px !important;
  background: transparent !important;
  box-shadow: none !important;
}

#content-panel.content-panel-video-apps .video-app-gallery-shell,
#content.content-custom-app-layout #content-panel.content-panel-custom-app.is-gallery .custom-app-gallery-shell {
  width: min(1120px, 100%) !important;
  max-width: 1120px !important;
  margin: 0 auto !important;
}

#content-panel.content-panel-video-apps .video-app-gallery-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 28px !important;
}

#content-panel.content-panel-video-apps .video-app-card-cover {
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 16 / 9 !important;
  border-radius: 26px !important;
  background-size: cover !important;
  background-position: center !important;
}

#content-panel.content-panel-video-apps .video-app-card-cover-img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
}

.quick-links-page {
  width: min(1180px, 100%) !important;
  margin: 0 auto !important;
}

.quick-links-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

.quick-link-card {
  min-height: 92px !important;
  height: auto !important;
  grid-template-columns: 88px minmax(0, 1fr) !important;
  border-radius: 22px !important;
}

.quick-link-card-user {
  grid-template-columns: 88px minmax(0, 1fr) auto !important;
}

.creator-shell,
.translate-shell,
.quick-links-section,
.music-status-bar,
.music-create-top,
.music-lyrics-panel,
.music-melody-panel,
.history-shell,
.history-card,
.quick-link-card,
.custom-app-card,
.modal-content,
.music-confirm-dialog,
.full-auto-dialog-content {
  border-color: var(--nala-v2-line) !important;
  background:
    radial-gradient(circle at 10% 0%, rgba(235, 100, 91, 0.09), transparent 34%),
    radial-gradient(circle at 90% 5%, rgba(105, 215, 229, 0.08), transparent 34%),
    var(--nala-v2-surface) !important;
  box-shadow: var(--nala-v2-shadow-soft) !important;
}

@media (max-width: 760px) {
  .quick-links-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  #content-panel.content-panel-music-create .music-create-bottom {
    grid-template-columns: 1fr !important;
  }

  #content-panel.content-panel-music-create .music-melody-panel {
    grid-column: 1 !important;
    grid-template-rows: repeat(3, minmax(198px, auto)) !important;
  }
}

@media (max-width: 980px) {
  #content-panel.content-panel-music-create {
    padding: 12px 14px 22px !important;
  }

  #content-panel.content-panel-music-create .music-mode-segment {
    padding: 4px !important;
    gap: 2px !important;
  }

  #content-panel.content-panel-music-create .music-mode-btn {
    min-height: 32px !important;
    padding: 0 16px !important;
    font-size: 12px !important;
  }

  #content-panel.content-panel-music-create .music-status-step {
    min-width: 50px !important;
    padding: 8px 5px 6px !important;
  }

  #content-panel.content-panel-music-create .music-status-line {
    min-width: 12px !important;
    margin: 0 3px !important;
  }

  #content-panel.content-panel-music-create .music-model-picker {
    width: min(286px, calc(100% - 24px)) !important;
  }

  #content-panel.content-panel-music-create .music-model-menu {
    width: min(388px, calc(100vw - 32px)) !important;
  }

  #content-panel.content-panel-music-create .music-create-bottom {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 16px !important;
  }
}

@media (max-width: 860px) {
  #content.content-custom-app-layout.content-custom-app-split {
    grid-template-columns: 1fr !important;
    grid-template-rows: minmax(0, 1fr) minmax(320px, 42vh) !important;
  }

  #content.content-custom-app-layout.content-custom-app-split #content-result,
  #content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app {
    grid-column: 1 !important;
  }

  #content.content-custom-app-layout.content-custom-app-split #content-result {
    grid-row: 1 !important;
    border-right: 0 !important;
    border-bottom: 1px solid var(--nala-v2-line) !important;
  }

  #content.content-custom-app-layout.content-custom-app-split #content-panel.content-panel-custom-app {
    grid-row: 2 !important;
    border-left: 0 !important;
  }

  .quick-links-grid,
  #content-panel.content-panel-video-apps .video-app-gallery-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Music checkbox/dialog final guard. Keep this block at EOF. */
.music-song-auto-open {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  min-width: 0 !important;
}

.music-song-auto-open input[type="checkbox"] {
  position: relative !important;
  display: inline-block !important;
  flex: 0 0 18px !important;
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 1px solid rgba(226, 232, 240, 0.42) !important;
  border-radius: 7px !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.04)),
    rgba(255, 255, 255, 0.08) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
  box-sizing: border-box !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  overflow: hidden !important;
}

.music-song-auto-open input[type="checkbox"]:checked {
  border-color: rgba(235, 100, 91, 0.92) !important;
  background: linear-gradient(135deg, #ff7f73, #eb645b) !important;
  box-shadow:
    0 0 0 3px rgba(235, 100, 91, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.24) !important;
}

.music-song-auto-open input[type="checkbox"]:checked::after {
  content: "" !important;
  position: absolute !important;
  left: 5px !important;
  top: 2px !important;
  display: block !important;
  width: 5px !important;
  height: 9px !important;
  border: solid #fff !important;
  border-width: 0 2px 2px 0 !important;
  box-sizing: border-box !important;
  transform: rotate(45deg) !important;
}

.full-auto-inspiration-dialog .full-auto-dialog-content {
  box-sizing: border-box !important;
  width: min(640px, calc(100vw - 88px)) !important;
  max-width: calc(100vw - 88px) !important;
  max-height: calc(100vh - 44px) !important;
}

.full-auto-inspiration-dialog .full-auto-dialog-config {
  box-sizing: border-box !important;
  width: 100% !important;
  padding: 20px 28px !important;
  overflow: hidden !important;
}

.full-auto-inspiration-dialog .full-auto-song-settings-row {
  grid-template-columns: max-content max-content minmax(132px, 1fr) !important;
  gap: 28px !important;
}

.full-auto-inspiration-dialog .full-auto-song-settings-row .music-song-exec-count {
  justify-content: flex-end !important;
}

.full-auto-inspiration-dialog .full-auto-workflow-options {
  display: grid !important;
  grid-template-columns: max-content max-content max-content !important;
  align-items: center !important;
  justify-content: start !important;
  gap: 16px 28px !important;
  width: 100% !important;
  min-width: 0 !important;
  overflow: hidden !important;
}

.full-auto-inspiration-dialog .full-auto-workflow-options .music-song-auto-open,
.full-auto-inspiration-dialog .full-auto-song-settings-row .music-song-auto-open,
.full-auto-inspiration-dialog .full-auto-song-settings-row .music-song-exec-count {
  min-width: 0 !important;
  margin: 0 !important;
  white-space: nowrap !important;
}

.full-auto-inspiration-dialog .full-auto-workflow-options .music-song-auto-open span,
.full-auto-inspiration-dialog .full-auto-song-settings-row .music-song-auto-open span,
.full-auto-inspiration-dialog .full-auto-song-settings-row .music-song-exec-count span {
  display: inline-block !important;
  max-width: none !important;
  overflow: visible !important;
  text-overflow: clip !important;
  white-space: nowrap !important;
}

@media (max-width: 1180px) {
  .full-auto-inspiration-dialog .full-auto-dialog-content {
    width: calc(100vw - 48px) !important;
    max-width: calc(100vw - 48px) !important;
  }

  .full-auto-inspiration-dialog .full-auto-workflow-options {
    grid-template-columns: max-content max-content !important;
  }

  .full-auto-inspiration-dialog .full-auto-workflow-options #full-auto-song-feishu-row {
    grid-column: 1 / -1 !important;
  }
}

/* Music inspiration modal footer: reset belongs directly before cancel in the right action group. */
.music-inspiration-modal-body > .modal-actions {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 14px !important;
}

.music-inspiration-modal-body > .modal-actions #btn-music-inspiration-reset,
.music-inspiration-modal-body > .modal-actions #btn-music-inspiration-cancel,
.music-inspiration-modal-body > .modal-actions #btn-music-inspiration-cancel-generate,
.music-inspiration-modal-body > .modal-actions #btn-music-inspiration-generate,
.music-inspiration-modal-body > .modal-actions #btn-music-inspiration-confirm,
.music-inspiration-modal-body > .modal-actions #btn-music-inspiration-save {
  margin-left: 0 !important;
  margin-right: 0 !important;
  justify-self: auto !important;
}

.music-inspiration-modal-body > .modal-actions #btn-music-inspiration-reset {
  order: 10 !important;
}

.music-inspiration-modal-body > .modal-actions #btn-music-inspiration-cancel {
  order: 20 !important;
}

.music-inspiration-modal-body > .modal-actions #btn-music-inspiration-cancel-generate {
  order: 25 !important;
}

.music-inspiration-modal-body > .modal-actions #btn-music-inspiration-generate,
.music-inspiration-modal-body > .modal-actions #btn-music-inspiration-confirm,
.music-inspiration-modal-body > .modal-actions #btn-music-inspiration-save {
  order: 30 !important;
}

/* Shell background unification: topbar, sidebar, and content share the body canvas. */
body:not(.theme-dark) {
  background:
    radial-gradient(circle at 12% 10%, rgba(235, 100, 91, 0.12), transparent 33%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.10), transparent 32%),
    linear-gradient(135deg, rgba(255, 252, 248, 0.96), rgba(239, 245, 248, 0.96)) !important;
}

body.theme-dark {
  background:
    radial-gradient(circle at 12% 10%, rgba(255, 118, 97, 0.20), transparent 34%),
    radial-gradient(circle at 88% 8%, rgba(105, 215, 229, 0.15), transparent 32%),
    radial-gradient(circle at 62% 92%, rgba(255, 202, 132, 0.08), transparent 38%),
    linear-gradient(135deg, rgba(15, 22, 31, 0.99), rgba(24, 36, 46, 0.98) 52%, rgba(12, 17, 25, 0.99)) !important;
}

#topbar,
#app,
#sidebar,
#content,
#content.content-custom-app-layout,
body:not(.theme-dark) #topbar,
body.theme-dark #topbar,
body:not(.theme-dark) #sidebar,
body.theme-dark #sidebar,
body:not(.theme-dark) #content,
body.theme-dark #content,
body.theme-dark #content.content-custom-app-layout,
body:not(.theme-dark) #content.content-custom-app-layout {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

#app::before {
  content: none !important;
  display: none !important;
}

/* Main workspace frame: fixed right/bottom gutters while the inner content scales. */
:root {
  --shell-content-gutter-right: 18px;
  --shell-content-gutter-bottom: 18px;
  --shell-content-frame-radius: 28px;
}

#content,
#content.content-custom-app-layout,
body:not(.theme-dark) #content,
body.theme-dark #content,
body:not(.theme-dark) #content.content-custom-app-layout,
body.theme-dark #content.content-custom-app-layout {
  position: relative !important;
  margin: 0 var(--shell-content-gutter-right) var(--shell-content-gutter-bottom) 0 !important;
  min-width: 0 !important;
  min-height: 0 !important;
  border: 0 !important;
  border-radius: var(--shell-content-frame-radius) !important;
  background:
    linear-gradient(142deg, rgba(255, 255, 255, 0.115), rgba(255, 255, 255, 0.032) 42%, rgba(105, 215, 229, 0.055) 100%),
    radial-gradient(circle at 14% 0%, rgba(255, 118, 97, 0.16), transparent 36%),
    radial-gradient(circle at 84% 6%, rgba(105, 215, 229, 0.16), transparent 42%),
    radial-gradient(circle at 60% 100%, rgba(255, 202, 132, 0.08), transparent 44%),
    rgba(18, 25, 34, 0.42) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    inset 1px 0 0 rgba(255, 255, 255, 0.075),
    inset 0 -1px 0 rgba(105, 215, 229, 0.075),
    inset 0 -24px 52px rgba(3, 8, 14, 0.12),
    0 28px 76px rgba(0, 0, 0, 0.16),
    0 0 44px rgba(105, 215, 229, 0.045) !important;
  backdrop-filter: blur(36px) saturate(1.34) contrast(1.03) !important;
  -webkit-backdrop-filter: blur(36px) saturate(1.34) contrast(1.03) !important;
  overflow-x: hidden !important;
}

body:not(.theme-dark) #content,
body:not(.theme-dark) #content.content-custom-app-layout {
  background:
    linear-gradient(142deg, rgba(255, 255, 255, 0.74), rgba(255, 255, 255, 0.38) 48%, rgba(232, 247, 250, 0.42) 100%),
    radial-gradient(circle at 14% 0%, rgba(235, 100, 91, 0.14), transparent 36%),
    radial-gradient(circle at 84% 6%, rgba(105, 215, 229, 0.16), transparent 42%),
    radial-gradient(circle at 60% 100%, rgba(255, 202, 132, 0.12), transparent 44%),
    rgba(255, 252, 248, 0.54) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.78),
    inset 1px 0 0 rgba(255, 255, 255, 0.40),
    inset 0 -1px 0 rgba(105, 215, 229, 0.18),
    inset 0 -22px 48px rgba(255, 255, 255, 0.22),
    0 24px 64px rgba(35, 45, 58, 0.10),
    0 0 38px rgba(105, 215, 229, 0.08) !important;
}

#content::after,
#content.content-custom-app-layout::after,
body.theme-dark #content::after,
body.theme-dark #content.content-custom-app-layout::after,
body:not(.theme-dark) #content::after,
body:not(.theme-dark) #content.content-custom-app-layout::after {
  content: none !important;
  display: none !important;
}

/* Sidebar app launcher: macOS-style rounded app icons with labels below. */
#sidebar:not(.sidebar-collapsed) #sidebar-modules {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  align-content: start !important;
  gap: 18px 16px !important;
  padding: 28px 24px 18px !important;
  overflow-y: auto !important;
}

#sidebar:not(.sidebar-collapsed) .sidebar-module {
  display: contents !important;
  padding: 0 !important;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service {
  width: 100% !important;
  min-width: 0 !important;
  height: 96px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 20px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 8px !important;
  background: transparent !important;
  color: rgba(255, 248, 242, 0.86) !important;
  text-align: center !important;
  box-shadow: none !important;
  transform: none !important;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service:hover {
  color: #fff8f2 !important;
  transform: translateY(-1px) !important;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service.active {
  color: #fff8f2 !important;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service-icon {
  position: relative !important;
  width: 54px !important;
  height: 54px !important;
  min-width: 54px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 16px !important;
  color: rgba(255, 248, 242, 0.96) !important;
  font-size: 0 !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  overflow: hidden !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.36),
    inset 0 -18px 32px rgba(0, 0, 0, 0.16),
    0 14px 32px rgba(0, 0, 0, 0.24) !important;
  background:
    radial-gradient(circle at 30% 18%, rgba(255, 255, 255, 0.42), transparent 32%),
    linear-gradient(145deg, rgba(255, 128, 112, 0.96), rgba(186, 59, 82, 0.92)) !important;
  transition: transform 0.16s ease, box-shadow 0.16s ease, filter 0.16s ease !important;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service:hover .sidebar-service-icon,
#sidebar:not(.sidebar-collapsed) .sidebar-service.active .sidebar-service-icon {
  transform: translateY(-1px) scale(1.03) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.42),
    inset 0 -18px 32px rgba(0, 0, 0, 0.14),
    0 18px 40px rgba(235, 100, 91, 0.24),
    0 0 26px rgba(105, 215, 229, 0.12) !important;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service-icon::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.32), transparent 42%, rgba(255, 255, 255, 0.08));
  pointer-events: none;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service-icon::after {
  position: relative;
  z-index: 1;
  font-size: 20px;
  letter-spacing: 0;
  color: currentColor;
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.18);
}

#sidebar:not(.sidebar-collapsed) .sidebar-service[data-service-kind="image"] .sidebar-service-icon {
  background:
    radial-gradient(circle at 32% 18%, rgba(255, 255, 255, 0.48), transparent 32%),
    linear-gradient(145deg, #ff7f73, #ea5f75 48%, #69d7e5) !important;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service[data-service-kind="image"] .sidebar-service-icon::after {
  content: "AI";
  font-size: 17px;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service[data-service-kind="apps"] .sidebar-service-icon {
  background:
    radial-gradient(circle at 30% 18%, rgba(255, 255, 255, 0.44), transparent 32%),
    linear-gradient(145deg, #7de3f0, #4e9bd7 48%, #8065f2) !important;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service[data-service-kind="apps"] .sidebar-service-icon::after {
  content: "▦";
  font-size: 24px;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service[data-service-kind="music"] .sidebar-service-icon {
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.46), transparent 32%),
    linear-gradient(145deg, #ff8a78, #eb645b 45%, #d94f8f) !important;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service[data-service-kind="music"] .sidebar-service-icon::after {
  content: "♪";
  font-size: 26px;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service[data-service-kind="translate"] .sidebar-service-icon {
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.46), transparent 32%),
    linear-gradient(145deg, #6bd8f2, #376ed8 48%, #6b5ff0) !important;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service[data-service-kind="translate"] .sidebar-service-icon::after {
  content: "文";
  font-size: 22px;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service[data-service-kind="links"] .sidebar-service-icon {
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.46), transparent 32%),
    linear-gradient(145deg, #ffe08a, #ff9a5c 48%, #eb645b) !important;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service[data-service-kind="links"] .sidebar-service-icon::after {
  content: "⌁";
  font-size: 27px;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service[data-service-kind="video"] .sidebar-service-icon {
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.46), transparent 32%),
    linear-gradient(145deg, #a58cff, #6156dd 48%, #1fc7d4) !important;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service[data-service-kind="video"] .sidebar-service-icon::after {
  content: "▶";
  font-size: 20px;
}

#sidebar:not(.sidebar-collapsed) .sidebar-service-text {
  display: block !important;
  width: 100% !important;
  max-width: 104px !important;
  min-width: 0 !important;
  color: currentColor !important;
  font-size: 13px !important;
  font-weight: 760 !important;
  line-height: 1.2 !important;
  text-align: center !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

body:not(.theme-dark) #sidebar:not(.sidebar-collapsed) .sidebar-service {
  color: rgba(24, 31, 42, 0.78) !important;
}

body:not(.theme-dark) #sidebar:not(.sidebar-collapsed) .sidebar-service:hover,
body:not(.theme-dark) #sidebar:not(.sidebar-collapsed) .sidebar-service.active {
  color: #17181d !important;
}
