:root{
  --bg:#15171a;
  --bg-2:#1b1e23;
  --surface:#22262d;
  --surface-2:#272c34;
  --line:#33393f;
  --line-bright:#454c54;
  --text:#e7eaed;
  --muted:#8a9199;
  --muted-2:#5f676f;
  --amber:#ffb31f;
  --amber-deep:#e8920a;
  --online:#54c47a;
  --maint:#ffb31f;
  --offline:#e5544f;
  --unknown:#8a9199;
  --r:6px;
}
*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none!important}
html,body{height:100%}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Archivo',sans-serif;
  -webkit-font-smoothing:antialiased;
  position:relative;
  overflow-x:hidden;
}
/* grain + vignette */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  background:radial-gradient(circle at 50% -10%, rgba(255,179,31,0.06), transparent 55%);
}
.wrap{position:relative;z-index:2;max-width:1240px;margin:0 auto;padding:0 28px 80px}

/* ===== Top utility bar ===== */
.util{
  display:flex;align-items:center;gap:22px;flex-wrap:wrap;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.04em;
  color:var(--muted);padding:11px 0;border-bottom:1px solid var(--line);
  text-transform:uppercase;
}
.util .dot{width:7px;height:7px;border-radius:50%;background:var(--online);
  box-shadow:0 0 8px rgba(84,196,122,.7);display:inline-block;margin-right:7px;
  animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}
.util .stat b{color:var(--text);font-weight:500}
.util .spacer{flex:1}
.util .host{color:var(--amber)}
.util .user{color:var(--text)}
.util .user b{color:var(--amber);font-weight:500}

/* ===== Masthead ===== */
header.head{padding:34px 0 26px;position:relative}
.stripe{
  height:8px;width:100%;border-radius:2px;margin-bottom:30px;
  background:repeating-linear-gradient(135deg,var(--amber) 0 18px,#1c1f24 18px 36px);
  opacity:.9;
}
.brand{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:18px}
.brand h1{
  font-family:'Saira Condensed',sans-serif;font-weight:700;
  font-size:clamp(38px,6vw,62px);line-height:.92;letter-spacing:.01em;
  text-transform:uppercase;
}
.brand h1 span{color:var(--amber)}
.brand .sub{
  font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--muted);
  margin-top:10px;letter-spacing:.03em;
}
.search{
  display:flex;align-items:center;gap:10px;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r);padding:11px 15px;min-width:280px;
  width:min(360px,100%);
}
.search:focus-within{border-color:var(--line-bright)}
.search svg{width:15px;height:15px;fill:var(--muted-2);flex:none}
.search input{
  background:none;border:none;outline:none;color:var(--text);width:100%;
  font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.02em;
}
.search input::placeholder{color:var(--muted-2)}

/* ===== Section label ===== */
.seclabel{
  display:flex;align-items:center;gap:14px;margin:8px 0 18px;
  font-family:'Saira Condensed',sans-serif;text-transform:uppercase;
  font-size:14px;letter-spacing:.18em;color:var(--muted);font-weight:600;
}
.app-section + .app-section .seclabel{margin-top:34px}
.seclabel .ln{flex:1;height:1px;background:var(--line)}
.seclabel .count{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted-2);letter-spacing:.05em}

/* ===== Grid ===== */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(312px,1fr));gap:16px}

.card{
  background:linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--line);border-radius:var(--r);
  padding:20px 20px 16px;position:relative;overflow:hidden;
  display:flex;flex-direction:column;min-height:172px;cursor:pointer;
  text-decoration:none;color:inherit;
  transition:transform .22s cubic-bezier(.2,.7,.3,1),border-color .22s,box-shadow .22s;
  opacity:0;transform:translateY(14px);
  animation:rise .5s forwards;
}
@keyframes rise{to{opacity:1;transform:translateY(0)}}
.card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--amber);
  transform:scaleY(0);transform-origin:top;transition:transform .25s ease;
}
.card:hover{transform:translateY(-4px);border-color:var(--line-bright);
  box-shadow:0 14px 34px -16px rgba(0,0,0,.7)}
.card:hover::before{transform:scaleY(1)}
.card:focus-visible{outline:2px solid var(--amber);outline-offset:2px}

.card .top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.icon{
  width:42px;height:42px;border-radius:8px;flex:none;display:grid;place-items:center;
  font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:19px;
  color:var(--bg);background:var(--amber);letter-spacing:.02em;
}
.icon.alt{background:var(--surface-2);color:var(--amber);border:1px solid var(--line-bright)}

