/* ═══════════════════════════════════════════════════════════════════
   E — AI-native IDE · landing site
   Aesthetic: engineered editorial, warm dark.
   Fraunces (display serif) · Hanken Grotesk (body) · JetBrains Mono (code)
   ═══════════════════════════════════════════════════════════════════ */

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

:root {
  /* surfaces — warm near-black, not blue-black */
  --bg: #0c0b0a;
  --bg-2: #100e0c;
  --panel: #15120f;
  --panel-2: #1b1713;
  --line: #272019;
  --line-2: #3a3027;

  /* ink — paper cream */
  --ink: #f4eee3;
  --ink-2: #d2c8b8;
  --dim: #968c7c;
  --faint: #6c6356;

  /* accent — terracotta (Claude-adjacent), warm */
  --accent: #e2733f;
  --accent-2: #f3a679;
  --accent-deep: #bd521f;
  --glow: rgba(226, 115, 63, 0.2);

  /* secondary hues for code + status */
  --sage: #93bd84;
  --gold: #dcb45f;
  --sky: #82a7c7;
  --mauve: #c08bb0;

  --serif: 'Fraunces', 'Iowan Old Style', Georgia, serif;
  --sans: 'Hanken Grotesk', ui-sans-serif, -apple-system, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, 'SF Mono', monospace;

  --container: 1120px;
  --r: 14px;
  --r-sm: 9px;
  --ease: cubic-bezier(0.22, 0.61, 0.36, 1);
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: var(--sans);
  background: var(--bg);
  color: var(--ink);
  line-height: 1.6;
  font-size: 17px;
  letter-spacing: -0.005em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* atmosphere: warm radial glows + a fine grain overlay -------------------- */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: -2;
  background:
    radial-gradient(900px 540px at 78% -8%, rgba(226, 115, 63, 0.16), transparent 60%),
    radial-gradient(760px 600px at 6% 4%, rgba(220, 180, 95, 0.06), transparent 55%), var(--bg);
}
body::after {
  content: '';
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: 0.04;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.wrap {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 28px;
}

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

::selection {
  background: var(--accent);
  color: #1a0f08;
}

/* ── Nav ──────────────────────────────────────────────────────────────── */
nav {
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(14px) saturate(140%);
  background: color-mix(in srgb, var(--bg) 72%, transparent);
  border-bottom: 1px solid transparent;
  transition: border-color 0.3s var(--ease);
}
nav.scrolled {
  border-bottom-color: var(--line);
}
.nav-in {
  max-width: var(--container);
  margin: 0 auto;
  padding: 14px 28px;
  display: flex;
  align-items: center;
  gap: 18px;
}
.brand {
  display: flex;
  align-items: baseline;
  gap: 10px;
  color: var(--ink);
}
.brand .mark {
  font-family: var(--serif);
  font-weight: 600;
  font-size: 1.7rem;
  line-height: 1;
  font-variation-settings:
    'SOFT' 40,
    'WONK' 1,
    'opsz' 40;
  background: linear-gradient(150deg, var(--ink) 30%, var(--accent-2));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.brand .mark-sub {
  font-family: var(--mono);
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--faint);
}
.nav-links {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 26px;
}
.nav-links a {
  color: var(--ink-2);
  font-size: 0.86rem;
  font-weight: 500;
}
.nav-links a:hover {
  color: var(--ink);
}
.nav-links .ext::after {
  content: ' ↗';
  color: var(--faint);
  font-size: 0.78em;
}
.nav-cta {
  font-family: var(--mono);
  font-size: 0.78rem;
  padding: 8px 14px;
  border: 1px solid var(--line-2);
  border-radius: 100px;
  color: var(--ink) !important;
  transition: all 0.18s var(--ease);
}
.nav-cta:hover {
  border-color: var(--accent);
  background: var(--glow);
}
@media (max-width: 780px) {
  .nav-links .hide-sm {
    display: none;
  }
}

/* ── Hero ─────────────────────────────────────────────────────────────── */
.hero {
  position: relative;
  padding: 92px 0 64px;
}
.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
  gap: 56px;
  align-items: center;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--mono);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--dim);
  padding: 6px 13px;
  border: 1px solid var(--line);
  border-radius: 100px;
  background: var(--panel);
}
.eyebrow .dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--sage);
  box-shadow: 0 0 8px var(--sage);
  animation: pulse 2.4s ease-in-out infinite;
}
@keyframes pulse {
  50% {
    opacity: 0.35;
  }
}

