@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;500;700&family=Outfit:wght@300;400;500;600;700;800;900&family=Orbitron:wght@400;500;700;900&display=swap');

/* ══ TOKENS ══════════════════════════════════════════════ */
:root {
  --bg:    #060b14; --bg2: #080e19; --bg3: #0a121e;
  --s1:    #0d1828; --s2:  #101f32; --s3:  #152640;
  --b1:    #1a2d47; --b2:  #224060; --b3:  #2d5280;
  --cyan:  #00e5ff; --cyan2: #00b8d4; --cyan3: #007ea0;
  --cyan-dim: rgba(0,229,255,0.08); --cyan-glow: rgba(0,229,255,0.2);
  --blue:  #1565ff; --indigo: #5e6ad2;
  --green: #00ffa3; --green2: #00cc80; --green-dim: rgba(0,255,163,0.08);
  --yellow:#ffb300; --yellow-dim: rgba(255,179,0,0.10);
  --red:   #ff2d55; --red-dim: rgba(255,45,85,0.10);
  --teal:  #00ffd0;
  --t1: #e2f0ff; --t2: #7090b0; --t3: #3a5570; --t4: #1e3348;
  --fd: 'Orbitron',monospace; --fb: 'Outfit',sans-serif; --fm: 'JetBrains Mono',monospace;
  --r: 10px; --rlg: 16px; --rxl: 22px;
}

/* ══ RESET ═══════════════════════════════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--t1);font-family:var(--fb);font-size:14px;line-height:1.6;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;}

/* ══ AURORA ══════════════════════════════════════════════ */
.aurora{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden;}
.aurora-1{position:absolute;top:-30%;left:-20%;width:80vw;height:70vh;border-radius:50%;
  background:radial-gradient(ellipse,rgba(0,100,255,.07) 0%,rgba(0,229,255,.04) 40%,transparent 70%);
  animation:aurora-drift 18s ease-in-out infinite alternate;}
.aurora-2{position:absolute;top:30%;right:-25%;width:70vw;height:60vh;border-radius:50%;
  background:radial-gradient(ellipse,rgba(0,229,255,.05) 0%,rgba(0,255,163,.03) 40%,transparent 70%);
  animation:aurora-drift 22s ease-in-out infinite alternate-reverse;}
.aurora-3{position:absolute;bottom:-20%;left:30%;width:60vw;height:50vh;border-radius:50%;
  background:radial-gradient(ellipse,rgba(94,106,210,.06) 0%,transparent 65%);
  animation:aurora-drift 26s ease-in-out infinite alternate;}
@keyframes aurora-drift{0%{transform:translate(0,0)scale(1)}50%{transform:translate(40px,-30px)scale(1.08)}100%{transform:translate(-20px,40px)scale(.95)}}

.grid-overlay{position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:linear-gradient(rgba(0,229,255,.015) 1px,transparent 1px),linear-gradient(90deg,rgba(0,229,255,.015) 1px,transparent 1px);
  background-size:56px 56px;}




/* ══ NAV ══════════════════════════════════════════════════ */
.nav{position:sticky;top:0;z-index:100;height:66px;display:flex;align-items:center;padding:0 28px;gap:0;
  background:rgba(6,11,20,.78);backdrop-filter:blur(28px) saturate(180%);-webkit-backdrop-filter:blur(28px) saturate(180%);
  border-bottom:1px solid rgba(0,229,255,.07);}
.nav::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(0,229,255,.4) 30%,rgba(0,229,255,.6) 50%,rgba(0,229,255,.4) 70%,transparent);}

/* Nav brand + logo ring */
.nav-brand{display:flex;align-items:center;gap:11px;cursor:pointer;flex-shrink:0;}
.nav-logo-ring{position:relative;width:40px;height:40px;min-width:40px;max-width:40px;flex-shrink:0;border-radius:50%;overflow:hidden;}
.nav-logo-ring::before{content:'';position:absolute;inset:-2px;border-radius:50%;
  background:conic-gradient(from 0deg,var(--cyan) 0%,var(--blue) 40%,transparent 60%,var(--cyan) 100%);
  animation:spin-ring 4s linear infinite;z-index:0;}
