/* ══════════ Proactive Defender — Cyber Audit Landing ══════════ */
:root{
  --bg:#060a14;--bg2:#0b1020;
  --text:#e9edff;--muted:rgba(233,237,255,.72);--muted2:rgba(233,237,255,.56);
  --border:rgba(255,255,255,.12);--panel:rgba(255,255,255,.05);--panel2:rgba(255,255,255,.07);
  --accent:#00ff88;--accent2:#3b82f6;--accent-glow:rgba(0,255,136,.15);
  --accentText:#0b1020;
  --radius:18px;--radius2:24px;
  --shadow:0 18px 60px rgba(0,0,0,.36);--shadow2:0 12px 34px rgba(0,0,0,.26);
  --max:1120px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:'Inter',ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:var(--bg);overflow-x:hidden}
.bg-glow{position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;overflow:hidden;pointer-events:none}
.blob{position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(0,255,136,.07) 0%,transparent 70%);border-radius:50%;filter:blur(60px);animation:float 20s infinite alternate}
.blob-1{top:-200px;left:-200px}
.blob-2{bottom:-200px;right:-200px;background:radial-gradient(circle,rgba(59,130,246,.07) 0%,transparent 70%);animation-delay:-5s}
.blob-3{top:20%;right:10%;background:radial-gradient(circle,rgba(139,92,246,.05) 0%,transparent 70%);animation-delay:-10s}
@keyframes float{from{transform:translate(0,0) scale(1)}to{transform:translate(100px,50px) scale(1.1)}}
.container{width:min(var(--max),calc(100% - 40px));margin:0 auto}
.muted{color:var(--muted)}.muted2{color:var(--muted2)}.small{font-size:13px}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}

