/* ═══════════════════════════════════════════════════════════════════
   Launch Week — hub + sub-pages
   Reuses base.css scaffolding (.section-inner, .section-head, etc.)
   Scoped under .lw-* classes to stay isolated from the homepage system.
   ═══════════════════════════════════════════════════════════════════ */

/* ──────────────────────────────────────────────────────────────────
   Category color palette (per launchweek/HANDOFF.md)
   ────────────────────────────────────────────────────────────────── */
.lw-card[data-cat="opensource"]   { --lw-cat: #22C55E; }
.lw-card[data-cat="devtools"]     { --lw-cat: #38BDF8; }
.lw-card[data-cat="compliance"]   { --lw-cat: #A78BFA; }
.lw-card[data-cat="status"]       { --lw-cat: #F59E0B; }
.lw-card[data-cat="intelligence"] { --lw-cat: #F97316; }

/* Same palette mirrored on sub-pages via [data-cat] anywhere */
[data-cat="opensource"]   { --lw-cat: #22C55E; }
[data-cat="devtools"]     { --lw-cat: #38BDF8; }
[data-cat="compliance"]   { --lw-cat: #A78BFA; }
[data-cat="status"]       { --lw-cat: #F59E0B; }
[data-cat="intelligence"] { --lw-cat: #F97316; }

/* ──────────────────────────────────────────────────────────────────
   HERO
   ────────────────────────────────────────────────────────────────── */
.lw-hero {
  background: var(--bg-primary);
  border-bottom: 1px solid var(--line-1);
  padding-top: var(--nav-h);
  position: relative;
  overflow: hidden;
}
.lw-hero .section-inner {
  padding-top: clamp(60px, 7vw, 96px);
  padding-bottom: clamp(48px, 6vw, 80px);
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 2vw, 26px);
  align-items: center;
  text-align: center;
  position: relative;
  z-index: 1;
}

.lw-hero__intro {
  max-width: 880px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.lw-hero__eyebrow {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-secondary);
  margin: 0;
}
.lw-hero__title {
  font-size: clamp(40px, 5.6vw, 76px);
  line-height: 1.04;
  letter-spacing: -0.028em;
  font-weight: 500;
  color: var(--text-heading);
  margin: 0;
}
.lw-hero__title-accent {
  color: var(--accent-purple-2);
}
.lw-hero__sub {
  font-size: clamp(15px, 1.2vw, 18px);
  line-height: 1.6;
  color: var(--text-body);
  max-width: 720px;
  margin: 0 auto;
}

/* ── Hero dot mesh (lw-hero-dots.js) ───────────────────────── */
.hero-anim {
  width: 100%;
  max-width: 1100px;
}
.lw-hero__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
  /* Vignette: keep the center where the H1 lives fully transparent so dots
     don't compete with text. Mesh visible only in a halo around the edges. */
  mask-image:
    radial-gradient(ellipse 60% 60% at 50% 50%,
      transparent 0%,
      transparent 42%,
      rgba(0,0,0,0.4) 58%,
      #000 78%,
      #000 100%);
  -webkit-mask-image:
    radial-gradient(ellipse 60% 60% at 50% 50%,
      transparent 0%,
      transparent 42%,
      rgba(0,0,0,0.4) 58%,
      #000 78%,
      #000 100%);
}
.lw-hero-dots__svg {
  width: 100%;
  height: 100%;
  display: block;
  overflow: visible;
}
.lw-hero-dots__mesh circle.lw-hero-dot {
  fill: rgba(255, 255, 255, var(--alpha, 0.32));
  transform-box: fill-box;
  transform-origin: center;
  transition: fill 200ms var(--ease-std);
}
.lw-hero-dots__mesh circle.lw-hero-dot.is-pulsing {
  animation: lw-hero-dot-pulse 600ms var(--ease-std) 1;
  fill: var(--pulse-color, var(--accent-purple-2));
  will-change: transform, fill;
}
@keyframes lw-hero-dot-pulse {
  0%   { transform: scale(1);   fill: rgba(255, 255, 255, var(--alpha, 0.32)); }
  35%  { transform: scale(2.4); fill: var(--pulse-color, var(--accent-purple-2)); }
  100% { transform: scale(1);   fill: rgba(255, 255, 255, var(--alpha, 0.32)); }
}
@media (prefers-reduced-motion: reduce) {
  .lw-hero-dots__mesh circle.lw-hero-dot { animation: none !important; }
}

/* ── Hub hero animation — Open Finance × Cumbuca build ──────────────────
   Glass assembly (5-segment icon) crossfades into the official OF lockup.
   Both layers are absolutely centered in .lw-mark__anim.
   Phase machine: locked → unlocking → building → settling → paired */
.lw-mark {
  --assembly-size: clamp(160px, 19vw, 220px);
  --stage-h:       clamp(360px, 44vw, 440px);

  position: relative;
  width: 100%;
  max-width: 1100px;
  height: var(--stage-h);
  margin: 0 auto;
}

.lw-mark__bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at 50% 40%, rgba(255,255,255,0.025) 0%, transparent 55%);
}

.lw-mark__stage {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: clamp(24px, 4vw, 48px);
}

/* ── Animation container — assembly and lockup overlap here ── */
.lw-mark__anim {
  position: relative;
  width: 100%;
  height: var(--assembly-size);
  flex-shrink: 0;
}

/* ── Assembly layer — shrinks + drifts left into the OF "O" symbol ── */
.lw-mark__assembly {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: var(--assembly-size);
  height: var(--assembly-size);
  opacity: 1;
  transition: opacity 800ms var(--ease-out), transform 900ms var(--ease-out);
  pointer-events: none;
}
/* SETTLING: shrink + drift left → visually becomes the OF "O" */
.lw-mark[data-phase="settling"] .lw-mark__assembly {
  transform: translate(-50%, -50%) translateX(calc(var(--assembly-size) * -0.55)) scale(0.28);
  opacity: 0.15;
}
/* PAIRED: fully gone, hold transform in place */
.lw-mark[data-phase="paired"] .lw-mark__assembly {
  transform: translate(-50%, -50%) translateX(calc(var(--assembly-size) * -0.55)) scale(0.28);
  opacity: 0;
  transition: opacity 300ms var(--ease-out);
}

.lw-mark__svg-symbol { width: 100%; height: 100%; display: block; overflow: visible; }

/* ── Lockup layer — crossfades in starting at settling, full at paired ── */
.lw-mark__lockup {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(14px, 2vw, 24px);
  opacity: 0;
  transition: opacity 500ms var(--ease-out);
  pointer-events: none;
  max-width: calc(100% - 32px);
}
.lw-mark[data-phase="settling"] .lw-mark__lockup {
  opacity: 0.45;
  transition: opacity 700ms var(--ease-out);
}
.lw-mark[data-phase="paired"] .lw-mark__lockup {
  opacity: 1;
  transition: opacity 350ms var(--ease-out);
}

/* Sep and Cumbuca SVG inherit opacity from lockup — no individual rules */
.lw-mark__sep {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: clamp(18px, 2.2vw, 26px);
  color: var(--text-secondary);
  line-height: 1;
  flex-shrink: 0;
  user-select: none;
}
.lw-mark__of-svg {
  display: block;
  height: clamp(34px, 4vw, 50px);
  width: auto;
  flex-shrink: 1;
}
.lw-mark__cumbuca-svg {
  display: block;
  height: clamp(26px, 3vw, 38px);
  width: auto;
  flex-shrink: 1;
}

/* ── OF symbol internals ── */

.lw-mark__guide {
  fill: none;
  stroke: rgba(255,255,255,0.07);
  stroke-width: 4;
  stroke-dasharray: 6 14;
  opacity: 0;
  transition: opacity 500ms var(--ease-out);
}
.lw-mark[data-phase="locked"]    .lw-mark__guide,
.lw-mark[data-phase="unlocking"] .lw-mark__guide { opacity: 1; }

.lw-mark__lock {
  transform-origin: 400px 400px;
  opacity: 0;
  transform: scale(0.58);
  transition: opacity 500ms var(--ease-out), transform 500ms var(--ease-out);
}
.lw-mark[data-phase="locked"]    .lw-mark__lock,
.lw-mark[data-phase="unlocking"] .lw-mark__lock { opacity: 1; transform: scale(0.68); }
.lw-mark[data-phase="building"]  .lw-mark__lock,
.lw-mark[data-phase="settling"]  .lw-mark__lock,
.lw-mark[data-phase="paired"]    .lw-mark__lock {
  opacity: 0; transform: scale(0.82);
  transition: opacity 380ms var(--ease-out), transform 600ms var(--ease-out);
}

.lw-mark__lock-body    { fill: none; stroke: #FFFFFF; stroke-width: 14; stroke-linejoin: round; }
.lw-mark__lock-keyhole { fill: #FFFFFF; }
.lw-mark__lock-shackle {
  fill: none; stroke: #FFFFFF; stroke-width: 14; stroke-linecap: round;
  transform-origin: 326px 359px;
  transition: transform 480ms var(--ease-out);
}
.lw-mark[data-phase="unlocking"] .lw-mark__lock-shackle { transform: rotate(-44deg); }

.lw-mark__click {
  fill: none;
  stroke: var(--accent-purple);
  stroke-width: 5;
  opacity: 0;
  transform-origin: 400px 414px;
  transform: scale(0.4);
}
.lw-mark[data-phase="unlocking"] .lw-mark__click {
  animation: lw-click 700ms var(--ease-out) 80ms forwards;
}
@keyframes lw-click {
  0%   { opacity: 0;    transform: scale(0.4); }
  35%  { opacity: 0.55; }
  100% { opacity: 0;    transform: scale(1.6); }
}

/* ── 5 BACEN segments ── */

.lw-mark__seg {
  --c: var(--text-heading);
  fill: var(--c);
  fill-opacity: 1;
  transform-origin: 400px 400px;
  transform: scale(0.001);
  opacity: 0;
  filter: none;
  transition:
    transform 760ms var(--ease-out),
    opacity 380ms var(--ease-out),
    fill 700ms var(--ease-out),
    fill-opacity 700ms var(--ease-out),
    filter 700ms var(--ease-out);
}
.lw-mark__seg[data-on="1"] { transform: scale(1); opacity: 1; }

.lw-mark[data-phase="building"] .lw-mark__seg[data-on="1"] {
  fill-opacity: 0.92;
  filter: drop-shadow(0 0 22px color-mix(in srgb, var(--c) 65%, transparent));
}
.lw-mark[data-phase="settling"] .lw-mark__seg {
  transform: scale(1); opacity: 1;
  filter: drop-shadow(0 0 14px color-mix(in srgb, var(--c) 50%, transparent));
  transition:
    transform 760ms var(--ease-out),
    opacity 380ms var(--ease-out),
    fill 500ms var(--ease-out),
    fill-opacity 500ms var(--ease-out),
    filter 500ms var(--ease-out);
}
.lw-mark[data-phase="paired"] .lw-mark__seg {
  transform: scale(1); opacity: 1; fill: #FFFFFF; filter: none;
}
.lw-mark__seg[data-i="1"] { --c: var(--c-mon); fill: url(#lw-grad-1); }
.lw-mark__seg[data-i="2"] { --c: var(--c-tue); fill: url(#lw-grad-2); }
.lw-mark__seg[data-i="3"] { --c: var(--c-wed); fill: url(#lw-grad-3); }
.lw-mark__seg[data-i="4"] { --c: var(--c-thu); fill: url(#lw-grad-4); }
.lw-mark__seg[data-i="5"] { --c: var(--c-fri); fill: url(#lw-grad-5); }

/* ── Footer: labels always visible ── */

.lw-mark__footer {
  position: relative;
  width: 100%;
  flex: 1;
  min-height: 80px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  margin-top: clamp(12px, 1.8vw, 20px);
}

.lw-mark__labels {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0 clamp(8px, 2vw, 24px);
  width: min(820px, 95%);
  text-align: center;
  pointer-events: none;
  transition: opacity 500ms var(--ease-out);
}
/* Labels stay visible in all phases; dim slightly when locked/unlocking */
.lw-mark[data-phase="locked"]    .lw-mark__labels,
.lw-mark[data-phase="unlocking"] .lw-mark__labels { opacity: 0.55; }

.lw-mark__label {
  --c: var(--text-heading);
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  opacity: 0; transform: translateY(8px);
  transition: opacity 480ms var(--ease-out), transform 480ms var(--ease-out);
}
.lw-mark__label[data-on="1"] { opacity: 1; transform: translateY(0); }
.lw-mark__label[data-i="1"] { --c: var(--c-mon); }
.lw-mark__label[data-i="2"] { --c: var(--c-tue); }
.lw-mark__label[data-i="3"] { --c: var(--c-wed); }
.lw-mark__label[data-i="4"] { --c: var(--c-thu); }
.lw-mark__label[data-i="5"] { --c: var(--c-fri); }

.lw-mark__label-icon {
  width: 48px; height: 48px;
  display: grid; place-items: center;
  color: var(--c);
  border: 1px solid color-mix(in srgb, var(--c) 45%, var(--line-2));
  border-radius: 13px;
  background: color-mix(in srgb, var(--c) 10%, transparent);
  box-shadow: 0 0 14px color-mix(in srgb, var(--c) 20%, transparent);
}
.lw-mark__label-icon svg { width: 26px; height: 26px; display: block; }
.lw-mark__label-day {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--c); opacity: 0.85;
}
.lw-mark__label-text {
  font-family: var(--font-sans); font-size: 14px; font-weight: 500;
  color: var(--c); white-space: nowrap;
}


@media (max-width: 760px) {
  .lw-mark {
    --stage-h: clamp(420px, 58vw, 520px);
    --assembly-size: clamp(130px, 18vw, 180px);
  }
  .lw-mark__labels { gap: 8px; }
  .lw-mark__label-text { font-size: 12px; }
  .lw-mark__label-icon { width: 38px; height: 38px; border-radius: 11px; }
  .lw-mark__label-icon svg { width: 21px; height: 21px; }
}
@media (prefers-reduced-motion: reduce) {
  .lw-mark *, .lw-mark *::before, .lw-mark *::after {
    transition: none !important;
    animation: none !important;
  }
}

/* ── Counter chip ───────────────────────────────────────────── */
.lw-counter {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin: 0;
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--text-secondary);
  letter-spacing: 0.04em;
}
.lw-counter__chip {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  border: 1px solid var(--line-2);
  border-radius: 999px;
  background: var(--bg-elev-1);
  color: var(--text-emphasis);
  font-variant-numeric: tabular-nums;
}
.lw-counter__chip strong {
  color: var(--text-heading);
  font-weight: 500;
}
.lw-counter__dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--text-dim);
  transition: background 240ms var(--ease-std), box-shadow 240ms var(--ease-std);
}
.lw-counter__pre {
  color: var(--text-secondary);
  font-variant-numeric: tabular-nums;
}
.lw-counter__pre strong {
  color: var(--text-emphasis);
  font-weight: 500;
}

/* Show pre-launch hint only when phase=pre */
body[data-launch-phase="pre"]   .lw-counter__pre { display: inline; }
body:not([data-launch-phase="pre"]) .lw-counter__pre { display: none; }

/* Live dot pulses during the active week */
body[data-launch-phase^="day-"] .lw-counter__dot,
body[data-launch-phase="post"]  .lw-counter__dot {
  background: var(--ok);
  box-shadow: 0 0 0 4px rgba(74, 222, 128, 0.18);
  animation: lw-pulse 2.4s ease-in-out infinite;
}
@keyframes lw-pulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(74, 222, 128, 0.18); }
  50%      { box-shadow: 0 0 0 10px rgba(74, 222, 128, 0.06); }
}

/* ──────────────────────────────────────────────────────────────────
   INITIATIVE GRID (5 cards, day-gated)
   ────────────────────────────────────────────────────────────────── */
.lw-grid-sec {
  background: var(--bg-section-alt-1);
  border-top: 1px solid var(--line-1);
}
.lw-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
/* Tablet: 2 cols */
@media (min-width: 720px) {
  .lw-grid { grid-template-columns: repeat(2, 1fr); }
}
/* Desktop: 3 + 2 layout — top row 3 cards × 33%, bottom row 2 cards × 50%.
   Uses a 6-col scaffold; bottom cards each span 3 cols so they fill the full row. */
@media (min-width: 960px) {
  .lw-grid { grid-template-columns: repeat(6, 1fr); }
  .lw-grid__cell:nth-child(1),
  .lw-grid__cell:nth-child(2),
  .lw-grid__cell:nth-child(3) { grid-column: span 2; }
  .lw-grid__cell:nth-child(4),
  .lw-grid__cell:nth-child(5) { grid-column: span 3; }
}

/* ── Card shell ─────────────────────────────────────────────── */
.lw-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 28px 24px 24px;
  background: var(--bg-elev-1);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-lg);
  color: inherit;
  text-decoration: none;
  transition:
    border-color 220ms var(--ease-std),
    transform 220ms var(--ease-std),
    background 220ms var(--ease-std),
    opacity 240ms var(--ease-std);
  overflow: hidden;
}
/* Category accent line on top */
.lw-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 1px;
  background: var(--lw-cat, var(--line-3));
  opacity: 0.6;
  transition: opacity 220ms var(--ease-std), height 220ms var(--ease-std);
}

.lw-card__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.lw-card__day {
  color: var(--text-secondary);
}
.lw-card__cat {
  color: var(--lw-cat, var(--text-secondary));
  opacity: 0.85;
}

.lw-card__title {
  font-size: 22px;
  font-weight: 500;
  letter-spacing: -0.014em;
  color: var(--text-heading);
  margin: 0;
}
.lw-card__desc {
  font-size: 14px;
  line-height: 1.55;
  color: var(--text-body);
  flex: 1;
  margin: 0;
}
.lw-card__cta {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 12.5px;
  letter-spacing: 0.04em;
  color: var(--text-emphasis);
  margin-top: 8px;
}
.lw-card__cta-open span[aria-hidden="true"] {
  display: inline-block;
  margin-left: 6px;
  transition: transform 220ms var(--ease-std);
}

/* ── States ─────────────────────────────────────────────────── */
/* Locked: teaser stays visible but the product info is frosted out — readers
   should see WHEN it launches, not WHAT it is. Only the day chip + "Em breve"
   CTA stay legible. Glassmorphism blur on cat tag + title + description. */
.lw-card[data-state="locked"] {
  cursor: default;
  pointer-events: none; /* whole card link is inert; aria-disabled set by JS */
  background: linear-gradient(180deg, var(--bg-elev-1) 0%, rgba(14, 15, 19, 0.86) 100%);
  border-color: var(--line-1);
}
.lw-card[data-state="locked"]::before {
  opacity: 0.18;
}
/* Frost the parts that would reveal the product */
.lw-card[data-state="locked"] .lw-card__cat,
.lw-card[data-state="locked"] .lw-card__title,
.lw-card[data-state="locked"] .lw-card__desc {
  filter: blur(7px);
  user-select: none;
  pointer-events: none;
  color: var(--text-emphasis);
}
.lw-card[data-state="locked"] .lw-card__title,
.lw-card[data-state="locked"] .lw-card__desc {
  opacity: 0.55;
}
.lw-card[data-state="locked"] .lw-card__cat {
  opacity: 0.45;
}
.lw-card[data-state="locked"] .lw-card__cta-open    { display: none; }
.lw-card[data-state="locked"] .lw-card__cta-locked {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  margin-top: 4px;
  align-self: flex-start;
  border: 1px solid var(--line-2);
  border-radius: 999px;
  background: var(--bg-elev-2);
  color: var(--text-emphasis);
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.lw-card[data-state="locked"] .lw-card__cta-locked::before {
  content: "";
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.6;
}
/* Open: full opacity, hover lift, only the open CTA visible */
.lw-card[data-state="open"] .lw-card__cta-locked { display: none; }
.lw-card[data-state="open"] .lw-card__cta-open   { display: inline-flex; }
.lw-card[data-state="open"]:hover {
  border-color: var(--line-3);
  transform: translateY(-2px);
  background: var(--bg-elev-2);
}
.lw-card[data-state="open"]:hover::before {
  opacity: 1;
  height: 2px;
}
.lw-card[data-state="open"]:hover .lw-card__cta-open span[aria-hidden="true"] {
  transform: translateX(3px);
}
.lw-card[data-state="open"]:focus-visible {
  outline: 2px solid var(--accent-purple);
  outline-offset: 2px;
}
/* Unlocking: just-launched flash. Brief category-color glow on the top accent. */
.lw-card[data-state="unlocking"] {
  opacity: 1;
  animation: lw-card-unlock 1.6s var(--ease-out);
}
.lw-card[data-state="unlocking"]::before {
  opacity: 1;
  height: 2px;
  box-shadow: 0 0 24px var(--lw-cat);
}
.lw-card[data-state="unlocking"] .lw-card__cta-locked { display: none; }
.lw-card[data-state="unlocking"] .lw-card__cta-open   { display: inline-flex; }
@keyframes lw-card-unlock {
  0%   { transform: translateY(8px); opacity: 0; }
  100% { transform: translateY(0);   opacity: 1; }
}

/* Default fallback when state attribute hasn't been set yet (gate hasn't run) */
.lw-card:not([data-state]) {
  opacity: 0.62;
  pointer-events: none;
}
.lw-card:not([data-state]) .lw-card__cta-open    { display: none; }
.lw-card:not([data-state]) .lw-card__cta-locked  { display: inline-flex; align-items: center; gap: 8px; color: var(--text-secondary); }

/* ──────────────────────────────────────────────────────────────────
   ATTRIBUTES (4-block narrative — "O que nos move")
   ────────────────────────────────────────────────────────────────── */
.lw-attrs {
  background: var(--bg-primary);
  border-top: 1px solid var(--line-1);
}
.lw-attrs__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px 48px;
}
.lw-attr {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding-top: 22px;
  border-top: 1px solid var(--line-2);
}
.lw-attr__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1px solid var(--line-2);
  border-radius: 8px;
  color: var(--accent-purple);
  background: var(--bg-elev-1);
}
.lw-attr__icon svg { width: 18px; height: 18px; display: block; }
.lw-attr__title {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.012em;
  color: var(--text-heading);
  margin: 0;
}
.lw-attr__body {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--text-body);
  margin: 0;
}
@media (max-width: 720px) {
  .lw-attrs__grid { grid-template-columns: 1fr; gap: 24px; }
}

/* ──────────────────────────────────────────────────────────────────
   CREDITS — Team + Investors
   ────────────────────────────────────────────────────────────────── */
.lw-credits {
  background: var(--bg-section-alt-1);
  border-top: 1px solid var(--line-1);
}
.lw-credits__inner {
  padding-top: 64px !important;
  padding-bottom: 64px !important;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 32px 64px;
  align-items: center;
}
.lw-credits__label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-secondary);
  margin: 0 0 8px;
}
.lw-credits__names {
  font-size: 14px;
  color: var(--text-secondary);
  margin: 0;
  line-height: 1.55;
}
.lw-credits__investors {
  text-align: right;
}
.lw-credits__logos {
  display: inline-flex;
  align-items: center;
  gap: 36px;
}
.lw-credits__logos img {
  height: 28px;
  width: auto;
  opacity: 0.85;
}
.lw-credits__logos img[alt="Lightspeed Venture Partners"] {
  height: 36px;
}
@media (max-width: 720px) {
  .lw-credits__inner {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .lw-credits__investors { text-align: center; }
  .lw-credits__logos {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 24px 28px;
  }
}
@media (max-width: 480px) {
  .lw-credits__logos { gap: 18px 24px; }
  .lw-credits__logos img { height: 22px; }
  .lw-credits__logos img[alt="Lightspeed Venture Partners"] { height: 28px; }
}

/* ═══════════════════════════════════════════════════════════════════
   SUB-PAGE PATTERNS  (Day 2 / Day 3 / Day 4 / Day 5)
   ═══════════════════════════════════════════════════════════════════ */

/* ── Section shells ────────────────────────────────────────── */
.lw-section { background: var(--bg-primary); border-top: 1px solid var(--line-1); }
.lw-section--alt { background: var(--bg-section-alt-1); }
.lw-narrow { max-width: 760px; }

/* ── Sub-page hero ─────────────────────────────────────────── */
.lw-sub-hero {
  background: var(--bg-primary);
  border-bottom: 1px solid var(--line-1);
  padding-top: var(--nav-h);
}
.lw-sub-hero .section-inner {
  padding-top: clamp(72px, 8vw, 110px);
  padding-bottom: clamp(56px, 6vw, 92px);
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: center;
  text-align: center;
}
.lw-back {
  align-self: flex-start;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-secondary);
  padding: 6px 0;
  transition: color 160ms var(--ease-std);
}
.lw-back:hover { color: var(--text-emphasis); }

.lw-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border: 1px solid var(--line-2);
  border-radius: 999px;
  background: var(--bg-elev-1);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--lw-cat, var(--text-secondary));
}
.lw-tag::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.85;
}

.lw-sub-hero__title {
  font-size: clamp(36px, 5vw, 64px);
  line-height: 1.05;
  letter-spacing: -0.028em;
  font-weight: 500;
  color: var(--text-heading);
  margin: 0;
  max-width: 880px;
}
.lw-sub-hero__title-accent {
  color: var(--lw-cat, var(--accent-purple-2));
}
.lw-sub-hero__sub {
  font-size: clamp(15px, 1.2vw, 18px);
  line-height: 1.6;
  color: var(--text-body);
  max-width: 700px;
  margin: 0;
}
.lw-sub-hero__ctas {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 8px;
}

/* ── Prose ─────────────────────────────────────────────────── */
.lw-prose {
  font-size: 16px;
  line-height: 1.65;
  color: var(--text-body);
  max-width: 720px;
  margin: 0;
}
.lw-prose--center {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}
.lw-prose-stack {
  display: flex;
  flex-direction: column;
  gap: 18px;
  max-width: 720px;
  margin: 0 auto;
}

.lw-bullet {
  list-style: none;
  margin: 24px 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.lw-bullet li {
  position: relative;
  padding-left: 22px;
  font-size: 15px;
  line-height: 1.6;
  color: var(--text-body);
}
.lw-bullet li::before {
  content: "";
  position: absolute;
  top: 8px; left: 0;
  width: 8px; height: 8px;
  border: 1px solid var(--accent-purple);
  border-radius: 2px;
  transform: rotate(45deg);
}
.lw-bullet strong { color: var(--text-heading); font-weight: 500; }

/* ── Quote ─────────────────────────────────────────────────── */
.lw-quote {
  margin: 48px auto 0;
  max-width: 760px;
  padding: 28px 32px;
  border-left: 2px solid var(--accent-purple);
  background: var(--bg-elev-1);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}
.lw-quote p {
  font-size: clamp(18px, 1.8vw, 22px);
  line-height: 1.45;
  letter-spacing: -0.012em;
  color: var(--text-heading);
  font-weight: 500;
  margin: 0;
}
.lw-quote footer {
  margin-top: 12px;
  font-size: 14px;
  line-height: 1.55;
  color: var(--text-secondary);
}
.lw-quote--soft {
  border-left-color: var(--line-3);
  background: transparent;
  border-radius: 0;
}
.lw-quote--soft p { font-weight: 400; color: var(--text-emphasis); font-style: italic; }

/* ── Feature grid (3 cards) ─────────────────────────────────── */
.lw-feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 900px) { .lw-feature-grid { grid-template-columns: 1fr; } }

.lw-feature {
  position: relative;
  background: var(--bg-elev-1);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: border-color 220ms var(--ease-std), transform 220ms var(--ease-std);
}
.lw-feature:hover { border-color: var(--line-3); transform: translateY(-2px); }
.lw-feature h3 {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.012em;
  color: var(--text-heading);
  margin: 0;
}
.lw-feature p {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--text-body);
  margin: 0;
}
.lw-feature__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  border: 1px solid var(--line-2);
  border-radius: 8px;
  color: var(--text-emphasis);
}
.lw-feature__icon svg { width: 18px; height: 18px; }
.lw-feature__pill {
  align-self: flex-start;
  padding: 4px 10px;
  border: 1px solid var(--line-2);
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-secondary);
}
.lw-feature--accent { border-color: var(--accent-purple); }
.lw-feature--accent .lw-feature__pill { color: var(--accent-purple); border-color: var(--accent-purple); }
.lw-feature__example {
  margin-top: 8px !important;
  padding: 12px 14px;
  background: var(--bg-elev-2);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-md);
  font-family: var(--font-mono);
  font-size: 12.5px !important;
  font-style: italic;
  color: var(--text-secondary) !important;
  line-height: 1.5 !important;
}

