/*
 * style.css — ASTARA 2DOF Web UI Demo
 * Identik dengan CSS embed di webui.h, dipisah ke file tersendiri
 */

*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#08111f;--bg2:#0d1b2a;--bg3:rgba(255,255,255,.04);
  --border:rgba(0,212,255,.13);--cyan:#00d4ff;--cyan2:#0066ff;
  --green:#00ff96;--yellow:#ffb400;--red:#ff4d4d;--purple:#a855f7;
  --text:rgba(255,255,255,.85);--muted:rgba(255,255,255,.38);
  --sidebar-w:210px;--topnav-h:52px;--botnav-h:56px;
}
html,body{height:100%;overflow:hidden}
body{background:var(--bg);font-family:'Segoe UI',sans-serif;color:var(--text);display:flex;flex-direction:column}
.topnav{height:var(--topnav-h);flex-shrink:0;background:rgba(8,17,31,.95);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:10px;z-index:200;backdrop-filter:blur(16px)}
.brand{font-size:14px;font-weight:800;letter-spacing:.4px;white-space:nowrap;background:linear-gradient(135deg,var(--cyan),var(--cyan2));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.dot-live{width:7px;height:7px;flex-shrink:0;border-radius:50%;background:var(--green);box-shadow:0 0 7px var(--green);animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.nav-status{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ml-auto{margin-left:auto;flex-shrink:0}
.logout{padding:5px 11px;background:rgba(255,75,75,.12);border:1px solid rgba(255,75,75,.3);border-radius:6px;color:var(--red);font-size:11px;text-decoration:none;font-weight:600;transition:.2s;white-space:nowrap;cursor:pointer}
.logout:hover{background:rgba(255,75,75,.22)}
.demo-badge{padding:3px 9px;background:rgba(255,180,0,.12);border:1px solid rgba(255,180,0,.3);border-radius:5px;color:var(--yellow);font-size:10px;font-weight:700;white-space:nowrap}
.shell{display:flex;flex:1;overflow:hidden}
.sidebar{width:var(--sidebar-w);flex-shrink:0;background:rgba(13,27,42,.98);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;padding:10px 0}
.sidebar-section{font-size:10px;font-weight:700;color:rgba(0,212,255,.4);text-transform:uppercase;letter-spacing:1px;padding:12px 14px 5px}
.nav-item{display:flex;align-items:center;gap:9px;padding:8px 14px;cursor:pointer;border-left:3px solid transparent;transition:.15s;font-size:12px;color:var(--muted);font-weight:500}
.nav-item:hover{background:rgba(0,212,255,.06);color:var(--text)}
.nav-item.active{border-left-color:var(--cyan);background:rgba(0,212,255,.08);color:var(--cyan);font-weight:700}
.nav-icon{font-size:14px;width:18px;text-align:center;flex-shrink:0}
.botnav{display:none}
.main{flex:1;overflow-y:auto;padding:16px}
.panel{display:none}.panel.active{display:block}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.sc{background:var(--bg3);border:1px solid var(--border);border-radius:13px;padding:16px;margin-bottom:14px}
.sc-title{font-size:13px;font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:7px}
.sc-title span{font-size:16px}
.info-cat-title{font-size:10px;font-weight:700;color:rgba(0,212,255,.5);text-transform:uppercase;letter-spacing:1px;padding:6px 0 4px;border-bottom:1px solid rgba(0,212,255,.1);margin-bottom:0}
.info-row{display:flex;align-items:flex-start;justify-content:space-between;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.info-row:last-child{border-bottom:none}
.info-left{flex:1;min-width:0;padding-right:8px}
.info-name{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap}
.info-desc{font-size:10px;color:var(--muted);margin-top:1px;line-height:1.4}
.info-right{font-size:13px;font-weight:800;font-family:monospace;color:var(--cyan);white-space:nowrap;text-align:right;flex-shrink:0}
.info-right.ok{color:var(--green)}.info-right.warn{color:var(--yellow)}.info-right.err{color:var(--red)}
.mrow{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.mrow:last-child{border-bottom:none;padding-bottom:0}
.mrow-lbl{font-size:12px;color:var(--muted)}
.mrow-val{font-size:19px;font-weight:800;font-family:monospace}
.bar-wrap{height:4px;background:rgba(255,255,255,.07);border-radius:3px;margin-top:3px;overflow:hidden}
.bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--cyan),var(--cyan2));transition:width .3s}
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase}
.badge-ok{background:rgba(0,255,150,.1);border:1px solid rgba(0,255,150,.25);color:var(--green)}
.badge-off{background:rgba(255,75,75,.1);border:1px solid rgba(255,75,75,.25);color:var(--red)}
.badge-warn{background:rgba(255,180,0,.1);border:1px solid rgba(255,180,0,.25);color:var(--yellow)}
.btn-row{display:flex;gap:7px;flex-wrap:wrap;margin-top:12px}
.btn{padding:8px 14px;border:none;border-radius:7px;font-size:12px;font-weight:700;cursor:pointer;transition:.15s;letter-spacing:.3px}
.btn:active{transform:scale(.97)}
.btn-p{background:linear-gradient(135deg,var(--cyan),var(--cyan2));color:#fff;box-shadow:0 3px 12px rgba(0,212,255,.2)}
.btn-p:hover{box-shadow:0 5px 20px rgba(0,212,255,.38)}
.btn-ok{background:linear-gradient(135deg,#00c851,#007e33);color:#fff}
.btn-err{background:linear-gradient(135deg,#ff4444,#cc0000);color:#fff}
.btn-warn{background:linear-gradient(135deg,#ffbb33,#ff8800);color:#fff}
.btn-ghost{background:rgba(255,255,255,.07);color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.12)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-full{width:100%}
.inp-row{display:flex;align-items:center;gap:9px;margin-bottom:10px}
.inp-row label{font-size:11px;color:var(--cyan);min-width:85px;text-transform:uppercase;letter-spacing:.5px;opacity:.8}
input[type=number]{background:rgba(255,255,255,.07);border:1px solid rgba(0,212,255,.2);border-radius:7px;color:#fff;padding:6px 10px;font-size:13px;outline:none;width:105px}
input[type=number]:focus{border-color:rgba(0,212,255,.5)}
input[type=text],input[type=password]{background:rgba(255,255,255,.07);border:1px solid rgba(0,212,255,.2);border-radius:7px;color:#fff;padding:6px 10px;font-size:13px;outline:none}
input[type=range]{width:100%;padding:0;height:5px;cursor:pointer;accent-color:var(--cyan)}
.inp-hint{font-size:11px;color:var(--muted);margin-left:3px}
.state-box{padding:12px;background:rgba(0,212,255,.06);border:1px solid rgba(0,212,255,.15);border-radius:10px;text-align:center;margin-bottom:12px}
.state-name{font-size:24px;font-weight:800;letter-spacing:2px;background:linear-gradient(135deg,var(--cyan),#66e0ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.state-desc{font-size:11px;color:var(--muted);margin-top:3px}
.led-toggle{display:flex;align-items:center;gap:12px;padding:14px;background:rgba(168,85,247,.07);border:1px solid rgba(168,85,247,.2);border-radius:11px;margin-bottom:10px}
.led-icon{font-size:28px}.led-info{flex:1}
.led-title{font-size:13px;font-weight:700}.led-sub{font-size:11px;color:var(--muted);margin-top:2px}
.toggle-wrap{display:flex;gap:7px}
.mot-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:10px}
.mot-btn{padding:13px;border-radius:9px;border:2px solid transparent;cursor:pointer;font-size:12px;font-weight:700;transition:.2s;text-align:center}
.mot-btn.inactive{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.1);color:var(--muted)}
.mot-btn.active-sin{background:rgba(0,212,255,.12);border-color:var(--cyan);color:var(--cyan)}
.mot-btn.active-tri{background:rgba(255,180,0,.12);border-color:var(--yellow);color:var(--yellow)}
.mot-icon{font-size:22px;margin-bottom:4px}
.chart-wrap{margin-top:14px;background:rgba(0,0,0,.4);border:1px solid var(--border);border-radius:11px;padding:10px;display:none}
.chart-wrap.visible{display:block;min-height:260px}
.chart-hdr{display:flex;align-items:center;margin-bottom:7px;gap:7px;flex-wrap:wrap}
.chart-hdr-title{font-size:10px;font-weight:700;color:rgba(0,212,255,.7);text-transform:uppercase;letter-spacing:.8px}
.chart-legend{display:flex;gap:10px;margin-left:auto;flex-wrap:wrap}
.leg-item{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--muted)}
.leg-line{width:14px;height:3px;border-radius:2px}
canvas#motionChart{display:block;width:100%!important;height:220px;border-radius:5px}
.stop-wrap{display:none;margin-top:10px}.stop-wrap.visible{display:block}
.cfg-table{width:100%;border-collapse:collapse}
.cfg-table th{font-size:10px;text-transform:uppercase;letter-spacing:.7px;color:var(--cyan);opacity:.7;padding:5px 7px;border-bottom:1px solid var(--border);text-align:left}
.cfg-table td{padding:7px;border-bottom:1px solid rgba(255,255,255,.04);font-size:12px}
.cfg-table input[type=number]{width:72px;padding:4px 7px;font-size:11px}
.cfg-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.cfg-table-wrap .cfg-table{min-width:420px}
.cur-pos{background:rgba(0,212,255,.05);border:1px solid rgba(0,212,255,.12);border-radius:9px;padding:12px;margin-bottom:10px}
.cur-pos-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0}
.cur-pos-lbl{font-size:11px;color:var(--muted)}
.cur-pos-val{font-size:15px;font-weight:800;font-family:monospace;color:var(--cyan)}
.wclient-table{width:100%;border-collapse:collapse;font-size:12px}
.wclient-table th{font-size:10px;text-transform:uppercase;letter-spacing:.7px;color:var(--cyan);opacity:.7;padding:5px 6px;border-bottom:1px solid var(--border);text-align:left}
.wclient-table td{padding:7px 6px;border-bottom:1px solid rgba(255,255,255,.04);color:var(--text)}
.wclient-empty{text-align:center;color:var(--muted);font-size:12px;padding:14px}
.toast{position:fixed;bottom:20px;right:16px;z-index:999;padding:10px 16px;border-radius:9px;font-size:12px;font-weight:700;opacity:0;transform:translateY(8px);transition:.3s;pointer-events:none}
.toast.show{opacity:1;transform:translateY(0)}
.toast-ok{background:#00c851;color:#fff}.toast-err{background:var(--red);color:#fff}
#color-picker-wrap{display:none;background:var(--bg2);border:1px solid var(--border);border-radius:11px;padding:14px;margin-bottom:10px}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(0,212,255,.2);border-radius:3px}

@media(max-width:768px){
  .sidebar{display:none}
  .botnav{display:flex;flex-shrink:0;height:var(--botnav-h);background:rgba(8,17,31,.97);border-top:1px solid var(--border);overflow-x:auto;overflow-y:hidden;z-index:200;order:10;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .botnav::-webkit-scrollbar{display:none}
  .bnav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:0 12px;cursor:pointer;font-size:9px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;flex-shrink:0;min-width:60px;border-top:2px solid transparent;transition:.15s}
  .bnav-item.active{color:var(--cyan);border-top-color:var(--cyan)}
  .bnav-icon{font-size:18px;line-height:1}
  .shell{flex-direction:column}
  .main{padding:10px;flex:1;overflow-y:auto}
  .two-col{grid-template-columns:1fr;gap:10px}
  .cfg-table th:nth-child(2),.cfg-table td:nth-child(2){display:none}
  .info-desc{display:none}
  .inp-row{flex-wrap:wrap}
  .inp-row label{min-width:100%;margin-bottom:2px}
  input[type=number],input[type=text],input[type=password]{width:100%}
  .btn{padding:10px 14px;font-size:13px}
  .state-name{font-size:20px}
  .led-toggle{gap:8px;padding:10px}
  .topnav{padding:0 10px;gap:7px}
  .nav-status{display:none}
  .demo-badge{display:none}
}