.hero h1 {
  font-family: var(--serif);
  font-weight: 460;
  font-size: clamp(2.9rem, 6.4vw, 4.9rem);
  line-height: 0.98;
  letter-spacing: -0.025em;
  margin: 22px 0 0;
  font-variation-settings:
    'SOFT' 30,
    'WONK' 0,
    'opsz' 144;
}
.hero h1 em {
  font-style: italic;
  font-variation-settings:
    'SOFT' 60,
    'WONK' 1,
    'opsz' 144;
  color: var(--accent);
}
.hero .lede {
  margin-top: 22px;
  max-width: 30em;
  font-size: 1.12rem;
  color: var(--ink-2);
  line-height: 1.62;
}

/* install command block */
.install {
  margin-top: 30px;
  max-width: 32em;
}
.install-label {
  font-family: var(--mono);
  font-size: 0.66rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--faint);
  margin-bottom: 8px;
}
.cmd {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--panel);
  border: 1px solid var(--line-2);
  border-radius: var(--r-sm);
  padding: 13px 13px 13px 16px;
  font-family: var(--mono);
  font-size: 0.82rem;
  box-shadow: 0 18px 40px -28px rgba(0, 0, 0, 0.9);
  transition: border-color 0.2s var(--ease);
}
.cmd:hover {
  border-color: var(--accent-deep);
}
.cmd .prompt {
  color: var(--accent);
  user-select: none;
}
.cmd code {
  color: var(--ink);
  white-space: nowrap;
  overflow-x: auto;
  flex: 1;
  scrollbar-width: none;
}
.cmd code::-webkit-scrollbar {
  display: none;
}
.copy {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--panel-2);
  border: 1px solid var(--line-2);
  color: var(--ink-2);
  border-radius: 6px;
  padding: 6px 10px;
  font-family: var(--mono);
  font-size: 0.72rem;
  cursor: pointer;
  transition: all 0.15s var(--ease);
}
.copy:hover {
  color: var(--ink);
  border-color: var(--accent);
}
.copy.done {
  color: var(--sage);
  border-color: var(--sage);
}

.cta-row {
  margin-top: 22px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}
.btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 12px 22px;
  border-radius: 100px;
  font-weight: 600;
  font-size: 0.92rem;
  cursor: pointer;
  border: 1px solid transparent;
  transition: all 0.18s var(--ease);
}
.btn-primary {
  background: linear-gradient(180deg, var(--accent-2), var(--accent));
  color: #20120a;
  box-shadow:
    0 10px 32px -12px var(--glow),
    inset 0 1px 0 rgba(255, 255, 255, 0.25);
}
.btn-primary:hover {
  color: #20120a;
  transform: translateY(-2px);
  box-shadow:
    0 16px 40px -12px var(--glow),
    inset 0 1px 0 rgba(255, 255, 255, 0.3);
}
.btn-ghost {
  border-color: var(--line-2);
  color: var(--ink);
  background: var(--panel);
}
.btn-ghost:hover {
  color: var(--ink);
  border-color: var(--dim);
  transform: translateY(-2px);
}

.hero-meta {
  margin-top: 22px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 18px;
  font-family: var(--mono);
  font-size: 0.74rem;
  color: var(--faint);
}
.hero-meta b {
  color: var(--ink-2);
  font-weight: 500;
}

/* ── Hero visual: the E editor mockup ─────────────────────────────────── */
/* Both hero columns must be allowed to shrink below their content's intrinsic
   width, or the long curl URL (white-space: nowrap) and the code mockup blow
   out the grid track and force horizontal scroll on narrow screens. */
.hero-copy,
.hero-visual {
  min-width: 0;
}
.cmd {
  min-width: 0;
}
.mock {
  position: relative;
  max-width: 100%;
  border-radius: var(--r);
  border: 1px solid var(--line-2);
  background: var(--bg-2);
  overflow: hidden;
  box-shadow:
    0 50px 90px -40px rgba(0, 0, 0, 0.85),
    0 0 0 1px rgba(255, 255, 255, 0.02) inset;
  transform: perspective(1600px) rotateY(-7deg) rotateX(2.5deg);
  transform-origin: center right;
}
.mock-glow {
  position: absolute;
  inset: -2px;
  z-index: -1;
  background: radial-gradient(60% 60% at 70% 0%, var(--glow), transparent 70%);
  filter: blur(20px);
}
.mock-menu {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 9px 14px;
  border-bottom: 1px solid var(--line);
  background: var(--panel);
}
.mm-logo {
  font-family: var(--serif);
  font-weight: 600;
  font-size: 0.95rem;
  line-height: 1;
  color: var(--accent);
}
.mm-items {
  font-family: var(--mono);
  font-size: 0.66rem;
  letter-spacing: 0.04em;
  color: var(--faint);
}
.mock-body {
  display: flex;
  min-height: 320px;
  font-family: var(--mono);
  font-size: 0.72rem;
}

