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

html { scroll-behavior: smooth; font-size: 16px; }

body {
  background-color: var(--color-bg);
  color: var(--color-ink-light);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.85;
  -webkit-font-smoothing: antialiased;
}
 
/* Grain de papel */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml;charset=utf-8,<svg xmlns='http://www.w3.org/2000/svg' width='256' height='256'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.78' numOctaves='4' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/></filter><rect width='256' height='256' filter='url(%23n)' opacity='0.05'/></svg>");
  pointer-events: none;
  z-index: 0;
}

/* Viñeta cálida */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  background: radial-gradient(ellipse 90% 80% at 50% 50%, transparent 40%, rgba(44,24,16,0.10) 100%);
  pointer-events: none;
  z-index: 0;
}

h1, h2, h3, h4 {
  font-family: var(--font-display);
  color: var(--color-ink);
  line-height: 1.15;
}
h1 { font-size: var(--text-3xl); font-style: italic; font-weight: 700; letter-spacing: -0.02em; }
h2 { font-size: var(--text-2xl); font-style: italic; font-weight: 700; }
h3 { font-size: var(--text-xl);  font-weight: 400; }
h4 { font-size: var(--text-lg);  font-weight: 400; }

p  { line-height: 1.85; color: var(--color-ink-light); margin-bottom: var(--space-sm); }
p:last-child { margin-bottom: 0; }

a  { color: var(--color-accent); text-decoration: none; transition: color 0.25s; }
a:hover { color: var(--color-ink); }

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

blockquote {
  border-left: 3px solid var(--color-gold);
  padding: 12px 0 12px 24px;
  font-family: var(--font-body);
  font-style: italic;
  font-size: var(--text-lg);
  color: var(--color-ink-mid);
  line-height: 1.75;
  margin: var(--space-md) 0;
}

/* Layout */
.container       { max-width: var(--max-wide);  margin: 0 auto; padding: 0 40px; position: relative; z-index: 1; }
.container-prose { max-width: var(--max-prose); margin: 0 auto; padding: 0 40px; position: relative; z-index: 1; }

/* Eyebrow */
.eyebrow {
  display: block;
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-sm);
}

/* Label */
.label {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-sage);
}

/* Buttons */
.btn {
  display: inline-block;
  position: relative;
  overflow: hidden;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  border: none;
  text-decoration: none;
  transition: color 0.3s;
}
.btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at center, rgba(255,255,255,0.15) 0%, transparent 70%);
  transform: scale(0);
  transition: transform 0.5s var(--ease-soft);
  border-radius: 50%;
}
.btn:hover::after { transform: scale(3); }

.btn-primary {
  padding: 13px 28px;
  background: var(--color-ink);
  color: var(--color-bg);
  transition: background 0.3s;
}
.btn-primary:hover { background: var(--color-accent); color: var(--color-bg); }

.btn-secondary {
  padding: 11px 24px;
  background: transparent;
  color: var(--color-accent);
  border: 1.5px solid var(--color-accent);
  transition: background 0.28s, color 0.28s;
}
.btn-secondary:hover { background: var(--color-accent); color: var(--color-bg); }

/* Divider */
.divider {
  display: flex;
  align-items: center;
  gap: 14px;
  max-width: 260px;
  margin: var(--space-md) auto;
}
.divider-rule  { flex: 1; height: 1px; background: linear-gradient(to right, transparent, var(--color-gold), transparent); }
.divider-glyph { color: var(--color-gold); font-size: 1rem; opacity: 0.85; }

.hr-simple { width: 40px; height: 1px; background: var(--color-gold); opacity: 0.5; margin: var(--space-md) auto; border: none; display: block; }

/* Portrait */
.portrait {
  border-radius: 50%;
  object-fit: cover;
  object-position: center 12%;
  box-shadow: 0 0 0 3px var(--color-bg), 0 0 0 5px var(--color-gold), 0 10px 32px rgba(44,24,16,0.18);
}

/* Page frame */
.page-frame {
  position: fixed;
  inset: 12px;
  border: 1px solid rgba(184,149,90,0.20);
  pointer-events: none;
  z-index: 999;
}

/* Section spacing */
.section { padding: var(--space-xl) 0; position: relative; z-index: 1; }
.section--alt { background: var(--color-bg-dark); }

/* Section header */
.section-header { text-align: center; margin-bottom: var(--space-xl); }
.section-header h2 { margin-top: var(--space-sm); }

/* Entry content */
.entry-content p  { margin-bottom: var(--space-sm); }
.entry-content ul { list-style: disc; padding-left: var(--space-md); margin-bottom: var(--space-sm); }
.entry-content ol { list-style: decimal; padding-left: var(--space-md); margin-bottom: var(--space-sm); }
.entry-content li { line-height: 1.75; color: var(--color-ink-light); }

/* Main content */
.site-main { position: relative; z-index: 1; }

/* Responsive */
@media (max-width: 768px) {
  .container, .container-prose { padding: 0 20px; }
  .section { padding: var(--space-lg) 0; }
}
@media (max-width: 480px) {
  .page-frame { display: none; }
  .section    { padding: var(--space-md) 0; }
}
