:root{
  --cream:#F1EDE4;
  --paper:#F7F4EE;
  --ink:#1B1810;
  --stone:#B7B0A0;
  --stone-deep:#8C8574;
  --taupe:#6B6559;
  --olive:#57503C;
  --lime:#DFFF1A;
  --line: rgba(27,24,16,0.14);
  --line-soft: rgba(27,24,16,0.08);
  --serif: 'Fraunces', serif;
  --sans: 'Inter', sans-serif;
  --maxw: 1180px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 32px;}
@media (max-width:640px){ .wrap{padding:0 20px;} }

.eyebrow{
  font-family:var(--sans); font-weight:700; font-size:12.5px;
  letter-spacing:0.14em; text-transform:uppercase; color:var(--olive);
  display:flex; align-items:center; gap:10px;
}
.eyebrow::before{
  content:""; width:7px; height:7px; border-radius:50%; background:var(--lime);
  box-shadow:0 0 0 3px rgba(223,255,26,0.28);
  flex-shrink:0;
}

h1,h2,h3{ font-family:var(--serif); font-weight:500; letter-spacing:-0.01em; color:var(--ink); }

/* ---------- NAV ---------- */
header{
  position:sticky; top:0; z-index:100;
  background:rgba(241,237,228,0.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line-soft);
}
nav{ display:flex; align-items:center; justify-content:space-between; padding:20px 32px; max-width:var(--maxw); margin:0 auto; }
nav img.logo{ height:20px; width:auto; }
nav .links{ display:flex; gap:36px; align-items:center; }
nav .links a{ font-size:14.5px; font-weight:500; color:var(--olive); transition:color .2s; }
nav .links a:hover{ color:var(--ink); }
nav .cta-btn{
  background:var(--ink); color:var(--cream)!important; padding:10px 20px; border-radius:100px;
  font-weight:600; font-size:14px;
}
nav .cta-btn:hover{ background:var(--olive); }
.nav-toggle{ display:none; }
@media (max-width:860px){
  nav .links{ display:none; }
  .nav-toggle{ display:block; font-size:14px; font-weight:600; }
}

/* ---------- HERO ---------- */
.hero{ position:relative; padding:120px 0 100px; overflow:hidden; }
.hero .wrap{ position:relative; z-index:2; }
.hero-dots{ position:absolute; top:-40px; right:-60px; width:700px; height:560px; color:var(--stone-deep); opacity:0.65; z-index:1; pointer-events:none; }
@media (max-width:900px){ .hero-dots{ right:-220px; opacity:0.4; } }
.hero-kicker{ margin-bottom:28px; }
.hero h1{
  font-size:clamp(40px, 6vw, 76px);
  line-height:1.02;
  max-width:820px;
  margin-bottom:28px;
}
.hero h1 em{ font-style:italic; color:var(--olive); }
.hero p.lead{
  font-size:19px; color:var(--taupe); max-width:520px; margin-bottom:40px; line-height:1.6;
}
.btn-row{ display:flex; gap:16px; flex-wrap:wrap; align-items:center; }
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:15px 28px; border-radius:100px; font-weight:600; font-size:15px;
  transition:all .2s ease;
}
.btn-primary{ background:var(--ink); color:var(--cream); }
.btn-primary:hover{ background:var(--olive); transform:translateY(-1px); }
.btn-ghost{ border:1.5px solid var(--line); color:var(--ink); }
.btn-ghost:hover{ border-color:var(--ink); }

.hero-tagline{
  margin-top:64px; padding-top:36px; border-top:1px solid var(--line);
  font-family:var(--serif); font-style:italic; font-size:20px; color:var(--taupe);
  max-width:640px;
}

/* ---------- MARQUEE / STAT BAND ---------- */
.stat-band{ background:var(--ink); color:var(--cream); padding:56px 0; }
.stat-band .wrap{ display:flex; flex-wrap:wrap; gap:48px; justify-content:space-between; align-items:center; }
.stat-item{ min-width:140px; }
.stat-num{ font-family:var(--serif); font-size:42px; color:var(--lime); line-height:1; margin-bottom:8px; }
.stat-label{ font-size:13.5px; color:var(--stone); letter-spacing:0.02em; max-width:180px; }

