/* ===================== 0) VARIABLES + BASE ===================== */
:root{
  --bg:#ffffff; --ink:#111111; --muted:#6f7076;
  --sand:#f4efe9; --line:#e8e3dd; --terra1:#f3e7dd; --terra2:#ecdacd;
  --radius:12px;
  --section-py:72px; --box-pad:18px; --gap:32px;
}

*{box-sizing:border-box}
html,body{height:100%}
html{ background:#fff; }   /* blanco base */
body{
  margin:0; background:transparent; color:var(--ink);
  font-family:"Manrope",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  line-height:1.7; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  position:relative; z-index:0;
}
/* Textura de fondo global */
body::before{
  content:"";
  position:fixed; inset:0;
  z-index:-1;              /* detrás del contenido */
  pointer-events:none;
  background-image:url('fondo.jpg');  /* <-- tu archivo */
  background-repeat:repeat;
  background-position:center;
  background-size:1000px;  /* AJUSTE: 800–1200px según gusto */
  opacity:.06;             /* AJUSTE: .04 muy sutil, .10 más visible */
}
img{max-width:100%; height:auto; display:block}
:focus-visible{outline:2px solid #000; outline-offset:2px}

/* ===================== 1) UTILIDADES ===================== */
.wrap{max-width:1120px; margin:0 auto; padding:24px}
.grid-2{display:grid; gap:var(--gap); align-items:start}
@media (min-width:960px){ .grid-2{grid-template-columns:1fr 1fr} }
.stack{display:flex; flex-direction:column; gap:16px; align-items:center; text-align:center}
.tiny{display:flex; flex-direction:column; gap:8px; align-items:center}
.lead{color:var(--muted); max-width:64ch}
.centered{display:flex; gap:12px; flex-wrap:wrap; justify-content:center}

/* ===================== 2) TITULARES / BOTONES ===================== */
h1,h2,h3{margin:0 0 12px; line-height:1.14; font-weight:800; color:var(--ink)}
h1{font-size:clamp(36px,6vw,58px)}
h2{font-size:clamp(26px,4.2vw,38px)}
h3{font-size:clamp(18px,2.6vw,22px)}

.btn{
  display:inline-grid; place-items:center;
  padding:10px 18px; border-radius:999px;
  text-decoration:none; font-weight:800; letter-spacing:.04em;
  color:#111; background:transparent; border:1px solid var(--ink);
  transition:transform .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease;
}
.btn:hover{ background:#111; color:#fff; transform:translateY(-3px); box-shadow:0 8px 18px rgba(0,0,0,.12) }
.btn-ghost2{
  color:#fff;
  border:1px solid #fff;
  background:transparent;
}
.btn-ghost2:hover{
  background:#fff;
  color:#000;
  border-color:#fff;
}
.btn-solid{ background:transparent; color:var(--ink); border:1px solid var(--ink) }
.btn-solid:hover{ background:#111; color:#fff; border-color:#111 }
.btn-primary{background:#111; color:#fff; border-color:#111}
.btn-light{background:transparent; border:1px solid var(--line); color:var(--ink)}
.btn-light:hover{background:#111; color:#fff; border-color:#111}

/* ===================== 3) NAV ===================== */
.nav{position:sticky; top:0; z-index:30; background:rgba(255,255,255,.9); backdrop-filter:blur(8px); border-bottom:1px solid var(--line)}
.nav .wrap{display:flex; justify-content:space-between; align-items:center}
.brand{ text-decoration:none; color:var(--ink); letter-spacing:.18em; font-weight:900; font-size:20px }
.links{display:none; gap:22px; align-items:center}
.links a{ color:var(--ink); text-decoration:none; font-weight:800; letter-spacing:.15em; font-size:12px }
.links a:hover{text-decoration:underline}
.menu{background:none; border:0; font-size:22px; color:var(--ink)}
@media (min-width:900px){ .links{display:flex} .menu{display:none} }

/* ===================== 4) HERO ===================== */
.section{padding:var(--section-py) 0}
.hero{position:relative; overflow:hidden}
.hero-photo{min-height:68vh; display:grid; place-items:center}
.hero-inner{position:relative; z-index:2}
.hero .text{max-width:720px; color:#fff}
.hero .text .lead, .hero .text h1, .hero .text strong{ color:#fff; text-shadow:0 2px 6px rgba(0,0,0,.5) }
.hero .actions{display:flex; gap:12px; flex-wrap:wrap; margin-top:10px}
.hero-bg{ position:absolute; inset:-10% -10% -10% -10%; background:
  radial-gradient(900px 500px at 12% 20%, var(--terra1) 0%, transparent 60%),
  radial-gradient(900px 520px at 88% 10%, var(--terra2) 0%, transparent 65%),
  var(--bg) }
.hero-bg::after{ content:""; position:absolute; inset:0; background-image:var(--img); background-size:cover; background-position:var(--pos, 50% 60%); transform: translate(var(--tx,0), var(--ty,0)) scale(1.06); transition: transform .2s ease-out; opacity:.92 }
.hero-veil{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,.48), rgba(0,0,0,.28) 40%, rgba(0,0,0,.08) 70%); mix-blend-mode:multiply; z-index:1 }

/* ===================== 5) INTRO ===================== */
/* Chips con marco (restaurado) */
.chips{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:8px;            /* opcional: un poco de aire */
}

.chip{
  font-size:12px;
  padding:6px 10px;
  border:1px solid var(--line);  /* marco sutil */
  border-radius:999px;           /* forma de pastilla */
  background:#fff;
  color:#333;
  line-height:1;                 /* para que queden compactos */
}
.intro .highlight{
  background:var(--sand); border:0px solid var(--line); border-radius:var(--radius);
  padding:var(--box-pad); box-shadow:0 6px 14px rgba(0,0,0,.04);
  transition: transform .18s ease, box-shadow .18s ease;
}
.intro .highlight:hover{ transform:translateY(-3px); box-shadow:0 10px 22px rgba(0,0,0,.12) }
.intro-box{ margin-top: var(--offset, 0px) } /* la altura la fija el JS */

#cuerpo .intro-text a {
  color: #000;               /* negro */
  text-decoration: underline; /* mantiene subrayado */
}

#cuerpo .intro-text a:hover {
  color: #333;               /* gris más suave al pasar el mouse */
  text-decoration: underline; /* sigue subrayado */
}


/* ===================== 6) PROCESO ===================== */
#proceso.section{ position:relative; overflow:hidden }
#proceso.section::before{
  content:""; position:absolute; inset:-8%; z-index:0;
  background-image:url('honguin.jpg');
  background-size:cover; background-position:50% 55%;
  transform: translate(var(--tx,0), var(--ty,0)) scale(1.00);
  transition: transform .25s ease-out;
}
#proceso.section::after{
  content:""; position:absolute; inset:0; z-index:0;
  background: radial-gradient(70% 60% at 30% 40%, rgba(0,0,0,.28) 0, rgba(0,0,0,.42) 60%, rgba(0,0,0,.55) 100%);
}
#proceso.section .wrap{ position:relative; z-index:1 }
#proceso.section h2, #proceso.section h3, #proceso.section p, #proceso.section em, #proceso.section strong{ color:#fff; text-shadow:0 2px 6px rgba(0,0,0,.35) }
.cards-3{ display:grid; gap:18px; grid-template-columns:repeat(3,1fr) }
@media (max-width:900px){ .cards-3{ grid-template-columns:repeat(2,1fr) } }
@media (max-width:600px){ .cards-3{ grid-template-columns:1fr } }
#proceso.section .card{
  background: rgba(0,0,0,.35); border:1px solid rgba(255,255,255,.22);
  color:#fff; border-radius:var(--radius); padding:20px; box-shadow:0 8px 20px rgba(0,0,0,.18);
  transition: transform .18s ease, box-shadow .18s ease;
}
#proceso.section .card:hover{ transform:translateY(-3px); box-shadow:0 12px 28px rgba(0,0,0,.22) }
#proceso.section .actions{ margin-top:24px; display:flex; gap:14px; flex-wrap:wrap; justify-content:center }
#proceso.section .actions .btn{ border:1px solid #fff; color:#fff; background:transparent }
#proceso.section .actions .btn:hover{ background:#fff; color:#000 }

/* ===================== 7) VIDEO ===================== */
.video .callout{
  background:var(--sand); border:0px solid var(--line); border-radius:var(--radius);
  padding:var(--box-pad); box-shadow:0 6px 14px rgba(0,0,0,.04);
  transition: transform .18s ease, box-shadow .18s ease;
}
.video .callout:hover{ transform:translateY(-3px); box-shadow:0 10px 22px rgba(0,0,0,.12) }
.video-box{ margin-top: var(--offset, 0px) } /* la altura la fija el JS */

@media (min-width:960px){ .section.video .wrap.grid-2{ grid-template-columns: 1.6fr 1fr } }
.video .ratio{ position:relative; width:100%; aspect-ratio:16/9; overflow:hidden; border-radius:12px; border:1px solid var(--line); box-shadow:0 10px 24px rgba(0,0,0,.06) }
.video .ratio iframe{ position:absolute; inset:0; width:100%; height:100%; border:0 }

/* ===== Botones Microdosis (callout): sand, borde negro, ancho según texto, a la izquierda */
.callout .pills{ list-style:none; padding:0; margin:16px 0 0; display:flex; flex-direction:column; gap:12px; align-items:flex-start }
.callout .pills li{ margin:0 }
.callout .pills a{
  display:inline-block; padding:10px 18px; border-radius:999px; text-decoration:none; font-weight:800;
  letter-spacing:.04em; background:var(--sand); color:var(--ink); border:1px solid var(--ink);
  white-space:nowrap; transition:transform .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.callout .pills a:hover{ background:#111; color:#fff; border-color:#111; transform:translateY(-3px); box-shadow:0 8px 18px rgba(0,0,0,.16) }

/* ===================== 8) PARA QUIÉN ES ===================== */
.quote{
  background:var(--sand); border:0px solid var(--line); border-radius:var(--radius);
  padding:var(--box-pad); font-weight:700; transition: transform .18s ease, box-shadow .18s ease;
}
.quote:hover{ transform:translateY(-3px); box-shadow:0 10px 22px rgba(0,0,0,.12) }
.pq-box{ margin-top: var(--offset, 0px) }
/* Fondo de la sección ¿para quién es? */
#para-quien.section {
  position:relative; 
  overflow:hidden;
}
#para-quien.section::before{
  content:""; 
  position:absolute; 
  inset:-8%; 
  z-index:0;
  background-image:url('hongultimo.jpg');
  background-size:cover; 
  background-position:50% 50%;
  transform: translate(var(--tx,0), var(--ty,0)) scale(1.00);
  transition: transform .25s ease-out;
}
#para-quien.section::after{
  content:""; 
  position:absolute; 
  inset:0; 
  z-index:1; 
  background:rgba(0,0,0,.35); /* velo para contraste */
}
#para-quien.section .wrap{
  position:relative; 
  z-index:2;
}
/* Para títulos y párrafos en la columna izquierda */
#para-quien.section .col-text h2,
#para-quien.section .col-text p {
  color:#fff;
  text-shadow:0 2px 6px rgba(0,0,0,.4);
}

