/* motiono — 다크 프리미엄 테마 (컴팩트·깔끔·직관·고급, 개발지시서 8장) */

/* ========== 변수 / 리셋 ========== */
:root {
  --bg: #0b0d12;
  --card: #14171f;
  --card-2: #191d27;
  --border: #232733;
  --accent: #7c5cff;
  --accent-2: #00e5c3;
  --text: #e8eaf0;
  --muted: #8b90a0;
  --danger: #ff5470;
  --warn: #ffb454;
  --ok: #2fd66f;
  --radius: 12px;
  --tr: 0.15s ease;
  --font: -apple-system, BlinkMacSystemFont, "Segoe UI", "Apple SD Gothic Neo",
          "Noto Sans KR", "Helvetica Neue", Arial, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body { height: 100%; overflow-x: clip; } /* 가로 스크롤 누수 방지 (clip: sticky 유지) */
body {
  background: radial-gradient(1100px 500px at 50% -10%, #141a2a 0%, var(--bg) 55%) fixed, var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

h2 { font-size: 22px; font-weight: 700; letter-spacing: -0.01em; }
h3 { font-size: 17px; font-weight: 700; }
h4 { font-size: 15px; font-weight: 600; }
a { color: var(--accent-2); text-decoration: none; }
.muted { color: var(--muted); font-size: 13px; }
video, audio { max-width: 100%; }

::selection { background: rgba(124, 92, 255, 0.35); }

/* 스크롤바 절제 */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: #262b38; border-radius: 8px; }
::-webkit-scrollbar-track { background: transparent; }

/* ========== 레이아웃 ========== */
.container { max-width: 1120px; margin: 0 auto; padding: 28px 24px 80px; }
.page-head { margin-bottom: 24px; }
.page-head p { margin-top: 4px; }
.page-loading {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  min-height: 40vh; color: var(--muted);
}

/* ========== 상단바 ========== */
#topbar {
  position: sticky; top: 0; z-index: 50;
  background: rgba(11, 13, 18, 0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
}
.topbar-inner {
  max-width: 1120px; margin: 0 auto; padding: 12px 24px;
  display: flex; align-items: center; justify-content: space-between;
}
.logo { color: var(--text); font-weight: 700; font-size: 17px; display: flex; align-items: center; gap: 7px; }
.logo-mark {
  display: inline-flex; align-items: center; justify-content: center;
  width: 30px; height: 30px; border-radius: 9px; font-size: 12px; font-weight: 800;
  color: #fff;
  background: linear-gradient(135deg, var(--accent), #4b2fd6);
  box-shadow: 0 0 14px rgba(124, 92, 255, 0.45);
}
.logo-mark.big { width: 44px; height: 44px; border-radius: 13px; font-size: 16px; }
/* motiono 로고 글리프 — 모션 궤도를 도는 'o' (링 우상단 트임 + 틸 위성 점) */
.logo-o { position: relative; width: 14px; height: 14px; display: inline-block; }
.logo-o::before {
  content: ''; position: absolute; inset: 0; border-radius: 50%;
  border: 2.5px solid rgba(255, 255, 255, 0.95); border-right-color: transparent;
  transform: rotate(-45deg);
}
.logo-o::after {
  content: ''; position: absolute; width: 5px; height: 5px; border-radius: 50%;
  background: var(--accent-2); top: -1.5px; right: -1.5px;
  box-shadow: 0 0 6px var(--accent-2);
}
.logo-o.big { width: 21px; height: 21px; }
.logo-o.big::before { border-width: 3.5px; }
.logo-o.big::after { width: 7px; height: 7px; top: -2px; right: -2px; }
.topbar-right { display: flex; align-items: center; gap: 12px; }
.credit-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 5px 12px; border-radius: 999px; font-size: 13px; font-weight: 600;
  color: var(--accent-2);
  border: 1px solid rgba(0, 229, 195, 0.35);
  background: rgba(0, 229, 195, 0.07);
}
.credit-dot { font-size: 12px; }

/* ========== 버튼 ========== */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  padding: 9px 18px; border-radius: 10px; border: 1px solid transparent;
  font-family: var(--font); font-size: 14px; font-weight: 600; color: var(--text);
  background: var(--card-2); cursor: pointer;
  transition: background var(--tr), border-color var(--tr), box-shadow var(--tr), opacity var(--tr), transform var(--tr);
}
.btn:hover:not(:disabled) { border-color: var(--border); }
.btn:disabled { opacity: 0.45; cursor: not-allowed; }
.btn-primary {
  background: linear-gradient(135deg, var(--accent), #5d3fe0);
  color: #fff;
  box-shadow: 0 0 0 1px rgba(124, 92, 255, 0.35), 0 4px 18px rgba(124, 92, 255, 0.22);
}
.btn-primary:hover:not(:disabled) { box-shadow: 0 0 0 1px rgba(124, 92, 255, 0.6), 0 6px 22px rgba(124, 92, 255, 0.32); }
.btn-ghost { background: transparent; border-color: var(--border); }
.btn-ghost:hover:not(:disabled) { border-color: var(--accent); }
.btn-sm { padding: 6px 12px; font-size: 13px; border-radius: 8px; }
.btn-lg { padding: 13px 28px; font-size: 16px; border-radius: 12px; }
.btn-block { width: 100%; }
.btn-row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 16px; }

.icon-btn {
  background: transparent; border: none; color: var(--muted); font-size: 14px;
  cursor: pointer; padding: 5px 7px; border-radius: 8px; transition: color var(--tr), background var(--tr);
}
.icon-btn:hover { color: var(--text); background: var(--card-2); }
.icon-btn.danger:hover { color: var(--danger); background: rgba(255, 84, 112, 0.1); }

/* ========== 입력 ========== */
.field { margin-bottom: 14px; }
.field > label { display: block; font-size: 13px; color: var(--muted); margin-bottom: 6px; font-weight: 600; }
.input, select.input, textarea.input {
  width: 100%; padding: 10px 13px; border-radius: 10px;
  background: #0f1219; border: 1px solid var(--border); color: var(--text);
  font-family: var(--font); font-size: 14px;
  transition: border-color var(--tr), box-shadow var(--tr);
}
.input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(124, 92, 255, 0.18); }
.input::placeholder { color: #565b6b; }
textarea.input { resize: vertical; min-height: 70px; }
select.input {
  appearance: none; -webkit-appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, var(--muted) 50%), linear-gradient(135deg, var(--muted) 50%, transparent 50%);
  background-position: calc(100% - 18px) 50%, calc(100% - 13px) 50%;
  background-size: 5px 5px; background-repeat: no-repeat;
}
.file-input { width: 100%; color: var(--muted); font-size: 13px; }
.file-input::file-selector-button {
  margin-right: 12px; padding: 8px 14px; border-radius: 9px;
  border: 1px solid var(--border); background: var(--card-2); color: var(--text);
  font-family: var(--font); font-size: 13px; font-weight: 600; cursor: pointer;
  transition: border-color var(--tr);
}
.file-input::file-selector-button:hover { border-color: var(--accent); }
.chk-label { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--text); cursor: pointer; margin: 10px 0; }
.chk-label input[type="checkbox"] { accent-color: var(--accent); width: 15px; height: 15px; }

/* ========== 카드 ========== */
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 24px;
  transition: border-color var(--tr), box-shadow var(--tr), transform var(--tr);
}
.card + .card { margin-top: 20px; }
.card h4 { margin-bottom: 12px; }

/* ========== 배지 / 칩 ========== */
.badge {
  display: inline-flex; align-items: center; padding: 3px 10px; border-radius: 999px;
  font-size: 11.5px; font-weight: 700; letter-spacing: 0.02em;
}
.b-draft  { color: var(--muted); background: rgba(139, 144, 160, 0.12); border: 1px solid rgba(139, 144, 160, 0.25); }
.b-run    { color: var(--accent); background: rgba(124, 92, 255, 0.1); border: 1px solid rgba(124, 92, 255, 0.4); }
.b-done   { color: var(--ok); background: rgba(47, 214, 111, 0.1); border: 1px solid rgba(47, 214, 111, 0.35); }
.b-err    { color: var(--danger); background: rgba(255, 84, 112, 0.1); border: 1px solid rgba(255, 84, 112, 0.35); }
.b-review { color: var(--warn); background: rgba(255, 180, 84, 0.1); border: 1px solid rgba(255, 180, 84, 0.35); }
.chip-mini {
  display: inline-flex; padding: 2px 9px; border-radius: 7px; font-size: 11.5px; font-weight: 600;
  color: var(--accent-2); border: 1px solid rgba(0, 229, 195, 0.3); background: rgba(0, 229, 195, 0.06);
}

