/* ═══════════════════════════════════════════════════════════════════
   TonalLab v2 — Dark academic theme
   ═══════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,wght@0,400;0,500;0,700&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
    --bg: #0c0f14;
    --bg-card: #141820;
    --bg-alt: #0f1319;
    --bg-input: #1a1f2a;
    --border: #1e2530;
    --border-hover: #2a3345;
    --text: #e2e8f0;
    --text-dim: #8892a4;
    --muted: #5a6478;
    --accent: #0ea5e9;
    --accent-hover: #38bdf8;
    --accent-dim: rgba(14,165,233,.12);
    --ok: #22c55e;
    --warn: #f59e0b;
    --err: #ef4444;
    --danger: #dc2626;
    --radius: 10px;
    --radius-sm: 6px;
    --shadow: 0 2px 12px rgba(0,0,0,.35);
    --font: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
    --mono: 'JetBrains Mono', monospace;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
    font-family: var(--font);
    background: var(--bg);
    color: var(--text);
    line-height: 1.6;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}
a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-hover); }

/* ── Container ─────────────────────────────────────────────────── */
.container { max-width: 1140px; margin: 0 auto; padding: 0 24px; }

/* ── Navbar ────────────────────────────────────────────────────── */
.navbar {
    background: rgba(12,15,20,.92);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--border);
    position: sticky; top: 0; z-index: 100;
    padding: 12px 0;
}
.nav-inner { display:flex; align-items:center; justify-content:space-between; }
.nav-brand { display:flex; align-items:center; gap:10px; color:var(--text); }
.nav-brand strong { font-size:1.1rem; display:block; }
.nav-brand small { font-size:.72rem; color:var(--muted); }
.brand-icon { font-size:1.5rem; }
.nav-links { display:flex; align-items:center; gap:18px; }
.nav-links a { color:var(--text-dim); font-size:.9rem; transition:color .15s; }
.nav-links a:hover { color:var(--text); }

/* ── Buttons ───────────────────────────────────────────────────── */
.btn {
    display:inline-flex; align-items:center; justify-content:center;
    padding:10px 22px; border-radius:var(--radius-sm);
    font-family:var(--font); font-size:.9rem; font-weight:600;
    border:none; cursor:pointer; transition:all .15s; text-decoration:none;
    line-height: 1.4;
}
.btn-primary { background:var(--accent); color:#fff; }
.btn-primary:hover { background:var(--accent-hover); color:#fff; }
.btn-outline { background:transparent; border:1px solid var(--border); color:var(--text-dim); }
.btn-outline:hover { border-color:var(--accent); color:var(--accent); }
.btn-danger { background:var(--danger); color:#fff; }
.btn-danger:hover { background:#b91c1c; color:#fff; }
.btn-warning { background:var(--warn); color:#000; }
.btn-sm { padding:6px 14px; font-size:.8rem; }
.btn-lg { padding:14px 32px; font-size:1rem; }
.btn-block { width:100%; }

/* ── Pill / Badge ──────────────────────────────────────────────── */
.pill {
    display:inline-block; padding:4px 14px; border-radius:20px;
    font-size:.78rem; font-weight:600; letter-spacing:.03em;
    background:var(--accent-dim); color:var(--accent); border:1px solid rgba(14,165,233,.2);
}
.badge {
    display:inline-block; padding:2px 10px; border-radius:12px;
    font-size:.75rem; font-weight:600;
}
.badge-ok { background:rgba(34,197,94,.15); color:var(--ok); }
.badge-warn { background:rgba(245,158,11,.15); color:var(--warn); }
.badge-err { background:rgba(239,68,68,.15); color:var(--err); }

/* ── Hero ──────────────────────────────────────────────────────── */
.hero {
    padding:100px 0 80px;
    background: radial-gradient(ellipse at 50% 0%, rgba(14,165,233,.08) 0%, transparent 60%);
}
.hero-content { max-width:680px; text-align:center; margin:0 auto; }
.hero h1 { font-size:2.6rem; font-weight:700; line-height:1.15; margin:20px 0 16px; }
.hero-sub { font-size:1.1rem; color:var(--text-dim); margin-bottom:30px; }
.hero-actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

/* ── Sections ──────────────────────────────────────────────────── */
.section { padding:70px 0; }
.section-alt { background:var(--bg-alt); }
.section-title { text-align:center; font-size:1.8rem; margin-bottom:12px; }
.section-sub { text-align:center; color:var(--text-dim); margin-bottom:40px; }

/* ── Features grid ─────────────────────────────────────────────── */
.features-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:20px; }
.feature-card {
    background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius);
    padding:28px 24px; transition:border-color .2s;
}
.feature-card:hover { border-color:var(--accent); }
.feature-icon { font-size:2rem; margin-bottom:12px; }
.feature-card h3 { font-size:1.1rem; margin-bottom:6px; }
.feature-card p { font-size:.9rem; color:var(--text-dim); }

/* ── Steps grid ────────────────────────────────────────────────── */
.steps-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:20px; }
.step-card {
    background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius);
    padding:28px 24px; position:relative;
}
.step-num {
    display:inline-flex; align-items:center; justify-content:center;
    width:36px; height:36px; border-radius:50%;
    background:var(--accent); color:#fff; font-weight:700; font-size:1rem;
    margin-bottom:12px;
}
.step-card h4 { margin-bottom:6px; }
.step-card p { font-size:.9rem; color:var(--text-dim); }

/* ── Video grid ────────────────────────────────────────────────── */
.video-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:20px; }
.video-placeholder {
    background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius);
    padding:60px 24px; text-align:center;
}
.video-icon { font-size:3rem; margin-bottom:10px; opacity:.5; }
.video-placeholder p { font-weight:600; }
.video-placeholder small { color:var(--muted); }