@keyframes spin-ring{to{transform:rotate(360deg)}}
.nav-logo-inner{position:absolute;inset:2px;border-radius:50%;overflow:hidden;background:var(--bg);z-index:1;}
.nav-logo-inner img{display:block;width:100%;height:100%;object-fit:cover;border-radius:50%;}

.nav-brand-name{font-family:var(--fd);font-size:15px;font-weight:700;color:var(--t1);letter-spacing:1px;text-transform:uppercase;}
.nav-brand-sub{font-family:var(--fm);font-size:9px;color:var(--t3);letter-spacing:2px;text-transform:uppercase;margin-top:1px;}
.nav-sep{width:1px;height:30px;background:var(--b1);margin:0 18px;flex-shrink:0;}
.nav-pharos{display:flex;align-items:center;gap:7px;background:rgba(0,229,255,.06);border:1px solid rgba(0,229,255,.15);border-radius:20px;padding:5px 12px 5px 8px;}
.nav-pharos-logo{width:20px;height:20px;border-radius:50%;overflow:hidden;flex-shrink:0;}
.nav-pharos-logo img{display:block;width:20px;height:20px;object-fit:cover;}
.nav-pharos-label{font-family:var(--fm);font-size:10px;color:var(--cyan);letter-spacing:1px;}

.nav-links{list-style:none;display:flex;gap:2px;margin:0 auto;}
.nav-links a{display:flex;align-items:center;gap:7px;padding:7px 14px;border-radius:8px;font-size:13px;font-weight:500;color:var(--t2);text-decoration:none;cursor:pointer;transition:all .18s;position:relative;}
.nav-links a:hover{color:var(--t1);background:rgba(255,255,255,.04);}
.nav-links a.active{color:var(--cyan);background:var(--cyan-dim);}
.nav-links a.active::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:18px;height:2px;background:var(--cyan);border-radius:1px;box-shadow:0 0 8px var(--cyan);}
.nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.nav-pill{display:flex;align-items:center;gap:6px;background:var(--s1);border:1px solid var(--b1);border-radius:8px;padding:5px 11px;font-family:var(--fm);font-size:11px;color:var(--t2);}

.live-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:blink 2s ease-in-out infinite;flex-shrink:0;}
@keyframes blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}

/* ══ LAYOUT ══════════════════════════════════════════════ */
.page-wrap{position:relative;z-index:1;max-width:1380px;margin:0 auto;padding:32px 28px 64px;}
.view{display:none;animation:view-in .28s ease;}
.view.active{display:block;}
@keyframes view-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ══ HERO ════════════════════════════════════════════════ */
.hero{text-align:center;padding:52px 0 44px;position:relative;}
.hero-beacon{position:absolute;top:0;left:50%;transform:translateX(-50%);width:2px;height:90px;
  background:linear-gradient(to bottom,transparent,var(--cyan),transparent);opacity:.28;
  animation:beacon 3s ease-in-out infinite;}
@keyframes beacon{0%,100%{opacity:.2;transform:translateX(-50%)scaleY(1)}50%{opacity:.5;transform:translateX(-50%)scaleY(1.3)}}
.hero-glow{position:absolute;top:-40px;left:50%;transform:translateX(-50%);width:700px;height:280px;
  background:radial-gradient(ellipse,rgba(0,100,255,.07) 0%,rgba(0,229,255,.04) 35%,transparent 70%);pointer-events:none;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:7px;background:rgba(0,229,255,.06);border:1px solid rgba(0,229,255,.18);
  border-radius:20px;padding:5px 16px;font-family:var(--fm);font-size:11px;color:rgba(0,229,255,.8);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:22px;}
