/* ═══════════════ RESET & BASE ═══════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#040412;--bg2:#070718;--bg3:#131830;--card:rgba(11,15,38,0.55);
  --cyan:#00f2fe;--purple:#9d4edd;--blue:#3a86ff;--green:#06d6a0;
  --red:#ff0054;--amber:#ffbe0b;--pink:#ff007f;
  --text:#f8f9fa;--text2:#b0b3c6;--text3:#6c757d;
  --grad:linear-gradient(135deg,var(--cyan),var(--purple));
  --radius:12px;--radius2:20px;
  --glass-border:1px solid rgba(255,255,255,0.08);
  --glass-shadow:0 16px 40px rgba(0,0,0,0.5), 0 1px 1px rgba(255,255,255,0.05) inset;
  --glow:0 0 25px rgba(0,242,254,0.25);
  --cyan-glow:0 0 25px rgba(0,242,254,0.3);
  --purple-glow:0 0 25px rgba(157,78,221,0.3);
  --green-glow:0 0 25px rgba(6,214,160,0.3);
  --red-glow:0 0 25px rgba(255,0,84,0.3);
}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:'Inter',sans-serif;
  background:var(--bg);
  background-image: 
    radial-gradient(circle at 10% 20%, rgba(0, 242, 254, 0.05) 0%, transparent 40%),
    radial-gradient(circle at 90% 80%, rgba(157, 78, 221, 0.05) 0%, transparent 45%);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
}
a{text-decoration:none;color:inherit}
img{max-width:100%}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
code{font-family:'JetBrains Mono',monospace;background:var(--bg3);padding:3px 10px;border-radius:6px;font-size:.85em;color:var(--cyan);border:1px solid rgba(255,255,255,0.03)}

/* ═══════════════ NAVBAR ═══════════════ */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:18px 0;transition:all .4s cubic-bezier(0.16, 1, 0.3, 1)}
.navbar.scrolled{background:rgba(4,4,18,0.85);backdrop-filter:blur(24px);border-bottom:1px solid rgba(255,255,255,0.06);padding:12px 0;box-shadow:0 8px 30px rgba(0,0,0,0.3)}
.nav-container{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:10px;font-size:1.4rem;font-weight:800;color:#fff}
.nav-logo i{color:var(--cyan);font-size:1.5rem}
.logo-dot{color:var(--cyan)}
.nav-links{display:flex;list-style:none;gap:8px;align-items:center}
.nav-links a{padding:8px 16px;border-radius:8px;font-size:.9rem;font-weight:500;color:var(--text2);transition:all .3s}
.nav-links a:hover,.nav-links a.active{color:#fff;background:rgba(6,182,212,.1)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:5px}
.nav-toggle span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:all .3s}

/* Admin Badge in Navbar */
.admin-badge-nav{font-size:.65rem;background:var(--grad);color:#fff;padding:3px 8px;border-radius:50px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-left:-4px}

/* Login Admin Link */
.btn-admin-link{display:inline-flex!important;align-items:center;gap:6px;background:rgba(6,182,212,.1)!important;border:1px solid rgba(6,182,212,.2)!important;color:var(--cyan)!important;font-weight:600!important;border-radius:8px!important;transition:all .3s!important}
.btn-admin-link:hover{background:rgba(6,182,212,.2)!important;border-color:var(--cyan)!important;color:#fff!important}

/* Logout Button in Navbar */
.btn-logout-nav{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);color:var(--red);font-size:.9rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .3s;font-family:'Inter',sans-serif}
.btn-logout-nav:hover{background:rgba(239,68,68,.2);border-color:var(--red);color:#fff}

/* ═══════════════ HERO ═══════════════ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:100px 20px 60px}
.hero::before {
  content: "";
  position: absolute;
  top: 15%;
  left: 15%;
  width: 350px;
  height: 350px;
  background: radial-gradient(circle, rgba(0,242,254,0.18) 0%, transparent 75%);
  filter: blur(60px);
  z-index: 0;
  pointer-events: none;
  animation: pulse-auras 8s ease-in-out infinite alternate;
}
.hero::after {
  content: "";
  position: absolute;
  bottom: 15%;
  right: 15%;
  width: 450px;
  height: 450px;
  background: radial-gradient(circle, rgba(157,78,221,0.18) 0%, transparent 75%);
  filter: blur(80px);
  z-index: 0;
  pointer-events: none;
  animation: pulse-auras 10s ease-in-out infinite alternate-reverse;
}
@keyframes pulse-auras {
  0% { transform: scale(1) translate(0, 0); opacity: 0.7; }
  100% { transform: scale(1.2) translate(30px, -20px); opacity: 1; }
}
.hero-bg{position:absolute;inset:0;z-index:0}
.grid-overlay{position:absolute;inset:0;background-image:linear-gradient(rgba(0,242,254,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,242,254,.03) 1px,transparent 1px);background-size:60px 60px}
.floating-particles{position:absolute;inset:0}
.particle{position:absolute;width:4px;height:4px;background:var(--cyan);border-radius:50%;opacity:.4;animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0) scale(1);opacity:.4}50%{transform:translateY(-30px) scale(1.5);opacity:.8}}
.hero-content{position:relative;z-index:1;text-align:center;max-width:800px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;border-radius:50px;background:rgba(0,242,254,.08);border:1px solid rgba(0,242,254,.2);font-size:.85rem;color:var(--cyan);margin-bottom:24px;box-shadow:var(--glow);animation:badge-pulse 2s infinite}
@keyframes badge-pulse {
  0%, 100% { box-shadow: 0 0 15px rgba(0,242,254,0.15); }
  50% { box-shadow: 0 0 25px rgba(0,242,254,0.3); }
}
.hero-title{font-size:clamp(2.5rem,6vw,4.5rem);font-weight:900;line-height:1.1;margin-bottom:20px;color:#fff;letter-spacing:-1px}
.gradient-text{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-subtitle{font-size:1.1rem;color:var(--text2);max-width:600px;margin:0 auto 40px;line-height:1.7}
.hero-subtitle strong{color:var(--cyan);text-shadow:0 0 10px rgba(0,242,254,0.2)}
.hero-stats{display:flex;justify-content:center;gap:50px;margin-bottom:40px}
.stat-item{text-align:center;position:relative}
.stat-number{display:block;font-size:2.5rem;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stat-label{font-size:.8rem;color:var(--text3);text-transform:uppercase;letter-spacing:1.5px;font-weight:600}
.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:12px;font-weight:700;font-size:.95rem;border:none;cursor:pointer;transition:all .3s cubic-bezier(0.16, 1, 0.3, 1)}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 4px 25px rgba(0,242,254,.35);position:relative;overflow:hidden;z-index:1}
.btn-primary::before {
  content: "";
  position: absolute;
  top: 0; right: 0; bottom: 0; left: 0;
  background: linear-gradient(135deg, var(--purple), var(--cyan));
  z-index: -1;
  opacity: 0;
  transition: opacity 0.5s ease;
}
.btn-primary:hover::before { opacity: 1; }
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 35px rgba(0,242,254,.5)}
.btn-outline{background:transparent;color:var(--text);border:1px solid rgba(255,255,255,0.15)}
.btn-outline:hover{border-color:var(--cyan);color:var(--cyan);box-shadow:0 0 15px rgba(0,242,254,0.15);transform:translateY(-3px)}
.btn-sm{padding:8px 18px;font-size:.85rem;border-radius:8px}

/* Scroll Indicator */
.scroll-indicator{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text3);font-size:.75rem;animation:bounce 2s infinite}
.mouse{width:24px;height:38px;border:2px solid var(--text3);border-radius:12px;position:relative}
.wheel{width:4px;height:8px;background:var(--text3);border-radius:2px;position:absolute;top:6px;left:50%;transform:translateX(-50%);animation:scroll 2s infinite}
@keyframes scroll{0%{opacity:1;top:6px}100%{opacity:0;top:20px}}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* ═══════════════ SECTIONS ═══════════════ */
.section{padding:100px 0;position:relative}
.section-dark{
  background:var(--bg2);
  background-image: radial-gradient(circle at 50% 50%, rgba(157, 78, 221, 0.04) 0%, transparent 60%);
}
.section-header{text-align:center;margin-bottom:60px}
.section-tag{display:inline-flex;align-items:center;gap:8px;padding:6px 18px;border-radius:50px;background:rgba(0,242,254,.08);border:1px solid rgba(0,242,254,.15);font-size:.8rem;color:var(--cyan);margin-bottom:16px;font-weight:600;text-transform:uppercase;letter-spacing:1px}
.section-title{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:900;color:#fff;margin-bottom:12px;letter-spacing:-0.5px}
.section-desc{color:var(--text2);max-width:600px;margin:0 auto;font-size:1rem}

/* ═══════════════ SCANNER ═══════════════ */
.scanner-card{
  background:var(--card);
  backdrop-filter:blur(24px) saturate(180%);
  border:var(--glass-border);
  border-radius:var(--radius2);
  padding:36px;
  box-shadow:var(--glass-shadow);
  transition:all .4s cubic-bezier(0.16, 1, 0.3, 1);
  position: relative;
  overflow: hidden;
}
.scanner-card::before {
  content: "";
  position: absolute;
  top: 0; left: -100%;
  width: 50%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(0,242,254,0.06), transparent);
  transition: 0.5s;
  pointer-events: none;
}
.scanner-card:hover::before {
  left: 150%;
  transition: 1.2s ease-in-out;
}
@keyframes scan-glow {
  0%, 100% { border-color: rgba(0,242,254,0.15); box-shadow: var(--glass-shadow); }
  50% { border-color: rgba(157,78,221,0.5); box-shadow: 0 0 30px rgba(157,78,221,0.25), var(--glass-shadow); }
}
.scanner-card.scanning {
  animation: scan-glow 2s infinite ease-in-out;
}
.scan-form{display:flex;flex-direction:column;gap:18px}
.input-wrapper{
  display:flex;
  align-items:center;
  background:rgba(4,4,18,0.55);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:var(--radius);
  padding:6px 6px 6px 18px;
  transition:all .4s cubic-bezier(0.16, 1, 0.3, 1);
  gap:12px;
  box-shadow: inset 0 2px 4px rgba(0,0,0,0.4);
}
.input-wrapper:focus-within{
  border-color:var(--cyan);
  box-shadow: 0 0 25px rgba(0,242,254,0.22), inset 0 2px 4px rgba(0,0,0,0.2);
  background: rgba(4,4,18,0.75);
}
.input-icon{color:var(--cyan);font-size:1.2rem;text-shadow:0 0 10px rgba(0,242,254,0.3)}
#urlInput{flex:1;background:none;border:none;color:#fff;font-size:1rem;padding:12px 0;outline:none;font-family:'Inter',sans-serif;font-weight:500}
#urlInput::placeholder{color:var(--text3)}
.btn-scan{padding:14px 28px;background:var(--grad);color:#fff;border:none;border-radius:10px;font-weight:700;font-size:.95rem;cursor:pointer;white-space:nowrap;transition:all .3s;font-family:'Inter',sans-serif;box-shadow:0 4px 15px rgba(0,242,254,0.2)}
.btn-scan:hover{transform:scale(1.03);box-shadow:0 8px 25px rgba(0,242,254,0.4)}
.btn-scan .btn-loading{display:none}
.btn-scan.loading .btn-text{display:none}
.btn-scan.loading .btn-loading{display:inline-flex;align-items:center;gap:8px}
.quick-test{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:.85rem;color:var(--text3);margin-top:4px}
.chip{padding:6px 16px;border-radius:50px;font-size:.8rem;border:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.03);color:var(--text2);cursor:pointer;transition:all .3s cubic-bezier(0.16, 1, 0.3, 1);font-family:'Inter',sans-serif}
.chip:hover{border-color:var(--cyan);color:var(--cyan);background:rgba(0,242,254,0.05);transform:translateY(-1px)}
.chip-danger:hover{border-color:var(--red);color:var(--red);background:rgba(255,0,84,0.05)}

/* ═══════════════ RESULT PANEL ═══════════════ */
.result-panel{margin-top:40px;animation:fadeUp .6s cubic-bezier(0.16, 1, 0.3, 1)}
@keyframes fadeUp{from{opacity:0;transform:translateY(25px)}to{opacity:1;transform:translateY(0)}}
.result-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:24px;margin-bottom:24px}
.result-card{
  background:var(--card);
  backdrop-filter:blur(24px) saturate(180%);
  border:var(--glass-border);
  border-radius:var(--radius2);
  padding:32px;
  box-shadow:var(--glass-shadow);
  transition:all .4s cubic-bezier(0.16, 1, 0.3, 1);
}
.result-card:hover{
  border-color: rgba(255,255,255,0.12);
  box-shadow: 0 20px 50px rgba(0,0,0,0.6), 0 1px 1px rgba(255,255,255,0.08) inset;
}
.result-main{text-align:center;position:relative}

/* Gauge */
.gauge-container{position:relative;width:210px;margin:0 auto 20px}
.gauge-svg{width:100%;display:block}
.gauge-bg{stroke:var(--bg3)}
.gauge-fill{stroke:var(--cyan);stroke-dasharray:251;stroke-dashoffset:251;transition:stroke-dashoffset 1.8s cubic-bezier(0.16, 1, 0.3, 1),stroke .5s;filter:drop-shadow(0 0 8px rgba(0,242,254,0.25))}
.gauge-value{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);font-size:2.2rem;font-weight:900;color:#fff;letter-spacing:-1px}
.status-badge{display:inline-block;padding:10px 28px;border-radius:50px;font-weight:800;font-size:.95rem;text-transform:uppercase;letter-spacing:1.5px;box-shadow:0 4px 15px rgba(0,0,0,0.2)}
.status-badge.safe{background:rgba(6,214,160,0.12);color:var(--green);border:1px solid rgba(6,214,160,0.3);box-shadow:0 0 15px rgba(6,214,160,0.1)}
.status-badge.danger{background:rgba(255,0,84,0.12);color:var(--red);border:1px solid rgba(255,0,84,0.3);box-shadow:0 0 15px rgba(255,0,84,0.1)}
.result-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:24px;padding-top:24px;border-top:1px solid rgba(255,255,255,0.06)}
.meta-item{text-align:center}
.meta-label{display:block;font-size:.7rem;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px;font-weight:600}
.meta-value{font-size:1.1rem;font-weight:800;color:#fff}

/* Factors */
.factors-tabs{display:flex;gap:10px;margin-bottom:20px}
.factor-tab{flex:1;padding:12px;background:rgba(4,4,18,0.4);border:1px solid rgba(255,255,255,0.06);border-radius:10px;color:var(--text2);font-size:.85rem;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(0.16, 1, 0.3, 1);font-family:'Inter',sans-serif;display:flex;align-items:center;justify-content:center;gap:8px}
.factor-tab:hover{border-color:rgba(255,255,255,0.15);color:#fff}
.factor-tab.active{border-color:var(--cyan);color:var(--cyan);background:rgba(0,242,254,0.05);box-shadow:0 0 15px rgba(0,242,254,0.1)}
.factor-list{max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}
.factor-list::-webkit-scrollbar{width:4px}
.factor-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:4px}
.factor-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:rgba(4,4,18,0.4);border-radius:10px;font-size:.88rem;transition:transform .2s}
.factor-item:hover{transform:translateX(3px)}
.factor-item.risk{border-left:3px solid var(--red)}
.factor-item.safe{border-left:3px solid var(--green)}
.factor-item i{font-size:.8rem}
.factor-item.risk i{color:var(--red);text-shadow:0 0 8px rgba(255,0,84,0.4)}
.factor-item.safe i{color:var(--green)}

