/* ================================================================
   Neverslain Labs — AI Audit Suite  |  Shared Styles
   Matches main site: dark space, magenta/purple, Three.js bg
   ================================================================ */

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
    --primary:   #ff00ff;
    --secondary: #9932CC;
    --accent:    #cb6ce6;
    --dark:      #0a0a15;
    --darker:    #05050a;
    --light:     #e0e0ff;
    --muted:     #b0b0c0;
    --dim:       #505060;
    --card-bg:   rgba(10,10,25,0.85);
    --card-border: rgba(255,0,255,0.12);
    --success:   #00ff88;
    --warning:   #ffaa00;
    --danger:    #ff4455;
    --info:      #00c8e8;
    --grad:      linear-gradient(135deg,var(--primary),var(--secondary));
    --modal-timing: cubic-bezier(0.165,0.84,0.44,1);
}

html { scroll-behavior:smooth; }

body {
    background: var(--darker);
    color: var(--light);
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    min-height: 100vh;
    overflow-x: hidden;
}

/* ── Three.js canvas ─────────────────────────── */
#canvas-container {
    position: fixed; top:0; left:0;
    width:100%; height:100vh;
    z-index: 0; pointer-events: none;
}
.noise-overlay {
    position: fixed; inset:0;
    background-image: url("data:image/png;base64,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");
    opacity: 0.03; z-index:1; pointer-events:none;
}

/* ── Layout ──────────────────────────────────── */
.site-wrap { position:relative; z-index:2; min-height:100vh; }

.container { max-width:1200px; margin:0 auto; padding:0 24px; }

/* ── Header ──────────────────────────────────── */
header {
    display:flex; justify-content:space-between; align-items:center;
    padding:24px 0;
    border-bottom: 1px solid rgba(255,0,255,0.25);
}
.logo {
    font-size:22px; font-weight:700;
    background: var(--grad);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent;
    display:flex; align-items:center; gap:10px; text-decoration:none;
}
.logo-icon {
    width:36px; height:36px;
    background: var(--grad);
    border-radius:8px; flex-shrink:0;
    position:relative; overflow:hidden;
}
.logo-icon::before {
    content:''; position:absolute;
    width:150%; height:150%;
    background:rgba(255,255,255,0.1);
    transform:rotate(45deg); top:-25%; left:-100%;
}
.header-nav { display:flex; gap:24px; align-items:center; }
.header-nav a {
    color:var(--muted); text-decoration:none; font-size:14px;
    font-weight:500; transition:color .2s;
}
.header-nav a:hover { color:var(--primary); }
.header-nav a.active { color:var(--light); }
.back-link {
    display:flex; align-items:center; gap:6px;
    color:var(--muted); text-decoration:none; font-size:14px;
    transition:color .2s;
}
.back-link:hover { color:var(--primary); }

/* ── Buttons ─────────────────────────────────── */
.btn {
    display:inline-flex; align-items:center; gap:8px;
    padding:11px 28px; font-size:15px; font-weight:500;
    border-radius:30px; cursor:pointer; border:none;
    text-decoration:none; transition:all .3s ease;
    position:relative; overflow:hidden; white-space:nowrap;
}
.btn-primary {
    background: var(--grad);
    color:#fff;
    box-shadow: 0 4px 20px rgba(203,108,230,0.3);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(203,108,230,0.5); }
