:root{--bg: #0f1419;--surface: #1a2332;--border: #2d3a4d;--text: #e8eef5;--muted: #8b9cb3;--accent: #3b82f6;--accent-dim: #2563eb;--danger: #ef4444;--ok: #22c55e;font-family:DM Sans,system-ui,sans-serif;color:var(--text);background:var(--bg);line-height:1.5}*{box-sizing:border-box}body{margin:0;min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:1rem}.layout{display:grid;grid-template-columns:220px 1fr;min-height:100vh}.sidebar{background:var(--surface);border-right:1px solid var(--border);padding:1.25rem 1rem}.sidebar h1{font-size:1rem;font-weight:700;margin:0 0 1.5rem;letter-spacing:.02em}.nav a{display:block;padding:.5rem .75rem;border-radius:8px;color:var(--muted);text-decoration:none;margin-bottom:4px}.nav a.active{background:#3b82f626;color:var(--text)}.nav a:hover{background:#ffffff0d;color:var(--text);text-decoration:none}main{padding:2rem;max-width:1100px}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.25rem;margin-bottom:1rem}h2{font-size:1.35rem;font-weight:600;margin:0 0 1rem}table{width:100%;border-collapse:collapse;font-size:.9rem}th,td{text-align:left;padding:.5rem .75rem;border-bottom:1px solid var(--border)}th{color:var(--muted);font-weight:600}.btn{display:inline-block;padding:.5rem 1rem;border-radius:8px;border:none;background:var(--accent);color:#fff;font-weight:600}.btn:hover{background:var(--accent-dim)}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text)}.field{margin-bottom:.75rem}.field label{display:block;font-size:.85rem;color:var(--muted);margin-bottom:.25rem}.field input,.field select,.field textarea{width:100%;max-width:420px;padding:.5rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text)}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.login-card{width:100%;max-width:400px}.error{color:var(--danger);font-size:.9rem}.badge{display:inline-block;padding:.15rem .5rem;border-radius:6px;font-size:.75rem;font-weight:600}.badge-ok{background:#22c55e33;color:var(--ok)}.badge-warn{background:#eab30833;color:#eab308}.badge-bad{background:#ef444433;color:var(--danger)}.mono{font-family:ui-monospace,monospace;font-size:.85rem;word-break:break-all}.toast{padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.95rem}.toast-success{background:#22c55e26;border:1px solid rgba(34,197,94,.4);color:#86efac}.table-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.btn-sm{padding:.35rem .65rem;font-size:.85rem;border-radius:6px}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}.btn-outline:hover{background:#ffffff0f}.btn-success{background:#15803d;border:none;color:#fff}.btn-success:hover{background:#166534}input[type=datetime-local]{max-width:100%}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000000a6;display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem;overflow-y:auto}.modal-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;max-width:560px;width:100%;box-shadow:0 20px 50px #00000073}.modal-panel-wide{max-width:720px}.modal-head{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.modal-body{padding:1.25rem;max-height:min(70vh,600px);overflow-y:auto}.detail-dl{display:grid;grid-template-columns:140px 1fr;gap:.35rem 1rem;font-size:.9rem}.detail-dl dt{color:var(--muted);margin:0}.detail-dl dd{margin:0;word-break:break-word}.table-row-click{cursor:pointer}.table-row-click:hover{background:#ffffff0a}.btn-danger{background:#7f1d1d;border:none;color:#fecaca}.btn-danger:hover{background:#991b1b}
