:root{--bg: #f5f6f8;--surface: #ffffff;--surface-2: #eceef2;--border: #e3e5ea;--text: #1f2329;--muted: #6b7280;--hint: #9aa1ab;--accent: #2563eb;--ok: #16a34a;--warn: #d97706;--danger: #dc2626}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans KR,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}input,select,button{font-family:inherit;font-size:14px}input,select{height:36px;padding:0 10px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text)}input:focus,select:focus{outline:none;border-color:var(--accent)}label{font-size:13px;color:var(--muted)}.layout{max-width:1080px;margin:0 auto;padding:0 20px 40px}.topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 0 12px}.brand{font-size:17px;font-weight:600;display:flex;align-items:center;gap:8px}.logo{color:var(--accent)}.top-right{display:flex;align-items:center;gap:14px}.user{color:var(--muted);font-size:13px}.tabs{display:flex;gap:22px;border-bottom:1px solid var(--border);margin-bottom:20px}.tab{background:none;border:none;cursor:pointer;color:var(--muted);padding:0 0 10px;font-size:14px;border-bottom:2px solid transparent}.tab.on{color:var(--text);border-bottom-color:var(--text)}.section{font-size:13px;color:var(--muted);margin:0 0 10px}.section.mt{margin-top:22px}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px}.card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:12px}.card.no-pad{padding:0;overflow-x:auto;-webkit-overflow-scrolling:touch}.muted{color:var(--muted)}.center{text-align:center;padding:16px}.row-between{display:flex;align-items:center;justify-content:space-between}.row-gap{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.mt{margin-top:22px}.metric-label{color:var(--muted);font-size:13px;margin-bottom:6px}.metric-value{font-size:26px;font-weight:600}.metric-value .unit{font-size:14px;color:var(--muted);margin-left:2px}.metric-lines{display:flex;flex-direction:column;gap:2px}.metric-line{font-size:18px;font-weight:600}.metric-sub{color:var(--hint);font-size:12px;margin-top:4px}.bar{height:5px;background:var(--surface-2);border-radius:4px;margin-top:10px;overflow:hidden}.fill{height:100%;border-radius:4px;background:var(--muted)}.fill.normal{background:var(--accent)}.fill.warn{background:var(--warn)}.fill.danger{background:var(--danger)}.live{font-size:13px;display:flex;align-items:center;gap:6px}.live .dot{width:8px;height:8px;border-radius:50%;background:var(--ok);display:inline-block}.live.on{color:var(--ok)}.live.off{color:var(--danger)}.live.off .dot{background:var(--danger)}.banner{padding:9px 14px;border-radius:8px;font-size:13px;margin-bottom:14px}.banner.danger{background:#fdecec;color:var(--danger)}.banner.warn{background:#fdf3e3;color:var(--warn)}.ctable{width:100%;border-collapse:collapse}.ctable th,.ctable td{text-align:left;padding:10px 14px;font-size:13px;border-bottom:1px solid var(--border);white-space:nowrap}.ctable th{color:var(--muted);font-weight:500;background:var(--surface-2)}.ctable tr:last-child td{border-bottom:none}.cname{font-weight:500}.cimg{font-size:11px;color:var(--hint)}.badge{font-size:12px;padding:2px 9px;border-radius:6px}.badge.ok{background:#e7f6ec;color:var(--ok)}.badge.danger{background:#fdecec;color:var(--danger)}.pill{border:none;cursor:pointer;font-size:11px;padding:3px 10px;border-radius:6px}.pill.on{background:#e7f6ec;color:var(--ok)}.pill.off{background:var(--surface-2);color:var(--muted)}.btn,.btn-primary,.btn-ghost{cursor:pointer;border-radius:8px;height:36px;padding:0 14px;font-size:14px}.btn{background:var(--surface);border:1px solid var(--border);color:var(--text)}.btn:hover{background:var(--surface-2)}.btn-primary{background:var(--accent);border:1px solid var(--accent);color:#fff}.btn-primary:disabled{opacity:.6;cursor:default}.btn-ghost{background:none;border:none;color:var(--muted)}.btn-ghost:hover{color:var(--danger)}.addform{margin-top:12px}.addgrid{display:grid;grid-template-columns:1.4fr 1.2fr .7fr .7fr .8fr .8fr .9fr auto;gap:8px;align-items:center}.addgrid input,.addgrid select{width:100%}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.login-card{width:100%;max-width:320px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:26px;display:flex;flex-direction:column;gap:6px}.login-title{font-size:18px;font-weight:600;text-align:center;display:flex;align-items:center;justify-content:center;gap:8px}.login-sub{text-align:center;color:var(--muted);font-size:13px;margin-bottom:14px}.login-card label{margin-top:8px}.login-card .btn-primary{margin-top:16px}.error{color:var(--danger);font-size:13px;margin-top:8px}.toast{position:fixed;bottom:22px;left:50%;transform:translate(-50%);background:var(--text);color:#fff;padding:10px 18px;border-radius:8px;font-size:13px}@media(max-width:720px){.addgrid{grid-template-columns:1fr 1fr}}@media(max-width:600px){.card.no-pad{border:none;background:transparent;overflow:visible}.ctable thead{display:none}.ctable,.ctable tbody,.ctable tr,.ctable td{display:block;width:100%}.ctable tr{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:10px;overflow:hidden}.ctable td{display:flex;justify-content:space-between;align-items:center;gap:12px;text-align:right;white-space:normal;padding:9px 14px;border-bottom:1px solid var(--border)}.ctable td:last-child{border-bottom:none}.ctable td:before{content:attr(data-label);color:var(--muted);text-align:left;white-space:nowrap}.ctable td.cardtitle{display:block;text-align:left;font-weight:500;background:var(--surface-2);padding:10px 14px}.ctable td.cardtitle:before{content:none}}@media(max-width:480px){.layout{padding:0 12px 32px}.topbar{padding:12px 0 10px}.addgrid{grid-template-columns:1fr}.metric-value{font-size:22px}}
