/* ilusm.dev homepage — punk zine collage (not a SaaS template) */

@import url("https://fonts.googleapis.com/css2?family=Archivo+Black&family=Caveat:wght@600;700&family=Chakra+Petch:wght@500;600;700&family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,600;0,9..40,700;0,9..40,800;1,9..40,600&family=JetBrains+Mono:wght@500;700&family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800;1,600&family=Syne:wght@700;800&display=swap");

:root {
  --line: #120b24;
  --paper: #f4f0e8;
  --paper-2: #ebe4d8;
  --surface: rgba(255, 255, 253, 0.92);
  --surface-solid: rgba(255, 255, 253, 0.97);
  --banana: #ffe135;
  --lavender: #c9b6ff;
  --coral: #e11d68;
  --pink: #ff6eb4;
  --sky: #00c8e0;
  --mint: #34d399;
  --tangelo: #ff8c00;
  --slime: #5ee84a;
  --vapor-magenta: #c026d3;
  --vapor-indigo: #4f46e5;
  --ink: #1a1428;
  --ink-muted: rgba(26, 20, 40, 0.72);
  --border: rgba(18, 11, 36, 0.12);
  --border-strong: rgba(18, 11, 36, 0.22);
  --strip: linear-gradient(90deg, var(--sky) 0%, var(--slime) 20%, var(--banana) 40%, var(--tangelo) 60%, var(--pink) 80%, var(--lavender) 100%);
  --shadow-pop-sm: 0 1px 2px rgba(22, 19, 46, 0.06), 0 4px 14px rgba(22, 19, 46, 0.08);
  --shadow-pop: 0 2px 4px rgba(22, 19, 46, 0.06), 0 8px 22px rgba(22, 19, 46, 0.1);
  --shadow-pop-md: 0 3px 8px rgba(22, 19, 46, 0.08), 0 12px 32px rgba(22, 19, 46, 0.12);
  --shadow-pop-lg: 0 4px 14px rgba(22, 19, 46, 0.09), 0 18px 44px rgba(22, 19, 46, 0.14);
  --shadow-pop-xl: 0 6px 20px rgba(22, 19, 46, 0.1), 0 24px 56px rgba(22, 19, 46, 0.16);
  --grid-cell: 36px;
  --grid-ink: rgba(34, 211, 238, 0.04);
  --grid-ink-2: rgba(244, 114, 182, 0.03);
  --ease-pop: cubic-bezier(0.25, 0.8, 0.25, 1);
  --radius-field: 12px;
  --radius-card: 14px;
  --icon-check: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M9 16.17 4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/%3E%3C/svg%3E");
  --icon-warn: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 3.5 21 20H3L12 3.5zm0 12a1.25 1.25 0 100 2.5 1.25 1.25 0 000-2.5zM11 9h2v5h-2V9z'/%3E%3C/svg%3E");
  --icon-cross: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M6.22 4.93 12 10.71 17.78 4.93 19.19 6.34 13.41 12l5.78 5.78-1.41 1.41L12 13.41l-5.78 5.78-1.41-1.41L10.59 12 4.81 6.22l1.41-1.41z'/%3E%3C/svg%3E");
  --memphis: url("data:image/svg+xml,%3Csvg width='400' height='400' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 50l30-50 30 50z' fill='%23ff0066' opacity='0.49'/%3E%3Cpath d='M340 60l40-60 40 60z' fill='%23ffcc00' opacity='0.47'/%3E%3Cpath d='M150 30l-25 40h50z' fill='%2300ffcc' opacity='0.47'/%3E%3Cpath d='M300 220l-30 50h60z' fill='%239300ff' opacity='0.44'/%3E%3Cpath d='M50 200l50-30v60z' fill='%23ff6600' opacity='0.47'/%3E%3Cpath d='M200 340l-35-55h70z' fill='%23ff00ff' opacity='0.41'/%3E%3Crect x='360' y='120' width='35' height='35' transform='rotate(45 377 137)' fill='%23ffff00' opacity='0.53'/%3E%3Crect x='90' y='340' width='28' height='28' transform='rotate(30 104 354)' fill='%2300ffff' opacity='0.49'/%3E%3Ccircle cx='60' cy='360' r='12' fill='%23ff0066' opacity='0.53'/%3E%3Ccircle cx='370' cy='40' r='18' fill='%23ccff00' opacity='0.47'/%3E%3Ccircle cx='220' cy='160' r='10' fill='%23ff00ff' opacity='0.44'/%3E%3Ccircle cx='110' cy='290' r='15' fill='%23ffff00' opacity='0.47'/%3E%3Cpath d='M10 140q25-30 50 0t50 0' stroke='%237a00ff' stroke-width='5' fill='none' opacity='0.41'/%3E%3Cpath d='M320 340q30-30 60 0t60 0' stroke='%23ff0066' stroke-width='4' fill='none' opacity='0.37'/%3E%3Cpath d='M60 270q20-40 40 0t40 0' stroke='%2300ffcc' stroke-width='4' fill='none' opacity='0.41'/%3E%3Cpath d='M280 40l-15 30 30 0z' fill='%23ffcc00' opacity='0.49'/%3E%3Cpath d='M30 340l20-35 20 35z' fill='%2300ccff' opacity='0.44'/%3E%3Crect x='320' y='300' width='20' height='50' transform='rotate(20 330 325)' fill='%23ff66cc' opacity='0.41'/%3E%3Cpath d='M180 80l20 20 20-20-20-20z' fill='%2332cd32' opacity='0.47'/%3E%3Ccircle cx='330' cy='200' r='8' fill='%23ff4500' opacity='0.49'/%3E%3Crect x='20' y='240' width='15' height='15' transform='rotate(75 27 247)' fill='%23ff1493' opacity='0.47'/%3E%3C/svg%3E");
  --memphis-v2: url("data:image/svg+xml,%3Csvg width='300' height='300' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M50 40l30-50 30 50z' fill='%23ff1493' opacity='0.35'/%3E%3Cpath d='M220 60l-20 35h40z' fill='%2300ced1' opacity='0.3'/%3E%3Ccircle cx='80' cy='200' r='15' fill='%23ffd700' opacity='0.25'/%3E%3Ccircle cx='250' cy='250' r='8' fill='%23ff4500' opacity='0.3'/%3E%3Cpath d='M10 150q25-25 50 0t50 0' stroke='%239320d6' stroke-width='5' fill='none' opacity='0.3'/%3E%3Cpath d='M180 280q20-20 40 0' stroke='%23ff1493' stroke-width='4' fill='none' opacity='0.35'/%3E%3Crect x='150' y='100' width='20' height='20' transform='rotate(45 160 110)' fill='%2332cd32' opacity='0.3'/%3E%3Crect x='40' y='260' width='15' height='15' transform='rotate(60 47 267)' fill='%23ff69b4' opacity='0.4'/%3E%3Cpath d='M270 180l-15 25 30 0z' fill='%23ffa500' opacity='0.3'/%3E%3C/svg%3E");
}

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

html {
  scroll-behavior: smooth;
  min-height: 100%;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: "Plus Jakarta Sans", "DM Sans", system-ui, sans-serif;
  font-weight: 500;
  color: var(--line);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  background-color: var(--paper);
  background-image:
    var(--memphis),
    linear-gradient(90deg, var(--grid-ink) 1px, transparent 1px),
    linear-gradient(0deg, var(--grid-ink-2) 1px, transparent 1px);
  background-size: 300px 300px, var(--grid-cell) var(--grid-cell), var(--grid-cell) var(--grid-cell);
  background-position: 0 0, -1px -1px, -1px -1px;
  background-attachment: fixed, fixed, fixed;
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: 0.04;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.home .navbar,
.home .zine-spread,
.home .zine-marquee,
.home .footer,
.site-wrap {
  position: relative;
  z-index: 1;
}

.container {
  max-width: min(1080px, 93vw);
  margin: 0 auto;
  padding: 0 1rem 2rem;
}

.footer .container {
  max-width: min(1000px, 93vw);
  padding-top: 0;
}

/* ——— Navbar ——— */
.navbar {
  position: sticky;
  top: 0;
  z-index: 200;
  background: var(--line);
  border-bottom: 3px solid transparent;
  border-image: linear-gradient(90deg, var(--sky), var(--banana), var(--coral), var(--vapor-magenta)) 1;
  box-shadow: 0 4px 0 rgba(0, 0, 0, 0.15);
}

.navbar-content {
  max-width: min(1140px, 94vw);
  margin: 0 auto;
  padding: 0.55rem 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.navbar .brand {
  font-family: "Archivo Black", sans-serif;
  font-size: 1.35rem;
  color: #fff;
  text-decoration: none;
  letter-spacing: 0.03em;
  text-transform: lowercase;
}

.navbar .brand:hover { color: var(--banana); }

.navbar .nav-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.15rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.navbar .nav-link {
  font-family: "Chakra Petch", sans-serif;
  font-weight: 600;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255, 255, 255, 0.72);
  text-decoration: none;
  padding: 0.4rem 0.6rem;
  border-radius: 4px;
}

.navbar .nav-link:hover,
.navbar .nav-link:focus-visible {
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
}

.navbar .nav-link--cta {
  background: var(--coral);
  color: #fff;
}

.navbar .nav-link--cta:hover {
  background: #ff2d6b;
}

.navbar .nav-link:focus-visible {
  outline: 2px solid var(--sky);
  outline-offset: 2px;
}

/* ——— Zine spread ——— */
.zine-spread {
  min-height: calc(100dvh - 3.5rem);
  padding: clamp(1.25rem, 4vw, 2.5rem) 0 clamp(2rem, 5vw, 3.5rem);
  overflow-x: clip;
}

.zine-paper {
  display: none;
}

.zine-inner {
  max-width: min(1100px, 94vw);
  margin: 0 auto;
  padding: 0 1rem;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(260px, 0.95fr);
  grid-template-rows: auto auto auto auto 1fr;
  gap: 0 1.5rem;
  align-items: start;
}

.zine-title-block {
  grid-column: 1;
  grid-row: 1 / 3;
  padding-right: clamp(0.5rem, 3vw, 2rem);
  align-self: center;
}

.zine-masthead {
  font-family: "Archivo Black", sans-serif;
  font-size: clamp(4rem, 18vw, 11rem);
  font-weight: 400;
  line-height: 0.88;
  margin: 0;
  letter-spacing: -0.04em;
  color: var(--line);
  transform: rotate(-2.5deg);
  transform-origin: 0 50%;
  text-shadow:
    3px 3px 0 var(--banana),
    6px 6px 0 rgba(225, 29, 104, 0.25);
}

.zine-strip {
  font-family: "Caveat", cursive;
  font-size: clamp(1.75rem, 5vw, 2.75rem);
  font-weight: 700;
  margin: 0.75rem 0 0;
  padding: 0.35rem 1.25rem 0.5rem;
  display: inline-block;
  background: #fffef8;
  color: var(--coral);
  border: 2px dashed var(--line);
  box-shadow: 4px 4px 0 var(--sky), 8px 8px 0 rgba(0, 0, 0, 0.06);
  transform: rotate(1deg);
  clip-path: polygon(
    0% 8%, 3% 0%, 12% 4%, 22% 0%, 35% 5%, 48% 0%, 62% 6%, 78% 2%, 92% 7%, 100% 3%,
    98% 18%, 100% 32%, 97% 48%, 100% 62%, 98% 78%, 100% 92%, 95% 100%,
    82% 97%, 68% 100%, 52% 96%, 38% 100%, 22% 95%, 8% 100%, 0% 92%,
    2% 78%, 0% 62%, 3% 45%, 0% 28%
  );
}

.zine-tagline {
  margin: 1.5rem 0 0;
  max-width: 36ch;
  font-size: clamp(0.95rem, 2vw, 1.1rem);
  font-weight: 600;
  color: var(--ink-muted);
  transform: rotate(-0.5deg);
}

.zine-tagline strong {
  color: var(--line);
  font-weight: 800;
  background: linear-gradient(transparent 60%, var(--banana) 60%);
}

.home-hero-tagline {
  margin: 1rem 0 0;
  max-width: 42ch;
  font-size: clamp(1.05rem, 2.4vw, 1.35rem);
  font-weight: 800;
  color: var(--line);
  line-height: 1.35;
  letter-spacing: -0.02em;
}

.caveat {
  font-family: "Caveat", cursive;
  font-size: clamp(1.2rem, 3vw, 1.55rem);
  font-weight: 700;
  color: var(--coral);
  margin: 0.65rem 0 0;
  max-width: 38ch;
  line-height: 1.25;
  transform: rotate(-0.8deg);
}

.home-mini-playground {
  margin-top: 1.25rem;
  border: 3px solid var(--line);
  border-radius: 8px;
  background: var(--surface-solid, #fffef8);
  box-shadow: 5px 5px 0 var(--lavender);
  overflow: hidden;
  max-width: min(100%, 52ch);
}

.home-mini-playground-chrome {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.4rem 0.65rem;
  background: var(--line);
  color: #fff;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.72rem;
  font-weight: 700;
}

.home-mini-run-btn {
  font-family: inherit;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 0.35rem 0.65rem;
  border: 2px solid #fff;
  border-radius: 4px;
  background: var(--coral);
  color: #fff;
  cursor: pointer;
}

.home-mini-run-btn:hover {
  filter: brightness(1.08);
}

.home-mini-textarea {
  display: block;
  width: 100%;
  margin: 0;
  padding: 0.65rem 0.75rem;
  border: none;
  border-top: 2px dashed rgba(26, 20, 40, 0.15);
  font-family: "JetBrains Mono", monospace;
  font-size: 0.78rem;
  line-height: 1.45;
  resize: vertical;
  min-height: 7rem;
  background: transparent;
  color: var(--line);
}

.home-mini-output {
  min-height: 2rem;
  padding: 0.5rem 0.75rem 0.65rem;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.75rem;
  background: rgba(0, 200, 224, 0.08);
  border-top: 2px solid var(--line);
  white-space: pre-wrap;
  color: var(--line);
}

.home-badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-top: 1rem;
}

.home-cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 1rem;
}

