/* Editor toolbar */
.editor-toolbar { display: flex; align-items: center; gap: 4px; padding: 8px 24px; background: var(--bg-card); border-bottom: 1px solid var(--border-light); flex-shrink: 0; flex-wrap: wrap; }
.toolbar-btn { width: 32px; height: 32px; border: none; background: transparent; border-radius: var(--radius-sm); cursor: pointer; display: flex; align-items: center; justify-content: center; color: var(--text-body); font-size: 14px; transition: all var(--transition-fast); }
.toolbar-btn:hover { background: var(--bg-hover); color: var(--primary); }
.toolbar-divider { width: 1px; height: 20px; background: var(--border); margin: 0 4px; }
.toolbar-ai-btn { display: flex; align-items: center; gap: 4px; padding: 4px 12px; border: 1px solid var(--primary); border-radius: var(--radius-pill); background: var(--primary-light); color: var(--primary); font-size: 12px; font-weight: 500; cursor: pointer; transition: all var(--transition-fast); }
.toolbar-ai-btn:hover { background: var(--primary); color: white; }

/* Script editor content */
.script-editor { flex: 1; padding: 32px 48px; overflow-y: auto; font-size: 14px; line-height: 2; outline: none; background: var(--bg-card); margin: 16px 24px; border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); min-height: 0; }

/* Script format styles */
.script-editor h1, .script-editor .episode-title { font-size: 20px; font-weight: 700; text-align: center; margin: 0 0 24px; padding-bottom: 12px; border-bottom: 2px solid var(--border); }

.script-editor .scene-header { background: #F0F2F5; padding: 8px 14px; border-radius: var(--radius-sm); font-weight: 600; color: var(--text-primary); margin: 24px 0 8px; font-size: 14px; border-left: 3px solid var(--primary); }

.script-editor .scene-characters { font-size: 13px; color: var(--text-secondary); padding: 4px 14px; margin-bottom: 12px; }

.script-editor .action-line { color: #5B6B82; font-style: normal; padding: 2px 0; }
.script-editor .action-marker { color: var(--primary); font-weight: 700; margin-right: 4px; }

.script-editor .dialogue-line { margin: 4px 0; }
.script-editor .char-name { font-weight: 700; color: var(--text-primary); }
.script-editor .char-state { color: var(--text-secondary); font-size: 13px; }
.script-editor .dialogue-text { color: var(--text-primary); }

.script-editor .os-line { color: #6366F1; font-style: italic; padding-left: 16px; border-left: 2px solid #6366F1; margin: 4px 0; }
.script-editor .vo-line { color: #8B5CF6; font-style: italic; padding-left: 16px; border-left: 2px solid #8B5CF6; margin: 4px 0; }

.script-editor .flashback-marker { display: inline-block; background: #FFF7E8; color: #FF7D00; padding: 2px 10px; border-radius: var(--radius-sm); font-weight: 600; font-size: 13px; margin: 8px 0; }

.script-editor .scene-divider { border: none; border-top: 1px dashed var(--border); margin: 20px 0; }

.script-editor .episode-footer { text-align: center; font-size: 13px; color: var(--text-secondary); margin-top: 20px; padding-top: 12px; border-top: 1px solid var(--border-light); }

/* Floating selection toolbar */
.float-toolbar { position: absolute; display: none; background: var(--text-primary); border-radius: var(--radius-md); padding: 4px; gap: 2px; box-shadow: var(--shadow-lg); z-index: 200; }
.float-toolbar.show { display: flex; }
.float-tb-btn { padding: 6px 10px; border: none; background: transparent; color: white; font-size: 12px; cursor: pointer; border-radius: var(--radius-xs); display: flex; align-items: center; gap: 4px; white-space: nowrap; }
.float-tb-btn:hover { background: rgba(255,255,255,.15); }
.float-tb-btn.ai-action { background: rgba(22,93,255,.8); }
.float-tb-btn.ai-action:hover { background: rgba(22,93,255,1); }