/* activity bar */
.mock-act {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  width: 40px;
  flex-shrink: 0;
  padding: 12px 0;
  border-right: 1px solid var(--line);
  background: var(--panel);
}
.act-logo {
  font-family: var(--serif);
  font-weight: 600;
  font-size: 1.1rem;
  line-height: 1;
  color: var(--accent);
}
.act-ic {
  font-size: 0.95rem;
  color: var(--faint);
}
.act-ic.active {
  color: var(--ink);
}

/* explorer sidebar */
.mock-side {
  width: 132px;
  flex-shrink: 0;
  border-right: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel) 55%, transparent);
  padding: 10px 8px;
}
.side-head {
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--faint);
  padding: 0 6px 8px;
}

/* editor + chat panes */
.mock-panes {
  flex: 1;
  display: flex;
  min-width: 0;
}
.pane {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.pane + .pane {
  border-left: 1px solid var(--line);
}
.pane-tabs {
  display: flex;
  border-bottom: 1px solid var(--line);
  background: var(--panel);
}
.pane-tabs .tab {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 11px;
  font-size: 0.66rem;
  color: var(--dim);
  border-right: 1px solid var(--line);
  white-space: nowrap;
}
.pane-tabs .tab.active {
  color: var(--ink);
  background: var(--bg-2);
  box-shadow: inset 0 2px 0 var(--accent);
}
.pane-tabs .star {
  color: var(--accent);
}

/* chat pane body + composer */
.chat-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 11px;
  background: color-mix(in srgb, var(--panel) 35%, transparent);
}
.composer {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 10px;
  padding: 8px 10px;
  border: 1px solid var(--line-2);
  border-radius: 8px;
  background: var(--panel);
  transition: border-color 0.18s var(--ease);
}
.composer.typing {
  border-color: var(--accent-deep);
}
.cmp-text {
  color: var(--ink);
  font-size: 0.68rem;
  white-space: pre-wrap;
  word-break: break-word;
}
.cmp-text:empty::before {
  content: attr(data-placeholder);
  color: var(--faint);
}
.cmp-caret {
  width: 1.5px;
  height: 0.95em;
  flex-shrink: 0;
  background: var(--accent);
  opacity: 0;
}
.composer.typing .cmp-caret {
  opacity: 1;
  animation: caret 1.1s steps(1) infinite;
}
.cmp-send {
  margin-left: auto;
  display: grid;
  place-items: center;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  border-radius: 5px;
  background: var(--accent);
  color: #20120a;
  font-size: 0.7rem;
}
/* dynamically inserted chat bubbles / chips + the live code edit */
.pop {
  animation: rise 0.3s var(--ease) both;
}
.code .ln.just-edited {
  animation: lineflash 1.2s var(--ease);
}
@keyframes lineflash {
  from {
    background: var(--glow);
  }
  to {
    background: transparent;
  }
}

/* status bar */
.mock-status {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 5px 12px;
  border-top: 1px solid var(--line);
  background: var(--panel);
  font-family: var(--mono);
  font-size: 0.6rem;
  color: var(--dim);
}
.st-l,
.st-r {
  display: flex;
  align-items: center;
  gap: 12px;
}
.st-branch {
  color: var(--ink-2);
}
.st-golem {
  color: var(--accent);
}
.st-model {
  color: var(--ink-2);
}

/* file tree (inside the explorer sidebar) */
.tree {
  color: var(--dim);
}
.tree .row {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 3px 7px;
  border-radius: 5px;
  white-space: nowrap;
}
.tree .row.active {
  background: var(--glow);
  color: var(--ink);
}
.tree .ic {
  width: 15px;
  text-align: center;
  font-size: 0.62rem;
  font-weight: 700;
  border-radius: 3px;
  color: #1a120b;
}
.ic.ts {
  background: var(--sky);
}
.ic.rs {
  background: var(--accent-2);
}
.ic.svelte {
  background: #e0533f;
  color: #fff;
}
.ic.dir {
  background: none;
  color: var(--gold);
}