.home-cta {
  display: inline-block;
  padding: 0.45rem 0.9rem;
  border: 3px solid var(--line);
  border-radius: 6px;
  background: #fff;
  color: var(--line);
  font-weight: 800;
  font-size: 0.78rem;
  text-decoration: none;
  box-shadow: 4px 4px 0 var(--sky);
  letter-spacing: 0.02em;
}

.home-cta:hover {
  transform: translate(-1px, -1px);
  box-shadow: 5px 5px 0 var(--banana);
}

.home-cta--hot {
  background: var(--coral);
  color: #fff;
  border-color: var(--line);
  box-shadow: 4px 4px 0 var(--banana);
}

.home-status {
  margin-top: 1rem;
  padding: 0.55rem 0.75rem;
  border: 2px dashed var(--border-strong);
  border-radius: 8px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--ink-muted);
  max-width: 52ch;
  background: rgba(255, 255, 255, 0.5);
}

.home-status-ok {
  color: var(--mint);
  font-weight: 900;
}

.footer-private-note {
  text-align: center;
  font-size: 0.85rem;
  color: var(--ink-muted);
  margin: 0 0 1.25rem;
  max-width: 52rem;
  margin-left: auto;
  margin-right: auto;
}

/* Code sticker */
.zine-code-sticker {
  grid-column: 2;
  grid-row: 1 / 3;
  margin: 0;
  margin-top: clamp(1rem, 4vw, 2.5rem);
  margin-left: clamp(-1rem, -4vw, -0.5rem);
  justify-self: end;
  position: relative;
  z-index: 3;
  transform: rotate(3.5deg);
  max-width: 100%;
}

.zine-tape {
  position: absolute;
  height: 22px;
  background: rgba(255, 235, 150, 0.85);
  border: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12);
  z-index: 4;
  pointer-events: none;
}

.zine-tape--tl {
  width: 72px;
  top: -10px;
  left: 18%;
  transform: rotate(-35deg);
}

.zine-tape--br {
  width: 64px;
  bottom: 14px;
  right: 12%;
  transform: rotate(42deg);
}

.zine-window {
  border-radius: 6px;
  overflow: hidden;
  border: 3px solid var(--line);
  box-shadow:
    8px 8px 0 var(--coral),
    16px 16px 0 rgba(0, 0, 0, 0.08),
    0 0 0 1px rgba(255, 255, 255, 0.5) inset;
  background: #0f0a1a;
}

.zine-window-chrome {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.55rem 0.75rem;
  background: #1a1230;
  border-bottom: 2px solid var(--line);
}

.hero-dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background: #ff5f57;
  box-shadow: 1rem 0 0 #febc2e, 2rem 0 0 #28c840;
}

.zine-window-title {
  margin-left: 1.35rem;
  flex: 1;
  text-align: center;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.65rem;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.35);
  letter-spacing: 0.04em;
}

.zine-window-body {
  margin: 0;
  padding: 1rem 1.05rem 1.15rem;
  font-family: "JetBrains Mono", monospace;
  font-size: clamp(0.72rem, 1.6vw, 0.82rem);
  line-height: 1.65;
  color: rgba(240, 238, 255, 0.92);
  white-space: pre;
  overflow-x: auto;
}

.hw-k { color: var(--pink); font-weight: 700; }
.hw-fn { color: var(--sky); font-weight: 700; }
.hw-s { color: var(--lavender); }
.hw-n { color: var(--banana); font-weight: 700; }

/* Label tape tags */
.zine-tag-cloud {
  grid-column: 1 / -1;
  grid-row: 3;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.65rem;
  margin-top: clamp(1.25rem, 3vw, 2rem);
  padding-left: 0.25rem;
}

.zine-label {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0.4rem 0.65rem;
  border: 2px solid var(--line);
  box-shadow: 3px 3px 0 rgba(0, 0, 0, 0.12);
}

.zine-label--coral { background: var(--coral); color: #fff; transform: rotate(-2deg); }
.zine-label--sky { background: var(--sky); color: #042830; transform: rotate(1.5deg); }
.zine-label--banana { background: var(--banana); color: var(--line); transform: rotate(-1deg); }
.zine-label--slime { background: var(--slime); color: #052208; transform: rotate(2.5deg); }

/* Stamp buttons */
.zine-stamps {
  grid-column: 1 / -1;
  grid-row: 4;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
  margin-top: 1.5rem;
}

.zine-stamp {
  font-family: "Chakra Petch", sans-serif;
  font-weight: 700;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  text-decoration: none;
  padding: 0.65rem 1.35rem;
  border: 3px solid var(--line);
  transition: transform 0.2s var(--ease-pop), box-shadow 0.2s;
}

.zine-stamp--hot {
  background: var(--coral);
  color: #fff;
  box-shadow: 5px 5px 0 var(--line);
  transform: rotate(-1deg);
}

.zine-stamp--plain {
  background: #fff;
  color: var(--line);
  box-shadow: 5px 5px 0 var(--sky);
  transform: rotate(1.5deg);
}

.zine-stamp--ghost {
  background: transparent;
  color: var(--line);
  border-style: dashed;
  box-shadow: none;
  transform: rotate(-0.5deg);
}

@media (hover: hover) {
  .zine-stamp:hover {
    transform: translate(-2px, -2px) rotate(0deg);
    box-shadow: 7px 7px 0 var(--line);
  }
  .zine-stamp--ghost:hover {
    background: rgba(255, 255, 255, 0.6);
  }
}

/* Explorable clippings */
.zine-explore {
  grid-column: 1 / -1;
  grid-row: 5;
  margin-top: clamp(2rem, 5vw, 3.5rem);
}

.zine-explore-heading {
  font-family: "Chakra Petch", sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin: 0 0 1rem;
  transform: rotate(-0.8deg);
}

.zine-clippings {
  position: relative;
  min-height: 380px;
  margin-bottom: 1rem;
}

.zine-clip {
  position: absolute;
  width: min(220px, 46vw);
  margin: 0;
  border: none;
  background: transparent;
}

.zine-clip summary {
  list-style: none;
  cursor: pointer;
  outline: none;
  font-family: "Archivo Black", sans-serif;
  font-size: 0.82rem;
  letter-spacing: 0.02em;
  padding: 0.65rem 0.85rem;
  background: #fffef6;
  color: var(--line);
  border: 2px solid var(--line);
  box-shadow: 4px 4px 0 rgba(0, 0, 0, 0.12);
  transition: transform 0.2s var(--ease-pop), box-shadow 0.2s;
}

.zine-clip summary::-webkit-details-marker { display: none; }

.zine-clip summary::after {
  content: " +";
  font-family: "JetBrains Mono", monospace;
  font-weight: 700;
  opacity: 0.45;
}

.zine-clip[open] summary::after {
  content: " −";
}

.zine-clip-body {
  margin-top: 0.35rem;
  padding: 0.75rem 0.85rem;
  background: #fff;
  border: 2px dashed var(--line);
  font-size: 0.86rem;
  font-weight: 600;
  color: var(--ink-muted);
  line-height: 1.5;
  box-shadow: 3px 3px 0 var(--banana);
}

.zine-clip-body p { margin: 0 0 0.5rem; }
.zine-clip-body p:last-child { margin-bottom: 0; }

.zine-clip-body a {
  color: var(--coral);
  font-weight: 700;
}

.zine-mini-code {
  margin: 0 0 0.5rem;
  padding: 0.5rem;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.72rem;
  background: #0f0a1a;
  color: #e8e6f5;
  border: 2px solid var(--line);
}

.c-kw { color: var(--pink); }
.c-num { color: var(--banana); }
.c-fn { color: var(--sky); }

.zine-clip--one { left: 0%; top: 4%; transform: rotate(-4deg); z-index: 2; }
.zine-clip--two { right: 2%; top: 0%; transform: rotate(3.5deg); z-index: 2; }
.zine-clip--three { left: 32%; top: 32%; transform: rotate(2deg); z-index: 1; }
.zine-clip--four { right: 0%; top: 38%; transform: rotate(-5deg); z-index: 2; }
.zine-clip--five { left: 6%; top: 58%; transform: rotate(-2deg); z-index: 1; }
.zine-clip--six { right: 22%; top: 52%; transform: rotate(4deg); z-index: 1; }

@media (hover: hover) {
  .zine-clip summary:hover {
    transform: translateY(-3px);
    box-shadow: 6px 6px 0 rgba(0, 0, 0, 0.15);
  }
}

.zine-clip[open] {
  z-index: 10;
}

.zine-clip[open] summary {
  background: var(--banana);
}

.zine-clip summary:focus-visible {
  outline: 3px solid var(--coral);
  outline-offset: 2px;
}

/* Marquee */
.zine-marquee {
  overflow: hidden;
  background: var(--line);
  color: var(--sky);
  border-top: 4px solid var(--coral);
  border-bottom: 4px solid var(--banana);
  padding: 0.55rem 0;
}

.zine-marquee__track {
  display: flex;
  width: max-content;
  animation: zine-marquee 28s linear infinite;
}

.zine-marquee__content {
  flex-shrink: 0;
  padding: 0 2rem;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  white-space: nowrap;
}

@keyframes zine-marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* Footer */
.footer {
  padding: 2.5rem 0;
  background:
    linear-gradient(180deg, rgba(0, 200, 224, 0.08) 0%, transparent 40%),
    linear-gradient(185deg, #1a1040 0%, var(--line) 50%, #0a0618 100%);
  color: rgba(255, 255, 255, 0.85);
  font-weight: 600;
  font-size: 0.88rem;
  position: relative;
}

.footer::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--strip);
}

.footer::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--memphis);
  background-size: 200px 200px;
  opacity: 0.03;
  pointer-events: none;
}

.footer .container { position: relative; z-index: 1; }

.footer-content {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 1.5rem;
}

