:root {
  --void:    #06070E;
  --void-2:  #0C0B18;
  --surface: #131120;
  --cream:   #F7F4EE;
  --paper:   #EDE9E0;
  --sand:    #D9D4C8;
  --fire:      oklch(67% 0.21 36);
  --fire-soft: oklch(79% 0.16 42);
  --fire-glow: oklch(67% 0.21 36 / 0.17);
  --steel:     oklch(62% 0.13 224);
  --od:   #EDE9E1;
  --od-2: rgba(237,233,225,0.70);
  --od-3: rgba(237,233,225,0.28);
  --ol:   #0B0A17;
  --ol-2: rgba(11,10,23,0.52);
  --pad: clamp(20px, 5vw, 64px);
  --max: 1360px;
  --disp: 'Archivo Black', ui-sans-serif, sans-serif;
  --disp-cond: 'Big Shoulders Display', ui-sans-serif, sans-serif;
  --body: 'Manrope', ui-sans-serif, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, monospace;
}
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: var(--body); line-height: 1.6; background: var(--void); color: var(--od); -webkit-font-smoothing: antialiased; overflow-x: clip; }
a { color: inherit; text-decoration: none; }
button { font: inherit; border: 0; cursor: pointer; background: none; color: inherit; padding: 0; }
img { display: block; max-width: 100%; }
::selection { background: var(--fire); color: var(--cream); }
.wrap { max-width: var(--max); margin: 0 auto; padding-inline: var(--pad); }

/* ══ NAV ══ */
.nav {
  position: fixed; inset: 0 0 auto; z-index: 100;
  padding-inline: var(--pad); height: 68px;
  display: flex; align-items: center; justify-content: space-between;
  border-bottom: 1px solid transparent;
  transition: background 0.5s, border-color 0.5s;
}
.nav.scrolled {
  background: rgba(6,7,14,0.92);
  -webkit-backdrop-filter: blur(20px) saturate(150%);
  backdrop-filter: blur(20px) saturate(150%);
  border-color: rgba(237,233,225,0.07);
}
.nav-logo {
  font-family: var(--disp); font-size: 20px; letter-spacing: -0.025em;
  color: var(--od); display: flex; align-items: center; gap: 9px;
}
.nav-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--fire); box-shadow: 0 0 14px var(--fire);
  animation: breathe 2.8s ease-in-out infinite;
}
@keyframes breathe {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: .42; transform: scale(.76); }
}
.nav-logo-a { color: var(--fire); }

/* ══ HERO ══ */
.hero {
  padding-block: clamp(120px, 15vw, 180px) clamp(48px, 6vw, 72px);
}
.hero-eyebrow {
  font-family: var(--body); font-size: 12px; font-weight: 600;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--fire); margin: 0 0 24px;
}
.hero-title {
  font-family: var(--disp-cond); font-size: clamp(56px, 10vw, 120px);
  font-weight: 900; line-height: 0.92; letter-spacing: -0.02em;
  margin: 0 0 32px; color: var(--od);
}
.hero-title em { font-style: italic; color: var(--fire); }
.hero-lead {
  font-size: clamp(18px, 2.4vw, 26px); font-weight: 400;
  color: var(--od); max-width: 760px; margin: 0 0 20px; line-height: 1.5;
}
.hero-lead strong { color: var(--fire); font-weight: 700; }
.hero-sub {
  font-size: clamp(15px, 1.8vw, 18px); font-weight: 400;
  color: var(--od-2); max-width: 640px; margin: 0; line-height: 1.7;
}

