:root{
  --bg:#0a0f0a; --panel:#0f1711; --panel2:#0c130d; --line:#1f3324;
  --txt:#cfead2; --dim:#7fa587; --amber:#ffb000; --green:#39ff14;
  --red:#ff5c5c; --accent:#39ff14;
  --mono:"SFMono-Regular",Consolas,"Liberation Mono",Menlo,monospace;
}
*{box-sizing:border-box}
body{
  margin:0;background:var(--bg);color:var(--txt);
  font-family:var(--mono);line-height:1.5;
  background-image:repeating-linear-gradient(0deg,rgba(57,255,20,.025) 0 1px,transparent 1px 3px);
}
a{color:var(--green)}
.wrap{max-width:760px;margin:0 auto;padding:24px 18px 64px}
header{text-align:center;padding:20px 0 8px}
h1{font-size:1.9rem;margin:.2em 0;letter-spacing:.04em;color:var(--green);text-shadow:0 0 10px rgba(57,255,20,.4)}
.sub{color:var(--dim);font-size:.9rem;margin:0}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:18px;margin:16px 0}
h2{font-size:1rem;color:var(--amber);margin:0 0 12px;letter-spacing:.05em;text-transform:uppercase}
.muted{color:var(--dim);font-size:.85rem}
/* unsupported-browser banner */
#unsupported{display:none;background:#2a0d0d;border:1px solid var(--red);color:#ffd0d0}
#unsupported.show{display:block}
/* step cards */
.row{display:flex;gap:10px;flex-wrap:wrap}
.card{
  flex:1 1 0;min-width:160px;background:var(--panel2);border:1px solid var(--line);
  border-radius:8px;padding:12px 14px;cursor:pointer;user-select:none;transition:.12s;
}
.card:hover{border-color:var(--green)}
.card.sel{border-color:var(--green);box-shadow:0 0 0 1px var(--green) inset;background:#0e1a10}
.card .t{font-weight:700;color:var(--txt)}
.card .d{font-size:.78rem;color:var(--dim);margin-top:4px}
.card.locked{opacity:.45;cursor:not-allowed}
.card.locked:hover{border-color:var(--line)}
.badge{display:inline-block;font-size:.65rem;padding:1px 6px;border-radius:4px;border:1px solid var(--amber);color:var(--amber);margin-left:6px;vertical-align:middle}
.badge.rift{border-color:var(--green);color:var(--green)}
.warn{background:#241a05;border:1px solid var(--amber);color:#ffe9b0;border-radius:8px;padding:10px 12px;font-size:.82rem;margin-top:10px}
/* install button host */
#install-host{margin-top:18px;text-align:center;min-height:48px}
esp-web-install-button{--esp-tools-button-color:#0a0f0a;--esp-tools-button-text-color:#39ff14;}
.ib{
  display:inline-block;background:var(--green);color:#04210a;font-weight:700;
  border:none;border-radius:8px;padding:12px 22px;font-size:1rem;cursor:pointer;font-family:var(--mono);
}
.ib[disabled]{opacity:.4;cursor:not-allowed}
/* auth box */
.field{display:flex;flex-direction:column;gap:4px;margin:8px 0}
label{font-size:.78rem;color:var(--dim)}
input{background:#060a06;border:1px solid var(--line);color:var(--txt);border-radius:6px;padding:9px 10px;font-family:var(--mono);font-size:.9rem}
input:focus{outline:none;border-color:var(--green)}
button.act{background:var(--amber);color:#1a1200;border:none;border-radius:6px;padding:10px 16px;font-weight:700;cursor:pointer;font-family:var(--mono)}
button.act[disabled]{opacity:.5;cursor:not-allowed}
.status{font-size:.82rem;margin-top:8px;min-height:1.2em}
.status.err{color:var(--red)}
.status.ok{color:var(--green)}
details{margin-top:8px}
summary{cursor:pointer;color:var(--amber);font-size:.85rem}
ol{padding-left:1.2em} li{margin:4px 0}
kbd{background:#060a06;border:1px solid var(--line);border-radius:4px;padding:1px 6px;font-size:.8rem}
footer{margin-top:28px;text-align:center;color:var(--dim);font-size:.75rem;line-height:1.7}
hr{border:none;border-top:1px solid var(--line);margin:16px 0}
