/*
Theme Name:  Poesías & Letras
Theme URI:   https://poesiasyletras.com
Author:      poesiasyletras.com
Description: Biblioteca digital de poesía — moderna, elegante y emocional. Diseñada para descubrir poemas por autor, emoción, tema y longitud.
Version:     1.0.0
Requires at least: 6.0
Tested up to:      6.6
Requires PHP:      8.0
License:     GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: poesiasyletras
Tags: poetry, literature, blog, custom-menu, custom-logo, featured-images, full-width-template, translation-ready
*/

/* ================================================================
   DESIGN TOKENS
   ================================================================ */
:root {
  --ink:          #0f0e0d;
  --ink-light:    #2e2b27;
  --ink-muted:    #6b6560;
  --ink-soft:     #a89f96;
  --paper:        #faf8f5;
  --paper-warm:   #f2ede6;
  --paper-mid:    #e8e1d8;
  --paper-dark:   #dbd3c8;
  --white:        #ffffff;
  --accent:       #c4622d;
  --accent-dark:  #a84f22;
  --accent-light: #f4e4d8;
  --accent-xlt:   #fdf5f0;
  --sage:         #5a7a5c;
  --sage-light:   #dce8dc;
  --gold:         #b8952a;
  --gold-light:   #f5edcc;
  --dusk:         #7b6fa0;
  --dusk-light:   #eae7f5;
  --mood-amor:        #e8c4c4;
  --mood-tristeza:    #b8c8d8;
  --mood-nostalgia:   #d4c4a8;
  --mood-esperanza:   #b8d4b8;
  --mood-desamor:     #d4b8b8;
  --mood-alegria:     #d4d8b0;
  --mood-reflexion:   #c4c0d8;
  --mood-soledad:     #c8c4bc;
  --mood-melancolia:  #b8c4cc;
  --mood-pasion:      #d8b0a8;
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'DM Sans', system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', monospace;
  --text-xs:   0.6875rem;
  --text-sm:   0.8125rem;
  --text-base: 1rem;
  --text-md:   1.0625rem;
  --text-lg:   1.125rem;
  --text-xl:   1.25rem;
  --text-2xl:  1.5rem;
  --text-3xl:  1.875rem;
  --text-4xl:  2.25rem;
  --text-5xl:  3rem;
  --text-6xl:  3.75rem;
  --s1:  0.25rem;  --s2:  0.5rem;  --s3:  0.75rem;
  --s4:  1rem;     --s5:  1.25rem; --s6:  1.5rem;
  --s8:  2rem;     --s10: 2.5rem;  --s12: 3rem;
  --s16: 4rem;     --s20: 5rem;    --s24: 6rem;
  --max-w:        1200px;
  --max-w-prose:  720px;
  --max-w-tight:  560px;
  --sidebar-w:    300px;
  --nav-h:        68px;
  --border:    1px solid rgba(15,14,13,0.09);
  --border-md: 1px solid rgba(15,14,13,0.16);
  --border-dk: 1px solid rgba(15,14,13,0.28);
  --r-sm:   4px;  --r-md:   8px;  --r-lg:  14px;
  --r-xl:  20px;  --r-2xl: 28px;  --r-full: 9999px;
  --sh-xs: 0 1px 2px rgba(15,14,13,0.06);
  --sh-sm: 0 2px 8px rgba(15,14,13,0.07);
  --sh-md: 0 4px 20px rgba(15,14,13,0.08);
  --sh-lg: 0 10px 40px rgba(15,14,13,0.10);
  --sh-xl: 0 20px 60px rgba(15,14,13,0.12);
  --ease:        150ms ease;
  --ease-md:     250ms ease;
  --ease-slow:   400ms ease;
  --ease-spring: 320ms cubic-bezier(0.34,1.56,0.64,1);
  --z-nav: 500; --z-overlay: 100; --z-modal: 1000;
}

/* ================================================================
   RESET
   ================================================================ */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.7;
  color: var(--ink);
  background-color: var(--paper);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img,video,svg { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; font-family: inherit; border: none; background: none; }
ul,ol { list-style: none; }
input,textarea,select { font-family: inherit; font-size: inherit; }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; border-radius: var(--r-sm); }
::selection { background-color: var(--accent-light); color: var(--accent-dark); }

/* ================================================================
   TIPOGRAFÍA
   ================================================================ */
h1,h2,h3,h4,h5,h6 {
  font-family: var(--font-display);
  line-height: 1.12;
  letter-spacing: -0.025em;
  color: var(--ink);
  font-weight: 600;
}
h1 { font-size: var(--text-5xl); font-weight: 700; }
h2 { font-size: var(--text-4xl); }
h3 { font-size: var(--text-3xl); }
h4 { font-size: var(--text-2xl); font-weight: 500; }
h5 { font-size: var(--text-xl);  font-weight: 500; }
h6 { font-size: var(--text-lg);  font-weight: 500; }
p  { margin-bottom: var(--s4); }
p:last-child { margin-bottom: 0; }
strong { font-weight: 600; }

blockquote {
  position: relative;
  border-left: 3px solid var(--accent);
  padding: var(--s5) var(--s6) var(--s5) var(--s8);
  margin: var(--s8) 0;
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-style: italic;
  line-height: 1.7;
  color: var(--ink-light);
  background: var(--paper-warm);
  border-radius: 0 var(--r-md) var(--r-md) 0;
}
blockquote::before {
  content: '\201C';
  position: absolute;
  top: 0; left: var(--s3);
  font-size: 4rem; line-height: 1;
  color: var(--accent); opacity: 0.25; font-style: normal;
}
blockquote cite {
  display: block; margin-top: var(--s4);
  font-family: var(--font-body); font-size: var(--text-sm);
  font-style: normal; font-weight: 600; color: var(--ink-muted);
  letter-spacing: 0.04em; text-transform: uppercase;
}
.poem-verse { font-family: var(--font-display); font-size: var(--text-xl); font-style: italic; line-height: 2; color: var(--ink-light); white-space: pre-line; }
.poem-verse .stanza { display: block; margin-bottom: var(--s6); }

/* ================================================================
   LAYOUT
   ================================================================ */
.container { width: 100%; max-width: var(--max-w); margin-inline: auto; padding-inline: var(--s6); }
.container--narrow { max-width: var(--max-w-prose); }
.container--tight  { max-width: var(--max-w-tight); }

/* ================================================================
   HEADER & NAV
   ================================================================ */
.site-header {
  position: sticky; top: 0; z-index: var(--z-nav);
  height: var(--nav-h);
  background: rgba(250,248,245,0.94);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-bottom: var(--border);
  transition: box-shadow var(--ease-md);
}
.site-header.is-scrolled { box-shadow: var(--sh-md); }
.nav-inner { display: flex; align-items: center; height: 100%; gap: var(--s6); }