/* ══ GUÍAS GRID ══ */
.guides-section {
  padding-block: clamp(24px, 4vw, 48px) clamp(72px, 9vw, 112px);
}
.guides-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: clamp(20px, 2.4vw, 28px);
}
.guide-card {
  display: flex; flex-direction: column; gap: 16px;
  border: 1px solid rgba(237,233,225,0.1); border-radius: 20px;
  padding: clamp(24px, 3vw, 32px); background: var(--surface);
  transition: border-color .25s, transform .25s;
}
.guide-card:hover { border-color: rgba(237,233,225,0.22); transform: translateY(-2px); }
.guide-tag {
  align-self: flex-start;
  font-size: 11px; font-weight: 600; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--fire);
  border: 1px solid rgba(255,255,255,0.14);
  padding: 4px 12px; border-radius: 100px;
}
.guide-title {
  font-family: var(--disp-cond); font-size: clamp(22px, 2.6vw, 27px);
  font-weight: 800; line-height: 1.08; margin: 0; color: var(--od);
}
.guide-desc { font-size: 15px; color: var(--od-2); margin: 0; line-height: 1.65; flex-grow: 1; }
.guide-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  background: var(--fire); color: var(--void);
  font-family: var(--body); font-size: 14px; font-weight: 800;
  padding: 13px 22px; border-radius: 100px;
  transition: opacity .2s, transform .2s;
}
.guide-btn:hover { opacity: .9; transform: translateY(-1px); }

/* ══ CTA (reutilizado del patrón del sitio) ══ */
.cta-section { padding-block: clamp(80px, 10vw, 120px); text-align: center; }
.cta-title {
  font-family: var(--disp-cond); font-size: clamp(40px, 7vw, 80px);
  font-weight: 900; line-height: 0.95; letter-spacing: -0.02em;
  margin: 0 0 32px; color: var(--od);
}
.cta-title em { font-style: italic; color: var(--fire); }
.cta-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--fire); color: var(--void);
  font-family: var(--body); font-size: 16px; font-weight: 800;
  padding: 16px 36px; border-radius: 100px;
  transition: opacity .2s, transform .2s;
}
.cta-btn:hover { opacity: .9; transform: translateY(-2px); }
.cta-sub { margin-top: 20px; font-size: 13px; color: var(--od-3); }

/* ══ FOOTER ══ */
.footer { padding-block: 48px; border-top: 1px solid rgba(237,233,225,0.07); }
.footer-word {
  font-family: var(--disp); font-size: clamp(48px, 8vw, 96px);
  font-weight: 700; letter-spacing: -0.04em; color: var(--od);
  margin-bottom: 32px; line-height: 1;
}
.footer-word span { color: var(--fire); }
.footer-bottom {
  display: grid; grid-template-columns: 1fr auto 1fr;
  align-items: center; gap: 24px; font-size: 12px; color: var(--od-3);
}
.footer-links { display: flex; gap: 22px; flex-wrap: wrap; }
.footer-links a { transition: color .2s; }
.footer-links a:hover { color: var(--fire); }
.footer-right { text-align: right; }
@media (max-width: 640px) {
  .footer-bottom { grid-template-columns: 1fr; text-align: left; }
  .footer-right { text-align: left; }
}

