/* ============================================================
   MUTATIS MUTANDIS — The Alchemist's Press
   Visual DNA: paper grain + ink + signal red + brutalist serif
   ============================================================ */

:root {
  --paper:        #f1ece0;
  --paper-2:      #e8e2d3;
  --paper-deep:   #d9d2c0;
  --ink:          #0b0a08;
  --ink-soft:     #1a1814;
  --ink-mute:     #5a534a;
  --rule:         #1a1814;
  --signal:       #c8161d;
  --signal-deep:  #8a0f15;
  --stain:        rgba(120, 50, 30, 0.18);
  --halftone:     rgba(11,10,8,0.55);

  --font-display: "EB Garamond", "DM Serif Display", Georgia, serif;
  --font-body:    "EB Garamond", Georgia, serif;
  --font-mono:    "JetBrains Mono", "Courier New", monospace;
  --font-hand:    "Caveat", cursive;
  --font-occult:  "Pirata One", serif;

  --max:          1440px;
  --pad-x:        clamp(20px, 4vw, 64px);
}

* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 18px;
  line-height: 1.5;
  overflow-x: hidden;
  cursor: crosshair;
}
body { min-height: 100vh; }

a { color: inherit; text-decoration: none; cursor: crosshair; }
button { font-family: inherit; cursor: crosshair; }
::selection { background: var(--signal); color: var(--paper); }

img { display: block; max-width: 100%; }

/* ─────────── Persistent textures ─────────── */
.grain {
  position: fixed; inset: 0; pointer-events: none; z-index: 9990;
  opacity: 0.5;
  mix-blend-mode: multiply;
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.05  0 0 0 0 0.04  0 0 0 0 0.03  0 0 0 0.35 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
.vignette {
  position: fixed; inset: 0; pointer-events: none; z-index: 9991;
  background: radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,0.15) 100%);
}

/* ─────────── Type primitives ─────────── */
.mono { font-family: var(--font-mono); letter-spacing: 0.02em; }
.mono-xs { font-family: var(--font-mono); font-size: 10px; line-height: 1.3; letter-spacing: 0.08em; text-transform: uppercase; }
.mono-sm { font-family: var(--font-mono); font-size: 11px; line-height: 1.4; letter-spacing: 0.06em; text-transform: uppercase; }
.mono-md { font-family: var(--font-mono); font-size: 13px; line-height: 1.5; letter-spacing: 0.04em; }

.serif-italic { font-family: var(--font-display); font-style: italic; }
.signal { color: var(--signal); }
.muted  { color: var(--ink-mute); }

/* Drop cap */
.dropcap::first-letter {
  font-family: var(--font-display);
  font-weight: 700;
  font-style: italic;
  float: left;
  font-size: 5.2em;
  line-height: 0.85;
  padding: 0.1em 0.08em 0 0;
  color: var(--ink);
}

/* ─────────── Stain / ink-bleed primitives ─────────── */
.stain {
  position: absolute;
  pointer-events: none;
  border-radius: 50%;
  filter: blur(8px);
  mix-blend-mode: multiply;
  background: radial-gradient(closest-side, var(--stain), transparent 70%);
}
.redaction {
  background: var(--ink);
  color: var(--ink);
  padding: 0 0.25em;
  user-select: none;
}
.stamp {
  display: inline-block;
  border: 2px solid var(--signal);
  color: var(--signal);
  padding: 4px 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  transform: rotate(-3deg);
  background: rgba(255, 255, 255, 0.05);
}

/* Hairlines */
.hr-hair { height: 1px; background: var(--ink); width: 100%; border: 0; }
.hr-double { height: 5px; border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink); width: 100%; }
.hr-fat { height: 4px; background: var(--ink); width: 100%; border: 0; }

/* ─────────── Layout shells ─────────── */
.shell {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 var(--pad-x);
  position: relative;
}

/* ─────────── Side rail (right) ─────────── */
.rail {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: 44px;
  z-index: 80;
  border-left: 1px solid var(--ink);
  background: rgba(241, 236, 224, 0.85);
  backdrop-filter: blur(8px);
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 14px 0;
  gap: 16px;
}
.rail .vlabel {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--signal);
}
.rail .vlabel-ink {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.15em;
  color: var(--ink);
}
.rail .stat {
  font-family: var(--font-mono);
  font-size: 9px;
  text-align: center;
  line-height: 1.4;
}
.rail .stat b { color: var(--signal); display: block; font-weight: 700; }
.rail .rec {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--signal);
  animation: pulse 1.4s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 0.35; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.35); }
}

/* When rail is hidden */
body.no-rail .rail { display: none; }
body.no-rail .shell { /* unchanged */ }

/* ─────────── Header / Masthead ─────────── */
/* Masthead — home uses full anatomical banner; inner pages also use full anatomy (section-specific) */
.masthead {
  border-bottom: 4px solid var(--ink);
  padding: 0;
  background: var(--ink);
  position: relative;
}
.mast-anatomy {
  display: block;
  text-decoration: none;
  background: var(--ink);
  padding: 24px var(--pad-x) 16px;
}
.mast-anatomy img {
  display: block;
  max-width: 100%;
  width: 100%;
  height: auto;
  margin: 0 auto;
}

/* Inner-page masthead: discreet "← Mutatis Mutandis" link + full-width section anatomy */
.mast-inner { background: var(--paper); }
.mast-inner-strip {
  display: block;
  padding: 0;
  background: var(--paper);
  color: var(--ink);
}
.mast-inner-logo {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  text-decoration: none;
  color: var(--ink);
  padding: 10px var(--pad-x);
  background: var(--ink);
  color: var(--paper);
  border-bottom: 1px solid var(--ink);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.mast-inner-mm {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 18px;
  line-height: 1;
  letter-spacing: -0.01em;
  text-transform: none;
  color: var(--paper);
}
.mast-inner-mm em {
  color: var(--signal);
  font-style: italic;
}
.mast-inner-back {
  color: var(--signal);
  opacity: 0.9;
}
.mast-inner-logo:hover .mast-inner-back { opacity: 1; text-decoration: underline; }
.mast-inner-anatomy {
  display: block;
  background: var(--paper);
  padding: 16px var(--pad-x);
  max-width: var(--max);
  margin: 0 auto;
}
.mast-inner-anatomy img {
  display: block;
  width: 100%;
  height: auto;
  max-height: 580px;
  object-fit: contain;
  margin: 0 auto;
}
@media (max-width: 700px) {
  .mast-inner-anatomy img { max-height: 380px; }
}
.masthead .meta-row {
  background: var(--paper);
  color: var(--ink);
  border: 0;
  border-top: 1px solid var(--ink);
  border-bottom: 0;
  padding: 10px var(--pad-x);
  margin: 0;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
}
.masthead .meta-row > span { display: inline-flex; gap: 8px; align-items: center; }
.masthead .meta-row .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--signal); display: inline-block; }

/* Nav strip */
.nav {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
  padding: 12px 0;
  border-bottom: 1px solid var(--ink);
  font-family: var(--font-mono);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  position: sticky;
  top: 0;
  z-index: 70;
  background: var(--paper);
  margin-bottom: 0;
}
.nav .item {
  padding: 6px 10px;
  border: 1px solid transparent;
  transition: all 0.18s ease;
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
}
.nav .item .hex { color: var(--signal); font-size: 10px; }
.nav .item:hover { background: var(--ink); color: var(--paper); }
.nav .item.active { background: var(--ink); color: var(--paper); }
.nav .spacer { flex: 1; }
.nav .live {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--signal);
}
.nav .live::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--signal); animation: pulse 1.2s infinite;
}

/* ─────────── HERO / MANIFIESTO ─────────── */
.hero {
  position: relative;
  padding: 64px 0 80px;
  border-bottom: 1px solid var(--ink);
}
.hero .kicker {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  padding-bottom: 24px;
}
.hero .kicker .signal { color: var(--signal); }

.hero h1 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(56px, 11vw, 168px);
  line-height: 0.88;
  letter-spacing: -0.045em;
  text-transform: uppercase;
  margin: 0;
}
.hero h1 .line { display: block; position: relative; }
.hero h1 .it { font-style: italic; color: var(--signal); }
.hero h1 .ind1 { padding-left: 0; }
.hero h1 .ind2 { padding-left: 12vw; }
.hero h1 .ind3 { padding-left: 4vw; font-style: italic; }
.hero h1 .strike { position: relative; }
.hero h1 .strike::after {
  content: ""; position: absolute; left: -2%; right: -2%; top: 52%;
  height: 6px; background: var(--signal);
  transform: rotate(-2deg);
}

.hero .grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  margin-top: 56px;
  align-items: start;
}
@media (max-width: 900px) { .hero .grid { grid-template-columns: 1fr; } }

.hero .pull {
  border-left: 3px solid var(--signal);
  padding: 6px 20px;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 24px;
  line-height: 1.35;
  position: relative;
}
.hero .pull cite {
  display: block;
  margin-top: 18px;
  font-family: var(--font-mono);
  font-style: normal;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ink);
}

.hero .photo-frame {
  position: relative;
  border: 1px solid var(--ink);
  padding: 14px;
  background: var(--paper);
}
.hero .photo-frame img {
  width: 100%; aspect-ratio: 4 / 5; object-fit: cover;
  filter: grayscale(1) contrast(1.15);
  display: block;
}
.hero .photo-frame .corner {
  position: absolute;
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--signal);
  text-transform: uppercase;
  letter-spacing: 0.15em;
}
.hero .photo-frame .c-tl { top: -10px; left: 14px; background: var(--paper); padding: 0 6px; }
.hero .photo-frame .c-tr { top: -10px; right: 14px; background: var(--paper); padding: 0 6px; }
.hero .photo-frame .c-bl { bottom: -10px; left: 14px; background: var(--paper); padding: 0 6px; }
.hero .photo-frame .c-br { bottom: -10px; right: 14px; background: var(--paper); padding: 0 6px; }
.hero .photo-frame .reticle {
  position: absolute; inset: 14px; pointer-events: none;
  border: 1px dashed var(--signal);
}
.hero .photo-frame .reticle::before,
.hero .photo-frame .reticle::after {
  content: ""; position: absolute;
}
.hero .photo-frame .reticle::before { left: 50%; top: 0; bottom: 0; width: 1px; background: var(--signal); opacity: 0.45; }
.hero .photo-frame .reticle::after  { top: 50%; left: 0; right: 0; height: 1px; background: var(--signal); opacity: 0.45; }

.hero .marginalia {
  position: absolute;
  font-family: var(--font-hand);
  color: var(--signal);
  font-size: 22px;
  line-height: 1;
  transform: rotate(-6deg);
  pointer-events: none;
}

