/* ---------- Tokens ---------- */
:root{
  --cream: #FBF6EC;
  --cream-alt: #F2E9DA;
  --paper: #FFFDF8;
  --ink: #2B2620;
  --ink-soft: #5B5348;
  --sage: #6E8B74;
  --sage-deep: #465C49;
  --sage-pale: #DCE6DD;
  --clay: #C97C5D;
  --clay-deep: #A85F42;
  --clay-pale: #F0DACE;
  --gold: #C9A15C;
  --line: rgba(43,38,32,0.12);
  --shadow: 0 20px 50px -20px rgba(43,38,32,0.25);

  --font-display: "Fraunces", serif;
  --font-body: "Instrument Sans", sans-serif;

  --radius: 22px;
  --wrap: 1180px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3{ font-family:var(--font-display); color:var(--ink); margin:0; font-weight:600; letter-spacing:-0.01em; }
p{ margin:0; }

.wrap{ max-width:var(--wrap); margin:0 auto; padding:0 28px; }

/* grain texture overlay */
.grain{
  position:fixed; inset:0; z-index:999; pointer-events:none; opacity:0.045; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.demo-tag{
  position:fixed; bottom:16px; right:16px; z-index:1000;
  background:var(--ink); color:var(--cream); font-size:12px; padding:8px 14px;
  border-radius:999px; opacity:0.82; letter-spacing:0.02em; box-shadow:var(--shadow);
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:15px 28px; border-radius:100px; font-weight:600; font-size:15px;
  border:1px solid transparent; cursor:pointer; transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
  white-space:nowrap;
}
.btn-primary{ background:var(--clay); color:var(--paper); box-shadow:0 10px 26px -10px rgba(169,95,66,0.55); }
.btn-primary:hover{ background:var(--clay-deep); transform:translateY(-2px); }
.btn-ghost{ color:var(--sage-deep); font-weight:600; }
.btn-ghost:hover{ color:var(--clay-deep); }
.btn-outline{ border-color:var(--line); color:var(--ink); background:transparent; }
.btn-outline:hover{ border-color:var(--sage); color:var(--sage-deep); }
.btn-light{ background:var(--paper); color:var(--sage-deep); }
.btn-light:hover{ transform:translateY(-2px); }
.btn-sm{ padding:10px 20px; font-size:14px; }
.btn-block{ width:100%; }

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:200;
  background:rgba(251,246,236,0.86); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; height:78px; }
.logo{ font-family:var(--font-display); font-size:24px; font-weight:600; color:var(--sage-deep); }
.logo-dot{ color:var(--clay); }
.nav{ display:flex; gap:34px; }
.nav a{ font-size:15px; font-weight:500; color:var(--ink-soft); transition:color .2s; }
.nav a:hover{ color:var(--clay-deep); }
.header-actions{ display:flex; align-items:center; gap:14px; }
.nav-toggle{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px; }
.nav-toggle span{ width:22px; height:2px; background:var(--ink); border-radius:2px; }

/* ---------- Hero ---------- */
.hero{ position:relative; padding:88px 0 90px; overflow:hidden; }
.hero-blob{
  position:absolute; top:-220px; right:-160px; width:640px; height:640px; border-radius:50%;
  background:radial-gradient(circle at 30% 30%, var(--sage-pale), transparent 70%),
             radial-gradient(circle at 70% 70%, var(--clay-pale), transparent 65%);
  filter:blur(8px); opacity:0.9; z-index:0;
}
.hero-inner{ position:relative; z-index:1; display:grid; grid-template-columns:1.1fr 0.9fr; gap:50px; align-items:center; }
.eyebrow{ font-size:13px; text-transform:uppercase; letter-spacing:0.14em; color:var(--sage-deep); font-weight:600; margin:0 0 14px; }
.eyebrow.center{ text-align:center; }
h1{ font-size:clamp(2.4rem, 4.4vw, 3.6rem); line-height:1.08; }
h1 em{ font-style:italic; color:var(--clay-deep); }
.hero-lead{ margin-top:22px; font-size:18px; color:var(--ink-soft); max-width:46ch; }
.hero-actions{ display:flex; align-items:center; gap:24px; margin-top:34px; flex-wrap:wrap; }
.hero-stats{ display:flex; gap:38px; margin-top:56px; flex-wrap:wrap; }
.stat strong{ display:block; font-family:var(--font-display); font-size:28px; color:var(--ink); }
.stat span{ font-size:13px; color:var(--ink-soft); }

.hero-visual{ position:relative; height:420px; }
.hero-swirl{ position:absolute; inset:0; width:100%; height:100%; color:var(--sage); }
.orbit-card{
  position:absolute; width:172px; background:var(--paper); border-radius:18px; padding:18px;
  box-shadow:var(--shadow); text-align:left; animation:float 7s ease-in-out infinite;
}
.card-a{ top:18px; left:10px; animation-delay:0s; }
.card-b{ bottom:24px; right:0; animation-delay:2.4s; }
@keyframes float{ 0%,100%{ transform:translateY(0px);} 50%{ transform:translateY(-14px);} }
.orbit-name{ font-weight:600; margin-top:10px; font-size:14px; }
.orbit-role{ font-size:12.5px; color:var(--ink-soft); margin-top:2px; }

.avatar{
  width:44px; height:44px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:600; font-size:15px; color:var(--paper); flex-shrink:0;
}
.avatar-clay{ background:var(--clay); }
.avatar-sage{ background:var(--sage-deep); }
.avatar-gold{ background:var(--gold); }

/* ---------- Sections ---------- */
.section{ padding:96px 0; }
.section-alt{ background:var(--cream-alt); }
.center{ text-align:center; }
h2{ font-size:clamp(1.8rem, 3vw, 2.5rem); margin-bottom:14px; }
.section-lead{ max-width:56ch; margin:0 auto 50px; color:var(--ink-soft); font-size:17px; }
.section > .wrap > h2.center{ margin-bottom:12px; }

/* steps */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:36px; margin-top:56px; }
.step{ position:relative; padding:30px 26px; background:var(--paper); border-radius:var(--radius); border:1px solid var(--line); }
.step-num{ font-family:var(--font-display); font-size:38px; color:var(--sage-pale); -webkit-text-stroke:1.5px var(--sage); display:block; margin-bottom:10px; }
.step h3{ font-size:20px; margin-bottom:10px; }
.step p{ color:var(--ink-soft); font-size:15px; }

