:root {
  --bg: #06090e;
  --bg-2: #090d13;
  --panel: rgba(13, 19, 28, .82);
  --panel-solid: #0d131c;
  --panel-2: #111925;
  --panel-3: #151f2c;
  --line: rgba(145, 177, 204, .13);
  --line-strong: rgba(145, 177, 204, .24);
  --text: #ecf4f8;
  --muted: #6f8190;
  --muted-2: #91a1ad;
  --cyan: #42e8d8;
  --cyan-2: #15b9b0;
  --cyan-dim: rgba(66, 232, 216, .13);
  --blue: #79a7ff;
  --violet: #9d8cff;
  --amber: #f2b85b;
  --red: #ff5d73;
  --green: #6ef2a3;
  --sidebar-w: 282px;
  --topbar-h: 74px;
  --radius: 16px;
  --radius-sm: 10px;
  --shadow: 0 22px 70px rgba(0, 0, 0, .4);
  --ease: cubic-bezier(.2, .75, .2, 1);
}

* { box-sizing: border-box; }
html { background: var(--bg); scroll-behavior: smooth; }
body {
  margin: 0;
  min-width: 320px;
  min-height: 100vh;
  overflow: hidden;
  color: var(--text);
  background:
    radial-gradient(circle at 74% -10%, rgba(34, 192, 180, .10), transparent 31%),
    radial-gradient(circle at 18% 98%, rgba(89, 100, 215, .08), transparent 31%),
    linear-gradient(145deg, #080b11 0%, #05080c 60%, #070b10 100%);
  font-family: Inter, ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 14px;
  letter-spacing: .01em;
}
button, input, select, textarea { font: inherit; }
button { color: inherit; }
a { color: inherit; text-decoration: none; }
code, kbd, .mono { font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace; }

::selection { background: rgba(66, 232, 216, .25); color: #fff; }
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(133, 157, 175, .18); border-radius: 999px; }
::-webkit-scrollbar-thumb:hover { background: rgba(133, 157, 175, .3); }

.noise, .scanlines {
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: 999;
}
.noise {
  opacity: .018;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.7'/%3E%3C/svg%3E");
}
.scanlines {
  opacity: .05;
  background: repeating-linear-gradient(to bottom, transparent 0, transparent 3px, rgba(255,255,255,.025) 4px);
}

.app-shell { display: grid; grid-template-columns: var(--sidebar-w) minmax(0, 1fr); height: 100vh; }
.sidebar {
  position: relative;
  z-index: 20;
  display: flex;
  flex-direction: column;
  min-width: 0;
  background: rgba(8, 12, 18, .93);
  border-right: 1px solid var(--line);
  backdrop-filter: blur(18px);
  transition: width .35s var(--ease), transform .35s var(--ease);
}
.brand-wrap {
  min-height: var(--topbar-h);
  padding: 0 18px 0 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--line);
}
.brand { display: flex; align-items: center; gap: 12px; min-width: 0; }
.brand-mark { width: 34px; height: 34px; position: relative; flex: 0 0 auto; }
.brand-mark::before, .brand-mark::after {
  content: "";
  position: absolute;
  inset: 2px;
  border: 1px solid rgba(66, 232, 216, .45);
  transform: rotate(45deg);
  box-shadow: inset 0 0 18px rgba(66, 232, 216, .08), 0 0 16px rgba(66, 232, 216, .09);
}
.brand-mark::after { inset: 8px; border-color: rgba(121, 167, 255, .6); }
.brand-mark i {
  position: absolute;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--cyan);
  box-shadow: 0 0 10px var(--cyan);
  z-index: 2;
}
.brand-mark i:nth-child(1) { top: 0; left: 15px; }
.brand-mark i:nth-child(2) { right: 0; bottom: 15px; }
.brand-mark i:nth-child(3) { left: 0; bottom: 2px; }
.brand-copy { display: flex; flex-direction: column; line-height: 1; min-width: 0; }
.brand-copy strong { font-size: 15px; letter-spacing: .16em; white-space: nowrap; }
.brand-copy strong span { color: var(--cyan); }
.brand-copy small { margin-top: 7px; color: var(--muted); font-size: 9px; letter-spacing: .11em; white-space: nowrap; }

.icon-btn {
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, .02);
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: inline-grid;
  place-items: center;
  cursor: pointer;
  transition: .2s ease;
}
.icon-btn:hover { border-color: rgba(66, 232, 216, .38); background: rgba(66, 232, 216, .07); transform: translateY(-1px); }
.menu-lines, .menu-lines::before, .menu-lines::after {
  width: 15px; height: 1px; background: currentColor; display: block; content: ""; transition: .2s;
}
.menu-lines::before { transform: translateY(-5px); }
.menu-lines::after { transform: translateY(4px); }
.mobile-menu { display: none; }

.node-card { margin: 18px 16px 8px; padding: 14px; border: 1px solid var(--line); border-radius: var(--radius-sm); background: linear-gradient(145deg, rgba(66, 232, 216, .055), rgba(255,255,255,.015)); position: relative; overflow: hidden; }
.node-card::before { content: ""; position: absolute; width: 80px; height: 80px; right: -30px; top: -40px; border: 1px solid rgba(66, 232, 216, .2); transform: rotate(45deg); }
.node-card__head { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 9px; }
.status-dot { width: 7px; height: 7px; border-radius: 50%; display: inline-block; flex: 0 0 auto; }
.status-dot.online { background: var(--green); box-shadow: 0 0 12px rgba(110, 242, 163, .8); }
.status-dot.warn { background: var(--amber); box-shadow: 0 0 12px rgba(242, 184, 91, .8); }
.status-dot.bad { background: var(--red); box-shadow: 0 0 12px rgba(255, 93, 115, .8); }
.node-card__head strong { display: block; font-size: 12px; letter-spacing: .11em; }
.node-card__head small { display: block; margin-top: 3px; color: var(--green); font-size: 8px; letter-spacing: .12em; }
.level-badge { font: 700 9px/1 Consolas, monospace; color: var(--cyan); border: 1px solid rgba(66, 232, 216, .25); background: rgba(66, 232, 216, .08); padding: 6px 7px; border-radius: 5px; }
.node-card__ip { margin-top: 12px; display: flex; align-items: center; gap: 7px; padding-top: 10px; border-top: 1px solid var(--line); color: var(--muted); font-size: 10px; }
.node-card__ip code { color: var(--muted-2); font-size: 11px; flex: 1; }
.tiny-btn { border: 0; background: transparent; color: var(--muted); cursor: pointer; padding: 1px 4px; }
.tiny-btn:hover { color: var(--cyan); }