.footer-column h4 {
  font-family: "Chakra Petch", sans-serif;
  color: var(--banana);
  margin: 0 0 0.6rem;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.footer-column p,
.footer-column li {
  color: rgba(255, 255, 255, 0.7);
  font-size: 0.86rem;
  font-weight: 500;
}

.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-links li { margin: 0.3rem 0; }

.footer-links a {
  color: var(--sky);
  text-decoration: none;
  font-weight: 600;
}

.footer-links a:hover {
  color: #fff;
  text-decoration: underline;
}

.footer-bottom {
  margin-top: 2rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  text-align: center;
  font-size: 0.8rem;
  color: rgba(255, 255, 255, 0.45);
}

/* Homepage responsive */
@media (max-width: 820px) {
  .zine-inner {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
  }

  .zine-title-block {
    grid-column: 1;
    grid-row: 1;
    padding-right: 0;
  }

  .zine-code-sticker {
    grid-column: 1;
    grid-row: 2;
    margin-left: 0;
    margin-top: 1.5rem;
    justify-self: center;
    transform: rotate(1.5deg);
    max-width: min(100%, 400px);
  }

  .zine-tag-cloud {
    grid-column: 1;
    grid-row: 3;
    justify-content: flex-start;
  }

  .zine-stamps {
    grid-column: 1;
    grid-row: 4;
  }

  .zine-explore {
    grid-column: 1;
    grid-row: 5;
  }

  .zine-clippings {
    position: static;
    min-height: auto;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-top: 1rem;
  }

  .zine-clip {
    position: static;
    width: 100%;
    max-width: 100%;
    transform: none !important;
  }

  .zine-clip summary {
    transform: none;
  }
}

@media (max-width: 720px) {
  .navbar-content {
    flex-direction: column;
    align-items: stretch;
    gap: 0.5rem;
  }
  .navbar .nav-links {
    justify-content: center;
  }
  .nav-actions {
    justify-content: center;
  }
}

@media (max-width: 520px) {
  .navbar .nav-links {
    flex-wrap: wrap;
    justify-content: center;
  }
  .nav-actions {
    justify-content: center;
  }
}

@media (prefers-reduced-motion: reduce) {
  .zine-marquee__track {
    animation: none;
    justify-content: center;
    flex-wrap: wrap;
    width: 100%;
  }
  .zine-masthead {
    text-shadow: none;
  }
}
/* ——— Inner layout (zine system — matches homepage energy) ——— */
.site-wrap {
  width: min(1080px, 93vw);
  margin: 0 auto;
  padding: 0 0 1.5rem;
}

.top-nav {
  position: sticky;
  top: 0;
  z-index: 150;
  margin-top: 0.65rem;
  margin-bottom: 0.35rem;
  padding: 0.55rem 1rem 0.65rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  background: var(--line);
  border: 3px solid var(--line);
  border-radius: 8px;
  box-shadow: 6px 6px 0 rgba(0, 200, 224, 0.35), 10px 10px 0 rgba(0, 0, 0, 0.06);
}

.top-nav::after {
  content: "";
  position: absolute;
  left: -3px;
  right: -3px;
  bottom: -3px;
  height: 5px;
  background: var(--strip);
  border-radius: 0 0 5px 5px;
  pointer-events: none;
}

.top-nav .brand {
  text-decoration: none;
  font-family: "Archivo Black", sans-serif;
  font-size: clamp(1.05rem, 2.5vw, 1.35rem);
  font-weight: 400;
  letter-spacing: 0.02em;
  text-transform: lowercase;
  padding: 0.35rem 0;
  color: #fff;
}

.top-nav .brand:hover {
  color: var(--banana);
}

.top-nav .nav-links {
  display: flex;
  gap: 0.2rem;
  flex-wrap: wrap;
  align-items: center;
}

.top-nav .nav-links a {
  color: rgba(255, 255, 255, 0.72);
  text-decoration: none;
  font-family: "Chakra Petch", sans-serif;
  font-weight: 600;
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 0.4rem 0.6rem;
  border-radius: 4px;
  transition: color 0.15s ease, background 0.15s ease;
}

.top-nav .nav-links a:hover,
.top-nav .nav-links a:focus-visible {
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
  outline: none;
}

.top-nav .nav-links a[href="/download/"],
.top-nav .nav-links a[href$="/download/"] {
  background: var(--coral);
  color: #fff;
}

.top-nav .nav-links a[href="/download/"]:hover,
.top-nav .nav-links a[href$="/download/"]:hover,
.top-nav .nav-links a[href="/download/"]:focus-visible,
.top-nav .nav-links a[href$="/download/"]:focus-visible {
  background: #ff2d6b;
  color: #fff;
}

.top-nav .nav-links a:focus-visible {
  outline: 2px solid var(--sky);
  outline-offset: 2px;
}

main.container,
.site-wrap .container,
.install-container .container {
  max-width: min(1080px, 93vw);
  margin: 0 auto;
  padding: 0 1rem 2rem;
}

.install-container {
  max-width: min(900px, 94vw);
  margin: 0 auto;
  padding: 0 1rem 2rem;
}

.site-wrap .hero,
main .hero,
.install-container .hero,
.effective-container .hero {
  margin-top: 1.75rem;
  border: 3px solid var(--line);
  border-radius: 6px;
  background: #fffef8;
  padding: clamp(1.2rem, 3vw, 2rem);
  box-shadow: 8px 8px 0 var(--coral), 12px 12px 0 rgba(0, 0, 0, 0.04);
  position: relative;
  overflow: visible;
}

.site-wrap .hero::after,
main .hero::after,
.install-container .hero::after {
  display: none;
}

.site-wrap .hero > *,
main .hero > *,
.install-container .hero > *,
.effective-container .hero > * {
  position: relative;
  z-index: 1;
}

h1 {
  line-height: 1.12;
  margin: 0.2rem 0 0;
  font-size: clamp(1.85rem, 4.2vw, 3.1rem);
  max-width: 24ch;
  text-transform: none;
  letter-spacing: -0.02em;
  font-family: "Archivo Black", "Chakra Petch", sans-serif;
  font-weight: 400;
  color: var(--line);
}

.lead {
  color: var(--ink-muted);
  margin-top: 0.85rem;
  max-width: 72ch;
  font-weight: 600;
  font-size: 1.04rem;
  line-height: 1.55;
}

.pill {
  display: inline-block;
  border: 2px solid var(--line);
  border-radius: 4px;
  background: var(--sky);
  color: #042830;
  padding: 0.3rem 0.75rem;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.68rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
  box-shadow: 3px 3px 0 var(--line);
  margin-bottom: 0.35rem;
}

.content-box {
  margin-top: 1.5rem;
  padding: 1.4rem 1.35rem;
  border: 3px solid var(--line);
  border-radius: 6px;
  background: #fff;
  box-shadow: 6px 6px 0 var(--lavender), 0 0 0 1px rgba(0, 0, 0, 0.04) inset;
}

/* Lead block on marketing pages (matches other content-box sections, not the coral hero card) */
.content-box.about-lead {
  margin-top: 1.75rem;
}

.content-box.about-lead .pill {
  display: inline-block;
  margin-bottom: 0.5rem;
}

.content-box.about-lead h1 {
  margin: 0 0 0.5rem;
  border-bottom: 1px solid var(--border-strong);
  padding-bottom: 0.35rem;
  display: block;
}

/* Content surface - solid panel so text sits on paper, not the memphis grid */
.content-surface {
  background: var(--surface-solid);
  border: 2px solid var(--line);
  border-radius: 12px;
  padding: 1.25rem clamp(1rem, 3vw, 1.75rem) 2.5rem;
  margin-top: 0.75rem;
  box-shadow: var(--shadow-pop-sm);
}

.content-box h2 {
  margin: 0 0 0.75rem;
  font-size: 1.2rem;
  text-transform: none;
  letter-spacing: -0.01em;
  border-bottom: 1px solid var(--border-strong);
  padding-bottom: 0.35rem;
  display: inline-block;
}

.content-box h3 {
  margin: 1rem 0 0.5rem;
  font-size: 1.05rem;
}

/* Doc pages: stack bordered sections (e.g. host contract tables) */
.doc-page .doc-body--stacked > .content-box:first-of-type {
  margin-top: 1.35rem;
}

.content-box.content-box--nav .nav-guide {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}

/* Stdlib module pages: scope note (overview vs full source API) */
.stdlib-doc-scope {
  margin: 0.35rem 0 1.25rem;
  padding: 0.55rem 0 0.55rem 0.85rem;
  border-left: 3px solid var(--line);
  font-size: 0.9rem;
  line-height: 1.5;
  color: #4a4a55;
}

[data-theme="dark"] .stdlib-doc-scope {
  color: #4a4a55;
  border-left-color: #000;
}

pre.code-block,
.code-block {
  margin: 0.75rem 0;
  padding: 1rem 1.1rem;
  border-radius: 4px;
  border: 3px solid var(--line);
  background: #0f0a1a;
  color: rgba(240, 238, 255, 0.92);
  font-size: 0.88rem;
  font-weight: 600;
  line-height: 1.45;
  overflow-x: auto;
  box-shadow: 5px 5px 0 var(--sky);
  font-family: "JetBrains Mono", ui-monospace, monospace;
}

.comparison {
  margin: 1rem 0;
  overflow-x: auto;
  border: 3px solid var(--line);
  border-radius: 6px;
  background: #fff;
  box-shadow: 5px 5px 0 var(--tangelo);
}

.comparison table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.comparison th,
.comparison td {
  padding: 0.65rem 0.85rem;
  text-align: left;
  border-bottom: 1px solid var(--border);
}

.comparison th {
  background: var(--lavender);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 0.75rem;
}

.comparison-highlight {
  background: var(--mint);
  font-weight: 700;
}

.quote {
  margin: 1.25rem 0;
  padding: 1rem 1rem 1rem 1.25rem;
  border: 3px solid var(--line);
  border-left-width: 6px;
  border-left-color: var(--coral);
  background: var(--sky);
  border-radius: 0 6px 6px 0;
  box-shadow: 4px 4px 0 var(--line);
  font-style: italic;
  font-weight: 600;
  color: var(--ink);
}

.feature-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1rem;
  margin-top: 1rem;
}

.feature-grid .feature-card {
  border: 3px solid var(--line);
  border-radius: 6px;
  padding: 1rem 1.1rem;
  background: #fff;
  box-shadow: 5px 5px 0 var(--mint);
}

.feature-grid .feature-card h3 {
  margin: 0 0 0.35rem;
  font-size: 1rem;
  text-transform: none;
  letter-spacing: -0.01em;
}

.docs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1rem;
  margin-top: 1.5rem;
}

.docs-card {
  border: 3px solid var(--line);
  border-radius: 6px;
  padding: 1.15rem;
  background: #fff;
  box-shadow: 6px 6px 0 var(--slime);
  transition: transform 0.2s var(--ease-pop), box-shadow 0.2s ease;
}

@media (hover: hover) {
  .docs-card:hover {
    transform: translate(-2px, -2px);
    box-shadow: 8px 8px 0 var(--sky);
  }
}

.docs-card h2 {
  margin: 0 0 0.65rem;
  font-size: 1.05rem;
  text-transform: none;
  letter-spacing: -0.01em;
  font-weight: 800;
}

.docs-card ul {
  margin: 0;
  padding-left: 1.15rem;
  font-weight: 600;
}

.docs-card h3 {
  margin: 0 0 0.4rem;
  font-size: 1rem;
  font-weight: 800;
}

.docs-card p {
  margin: 0;
  font-size: 0.87rem;
  color: #555;
  line-height: 1.4;
}

.docs-flow {
  margin: 1.5rem 0;
}

.docs-section {
  margin-bottom: 2.5rem;
}

.docs-section h2 {
  margin: 0 0 1rem;
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--line);
}

.docs-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1rem;
}

.docs-cards--compact {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.docs-link {
  padding: 0.5rem 1rem;
  background: #fff;
  border: 2px solid var(--line);
  border-radius: 4px;
  text-decoration: none;
  color: var(--line);
  font-weight: 700;
  font-size: 0.85rem;
  transition: transform 0.2s var(--ease-pop), box-shadow 0.2s ease;
}

@media (hover: hover) {
  .docs-link:hover {
    transform: translate(-2px, -2px);
    box-shadow: 4px 4px 0 var(--sky);
  }
}

.docs-card--primary {
  border-color: var(--coral);
  box-shadow: 6px 6px 0 var(--coral);
}

@media (hover: hover) {
  .docs-card--primary:hover {
    box-shadow: 8px 8px 0 var(--coral);
  }
}

.docs-section--secondary h2 {
  font-size: 1rem;
  opacity: 0.8;
}

/* Cookbook styles */
.recipe-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
  margin: 1.5rem 0 2.5rem;
}

