:root {
  color-scheme: dark;
  --bg: #11131a;
  --panel: rgba(255,255,255,.075);
  --panel-strong: rgba(255,255,255,.12);
  --text: #f5f7fb;
  --muted: #aab1c1;
  --line: rgba(255,255,255,.16);
  --accent: #8ed0ff;
  --accent2: #ffb6d5;
  --danger: #ff7777;
}

* { box-sizing: border-box; }
html, body { margin: 0; min-height: 100%; }
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  background:
    radial-gradient(circle at 20% 0%, rgba(142,208,255,.22), transparent 34%),
    radial-gradient(circle at 80% 10%, rgba(255,182,213,.18), transparent 30%),
    var(--bg);
  color: var(--text);
}

a { color: var(--accent); }

.wrap {
  width: min(760px, 100%);
  margin: 0 auto;
  padding: 24px 16px 36px;
}

.hero { padding: 24px 4px 16px; text-align: center; }
.badge {
  display: inline-flex;
  padding: 7px 11px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--accent);
  background: rgba(142,208,255,.08);
  font-size: 12px;
}
.hero h1 { margin: 14px 0 8px; font-size: clamp(30px, 8vw, 48px); letter-spacing: -0.04em; }
.hero p { margin: 0 auto; color: var(--muted); line-height: 1.55; max-width: 560px; }

.card {
  border: 1px solid var(--line);
  border-radius: 26px;
  background: var(--panel);
  backdrop-filter: blur(18px);
  box-shadow: 0 18px 60px rgba(0,0,0,.22);
  padding: 16px;
  margin-top: 16px;
}

.drop {
  display: grid;
  place-items: center;
  gap: 8px;
  min-height: 210px;
  border: 1.5px dashed rgba(255,255,255,.28);
  border-radius: 22px;
  background: rgba(255,255,255,.055);
  cursor: pointer;
  text-align: center;
  padding: 22px;
}
.drop input { display: none; }
.drop-icon { font-size: 42px; }
.drop strong { font-size: 20px; }
.drop span, .privacy { color: var(--muted); font-size: 13px; }

