*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#050508;--surface:#0d0d14;--surface2:#12121c;--surface3:#17172a;
  --border:rgba(255,255,255,.07);--borderh:rgba(255,255,255,.13);
  --text:#e8e8f0;--muted:#6b6b80;--muted2:#4a4a5e;
  --accent:#7c6af7;--accent2:#a78bfa;--aglow:rgba(124,106,247,.13);
  --green:#4ade80;--red:#f87171;--amber:#fbbf24;--blue:#60a5fa;--pink:#f472b6;
  --sans:'Space Grotesk',sans-serif;--mono:'JetBrains Mono',monospace;
  --sidebar:260px;--ease:cubic-bezier(.4,0,.2,1);
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--sans);min-height:100vh;overflow-x:hidden}

/* STARS */
.stars{position:fixed;inset:0;pointer-events:none;z-index:0}
.star{position:absolute;border-radius:50%;background:#fff;animation:tw var(--d,3s) ease-in-out infinite;opacity:var(--o,.3)}
@keyframes tw{0%,100%{opacity:var(--o,.3)}50%{opacity:.03}}

/* SIDEBAR */
.sidebar{
  position:fixed;left:0;top:0;bottom:0;width:var(--sidebar);
  background:rgba(8,8,14,.97);border-right:1px solid var(--border);
  z-index:300;display:flex;flex-direction:column;
  transform:translateX(-100%);transition:transform .35s var(--ease);
  backdrop-filter:blur(20px);
}
.sidebar.open{transform:translateX(0)}
.sb-head{padding:24px 20px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.sb-logo{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:700;letter-spacing:-.03em}
.sb-logo-icon{color:var(--accent);font-size:1.1rem}
.sb-close{
  background:var(--surface2);border:1px solid var(--border);color:var(--muted);
  width:26px;height:26px;border-radius:6px;cursor:pointer;font-size:.7rem;
  transition:all .18s var(--ease);display:flex;align-items:center;justify-content:center;
}
.sb-close:hover{color:var(--text);border-color:var(--borderh)}
.sb-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:3px;overflow-y:auto}
.sb-item{
  display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;
  cursor:pointer;transition:all .18s var(--ease);color:var(--muted);font-size:.88rem;
  border:1px solid transparent;
}
.sb-item:hover{background:var(--surface2);color:var(--text);border-color:var(--border)}
.sb-item.active{background:var(--aglow);color:var(--accent2);border-color:rgba(124,106,247,.25)}
.sb-item-icon{font-size:1rem;width:20px;text-align:center;flex-shrink:0}
.sb-item-label{font-weight:500}
.sb-item-badge{margin-left:auto;font-family:var(--mono);font-size:.58rem;padding:2px 6px;border-radius:10px;background:var(--aglow);color:var(--accent2);border:1px solid rgba(124,106,247,.2)}
.sb-divider{height:1px;background:var(--border);margin:10px 4px}
.sb-footer{padding:16px 20px;border-top:1px solid var(--border)}
.sb-version{font-family:var(--mono);font-size:.65rem;color:var(--muted2)}
.sidebar-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:299;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(2px)}
.sidebar-backdrop.show{opacity:1;pointer-events:all}

/* NAVBAR */
.navbar{
  position:sticky;top:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 24px;background:rgba(5,5,8,.9);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
}
.nav-left{display:flex;align-items:center;gap:12px}
.menu-btn{
  background:var(--surface2);border:1px solid var(--border);color:var(--muted);
  width:34px;height:34px;border-radius:8px;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  transition:all .18s var(--ease);flex-shrink:0;
}
.menu-btn:hover{border-color:var(--borderh);color:var(--text)}
.menu-btn span{display:block;width:14px;height:1.5px;background:currentColor;border-radius:2px;transition:all .25s var(--ease)}
.menu-btn.open span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}
.menu-btn.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.menu-btn.open span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}
.nav-brand{display:flex;align-items:center;gap:7px;font-size:1rem;font-weight:700;letter-spacing:-.03em}
.nav-dot{color:var(--accent)}
.nav-pills{display:flex;gap:7px}
.pill{font-family:var(--mono);font-size:.65rem;padding:4px 10px;border-radius:20px;border:1px solid var(--border);background:var(--surface);color:var(--muted)}
.pill.on{color:var(--green);border-color:rgba(74,222,128,.25);background:rgba(74,222,128,.05)}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:.5}50%{opacity:1}}