.recipe-card {
  background: #fff;
  border: 2px solid var(--line);
  border-radius: 8px;
  padding: 1rem 1.1rem;
  box-shadow: 4px 4px 0 var(--line);
  text-decoration: none;
  color: inherit;
  display: block;
  transition: transform 0.1s, box-shadow 0.1s;
}

.recipe-card:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 var(--line);
}

.recipe-card h3 {
  margin: 0 0 0.35rem;
  font-size: 0.95rem;
  font-weight: 800;
}

.recipe-card p {
  margin: 0;
  font-size: 0.8rem;
  color: #555;
  line-height: 1.4;
}

.recipe-tag {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 0.7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-right: 3px;
  margin-bottom: 6px;
}

.tag-wifi   { background: #dbeafe; color: #1e40af; }
.tag-nfc    { background: #fef3c7; color: #92400e; }
.tag-gps    { background: #d1fae5; color: #065f46; }
.tag-web    { background: #fce7f3; color: #9d174d; }
.tag-foren  { background: #f3f4f6; color: #374151; }
.tag-sbx    { background: #ede9fe; color: #5b21b6; }
.tag-lora   { background: #fee2e2; color: #991b1b; }
.tag-data   { background: #dbeafe; color: #1e40af; }

.recipe-section {
  margin-bottom: 4rem;
  padding-top: 1rem;
  border-top: 3px solid var(--line);
}

.recipe-section h2 {
  font-size: 1.4rem;
  margin-bottom: 0.5rem;
}

.recipe-meta {
  display: flex;
  gap: 0.5rem;
  margin: 0.75rem 0;
  flex-wrap: wrap;
}

.recipe-meta span {
  font-size: 0.78rem;
  font-weight: 700;
  color: #666;
}

.why-box {
  background: #fffbeb;
  border: 2px solid #f59e0b;
  border-radius: 6px;
  padding: 0.75rem 1rem;
  margin: 1rem 0;
  font-size: 0.88rem;
  line-height: 1.65;
}

.why-box strong { color: #92400e; }

.why-box code {
  vertical-align: baseline;
  font-size: 0.92em;
  line-height: inherit;
  padding: 0.08em 0.32em;
  border-radius: 3px;
}

.step-list {
  counter-reset: steps;
  list-style: none;
  padding: 0;
  margin: 0.75rem 0;
}

.step-list li {
  counter-increment: steps;
  display: flex;
  gap: 0.75rem;
  margin-bottom: 0.6rem;
  font-size: 0.88rem;
  line-height: 1.5;
}

.step-list li::before {
  content: counter(steps);
  min-width: 1.5rem;
  height: 1.5rem;
  background: var(--line);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.72rem;
  font-weight: 800;
  flex-shrink: 0;
  margin-top: 0.1rem;
}

.code-annotated {
  background: #0e0a1a;
  color: #e8e0f8;
  border-radius: 8px;
  padding: 1.25rem 1.4rem;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.82rem;
  line-height: 1.65;
  overflow-x: auto;
  white-space: pre;
  margin: 1rem 0;
  border: 2px solid var(--line);
  position: relative;
}

.code-annotated .ann {
  color: #7c6fa0;
  font-style: italic;
}

.code-annotated .kw  { color: #c084fc; }
.code-annotated .fn  { color: #67e8f9; }
.code-annotated .str { color: #86efac; }
.code-annotated .num { color: #fbbf24; }
.code-annotated .mod { color: #f9a8d4; }

.copy-btn {
  position: absolute;
  top: 0.6rem;
  right: 0.6rem;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.15);
  color: #ccc;
  border-radius: 4px;
  padding: 2px 8px;
  font-size: 0.72rem;
  cursor: pointer;
  font-family: inherit;
}

.copy-btn:hover { background: rgba(255,255,255,0.15); }

.docs-container {
  display: grid;
  grid-template-columns: min(220px, 100%) 1fr;
  gap: 1.5rem;
  margin-top: 1.5rem;
  align-items: start;
}

/* Stdlib module pages: no sidebar → single content column, full width */
.docs-container:has(> main:only-child),
.docs-container:has(> .content-area:only-child) {
  grid-template-columns: 1fr;
  max-width: min(860px, 96vw);
  margin-left: auto;
  margin-right: auto;
}

/* ── Stdlib module page styles ─────────────────────────────────────── */
.module-header {
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 3px solid var(--line);
}
.module-header h1 { margin: 0 0 0.35rem; max-width: none; }
.module-header h1 code { font-size: 1.8rem; }
.module-tagline { margin: 0.2rem 0 0.5rem; font-size: 1.05rem; opacity: 0.8; }

.quick-start {
  margin-bottom: 1.5rem;
}
.quick-start h2 { margin-bottom: 0.5rem; }

.function-groups h2 { margin-bottom: 1rem; }

.function-group {
  margin-bottom: 1.5rem;
}
.function-group h3 {
  margin: 0 0 0.75rem;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  opacity: 0.65;
  border-bottom: 2px solid var(--border-strong);
  padding-bottom: 0.3rem;
}

.function-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 0.75rem;
}

.function-item {
  padding: 0.75rem 0.9rem;
  border: 2px solid var(--line);
  border-radius: 6px;
  background: #fffef6;
  box-shadow: 3px 3px 0 var(--lavender);
}
.function-item code {
  display: block;
  font-size: 0.88rem;
  font-weight: 700;
  margin-bottom: 0.3rem;
  word-break: break-all;
}
.function-item p { margin: 0; font-size: 0.85rem; opacity: 0.8; }
.function-item.aliases {
  grid-column: 1 / -1;
  background: #f4f0e8;
}
.function-item.aliases ul {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin: 0.5rem 0 0;
  padding: 0;
  list-style: none;
}
.function-item.aliases li code {
  display: inline;
  font-size: 0.82rem;
  background: #fff;
  border: 1px solid var(--border-strong);
  padding: 0.1rem 0.35rem;
  border-radius: 3px;
}

.notes { margin-top: 1.5rem; }
.notes h2 { margin-bottom: 0.5rem; }
.notes ul { padding-left: 1.25rem; }
.notes li { margin-bottom: 0.4rem; font-size: 0.9rem; }

.module-nav {
  margin-top: 2rem;
  padding-top: 1rem;
  border-top: 2px solid var(--border-strong);
  font-size: 0.9rem;
}

[data-theme="dark"] .function-item {
  background: #fffef6;
  border: 3px solid #000;
  border-radius: 8px;
  box-shadow: 4px 4px 0 #000;
  color: var(--line);
}
[data-theme="dark"] .function-item p { color: rgba(20, 20, 28, 0.78); opacity: 1; }
[data-theme="dark"] .function-item.aliases { background: #f4f0e8; }
[data-theme="dark"] .function-item.aliases li code {
  background: #fff;
  border: 2px solid #000;
  color: var(--line);
}

.sidebar {
  position: sticky;
  top: 1rem;
  border: 3px dashed var(--line);
  border-radius: 6px;
  padding: 1rem;
  background: #fffef6;
  box-shadow: 5px 5px 0 var(--tangelo);
}

.sidebar h3 { margin: 0 0 0.5rem; font-size: 1rem; }
.sidebar ul { list-style: none; padding: 0; margin: 0.5rem 0 0; }
.sidebar li { margin: 0.35rem 0; }
.sidebar a { color: var(--line); font-weight: 700; text-decoration: none; }
.sidebar a:hover { text-decoration: underline; }

.content-area {
  border: 3px solid var(--line);
  border-radius: 6px;
  padding: 1.35rem 1.2rem;
  background: #fff;
  box-shadow: 6px 6px 0 var(--pink);
}

.content-area h1 { max-width: none; }

.func-box {
  margin: 1.15rem 0;
  padding: 1rem;
  border: 3px solid var(--line);
  border-radius: 6px;
  background: #fffef8;
  box-shadow: 4px 4px 0 var(--sky);
}

.func-sig {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-weight: 700;
  font-size: 0.9rem;
  margin-bottom: 0.5rem;
  padding: 0.35rem 0.55rem;
  background: var(--lavender);
  border: 2px solid var(--line);
  display: inline-block;
  border-radius: 4px;
  box-shadow: 2px 2px 0 var(--line);
}

.platform-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 1.5rem 0 1rem;
}

.platform-tab {
  font-family: inherit;
  font-weight: 600;
  padding: 0.45rem 0.95rem;
  border: 2px solid var(--line);
  border-radius: 999px;
  background: #fff;
  cursor: pointer;
  font-size: 0.85rem;
  text-transform: none;
  letter-spacing: 0;
  box-shadow: 2px 2px 0 var(--lavender);
}

.platform-tab.active {
  background: var(--line);
  color: #fff;
  border-color: var(--line);
  box-shadow: 4px 4px 0 var(--coral);
}

.platform-content { margin-bottom: 1.5rem; }
.install-section { margin-bottom: 1.5rem; }
.install-section h2 { margin-top: 0; }

.step {
  display: flex;
  gap: 1rem;
  margin: 1rem 0;
  align-items: flex-start;
}

.step-num {
  flex-shrink: 0;
  width: 2.35rem;
  height: 2.35rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  background: var(--banana);
  color: var(--line);
  border: 3px solid var(--line);
  border-radius: 50%;
  font-size: 0.95rem;
  box-shadow: 2px 2px 0 var(--line);
}

.verify-box {
  margin-top: 0.85rem;
  padding: 0.75rem 1rem;
  border: 3px dashed var(--line);
  background: var(--mint);
  border-radius: 6px;
  font-weight: 600;
  box-shadow: 4px 4px 0 var(--line);
}

.btn {
  display: inline-block;
  text-decoration: none;
  font-weight: 700;
  border-radius: 4px;
  padding: 0.72rem 1.15rem;
  border: 3px solid var(--line);
  background: #fff;
  box-shadow: 4px 4px 0 var(--lavender);
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
  text-transform: none;
  letter-spacing: 0;
  cursor: pointer;
  font-family: inherit;
  font-size: 0.92rem;
}

.btn-primary {
  background: var(--coral);
  color: #fff;
  border: 3px solid var(--line);
  border-radius: 4px;
  box-shadow: 5px 5px 0 var(--line);
}

.btn-secondary {
  background: #fff;
  color: var(--line);
  border: 3px solid var(--line);
  box-shadow: 5px 5px 0 var(--sky);
}

.btn:hover,
.btn:focus-visible {
  transform: translate(-1px, -1px);
  box-shadow: 6px 6px 0 var(--line);
  outline: none;
}

.btn:focus-visible {
  outline: 2px solid var(--coral);
  outline-offset: 3px;
}

.btn:active {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 var(--line);
}

.btn-group {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-top: 1.25rem;
}

.playground-controls {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}

.playground-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.code-input {
  width: 100%;
  min-height: 280px;
  padding: 1rem;
  border: 3px solid var(--line);
  border-radius: 6px;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.88rem;
  line-height: 1.45;
  resize: vertical;
  background: #0f0a1a;
  color: rgba(240, 238, 255, 0.95);
  box-shadow: 5px 5px 0 var(--sky);
}

.code-input::placeholder {
  color: rgba(240, 238, 255, 0.35);
}

.playground-output {
  border: 3px solid var(--line);
  border-radius: 6px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 280px;
  box-shadow: 5px 5px 0 var(--coral);
}

.output-header {
  padding: 0.5rem 1rem;
  background: var(--banana);
  border-bottom: 3px solid var(--line);
  font-weight: 800;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--line);
}

#code-output {
  margin: 0;
  flex: 1;
  padding: 1rem;
  background: #1c1746;
  color: var(--mint);
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.88rem;
  overflow: auto;
  white-space: pre-wrap;
  word-break: break-word;
}

.test-transcript {
  max-height: 22rem;
  overflow: auto;
  white-space: pre-wrap;
  word-break: break-word;
}

.error { color: #ff8585; font-weight: 700; }

.example-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 1rem 0;
}

.example-btn {
  padding: 0.5rem 0.85rem;
  background: var(--sky);
  border: 2px solid var(--line);
  border-radius: 4px;
  font-weight: 800;
  cursor: pointer;
  font-family: inherit;
  font-size: 0.82rem;
  transition: 120ms ease;
  box-shadow: 2px 2px 0 var(--line);
}

.example-btn:hover {
  background: var(--banana);
  transform: translate(-1px, -1px);
  box-shadow: 3px 3px 0 var(--line);
}

.nav-guide {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 2rem;
  padding-top: 1.25rem;
  border-top: 3px dashed var(--line);
}

.nav-guide a {
  padding: 0.55rem 1rem;
  background: #fff;
  color: var(--line);
  text-decoration: none;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 0.72rem;
  border: 3px solid var(--line);
  border-radius: 4px;
  box-shadow: 4px 4px 0 var(--lavender);
}

.nav-guide a:hover {
  background: var(--banana);
  border-color: var(--line);
  transform: translate(-1px, -1px);
  box-shadow: 5px 5px 0 var(--line);
}

.site-wrap > .footer:not(:has(.container)) {
  text-align: center;
  text-transform: none;
  letter-spacing: 0;
  border-radius: 6px;
  border: 3px solid var(--line);
  margin: 1.5rem 0 0;
  padding: 1rem;
  background: #fffef8;
  color: var(--line);
  box-shadow: 6px 6px 0 var(--sky);
  font-weight: 600;
}

a {
  color: var(--coral);
  font-weight: 600;
}

a:hover { text-decoration: underline; }

.top-nav a.brand,
.navbar .brand { text-decoration: none; }

.top-nav a.brand:hover,
.navbar .brand:hover { text-decoration: none; }

strong { font-weight: 800; }

code {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-weight: 700;
  font-size: 0.875em;
  background: rgba(203, 184, 255, 0.35);
  padding: 0 0.32em;
  border-radius: 4px;
  border: 1px solid rgba(20, 16, 42, 0.12);
  vertical-align: baseline;
  line-height: 1.45;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

pre code,
.code-block code {
  background: transparent;
  border: none;
  padding: 0;
}

ul, ol { line-height: 1.65; }

.content-page {
  margin-top: 1.5rem;
  padding: 1.5rem;
  border: 3px solid var(--line);
  border-radius: 6px;
  background: #fff;
  box-shadow: 8px 8px 0 var(--coral);
}

.docs-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 1rem 0 1.5rem;
  padding: 1rem;
  background: var(--sky);
  border: 3px solid var(--line);
  border-radius: 6px;
  box-shadow: 5px 5px 0 var(--line);
}

.docs-nav a {
  color: var(--line);
  font-weight: 700;
  text-decoration: none;
  padding: 0.4rem 0.75rem;
  background: #fff;
  border: 2px solid var(--line);
  border-radius: 4px;
  box-shadow: 2px 2px 0 var(--lavender);
}

.docs-nav a:hover { background: var(--banana); }

.creator-quote {
  margin: 1.25rem 0 0;
  padding: 1rem 1.25rem;
  border-left: 4px solid var(--coral);
  background: rgba(225, 29, 104, 0.06);
  font-family: "Caveat", "Syne", cursive;
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--line);
}

.creator-quote p {
  margin: 0;
}

[data-theme="dark"] .creator-quote {
  background: #fffef8;
  border-left: 4px solid var(--coral);
  color: var(--line);
}

.docs-table {
  width: 100%;
  border-collapse: collapse;
  margin: 1rem 0;
  font-size: 0.9rem;
}

.docs-table th,
.docs-table td {
  padding: 0.65rem;
  border: 1px solid var(--border);
  text-align: left;
}

.docs-table th {
  background: var(--lavender);
  font-weight: 800;
}

.stdlib-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 0.5rem;
  margin: 1rem 0;
}

.stdlib-item {
  padding: 0.5rem 0.75rem;
  background: #fff;
  border: 2px solid var(--line);
  border-radius: 4px;
  font-size: 0.88rem;
  box-shadow: 2px 2px 0 var(--mint);
}

.spec-container {
  display: grid;
  grid-template-columns: min(220px, 100%) 1fr;
  gap: 1.5rem;
  margin-top: 1.5rem;
  align-items: start;
}

.spec-sidebar {
  position: sticky;
  top: 1rem;
  border: 3px dashed var(--line);
  border-radius: 6px;
  padding: 1rem;
  background: #fffef6;
  box-shadow: 5px 5px 0 var(--tangelo);
  font-size: 0.9rem;
}

.spec-sidebar h3 { margin: 0 0 0.5rem; font-size: 1rem; }
.spec-sidebar ul { list-style: none; padding: 0; margin: 0; }
.spec-sidebar li { margin: 0.3rem 0; }
.spec-sidebar a { color: var(--line); font-weight: 700; text-decoration: none; }
.spec-sidebar a:hover { text-decoration: underline; }

.spec-content {
  border: 3px solid var(--line);
  border-radius: 6px;
  padding: 1.35rem 1.2rem;
  background: #fff;
  box-shadow: 7px 7px 0 var(--vapor-magenta);
}

.spec-content h1 { max-width: none; }

.spec-section {
  margin: 2rem 0;
  padding-bottom: 1.5rem;
  border-bottom: 2px dashed rgba(26, 20, 51, 0.2);
}

.spec-section:last-child { border-bottom: none; }

.spec-section h2 {
  font-family: "Chakra Petch", "Syne", sans-serif;
  font-weight: 700;
  margin-top: 0;
  font-size: 1.35rem;
}

.grammar {
  margin: 0.75rem 0;
  padding: 0.85rem 1rem;
  background: #0f0a1a;
  color: rgba(240, 238, 255, 0.9);
  border: 3px solid var(--line);
  border-radius: 4px;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.82rem;
  line-height: 1.5;
  box-shadow: 4px 4px 0 var(--sky);
}

.grammar .term { font-weight: 700; color: var(--banana); }

.tour-container,
.effective-container {
  max-width: min(920px, 94vw);
  margin: 0 auto;
  padding: 0 1rem 2rem;
}

.effective-container > h2 {
  font-family: "Chakra Petch", "Syne", sans-serif;
  font-weight: 700;
  font-size: 1.25rem;
  margin: 2rem 0 0.75rem;
  text-transform: none;
  letter-spacing: 0.02em;
  border-bottom: 1px solid var(--border);
  padding-bottom: 0.25rem;
  display: inline-block;
}

.tip-box {
  margin: 1rem 0;
  padding: 1rem 1.15rem;
  border: 3px solid var(--line);
  border-radius: 6px;
  background: var(--sky);
  box-shadow: 5px 5px 0 var(--line);
}

.tip-box h4 {
  margin: 0 0 0.35rem;
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.warning-box {
  margin: 1rem 0;
  padding: 1rem 1.15rem;
  border: 3px dashed var(--line);
  border-radius: 6px;
  background: var(--banana);
  box-shadow: 5px 5px 0 var(--coral);
}

.warning-box h4 { margin: 0 0 0.35rem; color: var(--line); }

.nav-chapters {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin: 1.25rem 0;
  padding: 0.85rem;
  border: 3px solid var(--line);
  border-radius: 6px;
  background: var(--lavender);
  box-shadow: 5px 5px 0 var(--line);
}

.chapter-link {
  padding: 0.4rem 0.75rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.9);
  color: var(--line);
  font-weight: 600;
  font-size: 0.8rem;
  text-decoration: none;
  text-transform: none;
  letter-spacing: 0;
}

.chapter-link:hover,
.chapter-link:focus-visible {
  background: var(--banana);
  outline: none;
}

.chapter-link.active {
  background: var(--banana);
  box-shadow: 3px 3px 0 var(--line);
  border-color: var(--line);
}

.tour-section { margin: 2rem 0; }

.tour-section > h2 {
  font-family: "Chakra Petch", "Syne", sans-serif;
  font-weight: 700;
  font-size: 1.35rem;
  margin: 0 0 1rem;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid var(--border-strong);
  display: inline-block;
  letter-spacing: 0.02em;
}

.example-box {
  margin: 1rem 0;
  padding: 1.1rem 1.15rem;
  border: 3px solid var(--line);
  border-radius: 6px;
  background: #fff;
  box-shadow: 5px 5px 0 var(--slime);
}

.example-box h4 { margin: 0 0 0.5rem; font-size: 1rem; color: var(--coral); }

.exercise {
  margin: 1.25rem 0;
  padding: 1rem 1.15rem;
  border: 3px dashed var(--line);
  border-radius: 6px;
  background: var(--mint);
  box-shadow: 5px 5px 0 var(--line);
}

.exercise h4 { margin: 0 0 0.5rem; }

.stdlib-page {
  max-width: min(1100px, 96vw);
  margin: 0 auto;
  padding: 0 1rem 2rem;
}

.stdlib-toolbar { margin-bottom: 1rem; }

.catalog-meta {
  margin: 0 0 0.85rem;
  font-weight: 600;
  color: var(--ink);
  max-width: 85ch;
  line-height: 1.5;
}

.module-search {
  width: 100%;
  max-width: 32rem;
  padding: 0.55rem 0.85rem;
  font: inherit;
  font-weight: 600;
  border: 3px solid var(--line);
  border-radius: 4px;
  background: #fff;
  box-shadow: 4px 4px 0 var(--banana);
}

.filter-hint {
  margin: 0.5rem 0 0;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--ink);
}

.catalog-wrap {
  overflow-x: auto;
  margin-top: 0.5rem;
  border: 3px solid var(--line);
  border-radius: 6px;
  background: #fff;
  box-shadow: 6px 6px 0 var(--sky);
}

.stdlib-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.86rem;
}

.stdlib-table th,
.stdlib-table td {
  padding: 0.55rem 0.65rem;
  text-align: left;
  vertical-align: top;
  border-bottom: 2px solid rgba(26, 20, 51, 0.12);
}

.stdlib-table thead th {
  background: var(--lavender);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 0.72rem;
  border-bottom: 1px solid var(--border-strong);
  white-space: nowrap;
}

.stdlib-table tbody th { font-weight: 800; white-space: nowrap; }
.stdlib-table tbody tr:hover { background: rgba(168, 230, 255, 0.35); }

.domain-tag {
  display: inline-block;
  font-weight: 800;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 0.2rem 0.45rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--sky);
}

.summary-cell {
  font-weight: 600;
  color: var(--ink);
  line-height: 1.45;
  max-width: 56ch;
}

.stat-list {
  margin: 0.5rem 0 0;
  padding-left: 1.25rem;
  font-weight: 600;
  line-height: 1.7;
  max-width: 75ch;
}

.stat-list li { margin: 0.4rem 0; }

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.plain-list,
.step-list {
  margin: 0.5rem 0 0;
  padding-left: 1.25rem;
  font-weight: 600;
  line-height: 1.65;
  max-width: 78ch;
}

.plain-list li,
.step-list li { margin: 0.45rem 0; }

@media (max-width: 720px) {
  .top-nav { flex-direction: column; align-items: stretch; }
  .top-nav .nav-links { justify-content: center; }
  h1 { max-width: none; }
  .playground-container { grid-template-columns: 1fr; }
  .docs-container, .spec-container { grid-template-columns: 1fr; }
  .sidebar, .spec-sidebar { position: static; }
  .nav-guide { flex-direction: column; align-items: stretch; }
  .nav-guide a { text-align: center; }
}

/* ——— Loveshack (guided tutorial) ——— */
.loveshack-page { padding-bottom: 2rem; }
.loveshack-hero { margin-bottom: 1.75rem; }

.loveshack-pill {
  background: var(--mint);
  border: 3px solid var(--line);
  border-radius: 6px;
  box-shadow: 5px 5px 0 var(--sky);
}

.loveshack-micro { font-size: 0.95rem; opacity: 0.92; max-width: 52rem; }

.loveshack-hub {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(148px, 1fr));
  gap: 0.75rem;
  margin: 1.25rem 0 1.75rem;
  max-width: 52rem;
}
.loveshack-hub-card {
  display: block;
  width: 100%;
  text-align: left;
  padding: 0.75rem 0.85rem;
  border: 2px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 3px 3px 0 var(--mint);
  cursor: pointer;
  font-family: inherit;
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}
.loveshack-hub-card:hover,
.loveshack-hub-card:focus-visible {
  transform: translate(-2px, -2px);
  box-shadow: 5px 5px 0 var(--sky);
  outline: none;
}
.loveshack-hub-card-active {
  border-color: var(--coral);
  box-shadow: 4px 4px 0 var(--coral);
  background: #fff8fa;
}
.loveshack-hub-card .hub-label {
  display: block;
  font-weight: 800;
  font-size: 0.82rem;
  color: var(--line);
}
.loveshack-hub-card .hub-desc {
  display: block;
  margin-top: 0.28rem;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--ink-muted);
  line-height: 1.35;
}
[data-theme="dark"] .loveshack-hub-card {
  background: #fffef8;
  border: 3px solid #000;
  box-shadow: 4px 4px 0 #000;
  color: var(--line);
}
[data-theme="dark"] .loveshack-hub-card .hub-label { color: var(--line); }
[data-theme="dark"] .loveshack-hub-card .hub-desc { color: var(--ink-muted); }
[data-theme="dark"] .loveshack-hub-card-active {
  background: #fff0f5;
  border-color: var(--coral);
  box-shadow: 4px 4px 0 #000;
}

.loveshack-layout {
  display: grid;
  grid-template-columns: min(220px, 32vw) 1fr;
  gap: 1.5rem;
  align-items: start;
}

.loveshack-rail {
  position: sticky;
  top: 0.75rem;
  padding: 1rem;
  background: var(--surface-solid);
  border: 2px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow-pop-sm);
}

.loveshack-rail-title {
  font-family: "Chakra Petch", "Syne", sans-serif;
  font-weight: 700;
  font-size: 0.78rem;
  text-transform: none;
  letter-spacing: 0.06em;
  margin-bottom: 0.65rem;
  color: var(--ink-muted);
}

.loveshack-step-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.loveshack-step-btn {
  width: 100%;
  text-align: left;
  padding: 0.55rem 0.65rem;
  font-family: inherit;
  font-size: 0.82rem;
  font-weight: 700;
  border: 2px solid var(--line);
  border-radius: 4px;
  background: #fff;
  cursor: pointer;
  transition: background 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
  color: var(--line);
  box-shadow: 2px 2px 0 var(--lavender);
}

.loveshack-step-btn:hover,
.loveshack-step-btn:focus-visible {
  background: var(--banana);
  border-color: var(--line);
  outline: none;
  transform: translate(-1px, -1px);
  box-shadow: 3px 3px 0 var(--line);
}

.loveshack-step-active {
  background: var(--coral) !important;
  color: #fff;
  border-color: var(--line) !important;
  box-shadow: 3px 3px 0 var(--line);
}

.loveshack-rail-foot { margin: 1rem 0 0; font-size: 0.82rem; line-height: 1.5; }
.loveshack-rail-foot a { color: var(--ink); font-weight: 700; }
.loveshack-panel { min-width: 0; }
.loveshack-lesson h2 { margin-top: 0; }

.loveshack-run-head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

.loveshack-run-title { margin: 0; font-size: 1.15rem; }
.loveshack-run-hint { font-size: 0.85rem; font-weight: 700; color: var(--ink); }

@media (max-width: 768px) {
  .loveshack-layout { grid-template-columns: 1fr; }
  .loveshack-rail { position: static; }
  .loveshack-step-list { flex-direction: row; flex-wrap: wrap; }
  .loveshack-step-btn { width: auto; flex: 1 1 auto; min-width: 6rem; }
}

/* ——— Inline SVG icons ——— */
.icon { width: 1.75rem; height: 1.75rem; flex-shrink: 0; color: var(--line); }
.icon--sm { width: 1.15rem; height: 1.15rem; }
.icon--lg { width: 2.125rem; height: 2.125rem; }

.category-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  border: 3px solid var(--line);
  border-radius: 6px;
  background: #fff;
  box-shadow: 3px 3px 0 var(--coral);
}

.category-icon .icon { width: 1.4rem; height: 1.4rem; }
.platform-icon { display: flex; align-items: center; justify-content: center; }
.platform-icon .icon { width: 2rem; height: 2rem; }
.implication-icon { display: flex; align-items: center; justify-content: center; }
.implication-icon .icon { width: 2.25rem; height: 2.25rem; }

.h-icon-row { display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; }
.h-icon-row .icon { width: 1.35rem; height: 1.35rem; flex-shrink: 0; }

.compliance-check,
.feature-compliance,
.module-compliance { display: inline-flex; align-items: center; gap: 0.35rem; }

.status-icon { display: flex; align-items: center; justify-content: center; }
.status-icon .ui-check { width: 1.25rem; height: 1.25rem; }
.badge-icon-svg { width: 1.35rem; height: 1.35rem; color: var(--line); }

.ui-check {
  display: inline-block;
  width: 1em;
  height: 1em;
  vertical-align: -0.1em;
  background-color: currentColor;
  -webkit-mask: var(--icon-check) center / contain no-repeat;
  mask: var(--icon-check) center / contain no-repeat;
}

.ui-warn {
  display: inline-block;
  width: 1em;
  height: 1em;
  vertical-align: -0.1em;
  background-color: currentColor;
  -webkit-mask: var(--icon-warn) center / contain no-repeat;
  mask: var(--icon-warn) center / contain no-repeat;
}

.status-indicator .ui-check,
.stage-indicator .ui-check,
.build-indicator .ui-check,
.gate-status .ui-check { width: 1.35rem; height: 1.35rem; display: block; margin: 0 auto; }

.module-status.success .ui-check,
.capability-check .ui-check { width: 0.95rem; height: 0.95rem; }

.capability-check { display: inline-flex; align-items: center; }

.verification-result,
.debunk-reality { display: flex; align-items: flex-start; gap: 0.5rem; }

.technical-note li { display: flex; align-items: flex-start; gap: 0.45rem; }
.technical-note .ui-check,
.technical-note .ui-cross { flex-shrink: 0; margin-top: 0.2rem; }

.verification-result .ui-check,
.debunk-reality .ui-check { flex-shrink: 0; width: 1.1rem; height: 1.1rem; margin-top: 0.15rem; }

.legend-item.status-success,
.legend-item.status-warning { display: inline-flex; align-items: center; gap: 0.35rem; }

.legend-item .ui-check,
.legend-item .ui-warn { width: 1rem; height: 1rem; }

/* ——— Global polish ——— */
::selection { background: var(--coral); color: #fff; }

a:focus-visible {
  outline: 2px solid var(--coral);
  outline-offset: 2px;
  border-radius: 4px;
}

.top-nav .nav-links a:focus-visible,
.navbar .nav-link:focus-visible { outline-offset: 4px; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* ——— Doc pages ——— */
.doc-page .hero { margin-bottom: 1.5rem; }

.doc-body {
  max-width: 860px;
}

.doc-body h2 {
  margin-top: 2.5rem;
  padding-bottom: 0.35rem;
  border-bottom: 3px solid var(--line);
}

.doc-body h3 {
  margin-top: 1.75rem;
  color: var(--line);
}

.doc-body p, .doc-body li { line-height: 1.7; }

.doc-body ul, .doc-body ol { padding-left: 1.5rem; }

.doc-toc {
  background: #fffef6;
  border: 3px dashed var(--line);
  border-radius: 6px;
  padding: 1rem 1.25rem;
  margin-bottom: 2rem;
  display: inline-block;
  min-width: 220px;
}

.doc-toc strong { display: block; margin-bottom: 0.5rem; font-size: 0.9rem; }
.doc-toc ul { list-style: none; padding: 0; margin: 0; }
.doc-toc li { margin: 0.3rem 0; }
.doc-toc a { color: var(--line); font-weight: 600; text-decoration: none; font-size: 0.9rem; }
.doc-toc a:hover { text-decoration: underline; }

/* Reference table */
.ref-table {
  width: 100%;
  border-collapse: collapse;
  margin: 1rem 0;
  font-size: 0.9rem;
}

.ref-table th {
  background: var(--line);
  color: #fff;
  padding: 0.5rem 0.75rem;
  text-align: left;
  font-weight: 700;
}

.ref-table td {
  padding: 0.45rem 0.75rem;
  border-bottom: 1px solid #e0dbd0;
  vertical-align: top;
}

.ref-table tr:nth-child(even) td { background: #faf8f2; }
.ref-table tr:hover td { background: #f0ede0; }

/* Callout boxes */
.callout {
  padding: 1rem 1.25rem;
  border-radius: 6px;
  margin: 1.25rem 0;
  border-left: 5px solid;
  font-size: 0.95rem;
}

.callout-warn {
  background: #fff8e1;
  border-color: #f59e0b;
}

.callout-info {
  background: #e8f4fd;
  border-color: #3b82f6;
}

/* Stdlib category grid */
.stdlib-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1.25rem;
  margin: 1.5rem 0;
}

.stdlib-cat {
  background: #fff;
  border: 2px solid var(--line);
  border-radius: 6px;
  padding: 1rem 1.1rem;
  box-shadow: 4px 4px 0 var(--mint);
}

.stdlib-cat h3 {
  margin: 0 0 0.75rem;
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-bottom: 2px solid var(--line);
  padding-bottom: 0.35rem;
}

.stdlib-cat ul { list-style: none; padding: 0; margin: 0; }
.stdlib-cat li { margin: 0.3rem 0; font-size: 0.88rem; }
.stdlib-cat code { font-size: 0.85rem; background: #f4f0e8; padding: 0 3px; border-radius: 2px; }

/* Comparison grid */
.compare-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin: 1rem 0;
}

@media (max-width: 640px) {
  .compare-grid { grid-template-columns: 1fr; }
}

.compare-col h4 {
  margin: 0 0 0.5rem;
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Loveshack track labels */
.loveshack-track-label {
  list-style: none;
  padding: 0.5rem 0.75rem 0.25rem;
  font-size: 0.7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #888;
  margin-top: 0.75rem;
  border-top: 1px solid #e0dbd0;
}

.loveshack-track-label:first-child { border-top: none; margin-top: 0; }

/* Prev/Next buttons in loveshack */
#btn-prev, #btn-next { font-size: 0.85rem; padding: 0.35rem 0.75rem; }

/* ══════════════════════════════════════════════════════════════════
   DARK MODE — composition notebook (Top Flight–style)
   Black marbled “cover” field; paper-white panels with black ink (same
   contrast as light mode). Applied by js/site.js via localStorage.
══════════════════════════════════════════════════════════════════ */
[data-theme="dark"] {
  --body-ink: #f2f2f2;
  --line: #141414;
  --paper: #030303;
  --paper-2: #080808;
  --surface: rgba(255, 254, 248, 0.97);
  --surface-solid: #fffef8;
  --ink: #141414;
  --ink-muted: rgba(20, 20, 20, 0.72);
  --border: rgba(0, 0, 0, 0.14);
  --border-strong: rgba(0, 0, 0, 0.32);
  --grid-ink: rgba(255, 255, 255, 0.045);
  --grid-ink-2: rgba(255, 255, 255, 0.03);
  --shadow-pop-sm: 4px 4px 0 #000;
  --shadow-pop: 5px 5px 0 #000;
  --shadow-pop-md: 6px 6px 0 #000;
  --shadow-pop-lg: 7px 7px 0 #000;
  --shadow-pop-xl: 8px 8px 0 #000;
  --strip: linear-gradient(90deg, #fff 0%, #d0d0d0 45%, #fff 100%);
  --memphis: none;
  --memphis-v2: none;
  --comp-grid: linear-gradient(rgba(0, 0, 0, 0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 0, 0, 0.06) 1px, transparent 1px);
  --comp-grid-size: 18px 18px;
}

/* Tape-bound spine + marbled noise (screen blend reads as light speckle on black) */
[data-theme="dark"] body::before {
  content: "";
  position: fixed;
  left: 0;
  top: 0;
  bottom: 0;
  width: 14px;
  z-index: 0;
  pointer-events: none;
  background: #000;
  box-shadow: inset -3px 0 0 rgba(255, 255, 255, 0.06);
}

[data-theme="dark"] body::after {
  opacity: 0.14;
  mix-blend-mode: screen;
}

[data-theme="dark"] body {
  background-color: #000;
  background-image:
    var(--comp-grid),
    linear-gradient(90deg, var(--grid-ink) 1px, transparent 1px),
    linear-gradient(0deg, var(--grid-ink-2) 1px, transparent 1px);
  background-size: var(--comp-grid-size), var(--grid-cell) var(--grid-cell), var(--grid-cell) var(--grid-cell);
  background-position: 0 0, -1px -1px, -1px -1px;
  background-attachment: fixed, fixed, fixed;
  color: var(--body-ink);
}

/* Primary nav — flat black & white */
[data-theme="dark"] .navbar {
  background: #000;
  border-bottom: 3px solid #fff;
  box-shadow: none;
  border-image: none;
}

[data-theme="dark"] .navbar .brand {
  color: #fff;
}

[data-theme="dark"] .navbar .brand:hover {
  color: #fff;
  text-decoration: underline;
  text-underline-offset: 3px;
}

[data-theme="dark"] .navbar .nav-link {
  color: rgba(255, 255, 255, 0.78);
}

[data-theme="dark"] .navbar .nav-link:hover,
[data-theme="dark"] .navbar .nav-link:focus-visible {
  color: #000;
  background: #fff;
}

[data-theme="dark"] .navbar .nav-link--cta {
  background: #fff;
  color: #000;
  border: 2px solid #000;
}

[data-theme="dark"] .navbar .nav-link--cta:hover {
  background: #e8e8e8;
}

/* Home hero on marble — light display type */
[data-theme="dark"] .zine-masthead {
  color: #fff;
  text-shadow:
    3px 3px 0 rgba(255, 255, 255, 0.35),
    6px 6px 0 rgba(0, 0, 0, 0.5);
}

[data-theme="dark"] .zine-strip {
  background: #fffef8;
  color: var(--coral);
  border: 3px solid #000;
  box-shadow: 5px 5px 0 #000;
}

[data-theme="dark"] .zine-tagline {
  color: rgba(242, 242, 242, 0.78);
}

[data-theme="dark"] .zine-tagline strong {
  color: #fff;
  background: linear-gradient(transparent 60%, rgba(255, 255, 255, 0.22) 60%);
}

[data-theme="dark"] .home-hero-tagline {
  color: var(--body-ink);
}

[data-theme="dark"] .footer-private-note {
  color: rgba(242, 242, 242, 0.72);
}

[data-theme="dark"] .zine-marquee {
  background: #000;
  color: #fff;
  border-top: 3px solid #fff;
  border-bottom: 3px solid #fff;
}

[data-theme="dark"] .home-mini-playground {
  background: #fffef8;
  border: 3px solid #000;
  box-shadow: 6px 6px 0 #000;
  color: var(--line);
}

[data-theme="dark"] .home-mini-playground-chrome {
  background: #000;
  color: #fff;
  border-bottom: 2px solid #000;
}

[data-theme="dark"] .home-mini-textarea {
  color: var(--line);
  border-top-color: rgba(0, 0, 0, 0.12);
  background: #fff;
}

[data-theme="dark"] .home-mini-output {
  background: #f0f4f8;
  border-top: 2px solid #000;
  color: var(--line);
}

[data-theme="dark"] .home-cta {
  background: #fffef8;
  color: var(--line);
  border: 3px solid #000;
  box-shadow: 5px 5px 0 #000;
}

[data-theme="dark"] .home-cta--hot {
  background: var(--coral);
  color: #fff;
}

[data-theme="dark"] .home-status {
  background: rgba(255, 255, 255, 0.06);
  border: 2px dashed rgba(255, 255, 255, 0.35);
  color: rgba(242, 242, 242, 0.85);
}

[data-theme="dark"] .pill {
  background: #fffef8;
  color: var(--line);
  border: 2px solid #000;
  box-shadow: 3px 3px 0 #000;
}

/* Paper panels — ink matches light mode */
[data-theme="dark"] .content-box,
[data-theme="dark"] .docs-card,
[data-theme="dark"] .recipe-card,
[data-theme="dark"] .tool-card,
[data-theme="dark"] .adv-card,
[data-theme="dark"] .stdlib-stat,
[data-theme="dark"] .stdlib-cat,
[data-theme="dark"] .tab-panel,
[data-theme="dark"] .layer,
[data-theme="dark"] .docs-link {
  background: #fffef8;
  background-image: var(--comp-grid);
  background-size: var(--comp-grid-size);
  color: var(--line);
  border: 3px solid #000;
  box-shadow: 6px 6px 0 #000;
}

[data-theme="dark"] .recipe-card p,
[data-theme="dark"] .docs-card p {
  color: #555;
}

[data-theme="dark"] .docs-section h2 {
  color: var(--line);
}

[data-theme="dark"] .recipe-meta {
  background: rgba(0, 0, 0, 0.04);
  border: 2px solid #000;
  box-shadow: none;
}

[data-theme="dark"] .recipe-modules {
  color: var(--ink-muted);
}

[data-theme="dark"] .site-wrap .hero,
[data-theme="dark"] main .hero,
[data-theme="dark"] .install-container .hero,
[data-theme="dark"] .effective-container .hero {
  background: #fffef8;
  background-image: var(--comp-grid);
  background-size: var(--comp-grid-size);
  border: 3px solid #000;
  box-shadow: 8px 8px 0 #000, 16px 16px 0 rgba(255, 255, 255, 0.04);
  color: var(--line);
}

[data-theme="dark"] .hero h1,
[data-theme="dark"] .hero .lead {
  color: var(--line);
}

[data-theme="dark"] .lead {
  color: var(--ink-muted);
}

[data-theme="dark"] h1 {
  color: var(--line);
}

/* Tables — light zebra on paper */
[data-theme="dark"] .docs-table th {
  background: #e8e8e8;
  color: var(--line);
}

[data-theme="dark"] .docs-table td,
[data-theme="dark"] .docs-table th {
  border-color: var(--border);
}

[data-theme="dark"] .ref-table th,
[data-theme="dark"] .flag-table th,
[data-theme="dark"] .api-table th,
[data-theme="dark"] .opcode-table th,
[data-theme="dark"] .env-table th,
[data-theme="dark"] .stdlib-table th {
  background: #e0e0e0;
  color: var(--line);
}

[data-theme="dark"] .ref-table tr:nth-child(even) td,
[data-theme="dark"] .flag-table tr:nth-child(even) td,
[data-theme="dark"] .api-table tr:nth-child(even) td,
[data-theme="dark"] .opcode-table tr:nth-child(even) td,
[data-theme="dark"] .env-table tr:nth-child(even) td,
[data-theme="dark"] .stdlib-table tr:nth-child(even) td {
  background: #f5f5f0;
}

[data-theme="dark"] .ref-table tr:hover td,
[data-theme="dark"] .stdlib-table tr:hover td {
  background: #eaeae4;
}

[data-theme="dark"] .ref-table td,
[data-theme="dark"] .flag-table td,
[data-theme="dark"] .api-table td,
[data-theme="dark"] .opcode-table td,
[data-theme="dark"] .env-table td,
[data-theme="dark"] .stdlib-table td {
  border-bottom-color: var(--border);
  color: var(--line);
}

[data-theme="dark"] .comparison {
  background: #fffef8;
  border: 3px solid #000;
  box-shadow: 6px 6px 0 #000;
}

/* Code — inverted “label” panel */
[data-theme="dark"] pre.code-block,
[data-theme="dark"] .arch-diagram,
[data-theme="dark"] .cmd-block,
[data-theme="dark"] .code-annotated {
  background: #0a0a0a;
  color: rgba(250, 250, 250, 0.94);
  border: 3px solid #000;
  box-shadow: 5px 5px 0 rgba(255, 255, 255, 0.12);
}

[data-theme="dark"] code {
  background: rgba(0, 0, 0, 0.06);
  color: #1a1a1a;
  border: 1px solid rgba(0, 0, 0, 0.12);
}

[data-theme="dark"] pre.code-block code,
[data-theme="dark"] .code-block code {
  background: transparent;
  border: none;
  color: inherit;
}

[data-theme="dark"] .callout-warn {
  background: #fff8e6;
  border: 3px solid #b45309;
  color: var(--line);
}

[data-theme="dark"] .callout-info {
  background: #eef6ff;
  border: 3px solid #1d4ed8;
  color: var(--line);
}

[data-theme="dark"] .why-box {
  background: #fff8e6;
  border: 3px solid #b45309;
  color: var(--line);
}

[data-theme="dark"] .doc-toc {
  background: #fffef8;
  background-image: var(--comp-grid);
  background-size: var(--comp-grid-size);
  border: 3px solid #000;
}

[data-theme="dark"] input[type="search"],
[data-theme="dark"] input[type="text"],
[data-theme="dark"] textarea {
  background: #fff;
  color: var(--line);
  border: 2px solid #000;
}

[data-theme="dark"] .top-nav {
  background: #000;
  border: 3px solid #000;
  box-shadow: 6px 6px 0 rgba(255, 255, 255, 0.12);
}

[data-theme="dark"] .top-nav::after {
  background: #fff;
  height: 4px;
  left: 0;
  right: 0;
}

[data-theme="dark"] .top-nav .brand {
  color: #fff;
}

[data-theme="dark"] .top-nav .brand:hover {
  color: #fff;
  opacity: 0.85;
}

[data-theme="dark"] .top-nav .nav-links a {
  color: rgba(255, 255, 255, 0.78);
}

[data-theme="dark"] .top-nav .nav-links a:hover,
[data-theme="dark"] .top-nav .nav-links a:focus-visible {
  color: #000;
  background: #fff;
}

[data-theme="dark"] .top-nav .nav-links a[href="/download/"],
[data-theme="dark"] .top-nav .nav-links a[href$="/download/"] {
  background: #fff;
  color: #000;
  border: 2px solid #fff;
}

[data-theme="dark"] .top-nav .nav-links a[href="/download/"]:hover,
[data-theme="dark"] .top-nav .nav-links a[href$="/download/"]:hover,
[data-theme="dark"] .top-nav .nav-links a[href="/download/"]:focus-visible,
[data-theme="dark"] .top-nav .nav-links a[href$="/download/"]:focus-visible {
  background: #e8e8e8;
  color: #000;
}

[data-theme="dark"] .stdlib-search-bar input {
  background: #fff;
  color: var(--line);
  border: 2px solid #000;
}

[data-theme="dark"] .filter-btn {
  background: #fffef8;
  color: var(--line);
  border: 2px solid #000;
}

[data-theme="dark"] .filter-btn.active,
[data-theme="dark"] .filter-btn:hover {
  background: #000;
  color: #fff;
}

[data-theme="dark"] .nav-guide a {
  color: var(--line);
  text-decoration: underline;
  text-underline-offset: 2px;
}

[data-theme="dark"] .content-surface {
  background: #fffef8;
  background-image: var(--comp-grid);
  background-size: var(--comp-grid-size);
  border: 3px solid #000;
  box-shadow: 6px 6px 0 #000;
  color: var(--line);
}

[data-theme="dark"] .content-area {
  background: #fffef8;
  background-image: var(--comp-grid);
  background-size: var(--comp-grid-size);
  border: 3px solid #000;
  box-shadow: 6px 6px 0 #000;
  color: var(--line);
}

[data-theme="dark"] .sidebar,
[data-theme="dark"] .spec-sidebar {
  background: #fffef8;
  border: 3px dashed #000;
  box-shadow: 5px 5px 0 #000;
  color: var(--line);
}

[data-theme="dark"] .spec-content {
  border: 3px solid #000;
  box-shadow: 6px 6px 0 #000;
  background: #fffef8;
  color: var(--line);
}

[data-theme="dark"] .stdlib-item {
  background: #fffef8;
  border: 2px solid #000;
  box-shadow: 3px 3px 0 #000;
  color: var(--line);
}

[data-theme="dark"] .loveshack-rail {
  background: #fffef8;
  background-image: var(--comp-grid);
  background-size: var(--comp-grid-size);
  border: 3px solid #000;
  box-shadow: 5px 5px 0 #000;
  color: var(--line);
}

[data-theme="dark"] .loveshack-rail-title {
  color: var(--ink-muted);
}

[data-theme="dark"] .loveshack-step-btn {
  background: #fff;
  color: var(--line);
  border: 2px solid #000;
  box-shadow: 3px 3px 0 #000;
}

[data-theme="dark"] .loveshack-step-btn:hover,
[data-theme="dark"] .loveshack-step-btn:focus-visible {
  background: #fff8a8;
}

[data-theme="dark"] .docs-nav a {
  background: #fffef8;
  color: var(--line);
  border: 2px solid #000;
  box-shadow: 3px 3px 0 #000;
}

[data-theme="dark"] .docs-nav a:hover {
  background: #fff;
}

[data-theme="dark"] .footer {
  background: #000;
  color: rgba(255, 255, 255, 0.82);
  border-top: 3px solid #fff;
}

[data-theme="dark"] .footer::before {
  height: 3px;
  background: #fff;
}

[data-theme="dark"] .footer::after {
  opacity: 0.08;
  mix-blend-mode: screen;
}

[data-theme="dark"] .footer-column h4 {
  color: #fff;
}

[data-theme="dark"] .footer-column p,
[data-theme="dark"] .footer-column li {
  color: rgba(255, 255, 255, 0.72);
}

[data-theme="dark"] .footer-links a {
  color: #fff;
  text-decoration: underline;
}

[data-theme="dark"] .footer-bottom {
  border-top-color: rgba(255, 255, 255, 0.2);
  color: rgba(255, 255, 255, 0.5);
}

[data-theme="dark"] .zine-window {
  border: 3px solid #000;
  box-shadow: 8px 8px 0 #000;
}

[data-theme="dark"] .zine-label {
  border: 2px solid #000;
  box-shadow: 3px 3px 0 #000;
}

[data-theme="dark"] .loveshack-track-label {
  color: rgba(242, 242, 242, 0.55);
  border-top-color: rgba(255, 255, 255, 0.15);
}

[data-theme="dark"] .zine-explore-heading {
  color: rgba(242, 242, 242, 0.72);
}

[data-theme="dark"] .zine-stamp {
  border-color: #000;
}

[data-theme="dark"] .zine-stamp--plain {
  background: #fffef8;
  box-shadow: 5px 5px 0 #000;
}

[data-theme="dark"] .zine-stamp--hot {
  box-shadow: 5px 5px 0 #000;
  border-color: #000;
}

[data-theme="dark"] .zine-stamp--ghost {
  color: var(--body-ink);
  border-color: rgba(255, 255, 255, 0.4);
}

[data-theme="dark"] .zine-clip summary {
  background: #fffef8;
  border: 2px solid #000;
  box-shadow: 4px 4px 0 #000;
}

[data-theme="dark"] .loveshack-step-active {
  box-shadow: 4px 4px 0 #000;
  border-color: #000 !important;
}

/* ══════════════════════════════════════════════════════════════════
   THEME TOGGLE BUTTON
══════════════════════════════════════════════════════════════════ */
.theme-toggle {
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: rgba(255, 255, 255, 0.8);
  border-radius: 5px;
  width: 2rem;
  height: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 0.9rem;
  line-height: 1;
  padding: 0;
  flex-shrink: 0;
  transition: background 0.15s, color 0.15s;
}
.theme-toggle:hover {
  background: rgba(255, 255, 255, 0.18);
  color: #fff;
}
.theme-toggle .theme-icon { pointer-events: none; }

/* ══════════════════════════════════════════════════════════════════
   SEARCH TRIGGER BUTTON (in nav)
══════════════════════════════════════════════════════════════════ */
.search-trigger {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.18);
  color: rgba(255, 255, 255, 0.65);
  border-radius: 5px;
  height: 2rem;
  padding: 0 0.6rem;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  cursor: pointer;
  font-size: 0.72rem;
  font-family: "Chakra Petch", sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  flex-shrink: 0;
  transition: background 0.15s, color 0.15s;
  text-decoration: none;
}
.search-trigger:hover {
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
}
.search-trigger .search-icon { font-size: 0.85rem; }
.search-trigger .search-kbd {
  font-size: 0.65rem;
  opacity: 0.55;
  font-family: "JetBrains Mono", monospace;
  background: rgba(255,255,255,0.1);
  border-radius: 3px;
  padding: 1px 4px;
}

/* ══════════════════════════════════════════════════════════════════
   FEEDBACK TRIGGER BUTTON
══════════════════════════════════════════════════════════════════ */
.feedback-trigger {
  background: none;
  border: none;
  color: rgba(255, 255, 255, 0.5);
  cursor: pointer;
  font-size: 0.72rem;
  font-family: "Chakra Petch", sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 0.4rem 0.5rem;
  border-radius: 4px;
  transition: color 0.15s;
  text-decoration: none;
}
.feedback-trigger:hover { color: rgba(255,255,255,0.85); }

/* ══════════════════════════════════════════════════════════════════
   GLOBAL SEARCH OVERLAY
══════════════════════════════════════════════════════════════════ */
#search-overlay {
  position: fixed;
  inset: 0;
  z-index: 9000;
  background: rgba(14, 10, 26, 0.75);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: clamp(4rem, 10vh, 8rem);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.15s;
}
#search-overlay.open {
  opacity: 1;
  pointer-events: all;
}

[data-theme="dark"] #search-overlay {
  background: rgba(0, 0, 0, 0.78);
}

#search-modal {
  width: min(640px, 94vw);
  background: #fff;
  border: 3px solid var(--line, #120b24);
  border-radius: 12px;
  box-shadow: 8px 8px 0 rgba(0,0,0,0.2), 0 24px 60px rgba(0,0,0,0.35);
  overflow: hidden;
  transform: translateY(-8px);
  transition: transform 0.15s;
}
#search-overlay.open #search-modal {
  transform: translateY(0);
}
[data-theme="dark"] #search-modal {
  background: #fffef8;
  background-image: var(--comp-grid);
  background-size: var(--comp-grid-size);
  border: 3px solid #000;
  box-shadow: 8px 8px 0 #000, 0 24px 60px rgba(0, 0, 0, 0.45);
  color: var(--line);
}