.preview { margin-top: 14px; border-radius: 22px; overflow: hidden; border: 1px solid var(--line); }
.preview img { width: 100%; max-height: 460px; object-fit: contain; display: block; background: #05060a; }

.primary {
  width: 100%;
  border: 0;
  border-radius: 18px;
  margin-top: 14px;
  padding: 16px 18px;
  font-size: 18px;
  font-weight: 800;
  color: #07111a;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  cursor: pointer;
}
.primary:disabled { opacity: .45; cursor: not-allowed; }
.privacy { margin: 12px 4px 0; text-align: center; line-height: 1.5; }

.result-head { display: grid; grid-template-columns: 150px 1fr; gap: 16px; align-items: center; }
.result-head img {
  width: 150px;
  height: 150px;
  border-radius: 28px;
  background: rgba(255,255,255,.1);
  border: 1px solid var(--line);
  object-fit: cover;
}
.small-label { color: var(--muted); font-size: 13px; }
.result h2 { margin: 4px 0 4px; font-size: 34px; letter-spacing: -0.04em; }
.score { display: inline-flex; align-items: baseline; gap: 2px; font-size: 28px; font-weight: 900; color: var(--accent); }
.score span { font-size: 42px; }
.reason { line-height: 1.6; color: #dce4f3; background: rgba(255,255,255,.07); padding: 14px; border-radius: 18px; }
.credit, .row-credit {
  display: block;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.45;
  font-style: normal;
  margin-top: 6px;
}
.result h3 { margin: 18px 0 10px; }
.rank-list { display: grid; gap: 10px; }
.rank-item {
  display: grid;
  grid-template-columns: 62px 1fr auto;
  gap: 12px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255,255,255,.06);
  padding: 10px;
}
.rank-item img {
  width: 62px;
  height: 62px;
  border-radius: 16px;
  object-fit: cover;
  background: rgba(255,255,255,.1);
}
.rank-item strong { display: block; }
.rank-item span { color: var(--muted); font-size: 13px; line-height: 1.4; }
.rank-score { font-weight: 900; color: var(--accent2); white-space: nowrap; }

.details { margin-top: 14px; color: var(--muted); }
.details pre { white-space: pre-wrap; background: rgba(0,0,0,.24); padding: 12px; border-radius: 14px; color: #d6e0ef; }
.notice { margin: 18px 4px 0; color: var(--muted); text-align: center; font-size: 12px; line-height: 1.5; }
.hidden { display: none; }

.axis-pool p { color: var(--muted); line-height: 1.55; margin: 8px 0 0; }
.pool-head { display: flex; justify-content: space-between; align-items: center; gap: 10px; }
.pool-head h3 { margin: 0; }
.pool-head span {
  color: var(--accent);
  border: 1px solid var(--line);
  background: rgba(142,208,255,.08);
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 13px;
  font-weight: 800;
}

@media (max-width: 480px) {
  .wrap { padding: 14px 12px 28px; }
  .card { border-radius: 22px; padding: 12px; }
  .result-head { grid-template-columns: 104px 1fr; }
  .result-head img { width: 104px; height: 104px; border-radius: 20px; }
  .result h2 { font-size: 26px; }
  .rank-item { grid-template-columns: 54px 1fr auto; gap: 9px; }
  .rank-item img { width: 54px; height: 54px; }
  .rank-item span { font-size: 12px; }
  .rank-score { font-size: 14px; }
}

.quality-text {
  color: var(--muted);
  font-size: 12px;
  margin-top: 2px;
}

.analysis-box {
  margin-top: 14px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: rgba(0,0,0,.18);
  padding: 14px;
}
.analysis-box h3 { margin: 0 0 8px; }
.muted-text { color: var(--muted); line-height: 1.5; margin: 0 0 10px; }
.pill-list { display: flex; flex-wrap: wrap; gap: 7px; margin: 8px 0 12px; }
.trait-pill {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 6px 9px;
  background: rgba(255,255,255,.07);
  color: #e6edf8;
  font-size: 12px;
  line-height: 1;
}
.factor-list { display: grid; gap: 8px; }
.factor-item {
  display: grid;
  grid-template-columns: minmax(120px, 1fr) 120px 42px;
  align-items: center;
  gap: 10px;
  padding: 9px;
  border-radius: 14px;
  background: rgba(255,255,255,.055);
}
.factor-item strong { display: block; font-size: 13px; }
.factor-item span { display: block; color: var(--muted); font-size: 12px; margin-top: 2px; }
.factor-item em { color: var(--accent); font-style: normal; font-weight: 900; text-align: right; font-size: 13px; }
.factor-meter {
  height: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  overflow: hidden;
}
.factor-meter i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
}

@media (max-width: 480px) {
  .factor-item {
    grid-template-columns: 1fr 78px 34px;
    gap: 8px;
    padding: 8px;
  }
  .factor-item strong { font-size: 12px; }
  .factor-item span { font-size: 11px; }
}


.secondary {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 18px;
  margin-top: 14px;
  padding: 15px 18px;
  font-size: 16px;
  font-weight: 800;
  color: var(--text);
  background: rgba(255,255,255,.08);
  cursor: pointer;
}
.secondary:hover { background: rgba(255,255,255,.12); }
.secondary:disabled { opacity: .5; cursor: not-allowed; }
.result-actions { margin-top: 16px; }
.export-hint {
  margin: 8px 4px 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
  text-align: center;
}


.crop-stage {
  position: relative;
  user-select: none;
  touch-action: none;
  background: #05060a;
}
.crop-stage img { -webkit-user-drag: none; user-select: none; }
.crop-overlay {
  position: absolute;
  border: 2px solid var(--accent);
  background: rgba(142,208,255,.18);
  box-shadow: 0 0 0 9999px rgba(0,0,0,.42), 0 0 24px rgba(142,208,255,.32);
  border-radius: 14px;
  pointer-events: none;
}
.crop-tools {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255,255,255,.055);
  padding: 12px;
  margin-top: 12px;
}
.crop-tools strong { display: block; font-size: 14px; }
.crop-tools span { display: block; color: var(--muted); font-size: 12px; line-height: 1.4; margin-top: 3px; }
.crop-tools button {
  flex: 0 0 auto;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255,255,255,.08);
  color: var(--text);
  padding: 9px 11px;
  font-weight: 800;
}
.crop-tools.hidden { display: none; }
.comparison-box {
  margin-top: 14px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: rgba(255,255,255,.055);
  padding: 14px;
}
.comparison-box h3 { margin: 0 0 8px; }
.compare-list { display: grid; gap: 8px; margin-top: 10px; }
.compare-item {
  display: grid;
  grid-template-columns: minmax(96px, 150px) 1fr auto;
  gap: 10px;
  align-items: center;
  border-radius: 14px;
  background: rgba(0,0,0,.16);
  padding: 9px;
}
.compare-item strong { font-size: 13px; }
.compare-item span { color: var(--muted); font-size: 12px; line-height: 1.35; }
.compare-item em { color: var(--accent); font-style: normal; font-weight: 900; font-size: 13px; white-space: nowrap; }
@media (max-width: 480px) {
  .crop-tools { align-items: stretch; flex-direction: column; }
  .crop-tools button { width: 100%; }
  .compare-item { grid-template-columns: 1fr auto; }
  .compare-item span { grid-column: 1 / -1; }
}