/* ── Reusable ── */
.card{border:1px solid var(--border);background:var(--panel);border-radius:var(--radius2);box-shadow:var(--shadow2);padding:24px}
.glass{background:rgba(255,255,255,.04);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius2)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;border-radius:14px;border:1px solid var(--border);background:transparent;color:var(--text);font-weight:700;cursor:pointer;transition:transform .12s,background .12s,border-color .12s,box-shadow .25s;user-select:none;white-space:nowrap;font-size:15px}
.btn:hover{transform:translateY(-1px);border-color:rgba(255,255,255,.18);background:rgba(255,255,255,.04)}
.btn:active{transform:translateY(0)}
.btn.primary{background:var(--accent);color:var(--accentText);border-color:transparent;font-weight:800}
.btn.primary:hover{box-shadow:0 0 24px rgba(0,255,136,.3);background:#00e67a}
.btn.ghost{background:rgba(255,255,255,.06)}
.btn.full{width:100%}
.btn.blue{background:var(--accent2);color:#fff;border-color:transparent}
.btn.blue:hover{box-shadow:0 0 20px rgba(59,130,246,.35)}
.pill{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;border:1px solid rgba(0,255,136,.2);background:rgba(0,255,136,.06);color:var(--accent);font-weight:800;font-size:13px}
.pill .dot{width:8px;height:8px;border-radius:999px;background:var(--accent);box-shadow:0 0 8px var(--accent);animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.tag{display:inline-flex;padding:4px 8px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.2px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06)}
.tag.solid{background:var(--accent);color:var(--accentText);border-color:transparent}
.badge{display:inline-flex;padding:5px 10px;border-radius:999px;font-size:12px;font-weight:800;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:var(--muted);white-space:nowrap}
.badge.high{background:rgba(239,68,68,.2);color:#fca5a5;border-color:rgba(239,68,68,.3)}
.badge.med{background:rgba(245,158,11,.15);color:#fcd34d;border-color:rgba(245,158,11,.25)}
.badge.low{background:rgba(59,130,246,.12);color:#93c5fd;border-color:rgba(59,130,246,.2)}
.badge.crit{background:rgba(239,68,68,.35);color:#fecaca;border-color:rgba(239,68,68,.5)}

.section{padding:44px 0}
section{scroll-margin-top:84px}
.head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:14px}
.eyebrow{margin:0 0 8px;color:var(--accent);font-weight:800;text-transform:uppercase;font-size:12px;letter-spacing:.14em}
h1{margin:14px 0 10px;font-size:clamp(34px,4.3vw,56px);line-height:1.03;letter-spacing:-.9px}
h2{margin:0;font-size:clamp(24px,2.7vw,36px);letter-spacing:-.5px}
h3{margin:0 0 8px;letter-spacing:-.2px}
p{margin:0}

/* ── Nav ── */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(12px);background:rgba(6,10,20,.8);border-bottom:1px solid rgba(255,255,255,.06)}
.nav .inner{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 0}
.brand{display:flex;align-items:center;gap:10px;font-weight:900;letter-spacing:.2px}
.brand .mark{width:10px;height:10px;border-radius:999px;background:var(--accent);box-shadow:0 0 10px var(--accent)}
.links{display:flex;gap:18px;color:var(--muted);font-weight:700;font-size:14px}
.links a:hover{color:var(--accent)}
.actions{display:flex;gap:10px;align-items:center}
.langSelect{background:rgba(255,255,255,.06);border:1px solid var(--border);color:var(--muted);padding:6px 8px;border-radius:8px;font-size:13px;cursor:pointer}
.langSelect option{background:#111;color:#eee}
#authStatus{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px}
#authStatus .dot-online{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent)}
#authStatus .dot-offline{width:7px;height:7px;border-radius:50%;background:#ef4444;box-shadow:0 0 6px #ef4444}

/* ── Hero ── */
.hero{padding:56px 0 28px;position:relative;overflow:hidden;background:url('proactive-defender.png') center center / cover no-repeat}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(105deg,rgba(6,10,20,.92) 0%,rgba(6,10,20,.82) 40%,rgba(6,10,20,.6) 70%,rgba(6,10,20,.45) 100%);z-index:1}
.hero>.container{position:relative;z-index:2}
.heroGrid{display:grid;grid-template-columns:1.08fr .92fr;gap:22px;align-items:center}
.lead{margin-top:6px;font-size:16px;line-height:1.65;max-width:62ch;color:var(--muted)}
.heroCtas{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.hero-highlight{color:var(--accent);font-weight:800}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:18px}
.kpi{border-radius:16px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);padding:12px;transition:border-color .25s,box-shadow .25s}
.kpi:hover{border-color:rgba(0,255,136,.25);box-shadow:0 0 20px rgba(0,255,136,.08)}
.kpi strong{display:block;font-weight:900;letter-spacing:.2px;margin-bottom:4px}
.kpi span{color:var(--muted);font-weight:700;font-size:13px}

/* ── Preview Terminal ── */
.preview{border-radius:var(--radius2);border:1px solid rgba(0,255,136,.15);background:rgba(0,0,0,.4);box-shadow:0 0 40px rgba(0,255,136,.06);overflow:hidden;transition:transform .5s ease-out}
.preview:hover{transform:perspective(1000px) rotateY(-2deg) rotateX(2deg)}
.previewTop,.previewBottom{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.06)}
.previewBottom{border-bottom:0;border-top:1px solid rgba(255,255,255,.06)}
.dots{display:flex;gap:6px}
.dots span{width:10px;height:10px;border-radius:999px}
.dots span:nth-child(1){background:#ef4444}.dots span:nth-child(2){background:#f59e0b}.dots span:nth-child(3){background:#22c55e}
.previewBody{padding:14px;display:grid;gap:10px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px}
.row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.divider{height:1px;background:rgba(255,255,255,.06);margin:6px 0}
.finding{display:flex;gap:12px;align-items:flex-start;padding:12px;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03)}
.finding p{margin-top:4px}
.score{display:inline-flex;padding:6px 10px;border-radius:999px;background:rgba(239,68,68,.2);border:1px solid rgba(239,68,68,.3);font-weight:800;color:#fca5a5}

/* ── Live Scanner ── */
.scanner-box{border:1px solid rgba(0,255,136,.2);background:rgba(0,0,0,.3);backdrop-filter:blur(10px);border-radius:var(--radius2);overflow:hidden;box-shadow:0 0 60px rgba(0,255,136,.05)}
.scanner-header{padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:10px}
.scanner-header h3{margin:0;color:var(--accent);font-size:15px}
.scanner-input-row{display:flex;gap:10px;padding:18px;align-items:center}
.scanner-input-row input{flex:1;padding:14px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:rgba(0,0,0,.4);color:var(--text);font-family:monospace;font-size:15px;outline:none;transition:border-color .2s}
.scanner-input-row input:focus{border-color:var(--accent);box-shadow:0 0 12px rgba(0,255,136,.1)}
.scanner-input-row input::placeholder{color:var(--muted2)}
.scanner-results{padding:0 18px 18px;max-height:420px;overflow-y:auto;font-family:monospace;font-size:13px;color:var(--accent);line-height:1.7}
.scanner-results::-webkit-scrollbar{width:6px}
.scanner-results::-webkit-scrollbar-thumb{background:rgba(0,255,136,.2);border-radius:3px}
.scanner-line{opacity:0;animation:typeLine .3s ease forwards}
.scanner-line.info{color:var(--muted)}
.scanner-line.warn{color:#fcd34d}
.scanner-line.error{color:#fca5a5}
.scanner-line.success{color:var(--accent)}
@keyframes typeLine{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.scanner-placeholder{padding:20px;text-align:center;color:var(--muted2);font-size:14px;font-family:sans-serif}

/* ── Benefits Grid ── */
.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.benefit-card{padding:24px 20px;border-radius:var(--radius2);border:1px solid var(--border);background:var(--panel);transition:border-color .3s,box-shadow .3s,transform .3s}
.benefit-card:hover{border-color:rgba(0,255,136,.25);box-shadow:0 0 30px rgba(0,255,136,.08);transform:translateY(-3px)}
.benefit-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:14px}
.benefit-card:nth-child(1) .benefit-icon{background:rgba(0,255,136,.12);border:1px solid rgba(0,255,136,.2)}
.benefit-card:nth-child(2) .benefit-icon{background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.2)}
.benefit-card:nth-child(3) .benefit-icon{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.2)}

/* ── How it works ── */
.howGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}
.howStep{position:relative;overflow:hidden;padding:20px 16px;border-radius:var(--radius2);border:1px solid var(--border);background:var(--panel);box-shadow:var(--shadow2);transition:border-color .3s}
.howStep:hover{border-color:rgba(0,255,136,.2)}
.howStep .num{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:14px;background:var(--accent);color:var(--accentText);display:flex;align-items:center;justify-content:center;font-weight:900}
.howStep .connector{display:none}
@media(min-width:640px){.howStep .connector{display:block;position:absolute;right:-8px;top:50%;width:16px;height:2px;background:rgba(0,255,136,.3)}.howStep:last-child .connector{display:none}}

/* ── Tools Grid ── */
.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}
.tool-card{padding:14px;border-radius:16px;border:1px solid var(--border);background:var(--panel);cursor:pointer;transition:all .25s;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}
.tool-card:hover{border-color:rgba(0,255,136,.3);box-shadow:0 0 20px rgba(0,255,136,.08);transform:translateY(-2px)}
.tool-card .tool-icon{font-size:22px}
.tool-card .tool-name{font-weight:700;font-size:14px}
.tool-card .tool-cat{font-size:11px;color:var(--muted2);text-transform:uppercase;letter-spacing:.5px}
.tool-card .tool-status{font-size:11px;padding:2px 8px;border-radius:999px}
.tool-card .tool-status.installed{background:rgba(0,255,136,.12);color:var(--accent);border:1px solid rgba(0,255,136,.2)}
.tool-card .tool-status.missing{background:rgba(239,68,68,.1);color:#fca5a5;border:1px solid rgba(239,68,68,.15)}
.tools-loading{text-align:center;padding:40px;color:var(--muted2)}

/* ── Pricing ── */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.prices{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;align-items:stretch}
.plan{position:relative;overflow:hidden;padding:20px;border-radius:var(--radius2);border:1px solid var(--border);background:var(--panel);box-shadow:var(--shadow2)}
.plan.featured{border-color:rgba(0,255,136,.25);background:linear-gradient(180deg,rgba(0,255,136,.06),rgba(0,0,0,.2));box-shadow:0 0 40px rgba(0,255,136,.06)}
.ribbon{position:absolute;top:14px;right:14px;padding:6px 10px;border-radius:999px;background:var(--accent);color:var(--accentText);font-weight:800;font-size:12px}
.priceLine{display:flex;align-items:flex-end;gap:8px;margin:10px 0}
.amount{font-size:38px;font-weight:900;letter-spacing:-.8px;line-height:1}
.per{color:var(--muted);font-weight:700}
.list{list-style:none;padding:0;margin:12px 0 0;display:grid;gap:10px}
.list li{display:flex;gap:10px;align-items:flex-start;color:var(--muted);font-weight:700;font-size:14px}
.check{flex-shrink:0;width:20px;height:20px}
.check svg{width:100%;height:100%;stroke:var(--accent);stroke-width:2.5;fill:none}
.fine{margin-top:10px;color:var(--muted2);font-size:12px;line-height:1.45}

/* ── FAQ ── */
.faq{display:grid;gap:8px}
.faq details{border:1px solid var(--border);border-radius:var(--radius);background:var(--panel);overflow:hidden;transition:border-color .2s}
.faq details[open]{border-color:rgba(0,255,136,.2)}
.faq summary{padding:14px 16px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:700;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary .plus{transition:transform .2s;color:var(--accent)}
.faq details[open] summary .plus{transform:rotate(45deg)}
.faq details p{padding:0 16px 14px;color:var(--muted);line-height:1.7}

/* ── CTA / Contact ── */
.cta{padding:44px 0}
.ctaBox{padding:24px;border-radius:var(--radius2);border:1px solid rgba(0,255,136,.2);background:linear-gradient(135deg,rgba(0,255,136,.06),rgba(59,130,246,.04));display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:20px}
.contactGrid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form{display:grid;gap:12px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.input{padding:12px;border-radius:14px;border:1px solid var(--border);background:rgba(0,0,0,.25);color:var(--text);outline:none;font-size:14px;font-family:inherit;width:100%}
.input:focus{border-color:var(--accent);box-shadow:0 0 10px rgba(0,255,136,.1)}
select.input{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.5)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 14px center;background-size:16px;padding-right:40px}
select.input option{background:var(--bg2);color:var(--text)}
textarea.input{min-height:80px;resize:vertical}
.disclaimer{margin-top:8px;color:var(--muted2);font-size:12px;line-height:1.5}
.callout{margin-top:12px;padding:12px;border-radius:var(--radius);border:1px solid rgba(0,255,136,.15);background:rgba(0,255,136,.04)}

/* ── Login Modal ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(6px);z-index:100;display:none;align-items:center;justify-content:center}
.modal-overlay.show{display:flex}
.modal-box{background:var(--bg2);border:1px solid rgba(0,255,136,.2);border-radius:var(--radius2);padding:28px;width:min(420px,90vw);box-shadow:0 0 60px rgba(0,255,136,.08)}
.modal-box h2{margin:0 0 6px;font-size:22px}
.modal-box .form{margin-top:14px}
.modal-close{position:absolute;top:14px;right:14px;background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer}

/* ── Footer ── */
.footer{padding:24px 0;border-top:1px solid rgba(255,255,255,.06)}
.footerRow{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}

/* ── Animations ── */
.fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* ── Responsive ── */
@media(min-width: 901px) {
  .nav-menu {
    display: contents;
  }
  .mobile-toggle {
    display: none;
  }
}
@media(max-width:900px){
  .heroGrid,.benefits-grid,.prices,.grid3,.contactGrid{grid-template-columns:1fr}
  .howGrid{grid-template-columns:1fr 1fr}
  .kpis{grid-template-columns:1fr 1fr}
  .row2,.row3{grid-template-columns:1fr}
  .tools-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}

  /* Mobile Nav */
  .mobile-toggle {
    display: block;
    background: none;
    border: none;
    color: var(--text);
    cursor: pointer;
    padding: 6px;
  }
  .nav-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    background: rgba(6,10,20,.98);
    backdrop-filter: blur(12px);
    flex-direction: column;
    padding: 20px;
    border-bottom: 1px solid rgba(255,255,255,.06);
    gap: 20px;
    box-shadow: var(--shadow2);
  }
  body.menu-open .nav-menu {
    display: flex;
  }
  .links {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 15px;
  }
  .actions {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    width: 100%;
  }
  .actions .btn {
    width: 100%;
  }
  .dropdown-content {
    position: static;
    display: none;
    background: transparent;
    border: none;
    box-shadow: none;
    padding-left: 15px;
    margin-top: 10px;
  }
  .dropdown.active .dropdown-content {
    display: block;
  }
}
@media(max-width:600px){
  .howGrid,.kpis{grid-template-columns:1fr}
  .hero{padding:32px 0 16px}
  h1{font-size:28px}
  .card{padding:20px}
}

/* ── Language Selector ── */
.lang-selector{position:relative;display:flex;align-items:center}
.lang-toggle{background:rgba(255,255,255,.06);border:1px solid var(--border);color:var(--muted);padding:6px 10px;border-radius:8px;font-size:13px;cursor:pointer;display:flex;align-items:center;gap:5px;font-weight:700;transition:border-color .2s,background .2s}
.lang-toggle:hover{border-color:rgba(0,255,136,.3);background:rgba(255,255,255,.08)}
.lang-dropdown{display:none;position:absolute;top:calc(100% + 6px);right:0;background:rgba(11,16,32,.98);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:6px;min-width:130px;box-shadow:0 12px 40px rgba(0,0,0,.5);z-index:200}
.lang-selector:hover .lang-dropdown,.lang-selector:focus-within .lang-dropdown{display:block}
.lang-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:transparent;color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;border-radius:6px;transition:background .15s,color .15s}
.lang-btn:hover{background:rgba(255,255,255,.06);color:var(--text)}
.lang-btn.active{color:var(--accent);background:rgba(0,255,136,.08)}
.lang-btn .lang-flag{font-size:16px;line-height:1}