/* HERO */
.hero{position:relative;z-index:1;text-align:center;padding:64px 24px 48px}
.hero-glow{position:absolute;top:-60px;left:50%;transform:translateX(-50%);width:500px;height:320px;background:radial-gradient(ellipse,rgba(124,106,247,.11) 0%,transparent 70%);pointer-events:none}
.eyebrow{font-family:var(--mono);font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;opacity:0;animation:fadeUp .6s var(--ease) .1s forwards}
.hero-title{font-size:clamp(2.6rem,7vw,4.8rem);font-weight:700;letter-spacing:-.04em;line-height:1;margin-bottom:16px;background:linear-gradient(135deg,#fff 40%,var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:0;animation:fadeUp .6s var(--ease) .2s forwards}
.hero-title .ac{-webkit-text-fill-color:var(--accent)}
.hero-sub{max-width:440px;margin:0 auto 26px;color:var(--muted);font-size:.9rem;line-height:1.7;opacity:0;animation:fadeUp .6s var(--ease) .3s forwards}
.hero-ep{display:inline-flex;align-items:center;gap:9px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 14px;opacity:0;animation:fadeUp .6s var(--ease) .4s forwards}
.ep-m{font-family:var(--mono);font-size:.72rem;color:var(--accent)}
.ep-u{font-family:var(--mono);font-size:.72rem;color:var(--muted)}
.copy-btn{font-family:var(--mono);font-size:.65rem;color:var(--accent);background:var(--aglow);border:1px solid rgba(124,106,247,.3);border-radius:4px;padding:3px 8px;cursor:pointer;transition:background .18s}
.copy-btn:hover{background:rgba(124,106,247,.22)}
.typewriter-wrap{margin-top:16px;font-family:var(--mono);font-size:.8rem;color:var(--muted);opacity:0;animation:fadeUp .6s var(--ease) .55s forwards;min-height:1.4em}
.tw-prefix{color:var(--accent)}
.tw-text{color:var(--accent2)}
.tw-cursor{color:var(--accent);animation:blink .7s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

/* CONTAINER */
.container{position:relative;z-index:1;max-width:1080px;margin:0 auto;padding:0 24px 80px}
.sec-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:22px}
.sec-label{font-family:var(--mono);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.tabs{display:flex;gap:5px;flex-wrap:wrap}
.tab{font-family:var(--mono);font-size:.68rem;padding:5px 11px;border-radius:4px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;transition:all .18s var(--ease)}
.tab:hover{border-color:var(--borderh);color:var(--text)}
.tab.active{background:var(--aglow);border-color:rgba(124,106,247,.4);color:var(--accent2)}

/* GRID */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px 18px;cursor:pointer;position:relative;overflow:hidden;transition:border-color .2s,transform .2s,box-shadow .2s;opacity:0;animation:fadeUp .4s var(--ease) var(--delay,.05s) forwards}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0;transition:opacity .3s}
.card:hover{border-color:var(--borderh);transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.45)}
.card:hover::before{opacity:1}
.card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px}
.cat-badge{font-family:var(--mono);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);background:var(--aglow);border:1px solid rgba(124,106,247,.2);border-radius:3px;padding:2px 6px}
.sdot{width:7px;height:7px;border-radius:50%;margin-top:3px;flex-shrink:0}
.sdot.on{background:var(--green);box-shadow:0 0 6px var(--green)}
.sdot.off{background:var(--red)}
.card-name{font-size:.9rem;font-weight:600;margin-bottom:5px}
.card-desc{font-size:.77rem;color:var(--muted);line-height:1.5;margin-bottom:12px}
.card-foot{display:flex;align-items:center;gap:6px}
.tbadge{font-family:var(--mono);font-size:.6rem;padding:2px 7px;border-radius:3px;border:1px solid var(--border);color:var(--muted)}
.tbadge.json{color:var(--amber);border-color:rgba(251,191,36,.25);background:rgba(251,191,36,.05)}
.tbadge.image{color:var(--blue);border-color:rgba(96,165,250,.25);background:rgba(96,165,250,.05)}
.tbadge.video{color:var(--pink);border-color:rgba(244,114,182,.25);background:rgba(244,114,182,.05)}
.tbadge.audio{color:var(--green);border-color:rgba(74,222,128,.25);background:rgba(74,222,128,.05)}
.pcount{font-family:var(--mono);font-size:.6rem;color:var(--muted);margin-left:auto}