/* Glyph row */
.glyph-row {
  display: flex; gap: 20px; align-items: center;
  font-family: var(--font-occult);
  font-size: 26px;
  color: var(--ink);
  padding: 8px 0;
  border-top: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  letter-spacing: 0.4em;
  justify-content: space-between;
}
.glyph-row .glyph { font-size: 22px; }
.glyph-row .seq {
  flex: 1;
  display: flex; gap: 18px; justify-content: space-between;
  opacity: 0.85;
}

/* ─────────── EL VIGÍA — newspaper columns ─────────── */
.vigia {
  padding: 80px 0;
  border-bottom: 1px solid var(--ink);
  position: relative;
}
.vigia .head {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-bottom: 24px;
}
.vigia .head h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-style: italic;
  font-size: clamp(40px, 7vw, 96px);
  line-height: 0.9;
  letter-spacing: -0.02em;
  margin: 0;
  text-transform: uppercase;
}
.vigia .head h2 .ord { font-style: normal; color: var(--signal); font-family: var(--font-mono); font-size: 0.25em; letter-spacing: 0.2em; vertical-align: super; }

.vigia .deck {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 18px;
  max-width: 480px;
  border-top: 1px solid var(--ink);
  padding-top: 12px;
  margin-bottom: 32px;
}

.columns {
  column-count: 4;
  column-gap: 28px;
  column-rule: 1px solid var(--ink);
}
@media (max-width: 1200px) { .columns { column-count: 3; } }
@media (max-width: 900px)  { .columns { column-count: 2; } }
@media (max-width: 600px)  { .columns { column-count: 1; } }

.col-item {
  break-inside: avoid;
  padding: 18px 0 22px;
  border-bottom: 1px solid var(--ink);
}
.col-item:last-child { border-bottom: 0; }
.col-item .dl {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--signal);
  margin-bottom: 8px;
  display: flex; justify-content: space-between;
}
.col-item h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 26px;
  line-height: 1.05;
  margin: 0 0 10px;
  letter-spacing: -0.01em;
  cursor: crosshair;
  transition: color 0.15s;
}
.col-item h3:hover { color: var(--signal); }
.col-item h3.it { font-style: italic; }
.col-item h3.big { font-size: 34px; }
.col-item h3.allcaps { text-transform: uppercase; font-size: 22px; letter-spacing: -0.005em; }
.col-item p {
  font-size: 15px; line-height: 1.45;
  margin: 0 0 8px;
}
.col-item .author {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ink-mute);
  margin-top: 6px;
}
.col-item .tag {
  display: inline-block;
  background: var(--ink); color: var(--paper);
  font-family: var(--font-mono); font-size: 9px;
  padding: 2px 6px; letter-spacing: 0.15em;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.col-item .tag.red { background: var(--signal); }

/* Special col items */
.col-item .ad {
  border: 2px solid var(--ink);
  padding: 14px;
  text-align: center;
  background: var(--paper);
}
.col-item .ad .small { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; }
.col-item .ad .big-word {
  font-family: var(--font-display);
  font-weight: 700; font-style: italic;
  font-size: 36px; line-height: 1;
  margin: 8px 0;
}

.col-item .image {
  width: 100%;
  aspect-ratio: 4 / 3;
  background: var(--ink);
  margin-bottom: 8px;
  filter: grayscale(1) contrast(1.2);
  position: relative;
  overflow: hidden;
}
.col-item .image img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1) contrast(1.1); }
.col-item .image .label {
  position: absolute; bottom: 4px; right: 4px;
  background: var(--signal); color: var(--paper);
  font-family: var(--font-mono); font-size: 9px;
  padding: 2px 5px; letter-spacing: 0.15em;
  text-transform: uppercase;
}
.col-item .cap {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-top: 4px;
}

/* ─────────── BIBLIOPATÍA ─────────── */
.biblio {
  padding: 100px 0;
  border-bottom: 1px solid var(--ink);
  position: relative;
  background: var(--paper);
}
.biblio .head {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 40px;
  margin-bottom: 56px;
}
@media (max-width: 900px) { .biblio .head { grid-template-columns: 1fr; } }
.biblio .head .label {
  display: inline-block;
  background: var(--signal);
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 4px 8px;
  margin-bottom: 12px;
}
.biblio h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(48px, 8vw, 120px);
  line-height: 0.85;
  letter-spacing: -0.04em;
  text-transform: uppercase;
  margin: 0;
}
.biblio h2 .lower { text-transform: lowercase; font-style: italic; font-weight: 500; }

.biblio .lede {
  font-family: var(--font-display);
  font-size: 22px;
  line-height: 1.45;
  font-style: italic;
  max-width: 580px;
}

.book-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 28px;
}
.book {
  position: relative;
  border: 1px solid var(--ink);
  background: var(--paper);
  padding: 16px;
  transition: transform 0.18s ease;
  cursor: crosshair;
  display: flex;
  flex-direction: column;
}
.book.book-horizontal {
  flex-direction: row;
  gap: 18px;
  align-items: stretch;
}
.book.book-horizontal .cover {
  flex-shrink: 0;
  width: 160px;
  aspect-ratio: 3 / 4;
  margin-bottom: 0;
}
.book.book-horizontal .book-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.book.book-horizontal .bar {
  margin: 0 0 12px;
}
.book:hover { transform: translate(-4px, -4px); box-shadow: 8px 8px 0 var(--ink); }
.book .bar {
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.15em;
  padding: 4px 8px;
  display: flex; justify-content: space-between; align-items: center;
  text-transform: uppercase;
  margin: -16px -16px 14px;
}
.book .cover {
  background: var(--ink);
  aspect-ratio: 3 / 4;
  position: relative;
  overflow: hidden;
  margin-bottom: 14px;
  max-height: 320px;
}
.book .cover img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: var(--ink);
}
.book .cover img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1) contrast(1.1); }
.book .cover .stamp-on {
  position: absolute;
  top: 18px; right: -10px;
  transform: rotate(8deg);
}
.book .cover .corner-bracket {
  position: absolute;
  width: 28px; height: 28px;
  border: 2px solid var(--signal);
}
.book .cover .corner-bracket.tl { top: 6px; left: 6px; border-right: 0; border-bottom: 0; }
.book .cover .corner-bracket.br { bottom: 6px; right: 6px; border-left: 0; border-top: 0; }

.book h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 24px;
  line-height: 1.05;
  margin: 0 0 8px;
  letter-spacing: -0.01em;
}
.book h3 .it { font-style: italic; }
.book .author { font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.18em; color: var(--signal); margin-bottom: 12px; }
.book .meta {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  border-top: 1px dashed var(--ink);
  padding-top: 8px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  color: var(--ink-mute);
  text-transform: uppercase;
}
.book .meta b { color: var(--ink); }

/* span variants */
.book.span-3 { grid-column: span 4; }
.book.span-4 { grid-column: span 4; }
.book.span-5 { grid-column: span 6; }
.book.span-6 { grid-column: span 8; }
.book.span-7 { grid-column: span 8; }
@media (max-width: 900px) { .book.span-3,.book.span-4,.book.span-5,.book.span-6,.book.span-7 { grid-column: span 12; } }
@media (max-width: 600px) {
  .book.book-horizontal { flex-direction: column; }
  .book.book-horizontal .cover { width: 100%; max-height: 240px; }
}

/* Book-note text card — sits among books */
.book-note {
  grid-column: span 4;
  border: 1px solid var(--ink);
  background: var(--paper-2);
  padding: 22px;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.book-note.span-6 { grid-column: span 6; }
.book-note.dark { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.book-note.red  { background: var(--signal); color: var(--paper); border-color: var(--signal); }
@media (max-width: 900px) { .book-note, .book-note.span-6 { grid-column: span 12; } }
.book-note .tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--signal);
  margin-bottom: 14px;
  padding-bottom: 8px;
  border-bottom: 1px dashed currentColor;
  display: flex;
  justify-content: space-between;
  opacity: 0.95;
}
.book-note.dark .tag, .book-note.red .tag { color: var(--paper); opacity: 0.6; }
.book-note .quote {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 24px;
  line-height: 1.25;
  margin: 0 0 16px;
  letter-spacing: -0.005em;
}
.book-note.dark .quote, .book-note.red .quote { color: var(--paper); }
.book-note .quote em { color: var(--signal); font-style: italic; }
.book-note.red .quote em, .book-note.dark .quote em { color: inherit; text-decoration: underline; text-decoration-color: var(--paper); text-decoration-thickness: 2px; text-underline-offset: 4px; }
.book-note .cite {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  opacity: 0.7;
}
.book-note .big-num {
  font-family: var(--font-display);
  font-weight: 700;
  font-style: italic;
  font-size: 96px;
  line-height: 0.85;
  color: var(--signal);
  margin: 0 0 6px;
  letter-spacing: -0.04em;
}
.book-note.dark .big-num, .book-note.red .big-num { color: var(--paper); }
.book-note .small {
  font-size: 14px;
  line-height: 1.4;
  margin: 0;
}

/* ─────────── THE ALCHEMIST'S EYE ─────────── */
.eye {
  padding: 100px 0 60px;
  border-bottom: 1px solid var(--ink);
  position: relative;
  background: var(--ink);
  color: var(--paper);
  overflow: hidden;
}
.eye .head {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-bottom: 36px;
}
.eye h2 {
  font-family: var(--font-display);
  font-weight: 600;
  font-style: italic;
  font-size: clamp(40px, 7vw, 96px);
  line-height: 0.9;
  letter-spacing: -0.02em;
  margin: 0;
  text-transform: uppercase;
}
.eye .mono-sm { color: var(--signal); }
.eye .strip {
  display: flex;
  gap: 24px;
  overflow-x: auto;
  padding: 0 var(--pad-x) 24px;
  margin: 0 calc(-1 * var(--pad-x));
  scrollbar-width: thin;
  scrollbar-color: var(--signal) transparent;
}
.eye .strip::-webkit-scrollbar { height: 6px; }
.eye .strip::-webkit-scrollbar-track { background: rgba(255,255,255,0.05); }
.eye .strip::-webkit-scrollbar-thumb { background: var(--signal); }

.frame {
  flex-shrink: 0;
  width: 220px;
  background: var(--paper);
  padding: 10px 10px 14px;
  color: var(--ink);
  position: relative;
}
.frame.wide { width: 340px; }
.frame.tall { width: 180px; }
.frame img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  filter: grayscale(1) contrast(1.25);
  transition: filter 0.4s;
}
.frame.wide img { aspect-ratio: 16 / 10; }
.frame.tall img { aspect-ratio: 3 / 5; }
.frame.portrait {
  width: 200px;
}
.frame.portrait img {
  aspect-ratio: 1 / 3;
  object-fit: cover;
  object-position: center;
  background: #000;
}
.frame:hover img { filter: grayscale(0) contrast(1.05); }
.frame .cap {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono); font-size: 9px;
  text-transform: uppercase; letter-spacing: 0.1em;
  margin-top: 8px;
}
.frame .cap b { color: var(--signal); }
.frame .desc {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 12px;
  line-height: 1.3;
  margin-top: 4px;
}
.frame .overlay-num {
  position: absolute;
  top: 18px; right: 18px;
  font-family: var(--font-mono);
  font-size: 9px;
  background: var(--signal);
  color: var(--paper);
  padding: 2px 5px;
  letter-spacing: 0.15em;
}
.frame .crosshair-overlay {
  position: absolute;
  inset: 10px;
  pointer-events: none;
}
.frame .crosshair-overlay::before,
.frame .crosshair-overlay::after { content: ""; position: absolute; background: var(--signal); opacity: 0.6; }
.frame .crosshair-overlay::before { left: 50%; top: 0; bottom: 0; width: 1px; }
.frame .crosshair-overlay::after  { top: 50%; left: 0; right: 0; height: 1px; }