.site-logo { flex-shrink: 0; display: flex; align-items: center; gap: var(--s3); }
.site-logo__text { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 700; letter-spacing: -0.035em; color: var(--ink); white-space: nowrap; }
.site-logo__text .logo-amp { color: var(--accent); font-style: italic; font-weight: 400; }
.site-logo__img { height: 38px; width: auto; }

.primary-nav { display: flex; align-items: center; gap: var(--s1); flex: 1; }
.primary-nav > ul { display: flex; align-items: center; gap: var(--s1); list-style: none; }
.primary-nav a {
  display: inline-flex; align-items: center; gap: var(--s2);
  padding: var(--s2) var(--s3); font-size: var(--text-sm); font-weight: 500;
  color: var(--ink-muted); border-radius: var(--r-md);
  transition: color var(--ease), background var(--ease); white-space: nowrap;
}
.primary-nav a:hover { color: var(--ink); background: var(--paper-warm); }
.primary-nav .current-menu-item > a { color: var(--accent); background: var(--accent-light); }
.primary-nav .menu-item-has-children { position: relative; }
.primary-nav .sub-menu {
  position: absolute; top: calc(100% + var(--s2)); left: 0;
  min-width: 220px; background: var(--white);
  border: var(--border-md); border-radius: var(--r-lg);
  box-shadow: var(--sh-lg); padding: var(--s2); list-style: none;
  opacity: 0; visibility: hidden; pointer-events: none;
  transform: translateY(-6px);
  transition: opacity var(--ease-md), transform var(--ease-md), visibility var(--ease-md);
  z-index: var(--z-overlay);
}
.primary-nav .menu-item-has-children:hover .sub-menu,
.primary-nav .menu-item-has-children:focus-within .sub-menu { opacity: 1; visibility: visible; pointer-events: auto; transform: translateY(0); }
.primary-nav .sub-menu a { display: flex; align-items: center; gap: var(--s2); padding: var(--s2) var(--s3); color: var(--ink-light); font-size: var(--text-sm); border-radius: var(--r-md); }
.primary-nav .sub-menu a:hover { background: var(--paper-warm); color: var(--ink); }

.nav-actions { display: flex; align-items: center; gap: var(--s3); margin-left: auto; flex-shrink: 0; }
.nav-search-btn {
  display: inline-flex; align-items: center; gap: var(--s2);
  padding: var(--s2) var(--s4); font-size: var(--text-sm); color: var(--ink-muted);
  background: var(--paper-warm); border: var(--border); border-radius: var(--r-full);
  cursor: pointer; transition: all var(--ease);
}
.nav-search-btn:hover { background: var(--paper-mid); color: var(--ink); }
.nav-kbd { display: inline-flex; align-items: center; padding: 1px 6px; font-size: 10px; font-family: var(--font-mono); background: var(--paper-mid); border-radius: var(--r-sm); color: var(--ink-soft); border: var(--border); }

.nav-toggle { display: none; flex-direction: column; justify-content: center; gap: 5px; width: 36px; height: 36px; padding: var(--s2); border-radius: var(--r-md); cursor: pointer; transition: background var(--ease); }
.nav-toggle:hover { background: var(--paper-warm); }
.nav-toggle__line { display: block; width: 100%; height: 1.5px; background: var(--ink); border-radius: 2px; transition: transform var(--ease-md), opacity var(--ease-md); transform-origin: center; }
.nav-toggle.is-open .nav-toggle__line:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-toggle.is-open .nav-toggle__line:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-toggle.is-open .nav-toggle__line:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

.mobile-nav { display: none; position: fixed; top: var(--nav-h); left: 0; right: 0; background: var(--white); border-bottom: var(--border-md); box-shadow: var(--sh-lg); padding: var(--s4); z-index: var(--z-overlay); max-height: calc(100vh - var(--nav-h)); overflow-y: auto; }
.mobile-nav.is-open { display: block; }
.mobile-nav ul { list-style: none; display: flex; flex-direction: column; gap: var(--s1); }
.mobile-nav a { display: flex; align-items: center; padding: var(--s3) var(--s4); font-size: var(--text-base); font-weight: 500; color: var(--ink-light); border-radius: var(--r-md); transition: background var(--ease); }
.mobile-nav a:hover { background: var(--paper-warm); color: var(--ink); }
.mobile-nav .sub-menu { padding-left: var(--s6); margin-top: var(--s1); }
.mobile-nav .sub-menu a { font-size: var(--text-sm); color: var(--ink-muted); }

/* ================================================================
   SEARCH OVERLAY
   ================================================================ */
.search-overlay {
  position: fixed; inset: 0; z-index: var(--z-modal);
  background: rgba(15,14,13,0.55); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 12vh; padding-inline: var(--s4);
  opacity: 0; visibility: hidden;
  transition: opacity var(--ease-md), visibility var(--ease-md);
}
.search-overlay.is-open { opacity: 1; visibility: visible; }
.search-overlay__box {
  width: 100%; max-width: 640px; background: var(--white); border-radius: var(--r-2xl);
  overflow: hidden; box-shadow: var(--sh-xl);
  transform: translateY(-16px) scale(0.98);
  transition: transform var(--ease-md);
}
.search-overlay.is-open .search-overlay__box { transform: translateY(0) scale(1); }
.search-overlay__top { display: flex; align-items: center; gap: var(--s4); padding: var(--s5) var(--s6); border-bottom: var(--border); }
.search-overlay__icon { color: var(--ink-soft); flex-shrink: 0; }
.search-overlay__input { flex: 1; font-family: var(--font-display); font-size: var(--text-xl); font-style: italic; color: var(--ink); border: none; outline: none; background: transparent; }
.search-overlay__input::placeholder { color: var(--ink-soft); }
.search-overlay__close { width: 32px; height: 32px; border-radius: var(--r-full); background: var(--paper-warm); color: var(--ink-muted); font-size: var(--text-base); display: flex; align-items: center; justify-content: center; flex-shrink: 0; cursor: pointer; transition: background var(--ease); }
.search-overlay__close:hover { background: var(--paper-mid); }
.search-overlay__body { padding: var(--s5) var(--s6); }
.search-overlay__label { display: block; font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: var(--s3); }
.search-overlay__tags { display: flex; flex-wrap: wrap; gap: var(--s2); }
.search-result-item { display: flex; align-items: center; gap: var(--s3); padding: var(--s3) var(--s4); border-radius: var(--r-md); cursor: pointer; transition: background var(--ease); }
.search-result-item:hover { background: var(--paper-warm); }
.search-result-item__icon { width: 32px; height: 32px; border-radius: var(--r-sm); background: var(--paper-warm); display: flex; align-items: center; justify-content: center; font-size: 14px; flex-shrink: 0; }
.search-result-item__title { font-size: var(--text-sm); font-weight: 500; color: var(--ink); }
.search-result-item__meta  { font-size: var(--text-xs); color: var(--ink-muted); margin-top: 1px; }
.search-result-item__type  { font-size: var(--text-xs); padding: 2px 8px; border-radius: var(--r-full); background: var(--paper-mid); color: var(--ink-muted); flex-shrink: 0; }