/* MODAL */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(6px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .25s var(--ease)}
.overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--surface);border:1px solid var(--borderh);border-radius:14px;width:100%;max-width:520px;max-height:88vh;display:flex;flex-direction:column;transform:scale(.94) translateY(8px);transition:transform .25s var(--ease)}
.overlay.open .modal{transform:scale(1) translateY(0)}
.modal-inner{overflow-y:auto;flex:1;overscroll-behavior:contain}
.modal-inner::-webkit-scrollbar{width:3px}
.modal-inner::-webkit-scrollbar-thumb{background:var(--borderh);border-radius:10px}
.mhead{display:flex;justify-content:space-between;align-items:flex-start;padding:20px 22px 0;flex-shrink:0}
.meyebrow{font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:4px}
.mtitle{font-size:1.02rem;font-weight:600}
.mclose{background:var(--surface2);border:1px solid var(--border);color:var(--muted);width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:.75rem;transition:all .18s;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.mclose:hover{color:var(--text);border-color:var(--borderh)}
.mbody{padding:12px 22px 22px}
.mdesc{color:var(--muted);font-size:.82rem;line-height:1.6;margin-bottom:12px}
.mmeta{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap;align-items:center}
.mtag{font-family:var(--mono);font-size:.62rem;padding:3px 8px;border-radius:4px;border:1px solid var(--border);color:var(--muted);text-transform:uppercase}
.mstatus{font-family:var(--mono);font-size:.67rem;margin-left:auto}
.mstatus.on{color:var(--green)}.mstatus.off{color:var(--red)}
.stitle{font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;margin-top:16px}
.param-row{display:flex;justify-content:space-between;align-items:center;padding:8px 11px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;margin-bottom:4px}
.pk{font-family:var(--mono);font-size:.76rem;color:var(--accent2)}
.pv{font-size:.73rem;color:var(--muted)}
.no-params{font-family:var(--mono);font-size:.73rem;color:var(--muted2);font-style:italic}
.input-row{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}
.input-label{font-family:var(--mono);font-size:.65rem;color:var(--muted)}
.tinput{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:8px 11px;color:var(--text);font-family:var(--mono);font-size:.76rem;outline:none;transition:border-color .18s;width:100%}
.tinput:focus{border-color:rgba(124,106,247,.5)}
.ep-preview{background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:9px 11px;margin-bottom:10px}
.ep-line{font-family:var(--mono);font-size:.7rem;color:var(--muted);word-break:break-all}
.ep-line .ep-base{color:var(--muted)}
.ep-line .ep-cat{color:var(--accent)}
.ep-line .ep-name{color:var(--accent2)}
.ep-line .ep-q{color:var(--muted)}
.ep-line .ep-key{color:var(--amber)}
.ep-line .ep-val{color:var(--green)}
.run-btn{width:100%;padding:10px;background:var(--aglow);border:1px solid rgba(124,106,247,.4);border-radius:7px;color:var(--accent2);font-family:var(--mono);font-size:.78rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:7px}
.run-btn:hover{background:rgba(124,106,247,.2)}
.run-btn:disabled{opacity:.4;cursor:default}
.run-spinner{width:12px;height:12px;border:2px solid rgba(167,139,250,.3);border-top-color:var(--accent2);border-radius:50%;animation:spin .7s linear infinite;display:none}

/* RESULT */
.result-wrap{margin-top:13px;display:none;animation:fadeUp .3s var(--ease)}
.result-wrap.show{display:block}
.result-label{font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:7px;display:flex;align-items:center;gap:6px}
.json-box{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:11px;font-family:var(--mono);font-size:.7rem;color:var(--muted);max-height:200px;overflow-y:auto;white-space:pre-wrap;word-break:break-all}
.json-box.ok{color:var(--green)}.json-box.err{color:var(--red)}
.img-result{border-radius:10px;overflow:hidden;border:1px solid var(--border);background:var(--surface2)}
.img-result img{width:100%;max-height:240px;object-fit:cover;display:block}
.media-bar{padding:8px 11px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px;background:var(--surface2)}
.media-url{font-family:var(--mono);font-size:.65rem;color:var(--muted);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.media-url a{color:var(--accent2);text-decoration:none}
.media-url a:hover{text-decoration:underline}
.dl-btn{display:flex;align-items:center;gap:5px;font-family:var(--mono);font-size:.65rem;padding:4px 9px;border-radius:5px;background:var(--aglow);border:1px solid rgba(124,106,247,.3);color:var(--accent2);text-decoration:none;cursor:pointer;transition:background .18s;flex-shrink:0;white-space:nowrap}
.dl-btn:hover{background:rgba(124,106,247,.22)}
.dl-btn svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.video-result{border-radius:10px;overflow:hidden;border:1px solid var(--border);background:#000}
.video-result video{width:100%;max-height:230px;display:block}
.audio-result{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:13px;display:flex;flex-direction:column;gap:9px}
.audio-result audio{width:100%}
.audio-actions{display:flex;gap:7px;align-items:center}
.audio-url{font-family:var(--mono);font-size:.65rem;color:var(--muted);word-break:break-all;flex:1}
.audio-url a{color:var(--accent2);text-decoration:none}

/* PAGES */
.page{display:none;animation:fadeIn .25s var(--ease)}
.page.active{display:block}
.page-title{font-size:1.1rem;font-weight:700;margin-bottom:4px}
.page-sub{font-size:.82rem;color:var(--muted);margin-bottom:24px}
.profile-card{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:20px;display:flex;align-items:center;gap:14px;margin-bottom:20px}
.avatar{width:48px;height:48px;border-radius:50%;background:var(--aglow);border:2px solid rgba(124,106,247,.4);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.profile-info-name{font-weight:600;font-size:.95rem;margin-bottom:3px}
.profile-info-role{font-family:var(--mono);font-size:.68rem;color:var(--accent)}
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:16px}
.stat-box{background:var(--surface2);border:1px solid var(--border);border-radius:9px;padding:13px 14px}
.stat-num{font-size:1.4rem;font-weight:700;color:var(--accent2);font-family:var(--mono)}
.stat-lbl{font-size:.72rem;color:var(--muted);margin-top:2px}
.apikey-box{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:14px}
.apikey-label{font-family:var(--mono);font-size:.63rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:9px}
.apikey-val{font-family:var(--mono);font-size:.8rem;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:9px 11px;display:flex;justify-content:space-between;align-items:center;gap:8px}
.apikey-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.apikey-copy{font-family:var(--mono);font-size:.65rem;color:var(--accent);background:var(--aglow);border:1px solid rgba(124,106,247,.3);border-radius:4px;padding:3px 8px;cursor:pointer;transition:background .18s;flex-shrink:0}
.apikey-copy:hover{background:rgba(124,106,247,.22)}
.plan-badge{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:.7rem;padding:5px 12px;border-radius:20px;background:rgba(74,222,128,.07);border:1px solid rgba(74,222,128,.25);color:var(--green);margin-bottom:14px}
.usage-bar-wrap{margin-top:12px}
.usage-label{font-size:.77rem;color:var(--muted);margin-bottom:6px;display:flex;justify-content:space-between}
.usage-bar{height:5px;background:var(--surface3);border-radius:10px;overflow:hidden}
.usage-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:10px;width:34%}

/* STATS PAGE */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:14px}
.scard{background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:18px 20px;position:relative;overflow:hidden;transition:border-color .2s,transform .2s;opacity:0;animation:fadeUp .45s var(--ease) var(--sd,.1s) forwards}
.scard:hover{border-color:var(--borderh);transform:translateY(-2px)}
.scard-glow{position:absolute;top:-20px;right:-20px;width:80px;height:80px;border-radius:50%;background:var(--gc,rgba(124,106,247,.08));filter:blur(18px);pointer-events:none}
.scard-label{font-family:var(--mono);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.scard-num{font-size:1.9rem;font-weight:700;letter-spacing:-.03em;font-family:var(--mono);line-height:1;margin-bottom:6px;color:var(--nc,var(--text))}
.scard-sub{font-size:.75rem;color:var(--muted);display:flex;align-items:center;gap:5px}
.trend{font-family:var(--mono);font-size:.65rem;padding:2px 6px;border-radius:3px}
.trend.up{background:rgba(74,222,128,.1);color:var(--green)}.trend.down{background:rgba(248,113,113,.1);color:var(--red)}
.slabel{font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.slabel::after{content:'';flex:1;height:1px;background:var(--border)}
.mid-row{display:grid;grid-template-columns:1fr 340px;gap:12px;margin-bottom:14px}
.chart-box,.ring-box,.resp-box,.status-box{background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:20px 22px;opacity:0;animation:fadeUp .45s var(--ease) .3s forwards}
.ring-box{display:flex;flex-direction:column}
.bar-list{display:flex;flex-direction:column;gap:11px;margin-top:4px}
.bar-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}
.bar-name{font-size:.82rem;font-weight:500}
.bar-stats{display:flex;align-items:center;gap:8px}
.bar-num{font-family:var(--mono);font-size:.72rem;color:var(--accent2)}
.bar-pct{font-family:var(--mono);font-size:.65rem;color:var(--muted)}
.bar-track{height:5px;background:var(--surface3);border-radius:10px;overflow:hidden}
.bar-fill{height:100%;border-radius:10px;width:0;transition:width 1.1s var(--ease)}
.ring-wrap{display:flex;align-items:center;justify-content:center;gap:20px;margin-top:8px;flex:1}
.ring-legend{display:flex;flex-direction:column;gap:9px}
.ring-item{display:flex;align-items:center;gap:8px}
.ring-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.ring-lname{font-size:.78rem;color:var(--muted);flex:1}
.ring-lval{font-family:var(--mono);font-size:.72rem;color:var(--text)}
.bot-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.resp-list{display:flex;flex-direction:column;gap:7px;margin-top:4px}
.resp-row{display:flex;align-items:center;justify-content:space-between;padding:8px 11px;background:var(--surface2);border:1px solid var(--border);border-radius:7px;transition:border-color .18s}
.resp-row:hover{border-color:var(--borderh)}
.resp-name{font-size:.8rem;font-weight:500}
.resp-right{display:flex;align-items:center;gap:10px}
.resp-ms{font-family:var(--mono);font-size:.75rem}
.resp-ms.fast{color:var(--green)}.resp-ms.mid{color:var(--amber)}.resp-ms.slow{color:var(--red)}
.resp-bar{width:50px;height:3px;background:var(--surface3);border-radius:10px;overflow:hidden}
.resp-fill{height:100%;border-radius:10px;width:0;transition:width 1s var(--ease)}
.stable{width:100%;border-collapse:collapse;margin-top:4px}
.stable th{font-family:var(--mono);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted2);text-align:left;padding:0 8px 10px;border-bottom:1px solid var(--border)}
.stable td{padding:9px 8px;border-bottom:1px solid var(--border);font-size:.8rem;transition:background .15s}
.stable tr:last-child td{border-bottom:none}
.stable tr:hover td{background:var(--surface2)}
.sdot2{display:inline-block;width:6px;height:6px;border-radius:50%;margin-right:5px;vertical-align:middle}
.sdot2.on{background:var(--green);box-shadow:0 0 5px var(--green)}.sdot2.off{background:var(--red)}
.cat-pill{font-family:var(--mono);font-size:.58rem;padding:2px 6px;border-radius:3px;background:var(--aglow);border:1px solid rgba(124,106,247,.2);color:var(--accent)}
.hit-num{font-family:var(--mono);font-size:.75rem;color:var(--accent2)}
.uptime-box{background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:20px 22px;opacity:0;animation:fadeUp .45s var(--ease) .5s forwards}
.uptime-bars{display:flex;gap:3px;margin-top:10px;align-items:flex-end}
.ubar{flex:1;border-radius:3px 3px 0 0;cursor:pointer;position:relative;transition:opacity .18s;min-height:4px}
.ubar:hover{opacity:.8}
.ubar-tip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--surface3);border:1px solid var(--borderh);border-radius:5px;padding:4px 8px;font-family:var(--mono);font-size:.62rem;white-space:nowrap;color:var(--text);pointer-events:none;opacity:0;transition:opacity .15s;z-index:10}
.ubar:hover .ubar-tip{opacity:1}
.uptime-footer{display:flex;justify-content:space-between;align-items:center;margin-top:6px}
.uptime-label{font-family:var(--mono);font-size:.63rem;color:var(--muted)}
.uptime-pct{font-family:var(--mono);font-size:.75rem;color:var(--green)}
.filter-group{display:flex;gap:5px}
.fbtn{font-family:var(--mono);font-size:.65rem;padding:5px 11px;border-radius:4px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;transition:all .18s var(--ease)}
.fbtn:hover{border-color:var(--borderh);color:var(--text)}
.fbtn.active{background:var(--aglow);border-color:rgba(124,106,247,.4);color:var(--accent2)}
.refresh-btn{font-family:var(--mono);font-size:.65rem;padding:5px 10px;border-radius:4px;border:1px solid var(--border);background:var(--surface2);color:var(--muted);cursor:pointer;transition:all .18s var(--ease);display:flex;align-items:center;gap:5px}
.refresh-btn:hover{border-color:var(--borderh);color:var(--text)}
.refresh-btn svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .4s var(--ease)}
.refresh-btn.spin svg{transform:rotate(360deg)}
.stats-header-row{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:20px}