.hero-eyebrow-dot{width:5px;height:5px;border-radius:50%;background:var(--cyan);box-shadow:0 0 6px var(--cyan);animation:blink 1.5s infinite;}
.hero h1{font-family:var(--fd);font-size:44px;font-weight:900;letter-spacing:-.5px;line-height:1.1;margin-bottom:14px;text-transform:uppercase;
  background:linear-gradient(135deg,#fff 0%,#a0d8ff 35%,var(--cyan) 65%,var(--teal) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.hero p{color:var(--t2);font-size:14.5px;margin-bottom:32px;font-weight:300;}

/* ══ SEARCH ══════════════════════════════════════════════ */
.search-wrap{max-width:640px;width:100%;margin:0 auto 12px;position:relative;}
.search-wrap input{display:block;width:100%;min-width:0;box-sizing:border-box;-webkit-appearance:none;
  background:rgba(13,24,40,.8);border:1px solid var(--b2);border-radius:12px;padding:15px 58px 15px 20px;
  color:var(--t1);font-size:13px;font-family:var(--fm);outline:none;transition:all .2s;backdrop-filter:blur(10px);}
.search-wrap input:focus{border-color:var(--cyan3);box-shadow:0 0 0 3px var(--cyan-dim);}
.search-wrap input::placeholder{color:var(--t3);font-size:12px;}
.search-btn{position:absolute;right:9px;top:50%;transform:translateY(-50%);width:38px;height:38px;
  background:linear-gradient(135deg,var(--cyan2),var(--blue));border:none;border-radius:8px;
  display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .2s;
  box-shadow:0 0 16px rgba(0,229,255,.3);}
.search-btn:hover{opacity:.85;}

/* ══ STAT CARDS ══════════════════════════════════════════ */
.stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:32px;}
.stat-card{position:relative;background:rgba(13,24,40,.7);border:1px solid rgba(255,255,255,.06);
  border-radius:var(--rlg);padding:22px 20px 18px;overflow:hidden;backdrop-filter:blur(20px);
  transition:transform .25s,border-color .25s,box-shadow .25s;}
.stat-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.03) 0%,transparent 60%);pointer-events:none;}
.stat-card:hover{transform:translateY(-3px);border-color:rgba(0,229,255,.18);box-shadow:0 12px 40px rgba(0,0,0,.3),0 0 20px rgba(0,229,255,.06);}
.stat-accent{position:absolute;top:0;left:0;right:0;height:2px;border-radius:var(--rlg) var(--rlg) 0 0;}
.acc-cyan{background:linear-gradient(90deg,transparent,var(--cyan),transparent);box-shadow:0 0 10px var(--cyan);}
.acc-green{background:linear-gradient(90deg,transparent,var(--green),transparent);box-shadow:0 0 10px var(--green);}
.acc-blue{background:linear-gradient(90deg,transparent,#4488ff,transparent);box-shadow:0 0 10px #4488ff;}
.acc-yellow{background:linear-gradient(90deg,transparent,var(--yellow),transparent);box-shadow:0 0 10px var(--yellow);}
.acc-teal{background:linear-gradient(90deg,transparent,var(--teal),transparent);box-shadow:0 0 10px var(--teal);}
.stat-icon-box{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;}
.stat-label{font-family:var(--fm);font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:6px;}
.stat-value{font-family:var(--fm);font-size:24px;font-weight:700;line-height:1.1;margin-bottom:4px;}
.stat-sub{font-size:11px;color:var(--t3);font-family:var(--fm);}
.v-cyan{color:var(--cyan)} .v-green{color:var(--green)} .v-blue{color:#4488ff} .v-yellow{color:var(--yellow)} .v-teal{color:var(--teal)}

/* ══ SECTION HEADERS ══════════════════════════════════════ */
.sec-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.sec-title{display:flex;align-items:center;gap:10px;font-family:var(--fm);font-size:11px;font-weight:700;color:var(--t2);text-transform:uppercase;letter-spacing:2px;}
.sec-pip{width:3px;height:16px;background:linear-gradient(to bottom,var(--cyan),var(--blue));border-radius:2px;box-shadow:0 0 8px var(--cyan);}
.btn-link{font-family:var(--fm);font-size:11px;color:var(--cyan);background:none;border:none;cursor:pointer;opacity:.7;transition:opacity .15s;}
.btn-link:hover{opacity:1;}

/* ══ CHART CARDS ══════════════════════════════════════════ */
.chart-card{background:rgba(13,24,40,.65);border:1px solid rgba(255,255,255,.06);border-radius:var(--rlg);padding:20px 22px;backdrop-filter:blur(20px);position:relative;overflow:hidden;}
.chart-card::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(0,229,255,.02) 0%,transparent 50%);pointer-events:none;}
.chart-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.chart-label{font-family:var(--fm);font-size:10.5px;color:var(--t3);text-transform:uppercase;letter-spacing:1.5px;}
.chart-meta{font-family:var(--fm);font-size:10px;color:var(--t3);}
.chart-wrap{width:100%;position:relative;}

/* ══ DATA TABLES ══════════════════════════════════════════ */
.data-card{background:rgba(13,24,40,.65);border:1px solid rgba(255,255,255,.06);border-radius:var(--rlg);overflow:hidden;backdrop-filter:blur(20px);}
.data-table{width:100%;border-collapse:collapse;}
.data-table thead tr{background:rgba(255,255,255,.025);}
.data-table th{padding:11px 16px;text-align:left;font-family:var(--fm);font-size:9.5px;color:var(--t3);
  text-transform:uppercase;letter-spacing:1.5px;border-bottom:1px solid rgba(255,255,255,.04);white-space:nowrap;cursor:pointer;user-select:none;transition:color .15s;}
.data-table th:hover{color:var(--t2);}
.data-table td{padding:13px 16px;font-size:13px;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle;}
.data-table tr:last-child td{border-bottom:none;}
.data-table tbody tr:hover td{background:rgba(0,229,255,.025);cursor:pointer;}

/* ══ BADGES ══════════════════════════════════════════════ */
.badge{display:inline-flex;align-items:center;gap:4px;font-family:var(--fm);font-size:9.5px;font-weight:700;padding:3px 8px;border-radius:5px;letter-spacing:.5px;white-space:nowrap;}
.badge-active{background:var(--green-dim);color:var(--green);border:1px solid rgba(0,255,163,.2);}
.badge-inactive{background:var(--red-dim);color:var(--red);border:1px solid rgba(255,45,85,.2);}
.badge-pending{background:var(--yellow-dim);color:var(--yellow);border:1px solid rgba(255,179,0,.2);}

/* ══ HASH ════════════════════════════════════════════════ */
.hash{font-family:var(--fm);font-size:12px;color:var(--cyan);cursor:pointer;transition:color .15s,text-shadow .15s;}
.hash:hover{color:var(--teal);text-shadow:0 0 8px rgba(0,229,255,.4);}

/* ══ STAKE BAR ═══════════════════════════════════════════ */
.stake-row{display:flex;align-items:center;gap:10px;}
.stake-bar{flex:1;min-width:60px;height:3px;background:rgba(255,255,255,.06);border-radius:2px;overflow:hidden;}
.stake-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--cyan2),var(--cyan));box-shadow:0 0 5px rgba(0,229,255,.4);transition:width .8s cubic-bezier(.34,1.56,.64,1);}
.stake-num{font-family:var(--fm);font-size:12px;color:var(--t1);white-space:nowrap;min-width:60px;text-align:right;}