/* ── Scrollbar ── */
::-webkit-scrollbar{width:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.2)}

/* Dropdown Menu Styles */
.dropdown {
  position: relative;
  display: inline-block;
}

.dropdown-content {
  display: none;
  position: absolute;
  background-color: #111;
  min-width: 160px;
  box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.5);
  z-index: 100;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 6px;
  top: 100%;
  left: 0;
  padding: 8px 0;
}

.dropdown-content a {
  color: var(--text);
  padding: 8px 16px;
  text-decoration: none;
  display: block;
  font-size: 0.9rem;
}

.dropdown-content a:hover {
  background-color: rgba(255,255,255,0.05);
  color: var(--accent);
}

.dropdown:hover .dropdown-content {
  display: block;
}

/* Responsive Grid Classes for Dashboard */
.grid-3-col {
  grid-template-columns: repeat(3, 1fr) !important;
}
.grid-2-1-col {
  grid-template-columns: 2fr 1fr !important;
}
.grid-2-col {
  grid-template-columns: 1fr 1fr !important;
}
.grid-1-2-col {
  grid-template-columns: 1fr 2fr !important;
}
.grid-1-col {
  grid-template-columns: 1fr !important;
}

.admin-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 15px;
  margin-top: 15px;
}

.responsive-input-group {
  display: flex;
  gap: 10px;
}
.responsive-input-group.align-end {
  align-items: flex-end;
}