/* Text-card variant interleaved with photos */
.eye-text {
  flex-shrink: 0;
  width: 260px;
  background: transparent;
  color: var(--paper);
  padding: 14px 16px 16px;
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(241, 236, 224, 0.35);
  position: relative;
}
.eye-text.quote { width: 320px; }
.eye-text.spec  { width: 220px; background: var(--paper); color: var(--ink); border-color: var(--ink); }
.eye-text.def   { width: 280px; background: var(--signal); color: var(--paper); border-color: var(--signal); }

.eye-text .et-tag {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--signal);
  margin-bottom: 10px;
  padding-bottom: 6px;
  border-bottom: 1px dashed currentColor;
  display: flex;
  justify-content: space-between;
}
.eye-text.spec .et-tag, .eye-text.def .et-tag { color: inherit; opacity: 0.7; }
.eye-text .et-body {
  font-family: var(--font-display);
  font-size: 17px;
  line-height: 1.32;
  font-style: italic;
  flex: 1;
}
.eye-text.quote .et-body { font-size: 21px; line-height: 1.25; }
.eye-text.def .et-body { font-style: normal; font-size: 15px; line-height: 1.4; }
.eye-text.def .et-body b { font-family: var(--font-display); font-size: 28px; font-style: italic; font-weight: 700; display: block; margin-bottom: 4px; line-height: 1; }
.eye-text .et-cite {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-top: 12px;
  opacity: 0.7;
}
.eye-text.spec .et-grid {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 4px 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  line-height: 1.5;
}
.eye-text.spec .et-grid b { color: var(--signal); font-weight: 500; }

@media (max-width: 700px) {
  .frame { width: 180px; }
  .frame.wide { width: 240px; }
  .frame.tall { width: 150px; }
  .eye-text, .eye-text.quote, .eye-text.spec, .eye-text.def { width: 220px; }
}

/* ─────────── DIÁLOGOS — IA Portal ─────────── */
.portal {
  padding: 100px 0;
  border-bottom: 4px solid var(--ink);
  position: relative;
  background: var(--paper);
}
.portal .corner-mark {
  position: absolute;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--signal);
  text-transform: uppercase;
}

.portal .head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  margin-bottom: 40px;
  align-items: end;
}
@media (max-width: 900px) { .portal .head { grid-template-columns: 1fr; } }
.portal h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(48px, 8vw, 120px);
  line-height: 0.85;
  letter-spacing: -0.04em;
  text-transform: uppercase;
  margin: 0;
}
.portal h2 .it { font-style: italic; color: var(--signal); }

.portal .preamble {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 19px;
  line-height: 1.45;
  border-left: 3px solid var(--signal);
  padding-left: 18px;
}

.portal .body {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 40px;
}
@media (max-width: 1000px) { .portal .body { grid-template-columns: 1fr; } }

/* Terminal */
.terminal {
  background: var(--ink);
  color: var(--paper);
  border: 1px solid var(--ink);
  font-family: var(--font-mono);
  font-size: 14px;
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 580px;
  max-height: 720px;
  overflow: hidden;
}
.terminal::before {
  content: "";
  position: absolute; inset: 0;
  pointer-events: none;
  background: repeating-linear-gradient(0deg, transparent 0, transparent 3px, rgba(255,255,255,0.025) 3px, rgba(255,255,255,0.025) 4px);
}
.terminal .tbar {
  background: var(--paper);
  color: var(--ink);
  padding: 8px 14px;
  border-bottom: 1px solid var(--paper);
  display: flex; justify-content: space-between; align-items: center;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.terminal .tbar .dots { display: inline-flex; gap: 5px; }
.terminal .tbar .dots span { width: 8px; height: 8px; background: var(--ink); border-radius: 50%; opacity: 0.6; }
.terminal .tbar .dots span:first-child { background: var(--signal); opacity: 1; }

.terminal .conv {
  flex: 1;
  overflow-y: auto;
  padding: 18px 18px 12px;
  scrollbar-width: thin;
  scrollbar-color: var(--signal) transparent;
}
.terminal .conv::-webkit-scrollbar { width: 6px; }
.terminal .conv::-webkit-scrollbar-thumb { background: var(--signal); }

.terminal .turn { margin-bottom: 18px; }
.terminal .turn .who {
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--signal);
  margin-bottom: 5px;
}
.terminal .turn.user .who { color: rgba(241, 236, 224, 0.55); }
.terminal .turn .msg {
  white-space: pre-wrap;
  line-height: 1.55;
  font-family: var(--font-mono);
  font-size: 13.5px;
}
.terminal .turn.machine .msg {
  font-family: var(--font-display);
  font-size: 19px;
  line-height: 1.4;
  font-style: italic;
  color: var(--paper);
}
.terminal .turn.machine .msg::first-letter {
  color: var(--signal);
}
.terminal .turn.user .msg {
  color: rgba(241, 236, 224, 0.85);
}
.terminal .typing::after {
  content: "▊";
  color: var(--signal);
  animation: blink 0.8s steps(2) infinite;
  margin-left: 2px;
}
@keyframes blink { 50% { opacity: 0; } }

.terminal .input {
  border-top: 1px solid rgba(241, 236, 224, 0.25);
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(11, 10, 8, 0.85);
}
.terminal .input .prompt { color: var(--signal); font-weight: 700; }
.terminal .input input {
  flex: 1;
  background: transparent;
  color: var(--paper);
  border: 0;
  outline: none;
  font-family: var(--font-mono);
  font-size: 14px;
  padding: 4px 0;
  caret-color: var(--signal);
}
.terminal .input input::placeholder { color: rgba(241, 236, 224, 0.35); }
.terminal .input button {
  background: var(--signal);
  color: var(--paper);
  border: 0;
  padding: 6px 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.terminal .input button:disabled { opacity: 0.5; }

/* Experiments column */
.experiments {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.experiments h3 {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--signal);
  margin: 0 0 6px;
}
.experiments .exp-card {
  border: 1px solid var(--ink);
  padding: 18px;
  background: var(--paper);
  position: relative;
}
.exp-card .tag-strip {
  position: absolute;
  top: -10px; left: 14px;
  background: var(--paper);
  font-family: var(--font-mono);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--ink);
  padding: 0 6px;
}
.exp-card .ttl {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 24px;
  line-height: 1.05;
  margin: 0 0 8px;
}
.exp-card .ttl .it { font-style: italic; }
.exp-card .desc {
  font-size: 14px;
  line-height: 1.45;
  color: var(--ink-mute);
  margin: 0 0 14px;
}
.exp-card .btn {
  background: var(--ink);
  color: var(--paper);
  border: 0;
  padding: 8px 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  display: inline-flex; gap: 8px; align-items: center;
}
.exp-card .btn:hover { background: var(--signal); }
.exp-card .btn:disabled { opacity: 0.5; }

.exp-card .output {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px dashed var(--ink);
  font-family: var(--font-display);
  font-style: italic;
  font-size: 17px;
  line-height: 1.4;
  min-height: 24px;
}
.exp-card .output.empty { color: var(--ink-mute); font-style: normal; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; }
.exp-card .output .meta {
  font-family: var(--font-mono);
  font-style: normal;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--signal);
  margin-top: 8px;
  display: block;
}

/* Oracle card */
.oracle-card {
  border: 2px solid var(--ink);
  background: var(--paper);
  padding: 22px;
  position: relative;
  text-align: center;
}
.oracle-card .symbol {
  font-family: var(--font-occult);
  font-size: 64px;
  color: var(--signal);
  line-height: 1;
  margin: 4px 0;
}
.oracle-card .arcana {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
}

/* Voice agent (future / placeholder) */
.voice-stub {
  border: 1px dashed var(--ink);
  padding: 16px;
  background: rgba(11,10,8,0.04);
  position: relative;
}
.voice-stub .badge {
  position: absolute; top: -10px; right: 14px;
  background: var(--signal); color: var(--paper);
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: 0.2em; padding: 2px 6px; text-transform: uppercase;
}
.voice-stub .waveform {
  height: 36px;
  display: flex; gap: 3px; align-items: end;
  margin-top: 8px;
}
.voice-stub .waveform span {
  width: 4px;
  background: var(--signal);
  border-radius: 0;
  animation: wave 1.2s ease-in-out infinite;
}
@keyframes wave {
  0%, 100% { height: 12%; opacity: 0.6; }
  50% { height: 100%; opacity: 1; }
}

/* ─────────── ARTICLE OVERLAY ─────────── */
.overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(11, 10, 8, 0.75);
  display: flex;
  justify-content: center;
  align-items: flex-start;
  padding: 40px 20px;
  overflow-y: auto;
  animation: fade 0.2s ease;
}
@keyframes fade { from { opacity: 0; } to { opacity: 1; } }
.overlay-card {
  background: var(--paper);
  max-width: 880px;
  width: 100%;
  padding: 56px 60px 72px;
  border: 1px solid var(--ink);
  position: relative;
  font-family: var(--font-display);
}
@media (max-width: 700px) { .overlay-card { padding: 40px 24px; } }
.overlay-card .close {
  position: absolute; top: 18px; right: 18px;
  background: var(--ink); color: var(--paper);
  border: 0; padding: 6px 10px;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
}
.overlay-card .close:hover { background: var(--signal); }
.overlay-card .dl {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--signal);
  display: flex; justify-content: space-between;
  border-bottom: 1px solid var(--ink);
  padding-bottom: 10px;
  margin-bottom: 22px;
}
.overlay-card h1 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(36px, 5vw, 68px);
  line-height: 0.95;
  letter-spacing: -0.025em;
  margin: 0 0 24px;
}
.overlay-card h1 .it { font-style: italic; color: var(--signal); }
.overlay-card .author {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 30px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--ink);
}
.overlay-card .body {
  column-count: 2;
  column-gap: 36px;
  column-rule: 1px solid var(--ink);
  font-size: 18px;
  line-height: 1.6;
}
@media (max-width: 700px) { .overlay-card .body { column-count: 1; } }
.overlay-card .body p { margin: 0 0 16px; text-align: justify; hyphens: auto; }
.overlay-card .body p.lead { font-size: 22px; font-style: italic; line-height: 1.5; }
.overlay-card .body .pull-in {
  border-left: 3px solid var(--signal);
  padding: 6px 16px;
  font-style: italic;
  font-size: 22px;
  margin: 20px 0;
  break-inside: avoid;
}

