:root {
  --bg-color: #0a0a0a;
  --bg-surface: #141414;
  --bg-surface-hover: #1f1f1f;
  --text-primary: #ffffff;
  --text-secondary: #a1a1aa;
  --accent-color: #6366f1; /* Indigo */
  --accent-hover: #4f46e5;
  --border-color: #27272a;
  --pill-bg: #1e1e1e;
  --pill-active: #6366f1;
  --font-family: 'Inter', sans-serif;
  --transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

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

body {
  font-family: var(--font-family);
  background-color: var(--bg-color);
  color: var(--text-primary);
  min-height: 100vh;
  overflow-x: hidden;
  position: relative;
}

/* Typography Hierarchy */
h1, h2, h3 {
  font-weight: 700;
  letter-spacing: -0.02em;
}

p {
  line-height: 1.6;
}

/* Ambient Background Orbs */
.bg-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(120px);
  z-index: 0;
  opacity: 0.5;
  pointer-events: none;
}

.orb-top {
  width: 500px;
  height: 500px;
  background: rgba(99, 102, 241, 0.2);
  top: -100px;
  left: -100px;
}

.orb-bottom {
  width: 600px;
  height: 600px;
  background: rgba(168, 85, 247, 0.15); /* Purple accent */
  bottom: -200px;
  right: -200px;
}

.glass-overlay {
  position: fixed;
  inset: 0;
  background: radial-gradient(circle at center, transparent 0%, var(--bg-color) 100%);
  pointer-events: none;
  z-index: 0;
}

/* Screens Base */
.screen {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  min-height: 100vh;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.6s ease, transform 0.6s ease;
  transform: translateY(20px);
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 2rem;
}

.screen.active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  position: relative;
}

/* TELA 1: DASHBOARD */
.dashboard-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  max-width: 800px;
  margin: 0 auto;
  min-height: calc(100vh - 4rem);
}

.brand-badge {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  padding: 0.5rem 1rem;
  border-radius: 2rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-secondary);
  margin-bottom: 2rem;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  backdrop-filter: blur(10px);
}

.main-title {
  font-size: clamp(3rem, 6vw, 5rem);
  line-height: 1.1;
  margin-bottom: 1.5rem;
}

.main-title span {
  background: linear-gradient(135deg, #a855f7 0%, #6366f1 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  display: inline-block;
}

.subtitle {
  font-size: clamp(1rem, 2vw, 1.25rem);
  color: var(--text-secondary);
  max-width: 600px;
  margin-bottom: 4rem;
  font-weight: 300;
}

.cta-button {
  background: var(--text-primary);
  color: var(--bg-color);
  border: none;
  padding: 1.25rem 3rem;
  font-size: 1.25rem;
  font-weight: 600;
  border-radius: 4rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  transition: var(--transition);
  font-family: var(--font-family);
  box-shadow: 0 0 40px rgba(255, 255, 255, 0.1);
}

.cta-button:hover {
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 0 60px rgba(255, 255, 255, 0.2);
}

.cta-icon {
  font-size: 1.5rem;
}

/* Pulsing effect for CTA */
@keyframes pulse {
  0% { box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.2); }
  70% { box-shadow: 0 0 0 20px rgba(255, 255, 255, 0); }
  100% { box-shadow: 0 0 0 0 rgba(255, 255, 255, 0); }
}
.pulse {
  animation: pulse 3s infinite;
}

/* TELA 2: BRIEFING FORM */
.briefing-container {
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
  padding-top: 2rem;
}

.briefing-header {
  margin-bottom: 3rem;
  position: relative;
}

.btn-back {
  background: transparent;
  border: 1px solid var(--border-color);
  color: var(--text-secondary);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  margin-bottom: 1.5rem;
  transition: var(--transition);
}

.btn-back:hover {
  background: var(--bg-surface);
  color: var(--text-primary);
}

.briefing-header h2 {
  font-size: 2.25rem;
  margin-bottom: 0.5rem;
}

.briefing-header p {
  color: var(--text-secondary);
  font-size: 1.1rem;
}

.briefing-form {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.row {
  display: flex;
  gap: 1.5rem;
  align-items: flex-start;
}

.flex-1 {
  flex: 1;
}

/* Card de Público-Alvo: 388 de largura, altura cresce conforme nº de pills */
.card-publico {
  flex: 0 0 388px;
  min-height: 255.22px;
}

@media (max-width: 768px) {
  .row {
    flex-direction: column;
  }
  .card-publico {
    flex: 0 0 auto;
    width: 100%;
    height: auto;
  }
}

.card {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: 1rem;
  padding: 2rem;
  transition: var(--transition);
}

.card:hover {
  border-color: rgba(255, 255, 255, 0.1);
}

.form-group label {
  display: block;
  font-size: 0.95rem;
  font-weight: 500;
  margin-bottom: 1rem;
  color: var(--text-primary);
}

.highlight-text {
  color: var(--accent-color);
  font-weight: 700;
}

/* Inputs */
textarea {
  width: 100%;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  color: var(--text-primary);
  border-radius: 0.75rem;
  padding: 1rem;
  font-family: var(--font-family);
  font-size: 1rem;
  resize: vertical;
  transition: var(--transition);
}

textarea:focus, select:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
}

textarea::placeholder {
  color: #52525b;
}

/* Custom Select */
.custom-select-wrapper {
  position: relative;
}

.custom-select {
  width: 100%;
  appearance: none;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  color: var(--text-primary);
  border-radius: 0.75rem;
  padding: 1rem;
  font-family: var(--font-family);
  font-size: 1rem;
  cursor: pointer;
  transition: var(--transition);
}

.custom-select-wrapper::after {
  content: "▼";
  font-size: 0.7rem;
  color: var(--text-secondary);
  position: absolute;
  right: 1.25rem;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
}

/* Size Options (Tamanho) — Cada botão renderiza na proporção real do formato */
.size-options {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 80px));
  gap: 0.75rem;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 0 0.25rem;
}

.size-option {
  width: 100%;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 0.6rem;
  color: var(--text-secondary);
  font-family: var(--font-family);
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition);
}

.size-option[data-value="1:1"]  { aspect-ratio: 1 / 1;  }
.size-option[data-value="4:5"]  { aspect-ratio: 4 / 5;  }
.size-option[data-value="9:16"] { aspect-ratio: 9 / 16; }

.size-option:hover {
  background: var(--bg-surface-hover);
  color: var(--text-primary);
  border-color: rgba(255, 255, 255, 0.18);
}

.size-option.active {
  background: rgba(99, 102, 241, 0.1);
  border-color: var(--accent-color);
  color: var(--text-primary);
}

/* Slides Grid (Quantidade de Slides) — 5 colunas × 2 linhas, pills horizontais */
.slides-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0.6rem;
}

.slide-count-btn {
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 0.6rem;
  color: var(--text-secondary);
  font-family: var(--font-family);
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  padding: 0.85rem 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition);
}

.slide-count-btn:hover {
  background: var(--bg-surface-hover);
  color: var(--text-primary);
  border-color: rgba(255, 255, 255, 0.18);
}

.slide-count-btn.active {
  background: rgba(99, 102, 241, 0.08);
  border-color: var(--accent-color);
  color: var(--text-primary);
}

/* Pills for Style */
.pills-container {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.pill {
  background: var(--pill-bg);
  border: 1px solid var(--border-color);
  color: var(--text-secondary);
  padding: 0.75rem 1.25rem;
  border-radius: 2rem;
  font-size: 0.95rem;
  font-weight: 500;
  cursor: pointer;
  transition: var(--transition);
  font-family: var(--font-family);
}

.pill:hover {
  background: var(--bg-surface-hover);
  color: var(--text-primary);
}

.pill.active {
  background: var(--accent-color);
  border-color: var(--accent-color);
  color: white;
}

/* Pills do Público-Alvo: super compactas pra acomodar ~24 nichos */
#input-publico-container {
  gap: 0.4rem;
}

#input-publico-container .pill {
  padding: 0.4rem 0.75rem;
  font-size: 0.72rem;
  font-weight: 500;
}

/* Pill "+ Outros" tem aparência diferente (tracejada, accent) pra indicar ação */
#input-publico-container .pill-outros {
  background: rgba(99, 102, 241, 0.08);
  border-style: dashed;
  border-color: rgba(99, 102, 241, 0.4);
  color: var(--accent-color);
}