/* LIVE CHAT */
.chat-fab{
  position:fixed;bottom:28px;right:28px;z-index:150;
  width:52px;height:52px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 24px rgba(124,106,247,.45);
  transition:transform .2s var(--ease),box-shadow .2s;
}
.chat-fab:hover{transform:scale(1.08);box-shadow:0 6px 32px rgba(124,106,247,.6)}
.chat-fab svg{width:22px;height:22px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.chat-badge{position:absolute;top:-3px;right:-3px;width:14px;height:14px;border-radius:50%;background:var(--green);border:2px solid var(--bg);animation:pulse 2s ease-in-out infinite}

.chat-window{
  position:fixed;bottom:92px;right:28px;z-index:150;
  width:340px;height:460px;
  background:var(--surface);border:1px solid var(--borderh);border-radius:14px;
  display:flex;flex-direction:column;
  transform:scale(.92) translateY(10px);transform-origin:bottom right;
  opacity:0;pointer-events:none;transition:all .25s var(--ease);
  box-shadow:0 16px 48px rgba(0,0,0,.5);
}
.chat-window.open{transform:scale(1) translateY(0);opacity:1;pointer-events:all}
.chat-head{
  padding:14px 16px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:10px;flex-shrink:0;
}
.chat-avatar{width:32px;height:32px;border-radius:50%;background:var(--aglow);border:1px solid rgba(124,106,247,.4);display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}
.chat-info{flex:1}
.chat-name{font-size:.85rem;font-weight:600}
.chat-status{font-family:var(--mono);font-size:.62rem;color:var(--green);display:flex;align-items:center;gap:4px}
.chat-status::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--green);display:inline-block}
.chat-close{background:transparent;border:none;color:var(--muted);cursor:pointer;font-size:.85rem;transition:color .15s;padding:4px}
.chat-close:hover{color:var(--text)}
.chat-msgs{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px;overscroll-behavior:contain}
.chat-msgs::-webkit-scrollbar{width:3px}
.chat-msgs::-webkit-scrollbar-thumb{background:var(--borderh);border-radius:10px}
.msg{display:flex;flex-direction:column;gap:3px;animation:fadeUp .25s var(--ease)}
.msg.bot{align-items:flex-start}
.msg.user{align-items:flex-end}
.msg-bubble{
  max-width:80%;padding:8px 12px;border-radius:10px;font-size:.8rem;line-height:1.5;
}
.msg.bot .msg-bubble{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:4px 10px 10px 10px}
.msg.user .msg-bubble{background:var(--aglow);border:1px solid rgba(124,106,247,.3);color:var(--accent2);border-radius:10px 4px 10px 10px}
.msg-time{font-family:var(--mono);font-size:.58rem;color:var(--muted)}
.chat-typing{display:flex;gap:4px;padding:8px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:4px 10px 10px 10px;width:fit-content;display:none}
.chat-typing span{width:5px;height:5px;border-radius:50%;background:var(--muted);animation:typing 1.2s ease-in-out infinite}
.chat-typing span:nth-child(2){animation-delay:.2s}
.chat-typing span:nth-child(3){animation-delay:.4s}
@keyframes typing{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-5px)}}
.chat-input-row{padding:12px 14px;border-top:1px solid var(--border);display:flex;gap:8px;flex-shrink:0}
.chat-input{
  flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:8px;
  padding:8px 11px;color:var(--text);font-family:var(--sans);font-size:.8rem;
  outline:none;transition:border-color .18s;resize:none;height:36px;
}
.chat-input:focus{border-color:rgba(124,106,247,.5)}
.chat-send{
  width:36px;height:36px;border-radius:8px;flex-shrink:0;
  background:var(--aglow);border:1px solid rgba(124,106,247,.4);
  color:var(--accent2);cursor:pointer;transition:background .18s;
  display:flex;align-items:center;justify-content:center;
}
.chat-send:hover{background:rgba(124,106,247,.22)}
.chat-send svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* FOOTER */
.footer{position:relative;z-index:1;text-align:center;padding:20px;border-top:1px solid var(--border);color:var(--muted);font-size:.73rem}
.footer span{font-family:var(--mono)}