/* ─────────── FOOTER ─────────── */
.footer {
  background: var(--ink);
  color: var(--paper);
  padding: 60px 0 0;
  margin-top: 0;
  position: relative;
}
.footer .grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
  padding-bottom: 60px;
}
@media (max-width: 900px) { .footer .grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .footer .grid { grid-template-columns: 1fr; } }
.footer h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(38px, 5vw, 64px);
  line-height: 0.9;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  margin: 0 0 16px;
}
.footer h3 .it { font-style: italic; color: var(--signal); }
.footer h4 {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--signal);
  margin: 0 0 14px;
}
.footer a { color: var(--paper); display: block; padding: 4px 0; font-family: var(--font-display); font-size: 17px; }
.footer a:hover { color: var(--signal); }
.footer .colophon { font-family: var(--font-mono); font-size: 11px; line-height: 1.7; opacity: 0.6; letter-spacing: 0.08em; }
.footer .marquee {
  background: var(--signal);
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  padding: 12px 0;
  overflow: hidden;
  white-space: nowrap;
}
.footer .marquee .track { display: inline-flex; gap: 60px; animation: marq 40s linear infinite; }
.footer .marquee span::after { content: " ✦ "; margin-left: 36px; color: rgba(255,255,255,0.55); }
@keyframes marq {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* ─────────── THEME MODES ─────────── */
/* PRENSA = old newspaper: more rules, more dense, halftone bg */
body.theme-prensa {
  --paper: #efe9d8;
  --paper-2: #e3dcc5;
}
body.theme-prensa::before {
  content: "";
  position: fixed; inset: 0; z-index: 1; pointer-events: none;
  background-image: radial-gradient(var(--halftone) 0.6px, transparent 0.6px);
  background-size: 5px 5px;
  opacity: 0.07;
  mix-blend-mode: multiply;
}
body.theme-prensa .nav { border-bottom-width: 3px; }
body.theme-prensa .col-item { padding: 14px 0 18px; }

/* MANUSCRITO = alchemical manuscript: ink stains everywhere, marginalia visible */
body.theme-manuscrito {
  --paper: #ede5cf;
  --paper-2: #e1d7b8;
}
body.theme-manuscrito::before {
  content: "";
  position: fixed; inset: 0; z-index: 1; pointer-events: none;
  background:
    radial-gradient(ellipse 380px 320px at 15% 22%, var(--stain), transparent 70%),
    radial-gradient(ellipse 460px 280px at 85% 65%, var(--stain), transparent 70%),
    radial-gradient(ellipse 240px 180px at 55% 90%, var(--stain), transparent 70%);
  mix-blend-mode: multiply;
  opacity: 0.55;
}
body.theme-manuscrito .marginalia-extra { display: block; }

/* TERMINAL = machine interface */
body.theme-terminal {
  --paper: #efece1;
}
body.theme-terminal::before {
  content: "";
  position: fixed; inset: 0; z-index: 1; pointer-events: none;
  background: repeating-linear-gradient(0deg, transparent 0, transparent 3px, rgba(11,10,8,0.025) 3px, rgba(11,10,8,0.025) 4px);
  mix-blend-mode: multiply;
}
body.theme-terminal .nav .item { font-family: var(--font-mono); }
body.theme-terminal .col-item h3,
body.theme-terminal .book h3 {
  font-family: var(--font-mono);
  font-size: 18px;
  text-transform: uppercase;
  letter-spacing: -0.01em;
}
body.theme-terminal .col-item h3.big { font-size: 22px; }

/* HIBRIDO = default (no extra bg) */

/* Density */
body.density-compact .vigia { padding: 56px 0; }
body.density-compact .biblio { padding: 64px 0; }
body.density-compact .portal { padding: 64px 0; }
body.density-comfy .vigia { padding: 120px 0; }
body.density-comfy .biblio { padding: 140px 0; }
body.density-comfy .portal { padding: 140px 0; }

/* Glitch on/off */
body.no-glitch .glitch { animation: none !important; }
.glitch {
  position: relative;
  display: inline-block;
}
.glitch:hover {
  animation: glitch 0.4s steps(2) infinite;
}
@keyframes glitch {
  0% { text-shadow: 2px 0 var(--signal), -2px 0 #00fff7; }
  40% { text-shadow: -2px 0 var(--signal), 2px 0 #00fff7; }
  80% { text-shadow: 1px 0 var(--signal), -1px 0 #00fff7; }
  100% { text-shadow: none; }
}

/* No marginalia */
body.no-marginalia .marginalia,
body.no-marginalia .marginalia-extra { display: none !important; }

/* Avoid rail offset eating mobile space */
@media (max-width: 700px) {
  .rail { display: none; }
  body { padding-right: 0 !important; }
}
body { padding-right: 44px; }
body.no-rail { padding-right: 0; }

/* Selection box for nav active */
.nav .item.scroll-active { background: var(--ink); color: var(--paper); }

/* ============================================================
   PLAYGROUND — Mancha · Tacha · Censura · Sello · Rompe
   ============================================================ */

.pg-toolbar {
  position: fixed;
  top: 0; left: 0; bottom: 0;
  width: 44px;
  z-index: 85;
  border-right: 1px solid var(--ink);
  background: rgba(241, 236, 224, 0.92);
  backdrop-filter: blur(8px);
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 14px 0;
  gap: 6px;
}
body.no-playground .pg-toolbar { display: none; }
body.no-playground { padding-left: 0; }
body { padding-left: 44px; }

.pg-vlabel {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--signal);
  margin-bottom: 12px;
}
.pg-vlabel-foot {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink);
  opacity: 0.6;
  margin-top: auto;
}

.pg-tool {
  width: 32px; height: 38px;
  background: transparent;
  border: 1px solid transparent;
  color: var(--ink);
  padding: 4px 0;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1px;
  cursor: crosshair;
  position: relative;
  transition: background 0.12s, color 0.12s;
}
.pg-tool .pg-sym {
  font-size: 18px;
  line-height: 1;
  font-family: var(--font-occult), var(--font-display);
}
.pg-tool .pg-lbl {
  font-size: 7.5px;
  letter-spacing: 0.05em;
  opacity: 0.7;
}
.pg-tool:hover { background: var(--ink); color: var(--paper); }
.pg-tool.active {
  background: var(--signal);
  color: var(--paper);
  border-color: var(--signal);
}
.pg-tool.active .pg-lbl { opacity: 1; }
.pg-tool.pg-reset { color: var(--ink-mute); margin-top: 8px; border-top: 1px dashed var(--ink); padding-top: 6px; }
.pg-tool.pg-reset:hover { color: var(--paper); }

/* Help banner that appears when a tool is active */
.pg-help-banner {
  position: fixed;
  left: 60px;
  bottom: 20px;
  z-index: 86;
  background: var(--ink);
  color: var(--paper);
  padding: 12px 16px;
  border: 2px solid var(--signal);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 14px;
  max-width: 340px;
  animation: pg-banner-in 0.25s ease;
  box-shadow: 4px 4px 0 var(--signal);
}
@keyframes pg-banner-in {
  from { transform: translateY(8px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
.pg-help-banner b { color: var(--signal); font-weight: 700; }
.pg-help-banner .x {
  background: var(--signal);
  color: var(--paper);
  border: 0;
  width: 22px; height: 22px;
  font-family: var(--font-mono);
  font-size: 11px;
  margin-left: auto;
}
.pg-help-banner .x:hover { background: var(--paper); color: var(--ink); }

/* Stain & stamp layer */
.pg-stain-layer {
  position: absolute;
  top: 0; left: 0; width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 60;
  overflow: visible;
}
.pg-stain {
  position: absolute;
  pointer-events: none;
  mix-blend-mode: multiply;
  animation: pg-splat 0.42s cubic-bezier(.2, .8, .2, 1);
}
@keyframes pg-splat {
  0% { transform: scale(0) rotate(var(--rot, 0deg)); opacity: 0; }
  60% { transform: scale(1.15) rotate(var(--rot, 0deg)); opacity: 1; }
  100% { transform: scale(1) rotate(var(--rot, 0deg)); opacity: 1; }
}

.pg-stamp {
  position: absolute;
  pointer-events: none;
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.25em;
  color: var(--signal);
  border: 3px solid var(--signal);
  padding: 8px 18px;
  text-transform: uppercase;
  opacity: 0.78;
  z-index: 65;
  white-space: nowrap;
  animation: pg-stamp-in 0.35s cubic-bezier(.2, .8, .2, 1);
  background: rgba(241, 236, 224, 0.15);
  text-shadow: 0 0 1px rgba(200, 22, 29, 0.4);
}
@keyframes pg-stamp-in {
  0%   { transform: translate(-50%, -50%) scale(2.2) rotate(var(--rot, 0deg)); opacity: 0; }
  60%  { transform: translate(-50%, -50%) scale(0.9) rotate(var(--rot, 0deg)); opacity: 0.95; }
  100% { transform: translate(-50%, -50%) scale(1) rotate(var(--rot, 0deg)); opacity: 0.78; }
}

/* Mutations applied to content */
.pg-tachado {
  position: relative;
}
.pg-tachado::after {
  content: "";
  position: absolute;
  left: -2%;
  right: -2%;
  top: 52%;
  height: 5px;
  background: var(--signal);
  transform: rotate(-1.5deg);
  pointer-events: none;
  z-index: 5;
  animation: pg-strike 0.3s ease;
  transform-origin: left center;
}
@keyframes pg-strike {
  from { transform: scaleX(0) rotate(-1.5deg); }
  to   { transform: scaleX(1) rotate(-1.5deg); }
}

.pg-censurado {
  position: relative;
}
.pg-censurado > * { visibility: hidden; }
.pg-censurado::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--ink);
  z-index: 4;
  animation: pg-redact 0.22s ease;
  pointer-events: none;
}
.pg-censurado::after {
  content: "■ CENSURADO ■";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--signal);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.25em;
  z-index: 5;
  pointer-events: none;
}
@keyframes pg-redact {
  from { transform: scaleX(0); transform-origin: left center; }
  to   { transform: scaleX(1); }
}

.pg-rotated {
  transition: transform 0.4s cubic-bezier(.7, -.4, .3, 1.6) !important;
  position: relative;
  z-index: 2;
}

/* Active tool body cursors */
body.pg-tool-mancha,
body.pg-tool-mancha * { cursor: crosshair; }
body.pg-tool-tacha,
body.pg-tool-tacha * { cursor: text; }
body.pg-tool-censura,
body.pg-tool-censura * { cursor: cell; }
body.pg-tool-sello,
body.pg-tool-sello * { cursor: crosshair; }
body.pg-tool-rompe,
body.pg-tool-rompe * { cursor: grab; }

/* Mode indicator strip — colored top edge when a tool is active */
body.pg-active::before {
  content: "";
  position: fixed;
  top: 0; left: 44px; right: 44px;
  height: 3px;
  background: var(--signal);
  z-index: 9995;
  animation: pg-pulse 1.4s ease-in-out infinite;
}
@keyframes pg-pulse {
  0%, 100% { opacity: 0.4; }
  50% { opacity: 1; }
}

@media (max-width: 700px) {
  .pg-toolbar { display: none; }
  body { padding-left: 0 !important; }
}

/* ============================================================
   CINTILLO / NEWS RIBBON — top destacados
   ============================================================ */

.ribbon {
  background: var(--signal);
  color: var(--paper);
  border-bottom: 2px solid var(--ink);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  padding: 0;
  position: relative;
  z-index: 75;
}
.ribbon .row {
  max-width: var(--max);
  margin: 0 auto;
  padding: 8px var(--pad-x);
  display: flex;
  align-items: flex-start;
  gap: 12px;
  flex-wrap: wrap;
}
.ribbon .badge {
  background: var(--ink);
  color: var(--signal);
  padding: 3px 8px;
  font-weight: 700;
  letter-spacing: 0.2em;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
.ribbon .badge::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--signal);
  animation: pulse 1.2s infinite;
}
.ribbon .items {
  display: flex;
  gap: 6px;
  flex: 1;
  flex-wrap: wrap;
  align-items: center;
  row-gap: 4px;
}
.ribbon .item {
  padding: 3px 12px;
  border: 1px solid transparent;
  white-space: nowrap;
  cursor: crosshair;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: background 0.15s;
}
.ribbon .item:hover { background: rgba(0,0,0,0.18); }
.ribbon .item .arr { font-family: var(--font-display); font-style: italic; font-size: 13px; opacity: 0.8; }
.ribbon .sep {
  width: 1px;
  height: 14px;
  background: rgba(255,255,255,0.45);
  flex-shrink: 0;
}
.ribbon .meta {
  margin-left: auto;
  opacity: 0.85;
  font-size: 10px;
  letter-spacing: 0.2em;
  white-space: nowrap;
}
@media (max-width: 1280px) {
  .ribbon .meta { display: none; }
}

/* Real CTA inside experimental sections */
.real-cta {
  display: inline-block;
  margin-top: 16px;
  padding: 10px 14px;
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  line-height: 1.4;
  text-transform: uppercase;
  border-left: 4px solid var(--signal);
  transition: background 0.15s;
  text-decoration: none;
}
.real-cta:hover { background: var(--signal); }
.real-cta b { color: var(--signal); font-weight: 700; letter-spacing: 0.08em; }
.real-cta:hover b { color: var(--paper); }
.real-cta em { font-style: italic; font-family: var(--font-display); text-transform: none; font-size: 13px; letter-spacing: 0; }

/* Ribbon: external "VER REAL" pill */
.ribbon .item-ext {
  background: var(--ink);
  color: var(--signal);
  padding: 3px 10px;
  font-weight: 700;
  letter-spacing: 0.2em;
  font-size: 10px;
  flex-shrink: 0;
}
.ribbon .item-ext:hover {
  background: var(--paper);
  color: var(--signal);
}
.ribbon .item .item-sub {
  opacity: 0.85;
  font-weight: 400;
}

/* ============================================================
   ARTÍCULOS — horizontal carousel
   ============================================================ */
.articulos {
  padding: 100px 0 80px;
  border-bottom: 1px solid var(--ink);
  position: relative;
  background: var(--paper);
}
.articulos .head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 32px;
  margin-bottom: 40px;
  flex-wrap: wrap;
}
.articulos h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(44px, 7vw, 108px);
  line-height: 0.88;
  letter-spacing: -0.04em;
  margin: 0;
  text-transform: uppercase;
}
.articulos h2 .it { font-style: italic; color: var(--signal); }