/* ── CTA ───────────────────────────────────────────────────────── */
.cta-section { text-align:center; max-width:600px; margin:0 auto; }
.cta-section h2 { font-size:2rem; margin-bottom:10px; }
.cta-section p { color:var(--text-dim); margin-bottom:24px; }

/* ── Auth pages ────────────────────────────────────────────────── */
.auth-page { flex:1; display:flex; align-items:center; justify-content:center; padding:40px 20px; }
.auth-card {
    background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius);
    padding:40px; width:100%; max-width:420px;
}
.auth-card h1 { font-size:1.5rem; margin-bottom:6px; }
.auth-sub { color:var(--text-dim); font-size:.9rem; margin-bottom:20px; }
.auth-link { text-align:center; margin-top:16px; font-size:.9rem; color:var(--text-dim); }

/* ── Forms ──────────────────────────────────────────────────────── */
label { display:block; margin-bottom:16px; }
label span, .label-text { display:block; font-size:.85rem; font-weight:600; margin-bottom:6px; color:var(--text-dim); }
input[type="text"], input[type="email"], input[type="password"],
input[type="number"], input[type="file"], select, textarea {
    width:100%; padding:10px 14px; border-radius:var(--radius-sm);
    background:var(--bg-input); border:1px solid var(--border); color:var(--text);
    font-family:var(--font); font-size:.9rem; transition:border-color .15s;
}
input:focus, select:focus, textarea:focus { outline:none; border-color:var(--accent); }
textarea { resize:vertical; min-height:80px; }
.check { display:flex; align-items:flex-start; gap:8px; cursor:pointer; }
.check input[type="checkbox"] { margin-top:4px; accent-color:var(--accent); }
.check span { font-size:.85rem; color:var(--text-dim); }
.form-group { display:flex; flex-direction:column; gap:14px; }

/* ── Dashboard ─────────────────────────────────────────────────── */
.dashboard-page { flex:1; padding:30px 0 60px; }
.dash-header { display:flex; justify-content:space-between; align-items:flex-start; flex-wrap:wrap; gap:16px; margin-bottom:30px; }
.dash-header h1 { font-size:1.6rem; }
.dash-actions { display:flex; gap:8px; flex-wrap:wrap; }
.text-muted { color:var(--text-dim); font-size:.9rem; }

