:root{--bg: #0f0f10;--bg-elev: #1a1a1c;--bg-elev-2: #232326;--fg: #ececec;--fg-dim: #9a9a9c;--accent: #7c5cff;--accent-hover: #9077ff;--ok: #4ade80;--loading: #facc15;--err: #f87171;--border: #2a2a2d;--radius: 10px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box}html,body,#app{margin:0;padding:0;height:100%;background:var(--bg);color:var(--fg);font-family:var(--font);-webkit-font-smoothing:antialiased}#app{display:flex;flex-direction:column;min-height:100%}#app.route-view{height:100vh;overflow:hidden}button{font-family:inherit;font-size:inherit;cursor:pointer;border:1px solid var(--border);background:var(--bg-elev);color:var(--fg);padding:8px 14px;border-radius:var(--radius);transition:background .15s,border-color .15s}button:hover{background:var(--bg-elev-2);border-color:#3a3a3d}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:disabled{opacity:.4;cursor:not-allowed}button.primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:500}button.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}button.ghost{background:transparent;border-color:var(--border)}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border);background:var(--bg-elev)}.brand{font-weight:600;letter-spacing:.2px}.status{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--fg-dim)}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--fg-dim)}.dot.ok{background:var(--ok);box-shadow:0 0 6px #4ade8080}.dot.loading{background:var(--loading);box-shadow:0 0 6px #facc1599;animation:pulse 1s infinite}.dot.err{background:var(--err);box-shadow:0 0 6px #f8717199}.dot.off{background:var(--fg-dim)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.list-main{padding:24px 20px 48px;max-width:920px;margin:0 auto;width:100%}.actions{display:flex;justify-content:flex-start;margin-bottom:20px}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.card{position:relative;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:14px 14px 14px 16px;cursor:pointer;transition:background .15s,border-color .15s,transform .05s}.card:hover{background:var(--bg-elev-2);border-color:#3a3a3d}.card:active{transform:scale(.997)}.card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.card-title{font-weight:500;margin-bottom:4px;word-break:break-word;padding-right:22px}.card-meta{font-size:12px;color:var(--fg-dim)}.card-remove{position:absolute;top:8px;right:8px;width:24px;height:24px;padding:0;border:none;background:transparent;color:var(--fg-dim);font-size:18px;line-height:1;border-radius:6px}.card-remove:hover{background:var(--bg-elev-2);color:var(--err)}.empty{text-align:center;padding:60px 20px;color:var(--fg-dim)}.empty .hint{font-size:13px;margin-top:8px}.picker-overlay{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center}.picker-backdrop{position:absolute;inset:0;background:#0009;backdrop-filter:blur(4px)}.picker{position:relative;background:var(--bg-elev);border:1px solid var(--border);border-radius:14px;width:min(560px,92vw);max-height:80vh;display:flex;flex-direction:column;box-shadow:0 24px 60px #00000080}.picker-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}.picker-head h2{margin:0;font-size:15px;font-weight:600}.picker-head .ghost{padding:4px 10px;font-size:18px;line-height:1}.picker-body{padding:14px 18px 18px;overflow:hidden;display:flex;flex-direction:column;gap:10px}.picker-search{font-family:inherit;font-size:14px;background:var(--bg);border:1px solid var(--border);color:var(--fg);padding:10px 12px;border-radius:8px;outline:none}.picker-search:focus{border-color:var(--accent)}.picker-status{font-size:12px;color:var(--fg-dim)}.picker-results{list-style:none;margin:0;padding:0;overflow-y:auto;display:flex;flex-direction:column;gap:4px;max-height:50vh}.picker-result{width:100%;text-align:left;background:transparent;border:1px solid transparent;padding:10px 12px}.picker-result:hover{background:var(--bg-elev-2);border-color:var(--border)}.picker-result-name{font-size:14px;font-weight:500;margin-bottom:2px}.picker-result-meta{font-size:11px;color:var(--fg-dim)}.viewer{position:relative;height:100vh;width:100vw;overflow:hidden}.viewer-hover-zone{position:absolute;top:0;left:0;right:0;height:16px;z-index:9;pointer-events:auto}.viewer-bar{position:absolute;top:0;left:0;right:0;z-index:10;display:flex;align-items:center;gap:10px;padding:8px 14px;background:#0f0f10eb;backdrop-filter:blur(8px);border-bottom:1px solid var(--border);height:44px;transition:transform .25s ease,opacity .25s ease;transform:translateY(0);opacity:1}.viewer-bar.hidden{transform:translateY(-100%);opacity:0;pointer-events:none}.viewer-back{font-size:18px;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px}.viewer-back:hover{background:var(--bg-elev-2);text-decoration:none}.viewer-title{flex:1;font-size:13px;color:var(--fg-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.viewer-refresh{width:28px;height:28px;padding:0;font-size:16px;line-height:1;border:1px solid var(--border);background:transparent;color:var(--fg);border-radius:6px}.viewer-refresh:hover{background:var(--bg-elev-2)}.viewer-frame{position:absolute;inset:0;width:100%;height:100%;border:0;background:#fff;z-index:1}