.diagnostic-box {
  margin-top: 14px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: rgba(0,0,0,.14);
  padding: 14px;
}
.diagnostic-box h3 { margin: 0 0 8px; }
.diagnostic-list { display: grid; gap: 8px; }
.diagnostic-item {
  display: grid;
  grid-template-columns: 1fr 76px;
  gap: 10px;
  align-items: center;
  padding: 10px;
  border-radius: 14px;
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.08);
}
.diagnostic-item strong { display: block; font-size: 13px; }
.diagnostic-item span { display: block; color: var(--muted); font-size: 12px; margin-top: 2px; }
.diagnostic-item em { font-style: normal; text-align: right; color: var(--accent); font-weight: 900; font-size: 13px; }
.diagnostic-item.high { background: rgba(142,208,255,.08); }
.diagnostic-item.low { background: rgba(255,182,213,.07); }


.progress-box {
  margin-top: 14px;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: rgba(0,0,0,.16);
}
.progress-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  font-size: 13px;
}
.progress-top strong { color: var(--text); }
.progress-top span { color: var(--accent); font-weight: 900; }
.progress-track {
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  overflow: hidden;
  margin-top: 10px;
}
.progress-fill {
  width: 0%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  transition: width .35s ease;
}
.progress-box p {
  margin: 9px 0 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}


.top-subtype {
  margin-top: 6px;
  color: var(--accent);
  font-weight: 700;
}
.co-box, .alt-box {
  margin-top: 14px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: rgba(0,0,0,.14);
  padding: 14px;
}
.co-box h3, .alt-box h3 { margin: 0 0 8px; }
.mini-list { display: grid; gap: 8px; }
.mini-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.08);
}
.mini-item strong { display: block; font-size: 13px; }
.mini-item span { display: block; margin-top: 2px; color: var(--muted); font-size: 12px; }
.mini-item em { font-style: normal; color: var(--accent); font-weight: 800; align-self: center; }
.rank-item .subtype-line { display:block; margin-top: 4px; color: var(--accent); font-size: 12px; font-weight: 700; }

.preview > img {
  display: block;
  width: 100%;
  max-height: 420px;
  object-fit: contain;
  border-radius: 18px;
}

.blend-meter {
  height: 8px;
  margin-top: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  overflow: hidden;
}
.blend-meter > i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #8ed0ff, #ffb6d5);
}

.embedding-badge{display:inline-flex;gap:6px;align-items:center;padding:4px 8px;border-radius:999px;background:rgba(255,255,255,.08);font-size:12px;}