/* ================================================================
   BOTONES
   ================================================================ */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--s2); padding: var(--s3) var(--s6);
  font-family: var(--font-body); font-size: var(--text-sm); font-weight: 600;
  line-height: 1; letter-spacing: 0.01em; border-radius: var(--r-full);
  border: none; cursor: pointer; text-decoration: none; white-space: nowrap;
  transition: all var(--ease-md);
}
.btn--primary { background: var(--ink); color: var(--white); }
.btn--primary:hover { background: var(--ink-light); transform: translateY(-1px); box-shadow: 0 6px 20px rgba(15,14,13,0.22); }
.btn--accent  { background: var(--accent); color: var(--white); }
.btn--accent:hover { background: var(--accent-dark); transform: translateY(-1px); box-shadow: 0 6px 20px rgba(196,98,45,0.32); }
.btn--outline { background: transparent; color: var(--ink); border: var(--border-md); }
.btn--outline:hover { background: var(--paper-warm); border-color: var(--ink-muted); }
.btn--ghost   { background: transparent; color: var(--ink-muted); padding-inline: var(--s3); }
.btn--ghost:hover { background: var(--paper-warm); color: var(--ink); }
.btn--paper   { background: var(--paper-warm); color: var(--ink); border: var(--border); }
.btn--paper:hover { background: var(--paper-mid); }
.btn--sm  { padding: var(--s2) var(--s4); font-size: var(--text-xs); }
.btn--lg  { padding: var(--s4) var(--s8); font-size: var(--text-base); }
.btn--xl  { padding: var(--s5) var(--s10); font-size: var(--text-lg); }
.btn:disabled { opacity: 0.45; pointer-events: none; }
.btn--icon { width: 40px; height: 40px; padding: 0; border-radius: var(--r-full); }

/* ================================================================
   TAGS / BADGES
   ================================================================ */
.tag {
  display: inline-flex; align-items: center; gap: var(--s1);
  padding: 3px var(--s3); font-size: var(--text-xs); font-weight: 500;
  border-radius: var(--r-full); background: var(--paper-warm);
  color: var(--ink-muted); border: var(--border); white-space: nowrap;
  text-decoration: none; transition: all var(--ease); cursor: default;
}
a.tag:hover,button.tag:hover { background: var(--paper-mid); color: var(--ink); border-color: var(--paper-dark); cursor: pointer; }
.tag--accent { background: var(--accent-light);  color: var(--accent-dark); border-color: transparent; }
.tag--sage   { background: var(--sage-light);     color: var(--sage);       border-color: transparent; }
.tag--gold   { background: var(--gold-light);     color: var(--gold);       border-color: transparent; }
.tag--dusk   { background: var(--dusk-light);     color: var(--dusk);       border-color: transparent; }
.tag--amor      { background: #f5e5e5; color: #8b3a3a; border-color: transparent; }
.tag--tristeza  { background: #dde8f2; color: #2c4a6e; border-color: transparent; }
.tag--nostalgia { background: #f0e8d4; color: #7a5c24; border-color: transparent; }
.tag--esperanza { background: #daeada; color: #2a5c2a; border-color: transparent; }
.tag--desamor   { background: #f2dfdf; color: #7a3030; border-color: transparent; }
.tag--alegria   { background: #eaedcc; color: #4a5a1a; border-color: transparent; }
.tag--reflexion { background: #eae8f5; color: #4a4070; border-color: transparent; }
.tag--soledad   { background: #e8e4de; color: #5a5040; border-color: transparent; }
.tag--melancolia{ background: #dce6ed; color: #304858; border-color: transparent; }
.tag--pasion    { background: #f2deda; color: #803030; border-color: transparent; }

.badge { display: inline-flex; align-items: center; gap: var(--s2); font-size: var(--text-xs); font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--accent); }
.badge::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--accent); flex-shrink: 0; }

/* ================================================================
   SECTION HEADERS
   ================================================================ */
.section-header { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--s4); margin-bottom: var(--s8); }
.section-eyebrow { display: block; font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); margin-bottom: var(--s2); }
.section-title { font-family: var(--font-display); font-size: var(--text-3xl); font-weight: 600; letter-spacing: -0.03em; line-height: 1.12; color: var(--ink); }
.section-subtitle { font-size: var(--text-base); color: var(--ink-muted); line-height: 1.65; margin-top: var(--s2); max-width: 480px; }
.section-link { display: inline-flex; align-items: center; gap: var(--s2); font-size: var(--text-sm); font-weight: 500; color: var(--ink-muted); white-space: nowrap; flex-shrink: 0; padding-bottom: 1px; border-bottom: 1px solid transparent; transition: all var(--ease); }
.section-link:hover { color: var(--accent); border-bottom-color: var(--accent); gap: var(--s3); }

/* ================================================================
   HERO
   ================================================================ */
.hero { padding: var(--s20) 0 var(--s16); position: relative; overflow: hidden; }
.hero__bg-word { position: absolute; top: -10px; right: -20px; font-family: var(--font-display); font-size: clamp(120px,18vw,260px); font-weight: 700; line-height: 1; color: var(--paper-mid); opacity: 0.55; pointer-events: none; user-select: none; z-index: 0; letter-spacing: -0.05em; }
.hero__inner { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 460px; gap: var(--s20); align-items: center; }
.hero__eyebrow { display: inline-flex; align-items: center; gap: var(--s2); font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); background: var(--accent-light); padding: 5px var(--s3) 5px var(--s2); border-radius: var(--r-full); margin-bottom: var(--s5); }
.hero__eyebrow::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--accent); flex-shrink: 0; animation: pulse-dot 2s ease-in-out infinite; }
@keyframes pulse-dot { 0%,100% { opacity:1;transform:scale(1); } 50% { opacity:0.5;transform:scale(0.75); } }
.hero__title { font-family: var(--font-display); font-size: clamp(2.4rem,4.5vw,4.25rem); font-weight: 700; letter-spacing: -0.045em; line-height: 1.05; color: var(--ink); margin-bottom: var(--s6); }
.hero__title em { font-style: italic; font-weight: 400; color: var(--accent); }
.hero__desc { font-size: var(--text-lg); color: var(--ink-muted); line-height: 1.72; max-width: 420px; margin-bottom: var(--s8); }
.hero__actions { display: flex; align-items: center; flex-wrap: wrap; gap: var(--s4); margin-bottom: var(--s10); }
.hero__stats { display: flex; gap: var(--s8); padding-top: var(--s8); border-top: var(--border); }
.hero__stat-num { font-family: var(--font-display); font-size: var(--text-3xl); font-weight: 600; letter-spacing: -0.04em; line-height: 1; color: var(--ink); margin-bottom: 3px; }
.hero__stat-label { font-size: var(--text-xs); font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-soft); }
.hero__poem-card { background: var(--white); border: var(--border-md); border-radius: var(--r-2xl); padding: var(--s8); box-shadow: var(--sh-lg); position: relative; overflow: hidden; }
.hero__poem-card::before { content: '\201C'; position: absolute; top: var(--s3); left: var(--s5); font-family: var(--font-display); font-size: 5.5rem; line-height: 1; color: var(--accent); opacity: 0.18; pointer-events: none; }
.hero__poem-card__label { font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); margin-bottom: var(--s5); display: block; }
.hero__poem-text { font-family: var(--font-display); font-size: var(--text-lg); font-style: italic; line-height: 1.92; color: var(--ink-light); padding-top: var(--s3); }
.hero__poem-text p { margin-bottom: var(--s2); }
.hero__poem-footer { margin-top: var(--s6); padding-top: var(--s4); border-top: var(--border); display: flex; align-items: center; justify-content: space-between; gap: var(--s4); }
.hero__poem-footer__author { font-size: var(--text-sm); font-weight: 600; color: var(--ink); margin-bottom: 2px; }
.hero__poem-footer__title  { font-size: var(--text-xs); color: var(--ink-muted); }
.hero__poem-link { display: inline-flex; align-items: center; gap: var(--s2); font-size: var(--text-sm); font-weight: 600; color: var(--accent); transition: gap var(--ease); flex-shrink: 0; }
.hero__poem-link:hover { gap: var(--s3); }
.hero__poem-tags { display: flex; flex-wrap: wrap; gap: var(--s2); margin-top: var(--s4); }

