:root{--bg: #0f1117;--surface: #1a1d27;--surface-2: #232735;--border: #2e3344;--text: #e6e8ee;--muted: #9aa0b4;--accent: #4f8cff;--accent-soft: #2a3a5c;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text)}a{color:var(--accent);text-decoration:none}button{font:inherit;cursor:pointer}.layout{display:flex;min-height:100vh}.sidebar{width:220px;background:var(--surface);border-right:1px solid var(--border);padding:20px 12px;display:flex;flex-direction:column;gap:4px}.sidebar h1{font-size:15px;margin:0 8px 16px;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}.nav-link{display:block;padding:9px 12px;border-radius:8px;color:var(--text)}.nav-link:hover{background:var(--surface-2)}.nav-link.router-link-active{background:var(--accent-soft);color:#fff}.logout{margin-top:auto;background:transparent;border:1px solid var(--border);color:var(--muted);padding:9px 12px;border-radius:8px}.content{flex:1;padding:28px 32px;overflow:auto}.page-head{display:flex;align-items:center;gap:16px;margin-bottom:20px;flex-wrap:wrap}.page-head h2{margin:0;font-size:22px}.filters{display:flex;gap:8px;flex-wrap:wrap}select,input{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:7px 10px}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:12px}.card-title{font-weight:600;margin:0 0 6px}.badge{display:inline-block;font-size:12px;padding:2px 8px;border-radius:999px;background:var(--accent-soft);color:#cdddff;margin-right:6px}.muted{color:var(--muted);font-size:13px}.excerpt{color:var(--muted);white-space:pre-wrap}table{width:100%;border-collapse:collapse;font-size:13px}th,td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--border);vertical-align:top}th{color:var(--muted);font-weight:600}.pager{display:flex;gap:10px;align-items:center;margin-top:16px}.pager button{background:var(--surface-2);border:1px solid var(--border);color:var(--text);padding:7px 14px;border-radius:8px}.pager button:disabled{opacity:.4;cursor:default}.login-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:20px;text-align:center}.state{color:var(--muted);padding:24px 0}.error{color:#ff8080}pre.body{white-space:pre-wrap;word-break:break-word;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:14px;line-height:1.5}textarea{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:9px 10px;font:inherit;width:100%;resize:vertical}.btn{background:var(--surface-2);border:1px solid var(--border);color:var(--text);padding:7px 14px;border-radius:8px}.btn:hover{border-color:var(--accent)}.btn:disabled{opacity:.5;cursor:default}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{filter:brightness(1.08)}.btn-danger{background:transparent;border-color:#6b2b2b;color:#ff9a9a}.btn-danger:hover{background:#3a1d1d;border-color:#b04545}.btn-sm{padding:4px 10px;font-size:13px}.row-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.spacer{flex:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:flex-start;justify-content:center;padding:48px 16px;overflow:auto;z-index:50}.modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:22px;width:100%;max-width:560px}.modal h3{margin:0 0 16px;font-size:18px}.field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.field>label{font-size:13px;color:var(--muted)}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:6px}.tab-bar{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);z-index:40;padding-bottom:env(safe-area-inset-bottom)}.tab-bar-link{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px;font-size:10px;color:var(--muted);gap:3px;background:transparent;border:none;cursor:pointer;text-decoration:none}.tab-bar-link.router-link-active{color:var(--accent)}.tab-bar-link:hover{color:var(--text)}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.graph-page{position:relative;margin:-28px -32px;height:calc(100vh + -0px);overflow:hidden}.graph-canvas{width:100%;height:100%}.graph-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.detail-panel{position:absolute;top:16px;right:16px;width:320px;max-height:calc(100% - 32px);overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:12px;box-shadow:0 8px 32px #00000080;z-index:10}.detail-header{display:flex;align-items:flex-start;gap:10px}.detail-title{flex:1;margin:0;font-size:16px;line-height:1.4}.detail-close{flex-shrink:0;line-height:1}.detail-meta{display:flex;flex-wrap:wrap;gap:4px}.detail-body{max-height:260px;overflow-y:auto;font-size:13px;margin:0}.detail-links{display:flex;flex-wrap:wrap;gap:4px}.detail-footer{padding-top:4px}.panel-slide-enter-active,.panel-slide-leave-active{transition:opacity .18s ease,transform .18s ease}.panel-slide-enter-from,.panel-slide-leave-to{opacity:0;transform:translate(16px)}@media(max-width:640px){.sidebar{display:none}.content{padding:16px;padding-bottom:calc(68px + env(safe-area-inset-bottom))}.tab-bar{display:flex}input,select,textarea{font-size:16px}.page-head h2{font-size:18px}.modal-overlay{padding:0;align-items:flex-end}.modal{border-radius:20px 20px 0 0;max-height:90vh;overflow-y:auto;padding:20px 16px;padding-bottom:calc(20px + env(safe-area-inset-bottom))}.graph-page{margin:-16px -16px calc(-68px - env(safe-area-inset-bottom));height:calc(100vh + -0px)}.detail-panel{top:auto;right:0;bottom:calc(60px + env(safe-area-inset-bottom));left:0;width:100%;max-height:55vh;border-radius:20px 20px 0 0;box-shadow:0 -4px 24px #00000080}.panel-slide-enter-from,.panel-slide-leave-to{opacity:0;transform:translateY(24px)}}