#input-publico-container .pill-outros:hover {
  background: rgba(99, 102, 241, 0.15);
  color: var(--accent-color);
}

#input-publico-container .pill-outros.active {
  background: var(--accent-color);
  border-style: solid;
  border-color: var(--accent-color);
  color: white;
}

/* Dropzone */
.dropzone {
  border: 2px dashed var(--border-color);
  border-radius: 1rem;
  padding: 3rem 2rem;
  text-align: center;
  cursor: pointer;
  transition: var(--transition);
  background: rgba(0, 0, 0, 0.2);
}

.dropzone:hover {
  border-color: var(--accent-color);
  background: rgba(99, 102, 241, 0.05);
}

.dropzone.drag-over {
  border-color: var(--accent-color);
  background: rgba(99, 102, 241, 0.12);
  transform: scale(1.01);
}

.dropzone-icon {
  color: var(--text-secondary);
  margin-bottom: 1rem;
  pointer-events: none;
}

.dropzone p {
  font-weight: 500;
  color: var(--text-primary);
  margin-bottom: 0.25rem;
  pointer-events: none;
}

.dropzone span {
  font-size: 0.85rem;
  color: var(--text-secondary);
  pointer-events: none;
}

.dropzone kbd {
  display: inline-block;
  padding: 0.1rem 0.4rem;
  font-size: 0.7rem;
  font-family: 'SF Mono', Menlo, monospace;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 0.3rem;
  color: var(--text-primary);
  margin: 0 0.1rem;
}

.dropzone-limit {
  display: block;
  margin-top: 0.75rem;
  font-size: 0.72rem;
  color: var(--text-secondary);
  opacity: 0.65;
  letter-spacing: 0.02em;
  pointer-events: none;
}

/* Preview de imagens enviadas */
.imagens-preview {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
  gap: 0.6rem;
  margin-top: 1rem;
}

.imagens-preview:empty {
  display: none;
}

.preview-thumb {
  position: relative;
  aspect-ratio: 1 / 1;
  border-radius: 0.6rem;
  overflow: hidden;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  animation: fadeIn 0.25s ease;
}

.preview-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.preview-thumb-remove {
  position: absolute;
  top: 4px;
  right: 4px;
  background: rgba(0, 0, 0, 0.65);
  border: none;
  color: white;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition);
  backdrop-filter: blur(4px);
}

.preview-thumb-remove:hover {
  background: rgba(239, 68, 68, 0.9);
  transform: scale(1.1);
}

/* Submit Button */
.form-actions {
  margin-top: 1rem;
  padding-bottom: 4rem;
}

.submit-button {
  width: 100%;
  background: var(--text-primary);
  color: var(--bg-color);
  border: none;
  padding: 1.25rem;
  font-size: 1.15rem;
  font-weight: 600;
  border-radius: 0.75rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  transition: var(--transition);
  font-family: var(--font-family);
}

.submit-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 30px rgba(255, 255, 255, 0.1);
}

/* TELA 3: LOADING & ERROR */
.loading-container {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  min-height: calc(100vh - 4rem);
}

.spinner {
  width: 60px;
  height: 60px;
  position: relative;
  margin-bottom: 2rem;
}

.double-bounce1, .double-bounce2 {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background-color: var(--accent-color);
  opacity: 0.6;
  position: absolute;
  top: 0;
  left: 0;
  animation: bounce 2.0s infinite ease-in-out;
  box-shadow: 0 0 20px rgba(99, 102, 241, 0.5);
}

.double-bounce2 {
  animation-delay: -1.0s;
}

@keyframes bounce {
  0%, 100% { 
    transform: scale(0.0);
  } 50% { 
    transform: scale(1.0);
  }
}

.loading-text {
  font-size: 1.25rem;
  font-weight: 500;
  color: var(--text-primary);
  min-height: 2rem; /* prevents layout shift */
  transition: opacity 0.5s ease;
}

/* Error State */
.error-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.3);
  padding: 3rem;
  border-radius: 1rem;
  backdrop-filter: blur(10px);
}

.error-icon {
  margin-bottom: 0.5rem;
}

.error-message {
  font-size: 1.1rem;
  color: #fca5a5;
  max-width: 400px;
}

.btn-error {
  background: transparent;
  color: #fca5a5;
  border: 1px solid #fca5a5;
  padding: 0.75rem 1.5rem;
  border-radius: 2rem;
  font-family: var(--font-family);
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  transition: var(--transition);
}

.btn-error:hover {
  background: rgba(239, 68, 68, 0.15);
  color: #fef2f2;
}

/* ============================================
   TELA 2: MODO MANUAL — Toggle + Slide Inputs
   ============================================ */

/* Toggle Card */
.toggle-card {
  padding: 1.1rem 1.4rem !important;
}

.toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  cursor: pointer;
  user-select: none;
}

.toggle-info {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.toggle-title {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-primary);
}

.toggle-desc {
  font-size: 0.75rem;
  color: var(--text-secondary);
  line-height: 1.4;
}

/* Toggle Switch Visual */
.toggle-switch-wrapper {
  position: relative;
  flex-shrink: 0;
  width: 48px;
  height: 26px;
}

.toggle-input {
  opacity: 0;
  width: 0;
  height: 0;
  position: absolute;
}

.toggle-thumb {
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.1);
  border: 1px solid var(--border-color);
  border-radius: 999px;
  cursor: pointer;
  transition: var(--transition);
}

.toggle-thumb::after {
  content: '';
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--text-secondary);
  /* Transição elástica/spring no thumb (overshoot ao chegar no destino).
     Cor muda em ease normal pra não "atrasar" o feedback visual. */
  transition:
    transform 0.45s cubic-bezier(0.34, 1.56, 0.64, 1),
    background 0.25s ease;
}

.toggle-input:checked + .toggle-thumb {
  background: rgba(99, 102, 241, 0.25);
  border-color: var(--accent-color);
}

.toggle-input:checked + .toggle-thumb::after {
  transform: translateX(22px);
  background: var(--accent-color);
}

/* Grupo de tema desabilitado */
#grupo-tema.disabled {
  opacity: 0.35;
  pointer-events: none;
}

#grupo-tema {
  transition: opacity 0.3s ease;
}

/* Container de Slides Manuais */
.slides-manuais-container {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  animation: fadeIn 0.35s ease;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Card de cada slide manual */
.slide-manual-card {
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--border-color);
  border-radius: 1rem;
  padding: 1.25rem 1.4rem;
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
  transition: border-color 0.2s ease;
}

.slide-manual-card:focus-within {
  border-color: rgba(99,102,241,0.4);
}

