/*
Theme Name: Astra Child
Theme URI: https://wpastra.com/
Version: 4.0.2
Description: Astra Child Theme
Author: Gallery Group
Author URI: https://www.recynet.com
Template: astra
*/

/* ╔══════════════════════════════════════════════════════════════════
   ║ NUTT DESIGN SYSTEM — Variables y utilidades para la home
   ║ No tocar salvo coordinación con diseño
   ╚══════════════════════════════════════════════════════════════════ */

:root {
  --green: #7a8447;
  --green-deep: #5d6634;
  --green-12: rgba(122, 132, 71, 0.12);
  --green-06: rgba(122, 132, 71, 0.06);
  --white: #ffffff;
  --ink: #1d1d1b;
  --ink-2: #4a4a45;
  --ink-3: #8a8a82;
  --hairline: rgba(0, 0, 0, 0.08);
  --hero-tag: #8fa81a;
  --hero-btn: #828234;
  --hero-trust-bg: #f5f1e8;
  --hero-trust-border: #e8dfd0;
  --hero-trust-text: #7a7268;
  --serif: 'Alice', Georgia, serif;
  --sans: 'Montserrat', system-ui, sans-serif;
  --kicker-tracking: 0.22em;
}

/* ── Wraps ── */
.nutt-wrap         { max-width: 1240px; margin: 0 auto; }
.nutt-wrap-narrow  { max-width: 880px;  margin: 0 auto; }

/* ── Bloques ── */
.nutt-block         { padding: 110px 64px; box-sizing: border-box; width: 100%; }
.nutt-block.tight   { padding: 72px 64px; }
.nutt-block.bg-green { background: var(--green); color: var(--white); }
.nutt-block.bg-tint  { background: var(--green-12); }
.nutt-block.bg-soft  { background: var(--green-06); }
.nutt-block.bg-white { background: var(--white); }

/* ── Kicker (eyebrow) ── */
.nutt-kicker {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: var(--kicker-tracking);
  text-transform: uppercase;
  color: var(--green);
  display: inline-block;
  margin-bottom: 16px;
}
.nutt-block.bg-green .nutt-kicker { color: rgba(255,255,255,0.75); }

/* ── Link-btn ── */
.nutt-link-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--green);
  text-decoration: none;
  padding: 6px 0;
  border-bottom: 1px solid var(--green);
  transition: opacity .2s ease, gap .2s ease;
}
.nutt-link-btn:hover { opacity: .65; gap: 14px; }

/* ── Botón sólido ── */
.nutt-btn-solid {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--green);
  color: #fff;
  font-family: var(--sans);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 16px 28px;
  border-radius: 999px;
  text-decoration: none;
  transition: background .2s ease;
  border: 1px solid var(--green);
  font-weight: 500;
}
.nutt-btn-solid:hover { background: var(--green-deep); border-color: var(--green-deep); }

/* ── Auto-marquee ── */
.nutt-marquee {
  overflow: hidden;
  width: 100%;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
}
.nutt-marquee-track {
  display: flex;
  width: max-content;
  animation: nuttMarquee 40s linear infinite;
  will-change: transform;
}
.nutt-marquee:hover .nutt-marquee-track { animation-play-state: paused; }

@keyframes nuttMarquee {
  0%   { transform: translate3d(0, 0, 0); }
  100% { transform: translate3d(-50%, 0, 0); }
}

@media (prefers-reduced-motion: reduce) {
  .nutt-marquee-track { animation: none; }
  .nutt-marquee { overflow-x: auto; }
}

/* ── S03 Sobre Elisa ── */
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
body .about-headline { font-family: var(--serif) !important; font-size: clamp(34px,3.4vw,52px) !important; line-height: 1.15 !important; margin-top: 24px; color: var(--ink) !important; font-weight: 400 !important; letter-spacing: -0.005em; }
.about-headline em { font-style: italic; color: var(--green); }
.about-p { font-family: var(--sans); margin-top: 32px; font-size: 16px; line-height: 1.7; color: var(--ink-2); font-weight: 300; }
.about-p + .about-p { margin-top: 18px; }
.cred-row { margin-top: 40px; display: grid; grid-template-columns: 1fr 1fr 1fr; border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); }
.cred-item { padding: 18px 12px; border-right: 1px solid var(--hairline); font-family: var(--sans); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--green-deep); text-align: center; font-weight: 500; }
.cred-item:last-child { border-right: none; }
.about-cta { margin-top: 40px; }
.about-image { aspect-ratio: 4/5; overflow: hidden; }
.about-image img { width: 100%; height: 100%; object-fit: cover; display: block; }
@media (max-width: 880px) {
  .about-grid { grid-template-columns: 1fr; gap: 40px; }
  .cred-row { grid-template-columns: 1fr; }
  .cred-item { border-right: none; border-bottom: 1px solid var(--hairline); padding: 16px 8px; }
  .cred-item:last-child { border-bottom: none; }
}

/* ── Posts y Blog ── */
.single .entry-title,
.blog .entry-title,
.archive .entry-title {
  font-family: var(--serif) !important;
  font-weight: 400 !important;
  letter-spacing: -0.005em;
  color: var(--ink) !important;
  line-height: 1.2;
}
.single .entry-content p,
.single .entry-content li {
  font-family: var(--sans) !important;
  font-size: 16px !important;
  font-weight: 300 !important;
  line-height: 1.7 !important;
  color: var(--ink-2) !important;
}
.single .entry-content h2,
.single .entry-content h3,
.single .entry-content h4 {
  font-family: var(--serif) !important;
  font-weight: 400 !important;
  color: var(--ink) !important;
  letter-spacing: -0.005em;
}
.single .entry-content h2 { font-size: clamp(28px, 2.8vw, 42px) !important; }
.single .entry-content h3 { font-size: clamp(22px, 2vw, 30px) !important; }
.single .entry-content a { color: var(--green); }
.single .entry-content a:hover { color: var(--green-deep); }
.single .entry-meta,
.single .entry-meta * {
  font-family: var(--sans) !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  color: var(--ink-3) !important;
  letter-spacing: 0.05em;
}
@media (max-width: 880px) {
  .single .entry-content p,
  .single .entry-content li { font-size: 15px !important; }
}

/* ── Responsive ── */
@media (max-width: 880px) {
  .nutt-block       { padding: 64px 20px !important; }
  .nutt-block.tight { padding: 48px 20px !important; }
}
@media (max-width: 480px) {
  .nutt-block       { padding: 48px 16px !important; }
  .nutt-block.tight { padding: 40px 16px !important; }
}
