/**
 * Roll20 Macro Studio — studio.css
 * ---------------------------------------------------------------------------
 * common.css의 테마 변수(--bg-*, --text-*, --border, --accent 등)를 그대로 사용합니다.
 * 3-Pane 레이아웃: 좌 컨트롤 / 중 미리보기 / 우 출력+가이드
 * ---------------------------------------------------------------------------
 */

.studio-page {
  padding-bottom: var(--space-xl);
}

.studio-hero {
  padding-block: var(--space-lg);
  border-bottom: 1px solid var(--border);
  background: var(--bg-secondary);
  transition: var(--transition-theme);
}

.studio-hero__inner {
  max-width: 90rem;
  margin-inline: auto;
  padding-inline: var(--space-md);
}

@media (min-width: 768px) {
  .studio-hero__inner {
    padding-inline: var(--space-lg);
  }
}

.studio-hero h1 {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--text-main);
  margin-bottom: var(--space-xs);
}

.studio-hero p {
  color: var(--text-muted);
  max-width: 42rem;
}

/* 매크로 가져오기(역파싱) */
.studio-import {
  border-bottom: 1px solid var(--border);
  background: var(--bg-primary);
  transition: var(--transition-theme);
}

.studio-import__inner {
  max-width: 90rem;
  margin-inline: auto;
  padding: var(--space-md) var(--space-md) var(--space-lg);
}

@media (min-width: 768px) {
  .studio-import__inner {
    padding-inline: var(--space-lg);
  }
}

.studio-import__title {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--text-main);
  margin-bottom: var(--space-sm);
}

.studio-import__hint {
  max-width: 48rem;
  margin-bottom: var(--space-md);
}

.studio-import__textarea {
  width: 100%;
  min-height: 7rem;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 0.8125rem;
  line-height: 1.45;
  padding: var(--space-sm);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--control-bg);
  color: var(--text-main);
  resize: vertical;
}

.studio-import__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}

.studio-import__error {
  margin-top: var(--space-sm);
  color: var(--accent);
  max-width: 48rem;
}

.studio-guide__h2-secondary {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--text-main);
  margin-top: var(--space-xl);
  margin-bottom: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid var(--border);
}

/* 3-Pane 그리드 */
.studio-shell {
  display: grid;
  gap: var(--space-md);
  max-width: 90rem;
  margin-inline: auto;
  padding: var(--space-md);
  grid-template-columns: 1fr;
}

@media (min-width: 1024px) {
  .studio-shell {
    padding: var(--space-lg);
    grid-template-columns: minmax(17rem, 22%) minmax(16rem, 1fr) minmax(17rem, 30%);
    align-items: start;
  }
}

@media (min-width: 1280px) {
  .studio-shell {
    grid-template-columns: minmax(18rem, 24%) minmax(18rem, 1.1fr) minmax(18rem, 32%);
  }
}

.studio-pane {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  transition: var(--transition-theme);
}

.studio-pane__title {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--accent);
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--border);
}

.studio-pane--controls .studio-pane__section ~ .studio-pane__section {
  margin-top: var(--space-lg);
}

/* 컨트롤 행 */
.ctl-field {
  margin-bottom: var(--space-md);
}

.ctl-field:last-child {
  margin-bottom: 0;
}

.ctl-field label,
.ctl-field .ctl-label {
  display: block;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--text-main);
  margin-bottom: var(--space-xs);
}

.ctl-inline {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.ctl-inline input[type="range"] {
  flex: 1;
  min-width: 0;
  accent-color: var(--accent);
}

.ctl-inline input[type="number"] {
  width: 4.25rem;
  padding: var(--space-xs) var(--space-sm);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--control-bg);
  color: var(--text-main);
}

.ctl-field select,
.ctl-field input[type="color"] {
  width: 100%;
  max-width: 100%;
  padding: var(--space-xs) var(--space-sm);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--control-bg);
  color: var(--text-main);
}

.ctl-field input[type="color"] {
  height: 2.25rem;
  padding: 2px;
  cursor: pointer;
}

