@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=Share+Tech+Mono&family=Orbitron:wght@400;700;900&display=swap');

:root {
  --bg:       #050508;
  --bg2:      #0a0a10;
  --bg3:      #0f0f18;
  --accent:   #00ff88;
  --accent2:  #00ccff;
  --accent3:  #ff3366;
  --yellow:   #ffd700;
  --purple:   #9d00ff;
  --text:     #b0c4de;
  --text-dim: #4a5568;
  --border:   rgba(0,255,136,0.12);
  --font-main:'Orbitron', monospace;
  --font-mono:'Share Tech Mono', monospace;
  --font-retro:'Press Start 2P', monospace;
  --sidebar-w:280px;
  --topbar-h: 58px;
  --radius:   6px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

html,body{
  width:100%;min-height:100%;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-mono);
  font-size:14px;
  overflow-x:hidden;
}

/* SCANLINE */
body::after{
  content:'';position:fixed;inset:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,0.08) 2px,rgba(0,0,0,0.08) 4px);
  pointer-events:none;z-index:9999;
}

/* ANIMATED BG */
#bg-canvas{position:fixed;inset:0;z-index:0;}

/* TOPBAR */
#topbar{
  position:fixed;top:0;left:0;right:0;
  height:var(--topbar-h);
  background:rgba(5,5,8,0.95);
  border-bottom:1px solid var(--border);
  backdrop-filter:blur(12px);
  display:flex;align-items:center;
  padding:0 20px;gap:16px;
  z-index:1000;
}
.topbar-logo{
  font-family:var(--font-main);
  font-size:clamp(12px,2vw,18px);
  font-weight:900;
  letter-spacing:3px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  white-space:nowrap;
}
.topbar-logo span{
  -webkit-text-fill-color:var(--accent3);
  color:var(--accent3);
}
#topbar .spacer{flex:1;}
.topbar-user{
  font-size:11px;color:var(--accent2);
  text-shadow:0 0 8px var(--accent2);
  letter-spacing:1px;
  display:flex;align-items:center;gap:10px;
}
.topbar-user strong{color:var(--accent);}

#menu-toggle{
  background:none;border:none;cursor:pointer;
  display:flex;flex-direction:column;gap:5px;padding:6px;
  transition:transform 0.2s;
}
#menu-toggle:hover{transform:scale(1.1);}
#menu-toggle span{
  display:block;width:24px;height:2px;
  background:var(--accent);
  box-shadow:0 0 6px var(--accent);
  transition:all 0.3s;border-radius:2px;
}
#menu-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
#menu-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0);}
#menu-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* SIDEBAR */
#sidebar{
  position:fixed;top:var(--topbar-h);left:0;bottom:0;
  width:var(--sidebar-w);
  background:rgba(5,5,8,0.98);
  border-right:1px solid var(--border);
  backdrop-filter:blur(16px);
  transform:translateX(calc(-1 * var(--sidebar-w)));
  transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);
  z-index:999;overflow-y:auto;padding:16px 0;
}
#sidebar.open{transform:translateX(0);}
#sidebar-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,0.7);
  z-index:998;opacity:0;pointer-events:none;
  transition:opacity 0.35s;
}
#sidebar-overlay.show{opacity:1;pointer-events:all;}

.sb-logo{
  padding:12px 20px 20px;
  font-family:var(--font-main);
  font-size:14px;font-weight:900;
  letter-spacing:2px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.sb-logo span{-webkit-text-fill-color:var(--accent3);color:var(--accent3);}
.sb-user{
  padding:0 20px 16px;
  font-size:10px;color:var(--text-dim);letter-spacing:1px;
  border-bottom:1px solid var(--border);margin-bottom:8px;
}
.sb-section{
  padding:10px 20px 4px;
  font-size:8px;color:var(--text-dim);
  letter-spacing:3px;text-transform:uppercase;
  font-family:var(--font-retro);margin-top:6px;
}
.sb-item{
  display:flex;align-items:center;gap:12px;
  padding:11px 20px;color:var(--text);
  text-decoration:none;font-size:12px;
  letter-spacing:1px;transition:all 0.2s;
  border-left:3px solid transparent;cursor:pointer;
}
.sb-item:hover,.sb-item.active{
  color:var(--accent);
  background:rgba(0,255,136,0.06);
  border-left-color:var(--accent);
  text-shadow:0 0 8px var(--accent);
}
.sb-item .sb-icon{font-size:14px;width:18px;text-align:center;opacity:0.8;}
.sb-badge{
  margin-left:auto;
  background:var(--accent3);color:#fff;
  font-size:7px;padding:2px 6px;border-radius:10px;
  box-shadow:0 0 8px var(--accent3);
  font-family:var(--font-retro);
}
.sb-divider{height:1px;background:var(--border);margin:8px 16px;}

/* MAIN */
#main{
  margin-top:var(--topbar-h);
  padding:28px 24px;
  min-height:calc(100vh - var(--topbar-h));
  position:relative;z-index:1;
}