#search-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.65rem 1rem 0.5rem;
  border-bottom: 2px solid rgba(18, 11, 36, 0.1);
}
[data-theme="dark"] #search-header {
  border-bottom-color: rgba(0, 0, 0, 0.12);
}
#search-label {
  font-family: "Chakra Petch", sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #888;
}
#search-close {
  background: none;
  border: none;
  font-size: 1.3rem;
  cursor: pointer;
  color: #888;
  line-height: 1;
  padding: 0 0.2rem;
}
#search-close:hover { color: var(--coral, #e11d68); }

#search-input {
  width: 100%;
  border: none;
  outline: none;
  padding: 0.85rem 1rem;
  font-size: 1.1rem;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-weight: 500;
  background: transparent;
  color: inherit;
  border-bottom: 2px solid rgba(18, 11, 36, 0.08);
}
[data-theme="dark"] #search-input {
  color: var(--line);
  border-bottom-color: rgba(0, 0, 0, 0.1);
}

#search-hint {
  padding: 0.3rem 1rem;
  font-size: 0.72rem;
  color: #aaa;
  display: flex;
  gap: 0.5rem;
}
.search-hint-key {
  background: rgba(18, 11, 36, 0.08);
  border-radius: 3px;
  padding: 1px 5px;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.68rem;
}
[data-theme="dark"] .search-hint-key {
  background: rgba(0, 0, 0, 0.06);
  color: var(--line);
}