.ctl-check {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-main);
  cursor: pointer;
}

.ctl-check input {
  margin-top: 0.2rem;
  accent-color: var(--accent);
}

.ctl-hint {
  font-size: 0.75rem;
  color: var(--text-muted);
  margin-top: var(--space-xs);
  line-height: 1.45;
}

.ctl-subgrid {
  display: grid;
  gap: var(--space-md);
  margin-top: var(--space-md);
}

.ctl-subgrid[hidden] {
  display: none !important;
}

/* Roll20 다크 채팅 유사 프리뷰 */
.r20-preview {
  --r20-chat-bg: #333333;
  --r20-chat-fg: #d0d0d0;
  background: var(--r20-chat-bg);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  min-height: 12rem;
  border: 1px solid #1f1f1f;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.r20-preview__meta {
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #888;
  margin-bottom: var(--space-sm);
}

.r20-preview__line {
  font-size: 0.8125rem;
  color: var(--r20-chat-fg);
  margin-bottom: var(--space-sm);
  line-height: 1.4;
}

.r20-preview__bubble-wrap {
  padding-top: var(--space-xs);
}

.studio-live-sandbox {
  margin-top: var(--space-md);
}

.studio-live-sandbox__head {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--accent);
  margin-bottom: var(--space-xs);
}

.studio-live-sandbox__frame {
  max-width: 100%;
}

.studio-live-sandbox__log {
  min-height: 6rem;
  max-height: 12rem;
}

/* 실제 매크로가 입혀지는 노드 */
#macro-preview-target {
  display: inline-block;
  max-width: 100%;
  word-break: break-word;
  vertical-align: top;
}

/* 글자별 컬러 스와치 */
.per-char-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-xs);
  max-height: 7rem;
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: var(--space-xs);
  margin-top: var(--space-sm);
  border: 1px dashed var(--border);
  border-radius: var(--radius-sm);
  padding: var(--space-sm);
}

.per-char-toolbar[hidden] {
  display: none !important;
}

.per-char-swatch {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}

.per-char-swatch span {
  font-size: 0.65rem;
  color: var(--text-muted);
  font-weight: 600;
}

.per-char-swatch input[type="color"] {
  width: 1.75rem;
  height: 1.75rem;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  cursor: pointer;
}

/* 출력 */
.studio-output__textarea {
  width: 100%;
  min-height: 10rem;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 0.75rem;
  line-height: 1.45;
  padding: var(--space-sm);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--control-bg);
  color: var(--text-main);
  resize: vertical;
}

.studio-output__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: var(--space-sm);
  margin-top: var(--space-sm);
}

.btn-studio {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-sm) var(--space-md);
  font-size: 0.875rem;
  font-weight: 600;
  border-radius: var(--radius-md);
  border: 1px solid var(--accent);
  background: var(--accent);
  color: #fff;
  transition: background 0.15s ease, border-color 0.15s ease, opacity 0.15s ease;
}

html.dark-mode .btn-studio {
  color: #0f172a;
}

.btn-studio:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
}

.btn-studio--ghost {
  background: transparent;
  color: var(--accent);
  border-color: var(--border);
}

.btn-studio--ghost:hover {
  background: var(--control-active-bg);
  border-color: var(--accent);
}

.btn-studio:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.btn-studio.is-done {
  opacity: 0.85;
}

/* 기술 가이드 (E-E-A-T) */
.studio-guide {
  margin-top: var(--space-lg);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--border);
}

.studio-guide h2 {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--text-main);
  margin-bottom: var(--space-md);
}

.studio-guide section {
  margin-bottom: var(--space-lg);
}

.studio-guide h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-main);
  margin-bottom: var(--space-sm);
}

.studio-guide p {
  font-size: 0.875rem;
  line-height: 1.65;
  color: var(--text-muted);
  margin-bottom: var(--space-sm);
}

.studio-guide p:last-child {
  margin-bottom: 0;
}

.preview-textarea {
  width: 100%;
  min-height: 4rem;
  padding: var(--space-sm);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--control-bg);
  color: var(--text-main);
  resize: vertical;
}
