/* Xowia Labs Pentest Suite — design system (no build step, hand-authored) */
:root{
  --bg:#0a0c11; --bg-2:#0f131b; --panel:#131826; --panel-2:#181f30;
  --line:#232c40; --line-2:#2e3a55;
  --txt:#e6ebf5; --muted:#8b97b0; --faint:#5b6680;
  --accent:#ff5b35; --accent-2:#ff7a4d; --teal:#22d3ee; --green:#34d399;
  --red:#f87171; --amber:#fbbf24;
  --radius:14px; --radius-sm:9px;
  --shadow:0 10px 30px -12px rgba(0,0,0,.6);
  --sb:264px; --tb:60px;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,Consolas,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{background:var(--bg);color:var(--txt);font-family:var(--font);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:#fff}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px}
::-webkit-scrollbar-track{background:transparent}

/* ---------- primitives ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:var(--radius-sm);
  font-weight:600;font-size:13px;border:1px solid var(--line-2);background:var(--panel-2);color:var(--txt);
  cursor:pointer;transition:.15s ease;white-space:nowrap}
.btn:hover{border-color:var(--faint);transform:translateY(-1px)}
.btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));border:0;color:#fff;
  box-shadow:0 8px 20px -8px rgba(255,91,53,.6)}
.btn.primary:hover{filter:brightness(1.07)}
.btn.ghost{background:transparent}
.btn.sm{padding:7px 12px;font-size:12px}
.btn.block{width:100%;justify-content:center}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}

input,select,textarea{width:100%;background:var(--bg-2);border:1px solid var(--line);color:var(--txt);
  padding:11px 13px;border-radius:var(--radius-sm);font-family:inherit;font-size:13px;outline:none;transition:.15s}
input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(255,91,53,.15)}
textarea{resize:vertical;min-height:120px;font-family:var(--mono);line-height:1.6}
label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px;font-weight:500}
.field{margin-bottom:14px}
.stack{display:flex;flex-direction:column;gap:12px}

.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.muted{color:var(--muted)}.faint{color:var(--faint)}.mono{font-family:var(--mono)}
.row{display:flex;gap:14px;flex-wrap:wrap}.between{justify-content:space-between;align-items:center}
.grid{display:grid;gap:16px}

.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;
  padding:3px 9px;border-radius:999px;border:1px solid var(--line-2);color:var(--muted)}
.badge.free{color:var(--green);border-color:rgba(52,211,153,.4);background:rgba(52,211,153,.08)}
.badge.pro{color:var(--amber);border-color:rgba(251,191,36,.4);background:rgba(251,191,36,.08)}
.badge.soon{color:var(--faint)}
.badge.live{color:var(--teal);border-color:rgba(34,211,238,.4);background:rgba(34,211,238,.08)}

.alert{padding:11px 14px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:12px;border:1px solid}
.alert.ok,.alert.success{background:rgba(52,211,153,.1);border-color:rgba(52,211,153,.4);color:#a7f3d0}
.alert.error{background:rgba(248,113,113,.1);border-color:rgba(248,113,113,.4);color:#fecaca}
.alert.warn{background:rgba(251,191,36,.1);border-color:rgba(251,191,36,.4);color:#fde68a}
.alert.info{background:rgba(34,211,238,.1);border-color:rgba(34,211,238,.35);color:#a5f3fc}

table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--line)}
th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em}
tbody tr:hover{background:var(--panel-2)}

.brand{font-size:22px;font-weight:800;letter-spacing:-.02em}
.brand span{color:var(--accent)}

/* ---------- auth pages ---------- */
.auth-bg{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;
  background:radial-gradient(900px 500px at 50% -10%,rgba(255,91,53,.13),transparent 60%),var(--bg)}
.auth-card{width:100%;max-width:400px;background:var(--panel);border:1px solid var(--line);
  border-radius:18px;padding:34px;box-shadow:var(--shadow)}
.auth-card h1{margin-bottom:2px}
.auth-card .muted{margin-bottom:22px}
.auth-card h3{font-size:13px;color:var(--muted);margin:14px 0 4px}
.auth-foot{margin-top:18px;font-size:13px;color:var(--muted);text-align:center}
.auth-foot a{color:var(--accent);font-weight:600}

/* ---------- app shell ---------- */
.shell{display:flex;min-height:100vh}
.sidebar{width:var(--sb);background:var(--bg-2);border-right:1px solid var(--line);
  position:fixed;inset:0 auto 0 0;display:flex;flex-direction:column;z-index:40}
.sidebar .logo{display:flex;align-items:center;gap:9px;padding:16px 20px;
  border-bottom:1px solid var(--line);font-size:19px;font-weight:800;letter-spacing:-.02em}
.sidebar .logo span{color:var(--accent)}
.sidebar .logo .logo-mark{width:27px;height:27px;border-radius:7px;flex:none;color:#fff;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  box-shadow:0 4px 12px -4px rgba(255,91,53,.6)}
.sidebar .logo .logo-mark svg{width:15px;height:15px}
.sidebar .logo .logo-txt{font-weight:800}

/* sidebar search */
.nav-search{padding:12px 14px 4px}
.nav-search .ns-wrap{position:relative}
.nav-search svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);
  width:15px;height:15px;color:var(--faint);pointer-events:none}
.nav-search input{padding:8px 10px 8px 32px;font-size:13px;background:var(--bg)}

.nav{flex:1;overflow-y:auto;padding:4px 12px 14px}
.nav .grp{font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--faint);
  padding:16px 12px 6px;font-weight:700}