/* ══ VALIDATOR CELLS ══════════════════════════════════════ */
.val-name-block{display:flex;flex-direction:column;gap:2px;}
.val-name{font-size:13.5px;font-weight:600;color:var(--t1);}
.val-ep{font-family:var(--fm);font-size:10.5px;color:var(--t3);}

/* ══ PAGE HEADER ══════════════════════════════════════════ */
.page-hd{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.05);}
.page-title{font-family:var(--fd);font-size:28px;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  background:linear-gradient(135deg,var(--t1),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.page-sub{font-size:13px;color:var(--t2);margin-top:4px;}
.live-chip{display:flex;align-items:center;gap:7px;background:var(--green-dim);border:1px solid rgba(0,255,163,.2);border-radius:20px;padding:5px 13px;font-family:var(--fm);font-size:10.5px;color:var(--green);}

/* ══ FILTER BAR ══════════════════════════════════════════ */
.filter-bar{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap;}
.filter-btn{background:rgba(13,24,40,.7);border:1px solid var(--b1);border-radius:7px;padding:6px 14px;font-family:var(--fm);font-size:11.5px;color:var(--t2);cursor:pointer;transition:all .15s;backdrop-filter:blur(10px);}
.filter-btn:hover{border-color:var(--b2);color:var(--t1);}
.filter-btn.active{background:var(--cyan-dim);border-color:rgba(0,229,255,.35);color:var(--cyan);box-shadow:0 0 12px rgba(0,229,255,.1);}
.search-sm{margin-left:auto;background:rgba(13,24,40,.7);border:1px solid var(--b1);border-radius:7px;padding:6px 14px;
  font-family:var(--fm);font-size:12px;color:var(--t1);outline:none;width:240px;transition:border-color .15s;backdrop-filter:blur(10px);}
.search-sm:focus{border-color:var(--cyan3);}
.search-sm::placeholder{color:var(--t3);}

/* ══ UPTIME STATUS BAR ════════════════════════════════════ */
.uptime-status-bar{display:flex;align-items:center;gap:8px;font-family:var(--fm);font-size:11px;color:var(--t3);
  margin-bottom:12px;padding:8px 14px;background:rgba(0,229,255,.04);border:1px solid rgba(0,229,255,.08);border-radius:8px;}

/* ══ PAGINATION ══════════════════════════════════════════ */
.pagination{display:flex;align-items:center;justify-content:center;gap:6px;padding:16px;border-top:1px solid rgba(255,255,255,.04);}
.page-btn{background:rgba(13,24,40,.7);border:1px solid var(--b1);border-radius:6px;padding:5px 11px;font-family:var(--fm);font-size:11.5px;color:var(--t2);cursor:pointer;min-width:34px;transition:all .15s;}
.page-btn:hover:not(:disabled){border-color:var(--b2);color:var(--t1);}
.page-btn.cur{background:var(--cyan-dim);border-color:rgba(0,229,255,.4);color:var(--cyan);}
.page-btn:disabled{opacity:.3;cursor:not-allowed;}

/* ══ MODAL ═══════════════════════════════════════════════ */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(3,6,12,.85);z-index:300;backdrop-filter:blur(10px);align-items:center;justify-content:center;}
.modal-overlay.open{display:flex;}
.modal-box{background:rgba(13,24,40,.97);border:1px solid rgba(0,229,255,.15);border-radius:var(--rxl);
  width:720px;max-width:96vw;max-height:88vh;overflow-y:auto;padding:32px;position:relative;
  box-shadow:0 24px 80px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.05);
  animation:modal-in .3s cubic-bezier(.34,1.56,.64,1);backdrop-filter:blur(30px);}
