:root{--chrome: #2d2d2d;--rail: #303030;--panel: #1f1f1f;--accent: #c4c4c4;--text: #e0e0e0;--muted: #b5b5b5;--status: #2b2b2b;--border: #050505;--canvas: #ffffff;--pill-green: #4ade80;--pill-yellow: #facc15;--pill-red: #f87171;font-family:IBM Plex Sans,Segoe UI,sans-serif;color:var(--text);background-color:var(--panel)}*,*:before,*:after{box-sizing:border-box}body{margin:0;background:#161616}#root{min-height:100vh}.paint-app{display:flex;flex-direction:column;min-height:100vh;background:radial-gradient(circle at 10% 10%,rgba(255,255,255,.04),transparent 40%),radial-gradient(circle at 90% 0%,rgba(255,255,255,.03),transparent 35%),var(--panel)}.title-bar{height:28px;display:flex;align-items:center;gap:12px;padding:0 14px;background:#1a1a1a;border-bottom:1px solid #1f1f1f;color:var(--muted);font-size:12px;letter-spacing:.02em}.title-text{color:var(--text);font-weight:600}.menu-bar{display:flex;align-items:center;padding:0 10px;height:34px;background:var(--chrome);color:var(--text);border-bottom:1px solid #1c1c1c;position:relative}.menu-root{position:relative;height:100%}.menu-label{background:none;border:none;color:var(--text);padding:0 12px;height:100%;cursor:pointer;font-weight:600}.menu-root:hover .menu-label,.menu-root.open .menu-label{background:#3a3a3a}.menu-dropdown{position:absolute;top:100%;left:0;background:#2f2f2f;border:1px solid #1b1b1b;box-shadow:0 8px 24px #00000073;min-width:160px;z-index:5;display:grid}.menu-item{background:none;border:none;color:var(--text);text-align:left;padding:8px 12px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px}.menu-item:hover{background:#414141}.menu-item.disabled,.menu-item:disabled{opacity:.45;cursor:not-allowed}.menu-chip{background:#3a3a3a;color:var(--muted);border-radius:999px;padding:2px 8px;font-size:11px;border:1px solid #1c1c1c}.menu-right{margin-left:auto;display:flex;align-items:center;gap:8px}.workspace{display:grid;grid-template-columns:120px minmax(0,1fr) 320px;gap:0;min-height:calc(100vh - 152px)}.workspace.rail-collapsed{grid-template-columns:54px minmax(0,1fr) 320px}.tool-rail{background:var(--rail);border-right:1px solid #1c1c1c;padding:10px 8px;display:flex;flex-direction:column;gap:14px;box-sizing:border-box;width:120px;min-width:120px}.tool-rail.collapsed{align-items:center;gap:10px;padding:10px 6px;width:54px;min-width:54px}.tool-rail-header{display:flex;align-items:center;justify-content:space-between;gap:6px}.rail-title{color:var(--muted);font-size:12px;letter-spacing:.04em;text-transform:uppercase}.rail-toggle{background:#2a2a2a;border:1px solid #1c1c1c;color:var(--text);width:26px;height:26px;border-radius:6px;cursor:pointer;display:grid;place-items:center}.tool-rail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.tool-rail.collapsed .tool-rail-grid{grid-template-columns:1fr}.tool-button{background:#2a2a2a;border:1px solid #1c1c1c;color:var(--text);height:36px;border-radius:4px;cursor:pointer;width:100%;display:inline-flex;align-items:center;justify-content:center;gap:6px}.tool-button:hover{border-color:var(--accent)}.tool-button.active{outline:1px solid var(--accent);background:#3a3a3a}.tool-split{position:relative;display:grid;grid-template-columns:1fr 28px;gap:4px}.eraser-duo{display:grid;grid-template-columns:1fr;gap:6px}.tool-rail.collapsed .eraser-duo .eraser-chip{display:none}.tool-button.caret{padding:0 6px;font-size:14px}.eraser-chip{display:inline-flex;align-items:center;justify-content:center;background:#111;color:var(--text);border:1px solid #333;border-radius:6px;font-size:10px;padding:2px 6px;margin-left:6px}.eraser-menu{position:absolute;top:40px;left:0;right:0;background:#1f1f1f;border:1px solid #111;border-radius:8px;padding:6px;display:grid;gap:4px;z-index:5;box-shadow:0 6px 18px #0006}.menu-item-btn{background:#262626;border:1px solid #111;color:var(--text);border-radius:6px;padding:6px 8px;text-align:left;cursor:pointer}.menu-item-btn:hover{border-color:var(--accent)}.menu-item-btn.active{background:#3a3a3a;outline:1px solid var(--accent)}.color-chips{display:flex;align-items:center;gap:8px}.tool-rail.collapsed .color-chips,.tool-rail.collapsed .rail-section{display:none}.primary-chip,.secondary-chip{width:30px;height:30px;border:1px solid #111;box-shadow:0 0 0 1px #444;display:grid;place-items:center;font-size:11px;font-weight:700;color:#111;cursor:pointer}.swap-btn{background:#2a2a2a;border:1px solid #1c1c1c;color:var(--text);padding:6px 8px;cursor:pointer}.rail-section{border-top:1px solid #1c1c1c;padding-top:8px}.rail-label{color:var(--muted);font-size:12px;margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em}.size-row,.type-row{display:flex;flex-wrap:wrap;gap:6px}.size-dot{width:32px;height:26px;border:1px solid #1c1c1c;background:#2a2a2a;display:grid;place-items:center;cursor:pointer}.size-dot span{display:block;background:var(--text);border-radius:50%}.size-dot.active{outline:1px solid var(--accent);background:#3a3a3a}.type-btn{width:42px;height:32px;background:#2a2a2a;border:1px solid #1c1c1c;color:var(--text);cursor:pointer}.type-btn.active{outline:1px solid var(--accent);background:#3a3a3a}.canvas-area{background:#202020;padding:12px 16px;display:flex;flex-direction:column;gap:10px;min-width:0}.canvas-top{display:flex;justify-content:space-between;align-items:center;gap:12px;color:var(--text)}.canvas-presence{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;min-width:0}.file-title{font-weight:700;display:flex;align-items:center;gap:6px}.file-sub{color:var(--muted);font-size:12px;display:flex;align-items:center;gap:6px}.session-actions{display:flex;gap:8px}.ghost-btn{background:#2a2a2a;color:var(--text);border:1px solid #1c1c1c;padding:6px 10px;cursor:pointer}.ghost-btn:disabled{opacity:.5;cursor:not-allowed}.canvas-shell{flex:1;display:grid;place-items:center;background:#1a1a1a;border:1px solid #111;padding:8px;min-height:420px;width:100%;min-width:0;overflow:auto}.annotator{position:relative;width:100%;height:100%;display:grid;place-items:center;min-height:400px;border:none;border-radius:6px;background:transparent;overflow:hidden}.annotator-toolbar{position:absolute;top:8px;left:8px;display:flex;gap:8px;background:#1a1a1a;border:1px solid #1c1c1c;border-radius:8px;padding:6px 8px;z-index:4;align-items:center}.tool-group{display:flex;gap:6px;align-items:center}.tool{background:#2a2a2a;color:var(--text);border:1px solid #1c1c1c;border-radius:6px;padding:6px 10px;cursor:pointer}.tool.active{outline:1px solid var(--accent);background:#3a3a3a}.color-chip{width:18px;height:18px;border-radius:50%;border:2px solid #444}.mode-pill{background:#141414;border:1px solid #262626;border-radius:6px;padding:4px 8px;text-transform:lowercase;font-variant-numeric:tabular-nums;color:var(--muted)}.presence-group{display:flex;align-items:center;gap:6px;max-width:520px;overflow:hidden;white-space:nowrap}.presence-badge{background:#0f0f0f;color:#74c69d;border:1px solid #1c1c1c;border-radius:10px;padding:4px 8px;font-weight:700}.presence-chips{display:flex;gap:6px;flex-wrap:nowrap;max-width:440px;overflow:hidden}.presence-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border:1px solid #1c1c1c;border-radius:999px;background:#1f1f1f}.presence-chip.self{border-color:var(--accent)}.presence-chip.presence-more{background:#262626;color:var(--muted);border-style:dashed}.presence-chip .dot{width:10px;height:10px;border-radius:50%;display:block}.presence-chip .name{font-size:12px}.annotator-stage{position:absolute;border:1px solid #111;background:var(--canvas);max-width:100%;max-height:100%}.canvas-frame{position:relative;display:flex;align-items:stretch;justify-content:stretch;background:var(--border);padding:12px;border:2px solid #000;box-shadow:inset 0 0 0 1px #0f0f0f;max-width:100%;max-height:calc(100vh - 260px);box-sizing:border-box}.canvas-inner{position:relative;background:var(--canvas);overflow:hidden;width:100%;height:100%;border:4px solid #000;box-shadow:inset 0 0 0 1px #111;max-width:100%;max-height:100%}.canvas-inner .annotator{border-radius:0;max-width:100%;max-height:100%}.canvas-inner .placeholder{display:grid;place-items:center;height:100%}.canvas-size-indicator{position:absolute;top:8px;right:8px;display:flex;gap:8px;align-items:center;background:#000000a6;border:1px solid #1c1c1c;border-radius:8px;padding:6px 10px;font-size:12px;z-index:6}.canvas-size-indicator .hint{color:var(--muted);font-size:11px}.resize-handle{position:absolute;right:6px;bottom:6px;width:26px;height:26px;background:#2a2a2a;border:1px solid #0f0f0f;box-shadow:0 0 0 1px #333;cursor:nwse-resize;border-radius:6px;display:grid;place-items:center;color:var(--muted);z-index:6}.resize-handle:after{content:"◢";font-size:13px}.resize-handle:hover{background:#3a3a3a;color:var(--text)}.ghost-btn.mini{padding:4px 8px;font-size:12px}.annotator-image{width:100%;height:100%;object-fit:contain;display:block;-webkit-user-select:none;user-select:none}.annotator-overlay{position:absolute;inset:0;pointer-events:none}.grid-overlay{position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(to right,rgba(148,163,184,.35) 1px,transparent 1px),linear-gradient(to bottom,rgba(148,163,184,.35) 1px,transparent 1px);background-size:32px 32px;opacity:.55;mix-blend-mode:multiply}.selection-rect{fill:#6366f11f;stroke:#60a5fa;stroke-width:1.5;stroke-dasharray:4 4}.selection-outline{fill:none;stroke:#fbbf24;stroke-width:2;stroke-dasharray:6 3;pointer-events:none}.text-input{position:absolute;transform:translate(-50%,-50%);background:#2a2a2a;color:var(--text);border:1px solid #1c1c1c;padding:5px 8px;min-width:140px;z-index:3}.cursor{position:absolute;width:14px;height:14px;border:2px solid #fff;border-radius:3px;transform:translate(-50%,-50%);pointer-events:none}.cursor span{position:absolute;top:-18px;left:12px;padding:2px 6px;border-radius:4px;color:#0b0b0b;font-size:11px;font-weight:700}.explorer{background:#222;border-left:1px solid #1b1b1b;padding:10px;display:flex;flex-direction:column;gap:10px}.explorer.collapsed .explorer-body{display:none}.explorer-toggle{background:#2a2a2a;border:1px solid #1c1c1c;color:var(--text);padding:6px 10px;cursor:pointer}.tree-header{display:flex;align-items:center;justify-content:space-between;background:#1b1b1b;border:1px solid #111;border-radius:6px;padding:6px 8px}.tree-title{color:var(--muted);font-size:12px;letter-spacing:.04em;text-transform:uppercase}.tree-actions{display:flex;gap:6px}.quickstart,.tree{background:#1b1b1b;border:1px solid #111;border-radius:6px;padding:8px}.quickstart-title-row{display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:12px}.starter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;margin-top:6px}.starter-card{background:#242424;border:1px solid #111;color:var(--text);padding:6px;border-radius:6px;display:flex;gap:8px;cursor:pointer}.starter-card.active,.starter-card:hover{outline:1px solid var(--accent)}.starter-thumb{width:42px;height:42px;background-size:cover;background-position:center;border:1px solid #111}.tree{font-size:13px;max-height:320px;overflow:auto}.folder-row,.file-row{display:grid;grid-template-columns:26px 1fr 60px;align-items:center;gap:6px;padding:4px 6px;border-radius:4px}.folder-row:hover,.file-row:hover{background:#262626}.file-spacer{display:block;width:16px;height:1px}.file-row.selected{outline:1px solid var(--accent);background:#2f2f2f}.rename-input{background:#1c1c1c;color:var(--text);border:1px solid #444;border-radius:4px;padding:2px 6px;width:160px;font-size:14px}.folder-children{margin-left:12px;padding-left:10px;border-left:1px dashed #2f2f2f}.row-actions{display:flex;gap:4px}.file-code{display:inline-flex;align-items:center;gap:4px;padding:1px 6px;border-radius:999px;background:#2d2d2d;border:1px solid #3a3a3a;color:var(--muted);font-size:11px;letter-spacing:.04em;text-transform:uppercase}.file-dot{color:#4a4a4a}.icon-btn{background:#2a2a2a;color:var(--text);border:1px solid #1c1c1c;border-radius:4px;padding:4px 6px;cursor:pointer}.icon-btn.danger{color:var(--pill-red);border-color:#2e1414}.palette-bar{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:12px;padding:8px 14px;background:#252525;border-top:1px solid #1b1b1b}.active-swatches{position:relative;width:46px;height:32px}.swatch-active{width:30px;height:20px;border:1px solid #111;position:absolute}.swatch-active.primary{top:0;left:0}.swatch-active.secondary{bottom:0;right:0}.swatch-grid{display:grid;grid-template-columns:repeat(14,22px);grid-auto-rows:22px;gap:4px}.swatch{width:22px;height:22px;border:1px solid #111;cursor:pointer}.status-bar{background:var(--status);color:var(--muted);display:flex;align-items:center;justify-content:space-between;padding:6px 12px;font-size:12px;border-top:1px solid #1b1b1b}.status-text{color:var(--text)}.status-right{font-variant-numeric:tabular-nums}.pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:10px;font-size:12px;background:#333;color:var(--text);border:1px solid #444}.pill.connecting,.pill.reconnecting{background:#facc1529;color:var(--pill-yellow)}.pill.open{background:#4ade8029;color:var(--pill-green)}.pill.closed{background:#f8717129;color:var(--pill-red)}.error{padding:8px 10px;border:1px solid #c0392b;background:#c0392b33;color:#f5c2c7;border-radius:6px;margin-top:8px}.uploads{display:grid;gap:8px}.upload{border:1px solid #111;padding:8px 10px;background:#1f1f1f;border-radius:6px}.progress{margin-top:4px;background:#2d2d2d;height:6px;border-radius:10px;overflow:hidden}.progress>div{height:100%;background:linear-gradient(90deg,#4ade80,#3b82f6)}.placeholder{color:var(--muted)}.banner{margin-bottom:10px;padding:8px 10px;border-radius:8px;border:1px solid #3a3a3a;background:#2a2a2a;color:var(--text)}.banner.warning{border-color:#facc1580;color:var(--pill-yellow)}.banner.info{border-color:#6366f199;color:#c7d2fe}.annotator-banner{position:absolute;top:10px;left:10px;right:10px;z-index:4}.toast-stack{position:fixed;top:12px;right:12px;display:flex;flex-direction:column;gap:10px;z-index:30;pointer-events:none}.toast{pointer-events:auto;display:grid;grid-template-columns:22px 1fr auto;gap:8px;align-items:flex-start;min-width:240px;max-width:360px;padding:10px 12px;border-radius:10px;background:#1f1f1f;border:1px solid #2e2e2e;box-shadow:0 10px 30px #0006}.toast-title{font-weight:700}.toast-message{color:var(--text);font-size:14px}.toast-dismiss{background:none;border:none;color:var(--muted);cursor:pointer}.toast-success{border-color:#4ade8080}.toast-warning{border-color:#facc1580}.toast-error{border-color:#f8717180}.modal-backdrop{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:40;padding:24px}.modal{width:min(960px,90vw);max-height:80vh;background:#111;border:1px solid #2f2f2f;border-radius:12px;box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid #222;background:linear-gradient(90deg,#1c1c1c,#161616)}.modal-title{font-weight:700;color:var(--text)}.modal-body{padding:16px;overflow:auto;color:var(--text);background:#0e0e0e}.markdown h1,.markdown h2,.markdown h3,.markdown h4,.markdown h5,.markdown h6{margin:0 0 8px}.markdown p{margin:0 0 10px;line-height:1.5}.markdown ul{padding-left:20px;margin:0 0 10px;list-style:disc}.markdown img{max-width:100%;border:1px solid #222;border-radius:8px;margin:10px 0}.markdown a{color:#93c5fd}.about-body{display:grid;gap:12px}.about-row{display:flex;justify-content:space-between;font-size:14px}.about-label{color:var(--muted)}.about-links{display:grid;gap:8px}.ghost-link{color:#a5b4fc;text-decoration:none}.ghost-link:hover{text-decoration:underline}.folder-row.pending,.file-row.pending{opacity:.6;pointer-events:none}.icon-btn:disabled,.tool-button:disabled,.type-btn:disabled,.size-dot:disabled,.swap-btn:disabled{opacity:.5;cursor:not-allowed}.annotator.brush-mode .annotator-stage,.annotator.pencil-mode .annotator-stage,.annotator.airbrush-mode .annotator-stage,.annotator.eraser-mode .annotator-stage{cursor:crosshair}.annotator.object-eraser-mode .annotator-stage{cursor:not-allowed}.annotator.pixel-eraser-mode .annotator-stage{cursor:crosshair}.annotator.text-mode .annotator-stage{cursor:text}.annotator.select-mode .annotator-stage,.annotator.lasso-mode .annotator-stage{cursor:crosshair}.annotator.picker-mode .annotator-stage{cursor:copy}.annotator.zoom-mode .annotator-stage{cursor:zoom-in}.annotator.fill-mode .annotator-stage{cursor:cell}.pill.muted{background:#2a2a2a;color:var(--muted);border-color:#3a3a3a}button:focus-visible,.icon-btn:focus-visible,.tool-button:focus-visible,.type-btn:focus-visible,.size-dot:focus-visible,.menu-label:focus-visible,.ghost-btn:focus-visible{outline:2px solid #8b5cf6;outline-offset:2px}@media(max-width:1280px){.workspace{grid-template-columns:96px 1fr}.explorer{display:none}}
