﻿:root {
  color-scheme: dark;
  --bg: #080a12;
  --ink: #edf7ff;
  --muted: #9ab1c2;
  --line: #203246;
  --panel: rgba(12, 18, 31, .94);
  --accent: #20d6ff;
  --accent-rgb: 32, 214, 255;
  --accent-2: #ff4fd8;
  --accent-soft: #b9f3ff;
  --accent-pale: #dff7ff;
  --button: #0d7f9f;
  --soft: #111b2d;
  --field: #0a1120;
  --glow: rgba(0, 0, 0, .16);
  --body-bg:
    linear-gradient(180deg, rgba(255, 255, 255, .025), rgba(255, 255, 255, 0) 220px),
    linear-gradient(180deg, #080a12 0%, #0b1020 52%, #080a12 100%);
}

:root[data-palette="black"] {
  --bg: #030406;
  --ink: #f5f7fa;
  --muted: #9ca3af;
  --line: #242832;
  --panel: rgba(10, 11, 14, .94);
  --accent: #e5e7eb;
  --accent-rgb: 229, 231, 235;
  --accent-2: #c7a96b;
  --accent-soft: #e5e7eb;
  --accent-pale: #f5f7fa;
  --button: #323640;
  --soft: #111318;
  --field: #07080b;
  --glow: rgba(0, 0, 0, .2);
  --body-bg:
    linear-gradient(180deg, rgba(255, 255, 255, .03), rgba(255, 255, 255, 0) 240px),
    #030406;
}

:root[data-palette="emerald"] {
  --bg: #050b09;
  --ink: #eefcf6;
  --muted: #9db8ad;
  --line: #1f3d34;
  --panel: rgba(8, 18, 15, .94);
  --accent: #58e39d;
  --accent-rgb: 88, 227, 157;
  --accent-2: #f0c45c;
  --accent-soft: #baf8d7;
  --accent-pale: #e1fff0;
  --button: #168557;
  --soft: #0e211a;
  --field: #081510;
  --glow: rgba(0, 0, 0, .18);
  --body-bg:
    linear-gradient(180deg, rgba(88, 227, 157, .045), rgba(255, 255, 255, 0) 230px),
    linear-gradient(180deg, #050b09 0%, #09140f 54%, #050b09 100%);
}

:root[data-palette="rose"] {
  --bg: #10080d;
  --ink: #fff4f8;
  --muted: #c2a0ad;
  --line: #442334;
  --panel: rgba(22, 10, 17, .94);
  --accent: #ff7aa8;
  --accent-rgb: 255, 122, 168;
  --accent-2: #7fd8ff;
  --accent-soft: #ffc2d6;
  --accent-pale: #ffe6ef;
  --button: #a43c64;
  --soft: #211019;
  --field: #150911;
  --glow: rgba(0, 0, 0, .18);
  --body-bg:
    linear-gradient(180deg, rgba(255, 122, 168, .04), rgba(255, 255, 255, 0) 230px),
    linear-gradient(180deg, #10080d 0%, #170d14 54%, #10080d 100%);
}

:root[data-palette="violet"] {
  --bg: #090813;
  --ink: #f7f3ff;
  --muted: #aaa1c2;
  --line: #312850;
  --panel: rgba(13, 11, 28, .94);
  --accent: #b993ff;
  --accent-rgb: 185, 147, 255;
  --accent-2: #62d6ff;
  --accent-soft: #d7c4ff;
  --accent-pale: #f0e9ff;
  --button: #6b4bb2;
  --soft: #18132a;
  --field: #0d0a1b;
  --glow: rgba(0, 0, 0, .18);
  --body-bg:
    linear-gradient(180deg, rgba(185, 147, 255, .04), rgba(255, 255, 255, 0) 230px),
    linear-gradient(180deg, #090813 0%, #100d1f 54%, #090813 100%);
}

:root[data-palette="amber"] {
  --bg: #0d0c09;
  --ink: #fff8ea;
  --muted: #b7aa91;
  --line: #3d3322;
  --panel: rgba(18, 15, 10, .94);
  --accent: #f0b85f;
  --accent-rgb: 240, 184, 95;
  --accent-2: #79d5c7;
  --accent-soft: #ffd89a;
  --accent-pale: #fff0cf;
  --button: #8f6730;
  --soft: #1d180f;
  --field: #120f09;
  --glow: rgba(0, 0, 0, .18);
  --body-bg:
    linear-gradient(180deg, rgba(240, 184, 95, .04), rgba(255, 255, 255, 0) 230px),
    linear-gradient(180deg, #0d0c09 0%, #161209 54%, #0d0c09 100%);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  background: var(--body-bg);
  background-size: auto;
  color: var(--ink);
  font-family: "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, "Microsoft YaHei", sans-serif;
}

.shell {
  width: min(1440px, calc(100vw - 32px));
  margin: 0 auto;
  padding: 24px 0;
}

.workspace {
  display: grid;
  grid-template-columns: minmax(360px, 520px) 1fr;
  gap: 18px;
  align-items: start;
}

.panel,
.results {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 18px;
  box-shadow: 0 18px 44px rgba(0, 0, 0, .28);
  backdrop-filter: none;
}

.panel.dragOver {
  border-color: rgba(var(--accent-rgb), .86);
  box-shadow: 0 0 0 2px rgba(var(--accent-rgb), .16), 0 18px 44px rgba(0, 0, 0, .28);
}

.topbar,
.topActions,
.pageHeader,
.resultHead,
.actions,
.meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

h1,
h2,
p {
  margin: 0;
}

h1 {
  font-size: 28px;
  line-height: 1.1;
  color: #f6fbff;
  text-shadow: none;
}

h2 {
  font-size: 18px;
}

.topbar p {
  margin-top: 5px;
  color: var(--muted);
}

.notice {
  margin-top: 16px;
  padding: 11px 12px;
  border: 1px solid rgba(var(--accent-rgb), .24);
  border-left: 3px solid var(--accent);
  border-radius: 6px;
  background: rgba(var(--accent-rgb), .08);
  color: var(--accent-pale);
  font-size: 13px;
  line-height: 1.45;
}

.ocTemplatePanel {
  width: min(760px, 100%);
}

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

.promptSafetyStatus {
  margin-top: 8px;
  padding: 9px 10px;
  border: 1px solid rgba(255, 106, 159, .35);
  border-radius: 6px;
  background: rgba(255, 106, 159, .09);
  color: #ffb4ca;
  font-size: 13px;
  line-height: 1.45;
}

.safetyHint {
  margin-top: 4px;
  color: #ffd0dd;
}

.safetyHitList {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}

.safetyHit {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 3px 8px;
  border: 1px solid rgba(255, 106, 159, .42);
  border-radius: 999px;
  background: rgba(255, 106, 159, .14);
  color: #ffe4ec;
  font-size: 12px;
  font-weight: 700;
}

.promptSafetyActions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 8px;
}

.promptSafetyActions .quietButton {
  min-height: 30px;
  padding: 5px 9px;
  border-color: rgba(255, 106, 159, .42);
  background: rgba(255, 106, 159, .12);
  color: #ffe4ec;
  font-size: 12px;
}

.promptToolBar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}

.promptToolBar .quietButton {
  min-height: 32px;
  padding: 6px 10px;
  font-size: 13px;
}

.negativePromptField {
  margin-top: 8px;
}

#negativePrompt {
  min-height: 78px;
}

.keywordBox {
  margin-top: 16px;
  padding: 12px;
  border: 1px solid rgba(var(--accent-rgb), .2);
  border-radius: 8px;
  background: rgba(var(--accent-rgb), .045);
}

.sharedResourceBox {
  margin-top: 16px;
  padding: 12px;
  border: 1px solid rgba(var(--accent-rgb), .2);
  border-radius: 8px;
  background: rgba(var(--accent-rgb), .045);
}

.referenceAssetStrip {
  margin-top: 10px;
  padding: 10px;
  border: 1px solid rgba(var(--accent-rgb), .2);
  border-radius: 8px;
  background: rgba(var(--accent-rgb), .045);
}

.referenceAssetStripHead {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.referenceAssetStripHead h2 {
  font-size: 14px;
}

.sharedReferenceAssets,
.sharedKeywordCategories {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(92px, 1fr));
  gap: 7px;
  margin-top: 9px;
}

.resourceCategoryGroup {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.resourceCategoryTitle {
  color: var(--accent-soft);
  font-size: 12px;
  font-weight: 750;
}

.resourceCategoryButton {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  max-width: 100%;
  width: 100%;
  min-height: 30px;
  padding: 5px 8px;
  margin-top: 0;
  border: 1px solid rgba(var(--accent-rgb), .24);
  border-radius: 6px;
  background: rgba(9, 15, 27, .82);
  color: #f8f3e8;
  box-shadow: none;
}

.resourceCategoryButtonTitle {
  max-width: 150px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 13px;
  font-weight: 750;
  color: #f8f3e8;
}

.resourceCategoryButtonCount {
  min-width: 22px;
  padding: 1px 7px;
  border-radius: 999px;
  background: rgba(var(--accent-rgb), .12);
  color: var(--accent-soft);
  font-size: 11px;
  font-weight: 750;
  text-align: center;
}

.resourceCategoryBody,
.sharedReferenceAssetBody {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  max-height: 126px;
  overflow: auto;
  padding-right: 2px;
}

.sharedReferenceAsset {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 4px 8px 4px 4px;
  border-radius: 6px;
  border: 1px solid rgba(var(--accent-rgb), .24);
  background: rgba(9, 15, 27, .82);
  color: var(--accent-pale);
  box-shadow: none;
}

.categoryModalPanel {
  width: min(820px, 100%);
}

.categoryModalContent {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  max-height: min(62vh, 680px);
  overflow: auto;
}

.taskReferencePanel {
  width: min(760px, 100%);
}

.taskReferenceContent {
  min-height: 120px;
  color: var(--muted);
}

.taskReferenceGrid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(132px, 1fr));
  gap: 10px;
}

.taskReferenceCard {
  overflow: hidden;
  border: 1px solid rgba(var(--accent-rgb), .22);
  border-radius: 8px;
  background: rgba(7, 14, 26, .72);
}

.taskReferenceCard img,
.taskReferenceFailed {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
  background: rgba(var(--accent-rgb), .08);
}

.taskReferenceFailed {
  display: grid;
  place-items: center;
  color: var(--muted);
  font-size: 13px;
}

.taskReferenceMeta {
  display: grid;
  gap: 3px;
  padding: 8px;
  min-width: 0;
}

.taskReferenceMeta strong,
.taskReferenceMeta span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

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

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

.sharedReferenceAsset img {
  width: 30px;
  height: 30px;
  border-radius: 4px;
  object-fit: cover;
  background: #0e0d0b;
}

.sharedReferenceAsset span {
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 13px;
}

.keywordHead {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.keywordHead h2 {
  font-size: 15px;
}

.keywordAdd {
  display: flex;
  gap: 8px;
  min-width: 0;
}

.keywordAdd input {
  width: 170px;
  min-height: 36px;
}

.keywordAdd input + input {
  width: 230px;
}

.keywordAdd button {
  min-height: 36px;
  padding: 7px 11px;
}

.keywordContentInput {
  width: 100%;
  min-height: 78px;
  margin-top: 10px;
}

.keywordList {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.keywordBox .keywordGroup:last-of-type .keywordList {
  max-height: 124px;
  overflow: auto;
  padding-right: 2px;
}

.sharedResourceBox .keywordGroup:last-of-type .keywordList {
  max-height: 124px;
  overflow: auto;
  padding-right: 2px;
}

.keywordGroup {
  margin-top: 12px;
}

.keywordLabel {
  margin-bottom: 8px;
  color: var(--muted);
  font-size: 12px;
}

.keywordItem {
  display: inline-flex;
  align-items: stretch;
  max-width: 100%;
}

.keywordChip,
.keywordRemove {
  min-height: 32px;
  padding: 6px 10px;
  border-color: rgba(var(--accent-rgb), .28);
  box-shadow: none;
}

.keywordChip {
  max-width: 260px;
  overflow: hidden;
  text-overflow: ellipsis;
  background: var(--soft);
  color: var(--accent-pale);
  border-radius: 6px 0 0 6px;
  white-space: nowrap;
}

.keywordRemove {
  width: 32px;
  padding: 0;
  background: rgba(255, 79, 216, .12);
  color: #ff9ceb;
  border-left: 0;
  border-radius: 0 6px 6px 0;
}

.emptyKeywords {
  color: var(--muted);
  font-size: 13px;
}

.referenceTools {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-top: 10px;
}

.referenceList {
  display: flex;
  flex: 1;
  flex-wrap: wrap;
  gap: 8px;
  min-width: 0;
}

.referenceItem {
  display: inline-flex;
  align-items: stretch;
  max-width: 100%;
  cursor: grab;
}

.referenceField input[type="file"] {
  min-height: 44px;
}

.referenceItem.dragging {
  opacity: .58;
}

.referenceItem.dragOver {
  outline: 2px solid rgba(var(--accent-rgb), .72);
  outline-offset: 2px;
}

.referenceItem.locked .referenceHandle,
.referenceItem.locked .referenceOrder {
  background: rgba(var(--accent-rgb), .22);
  color: #fff;
}

.referenceHandle {
  appearance: none;
  width: 28px;
  min-height: 32px;
  padding: 6px 0;
  border: 1px solid rgba(var(--accent-rgb), .28);
  border-right: 0;
  border-radius: 6px 0 0 6px;
  background: rgba(var(--accent-rgb), .08);
  color: var(--accent-soft);
  font-size: 13px;
  font-family: inherit;
  text-align: center;
  user-select: none;
  cursor: pointer;
}

.referenceOrder {
  min-height: 32px;
  padding: 6px 9px;
  border: 1px solid rgba(var(--accent-rgb), .36);
  border-right: 0;
  border-radius: 0;
  background: rgba(var(--accent-rgb), .13);
  color: var(--accent);
  font-size: 13px;
  font-weight: 750;
  white-space: nowrap;
}

.referenceName {
  max-width: 180px;
  min-height: 32px;
  padding: 6px 10px;
  border: 1px solid rgba(var(--accent-rgb), .28);
  border-left: 0;
  border-radius: 0;
  background: var(--soft);
  color: var(--accent-pale);
  font-size: 13px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.referencePreview {
  width: 42px;
  height: 32px;
  border: 1px solid rgba(var(--accent-rgb), .28);
  border-left: 0;
  background: #0e0d0b;
  object-fit: cover;
}

.referenceAssetPanel {
  max-width: 900px;
}

.referencePreviewPanel {
  width: min(980px, 100%);
}

.referencePreviewLarge {
  display: block;
  width: 100%;
  max-height: min(76vh, 820px);
  border: 1px solid rgba(var(--accent-rgb), .2);
  border-radius: 8px;
  object-fit: contain;
  background: #050914;
}

.reverseResultPanel {
  width: min(820px, 100%);
}

.reverseResultText {
  width: 100%;
  min-height: 220px;
  resize: vertical;
}

.reverseResultActions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 12px;
}

.reverseResultActions button {
  min-height: 34px;
  padding: 7px 10px;
}

.feedbackPanel {
  width: min(760px, 100%);
}

.feedbackList {
  display: grid;
  gap: 8px;
  max-height: 260px;
  margin-top: 14px;
  overflow: auto;
  padding-right: 2px;
}

.feedbackItem {
  display: grid;
  gap: 6px;
  padding: 10px;
  border: 1px solid rgba(var(--accent-rgb), .2);
  border-radius: 8px;
  background: rgba(9, 15, 27, .72);
}

.feedbackMeta {
  color: var(--muted);
  font-size: 12px;
}

.feedbackMessage {
  color: var(--ink);
  font-size: 13px;
  line-height: 1.45;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.resourceCategoryPanel {
  max-width: 900px;
}

.referenceAssetPanel.dragOver {
  border-color: rgba(var(--accent-rgb), .86);
  box-shadow: 0 0 0 2px rgba(var(--accent-rgb), .2), 0 22px 60px rgba(0, 0, 0, .34);
}

.referenceAssetList {
  display: grid;
  gap: 8px;
  margin-top: 14px;
}

.referenceAssetRow {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px;
  border: 1px solid rgba(var(--accent-rgb), .2);
  border-radius: 8px;
  background: rgba(var(--accent-rgb), .05);
}

.referenceAssetPreview {
  width: 48px;
  height: 48px;
  border-radius: 6px;
  object-fit: cover;
  background: #0e0d0b;
}

#referenceAssetPreview {
  display: block;
  width: 100%;
  max-height: 180px;
  margin-top: 10px;
  border: 1px solid rgba(var(--accent-rgb), .2);
  border-radius: 8px;
  object-fit: contain;
  background: #0e0d0b;
}

.referenceAssetMeta {
  display: grid;
  gap: 3px;
  min-width: 0;
  flex: 1;
}

.referenceAssetTitle {
  font-size: 13px;
  color: var(--accent-pale);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.referenceAssetInfo {
  font-size: 12px;
  color: var(--muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.referenceAssetRemove {
  width: 32px;
  min-height: 32px;
  padding: 0;
  border-left: 0;
  box-shadow: none;
  border-radius: 6px;
  background: rgba(255, 79, 216, .12);
  color: #ff9ceb;
}

.categoryManageList {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.categoryManageItem {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  border: 1px solid rgba(var(--accent-rgb), .28);
  border-radius: 6px;
  background: rgba(var(--accent-rgb), .08);
  overflow: hidden;
}

.categoryManageItem span {
  padding: 6px 10px;
  color: var(--accent-pale);
  font-size: 13px;
}

.categoryManageItem button {
  width: 32px;
  min-height: 32px;
  padding: 0;
  border: 0;
  border-left: 1px solid rgba(var(--accent-rgb), .24);
  border-radius: 0;
  background: rgba(255, 79, 216, .12);
  color: #ff9ceb;
  box-shadow: none;
}

.referenceMove,
.referenceReverse,
.referenceRemove {
  width: 32px;
  min-height: 32px;
  padding: 0;
  border-left: 0;
  box-shadow: none;
}

.referenceMove {
  border-radius: 0;
  background: rgba(var(--accent-rgb), .08);
  color: var(--accent-soft);
}

.referenceMove:disabled {
  cursor: default;
  opacity: .35;
}

.referenceReverse {
  width: 44px;
  border-radius: 0;
  background: rgba(var(--accent-rgb), .08);
  color: var(--accent-soft);
  font-size: 12px;
}

.referenceRemove {
  border-radius: 0 6px 6px 0;
  background: rgba(255, 79, 216, .12);
  color: #ff9ceb;
}

.quietButton {
  min-height: 32px;
  padding: 6px 10px;
  background: var(--soft);
  color: var(--accent-soft);
  border-color: rgba(var(--accent-rgb), .32);
  box-shadow: none;
}

.quietButton:disabled {
  cursor: default;
  opacity: .45;
}

.emptyReferences {
  color: var(--muted);
  font-size: 13px;
  line-height: 32px;
}

.topActions {
  align-items: center;
  flex-direction: row;
  justify-content: flex-start;
}

.keyActions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
}

.publicBalance {
  min-height: 32px;
  padding: 6px 10px;
  border: 1px solid rgba(var(--accent-rgb), .26);
  border-radius: 6px;
  background: rgba(var(--accent-rgb), .08);
  color: var(--accent-soft);
  font-size: 13px;
  font-weight: 700;
  text-align: right;
  white-space: nowrap;
}

.ghostButton {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 9px 12px;
  border: 1px solid rgba(var(--accent-rgb), .34);
  border-radius: 6px;
  color: var(--accent-soft);
  background: var(--soft);
  text-decoration: none;
  font-weight: 650;
  white-space: nowrap;
}

.iconButton {
  width: 36px;
  min-height: 36px;
  padding: 0;
  border-radius: 6px;
  background: var(--soft);
  color: var(--accent-soft);
  border-color: rgba(var(--accent-rgb), .32);
  box-shadow: none;
  font-size: 20px;
  line-height: 1;
}

.modalBackdrop {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 16px;
  background: rgba(3, 6, 12, .72);
  backdrop-filter: blur(6px);
  z-index: 40;
}

.modalBackdrop[hidden] {
  display: none;
}

.modalPanel {
  width: min(560px, 100%);
  max-height: min(84vh, 820px);
  overflow: auto;
}

.modalHeader {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.modalHeader p {
  margin-top: 6px;
  color: var(--muted);
  font-size: 13px;
}

.categoryModalPanel .modalHeader h2 {
  font-size: 22px;
  line-height: 1.15;
}

.modalActionGroup {
  display: flex;
  align-items: center;
  gap: 8px;
}

.resultActions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.paletteSelect {
  min-height: 32px;
  padding: 6px 10px;
  background: var(--soft);
  color: var(--accent-soft);
  border: 1px solid rgba(var(--accent-rgb), .32);
  border-radius: 6px;
}

.keysPage {
  display: grid;
  gap: 18px;
}

.narrowPage {
  max-width: 640px;
}

.pageHeader {
  padding: 6px 0 2px;
}

.pageHeader p {
  margin-top: 6px;
  color: var(--muted);
}

.contactNotice {
  padding: 12px 14px;
  border: 1px solid rgba(var(--accent-rgb), .28);
  border-radius: 8px;
  background: rgba(var(--accent-rgb), .08);
  color: var(--accent-pale);
  font-weight: 700;
}

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

.keyContact .quietButton {
  flex: 0 0 auto;
}

.keyPanels {
  display: grid;
  grid-template-columns: minmax(320px, 420px) minmax(360px, 560px);
  gap: 18px;
  align-items: start;
}

.usagePanel {
  overflow: hidden;
}

.adminTokenPanel {
  max-width: 560px;
}

.sharedKeywordPanel {
  max-width: 900px;
}

.billingPanel {
  max-width: 900px;
}

.balancePanel {
  max-width: 900px;
}

.billingGrid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

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

.balanceGrid[hidden] {
  display: none;
}

.balanceGrid div {
  padding: 12px;
  border: 1px solid rgba(var(--accent-rgb), .2);
  border-radius: 8px;
  background: rgba(var(--accent-rgb), .06);
}

.balanceGrid dt,
.balanceGrid dd {
  margin: 0;
}

.balanceGrid dt {
  color: var(--muted);
  font-size: 12px;
}

.balanceGrid dd {
  margin-top: 4px;
  color: var(--ink);
  font-size: 18px;
  font-weight: 750;
  overflow-wrap: anywhere;
}

.adminKeywordList {
  margin-top: 14px;
}

.field {
  display: grid;
  gap: 7px;
}

.field span,
.check span {
  color: var(--muted);
  font-size: 13px;
}

.dropHint {
  margin-left: 8px;
  color: var(--accent-soft);
  font-size: 12px;
  font-weight: 500;
}

.full {
  margin-top: 16px;
}

input,
select,
textarea,
button {
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 9px 10px;
  font: inherit;
  color: inherit;
  background: var(--field);
}

input:focus,
select:focus,
textarea:focus {
  outline: 2px solid rgba(var(--accent-rgb), .34);
  border-color: var(--accent);
}

textarea {
  resize: vertical;
  min-height: 150px;
}

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

.sizePickerButton {
  display: grid;
  gap: 3px;
  width: 100%;
  min-height: 40px;
  padding: 8px 10px;
  text-align: left;
  background: var(--field);
  color: var(--ink);
  border-color: var(--line);
  box-shadow: none;
}

.sizePickerButton > span {
  color: var(--accent-pale);
  font-size: 14px;
  font-weight: 750;
}

.sizePickerButton > small {
  color: var(--muted);
  font-size: 12px;
}

.sizePickerPanel {
  width: min(760px, 100%);
}

.sizePickerSections {
  display: grid;
  gap: 12px;
}

.sizePickerSection {
  padding: 12px;
  border: 1px solid rgba(var(--accent-rgb), .2);
  border-radius: 8px;
  background: rgba(var(--accent-rgb), .045);
}

.sizePickerSection h3 {
  margin: 0 0 10px;
  color: var(--accent-pale);
  font-size: 14px;
}

.ratioPresetGrid,
.resolutionPresetGrid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.ratioPreset,
.sizePreset {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 7px 9px;
  border-color: rgba(var(--accent-rgb), .24);
  background: rgba(9, 15, 27, .78);
  color: var(--accent-pale);
  box-shadow: none;
}

.ratioPreset {
  gap: 8px;
}

.ratioPreset span {
  display: block;
  width: 20px;
  border: 1px solid rgba(185, 243, 255, .7);
  border-radius: 3px;
  background: rgba(var(--accent-rgb), .08);
}

.ratioPreset[data-ratio="1:1"] span {
  aspect-ratio: 1 / 1;
}

.ratioPreset[data-ratio="3:2"] span {
  aspect-ratio: 3 / 2;
}

.ratioPreset[data-ratio="2:3"] span {
  aspect-ratio: 2 / 3;
}

.ratioPreset[data-ratio="16:9"] span {
  aspect-ratio: 16 / 9;
}

.ratioPreset[data-ratio="9:16"] span {
  aspect-ratio: 9 / 16;
}

.ratioPreset[data-ratio="4:3"] span {
  aspect-ratio: 4 / 3;
}

.ratioPreset[data-ratio="3:4"] span {
  aspect-ratio: 3 / 4;
}

.ratioPreset[data-ratio="21:9"] span {
  aspect-ratio: 21 / 9;
}

.ratioPreset.active,
.sizePreset.active {
  border-color: rgba(var(--accent-rgb), .76);
  background: rgba(var(--accent-rgb), .18);
  color: #ffffff;
  box-shadow: 0 0 0 1px rgba(var(--accent-rgb), .16) inset;
}

.customSizeGrid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
  gap: 8px;
  align-items: end;
}

.customSizeGrid label {
  display: grid;
  gap: 6px;
}

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

.customSizeGrid input {
  width: 100%;
}

.sizePickerHint {
  margin-top: 8px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

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

.adminActions {
  margin-top: 14px;
}

.miniStatus {
  min-height: 20px;
  color: var(--muted);
  font-size: 13px;
}

.createdKey {
  width: 100%;
  min-height: 66px;
  margin-top: 12px;
  font-family: Consolas, "Cascadia Mono", monospace;
}

.check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.check input {
  min-height: auto;
}

button {
  cursor: pointer;
  background: var(--button);
  color: #ffffff;
  border-color: rgba(var(--accent-rgb), .52);
  font-weight: 650;
  box-shadow: 0 1px 0 rgba(255, 255, 255, .1) inset;
}

button:disabled {
  cursor: wait;
  opacity: .65;
}

#refreshGallery {
  background: var(--soft);
  color: var(--accent-soft);
  border-color: rgba(var(--accent-rgb), .32);
}

#refreshMyUsage,
#refreshUsage {
  min-height: 36px;
  padding: 7px 11px;
  background: var(--soft);
  color: var(--accent-soft);
  border-color: rgba(var(--accent-rgb), .32);
}

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

.myUsage[hidden] {
  display: none;
}

.myUsage div {
  padding: 12px;
  border: 1px solid rgba(var(--accent-rgb), .2);
  border-radius: 8px;
  background: rgba(var(--accent-rgb), .06);
}

.myUsage dt,
.myUsage dd {
  margin: 0;
}

.myUsage dt {
  color: var(--muted);
  font-size: 12px;
}

.myUsage dd {
  margin-top: 4px;
  color: var(--ink);
  font-size: 20px;
  font-weight: 750;
}

.status {
  min-height: 22px;
  margin: 14px 0;
  color: var(--accent-2);
}

.taskPanel {
  margin-bottom: 16px;
  padding: 12px;
  border: 1px solid rgba(var(--accent-rgb), .2);
  border-radius: 8px;
  background: rgba(var(--accent-rgb), .045);
}

.taskPanelHead,
.taskTop,
.taskActions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.taskPanelHead h3 {
  margin: 0;
  font-size: 15px;
}

.taskPanelHead p {
  margin-top: 5px;
  color: var(--muted);
  font-size: 12px;
}

.taskSummary {
  color: var(--accent-soft);
  font-size: 13px;
  white-space: nowrap;
}

.taskList {
  display: grid;
  gap: 10px;
  margin-top: 12px;
  max-height: 340px;
  overflow: auto;
  padding-right: 2px;
}

.taskItem {
  display: grid;
  gap: 8px;
  padding: 11px;
  border: 1px solid rgba(32, 50, 70, .84);
  border-radius: 8px;
  background: rgba(9, 15, 27, .72);
}

.taskBadge {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 4px 8px;
  border: 1px solid rgba(var(--accent-rgb), .32);
  border-radius: 999px;
  color: var(--accent);
  background: rgba(var(--accent-rgb), .1);
  font-size: 12px;
  font-weight: 750;
}

.taskItem[data-status="running"] .taskBadge,
.taskItem[data-status="queued"] .taskBadge {
  color: var(--accent-pale);
  border-color: rgba(var(--accent-rgb), .46);
  background: rgba(var(--accent-rgb), .16);
}

.taskItem[data-status="succeeded"] .taskBadge {
  color: #8fffc1;
  border-color: rgba(143, 255, 193, .36);
  background: rgba(143, 255, 193, .1);
}

.taskItem[data-status="failed"] .taskBadge {
  color: #ff8fb5;
  border-color: rgba(255, 106, 159, .4);
  background: rgba(255, 106, 159, .1);
}

.taskTime,
.taskMeta,
.taskError,
.emptyTasks {
  color: var(--muted);
  font-size: 12px;
}

.taskPrompt {
  color: var(--accent-pale);
  font-size: 13px;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.taskMeta {
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.taskError {
  color: #ff8fb5;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.taskActions {
  justify-content: flex-start;
}

.taskActions .quietButton {
  min-height: 30px;
  padding: 5px 9px;
  font-size: 12px;
}

.taskActions .quietButton:disabled {
  cursor: default;
  opacity: .45;
}

.usageTableWrap {
  overflow-x: auto;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.usageTable {
  width: 100%;
  min-width: 620px;
  border-collapse: collapse;
}

.usageTable th,
.usageTable td {
  padding: 12px 14px;
  border-bottom: 1px solid rgba(32, 50, 70, .78);
  text-align: left;
  font-size: 14px;
}

.usageTable th {
  color: var(--accent-pale);
  background: rgba(var(--accent-rgb), .08);
  font-weight: 700;
}

.usageTable td {
  color: var(--ink);
}

.usageTable tbody tr:last-child td {
  border-bottom: 0;
}

.emptyUsage {
  color: var(--muted) !important;
  text-align: center !important;
}

.imageGrid {
  display: block;
}

.emptyResult {
  display: grid;
  min-height: 220px;
  place-items: center;
  border: 1px dashed rgba(var(--accent-rgb), .25);
  border-radius: 8px;
  color: var(--muted);
  background: rgba(9, 15, 27, .5);
  font-size: 13px;
}

.imageCard {
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  background: rgba(9, 15, 27, .9);
}

.imageCard img {
  display: block;
  width: 100%;
  max-height: 72vh;
  object-fit: contain;
  background: #0e0d0b;
}

.meta {
  padding: 10px 11px 0;
  font-size: 13px;
}

.mode {
  color: var(--accent);
  font-weight: 700;
}

.open {
  color: #ff8be7;
  text-decoration: none;
}

.imageDetails {
  display: grid;
  gap: 6px;
  margin: 10px 11px 0;
  padding: 10px 0 0;
  border-top: 1px solid rgba(32, 50, 70, .78);
}

.imageDetails div {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  gap: 8px;
  align-items: baseline;
}

.imageDetails dt,
.imageDetails dd {
  margin: 0;
  font-size: 12px;
  line-height: 1.35;
}

.imageDetails dt {
  color: var(--muted);
}

.imageDetails dd {
  color: var(--accent-pale);
  overflow-wrap: anywhere;
}

.prompt {
  padding: 8px 11px 12px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

body:has(#generateForm) {
  overflow: hidden;
}

body:has(#generateForm) .shell {
  width: min(1500px, calc(100vw - 24px));
  height: 100vh;
  padding: 12px 0;
}

body:has(#generateForm) .workspace {
  height: calc(100vh - 24px);
  grid-template-columns: minmax(380px, 520px) minmax(520px, 1fr);
  align-items: stretch;
}

body:has(#generateForm) .panel,
body:has(#generateForm) .results {
  min-height: 0;
  overflow: auto;
  padding: 14px;
}

body:has(#generateForm) .panel {
  display: flex;
  flex-direction: column;
}

body:has(#generateForm) .results {
  display: grid;
  grid-template-rows: auto auto minmax(120px, .48fr) minmax(220px, .52fr);
  gap: 10px;
}

body:has(#generateForm) .topbar {
  align-items: flex-start;
}

body:has(#generateForm) h1 {
  font-size: 26px;
}

body:has(#generateForm) textarea {
  min-height: 104px;
}

body:has(#generateForm) #prompt {
  min-height: 150px;
}

body:has(#generateForm) #negativePrompt {
  min-height: 68px;
}

body:has(#generateForm) .full,
body:has(#generateForm) .grid,
body:has(#generateForm) .keywordGroup {
  margin-top: 10px;
}

body:has(#generateForm) .referenceAssetStrip,
body:has(#generateForm) .taskPanel {
  padding: 8px;
}

body:has(#generateForm) .sharedResourceBox {
  padding: 10px;
}

body:has(#generateForm) .sharedReferenceAssets,
body:has(#generateForm) .sharedKeywordCategories {
  gap: 6px;
  grid-template-columns: repeat(auto-fit, minmax(82px, 1fr));
  margin-top: 8px;
}

body:has(#generateForm) .resourceCategoryButton {
  min-height: 28px;
  padding: 4px 7px;
}

body:has(#generateForm) .resourceCategoryButtonTitle {
  max-width: 96px;
  font-size: 12px;
}

body:has(#generateForm) .keywordContentInput {
  min-height: 62px;
}

body:has(#generateForm) .resourceCategoryBody,
body:has(#generateForm) .sharedReferenceAssetBody,
body:has(#generateForm) .keywordBox .keywordGroup:last-of-type .keywordList,
body:has(#generateForm) .sharedResourceBox .keywordGroup:last-of-type .keywordList {
  max-height: 82px;
}

body:has(#generateForm) .grid {
  gap: 8px;
}

body:has(#generateForm) .sizePickerSections {
  gap: 10px;
}

body:has(#generateForm) .sizePickerSection {
  padding: 10px;
}

body:has(#generateForm) .ocTemplateGrid {
  gap: 8px;
  margin-top: 10px;
}

body:has(#generateForm) input,
body:has(#generateForm) select,
body:has(#generateForm) button {
  min-height: 34px;
  padding: 7px 9px;
}

body:has(#generateForm) .actions {
  margin-top: 10px;
}

body:has(#generateForm) .status {
  min-height: 20px;
  margin: 0;
}

body:has(#generateForm) .taskPanel {
  min-height: 0;
  margin-bottom: 0;
  overflow: hidden;
}

body:has(#generateForm) .taskList {
  max-height: none;
  height: calc(100% - 56px);
}

body:has(#generateForm) .taskItem {
  gap: 6px;
  padding: 9px;
}

body:has(#generateForm) .taskPrompt {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

body:has(#generateForm) .imageGrid {
  min-height: 0;
  overflow: auto;
}

body:has(#generateForm) .imageCard img {
  max-height: 34vh;
}

body:has(#generateForm) .imageDetails {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.modalOpen {
  overflow: hidden;
}

@media (max-width: 900px) {
  .workspace,
  .keyPanels {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .shell {
    width: min(100vw - 20px, 1440px);
    padding: 10px 0;
  }

  .topbar,
  .pageHeader {
    align-items: stretch;
    flex-direction: column;
  }

  .topActions {
    align-items: stretch;
    flex-direction: column;
  }

  .keyActions {
    align-items: stretch;
    flex-direction: column;
  }

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

  .resourceCategoryButtonTitle {
    max-width: 42vw;
  }

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

  .customSizeGrid button {
    grid-column: 1 / -1;
  }

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

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

  .keywordHead,
  .keywordAdd {
    align-items: stretch;
    flex-direction: column;
  }

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

  .keywordAdd input {
    width: 100%;
  }

  .referenceTools {
    align-items: stretch;
    flex-direction: column;
  }

  .taskPanelHead,
  .taskTop,
  .taskActions {
    align-items: stretch;
    flex-direction: column;
  }

  .taskSummary {
    white-space: normal;
  }

  .modalPanel {
    max-height: 90vh;
  }

  .modalActionGroup {
    align-items: stretch;
    flex-direction: column;
  }

  .resultActions {
    align-items: stretch;
    flex-direction: column;
  }

  .reverseResultActions {
    align-items: stretch;
    flex-direction: column;
  }

  body:has(#generateForm) {
    overflow: auto;
  }

  body.modalOpen:has(#generateForm) {
    overflow: hidden;
  }

  body:has(#generateForm) .shell,
  body:has(#generateForm) .workspace {
    height: auto;
  }
}