/* Feature Table */
.feature-table-card h3{margin-bottom:16px;font-size:1.1rem;color:#fff;display:flex;align-items:center;gap:8px}
.table-responsive{overflow-x:auto}
.feature-table{width:100%;border-collapse:collapse;font-size:.85rem}
.feature-table th{background:var(--bg);padding:10px 14px;text-align:left;color:var(--text2);font-weight:600;border-bottom:1px solid var(--bg3);white-space:nowrap}
.feature-table td{padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.03)}
.feature-table tr:hover td{background:rgba(6,182,212,.03)}
.val-safe{color:var(--green);font-weight:600}
.val-suspicious{color:var(--amber);font-weight:600}
.val-danger{color:var(--red);font-weight:600}
.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px}

/* ═══════════════ DASHBOARD ═══════════════ */
.dashboard-alert{background:rgba(0,242,254,.06);border:1px solid rgba(0,242,254,.15);border-radius:var(--radius);padding:18px 24px;margin-bottom:30px;display:flex;align-items:center;gap:12px;color:var(--cyan);font-size:.9rem;box-shadow:var(--glow)}
.metric-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:40px}
.metric-card{
  background:var(--card);
  backdrop-filter:blur(24px) saturate(180%);
  border:var(--glass-border);
  border-radius:var(--radius2);
  padding:26px;
  box-shadow:var(--glass-shadow);
  display:flex;
  flex-direction:column;
  gap:14px;
  position:relative;
  overflow:hidden;
  transition:all .4s cubic-bezier(0.16, 1, 0.3, 1);
}
.metric-card:nth-child(1){border-left:4px solid var(--green)}
.metric-card:nth-child(2){border-left:4px solid var(--blue)}
.metric-card:nth-child(3){border-left:4px solid var(--purple)}
.metric-card:nth-child(4){border-left:4px solid var(--amber)}

