/* ═══ Creator ═══ */
.creator-section { padding: var(--sp-10) 0 var(--sp-5); }
.creator-card {
  background: var(--surface); border: 1px solid var(--border-subtle); border-radius: var(--r-xl);
  padding: var(--sp-10); position: relative; overflow: hidden;
}
.creator-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--gradient);
}
.creator-title { font-size: 24px; font-weight: 700; margin-bottom: var(--sp-2); }
.creator-desc { font-size: 14px; color: var(--text-2); margin-bottom: var(--sp-6); line-height: 1.65; }

.creator-textarea {
  width: 100%; min-height: 180px; max-height: 400px; background: var(--elevated); border: 1px solid var(--border-subtle);
  border-radius: var(--r-md); padding: var(--sp-4); font-family: inherit; font-size: 15px; color: var(--text);
  line-height: 1.7; resize: vertical; transition: border-color var(--t-normal) var(--ease), box-shadow var(--t-normal) var(--ease);
}
.creator-textarea:focus {
  outline: none; border-color: color-mix(in srgb, var(--accent) 45%, var(--border)); box-shadow: 0 0 0 3px var(--accent-glow);
}
.creator-textarea::placeholder { color: var(--text-muted); }

.creator-char-row {
  font-size: 11px; font-family: var(--font-mono); color: var(--text-muted); text-align: right; margin-top: var(--sp-2);
}
.creator-char-row.is-enough #creatorCharCount { color: var(--accent); }

.creator-row { display: flex; gap: var(--sp-3); margin-top: var(--sp-4); flex-wrap: wrap; align-items: flex-end; }
.creator-field { display: flex; flex-direction: column; gap: var(--sp-2); }
.creator-field label {
  font-size: 11px; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em;
}
.creator-input {
  background: var(--elevated); border: 1px solid var(--border-subtle); border-radius: var(--r-sm);
  padding: 10px 14px; font-size: 13px; color: var(--text); min-width: 200px;
}
.creator-input:focus { outline: none; border-color: var(--border-accent); box-shadow: 0 0 0 2px var(--accent-glow); }

.creator-modes { display: flex; gap: var(--sp-3); flex: 1; min-width: 0; }
.creator-mode-btn {
  flex: 1; padding: var(--sp-3) var(--sp-5); border-radius: var(--r-sm); font-size: 13px; font-weight: 600;
  transition: transform var(--t-fast) var(--ease), box-shadow var(--t-normal) var(--ease), background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
  display: flex; align-items: center; justify-content: center; gap: var(--sp-2); min-width: 160px;
}
.creator-mode-btn.narration { background: var(--gradient); color: var(--text); animation: btnPulse 3s var(--ease) infinite; }
.creator-mode-btn.narration:hover { box-shadow: var(--shadow-glow-strong); transform: translateY(-1px); animation: none; }
.creator-mode-btn.interactive { background: transparent; border: 1px solid var(--border-accent); color: var(--text-accent); }
.creator-mode-btn.interactive:hover {
  background: color-mix(in srgb, var(--accent) 12%, transparent); border-color: var(--accent); color: var(--text);
}
.creator-mode-btn:disabled { opacity: 0.45; cursor: not-allowed; transform: none !important; animation: none !important; }

.creator-status {
  margin-top: var(--sp-4); padding: var(--sp-3) var(--sp-4); border-radius: var(--r-sm); font-size: 13px;
  display: none; align-items: center; gap: var(--sp-3);
}
.creator-status.sending, .creator-status.success, .creator-status.error { display: flex; }
.creator-status.sending {
  background: color-mix(in srgb, var(--accent) 10%, transparent); border: 1px solid var(--border-accent); color: var(--text-accent);
}
.creator-status.success {
  background: color-mix(in srgb, var(--success) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--success) 28%, transparent); color: var(--success);
}
.creator-status.error {
  background: color-mix(in srgb, var(--error) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--error) 28%, transparent); color: var(--error);
}
.creator-spinner {
  width: 16px; height: 16px; border: 2px solid color-mix(in srgb, var(--accent) 35%, transparent);
  border-top-color: var(--accent); border-radius: 50%; animation: spin 0.8s linear infinite; flex-shrink: 0;
}

@media (max-width: 768px) {
  .creator-card { padding: var(--sp-6); }
  .creator-modes { flex-direction: column; }
  .creator-mode-btn { min-width: 100%; }
}