/* quiz */
.quiz-wrap{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:56px; align-items:start; }
.quiz-card{
  background:var(--paper); border-radius:var(--radius); padding:40px; box-shadow:var(--shadow); min-height:280px;
}
.quiz-question{ font-family:var(--font-display); font-size:22px; margin-bottom:22px; }
.quiz-options{ display:flex; flex-direction:column; gap:12px; }
.quiz-opt{
  text-align:left; padding:14px 18px; border-radius:14px; border:1px solid var(--line); background:transparent;
  font-family:var(--font-body); font-size:15.5px; cursor:pointer; transition:all .2s;
}
.quiz-opt:hover{ border-color:var(--sage); background:var(--sage-pale); }
.quiz-progress{ display:flex; gap:6px; margin-bottom:26px; }
.quiz-progress span{ height:5px; flex:1; border-radius:4px; background:var(--line); }
.quiz-progress span.done{ background:var(--sage); }
.quiz-result-tag{ font-size:13px; text-transform:uppercase; letter-spacing:0.1em; color:var(--clay-deep); font-weight:600; }
.quiz-result h3{ font-size:26px; margin:10px 0 12px; }
.quiz-result p{ color:var(--ink-soft); margin-bottom:24px; }
.quiz-restart{ font-size:14px; color:var(--sage-deep); font-weight:600; cursor:pointer; background:none; border:none; margin-top:18px; }

/* directorio */
.grid-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; margin-top:48px; }
.psych-card{
  background:var(--paper); border-radius:var(--radius); padding:28px; border:1px solid var(--line);
  display:flex; flex-direction:column; gap:18px; transition:transform .25s ease, box-shadow .25s ease;
}
.psych-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.psych-top{ display:flex; gap:14px; align-items:center; }
.psych-top h3{ font-size:17px; }
.psych-title{ font-size:13px; color:var(--ink-soft); margin-top:2px; }
.tags{ display:flex; gap:8px; flex-wrap:wrap; }
.tag{ font-size:12px; background:var(--sage-pale); color:var(--sage-deep); padding:5px 12px; border-radius:100px; font-weight:600; }
.psych-quote{ font-style:italic; color:var(--ink-soft); font-size:14.5px; border-left:2px solid var(--clay-pale); padding-left:14px; }
.psych-foot{ display:flex; align-items:center; justify-content:space-between; margin-top:auto; padding-top:6px; border-top:1px solid var(--line); }
.price{ font-family:var(--font-display); font-weight:600; font-size:17px; }
.price small{ font-family:var(--font-body); font-weight:400; color:var(--ink-soft); font-size:12px; }

