:root{--bg:#06142e;--panel:#0b2853;--panel2:#0d3266;--line:#3f78b1;--cyan:#20d9ff;--green:#3fffc2;--pink:#ff4e9f;--purple:#b958ff;--orange:#ff9b62;--gold:#ffd66b;--text:#edf8ff;--muted:#8db0cf}
*{box-sizing:border-box}html,body{margin:0;min-width:1180px;min-height:760px;background:#020817;color:var(--text);font-family:"Arial Narrow","Roboto Condensed",Arial,sans-serif}body{background:radial-gradient(circle at 48% 25%,#123f73 0,#061735 43%,#020817 100%);overflow:auto}.scanlines{position:fixed;inset:0;pointer-events:none;z-index:9;opacity:.14;background:repeating-linear-gradient(0deg,transparent 0 3px,#7edbff10 4px)}
.dashboard{width:100vw;min-width:1180px;min-height:100vh;padding:8px}.topbar{height:60px;border-bottom:2px solid var(--cyan);display:flex;align-items:center;justify-content:space-between;padding:0 18px;background:linear-gradient(90deg,#0d2851,#07152d)}.brand{font-size:25px;font-weight:900;letter-spacing:2px;display:flex;align-items:center}.brand-secret{display:flex;border-radius:50%;text-decoration:none}.brand-mark{width:32px;height:32px;border-radius:50%;margin-right:14px;background:repeating-conic-gradient(#84ff80 0 8deg,transparent 8deg 16deg);box-shadow:0 0 18px #6cffba;transition:filter .2s,transform .2s}.brand-secret:hover .brand-mark{filter:brightness(1.35);transform:scale(1.06)}.status-strip{display:flex;align-items:center;gap:24px;text-align:center}.status-strip div{display:flex;flex-direction:column}.status-strip b{font-size:13px}.status-strip small{font-size:9px;color:var(--muted);margin-bottom:3px}.demo-links{display:flex;gap:7px}.demo-links a{display:flex;align-items:center;gap:6px;height:31px;padding:0 11px;border:1px solid #3b78a8;border-radius:5px;background:linear-gradient(135deg,#103d6b,#0b254a);color:#dff8ff;font-size:11px;font-weight:700;text-decoration:none;white-space:nowrap;box-shadow:inset 0 0 10px #19cfff16;transition:border-color .2s,color .2s,box-shadow .2s,transform .2s}.demo-links a span{color:var(--cyan)}.demo-links a:hover{color:#fff;border-color:var(--cyan);box-shadow:0 0 12px #20d9ff55,inset 0 0 12px #20d9ff22;transform:translateY(-1px)}.green{color:var(--green)!important}.gold{color:var(--gold)!important}
.layout{display:grid;grid-template-columns:230px minmax(600px,1fr) 400px;gap:8px;padding-top:8px}.left-col,.right-col,.center-col{display:flex;flex-direction:column;gap:8px}.panel{background:linear-gradient(145deg,#0c2c59eF,#081d40ef);border:1px solid #4b77a9;border-radius:10px;box-shadow:inset 0 0 20px #1f6ba322,0 0 8px #000b}.panel h2{margin:0;color:#eaf7ff;font-size:13px;letter-spacing:.7px}.panel h2:first-letter{color:var(--cyan)}.panel h3{font-size:10px;margin:12px 0 7px;letter-spacing:.5px}.panel small{color:var(--muted)}
.profile{height:150px;padding:14px;text-align:center}.avatar{margin:auto;width:68px;height:68px;border:2px solid var(--cyan);border-radius:50%;display:grid;place-items:center;font-size:34px;box-shadow:0 0 16px #20d9ff77}.online{display:block;width:14px;height:14px;border-radius:50%;background:#4dffac;box-shadow:0 0 10px #4dffac;margin:-15px 0 10px 128px}.wallet{height:38px;border:1px solid #587da4;border-radius:7px;text-align:left;padding:10px;font-weight:bold}.wallet button{float:right;background:none;color:white;border:0}
.watch{padding:12px}.watch h2 span{color:var(--cyan)}.watch-device{text-align:center;padding:13px 0 9px}.watch-icon{margin:auto auto 7px;width:54px;height:54px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(145deg,#0087e9,#20e6ff);font-size:27px;box-shadow:0 0 20px #00bdff88}.metric{margin-top:8px;padding:10px 7px;border:1px solid #315b88;border-radius:7px;font-size:12px}.metric>b{float:right}.metric .line{clear:both;margin-top:13px;height:3px;background:linear-gradient(90deg,#ff719d,#ff9aab);box-shadow:0 0 7px #ff5e88}.bar{clear:both;height:7px;margin-top:9px;background:#284b73;border-radius:5px;overflow:hidden}.bar i{height:100%;display:block;background:linear-gradient(90deg,#10e3f5,#48b8ff);box-shadow:0 0 7px #11dff0}.steps .bar i{width:91%}.mini-grid{display:grid;grid-template-columns:1fr 1fr;margin-top:8px;gap:6px}.mini-grid div{padding:8px;border:1px solid #315b88;border-radius:7px;display:flex;flex-direction:column;font-size:11px}.agent{margin-top:8px;padding:8px;border:1px solid #4b6fa0;border-radius:7px;background:linear-gradient(90deg,#304379,#1b5fa3);font-size:10px}.agent>b{color:#c7ff9f}.agent p{margin:6px 0 0;font-style:italic}.contribution{padding:12px}.contribution>div:not(.reward){position:relative;padding:9px;border:1px solid #315b88;border-radius:6px;margin-top:7px;display:flex;flex-direction:column;font-size:11px}.contribution>div>b{position:absolute;right:8px;color:var(--green)}.contribution strong{font-size:15px;margin-top:3px}.contribution small{font-size:10px}.rewards{margin-top:10px!important}.reward{background:linear-gradient(90deg,#423257,#692751);border-color:#ff7f90!important}.reward strong{color:var(--gold)}
.topology{height:43vh;min-height:330px;padding:10px}.topology h1{text-align:center;font-size:11px;letter-spacing:2px;margin:3px}.graph{height:calc(100% - 20px);position:relative;background-image:radial-gradient(#4380a844 1px,transparent 1px);background-size:12px 12px}.graph svg{width:100%;height:100%}.links path{fill:none;stroke-width:2;stroke-dasharray:5 5;animation:dash 2s linear infinite}.links .pink{stroke:var(--pink)}.links .cyan{stroke:var(--cyan)}.links .green{stroke:var(--green)}.links .purple{stroke:var(--purple)}.links .orange{stroke:var(--orange)}@keyframes dash{to{stroke-dashoffset:-20}}.nodes circle{fill:#0c244c;stroke:currentColor;stroke-width:2}.nodes text{text-anchor:middle;fill:currentColor;font-weight:bold;font-size:12px}.nodes text:first-of-type{font-size:18px}.n-pink{color:var(--pink)}.n-blue{color:#55a8ff}.n-cyan{color:var(--cyan)}.n-green{color:var(--green)}.n-purple{color:var(--purple)}.n-orange{color:var(--orange)}.labels text{fill:#bcefff;font-size:9px;stroke:#0b203e;stroke-width:3;paint-order:stroke}.zoom,.map-zoom{position:absolute;left:8px;bottom:10px;background:#16477a;border:1px solid #5794ca;width:28px;text-align:center;font-size:22px}.zoom hr,.map-zoom hr{margin:1px;border:0;border-top:1px solid #5794ca}
.map-panel{height:calc(57vh - 84px);min-height:350px;overflow:hidden}.map-head{height:70px;padding:10px;display:flex;justify-content:space-between;align-items:flex-start}.map-head h2{color:var(--cyan)}.map-head b{font-size:11px}.map-head strong{color:var(--green);font-size:18px}.map-head #legend{max-width:70%;display:grid;grid-template-columns:repeat(5,auto);gap:4px 12px;font-size:10px}.legend-item:before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--c);margin-right:4px}.legend-item b{color:var(--c)}.world-map{height:calc(100% - 70px);position:relative;background:#030b19;overflow:hidden}.world-map svg{width:100%;height:100%}.graticule{stroke:#4e7893;stroke-width:.45;stroke-dasharray:3 5;opacity:.32}.country{fill:#152d42;stroke:#7ba4ba;stroke-width:.7;vector-effect:non-scaling-stroke;transition:fill .25s,stroke .25s}.country:hover{fill:#1f4d68;stroke:#69ddff}.map-labels text{fill:#c5d7df;font-size:15px;letter-spacing:1.5px;text-anchor:middle;opacity:.76;text-shadow:0 1px 4px #000}.marker{--c:#29e9ff;position:absolute;transform:translate(-50%,-50%);width:52px;height:52px;border:2px solid var(--c);border-radius:50%;display:grid;place-items:center;color:var(--c);font-weight:bold;font-size:12px;box-shadow:0 0 9px var(--c),inset 0 0 10px var(--c);animation:pulse 2.4s ease-in-out infinite}.marker:before,.marker:after{content:"";position:absolute;border:1px solid var(--c);border-radius:50%;inset:-7px;opacity:.5}.marker:after{inset:-13px;opacity:.25}.marker span{position:absolute;top:55px;white-space:nowrap;text-shadow:0 0 5px var(--c)}@keyframes pulse{50%{filter:brightness(1.5);transform:translate(-50%,-50%) scale(1.08)}}
.right-col{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;align-content:start}.hardware,.validation{padding:12px;min-height:660px}.hardware h2,.validation h2,.lower-cards h2{color:var(--cyan)}.hw{padding:9px;border:1px solid #315b88;border-radius:7px;margin-top:7px;font-size:10px}.hw>b{float:right}.hw .bar{margin-top:7px}.temp{height:40px}.npu span{display:block;margin:6px 0 2px}.npu span b{float:right}.model{padding:10px;border:1px solid #ba51fb;border-radius:7px;background:linear-gradient(90deg,#632b98,#a32c82);display:flex;flex-direction:column}.model strong{font-size:15px;margin-top:5px}.row{display:flex;justify-content:space-between;padding:11px 1px;font-size:10px}.earned{display:flex;justify-content:space-between;padding:8px;border:1px solid #f5b85f;border-radius:7px;font-size:10px;color:#ffe07e}.system{display:grid;grid-template-columns:50px 1fr;gap:7px;font-size:9px;padding-top:12px}.system b{text-align:right}
.validated{position:relative;border:1px solid #315b88;border-radius:7px;padding:11px;display:flex;flex-direction:column;font-size:10px}.validated strong{font-size:18px}.validated b{position:absolute;right:8px;bottom:12px;color:#6affb9}.pass{display:flex;align-items:center;padding:14px 5px;gap:12px}.ring{width:60px;height:60px;border:6px solid #48ffc4;border-radius:50%;display:grid;place-items:center;box-shadow:0 0 10px #48ffc4}.ring b{font-size:11px}.ring small{margin-top:-16px}.pass span{display:flex;flex-direction:column;font-size:9px}.pass strong{font-size:20px;color:#54ffc3}.vrow{display:flex;justify-content:space-between;padding:12px 3px;font-size:10px}.vrow b{color:#ff8dd2}.validation hr{border:0;border-top:1px solid #37618b}.epoch{padding:10px;border:1px solid #3b7edd;border-radius:7px;background:linear-gradient(135deg,#123e80,#152d5b);display:flex;flex-direction:column;gap:5px}.epoch strong{font-size:22px}.epoch span{font-size:10px}.dispute{display:flex;flex-direction:column;padding:12px 6px;font-size:10px}.dispute b{color:#55ffc2;margin-top:4px}.lower-cards{grid-column:1/3;display:grid;grid-template-columns:1fr 1fr;gap:8px}.lower-cards .panel{height:80px;padding:13px}.lower-cards span{font-size:11px}
@media(max-width:1450px){.layout{grid-template-columns:215px minmax(550px,1fr) 340px}.right-col{grid-template-columns:1fr 1fr}.hardware,.validation{padding:8px}.status-strip{gap:9px}.demo-links{gap:4px}.demo-links a{padding:0 7px;font-size:10px}.map-head #legend{grid-template-columns:repeat(4,auto)}}@media(min-height:901px){.topology{height:41.5vh}.map-panel{height:calc(58.5vh - 92px)}}@media(max-height:900px){.topbar{height:48px}.topology{height:42vh}.map-panel{height:calc(58vh - 72px)}.hardware,.validation{min-height:590px}.watch{padding:8px}.watch-device{padding:6px 0}.metric{padding:7px}.agent{padding:6px}}
@media(max-width:700px){
  html,body{min-width:0;overflow-x:hidden}
  .dashboard{width:100%;min-width:0;padding:5px}
  .topbar{height:auto;min-height:0;padding:10px 8px;gap:10px;flex-direction:column;align-items:stretch}
  .brand{justify-content:center;font-size:17px;letter-spacing:1.2px}
  .brand-mark{width:28px;height:28px;margin-right:9px}
  .status-strip{width:100%;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px}
  .status-strip div{min-width:0}
  .status-strip b{font-size:10px;white-space:nowrap}
  .status-strip small{font-size:7px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .demo-links{grid-column:1/-1;justify-content:center}
  .demo-links a{height:30px;padding:0 12px;font-size:10px}
  .layout{display:flex;flex-direction:column;padding-top:6px;gap:7px}
  .center-col{order:1}.left-col{order:2}.right-col{order:3}
  .left-col,.center-col,.right-col,.panel{width:100%;min-width:0}
  .topology{height:355px;min-height:355px;padding:7px}
  .topology h1{font-size:9px;letter-spacing:1px}
  .graph{height:calc(100% - 17px)}
  .labels{display:none}
  .zoom,.map-zoom{width:24px;font-size:17px}
  .map-panel{height:545px;min-height:545px}
  .map-head{height:146px;padding:10px;display:block}
  .map-head #legend{max-width:100%;margin-top:8px;grid-template-columns:repeat(3,minmax(0,1fr));gap:4px 6px;font-size:8px}
  .world-map{height:calc(100% - 146px)}
  .map-labels text{font-size:11px;letter-spacing:.5px}
  .marker{width:30px;height:30px;font-size:8px;border-width:1px}
  .marker:before{inset:-4px}.marker:after{inset:-8px}
  .marker span{top:32px;font-size:8px}
  .right-col{display:grid;grid-template-columns:1fr;grid-template-rows:auto;gap:7px}
  .hardware,.validation{min-height:0;padding:12px}
  .lower-cards{grid-column:1;grid-template-columns:1fr}
  .profile{height:145px}
  .online{margin-left:56%}
}