/* ---------- PROBLEM SECTION ---------- */
.problem{ padding:120px 0; background:var(--paper); position:relative; }
.problem-grid{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:64px; align-items:start; }
@media (max-width:860px){ .problem-grid{ grid-template-columns:1fr; gap:36px; } }
.problem h2{ font-size:clamp(32px,4.4vw,52px); line-height:1.08; }
.problem-copy{ padding-top:14px; }
.problem-copy p{ font-size:17px; color:var(--taupe); margin-bottom:20px; line-height:1.7; max-width:480px; }
.problem-copy p:last-child{ margin-bottom:0; }
.problem-copy .accent{ color:var(--ink); font-weight:600; }

/* ---------- SOLUTION QUOTE ---------- */
.solution{ background:var(--olive); color:var(--paper); padding:110px 0; position:relative; overflow:hidden; }
.solution .wrap{ position:relative; z-index:2; max-width:880px; }
.solution blockquote{
  font-family:var(--serif); font-weight:400; font-size:clamp(26px,3.6vw,40px);
  line-height:1.28; color:var(--paper); margin-bottom:32px;
}
.solution .fine{ font-size:16.5px; color:rgba(247,244,238,0.62); max-width:560px; line-height:1.7; }
.solution-dots{ position:absolute; left:-120px; bottom:-160px; width:520px; height:520px; color:rgba(247,244,238,0.18); z-index:1; }

/* ---------- RECURSOS ---------- */
.recursos{ padding:120px 0; }
.section-head{ max-width:640px; margin-bottom:64px; }
.section-head h2{ font-size:clamp(32px,4.2vw,48px); margin-top:16px; line-height:1.1; }
.section-head p{ margin-top:18px; font-size:17px; color:var(--taupe); }