#search-results {
  list-style: none;
  padding: 0.4rem 0;
  margin: 0;
  max-height: 380px;
  overflow-y: auto;
}
#search-results li {
  display: flex;
  align-items: baseline;
  gap: 0.6rem;
  padding: 0.5rem 1rem;
  cursor: pointer;
  border-radius: 0;
  transition: background 0.1s;
  flex-wrap: wrap;
}
#search-results li:hover,
#search-results li.active {
  background: rgba(18, 11, 36, 0.06);
}
[data-theme="dark"] #search-results li:hover,
[data-theme="dark"] #search-results li.active {
  background: rgba(0, 0, 0, 0.06);
}
.search-empty {
  padding: 1rem;
  color: #aaa;
  font-style: italic;
  font-size: 0.88rem;
  cursor: default !important;
}
.sr-badge {
  font-size: 0.65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 1px 5px;
  border-radius: 3px;
  white-space: nowrap;
  flex-shrink: 0;
}
.sb-stdlib { background: #d1fae5; color: #065f46; }
.sb-site   { background: #dbeafe; color: #1e40af; }
.sb-learn  { background: #fce7f3; color: #9d174d; }
.sb-ref    { background: #ede9fe; color: #5b21b6; }
.sb-proj   { background: #f3f4f6; color: #374151; }
.sr-title {
  font-weight: 700;
  font-size: 0.9rem;
  font-family: "JetBrains Mono", monospace;
}
.sr-desc {
  font-size: 0.78rem;
  color: #777;
  flex-basis: 100%;
  padding-left: calc(0.65rem + 40px);
  line-height: 1.3;
}
[data-theme="dark"] .sr-desc { color: #5a5a5a; }

#search-footer {
  display: flex;
  justify-content: space-between;
  padding: 0.45rem 1rem;
  font-size: 0.72rem;
  color: #aaa;
  border-top: 1px solid rgba(18, 11, 36, 0.08);
}
[data-theme="dark"] #search-footer {
  border-top-color: rgba(0, 0, 0, 0.1);
  color: #666;
}

[data-theme="dark"] #search-label {
  color: #555;
}

[data-theme="dark"] #search-close {
  color: #333;
}

[data-theme="dark"] #search-hint {
  color: #666;
}

[data-theme="dark"] .search-empty {
  color: #777;
}

[data-theme="dark"] .sr-title {
  color: var(--line);
}

/* ══════════════════════════════════════════════════════════════════
   COPY BUTTON (auto-injected into code blocks)
══════════════════════════════════════════════════════════════════ */
.copy-btn {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: rgba(255, 255, 255, 0.6);
  border-radius: 4px;
  padding: 2px 8px;
  font-size: 0.7rem;
  font-family: "JetBrains Mono", monospace;
  cursor: pointer;
  transition: background 0.1s, color 0.1s;
  z-index: 2;
}
.copy-btn:hover {
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
}
.copy-btn.copied {
  color: #86efac;
  border-color: rgba(134, 239, 172, 0.4);
}

/* Lazy-loaded demo source (cookbook/examples.html) */
details.demo-fetch-details {
  margin-top: 0.4rem;
  border: none;
}
details.demo-fetch-details > summary {
  cursor: pointer;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--muted, #5c4d7a);
  list-style-position: outside;
  user-select: none;
}
details.demo-fetch-details > summary:hover {
  color: var(--coral, #e11d68);
}
details.demo-fetch-details > summary code {
  font-size: 0.88em;
}
details.demo-fetch-details pre.code-block {
  margin-top: 0.5rem;
  max-height: min(70vh, 28rem);
  overflow: auto;
  font-size: 0.78rem;
  line-height: 1.45;
}
details.readme-embed pre.code-block {
  max-height: min(80vh, 36rem);
}
#page-examples .ref-table td {
  vertical-align: top;
}
#page-examples .ref-table td > a {
  display: inline-block;
  margin-bottom: 0.15rem;
}