/* Verdict-coloured features (Day 5) */
.lw-feature__verdict {
  font-size: 16px;
  line-height: 1;
}
.lw-feature--ok   { border-top: 2px solid var(--ok); }
.lw-feature--warn { border-top: 2px solid var(--warn); }
.lw-feature--bad  { border-top: 2px solid #EF4444; }
.lw-feature--ok   .lw-feature__verdict { color: var(--ok); }
.lw-feature--warn .lw-feature__verdict { color: var(--warn); }
.lw-feature--bad  .lw-feature__verdict { color: #EF4444; }

/* ── Personas (text-only blocks, 2x2 / 3x2 / 1x4) ──────────── */
.lw-personas {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px 40px;
}
.lw-personas--4 { grid-template-columns: repeat(2, 1fr); }
.lw-personas--6 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 720px) {
  .lw-personas, .lw-personas--4, .lw-personas--6 { grid-template-columns: 1fr; gap: 24px; }
}
.lw-persona {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-top: 18px;
  border-top: 1px solid var(--line-2);
}
.lw-persona h3 {
  font-size: 17px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--text-heading);
  margin: 0;
}
.lw-persona p {
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-body);
  margin: 0;
}

/* ── Steps (numbered, horizontal then stack) ───────────────── */
.lw-steps {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  position: relative;
}
@media (max-width: 900px) { .lw-steps { grid-template-columns: 1fr; gap: 16px; } }
.lw-step {
  position: relative;
  padding: 28px 24px;
  background: var(--bg-elev-1);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  gap: 10px;
  overflow: hidden;
}
.lw-step__num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--accent-purple);
  position: relative;
  z-index: 1;
}
.lw-step::before {
  content: attr(data-bg-num);
  position: absolute;
  top: -22px; right: -8px;
  font-family: var(--font-mono);
  font-size: 88px;
  line-height: 1;
  color: var(--text-heading);
  opacity: 0.04;
  pointer-events: none;
  font-weight: 500;
}
.lw-step h3 {
  font-size: 17px;
  font-weight: 500;
  letter-spacing: -0.012em;
  color: var(--text-heading);
  margin: 0;
  position: relative; z-index: 1;
}
.lw-step p {
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-body);
  margin: 0;
  position: relative; z-index: 1;
}