.card-grid{ display:grid; grid-template-columns:repeat(3, 1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
@media (max-width:900px){ .card-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px){ .card-grid{ grid-template-columns:1fr; } }
.card{ background:var(--cream); padding:40px 32px; transition:background .25s ease; position:relative; }
.card:hover{ background:var(--paper); }
.card .num{ font-family:var(--serif); font-style:italic; color:var(--stone-deep); font-size:15px; margin-bottom:22px; display:block; }
.card h3{ font-size:21px; margin-bottom:12px; font-weight:500; }
.card p{ font-size:14.5px; color:var(--taupe); line-height:1.65; margin-bottom:18px; }
.card ul{ list-style:none; }
.card ul li{ font-size:13.5px; color:var(--olive); padding-left:16px; position:relative; margin-bottom:7px; }
.card ul li::before{ content:"–"; position:absolute; left:0; color:var(--stone-deep); }
.card-link{ display:inline-block; margin-top:20px; font-size:13.5px; font-weight:600; color:var(--ink); border-bottom:1px solid var(--ink); padding-bottom:1px; }
.card-link:hover{ color:var(--olive); border-color:var(--olive); }

/* ---------- MANIFESTO / LIME ---------- */
.manifesto{ background:var(--lime); color:var(--ink); padding:140px 0; position:relative; overflow:hidden; }
.manifesto .wrap{ position:relative; z-index:2; }
.manifesto h2{
  font-family:var(--serif); font-weight:400; font-style:italic;
  font-size:clamp(34px, 6vw, 68px); line-height:1.08; max-width:900px;
}
.manifesto .sig{ margin-top:44px; display:flex; align-items:center; gap:14px; }
.manifesto .sig img{ height:16px; }
.manifesto-crop{
  position:absolute; right:-4%; top:50%; transform:translateY(-50%);
  display:grid; grid-template-columns:repeat(2,1fr); gap:14px; opacity:0.9;
}
.manifesto-crop div{ width:64px; height:64px; border-radius:50%; background:rgba(27,24,16,0.85); }
@media (max-width:760px){ .manifesto-crop{ display:none; } }

/* ---------- PURPOSE / DOT CLOUD ---------- */
.purpose{ padding:130px 0; background:var(--paper); position:relative; overflow:hidden;}
.purpose .wrap{ position:relative; z-index:2; text-align:center; max-width:760px; }
.purpose-dots{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:760px; height:760px; color:var(--stone-deep); opacity:0.55; z-index:1;}
.purpose h2{ font-size:clamp(28px,4vw,44px); line-height:1.28; font-style:italic; font-weight:400; margin-bottom:26px; }
.purpose p{ font-size:16px; color:var(--taupe); max-width:460px; margin:0 auto; }

/* ---------- MANIFESTO (Propósito de marca) ---------- */
.manifesto-full{ background:var(--olive); color:var(--paper); padding:140px 0; }
.manifesto-full .wrap{ max-width:760px; }
.eyebrow-dark{ color:var(--stone); margin-bottom:40px; }
.eyebrow-dark::before{ background:var(--lime); }
.manifesto-text p{
  font-family:var(--serif); font-weight:400; font-size:clamp(21px, 2.6vw, 30px);
  line-height:1.5; color:rgba(247,244,238,0.82); margin-bottom:28px;
}
.manifesto-text p.manifesto-turn{ color:var(--paper); font-style:italic; margin-top:44px; }
.manifesto-text .accent-lime{ color:var(--lime); font-style:italic; }
.manifesto-close{
  margin-top:56px; padding-top:44px; border-top:1px solid rgba(247,244,238,0.22);
  display:flex; gap:18px; align-items:flex-start;
}
.manifesto-close .quote-mark{
  font-family:var(--serif); font-size:56px; line-height:0.6; color:var(--lime); flex-shrink:0; margin-top:12px;
}
.manifesto-close p{
  font-family:var(--serif); font-style:italic; font-size:clamp(20px,2.4vw,26px);
  color:var(--paper); line-height:1.4;
}

/* ---------- FINAL CTA ---------- */
.final-cta{ background:var(--ink); color:var(--cream); padding:130px 0; text-align:center; position:relative; overflow:hidden; }
.final-cta .wrap{ position:relative; z-index:2; }
.final-cta h2{ color:var(--cream); font-size:clamp(30px,4.6vw,50px); font-weight:500; font-style:normal; margin-bottom:20px; max-width:680px; margin-left:auto; margin-right:auto; line-height:1.18; }
.final-cta .lead{ color:rgba(247,244,238,0.64); font-size:16.5px; max-width:460px; margin:0 auto 44px; line-height:1.6; }
.final-cta .btn-row{ justify-content:center; }
.final-cta .btn-primary{ background:var(--lime); color:var(--ink); }
.final-cta .btn-primary:hover{ background:#c9e600; }
.final-cta .btn-ghost{ border-color:rgba(247,244,238,0.3); color:var(--cream); }
.final-cta .btn-ghost:hover{ border-color:var(--cream); }

/* ---------- FOOTER ---------- */
footer{ background:var(--cream); padding:80px 0 40px; border-top:1px solid var(--line); }
.footer-top{ display:grid; grid-template-columns:1.4fr repeat(3,1fr); gap:40px; margin-bottom:64px; }
@media (max-width:760px){ .footer-top{ grid-template-columns:1fr 1fr; } }
.footer-brand img{ height:18px; margin-bottom:18px; }
.footer-brand p{ font-size:14px; color:var(--taupe); max-width:260px; line-height:1.6; }
.footer-col h5{ font-size:12.5px; text-transform:uppercase; letter-spacing:0.1em; color:var(--stone-deep); margin-bottom:16px; font-weight:700; }
.footer-col a, .footer-col span{ display:block; font-size:14.5px; color:var(--olive); margin-bottom:10px; }
.footer-col a:hover{ color:var(--ink); }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; padding-top:28px; border-top:1px solid var(--line); font-size:13px; color:var(--stone-deep); }

/* ---------- reveal on scroll ---------- */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:translateY(0); }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto; }
}
:focus-visible{ outline:2px solid var(--olive); outline-offset:3px; }