/* ════ MENÚ (botón + overlay) ════ */
.nav-menu-btn {
  display: flex; flex-direction: column; justify-content: center; gap: 5px;
  width: 36px; height: 36px; padding: 6px; position: relative; z-index: 101;
}
.nav-menu-bar {
  display: block; width: 22px; height: 1.5px; background: var(--od);
  transform-origin: center;
  transition: transform .45s cubic-bezier(.32,.72,0,1), opacity .3s ease;
}
.nav-menu-btn[aria-expanded="true"] .nav-menu-bar:nth-child(1) { transform: translateY(3.25px) rotate(45deg); }
.nav-menu-btn[aria-expanded="true"] .nav-menu-bar:nth-child(2) { transform: translateY(-3.25px) rotate(-45deg); }
.nav-overlay {
  position: fixed; inset: 0; z-index: 99; background: var(--void);
  display: flex; align-items: center; padding-inline: var(--pad);
  clip-path: inset(0 0 100% 0);
  transition: clip-path .65s cubic-bezier(.32,.72,0,1); pointer-events: none;
}
.nav-overlay.open { clip-path: inset(0 0 0% 0); pointer-events: auto; }
.nav-overlay-nav { display: flex; flex-direction: column; align-items: flex-start; gap: .1em; margin-top: 24px; }
.nav-ol-link {
  position: relative; isolation: isolate; display: inline-block;
  font-family: var(--disp-cond); font-weight: 800; text-transform: uppercase;
  letter-spacing: .01em; font-size: clamp(1.3rem, 3.1vw, 2.2rem);
  color: var(--od-2); line-height: 1.1; padding: .06em .34em;
  opacity: 0; transform: translateY(28px);
  transition: color .3s cubic-bezier(.32,.72,0,1), opacity .55s cubic-bezier(.32,.72,0,1), transform .55s cubic-bezier(.32,.72,0,1);
}
.nav-ol-link::before {
  content: ''; position: absolute; inset: 0; z-index: -1;
  border-top: 2px solid var(--fire); border-bottom: 2px solid var(--fire);
  transform: scaleY(2); opacity: 0;
  transition: transform .3s cubic-bezier(.32,.72,0,1), opacity .3s; pointer-events: none;
}
.nav-ol-link::after {
  content: ''; position: absolute; inset: 0; z-index: -2; background: var(--fire);
  transform: scaleY(0); transform-origin: top; opacity: 0;
  transition: transform .3s cubic-bezier(.32,.72,0,1), opacity .3s; pointer-events: none;
}
.nav-overlay.open .nav-ol-link:nth-child(1) { opacity:1; transform:none; transition-delay:.06s; }
.nav-overlay.open .nav-ol-link:nth-child(2) { opacity:1; transform:none; transition-delay:.11s; }
.nav-overlay.open .nav-ol-link:nth-child(3) { opacity:1; transform:none; transition-delay:.16s; }
.nav-overlay.open .nav-ol-link:nth-child(4) { opacity:1; transform:none; transition-delay:.21s; }
.nav-overlay.open .nav-ol-link:nth-child(5) { opacity:1; transform:none; transition-delay:.26s; }
.nav-overlay.open .nav-ol-link:nth-child(6) { opacity:1; transform:none; transition-delay:.31s; }
.nav-overlay.open .nav-ol-link:nth-child(7) { opacity:1; transform:none; transition-delay:.36s; }
.nav-overlay.open .nav-ol-link:nth-child(8) { opacity:1; transform:none; transition-delay:.41s; }
.nav-ol-link:hover, .nav-ol-link:focus-visible { color: var(--void); }
.nav-ol-link:hover::before, .nav-ol-link:focus-visible::before { transform: scaleY(1); opacity:1; }
.nav-ol-link:hover::after, .nav-ol-link:focus-visible::after { transform: scaleY(1); opacity:1; }
.nav-ol-n{font-family:var(--mono);font-style:normal;font-weight:500;font-size:.3em;letter-spacing:.14em;color:var(--fire);opacity:.6;margin-right:.55em;vertical-align:.14em;position:relative;z-index:1;display:inline-block;transition:color .3s,opacity .3s}
.nav-ol-link:hover .nav-ol-n,.nav-ol-link:focus-visible .nav-ol-n{color:var(--void);opacity:.7}

/* ── CTA flotante (Hablemos) ── */
@keyframes fab-pulse { 0%,100%{opacity:.25} 50%{opacity:.7} }
.fab-cta {
  position: fixed; bottom: 24px; right: 24px; z-index: 201;
  height: 48px; padding: 0 24px; border-radius: 999px;
  background: var(--fire); color: var(--void);
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--body); font-size: 14px; font-weight: 800; letter-spacing: .01em;
  box-shadow: 0 8px 32px rgba(0,0,0,.5), 0 0 18px var(--fire-glow);
  transition: box-shadow .3s cubic-bezier(.25,1,.5,1), transform .2s cubic-bezier(.25,1,.5,1);
}
.fab-cta::after {
  content: ''; position: absolute; inset: -4px; border-radius: 999px;
  background: var(--fire); opacity: .25; filter: blur(12px); z-index: -1; pointer-events: none;
  animation: fab-pulse 2.6s ease-in-out infinite;
}
.fab-cta:hover { box-shadow: 0 8px 32px rgba(0,0,0,.5), 0 0 34px var(--fire-glow); transform: translateY(-2px); }
.fab-cta-arrow { display: inline-block; transition: transform .3s cubic-bezier(.32,.72,0,1); }
.fab-cta:hover .fab-cta-arrow { transform: translate(2px,-2px); }
@media (prefers-reduced-motion: reduce) { .fab-cta::after { animation: none; } }