/* code editor */
.code {
  padding: 14px 16px;
  overflow: hidden;
  counter-reset: ln;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--panel) 40%, transparent) 0 30px,
    transparent 30px
  );
}
.code .ln {
  display: block;
  white-space: pre;
  line-height: 1.85;
  padding-left: 30px;
  position: relative;
  color: var(--ink-2);
}
.code .ln::before {
  counter-increment: ln;
  content: counter(ln);
  position: absolute;
  left: 0;
  width: 22px;
  text-align: right;
  color: var(--faint);
  font-size: 0.66rem;
}
.k {
  color: var(--mauve);
}
.f {
  color: var(--sky);
}
.s {
  color: var(--sage);
}
.c {
  color: var(--faint);
  font-style: italic;
}
.n {
  color: var(--gold);
}
.t {
  color: var(--accent-2);
}

/* chat bubbles */
.bubble {
  border-radius: 9px;
  padding: 8px 10px;
  font-family: var(--sans);
  font-size: 0.7rem;
  line-height: 1.5;
}
.bubble.user {
  background: var(--panel-2);
  color: var(--ink-2);
  align-self: flex-end;
  border: 1px solid var(--line);
}
.bubble.ai {
  background: linear-gradient(180deg, rgba(226, 115, 63, 0.12), rgba(226, 115, 63, 0.04));
  border: 1px solid var(--accent-deep);
  color: var(--ink);
}
.tool {
  font-family: var(--mono);
  font-size: 0.62rem;
  color: var(--sage);
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 8px;
  border: 1px dashed var(--line-2);
  border-radius: 6px;
}
.tool .tick {
  color: var(--sage);
}
.typing {
  display: inline-flex;
  gap: 3px;
  padding-top: 2px;
}
.typing i {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--accent);
  animation: blink 1.2s infinite ease-in-out;
}
.typing i:nth-child(2) {
  animation-delay: 0.18s;
}
.typing i:nth-child(3) {
  animation-delay: 0.36s;
}
@keyframes blink {
  0%,
  60%,
  100% {
    opacity: 0.25;
  }
  30% {
    opacity: 1;
  }
}
.caret {
  display: inline-block;
  width: 7px;
  height: 1.05em;
  background: var(--accent);
  vertical-align: text-bottom;
  margin-left: 1px;
  animation: caret 1.1s steps(1) infinite;
}
@keyframes caret {
  50% {
    opacity: 0;
  }
}

/* ── Marquee band ─────────────────────────────────────────────────────── */
.band {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--bg-2);
  overflow: hidden;
  padding: 16px 0;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
}
.marquee {
  display: flex;
  gap: 0;
  width: max-content;
  animation: scroll 38s linear infinite;
}
.marquee span {
  font-family: var(--mono);
  font-size: 0.8rem;
  color: var(--dim);
  padding: 0 28px;
  display: inline-flex;
  align-items: center;
  gap: 28px;
  white-space: nowrap;
}
.marquee span::after {
  content: '✶';
  color: var(--accent);
}
@keyframes scroll {
  to {
    transform: translateX(-50%);
  }
}

/* ── Section scaffolding ──────────────────────────────────────────────── */
section.block {
  padding: 96px 0;
}
.sec-head {
  max-width: 42em;
  margin-bottom: 48px;
}
.sec-tag {
  font-family: var(--mono);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent);
  display: flex;
  align-items: center;
  gap: 12px;
}
.sec-tag::before {
  content: '';
  width: 26px;
  height: 1px;
  background: var(--accent);
}
.sec-head h2 {
  font-family: var(--serif);
  font-weight: 450;
  font-size: clamp(2rem, 4.2vw, 3rem);
  line-height: 1.04;
  letter-spacing: -0.02em;
  margin: 16px 0 0;
  font-variation-settings:
    'SOFT' 20,
    'opsz' 144;
}
.sec-head p {
  color: var(--dim);
  margin-top: 14px;
  font-size: 1.05rem;
  max-width: 36em;
}