.slide-manual-header {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.slide-manual-badge {
  width: 24px;
  height: 24px;
  border-radius: 6px;
  background: rgba(99,102,241,0.15);
  border: 1px solid rgba(99,102,241,0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.65rem;
  font-weight: 700;
  color: var(--accent-color);
  flex-shrink: 0;
}

.slide-manual-label {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.slide-manual-card input[type="text"],
.slide-manual-card textarea {
  width: 100%;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 0.6rem;
  color: var(--text-primary);
  font-family: var(--font-family);
  font-size: 0.9rem;
  padding: 0.7rem 0.9rem;
  outline: none;
  resize: vertical;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.slide-manual-card input[type="text"]:focus,
.slide-manual-card textarea:focus {
  border-color: var(--accent-color);
  box-shadow: 0 0 0 3px rgba(99,102,241,0.1);
}

.slide-manual-card input[type="text"]::placeholder,
.slide-manual-card textarea::placeholder {
  color: #52525b;
}

/* Checkbox de instrução de imagem por slide */
.img-instrucao-toggle {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  font-size: 0.78rem;
  color: var(--text-secondary);
  user-select: none;
  padding: 0.4rem 0;
  width: fit-content;
}

.img-instrucao-toggle input[type="checkbox"] {
  accent-color: var(--accent-color);
  width: 14px;
  height: 14px;
  cursor: pointer;
}

.img-instrucao-toggle:hover {
  color: var(--text-primary);
}

.img-instrucao-box {
  display: none;
  animation: fadeIn 0.2s ease;
}

.img-instrucao-box.visible {
  display: block;
}

.img-instrucao-box textarea {
  font-size: 0.82rem !important;
  min-height: 60px;
}

/* ============================================
   TELA 4: EDITOR VISUAL
   ============================================ */

/* Override screen padding for TELA 4 */
#tela-4 {
  padding: 0;
  align-items: stretch;
}

.editor-layout {
  display: flex;
  width: 100%;
  min-height: 100vh;
}

/* ============================================
   TELA 4 — TOP BAR (contador de slides + ação adicionar mais)
   ============================================ */
.top-bar {
  position: sticky;
  top: 0;
  z-index: 50;
  width: 100%;
  background: rgba(17, 17, 17, 0.92);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border-color);
  padding: 0.85rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.top-bar-info {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.85rem;
  color: var(--text-secondary);
}

.top-bar-info strong {
  color: var(--accent-color);
  font-weight: 700;
  font-size: 0.95rem;
  font-variant-numeric: tabular-nums;
}

.top-bar-divider {
  opacity: 0.4;
  margin: 0 0.1rem;
}

.top-bar-max {
  font-variant-numeric: tabular-nums;
}

.top-bar-actions {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

.top-bar-actions input[type="number"] {
  width: 64px;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 0.5rem;
  color: var(--text-primary);
  padding: 0.5rem 0.6rem;
  font-family: var(--font-family);
  font-size: 0.88rem;
  outline: none;
  text-align: center;
}

.top-bar-actions input[type="number"]:focus {
  border-color: var(--accent-color);
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
}

#btn-add-slides {
  background: var(--accent-color);
  color: white;
  border: none;
  padding: 0.55rem 1.1rem;
  border-radius: 0.5rem;
  font-family: var(--font-family);
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s ease, transform 0.15s ease;
}

#btn-add-slides:hover:not(:disabled) {
  background: var(--accent-hover);
  transform: translateY(-1px);
}

#btn-add-slides:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

/* --- SIDEBAR (30%) --- */
.editor-sidebar {
  width: 30%;
  min-width: 260px;
  max-width: 340px;
  background: #111111;
  border-right: 1px solid var(--border-color);
  display: flex;
  flex-direction: column;
  position: sticky;
  top: 0;
  height: 100vh;
}

.sidebar-header {
  padding: 1.75rem 1.5rem;
  border-bottom: 1px solid var(--border-color);
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-shrink: 0;
}

.sidebar-header h3 {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 0.1rem;
}

.sidebar-header p {
  font-size: 0.75rem;
  color: var(--text-secondary);
  line-height: 1;
}

.sidebar-content {
  flex: 1;
  overflow-y: auto;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  scrollbar-width: thin;
  scrollbar-color: var(--border-color) transparent;
}

.sidebar-content::-webkit-scrollbar { width: 4px; }
.sidebar-content::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 2px; }

.control-section {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}

/* ============================================
   SEÇÕES RECOLHÍVEIS — JS auto-injeta um botão "section-toggle" no topo
   de cada control-section/editor-element-section, transforma o label em
   header clicável e wrappa o resto do conteúdo num section-content que
   pode ser ocultado via class "collapsed".
   ============================================ */

.section-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  width: 100%;
  background: transparent;
  border: none;
  padding: 0;
  margin: 0;
  cursor: pointer;
  font-family: inherit;
  text-align: left;
  color: inherit;
}

.section-toggle:hover .control-label {
  color: var(--text-primary);
}

.section-toggle .control-label {
  margin: 0;
  flex: 1;
}

.section-chevron {
  width: 12px;
  height: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.7rem;
  color: var(--text-secondary);
  flex-shrink: 0;
  transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.control-section.collapsed .section-chevron,
.editor-element-section.collapsed .section-chevron {
  transform: rotate(-90deg);
}

.section-content {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
  overflow: hidden;
  transition: max-height 0.35s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.2s ease;
  max-height: 6000px;
  opacity: 1;
}

.control-section.collapsed .section-content,
.editor-element-section.collapsed .section-content {
  max-height: 0;
  opacity: 0;
  pointer-events: none;
}

.control-label {
  display: block;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-secondary);
}

/* Font Template Buttons */
.font-templates-list {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.font-template-btn {
  background: transparent;
  border: 1px solid var(--border-color);
  border-radius: 0.75rem;
  padding: 0.75rem 1rem;
  cursor: pointer;
  text-align: left;
  transition: var(--transition);
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  font-family: var(--font-family);
  width: 100%;
}

.font-template-btn:hover {
  background: rgba(255,255,255,0.03);
  border-color: rgba(255,255,255,0.15);
}

.font-template-btn.active {
  background: rgba(99, 102, 241, 0.1);
  border-color: var(--accent-color);
}

.template-name {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-primary);
}

.template-fonts {
  font-size: 0.7rem;
  color: var(--text-secondary);
}

.font-template-btn.active .template-name { color: var(--accent-color); }

/* Instagram Input */
.instagram-input-wrapper {
  display: flex;
  align-items: center;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 0.75rem;
  overflow: hidden;
  transition: var(--transition);
}

.instagram-input-wrapper:focus-within {
  border-color: var(--accent-color);
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
}

.input-prefix {
  padding: 0.75rem 0.25rem 0.75rem 1rem;
  color: var(--accent-color);
  font-weight: 700;
  font-size: 1rem;
  flex-shrink: 0;
}

.instagram-input {
  background: transparent;
  border: none;
  color: var(--text-primary);
  font-family: var(--font-family);
  font-size: 0.9rem;
  padding: 0.75rem 1rem 0.75rem 0.25rem;
  width: 100%;
  outline: none;
}

.instagram-input::placeholder { color: #52525b; }

/* Download Button */
.sidebar-footer {
  padding: 1.25rem 1.5rem;
  border-top: 1px solid var(--border-color);
  flex-shrink: 0;
}

.btn-download {
  width: 100%;
  background: linear-gradient(135deg, #a855f7 0%, #6366f1 100%);
  color: white;
  border: none;
  padding: 1rem;
  font-size: 0.95rem;
  font-weight: 600;
  border-radius: 0.75rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  transition: var(--transition);
  font-family: var(--font-family);
}

.btn-download:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 25px rgba(99, 102, 241, 0.4);
}

/* --- PREVIEW (70%) --- */
.editor-preview {
  flex: 1;
  overflow-y: auto;
  padding: 2rem 3rem 4rem;
  background: #0d0d0d;
}

.preview-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--border-color);
}

.preview-label {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-secondary);
}

.slides-count {
  font-size: 0.8rem;
  color: var(--accent-color);
  font-weight: 500;
}

/* Slides Gallery — Layout horizontal estilo carrossel do Instagram */
.slides-gallery {
  display: flex;
  flex-direction: row;
  gap: 2rem;
  align-items: center;
  overflow-x: auto;
  overflow-y: visible;
  padding: 0.5rem 0 1.5rem;
  scroll-snap-type: x mandatory;
  scroll-padding: 0 2rem;
  scrollbar-width: thin;
  scrollbar-color: var(--accent-color) transparent;
}

.slides-gallery::-webkit-scrollbar {
  height: 8px;
}
.slides-gallery::-webkit-scrollbar-thumb {
  background: var(--accent-color);
  border-radius: 4px;
}
.slides-gallery::-webkit-scrollbar-track {
  background: rgba(255,255,255,0.04);
  border-radius: 4px;
}

/* Slide Card — Regra de Design: 80px de margem interna em todos os lados
   container-type: inline-size habilita unidades cqw (proporcional ao card)
   Canvas final = 1080px → 100cqw, então 1px ≈ 0.0926cqw */