@media(max-width:900px){
  .grid-3-col, .grid-2-1-col, .grid-2-col, .grid-1-2-col {
    grid-template-columns: 1fr !important;
  }
}

@media(max-width:600px){
  .admin-form-grid {
    grid-template-columns: 1fr;
  }
  .admin-form-grid > div {
    grid-column: span 1 !important;
  }
}

@media(max-width:480px){
  .responsive-input-group, .responsive-input-group.align-end, .scanner-input-row {
    flex-direction: column;
    align-items: stretch;
  }
  .responsive-input-group input, .responsive-input-group .input, .responsive-input-group div,
  .scanner-input-row input, .scanner-input-row .input, .scanner-input-row div {
    width: 100% !important;
  }
}

/* ══════════════════════════════════════════════════════════════════════
   Dashboard v2 — Grafana-Style Panels
   ══════════════════════════════════════════════════════════════════════ */

/* ── Grafana Panel ── */
.grafana-panel {
  background: rgba(255,255,255,.025);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 16px;
  overflow: hidden;
  transition: border-color .3s, box-shadow .3s, transform .2s;
  display: flex;
  flex-direction: column;
}
.grafana-panel:hover {
  border-color: rgba(0,255,136,.15);
  box-shadow: 0 0 30px rgba(0,255,136,.04);
}