/* For light-background code blocks */
pre.code-block {
  position: relative;
}

/* ══════════════════════════════════════════════════════════════════
   RUN IN LOVESHACK BUTTON
══════════════════════════════════════════════════════════════════ */
.run-btn-wrap {
  margin: -0.5rem 0 1rem;
  display: flex;
}
.btn-run-loveshack {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  background: var(--coral, #e11d68);
  color: #fff;
  border: 2px solid var(--line, #120b24);
  border-radius: 0 0 6px 6px;
  padding: 0.28rem 0.75rem;
  font-size: 0.75rem;
  font-weight: 700;
  font-family: "Chakra Petch", sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  cursor: pointer;
  text-decoration: none;
  box-shadow: 2px 2px 0 var(--line, #120b24);
  transition: transform 0.1s, box-shadow 0.1s;
}
.btn-run-loveshack:hover {
  transform: translate(-1px, -1px);
  box-shadow: 3px 3px 0 var(--line, #120b24);
  color: #fff;
}

/* ══════════════════════════════════════════════════════════════════
   VERSION SELECTOR (in nav)
══════════════════════════════════════════════════════════════════ */
.version-selector {
  font-size: 0.68rem;
  font-family: "JetBrains Mono", monospace;
  color: rgba(255, 255, 255, 0.45);
  padding: 0.2rem 0.45rem;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 3px;
  cursor: default;
  white-space: nowrap;
}


/* ══════════════════════════════════════════════════════════════════
   NAV ACTIONS ROW (search + theme toggle)
══════════════════════════════════════════════════════════════════ */
.nav-actions {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  flex-shrink: 0;
}

/* On very small screens, hide keyboard shortcut hint */
@media (max-width: 480px) {
  .search-trigger .search-kbd { display: none; }
}