/* ── Two pillars ──────────────────────────────────────────────────────── */
.pillars {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}
.pillar {
  position: relative;
  border: 1px solid var(--line);
  border-radius: var(--r);
  background: linear-gradient(
    180deg,
    var(--panel),
    color-mix(in srgb, var(--panel) 40%, transparent)
  );
  padding: 30px;
  overflow: hidden;
  transition:
    border-color 0.25s var(--ease),
    transform 0.25s var(--ease);
}
.pillar:hover {
  border-color: var(--line-2);
  transform: translateY(-3px);
}
.pillar::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--accent), transparent);
  opacity: 0.7;
}
.pillar .pidx {
  font-family: var(--mono);
  font-size: 0.72rem;
  color: var(--faint);
}
.pillar h3 {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 1.7rem;
  margin: 10px 0 6px;
  letter-spacing: -0.01em;
}
.pillar > p {
  color: var(--dim);
  font-size: 0.96rem;
  margin-bottom: 18px;
}
.pillar ul {
  list-style: none;
  display: grid;
  gap: 16px;
}
/* Each item is a two-row grid: an accent marker in the gutter, then a bold
   label and its description stacked in the content column — so labels and
   descriptions line up regardless of length (no ragged inline dashes). */
.pillar li {
  display: grid;
  grid-template-columns: 12px 1fr;
  column-gap: 10px;
  align-items: start;
}
.pillar li::before {
  content: '';
  grid-column: 1;
  grid-row: 1;
  width: 5px;
  height: 5px;
  margin-top: 7px;
  border-radius: 1px;
  background: var(--accent);
}
.pillar li strong {
  grid-column: 2;
  grid-row: 1;
  color: var(--ink);
  font-weight: 600;
  font-size: 0.92rem;
}
.pillar li span {
  grid-column: 2;
  grid-row: 2;
  margin-top: 2px;
  color: var(--dim);
  font-size: 0.85rem;
  line-height: 1.5;
}

/* ── Feature bento ────────────────────────────────────────────────────── */
.bento {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.feat {
  border: 1px solid var(--line);
  border-radius: var(--r);
  background: var(--panel);
  padding: 24px;
  transition: all 0.22s var(--ease);
}
.feat:hover {
  border-color: var(--accent-deep);
  background: var(--panel-2);
  transform: translateY(-3px);
}
.feat .fidx {
  font-family: var(--mono);
  font-size: 0.7rem;
  color: var(--faint);
  letter-spacing: 0.1em;
}
.feat h4 {
  font-size: 1.05rem;
  font-weight: 600;
  margin: 12px 0 7px;
  letter-spacing: -0.01em;
}
.feat p {
  font-size: 0.88rem;
  color: var(--dim);
  line-height: 1.55;
}
.feat.wide {
  grid-column: span 2;
}

/* ── Download ─────────────────────────────────────────────────────────── */
#download {
  border-top: 1px solid var(--line);
  background:
    radial-gradient(700px 360px at 50% 0%, rgba(226, 115, 63, 0.1), transparent 65%), var(--bg-2);
}
.dl-top {
  text-align: center;
  max-width: 40em;
  margin: 0 auto 44px;
}
.dl-top .sec-tag {
  justify-content: center;
}
.dl-top .sec-tag::before {
  display: none;
}
.dl-top h2 {
  font-family: var(--serif);
  font-weight: 450;
  font-size: clamp(2.1rem, 4.5vw, 3.1rem);
  letter-spacing: -0.02em;
  margin: 14px 0 0;
}
.dl-top p {
  color: var(--dim);
  margin-top: 12px;
}

.dl-cta {
  max-width: 34em;
  margin: 0 auto 14px;
}
.dl-reco {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  margin-bottom: 30px;
}
.dl-reco .detected {
  font-family: var(--mono);
  font-size: 0.74rem;
  color: var(--faint);
}
.dl-reco .detected b {
  color: var(--ink-2);
}
.version-meta {
  font-family: var(--mono);
  font-size: 0.74rem;
  color: var(--faint);
}
#loading {
  text-align: center;
  color: var(--dim);
  font-family: var(--mono);
  font-size: 0.85rem;
  padding: 8px 0 24px;
}

