* { box-sizing: border-box; margin: 0; padding: 0; } /* ── Dark theme (default) ────────────────────────────────────── */ :root { --bg-primary: #1a1a1a; --bg-secondary: #252525; --bg-tertiary: #333; --border: #444; --text-primary: #e0e0e0; --text-secondary: #888; --accent: #60a5fa; --accent-hover: #93c5fd; --success: #10b981; --warning: #f59e0b; --danger: #ef4444; } /* ── Light theme overrides ───────────────────────────────────── */ html[data-theme="light"] { --bg-primary: #f4f4f2; --bg-secondary: #e8e8e5; --bg-tertiary: #d8d8d4; --border: #b4b4b0; --text-primary: #1a1a18; --text-secondary: #5a5a56; --accent: #2563eb; --accent-hover: #1d4ed8; --success: #059669; --warning: #d97706; --danger: #dc2626; } /* ── Base ────────────────────────────────────────────────────── */ body { font-family: "SF Mono", "Cascadia Code", "JetBrains Mono", "Fira Code", Monaco, "Courier New", monospace; background: var(--bg-primary); color: var(--text-primary); overflow: hidden; font-size: 13px; } .app { display: flex; flex-direction: column; height: 100vh; } /* ── Header ──────────────────────────────────────────────────── */ .header { display: flex; justify-content: space-between; align-items: center; padding: 10px 16px; background: var(--bg-secondary); border-bottom: 1px solid var(--border); -webkit-app-region: drag; } .header-left, .header-right { display: flex; align-items: center; gap: 8px; -webkit-app-region: no-drag; } /* App wordmark */ .app-wordmark { font-size: 12px; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; color: var(--text-primary); padding-right: 12px; border-right: 1px solid var(--border); margin-right: 4px; user-select: none; white-space: nowrap; } .header select, .header button { padding: 5px 10px; background: var(--bg-tertiary); border: 1px solid var(--border); border-radius: 2px; color: var(--text-primary); cursor: pointer; font-size: 12px; font-family: inherit; } .header button:hover { background: var(--border); } .header button.btn-delete { background: transparent; border: 1px solid var(--border); padding: 5px 8px; font-size: 13px; } .header button.btn-delete:hover { background: var(--danger); border-color: var(--danger); } .header button.btn-rename { background: transparent; border: 1px solid var(--border); padding: 5px 8px; font-size: 13px; } .header button.btn-rename:hover { background: var(--bg-tertiary); } /* Theme toggle */ .theme-toggle { font-size: 11px; letter-spacing: 0.08em; text-transform: lowercase; opacity: 0.7; transition: opacity 0.15s; } .theme-toggle:hover { opacity: 1; background: var(--bg-tertiary) !important; } /* Phase indicator */ .phase-indicator { display: flex; gap: 4px; } .phase-step { padding: 3px 10px; font-size: 11px; letter-spacing: 0.07em; text-transform: uppercase; border-radius: 2px; background: var(--bg-tertiary); color: var(--text-secondary); border: none; font-family: inherit; } /* Reachable phases rendered as