/* ── Terminal-style sample block ───────────────────────────── */
.lw-terminal {
  margin: 56px auto 0;
  max-width: 720px;
  background: var(--bg-elev-2);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.lw-terminal__head {
  padding: 10px 16px;
  border-bottom: 1px solid var(--line-2);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-secondary);
}
.lw-terminal__body {
  margin: 0;
  padding: 20px 22px;
  font-family: var(--font-mono);
  font-size: 13.5px;
  line-height: 1.7;
  color: var(--text-emphasis);
  overflow-x: auto;
}
.lw-terminal__prompt { color: var(--accent-purple); margin-right: 10px; }

/* ── Compare (2-col side-by-side: Regulus vs IA Genérica) ──── */
.lw-compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
@media (max-width: 720px) { .lw-compare { grid-template-columns: 1fr; } }
.lw-compare__col {
  background: var(--bg-elev-1);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.lw-compare__col--good {
  background: var(--bg-elev-2);
  border-color: var(--accent-purple);
}
.lw-compare__col--bad {
  opacity: 0.85;
}
.lw-compare__label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--lw-cat, var(--text-secondary));
}
.lw-compare__col--bad .lw-compare__label { color: var(--text-secondary); }
.lw-compare__col ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.lw-compare__col li {
  position: relative;
  padding-left: 22px;
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--text-body);
}
.lw-compare__col--good li::before {
  content: "";
  position: absolute;
  top: 7px; left: 0;
  width: 10px; height: 6px;
  border-left: 2px solid var(--accent-purple);
  border-bottom: 2px solid var(--accent-purple);
  transform: rotate(-45deg);
}
.lw-compare__col--bad li::before {
  content: "";
  position: absolute;
  top: 6px; left: 0;
  width: 10px; height: 10px;
  border: 2px solid var(--text-secondary);
  border-radius: 50%;
  opacity: 0.5;
}