@keyframes modal-in{from{opacity:0;transform:translateY(28px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}
.modal-close{position:absolute;top:18px;right:18px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);
  border-radius:7px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--t2);font-size:15px;transition:all .15s;}
.modal-close:hover{background:rgba(255,45,85,.12);color:var(--red);border-color:rgba(255,45,85,.3);}
.modal-title{font-family:var(--fd);font-size:18px;font-weight:700;margin-bottom:24px;display:flex;align-items:center;gap:12px;padding-right:42px;text-transform:uppercase;letter-spacing:.5px;}
.modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px;}
.modal-field{background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.06);border-radius:9px;padding:12px 14px;transition:border-color .15s;}
.modal-field:hover{border-color:rgba(0,229,255,.1);}
.modal-field.full{grid-column:1/-1;}
.mf-label{font-family:var(--fm);font-size:9.5px;color:var(--t3);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:6px;}
.mf-val{font-family:var(--fm);font-size:12.5px;color:var(--t1);word-break:break-all;line-height:1.5;}
.mf-val.cyan{color:var(--cyan)} .mf-val.green{color:var(--green)} .mf-val.small{font-size:10.5px;color:var(--t2);}

/* ══ SKELETON ════════════════════════════════════════════ */
@keyframes shimmer{0%{background-position:-800px 0}100%{background-position:800px 0}}
.skel{background:linear-gradient(90deg,rgba(255,255,255,.04) 25%,rgba(255,255,255,.09) 50%,rgba(255,255,255,.04) 75%);background-size:1600px 100%;animation:shimmer 1.8s infinite;border-radius:4px;display:inline-block;}

/* ══ TOAST ═══════════════════════════════════════════════ */
#toast{position:fixed;bottom:28px;right:28px;background:rgba(13,24,40,.97);border:1px solid rgba(0,229,255,.25);
  border-radius:10px;padding:11px 18px;font-family:var(--fm);font-size:12px;color:var(--cyan);z-index:999;
  opacity:0;transform:translateY(10px);transition:all .22s;pointer-events:none;backdrop-filter:blur(20px);box-shadow:0 8px 32px rgba(0,0,0,.4),0 0 20px rgba(0,229,255,.1);}
#toast.show{opacity:1;transform:translateY(0);}