.art-controls {
  display: flex;
  gap: 8px;
  align-items: center;
}
.art-controls button {
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--ink);
  padding: 8px 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  cursor: crosshair;
  transition: all 0.15s;
}
.art-controls button:hover { background: var(--ink); color: var(--paper); }
.art-controls .all {
  background: var(--signal);
  color: var(--paper);
  padding: 9px 16px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-left: 6px;
}
.art-controls .all:hover { background: var(--ink); }

.art-rail {
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: thin;
  scrollbar-color: var(--signal) transparent;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding: 0 var(--pad-x) 20px;
}
.art-rail::-webkit-scrollbar { height: 5px; }
.art-rail::-webkit-scrollbar-thumb { background: var(--signal); }

.art-track {
  display: flex;
  gap: 24px;
  padding-bottom: 6px;
  max-width: var(--max);
  margin: 0 auto;
}

.art-card {
  flex-shrink: 0;
  width: 360px;
  border: 1px solid var(--ink);
  background: var(--paper);
  padding: 18px;
  display: flex;
  flex-direction: column;
  scroll-snap-align: start;
  position: relative;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
  text-decoration: none;
  color: var(--ink);
}
.art-card:hover {
  transform: translate(-3px, -3px);
  box-shadow: 6px 6px 0 var(--ink);
}
.art-card:hover .art-img img { filter: grayscale(0.3) contrast(1.1); }

.art-num {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 10px;
  border-bottom: 1px solid var(--ink);
  padding-bottom: 6px;
  display: flex;
  justify-content: space-between;
}
.art-num.signal { color: var(--signal); border-bottom-color: var(--signal); }

.art-img {
  width: 100%;
  aspect-ratio: 16 / 10;
  background: var(--ink);
  margin-bottom: 14px;
  position: relative;
  overflow: hidden;
}
.art-img img {
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(1) contrast(1.2);
  transition: filter 0.35s;
}
.art-tag {
  position: absolute;
  top: 10px; left: 10px;
  background: var(--signal);
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 3px 7px;
}
.art-meta {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 8px;
  color: var(--ink-mute);
}
.art-meta .art-go { color: var(--signal); }
.art-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 22px;
  line-height: 1.1;
  margin: 0 0 10px;
  letter-spacing: -0.012em;
  flex: 1;
}
.art-excerpt {
  font-size: 14px;
  line-height: 1.45;
  margin: 0;
  color: var(--ink-mute);
}

.art-card-end {
  background: var(--ink);
  color: var(--paper);
  justify-content: space-between;
}
.art-card-end .art-title { color: var(--paper); }
.art-card-end .art-excerpt { color: rgba(241, 236, 224, 0.7); }
.art-card-end:hover { box-shadow: 6px 6px 0 var(--signal); }
.art-card-end .art-go.big {
  font-family: var(--font-mono);
  font-size: 14px;
  letter-spacing: 0.15em;
  color: var(--signal);
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(241, 236, 224, 0.3);
  text-transform: uppercase;
}

@media (max-width: 700px) {
  .art-card { width: 280px; }
}

/* ============================================================
   DICCIONARIO IA
   ============================================================ */
.diccionario {
  padding: 100px 0;
  border-bottom: 1px solid var(--ink);
  position: relative;
  background: var(--paper);
}
.diccionario .running-head {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--ink);
  padding-bottom: 6px;
  margin-bottom: 30px;
  color: var(--ink-mute);
}
.diccionario .running-head b { color: var(--signal); }
.diccionario .head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  margin-bottom: 48px;
  align-items: end;
}
@media (max-width: 900px) { .diccionario .head { grid-template-columns: 1fr; } }
.diccionario h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(44px, 7vw, 108px);
  line-height: 0.88;
  letter-spacing: -0.04em;
  margin: 0;
  text-transform: uppercase;
}
.diccionario h2 .it { font-style: italic; color: var(--signal); }
.diccionario h2 .sub {
  display: block;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 0.36em;
  margin-top: 14px;
  letter-spacing: -0.01em;
  text-transform: none;
  color: var(--ink-mute);
}
.diccionario .invite {
  font-family: var(--font-display);
  font-size: 19px;
  line-height: 1.45;
  font-style: italic;
  border-left: 3px solid var(--signal);
  padding-left: 18px;
}

/* Generador panel */
.dic-gen {
  border: 2px solid var(--ink);
  background: var(--paper);
  padding: 28px 32px;
  margin-bottom: 44px;
  position: relative;
}
.dic-gen .tab {
  position: absolute;
  top: -14px; left: 24px;
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 4px 10px;
}
.dic-gen .ttl {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 28px;
  line-height: 1.05;
  margin: 0 0 6px;
  letter-spacing: -0.015em;
}
.dic-gen .ttl .it { font-style: italic; color: var(--signal); }
.dic-gen p { margin: 0 0 16px; color: var(--ink-mute); font-size: 15px; line-height: 1.4; }
.dic-gen .form {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.dic-gen .form input {
  flex: 1; min-width: 200px;
  background: transparent;
  border: 0;
  border-bottom: 2px solid var(--ink);
  padding: 10px 4px;
  font-family: var(--font-display);
  font-size: 24px;
  outline: none;
  color: var(--ink);
}
.dic-gen .form input:focus { border-bottom-color: var(--signal); }
.dic-gen .form input::placeholder { color: rgba(11,10,8,0.25); font-style: italic; }
.dic-gen .form .btn {
  background: var(--ink);
  color: var(--paper);
  border: 0;
  padding: 0 16px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: crosshair;
}
.dic-gen .form .btn:hover:not(:disabled) { background: var(--signal); }
.dic-gen .form .btn.alt { background: transparent; color: var(--ink); border: 2px solid var(--ink); padding: 8px 14px; }
.dic-gen .form .btn.alt:hover { background: var(--signal); color: var(--paper); border-color: var(--signal); }
.dic-gen .form .btn:disabled { opacity: 0.5; }

/* Entries */
.dic-entries {
  column-count: 2;
  column-gap: 40px;
  column-rule: 1px solid var(--ink);
}
@media (max-width: 900px) { .dic-entries { column-count: 1; } }

.dic-entry {
  break-inside: avoid;
  padding: 18px 0 22px;
  border-bottom: 1px solid var(--ink);
  position: relative;
}
.dic-entry.featured {
  background: var(--paper-2);
  padding: 18px 22px 22px;
  border: 2px solid var(--ink);
  margin-bottom: 18px;
}
.dic-entry .featured-tab {
  position: absolute;
  top: -12px; right: 14px;
  background: var(--signal);
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 3px 8px;
}
.dic-entry .term {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 28px;
  line-height: 1;
  display: inline;
  margin-right: 8px;
  letter-spacing: -0.005em;
}
.dic-entry .pron {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--ink-mute);
  display: inline;
  margin-right: 8px;
  letter-spacing: 0.04em;
}
.dic-entry .tipo {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 14px;
  color: var(--ink-mute);
  display: inline;
  margin-right: 12px;
}
.dic-entry .campo {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--signal);
  background: var(--paper);
  padding: 1px 5px;
  border: 1px solid var(--signal);
  display: inline-block;
  vertical-align: middle;
}
.dic-entry .def {
  font-family: var(--font-display);
  font-size: 17px;
  line-height: 1.45;
  margin: 10px 0 0;
  text-align: justify;
  hyphens: auto;
}
.dic-entry .def b { font-weight: 700; }
.dic-entry .etim {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 14px;
  line-height: 1.4;
  margin: 8px 0 0;
  color: var(--ink-mute);
}
.dic-entry .etim b { color: var(--ink); font-style: normal; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; }
.dic-entry .uso {
  font-family: var(--font-display);
  font-size: 14px;
  line-height: 1.4;
  margin: 6px 0 0;
  padding-left: 14px;
  border-left: 2px solid var(--signal);
}
.dic-entry .uso b { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink); }
.dic-entry .uso .ex { font-style: italic; }
.dic-entry .see {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-top: 8px;
  color: var(--ink-mute);
}
.dic-entry .see b { color: var(--signal); }