::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:var(--borderh);border-radius:10px}

@media(max-width:860px){
  .stat-row{grid-template-columns:repeat(2,1fr)}
  .mid-row,.bot-row{grid-template-columns:1fr}
}
@media(max-width:600px){
  .navbar{padding:10px 16px}
  .hero{padding:48px 16px 36px}
  .container{padding:0 14px 60px}
  .grid{grid-template-columns:1fr}
  .stat-row{grid-template-columns:1fr 1fr}
  .chat-window{width:calc(100vw - 32px);right:16px;bottom:84px}
  .chat-fab{bottom:20px;right:16px}
}

/* GROUPED GRID */
.cat-group{margin-bottom:28px}
.cat-group-title{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent);margin-bottom:10px;display:flex;align-items:center;gap:8px;
  padding:0 2px;
}
.cat-group-title::after{content:'';flex:1;height:1px;background:var(--border)}
.cat-group-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}

/* CHAT LOAD BOX */
.chat-load-box{
  background:rgba(255,255,255,.06)!important;
  border:1px solid var(--border)!important;
  min-width:180px;
}
.chat-load-text{
  font-family:var(--mono);font-size:.72rem;color:var(--muted);
  animation:pulse 1.5s ease-in-out infinite;
}

/* ── LIVE CHAT SECTION ── */
.livechat-section{padding-bottom:60px;margin-top:40px}
.livechat-box{
  background:#111118;
  border:1.5px solid rgba(0,255,220,.25);
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 0 0 1px rgba(0,0,0,.6), 0 2px 32px rgba(0,255,220,.06);
  max-width:680px;
  margin:0 auto;
}
.livechat-header{
  padding:14px 18px;
  display:flex;align-items:center;gap:8px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.livechat-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--green);box-shadow:0 0 6px var(--green);
  animation:pulse 2s ease-in-out infinite;
}
.livechat-title{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.18em;
  text-transform:uppercase;color:rgba(255,255,255,.35);
}
.livechat-msgs{
  min-height:260px;max-height:360px;
  overflow-y:auto;padding:16px;
  display:flex;flex-direction:column;gap:10px;
  background:#111118;
  overscroll-behavior:contain;
}
.livechat-msgs::-webkit-scrollbar{width:3px}
.livechat-msgs::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:10px}