/* v6 face-reading layout */
.face-head { grid-template-columns: 128px 1fr; }
.face-icon {
  width: 128px;
  height: 128px;
  display: grid;
  place-items: center;
  border-radius: 28px;
  background: linear-gradient(135deg, rgba(142,208,255,.18), rgba(255,182,213,.20));
  border: 1px solid var(--line);
  font-size: 62px;
}
.radar-card {
  margin-top: 16px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(0,0,0,.18);
  overflow: hidden;
}
.radar-card canvas {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 18px;
}
.axis-list { display: grid; gap: 10px; }
.axis-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 150px 58px;
  gap: 12px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255,255,255,.055);
  padding: 11px;
}
.axis-item.high { background: rgba(142,208,255,.085); }
.axis-item.low { background: rgba(255,182,213,.075); }
.axis-main strong { display: block; font-size: 14px; }
.axis-main span { display: block; color: var(--muted); font-size: 12px; line-height: 1.38; margin-top: 3px; }
.axis-evidence {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 7px;
}
.axis-evidence span {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  width: auto;
  padding: 4px 6px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  background: rgba(0,0,0,.18);
  color: #dfe8f7;
  font-size: 11px;
  line-height: 1;
}
.axis-evidence b { color: var(--accent); font-weight: 800; }
.axis-evidence small { color: var(--muted); font-size: 10px; }
.axis-meter {
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.13);
  overflow: hidden;
}
.axis-meter i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
}
.axis-item em {
  font-style: normal;
  font-weight: 900;
  color: var(--accent);
  text-align: right;
  font-size: 13px;
}
@media (max-width: 520px) {
  .face-head { grid-template-columns: 88px 1fr; }
  .face-icon { width: 88px; height: 88px; border-radius: 20px; font-size: 44px; }
  .axis-item {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px 10px;
    padding: 10px;
    align-items: start;
  }
  .axis-main { grid-column: 1 / -1; min-width: 0; }
  .axis-main strong { font-size: 13px; }
  .axis-main span { font-size: 12px; line-height: 1.45; }
  .axis-evidence { gap: 6px; }
  .axis-evidence span {
    max-width: 100%;
    white-space: normal;
    line-height: 1.25;
    padding: 5px 7px;
  }
  .axis-evidence small { display: none; }
  .axis-meter { grid-column: 1; grid-row: 2; width: 100%; height: 9px; align-self: center; }
  .axis-item em { grid-column: 2; grid-row: 2; font-size: 12px; align-self: center; }
}


.ai-toggle-card {
  margin-top: 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 13px 14px;
  background: rgba(255,255,255,.06);
}
.ai-toggle-card strong { display: block; font-size: 15px; }
.ai-toggle-card span { display: block; margin-top: 3px; color: var(--muted); font-size: 12px; line-height: 1.4; }
.switch { position: relative; width: 58px; height: 34px; flex: 0 0 auto; }
.switch input { display: none; }
.switch i {
  position: absolute;
  inset: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.18);
  transition: .18s ease;
}
.switch i::after {
  content: "";
  position: absolute;
  width: 26px;
  height: 26px;
  left: 4px;
  top: 3px;
  border-radius: 999px;
  background: #fff;
  box-shadow: 0 4px 14px rgba(0,0,0,.24);
  transition: .18s ease;
}
.switch input:checked + i { background: linear-gradient(135deg, var(--accent), var(--accent2)); }
.switch input:checked + i::after { transform: translateX(23px); }
.ai-toggle-card.on { border-color: rgba(142,208,255,.5); background: rgba(142,208,255,.10); }

/* v6.1.9: result actions / png layout */
.result-actions-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
  align-items: center;
}
.result-actions-grid .export-hint {
  grid-column: 1 / -1;
}


.face-detection-card {
  margin: 14px 0 16px;
  border: 1px solid rgba(142,208,255,.28);
  border-radius: 22px;
  background: rgba(142,208,255,.075);
  padding: 14px;
}
.face-detection-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}
.face-detection-head h3 { margin: 0 0 4px; }
.face-detection-badge {
  flex: 0 0 auto;
  border: 1px solid rgba(142,208,255,.45);
  background: rgba(142,208,255,.12);
  color: var(--accent);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  padding: 6px 10px;
}
.face-preview-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.face-preview-grid figure {
  margin: 0;
  border: 1px solid var(--line);
  background: rgba(0,0,0,.22);
  border-radius: 18px;
  overflow: hidden;
}
.face-preview-grid figcaption {
  padding: 8px 10px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
  border-bottom: 1px solid var(--line);
}
.face-preview-grid img {
  display: block;
  width: 100%;
  height: 260px;
  object-fit: contain;
  background: #05060a;
}
.face-detection-fail {
  border-color: rgba(255,119,119,.35);
  background: rgba(255,119,119,.07);
}
.face-detection-fail .face-detection-badge {
  color: var(--danger);
  border-color: rgba(255,119,119,.45);
  background: rgba(255,119,119,.12);
}
@media (max-width: 560px) {
  .face-preview-grid { grid-template-columns: 1fr; }
  .face-preview-grid img { height: 240px; }
  .face-detection-head { flex-direction: column; }
}