/* ── Tabs / IDE shell (CSS-only, radio-input driven) — Day 2 quick start ── */
.lw-tabs {
  background: var(--bg-elev-1);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.45), 0 2px 0 rgba(255, 255, 255, 0.02) inset;
}
.lw-tabs > input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.lw-tabs__panel { display: none; }

/* ── IDE chrome ─────────────────────────────────────────── */
.lw-ide__chrome {
  display: flex;
  align-items: stretch;
  background: var(--bg-elev-2);
  border-bottom: 1px solid var(--line-2);
  padding: 0 14px;
  min-height: 40px;
}
.lw-ide__dots {
  display: flex;
  align-items: center;
  gap: 6px;
  padding-right: 16px;
  border-right: 1px solid var(--line-1);
  margin-right: 12px;
}
.lw-ide__dot {
  width: 11px; height: 11px;
  border-radius: 50%;
  display: inline-block;
  background: var(--text-dim);
}
.lw-ide__dot--r { background: #FF5F56; }
.lw-ide__dot--y { background: #FFBD2E; }
.lw-ide__dot--g { background: #27C93F; }

.lw-ide__tabs {
  display: flex;
  align-items: stretch;
  gap: 0;
  flex: 1;
  min-width: 0;
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.lw-ide__tabs::-webkit-scrollbar { display: none; }

.lw-ide__tab {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0 16px;
  font-family: var(--font-mono);
  font-size: 12.5px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--text-secondary);
  cursor: pointer;
  border-right: 1px solid var(--line-1);
  background: transparent;
  white-space: nowrap;
  transition: color 160ms var(--ease-std), background 160ms var(--ease-std);
  position: relative;
}
.lw-ide__tab:hover { color: var(--text-emphasis); background: rgba(255, 255, 255, 0.02); }
.lw-ide__tab-icon {
  display: inline-flex;
  width: 14px; height: 14px;
  flex-shrink: 0;
}
.lw-ide__tab-icon svg { width: 100%; height: 100%; display: block; }
.lw-ide__tab[data-ext="json"] .lw-ide__tab-icon { color: var(--accent-data); }
.lw-ide__tab[data-ext="md"]   .lw-ide__tab-icon { color: var(--accent-purple); }

#lw-tab-claude:checked  ~ .lw-ide__chrome label[for="lw-tab-claude"],
#lw-tab-chatgpt:checked ~ .lw-ide__chrome label[for="lw-tab-chatgpt"],
#lw-tab-outros:checked  ~ .lw-ide__chrome label[for="lw-tab-outros"] {
  color: var(--text-heading);
  background: var(--bg-elev-1);
  box-shadow: inset 0 -2px 0 var(--accent-purple);
}

#lw-tab-claude:checked  ~ .lw-ide__editor [data-for="lw-tab-claude"],
#lw-tab-chatgpt:checked ~ .lw-ide__editor [data-for="lw-tab-chatgpt"],
#lw-tab-outros:checked  ~ .lw-ide__editor [data-for="lw-tab-outros"] {
  display: block;
}

/* ── Editor pane ────────────────────────────────────────── */
.lw-ide__editor {
  background: var(--bg-elev-1);
}

/* ── Code lines (numbered gutter) ───────────────────────── */
.lw-code__lines {
  list-style: none;
  margin: 0;
  padding: 18px 0 14px;
  counter-reset: line;
  font-family: var(--font-mono);
  font-size: 13.5px;
  line-height: 1.85;
  color: var(--text-emphasis);
}
.lw-code__lines li {
  position: relative;
  padding: 0 24px 0 64px;
  counter-increment: line;
}
.lw-code__lines li::before {
  content: counter(line);
  position: absolute;
  left: 0;
  width: 44px;
  padding-right: 14px;
  text-align: right;
  color: var(--text-dim);
  font-variant-numeric: tabular-nums;
  user-select: none;
  border-right: 1px solid var(--line-1);
  height: 100%;
}
.lw-code__lines li.lw-code__blank { color: var(--text-dim); }
.lw-code__lines li.lw-code__indent       { padding-left: 80px; }
.lw-code__lines li.lw-code__indent--2    { padding-left: 96px; }
.lw-code__lines li.lw-code__indent--3    { padding-left: 112px; }
.lw-code__lines li.lw-code__indent::before,
.lw-code__lines li.lw-code__indent--2::before,
.lw-code__lines li.lw-code__indent--3::before { /* keep gutter aligned */ }
.lw-code__lines--json li { color: var(--text-emphasis); }

.lw-code__url     { color: var(--accent-purple); font-weight: 500; }
.lw-code__keyword { color: var(--accent-data); }
.lw-code__string  { color: #F0A07A; } /* warm orange — string literal */
.lw-code__key     { color: var(--accent-purple-2); }

/* ── Status bar (under the editor) ──────────────────────── */
.lw-ide__statusbar {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 10px 16px;
  border-top: 1px solid var(--line-1);
  background: var(--bg-elev-2);
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--text-secondary);
  letter-spacing: 0.04em;
  flex-wrap: wrap;
}
.lw-ide__statusbar-item {
  padding: 2px 8px;
  border: 1px solid var(--line-1);
  border-radius: 4px;
  color: var(--text-emphasis);
}
.lw-ide__statusbar-note {
  margin-left: auto;
  color: var(--text-secondary);
  font-size: 11.5px;
}
.lw-ide__statusbar-note code {
  color: var(--accent-purple);
  font-size: inherit;
}
@media (max-width: 720px) {
  .lw-ide__statusbar-note { margin-left: 0; flex-basis: 100%; }
}

/* ── Consent privacy grid (Day 2 — replaces lw-bullet) ──── */
.lw-consent-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-top: 20px;
}
@media (max-width: 720px) { .lw-consent-grid { grid-template-columns: 1fr; } }
.lw-consent {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 22px 22px;
  background: var(--bg-elev-1);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-md);
}
.lw-consent__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px; height: 32px;
  border: 1px solid var(--line-2);
  border-radius: 8px;
  color: var(--accent-purple);
  background: var(--bg-elev-2);
}
.lw-consent__icon svg { width: 16px; height: 16px; }
.lw-consent h3 {
  font-size: 16px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--text-heading);
  margin: 0;
}
.lw-consent p {
  font-size: 13.5px;
  line-height: 1.6;
  color: var(--text-body);
  margin: 0;
}