.lc-msg{display:flex;flex-direction:column;gap:3px;animation:fadeUp .25s var(--ease)}
.lc-msg.lc-bot{align-items:flex-start}
.lc-msg.lc-user{align-items:flex-end}
.lc-bubble{
  max-width:75%;padding:9px 13px;font-size:.82rem;line-height:1.55;border-radius:10px;
}
.lc-bot .lc-bubble{
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.08);
  color:var(--text);
  border-radius:4px 10px 10px 10px;
}
.lc-user .lc-bubble{
  background:var(--aglow);
  border:1px solid rgba(124,106,247,.3);
  color:var(--accent2);
  border-radius:10px 4px 10px 10px;
}
.lc-time{font-family:var(--mono);font-size:.58rem;color:var(--muted)}

.lc-info-box{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  border-radius:8px;padding:9px 13px;
  font-family:var(--mono);font-size:.72rem;color:rgba(255,255,255,.35);
  align-self:flex-start;
  transition:opacity .3s;
  min-width:160px;
}
.lc-typing{
  display:none;gap:4px;padding:9px 13px;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.08);
  border-radius:4px 10px 10px 10px;width:fit-content;
}
.lc-typing span{
  width:5px;height:5px;border-radius:50%;background:var(--muted);
  animation:typing 1.2s ease-in-out infinite;
}
.lc-typing span:nth-child(2){animation-delay:.2s}
.lc-typing span:nth-child(3){animation-delay:.4s}

.livechat-input-row{
  display:flex;gap:8px;padding:12px 14px;
  border-top:1px solid rgba(255,255,255,.06);
  background:#0e0e17;
}
.lc-input{
  flex:1;background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);border-radius:8px;
  padding:9px 12px;color:var(--text);font-family:var(--sans);font-size:.82rem;
  outline:none;transition:border-color .18s;
}
.lc-input:focus{border-color:rgba(124,106,247,.4)}
.lc-input::placeholder{color:var(--muted)}
.lc-send{
  width:38px;height:38px;border-radius:8px;flex-shrink:0;
  background:var(--aglow);border:1px solid rgba(124,106,247,.35);
  color:var(--accent2);cursor:pointer;transition:background .18s;
  display:flex;align-items:center;justify-content:center;
}
.lc-send:hover{background:rgba(124,106,247,.22)}
.lc-send svg{width:14px;height:14px}

/* sidebar WA icon fix */
.sb-item-icon svg{vertical-align:middle}