.pill{
  font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:500;
  letter-spacing:.06em;text-transform:uppercase;padding:4px 9px;border-radius:20px;
  display:inline-flex;align-items:center;gap:6px;white-space:nowrap;
}
.pill i{width:6px;height:6px;border-radius:50%;display:inline-block}
.pill.online{color:var(--online);background:rgba(84,196,122,.1);border:1px solid rgba(84,196,122,.25)}
.pill.online i{background:var(--online);box-shadow:0 0 6px var(--online)}
.pill.maintenance{color:var(--maint);background:rgba(255,179,31,.1);border:1px solid rgba(255,179,31,.25)}
.pill.maintenance i{background:var(--maint)}
.pill.offline{color:var(--offline);background:rgba(229,84,79,.1);border:1px solid rgba(229,84,79,.25)}
.pill.offline i{background:var(--offline)}
.pill.unknown{color:var(--unknown);background:rgba(138,145,153,.08);border:1px solid rgba(138,145,153,.22)}
.pill.unknown i{background:var(--unknown)}

.card h3{font-family:'Saira Condensed',sans-serif;font-weight:600;font-size:21px;
  text-transform:uppercase;letter-spacing:.01em;margin:16px 0 5px}
.card p{font-size:13px;color:var(--muted);line-height:1.45;flex:1}

.meta{display:flex;align-items:center;justify-content:space-between;gap:10px;
  margin-top:16px;padding-top:13px;border-top:1px solid var(--line)}
.path{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--amber);
  letter-spacing:.01em;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.owner{display:flex;align-items:center;gap:7px;font-family:'JetBrains Mono',monospace;
  font-size:10px;color:var(--muted-2);text-transform:uppercase;letter-spacing:.04em;
  flex:none;max-width:42%;overflow:hidden;white-space:nowrap}
.ava{width:20px;height:20px;border-radius:50%;background:var(--surface-2);
  border:1px solid var(--line-bright);display:grid;place-items:center;
  font-size:9px;color:var(--text);font-weight:700}

/* add card */
.card.add{
  align-items:center;justify-content:center;text-align:center;cursor:pointer;
  background:none;border:1px dashed var(--line-bright);
  appearance:none;width:100%;font:inherit;color:inherit;
}
.card.add::before{display:none}
.card.add:hover{border-color:var(--amber);background:rgba(255,179,31,.03)}
.card.add .plus{width:46px;height:46px;border-radius:50%;border:1px solid var(--line-bright);
  display:grid;place-items:center;font-size:26px;color:var(--muted);margin-bottom:12px;
  font-family:'Saira Condensed',sans-serif;transition:.2s}
.card.add:hover .plus{color:var(--amber);border-color:var(--amber)}
.card.add span{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;
  letter-spacing:.12em;font-size:14px;color:var(--muted);font-weight:600}
.card.add small{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--muted-2);
  margin-top:6px;letter-spacing:.03em}

.empty{text-align:center;padding:60px 0;color:var(--muted-2);
  font-family:'JetBrains Mono',monospace;font-size:13px;grid-column:1/-1}

footer{margin-top:46px;padding-top:18px;border-top:1px solid var(--line);
  font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted-2);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;letter-spacing:.03em}
footer .host{color:var(--muted)}

/* ===== Register-App modal (spec §5) ===== */
.modal-back{
  position:fixed;inset:0;z-index:50;display:none;
  background:rgba(10,11,13,.72);backdrop-filter:blur(2px);
  align-items:center;justify-content:center;padding:24px;
}
.modal-back.open{display:flex}
.modal{
  background:linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--line-bright);border-radius:var(--r);
  max-width:560px;width:100%;padding:0;position:relative;overflow:hidden;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.8);
  animation:rise .35s forwards;
}
.modal .stripe{margin:0;border-radius:0}
.modal .body{padding:24px 26px 28px}
.modal h2{font-family:'Saira Condensed',sans-serif;font-weight:700;text-transform:uppercase;
  font-size:26px;letter-spacing:.02em;margin-bottom:4px}
.modal .lead{font-size:13.5px;color:var(--muted);line-height:1.5;margin-bottom:18px}
.modal ol{list-style:none;counter-reset:step;display:flex;flex-direction:column;gap:14px}
.modal li{counter-increment:step;position:relative;padding-left:34px;font-size:13px;
  color:var(--text);line-height:1.5}
.modal li::before{content:counter(step,decimal-leading-zero);position:absolute;left:0;top:0;
  font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--bg);background:var(--amber);
  width:22px;height:22px;border-radius:5px;display:grid;place-items:center;font-weight:700}
.modal li b{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:.03em;
  font-size:14px;display:block;margin-bottom:3px}
.modal code,.modal pre{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--amber)}
.modal pre{background:var(--bg);border:1px solid var(--line);border-radius:var(--r);
  padding:12px 14px;margin-top:8px;overflow-x:auto;color:var(--text);line-height:1.55;
  white-space:pre}
.modal pre .k{color:var(--amber)}
.modal .x{position:absolute;top:14px;right:14px;z-index:2;background:var(--surface-2);
  border:1px solid var(--line-bright);color:var(--muted);width:30px;height:30px;border-radius:6px;
  cursor:pointer;font-size:16px;line-height:1;display:grid;place-items:center;font-family:'JetBrains Mono',monospace}
.modal .x:hover{color:var(--amber);border-color:var(--amber)}

@media (max-width:480px){
  .wrap{padding:0 16px 60px}
  .grid{grid-template-columns:1fr}
}