/* ========== 탭 ========== */
.tabs { display: flex; gap: 6px; margin-bottom: 18px; border-bottom: 1px solid var(--border); }
.tab {
  padding: 9px 18px; background: transparent; border: none; border-bottom: 2px solid transparent;
  color: var(--muted); font-family: var(--font); font-size: 14px; font-weight: 600; cursor: pointer;
  transition: color var(--tr), border-color var(--tr);
}
.tab:hover { color: var(--text); }
.tab.active { color: var(--accent); border-bottom-color: var(--accent); }
.tab-body { padding-top: 4px; }

/* ========== 토스트 ========== */
#toasts {
  position: fixed; top: 16px; left: 50%; transform: translateX(-50%);
  z-index: 200; display: flex; flex-direction: column; gap: 8px; align-items: center;
  pointer-events: none; width: min(92vw, 480px);
}
.toast {
  padding: 11px 20px; border-radius: 10px; font-size: 14px; font-weight: 600;
  color: #fff; box-shadow: 0 8px 30px rgba(0, 0, 0, 0.5);
  animation: toast-in 0.2s ease; max-width: 100%;
}
.toast-err { background: linear-gradient(135deg, #d5314f, #a91f3a); border: 1px solid rgba(255, 84, 112, 0.6); }
.toast-ok  { background: linear-gradient(135deg, #0d8f78, #086b5b); border: 1px solid rgba(0, 229, 195, 0.5); }
.toast.out { opacity: 0; transform: translateY(-8px); transition: opacity 0.3s ease, transform 0.3s ease; }
@keyframes toast-in { from { opacity: 0; transform: translateY(-10px); } to { opacity: 1; transform: none; } }

/* ========== 스피너 ========== */
.spinner {
  display: inline-block; width: 14px; height: 14px; flex: none;
  border: 2px solid rgba(232, 234, 240, 0.25); border-top-color: var(--accent-2);
  border-radius: 50%; animation: spin 0.7s linear infinite; vertical-align: -2px;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ========== 모달 ========== */
.modal-overlay {
  position: fixed; inset: 0; z-index: 100;
  background: rgba(5, 6, 10, 0.7); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center; padding: 20px;
}
.modal { width: min(440px, 100%); animation: toast-in 0.18s ease; }
.modal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.modal-foot { display: flex; justify-content: flex-end; gap: 10px; margin-top: 20px; }

/* 비율 토글 */
.aspect-toggle { display: flex; gap: 0; border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
.aspect-btn {
  flex: 1; padding: 10px; background: transparent; border: none; color: var(--muted);
  font-family: var(--font); font-size: 14px; font-weight: 600; cursor: pointer;
  transition: background var(--tr), color var(--tr);
}
.aspect-btn + .aspect-btn { border-left: 1px solid var(--border); }
.aspect-btn.active { background: rgba(124, 92, 255, 0.16); color: var(--accent); }

/* ========== 로그인 ========== */
.auth-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 24px; }
.auth-card { width: min(400px, 100%); padding: 36px 32px; }
.auth-logo { display: flex; align-items: center; gap: 10px; font-size: 22px; font-weight: 800; margin-bottom: 6px; }
.auth-sub { margin-bottom: 22px; }
.auth-hint { margin-top: 14px; text-align: center; }

/* ========== 대시보드 ========== */
.grid-cards {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 20px;
}
.project-card { cursor: pointer; }
.project-card:hover { border-color: var(--accent); transform: translateY(-2px); box-shadow: 0 8px 26px rgba(0, 0, 0, 0.35); }
.project-card-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; margin-bottom: 14px; }
.project-title { font-size: 16px; font-weight: 700; word-break: break-all; }
.project-card-meta { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.new-card {
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px;
  min-height: 128px; cursor: pointer; border-style: dashed; border-color: #2d3342;
  color: var(--muted); font-family: var(--font); font-size: 14px; font-weight: 600;
}
.new-card:hover { border-color: var(--accent); color: var(--accent); box-shadow: 0 0 20px rgba(124, 92, 255, 0.15); }
.new-plus { font-size: 30px; line-height: 1; font-weight: 300; }

/* ========== 위저드 ========== */
.wiz-head { margin-bottom: 20px; }
.back-link { color: var(--muted); font-size: 13px; transition: color var(--tr); }
.back-link:hover { color: var(--text); }
.wiz-title-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-top: 6px; }
.wiz-title { word-break: break-all; }

/* 스텝바 */
.stepbar {
  display: flex; align-items: center; gap: 6px;
  padding: 14px 18px; margin-bottom: 26px;
  background: var(--card); border: 1px solid var(--border); border-radius: var(--radius);
  overflow-x: auto;
}
.step {
  display: flex; align-items: center; gap: 8px; flex: none;
  background: transparent; border: none; padding: 5px 8px; border-radius: 9px;
  font-family: var(--font); font-size: 13px; font-weight: 600; color: var(--muted);
  cursor: pointer; transition: color var(--tr), background var(--tr);
}
.step:hover:not(:disabled) { color: var(--text); background: var(--card-2); }
.step-dot {
  display: inline-flex; align-items: center; justify-content: center; flex: none;
  width: 26px; height: 26px; border-radius: 50%;
  border: 1.5px solid var(--border); font-size: 12px; font-weight: 700;
  transition: all var(--tr);
}
.step.active { color: var(--accent); }
.step.active .step-dot {
  border-color: var(--accent); color: #fff;
  background: linear-gradient(135deg, var(--accent), #5d3fe0);
  box-shadow: 0 0 12px rgba(124, 92, 255, 0.55);
}
.step.done { color: var(--accent-2); }
.step.done .step-dot { border-color: var(--accent-2); color: var(--accent-2); background: rgba(0, 229, 195, 0.08); }
.step.locked { opacity: 0.4; cursor: not-allowed; }
.step-line { flex: 1; min-width: 14px; height: 1.5px; background: var(--border); border-radius: 2px; }
.step-line.done { background: rgba(0, 229, 195, 0.45); }

.sec-head { margin-bottom: 18px; }
.sec-head p { margin-top: 3px; }

/* 완료 카드 / 안내 */
.done-card { border-color: rgba(0, 229, 195, 0.35); }
.done-row { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.done-check {
  display: inline-flex; align-items: center; justify-content: center; flex: none;
  width: 30px; height: 30px; border-radius: 50%; font-size: 15px; font-weight: 800;
  color: #06120e; background: var(--accent-2); box-shadow: 0 0 14px rgba(0, 229, 195, 0.4);
}
.notice {
  padding: 16px 18px; border-radius: 10px; margin: 14px 0;
  background: rgba(124, 92, 255, 0.07); border: 1px solid rgba(124, 92, 255, 0.3);
  font-size: 14px;
}
.notice.warn { background: rgba(255, 180, 84, 0.07); border-color: rgba(255, 180, 84, 0.35); }
.notice .btn-row { margin-top: 10px; }
.audio-full { width: 100%; margin: 10px 0; }

/* ========== 스텝① 트랙 선택 ========== */
.track-picker { margin-top: 22px; }
.track-picker h4 { margin-bottom: 4px; }
.track-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; margin-top: 14px; }
.track-card { cursor: pointer; padding: 18px; }
.track-card:hover { border-color: var(--accent); }
.track-card.selected { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent), 0 0 18px rgba(124, 92, 255, 0.25); }
.track-head { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.persona-row { margin-top: 16px; }
.persona-row .input { margin-top: 8px; max-width: 320px; }

/* ========== 스텝① 곡 구간 선택 ========== */
.segment-card { margin-top: 16px; }
.seg-head { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 4px; }
.seg-state {
  font-size: 12px; font-weight: 600; padding: 3px 10px; border-radius: 999px;
  color: var(--muted); background: rgba(139, 144, 160, 0.1); border: 1px solid var(--border);
}
.seg-state.on { color: var(--accent-2); background: rgba(0, 229, 195, 0.1); border-color: rgba(0, 229, 195, 0.4); }
.seg-row { display: flex; align-items: flex-end; gap: 18px; flex-wrap: wrap; margin-top: 10px; }
.seg-field { margin-bottom: 0; }
.seg-input-row { display: flex; align-items: center; gap: 8px; }
.seg-num { width: 110px; }
.seg-len { font-size: 13px; color: var(--accent-2); padding-bottom: 9px; }
.seg-len.bad { color: var(--warn); }

/* ========== 스텝② 캐릭터 ========== */
.char-grid { margin-top: 4px; }
.char-card { padding: 16px; cursor: pointer; display: flex; flex-direction: column; gap: 10px; }
.char-card:hover { border-color: var(--accent); }
.char-card.selected { border-color: var(--accent); box-shadow: 0 0 0 1.5px var(--accent), 0 0 22px rgba(124, 92, 255, 0.3); }
.char-card.add-card { cursor: default; border-style: dashed; border-color: #2d3342; }
.char-card.add-card:hover { border-color: #3a4156; box-shadow: none; }
.char-card.add-card .field { margin-bottom: 8px; }
.char-thumb {
  aspect-ratio: 1 / 1; border-radius: 9px; overflow: hidden; background: #0f1219;
  display: flex; align-items: center; justify-content: center;
}
.char-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.char-meta { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.char-foot { display: flex; align-items: center; justify-content: space-between; gap: 8px; min-height: 22px; }
.lock-ok { color: var(--accent-2); }

/* ========== 스텝③ 챗 ========== */
.chat-card { padding: 18px; }
.chat-box {
  height: 400px; overflow-y: auto; display: flex; flex-direction: column; gap: 10px;
  padding: 6px 4px 12px;
}
.bubble {
  max-width: 78%; padding: 10px 15px; border-radius: 14px; font-size: 14px;
  white-space: pre-wrap; word-break: break-word;
}
.bubble.ai { align-self: flex-start; background: var(--card-2); border: 1px solid var(--border); border-bottom-left-radius: 5px; }
.bubble.user {
  align-self: flex-end; border-bottom-right-radius: 5px; color: #fff;
  background: linear-gradient(135deg, rgba(124, 92, 255, 0.85), rgba(93, 63, 224, 0.85));
}
.bubble.typing { display: flex; gap: 5px; padding: 14px 16px; }
.bubble.typing .dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--muted);
  animation: blink 1.2s infinite;
}
.bubble.typing .dot:nth-child(2) { animation-delay: 0.2s; }
.bubble.typing .dot:nth-child(3) { animation-delay: 0.4s; }
@keyframes blink { 0%, 60%, 100% { opacity: 0.25; } 30% { opacity: 1; } }

.chips { display: flex; flex-wrap: wrap; gap: 8px; padding: 8px 0; }
.chip {
  padding: 6px 14px; border-radius: 999px; font-family: var(--font); font-size: 13px; font-weight: 600;
  color: var(--accent-2); background: rgba(0, 229, 195, 0.06);
  border: 1px solid rgba(0, 229, 195, 0.35); cursor: pointer;
  transition: background var(--tr), color var(--tr), border-color var(--tr);
}
.chip:hover:not(:disabled) { background: rgba(0, 229, 195, 0.16); }
.chip:disabled { opacity: 0.45; cursor: not-allowed; }
.chat-input-row { display: flex; gap: 10px; padding-top: 10px; border-top: 1px solid var(--border); }
.chat-input-row .input { flex: 1; }

/* 컨셉 확정(Design System) 요약 */
.ds-card { margin-bottom: 20px; border-color: rgba(0, 229, 195, 0.35); }
.ds-card .done-row { margin-bottom: 10px; }
.ds-row { display: grid; grid-template-columns: 92px 1fr; gap: 10px; padding: 6px 0; font-size: 14px; border-top: 1px solid rgba(35, 39, 51, 0.6); word-break: break-word; }
.ds-label { color: var(--muted); font-weight: 600; font-size: 13px; }

/* ========== 스텝④ 파이프라인 ========== */
.gen-start { text-align: center; padding: 26px 0 8px; }
.gen-start p { margin-top: 10px; }
.pipe-card { margin-top: 20px; padding: 20px 24px; }
.pipe-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; flex-wrap: wrap; margin-bottom: 12px; }
.pipe-head h4 { margin-bottom: 0; }
.pipe-stages { display: flex; flex-wrap: wrap; align-items: center; gap: 4px; margin-bottom: 12px; }
.pstage {
  padding: 4px 11px; border-radius: 999px; font-size: 12px; font-weight: 600;
  color: var(--muted); border: 1px solid var(--border);
  transition: all var(--tr);
}
.pstage:not(:last-child)::after { content: ""; }
.pipe-stages .pstage + .pstage { position: relative; margin-left: 14px; }
.pipe-stages .pstage + .pstage::before {
  content: "›"; position: absolute; left: -12px; top: 50%; transform: translateY(-50%);
  color: #3a4156; font-size: 13px;
}
.pstage.active {
  color: #fff; border-color: var(--accent);
  background: rgba(124, 92, 255, 0.22); box-shadow: 0 0 12px rgba(124, 92, 255, 0.35);
}
.pstage.done { color: var(--accent-2); border-color: rgba(0, 229, 195, 0.4); }
.pipe-bar { height: 8px; border-radius: 6px; background: #0f1219; overflow: hidden; }
.pipe-fill {
  height: 100%; width: 0; border-radius: 6px;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  box-shadow: 0 0 10px rgba(0, 229, 195, 0.4);
  transition: width 0.35s ease;
}
.pipe-msg { margin-top: 9px; min-height: 18px; font-size: 13px; word-break: break-word; }

/* ========== 컷 카드 그리드 ========== */
.scene-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 18px;
  margin-top: 20px;
}
.scene-grid.v-grid { grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); }
.grid-empty { grid-column: 1 / -1; text-align: center; padding: 34px 0; }
.scene-card { padding: 14px; display: flex; flex-direction: column; gap: 9px; }
.scene-card.failed { border-color: rgba(255, 84, 112, 0.5); }
.thumb {
  aspect-ratio: 16 / 9; border-radius: 9px; overflow: hidden; background: #0f1219;
  display: flex; align-items: center; justify-content: center;
}
.thumb.vertical { aspect-ratio: 9 / 16; }
.thumb img, .thumb video { width: 100%; height: 100%; object-fit: cover; display: block; }
.thumb-empty {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  color: var(--muted); font-size: 13px;
}
.scene-meta { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.scene-title { font-size: 13.5px; min-width: 0; }
.scene-badges { display: flex; align-items: center; gap: 6px; flex: none; }
.scene-status { font-size: 12px; }
.scene-actions { display: flex; gap: 8px; margin-top: 2px; }
.scene-actions .input { flex: 1; padding: 7px 11px; font-size: 13px; }
.retry-count { font-size: 11.5px; color: var(--warn); font-weight: 600; }

/* QA 배지: PASS 초록 / RETRY 주황 / REVIEW 빨강 / 립싱크 보라 */
.qa {
  display: inline-flex; align-items: center; padding: 2.5px 9px; border-radius: 999px;
  font-size: 10.5px; font-weight: 800; letter-spacing: 0.05em;
}
.qa-pass   { color: var(--ok); background: rgba(47, 214, 111, 0.12); border: 1px solid rgba(47, 214, 111, 0.4); }
.qa-retry  { color: var(--warn); background: rgba(255, 180, 84, 0.12); border: 1px solid rgba(255, 180, 84, 0.4); }
.qa-review { color: var(--danger); background: rgba(255, 84, 112, 0.12); border: 1px solid rgba(255, 84, 112, 0.45); }
.qa-lipsync { color: #b39dff; background: rgba(124, 92, 255, 0.14); border: 1px solid rgba(124, 92, 255, 0.5); }
.qa-legend { margin-bottom: 6px; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }

/* ========== 스텝⑥ 내보내기 ========== */
.master-video { width: 100%; max-height: 62vh; border-radius: 10px; background: #000; display: block; }
.master-video.vertical { max-width: 380px; margin: 0 auto; }
.thumb-preview { width: 100%; max-width: 560px; border-radius: 10px; display: block; border: 1px solid var(--border); }
.thumb-preview.vertical { max-width: 300px; }
.burn-row { display: flex; gap: 10px; margin-top: 14px; }
.burn-row .input { flex: 1; max-width: 420px; }

/* 키프레임 승인 게이트 */
.kf-gate { border-color: rgba(124, 92, 255, 0.45); }
.kf-gate h4 { margin: 0 0 6px; }
.gate-opt { display: block; margin-top: 12px; color: var(--text-dim, #8b90a0); font-size: 13px; cursor: pointer; user-select: none; }
.gate-opt input { accent-color: #7c5cff; margin-right: 6px; vertical-align: -2px; }

/* ========== 스텝① 곡 스타일 (선택) 패널 ========== */
.style-panel {
  margin: 14px 0 18px; border: 1px solid var(--border); border-radius: var(--radius);
  background: #10131b; overflow: hidden;
}
.style-head {
  width: 100%; display: flex; align-items: center; gap: 10px;
  padding: 14px 18px; background: transparent; border: none; text-align: left;
  color: var(--text); font-family: var(--font); font-size: 14px; font-weight: 700; cursor: pointer;
  transition: background var(--tr);
}
.style-head:hover { background: var(--card-2); }
.style-arrow { color: var(--muted); font-size: 12px; flex: none; }
.style-summary { margin-left: auto; font-weight: 500; flex: none; }
.style-body { padding: 2px 18px 18px; border-top: 1px solid var(--border); }
.style-note { margin: 12px 0 2px; }
.style-group { margin-top: 15px; }
.style-group > label { display: block; font-size: 12.5px; color: var(--muted); font-weight: 600; margin-bottom: 7px; }

/* 장르 프리셋 — 가로 스크롤 카드 */
.preset-row { display: flex; gap: 10px; overflow-x: auto; padding-bottom: 6px; -webkit-overflow-scrolling: touch; }
.preset-chip {
  flex: none; width: 172px; display: flex; flex-direction: column; gap: 3px;
  padding: 11px 13px; border-radius: 10px; text-align: left; cursor: pointer;
  background: var(--card-2); border: 1px solid var(--border); color: var(--text);
  font-family: var(--font); transition: border-color var(--tr), box-shadow var(--tr);
}
.preset-chip:hover { border-color: var(--accent); }
.preset-chip.on { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent), 0 0 14px rgba(124, 92, 255, 0.25); }
.preset-chip strong { font-size: 13px; line-height: 1.35; }
.preset-tag { font-size: 11.5px; color: var(--muted); }
.preset-bpm { font-size: 11px; color: var(--accent-2); font-weight: 600; }

/* 선택 칩 (무드·보컬·템포·기법) */
.schips { display: flex; flex-wrap: wrap; gap: 8px; }
.schip {
  padding: 6px 13px; border-radius: 999px; font-family: var(--font); font-size: 13px; font-weight: 600;
  color: var(--muted); background: var(--card-2); border: 1px solid var(--border); cursor: pointer;
  transition: color var(--tr), border-color var(--tr), background var(--tr);
}
.schip:hover { color: var(--text); border-color: var(--accent); }
.schip.on { color: var(--accent); border-color: var(--accent); background: rgba(124, 92, 255, 0.14); }

/* 내 프리셋 / 저장 */
.mine-row { display: flex; align-items: center; gap: 8px; }
.mine-row .input { max-width: 280px; }
.preset-save-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-top: 16px; }
.preset-save-row .preset-name { max-width: 220px; }

/* ========== 스텝① 곡 생성 모드 토글 (라벨 + 1줄 부제) ========== */
.mode-toggle {
  display: flex; gap: 0; margin-bottom: 18px;
  border: 1px solid var(--border); border-radius: 10px; overflow: hidden;
}
.mode-btn {
  flex: 1; min-width: 0; padding: 10px 12px;
  display: flex; flex-direction: column; align-items: center; gap: 3px; text-align: center;
  background: transparent; border: none; color: var(--muted);
  font-family: var(--font); font-size: 14px; font-weight: 600; cursor: pointer;
  transition: background var(--tr), color var(--tr);
}
.mode-btn + .mode-btn { border-left: 1px solid var(--border); }
.mode-btn.active { background: rgba(124, 92, 255, 0.16); color: var(--accent); }
.mode-btn-label { display: inline-flex; align-items: center; gap: 6px; font-size: 14px; font-weight: 700; }
.mode-sub { font-size: 11.5px; font-weight: 500; line-height: 1.4; color: var(--muted); word-break: keep-all; }
.mode-badge {
  display: inline-flex; align-items: center; padding: 1px 7px; border-radius: 999px;
  font-size: 10px; font-weight: 800; letter-spacing: 0.03em;
  color: var(--accent-2); background: rgba(0, 229, 195, 0.08); border: 1px solid rgba(0, 229, 195, 0.4);
}

/* 온보딩 흐름 배너 — 컴팩트 1줄 카드 */
.onboard-banner {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  padding: 10px 14px; margin-bottom: 14px;
  background: rgba(124, 92, 255, 0.08); border: 1px solid rgba(124, 92, 255, 0.3);
  border-radius: 10px; font-size: 13px;
}
.onboard-text { flex: 1; min-width: 200px; word-break: keep-all; }
.onboard-banner .btn { flex: none; margin-left: auto; }

.topic-input { min-height: 84px; }
.draft-card {
  margin-top: 4px; padding: 18px;
  background: #10131b; border: 1px solid var(--border); border-radius: var(--radius);
}
.draft-title { font-weight: 700; }
.draft-lyrics { min-height: 320px; line-height: 1.7; }

/* 추천 스타일 3개 — 라디오 카드 */
.style-opt-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.style-opt {
  display: flex; flex-direction: column; gap: 6px; padding: 14px; text-align: left;
  background: var(--card-2); border: 1px solid var(--border); border-radius: 10px;
  color: var(--text); font-family: var(--font); cursor: pointer;
  transition: border-color var(--tr), box-shadow var(--tr);
}
.style-opt:hover { border-color: var(--accent); }
.style-opt.on { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent), 0 0 14px rgba(124, 92, 255, 0.25); }
.style-opt strong { font-size: 13.5px; line-height: 1.35; }
.style-opt-why { font-size: 12.5px; color: var(--accent-2); line-height: 1.45; }
.style-opt-preview { font-size: 11.5px; line-height: 1.5; word-break: break-word; }

/* ========== 스텝① 레퍼런스 곡 모드 ========== */
.ref-hint { min-height: 70px; }
.ref-status { display: flex; align-items: center; gap: 8px; margin: 4px 0 10px; }
.ref-card {
  margin-top: 4px; padding: 18px;
  background: #10131b; border: 1px solid rgba(0, 229, 195, 0.3); border-radius: var(--radius);
}
.ref-head { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 10px; }
.ref-head h4 { margin-bottom: 0; }
.ref-badge {
  display: inline-flex; align-items: center; padding: 2.5px 10px; border-radius: 999px;
  font-size: 11.5px; font-weight: 700; letter-spacing: 0.02em;
  color: var(--accent-2); background: rgba(0, 229, 195, 0.08); border: 1px solid rgba(0, 229, 195, 0.35);
}
.ref-badge.mood { color: var(--accent); background: rgba(124, 92, 255, 0.1); border-color: rgba(124, 92, 255, 0.4); }
.ref-summary { font-size: 14px; line-height: 1.6; margin-bottom: 8px; }
.ref-hint-line { margin-bottom: 6px; }
.ref-traits { line-height: 1.55; word-break: break-word; margin-bottom: 8px; }

/* ========== 스텝① 추천 구간 (하이라이트 자동 탐지) ========== */
.seg-suggest-row { display: flex; align-items: center; gap: 10px; margin-top: 12px; }
.seg-len-sel { width: 92px; padding: 6px 11px; font-size: 13px; }
.seg-reason { margin-top: 8px; color: var(--accent-2); }

/* ========== 스텝③ 컨셉 추천 ========== */
.concept-card { margin-bottom: 20px; border-color: rgba(124, 92, 255, 0.35); }
.concept-loading { display: flex; align-items: center; gap: 10px; color: var(--muted); font-size: 13px; padding: 16px 0 4px; }
.concept-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 14px; }
.concept-item {
  display: flex; flex-direction: column; gap: 10px; padding: 16px;
  background: var(--card-2); border: 1px solid var(--border); border-radius: 10px;
  transition: border-color var(--tr);
}
.concept-item:hover { border-color: var(--accent); }
.concept-item h5 { font-size: 14.5px; font-weight: 700; }
.concept-summary { line-height: 1.5; }
.concept-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.arc-row { display: flex; flex-direction: column; gap: 4px; }
.arc-badge {
  display: inline-flex; align-items: baseline; gap: 6px; align-self: flex-start;
  font-size: 11.5px; padding: 3px 9px; border-radius: 7px;
  border: 1px solid var(--border); background: #0f1219; color: var(--text);
}
.arc-badge .arc-num { font-size: 10px; font-weight: 800; letter-spacing: 0.05em; }
.arc-badge.a1 { border-color: rgba(124, 92, 255, 0.45); } .arc-badge.a1 .arc-num { color: var(--accent); }
.arc-badge.a2 { border-color: rgba(255, 180, 84, 0.4); }  .arc-badge.a2 .arc-num { color: var(--warn); }
.arc-badge.a3 { border-color: rgba(0, 229, 195, 0.4); }   .arc-badge.a3 .arc-num { color: var(--accent-2); }
.concept-item .btn { margin-top: auto; align-self: flex-start; }

/* ============================================================
 * 반응형 — 모바일 전면 대응 (720px 태블릿/모바일 · 480px 소형)
 * ============================================================ */

@media (max-width: 720px) {
  /* 레이아웃 · 패딩 */
  .container { padding: 16px 16px 60px; }
  .card { padding: 16px; }
  .card + .card { margin-top: 16px; }

  /* 상단바 — 로고 축약(MV), 크레딧 뱃지 유지 */
  .topbar-inner { padding: 8px 14px; }
  .logo-text { display: none; }

  /* 토스트 풀폭 (좌우 12px) */
  #toasts { left: 12px; right: 12px; width: auto; transform: none; }
  .toast { width: 100%; text-align: center; }

  /* 스텝바 — 활성 스텝만 라벨, 가로 스크롤(스크롤바 숨김), 연결선 축소 */
  .stepbar { padding: 10px 12px; gap: 4px; scrollbar-width: none; }
  .stepbar::-webkit-scrollbar { display: none; }
  .step:not(.active) .step-label { display: none; }
  .step-line { flex: none; width: 10px; min-width: 10px; }

  /* 터치 타깃 — 버튼 44px · 칩 40px · 입력 16px(iOS 자동 줌 방지) */
  .btn { min-height: 44px; }
  .tab, .aspect-btn, .mode-btn, .style-head { min-height: 44px; }
  .step { min-height: 40px; }
  .icon-btn { min-height: 40px; min-width: 40px; }
  .chip, .schip { min-height: 40px; }
  .preset-chip { min-height: 44px; }
  .input, select.input, textarea.input,
  .scene-actions .input, .seg-len-sel { font-size: 16px; }

  /* 카드 그리드 — 프로젝트·캐릭터·컨셉·컷 2열 */
  .grid-cards { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .scene-grid, .scene-grid.v-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .concept-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .track-grid { grid-template-columns: 1fr; }
  .style-opt-grid { grid-template-columns: 1fr; }

  /* 모드 토글 — 세로 스택(풀폭) + 부제 표시 */
  .mode-toggle { flex-direction: column; }
  .mode-btn { width: 100%; align-items: flex-start; text-align: left; }
  .mode-btn + .mode-btn { border-left: none; border-top: 1px solid var(--border); }

  /* 챗 UI · 구간 선택 폼 · 각종 입력 풀폭 */
  .chat-box { height: 320px; }
  .bubble { max-width: 90%; }
  .seg-row { flex-direction: column; align-items: stretch; gap: 12px; }
  .seg-field { width: 100%; }
  .seg-input-row { width: 100%; }
  .seg-num { flex: 1; width: auto; min-width: 0; }
  .seg-len { padding-bottom: 0; }
  .mine-row .input, .preset-save-row .preset-name { max-width: none; flex: 1; }
  .persona-row .input { max-width: none; }
  .burn-row { flex-direction: column; }
  .burn-row .input { max-width: none; }
  .scene-actions { flex-direction: column; }

  /* 플레이어 */
  .master-video.vertical, .thumb-preview.vertical { max-width: 100%; }
}

@media (max-width: 480px) {
  .container { padding: 12px 12px 48px; }
  .card { padding: 14px; }
  h2 { font-size: 19px; }

  /* 카드 그리드 — 1열 */
  .grid-cards { grid-template-columns: 1fr; }
  .scene-grid, .scene-grid.v-grid { grid-template-columns: 1fr; }
  .concept-grid { grid-template-columns: 1fr; }

  .chat-box { height: 280px; }
  .onboard-banner .btn { margin-left: 0; width: 100%; }
}

/* ========== 랜딩 (홍보 첫 화면) ========== */
.landing { min-height: 100vh; display: flex; flex-direction: column; }
.landing-top {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 26px; position: relative; z-index: 2;
}
.landing-top-right { display: flex; gap: 10px; align-items: center; }

.landing-hero { position: relative; text-align: center; padding: 84px 20px 56px; overflow: clip; }
.hero-glow { position: absolute; border-radius: 50%; filter: blur(90px); pointer-events: none; }
.hero-glow.g1 { width: 440px; height: 440px; background: var(--accent); opacity: 0.32; top: -140px; left: 50%; transform: translateX(-85%); }
.hero-glow.g2 { width: 400px; height: 400px; background: var(--accent-2); opacity: 0.14; top: 30px; left: 50%; transform: translateX(5%); }
.hero-eyebrow { letter-spacing: 0.42em; font-size: 11px; font-weight: 700; color: var(--accent-2); text-indent: 0.42em; }
.hero-title { font-size: 52px; line-height: 1.16; font-weight: 800; letter-spacing: -0.02em; margin: 18px 0 16px; position: relative; }
.hero-title .grad {
  background: linear-gradient(92deg, #a78bfa 10%, #7c5cff 45%, #22d3ee 95%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.hero-sub { color: var(--muted); font-size: 17px; line-height: 1.75; max-width: 540px; margin: 0 auto 30px; position: relative; }
.hero-cta { display: flex; flex-direction: column; align-items: center; gap: 12px; position: relative; }
.btn-lg { padding: 14px 36px; font-size: 17px; border-radius: 14px; font-weight: 700; }
.hero-hint { font-size: 12px; }

/* 이퀄라이저 (순수 CSS 감성 비주얼) */
.eq { display: flex; gap: 5px; justify-content: center; align-items: flex-end; height: 48px; margin-top: 56px; position: relative; }
.eq-bar {
  width: 5px; border-radius: 3px; height: 30%;
  background: linear-gradient(180deg, #a78bfa, #22d3ee);
  animation: eqb 1.1s ease-in-out infinite alternate;
}
@keyframes eqb { from { height: 12%; opacity: 0.4; } to { height: 100%; opacity: 1; } }
@media (prefers-reduced-motion: reduce) { .eq-bar { animation: none; height: 55%; } }

.landing-h2 { text-align: center; font-size: 28px; margin-bottom: 26px; letter-spacing: -0.01em; }

/* 4스텝 플로우 */
.landing-flow { padding: 44px 20px 10px; }
.flow-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; max-width: 1080px; margin: 0 auto; }
.flow-card { position: relative; padding: 22px 18px 18px; }
.flow-num {
  position: absolute; top: 14px; right: 16px;
  font-size: 30px; font-weight: 800; color: var(--border); line-height: 1;
}
.flow-icon { font-size: 26px; margin-bottom: 10px; }
.flow-card h3 { margin-bottom: 6px; }
.flow-card p { line-height: 1.6; }

/* 디테일 포인트 */
.landing-feats {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px;
  max-width: 880px; margin: 0 auto; padding: 44px 20px 8px;
}
.feat-card { display: flex; gap: 12px; align-items: flex-start; padding: 14px 16px; border: 1px solid var(--border); border-radius: var(--radius); background: rgba(20, 23, 31, 0.6); }
.feat-icon { font-size: 22px; line-height: 1.3; }
.feat-card h4 { margin-bottom: 3px; }
.feat-card p { line-height: 1.55; }

/* 마무리 CTA + 푸터 */
.landing-cta2 { text-align: center; padding: 72px 20px 84px; }
.landing-cta2 p { margin: 8px 0 24px; }
.landing-foot { text-align: center; color: var(--muted); font-size: 12px; padding: 18px; border-top: 1px solid var(--border); margin-top: auto; }

/* 구글 로그인 버튼 */
.btn-google {
  background: #fff; color: #1f1f1f; border: 1px solid #dadce0;
  display: inline-flex; align-items: center; justify-content: center; gap: 9px; font-weight: 600;
}
.btn-google:hover:not(:disabled) { background: #f1f3f6; border-color: #c6cad1; }
.gmark {
  width: 20px; height: 20px; border-radius: 50%; flex: none;
  background: #fff; color: #4285f4; box-shadow: inset 0 0 0 1.5px #dadce0;
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 12px; font-family: Arial, Helvetica, sans-serif;
}
.gauth-row { margin-bottom: 16px; }
.or-sep { display: flex; align-items: center; gap: 12px; color: var(--muted); font-size: 12px; margin-top: 16px; }
.or-sep::before, .or-sep::after { content: ""; flex: 1; height: 1px; background: var(--border); }
.auth-back { margin-top: 16px; text-align: center; font-size: 13px; }

/* 랜딩 모바일 */
@media (max-width: 860px) {
  .flow-grid { grid-template-columns: repeat(2, 1fr); }
  .landing-feats { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .landing-top { padding: 12px 14px; }
  .landing-hero { padding: 56px 18px 40px; }
  .hero-title { font-size: 34px; }
  .hero-sub { font-size: 15px; }
  .landing-h2 { font-size: 22px; }
  .landing-top-right .btn { min-height: 40px; }
}
@media (max-width: 480px) {
  .flow-grid { grid-template-columns: 1fr; }
  .hero-title { font-size: 30px; }
  .landing-top-right { gap: 6px; }
}

/* ============================================================
 * CF 스튜디오 (Phase 1) — cf- 접두 클래스, 기존 변수 재사용 (추가 전용)
 * ============================================================ */

/* 대시보드 세그먼트 탭 + 타입 배지 */
.cf-dash-tabs { margin-bottom: 20px; }
.chip-mini.cf-type-mv { color: #b39dff; border-color: rgba(124, 92, 255, 0.45); background: rgba(124, 92, 255, 0.09); }
.chip-mini.cf-type-cf { color: var(--accent-2); border-color: rgba(0, 229, 195, 0.45); background: rgba(0, 229, 195, 0.08); }
.chip-mini.cf-format-chip { color: var(--muted); border-color: var(--border); background: rgba(139, 144, 160, 0.08); }
.cf-new-card:hover { border-color: var(--accent-2); color: var(--accent-2); box-shadow: 0 0 20px rgba(0, 229, 195, 0.15); }

/* 랜딩 2제품 카드 */
.cf-landing-products {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px;
  max-width: 880px; margin: 0 auto; padding: 36px 20px 0; position: relative;
}
.cf-product-card { text-align: left; padding: 22px; }
.cf-product-card:hover { border-color: var(--accent); }
.cf-product-icon { font-size: 26px; display: block; margin-bottom: 10px; }
.cf-product-card h3 { margin-bottom: 6px; }
.cf-product-card p { line-height: 1.6; }
.cf-products-sub { text-align: center; margin-top: 12px; }

/* 공통 그룹 (브리프·제품·BGM 카드 내부) */
.cf-group { margin-top: 15px; }
.cf-group > label { display: block; font-size: 12.5px; color: var(--muted); font-weight: 600; margin-bottom: 7px; }
.cf-group-sub { margin: -3px 0 7px; }
.cf-kb-badge { margin-top: 8px; color: var(--accent-2); font-size: 12.5px; }

/* 브리프 — 접근 A·B·C 카드 */
.cf-brief-card h4 { margin-bottom: 4px; }
.cf-approach-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 12px; }
.cf-approach-card {
  display: flex; flex-direction: column; gap: 6px; padding: 14px; text-align: left;
  background: var(--card-2); border: 1px solid var(--border); border-radius: 10px;
  color: var(--text); font-family: var(--font); cursor: pointer;
  transition: border-color var(--tr), box-shadow var(--tr);
}
.cf-approach-card:hover { border-color: var(--accent); }
.cf-approach-card.on { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent), 0 0 14px rgba(124, 92, 255, 0.25); }
.cf-approach-card strong { font-size: 13.5px; display: inline-flex; align-items: center; gap: 6px; }
.cf-approach-card span:not(.mode-badge):not(.cf-tag-warn) { font-size: 12px; color: var(--muted); line-height: 1.5; }
.cf-tag-warn { color: var(--warn); font-size: 12px; }

/* 브랜드 컬러 입력 */
.cf-color-row { display: flex; align-items: center; gap: 10px; }
.cf-color-row input[type="color"] {
  width: 46px; height: 40px; padding: 3px; flex: none;
  border-radius: 9px; border: 1px solid var(--border); background: #0f1219; cursor: pointer;
}
.cf-color-row .input { max-width: 160px; }

/* 제품 — 드롭존·누끼·팩샷·로고 */
.cf-dropzone {
  margin-top: 14px; border: 2px dashed #2d3342; border-radius: 12px;
  padding: 30px 20px; text-align: center; cursor: pointer;
  transition: border-color var(--tr), background var(--tr);
}
.cf-dropzone:hover, .cf-dropzone.drag { border-color: var(--accent); background: rgba(124, 92, 255, 0.06); }
.cf-drop-icon { font-size: 30px; display: block; margin-bottom: 8px; }
.cf-file-label { margin-top: 8px; }
.cf-cutout-preview {
  max-width: 240px; max-height: 240px; display: block; margin-bottom: 12px;
  border-radius: 10px; border: 1px solid var(--border); background: #0f1219;
}
.cf-pack-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 12px; }
.cf-pack-card {
  display: flex; flex-direction: column; gap: 8px; padding: 12px;
  background: var(--card-2); border: 1px solid var(--border); border-radius: 10px;
}
.cf-pack-card.locked { border-color: var(--accent-2); box-shadow: 0 0 0 1px var(--accent-2), 0 0 14px rgba(0, 229, 195, 0.2); }
.cf-pack-card img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; border-radius: 8px; background: #0f1219; display: block; }
.cf-pack-card strong { font-size: 13px; }
.cf-logo-preview {
  max-height: 64px; margin: 6px 0 12px; display: block;
  padding: 8px; border-radius: 8px; border: 1px solid var(--border); background: #0f1219;
}
.cf-logo-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.cf-logo-row .file-input { flex: 1; min-width: 200px; }

/* 스토리보드 — 포맷 프리셋 카드 */
.cf-preset-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.cf-preset-card {
  display: flex; flex-direction: column; gap: 4px; padding: 13px; text-align: left;
  background: var(--card-2); border: 1px solid var(--border); border-radius: 10px;
  color: var(--text); font-family: var(--font); cursor: pointer;
  transition: border-color var(--tr), box-shadow var(--tr);
}
.cf-preset-card:hover:not(:disabled) { border-color: var(--accent); }
.cf-preset-card:disabled { opacity: 0.5; cursor: not-allowed; }
.cf-preset-card.on { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent), 0 0 14px rgba(124, 92, 255, 0.25); }
.cf-preset-card strong { font-size: 13.5px; }
.cf-preset-card .muted { font-size: 12px; }
.cf-preset-desc { line-height: 1.45; }
.cf-preset-price { font-size: 12px; color: var(--accent-2); font-weight: 700; margin-top: 2px; }

/* 스토리보드 — 컷 테이블 */
.cf-sb-summary { margin-bottom: 10px; line-height: 1.6; }
.cf-table-wrap { overflow-x: auto; margin-top: 10px; -webkit-overflow-scrolling: touch; }
.cf-cut-table { width: 100%; border-collapse: collapse; font-size: 13px; min-width: 820px; }
.cf-cut-table th {
  text-align: left; color: var(--muted); font-size: 12px; font-weight: 600;
  padding: 8px 10px; border-bottom: 1px solid var(--border); white-space: nowrap;
}
.cf-cut-table td { padding: 8px 10px; border-bottom: 1px solid rgba(35, 39, 51, 0.6); vertical-align: top; }
.cf-cut-table .input { padding: 6px 9px; font-size: 13px; min-width: 150px; }
.cf-scene-sum { max-width: 260px; line-height: 1.5; color: var(--text); }
.cf-act {
  display: inline-flex; padding: 2px 8px; border-radius: 7px; font-size: 11px; font-weight: 700;
  color: var(--muted); border: 1px solid var(--border); white-space: nowrap;
}

/* 제품 역할 배지 */
.cf-role { display: inline-flex; padding: 2px 8px; border-radius: 7px; font-size: 11px; font-weight: 700; white-space: nowrap; }
.cf-role-absent { color: var(--muted); border: 1px solid var(--border); }
.cf-role-hint { color: var(--warn); border: 1px solid rgba(255, 180, 84, 0.4); background: rgba(255, 180, 84, 0.08); }
.cf-role-hero { color: var(--accent); border: 1px solid rgba(124, 92, 255, 0.45); background: rgba(124, 92, 255, 0.1); }
.cf-role-pack { color: var(--accent-2); border: 1px solid rgba(0, 229, 195, 0.4); background: rgba(0, 229, 195, 0.07); }

/* 게이트A 승인 바 */
.cf-approve-bar {
  display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap;
  margin-top: 16px; padding: 14px 16px; border-radius: 10px;
  border: 1px solid rgba(124, 92, 255, 0.35); background: rgba(124, 92, 255, 0.06);
}
.cf-estimate { font-size: 13px; color: var(--text); font-weight: 600; }
.cf-approve-btns { display: flex; gap: 10px; flex-wrap: wrap; }

/* 리뷰 컷 카드 — 카피 라인 */
.cf-copy-line { font-size: 12px; line-height: 1.5; word-break: break-word; }

/* 납품 — BGM */
.cf-bgm-tracks { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-top: 12px; }
.cf-bgm-upload { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--border); }
.cf-bgm-upload p { margin-bottom: 8px; }

/* 반응형 — 기존 모바일 규칙과 동일 수준 (720px / 480px) */
@media (max-width: 720px) {
  .cf-landing-products { grid-template-columns: 1fr; padding-top: 28px; }
  .cf-approach-grid { grid-template-columns: 1fr; }
  .cf-approach-card, .cf-preset-card { min-height: 44px; }
  .cf-preset-grid { grid-template-columns: repeat(2, 1fr); }
  .cf-pack-grid { grid-template-columns: repeat(2, 1fr); }
  .cf-bgm-tracks { grid-template-columns: 1fr; }
  .cf-approve-bar { flex-direction: column; align-items: stretch; }
  .cf-approve-btns { flex-direction: column; }
  .cf-approve-btns .btn { width: 100%; }
  .cf-cut-table .input { font-size: 16px; } /* iOS 자동 줌 방지 */
  .cf-color-row .input { max-width: none; flex: 1; }
  .cf-dropzone { padding: 24px 14px; }
}
@media (max-width: 480px) {
  .cf-preset-grid { grid-template-columns: 1fr; }
  .cf-pack-grid { grid-template-columns: 1fr; }
  .cf-dash-tabs .tab { padding: 9px 12px; font-size: 13px; }
}

/* 히어로 듀얼 그라디언트 — CF(광고)는 틸→그린 계열로 MV(보라)와 구분 */
.hero-title .grad-cf {
  background: linear-gradient(92deg, #22d3ee 5%, #00e5c3 55%, #4ade80 95%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

/* ============================================================
 * 가격 페이지 (#/pricing) — pr- 접두 클래스 (추가 전용, 기존 규칙 수정 없음)
 * ============================================================ */

/* 헤더 */
.pr-container { padding-top: 22px; }
.pr-head { text-align: center; padding: 26px 0 8px; }
.pr-title { font-size: 34px; font-weight: 800; letter-spacing: -0.02em; }
.pr-sub { margin-top: 8px; font-size: 15px; }
.pr-sec-head { text-align: center; margin: 46px 0 18px; }
.pr-sec-head h3 { font-size: 21px; letter-spacing: -0.01em; }
.pr-sec-head p { margin-top: 4px; }

/* 플랜 카드 4장 */
.pr-plan-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-top: 30px; align-items: stretch; }
.pr-plan-grid .card + .card { margin-top: 0; } /* 그리드 안에서는 카드 간 세로 마진 무효 */
.pr-plan-card { position: relative; display: flex; flex-direction: column; gap: 12px; padding: 24px 20px 20px; }
.pr-plan-card.pr-popular { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent), 0 10px 34px rgba(124, 92, 255, 0.22); }
.pr-plan-card.pr-current { border-color: rgba(0, 229, 195, 0.55); }
.pr-pop-badge {
  position: absolute; top: -11px; left: 50%; transform: translateX(-50%);
  padding: 3px 13px; border-radius: 999px; font-size: 11px; font-weight: 800; letter-spacing: 0.04em;
  color: #fff; background: linear-gradient(135deg, var(--accent), #5d3fe0);
  box-shadow: 0 4px 14px rgba(124, 92, 255, 0.4);
}
.pr-plan-top { display: flex; align-items: center; gap: 8px; }
.pr-plan-name { font-size: 17px; }
.pr-price-num { font-size: 28px; font-weight: 800; letter-spacing: -0.02em; }
.pr-price-unit { color: var(--muted); font-size: 13px; font-weight: 600; }
.pr-feats { list-style: none; display: flex; flex-direction: column; gap: 6px; font-size: 13.5px; }
.pr-feats li::before { content: "✓ "; color: var(--accent-2); font-weight: 700; }
.pr-eff { color: var(--accent-2); font-weight: 700; }
.pr-desc { line-height: 1.55; margin-top: auto; }

/* 충전 팩 — 가로 카드 3종 */
.pr-pack-list { display: flex; flex-direction: column; gap: 12px; max-width: 720px; margin: 0 auto; }
.pr-pack-list .card + .card { margin-top: 0; }
.pr-pack-card { position: relative; display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; padding: 18px 22px; }
.pr-pack-card.pr-popular { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent), 0 6px 24px rgba(124, 92, 255, 0.18); }
.pr-pack-card .pr-pop-badge { left: 24px; transform: none; }
.pr-pack-info { display: flex; flex-direction: column; gap: 3px; }
.pr-pack-cr { font-size: 17px; font-weight: 800; }
.pr-pack-buy { display: flex; align-items: center; gap: 14px; }
.pr-pack-price { font-size: 17px; font-weight: 800; color: var(--accent-2); }

/* 제품별 예상 비용 표 — 모바일 가로 스크롤 */
.pr-table-wrap {
  overflow-x: auto; -webkit-overflow-scrolling: touch;
  max-width: 880px; margin: 0 auto;
  border: 1px solid var(--border); border-radius: var(--radius);
}
.pr-table { width: 100%; border-collapse: collapse; font-size: 13.5px; min-width: 640px; }
.pr-table th {
  text-align: left; color: var(--muted); font-size: 12px; font-weight: 600;
  padding: 11px 16px; border-bottom: 1px solid var(--border); background: var(--card); white-space: nowrap;
}
.pr-table td { padding: 11px 16px; border-bottom: 1px solid rgba(35, 39, 51, 0.6); background: rgba(20, 23, 31, 0.5); }
.pr-table tbody tr:last-child td { border-bottom: none; }
.pr-table .pr-num { font-weight: 700; color: var(--text); white-space: nowrap; }
.pr-table-note { text-align: center; margin-top: 10px; }

/* FAQ 아코디언 (네이티브 details) */
.pr-faq-list { max-width: 720px; margin: 0 auto; display: flex; flex-direction: column; gap: 10px; }
.pr-faq { border: 1px solid var(--border); border-radius: 10px; background: var(--card); padding: 0 16px; }
.pr-faq summary { cursor: pointer; padding: 13px 4px; font-size: 14px; font-weight: 600; list-style: none; }
.pr-faq summary::-webkit-details-marker { display: none; }
.pr-faq summary::before { content: "▸ "; color: var(--accent-2); }
.pr-faq[open] summary::before { content: "▾ "; }
.pr-faq p { padding: 0 4px 14px; line-height: 1.65; }

/* 하단 고지 */
.pr-demo-note { text-align: center; margin: 48px 0 8px; font-size: 13px; font-weight: 600; color: var(--warn); }

/* 비로그인 단독 페이지 — 랜딩식 헤더/푸터 사이 본문이 밀리지 않게 */
.pr-standalone .pr-container { flex: 1; width: 100%; }

/* 랜딩 히어로 가격 링크 */
.hero-price-link { font-size: 13px; font-weight: 600; position: relative; }
.hero-price-link:hover { text-decoration: underline; }

/* 크레딧 배지 링크화 (클릭 → #/pricing) */
a.credit-badge { cursor: pointer; transition: background var(--tr), border-color var(--tr); }
a.credit-badge:hover { background: rgba(0, 229, 195, 0.14); border-color: rgba(0, 229, 195, 0.6); }

/* 반응형 — 기존 브레이크포인트(720px/480px)와 동일 수준 */
@media (max-width: 980px) {
  .pr-plan-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 720px) {
  .pr-plan-grid { grid-template-columns: 1fr; } /* 플랜 카드 1열 */
  .pr-title { font-size: 26px; }
  .pr-sec-head { margin: 36px 0 14px; }
  .pr-pack-card { flex-direction: column; align-items: stretch; }
  .pr-pack-buy { justify-content: space-between; }
}
@media (max-width: 480px) {
  .pr-container { padding-left: 16px; padding-right: 16px; }
  .pr-pack-buy { flex-direction: column; align-items: stretch; }
  .pr-pack-buy .btn { width: 100%; }
}

/* ============================================================
 * 무비 스튜디오 (영화·드라마) — mv- 접두 신규 클래스만 (MOVIE-SPEC 프론트)
 * ============================================================ */

/* 타입 칩 · 대시보드 새 카드 · 랜딩 3제품 */
.mv-movie-type { color: var(--warn); border-color: rgba(255, 180, 84, 0.4); background: rgba(255, 180, 84, 0.07); }
.mv-movie-new-card:hover { border-color: var(--warn); color: var(--warn); box-shadow: 0 0 20px rgba(255, 180, 84, 0.15); }
.mv-landing-3 { grid-template-columns: repeat(3, 1fr); max-width: 1100px; }

/* ① 이야기 — 입력·결정 카드 */
.mv-story-input { min-height: 150px; resize: vertical; line-height: 1.6; }
.mv-script-badge {
  display: inline-flex; align-items: center; gap: 6px; margin-bottom: 14px;
  padding: 7px 14px; border-radius: 999px; font-family: var(--font); font-size: 13px; font-weight: 600;
  color: var(--muted); background: var(--card-2); border: 1px dashed var(--border); cursor: pointer;
  transition: color var(--tr), border-color var(--tr), background var(--tr);
}
.mv-script-badge.on { color: var(--warn); border-color: rgba(255, 180, 84, 0.5); background: rgba(255, 180, 84, 0.08); }
.mv-decision-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 14px; }
.mv-decision-grid .mv-span2 { grid-column: 1 / -1; }
.mv-chip-list { display: flex; flex-wrap: wrap; gap: 6px; }

/* ② 인물·장소 카드 */
.mv-char-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-top: 10px; }
.mv-char-grid .card + .card { margin-top: 0; }
.mv-char-card { display: flex; flex-direction: column; gap: 4px; }
.mv-char-head { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 4px; }
.mv-tier-lead { color: var(--accent); border-color: rgba(124, 92, 255, 0.45); background: rgba(124, 92, 255, 0.1); }
.mv-tier-support { color: var(--accent-2); }
.mv-tier-extra { color: var(--muted); border-color: var(--border); background: transparent; }
.mv-anchors-input { min-height: 76px; resize: vertical; line-height: 1.55; }
.mv-anchors-view { font-size: 13px; line-height: 1.6; white-space: pre-wrap; word-break: break-word; }

/* ③ 스토리보드 — 요약 바 · 씬 아코디언 · 컷 행 */
.mv-summary-bar {
  display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap;
  padding: 12px 16px; margin-bottom: 14px; font-size: 14px; font-weight: 700;
  border: 1px solid var(--border); border-radius: var(--radius); background: var(--card);
}
.mv-acc-list { margin-bottom: 16px; }
.mv-acc { border: 1px solid var(--border); border-radius: var(--radius); background: var(--card); overflow: hidden; }
.mv-acc + .mv-acc { margin-top: 10px; }
.mv-acc summary { cursor: pointer; padding: 12px 16px; font-size: 14px; list-style: none; }
.mv-acc summary::-webkit-details-marker { display: none; }
.mv-acc summary::before { content: "▸ "; color: var(--accent-2); }
.mv-acc[open] summary::before { content: "▾ "; }
.mv-cut-row {
  display: grid; grid-template-columns: 52px 92px minmax(0, 1fr) 180px 44px 100px;
  gap: 8px; align-items: center; padding: 8px 16px; border-top: 1px solid rgba(35, 39, 51, 0.6);
}
.mv-kind {
  display: inline-block; padding: 2px 8px; border-radius: 999px; text-align: center;
  font-size: 11px; font-weight: 700; letter-spacing: 0.02em; white-space: nowrap;
}
.mv-kind-dialogue { color: var(--accent); border: 1px solid rgba(124, 92, 255, 0.45); background: rgba(124, 92, 255, 0.1); }
.mv-kind-narration { color: var(--accent-2); border: 1px solid rgba(0, 229, 195, 0.4); background: rgba(0, 229, 195, 0.07); }
.mv-kind-action { color: var(--muted); border: 1px solid var(--border); background: var(--card-2); }
.mv-cut-speaker { font-size: 12.5px; font-weight: 700; overflow-wrap: anywhere; }
.mv-cut-sec { font-size: 12px; text-align: right; white-space: nowrap; }
.mv-lip-toggle {
  padding: 5px 8px; border-radius: 999px; font-family: var(--font); font-size: 11.5px; font-weight: 700;
  color: var(--muted); background: var(--card-2); border: 1px solid var(--border); cursor: pointer;
  transition: color var(--tr), border-color var(--tr), background var(--tr); white-space: nowrap;
}
.mv-lip-toggle:hover { border-color: var(--warn); color: var(--warn); }
.mv-lip-toggle.on { color: var(--warn); border-color: rgba(255, 180, 84, 0.55); background: rgba(255, 180, 84, 0.1); }
.mv-lip-spacer { display: inline-block; }

/* ③ 목소리 패널 · 승인 바 견적 */
.mv-voice-panel .cf-group + .cf-group { margin-top: 14px; }
.mv-voice-rows { display: flex; flex-direction: column; gap: 8px; }
.mv-voice-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.mv-voice-name { min-width: 110px; font-weight: 600; font-size: 13.5px; }
.mv-voice-sel { max-width: 280px; }
.mv-est { font-size: 13px; font-weight: 600; line-height: 1.6; word-break: keep-all; overflow-wrap: anywhere; }

/* ⑤ 리뷰 — 씬 헤더 */
.mv-scene-head { display: flex; align-items: baseline; gap: 8px; margin: 20px 0 10px; font-size: 14px; }
.mv-scene-head:first-child { margin-top: 0; }

/* ⑥ 납품 — 썸네일 선택 · 패키지 */
.mv-thumb-cur { display: block; max-width: 340px; width: 100%; margin-top: 8px; border-radius: 10px; border: 1px solid var(--border); }
.mv-thumb-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-top: 10px; }
.mv-thumb-pick { display: flex; flex-direction: column; gap: 6px; }
.mv-thumb-pick img { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; border-radius: 8px; border: 1px solid var(--border); }
.mv-pkg-text { white-space: pre-wrap; line-height: 1.6; font-size: 14px; word-break: break-word; }

/* 반응형 — 기존 브레이크포인트(720px/480px)와 동일 수준 */
@media (max-width: 720px) {
  .mv-landing-3 { grid-template-columns: 1fr; }
  .mv-char-grid { grid-template-columns: 1fr; }
  .mv-decision-grid { grid-template-columns: 1fr; }
  .mv-cut-row { grid-template-columns: minmax(0, 1fr) auto; }
  .mv-cut-content, .mv-cut-camera { grid-column: 1 / -1; }
  .mv-thumb-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .mv-voice-row { flex-direction: column; align-items: stretch; gap: 4px; }
  .mv-voice-sel { max-width: none; }
  .mv-summary-bar { font-size: 13px; }
  .mv-lip-toggle { min-height: 40px; }
}

/* 언어 스위처 — 🌐 고스트 필 (input 스타일 아님) */
.lang-wrap { position: relative; display: inline-flex; align-items: center; flex: none; }
.lang-ico { position: absolute; left: 11px; font-size: 12px; pointer-events: none; opacity: 0.75; }
.lang-sel {
  appearance: none; -webkit-appearance: none;
  background: rgba(255, 255, 255, 0.05);
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5'%3E%3Cpath d='M0 0l4 5 4-5z' fill='%238b90a0'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 11px center;
  border: 1px solid rgba(255, 255, 255, 0.08); border-radius: 999px;
  color: var(--muted); font-size: 12.5px; font-family: var(--font);
  padding: 7px 27px 7px 30px; cursor: pointer; transition: border-color var(--tr), color var(--tr);
}
.lang-sel:hover { border-color: rgba(255, 255, 255, 0.22); color: var(--text); }
.lang-sel:focus { outline: none; border-color: var(--accent); }
.lang-sel option { background: var(--card); color: var(--text); }
.auth-lang { margin-top: 12px; display: flex; justify-content: center; }

/* 버튼 줄바꿈 금지 — 좁은 컨테이너에서 글자가 세로로 꺾이는 문제 방지 */
.btn { white-space: nowrap; flex: none; }
.landing-top-right { flex-wrap: nowrap; }
.landing-top-right .btn-google { box-shadow: 0 2px 14px rgba(255, 255, 255, 0.10); }

/* 히어로 영화 그라디언트 — 시네마틱 앰버 */
.hero-title .grad-movie {
  background: linear-gradient(92deg, #fbbf24 10%, #f59e0b 50%, #fb7185 95%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

/* ── 정책 페이지 (#/privacy · #/terms) ── */
.policy-page .policy-card { max-width: 760px; margin: 28px auto 40px; padding: 36px 40px; text-align: left; }
.policy-card h1 { font-size: 26px; margin: 0 0 4px; }
.policy-date { font-size: 13px; margin: 0 0 22px; }
.policy-card h3 { font-size: 16px; margin: 26px 0 8px; color: var(--text); }
.policy-card p { color: var(--muted); font-size: 14.5px; line-height: 1.75; margin: 0 0 10px; }
.foot-links { margin-left: 14px; }
.foot-links a { color: var(--muted); text-decoration: none; }
.foot-links a:hover { color: var(--text); text-decoration: underline; }
.auth-policy { text-align: center; font-size: 12.5px; margin: 10px 0 0; color: var(--muted); }
.auth-policy a { color: var(--muted); text-decoration: none; }
.auth-policy a:hover { color: var(--text); text-decoration: underline; }
@media (max-width: 720px) { .policy-page .policy-card { padding: 24px 18px; margin: 14px 10px 28px; } }