/* Panel Header */
.panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px 10px;
  border-bottom: 1px solid rgba(255,255,255,.04);
  gap: 10px;
}
.panel-header h3 {
  margin: 0;
  font-size: 14px;
  font-weight: 700;
  color: rgba(255,255,255,.85);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.panel-header-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

/* Panel Toolbar Buttons */
.panel-btn {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.5);
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 14px;
  transition: all .2s;
  padding: 0;
}
.panel-btn:hover {
  background: rgba(255,255,255,.1);
  color: var(--accent);
  border-color: rgba(0,255,136,.2);
}
.panel-btn.active {
  background: rgba(0,255,136,.1);
  color: var(--accent);
  border-color: rgba(0,255,136,.25);
}

/* Panel Body */
.panel-body {
  padding: 14px 18px 18px;
  flex: 1;
  position: relative;
  min-height: 100px;
}

/* Filter Dropdown */
.panel-filter-dropdown {
  display: none;
  padding: 12px 18px;
  border-top: 1px solid rgba(255,255,255,.05);
  background: rgba(0,0,0,.15);
  animation: slideDown .2s ease;
}
.panel-filter-dropdown.show {
  display: block;
}
@keyframes slideDown {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.filter-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.filter-row label {
  font-size: 12px;
  color: rgba(255,255,255,.5);
  font-weight: 600;
  white-space: nowrap;
}
.filter-input {
  flex: 1;
  min-width: 120px;
  padding: 7px 10px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(0,0,0,.3);
  color: var(--text);
  font-size: 13px;
  font-family: inherit;
  outline: none;
  transition: border-color .2s;
}
.filter-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 8px rgba(0,255,136,.08);
}
.filter-input::placeholder {
  color: rgba(255,255,255,.25);
}
.filter-add-btn {
  padding: 7px 12px;
  border-radius: 8px;
  border: 1px solid rgba(0,255,136,.2);
  background: rgba(0,255,136,.08);
  color: var(--accent);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: all .2s;
  white-space: nowrap;
}
.filter-add-btn:hover {
  background: rgba(0,255,136,.15);
  border-color: rgba(0,255,136,.35);
}