.metric-card:nth-child(1):hover{border-color:rgba(6,214,160,0.4);box-shadow:0 16px 35px rgba(6,214,160,0.1),var(--glass-shadow);transform:translateY(-5px)}
.metric-card:nth-child(2):hover{border-color:rgba(58,134,255,0.4);box-shadow:0 16px 35px rgba(58,134,255,0.1),var(--glass-shadow);transform:translateY(-5px)}
.metric-card:nth-child(3):hover{border-color:rgba(157,78,221,0.4);box-shadow:0 16px 35px rgba(157,78,221,0.1),var(--glass-shadow);transform:translateY(-5px)}
.metric-card:nth-child(4):hover{border-color:rgba(255,190,11,0.4);box-shadow:0 16px 35px rgba(255,190,11,0.1),var(--glass-shadow);transform:translateY(-5px)}

.metric-icon{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(6,214,160,.12);color:var(--green);font-size:1.2rem;box-shadow:0 0 15px rgba(6,214,160,0.12)}
.metric-icon.icon-blue{background:rgba(58,134,255,.12);color:var(--blue);box-shadow:0 0 15px rgba(58,134,255,0.12)}
.metric-icon.icon-purple{background:rgba(157,78,221,.12);color:var(--purple);box-shadow:0 0 15px rgba(157,78,221,0.12)}
.metric-icon.icon-amber{background:rgba(255,190,11,.12);color:var(--amber);box-shadow:0 0 15px rgba(255,190,11,0.12)}
.metric-value{font-size:2rem;font-weight:900;color:#fff;letter-spacing:-0.5px}
.metric-label{font-size:.8rem;color:var(--text3);text-transform:uppercase;letter-spacing:1px;font-weight:600}
.metric-bar{height:5px;background:var(--bg3);border-radius:4px;overflow:hidden;margin-top:auto}
.metric-bar-fill{height:100%;background:var(--green);border-radius:4px;width:0;transition:width 1.8s cubic-bezier(0.16, 1, 0.3, 1)}
.bar-blue{background:var(--blue)}.bar-purple{background:var(--purple)}.bar-amber{background:var(--amber)}

/* Charts */
.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:30px}
.chart-card{
  background:var(--card);
  backdrop-filter:blur(24px) saturate(180%);
  border:var(--glass-border);
  border-radius:var(--radius2);
  padding:28px;
  box-shadow:var(--glass-shadow);
  transition:all .4s cubic-bezier(0.16, 1, 0.3, 1);
}
.chart-card:hover{
  border-color:rgba(255,255,255,0.12);
  box-shadow:0 20px 45px rgba(0,0,0,0.55);
}
.chart-card h3{font-size:1.05rem;color:#fff;margin-bottom:20px;display:flex;align-items:center;gap:8px;font-weight:700}
.chart-card h3 i{color:var(--cyan);text-shadow:0 0 10px rgba(0,242,254,0.3)}
.chart-body{position:relative;min-height:280px}

/* Confusion Matrix */
.confusion-matrix{display:grid;grid-template-columns:auto 1fr 1fr;grid-template-rows:auto 1fr 1fr;gap:8px;max-width:350px;margin:20px auto}
.cm-cell{display:flex;align-items:center;justify-content:center;padding:22px;border-radius:12px;font-weight:800;font-size:1.3rem;box-shadow:inset 0 1px 1px rgba(255,255,255,0.05);transition:all .3s}
.cm-cell:hover{transform:scale(1.04)}
.cm-header{font-size:.78rem;color:var(--text3);text-transform:uppercase;letter-spacing:1px;font-weight:700;text-align:center;padding:8px}
.cm-tp{background:rgba(6,214,160,.12);color:var(--green);border:1px solid rgba(6,214,160,.25);box-shadow:0 0 15px rgba(6,214,160,0.05)}
.cm-tn{background:rgba(58,134,255,.12);color:var(--blue);border:1px solid rgba(58,134,255,.25);box-shadow:0 0 15px rgba(58,134,255,0.05)}
.cm-fp{background:rgba(255,0,84,.12);color:var(--red);border:1px solid rgba(255,0,84,.25);box-shadow:0 0 15px rgba(255,0,84,0.05)}
.cm-fn{background:rgba(255,190,11,.12);color:var(--amber);border:1px solid rgba(255,190,11,.25);box-shadow:0 0 15px rgba(255,190,11,0.05)}
.cm-corner{visibility:hidden}

/* Model Info */
.model-info-card{
  background:var(--card);
  backdrop-filter:blur(24px) saturate(180%);
  border:var(--glass-border);
  border-radius:var(--radius2);
  padding:28px;
  box-shadow:var(--glass-shadow);
}
.model-info-card h3{font-size:1.1rem;color:#fff;margin-bottom:20px;display:flex;align-items:center;gap:8px;font-weight:700}
.model-info-card h3 i{color:var(--cyan);text-shadow:0 0 10px rgba(0,242,254,0.3)}
.info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}
.info-item{background:rgba(4,4,18,0.45);border-radius:10px;padding:14px 18px;border:1px solid rgba(255,255,255,0.04);transition:transform .2s}
.info-item:hover{transform:translateY(-2px)}
.info-item .info-label{font-size:.75rem;color:var(--text3);text-transform:uppercase;letter-spacing:1px;display:block;margin-bottom:6px;font-weight:600}
.info-item .info-val{font-size:1.05rem;font-weight:800;color:#fff;font-family:'JetBrains Mono',monospace}

/* ═══════════════ DATASET ═══════════════ */
.dataset-overview{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:50px}
.ds-card{
  background:var(--card);
  backdrop-filter:blur(24px) saturate(180%);
  border:var(--glass-border);
  border-radius:var(--radius2);
  padding:32px;
  text-align:center;
  box-shadow:var(--glass-shadow);
  transition:all .4s cubic-bezier(0.16, 1, 0.3, 1);
}
.ds-card:hover{
  transform:translateY(-6px);
  border-color:rgba(0,242,254,0.35);
  box-shadow:0 16px 35px rgba(0,242,254,0.15),var(--glass-shadow);
}
.ds-card i{font-size:2.2rem;color:var(--cyan);margin-bottom:14px;text-shadow:0 0 15px rgba(0,242,254,0.3)}
.ds-card h4{font-size:2.2rem;font-weight:900;color:#fff;margin-bottom:6px;letter-spacing:-0.5px}
.ds-card p{color:var(--text3);font-size:.85rem;text-transform:uppercase;letter-spacing:1px;font-weight:600}
.feature-cards-section h3{font-size:1.3rem;color:#fff;margin-bottom:28px;text-align:center;font-weight:700}
.feature-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px;margin-bottom:40px}
.f-card{
  background:rgba(255,255,255,0.02);
  border:1px solid rgba(255,255,255,0.05);
  border-radius:var(--radius);
  padding:20px;
  transition:all .3s cubic-bezier(0.16, 1, 0.3, 1);
}
.f-card:hover{
  border-color:rgba(157,78,221,0.35);
  background:rgba(157,78,221,0.04);
  transform:translateY(-4px);
  box-shadow:0 12px 24px rgba(0,0,0,0.35);
}
.f-card .f-num{font-size:.72rem;color:var(--text3);margin-bottom:6px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px}
.f-card .f-name{font-weight:700;color:var(--cyan);font-size:.88rem;margin-bottom:8px;font-family:'JetBrains Mono',monospace;text-shadow:0 0 8px rgba(0,242,254,0.1)}
.f-card .f-desc{font-size:.82rem;color:var(--text2);line-height:1.6}
.reference-card{
  background:var(--card);
  backdrop-filter:blur(24px) saturate(180%);
  border:var(--glass-border);
  border-radius:var(--radius2);
  padding:32px;
  box-shadow:var(--glass-shadow);
}
.reference-card h3{color:#fff;margin-bottom:18px;display:flex;align-items:center;gap:8px;font-weight:700}
.reference-card h3 i{color:var(--cyan);text-shadow:0 0 10px rgba(0,242,254,0.3)}
.reference-card p{color:var(--text2);font-size:.9rem;margin-bottom:14px;line-height:1.7}
.reference-card a{color:var(--cyan);text-decoration:none;border-bottom:1px dashed var(--cyan);transition:border-bottom .3s}
.reference-card a:hover{border-bottom-style:solid}

/* ═══════════════ HISTORY ═══════════════ */
.history-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.history-stats{display:flex;gap:20px;font-size:.88rem;color:var(--text2);font-weight:500}
.history-stats span{color:var(--cyan);font-weight:800;text-shadow:0 0 8px rgba(0,242,254,0.2)}
.history-table-wrap{
  overflow-x:auto;
  background:var(--card);
  backdrop-filter:blur(24px) saturate(180%);
  border:var(--glass-border);
  border-radius:var(--radius2);
  box-shadow:var(--glass-shadow);
}
.history-table{width:100%;border-collapse:collapse;font-size:.85rem}
.history-table th{padding:16px 20px;text-align:left;color:var(--text3);font-weight:700;border-bottom:1px solid rgba(255,255,255,0.06);background:rgba(4,4,18,0.45);text-transform:uppercase;font-size:.78rem;letter-spacing:1px}
.history-table td{padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.04)}
.history-table tr:hover td{background:rgba(0,242,254,.04)}
.empty-state{text-align:center;padding:70px 20px!important;color:var(--text3);font-size:.92rem}
.empty-state i{font-size:2.5rem;margin-bottom:12px;display:block;color:var(--bg3)}
.badge{display:inline-block;padding:5px 14px;border-radius:50px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0.5px}
.badge-safe{background:rgba(6,214,160,.12);color:var(--green);border:1px solid rgba(6,214,160,0.2)}
.badge-danger{background:rgba(255,0,84,.12);color:var(--red);border:1px solid rgba(255,0,84,0.2)}

/* ═══════════════ LOGIN PAGE ═══════════════ */
.login-page{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
  padding:20px;
  background-image: 
    radial-gradient(circle at 50% 50%, rgba(0, 242, 254, 0.08) 0%, transparent 50%),
    radial-gradient(circle at 10% 90%, rgba(157, 78, 221, 0.08) 0%, transparent 40%);
}
.login-bg{position:absolute;inset:0;z-index:0}
.login-container{position:relative;z-index:1;width:100%;max-width:440px}
.login-card{
  background:rgba(11,15,38,0.65);
  backdrop-filter:blur(30px);
  border:var(--glass-border);
  border-radius:var(--radius2);
  padding:44px 40px;
  box-shadow:0 30px 70px rgba(0,0,0,0.6), 0 0 50px rgba(0,242,254,0.05);
  animation:fadeUp .7s cubic-bezier(0.16, 1, 0.3, 1);
}
.login-logo{text-align:center;margin-bottom:36px}
.login-logo-icon{
  width:76px;
  height:76px;
  margin:0 auto 18px;
  background:var(--grad);
  border-radius:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:2.2rem;
  color:#fff;
  box-shadow:0 8px 32px rgba(0,242,254,.35);
  animation:pulse-glow 3s ease-in-out infinite;
}
@keyframes pulse-glow{0%,100%{box-shadow:0 8px 32px rgba(0,242,254,.35);transform:scale(1)}50%{box-shadow:0 8px 48px rgba(0,242,254,.6);transform:scale(1.03)}}
.login-logo h1{font-size:1.9rem;font-weight:900;color:#fff;margin-bottom:6px;letter-spacing:-0.5px}
.login-logo p{color:var(--text3);font-size:.85rem;text-transform:uppercase;letter-spacing:2px;font-weight:700}

/* Login Alert */
.login-alert{display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:var(--radius);font-size:.88rem;margin-bottom:24px;animation:fadeUp .3s cubic-bezier(0.16, 1, 0.3, 1)}
.login-alert.error{background:rgba(255,0,84,.1);border:1px solid rgba(255,0,84,.2);color:var(--red)}
.login-alert.success{background:rgba(6,214,160,.1);border:1px solid rgba(6,214,160,.2);color:var(--green)}

/* Login Form */
.login-form{display:flex;flex-direction:column;gap:22px}
.form-group label{display:flex;align-items:center;gap:6px;font-size:.8rem;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.form-group label i{color:var(--cyan);font-size:.78rem;text-shadow:0 0 8px rgba(0,242,254,0.3)}
.form-group input{
  width:100%;
  padding:14px 18px;
  background:rgba(4,4,18,0.55);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:var(--radius);
  color:#fff;
  font-size:.95rem;
  font-family:'Inter',sans-serif;
  transition:all .3s cubic-bezier(0.16, 1, 0.3, 1);
  outline:none;
  box-shadow:inset 0 2px 4px rgba(0,0,0,0.3);
}
.form-group input:focus{
  border-color:var(--cyan);
  box-shadow:0 0 25px rgba(0,242,254,0.2), inset 0 2px 4px rgba(0,0,0,0.1);
  background:rgba(4,4,18,0.75);
}
.form-group input::placeholder{color:var(--text3)}
.password-wrapper{position:relative}
.password-wrapper input{padding-right:48px}
.toggle-password{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:40px;height:40px;background:none;border:none;color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:color .3s}
.toggle-password:hover{color:var(--cyan)}

/* Login Button */
.btn-login{width:100%;padding:14px;background:var(--grad);color:#fff;border:none;border-radius:var(--radius);font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s cubic-bezier(0.16, 1, 0.3, 1);font-family:'Inter',sans-serif;box-shadow:0 4px 20px rgba(0,242,254,.3)}
.btn-login:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,242,254,.5)}
.btn-login .btn-loading{display:none}
.btn-login.loading .btn-text{display:none}
.btn-login.loading .btn-loading{display:inline-flex;align-items:center;gap:8px}
.btn-login:disabled{opacity:.7;cursor:not-allowed;transform:none}

/* Login Footer */
.login-footer{text-align:center;margin-top:24px;padding-top:20px;border-top:1px solid rgba(255,255,255,.05)}
.login-footer a{color:var(--text3);font-size:.85rem;transition:color .3s;display:inline-flex;align-items:center;gap:6px}
.login-footer a:hover{color:var(--cyan)}
.login-info{text-align:center;margin-top:20px}
.login-info p{color:var(--text3);font-size:.8rem;display:inline-flex;align-items:center;gap:6px}
.login-info i{color:var(--cyan)}

/* ═══════════════ HYPERPARAMETER SECTION ═══════════════ */
.hp-current-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;margin-bottom:40px}
.hp-card{
  background:var(--card);
  backdrop-filter:blur(24px) saturate(180%);
  border:var(--glass-border);
  border-radius:var(--radius2);
  padding:24px;
  box-shadow:var(--glass-shadow);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
  text-align:center;
  transition:all .4s cubic-bezier(0.16, 1, 0.3, 1);
}
.hp-card:hover{
  border-color:rgba(0,242,254,0.35);
  transform:translateY(-5px);
  box-shadow:0 16px 35px rgba(0,242,254,0.15),var(--glass-shadow);
}
.hp-card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(6,214,160,.12);color:var(--green);font-size:1.2rem;box-shadow:0 0 15px rgba(6,214,160,0.1)}
.hp-card-icon.icon-blue{background:rgba(58,134,255,.12);color:var(--blue);box-shadow:0 0 15px rgba(58,134,255,0.1)}
.hp-card-icon.icon-purple{background:rgba(157,78,221,.12);color:var(--purple);box-shadow:0 0 15px rgba(157,78,221,0.1)}
.hp-card-icon.icon-amber{background:rgba(255,190,11,.12);color:var(--amber);box-shadow:0 0 15px rgba(255,190,11,0.1)}
.hp-card-value{font-size:1.68rem;font-weight:900;color:#fff;font-family:'JetBrains Mono',monospace;letter-spacing:-0.5px}
.hp-card-label{font-size:.78rem;color:var(--cyan);font-weight:700;font-family:'JetBrains Mono',monospace;letter-spacing:0.5px}
.hp-card-desc{font-size:.72rem;color:var(--text3);line-height:1.5}

/* HP Form Card */
.hp-form-card{
  background:var(--card);
  backdrop-filter:blur(24px) saturate(180%);
  border:var(--glass-border);
  border-radius:var(--radius2);
  padding:32px;
  box-shadow:var(--glass-shadow);
}
.hp-form-card h3{font-size:1.1rem;color:#fff;margin-bottom:24px;display:flex;align-items:center;gap:8px;font-weight:700}
.hp-form-card h3 i{color:var(--cyan);text-shadow:0 0 10px rgba(0,242,254,0.3)}
.hp-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;margin-bottom:24px}
.hp-field label{display:block;font-size:.8rem;font-weight:700;color:var(--text2);margin-bottom:8px;font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:0.5px}
.hp-field label i{color:var(--cyan);margin-right:4px}
.hp-field .hp-range{color:var(--text3);font-weight:500;font-family:'Inter',sans-serif;text-transform:none;letter-spacing:0}
.hp-field input,.hp-field select{
  width:100%;
  padding:12px 16px;
  background:rgba(4,4,18,0.55);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:var(--radius);
  color:#fff;
  font-size:.95rem;
  font-family:'JetBrains Mono',monospace;
  transition:all .3s cubic-bezier(0.16, 1, 0.3, 1);
  outline:none;
  -webkit-appearance:none;
  appearance:none;
  box-shadow:inset 0 2px 4px rgba(0,0,0,0.3);
}
.hp-field select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.hp-field input:focus,.hp-field select:focus{
  border-color:var(--cyan);
  box-shadow:0 0 25px rgba(0,242,254,0.2), inset 0 2px 4px rgba(0,0,0,0.1);
  background:rgba(4,4,18,0.75);
}

/* HP Alert */
.hp-alert{display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:var(--radius);font-size:.9rem;margin-bottom:20px;animation:fadeUp .3s cubic-bezier(0.16, 1, 0.3, 1)}
.hp-alert.success{background:rgba(6,214,160,.1);border:1px solid rgba(6,214,160,.2);color:var(--green)}
.hp-alert.error{background:rgba(255,0,84,.1);border:1px solid rgba(255,0,84,.2);color:var(--red)}

/* Train Button */
.btn-train{width:100%;padding:14px 28px;font-size:1rem;justify-content:center;box-shadow:0 4px 15px rgba(0,242,254,0.2)}
.btn-train:hover{box-shadow:0 8px 25px rgba(0,242,254,0.4);transform:scale(1.01)}
.btn-train .btn-loading{display:none}
.btn-train.loading .btn-text{display:none}
.btn-train.loading .btn-loading{display:inline-flex;align-items:center;gap:8px}
.btn-train:disabled{opacity:.7;cursor:not-allowed;transform:none}

/* ═══════════════ FOOTER ═══════════════ */
.footer{background:var(--bg2);border-top:1px solid rgba(255,255,255,0.06);padding:60px 0 0}
.footer-content{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;padding-bottom:40px}
.footer-brand h3{color:#fff;font-size:1.4rem;margin-bottom:14px;display:flex;align-items:center;gap:8px;font-weight:800}
.footer-brand h3 i{color:var(--cyan);text-shadow:0 0 10px rgba(0,242,254,0.35)}
.footer-brand p{color:var(--text3);font-size:.85rem;line-height:1.7}
.footer-links h4{color:#fff;font-size:.95rem;margin-bottom:18px;font-weight:700;text-transform:uppercase;letter-spacing:1px}
.footer-links a{display:block;color:var(--text3);font-size:.85rem;padding:5px 0;transition:color .3s cubic-bezier(0.16, 1, 0.3, 1)}
.footer-links a:hover{color:var(--cyan);transform:translateX(2px)}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.05);padding:24px 0;text-align:center;color:var(--text3);font-size:.8rem;font-weight:500}

/* ═══════════════ RESPONSIVE ═══════════════ */
@media(max-width:1024px){
  .metric-cards,.dataset-overview{grid-template-columns:repeat(2,1fr);gap:20px}
  .charts-grid{grid-template-columns:1fr}
  .footer-content{grid-template-columns:1fr 1fr}
  .hp-current-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:rgba(4,4,18,.98);backdrop-filter:blur(24px);flex-direction:column;padding:20px;border-bottom:1px solid rgba(255,255,255,0.08)}
  .nav-links.open{display:flex}
  .nav-toggle{display:flex}
  .hero-stats{gap:24px}
  .result-grid{grid-template-columns:1fr}
  .metric-cards{grid-template-columns:1fr 1fr}
  .dataset-overview{grid-template-columns:1fr 1fr}
  .result-meta{grid-template-columns:1fr;gap:16px}
  .footer-content{grid-template-columns:1fr}
  .input-wrapper{flex-direction:column;padding:12px;align-items:stretch}
  #urlInput{padding:8px 0;text-align:center}
  .btn-scan{width:100%;justify-content:center}
  .hp-current-grid{grid-template-columns:repeat(2,1fr)}
  .hp-form-grid{grid-template-columns:1fr 1fr}
  .login-card{padding:36px 28px}
}
@media(max-width:480px){
  .metric-cards,.dataset-overview{grid-template-columns:1fr}
  .hero-title{font-size:2rem}
  .hp-current-grid{grid-template-columns:1fr}
  .hp-form-grid{grid-template-columns:1fr}
}
