/* SpawnWeaver shared design system — cool "deep blue" 2D-pixel theme. */
:root {
    /* Surfaces */
    --bg-main: #0f141c;
    --bg-section: #0c1118;
    --bg-card: #182230;
    --bg-inset: #0b0f16;
    --midnight: #182230;

    /* Accents (cool). Old names are kept as aliases so every rule/class still resolves. */
    --blue: #4a9eff;
    --azure: #38bdf8;
    --mint: #54d6a0;
    --cyan: var(--blue);
    --purple: var(--azure);
    --violet: var(--azure);
    --green: var(--mint);

    /* Text */
    --white: #e8eef7;
    --steel: #a6b6cb;
    --dim: #647590;

    --gradient: linear-gradient(90deg, #4a9eff, #38bdf8);
    --border: #28323f;
    --border-strong: #3c4a5d;
    --radius: 5px;
    --shadow: 4px 4px 0 rgba(0, 0, 0, 0.40);
    --shadow-sm: 3px 3px 0 rgba(0, 0, 0, 0.34);

    /* Fonts — pixel font for small chrome (logo/nav/buttons/labels); readable sans for headings + body. */
    --font-pixel: "Silkscreen", ui-monospace, "Cascadia Code", monospace;
    --font-body: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    --font-mono: ui-monospace, "Cascadia Code", "Fira Code", monospace;
}

* { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }

body {
    font-family: var(--font-body);
    color: var(--steel);
    background:
        radial-gradient(circle at 50% -10%, rgba(74, 158, 255, 0.12), transparent 45%),
        var(--bg-main);
    background-attachment: fixed;
    min-height: 100vh;
    line-height: 1.62;
    -webkit-font-smoothing: antialiased;
}

a { color: var(--blue); text-decoration: none; transition: color 0.15s ease; }
a:hover { color: var(--azure); }

/* Headings use the readable sans (eased off the pixel font); small chrome stays pixel below. */
h1, h2, h3, h4 {
    color: var(--white);
    font-family: var(--font-body);
    font-weight: 700;
    letter-spacing: -0.01em;
    line-height: 1.3;
}

code {
    background: var(--bg-inset);
    border: 1px solid var(--border);
    padding: 1px 6px;
    border-radius: 4px;
    color: var(--azure);
    font-family: var(--font-mono);
    font-size: 0.88em;
}

pre {
    background: var(--bg-inset);
    border: 2px solid var(--border);
    padding: 14px 16px;
    border-radius: var(--radius);
    overflow: auto;
    color: var(--white);
    font-size: 13px;
    box-shadow: var(--shadow-sm);
}
pre code { background: none; border: none; padding: 0; color: var(--white); }

.brand-gradient {
    background: var(--gradient);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.muted { color: var(--dim); }
.mono { font-family: var(--font-mono); color: var(--steel); font-size: 0.92em; }

/* --- Buttons --- */
.btn {
    display: inline-block;
    font-family: var(--font-pixel);
    padding: 11px 18px;
    border-radius: var(--radius);
    font-weight: 400;
    font-size: 12px;
    line-height: 1.2;
    cursor: pointer;
    border: 2px solid var(--border-strong);
    box-shadow: var(--shadow-sm);
    transition: background 0.15s ease, transform 0.04s ease, box-shadow 0.04s ease;
}
.btn:active { transform: translate(2px, 2px); box-shadow: none; }
.btn-primary {
    background: var(--blue);
    color: #07111f;
    border-color: #2f7fd6;
}
.btn-primary:hover { background: #66b0ff; color: #07111f; }
.btn-secondary {
    background: var(--bg-card);
    border-color: var(--border-strong);
    color: var(--white);
}
.btn-secondary:hover { background: #20304380; color: var(--white); }

/* --- Cards --- */
.card {
    background: var(--bg-card);
    border: 2px solid var(--border);
    border-radius: var(--radius);
    padding: 20px 22px;
    box-shadow: var(--shadow);
}
.card + .card { margin-top: 18px; }

/* --- Tables --- */
table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
thead th {
    text-align: left;
    color: var(--steel);
    font-family: var(--font-pixel);
    font-weight: 400;
    text-transform: uppercase;
    font-size: 9.5px;
    letter-spacing: 0.04em;
    padding: 9px 12px;
    border-bottom: 2px solid var(--border);
}
tbody td {
    padding: 10px 12px;
    border-bottom: 1px solid rgba(100, 117, 144, 0.22);
    color: var(--white);
    vertical-align: middle;
}
tbody tr:last-child td { border-bottom: none; }
tbody tr:hover { background: rgba(74, 158, 255, 0.07); }

/* --- Badges & status --- */
.badge {
    display: inline-block;
    font-family: var(--font-pixel);
    padding: 3px 9px;
    border-radius: 4px;
    font-size: 9.5px;
    font-weight: 400;
    border: 1px solid var(--border);
}
.badge-cyan { color: var(--blue); background: rgba(74, 158, 255, 0.12); border-color: rgba(74, 158, 255, 0.40); }
.badge-purple { color: var(--azure); background: rgba(56, 189, 248, 0.12); border-color: rgba(56, 189, 248, 0.40); }
.badge-green { color: var(--mint); background: rgba(84, 214, 160, 0.12); border-color: rgba(84, 214, 160, 0.40); }
.badge-amber { color: #ffcf6b; background: rgba(255, 184, 76, 0.12); border-color: rgba(255, 184, 76, 0.40); }
.badge-red { color: #ff7a90; background: rgba(255, 122, 144, 0.12); border-color: rgba(255, 122, 144, 0.42); }
.badge-dim { color: var(--steel); background: rgba(100, 117, 144, 0.16); border-color: rgba(100, 117, 144, 0.4); }

.dot { display: inline-block; width: 8px; height: 8px; border-radius: 2px; margin-right: 7px; vertical-align: middle; }
.dot-online { background: var(--mint); }

/* --- Dashboard shell --- */
.app-shell { max-width: 1400px; margin: 0 auto; padding: 26px 22px 64px; }
.topbar {
    display: flex; align-items: center; justify-content: space-between; gap: 16px;
    padding-bottom: 16px; margin-bottom: 26px;
    border-bottom: 2px solid var(--border);
}
.topbar .logo { font-family: var(--font-pixel); font-size: 16px; color: var(--white); }
.topbar a.logo:hover { color: var(--white); }
.topbar .logo .dim { color: var(--dim); font-size: 11px; }
.nav { display: flex; gap: 6px; flex-wrap: wrap; }
.nav a {
    font-family: var(--font-pixel); font-size: 11.5px;
    padding: 9px 13px; border-radius: var(--radius);
    color: var(--steel); border: 2px solid transparent;
}
.nav a:hover { color: var(--white); background: rgba(74, 158, 255, 0.08); }
.nav a.active { color: var(--blue); background: rgba(74, 158, 255, 0.12); border-color: var(--border-strong); }

.page-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 16px; gap: 12px; }
.page-head h2 { margin: 0; font-size: 20px; }
.section-title { font-family: var(--font-pixel); margin: 26px 0 10px; font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em; color: var(--steel); }
.section-title:first-child { margin-top: 0; }

/* --- Stat cards --- */
.stat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(168px, 1fr)); gap: 14px; margin-bottom: 22px; }
.stat { padding: 18px 20px; }
.stat .value { font-family: var(--font-pixel); font-size: 24px; color: var(--white); line-height: 1.1; }
.stat .value.cyan { color: var(--blue); }
.stat .value.green { color: var(--mint); }
.stat .value.violet { color: var(--azure); }
.stat .label { color: var(--steel); font-size: 12.5px; margin-top: 9px; }

.empty { color: var(--dim); padding: 8px 2px; }

/* --- Forms --- */
.field {
    width: 100%; background: var(--bg-inset); border: 2px solid var(--border);
    border-radius: var(--radius); color: var(--white); padding: 10px 12px; margin: 6px 0; font-size: 14px;
    font-family: var(--font-body);
}
.field::placeholder { color: var(--dim); }
.field:focus { outline: none; border-color: var(--border-strong); box-shadow: 0 0 0 3px rgba(74, 158, 255, 0.22); }

/* --- Landing --- */
.landing { max-width: 1000px; margin: 0 auto; padding: 60px 22px 90px; }
.pill {
    display: inline-block; font-family: var(--font-pixel); padding: 6px 12px; border-radius: 4px; font-size: 10px;
    letter-spacing: 0.04em; color: var(--azure); background: rgba(56, 189, 248, 0.10);
    border: 2px solid rgba(56, 189, 248, 0.45); margin-bottom: 20px;
}
.hero h1 { font-size: 42px; line-height: 1.12; margin: 0 0 16px; letter-spacing: -0.02em; }
.hero .sub { font-size: 17px; color: var(--steel); max-width: 620px; line-height: 1.6; }
.cta-row { display: flex; gap: 12px; margin: 28px 0 8px; flex-wrap: wrap; }
.steps { counter-reset: step; list-style: none; padding: 0; margin: 14px 0 0; }
.steps li { position: relative; padding: 2px 0 18px 42px; }
.steps li::before {
    counter-increment: step; content: counter(step);
    position: absolute; left: 0; top: 0; width: 28px; height: 28px; border-radius: 4px;
    display: flex; align-items: center; justify-content: center; font-family: var(--font-pixel); font-size: 12px;
    color: #07111f; background: var(--blue); border: 2px solid #2f7fd6;
}
.portal-glow { box-shadow: var(--shadow); }
.links-row { display: flex; gap: 18px; flex-wrap: wrap; margin-top: 16px; font-size: 14px; }
.footer { margin-top: 40px; color: var(--dim); font-size: 13px; border-top: 2px solid var(--border); padding-top: 18px; }

/* --- Create project / key reveal --- */
.create-row { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.create-row .field { flex: 1; min-width: 220px; margin: 0; }

.banner {
    border-radius: var(--radius); padding: 10px 14px; font-size: 13px; margin: 0 0 14px;
    border: 2px solid; display: flex; gap: 8px; align-items: flex-start;
}
.banner-warn { color: #ffcf6b; background: rgba(255, 184, 76, 0.10); border-color: rgba(255, 184, 76, 0.40); }
.banner-error { color: #ff7a90; background: rgba(255, 122, 144, 0.10); border-color: rgba(255, 122, 144, 0.45); }

.key-row { margin: 14px 0; }
.key-row .key-label { font-family: var(--font-pixel); font-size: 10px; text-transform: uppercase; letter-spacing: 0.04em; color: var(--steel); margin-bottom: 6px; }
.key-row .key-box {
    display: flex; align-items: center; gap: 8px;
    background: var(--bg-inset); border: 2px solid var(--border); border-radius: var(--radius); padding: 8px 10px;
}
.key-row.secret .key-box { border-color: rgba(56, 189, 248, 0.55); }
.key-box .key-value { flex: 1; font-family: var(--font-mono); font-size: 13px; color: var(--white); word-break: break-all; }
.copy-btn {
    background: rgba(74, 158, 255, 0.10); border: 2px solid var(--border-strong); color: var(--blue);
    border-radius: 4px; padding: 5px 11px; font-size: 12px; font-weight: 600; cursor: pointer; white-space: nowrap;
    font-family: var(--font-pixel);
}
.copy-btn:hover { background: rgba(74, 158, 255, 0.18); }
.hidden { display: none; }

/* --- Account / auth --- */
.btn-ghost {
    background: var(--bg-card); border: 2px solid var(--border-strong); color: var(--white);
}
.btn-ghost:hover { background: #20304380; color: var(--white); }
.btn-sm { padding: 7px 12px; font-size: 11px; }
.btn-block { display: block; width: 100%; margin-top: 8px; text-align: center; }

.nav-account { display: flex; align-items: center; gap: 10px; margin-left: auto; }
.nav-account a { font-family: var(--font-pixel); color: var(--steel); font-size: 11.5px; }
.nav-account a:hover { color: var(--white); }
.nav-account a.active { color: var(--blue); }

.field-label {
    display: block; font-family: var(--font-pixel); margin: 16px 0 4px; font-size: 10.5px;
    color: var(--steel); letter-spacing: 0.02em;
}
.form-status { display: block; min-height: 18px; margin-top: 10px; font-size: 13px; }

.auth-wrap { max-width: 420px; margin: 40px auto 0; }
.auth-card { padding: 26px 26px 24px; }
.auth-alt { margin: 16px 0 0; font-size: 13.5px; text-align: center; }
.auth-divider { display: flex; align-items: center; gap: 10px; margin: 16px 0; color: var(--dim); font-size: 12px; }
.auth-divider::before, .auth-divider::after { content: ""; flex: 1; height: 2px; background: var(--border); }

/* --- Onboarding wizard --- */
.choice-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 8px; margin: 8px 0 4px; }
.choice {
    display: flex; align-items: center; gap: 8px; cursor: pointer;
    background: var(--bg-inset); border: 2px solid var(--border); border-radius: var(--radius); padding: 9px 11px;
    font-size: 13.5px; color: var(--white); transition: border-color 0.15s ease, background 0.15s ease;
}
.choice:hover { border-color: var(--border-strong); background: rgba(74, 158, 255, 0.06); }
.choice input { accent-color: var(--blue); }

.setup-list { list-style: none; padding: 0; margin: 8px 0 14px; }
.setup-step {
    display: flex; align-items: center; gap: 10px; padding: 9px 12px; margin: 6px 0;
    background: var(--bg-inset); border: 2px solid var(--border); border-radius: var(--radius); color: var(--white); font-size: 14px;
}
.setup-step.done { border-color: rgba(84, 214, 160, 0.45); }
.setup-mark { color: var(--blue); font-weight: 700; width: 18px; text-align: center; }
.setup-step.done .setup-mark { color: var(--mint); }

/* --- Key/value detail rows --- */
.kv { display: grid; grid-template-columns: 160px 1fr; gap: 8px 16px; margin: 6px 0 4px; font-size: 14px; align-items: center; }
.kv-label { color: var(--steel); font-size: 12.5px; }

/* --- Debugger: session timeline --- */
textarea.field { resize: vertical; font-family: var(--font-mono); font-size: 13px; }
.timeline { list-style: none; padding: 0; margin: 6px 0 2px; }
.timeline-row {
    display: grid; grid-template-columns: 110px 110px 1fr; gap: 12px; align-items: baseline;
    padding: 8px 10px; border-left: 3px solid var(--border); margin: 3px 0;
    background: var(--bg-inset); border-radius: 0 var(--radius) var(--radius) 0; font-size: 13.5px;
}
.timeline-time { color: var(--dim); font-size: 12px; }
.timeline-kind { color: var(--steel); text-transform: uppercase; font-size: 11px; letter-spacing: 0.04em; }
.timeline-detail { color: var(--white); word-break: break-word; }
.timeline-good { border-left-color: rgba(84, 214, 160, 0.7); }
.timeline-good .timeline-kind { color: var(--mint); }
.timeline-error { border-left-color: rgba(255, 122, 144, 0.7); }
.timeline-error .timeline-kind { color: #ff7a90; }
.timeline-dim { border-left-color: rgba(100, 117, 144, 0.5); }

/* --- Friendly UI: welcome card, tutorials, debugger hub --- */
.welcome-card p { font-size: 15px; color: var(--steel); }
.welcome-card .cta-row { margin: 18px 0 2px; }

.tut-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; margin: 6px 0 14px; }
.tut {
    background: var(--bg-inset); border: 2px solid var(--border); border-radius: var(--radius); padding: 16px;
    display: flex; flex-direction: column;
}
.tut-title { color: var(--white); font-weight: 700; font-size: 15px; margin-bottom: 8px; }
.tut p { font-size: 13.5px; margin: 0 0 12px; flex: 1; }
.tut-foot { font-size: 12.5px; color: var(--steel); border-top: 1px solid var(--border); padding-top: 9px; }

.hub-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 14px; }
.hub-card {
    display: block; background: var(--bg-card); border: 2px solid var(--border); border-radius: var(--radius);
    padding: 20px; box-shadow: var(--shadow-sm); transition: border-color 0.15s ease, transform 0.06s ease;
}
.hub-card:hover { border-color: var(--border-strong); color: inherit; }
.hub-card:active { transform: translate(2px, 2px); box-shadow: none; }
.hub-icon { font-size: 26px; margin-bottom: 8px; }
.hub-title { color: var(--white); font-weight: 700; font-size: 16px; margin-bottom: 7px; }
.hub-desc { color: var(--steel); font-size: 13.5px; }

/* --- Landing: honest-fit section --- */
.fit-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 20px; }
.fit-head { font-family: var(--font-pixel); font-size: 12px; margin-bottom: 10px; }
.fit-good { color: var(--mint); }
.fit-bad { color: #ff7a90; }
.fit-list { margin: 0; padding-left: 18px; color: var(--steel); font-size: 14px; }
.fit-list li { margin: 4px 0; }

/* --- Docs --- */
.docs-shell { display: grid; grid-template-columns: 220px 1fr; gap: 26px; align-items: start; }
.docs-nav {
    position: sticky; top: 18px; display: flex; flex-direction: column; gap: 2px;
    background: var(--bg-card); border: 2px solid var(--border); border-radius: var(--radius); padding: 14px;
}
.docs-group {
    color: var(--steel); font-family: var(--font-pixel); font-size: 9.5px; text-transform: uppercase; letter-spacing: 0.04em;
    margin: 16px 0 6px;
}
.docs-group:first-child { margin-top: 0; }
.docs-nav a {
    color: var(--steel); font-size: 13.5px; padding: 6px 10px; border-radius: 4px; border: 2px solid transparent;
}
.docs-nav a:hover { color: var(--white); background: rgba(74, 158, 255, 0.07); }
.docs-nav a.active { color: var(--blue); background: rgba(74, 158, 255, 0.12); border-color: var(--border-strong); }

.docs-content {
    background: var(--bg-card); border: 2px solid var(--border); border-radius: var(--radius);
    padding: 26px 30px; box-shadow: var(--shadow); min-width: 0;
}
.docs-content h1 { font-size: 27px; margin: 0 0 10px; line-height: 1.25; }
.docs-content h2 { font-size: 19px; margin: 28px 0 10px; line-height: 1.3; }
.docs-content h3 { font-size: 15px; margin: 20px 0 6px; color: var(--white); }
.docs-content p, .docs-content li { color: var(--steel); font-size: 14.5px; line-height: 1.7; }
.docs-content .lead { color: var(--white); font-size: 16px; }
.docs-content ul, .docs-content ol { padding-left: 22px; }
.docs-content li { margin: 6px 0; }
.docs-content pre { margin: 12px 0; }
.docs-content table { margin: 12px 0; }
.docs-content a { font-weight: 600; }
.docs-next { display: flex; justify-content: space-between; gap: 12px; margin-top: 30px; border-top: 2px solid var(--border); padding-top: 16px; }
.docs-next a { font-family: var(--font-pixel); font-size: 11px; }
@media (max-width: 760px) {
    .docs-shell { grid-template-columns: 1fr; }
    .docs-nav { position: static; flex-direction: row; flex-wrap: wrap; }
}