/* pricing */
.pricing-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; margin-top:50px; }
.price-card{
  position:relative; background:var(--paper); border-radius:var(--radius); padding:36px 30px; border:1px solid var(--line); text-align:center;
}
.price-card.featured{ background:var(--sage-deep); color:var(--paper); border-color:var(--sage-deep); transform:scale(1.04); box-shadow:var(--shadow); }
.price-card.featured h3, .price-card.featured .price-tag{ color:var(--paper); }
.price-card.featured .price-desc{ color:rgba(255,253,248,0.8); }
.badge{ position:absolute; top:-14px; left:50%; transform:translateX(-50%); background:var(--clay); color:var(--paper); font-size:12px; font-weight:700; padding:6px 16px; border-radius:100px; }
.price-card h3{ font-size:19px; margin-bottom:14px; }
.price-tag{ font-family:var(--font-display); font-size:32px; margin-bottom:14px; }
.price-tag small{ font-family:var(--font-body); font-size:14px; font-weight:400; opacity:0.75; }
.price-desc{ color:var(--ink-soft); font-size:14.5px; margin-bottom:26px; min-height:44px; }
.pricing-note{ text-align:center; margin-top:40px; color:var(--ink-soft); font-size:14px; }

/* testimonios */
.testimonial-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; margin-top:50px; }
.testimonial{ margin:0; padding:34px 28px; background:var(--paper); border-radius:var(--radius); border:1px solid var(--line); position:relative; }
.testimonial p{ font-family:var(--font-display); font-size:19px; font-style:italic; line-height:1.4; color:var(--ink); }
.testimonial cite{ display:block; margin-top:18px; font-style:normal; font-size:13.5px; color:var(--ink-soft); font-weight:600; }

/* cta final */
.cta-final{ background:var(--ink); color:var(--cream); padding:100px 0; text-align:center; }
.cta-final h2{ color:var(--cream); font-size:clamp(2rem,4vw,3rem); }
.cta-final p{ color:rgba(251,246,236,0.7); margin:16px 0 34px; font-size:17px; }

/* footer */
.site-footer{ background:var(--cream-alt); padding:64px 0 0; }
.footer-inner{ display:flex; justify-content:space-between; align-items:flex-start; padding-bottom:40px; border-bottom:1px solid var(--line); flex-wrap:wrap; gap:24px; }
.footer-tag{ margin-top:10px; color:var(--ink-soft); font-size:14px; max-width:32ch; }
.footer-nav{ display:flex; gap:26px; flex-wrap:wrap; }
.footer-nav a{ font-size:14px; color:var(--ink-soft); }
.footer-nav a:hover{ color:var(--clay-deep); }
.footer-bottom{ padding:24px 0; }
.footer-bottom p{ font-size:12.5px; color:var(--ink-soft); text-align:center; }

/* ---------- Responsive ---------- */
@media (max-width: 900px){
  .hero-inner{ grid-template-columns:1fr; }
  .hero-visual{ height:280px; margin-top:20px; }
  .quiz-wrap{ grid-template-columns:1fr; }
  .steps, .grid-cards, .pricing-grid, .testimonial-grid{ grid-template-columns:1fr; }
  .price-card.featured{ transform:none; }
  .nav{
    position:absolute; top:78px; left:0; right:0; background:var(--paper);
    flex-direction:column; padding:20px 28px; gap:18px; border-bottom:1px solid var(--line);
    transform:translateY(-12px); opacity:0; pointer-events:none; transition:all .25s ease;
  }
  .nav.open{ transform:translateY(0); opacity:1; pointer-events:auto; }
  .nav-toggle{ display:flex; }
  .header-actions .btn-primary.btn-sm{ display:none; }
}
@media (max-width: 520px){
  .hero-stats{ gap:24px; }
  .demo-tag{ left:16px; right:16px; text-align:center; }
}