.slide-card {
  container-type: inline-size;
  width: 605px;            /* preview reduzido 20% (era 756px) — cqw escala automaticamente */
  flex-shrink: 0;          /* impede que o flex horizontal encolha o card */
  scroll-snap-align: center; /* snap suave ao rolar horizontalmente */
  aspect-ratio: 1 / 1;
  border-radius: 1.5rem;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,0.55), 0 0 0 1px rgba(255,255,255,0.05);
  position: relative;
  display: flex;
  flex-direction: column;
  /* Margem reduzida 30%: 80px × 0.7 = 56px → 5.19cqw em 1080 */
  padding: 5.19cqw;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  background-color: var(--slide-bg, #0A0E27);
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
  color: var(--slide-text, #ffffff);
  animation: cardFadeIn 0.6s ease forwards;
  /* Sem quebra de palavra — palavra inteira vai pra próxima linha */
  word-break: keep-all;
  overflow-wrap: normal;
}

@keyframes cardFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Degradê estilo "Só Fundo" — linear, de baixo pra cima, da cor escolhida → transparente
   Avanço de 80px no briefing (reduzido 30% = 56px = 5.19cqw em 1080)
   Opacidade e cor controladas pelo usuário no Editor (--overlay-opacity, --overlay-color) */
.slide-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    var(--overlay-color, #000000) 0,
    var(--overlay-color, #000000) 5.19cqw,
    transparent 100%
  );
  z-index: 0;
  border-radius: inherit;
  opacity: 0;
  transition: opacity 0.3s ease, background 0.3s ease;
  pointer-events: none;
}

.slide-card.has-bg-image::before {
  opacity: var(--overlay-opacity, 1);
}

.slide-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 36px 80px rgba(0,0,0,0.65), 0 0 0 1px rgba(255,255,255,0.08);
}

.slide-accent-bar {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 3px;
  background: var(--slide-accent, #6366f1);
  z-index: 1;
}

.slide-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.6rem;
  position: relative;
  z-index: 1;
}

/* Com imagem: empurra o texto para a base do card (área mais escura do gradiente) */
.slide-card.has-bg-image .slide-body {
  justify-content: flex-end;
  padding-bottom: 0.5rem;
}

/* ============================================
   ASSETS FIXOS (todos os slides, todos os estilos)
   Conforme DESIGN_RULES.md seção 2 — Regra de Assets
   Tamanho de fonte de assets: 25px → 2.3cqw
   ============================================ */

/* Assets de cabeçalho/rodapé — flex items dentro do slide-card (preserva espaçamento
   horizontal e proximidade lateral original). O slider só controla vertical via
   transform: translateY, sem alterar o layout do slide-body/grade-content/imagens. */
.slide-assets-top,
.slide-assets-bottom {
  position: relative;
  z-index: 2;
  flex-shrink: 0;
  font-size: 2.16cqw;        /* 25pt @ 96dpi × 0.7 = 23.3px ≈ 2.16cqw */
  font-family: var(--font-body, 'Inter', sans-serif);
  font-weight: 600;
  color: var(--slide-text, #ffffff);
  letter-spacing: 0.01em;
}

.slide-assets-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1cqw;
  /* Translate vertical em direção à borda superior. Apenas vertical, sem mexer
     em nada lateralmente. Fator 1.5 amplia o alcance para ir além do padding
     original — em 100% o asset chega bem próximo da borda real do slide-card
     (ligeiro clip aceitável já que o usuário autorizou quebrar a regra dos 80px). */
  transform: translateY(calc(-5.19cqw * var(--assets-edge-pull, 0.2) * 1.5));
}

.slide-assets-bottom {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 1cqw;
  margin-top: auto; /* gruda na base do flex container */
  /* Mesmo fator 1.5 simétrico para a borda inferior */
  transform: translateY(calc(5.19cqw * var(--assets-edge-pull, 0.2) * 1.5));
}

.asset-handle {
  /* topo esquerdo: @user (texto puro) */
  text-align: left;
}

.asset-brand {
  /* base esquerda: "Macelista" */
  text-align: left;
}

/* ============================================
   IDENTIDADE — asset ancorado dentro do bloco do H1
   - Renderiza acima do H1 com gap proporcional
   - Acompanha o alinhamento (data-pos / data-align) do text-block via align-self
   - 2 variantes visuais: badge (pill com blur+ícone) ou avatar (foto+texto)
   ============================================ */

.text-block[data-element="h1"] .identity-asset {
  --identity-scale: 1;
  font-size: calc(2.16cqw * var(--identity-scale));
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  width: max-content;            /* não estica até a borda do text-block */
  max-width: 100%;
  align-self: flex-start;        /* SEMPRE à esquerda, independente do alinhamento do H1 */
  margin-bottom: 2cqw;           /* respiro pra o H1 (~20% relativo) */
  text-align: left;              /* impede que text-align: center/right do parent vaze nas spans internas */
}

/* Quando vazio (não ativado), some sem ocupar espaço */
.text-block[data-element="h1"] .identity-asset:empty {
  display: none;
}

/* Variant: badge (pill com gaussian blur) */
.identity-asset.identity-badge {
  padding: 0.32em 0.85em 0.32em 0.5em;
  background: rgba(0, 0, 0, 0.32);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
  backdrop-filter: blur(12px) saturate(140%);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 999px;
  font-weight: 600;
}

.identity-asset.identity-avatar {
  font-weight: 600;
}

/* Ícones e avatar internos */
.identity-asset .identity-icon {
  width: 1.4em;
  height: 1.4em;
  flex-shrink: 0;
}

.identity-asset .identity-avatar-img {
  width: 1.7em;
  height: 1.7em;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  display: inline-block;
}

.identity-asset .identity-avatar-placeholder {
  background: linear-gradient(135deg, #6366f1 0%, #a855f7 100%);
  border: 1px solid rgba(255, 255, 255, 0.2);
}

/* Wrapper que clipa a imagem do avatar no círculo, permitindo zoom/pan
   sem que a imagem extrapole os limites do círculo */
.identity-asset .identity-avatar-wrap {
  overflow: hidden;
  position: relative;
}

.identity-asset .identity-avatar-wrap > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  /* Vars controladas pelo usuário no editor de Identidade */
  object-position: var(--avatar-pan-x, 50%) var(--avatar-pan-y, 50%);
  transform: scale(var(--avatar-zoom, 1));
  transform-origin: center center;
  display: block;
}

/* Selo de verificado (genérico) */
.verified-badge {
  width: 0.95em;
  height: 0.95em;
  flex-shrink: 0;
}

.asset-tagline {
  /* topo direito: tagline ≤20 chars */
  text-align: right;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  white-space: nowrap;   /* impede quebra de linha (ex: "CONTEÚDO VIRAL" em uma linha só) */
}

.asset-brand {
  /* base esquerda: "Macelista" */
  text-align: left;
}

.asset-swipe {
  /* base direita: "arrasta →" (slides 2 ao penúltimo) */
  text-align: right;
  opacity: 0.85;
  white-space: nowrap;   /* impede quebra entre "arrasta" e o ícone (→/▶/⟶/➜) */
}

.asset-swipe:empty {
  /* slides extremos não exibem o "arrasta" mas mantêm a coluna pra alinhar */
  visibility: hidden;
}

/* Indicador de slide (elipses) — 14×14px no canvas 1080 = 1.3cqw, gap 5px = 0.46cqw */
.asset-dots {
  display: flex;
  gap: 0.46cqw;
  align-items: center;
  justify-self: center;
}

.asset-dot {
  width: 0.91cqw;     /* 14px × 0.7 = 9.8px → 0.91cqw em 1080 */
  height: 0.91cqw;
  min-width: 5px;
  min-height: 5px;
  border-radius: 50%;
  border: 1px solid currentColor;
  box-sizing: border-box;
  flex-shrink: 0;
}

@container (min-width: 700px) {
  .asset-dot {
    border-width: 0.18cqw; /* borda proporcional só em telas grandes/export */
  }
}

.asset-dot.active {
  background: currentColor;
}

/* Toggle global "Mostrar assets fixos" — quando OFF esconde tudo */
.slides-gallery.assets-hidden .slide-assets-top,
.slides-gallery.assets-hidden .slide-assets-bottom {
  display: none;
}

/* ============================================
   ESTILO "GRADE" — Layout texto + imagem em containers separados
   - Fundo chapado (default branco, customizável via --grade-bg-color)
   - Imagem dentro de container com cantos arredondados de 25px (2.31cqw)
   - 2 variantes: text-top (texto em cima + imagem embaixo) ou image-top (inverso)
   ============================================ */