/* ================================================================
   SEARCH BAR — HOMEPAGE
   ================================================================ */
.search-section { padding: var(--s12) 0; background: var(--paper-warm); border-top: var(--border); border-bottom: var(--border); }
.search-section__label { display: block; text-align: center; font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: var(--s5); }
.search-bar { display: flex; align-items: center; gap: var(--s3); background: var(--white); border: var(--border-md); border-radius: var(--r-full); padding: var(--s3) var(--s3) var(--s3) var(--s5); max-width: 680px; margin: 0 auto; box-shadow: var(--sh-sm); transition: box-shadow var(--ease-md), border-color var(--ease-md); }
.search-bar:focus-within { box-shadow: var(--sh-md), 0 0 0 3px var(--accent-light); border-color: rgba(196,98,45,0.3); }
.search-bar__icon { color: var(--ink-soft); flex-shrink: 0; }
.search-bar__input { flex: 1; font-family: var(--font-display); font-size: var(--text-lg); font-style: italic; color: var(--ink); border: none; outline: none; background: transparent; min-width: 0; }
.search-bar__input::placeholder { color: var(--ink-soft); }
.search-bar__btn { background: var(--accent); color: var(--white); border: none; border-radius: var(--r-full); padding: var(--s3) var(--s6); font-size: var(--text-sm); font-weight: 600; cursor: pointer; flex-shrink: 0; transition: background var(--ease); }
.search-bar__btn:hover { background: var(--accent-dark); }
.search-popular { display: flex; flex-wrap: wrap; gap: var(--s2); justify-content: center; max-width: 620px; margin: var(--s4) auto 0; }

/* ================================================================
   MOOD CARDS
   ================================================================ */
.moods-section { padding: var(--s16) 0; background: var(--paper-warm); border-top: var(--border); border-bottom: var(--border); }
.moods-grid { display: grid; grid-template-columns: repeat(5,1fr); gap: var(--s3); }
.mood-card { display: block; text-decoration: none; position: relative; padding: var(--s6) var(--s4); background: var(--white); border: var(--border); border-radius: var(--r-lg); text-align: center; overflow: hidden; cursor: pointer; transition: all var(--ease-md); }
.mood-card::before { content: ''; position: absolute; inset: 0; background: var(--mood-bg,var(--paper-warm)); opacity: 0; transition: opacity var(--ease-md); }
.mood-card:hover { transform: translateY(-4px); box-shadow: var(--sh-md); border-color: transparent; }
.mood-card:hover::before { opacity: 1; }
.mood-card__icon { position: relative; z-index: 1; width: 52px; height: 52px; border-radius: var(--r-full); background: var(--mood-bg,var(--paper-warm)); display: flex; align-items: center; justify-content: center; font-size: 24px; margin: 0 auto var(--s3); transition: transform var(--ease-spring); }
.mood-card:hover .mood-card__icon { transform: scale(1.18) rotate(-5deg); }
.mood-card__name { position: relative; z-index: 1; font-family: var(--font-display); font-size: var(--text-base); font-weight: 500; color: var(--ink); display: block; margin-bottom: 3px; }
.mood-card__count { position: relative; z-index: 1; font-size: var(--text-xs); color: var(--ink-soft); display: block; }

.emotional-selector { padding: var(--s16) 0; background: var(--ink); text-align: center; position: relative; overflow: hidden; }
.emotional-selector::before { content: '?'; position: absolute; top: -60px; right: -20px; font-family: var(--font-display); font-size: 300px; font-weight: 700; color: var(--white); opacity: 0.025; line-height: 1; pointer-events: none; }
.emotional-selector__title { font-family: var(--font-display); font-size: clamp(1.8rem,3.5vw,3rem); font-weight: 400; font-style: italic; letter-spacing: -0.04em; color: var(--paper); margin-bottom: var(--s3); }
.emotional-selector__sub { font-size: var(--text-base); color: var(--ink-soft); margin-bottom: var(--s8); }
.mood-pills { display: flex; flex-wrap: wrap; gap: var(--s3); justify-content: center; max-width: 680px; margin: 0 auto; }
.mood-pill { display: inline-flex; align-items: center; gap: var(--s2); padding: var(--s3) var(--s6); background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1); border-radius: var(--r-full); font-size: var(--text-sm); font-weight: 500; color: rgba(250,248,245,0.65); cursor: pointer; transition: all var(--ease-md); }
.mood-pill:hover,.mood-pill.is-active { background: var(--accent); border-color: var(--accent); color: var(--white); transform: scale(1.06); }

