/* ============================================================
   Shared design system — Data Engineering book companion
   Blue / purple / yellow / green · IBM Plex Sans + JetBrains Mono
   ============================================================ */
:root{
  --paper:#f6f9ff;
  --paper-2:#eef3fe;
  --ink:#1b2440;
  --ink-soft:#5a6486;
  --rule:#d4ddf2;
  --blue:#2f6bff;
  --blue-soft:#5e8cff;
  --purple:#7c5cff;
  --purple-soft:#9d86ff;
  --yellow:#ffd34e;
  --yellow-soft:#fff3cc;
  --green:#22b07d;
  --green-soft:#d6f5e8;
  --red:#e2476b;
  --red-soft:#ffe1e8;
  --white:#ffffff;
  --shadow:rgba(47,107,255,.14);
  --shadow-lg:rgba(27,36,64,.10);
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --sans:'IBM Plex Sans',system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--sans);font-size:16.5px;line-height:1.62;
  -webkit-font-smoothing:antialiased;
  background-image:radial-gradient(var(--rule) .6px,transparent .6px);
  background-size:24px 24px;
}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:1080px;margin:0 auto;padding:0 26px}
.narrow{max-width:760px}

/* ---- top nav bar ---- */
.topbar{position:sticky;top:0;z-index:50;background:rgba(246,249,255,.86);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--rule)}
.topbar .row{display:flex;align-items:center;gap:18px;height:60px;max-width:1080px;
  margin:0 auto;padding:0 26px}
.topbar .brand{font-weight:700;letter-spacing:-.02em;color:var(--ink);font-size:15px}
.topbar .brand b{color:var(--blue)}
.topbar nav{margin-left:auto;display:flex;gap:6px;flex-wrap:wrap}
.topbar nav a{font-family:var(--mono);font-size:12px;padding:6px 11px;border-radius:7px;
  color:var(--ink-soft);text-decoration:none;transition:.15s}
.topbar nav a:hover{background:var(--paper-2);color:var(--blue)}
.topbar nav a.active{background:var(--blue);color:#fff}

/* ---- generic section headings ---- */
.kicker{font-family:var(--mono);font-size:12px;letter-spacing:.28em;
  text-transform:uppercase;color:var(--purple)}
h1.title{font-weight:700;font-size:clamp(32px,5vw,52px);line-height:1.05;
  letter-spacing:-.03em;margin:14px 0 0}
h1.title em{font-style:normal;color:var(--blue)}
h2.sec{font-weight:700;font-size:26px;letter-spacing:-.02em;margin:48px 0 6px}
h3.sub{font-weight:600;font-size:19px;margin:30px 0 6px;color:var(--ink)}
p.lede{font-size:19px;color:var(--ink-soft);line-height:1.55;margin-top:16px}

/* ---- pills / badges ---- */
.pills{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0}
.pill{font-family:var(--mono);font-size:11px;letter-spacing:.04em;padding:5px 11px;
  border-radius:20px;background:var(--paper-2);color:var(--ink-soft);border:1px solid var(--rule)}
.pill.blue{background:var(--blue);color:#fff;border-color:var(--blue)}
.pill.purple{background:var(--purple);color:#fff;border-color:var(--purple)}
.pill.green{background:var(--green);color:#fff;border-color:var(--green)}

/* ---- callouts ---- */
.callout{margin:18px 0;padding:15px 18px;border-radius:12px;border:1px solid var(--rule)}
.callout .lbl{font-family:var(--mono);font-size:10px;letter-spacing:.14em;
  text-transform:uppercase;font-weight:600;display:block;margin-bottom:5px}
.callout p{margin:0}
.callout.q{background:#f3efff;border-color:var(--purple-soft)}
.callout.q .lbl{color:var(--purple)}
.callout.danger{background:var(--red-soft);border-color:#f5b6c5}
.callout.danger .lbl{color:var(--red)}
.callout.win{background:var(--green-soft);border-color:#b7ead4}
.callout.win .lbl{color:var(--green)}
.callout.note{background:var(--yellow-soft);border-color:#ffe49a}
.callout.note .lbl{color:#b78900}

/* ---- code ---- */
code{font-family:var(--mono);font-size:.9em;background:var(--paper-2);
  padding:1px 6px;border-radius:5px;border:1px solid var(--rule)}
pre{font-family:var(--mono);font-size:13.5px;line-height:1.6;background:#0f1830;color:#dbe6ff;
  padding:16px 18px;border-radius:12px;overflow:auto;margin:14px 0}
pre code{background:none;border:none;padding:0;color:inherit;font-size:inherit}

/* ---- buttons ---- */
button{font-family:var(--mono);cursor:pointer;border:0;transition:.15s}
.btn{font-size:12px;letter-spacing:.06em;text-transform:uppercase;font-weight:600;
  background:var(--blue);color:#fff;padding:10px 18px;border-radius:8px;box-shadow:0 3px 10px var(--shadow)}
.btn:hover{background:var(--purple);transform:translateY(-1px)}
.btn.ghost{background:var(--white);color:var(--ink-soft);border:1px solid var(--rule);box-shadow:none}
.btn.ghost:hover{border-color:var(--blue);color:var(--blue);background:var(--white)}
.btn.danger{background:var(--red)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* ---- footer ---- */
footer.site{border-top:1px solid var(--rule);margin-top:80px;padding:28px 0 60px;
  font-family:var(--mono);font-size:12px;color:var(--ink-soft)}

/* ---- interactive lab shell ---- */
.lab{border:1px solid var(--rule);border-radius:16px;background:var(--white);
  box-shadow:0 8px 30px var(--shadow);margin:24px 0;overflow:hidden}
.lab-head{background:linear-gradient(90deg,var(--blue),var(--purple));color:#fff;
  padding:14px 20px;display:flex;align-items:center;gap:10px}
.lab-head .tag{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  background:rgba(255,255,255,.22);padding:3px 9px;border-radius:12px}
.lab-head h3{margin:0;font-size:16px;font-weight:600}
.lab-body{padding:20px}
.lab-note{font-size:14px;color:var(--ink-soft);margin:0 0 14px}