/* v6.1.9: mobile result readability polish */
@media (max-width: 480px) {
  .result.card { margin-top: 14px; }
  .reason { font-size: 13px; line-height: 1.62; padding: 12px; }
  .analysis-box { padding: 12px; border-radius: 18px; }
  .face-detection-card { padding: 12px; border-radius: 20px; }
  .result-actions-grid { grid-template-columns: 1fr; }
  .secondary { padding: 14px 16px; font-size: 15px; }
}

.dataset-consent {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  width: min(640px, 100%);
  margin: 14px auto 10px;
  padding: 12px 14px;
  border: 1px solid rgba(142, 208, 255, .22);
  border-radius: 16px;
  background: rgba(142, 208, 255, .08);
  color: var(--text);
  font-size: .92rem;
  line-height: 1.45;
}
.dataset-consent input {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  accent-color: #8ed0ff;
  flex: 0 0 auto;
}
.privacy code {
  padding: 1px 5px;
  border-radius: 6px;
  background: rgba(255,255,255,.09);
  color: #dfe8f7;
}
@media (max-width: 520px) {
  .dataset-consent {
    font-size: .86rem;
    padding: 11px 12px;
  }
}

/* v6.1.9: administrator feedback center */
.admin-wrap { width: min(1180px, 100%); }
.admin-hero p { max-width: 760px; }
.admin-top-link { margin-top: 8px; }
.admin-token-card h3 { margin: 0 0 6px; }
.admin-token-row,
.admin-filter-row,
.admin-button-row,
.admin-check-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
}
.admin-token-row input,
.admin-filter-row select,
.admin-form-grid select,
.admin-axis-row select,
.admin-axis-row input,
.admin-note-label textarea {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(0,0,0,.28);
  color: var(--text);
  padding: 11px 12px;
  font: inherit;
}
.admin-token-row input { flex: 1 1 260px; min-width: 0; }
.secondary.small { width: auto; padding: 10px 14px; font-size: 14px; }
.secondary.ghost { background: rgba(255,255,255,.055); color: var(--text); }
.error-text { color: var(--danger) !important; }
.admin-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 16px;
}
.admin-stat { margin-top: 0; text-align: center; }
.admin-stat strong { display: block; font-size: 32px; color: var(--accent); line-height: 1.1; }
.admin-stat span { color: var(--muted); font-size: 13px; }
.admin-controls label { color: var(--muted); display: flex; align-items: center; gap: 8px; }
.admin-export-link { display: inline-flex; text-decoration: none; align-items: center; justify-content: center; width: auto; margin-top: 0; padding: 10px 14px; font-size: 14px; }
.admin-layout {
  display: grid;
  grid-template-columns: minmax(300px, 380px) 1fr;
  gap: 16px;
  align-items: start;
  margin-top: 16px;
}
.admin-list-card,
.admin-detail-card { margin-top: 0; }
.admin-list-card { position: sticky; top: 12px; max-height: calc(100vh - 24px); overflow: auto; }
.admin-sample-list { display: grid; gap: 10px; }
.admin-sample-item {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255,255,255,.055);
  color: var(--text);
  display: grid;
  grid-template-columns: 64px 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 10px;
  text-align: left;
  cursor: pointer;
}
.admin-sample-item.active,
.admin-sample-item:hover { border-color: rgba(142,208,255,.52); background: rgba(142,208,255,.09); }
.admin-sample-item img { width: 64px; height: 64px; border-radius: 14px; object-fit: cover; background: #05060a; }
.admin-sample-item strong,
.admin-sample-item span,
.admin-sample-item small { display: block; }
.admin-sample-item strong { font-size: 14px; line-height: 1.25; }
.admin-sample-item span { color: var(--muted); font-size: 12px; margin-top: 3px; }
.admin-sample-item small { color: #cbd5e5; font-size: 11px; margin-top: 3px; line-height: 1.3; }
.admin-sample-item em,
.admin-status-badge {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 5px 8px;
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  white-space: nowrap;
}
.status-labeled { color: #baffd1; border-color: rgba(186,255,209,.35); background: rgba(186,255,209,.09); }
.status-unlabeled { color: var(--accent2); border-color: rgba(255,182,213,.35); background: rgba(255,182,213,.08); }
.status-needs_review { color: #ffe6a3; border-color: rgba(255,230,163,.35); background: rgba(255,230,163,.08); }
.status-skip { color: #c3c8d6; border-color: rgba(195,200,214,.32); background: rgba(195,200,214,.07); }
.load-more { width: 100%; margin-top: 12px; }
.empty-admin-detail { min-height: 240px; display: grid; place-items: center; text-align: center; color: var(--muted); }
.admin-detail-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.admin-detail-head h2 { margin: 4px 0 4px; font-size: clamp(24px, 4vw, 36px); letter-spacing: -0.04em; }
.admin-image-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}
.admin-image-grid figure {
  margin: 0;
  border: 1px solid var(--line);
  background: rgba(0,0,0,.22);
  border-radius: 18px;
  overflow: hidden;
}
.admin-image-grid figcaption { padding: 8px 10px; color: var(--muted); font-size: 12px; border-bottom: 1px solid var(--line); }
.admin-image-grid img { display: block; width: 100%; height: 250px; object-fit: contain; background: #05060a; }
.admin-summary-box { margin-top: 14px; }
.admin-feedback-form {
  margin-top: 16px;
  border: 1px solid rgba(142,208,255,.22);
  border-radius: 20px;
  background: rgba(142,208,255,.06);
  padding: 14px;
}
.admin-feedback-form h3 { margin: 0 0 12px; }
.admin-form-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
.admin-form-grid label,
.admin-note-label { color: var(--muted); display: grid; gap: 6px; font-size: 13px; }
.admin-check-row label { color: var(--text); font-size: 13px; }
.admin-axis-feedback h4 { margin: 16px 0 8px; }
.admin-axis-list { display: grid; gap: 8px; }
.admin-axis-row {
  display: grid;
  grid-template-columns: 1fr 150px minmax(130px, 220px);
  gap: 8px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(0,0,0,.18);
  padding: 10px;
}
.admin-axis-title strong,
.admin-axis-title span,
.admin-axis-title small { display: block; }
.admin-axis-title strong { font-size: 14px; }
.admin-axis-title span { color: #dce4f3; font-size: 12px; margin-top: 3px; line-height: 1.3; }
.admin-axis-title small { color: var(--muted); font-size: 11px; margin-top: 3px; }
.admin-note-label { margin-top: 12px; }
.admin-note-label textarea { resize: vertical; min-height: 90px; }
.admin-json-details pre { max-height: 520px; overflow: auto; }
@media (max-width: 900px) {
  .admin-stats-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .admin-layout { grid-template-columns: 1fr; }
  .admin-list-card { position: static; max-height: none; }
  .admin-image-grid { grid-template-columns: 1fr; }
  .admin-image-grid img { height: 260px; }
  .admin-form-grid { grid-template-columns: 1fr; }
  .admin-axis-row { grid-template-columns: 1fr; }
}
@media (max-width: 520px) {
  .admin-wrap { padding-left: 10px; padding-right: 10px; }
  .admin-stats-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
  .admin-stat strong { font-size: 26px; }
  .admin-sample-item { grid-template-columns: 54px 1fr; }
  .admin-sample-item em { grid-column: 2; justify-self: start; }
  .admin-sample-item img { width: 54px; height: 54px; }
  .admin-token-row input { flex-basis: 100%; }
  .admin-detail-head { flex-direction: column; }
}