/* ── Spec table ────────────────────────────────────────────── */
.lw-spec {
  margin: 32px 0 0;
  width: 100%;
  table-layout: fixed;
  border-collapse: collapse;
  background: var(--bg-elev-1);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.lw-spec td, .lw-spec th { word-break: break-word; overflow-wrap: anywhere; }
@media (max-width: 560px) {
  .lw-spec th, .lw-spec td { padding: 10px 14px; font-size: 12.5px; }
  .lw-spec th { width: 38%; }
  .lw-spec td code { font-size: 11.5px; }
}
.lw-spec__caption {
  text-align: left;
  padding: 14px 20px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-secondary);
  border-bottom: 1px solid var(--line-2);
}
.lw-spec th, .lw-spec td {
  padding: 12px 20px;
  font-size: 14px;
  text-align: left;
  vertical-align: top;
  border-bottom: 1px solid var(--line-1);
}
.lw-spec tr:last-child th, .lw-spec tr:last-child td { border-bottom: 0; }
.lw-spec th { color: var(--text-secondary); font-weight: 400; width: 40%; }
.lw-spec td { color: var(--text-body); }
.lw-spec td code { color: var(--accent-purple); }

/* ── Status cards (Day 4) ──────────────────────────────────── */
.lw-status-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 900px) { .lw-status-cards { grid-template-columns: 1fr; } }
.lw-status-card {
  background: var(--bg-elev-1);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.lw-status-card__head {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.lw-status-card__dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.lw-status-card__dot--ok {
  background: var(--ok);
  box-shadow: 0 0 0 4px rgba(74, 222, 128, 0.18);
  animation: lw-pulse 2.4s ease-in-out infinite;
}
.lw-status-card__tag { color: var(--text-secondary); }
.lw-status-card__state { margin-left: auto; color: var(--ok); }
.lw-status-card h3 {
  font-size: 19px;
  font-weight: 500;
  letter-spacing: -0.012em;
  color: var(--text-heading);
  margin: 0;
}
.lw-status-card p {
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-body);
  margin: 0;
}
.lw-status-card__meta {
  font-size: 12.5px !important;
  color: var(--text-secondary) !important;
  padding-top: 12px;
  border-top: 1px solid var(--line-1);
  margin-top: auto !important;
}

/* ── SEO pills (Day 4) ─────────────────────────────────────── */
.lw-pills {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.lw-pills li {
  padding: 10px 16px;
  background: var(--bg-elev-1);
  border: 1px solid var(--line-2);
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--text-body);
}

/* ── Stats strip (Day 5) ───────────────────────────────────── */
.lw-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  padding: 32px;
  background: var(--bg-elev-1);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-lg);
}
@media (max-width: 720px) { .lw-stats { grid-template-columns: 1fr; gap: 16px; } }
.lw-stat {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.lw-stat__val {
  font-family: var(--font-mono);
  font-size: clamp(36px, 4vw, 52px);
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--text-heading);
  font-variant-numeric: tabular-nums;
}
.lw-stat__label {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-secondary);
}