/* ============================================================
   HERRAMIENTAS IA — fake startup tools
   ============================================================ */
.herramientas {
  padding: 100px 0;
  border-bottom: 4px solid var(--ink);
  position: relative;
  background: var(--paper-2);
}
.herramientas .head {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 40px;
  margin-bottom: 40px;
  align-items: end;
}
@media (max-width: 900px) { .herramientas .head { grid-template-columns: 1fr; } }
.herramientas h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(44px, 7vw, 108px);
  line-height: 0.88;
  letter-spacing: -0.04em;
  margin: 0;
  text-transform: uppercase;
}
.herramientas h2 .it { font-style: italic; color: var(--signal); }

.herramientas .invite {
  font-family: var(--font-display);
  font-size: 19px;
  line-height: 1.45;
  font-style: italic;
  border-left: 3px solid var(--signal);
  padding-left: 18px;
}

.her-gen {
  border: 2px solid var(--ink);
  background: var(--paper);
  padding: 28px 32px;
  margin-bottom: 44px;
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 28px;
  align-items: center;
}
@media (max-width: 700px) { .her-gen { grid-template-columns: 1fr; } }
.her-gen .tab {
  position: absolute;
  top: -14px; left: 24px;
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 4px 10px;
}
.her-gen h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 26px;
  line-height: 1.05;
  margin: 0 0 12px;
  letter-spacing: -0.015em;
}
.her-gen h3 .it { font-style: italic; color: var(--signal); }
.her-gen input {
  width: 100%;
  background: transparent;
  border: 0;
  border-bottom: 2px solid var(--ink);
  padding: 8px 4px;
  font-family: var(--font-display);
  font-size: 20px;
  outline: none;
  color: var(--ink);
}
.her-gen input::placeholder { color: rgba(11,10,8,0.3); font-style: italic; }
.her-gen input:focus { border-bottom-color: var(--signal); }
.her-gen .btn {
  background: var(--ink);
  color: var(--paper);
  border: 0;
  padding: 14px 22px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  cursor: crosshair;
  white-space: nowrap;
}
.her-gen .btn:hover:not(:disabled) { background: var(--signal); }
.her-gen .btn:disabled { opacity: 0.55; }

/* Tools grid */
.her-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 28px;
}
.her-tool {
  grid-column: span 4;
  border: 1px solid var(--ink);
  background: var(--paper);
  padding: 24px;
  position: relative;
  overflow: hidden;
  transition: transform 0.18s ease;
}
.her-tool:hover { transform: translate(-3px, -3px); box-shadow: 6px 6px 0 var(--ink); }
.her-tool.span-6 { grid-column: span 6; }
@media (max-width: 1100px) { .her-tool { grid-column: span 6; } .her-tool.span-6 { grid-column: span 12; } }
@media (max-width: 700px)  { .her-tool, .her-tool.span-6 { grid-column: span 12; } }

.her-tool .corner {
  position: absolute;
  top: 0; right: 0;
  background: var(--signal);
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  padding: 3px 8px;
  text-transform: uppercase;
}
.her-tool .urlbar {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  background: var(--ink);
  color: var(--paper);
  padding: 5px 10px;
  margin: -24px -24px 18px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.her-tool .urlbar .dots { display: inline-flex; gap: 4px; }
.her-tool .urlbar .dots span { width: 6px; height: 6px; background: var(--paper); border-radius: 50%; opacity: 0.6; }
.her-tool .name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 36px;
  line-height: 1;
  margin: 0 0 6px;
  letter-spacing: -0.025em;
}
.her-tool .name .dot { color: var(--signal); }
.her-tool .tagline {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 17px;
  line-height: 1.3;
  margin: 0 0 18px;
  color: var(--ink);
}
.her-tool .desc {
  font-size: 14px;
  line-height: 1.45;
  margin: 0 0 18px;
  color: var(--ink-mute);
}
.her-tool .strip-meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px 14px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-top: 1px dashed var(--ink);
  border-bottom: 1px dashed var(--ink);
  padding: 10px 0;
  margin-bottom: 14px;
}
.her-tool .strip-meta b { color: var(--signal); font-weight: 500; display: block; }
.her-tool .use-case {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 14px;
  line-height: 1.4;
  margin: 0 0 14px;
}
.her-tool .use-case b { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; font-style: normal; color: var(--signal); display: block; margin-bottom: 4px; }
.her-tool .testimonial {
  background: var(--paper-2);
  padding: 14px 14px 14px 18px;
  border-left: 3px solid var(--signal);
  font-family: var(--font-display);
  font-style: italic;
  font-size: 15px;
  line-height: 1.35;
}
.her-tool .testimonial cite {
  display: block;
  font-style: normal;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-top: 8px;
  color: var(--ink-mute);
}
.her-tool .fake-btns {
  display: flex;
  gap: 8px;
  margin-top: 14px;
}
.her-tool .fake-btns button {
  background: var(--ink);
  color: var(--paper);
  border: 0;
  padding: 8px 12px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  cursor: crosshair;
}
.her-tool .fake-btns button.ghost { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
.her-tool .fake-btns button:hover { background: var(--signal); border-color: var(--signal); color: var(--paper); }

.her-tool .mock-screenshot {
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: 10px;
  padding: 16px;
  line-height: 1.5;
  margin: 0 0 14px;
  position: relative;
  overflow: hidden;
}
.her-tool .mock-screenshot::before {
  content: "";
  position: absolute; inset: 0;
  background: repeating-linear-gradient(0deg, transparent 0, transparent 2px, rgba(255,255,255,0.03) 2px, rgba(255,255,255,0.03) 3px);
  pointer-events: none;
}
.her-tool .mock-screenshot .blink { color: var(--signal); animation: blink 0.9s infinite; }

/* Loading dots */
.dots-anim::after {
  content: "";
  animation: dots 1.4s steps(4, end) infinite;
}
/* ═══════════════════════════════════════════════════════════════
   MULTI-PAGE — Doorways, archives, article template
   ═══════════════════════════════════════════════════════════════ */

/* ─── Generic page-section header ─── */
.page-section {
  padding: 80px 0 60px;
  border-bottom: 1px solid var(--ink);
}
.page-section-head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 40px;
  align-items: end;
  margin-bottom: 56px;
}
@media (max-width: 900px) { .page-section-head { grid-template-columns: 1fr; } }
.page-section-head h1 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(56px, 9vw, 144px);
  line-height: 0.85;
  letter-spacing: -0.045em;
  margin: 14px 0 0;
  text-transform: uppercase;
}
.page-section-lede {
  font-family: var(--font-display);
  font-size: 21px;
  line-height: 1.45;
  font-style: italic;
  border-left: 3px solid var(--signal);
  padding-left: 20px;
  margin: 0;
}
.page-section-foot {
  margin-top: 48px;
  padding-top: 18px;
  border-top: 1px solid var(--ink);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 14px;
}
.page-section-cta {
  background: var(--ink);
  color: var(--paper);
  padding: 10px 18px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
.page-section-cta:hover { background: var(--signal); }

/* ─── HOME · doorways grid ─── */
.doorways {
  padding: 80px 0 100px;
  border-bottom: 4px solid var(--ink);
  position: relative;
}
.doorways-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 32px;
  margin-bottom: 40px;
  flex-wrap: wrap;
}
.doorways-head h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(44px, 7vw, 108px);
  line-height: 0.85;
  letter-spacing: -0.04em;
  margin: 12px 0 0;
  text-transform: uppercase;
}
.doorways-head h2 .it { font-style: italic; color: var(--signal); }

.doorways-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 24px;
}
@media (max-width: 1100px) { .doorways-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 700px)  { .doorways-grid { grid-template-columns: 1fr; } }

.door {
  background: var(--paper);
  border: 1px solid var(--ink);
  padding: 22px;
  text-decoration: none;
  color: var(--ink);
  display: flex;
  flex-direction: column;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  position: relative;
  overflow: hidden;
  grid-column: span 3;
}
.door:hover { transform: translate(-4px, -4px); box-shadow: 8px 8px 0 var(--ink); }
.door-list, .door-stat { grid-column: span 3; }
.door-image { grid-column: span 3; }
.door-filmstrip-card { grid-column: span 6; }
.door-lab { grid-column: span 6; }

/* Specific spans */
.door-list           { grid-column: span 3; }
.door-image          { grid-column: span 3; }
.door-stat           { grid-column: span 2; }
.door-filmstrip      { grid-column: span 4; }
.door-lab            { grid-column: span 6; }
@media (max-width: 1100px) {
  .door-list, .door-image, .door-stat, .door-filmstrip { grid-column: span 2; }
  .door-lab { grid-column: span 4; }
}
@media (max-width: 700px)  { .door, .door-list, .door-image, .door-stat, .door-filmstrip, .door-lab { grid-column: span 1; } }

.door-accent {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}
.door-accent:hover { box-shadow: 8px 8px 0 var(--signal); }

.door-head {
  display: flex;
  justify-content: space-between;
  padding-bottom: 10px;
  border-bottom: 1px solid currentColor;
  margin-bottom: 18px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.door-num { color: var(--signal); font-weight: 700; }
.door-accent .door-num { color: var(--signal); }
.door-cta { font-weight: 500; opacity: 0.85; }

.door-label {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 38px;
  line-height: 0.95;
  margin: 0 0 6px;
  letter-spacing: -0.025em;
}
.door-sub {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 16px;
  line-height: 1.3;
  margin: 0 0 18px;
  opacity: 0.85;
}

.door-list ol, .door-list ul, .door .door-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.door .door-list li {
  padding: 8px 0;
  border-top: 1px dashed currentColor;
  font-size: 14px;
  line-height: 1.35;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.door .door-list-compact li { flex-direction: row; gap: 6px; align-items: baseline; }
.door-list-meta {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--signal);
  opacity: 0.85;
}
.door-list-title {
  font-family: var(--font-display);
  font-size: 15px;
  line-height: 1.3;
}

.door-img {
  margin: -22px -22px 18px;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--ink);
}
.door-img img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1) contrast(1.18); }
.door:hover .door-img img { filter: grayscale(0.3) contrast(1.05); }