/* Filter Chips */
.filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 0 18px 8px;
}
.filter-chips:empty {
  display: none;
}
.filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(239,68,68,.12);
  border: 1px solid rgba(239,68,68,.2);
  color: #fca5a5;
  font-size: 11px;
  font-weight: 700;
  animation: chipIn .2s ease;
}
@keyframes chipIn {
  from { opacity: 0; transform: scale(.8); }
  to   { opacity: 1; transform: scale(1); }
}
.filter-chip .chip-remove {
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
  opacity: .7;
  transition: opacity .15s;
}
.filter-chip .chip-remove:hover {
  opacity: 1;
}

/* Panel Loading */
.panel-loading {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(6,10,20,.6);
  backdrop-filter: blur(4px);
  z-index: 5;
  border-radius: 0 0 16px 16px;
}
.panel-spinner {
  width: 32px;
  height: 32px;
  border: 3px solid rgba(255,255,255,.08);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: panelSpin .7s linear infinite;
}
@keyframes panelSpin {
  to { transform: rotate(360deg); }
}

/* Panel Error */
.panel-error {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  color: #fca5a5;
  font-size: 13px;
  font-weight: 600;
  padding: 20px;
}

/* ── KPI Row ── */
.kpi-row-v2 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 20px;
}
.kpi-card-v2 {
  background: rgba(255,255,255,.025);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 14px;
  padding: 18px;
  transition: border-color .3s, box-shadow .3s, transform .2s;
}
.kpi-card-v2:hover {
  border-color: rgba(0,255,136,.15);
  box-shadow: 0 0 20px rgba(0,255,136,.05);
  transform: translateY(-1px);
}
.kpi-card-v2 .kpi-label {
  font-size: 12px;
  font-weight: 700;
  color: rgba(255,255,255,.45);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 6px;
}
.kpi-card-v2 .kpi-value {
  font-size: 2rem;
  font-weight: 900;
  letter-spacing: -.5px;
  line-height: 1.1;
  transition: color .3s;
}
.kpi-card-v2 .kpi-value.green { color: #4ade80; }
.kpi-card-v2 .kpi-value.blue { color: #3b82f6; }
.kpi-card-v2 .kpi-value.amber { color: #fbbf24; }
.kpi-card-v2 .kpi-value.red { color: #f87171; }
.kpi-card-v2 .kpi-sub {
  font-size: 11px;
  color: rgba(255,255,255,.35);
  margin-top: 4px;
}

/* ── Dashboard Grid v2 ── */
.dash-grid-v2 {
  display: grid;
  gap: 16px;
  margin-bottom: 16px;
}
.dash-grid-v2.cols-1 { grid-template-columns: 1fr; }
.dash-grid-v2.cols-2 { grid-template-columns: 1fr 1fr; }
.dash-grid-v2.cols-3 { grid-template-columns: 1fr 1fr 1fr; }
.dash-grid-v2.cols-2-1 { grid-template-columns: 2fr 1fr; }
.dash-grid-v2.cols-1-2 { grid-template-columns: 1fr 2fr; }

/* ── Global Time Bar ── */
.dash-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 20px;
  padding: 12px 16px;
  border-radius: 12px;
  background: rgba(255,255,255,.025);
  border: 1px solid rgba(255,255,255,.06);
}
.dash-toolbar-group {
  display: flex;
  align-items: center;
  gap: 8px;
}
.dash-toolbar label {
  font-size: 12px;
  font-weight: 700;
  color: rgba(255,255,255,.4);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.time-btn {
  padding: 6px 12px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.5);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: all .15s;
}
.time-btn:hover {
  background: rgba(255,255,255,.07);
  color: var(--text);
}
.time-btn.active {
  background: rgba(0,255,136,.1);
  border-color: rgba(0,255,136,.25);
  color: var(--accent);
}

/* ── Counter Animation ── */
@keyframes countUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.counter-animate {
  animation: countUp .4s ease-out;
}

/* ── Admin Section v2 Header ── */
.admin-v2-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}
.admin-v2-header h2 {
  margin: 0;
  color: #4ade80;
}
.admin-v2-header .refresh-all-btn {
  padding: 8px 16px;
  border-radius: 10px;
  border: 1px solid rgba(0,255,136,.2);
  background: rgba(0,255,136,.06);
  color: var(--accent);
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: all .2s;
  display: flex;
  align-items: center;
  gap: 6px;
}
.admin-v2-header .refresh-all-btn:hover {
  background: rgba(0,255,136,.12);
  border-color: rgba(0,255,136,.35);
}
.admin-v2-header .refresh-all-btn.spinning svg {
  animation: panelSpin .7s linear infinite;
}

/* ── Responsive v2 ── */
@media(max-width:900px){
  .kpi-row-v2 { grid-template-columns: 1fr 1fr; }
  .dash-grid-v2.cols-2, .dash-grid-v2.cols-3, .dash-grid-v2.cols-2-1, .dash-grid-v2.cols-1-2 {
    grid-template-columns: 1fr;
  }
}
@media(max-width:600px){
  .kpi-row-v2 { grid-template-columns: 1fr; }
  .dash-toolbar { flex-direction: column; align-items: stretch; }
  .panel-header { flex-direction: column; align-items: flex-start; }
}