/* ══ FOOTER ══════════════════════════════════════════════ */
.footer{position:relative;z-index:1;border-top:1px solid rgba(255,255,255,.04);background:rgba(6,11,20,.5);backdrop-filter:blur(20px);padding:28px;}
.footer-inner{max-width:1380px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;}
.footer-brand{display:flex;align-items:center;gap:10px;}
.footer-logo{width:28px;height:28px;min-width:28px;border-radius:50%;overflow:hidden;border:1px solid rgba(0,229,255,.2);flex-shrink:0;}
.footer-logo img{display:block;width:28px;height:28px;object-fit:cover;}
.footer-text{font-family:var(--fm);font-size:11px;color:var(--t3);line-height:1.7;}
.footer-text b{color:var(--t2);}
.footer-links{display:flex;gap:20px;}
.footer-links a{font-family:var(--fm);font-size:11px;color:var(--t3);text-decoration:none;transition:color .15s;}
.footer-links a:hover{color:var(--cyan);}

/* ══ GRIDS ═══════════════════════════════════════════════ */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px;}
.three-col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px;margin-bottom:28px;}

/* ══ UPTIME STREAM PAGE ══════════════════════════════════ */
.epoch-row{border-bottom:1px solid rgba(255,255,255,.04);padding:14px 20px;transition:background .2s;}
.epoch-row:last-child{border-bottom:none;}
.epoch-row:hover{background:rgba(0,229,255,.02);}
.epoch-row-new{animation:epoch-arrive .6s ease;}
@keyframes epoch-arrive{0%{background:rgba(0,229,255,.14);transform:translateY(-6px);opacity:0}40%{opacity:1;transform:translateY(0)}100%{background:transparent}}
.epoch-row-header{display:flex;align-items:center;gap:14px;margin-bottom:10px;flex-wrap:wrap;}
.epoch-num-badge{display:flex;flex-direction:column;min-width:76px;}
.epoch-num-label{font-family:var(--fm);font-size:8px;color:var(--t3);letter-spacing:2px;text-transform:uppercase;}
.epoch-num-val{font-family:var(--fm);font-size:17px;font-weight:700;color:var(--cyan);line-height:1.2;}
.epoch-block-ref{display:flex;align-items:center;gap:5px;font-family:var(--fm);font-size:11px;color:var(--t3);}
.epoch-ts{font-family:var(--fm);font-size:11px;color:var(--t3);}
.epoch-participation{display:flex;align-items:center;gap:8px;margin-left:auto;}
.ep-count{font-family:var(--fm);font-size:12px;font-weight:600;}
.ep-pct{font-family:var(--fm);font-size:17px;font-weight:700;}
.epoch-mini-bar{width:72px;height:4px;background:rgba(255,255,255,.06);border-radius:2px;overflow:hidden;}
.epoch-mini-fill{height:100%;border-radius:2px;transition:width .4s;}
.epoch-blocks-grid{display:flex;flex-wrap:wrap;gap:3px;padding-top:2px;}
.val-block{width:16px;height:16px;border-radius:3px;cursor:pointer;transition:transform .12s,box-shadow .12s;flex-shrink:0;}
.val-block:hover{transform:scale(1.55);z-index:10;}
.val-legend{display:flex;flex-wrap:wrap;gap:6px;padding:12px 20px;border-bottom:1px solid rgba(255,255,255,.04);background:rgba(0,0,0,.12);}
.val-legend-item{display:flex;align-items:center;gap:5px;font-family:var(--fm);font-size:10.5px;color:var(--t2);cursor:pointer;padding:2px 7px;border-radius:4px;transition:background .15s;}
.val-legend-item:hover{background:rgba(255,255,255,.05);}
.val-legend-dot{width:10px;height:10px;border-radius:2px;flex-shrink:0;}
.live-stream-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,45,85,.1);border:1px solid rgba(255,45,85,.25);border-radius:20px;padding:4px 12px;font-family:var(--fm);font-size:10px;color:var(--red);}

/* ══ RESPONSIVE ══════════════════════════════════════════ */
@media(max-width:1100px){.stats-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:900px){
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .two-col,.three-col{grid-template-columns:1fr;}
  .modal-grid{grid-template-columns:1fr;}.modal-field.full{grid-column:1;}
  .nav-links{display:none;}.hero h1{font-size:32px;}
}
@media(max-width:600px){.stats-grid{grid-template-columns:1fr 1fr;}.page-wrap{padding:16px 16px 48px;}}
