/* StarkRista — product mocks shared styles */

/* ---- app window chrome ---- */
.appwin {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow:
    0 30px 60px -30px rgba(0,0,0,0.6),
    0 8px 20px -10px rgba(0,0,0,0.4);
}

.appwin-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,0.02), transparent);
}

.appwin-traffic {
  display: flex; gap: 6px;
}
.appwin-traffic span {
  width: 11px; height: 11px; border-radius: 50%;
  background: #2c3550;
}
.appwin-traffic span:nth-child(1) { background: #ef4444; opacity: 0.7; }
.appwin-traffic span:nth-child(2) { background: #f97316; opacity: 0.7; }
.appwin-traffic span:nth-child(3) { background: #22c55e; opacity: 0.7; }

.appwin-addr {
  display: flex;
  align-items: center;
  gap: 6px;
  flex: 1;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--muted);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 5px 10px;
  max-width: 380px;
  margin: 0 auto;
}
.appwin-addr .lock { color: var(--success); font-size: 10px; }

.appwin-body {
  display: grid;
  grid-template-columns: 220px 1fr;
  min-height: 460px;
}

/* ---- app sidebar ---- */
.app-side {
  border-right: 1px solid var(--border);
  background: rgba(255,255,255,0.012);
  padding: 16px 12px;
  font-size: 13px;
}

.app-side-title {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 8px 10px 6px;
}

.app-side a, .app-side .item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  border-radius: 6px;
  color: var(--text-dim);
  cursor: pointer;
}
.app-side .item.active {
  background: var(--accent-soft);
  color: var(--accent);
}
.app-side .item .ic {
  width: 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
}
.app-side .item.active .ic { color: var(--accent); }

.app-side .switch-pick {
  margin-top: 16px;
  padding: 10px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
}
.app-side .switch-pick .label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--muted);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.app-side .switch-pick .name {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text);
}
.app-side .switch-pick .meta {
  font-size: 11px;
  color: var(--muted);
  margin-top: 2px;
}

/* ---- app main ---- */
.app-main {
  padding: 18px 22px 22px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  overflow: hidden;
}

.app-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.app-head h3 {
  font-family: var(--font-sans);
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.app-head .breadcrumb {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 0.04em;
}

.app-head .actions {
  display: flex; gap: 8px;
}
.app-head .actions .b {
  padding: 6px 10px;
  border-radius: 5px;
  border: 1px solid var(--border);
  font-size: 12px;
  color: var(--text-dim);
  font-family: var(--font-sans);
  background: var(--surface);
}

/* stat row */
.statrow {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.stat {
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
}
.stat .k {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
}
.stat .v {
  font-family: var(--font-mono);
  font-size: 22px;
  margin-top: 4px;
  color: var(--text);
  letter-spacing: -0.01em;
}
.stat .delta {
  font-size: 11px;
  margin-top: 2px;
  font-family: var(--font-mono);
}
.stat .delta.up { color: var(--success); }
.stat .delta.warn { color: var(--warning); }
.stat .delta.dim { color: var(--muted); }

/* port grid */
.port-grid {
  display: grid;
  grid-template-columns: repeat(24, 1fr);
  gap: 4px;
}
.port {
  aspect-ratio: 1.4 / 1;
  border-radius: 3px;
  border: 1px solid rgba(255,255,255,0.04);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 9px;
  color: rgba(255,255,255,0.5);
}
.port.up   { background: linear-gradient(180deg, rgba(34,197,94,0.6), rgba(34,197,94,0.3)); border-color: rgba(34,197,94,0.5); color: rgba(255,255,255,0.85); }
.port.warn { background: linear-gradient(180deg, rgba(249,115,22,0.55), rgba(249,115,22,0.25)); border-color: rgba(249,115,22,0.5); color: rgba(255,255,255,0.85); }
.port.down { background: linear-gradient(180deg, rgba(239,68,68,0.5), rgba(239,68,68,0.2)); border-color: rgba(239,68,68,0.4); color: rgba(255,255,255,0.85); }
.port.idle { background: var(--surface); border-color: var(--border); color: var(--muted); }

/* mini bgp / table */
.tbl {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-mono);
  font-size: 12px;
}
.tbl th {
  text-align: left;
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 8px 10px;
  border-bottom: 1px solid var(--border);
  background: rgba(255,255,255,0.015);
}
.tbl td {
  padding: 8px 10px;
  border-bottom: 1px solid var(--border);
  color: var(--text);
}
.tbl tr:last-child td { border-bottom: 0; }
.tbl tr:hover td { background: rgba(58, 134, 255, 0.04); }

.tbl .net { color: var(--text); }
.tbl .ip  { color: var(--accent); }
.tbl .asn { color: var(--warning); }
.tbl .num { color: var(--text); text-align: right; }
.tbl .com { color: var(--muted); }

/* legend chips */
.legend {
  display: flex;
  gap: 16px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
  margin-top: 8px;
}
.legend .it {
  display: flex; align-items: center; gap: 6px;
}

/* feature mock captions */
.tour-cap {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--muted);
  margin-top: 14px;
}
.tour-cap .num {
  color: var(--accent);
  margin-right: 8px;
}

/* responsive */
@media (max-width: 900px) {
  .appwin-body { grid-template-columns: 1fr; }
  .app-side { display: none; }
  .statrow { grid-template-columns: repeat(2, 1fr); }
  .port-grid { grid-template-columns: repeat(12, 1fr); }
}