/* PAGE TRANSITION */
.page{display:none;animation:pageIn 0.4s ease;}
.page.active{display:block;}
@keyframes pageIn{
  from{opacity:0;transform:translateY(14px);}
  to{opacity:1;transform:translateY(0);}
}

/* CARDS */
.card{
  background:rgba(10,10,16,0.92);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:22px;position:relative;overflow:hidden;
  transition:border-color 0.3s,box-shadow 0.3s;
}
.card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--accent),var(--accent2),transparent);
  opacity:0.6;
}
.card:hover{border-color:rgba(0,255,136,0.25);box-shadow:0 0 20px rgba(0,255,136,0.06);}
.card-title{
  font-family:var(--font-main);font-size:11px;font-weight:700;
  color:var(--accent);text-shadow:0 0 8px var(--accent);
  letter-spacing:3px;margin-bottom:18px;
  display:flex;align-items:center;gap:10px;
}

/* STATS */
.stats-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:14px;margin-bottom:22px;
}
.stat-card{
  background:rgba(10,10,16,0.92);
  border:1px solid var(--border);
  border-radius:var(--radius);padding:18px;
  text-align:center;transition:all 0.3s;
}
.stat-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,0.5);}
.stat-val{
  font-family:var(--font-main);font-weight:700;
  font-size:clamp(16px,3vw,24px);margin-bottom:6px;
}
.stat-label{font-size:9px;color:var(--text-dim);letter-spacing:2px;text-transform:uppercase;}
.stat-card.green{border-color:rgba(0,255,136,0.25);}
.stat-card.green .stat-val{color:var(--accent);text-shadow:0 0 10px var(--accent);}
.stat-card.blue{border-color:rgba(0,204,255,0.25);}
.stat-card.blue .stat-val{color:var(--accent2);text-shadow:0 0 10px var(--accent2);}
.stat-card.red{border-color:rgba(255,51,102,0.25);}
.stat-card.red .stat-val{color:var(--accent3);text-shadow:0 0 10px var(--accent3);}
.stat-card.yellow{border-color:rgba(255,215,0,0.25);}
.stat-card.yellow .stat-val{color:var(--yellow);text-shadow:0 0 10px var(--yellow);}

/* FORMS */
.form-group{margin-bottom:16px;}
.form-label{
  display:block;font-size:9px;
  color:var(--accent2);text-shadow:0 0 6px var(--accent2);
  letter-spacing:2px;margin-bottom:7px;
  font-family:var(--font-retro);
}
.form-input{
  width:100%;
  background:rgba(0,204,255,0.04);
  border:1px solid rgba(0,204,255,0.2);
  border-radius:var(--radius);color:var(--text);
  font-family:var(--font-mono);font-size:14px;
  padding:11px 14px;outline:none;
  transition:all 0.3s;letter-spacing:1px;
}
.form-input:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 2px rgba(0,255,136,0.12),0 0 16px rgba(0,255,136,0.08);
  color:var(--accent);
}
.form-input::placeholder{color:var(--text-dim);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}

/* BUTTONS */
.btn{
  font-family:var(--font-retro);font-size:9px;
  padding:12px 24px;border:2px solid;
  border-radius:var(--radius);cursor:pointer;
  letter-spacing:2px;text-transform:uppercase;
  position:relative;overflow:hidden;
  transition:all 0.25s;
  display:inline-flex;align-items:center;gap:8px;
  text-decoration:none;white-space:nowrap;
}
.btn::before{
  content:'';position:absolute;inset:0;
  transform:scaleX(0);transform-origin:left;
  transition:transform 0.25s;z-index:0;
}
.btn span{position:relative;z-index:1;}
.btn:active{transform:scale(0.97);}