/* ================================================================
   POEM CARDS
   ================================================================ */
.poems-grid { display: grid; gap: var(--s5); }
.poems-grid--1 { grid-template-columns: 1fr; }
.poems-grid--2 { grid-template-columns: repeat(2,1fr); }
.poems-grid--3 { grid-template-columns: repeat(3,1fr); }
.poems-grid--4 { grid-template-columns: repeat(4,1fr); }

.poem-card { display: flex; flex-direction: column; gap: var(--s4); background: var(--white); border: var(--border); border-radius: var(--r-lg); padding: var(--s6); position: relative; overflow: hidden; transition: box-shadow var(--ease-md), transform var(--ease-md), border-color var(--ease-md); }
.poem-card::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg,var(--accent),var(--gold)); transform: scaleX(0); transform-origin: left center; transition: transform var(--ease-md); }
.poem-card:hover { box-shadow: var(--sh-lg); transform: translateY(-3px); border-color: var(--paper-mid); }
.poem-card:hover::after { transform: scaleX(1); }
.poem-card__rank { font-family: var(--font-display); font-size: var(--text-4xl); font-weight: 700; color: var(--paper-mid); line-height: 1; letter-spacing: -0.05em; position: absolute; top: var(--s4); right: var(--s5); }
.poem-card__header { display: flex; flex-direction: column; gap: 4px; }
.poem-card__title { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 600; letter-spacing: -0.025em; line-height: 1.22; color: var(--ink); }
.poem-card__title a { color: inherit; }
.poem-card__title a:hover { color: var(--accent); }
.poem-card__author { font-size: var(--text-xs); font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-soft); }
.poem-card__author a:hover { color: var(--accent); }
.poem-card__excerpt { flex: 1; font-family: var(--font-display); font-size: var(--text-base); font-style: italic; color: var(--ink-muted); line-height: 1.85; padding-left: var(--s4); border-left: 2px solid var(--accent-light); }
.poem-card__footer { display: flex; align-items: center; justify-content: space-between; gap: var(--s3); padding-top: var(--s3); border-top: var(--border); }
.poem-card__tags { display: flex; flex-wrap: wrap; gap: var(--s2); }
.poem-card__meta { display: flex; align-items: center; gap: var(--s1); font-size: var(--text-xs); color: var(--ink-soft); flex-shrink: 0; }

.poem-card--featured { background: var(--ink); border-color: var(--ink-light); }
.poem-card--featured::after { display: none; }
.poem-card--featured .poem-card__title { color: var(--paper); }
.poem-card--featured .poem-card__title a:hover { color: var(--accent-light); }
.poem-card--featured .poem-card__author { color: var(--ink-soft); }
.poem-card--featured .poem-card__excerpt { color: rgba(250,248,245,0.65); border-left-color: var(--accent); }
.poem-card--featured .poem-card__footer { border-top-color: rgba(255,255,255,0.08); }
.poem-card--featured:hover { border-color: var(--ink-muted); }

.poem-card--horizontal { flex-direction: row; align-items: center; padding: var(--s5) var(--s6); gap: var(--s5); }
.poem-card--horizontal .poem-card__rank { position: static; flex-shrink: 0; width: 52px; text-align: center; }
.poem-card--horizontal .poem-card__body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: var(--s2); }

.poem-card--visual { padding: 0; overflow: hidden; }
.poem-card--visual .poem-card__image { aspect-ratio: 4/3; overflow: hidden; background: var(--paper-warm); }
.poem-card--visual .poem-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--ease-slow); }
.poem-card--visual:hover .poem-card__image img { transform: scale(1.04); }
.poem-card--visual .poem-card__body { padding: var(--s5) var(--s6); display: flex; flex-direction: column; gap: var(--s3); }

/* ================================================================
   AUTHOR CARDS
   ================================================================ */
.authors-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: var(--s5); }
.author-card { display: block; text-decoration: none; background: var(--white); border: var(--border); border-radius: var(--r-lg); padding: var(--s6) var(--s5); text-align: center; transition: all var(--ease-md); }
.author-card:hover { box-shadow: var(--sh-md); transform: translateY(-3px); border-color: var(--paper-mid); }
.author-card__avatar { width: 76px; height: 76px; border-radius: var(--r-full); margin: 0 auto var(--s4); overflow: hidden; background: var(--paper-warm); box-shadow: 0 0 0 3px var(--white),0 0 0 4px var(--paper-mid); }
.author-card__avatar img { width: 100%; height: 100%; object-fit: cover; }
.author-card__initial { width: 76px; height: 76px; border-radius: var(--r-full); margin: 0 auto var(--s4); background: var(--ink); color: var(--paper); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 600; letter-spacing: -0.04em; }
.author-card__name { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 600; color: var(--ink); margin-bottom: 3px; letter-spacing: -0.02em; }
.author-card__dates { font-size: var(--text-xs); color: var(--ink-soft); margin-bottom: var(--s3); }
.author-card__movement { display: inline-block; font-size: var(--text-xs); padding: 3px var(--s3); background: var(--paper-warm); border-radius: var(--r-full); color: var(--ink-muted); border: var(--border); margin-bottom: var(--s3); }
.author-card__count { font-size: var(--text-sm); color: var(--ink-muted); }
.author-card__count strong { color: var(--ink); font-weight: 600; }

/* ================================================================
   COLLECTIONS
   ================================================================ */
