:root{--bg:#fafbfc;--bg-2:#f1f3f7;--panel:#fff;--line:#e6e9ef;--line-soft:#eef0f4;--text:#0f172a;--text-soft:#334155;--muted:#64748b;--muted-2:#94a3b8;--accent:#4f46e5;--accent-soft:#eef2ff;--accent-strong:#4338ca;--success:#059669;--success-soft:#ecfdf5;--warn:#d97706;--warn-soft:#fffbeb;--danger:#dc2626;--danger-soft:#fef2f2;--shadow-sm:0 1px 2px #0f172a0a, 0 1px 3px #0f172a0f;--shadow-md:0 6px 20px #0f172a0d, 0 2px 6px #0f172a0a;--shadow-lg:0 24px 60px #0f172a12, 0 4px 12px #0f172a0a;--radius-sm:8px;--radius:12px;--radius-lg:16px;--mono:"JetBrains Mono", "Cascadia Code", "Fira Code", Consolas, "SFMono-Regular", monospace}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--text);letter-spacing:.005em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Sans,Yu Gothic UI,Yu Gothic,Meiryo,Helvetica Neue,Arial,sans-serif;font-size:14px;line-height:1.6}button{letter-spacing:.01em;border-radius:var(--radius-sm);cursor:pointer;border:1px solid #0000;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:background .12s,border-color .12s,color .12s,box-shadow .12s,transform 40ms}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:active:not(:disabled){transform:translateY(.5px)}button:disabled{cursor:not-allowed;opacity:.5}button.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:var(--shadow-sm)}button.btn-primary:hover:not(:disabled){background:var(--accent-strong);border-color:var(--accent-strong)}button.btn-secondary{background:var(--panel);border-color:var(--line);color:var(--text-soft)}button.btn-secondary:hover:not(:disabled){background:var(--bg-2);color:var(--text)}button.btn-ghost{color:var(--muted);background:0 0;border-color:#0000;padding:6px 10px}button.btn-ghost:hover:not(:disabled){background:var(--bg-2);color:var(--text)}button.btn-chip{background:var(--bg-2);border-color:var(--line);color:var(--text-soft);border-radius:999px;padding:4px 10px;font-size:12px;font-weight:500}button.btn-chip:hover:not(:disabled){background:var(--accent-soft);color:var(--accent-strong);border-color:#c7d2fe}input,textarea{color:var(--text);font-family:inherit;font-size:14px}input:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:1px}h1,h2,h3,p{margin:0}h1{letter-spacing:-.01em;font-size:18px;font-weight:700}h2{letter-spacing:-.005em;font-size:16px;font-weight:700}h3{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:13px;font-weight:700}.app{grid-template-rows:auto 1fr;min-height:100vh;display:grid}.appbar{background:var(--panel);border-bottom:1px solid var(--line);z-index:10;align-items:center;gap:16px;padding:14px 24px;display:flex;position:sticky;top:0}.appbar .brand{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.brand-mark{background:linear-gradient(135deg, var(--accent), #7c3aed);color:#fff;letter-spacing:-.02em;width:28px;height:28px;box-shadow:var(--shadow-sm);border-radius:8px;flex-shrink:0;place-items:center;font-size:14px;font-weight:800;display:grid}.brand-text{flex-direction:column;min-width:0;line-height:1.15;display:flex}.brand-text strong{font-size:14px;font-weight:700}.brand-text span{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.appbar-actions{align-items:center;gap:8px;display:flex}.connection{background:var(--bg-2);color:var(--text-soft);border:1px solid var(--line);border-radius:999px;align-items:center;gap:8px;padding:6px 10px 6px 8px;font-size:12px;font-weight:600;display:inline-flex}.connection.is-ok{background:var(--success-soft);color:#065f46;border-color:#a7f3d0}.connection.is-warn{background:var(--warn-soft);color:#92400e;border-color:#fde68a}.connection .dot{background:currentColor;border-radius:999px;width:8px;height:8px}.connection.is-ok .dot{animation:2.4s ease-in-out infinite pulse}@keyframes pulse{0%,to{box-shadow:0 0 #10b98173}50%{box-shadow:0 0 0 6px #10b98100}}.main{grid-template-columns:260px 1fr;min-height:0;display:grid}.rail{border-right:1px solid var(--line);background:var(--panel);flex-direction:column;gap:14px;height:calc(100vh - 57px);padding:18px 14px;display:flex;position:sticky;top:57px;overflow-y:auto}.rail-section{flex-direction:column;gap:6px;display:flex}.tab{text-align:left;width:100%;color:var(--text-soft);background:0 0;border:1px solid #0000;border-radius:10px;grid-template-columns:18px 1fr auto;align-items:center;gap:10px;padding:10px 12px;font-weight:500;display:grid}.tab:hover{background:var(--bg-2);color:var(--text)}.tab.is-active{background:var(--accent-soft);color:var(--accent-strong);border-color:#e0e7ff}.tab .tab-icon{width:18px;height:18px;color:var(--muted-2);place-items:center;display:grid}.tab.is-active .tab-icon{color:var(--accent)}.tab .tab-meta{color:var(--muted);font-size:11px;font-weight:500}.tab.is-active .tab-meta{color:var(--accent)}.tab.is-readonly .tab-meta:after{content:" · 読取"}.rail-foot{border-top:1px solid var(--line-soft);flex-direction:column;gap:8px;margin-top:auto;padding-top:12px;display:flex}.rail-foot small{color:var(--muted);font-size:11px;line-height:1.5}.workspace{grid-template-rows:auto auto 1fr auto;gap:14px;min-width:0;padding:22px 28px 28px;display:grid}.doc-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:18px;display:flex}.doc-head-left{flex-direction:column;gap:4px;min-width:0;display:flex}.path{font-family:var(--mono);color:var(--muted);background:var(--bg-2);border-radius:6px;align-items:center;gap:6px;width:max-content;padding:3px 8px;font-size:11px;display:inline-flex}.doc-head h2{letter-spacing:-.015em;font-size:22px}.meta-row{color:var(--muted);flex-wrap:wrap;align-items:center;gap:10px;margin-top:4px;font-size:12px;display:flex}.meta-row .sep{color:var(--muted-2)}.doc-head-right{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.kbd{font-family:var(--mono);background:var(--bg-2);border:1px solid var(--line);color:var(--text-soft);border-bottom-width:2px;border-radius:5px;align-items:center;gap:2px;padding:1px 5px;font-size:11px;display:inline-flex}.banner{border-radius:var(--radius);border:1px solid var(--line);background:var(--panel);align-items:flex-start;gap:10px;padding:12px 14px;font-size:13px;line-height:1.55;display:flex}.banner.is-info{background:var(--accent-soft);color:var(--accent-strong);border-color:#e0e7ff}.banner.is-success{background:var(--success-soft);color:#065f46;border-color:#a7f3d0}.banner.is-warn{background:var(--warn-soft);color:#92400e;border-color:#fde68a}.banner.is-danger{background:var(--danger-soft);color:#991b1b;border-color:#fecaca}.banner .banner-icon{flex-shrink:0;width:18px;height:18px;margin-top:1px}.banner-body{flex:1;min-width:0}.banner-body strong{font-weight:700}.banner-close{color:inherit;opacity:.6;cursor:pointer;background:0 0;border:0;padding:0}.banner-close:hover{opacity:1}.doc-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);flex-direction:column;min-height:0;display:flex;overflow:hidden}.doc-toolbar{border-bottom:1px solid var(--line-soft);background:var(--bg);color:var(--muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:8px 12px;font-size:12px;display:flex}.doc-toolbar .stats{align-items:center;gap:8px;display:inline-flex}.doc-toolbar .stats .sep{color:var(--muted-2)}.toggle-group{background:var(--bg-2);border-radius:8px;gap:2px;padding:3px;display:inline-flex}.toggle-group button{color:var(--muted);background:0 0;border:0;border-radius:6px;padding:5px 12px;font-size:12px;font-weight:600}.toggle-group button.is-active{background:var(--panel);color:var(--text);box-shadow:var(--shadow-sm)}.editor,.viewer{width:100%;font-family:var(--mono);color:var(--text);background:var(--panel);resize:none;white-space:pre-wrap;tab-size:2;border:0;outline:none;flex:1;min-height:480px;padding:22px 26px;font-size:13.5px;line-height:1.75;overflow:auto}.viewer{word-break:break-word;margin:0}.search{background:var(--bg);border:1px solid var(--line-soft);border-radius:8px;align-items:center;gap:8px;width:min(100%,280px);padding:4px 8px;display:flex}.search input{background:0 0;border:0;outline:0;width:100%;padding:4px 0;font-size:13px}.search svg{color:var(--muted-2);flex-shrink:0}.search-hits{color:var(--muted);font-size:11px}mark{color:var(--text);background:#fef3c7;border-radius:3px;padding:0 2px}.quick{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);flex-direction:column;gap:12px;padding:16px;display:flex}.quick-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.quick-head h3{text-transform:none;letter-spacing:0;color:var(--text);align-items:center;gap:8px;font-size:13px;font-weight:700;display:inline-flex}.quick-templates{flex-wrap:wrap;gap:6px;display:flex}.quick textarea{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-sm);width:100%;font-family:var(--mono);resize:vertical;min-height:110px;padding:12px 14px;font-size:13px;line-height:1.65}.quick-foot{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.quick-foot .hint{color:var(--muted);font-size:11.5px}.empty{background:var(--panel);border:1px dashed var(--line);border-radius:var(--radius);text-align:center;color:var(--muted);flex-direction:column;align-items:center;gap:10px;padding:40px 28px;display:flex}.empty h3{text-transform:none;letter-spacing:0;color:var(--text);font-size:16px}.empty code{background:var(--bg-2);font-family:var(--mono);border-radius:4px;padding:1px 6px;font-size:12.5px}@media (max-width:880px){.main{grid-template-columns:1fr}.rail{border-right:0;border-bottom:1px solid var(--line);gap:8px;height:auto;padding:12px;position:static}.rail-section{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;flex-direction:row;padding-bottom:4px;overflow-x:auto}.rail-section::-webkit-scrollbar{height:0}.tab{scroll-snap-align:start;flex:none;grid-template-columns:16px auto;padding:8px 12px}.tab .tab-meta{display:none}.rail-foot{border-top:0;flex-direction:row;justify-content:space-between;align-items:center;padding-top:0}.workspace{padding:16px}.doc-head{flex-direction:column;align-items:flex-start}.editor,.viewer{min-height:360px;padding:16px 18px;font-size:13px}.appbar{padding:10px 14px}.connection .label{display:none}}.md{color:var(--text);min-height:480px;padding:22px 26px;font-size:14px;line-height:1.75;overflow:auto}.md h1,.md h2,.md h3,.md h4{letter-spacing:-.005em;color:var(--text);margin:18px 0 8px}.md h1{border-bottom:1px solid var(--line);padding-bottom:8px;font-size:22px;font-weight:700}.md h2{font-size:18px;font-weight:700}.md h3{color:var(--text);text-transform:none;letter-spacing:0;font-size:15px;font-weight:700}.md p{margin:8px 0}.md ul,.md ol{margin:8px 0;padding-left:22px}.md li{margin:3px 0}.md code{font-family:var(--mono);background:var(--bg-2);border:1px solid var(--line-soft);border-radius:4px;padding:1px 5px;font-size:12.5px}.md pre{background:var(--bg-2);border:1px solid var(--line-soft);border-radius:8px;padding:12px 14px;overflow-x:auto}.md pre code{background:0 0;border:0;padding:0}.md blockquote{background:var(--accent-soft);color:var(--text-soft);border-left:3px solid #c7d2fe;border-radius:0 8px 8px 0;margin:8px 0;padding:8px 12px}.md hr{border:0;border-top:1px solid var(--line);margin:20px 0}.md a{color:var(--accent-strong);text-underline-offset:2px;text-decoration:underline}.md strong{font-weight:700}.md table{border-collapse:collapse;width:100%;margin:8px 0;font-size:13px}.md th,.md td{border:1px solid var(--line);text-align:left;padding:6px 10px}.md th{background:var(--bg-2)}.filter-bar{flex-wrap:wrap;align-items:center;gap:12px;padding:4px 0;display:flex}.filter-bar .search{flex:0 280px}.chip-row{flex-wrap:wrap;gap:6px;display:flex}.chip{background:var(--panel);border:1px solid var(--line);color:var(--text-soft);cursor:pointer;border-radius:999px;padding:5px 12px;font-size:12px;font-weight:500;transition:background .12s,border-color .12s,color .12s}.chip:hover{background:var(--bg-2);border-color:var(--muted-2)}.chip.is-active{background:var(--accent-soft);color:var(--accent-strong);border-color:#c7d2fe;font-weight:600}.card-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.proj-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);cursor:pointer;flex-direction:column;gap:8px;padding:14px 16px 12px;transition:box-shadow .16s,border-color .16s,transform 40ms;display:flex}.proj-card:hover{box-shadow:var(--shadow-md);border-color:#cbd5e1}.proj-card:active{transform:translateY(.5px)}.proj-head{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.proj-name{letter-spacing:-.005em;color:var(--text);text-transform:none;margin:0;font-size:16px;font-weight:700}.status-pill{letter-spacing:.02em;white-space:nowrap;border-radius:999px;flex-shrink:0;align-items:center;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.proj-url{font-family:var(--mono);color:var(--muted);font-size:12px}.proj-focus{color:var(--text-soft);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-size:13px;line-height:1.55;display:-webkit-box;overflow:hidden}.proj-foot{border-top:1px solid var(--line-soft);justify-content:space-between;align-items:center;gap:10px;margin-top:auto;padding-top:6px;display:flex}.proj-tags{flex-wrap:wrap;gap:5px;display:flex}.proj-tag{color:var(--accent-strong);background:var(--accent-soft);border-radius:4px;padding:1px 7px;font-size:11px;font-weight:500}.proj-detail{border-top:1px solid var(--line-soft);cursor:default;margin-top:6px;padding-top:10px}.proj-actions{flex-wrap:wrap;gap:6px;display:flex}.proj-actions .btn-secondary{min-height:0;padding:5px 10px;font-size:12px}.modal-backdrop{z-index:50;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a66;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.modal{background:var(--panel);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);flex-direction:column;gap:14px;width:min(520px,100%);max-height:90vh;padding:22px;display:flex;overflow-y:auto}.form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-grid label{color:var(--muted);flex-direction:column;gap:4px;font-size:12px;display:flex}.form-grid label.full{grid-column:1/-1}.form-grid input,.form-grid select{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--text);padding:8px 10px;font-size:14px}.form-grid input:focus,.form-grid select:focus{border-color:var(--accent);outline:2px solid var(--accent-soft);outline-offset:1px}@media (max-width:600px){.form-grid{grid-template-columns:1fr}}