.btn-green{border-color:var(--accent);color:var(--accent);box-shadow:0 0 12px rgba(0,255,136,0.15);}
.btn-green::before{background:var(--accent);}
.btn-green:hover{color:#000;box-shadow:0 0 25px rgba(0,255,136,0.5);}
.btn-green:hover::before{transform:scaleX(1);}

.btn-blue{border-color:var(--accent2);color:var(--accent2);box-shadow:0 0 12px rgba(0,204,255,0.15);}
.btn-blue::before{background:var(--accent2);}
.btn-blue:hover{color:#000;box-shadow:0 0 25px rgba(0,204,255,0.5);}
.btn-blue:hover::before{transform:scaleX(1);}

.btn-red{border-color:var(--accent3);color:var(--accent3);box-shadow:0 0 12px rgba(255,51,102,0.15);}
.btn-red::before{background:var(--accent3);}
.btn-red:hover{color:#fff;box-shadow:0 0 25px rgba(255,51,102,0.5);}
.btn-red:hover::before{transform:scaleX(1);}

.btn-yellow{border-color:var(--yellow);color:var(--yellow);box-shadow:0 0 12px rgba(255,215,0,0.15);}
.btn-yellow::before{background:var(--yellow);}
.btn-yellow:hover{color:#000;box-shadow:0 0 25px rgba(255,215,0,0.5);}
.btn-yellow:hover::before{transform:scaleX(1);}

.btn-full{width:100%;justify-content:center;}
.btn-sm{font-size:7px;padding:8px 16px;letter-spacing:1px;}

/* RESULT */
.result-box{
  background:rgba(0,0,0,0.5);
  border:1px solid var(--border);
  border-radius:var(--radius);padding:18px;
  margin-top:18px;display:none;
  animation:pageIn 0.3s ease;
}
.result-box.show{display:block;}
.result-row{
  display:flex;align-items:flex-start;gap:12px;
  padding:9px 0;border-bottom:1px solid rgba(255,255,255,0.04);
  font-size:13px;
}
.result-row:last-child{border-bottom:none;}
.result-key{
  font-family:var(--font-retro);font-size:7px;
  color:var(--accent2);text-shadow:0 0 6px var(--accent2);
  letter-spacing:1px;min-width:140px;padding-top:2px;
}
.result-val{color:var(--accent);text-shadow:0 0 6px rgba(0,255,136,0.3);font-size:13px;word-break:break-all;}
.result-val.null-val{color:var(--text-dim);font-style:italic;}

/* TABLE */
.result-table{width:100%;border-collapse:collapse;font-size:12px;}
.result-table th{
  font-family:var(--font-retro);font-size:7px;
  color:var(--accent2);text-shadow:0 0 6px var(--accent2);
  letter-spacing:2px;padding:9px 12px;text-align:left;
  border-bottom:1px solid var(--border);
  background:rgba(0,204,255,0.04);
}
.result-table td{
  padding:9px 12px;border-bottom:1px solid rgba(255,255,255,0.03);
  color:var(--text);vertical-align:middle;font-family:var(--font-mono);
}
.result-table tr:hover td{background:rgba(0,255,136,0.03);}
.table-wrap{max-height:480px;overflow-y:auto;border-radius:var(--radius);}
.result-count{
  font-family:var(--font-retro);font-size:8px;
  color:var(--accent);letter-spacing:2px;margin-bottom:12px;
}

/* SPINNER */
.spinner{
  display:inline-block;width:16px;height:16px;
  border:2px solid rgba(0,255,136,0.2);
  border-top-color:var(--accent);
  border-radius:50%;animation:spin 0.7s linear infinite;
  vertical-align:middle;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* ALERT */
.alert{
  padding:11px 14px;border-radius:var(--radius);
  font-size:11px;letter-spacing:1px;
  margin-bottom:14px;border-left:3px solid;
  display:none;animation:pageIn 0.3s ease;
}
.alert.show{display:block;}
.alert-error{background:rgba(255,51,102,0.1);border-color:var(--accent3);color:var(--accent3);}
.alert-success{background:rgba(0,255,136,0.08);border-color:var(--accent);color:var(--accent);}
.alert-info{background:rgba(0,204,255,0.08);border-color:var(--accent2);color:var(--accent2);}
.alert-warn{background:rgba(255,215,0,0.08);border-color:var(--yellow);color:var(--yellow);}

/* TAGS */
.tag{
  display:inline-block;font-size:8px;
  padding:3px 8px;border-radius:3px;
  font-family:var(--font-retro);letter-spacing:1px;
}
.tag-green{background:rgba(0,255,136,0.1);color:var(--accent);border:1px solid rgba(0,255,136,0.25);}
.tag-blue{background:rgba(0,204,255,0.1);color:var(--accent2);border:1px solid rgba(0,204,255,0.25);}
.tag-red{background:rgba(255,51,102,0.1);color:var(--accent3);border:1px solid rgba(255,51,102,0.25);}
.tag-yellow{background:rgba(255,215,0,0.1);color:var(--yellow);border:1px solid rgba(255,215,0,0.25);}

/* PAGE TITLE */
.page-title{
  font-family:var(--font-main);font-weight:700;
  font-size:clamp(14px,2.5vw,20px);
  color:var(--accent);text-shadow:0 0 15px var(--accent);
  letter-spacing:4px;margin-bottom:4px;
}
.page-subtitle{font-size:11px;color:var(--text-dim);letter-spacing:1px;margin-bottom:24px;}

/* GRID */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
@media(max-width:768px){
  .grid-2,.grid-3{grid-template-columns:1fr;}
  #main{padding:18px 12px;}
  .stats-grid{grid-template-columns:1fr 1fr;}
  .form-row{grid-template-columns:1fr;}
}
@media(max-width:480px){.stats-grid{grid-template-columns:1fr;}}

/* COPY BTN */
.copy-btn{
  background:none;border:1px solid rgba(0,204,255,0.25);
  color:var(--accent2);font-size:9px;padding:2px 7px;
  border-radius:3px;cursor:pointer;transition:all 0.2s;
  font-family:var(--font-mono);margin-left:6px;
}
.copy-btn:hover{background:rgba(0,204,255,0.1);border-color:var(--accent2);}

/* LOG */
.log-entry{
  display:flex;align-items:center;gap:10px;
  padding:8px 12px;border-bottom:1px solid rgba(255,255,255,0.03);
  font-size:12px;transition:background 0.2s;
}
.log-entry:hover{background:rgba(0,255,136,0.03);}
.log-time{color:var(--text-dim);font-size:10px;min-width:65px;}
.log-type{min-width:90px;}
.log-val{color:var(--accent);font-family:var(--font-mono);}

/* MISC */
.neon-divider{height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);margin:20px 0;opacity:0.35;}
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:var(--bg);}
::-webkit-scrollbar-thumb{background:rgba(0,255,136,0.25);border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:rgba(0,255,136,0.45);}

/* ── AUTH ── */
.auth-page{
  min-height:100vh;display:flex;
  align-items:center;justify-content:center;
  padding:20px;position:relative;z-index:1;
}
.auth-container{
  width:100%;max-width:440px;
  perspective:1000px;
}
.auth-flipper{
  position:relative;
  -webkit-transition: -webkit-transform 0.6s cubic-bezier(0.4,0,0.2,1);
  transition: transform 0.6s cubic-bezier(0.4,0,0.2,1);
  -webkit-transform-style: preserve-3d;
  transform-style: preserve-3d;
  min-height:600px;
}
.auth-flipper.flipped{
  -webkit-transform: rotateY(180deg);
  transform: rotateY(180deg);
}
.auth-front,.auth-back{
  width:100%;
  background:rgba(8,8,14,0.97);
  border:1px solid var(--border);
  border-radius:10px;padding:36px 32px;
  position:absolute;top:0;left:0;
  overflow:hidden;
  box-shadow:0 0 60px rgba(0,255,136,0.06),0 20px 60px rgba(0,0,0,0.6);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  -webkit-transform-style: preserve-3d;
  transform-style: preserve-3d;
}
.auth-back{
  -webkit-transform:rotateY(180deg);
  transform:rotateY(180deg);
}
.auth-front{ -webkit-transform:rotateY(0deg); transform:rotateY(0deg); }
.auth-box-top{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--accent),var(--accent2),transparent);
  background-size:200% 100%;
  animation:borderFlow 3s linear infinite;
}
@keyframes borderFlow{
  0%{background-position:-100% 0;}
  100%{background-position:100% 0;}
}
.auth-logo{
  font-family:var(--font-main);font-weight:900;
  font-size:clamp(18px,4vw,26px);
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  text-align:center;letter-spacing:4px;margin-bottom:4px;
  animation:logoPulse 3s ease-in-out infinite;
}
.auth-logo span{-webkit-text-fill-color:var(--accent3);color:var(--accent3);}
@keyframes logoPulse{
  0%,100%{filter:drop-shadow(0 0 8px rgba(0,255,136,0.5));}
  50%{filter:drop-shadow(0 0 20px rgba(0,255,136,0.9));}
}
.auth-subtitle{
  text-align:center;font-size:9px;
  color:var(--text-dim);letter-spacing:3px;margin-bottom:28px;
  font-family:var(--font-retro);
}
.auth-switch{
  text-align:center;margin-top:18px;
  font-size:10px;color:var(--text-dim);letter-spacing:1px;
}
.auth-switch a{
  color:var(--accent2);text-decoration:none;
  text-shadow:0 0 6px var(--accent2);cursor:pointer;
}
.auth-switch a:hover{color:var(--accent);text-shadow:0 0 8px var(--accent);}

/* CAPTCHA */
.captcha-wrap{
  display:flex;align-items:center;gap:10px;
  background:rgba(0,0,0,0.4);
  border:1px solid var(--border);
  border-radius:var(--radius);padding:10px 14px;
  margin-bottom:16px;
}
.captcha-code{
  font-family:var(--font-retro);font-size:14px;
  color:var(--yellow);text-shadow:0 0 10px var(--yellow);
  letter-spacing:6px;flex:1;text-align:center;
  user-select:none;-webkit-user-select:none;
  filter:blur(0.3px);
}
.captcha-refresh{
  background:none;border:1px solid rgba(255,215,0,0.3);
  color:var(--yellow);font-size:16px;
  width:32px;height:32px;border-radius:4px;
  cursor:pointer;transition:all 0.2s;
  display:flex;align-items:center;justify-content:center;
}
.captcha-refresh:hover{background:rgba(255,215,0,0.1);}

/* QUICK ACCESS GRID */
.quick-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:12px;margin-bottom:22px;
}
.quick-card{
  background:rgba(10,10,16,0.92);
  border:1px solid var(--border);
  border-radius:var(--radius);padding:16px;
  text-align:center;cursor:pointer;
  transition:all 0.25s;text-decoration:none;
  display:block;
}
.quick-card:hover{
  border-color:var(--accent);
  box-shadow:0 0 20px rgba(0,255,136,0.12);
  transform:translateY(-2px);
}
.quick-card .qc-icon{font-size:24px;margin-bottom:8px;}
.quick-card .qc-label{
  font-family:var(--font-retro);font-size:7px;
  color:var(--accent);letter-spacing:2px;
}

/* PROGRESS BAR */
.progress-wrap{margin:8px 0;}
.progress-bar{
  height:4px;background:rgba(255,255,255,0.05);
  border-radius:2px;overflow:hidden;
}
.progress-fill{
  height:100%;border-radius:2px;
  transition:width 0.5s ease;
  background:linear-gradient(90deg,var(--accent),var(--accent2));
  box-shadow:0 0 8px var(--accent);
}

/* VULN BADGE */
.vuln-badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 10px;border-radius:4px;
  font-family:var(--font-retro);font-size:7px;
  letter-spacing:1px;
}
.vuln-critical{background:rgba(255,0,0,0.15);color:#ff4444;border:1px solid rgba(255,0,0,0.3);}
.vuln-high{background:rgba(255,100,0,0.15);color:#ff6400;border:1px solid rgba(255,100,0,0.3);}
.vuln-medium{background:rgba(255,215,0,0.15);color:var(--yellow);border:1px solid rgba(255,215,0,0.3);}
.vuln-low{background:rgba(0,255,136,0.1);color:var(--accent);border:1px solid rgba(0,255,136,0.25);}
.vuln-safe{background:rgba(0,204,255,0.1);color:var(--accent2);border:1px solid rgba(0,204,255,0.25);}