.collections-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--s5); }
.collection-card { display: block; text-decoration: none; position: relative; overflow: hidden; padding: var(--s8) var(--s7); border: var(--border); border-radius: var(--r-lg); transition: all var(--ease-md); }
.collection-card:hover { transform: translateY(-4px); box-shadow: var(--sh-lg); border-color: transparent; }
.collection-card__big-num { position: absolute; top: var(--s3); right: var(--s5); font-family: var(--font-display); font-size: 5.5rem; font-weight: 700; line-height: 1; color: var(--ink); opacity: 0.08; letter-spacing: -0.05em; pointer-events: none; user-select: none; }
.collection-card__icon { width: 44px; height: 44px; border-radius: var(--r-md); background: rgba(255,255,255,0.55); display: flex; align-items: center; justify-content: center; font-size: 20px; margin-bottom: var(--s4); border: var(--border); }
.collection-card__title { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 600; line-height: 1.25; color: var(--ink); margin-bottom: var(--s2); letter-spacing: -0.02em; }
.collection-card__desc  { font-size: var(--text-sm); color: var(--ink-muted); line-height: 1.65; }
.collection-card__footer{ display: flex; align-items: center; gap: var(--s2); margin-top: var(--s5); font-size: var(--text-xs); font-weight: 600; color: var(--ink-muted); }
.collection-card--amor      { background: #f9eded; }
.collection-card--tristeza  { background: #edf3f9; }
.collection-card--clasico   { background: #f5f2e8; }
.collection-card--cortos    { background: #f2f5e8; }
.collection-card--latam     { background: #eeeaf5; }
.collection-card--tiempo    { background: #f5ede8; }
.collection-card--naturaleza{ background: #eaf0e8; }

/* ================================================================
   SINGLE POEM PAGE
   ================================================================ */
.poem-single { padding: var(--s16) 0; }
.poem-single__layout { display: grid; grid-template-columns: 1fr var(--sidebar-w); gap: var(--s12); align-items: start; }
.poem-single__image { width: 100%; aspect-ratio: 16/6; overflow: hidden; border-radius: var(--r-lg); background: var(--paper-warm); margin-bottom: var(--s8); }
.poem-single__image img { width: 100%; height: 100%; object-fit: cover; }
.poem-single__eyebrow { display: flex; align-items: center; flex-wrap: wrap; gap: var(--s2); margin-bottom: var(--s5); }
.poem-single__title { font-family: var(--font-display); font-size: clamp(2rem,4vw,3.5rem); font-weight: 700; letter-spacing: -0.045em; line-height: 1.06; color: var(--ink); margin-bottom: var(--s5); }
.poem-single__author-row { display: flex; align-items: center; gap: var(--s3); margin-bottom: var(--s6); }
.poem-single__author-avatar { width: 40px; height: 40px; border-radius: var(--r-full); overflow: hidden; background: var(--paper-warm); flex-shrink: 0; border: 2px solid var(--white); box-shadow: 0 0 0 1px var(--paper-mid); }
.poem-single__author-avatar img { width: 100%; height: 100%; object-fit: cover; }
.poem-single__author-link { font-size: var(--text-base); font-weight: 600; color: var(--ink); transition: color var(--ease); }
.poem-single__author-link:hover { color: var(--accent); }
.poem-single__year { font-size: var(--text-sm); color: var(--ink-muted); }
.poem-single__body { font-family: var(--font-display); font-size: var(--text-xl); line-height: 2; color: var(--ink-light); padding: var(--s10) 0; border-top: var(--border); border-bottom: var(--border); margin-bottom: var(--s8); }
.poem-single__body .stanza { display: block; margin-bottom: var(--s8); }
.poem-single__body .stanza:last-child { margin-bottom: 0; }
.poem-single__actions { display: flex; align-items: center; gap: var(--s3); flex-wrap: wrap; margin-bottom: var(--s8); }
.poem-sidebar { position: sticky; top: calc(var(--nav-h) + var(--s6)); display: flex; flex-direction: column; gap: var(--s5); }
.poem-meta-card { background: var(--white); border: var(--border); border-radius: var(--r-lg); overflow: hidden; }
.poem-meta-card__header { padding: var(--s4) var(--s5); background: var(--paper-warm); border-bottom: var(--border); font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-muted); }
.poem-meta-card__body { padding: var(--s2) var(--s1); }
.poem-meta-item { display: flex; align-items: center; justify-content: space-between; gap: var(--s3); padding: var(--s3) var(--s4); border-bottom: var(--border); }
.poem-meta-item:last-child { border-bottom: none; }
.poem-meta-item__label { font-size: var(--text-xs); font-weight: 600; letter-spacing: 0.07em; text-transform: uppercase; color: var(--ink-soft); flex-shrink: 0; }
.poem-meta-item__value { font-size: var(--text-sm); color: var(--ink); text-align: right; }
.related-section { padding: var(--s16) 0; background: var(--paper-warm); border-top: var(--border); }

/* ================================================================
   AUTHOR PAGE
   ================================================================ */
.author-single { padding: var(--s16) 0; }
.author-hero { display: grid; grid-template-columns: 220px 1fr; gap: var(--s10); align-items: start; padding-bottom: var(--s12); border-bottom: var(--border); margin-bottom: var(--s12); }
.author-hero__photo { width: 220px; height: 220px; border-radius: var(--r-xl); overflow: hidden; background: var(--paper-warm); box-shadow: var(--sh-md); flex-shrink: 0; }
.author-hero__photo img { width: 100%; height: 100%; object-fit: cover; }
.author-hero__initial { width: 220px; height: 220px; border-radius: var(--r-xl); background: var(--ink); color: var(--paper); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 6rem; font-weight: 600; letter-spacing: -0.05em; flex-shrink: 0; }
.author-hero__name { font-family: var(--font-display); font-size: clamp(2rem,4vw,3.5rem); font-weight: 700; letter-spacing: -0.045em; line-height: 1.06; color: var(--ink); margin-bottom: var(--s3); }
.author-hero__meta { display: flex; align-items: center; flex-wrap: wrap; gap: var(--s4); margin-bottom: var(--s5); }
.author-hero__meta-item { display: flex; align-items: center; gap: var(--s2); font-size: var(--text-sm); color: var(--ink-muted); }
.author-hero__bio { font-size: var(--text-md); color: var(--ink-muted); line-height: 1.78; max-width: 600px; }
.author-hero__actions { display: flex; gap: var(--s3); flex-wrap: wrap; margin-top: var(--s6); }

/* ================================================================
   ARCHIVE / TAXONOMY
   ================================================================ */
.archive-hero { padding: var(--s16) 0 var(--s12); text-align: center; background: var(--paper-warm); border-bottom: var(--border); }
.archive-hero__mood-icon { width: 88px; height: 88px; border-radius: var(--r-full); margin: 0 auto var(--s5); display: flex; align-items: center; justify-content: center; font-size: 40px; box-shadow: var(--sh-sm); }
.archive-hero__eyebrow { display: block; font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); margin-bottom: var(--s3); }
.archive-hero__title { font-family: var(--font-display); font-size: clamp(2.4rem,5vw,4rem); font-weight: 700; letter-spacing: -0.045em; line-height: 1.06; color: var(--ink); margin-bottom: var(--s4); }
.archive-hero__desc { font-size: var(--text-lg); color: var(--ink-muted); max-width: 480px; margin: 0 auto var(--s6); line-height: 1.7; }
.archive-hero__count { display: inline-flex; align-items: center; gap: var(--s2); font-size: var(--text-sm); color: var(--ink-soft); padding: var(--s2) var(--s5); background: var(--white); border: var(--border); border-radius: var(--r-full); }
.archive-layout { display: grid; grid-template-columns: 1fr var(--sidebar-w); gap: var(--s10); align-items: start; padding: var(--s12) 0; }
.archive-sidebar { position: sticky; top: calc(var(--nav-h) + var(--s6)); }

/* ================================================================
   FILTER BAR
   ================================================================ */
.filter-bar { display: flex; align-items: center; gap: var(--s3); padding: var(--s4) 0; border-bottom: var(--border); overflow-x: auto; scrollbar-width: none; }
.filter-bar::-webkit-scrollbar { display: none; }
.filter-bar__label { font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-soft); white-space: nowrap; flex-shrink: 0; }
.filter-pill { display: inline-flex; align-items: center; gap: var(--s2); padding: var(--s2) var(--s4); background: var(--white); border: var(--border); border-radius: var(--r-full); font-size: var(--text-sm); font-weight: 500; color: var(--ink-muted); cursor: pointer; white-space: nowrap; flex-shrink: 0; transition: all var(--ease); }
.filter-pill:hover { border-color: var(--ink-muted); color: var(--ink); }
.filter-pill.is-active { background: var(--ink); color: var(--paper); border-color: var(--ink); }

/* ================================================================
   SIDEBAR
   ================================================================ */
.sidebar-widget { background: var(--white); border: var(--border); border-radius: var(--r-lg); overflow: hidden; margin-bottom: var(--s5); }
.sidebar-widget:last-child { margin-bottom: 0; }
.sidebar-widget__title { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 600; color: var(--ink); padding: var(--s4) var(--s5); background: var(--paper-warm); border-bottom: var(--border); letter-spacing: -0.02em; }
.sidebar-widget__body { padding: var(--s4) var(--s5); }
.sidebar-poem-list { display: flex; flex-direction: column; }
.sidebar-poem-item { display: flex; gap: var(--s3); align-items: flex-start; padding: var(--s3) 0; border-bottom: var(--border); }
.sidebar-poem-item:last-child { border-bottom: none; }
.sidebar-poem-item__num { font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 700; color: var(--paper-mid); line-height: 1; flex-shrink: 0; width: 28px; text-align: center; letter-spacing: -0.04em; }
.sidebar-poem-item__title { font-family: var(--font-display); font-size: var(--text-sm); font-weight: 500; line-height: 1.35; color: var(--ink); margin-bottom: 2px; display: block; }
.sidebar-poem-item__title a { color: inherit; }
.sidebar-poem-item__title a:hover { color: var(--accent); }
.sidebar-poem-item__author { font-size: var(--text-xs); color: var(--ink-soft); }
.sidebar-tag-cloud { display: flex; flex-wrap: wrap; gap: var(--s2); }

/* ================================================================
   CTA / NEWSLETTER
   ================================================================ */
.cta-band { padding: var(--s16) 0; background: var(--ink); text-align: center; position: relative; overflow: hidden; }
.cta-band::before { content: '\201C'; position: absolute; top: -60px; left: 3%; font-family: var(--font-display); font-size: 22rem; font-weight: 700; color: var(--white); opacity: 0.025; line-height: 1; pointer-events: none; }
.cta-band__eyebrow { display: block; font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); margin-bottom: var(--s4); }
.cta-band__title { font-family: var(--font-display); font-size: clamp(1.75rem,3.5vw,3rem); font-weight: 400; font-style: italic; letter-spacing: -0.04em; color: var(--paper); line-height: 1.15; margin-bottom: var(--s3); }
.cta-band__sub { font-size: var(--text-base); color: var(--ink-soft); margin-bottom: var(--s8); max-width: 420px; margin-inline: auto; }
.newsletter-form { display: flex; gap: var(--s3); max-width: 440px; margin: 0 auto; }
.newsletter-form__input { flex: 1; padding: var(--s3) var(--s5); background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.12); border-radius: var(--r-full); color: var(--paper); font-family: var(--font-body); font-size: var(--text-sm); outline: none; min-width: 0; transition: border-color var(--ease); }
.newsletter-form__input::placeholder { color: rgba(250,248,245,0.35); }
.newsletter-form__input:focus { border-color: rgba(255,255,255,0.35); }
.newsletter-form__btn { background: var(--accent); color: var(--white); border: none; border-radius: var(--r-full); padding: var(--s3) var(--s6); font-family: var(--font-body); font-size: var(--text-sm); font-weight: 600; cursor: pointer; flex-shrink: 0; transition: background var(--ease); }
.newsletter-form__btn:hover { background: var(--accent-dark); }

/* ================================================================
   FOOTER
   ================================================================ */
.site-footer { background: var(--paper-warm); border-top: var(--border); padding-top: var(--s16); }
.footer-grid { display: grid; grid-template-columns: 2.2fr 1fr 1fr 1fr; gap: var(--s10); padding-bottom: var(--s12); border-bottom: var(--border); }
.footer-brand__logo { font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 700; letter-spacing: -0.035em; color: var(--ink); margin-bottom: var(--s4); display: block; }
.footer-brand__logo .logo-amp { color: var(--accent); font-style: italic; font-weight: 400; }
.footer-brand__desc { font-size: var(--text-sm); color: var(--ink-muted); line-height: 1.72; max-width: 260px; margin-bottom: var(--s6); }
.footer-social { display: flex; gap: var(--s2); }
.footer-social-btn { width: 38px; height: 38px; border-radius: var(--r-md); border: var(--border); background: var(--white); display: flex; align-items: center; justify-content: center; font-size: var(--text-sm); color: var(--ink-muted); cursor: pointer; transition: all var(--ease); }
.footer-social-btn:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); transform: translateY(-2px); }
.footer-col__title { font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink); margin-bottom: var(--s5); }
.footer-col__list { display: flex; flex-direction: column; gap: var(--s3); list-style: none; }
.footer-col__list a { font-size: var(--text-sm); color: var(--ink-muted); transition: color var(--ease); display: inline-flex; align-items: center; gap: var(--s2); }
.footer-col__list a:hover { color: var(--ink); }
.footer-bottom { display: flex; align-items: center; justify-content: space-between; padding: var(--s5) 0; gap: var(--s4); flex-wrap: wrap; }
.footer-bottom__copy  { font-size: var(--text-xs); color: var(--ink-soft); }
.footer-bottom__quote { font-family: var(--font-display); font-size: var(--text-sm); font-style: italic; color: var(--ink-muted); }