/* ── Cards ──────────────────────────────────────────────────────── */
.card {
    background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius);
    padding:24px;
}
.card h3, .card h4 { margin-bottom:10px; }
.card p { font-size:.9rem; color:var(--text-dim); margin-bottom:6px; }

/* ── Project grid ──────────────────────────────────────────────── */
.project-grid { display:grid; grid-template-columns:1fr 320px; gap:24px; }
@media(max-width:800px) { .project-grid { grid-template-columns:1fr; } }

/* ── Tables ────────────────────────────────────────────────────── */
.table-wrap { overflow-x:auto; margin-bottom:30px; }
table { width:100%; border-collapse:collapse; font-size:.85rem; }
thead { background:var(--bg-alt); }
th, td { padding:10px 14px; text-align:left; border-bottom:1px solid var(--border); }
th { font-weight:600; color:var(--text-dim); font-size:.8rem; text-transform:uppercase; letter-spacing:.04em; }
tr:hover td { background:rgba(14,165,233,.03); }

/* ── Stats grid ────────────────────────────────────────────────── */
.stats-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:12px; margin-bottom:20px; }
.stat-card {
    background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius);
    padding:18px 16px;
}
.stat-num { font-size:1.8rem; font-weight:700; margin-bottom:2px; }
.stat-card div:last-child { font-size:.8rem; color:var(--text-dim); }

/* ── Flash ─────────────────────────────────────────────────────── */
.flash-container { padding-top:12px; }
.flash {
    padding:12px 18px; border-radius:var(--radius-sm); margin-bottom:8px;
    font-size:.9rem; font-weight:500;
}
.flash-success { background:rgba(34,197,94,.12); color:var(--ok); border:1px solid rgba(34,197,94,.25); }
.flash-error { background:rgba(239,68,68,.12); color:var(--err); border:1px solid rgba(239,68,68,.25); }

/* ── FAQ ───────────────────────────────────────────────────────── */
.faq-category { margin-bottom:30px; }
.faq-cat-title { font-size:1.2rem; margin-bottom:12px; text-transform:capitalize; }
.faq-item {
    background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-sm);
    margin-bottom:8px;
}
.faq-item summary {
    padding:14px 18px; cursor:pointer; font-weight:600; font-size:.95rem;
    list-style:none; display:flex; align-items:center; justify-content:space-between;
}
.faq-item summary::after { content:'＋'; color:var(--muted); font-size:1.2rem; }
.faq-item[open] summary::after { content:'−'; }
.faq-answer { padding:0 18px 16px; font-size:.9rem; color:var(--text-dim); line-height:1.7; }

/* ── Log box ───────────────────────────────────────────────────── */
.log-box {
    background:var(--bg); border:1px solid var(--border); border-radius:var(--radius-sm);
    padding:16px; font-family:var(--mono); font-size:.8rem; color:var(--text-dim);
    max-height:400px; overflow-y:auto; white-space:pre-wrap; word-break:break-word;
}

/* ── Empty state ───────────────────────────────────────────────── */
.empty-state {
    text-align:center; padding:60px 20px;
    background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius);
}
.empty-state p { color:var(--text-dim); margin-bottom:16px; }

/* ── Footer ────────────────────────────────────────────────────── */
.footer {
    margin-top:auto; padding:20px 0;
    border-top:1px solid var(--border); background:var(--bg-alt);
}
.footer-inner { display:flex; justify-content:space-between; align-items:center; }
.footer p { font-size:.82rem; color:var(--muted); }
.footer-links { display:flex; gap:16px; }
.footer-links a { font-size:.82rem; color:var(--muted); }
.footer-links a:hover { color:var(--accent); }

/* ── Responsive ────────────────────────────────────────────────── */
@media(max-width:640px) {
    .hero h1 { font-size:1.8rem; }
    .nav-links { gap:10px; }
    .dash-header { flex-direction:column; }
    .footer-inner { flex-direction:column; gap:8px; text-align:center; }
    .stats-grid { grid-template-columns:repeat(2,1fr); }
}