/* ══ MODAL DE DESCARGA ══ */
.gd-backdrop {
  position: fixed; inset: 0; z-index: 300;
  background: rgba(6,7,14,0.78); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center; padding: 20px;
  opacity: 0; pointer-events: none; transition: opacity .3s ease;
}
.gd-backdrop.open { opacity: 1; pointer-events: auto; }
.gd-modal {
  position: relative; width: 100%; max-width: 440px;
  background: var(--void-2); border: 1px solid rgba(237,233,225,0.12);
  border-radius: 20px; padding: clamp(28px, 4vw, 40px);
  transform: translateY(12px); transition: transform .3s ease;
}
.gd-backdrop.open .gd-modal { transform: translateY(0); }
.gd-modal-close {
  position: absolute; top: 16px; right: 16px;
  width: 32px; height: 32px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--od-2); font-size: 18px; transition: color .2s, background .2s;
}
.gd-modal-close:hover { color: var(--od); background: rgba(255,255,255,0.08); }
.gd-modal-eyebrow {
  font-family: var(--mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase;
  color: var(--fire); margin: 0 0 10px;
}
.gd-modal-title {
  font-family: var(--disp-cond); font-size: clamp(24px, 3.2vw, 30px);
  font-weight: 800; line-height: 1.1; margin: 0 0 22px; color: var(--od);
}
.gd-field { margin-bottom: 16px; }
.gd-label { display: block; font-size: 12px; font-weight: 600; color: var(--od-2); margin-bottom: 6px; }
.gd-input {
  width: 100%; background: rgba(255,255,255,0.05);
  border: 1px solid rgba(237,233,225,0.16); border-radius: 10px;
  padding: 12px 14px; font-family: var(--body); font-size: 15px; color: var(--od);
  transition: border-color .2s;
}
.gd-input:focus { outline: none; border-color: var(--fire); }
.gd-input.has-error { border-color: #ef4444; }
.gd-error-msg { display: block; font-size: 12px; color: #f87171; margin-top: 6px; min-height: 14px; }
.gd-submit {
  width: 100%; display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  background: var(--fire); color: var(--void);
  font-family: var(--body); font-size: 15px; font-weight: 800;
  padding: 14px 22px; border-radius: 100px; margin-top: 6px;
  transition: opacity .2s;
}
.gd-submit:hover { opacity: .9; }
.gd-submit:disabled { opacity: .6; cursor: default; }
.gd-note { font-size: 12px; color: var(--od-3); margin-top: 14px; line-height: 1.5; }
.gd-send-error {
  display: none; font-size: 13px; color: #f87171; margin-top: 12px;
}
.gd-send-error.show { display: block; }
.gd-success { display: none; text-align: center; padding: 8px 0; }
.gd-success.show { display: block; }
.gd-success-title {
  font-family: var(--disp-cond); font-size: clamp(22px, 3vw, 26px);
  font-weight: 800; color: var(--od); margin: 0 0 12px;
}
.gd-success-desc { font-size: 14px; color: var(--od-2); margin: 0 0 20px; line-height: 1.6; }
.gd-success-link {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  background: var(--fire); color: var(--void);
  font-family: var(--body); font-size: 14px; font-weight: 800;
  padding: 13px 26px; border-radius: 100px;
}