/* ================================================================
   BREADCRUMBS & PAGINATION
   ================================================================ */
.breadcrumbs { display: flex; align-items: center; flex-wrap: wrap; gap: var(--s2); padding: var(--s4) 0; font-size: var(--text-xs); color: var(--ink-soft); }
.breadcrumbs a { color: var(--ink-muted); transition: color var(--ease); }
.breadcrumbs a:hover { color: var(--accent); }
.breadcrumbs__sep { color: var(--paper-dark); font-size: 10px; }
.breadcrumbs__current { color: var(--ink); font-weight: 500; }

.pagination { display: flex; align-items: center; justify-content: center; gap: var(--s2); padding: var(--s10) 0; }
.page-numbers { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: var(--r-md); font-size: var(--text-sm); font-weight: 500; color: var(--ink-muted); background: var(--white); border: var(--border); text-decoration: none; transition: all var(--ease); }
.page-numbers:hover { background: var(--paper-warm); color: var(--ink); border-color: var(--paper-dark); }
.page-numbers.current { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.page-numbers.prev,.page-numbers.next { width: auto; padding: 0 var(--s4); }
.page-numbers.dots { border: none; background: none; color: var(--ink-soft); pointer-events: none; }

/* ================================================================
   ACCESIBILIDAD & UTILIDADES
   ================================================================ */
.skip-link { position: absolute; top: -200%; left: var(--s4); z-index: 9999; padding: var(--s3) var(--s5); background: var(--ink); color: var(--paper); font-size: var(--text-sm); font-weight: 600; border-radius: var(--r-md); text-decoration: none; transition: top var(--ease); }
.skip-link:focus { top: var(--s4); }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

.text-center { text-align: center; }
.hidden  { display: none !important; }
.section-pad    { padding: var(--s16) 0; }
.section-pad-sm { padding: var(--s10) 0; }
.section-pad-lg { padding: var(--s24) 0; }
.divider { height: 1px; background: var(--paper-mid); border: none; margin: var(--s8) 0; }
.divider--accent { background: linear-gradient(90deg,var(--accent),transparent); height: 2px; }

.skeleton { background: linear-gradient(90deg,var(--paper-warm) 25%,var(--paper-mid) 50%,var(--paper-warm) 75%); background-size: 200% 100%; animation: shimmer 1.4s ease infinite; border-radius: var(--r-sm); }
@keyframes shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--paper-warm); }
::-webkit-scrollbar-thumb { background: var(--paper-dark); border-radius: var(--r-full); }
::-webkit-scrollbar-thumb:hover { background: var(--ink-soft); }