.nav a{position:relative;display:flex;align-items:center;gap:11px;padding:8px 12px;border-radius:9px;
  color:var(--muted);font-size:13px;font-weight:500;margin:1px 0;transition:.12s}
.nav a span:not(.tag){flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav a:hover{background:var(--panel);color:var(--txt)}
.nav a:hover svg{opacity:1}
.nav a.active{background:rgba(255,91,53,.12);color:var(--accent-2);font-weight:600}
.nav a.active svg{opacity:1;color:var(--accent)}
.nav a.active::before{content:'';position:absolute;left:3px;top:8px;bottom:8px;width:3px;
  border-radius:0 3px 3px 0;background:var(--accent)}
.nav a svg{width:17px;height:17px;flex:none;opacity:.7;transition:.12s}
.nav a .tag{margin-left:auto;flex:none;font-size:9px;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;color:var(--faint);background:var(--panel-2);
  border:1px solid var(--line);border-radius:5px;padding:2px 6px}

/* sidebar footer / upgrade CTA */
.sidebar .sb-foot{padding:12px;border-top:1px solid var(--line)}
.sb-upgrade{display:block;border-radius:11px;padding:11px 13px;text-decoration:none;transition:.15s;
  background:linear-gradient(135deg,rgba(255,91,53,.16),rgba(255,122,77,.06));
  border:1px solid rgba(255,91,53,.30)}
.sb-upgrade:hover{border-color:var(--accent);transform:translateY(-1px)}
.sb-upgrade .t{display:flex;align-items:center;gap:7px;font-weight:700;font-size:13px;color:var(--txt)}
.sb-upgrade .t svg{width:15px;height:15px;color:var(--accent);flex:none}
.sb-upgrade .d{display:block;font-size:11px;color:var(--muted);margin-top:3px;line-height:1.45}
.sb-status{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);padding:4px 2px}
.sb-status .dot{width:7px;height:7px;border-radius:50%;background:var(--green);flex:none;
  box-shadow:0 0 0 3px rgba(52,211,153,.15)}

.main{flex:1;margin-left:var(--sb);display:flex;flex-direction:column;min-width:0}
.topbar{height:var(--tb);border-bottom:1px solid var(--line);background:var(--bg-2);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 26px;position:sticky;top:0;z-index:30}
.topbar .title{font-weight:700;font-size:15px}
.umenu{display:flex;align-items:center;gap:12px}
.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--teal));
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#0a0c11}
.content{padding:28px;flex:1}
.page-head{margin-bottom:22px}
.page-head h2{font-size:22px;font-weight:700;letter-spacing:-.02em}
.page-head p{color:var(--muted);margin-top:4px}

/* stat + tool cards */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-bottom:26px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.stat .k{font-size:12px;color:var(--muted);font-weight:600}
.stat .v{font-size:26px;font-weight:800;margin-top:6px}
.stat .v small{font-size:13px;color:var(--faint);font-weight:600}

.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.tool{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;
  display:flex;flex-direction:column;gap:10px;transition:.15s;position:relative;overflow:hidden}
.tool:hover{border-color:var(--line-2);transform:translateY(-2px);box-shadow:var(--shadow)}
.tool .ico{width:40px;height:40px;border-radius:10px;background:var(--panel-2);border:1px solid var(--line-2);
  display:flex;align-items:center;justify-content:center;color:var(--accent-2)}
.tool .ico svg{width:20px;height:20px}
.tool h4{font-size:15px;font-weight:700}
.tool p{font-size:12.5px;color:var(--muted);flex:1}
.tool .foot{display:flex;align-items:center;justify-content:space-between;margin-top:4px}
.tool.locked{opacity:.65}
.tool.soon::after{content:'SOON';position:absolute;top:12px;right:-26px;background:var(--line-2);
  color:var(--muted);font-size:10px;font-weight:700;padding:3px 30px;transform:rotate(40deg)}

.tool-frame{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.empty{text-align:center;padding:60px 20px;color:var(--muted)}
.empty svg{width:46px;height:46px;opacity:.4;margin-bottom:14px}

/* pricing */
.plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.plan{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:26px}
.plan.pop{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),var(--shadow)}
.plan .price{font-size:34px;font-weight:800;margin:10px 0}
.plan .price small{font-size:14px;color:var(--muted);font-weight:500}
.plan ul{list-style:none;margin:16px 0;display:flex;flex-direction:column;gap:9px}
.plan li{font-size:13px;color:var(--muted);display:flex;gap:9px}
.plan li::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--green);margin-top:7px;flex:none}

.menu-btn{display:none}
@media(max-width:920px){
  .sidebar{transform:translateX(-100%);transition:.2s}
  .sidebar.open{transform:none}
  .main{margin-left:0}
  .menu-btn{display:inline-flex}
}
.hidden{display:none}

/* ---- Light theme (toggled via html[data-theme=light]) ---- */
html[data-theme=light]{
  --bg:#f5f7fb; --bg-2:#ffffff; --panel:#ffffff; --panel-2:#f0f3f9;
  --line:#dde3ee; --line-2:#c8d1e3;
  --txt:#1a2030; --muted:#5b6680; --faint:#8b97b0;
}
html[data-theme=light] body{background:var(--bg)}
html[data-theme=light] .auth-bg{
  background:radial-gradient(900px 500px at 50% -10%,rgba(255,91,53,.10),transparent 60%),var(--bg)}
.theme-btn{background:transparent;border:1px solid var(--line-2);color:var(--muted);
  border-radius:8px;padding:5px 9px;cursor:pointer;font-size:13px}