.btn-secondary {
    background:transparent; color:var(--light);
    border:1px solid var(--primary);
}
.btn-secondary:hover { background:rgba(255,0,255,0.1); transform:translateY(-2px); }
.btn-ghost {
    background:rgba(255,255,255,0.05); color:var(--muted);
    border:1px solid rgba(255,255,255,0.1);
}
.btn-ghost:hover { background:rgba(255,255,255,0.1); color:var(--light); }
.btn-sm { padding:7px 18px; font-size:13px; }
.btn-danger { background:linear-gradient(135deg,#ff4455,#aa0011); color:#fff; }
.btn-success { background:linear-gradient(135deg,#00ff88,#00aa55); color:#000; }
.btn:disabled { opacity:.4; cursor:not-allowed; transform:none !important; }

/* ── Cards ───────────────────────────────────── */
.card {
    background: var(--card-bg);
    border: 1px solid var(--card-border);
    border-radius:15px; padding:24px;
    backdrop-filter:blur(10px);
    transition:all .3s ease;
    position:relative; overflow:hidden;
}
.card:hover { border-color:rgba(255,0,255,0.3); box-shadow:0 10px 30px rgba(203,108,230,0.15); }
.card-top-bar { position:absolute; top:0; left:0; width:100%; height:4px; background:var(--grad); }
.card-top-bar.info { background:linear-gradient(135deg,var(--info),#0066aa); }
.card-top-bar.success { background:linear-gradient(135deg,var(--success),#009944); }
.card-top-bar.warning { background:linear-gradient(135deg,var(--warning),#aa5500); }
.card-top-bar.danger { background:linear-gradient(135deg,var(--danger),#aa0011); }

/* ── Section titles ──────────────────────────── */
.section-title {
    font-size:32px; font-weight:700;
    margin-bottom:40px; text-align:center;
}
.section-title span {
    background: var(--grad);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.eyebrow {
    font-size:11px; font-weight:700; letter-spacing:.12em;
    text-transform:uppercase; color:var(--accent);
    margin-bottom:8px; display:block;
}

/* ── Forms ───────────────────────────────────── */
.form-group { margin-bottom:20px; }
.form-group label { display:block; margin-bottom:6px; font-weight:500; font-size:14px; color:var(--muted); }
.form-control {
    width:100%; padding:11px 14px;
    background:rgba(10,10,25,0.6);
    border:1px solid rgba(255,0,255,0.15);
    border-radius:8px; color:var(--light);
    font-size:14px; font-family:inherit;
    transition:border-color .2s, box-shadow .2s;
}
.form-control:focus {
    outline:none;
    border-color:var(--primary);
    box-shadow:0 0 0 3px rgba(255,0,255,0.1);
}
.form-control::placeholder { color:var(--dim); }
select.form-control option { background:var(--dark); color:var(--light); }
textarea.form-control { resize:vertical; min-height:100px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-row.three { grid-template-columns:1fr 1fr 1fr; }
.form-hint { font-size:12px; color:var(--dim); margin-top:4px; }
.required { color:var(--primary); margin-left:2px; }

/* ── Range slider ────────────────────────────── */
input[type=range] {
    -webkit-appearance:none; width:100%; height:4px;
    background: linear-gradient(to right, var(--primary) 0%, var(--primary) var(--val,50%), rgba(255,0,255,0.2) var(--val,50%));
    border-radius:2px; outline:none;
}
input[type=range]::-webkit-slider-thumb {
    -webkit-appearance:none; width:18px; height:18px;
    background:var(--primary); border-radius:50%;
    cursor:pointer; box-shadow:0 0 8px rgba(255,0,255,0.5);
}

/* ── Badges ──────────────────────────────────── */
.badge {
    display:inline-block; padding:3px 10px;
    border-radius:20px; font-size:11px; font-weight:700;
    letter-spacing:.06em; text-transform:uppercase;
}
.badge-primary { background:rgba(255,0,255,0.15); color:var(--primary); border:1px solid rgba(255,0,255,0.3); }
.badge-success { background:rgba(0,255,136,0.12); color:var(--success); border:1px solid rgba(0,255,136,0.3); }
.badge-warning { background:rgba(255,170,0,0.12); color:var(--warning); border:1px solid rgba(255,170,0,0.3); }
.badge-danger  { background:rgba(255,68,85,0.12);  color:var(--danger);  border:1px solid rgba(255,68,85,0.3); }
.badge-info    { background:rgba(0,200,232,0.12);  color:var(--info);    border:1px solid rgba(0,200,232,0.3); }

/* ── Progress bar ────────────────────────────── */
.progress-bar { background:rgba(255,255,255,0.06); border-radius:4px; height:6px; overflow:hidden; }
.progress-fill { height:100%; background:var(--grad); border-radius:4px; transition:width .5s ease; }

/* ── Modal ───────────────────────────────────── */
.modal-overlay {
    position:fixed; inset:0; background:rgba(0,0,0,0.85);
    z-index:9000; display:flex; align-items:center; justify-content:center;
    opacity:0; visibility:hidden;
    transition:opacity .4s var(--modal-timing), visibility .4s var(--modal-timing);
}
.modal-overlay.active { opacity:1; visibility:visible; }
.modal {
    background:rgba(12,12,28,0.97); border-radius:20px;
    width:90%; max-width:760px; max-height:88vh; overflow-y:auto;
    border:1px solid rgba(255,0,255,0.2);
    box-shadow:0 20px 80px rgba(153,50,204,0.35);
    padding:36px;
    transform:translateY(40px) scale(0.96); opacity:0;
    transition:transform .5s var(--modal-timing), opacity .5s var(--modal-timing);
}
.modal-overlay.active .modal { transform:none; opacity:1; }
.modal-header {
    display:flex; justify-content:space-between; align-items:flex-start;
    margin-bottom:24px; padding-bottom:18px;
    border-bottom:1px solid rgba(255,0,255,0.15);
}
.modal-title {
    font-size:24px; font-weight:700;
    background:var(--grad);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.modal-close {
    width:36px; height:36px; border-radius:50%; cursor:pointer;
    background:rgba(255,0,255,0.1); border:none; color:var(--light);
    display:flex; align-items:center; justify-content:center;
    font-size:18px; transition:all .3s; flex-shrink:0;
}
.modal-close:hover { background:rgba(255,0,255,0.3); transform:rotate(90deg); }

/* ── Toast notifications ─────────────────────── */
#toast-container {
    position:fixed; bottom:24px; right:24px;
    z-index:9999; display:flex; flex-direction:column; gap:10px;
}
.toast {
    background:rgba(12,12,28,0.95); border-radius:10px;
    padding:14px 20px; min-width:280px;
    border-left:3px solid var(--primary);
    display:flex; align-items:center; gap:12px;
    box-shadow:0 8px 30px rgba(0,0,0,0.5);
    transform:translateX(120%); transition:transform .4s var(--modal-timing);
    font-size:14px;
}
.toast.show { transform:none; }
.toast.success { border-color:var(--success); }
.toast.warning { border-color:var(--warning); }
.toast.danger  { border-color:var(--danger); }
.toast-icon { font-size:18px; flex-shrink:0; }

/* ── Tables ──────────────────────────────────── */
.table-wrap { overflow-x:auto; border-radius:10px; border:1px solid var(--card-border); }
table { width:100%; border-collapse:collapse; font-size:14px; }
th {
    background:rgba(255,0,255,0.08); color:var(--muted);
    font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.08em;
    padding:12px 16px; text-align:left;
}
td { padding:12px 16px; border-top:1px solid rgba(255,255,255,0.05); color:var(--light); }
tr:hover td { background:rgba(255,0,255,0.04); }

/* ── Tabs ────────────────────────────────────── */
.tabs { display:flex; gap:4px; border-bottom:1px solid rgba(255,0,255,0.15); margin-bottom:28px; }
.tab {
    padding:10px 20px; font-size:14px; font-weight:500; cursor:pointer;
    border:none; background:none; color:var(--muted);
    border-bottom:2px solid transparent; margin-bottom:-1px;
    transition:all .2s;
}
.tab:hover { color:var(--light); }
.tab.active { color:var(--primary); border-bottom-color:var(--primary); }
.tab-panel { display:none; }
.tab-panel.active { display:block; }

/* ── Utilities ───────────────────────────────── */
.text-grad { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.text-muted { color:var(--muted); }
.text-dim   { color:var(--dim); }
.text-primary { color:var(--primary); }
.text-success { color:var(--success); }
.text-warning { color:var(--warning); }
.text-danger  { color:var(--danger); }
.text-info    { color:var(--info); }
.text-center  { text-align:center; }
.mt-8  { margin-top:8px; }
.mt-16 { margin-top:16px; }
.mt-24 { margin-top:24px; }
.mt-32 { margin-top:32px; }
.mt-48 { margin-top:48px; }
.mb-8  { margin-bottom:8px; }
.mb-16 { margin-bottom:16px; }
.mb-24 { margin-bottom:24px; }
.gap-16 { gap:16px; }
.flex { display:flex; }
.flex-center { display:flex; align-items:center; }
.flex-between { display:flex; align-items:center; justify-content:space-between; }
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.glow-dot {
    width:8px; height:8px; border-radius:50%; flex-shrink:0;
    box-shadow: 0 0 8px currentColor;
}

/* ── Hero ────────────────────────────────────── */
.page-hero { padding:60px 0 40px; }
.page-hero h1 { font-size:48px; font-weight:800; line-height:1.1; margin-bottom:16px; }
.page-hero p  { font-size:17px; color:var(--muted); max-width:620px; line-height:1.7; }

/* ── Voice indicator ─────────────────────────── */
.voice-indicator {
    display:inline-flex; align-items:center; gap:8px;
    padding:6px 14px; border-radius:20px;
    background:rgba(255,68,85,0.1); border:1px solid rgba(255,68,85,0.3);
    font-size:13px; color:var(--danger); opacity:0; transition:opacity .3s;
}
.voice-indicator.active { opacity:1; }
.pulse-dot {
    width:8px; height:8px; background:var(--danger); border-radius:50%;
    animation: pulse 1s infinite;
}
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(1.3)} }

/* ── Stat number ─────────────────────────────── */
.stat-card { text-align:center; }
.stat-number {
    font-size:42px; font-weight:800; line-height:1;
    background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.stat-label { font-size:12px; color:var(--muted); margin-top:4px; text-transform:uppercase; letter-spacing:.08em; }

/* ── Step indicator ──────────────────────────── */
.steps { display:flex; gap:0; margin-bottom:36px; }
.step-item {
    flex:1; display:flex; flex-direction:column; align-items:center;
    position:relative;
}
.step-item:not(:last-child)::after {
    content:''; position:absolute; top:16px; left:50%;
    width:100%; height:2px;
    background:rgba(255,0,255,0.15);
    z-index:0;
}
.step-item.done::after  { background:linear-gradient(to right,var(--primary),rgba(255,0,255,0.15)); }
.step-num {
    width:32px; height:32px; border-radius:50%;
    border:2px solid rgba(255,0,255,0.2);
    background:var(--darker); color:var(--dim);
    display:flex; align-items:center; justify-content:center;
    font-size:13px; font-weight:700; position:relative; z-index:1;
    transition:all .3s;
}
.step-item.active .step-num { border-color:var(--primary); color:var(--primary); box-shadow:0 0 14px rgba(255,0,255,0.3); }
.step-item.done   .step-num { background:var(--primary); color:#fff; border-color:var(--primary); }
.step-label { font-size:11px; color:var(--dim); margin-top:6px; text-align:center; }
.step-item.active .step-label { color:var(--light); }

/* ── Footer ──────────────────────────────────── */
footer {
    background:var(--dark); padding:40px 0 20px;
    border-top:1px solid rgba(255,0,255,0.1);
    position:relative; z-index:2; margin-top:80px;
}
.footer-bottom { text-align:center; color:var(--dim); font-size:13px; padding-top:20px; border-top:1px solid rgba(255,255,255,0.04); }

/* ── Scrollbar ───────────────────────────────── */
::-webkit-scrollbar { width:6px; height:6px; }
::-webkit-scrollbar-track { background:var(--darker); }
::-webkit-scrollbar-thumb { background:rgba(255,0,255,0.3); border-radius:3px; }

/* ── Animations ──────────────────────────────── */
@keyframes fadeUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:none} }
@keyframes shimmer { 0%{background-position:-200% center} 100%{background-position:200% center} }
@keyframes spin { to{transform:rotate(360deg)} }
.fade-up { animation:fadeUp .5s ease forwards; }
.spinning { animation:spin 1s linear infinite; }

/* ── Responsive ──────────────────────────────── */
@media(max-width:768px) {
    .page-hero h1 { font-size:32px; }
    .grid-2,.grid-3,.grid-4 { grid-template-columns:1fr; }
    .form-row,.form-row.three { grid-template-columns:1fr; }
    .steps { flex-wrap:wrap; gap:8px; }
    .step-item::after { display:none; }
}