.nav-scroll { flex: 1; overflow-y: auto; padding: 3px 12px 18px; }
.nav-section { margin-top: 17px; }
.nav-label { display: block; padding: 0 10px 8px; color: #4f5f6c; font-size: 8px; letter-spacing: .19em; text-transform: uppercase; font-weight: 800; }
.nav-item { min-height: 41px; display: flex; align-items: center; gap: 11px; padding: 0 10px; margin: 2px 0; color: #8494a1; border: 1px solid transparent; border-radius: 9px; position: relative; transition: .18s ease; overflow: hidden; }
.nav-item::before { content: ""; position: absolute; left: 0; top: 50%; width: 2px; height: 0; transform: translateY(-50%); background: var(--cyan); box-shadow: 0 0 10px var(--cyan); transition: height .2s var(--ease); }
.nav-item:hover { color: #cbd7df; background: rgba(255,255,255,.025); }
.nav-item.active { color: #ecfbfa; border-color: rgba(66, 232, 216, .11); background: linear-gradient(90deg, rgba(66, 232, 216, .105), rgba(66, 232, 216, .025)); }
.nav-item.active::before { height: 22px; }
.nav-icon { width: 19px; text-align: center; color: #667c8d; font-size: 14px; transition: .18s; }
.nav-item.active .nav-icon, .nav-item:hover .nav-icon { color: var(--cyan); text-shadow: 0 0 12px rgba(66, 232, 216, .28); }
.nav-text { flex: 1; white-space: nowrap; font-size: 12px; }
.nav-count, .nav-kbd { flex: 0 0 auto; min-width: 19px; height: 18px; display: inline-grid; place-items: center; padding: 0 5px; border-radius: 5px; background: rgba(255,255,255,.045); color: #728594; font: 700 8px/1 Consolas, monospace; }
.live-count { color: var(--cyan); background: rgba(66,232,216,.09); }
.danger-count { color: var(--red); background: rgba(255,93,115,.1); }
.nav-pulse { width: 6px; height: 6px; background: var(--red); border-radius: 50%; box-shadow: 0 0 0 0 rgba(255,93,115,.45); animation: pulseRing 1.7s infinite; }

.sidebar-footer { padding: 12px; border-top: 1px solid var(--line); }
.xp-line { padding: 8px 10px 12px; }
.xp-line > div:first-child { display: flex; justify-content: space-between; gap: 8px; font-size: 9px; color: var(--muted); }
.xp-line strong { color: #8ea0ad; font-size: 8px; font-family: Consolas, monospace; }
.meter, .mini-meter { height: 3px; background: rgba(255,255,255,.06); overflow: hidden; border-radius: 999px; }
.meter { margin-top: 7px; }
.meter span, .mini-meter span { height: 100%; display: block; background: linear-gradient(90deg, var(--cyan-2), var(--cyan)); box-shadow: 0 0 8px rgba(66,232,216,.45); border-radius: inherit; transition: width .5s var(--ease); }
.footer-nav { margin: 0; }

.main-frame { min-width: 0; display: grid; grid-template-rows: var(--topbar-h) 64px minmax(0,1fr); height: 100vh; }
.topbar { display: flex; align-items: center; gap: 24px; padding: 0 24px; background: rgba(8,12,18,.78); border-bottom: 1px solid var(--line); backdrop-filter: blur(18px); z-index: 15; }
.topbar-left { display: flex; align-items: center; min-width: 200px; }
.breadcrumb { display: flex; align-items: center; gap: 9px; color: #52636f; font: 700 9px/1 Consolas, monospace; letter-spacing: .09em; }
.breadcrumb i { font-style: normal; color: #35434e; }
.breadcrumb strong { color: #a7b6c0; }
.global-search { margin: 0 auto; width: min(520px, 42vw); height: 40px; display: flex; align-items: center; gap: 10px; padding: 0 10px 0 13px; border: 1px solid var(--line); border-radius: 10px; background: rgba(255,255,255,.02); position: relative; transition: .2s; }
.global-search:focus-within { border-color: rgba(66,232,216,.32); box-shadow: 0 0 0 3px rgba(66,232,216,.05), inset 0 0 30px rgba(66,232,216,.02); }
.global-search > span { color: #607484; font-size: 16px; }
.global-search input { flex: 1; min-width: 0; color: #dfe9ee; background: transparent; border: 0; outline: 0; font-size: 11px; }
.global-search input::placeholder { color: #52616d; }
kbd { color: #61717d; background: rgba(255,255,255,.045); border: 1px solid rgba(255,255,255,.055); border-bottom-color: rgba(255,255,255,.1); padding: 4px 6px; border-radius: 5px; font: 700 8px/1 Consolas, monospace; }
.search-results { position: absolute; top: calc(100% + 8px); left: 0; right: 0; max-height: 390px; overflow: auto; padding: 7px; border: 1px solid var(--line-strong); border-radius: 12px; background: rgba(10,15,22,.98); box-shadow: var(--shadow); z-index: 50; }
.search-result { width: 100%; border: 0; background: transparent; color: #b9c6ce; display: grid; grid-template-columns: 35px 1fr auto; gap: 10px; align-items: center; padding: 10px; border-radius: 8px; cursor: pointer; text-align: left; }
.search-result:hover { background: rgba(66,232,216,.07); color: #fff; }
.search-result .sr-icon { width: 31px; height: 31px; border: 1px solid var(--line); border-radius: 7px; display: grid; place-items: center; color: var(--cyan); }
.search-result strong { display: block; font-size: 11px; }
.search-result small { color: var(--muted); display: block; margin-top: 3px; font-size: 9px; }

.topbar-right { display: flex; align-items: center; gap: 10px; }
.wallet-chip { height: 40px; display: flex; align-items: center; gap: 7px; padding: 0 12px; border: 1px solid var(--line); border-radius: 10px; background: rgba(255,255,255,.02); }
.wallet-chip > span { color: var(--cyan); }
.wallet-chip strong { font: 700 11px Consolas, monospace; letter-spacing: .03em; }
.wallet-chip small { color: #60717e; font-size: 8px; }
.activity-btn { position: relative; font-size: 16px; }
.activity-btn i { position: absolute; top: -4px; right: -4px; min-width: 17px; height: 17px; padding: 0 4px; display: grid; place-items: center; border: 2px solid #080c12; border-radius: 999px; background: var(--red); color: #fff; font: 800 8px/1 sans-serif; }
.profile-chip { height: 44px; display: flex; align-items: center; gap: 10px; background: transparent; border: 0; padding: 0 2px 0 5px; cursor: pointer; }
.avatar { width: 34px; height: 34px; display: grid; place-items: center; border: 1px solid rgba(66,232,216,.26); background: linear-gradient(145deg, rgba(66,232,216,.15), rgba(121,167,255,.08)); color: #d7fffb; border-radius: 8px; font: 800 10px Consolas, monospace; }
.profile-copy { text-align: left; min-width: 90px; }
.profile-copy strong { display: block; font-size: 11px; }
.profile-copy small { color: #657886; font-size: 8px; display: block; margin-top: 3px; }
.chev { color: #5a6a76; }

.system-strip { display: grid; grid-template-columns: 1fr 1fr 1.12fr 1.55fr .72fr; min-width: 0; border-bottom: 1px solid var(--line); background: rgba(9,14,20,.65); }
.strip-node { min-width: 0; display: flex; align-items: center; gap: 10px; padding: 0 16px; border-right: 1px solid var(--line); position: relative; }
.strip-icon { width: 30px; height: 30px; flex: 0 0 auto; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 7px; color: #617684; background: rgba(255,255,255,.018); font: 800 7px Consolas, monospace; }
.strip-icon.cpu { color: var(--cyan); border-color: rgba(66,232,216,.18); }
.strip-icon.gpu { color: var(--violet); border-color: rgba(157,140,255,.18); }
.strip-icon.ram { color: var(--blue); border-color: rgba(121,167,255,.18); }
.strip-icon.net { color: var(--green); border-color: rgba(110,242,163,.18); }
.strip-node small { color: #556673; font-size: 7px; letter-spacing: .12em; display: block; }
.strip-node strong { margin-top: 3px; display: block; font: 700 11px Consolas, monospace; white-space: nowrap; }
.strip-node strong em, .upload-stat em { font-style: normal; }
.strip-node .mini-meter { flex: 1; min-width: 35px; }
.wide-strip .traffic-spark { width: 76px; height: 28px; display: flex; align-items: end; gap: 2px; }
.traffic-spark i { flex: 1; min-width: 2px; border-radius: 1px 1px 0 0; background: rgba(110,242,163,.45); transition: height .35s ease; }
.upload-stat { color: #617783; font: 700 9px Consolas, monospace; white-space: nowrap; }
.temp-node { border-right: 0; }

.page-stage { min-height: 0; overflow: auto; position: relative; }
.page-content { min-height: 100%; padding: 23px 24px 40px; animation: pageIn .35s var(--ease); }
.route-progress { position: sticky; top: 0; left: 0; width: 0; height: 2px; background: linear-gradient(90deg, var(--cyan), var(--blue)); box-shadow: 0 0 14px rgba(66,232,216,.8); z-index: 50; opacity: 0; }
.route-progress.loading { animation: routeLoad .7s var(--ease) forwards; opacity: 1; }

.page-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; margin-bottom: 20px; }
.page-title small { display: block; color: var(--cyan); font: 700 8px Consolas, monospace; letter-spacing: .18em; text-transform: uppercase; margin-bottom: 8px; }
.page-title h1 { margin: 0; font-size: clamp(22px, 2.2vw, 31px); line-height: 1; letter-spacing: -.035em; font-weight: 650; }
.page-title p { max-width: 720px; margin: 9px 0 0; color: #71828f; font-size: 11px; line-height: 1.65; }
.page-actions { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }

.btn { min-height: 38px; border: 1px solid var(--line-strong); background: rgba(255,255,255,.025); color: #aebcc5; border-radius: 9px; padding: 0 13px; display: inline-flex; align-items: center; justify-content: center; gap: 8px; cursor: pointer; font-size: 10px; font-weight: 700; letter-spacing: .03em; transition: .18s ease; }
.btn:hover { transform: translateY(-1px); border-color: rgba(66,232,216,.32); color: #fff; background: rgba(66,232,216,.055); }
.btn.primary { color: #05100f; border-color: var(--cyan); background: var(--cyan); box-shadow: 0 8px 25px rgba(66,232,216,.14); }
.btn.primary:hover { background: #71f4e8; }
.btn.danger { color: #ffc7cf; border-color: rgba(255,93,115,.25); background: rgba(255,93,115,.06); }
.btn.ghost { background: transparent; }
.btn.small { min-height: 31px; padding: 0 10px; font-size: 9px; }
.btn .dot { width: 5px; height: 5px; border-radius: 50%; background: currentColor; }

.dashboard-grid { display: grid; grid-template-columns: minmax(0, 1.58fr) minmax(290px, .72fr); gap: 16px; }
.stack { display: grid; gap: 16px; min-width: 0; align-content: start; }
.grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 16px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 13px; }

.panel { min-width: 0; border: 1px solid var(--line); border-radius: var(--radius); background: linear-gradient(145deg, rgba(16,24,34,.86), rgba(10,15,22,.8)); box-shadow: inset 0 1px rgba(255,255,255,.015); position: relative; overflow: hidden; }
.panel::after { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, rgba(119,156,178,.14), transparent); pointer-events: none; }
.panel-head { min-height: 54px; display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 0 16px; border-bottom: 1px solid var(--line); }
.panel-head h2, .panel-head h3 { margin: 0; font-size: 11px; letter-spacing: .035em; }
.panel-head-left { display: flex; align-items: center; gap: 9px; }
.panel-kicker { color: #526571; font: 700 8px Consolas, monospace; letter-spacing: .11em; }
.panel-body { padding: 16px; }
.panel-menu { color: #5e707d; background: transparent; border: 0; cursor: pointer; letter-spacing: .15em; }

.hero-machine { min-height: 390px; display: grid; grid-template-columns: minmax(260px, .82fr) minmax(360px, 1.18fr); }
.machine-summary { padding: 25px; border-right: 1px solid var(--line); display: flex; flex-direction: column; justify-content: space-between; }
.machine-id { display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; }
.machine-id h2 { margin: 0; font-size: 23px; letter-spacing: -.02em; }
.machine-id p { color: #617480; font-size: 10px; margin: 6px 0 0; }
.machine-score { width: 72px; height: 72px; border-radius: 50%; display: grid; place-items: center; position: relative; background: conic-gradient(var(--cyan) 0 86%, rgba(255,255,255,.06) 86%); box-shadow: 0 0 30px rgba(66,232,216,.07); }
.machine-score::before { content: ""; position: absolute; inset: 5px; border-radius: inherit; background: #0d141d; }
.machine-score span { position: relative; text-align: center; font: 800 16px Consolas, monospace; }
.machine-score small { display: block; color: #667886; font-size: 6px; letter-spacing: .1em; }

.machine-visual { height: 165px; display: grid; place-items: center; position: relative; }
.case-model { width: 210px; height: 128px; position: relative; border: 1px solid rgba(116,151,174,.28); border-radius: 10px; background: linear-gradient(140deg, rgba(72,96,116,.08), rgba(7,11,16,.5)); box-shadow: inset 0 0 35px rgba(66,232,216,.02), 0 22px 40px rgba(0,0,0,.32); transform: perspective(600px) rotateX(2deg) rotateY(-9deg); }
.case-model::before { content: ""; position: absolute; left: 17px; top: 14px; width: 64%; height: 72%; border: 1px solid rgba(66,232,216,.16); background: linear-gradient(135deg, rgba(66,232,216,.04), transparent 60%); }
.case-model::after { content: ""; position: absolute; right: 13px; top: 13px; width: 35px; bottom: 13px; border-left: 1px solid var(--line); background: repeating-linear-gradient(90deg, transparent 0 5px, rgba(255,255,255,.035) 6px); }
.case-glow { position: absolute; inset: 0; background: radial-gradient(circle at 45% 55%, rgba(66,232,216,.15), transparent 33%); animation: casePulse 3.5s infinite alternate ease-in-out; }
.case-board { position: absolute; left: 33px; top: 35px; width: 92px; height: 56px; border: 1px solid rgba(121,167,255,.18); }
.case-board::before, .case-board::after { content: ""; position: absolute; background: rgba(66,232,216,.38); box-shadow: 0 0 8px rgba(66,232,216,.4); }
.case-board::before { width: 30px; height: 18px; left: 9px; top: 9px; }
.case-board::after { width: 35px; height: 3px; right: 8px; bottom: 9px; }
.case-gpu { position: absolute; left: 38px; bottom: 20px; width: 113px; height: 19px; border: 1px solid rgba(157,140,255,.28); background: rgba(157,140,255,.07); }
.case-fan { position: absolute; right: 24px; bottom: 26px; width: 34px; height: 34px; border: 1px solid rgba(110,242,163,.18); border-radius: 50%; animation: spin 5s linear infinite; }
.case-fan::before, .case-fan::after { content: ""; position: absolute; left: 50%; top: 3px; width: 2px; height: 26px; background: rgba(110,242,163,.2); transform-origin: 50% 14px; }
.case-fan::after { transform: rotate(90deg); }

.machine-core-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; }
.core-stat { padding: 10px; border: 1px solid var(--line); border-radius: 8px; background: rgba(255,255,255,.015); }
.core-stat small { color: #566975; display: block; font-size: 7px; letter-spacing: .1em; }
.core-stat strong { display: block; margin-top: 5px; font: 700 10px Consolas, monospace; }

.machine-parts { padding: 14px; display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 8px; align-content: center; position: relative; }
.machine-parts::before { content: ""; position: absolute; inset: 15%; background: radial-gradient(circle, rgba(66,232,216,.045), transparent 58%); pointer-events: none; }
.part-card { min-height: 80px; border: 1px solid var(--line); background: rgba(255,255,255,.014); border-radius: 9px; padding: 11px; display: grid; grid-template-columns: 35px 1fr auto; gap: 9px; align-items: center; cursor: pointer; position: relative; transition: .2s var(--ease); overflow: hidden; }
.part-card::before { content: ""; position: absolute; left: 0; bottom: 0; height: 1px; width: var(--load,0%); background: var(--accent,var(--cyan)); box-shadow: 0 0 9px var(--accent,var(--cyan)); }
.part-card:hover { transform: translateY(-2px); border-color: rgba(66,232,216,.28); background: rgba(66,232,216,.028); }
.part-icon { width: 34px; height: 34px; display: grid; place-items: center; border-radius: 7px; border: 1px solid rgba(66,232,216,.14); background: rgba(66,232,216,.04); color: var(--accent,var(--cyan)); font: 800 8px Consolas, monospace; }
.part-copy { min-width: 0; }
.part-copy small { color: #526671; font-size: 7px; letter-spacing: .09em; display: block; }
.part-copy strong { display: block; margin-top: 4px; font-size: 10px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.part-copy em { display: block; margin-top: 3px; color: #6c808d; font: 400 8px Consolas, monospace; font-style: normal; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.part-load { color: #81939e; font: 700 9px Consolas, monospace; }

.stat-card { padding: 15px; min-height: 112px; }
.stat-card__top { display: flex; justify-content: space-between; gap: 10px; align-items: center; }
.stat-card__icon { width: 30px; height: 30px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 7px; color: var(--cyan); background: rgba(66,232,216,.035); }
.stat-card__trend { font: 700 8px Consolas, monospace; color: var(--green); }
.stat-card__trend.down { color: var(--red); }
.stat-card strong.big { display: block; margin-top: 16px; font: 800 19px Consolas, monospace; letter-spacing: -.03em; }
.stat-card p { margin: 5px 0 0; color: #5e717d; font-size: 9px; }

.net-panel { min-height: 248px; }
.chart-toolbar { display: flex; gap: 4px; }
.chart-toolbar button { border: 0; background: transparent; color: #586b78; font: 700 8px Consolas, monospace; padding: 6px 8px; border-radius: 5px; cursor: pointer; }
.chart-toolbar button.active { color: var(--cyan); background: rgba(66,232,216,.08); }
.net-chart-wrap { height: 177px; padding: 7px 12px 0; position: relative; }
.net-chart-wrap canvas { width: 100%; height: 100%; display: block; }
.chart-values { position: absolute; top: 14px; left: 18px; display: flex; gap: 16px; }
.chart-values small { display: block; color: #586b78; font-size: 7px; }
.chart-values strong { font: 800 10px Consolas, monospace; }
.chart-values .down strong { color: var(--cyan); }
.chart-values .up strong { color: var(--violet); }

.activity-list { padding: 6px 0; }
.activity-row { display: grid; grid-template-columns: 31px 1fr auto; gap: 10px; align-items: center; padding: 10px 14px; position: relative; }
.activity-row + .activity-row { border-top: 1px solid rgba(145,177,204,.07); }
.activity-row::before { content: ""; position: absolute; left: 29px; top: 0; bottom: 0; width: 1px; background: rgba(145,177,204,.06); z-index: 0; }
.activity-dot { width: 24px; height: 24px; z-index: 1; border: 1px solid var(--line); background: #0e151e; border-radius: 50%; display: grid; place-items: center; font-size: 8px; color: var(--cyan); }
.activity-copy { min-width: 0; }
.activity-copy strong { display: block; font-size: 9px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.activity-copy small { display: block; margin-top: 3px; color: #5d707d; font: 400 8px Consolas, monospace; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.activity-time { color: #4f606d; font: 700 7px Consolas, monospace; }

.threat-panel { background: linear-gradient(150deg, rgba(39,18,24,.55), rgba(14,18,26,.9)); }
.threat-summary { display: grid; grid-template-columns: 84px 1fr; gap: 16px; align-items: center; }
.radar { width: 82px; height: 82px; border: 1px solid rgba(255,93,115,.14); border-radius: 50%; position: relative; overflow: hidden; background: repeating-radial-gradient(circle, rgba(255,93,115,.09) 0 1px, transparent 1px 16px); }
.radar::before, .radar::after { content: ""; position: absolute; background: rgba(255,93,115,.12); }
.radar::before { left: 50%; top: 0; bottom: 0; width: 1px; }
.radar::after { top: 50%; left: 0; right: 0; height: 1px; }
.radar-sweep { position: absolute; inset: 0; border-radius: 50%; background: conic-gradient(from 0deg, rgba(255,93,115,.26), transparent 20%); animation: spin 4s linear infinite; }
.radar-blip { position: absolute; width: 4px; height: 4px; border-radius: 50%; background: var(--red); box-shadow: 0 0 9px var(--red); }
.radar-blip.b1 { top: 25%; left: 61%; }
.radar-blip.b2 { top: 62%; left: 32%; animation: blink 1.2s infinite; }
.threat-copy small { color: #6f5e64; font-size: 8px; letter-spacing: .1em; }
.threat-copy strong { display: block; margin: 6px 0 7px; font-size: 17px; }
.threat-copy p { margin: 0; color: #83717a; font-size: 9px; line-height: 1.6; }

.quick-actions { display: grid; grid-template-columns: repeat(2,1fr); gap: 8px; padding: 12px; }
.quick-action { min-height: 73px; border: 1px solid var(--line); background: rgba(255,255,255,.015); border-radius: 9px; padding: 10px; cursor: pointer; text-align: left; transition: .18s; }
.quick-action:hover { border-color: rgba(66,232,216,.26); transform: translateY(-2px); background: rgba(66,232,216,.035); }
.quick-action span { color: var(--cyan); font-size: 15px; }
.quick-action strong { display: block; margin-top: 8px; font-size: 9px; }
.quick-action small { display: block; margin-top: 3px; color: #596c78; font-size: 8px; }

.table-wrap { overflow: auto; }
.data-table { width: 100%; border-collapse: collapse; min-width: 720px; }
.data-table th { color: #526572; font-size: 7px; letter-spacing: .12em; text-transform: uppercase; text-align: left; padding: 11px 14px; border-bottom: 1px solid var(--line); background: rgba(255,255,255,.01); white-space: nowrap; }
.data-table td { padding: 12px 14px; border-bottom: 1px solid rgba(145,177,204,.07); color: #9babb5; font-size: 9px; white-space: nowrap; }
.data-table tr { transition: .16s; }
.data-table tbody tr:hover { background: rgba(66,232,216,.025); }
.data-table td strong { color: #d4dfe5; font-size: 10px; }
.badge { display: inline-flex; align-items: center; gap: 5px; min-height: 21px; padding: 0 7px; border: 1px solid var(--line); border-radius: 5px; color: #7e909d; background: rgba(255,255,255,.02); font: 700 7px Consolas, monospace; }
.badge.good { color: var(--green); border-color: rgba(110,242,163,.16); background: rgba(110,242,163,.05); }
.badge.warn { color: var(--amber); border-color: rgba(242,184,91,.16); background: rgba(242,184,91,.05); }
.badge.bad { color: var(--red); border-color: rgba(255,93,115,.16); background: rgba(255,93,115,.05); }
.badge.info { color: var(--cyan); border-color: rgba(66,232,216,.16); background: rgba(66,232,216,.05); }

.catalog-toolbar { display: grid; grid-template-columns: 1fr auto auto; gap: 8px; margin-bottom: 14px; }
.input, .select { height: 38px; border: 1px solid var(--line); border-radius: 8px; background: rgba(255,255,255,.018); color: #b7c4cc; outline: 0; padding: 0 11px; font-size: 10px; }
.input:focus, .select:focus { border-color: rgba(66,232,216,.28); }
.select { color-scheme: dark; min-width: 140px; }
.catalog-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(235px,1fr)); gap: 12px; }
.product-card { min-height: 235px; padding: 14px; border: 1px solid var(--line); border-radius: 12px; background: linear-gradient(145deg, rgba(255,255,255,.022), rgba(255,255,255,.008)); position: relative; overflow: hidden; transition: .22s var(--ease); }
.product-card:hover { transform: translateY(-4px); border-color: rgba(66,232,216,.25); box-shadow: 0 14px 40px rgba(0,0,0,.18); }
.product-card::before { content: ""; position: absolute; width: 130px; height: 130px; right: -65px; top: -65px; border-radius: 50%; background: radial-gradient(circle, rgba(66,232,216,.09), transparent 65%); }
.product-type { display: flex; justify-content: space-between; align-items: center; }
.product-type span { color: #576b78; font: 700 7px Consolas, monospace; letter-spacing: .12em; }
.product-rarity { width: 7px; height: 7px; border-radius: 50%; background: var(--cyan); box-shadow: 0 0 10px rgba(66,232,216,.45); }
.product-visual { height: 70px; display: grid; place-items: center; color: var(--cyan); font: 800 22px Consolas, monospace; opacity: .7; }
.product-card h3 { margin: 2px 0 4px; font-size: 12px; }
.product-card > p { color: #657783; margin: 0; font-size: 8px; min-height: 28px; line-height: 1.5; }
.product-specs { display: grid; grid-template-columns: repeat(2,1fr); gap: 6px; margin-top: 12px; }
.product-specs div { padding: 7px; background: rgba(255,255,255,.018); border: 1px solid rgba(145,177,204,.07); border-radius: 6px; }
.product-specs small { color: #4f626e; display: block; font-size: 6px; }
.product-specs strong { display: block; margin-top: 3px; color: #aab8c0; font: 700 8px Consolas, monospace; }
.product-foot { margin-top: 13px; padding-top: 11px; border-top: 1px solid var(--line); display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.product-price { font: 800 11px Consolas, monospace; color: #dce8ed; }

.scanner-layout { display: grid; grid-template-columns: minmax(320px,.72fr) minmax(0,1.28fr); gap: 16px; }
.scanner-console { min-height: 580px; }
.scan-target { padding: 18px; border-bottom: 1px solid var(--line); }
.scan-target label { display: block; color: #596c78; font-size: 8px; letter-spacing: .1em; margin-bottom: 7px; }
.target-row { display: flex; gap: 8px; }
.target-row input { flex: 1; min-width: 0; }
.scan-screen { height: 260px; position: relative; display: grid; place-items: center; overflow: hidden; background: radial-gradient(circle at center, rgba(66,232,216,.035), transparent 50%); }
.scan-rings { width: 210px; height: 210px; border: 1px solid rgba(66,232,216,.14); border-radius: 50%; position: relative; background: repeating-radial-gradient(circle, transparent 0 27px, rgba(66,232,216,.07) 28px 29px); }
.scan-rings::before, .scan-rings::after { content: ""; position: absolute; background: rgba(66,232,216,.09); }
.scan-rings::before { left: 50%; top: 0; width: 1px; height: 100%; }
.scan-rings::after { top: 50%; left: 0; height: 1px; width: 100%; }
.scan-sweep { position: absolute; inset: 0; border-radius: 50%; background: conic-gradient(rgba(66,232,216,.2), transparent 23%); animation: spin 2.2s linear infinite; transform-origin: center; opacity: 0; }
.scanning .scan-sweep { opacity: 1; }
.scan-center { position: absolute; left: 50%; top: 50%; width: 7px; height: 7px; transform: translate(-50%,-50%); border-radius: 50%; background: var(--cyan); box-shadow: 0 0 16px var(--cyan); }
.scan-progress { padding: 0 18px 18px; }
.progress-info { display: flex; justify-content: space-between; color: #61727e; font: 700 8px Consolas, monospace; margin-bottom: 7px; }
.progress-bar { height: 5px; background: rgba(255,255,255,.05); overflow: hidden; border-radius: 999px; }
.progress-bar span { display: block; width: 0; height: 100%; background: linear-gradient(90deg,var(--cyan-2),var(--cyan)); box-shadow: 0 0 10px rgba(66,232,216,.45); transition: width .18s linear; }
.terminal { background: #070b10; border: 1px solid var(--line); border-radius: 10px; overflow: hidden; }
.terminal-head { height: 36px; padding: 0 12px; display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--line); }
.terminal-dots { display: flex; gap: 5px; }
.terminal-dots i { width: 6px; height: 6px; border-radius: 50%; background: #3c4b55; }
.terminal-body { min-height: 370px; max-height: 520px; overflow: auto; padding: 13px; color: #7e929f; font: 400 9px/1.75 Consolas, monospace; }
.terminal-line { display: flex; gap: 8px; animation: terminalIn .18s ease; }
.terminal-line .time { color: #40515c; }
.terminal-line .ok { color: var(--green); }
.terminal-line .warn { color: var(--amber); }
.terminal-line .bad { color: var(--red); }
.terminal-line .info { color: var(--cyan); }

.process-list { display: grid; gap: 8px; }
.process-card { display: grid; grid-template-columns: 40px minmax(150px,1fr) 110px 110px 90px auto; gap: 12px; align-items: center; padding: 12px; border: 1px solid var(--line); background: rgba(255,255,255,.012); border-radius: 9px; }
.process-icon { width: 38px; height: 38px; border: 1px solid var(--line); border-radius: 7px; display: grid; place-items: center; color: var(--cyan); font: 800 8px Consolas, monospace; }
.process-name strong { display: block; font-size: 10px; }
.process-name small { display: block; margin-top: 3px; color: #566975; font: 400 8px Consolas, monospace; }
.process-metric small { display: block; color: #50626f; font-size: 7px; margin-bottom: 5px; }
.process-metric strong { font: 700 9px Consolas, monospace; }

.storage-map { display: grid; grid-template-columns: repeat(12,1fr); gap: 4px; min-height: 140px; }
.storage-block { min-width: 10px; border-radius: 4px; background: rgba(66,232,216,.14); border: 1px solid rgba(66,232,216,.12); transition: .15s; }
.storage-block:hover { background: rgba(66,232,216,.27); transform: translateY(-2px); }
.storage-block.used { background: rgba(121,167,255,.17); border-color: rgba(121,167,255,.15); }
.storage-block.system { background: rgba(157,140,255,.18); border-color: rgba(157,140,255,.17); }
.storage-block.danger { background: rgba(255,93,115,.2); border-color: rgba(255,93,115,.19); }

.skeleton { position: relative; overflow: hidden; background: rgba(255,255,255,.03); border-radius: 7px; }
.skeleton::after { content: ""; position: absolute; inset: 0; transform: translateX(-100%); background: linear-gradient(90deg, transparent, rgba(255,255,255,.04), transparent); animation: shimmer 1.25s infinite; }
.skeleton-page { display: grid; gap: 16px; }
.skeleton-line { height: 16px; width: 40%; }
.skeleton-hero { height: 360px; }
.skeleton-cards { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; }
.skeleton-cards .skeleton { height: 110px; }

.empty-state { min-height: 360px; display: grid; place-items: center; text-align: center; padding: 40px; }
.empty-state__icon { width: 76px; height: 76px; margin: 0 auto 18px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 50%; color: var(--cyan); font-size: 26px; background: radial-gradient(circle, rgba(66,232,216,.08), transparent 65%); }
.empty-state h2 { margin: 0; }
.empty-state p { color: #667985; max-width: 500px; line-height: 1.7; }

.command-palette[hidden] { display: none; }
.command-palette { position: fixed; inset: 0; z-index: 2000; display: grid; place-items: start center; padding-top: 12vh; }
.palette-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.66); backdrop-filter: blur(8px); }
.palette-panel { width: min(650px, calc(100vw - 30px)); max-height: 70vh; position: relative; border: 1px solid var(--line-strong); border-radius: 14px; overflow: hidden; background: rgba(10,15,22,.98); box-shadow: 0 35px 100px rgba(0,0,0,.65); animation: paletteIn .22s var(--ease); }
.palette-input-wrap { height: 58px; display: flex; align-items: center; gap: 11px; padding: 0 14px; border-bottom: 1px solid var(--line); }
.palette-input-wrap > span { color: var(--cyan); }
.palette-input-wrap input { flex: 1; min-width: 0; border: 0; outline: 0; background: transparent; color: #e1edf1; font-size: 12px; }
.palette-body { max-height: calc(70vh - 93px); overflow: auto; padding: 8px; }
.palette-group-title { padding: 9px 10px 6px; color: #4d606c; font-size: 7px; letter-spacing: .15em; }
.palette-item { width: 100%; border: 0; background: transparent; color: #aab8c1; display: grid; grid-template-columns: 36px 1fr auto; gap: 10px; align-items: center; padding: 10px; border-radius: 8px; text-align: left; cursor: pointer; }
.palette-item:hover, .palette-item.active { background: rgba(66,232,216,.07); color: #fff; }
.palette-item .pi-icon { width: 32px; height: 32px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 7px; color: var(--cyan); }
.palette-item strong { display: block; font-size: 10px; }
.palette-item small { display: block; color: #596c78; margin-top: 3px; font-size: 8px; }
.palette-footer { height: 35px; display: flex; align-items: center; gap: 16px; padding: 0 12px; border-top: 1px solid var(--line); color: #4e616e; font-size: 7px; }

.drawer { position: fixed; z-index: 1600; top: 0; right: 0; width: min(390px,100vw); height: 100vh; transform: translateX(105%); transition: transform .3s var(--ease); border-left: 1px solid var(--line-strong); background: rgba(9,14,20,.98); box-shadow: -25px 0 80px rgba(0,0,0,.35); }
.drawer.open { transform: translateX(0); }
.drawer-overlay { position: fixed; z-index: 1500; inset: 0; background: rgba(0,0,0,.42); backdrop-filter: blur(2px); }
.drawer-head { height: 74px; padding: 0 16px 0 19px; display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--line); }
.drawer-head small { color: var(--cyan); font: 700 7px Consolas, monospace; letter-spacing: .14em; }
.drawer-head h3 { margin: 4px 0 0; font-size: 16px; }
.drawer-tabs { height: 48px; display: flex; padding: 6px 12px; gap: 4px; border-bottom: 1px solid var(--line); }
.drawer-tabs button { flex: 1; border: 0; border-radius: 7px; background: transparent; color: #5f717d; font-size: 8px; cursor: pointer; }
.drawer-tabs button.active { background: rgba(66,232,216,.07); color: var(--cyan); }
.drawer-feed { height: calc(100vh - 122px); overflow: auto; padding: 6px 0; }

.modal-root { position: fixed; z-index: 3000; inset: 0; pointer-events: none; }
.modal-root.active { pointer-events: auto; }
.modal-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.7); backdrop-filter: blur(8px); animation: fadeIn .18s ease; }
.modal { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); width: min(650px,calc(100vw - 30px)); max-height: calc(100vh - 40px); overflow: auto; border: 1px solid var(--line-strong); border-radius: 14px; background: #0b1119; box-shadow: 0 35px 100px rgba(0,0,0,.7); animation: modalIn .25s var(--ease); }
.modal-head { min-height: 58px; display: flex; align-items: center; justify-content: space-between; padding: 0 16px; border-bottom: 1px solid var(--line); }
.modal-head h3 { margin: 0; font-size: 13px; }
.modal-body { padding: 17px; }
.modal-foot { padding: 13px 16px; border-top: 1px solid var(--line); display: flex; justify-content: flex-end; gap: 8px; }
.detail-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 8px; }
.detail-item { padding: 11px; border: 1px solid var(--line); border-radius: 8px; }
.detail-item small { color: #536672; font-size: 7px; display: block; }
.detail-item strong { margin-top: 5px; display: block; font: 700 10px Consolas, monospace; }

.toast-stack { position: fixed; right: 18px; bottom: 18px; z-index: 4000; width: min(350px,calc(100vw - 36px)); display: grid; gap: 8px; }
.toast { min-height: 62px; display: grid; grid-template-columns: 31px 1fr auto; align-items: center; gap: 10px; padding: 10px 11px; border: 1px solid var(--line-strong); border-radius: 10px; background: rgba(12,18,26,.98); box-shadow: 0 18px 55px rgba(0,0,0,.38); animation: toastIn .28s var(--ease); }
.toast.leaving { animation: toastOut .24s ease forwards; }
.toast-icon { width: 30px; height: 30px; display: grid; place-items: center; border: 1px solid rgba(66,232,216,.18); border-radius: 7px; color: var(--cyan); background: rgba(66,232,216,.05); }
.toast.error .toast-icon { color: var(--red); border-color: rgba(255,93,115,.18); background: rgba(255,93,115,.05); }
.toast.warn .toast-icon { color: var(--amber); border-color: rgba(242,184,91,.18); background: rgba(242,184,91,.05); }
.toast strong { display: block; font-size: 9px; }
.toast small { color: #60727f; display: block; margin-top: 3px; font-size: 8px; line-height: 1.4; }
.toast-close { border: 0; background: transparent; color: #536572; cursor: pointer; }

body.sidebar-collapsed { --sidebar-w: 76px; }
body.sidebar-collapsed .brand-copy,
body.sidebar-collapsed .node-card,
body.sidebar-collapsed .nav-label,
body.sidebar-collapsed .nav-text,
body.sidebar-collapsed .nav-count,
body.sidebar-collapsed .nav-kbd,
body.sidebar-collapsed .nav-pulse,
body.sidebar-collapsed .xp-line { opacity: 0; visibility: hidden; pointer-events: none; position: absolute; }
body.sidebar-collapsed .brand-wrap { padding: 0; justify-content: center; }
body.sidebar-collapsed .sidebar-toggle { display: none; }
body.sidebar-collapsed .nav-scroll { padding-inline: 10px; }
body.sidebar-collapsed .nav-section { margin-top: 12px; }
body.sidebar-collapsed .nav-item { justify-content: center; padding: 0; }
body.sidebar-collapsed .nav-icon { width: auto; font-size: 16px; }
body.sidebar-collapsed .sidebar-footer { padding: 10px; }
body.sidebar-collapsed .footer-nav { display: flex; }

@keyframes pulseRing { 0% { box-shadow: 0 0 0 0 rgba(255,93,115,.42); } 70% { box-shadow: 0 0 0 7px rgba(255,93,115,0); } 100% { box-shadow: 0 0 0 0 rgba(255,93,115,0); } }
@keyframes casePulse { from { opacity: .45; } to { opacity: 1; } }
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes blink { 50% { opacity: .2; } }
@keyframes pageIn { from { opacity: 0; transform: translateY(7px); } to { opacity: 1; transform: translateY(0); } }
@keyframes routeLoad { 0% { width: 0; } 65% { width: 78%; } 100% { width: 100%; } }
@keyframes terminalIn { from { opacity: 0; transform: translateX(-4px); } to { opacity: 1; transform: translateX(0); } }
@keyframes shimmer { to { transform: translateX(100%); } }
@keyframes paletteIn { from { opacity: 0; transform: translateY(-8px) scale(.985); } to { opacity: 1; transform: none; } }
@keyframes modalIn { from { opacity: 0; transform: translate(-50%,-47%) scale(.985); } to { opacity: 1; transform: translate(-50%,-50%) scale(1); } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes toastIn { from { opacity: 0; transform: translateX(15px) scale(.97); } to { opacity: 1; transform: none; } }
@keyframes toastOut { to { opacity: 0; transform: translateX(15px) scale(.97); } }

@media (max-width: 1280px) {
  :root { --sidebar-w: 248px; }
  .global-search { width: min(420px,34vw); }
  .profile-copy { display: none; }
  .system-strip { grid-template-columns: 1fr 1fr 1fr 1.5fr; }
  .temp-node { display: none; }
  .hero-machine { grid-template-columns: 1fr; }
  .machine-summary { border-right: 0; border-bottom: 1px solid var(--line); }
}

@media (max-width: 980px) {
  .app-shell { grid-template-columns: 1fr; }
  .sidebar { position: fixed; left: 0; top: 0; bottom: 0; width: min(290px,88vw); transform: translateX(-105%); box-shadow: 25px 0 70px rgba(0,0,0,.45); }
  body.mobile-nav-open .sidebar { transform: translateX(0); }
  .mobile-menu { display: inline-grid; margin-right: 10px; }
  .topbar { padding-inline: 14px; gap: 12px; }
  .topbar-left { min-width: auto; }
  .breadcrumb span, .breadcrumb i { display: none; }
  .global-search { flex: 1; width: auto; margin: 0; }
  .wallet-chip { display: none; }
  .system-strip { grid-template-columns: repeat(3,1fr); }
  .wide-strip { display: none; }
  .dashboard-grid, .scanner-layout { grid-template-columns: 1fr; }
  .grid-4 { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 680px) {
  :root { --topbar-h: 62px; }
  .main-frame { grid-template-rows: var(--topbar-h) 53px minmax(0,1fr); }
  .topbar { padding-inline: 10px; }
  .breadcrumb { display: none; }
  .global-search { height: 38px; }
  .global-search kbd { display: none; }
  .profile-chip { display: none; }
  .system-strip { grid-template-columns: repeat(3,1fr); }
  .strip-node { padding-inline: 8px; gap: 6px; }
  .strip-icon { display: none; }
  .strip-node .mini-meter { display: none; }
  .page-content { padding: 16px 12px 30px; }
  .page-head { align-items: flex-start; flex-direction: column; }
  .page-actions { justify-content: flex-start; }
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .hero-machine { min-height: auto; }
  .machine-summary { padding: 17px; }
  .machine-parts { grid-template-columns: 1fr; }
  .machine-core-stats { grid-template-columns: 1fr; }
  .process-card { grid-template-columns: 38px 1fr auto; }
  .process-card .process-metric:nth-of-type(n+2) { display: none; }
  .catalog-toolbar { grid-template-columns: 1fr; }
  .detail-grid { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: .01ms !important; }
}

/* Botnet / mining / AI additions */
.compact-terminal { padding: 14px; color: #8ca0ac; font: 500 10px/1.8 Consolas, monospace; }
.term-ok { color: var(--green); }
.term-info { color: var(--cyan); }
.term-warn { color: var(--amber); }
.muted { color: var(--muted); font-size: 12px; line-height: 1.6; }
.btn.small { padding: 7px 10px; font-size: 9px; min-height: auto; }

/* VPN / end-to-end network limits */
.vpn-lock-panel{display:flex;align-items:center;gap:18px;padding:20px;margin-bottom:16px;border-color:rgba(255,92,118,.28);background:linear-gradient(135deg,rgba(255,92,118,.07),rgba(10,15,22,.72))}
.vpn-lock-panel h3{margin:5px 0 7px}.vpn-lock-panel p{margin:0;color:var(--muted);max-width:760px}
.vpn-lock-mark{width:64px;height:64px;display:grid;place-items:center;border:1px solid rgba(255,92,118,.35);background:rgba(255,92,118,.08);font:700 12px var(--mono);letter-spacing:2px;color:var(--red);clip-path:polygon(14% 0,86% 0,100% 14%,100% 86%,86% 100%,14% 100%,0 86%,0 14%)}
.vpn-control-panel{margin-bottom:16px;overflow:hidden}
.vpn-status-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1px;background:var(--line);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.vpn-ip-card{padding:18px;background:rgba(8,13,19,.92);min-width:0;position:relative}
.vpn-ip-card.connected:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--cyan);box-shadow:0 0 14px rgba(66,232,216,.55)}
.vpn-ip-card small{display:block;color:var(--muted);font:700 8px var(--mono);letter-spacing:1.5px;margin-bottom:8px}
.vpn-ip-card strong{display:block;color:var(--text);font:700 17px var(--mono);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.vpn-ip-card span{display:block;color:var(--muted);font-size:10px;margin-top:7px;line-height:1.45}
.vpn-session-controls{display:flex;flex-wrap:wrap;gap:8px;padding:16px}
.vpn-session-note{margin:0 16px 16px;padding:10px 12px;border:1px solid rgba(66,232,216,.12);background:rgba(66,232,216,.035);color:var(--muted);font:500 9px var(--mono);line-height:1.65}
.vpn-plan-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:16px}
.vpn-plan-card{position:relative;padding:18px;border:1px solid var(--line);background:linear-gradient(155deg,rgba(17,25,35,.94),rgba(8,12,18,.98));box-shadow:0 12px 36px rgba(0,0,0,.16);transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;overflow:hidden}
.vpn-plan-card:hover{transform:translateY(-2px);border-color:rgba(66,232,216,.26);box-shadow:0 16px 44px rgba(0,0,0,.25)}
.vpn-plan-card.selected{border-color:rgba(66,232,216,.46);box-shadow:inset 0 0 0 1px rgba(66,232,216,.08),0 0 28px rgba(66,232,216,.07)}
.vpn-plan-card.selected:after{content:"ACTIVE RENTAL";position:absolute;right:-33px;top:18px;transform:rotate(35deg);padding:4px 34px;background:rgba(66,232,216,.13);color:var(--cyan);font:700 7px var(--mono);letter-spacing:1px}
.vpn-plan-card.locked{opacity:.64}
.vpn-plan-top{display:flex;justify-content:space-between;gap:10px;align-items:center}
.vpn-plan-speed{margin:22px 0 8px;color:var(--cyan);font:800 30px/1 var(--mono);letter-spacing:-1.5px;text-shadow:0 0 22px rgba(66,232,216,.15)}
.vpn-plan-card h3{margin:0 0 7px}.vpn-plan-card p{min-height:34px;margin:0;color:var(--muted);font-size:10px;line-height:1.55}
.vpn-plan-metrics{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:16px 0;padding:12px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.vpn-plan-metrics small{display:block;color:var(--muted);font:700 7px var(--mono);letter-spacing:1px;margin-bottom:5px}.vpn-plan-metrics strong{font:700 11px var(--mono)}
.vpn-plan-foot{display:flex;justify-content:space-between;align-items:center;gap:12px}.vpn-plan-foot>span{color:var(--muted);font-size:9px}.vpn-plan-foot>span strong{color:var(--text);font:800 14px var(--mono)}
.network-limit-panel{overflow:hidden}
.network-limit-chain{display:grid;gap:10px}
.network-limit-row{display:grid;grid-template-columns:150px minmax(100px,1fr) 92px;gap:12px;align-items:center;padding:8px 10px;border:1px solid transparent;transition:border-color .2s ease,background .2s ease}
.network-limit-row>div:first-child{min-width:0}.network-limit-row strong{display:block;font-size:10px}.network-limit-row small{color:var(--muted);font:600 7px var(--mono);letter-spacing:.8px}.network-limit-row b{text-align:right;font:700 10px var(--mono)}
.network-limit-row.is-limit{border-color:rgba(255,182,72,.2);background:rgba(255,182,72,.035)}
.network-limit-row.is-limit b{color:var(--amber)}
.network-effective-result{display:grid;grid-template-columns:1fr auto;gap:5px 18px;align-items:end;margin-top:16px;padding:14px 16px;border:1px solid rgba(66,232,216,.18);background:linear-gradient(90deg,rgba(66,232,216,.05),transparent)}
.network-effective-result span{font:700 8px var(--mono);letter-spacing:1.3px;color:var(--muted)}.network-effective-result strong{grid-row:span 2;color:var(--cyan);font:800 24px var(--mono)}.network-effective-result small{color:var(--muted);font-size:9px}
@media(max-width:1100px){.vpn-status-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.vpn-plan-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:700px){.vpn-status-grid,.vpn-plan-grid{grid-template-columns:1fr}.network-limit-row{grid-template-columns:110px minmax(70px,1fr) 78px;gap:8px}.vpn-session-controls .btn{flex:1 1 calc(50% - 8px)}.network-effective-result{grid-template-columns:1fr}.network-effective-result strong{grid-row:auto;font-size:20px}}