/* ================================================================
   ANIMACIONES SCROLL
   ================================================================ */
[data-animate] { opacity: 0; transform: translateY(20px); transition: opacity 0.5s ease, transform 0.5s ease; }
[data-animate].is-visible { opacity: 1; transform: translateY(0); }
[data-animate-delay="1"] { transition-delay: 80ms; }
[data-animate-delay="2"] { transition-delay: 160ms; }
[data-animate-delay="3"] { transition-delay: 240ms; }
[data-animate-delay="4"] { transition-delay: 320ms; }
[data-animate-delay="5"] { transition-delay: 400ms; }

/* ================================================================
   RESPONSIVE — TABLET ≤1024px
   ================================================================ */
@media (max-width: 1024px) {
  :root { --sidebar-w: 260px; }
  .hero__inner        { grid-template-columns: 1fr; }
  .hero__poem-card    { display: none; }
  .hero__desc         { max-width: 100%; }
  .moods-grid         { grid-template-columns: repeat(4,1fr); }
  .authors-grid       { grid-template-columns: repeat(3,1fr); }
  .collections-grid   { grid-template-columns: repeat(2,1fr); }
  .poems-grid--3      { grid-template-columns: repeat(2,1fr); }
  .poems-grid--4      { grid-template-columns: repeat(3,1fr); }
  .footer-grid        { grid-template-columns: 1fr 1fr; gap: var(--s8); }
  .poem-single__layout{ grid-template-columns: 1fr; }
  .poem-sidebar       { position: static; }
  .archive-layout     { grid-template-columns: 1fr; }
  .archive-sidebar    { position: static; }
  .author-hero { grid-template-columns: 160px 1fr; gap: var(--s8); }
  .author-hero__photo,.author-hero__initial { width: 160px; height: 160px; }
}

/* ================================================================
   RESPONSIVE — MÓVIL ≤768px
   ================================================================ */
@media (max-width: 768px) {
  :root { --nav-h: 60px; }
  .primary-nav { display: none; }
  .nav-toggle  { display: flex; }
  .nav-kbd     { display: none; }
  h1 { font-size: var(--text-4xl); }
  h2 { font-size: var(--text-3xl); }
  h3 { font-size: var(--text-2xl); }
  .hero { padding: var(--s12) 0 var(--s10); }
  .hero__actions { flex-direction: column; align-items: flex-start; }
  .hero__stats { gap: var(--s6); flex-wrap: wrap; }
  .moods-grid { grid-template-columns: repeat(3,1fr); }
  .authors-grid { grid-template-columns: repeat(2,1fr); }
  .collections-grid { grid-template-columns: 1fr; }
  .poems-grid--2,.poems-grid--3,.poems-grid--4 { grid-template-columns: 1fr; }
  .section-header { flex-direction: column; align-items: flex-start; }
  .section-link { display: none; }
  .footer-grid { grid-template-columns: 1fr; gap: var(--s8); }
  .author-hero { grid-template-columns: 1fr; }
  .author-hero__photo,.author-hero__initial { margin: 0 auto; }
  .newsletter-form { flex-direction: column; }
  .poem-single__title { font-size: clamp(1.8rem,6vw,2.75rem); }
  .poem-single__body  { font-size: var(--text-lg); }
  .cta-band__title { font-size: var(--text-3xl); }
}

/* ================================================================
   RESPONSIVE — MÓVIL PEQUEÑO ≤480px
   ================================================================ */
@media (max-width: 480px) {
  .moods-grid { grid-template-columns: repeat(2,1fr); }
  .collection-card { padding: var(--s6); }
  .poem-card { padding: var(--s5); }
  .pagination .page-numbers:not(.prev):not(.next):not(.current) { display: none; }
}

/* ================================================================
   PRINT
   ================================================================ */
@media print {
  .site-header,.site-footer,.poem-sidebar,.related-section,
  .cta-band,.emotional-selector,.filter-bar,.pagination,
  .search-overlay,.mobile-nav,.nav-toggle { display: none !important; }
  body { background: white; color: black; }
  .poem-single__layout { display: block; }
  .poem-single__body { font-size: 14pt; line-height: 1.9; }
  a[href]::after { content: ' (' attr(href) ')'; font-size: 10pt; color: gray; }
  .poem-card { break-inside: avoid; }
}
