:root{
  --bg:#f4f6f9; --card:#fff; --ink:#1e2a36; --muted:#6b7886; --line:#d7dee6;
  --brand:#1f6feb; --brand-d:#1551b5; --ok:#1a7f37; --okbg:#e7f6ec;
  --no:#c0392b; --nobg:#fdecea; --cond:#b9770e; --condbg:#fdf3e0; --warnbg:#fff7e6;
}
*{box-sizing:border-box}
body{margin:0;font-family:"Segoe UI",Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:14px}
a{color:var(--brand);text-decoration:none}
.topbar{display:flex;align-items:center;gap:24px;background:#fff;border-bottom:1px solid var(--line);padding:10px 18px;flex-wrap:wrap}
.brand{font-weight:700;font-size:16px}
.brand .ver{color:var(--muted);font-weight:400;font-size:12px}
.topbar nav{display:flex;gap:16px;flex-wrap:wrap}
.topbar nav a{padding:4px 6px;border-radius:6px;color:var(--ink)}
.topbar nav a.active{background:var(--brand);color:#fff}
.topbar nav a.logout{margin-left:auto;color:var(--no)}
.statusbar{background:#eef3f8;border-bottom:1px solid var(--line);padding:6px 18px;font-size:13px;color:var(--muted)}
.statusbar.warn{background:var(--warnbg)}
.container{padding:18px;max-width:1500px;margin:0 auto}
h1{font-size:20px;margin:0 0 4px}
h2{font-size:16px;margin:22px 0 10px}
.muted{color:var(--muted)}
.card{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:16px;margin-bottom:16px}
.grid{display:grid;gap:10px 16px}
.grid.cols4{grid-template-columns:repeat(4,1fr)}
.grid.cols3{grid-template-columns:repeat(3,1fr)}
.grid.cols2{grid-template-columns:repeat(2,1fr)}
label{display:flex;flex-direction:column;gap:3px;font-size:12px;color:var(--muted)}
input,select,textarea{font:inherit;padding:6px 8px;border:1px solid var(--line);border-radius:6px;background:#fff;color:var(--ink)}
input:focus,select:focus{outline:2px solid #bcd4ff;border-color:var(--brand)}
button{font:inherit;cursor:pointer;border:1px solid var(--brand);background:var(--brand);color:#fff;padding:7px 14px;border-radius:7px}
button:hover{background:var(--brand-d)}
button.secondary{background:#fff;color:var(--brand)}
button.ghost{background:#fff;color:var(--ink);border-color:var(--line)}
button.danger{background:#fff;color:var(--no);border-color:var(--no)}
button.small{padding:3px 8px;font-size:12px}
.toolbar{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}
table{border-collapse:collapse;width:100%;background:#fff}
th,td{border:1px solid var(--line);padding:4px 6px;text-align:center;font-size:12px}
th{background:#eef3f8;position:sticky;top:0}
td input{width:100%;border:none;text-align:center;padding:4px 2px}
td input:focus{outline:1px solid var(--brand)}
.scroll{overflow:auto;max-width:100%;border:1px solid var(--line);border-radius:8px}
.tag{padding:2px 8px;border-radius:20px;font-size:12px;font-weight:600;display:inline-block}
.tag.yes{background:var(--okbg);color:var(--ok)}
.tag.no{background:var(--nobg);color:var(--no)}
.tag.cond{background:var(--condbg);color:var(--cond)}
tr.row-yes td{background:var(--okbg)}
tr.row-no td{background:var(--nobg)}
tr.row-cond td{background:var(--condbg)}
.alert{padding:9px 12px;border-radius:8px;margin:8px 0;font-size:13px}
.alert.error{background:var(--nobg);color:var(--no)}
.alert.warn{background:var(--warnbg);color:var(--cond)}
.alert.ok{background:var(--okbg);color:var(--ok)}
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#1f6feb22,#f4f6f9)}
.login-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:30px;width:340px;display:flex;flex-direction:column;gap:12px;box-shadow:0 10px 30px #0001}
.login-card h1{text-align:center}
.login-card p{text-align:center;margin:0 0 8px}
.right{text-align:right}
.nowrap{white-space:nowrap}
small.hint{color:var(--muted);font-size:11px}