/* Para el bloque de la derecha */
#para-quien.section .pq-box .quote {
  color:#000;           /* texto negro */
  text-shadow:none;     /* sin sombra */
  background:rgba(255,255,255,0.65); /* fondo clarito */
}

/* ===================== 9) FAQ / CTA / FOOTER ===================== */
.micro-faq .faq-list{ display:grid; gap:14px; margin-top:24px }
.micro-faq details{
  background:var(--sand); border:1px solid var(--line); border-radius:var(--radius);
  padding:16px 18px; font-size:15px; line-height:1.6; cursor:pointer;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.micro-faq details:hover{ transform:translateY(-3px); box-shadow:0 8px 18px rgba(0,0,0,.10) }
.micro-faq summary{ font-weight:700; cursor:pointer; list-style:none }
.micro-faq summary::-webkit-details-marker{display:none}
.micro-faq a{ color:var(--ink); font-weight:600; text-decoration:underline }

.cta{padding:80px 0; background:linear-gradient(180deg, var(--bg), var(--sand))}

/* Footer base + centrado */
.footer{ border-top:1px solid var(--line); background:#fff; color:#4b4f55 }
.footer .wrap{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:8px; padding:24px }
.footer nav{ display:flex; flex-wrap:wrap; justify-content:center; gap:6px }
.footer nav a{ color:inherit; text-decoration:none }
.footer nav a:hover{ color:#111 }
.footer p{ margin:6px 0 0 }

/* ===================== 10) REVEAL ===================== */
.reveal{opacity:0; transform:translateY(14px)}
.reveal--visible{opacity:1; transform:none; transition:opacity .45s ease, transform .45s ease}
@media (prefers-reduced-motion: reduce){
  *{animation:none!important; transition:none!important; scroll-behavior:auto!important}
}

/* ====== MOBILE TUNING: sin offsets y menos aire en 1 columna ====== */
@media (max-width:959px){
  .grid-2{ gap:14px }
  .intro-box, .video-box, .pq-box{ --offset:0px; margin-top:0 }
  .video .callout, .intro .highlight, .quote{ margin-top:10px }
  .section{ padding:56px 0 } /* leve compresión vertical en móvil */
}

#cuerpo {
  text-align: justify;
}
/* ====== OVERLAY MENÚ MÓVIL (forzado) ====== */
@media (max-width: 899px){

  /* el overlay ocupa TODA la pantalla y es blanco sólido */
  header.nav .links{
    position: fixed !important;
    top: 0; right: 0; bottom: 0; left: 0;
    width: 100vw; height: 100vh;
    margin: 0 !important;
    max-width: none !important;
    padding: 24px;
    display: none;                  /* cerrado */
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 26px;
    background: #fff !important;    /* ← BLANCO */
    z-index: 10000;                 /* por encima de todo */
  }
  header.nav .links.open{ display:flex; }

  /* oculto la marca detrás del overlay */
  header.nav.is-open .brand{ opacity:0; visibility:hidden; pointer-events:none; }

  /* botón hamburguesa visible y por encima (sin “X”) */
  header.nav .menu{ position:relative; z-index:11001; color:#111; }
  header.nav.is-open .menu{ position:fixed; right:24px; top:16px; color:#111; }

  /* textos en negro dentro del overlay */
  header.nav .links a{
    color:#111;
    font-size:22px;
    letter-spacing:.16em;
    font-weight:800;
    text-decoration:none;
  }
  header.nav .links .btn{ font-size:18px; padding:12px 22px; }

  /* iconos al pie en NEGRO (tus PNG blancos se invierten) */
  header.nav .links .mobile-social{ display:flex; gap:18px; margin-top:28px; }
  header.nav .links .mobile-social img{ width:28px; height:28px; display:block; filter:invert(1); }
}

/* en desktop, ocultar siempre los iconos del overlay */
@media (min-width:900px){
  header.nav .links .mobile-social{ display:none !important; }
}