.dl-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 18px;
  max-width: 760px;
  margin: 0 auto;
}
.dl-card {
  border: 1px solid var(--line);
  border-radius: var(--r);
  background: var(--panel);
  overflow: hidden;
  transition: border-color 0.2s var(--ease);
}
.dl-card.current-platform {
  border-color: var(--accent);
  box-shadow:
    0 0 0 1px var(--accent-deep),
    0 24px 50px -30px var(--glow);
}
.dl-card-head {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 18px 18px 12px;
  border-bottom: 1px solid var(--line);
}
.dl-card-head .pic {
  font-size: 1.35rem;
}
.dl-card-head h3 {
  font-size: 1.05rem;
  font-weight: 600;
}
.dl-card-head .badge {
  margin-left: auto;
  font-family: var(--mono);
  font-size: 0.6rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
  border: 1px solid var(--accent-deep);
  border-radius: 100px;
  padding: 3px 8px;
  opacity: 0;
}
.dl-card.current-platform .badge {
  opacity: 1;
}
.dl-links {
  padding: 8px;
}
.download-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 12px;
  border-radius: var(--r-sm);
  color: var(--ink);
}
.download-link:hover {
  background: var(--panel-2);
  color: var(--ink);
}
.download-link .format {
  font-family: var(--mono);
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--accent-2);
  background: rgba(226, 115, 63, 0.1);
  padding: 4px 10px;
  border-radius: 5px;
  min-width: 96px;
  text-align: center;
}
.download-link .size {
  margin-left: auto;
  font-family: var(--mono);
  font-size: 0.74rem;
  color: var(--faint);
}
.download-link.unavailable {
  opacity: 0.4;
  pointer-events: none;
}
.repo-link {
  text-align: center;
  margin-top: 30px;
  font-size: 0.9rem;
  color: var(--dim);
  font-family: var(--mono);
}
.error {
  color: var(--accent-2);
}

/* ── Footer ───────────────────────────────────────────────────────────── */
footer {
  border-top: 1px solid var(--line);
  padding: 56px 0 40px;
  background: var(--bg);
}
.foot-grid {
  display: grid;
  grid-template-columns: 1.6fr repeat(3, 1fr);
  gap: 32px;
}
.foot-brand .mark {
  font-family: var(--serif);
  font-size: 2rem;
  font-weight: 600;
  font-variation-settings:
    'SOFT' 40,
    'WONK' 1,
    'opsz' 40;
}
.foot-brand p {
  color: var(--dim);
  font-size: 0.9rem;
  max-width: 24em;
  margin-top: 8px;
}
.foot-col h5 {
  font-family: var(--mono);
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--faint);
  margin-bottom: 14px;
}
.foot-col a {
  display: block;
  color: var(--ink-2);
  font-size: 0.9rem;
  padding: 4px 0;
}
.foot-col a:hover {
  color: var(--accent);
}
.foot-base {
  margin-top: 44px;
  padding-top: 22px;
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
  font-family: var(--mono);
  font-size: 0.74rem;
  color: var(--faint);
}

/* ── Reveal animation ─────────────────────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(18px);
  animation: rise 0.8s var(--ease) forwards;
}
@keyframes rise {
  to {
    opacity: 1;
    transform: none;
  }
}
.d1 {
  animation-delay: 0.05s;
}
.d2 {
  animation-delay: 0.14s;
}
.d3 {
  animation-delay: 0.23s;
}
.d4 {
  animation-delay: 0.32s;
}
.d5 {
  animation-delay: 0.42s;
}
.d6 {
  animation-delay: 0.54s;
}

/* scroll-in for sections — only hidden when JS is active, so content is
   never invisible to no-JS clients or crawlers. */
.js .io {
  opacity: 0;
  transform: translateY(26px);
  transition:
    opacity 0.7s var(--ease),
    transform 0.7s var(--ease);
}
.js .io.in {
  opacity: 1;
  transform: none;
}

/* ── Responsive ───────────────────────────────────────────────────────── */
@media (max-width: 920px) {
  .hero-grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .mock {
    transform: none;
  }
  .bento {
    grid-template-columns: repeat(2, 1fr);
  }
  .feat.wide {
    grid-column: span 2;
  }
  .foot-grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 620px) {
  body {
    font-size: 16px;
  }
  section.block {
    padding: 72px 0;
  }
  .pillars {
    grid-template-columns: 1fr;
  }
  .bento {
    grid-template-columns: 1fr;
  }
  .feat.wide {
    grid-column: span 1;
  }
  .foot-grid {
    grid-template-columns: 1fr;
  }
  /* On narrow screens drop the explorer and the chat pane so the editor pane
     stays legible — keep the activity bar so it still reads as E. */
  .mock-side {
    display: none;
  }
  .mock-panes .pane + .pane {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001s !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001s !important;
  }
  .reveal,
  .io {
    opacity: 1;
    transform: none;
  }
  .mock {
    transform: none;
  }
}
