:root{--primary: #059669;--primary-dark: #047857;--primary-light: #d1fae5;--accent: #d97706;--bg: #f3f4f6;--surface: #ffffff;--text-main: #111827;--text-sec: #6b7280;--border: #e5e7eb;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--radius: 16px}*{box-sizing:border-box}body{margin:0;font-family:Kanit,sans-serif;background:var(--bg);color:var(--text-main);min-height:100vh}#app{min-height:100vh}.app-layout{display:grid;grid-template-columns:1fr;max-width:1200px;margin:0 auto;width:100%}@media(min-width:768px){.app-layout{grid-template-columns:240px 1fr;min-height:100vh}}.sidebar{background:var(--surface);border-right:1px solid var(--border);padding:20px;position:sticky;top:0;display:flex;flex-direction:column;z-index:50}@media(max-width:767px){.sidebar{position:fixed;inset:auto 0 0;flex-direction:row;justify-content:space-around;padding:10px;border-top:1px solid var(--border);box-shadow:0 -4px 6px -1px #0000000d}}.brand{padding-bottom:20px;margin-bottom:20px;border-bottom:1px solid var(--border)}.brand-title{display:flex;align-items:center;gap:10px;font-size:1.25rem;font-weight:600;color:var(--primary-dark)}.node-subtitle{font-size:.85rem;color:var(--text-sec);margin-top:4px;padding-left:30px;font-weight:400}@media(max-width:767px){.brand{display:none}}.nav-item{display:flex;flex-direction:column;gap:4px;align-items:center;padding:8px 12px;margin-bottom:4px;border-radius:12px;color:var(--text-sec);text-decoration:none;cursor:pointer;transition:.2s;font-weight:500;text-align:center;background:transparent;border:none}@media(min-width:768px){.nav-item{flex-direction:row;font-size:1rem;text-align:left}.nav-item i{width:24px}}.nav-item:hover{background:var(--primary-light);color:var(--primary-dark)}.nav-item.active{background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.nav-txt{font-size:.75rem}@media(min-width:768px){.nav-txt{font-size:1rem}.nav-sub{font-size:.8rem;opacity:.8}}.main-content{padding:20px 20px 80px;overflow-y:auto}@media(min-width:768px){.main-content{padding:40px}}.top-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;background:var(--surface);padding:15px 20px;border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border)}.page-title h1{font-size:1.5rem;font-weight:600;margin:0;line-height:1.2}.page-title p{margin:0;font-size:.85rem;color:var(--text-sec)}.pill{padding:6px 12px;border-radius:20px;font-size:.85rem;font-weight:500;display:flex;align-items:center;gap:6px;background:#f1f5f9;color:var(--text-sec)}.pill.online{background:#ecfdf5;color:var(--primary);border:1px solid #a7f3d0}.sys-bar-modern{display:flex;gap:20px;overflow-x:auto;padding:15px;margin-bottom:20px;background:#fff;border-radius:12px;border:1px solid var(--border);scrollbar-width:none}.sys-info-item{display:flex;flex-direction:column;min-width:80px}.sys-info-lbl{font-size:.7rem;text-transform:uppercase;color:var(--text-sec);letter-spacing:.5px}.sys-info-val{font-size:.95rem;font-weight:600;color:var(--text-main)}.node-grid{display:grid;gap:20px;grid-template-columns:1fr}.gateway-card{background:linear-gradient(135deg,#ecfdf5,#f0f9ff);border:1px solid #a7f3d0}.gateway-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.gateway-title{font-size:1.1rem;font-weight:600}.gateway-meta{font-size:.85rem;color:var(--text-sec)}.node-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}@media(min-width:640px){.node-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.node-grid{grid-template-columns:repeat(3,1fr)}}.node-card{background:var(--surface);padding:20px;border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:.2s}.node-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.node-id{font-weight:600;font-size:1.1rem;color:var(--text-main);display:flex;align-items:center;gap:8px}.n-badge{font-size:.7rem;padding:2px 8px;border-radius:10px;background:#e5e7eb;color:#374151}.n-badge.on{background:#d1fae5;color:#065f46}.node-data-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}.nd-item{background:#f9fafb;padding:8px;border-radius:8px;text-align:center}.nd-val{font-size:1.2rem;font-weight:600;color:var(--text-main)}.nd-lbl{font-size:.75rem;color:var(--text-sec)}.node-footer{border-top:1px solid var(--border);padding-top:10px;font-size:.8rem;color:var(--text-sec);display:flex;justify-content:space-between}.card{background:#fff;padding:20px;border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow-sm)}.chart-card{background:linear-gradient(180deg,#fff,#f8fafc)}.chart-summary{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px}.chart-summary .pill{background:#eff6ff;color:#1d4ed8}.view-sec.hidden{display:none}.form-grp{margin-bottom:20px}.form-lbl{font-weight:500;margin-bottom:8px;display:block;color:var(--text-sec)}.form-inp{width:100%;padding:10px;border:1px solid var(--border);border-radius:8px;font-family:inherit;font-size:1rem}.btn-save{background:var(--primary);color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:1rem}.map-container{position:relative;width:100%;height:360px;background:#e5e7eb;border-radius:12px;overflow:hidden;border:2px solid var(--border)}.map-bg-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#9ca3af}.map-node{position:absolute;width:90px;padding:6px;background:#fffffff2;border-radius:8px;border:2px solid var(--primary);box-shadow:0 4px 6px #0000001f;font-size:12px;cursor:grab;transform:translate(-50%,-50%)}.map-node:active{cursor:grabbing}.mn-head{font-weight:600;font-size:12px;margin-bottom:4px;border-bottom:1px solid #e5e7eb;text-align:center}.mn-row{display:flex;justify-content:space-between}.mn-foot{margin-top:4px;font-size:10px;color:#6b7280}.log-table{width:100%;border-collapse:collapse;font-size:13px}.log-table th,.log-table td{padding:8px 12px;text-align:left;border-bottom:1px solid #eee}.log-table th{background:#f9fafb;font-weight:600;color:var(--text-sec)}.log-lvl-INFO{color:#10b981;font-weight:600}.log-lvl-WARN{color:#f59e0b;font-weight:600}.log-lvl-ERROR{color:#ef4444;font-weight:600}.rule-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #e5e7eb;font-size:.9rem}.btn-ghost{background:#f3f4f6;border:none;border-radius:8px;padding:6px 10px;cursor:pointer;font-size:.85rem}.btn-ghost.danger{background:#fee2e2;color:#991b1b}