.door-stat .door-big-num {
  font-family: var(--font-display);
  font-weight: 700;
  font-style: italic;
  font-size: clamp(96px, 12vw, 160px);
  line-height: 0.85;
  color: var(--signal);
  margin: 0 0 8px;
  letter-spacing: -0.04em;
}
.door-stat p {
  margin: 0;
  font-size: 14px;
  line-height: 1.45;
}

.door-filmstrip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  margin: 0 -22px -22px;
}
.door-film-frame {
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--ink);
  border-top: 1px solid var(--ink);
}
.door-film-frame img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1) contrast(1.2); }

.door-lab .door-lab-row {
  display: flex;
  gap: 18px;
  padding: 12px 0;
  border-top: 1px dashed rgba(241, 236, 224, 0.3);
  font-size: 15px;
  align-items: center;
}
.door-lab .door-lab-row:first-of-type { border-top: 0; padding-top: 0; }
.door-lab-tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  color: var(--signal);
  flex-shrink: 0;
  width: 110px;
}

/* ─── Vigía archive ─── */
.vigia-archive-list {
  list-style: none;
  padding: 0;
  margin: 0;
  border-top: 2px solid var(--ink);
}
.vigia-row {
  display: grid;
  grid-template-columns: 50px 140px 1fr auto;
  gap: 24px;
  padding: 24px 0;
  border-bottom: 1px solid var(--ink);
  align-items: start;
}
@media (max-width: 800px) { .vigia-row { grid-template-columns: 40px 1fr; gap: 14px; } .vigia-row-date { grid-column: 2; } .vigia-row-body { grid-column: 1 / -1; } .vigia-row-go { grid-column: 2; justify-self: start; } }

.vigia-row-num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--signal);
  padding-top: 6px;
}
.vigia-row-date {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding-top: 6px;
  color: var(--ink-mute);
}
.vigia-row-body h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 26px;
  line-height: 1.1;
  margin: 0 0 8px;
  letter-spacing: -0.012em;
}
.vigia-row-body h3 a { color: var(--ink); }
.vigia-row-body h3 a:hover { color: var(--signal); }
.vigia-row-body p {
  margin: 0;
  font-size: 15px;
  line-height: 1.5;
  color: var(--ink-mute);
}
.vigia-row-go {
  background: var(--ink);
  color: var(--paper);
  padding: 8px 12px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  align-self: start;
}
.vigia-row-go:hover { background: var(--signal); }

/* ─── Artículos grid (page) ─── */
.articulos-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
@media (max-width: 1000px) { .articulos-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .articulos-grid { grid-template-columns: 1fr; } }
.art-card-page { width: auto; }

/* ─── Bibliopatía manifest ─── */
.biblio-manifest {
  border-left: 3px solid var(--signal);
  padding: 14px 24px;
  max-width: 760px;
}
.biblio-mani-lede {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 22px;
  line-height: 1.5;
  margin: 0 0 14px;
}
.biblio-mani-cite {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--signal);
  margin: 0;
}
.biblio-mani-cite em { font-family: var(--font-display); text-transform: none; font-style: italic; font-size: 14px; letter-spacing: 0; }

/* ─── Article template ─── */
.article-page { padding: 60px 0 80px; }

.article-breadcrumb {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--ink);
  margin-bottom: 40px;
}
.article-breadcrumb a {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--signal);
}
.article-breadcrumb a:hover { color: var(--ink); text-decoration: underline; }

.article-head {
  max-width: 920px;
  margin-bottom: 40px;
}
.article-kicker {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-bottom: 24px;
  flex-wrap: wrap;
  gap: 12px;
}
.article-head h1 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(44px, 7vw, 96px);
  line-height: 0.92;
  letter-spacing: -0.035em;
  margin: 0 0 22px;
}
.article-head h1 .it { font-style: italic; color: var(--signal); }
.article-deck {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 24px;
  line-height: 1.4;
  margin: 0 0 28px;
  max-width: 760px;
}
.article-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 28px;
  padding: 14px 0;
  border-top: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.article-meta b { color: var(--signal); margin-right: 6px; }

.article-image-block {
  margin-bottom: 56px;
  border: 1px solid var(--ink);
  background: var(--paper);
  padding: 10px;
}
.article-image-block img {
  width: 100%;
  aspect-ratio: 2 / 1;
  object-fit: cover;
  filter: grayscale(1) contrast(1.2);
}
.article-image-cap {
  display: flex;
  justify-content: space-between;
  padding: 10px 4px 0;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.article-image-cap b { color: var(--signal); }

.article-body-grid {
  display: grid;
  grid-template-columns: 2.4fr 1fr;
  gap: 56px;
  align-items: start;
  margin-bottom: 56px;
}
@media (max-width: 900px) { .article-body-grid { grid-template-columns: 1fr; } }

.article-body {
  font-family: var(--font-display);
  font-size: 19px;
  line-height: 1.6;
}
.article-body p { margin: 0 0 18px; text-align: justify; hyphens: auto; }
.article-body p.dropcap::first-letter {
  font-family: var(--font-display);
  font-weight: 700;
  font-style: italic;
  float: left;
  font-size: 4.8em;
  line-height: 0.85;
  padding: 0.1em 0.08em 0 0;
  color: var(--signal);
}
.article-body h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-style: italic;
  font-size: 36px;
  line-height: 1.05;
  margin: 36px 0 18px;
  letter-spacing: -0.015em;
}
.article-body em { color: var(--signal); font-style: italic; }
.article-pull {
  border-top: 3px solid var(--signal);
  border-bottom: 3px solid var(--signal);
  padding: 20px 0;
  margin: 26px 0;
  font-family: var(--font-display);
  font-weight: 600;
  font-style: italic;
  font-size: 28px;
  line-height: 1.25;
}
.article-end {
  font-family: var(--font-mono) !important;
  font-size: 11px !important;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--signal);
  text-align: right !important;
  margin-top: 32px !important;
}

.article-aside {
  display: flex;
  flex-direction: column;
  gap: 18px;
  position: sticky;
  top: 80px;
}
.article-aside-card {
  border: 1px solid var(--ink);
  padding: 18px;
  background: var(--paper);
}
.article-aside-card.dark { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.article-aside-card h4 {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--signal);
  margin: 0 0 12px;
  padding-bottom: 8px;
  border-bottom: 1px dashed currentColor;
}
.article-aside-sub {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 15px;
  line-height: 1.35;
  margin: 0 0 12px;
}
.article-aside-btn {
  background: var(--ink);
  color: var(--paper);
  border: 0;
  padding: 10px 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  cursor: crosshair;
  width: 100%;
}
.article-aside-card.dark .article-aside-btn { background: var(--signal); }
.article-aside-btn:hover { background: var(--signal); }
.article-marginalia {
  font-family: var(--font-hand);
  font-size: 22px;
  line-height: 1.2;
  color: var(--signal);
  margin: 0;
  transform: rotate(-1.5deg);
}
.article-related {
  list-style: none;
  margin: 0;
  padding: 0;
}
.article-related li {
  padding: 8px 0;
  border-top: 1px dashed var(--ink);
}
.article-related li:first-child { border-top: 0; }
.article-related a {
  font-family: var(--font-display);
  font-size: 15px;
  line-height: 1.3;
  color: var(--ink);
}
.article-related a:hover { color: var(--signal); }

.article-waveform {
  display: flex;
  gap: 3px;
  align-items: end;
  height: 36px;
  margin-top: 10px;
}
.article-waveform span {
  width: 4px;
  background: var(--signal);
  animation: wave 1.2s ease-in-out infinite;
}

.article-foot {
  display: flex;
  justify-content: space-between;
  padding-top: 24px;
  border-top: 1px solid var(--ink);
  flex-wrap: wrap;
  gap: 14px;
}
.article-nav-link {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 10px 14px;
  border: 1px solid var(--ink);
}
.article-nav-link:hover { background: var(--ink); color: var(--paper); }
.article-nav-link.signal { background: var(--signal); color: var(--paper); border-color: var(--signal); }
.article-nav-link.signal:hover { background: var(--ink); border-color: var(--ink); }

@keyframes dots {
  0% { content: ""; }
  25% { content: "."; }
  50% { content: ".."; }
  75% { content: "..."; }
}

/* ═══════════════════════════════════════════════════════════════
   APOCALYPSE BAND — Tablero del fin
   ═══════════════════════════════════════════════════════════════ */
.apoc-band {
  background: var(--ink);
  color: var(--paper);
  border-bottom: 2px solid var(--signal);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  overflow: hidden;
  position: relative;
  z-index: 74;
}
.apoc-band::before {
  content: "";
  position: absolute; inset: 0;
  pointer-events: none;
  background: repeating-linear-gradient(0deg, transparent 0, transparent 2px, rgba(255,255,255,0.02) 2px, rgba(255,255,255,0.02) 3px);
}
.apoc-row {
  max-width: var(--max);
  margin: 0 auto;
  padding: 10px var(--pad-x);
  display: flex;
  align-items: center;
  gap: 22px;
  overflow-x: auto;
  scrollbar-width: none;
  position: relative;
}
.apoc-row::-webkit-scrollbar { display: none; }

.apoc-title {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--signal);
  color: var(--paper);
  padding: 4px 10px;
  font-weight: 700;
  letter-spacing: 0.2em;
  flex-shrink: 0;
}
.apoc-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--paper);
  animation: pulse 1.4s ease-in-out infinite;
}

.apoc-item {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  flex-shrink: 0;
  padding-left: 18px;
  border-left: 1px dashed rgba(241, 236, 224, 0.25);
}
.apoc-item:first-of-type { border-left: 0; padding-left: 0; }
.apoc-lbl {
  color: var(--paper);
  opacity: 0.55;
  font-size: 9px;
  letter-spacing: 0.2em;
}
.apoc-time {
  color: var(--paper);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.05em;
  font-variant-numeric: tabular-nums;
}
.apoc-signal .apoc-time { color: var(--signal); }
.apoc-flavor {
  color: var(--paper);
  opacity: 0.4;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 11px;
  letter-spacing: 0;
  text-transform: none;
  font-weight: 400;
}

.apoc-end {
  margin-left: auto;
  color: var(--signal);
  font-family: var(--font-occult);
  font-size: 18px;
  flex-shrink: 0;
}

@media (max-width: 800px) {
  .apoc-flavor { display: none; }
  .apoc-row { gap: 14px; padding: 8px 14px; }
  .apoc-item { padding-left: 12px; }
}

