*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#0a0a08;--card:#161513;--card2:#1f1d19;--line:#35322c;--text:#e8dfce;--dim:#8a816e;--accent:#d1ff4a;--green:#45b86d;--red:#d45544;--amber:#e09330;--cyan:#51c2bc;--radius:6px;--mono:'SF Mono','Cascadia Code','Consolas',monospace;--sans:-apple-system,'Segoe UI','Microsoft YaHei',sans-serif}
body{background:var(--bg);color:var(--text);font:13px/1.5 var(--sans);min-height:100vh}
.app{max-width:1100px;margin:0 auto;padding:8px 10px 20px}

/* Bar */
.bar{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line);margin-bottom:8px}
.bar-l{display:flex;align-items:center;gap:8px}
.badge{background:var(--accent);color:#111;padding:1px 7px;border-radius:3px;font:700 10px/16px var(--mono);letter-spacing:.5px}
h1{font-size:16px;font-weight:750}
.bar-r{display:flex;gap:5px}
.pill{font:700 10px/1 var(--mono);padding:3px 8px;border:1px solid var(--green);border-radius:999px;color:var(--green);background:rgba(69,184,109,.12)}
.pill.dim{border-color:var(--line);color:var(--dim);background:rgba(255,255,255,.03)}
.pill.warn{border-color:var(--red);color:var(--red);background:rgba(212,85,68,.14)}

/* Split Layout */
.split{display:flex;gap:10px}
.left{flex:0 0 380px;min-width:0;overflow-y:auto;max-height:calc(100vh - 60px)}
.right{flex:1;min-width:0;display:flex}
.right .card{flex:1;display:flex;flex-direction:column}
.right .log{flex:1;min-height:0;max-height:calc(100vh - 80px)}

/* Card */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:10px;margin-bottom:6px}
.card-hd{display:flex;align-items:center;gap:6px;margin-bottom:8px}
.tag{font:700 9px/1 var(--mono);color:var(--accent);border:1px solid var(--accent);border-radius:2px;padding:1px 4px;letter-spacing:.3px;flex-shrink:0}
.ct{font-size:13px;font-weight:700;flex:1}
.hint{color:var(--dim);font-size:11px;margin:0 0 6px}

/* Fields */
.fld{display:flex;align-items:center;gap:5px;margin-bottom:5px;flex-wrap:wrap}
.fld label{color:var(--dim);font-size:11px;min-width:42px;flex-shrink:0}
.fld input{flex:1;min-height:30px;border:1px solid var(--line);border-radius:4px;background:#0d0c0a;color:var(--text);padding:5px 8px;font:12px var(--mono);outline:none}
.fld input:focus{border-color:var(--accent)}
.fld .tip{width:100%;color:var(--dim);font-size:10px;padding:1px 0 0 47px;line-height:1.4}
.fld.shrink input.inp-sm{width:70px;flex:0 0 70px}
.row-2{display:flex;gap:6px;align-items:center;margin-bottom:5px}
.ck{display:flex;align-items:center;gap:5px;margin-top:4px}
.ck input{width:14px;height:14px;accent-color:var(--accent)}
.ck label{color:var(--dim);font-size:12px}

/* Buttons */
button{min-height:30px;border:1px solid var(--line);border-radius:5px;background:var(--card2);color:var(--text);padding:0 10px;font:600 11px/1 var(--sans);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
button:hover{opacity:.8}
button:active{opacity:.6}
button.accent{background:var(--accent);color:#111;border-color:var(--accent)}
button.ghost{background:transparent;color:var(--dim);border-color:transparent}
button.ca{background:var(--red);color:#fff;border-color:#b04a3e}
button:disabled{opacity:.3;cursor:default}
.btn-sm{min-height:28px;font-size:10px;padding:0 8px}
.btn-xs{min-height:26px;font-size:10px;padding:0 6px;border-radius:3px}
.btn-row{display:flex;gap:4px;flex-wrap:wrap;padding:3px 0}
.btn-row button{flex:1;min-width:50px;text-align:center}

/* Attack buttons */
.atta{min-height:32px;border-radius:5px;border:1px solid var(--accent);background:var(--accent);color:#111;font:700 11px/1 var(--sans);padding:0 12px;cursor:pointer}
.atta.red{background:var(--red);color:#fff;border-color:#b04a3e}
.atta:disabled{opacity:.35;cursor:default}

/* Grid 3-col */
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px}
.g3 button{font-size:10px;padding:5px 3px;text-align:center;min-height:30px}

/* Flow */
.flow{display:grid;gap:8px}
.fi{display:flex;gap:8px;align-items:flex-start;border:1px solid var(--line);border-radius:var(--radius);padding:10px;background:var(--card2)}
.dot{width:22px;height:22px;border-radius:50%;background:var(--accent);color:#111;font:700 11px/22px var(--mono);text-align:center;flex-shrink:0}
.fb{flex:1;min-width:0}
.fb strong{display:block;font-size:12px;margin-bottom:2px}
.fb p{margin:0 0 6px;color:var(--dim);font-size:11px}
.m{font-family:var(--mono);font-size:11px}

/* Device */
.dev-box{min-height:36px;border:1px dashed var(--line);border-radius:5px;padding:8px;margin-bottom:6px;background:rgba(255,255,255,.015);font-size:12px;color:var(--dim)}
.dev-box strong{color:var(--text)}
.dev-box code{display:block;color:var(--cyan);font:11px var(--mono);word-break:break-all;margin-top:1px}
.svc-box{font-size:11px;color:var(--dim);max-height:100px;overflow:auto}
.svc-item{border:1px solid var(--line);border-radius:4px;padding:5px 7px;margin-bottom:3px;background:var(--card2)}
.svc-item strong{color:var(--text);font-size:11px}

/* Textarea / Result */
textarea{width:100%;min-height:52px;resize:vertical;border:1px solid var(--line);border-radius:4px;background:#0d0c0a;color:var(--text);padding:6px 8px;font:11px/1.4 var(--mono);outline:none}
textarea:focus{border-color:var(--accent)}
.res{min-height:60px;max-height:110px;overflow:auto;border:1px solid var(--line);border-radius:4px;background:#090907;color:var(--text);padding:6px 8px;font:10px/1.5 var(--mono);white-space:pre-wrap;word-break:break-all;margin-top:4px}
.sg{display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-top:6px}
.sample-item{border:1px solid var(--line);border-radius:3px;padding:4px 6px;cursor:pointer;background:var(--card2)}
.sample-item:hover{border-color:var(--accent)}
.sample-item strong{display:block;font-size:10px;color:var(--text)}
.sample-item code{display:block;font:9px var(--mono);color:var(--cyan);word-break:break-all;margin-top:1px}

/* Log */
.log-card{position:relative}
.log-card .log{overflow:auto;border:1px solid var(--line);border-radius:4px;background:#080806;color:#d4ccba;padding:8px;font:10px/1.5 var(--mono);white-space:pre-wrap;word-break:break-all;height:100%}

/* Responsive */
@media(max-width:800px){.split{flex-direction:column}.left{flex:1;max-height:none}.right .log{max-height:320px;min-height:200px}}
