:root {
  --bg: #101015;
  --panel: #171a22;
  --text: #e5e7eb;
  --muted: #9aa1ac;
  --accent: #7c5cff;
  --accent-2: #2dd4bf;
  --danger: #ef4444;
  --border: #2a2f3a;
}
:root.light {
  --bg: #f7f7f8; --panel: #ffffff; --text: #0b1220; --muted: #4b5563; --accent: #6d28d9;
  --accent-2: #0ea5e9; --danger: #dc2626; --border: #e5e7eb;
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0; font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Noto Sans", "Helvetica Neue", Arial, "Apple Color Emoji", "Segoe UI Emoji";
  background: var(--bg); color: var(--text);
}

.topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px; border-bottom: 1px solid var(--border); background: var(--panel);
}
.tabs { display: flex; gap: 8px; }
.tab-btn {
  background: transparent; color: var(--text); border: 1px solid var(--border);
  padding: 8px 12px; border-radius: 8px; cursor: pointer;
}
.tab-btn.active, .btn.primary { background: var(--accent); border-color: var(--accent); color: white; }
.btn { background: var(--panel); color: var(--text); border: 1px solid var(--border); padding: 6px 10px; border-radius: 8px; cursor: pointer; }
.btn.success { background: var(--accent-2); border-color: var(--accent-2); color: #03251f; }
.btn.danger { background: var(--danger); border-color: var(--danger); color: white; }

main { padding: 12px; }
.tab { display: none; }
.tab.active { display: block; }

.editor-layout {
  display: grid; grid-template-columns: 280px 1fr 220px; gap: 12px; align-items: start;
}
.editor-sidebar, .editor-preview, .panel { background: var(--panel); border: 1px solid var(--border); border-radius: 10px; }
.editor-sidebar { padding: 12px; display: flex; flex-direction: column; gap: 12px; }
.panel { padding: 12px; }
.canvas-wrap {
  background: #0b0f15; border: 1px solid var(--border); border-radius: 10px; padding: 12px; display: flex; justify-content: center; align-items: center;
}
#editorCanvas { image-rendering: pixelated; background: #0b0f15; border-radius: 6px; }

.timeline { margin-top: 12px; background: var(--panel); border: 1px solid var(--border); border-radius: 10px; padding: 8px; }
.timeline-controls { display: flex; gap: 8px; margin-bottom: 8px; }
.frames-strip { display: flex; gap: 8px; overflow-x: auto; padding-bottom: 4px; }
.frame-thumb {
  border: 2px solid transparent; border-radius: 6px; background: #0b0f15; padding: 4px; cursor: pointer;
}
.frame-thumb.active { border-color: var(--accent); }
.frame-thumb canvas { image-rendering: pixelated; }

.palette { display: grid; grid-template-columns: repeat(8, 1fr); gap: 6px; margin-bottom: 8px; }
.swatch { width: 28px; height: 28px; border-radius: 6px; border: 1px solid var(--border); cursor: pointer; }
.swatch.selected { outline: 2px solid var(--accent); }

.editor-preview { padding: 12px; }
#previewCanvas { image-rendering: pixelated; background: #0b0f15; border-radius: 8px; border: 1px solid var(--border); }

.row, .tool-row, .lang-row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.settings-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; }
.setting { background: var(--panel); border: 1px solid var(--border); border-radius: 10px; padding: 12px; }

.shop-header { display: flex; gap: 8px; margin-bottom: 12px; }
.shop-header input { width: 100%; padding: 8px; border-radius: 8px; border: 1px solid var(--border); background: var(--panel); color: var(--text); }

.statusbar { position: sticky; bottom: 0; padding: 8px 12px; border-top: 1px solid var(--border); background: var(--panel); color: var(--muted); }