/* ═══════════════════════════════════════════════════════════════
   MANIFIESTO PAGE
   ═══════════════════════════════════════════════════════════════ */
.manifiesto-page { padding: 0 0 80px; background: var(--paper); }

.manifiesto-banner {
  background: var(--paper);
  padding: 32px var(--pad-x) 24px;
  text-align: center;
}
.manifiesto-banner img {
  display: block;
  max-width: 920px;
  width: 100%;
  height: auto;
  margin: 0 auto;
}

.manifiesto-head {
  text-align: center;
  padding: 40px 0 56px;
  border-bottom: 1px solid var(--ink);
  margin-bottom: 56px;
}
.manifiesto-kicker {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--signal);
  margin-bottom: 18px;
}
.manifiesto-head h1 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(72px, 12vw, 192px);
  line-height: 0.85;
  letter-spacing: -0.045em;
  text-transform: uppercase;
  margin: 0 0 18px;
  color: var(--signal);
}
.manifiesto-sub {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 22px;
  line-height: 1.4;
  margin: 0;
  color: var(--ink);
}

.manifiesto-body {
  max-width: 720px;
  margin: 0 auto;
  font-family: var(--font-display);
  font-size: 22px;
  line-height: 1.65;
  color: var(--ink);
}
.manifiesto-body p {
  margin: 0 0 26px;
  text-align: left;
}
.manifiesto-body em {
  font-style: italic;
  color: var(--signal);
}
.manifiesto-pivot {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 600;
  font-size: 30px !important;
  line-height: 1.3 !important;
  color: var(--signal) !important;
  margin: 36px 0 28px !important;
  border-left: 3px solid var(--signal);
  padding-left: 22px;
}
.manifiesto-emphatic {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 32px !important;
  line-height: 1.2 !important;
  text-transform: uppercase;
  letter-spacing: -0.015em;
  margin: 28px 0 !important;
}
.manifiesto-stanza {
  margin: 28px 0 36px;
  padding-left: 22px;
  border-left: 1px solid var(--ink);
}
.manifiesto-stanza p {
  margin: 0 0 8px;
  font-size: 21px;
  line-height: 1.5;
}
.manifiesto-stanza p:last-child { margin-bottom: 0; }

.manifiesto-sign {
  margin-top: 64px;
  padding-top: 32px;
  border-top: 3px solid var(--signal);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 8px;
}
.manifiesto-sign-name {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 600;
  font-size: 44px;
  line-height: 1;
  letter-spacing: -0.02em;
}
.manifiesto-sign-role {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--signal);
}
.manifiesto-sign-coords {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-top: 14px;
}

@media (max-width: 700px) {
  .manifiesto-body { font-size: 19px; }
  .manifiesto-pivot { font-size: 24px !important; }
  .manifiesto-emphatic { font-size: 26px !important; }
  .manifiesto-sign-name { font-size: 34px; }
}

/* ═══════════ Yo medito, tú me editas — spin-off book grid ═══════════ */
.ym-section {
  margin-top: 80px;
  padding-top: 40px;
  border-top: 1px solid var(--ink);
}
.ym-head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  margin-bottom: 32px;
  align-items: end;
}
@media (max-width: 800px) { .ym-head { grid-template-columns: 1fr; } }
.ym-head h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(32px, 5vw, 60px);
  line-height: 0.95;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  margin: 12px 0 0;
}
.ym-it { font-style: italic; color: var(--signal); }
.ym-lede {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 16px;
  line-height: 1.45;
  margin: 0;
  color: var(--ink-mute);
  border-left: 2px solid var(--signal);
  padding-left: 14px;
}
.ym-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
@media (max-width: 1000px) { .ym-grid { grid-template-columns: repeat(2, 1fr); } }
.ym-book {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.ym-cover {
  background: var(--ink);
  aspect-ratio: 3 / 4.7;
  overflow: hidden;
  border: 1px solid var(--ink);
  position: relative;
}
.ym-cover img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.3s ease;
}
.ym-book:hover .ym-cover img { transform: scale(1.03); }
.ym-meta {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.ym-year {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--signal);
}
.ym-book h4 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 18px;
  line-height: 1.15;
  letter-spacing: -0.005em;
  margin: 0;
}
.ym-sub {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 14px;
  line-height: 1.3;
  margin: 0;
  color: var(--ink-mute);
}
.ym-author {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink);
  margin-top: 4px;
}

/* ═══════════ Blog Links Ribbon (third strip) ═══════════ */
.blogribbon {
  background: var(--paper-2);
  border-bottom: 1px solid var(--ink);
  font-family: var(--font-mono);
  font-size: 11px;
  position: relative;
  z-index: 73;
}
.blogribbon .row {
  max-width: var(--max);
  margin: 0 auto;
  padding: 8px var(--pad-x);
  display: flex;
  align-items: flex-start;
  gap: 14px;
  flex-wrap: wrap;
}
.blogribbon-badge {
  background: var(--ink);
  color: var(--paper);
  padding: 6px 12px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-size: 10px;
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  white-space: nowrap;
}
.blogribbon .items {
  display: flex;
  gap: 6px;
  align-items: stretch;
  flex: 1;
  flex-wrap: wrap;
  row-gap: 4px;
}
.blogribbon .item {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  padding: 4px 12px;
  border: 1px solid transparent;
  white-space: nowrap;
  text-decoration: none;
  color: var(--ink);
  transition: all 0.15s;
}
.blogribbon .item:hover {
  background: var(--ink);
  color: var(--paper);
}
.blogribbon-label {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: -0.005em;
  text-transform: none;
}
.blogribbon-sub {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--signal);
  opacity: 0.9;
}
.blogribbon .item:hover .blogribbon-sub { color: var(--paper); opacity: 0.7; }
.blogribbon-arr {
  font-size: 14px;
  color: var(--signal);
}
.blogribbon .sep {
  width: 1px;
  background: rgba(11, 10, 8, 0.15);
  align-self: stretch;
  flex-shrink: 0;
}

@media (max-width: 800px) {
  .blogribbon-sub { display: none; }
  .blogribbon .row { gap: 8px; padding: 6px 14px; }
}

/* Contact link in footer */
.contact-link {
  display: inline-block;
  padding: 8px 14px;
  border: 1px solid var(--signal);
  color: var(--signal) !important;
  font-family: var(--font-mono);
  font-size: 12px !important;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  margin-bottom: 12px;
  transition: all 0.15s;
}
.contact-link:hover {
  background: var(--signal);
  color: var(--paper) !important;
}

/* ═══════════════════════════════════════════════════════════════
   HERO — "Escritorio del editor" composite mosaic
   ═══════════════════════════════════════════════════════════════ */
.desk {
  position: relative;
  width: 100%;
  height: 600px;
  max-width: 560px;
  margin: 0 auto;
}
@media (max-width: 900px) { .desk { height: 680px; max-width: none; } }

.desk-photo {
  position: absolute;
  top: 0; left: 0;
  width: 62%;
  border: 1px solid var(--ink);
  background: var(--paper);
  padding: 10px;
  transform: rotate(-2.2deg);
  box-shadow: 4px 6px 0 var(--ink);
  z-index: 1;
}
.desk-photo img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  filter: grayscale(1) contrast(1.18);
  display: block;
}
.desk-photo-cap, .desk-photo-coord {
  position: absolute;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--signal);
  background: var(--paper);
  padding: 0 6px;
  white-space: nowrap;
}
.desk-photo-cap { top: -8px; left: 16px; }
.desk-photo-coord { bottom: -8px; right: 16px; }

.desk-card {
  position: absolute;
  border: 1px solid var(--ink);
  background: var(--paper);
  display: block;
  text-decoration: none;
  color: var(--ink);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  box-shadow: 3px 4px 0 var(--ink);
}
.desk-card:hover {
  transform: translate(-2px, -2px) rotate(0deg) !important;
  box-shadow: 6px 8px 0 var(--signal);
  z-index: 20 !important;
}

.desk-card-head {
  background: var(--ink);
  color: var(--paper);
  padding: 5px 10px;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  display: flex;
  justify-content: space-between;
  gap: 6px;
}
.desk-card-head.red { background: var(--signal); }
.desk-card-foot {
  border-top: 1px dashed var(--ink);
  padding: 6px 12px;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--signal);
  background: var(--paper-2);
}

/* Dictionary card */
.desk-dic {
  right: 0;
  top: 14%;
  width: 58%;
  transform: rotate(2.6deg);
  z-index: 2;
}
.desk-dic-body { padding: 10px 12px 12px; }
.desk-dic-term {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 21px;
  letter-spacing: -0.005em;
  margin-right: 5px;
}
.desk-dic-pron {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-mute);
  margin-right: 5px;
  letter-spacing: 0.04em;
}
.desk-dic-tipo {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 12px;
  color: var(--ink-mute);
}
.desk-dic-def {
  font-family: var(--font-display);
  font-size: 13.5px;
  line-height: 1.4;
  margin: 8px 0 0;
  text-align: justify;
  hyphens: auto;
}

/* Vigía card */
.desk-vigia {
  left: 4%;
  bottom: 0;
  width: 72%;
  transform: rotate(-1.4deg);
  z-index: 3;
  padding-bottom: 0;
}
.desk-vigia-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 19px;
  line-height: 1.1;
  margin: 12px 14px 6px;
  letter-spacing: -0.012em;
}
.desk-vigia-lead {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 13px;
  line-height: 1.35;
  margin: 0 14px 10px;
  color: var(--ink-mute);
}

/* Stamp */
.desk-stamp {
  position: absolute;
  top: 36%;
  right: -2%;
  background: rgba(255, 255, 255, 0.1);
  color: var(--signal);
  border: 3px solid var(--signal);
  padding: 6px 14px;
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  transform: rotate(8deg);
  z-index: 5;
  opacity: 0.85;
  pointer-events: none;
  white-space: nowrap;
}

.desk-glyph {
  position: absolute;
  bottom: 30%;
  right: 14%;
  font-family: var(--font-occult);
  font-size: 42px;
  color: var(--signal);
  opacity: 0.55;
  transform: rotate(-12deg);
  z-index: 4;
  pointer-events: none;
  width: 60px;
  height: 60px;
}
.desk-glyph svg { display: block; opacity: 0.85; }


/* ═══════ Her-tool fake button reaction toast ═══════ */
.her-reaction {
  margin-top: 12px;
  background: var(--ink);
  color: var(--paper);
  padding: 10px 14px;
  border-left: 3px solid var(--signal);
  font-family: var(--font-display);
  font-size: 15px;
  line-height: 1.4;
  font-style: italic;
  animation: pg-banner-in 0.28s ease;
}
.her-reaction p { margin: 4px 0 0; }
.her-reaction-tag {
  display: block;
  font-family: var(--font-mono);
  font-style: normal;
  font-size: 9px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--signal);
  margin-bottom: 6px;
}