.slide-card[data-estilo="Grade"] {
  background-color: var(--grade-bg-color, #ffffff) !important;
  background-image: none !important;
  color: var(--grade-text-color, #1a1a1a);
}

/* Sem degradê na grade — fundo é chapado */
.slide-card[data-estilo="Grade"]::before {
  display: none;
}

/* Wrapper que contém body e imagem (entre os assets) */
.slide-card[data-estilo="Grade"] .grade-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 5cqw;            /* respiro entre H1 e imagem */
  min-height: 0;
  padding-top: 3cqw;    /* respiro entre top assets e imagem (era 0) */
  padding-bottom: 2.5cqw; /* respiro entre imagem e assets-bottom */
}

/* Variante B: imagem em cima + texto embaixo (alterna pelos slides) */
.slide-card[data-estilo="Grade"][data-variante="image-top"] .grade-content {
  flex-direction: column-reverse;
}

/* Body do texto na grade */
.slide-card[data-estilo="Grade"] .slide-body {
  flex-shrink: 0;
  flex-grow: 0;
  justify-content: flex-start;
  padding-bottom: 0;
}

/* Container da imagem — cantos arredondados, ocupa o resto do espaço */
.slide-image-container {
  flex: 1;
  width: 100%;
  border-radius: 2.31cqw;     /* 25px no canvas 1080 */
  overflow: hidden;
  background: rgba(0, 0, 0, 0.04);
  display: none;              /* só aparece em estilo Grade (regra abaixo) */
  min-height: 0;
}

.slide-card[data-estilo="Grade"] .slide-image-container {
  display: block;
}

.slide-image-container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Texto e assets escuros na grade */
.slide-card[data-estilo="Grade"] .slide-h1,
.slide-card[data-estilo="Grade"] .slide-h2,
.slide-card[data-estilo="Grade"] .slide-p,
.slide-card[data-estilo="Grade"] .slide-assets-top,
.slide-card[data-estilo="Grade"] .slide-assets-bottom {
  color: var(--grade-text-color, #1a1a1a);
}

/* Bordas das elipses indicadoras na grade — escuras */
.slide-card[data-estilo="Grade"] .asset-dot {
  border-color: var(--grade-text-color, #1a1a1a);
}
.slide-card[data-estilo="Grade"] .asset-dot.active {
  background: var(--grade-text-color, #1a1a1a);
}

/* Reset do justify-content da capa em grade — flow natural */
.slide-card[data-estilo="Grade"][data-tipo="capa"] .slide-body {
  justify-content: flex-start;
  padding-bottom: 0;
}

/* ============================================
   FASE 4 — EDITOR AVANÇADO POR SLIDE
   Modo de seleção, posicionamento via 9-grid, pills clicáveis, popover
   ============================================ */

/* Visual de slide selecionado */
.slide-card.selected {
  outline: 3px solid var(--accent-color);
  outline-offset: 6px;
  cursor: default;
}

.slide-card {
  cursor: pointer;
}

/* Slide-body vira contexto de posicionamento (relative pra absolute funcionar nos text-blocks) */
.slide-body {
  position: relative;
  overflow: visible;
  gap: 3cqw;            /* respiro maior entre H1 e H2 no fluxo default */
  padding-top: 3cqw;    /* respiro do top assets (era 1cqw — usuário pediu mais distância) */
  padding-bottom: 1cqw; /* respiro do bottom assets */
}

/* TEXT-BLOCK — DEFAULT é fluxo normal (relative), só vira absoluto quando user posiciona */
.text-block {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0.6cqw;
  max-width: 100%;
  z-index: 1;
}

/* Quando o user EXPLICITAMENTE escolhe uma posição na 9-grid, vira absoluto.
   IMPORTANTE: o bloco SEMPRE ocupa a largura total disponível (left:0 + right:0).
   Isso evita o "shrink-to-fit" que faz o texto quebrar em linhas extras quando
   centralizado. O alinhamento horizontal é controlado por text-align. */
.text-block[data-positioned="true"] {
  position: absolute;
  left: 0;
  right: 0;
}

/* 9 posições — usam apenas top/bottom + text-align.
   Margem de segurança vertical:
   - SUP/INF default = 1cqw (combina com padding do slide-body)
   - INF na CAPA = 4cqw (regra abaixo, mantém o respiro original do briefing) */
.text-block[data-positioned="true"][data-pos="SUP.ESQ"]    { top: 3cqw;    text-align: left;   }
.text-block[data-positioned="true"][data-pos="SUP.CENTRO"] { top: 3cqw;    text-align: center; }
.text-block[data-positioned="true"][data-pos="SUP.DIR"]    { top: 3cqw;    text-align: right;  }
.text-block[data-positioned="true"][data-pos="MEIO.ESQ"]   { top: 50%; transform: translateY(-50%); text-align: left;   }
.text-block[data-positioned="true"][data-pos="MEIO"]       { top: 50%; transform: translateY(-50%); text-align: center; }
.text-block[data-positioned="true"][data-pos="MEIO.DIR"]   { top: 50%; transform: translateY(-50%); text-align: right;  }
.text-block[data-positioned="true"][data-pos="INF.ESQ"]    { bottom: 1cqw; text-align: left;   }
.text-block[data-positioned="true"][data-pos="INF.CENTRO"] { bottom: 1cqw; text-align: center; }
.text-block[data-positioned="true"][data-pos="INF.DIR"]    { bottom: 1cqw; text-align: right;  }

/* CAPA: respiro maior na base (4cqw) — preserva o feel original do briefing
   para que mover H1 entre INF.ESQ/INF.CENTRO/INF.DIR não suba o texto */
.slide-card[data-tipo="capa"] .text-block[data-positioned="true"][data-pos^="INF."] {
  bottom: 4cqw;
}

/* GRADE: text-blocks SEMPRE em fluxo — nunca absolute.
   Razão: no estilo Grade, .slide-body é content-sized (flex-shrink:0, flex-grow:0)
   e divide espaço com .slide-image-container. Posicionamento absoluto faz o
   text-block sair do fluxo, o slide-body colapsa, e os textos/imagens se
   sobrepõem. Mantemos o text-align horizontal vindo dos data-pos rules
   (centralizar/alinhar à direita continua funcionando), só anulamos o
   posicionamento vertical e a propriedade position. */
.slide-card[data-estilo="Grade"] .text-block[data-positioned="true"] {
  position: static;
  top: auto;
  bottom: auto;
  left: auto;
  right: auto;
  transform: none;
}

/* Alinhamento (sobrescreve text-align — vale com ou sem position) */
.text-block[data-align="ESQ"]    { text-align: left;   }
.text-block[data-align="CENTRO"] { text-align: center; }
.text-block[data-align="DIR"]    { text-align: right;  }

/* H2 ancorado ao H1 (mesma célula da 9-grid): herda a posição absoluta do H1,
   flui em flex column logo abaixo do H1, com respiro de 2cqw */
.text-block[data-element="h1"] > .text-block[data-element="h2"] {
  margin-top: 2cqw;
  width: 100%;
}

/* Textarea de edição inline no painel do editor */
.control-textarea {
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 0.5rem;
  padding: 0.55rem 0.65rem;
  color: var(--text-primary);
  font-family: var(--font-family);
  font-size: 0.82rem;
  line-height: 1.4;
  resize: vertical;
  width: 100%;
  min-height: 50px;
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.control-textarea:focus {
  border-color: var(--accent-color);
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
}

.control-textarea::placeholder {
  color: #52525b;
}

/* Word pills no H1 — sempre rendererizados como spans inline */
.word-pill {
  display: inline-block;
  transition: opacity 0.15s ease, outline-color 0.15s ease;
}

/* Quando o slide está selecionado, pills viram clicáveis com hint visual */
.slide-card.selected .word-pill {
  cursor: pointer;
  outline: 2px dashed transparent;
  outline-offset: 3px;
  border-radius: 4px;
}

.slide-card.selected .word-pill:hover {
  outline-color: var(--accent-color);
  opacity: 0.85;
}

.word-pill.editing {
  outline: 2px solid var(--accent-color) !important;
  outline-offset: 3px;
  border-radius: 4px;
}

/* POPOVER de edição de palavra (flutuante, fixed) */
.word-popover {
  position: fixed;
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: 0.75rem;
  padding: 1rem;
  z-index: 9999;
  box-shadow: 0 12px 40px rgba(0,0,0,0.6);
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  min-width: 230px;
  font-family: var(--font-family);
}

.word-popover[hidden] { display: none; }

.word-popover-title {
  font-size: 0.75rem;
  color: var(--text-secondary);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.word-popover-title b {
  color: var(--accent-color);
  font-weight: 700;
}

.word-popover-row {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.word-popover-row label {
  font-size: 0.7rem;
  color: var(--text-secondary);
  font-weight: 500;
}

.word-popover input[type="color"],
.word-popover select {
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 0.5rem;
  color: var(--text-primary);
  padding: 0.5rem;
  font-family: var(--font-family);
  font-size: 0.85rem;
  width: 100%;
}

.word-popover input[type="color"] {
  height: 36px;
  padding: 2px;
  cursor: pointer;
}

.word-popover-actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.25rem;
}

.word-popover-actions button {
  flex: 1;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  color: var(--text-secondary);
  padding: 0.55rem;
  border-radius: 0.5rem;
  font-family: var(--font-family);
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}

.word-popover-actions button:hover {
  background: var(--bg-surface-hover);
  color: var(--text-primary);
}

.word-popover-actions .btn-popover-primary {
  background: var(--accent-color);
  border-color: var(--accent-color);
  color: white;
}
.word-popover-actions .btn-popover-primary:hover { background: var(--accent-hover); color: white; }

/* PAINEL DE EDIÇÃO DO SLIDE na sidebar */
.editor-slide-panel {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--border-color);
  margin-bottom: 0.5rem;
}

.editor-slide-panel[hidden] { display: none; }

.editor-slide-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}

.editor-element-section {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--border-color);
  border-radius: 0.6rem;
  padding: 0.85rem;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.editor-element-section .control-label {
  margin: 0;
}

/* Linha de alinhamento (3 botões) */
.alignment-row {
  display: flex;
  gap: 4px;
}

.alignment-row button {
  flex: 1;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  cursor: pointer;
  color: var(--text-secondary);
  padding: 0.5rem 0;
  font-size: 0.85rem;
  font-weight: 600;
  transition: all 0.2s ease;
}

.alignment-row button:hover {
  background: var(--bg-surface-hover);
  color: var(--text-primary);
}

.alignment-row button.active {
  background: var(--accent-color);
  border-color: var(--accent-color);
  color: white;
}

/* ============================================
   ORIENTATION TOGGLE GROUP — 9 posições em pílula horizontal compacta
   (referência Base UI Toggle Group, adaptado pra nossa identidade visual)
   Botões gerados via JS pra evitar 9 SVGs duplicados em 2 lugares no HTML.
   ============================================ */

.orientation-toggle-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
  width: fit-content;
}

.orientation-toggle-pill {
  display: flex;
  gap: 1px;
  border-radius: 0.5rem;
  border: 1px solid var(--border-color);
  background: rgba(255, 255, 255, 0.03);
  padding: 2px;
}

.orientation-toggle-group button {
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  border-radius: 4px;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 0;
  transition: background 0.18s ease, color 0.18s ease;
}

.orientation-toggle-group button:hover {
  background: rgba(255, 255, 255, 0.06);
  color: var(--text-primary);
}

.orientation-toggle-group button:active {
  background: rgba(255, 255, 255, 0.1);
}

.orientation-toggle-group button.active {
  background: rgba(99, 102, 241, 0.18);
  color: var(--accent-color);
}

.orientation-toggle-group button svg {
  width: 25px;
  height: 25px;
  display: block;
}

/* Controles tipográficos (size/weight/color/family) */
.font-controls {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.font-controls .ctrl-row {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.font-controls .ctrl-label {
  font-size: 0.7rem;
  color: var(--text-secondary);
  font-weight: 500;
  min-width: 56px;
}

.font-controls select,
.font-controls input[type="color"] {
  flex: 1;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 0.5rem;
  color: var(--text-primary);
  padding: 0.45rem 0.5rem;
  font-family: var(--font-family);
  font-size: 0.8rem;
  cursor: pointer;
}

.font-controls input[type="color"] {
  height: 32px;
  padding: 2px;
  flex: 0 0 38px;
  width: 38px;
}

.font-controls .control-slider {
  flex: 1;
  margin: 0;
}

.btn-reset-slide {
  background: transparent;
  border: 1px solid rgba(239, 68, 68, 0.3);
  color: #fca5a5;
  padding: 0.55rem 1rem;
  border-radius: 0.5rem;
  cursor: pointer;
  font-size: 0.78rem;
  font-weight: 500;
  font-family: var(--font-family);
  transition: all 0.2s ease;
}

.btn-reset-slide:hover {
  background: rgba(239, 68, 68, 0.1);
  color: #fef2f2;
}


/* ============================================
   TIPOGRAFIA — Briefing reduzido 30% (preview travado em 756px)
   Mantém hierarquia: H1 capa > H1 normal > H2 capa > H2 normal > parágrafo
   ============================================ */

/* Slides secundários (default) */
.slide-h1 {
  font-size: 6.5cqw;       /* 80pt @ 96dpi × 0.7 = 75px ≈ 6.93cqw */
  font-weight: 700;
  line-height: 1.1;
  font-family: var(--font-heading, 'Poppins', sans-serif);
  color: var(--slide-text, #ffffff);
  letter-spacing: -0.02em;
  text-transform: uppercase;
}

.slide-h2 {
  font-size: 3.96cqw;      /* base 180% (era 2.2cqw — usuário considerou pequeno demais) */
  font-weight: 400;
  opacity: 0.75;
  font-family: var(--font-body, 'Lora', serif);
  color: var(--slide-text, #ffffff);
}

.slide-p {
  font-size: 3.15cqw;      /* base 180% (era 1.75cqw — escala junto com H2) */
  line-height: 1.45;
  opacity: 0.7;
  font-family: var(--font-body, 'Lora', serif);
  color: var(--slide-text, #ffffff);
  margin-top: 0.5cqw;
}

/* CAPA (slide 1): tipografia mais impactante */
.slide-card[data-tipo="capa"] .slide-h1 {
  font-size: 9.5cqw;       /* 110pt @ 96dpi × 0.7 = 102.7px ≈ 9.5cqw */
  line-height: 1.0;
  font-weight: 900;
  letter-spacing: -0.04em;
}

.slide-card[data-tipo="capa"] .slide-h2 {
  font-size: 4.68cqw;      /* base 180% (era 2.6cqw) */
  opacity: 0.85;
  font-weight: 500;
}

.slide-card[data-tipo="capa"] .slide-p {
  font-size: 3.15cqw;      /* base 180% (era 1.75cqw) */
  opacity: 0.7;
  margin-top: 0.8cqw;
}

/* CAPA: texto posicionado do meio para baixo (regra do briefing seção 3)
   justify-content: flex-end empurra o conteúdo para a base do body,
   que fica logo acima dos assets inferiores → texto na metade de baixo */
.slide-card[data-tipo="capa"] .slide-body {
  justify-content: flex-end;
  padding-bottom: 4cqw; /* respiro entre texto e assets-bottom */
}

/* ============================================
   CONTROLES DO EDITOR — Estilo Só Fundo
   ============================================ */

.control-slider-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.control-slider {
  flex: 1;
  -webkit-appearance: none;
  appearance: none;
  height: 4px;
  background: var(--border-color);
  border-radius: 2px;
  outline: none;
  cursor: pointer;
}

.control-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--accent-color);
  cursor: pointer;
  box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.15);
  transition: transform 0.1s ease;
}

.control-slider::-webkit-slider-thumb:hover {
  transform: scale(1.15);
}

.control-slider-value {
  min-width: 42px;
  text-align: right;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--accent-color);
  font-variant-numeric: tabular-nums;
}

.control-color-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.control-color-picker {
  -webkit-appearance: none;
  appearance: none;
  width: 38px;
  height: 38px;
  border: 2px solid var(--border-color);
  border-radius: 0.5rem;
  background: transparent;
  cursor: pointer;
  padding: 0;
  flex-shrink: 0;
  transition: border-color 0.2s ease;
}

.control-color-picker:hover {
  border-color: var(--accent-color);
}

.control-color-picker::-webkit-color-swatch-wrapper { padding: 2px; border-radius: 0.4rem; }
.control-color-picker::-webkit-color-swatch { border: none; border-radius: 0.3rem; }

.control-color-hex {
  font-size: 0.78rem;
  color: var(--text-secondary);
  font-family: 'SF Mono', Menlo, monospace;
  text-transform: uppercase;
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

/* ============================================
   MODAL POPOVER (genérico) — usado em "+ Outros" do público-alvo
   e por outros futuros prompts customizados
   ============================================ */
.popover-modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  animation: popoverFadeIn 0.2s ease;
}

.popover-modal[hidden] { display: none; }

@keyframes popoverFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

.popover-modal-content {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: 1rem;
  padding: 2rem;
  max-width: 480px;
  width: 100%;
  box-shadow: 0 24px 80px rgba(0,0,0,0.7);
  animation: popoverIn 0.35s cubic-bezier(0.34, 1.4, 0.64, 1);
}

@keyframes popoverIn {
  from { opacity: 0; transform: scale(0.92) translateY(20px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

.popover-modal-content h3 {
  font-size: 1.25rem;
  margin-bottom: 0.5rem;
  color: var(--text-primary);
  letter-spacing: -0.01em;
}

.popover-modal-content > p {
  font-size: 0.9rem;
  color: var(--text-secondary);
  margin-bottom: 1.25rem;
  line-height: 1.5;
}

.popover-modal-content input[type="text"] {
  width: 100%;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 0.6rem;
  color: var(--text-primary);
  padding: 0.85rem 1rem;
  font-family: var(--font-family);
  font-size: 1rem;
  outline: none;
  margin-bottom: 1.25rem;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.popover-modal-content input[type="text"]:focus {
  border-color: var(--accent-color);
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
}

.popover-modal-actions {
  display: flex;
  gap: 0.75rem;
  justify-content: flex-end;
}

.popover-modal-actions button {
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  color: var(--text-secondary);
  padding: 0.7rem 1.4rem;
  border-radius: 0.6rem;
  font-family: var(--font-family);
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}

.popover-modal-actions button:hover {
  background: var(--bg-surface-hover);
  color: var(--text-primary);
}

.popover-modal-actions .btn-popover-primary {
  background: var(--accent-color);
  border-color: var(--accent-color);
  color: white;
}

.popover-modal-actions .btn-popover-primary:hover {
  background: var(--accent-hover);
  color: white;
}

/* ============================================
   CORES RECENTES — Memoria das últimas 8 cores usadas em qualquer color picker.
   Persistido em localStorage, JS injeta uma row .recent-colors após cada
   <input type="color">. Click num swatch aplica a cor no input mais próximo.
   ============================================ */

.recent-colors {
  display: grid;
  grid-template-columns: repeat(7, 1fr);    /* 2 linhas × 7 colunas = 14 max */
  gap: 4px;
  width: 100%;
  flex-basis: 100%;     /* força quebra de linha em flex rows (color picker fica acima) */
  margin-top: 4px;
}

.recent-colors:empty {
  display: none;
}

.recent-color-swatch {
  width: 100%;
  aspect-ratio: 1;
  height: auto;
  border-radius: 4px;
  border: 1px solid var(--border-color);
  cursor: pointer;
  padding: 0;
  background-clip: padding-box;
  transition: transform 0.15s ease, border-color 0.15s ease;
}

.recent-color-swatch:hover {
  transform: scale(1.18);
  border-color: var(--accent-color);
}

/* ============================================
   FASE C.1: SAVE STYLE + MEUS ESTILOS
   ============================================ */

/* Botão "Salvar estilo" — acima do "Baixar carrossel" no sidebar-footer */
.btn-save-style {
  width: 100%;
  background: transparent;
  color: var(--text-primary);
  border: 1px solid var(--border-color);
  padding: 0.85rem 1rem;
  font-size: 0.88rem;
  font-weight: 500;
  font-family: var(--font-family);
  border-radius: 0.7rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  transition: all 0.2s ease;
  margin-bottom: 0.6rem;
}

.btn-save-style:hover {
  background: rgba(99, 102, 241, 0.08);
  border-color: var(--accent-color);
  color: var(--accent-color);
}

/* Botão "Meus estilos" no top bar */
.btn-top-bar-secondary {
  background: rgba(255, 255, 255, 0.05);
  color: var(--text-primary);
  border: 1px solid var(--border-color);
  padding: 0.5rem 0.95rem;
  border-radius: 0.5rem;
  font-family: var(--font-family);
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  transition: all 0.2s ease;
}

.btn-top-bar-secondary:hover {
  background: rgba(99, 102, 241, 0.1);
  border-color: var(--accent-color);
  color: var(--accent-color);
}

/* Modal "Meus estilos" — header com close button + grid de cards */
.popover-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.4rem;
}

.popover-modal-header h3 {
  margin: 0;
}

.btn-modal-close {
  background: transparent;
  border: none;
  color: var(--text-secondary);
  font-size: 1.5rem;
  cursor: pointer;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  line-height: 1;
  transition: all 0.2s ease;
}

.btn-modal-close:hover {
  background: rgba(255, 255, 255, 0.05);
  color: var(--text-primary);
}

.meus-estilos-content {
  max-width: 640px;
  max-height: 80vh;
  overflow-y: auto;
}

.meus-estilos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 0.75rem;
  margin-top: 0.75rem;
}

.meus-estilos-grid:empty::before {
  content: 'Você ainda não salvou nenhum estilo. Clique em "Salvar estilo" no rodapé da sidebar pra criar o primeiro.';
  color: var(--text-secondary);
  font-size: 0.88rem;
  line-height: 1.5;
  grid-column: 1 / -1;
  padding: 2.5rem 1rem;
  text-align: center;
  border: 1px dashed var(--border-color);
  border-radius: 0.6rem;
}

.estilo-card {
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 0.75rem;
  padding: 1rem;
  cursor: pointer;
  position: relative;
  transition: all 0.2s ease;
  min-height: 90px;
}

.estilo-card:hover {
  border-color: var(--accent-color);
  background: rgba(99, 102, 241, 0.06);
  transform: translateY(-2px);
}

.estilo-card-name {
  font-weight: 600;
  color: var(--text-primary);
  font-size: 0.9rem;
  margin-bottom: 0.4rem;
  word-break: break-word;
  padding-right: 1.5rem;   /* deixa espaço pro botão delete no canto */
}

.estilo-card-date {
  font-size: 0.72rem;
  color: var(--text-secondary);
  font-variant-numeric: tabular-nums;
}

.estilo-card-delete {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  background: transparent;
  border: none;
  color: var(--text-secondary);
  width: 22px;
  height: 22px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  line-height: 1;
  opacity: 0;
  transition: all 0.2s ease;
}

.estilo-card:hover .estilo-card-delete {
  opacity: 1;
}

.estilo-card-delete:hover {
  background: rgba(239, 68, 68, 0.15);
  color: #fca5a5;
}

/* ============================================
   FASE C.2: HISTÓRICO DE CARROSSEIS — TELA 2
   Cards com thumbnail (slide 1), título e data. Click reabre o carrossel.
   ============================================ */

.meus-carrosseis-section {
  width: 100%;
  margin-bottom: 1.5rem;
  padding: 1.25rem;
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: 1rem;
}

.meus-carrosseis-section[hidden] { display: none; }

.meus-carrosseis-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.85rem;
}

.meus-carrosseis-header h3 {
  font-size: 1.1rem;
  margin: 0;
  color: var(--text-primary);
}

.meus-carrosseis-hint {
  font-size: 0.75rem;
  color: var(--text-secondary);
}

.meus-carrosseis-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 0.75rem;
}

.carrossel-card {
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 0.75rem;
  overflow: hidden;
  cursor: pointer;
  position: relative;
  transition: all 0.2s ease;
}

.carrossel-card:hover {
  border-color: var(--accent-color);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(99, 102, 241, 0.15);
}

.carrossel-card-thumb {
  width: 100%;
  aspect-ratio: 1 / 1;
  background-size: cover;
  background-position: center;
  background-color: #1a1a1a;
  background-image: linear-gradient(135deg, #2a2a2a 0%, #1a1a1a 100%);
}

.carrossel-card-info {
  padding: 0.6rem 0.7rem 0.7rem;
}

.carrossel-card-name {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 0.25rem;
  line-height: 1.3;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
}

.carrossel-card-meta {
  font-size: 0.68rem;
  color: var(--text-secondary);
  font-variant-numeric: tabular-nums;
}

.carrossel-card-delete {
  position: absolute;
  top: 0.4rem;
  right: 0.4rem;
  background: rgba(0, 0, 0, 0.65);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: none;
  color: white;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  line-height: 1;
  opacity: 0;
  transition: all 0.2s ease;
}

.carrossel-card:hover .carrossel-card-delete {
  opacity: 1;
}

.carrossel-card-delete:hover {
  background: rgba(239, 68, 68, 0.85);
}

/* ============================================
   EDITOR DE ASSETS FIXOS — Sidebar
   Cada asset (handle, tagline, brand, arrow, dots) vive em um .asset-block
   com header (label + toggle de visibilidade) e controles abaixo
   ============================================ */

/* Bloco principal de cada asset */
.asset-block {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--border-color);
  border-radius: 0.55rem;
  padding: 0.7rem 0.8rem;
  margin-top: 0.6rem;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.asset-block-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}

.asset-block-header > label {
  font-size: 0.78rem;
  color: var(--text-primary);
  font-weight: 600;
  margin: 0;
  flex: 1;
  min-width: 0;
}

/* Toggle do asset-block — tamanho padrão 48×26 (igual ao toggle-switch-wrapper).
   !important + flex: 0 0 48px defensivo pra garantir que NUNCA estique mesmo
   dentro de containers flex que tentem fazer o item crescer. */
.asset-toggle-mini {
  position: relative;
  display: inline-block;
  width: 48px !important;
  height: 26px !important;
  flex: 0 0 48px !important;
  flex-shrink: 0;
  cursor: pointer;
  box-sizing: border-box;
}

.asset-toggle-mini input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.asset-toggle-thumb {
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid var(--border-color);
  border-radius: 999px;
  transition: var(--transition);
}

.asset-toggle-thumb::after {
  content: '';
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--text-secondary);
  /* Transição elástica/spring (overshoot ao chegar no destino) */
  transition:
    transform 0.45s cubic-bezier(0.34, 1.56, 0.64, 1),
    background 0.25s ease;
}

.asset-toggle-mini input:checked + .asset-toggle-thumb {
  background: rgba(99, 102, 241, 0.25);
  border-color: var(--accent-color);
}

.asset-toggle-mini input:checked + .asset-toggle-thumb::after {
  transform: translateX(22px);
  background: var(--accent-color);
}

/* Sub-label dentro de um block (ex: "Estilo", "Cor", "Ícone") */
.asset-mini-label {
  font-size: 0.65rem;
  color: var(--text-secondary);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-top: 0.15rem;
}

/* Linha de checkboxes (mostrar texto / mostrar ícone) */
.asset-mini-toggles {
  display: flex;
  gap: 1rem;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 0.1rem;
}

.asset-mini-check {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.75rem;
  color: var(--text-secondary);
  cursor: pointer;
  user-select: none;
}

.asset-mini-check input[type="checkbox"] {
  accent-color: var(--accent-color);
  width: 13px;
  height: 13px;
  cursor: pointer;
}

/* Variante compacta do Instagram input para caber no asset-block */
.instagram-input-wrapper.compact {
  height: 32px;
  border-radius: 0.5rem;
  flex: 1;
  min-width: 0;
}

.instagram-input-wrapper.compact .instagram-input {
  font-size: 0.82rem;
  padding: 0.4rem 0.6rem 0.4rem 0.2rem;
}

.instagram-input-wrapper.compact .input-prefix {
  font-size: 0.85rem;
  padding: 0.4rem 0.15rem 0.4rem 0.65rem;
}

/* Quando block está desabilitado, o conteúdo fica esmaecido */
.asset-block.disabled > :not(.asset-block-header) {
  opacity: 0.4;
  pointer-events: none;
}

.asset-row {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.4rem;
}

.asset-row.stacked {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.45rem;
}

.asset-row > label {
  font-size: 0.7rem;
  color: var(--text-secondary);
  font-weight: 500;
  grid-column: 1 / -1;
  margin-bottom: 0.1rem;
}

.asset-row.stacked > label {
  margin-bottom: 0;
}

.asset-row input[type="text"] {
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 0.5rem;
  color: var(--text-primary);
  padding: 0.45rem 0.6rem;
  font-family: var(--font-family);
  font-size: 0.82rem;
  outline: none;
  transition: border-color 0.2s ease;
  min-width: 0;       /* impede overflow no grid */
}

.asset-row input[type="text"]:focus {
  border-color: var(--accent-color);
}

.asset-row input[type="color"] {
  -webkit-appearance: none;
  appearance: none;
  width: 36px;
  height: 32px;
  border: 1px solid var(--border-color);
  border-radius: 0.4rem;
  background: transparent;
  cursor: pointer;
  padding: 2px;
}
.asset-row input[type="color"]::-webkit-color-swatch-wrapper { padding: 1px; border-radius: 0.3rem; }
.asset-row input[type="color"]::-webkit-color-swatch { border: none; border-radius: 0.25rem; }

/* Linha de botões para escolher estilo (setas e elipses) */
.asset-style-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
}

.asset-style-row button {
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  cursor: pointer;
  color: var(--text-secondary);
  padding: 0.45rem 0.25rem;
  font-size: 0.78rem;
  font-weight: 600;
  font-family: var(--font-family);
  transition: all 0.2s ease;
  min-width: 0;       /* permite encolher sem overflow */
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.asset-style-row button:hover {
  background: var(--bg-surface-hover);
  color: var(--text-primary);
}

.asset-style-row button.active {
  background: rgba(99, 102, 241, 0.15);
  border-color: var(--accent-color);
  color: var(--accent-color);
}

/* ============================================
   ESTILOS DAS ELIPSES (4 variantes)
   default = circle | dot-line | dot-square | dot-pill
   Aplicados via [data-style="..."] no .asset-dots
   ============================================ */

/* dot-line: linhas horizontais (ativo é mais largo) */
.asset-dots[data-style="dot-line"] .asset-dot {
  width: 1.5cqw;
  min-width: 8px;
  height: 0.25cqw;
  min-height: 2px;
  border-radius: 0;
  border: none;
  background: currentColor;
  opacity: 0.4;
}
.asset-dots[data-style="dot-line"] .asset-dot.active {
  opacity: 1;
  width: 2.5cqw;
  min-width: 14px;
}

/* dot-square: quadrados em vez de círculos */
.asset-dots[data-style="dot-square"] .asset-dot {
  border-radius: 0;
}

/* dot-pill: pequenas pílulas verticais (ativo é mais alto) */
.asset-dots[data-style="dot-pill"] .asset-dot {
  width: 0.5cqw;
  min-width: 4px;
  height: 1cqw;
  min-height: 8px;
  border-radius: 999px;
  border: none;
  background: currentColor;
  opacity: 0.4;
}
.asset-dots[data-style="dot-pill"] .asset-dot.active {
  opacity: 1;
  height: 1.6cqw;
  min-height: 12px;
}

/* ============================================
   IMAGEM POR SLIDE — Editor (no painel do slide selecionado)
   ============================================ */

.slide-image-controls {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.btn-slide-image,
.btn-slide-image-revert {
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 0.5rem;
  color: var(--text-primary);
  padding: 0.55rem 0.75rem;
  font-size: 0.82rem;
  font-weight: 500;
  font-family: var(--font-family);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  transition: all 0.2s ease;
}

.btn-slide-image:hover {
  background: rgba(99, 102, 241, 0.1);
  border-color: var(--accent-color);
  color: var(--accent-color);
}

.btn-slide-image-revert {
  background: transparent;
  color: var(--text-secondary);
  font-size: 0.75rem;
  padding: 0.4rem 0.75rem;
}

.btn-slide-image-revert:hover {
  color: var(--text-primary);
  border-color: rgba(255,255,255,0.18);
}

/* Bloco de controles que só aparece no estilo "Grade" (inverter + largura) */
.grade-only-controls {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 0.5rem;
  padding-top: 0.6rem;
  border-top: 1px dashed var(--border-color);
}

.grade-only-controls[hidden] { display: none; }

/* O <img> do Grade precisa permitir transform pra zoom (overflow:hidden no container já existe) */
.slide-image-container img {
  transform-origin: center center;
  transition: transform 0.15s ease, object-position 0.15s ease;
}
