/* ============================================================
   TikRay — pages.css
   Estilos específicos de cada página/sección.
   ============================================================ */

/* ---------- HERO (inicio) ---------- */
.hero {
  min-height: 100svh;
  display: flex;
  align-items: center;
  padding-top: var(--nav-h);
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 4rem;
  align-items: center;
}
.hero p.lead {
  font-size: 1.2rem;
  color: var(--muted);
  max-width: 480px;
  margin: 1.6rem 0 2.4rem;
}
.hero-ctas { display: flex; gap: 1rem; flex-wrap: wrap; }

.hero-note {
  margin-top: 2.2rem;
  font-size: 0.88rem;
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* El chat del hero flota ligeramente */
.hero-chat {
  animation: float 7s ease-in-out infinite;
}
@keyframes float {
  0%, 100% { transform: translateY(0) rotate(0.4deg); }
  50% { transform: translateY(-14px) rotate(-0.4deg); }
}

/* ---------- Sección "cómo funciona" ---------- */
.steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  counter-reset: step;
}
.step {
  position: relative;
  padding: 2.2rem 1.8rem 1.8rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
}
.step::before {
  counter-increment: step;
  content: "0" counter(step);
  font-family: var(--font-display);
  font-size: 3.4rem;
  font-weight: 700;
  line-height: 1;
  display: block;
  margin-bottom: 1.1rem;
  -webkit-text-stroke: 1.5px rgba(167, 139, 250, 0.55);
  color: transparent;
}
.step h3 { font-size: 1.18rem; margin-bottom: 0.5rem; }
.step p { color: var(--muted); font-size: 0.95rem; }

/* ---------- Bento de características ---------- */
.bento {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: minmax(190px, auto);
  gap: 1.3rem;
}
.bento .card.wide { grid-column: span 2; }
.bento .card.tall { grid-row: span 2; display: flex; flex-direction: column; justify-content: flex-end; }
.bento .card.tall .big-number {
  font-family: var(--font-display);
  font-size: clamp(3.5rem, 6vw, 5.5rem);
  font-weight: 700;
  background: var(--gradient);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  line-height: 1;
  margin-bottom: 0.8rem;
}

/* ---------- Sección demo ---------- */
.demo-section { position: relative; }
.demo-grid {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 3.5rem;
  align-items: start;
}
.persona-tabs {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
  margin-top: 2rem;
}
.persona-tab {
  display: flex;
  align-items: center;
  gap: 1rem;
  text-align: left;
  padding: 1.1rem 1.3rem;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: var(--surface);
  transition: all 0.25s ease;
}
.persona-tab .emoji { font-size: 1.6rem; }
.persona-tab strong { font-family: var(--font-display); display: block; font-size: 1rem; }
.persona-tab small { color: var(--muted); font-size: 0.83rem; }
.persona-tab:hover { border-color: rgba(167, 139, 250, 0.5); }
.persona-tab.active {
  border-color: var(--violet);
  background: linear-gradient(100deg, rgba(34, 211, 238, 0.08), rgba(167, 139, 250, 0.1));
  box-shadow: 0 0 0 1px var(--violet), 0 8px 30px rgba(167, 139, 250, 0.15);
}

/* ---------- Banda CTA final ---------- */
.cta-band {
  text-align: center;
  padding: clamp(4rem, 8vw, 7rem) 2rem;
  border: 1px solid var(--border);
  border-radius: 28px;
  background:
    radial-gradient(ellipse at 50% 120%, rgba(167, 139, 250, 0.22), transparent 60%),
    var(--surface);
  overflow: hidden;
  position: relative;
}
.cta-band h2 { font-size: clamp(2rem, 4.5vw, 3.2rem); margin-bottom: 1rem; }
.cta-band p { color: var(--muted); margin-bottom: 2.2rem; }

/* ---------- Cabecera de páginas interiores ---------- */
.page-head {
  padding: calc(var(--nav-h) + clamp(3.5rem, 8vw, 6rem)) 0 clamp(2.5rem, 5vw, 4rem);
}
.page-head h1 { font-size: clamp(2.4rem, 5.5vw, 4rem); max-width: 800px; }
.page-head p {
  color: var(--muted);
  font-size: 1.15rem;
  max-width: 620px;
  margin-top: 1.3rem;
}

/* ---------- Página: Qué ofrecemos ---------- */
.offer-list { display: flex; flex-direction: column; gap: 1.3rem; }
.offer-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 1.6rem;
  align-items: center;
  padding: 1.8rem 2rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  transition: border-color 0.25s;
}
.offer-item:hover { border-color: rgba(34, 211, 238, 0.45); }
.offer-item .num {
  font-family: var(--font-display);
  font-size: 1rem;
  color: var(--cyan);
}
.offer-item h3 { font-size: 1.3rem; margin-bottom: 0.35rem; }
.offer-item p { color: var(--muted); font-size: 0.96rem; max-width: 560px; }
.offer-item .tag {
  font-size: 0.75rem;
  font-family: var(--font-display);
  padding: 0.35rem 0.8rem;
  border-radius: 99px;
  border: 1px solid var(--border);
  color: var(--muted);
  white-space: nowrap;
}
.offer-item .tag.soon { border-color: rgba(244, 114, 182, 0.4); color: var(--pink); }

/* Planes */
.plans {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  align-items: stretch;
}
.plan {
  display: flex;
  flex-direction: column;
  padding: 2.3rem 2rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
}
.plan.featured {
  border-color: var(--violet);
  background: linear-gradient(160deg, rgba(167, 139, 250, 0.1), rgba(34, 211, 238, 0.05));
  box-shadow: 0 20px 60px rgba(167, 139, 250, 0.18);
}
.plan .plan-name { font-family: var(--font-display); font-size: 1.05rem; color: var(--muted); }
.plan .price {
  font-family: var(--font-display);
  font-size: 2.6rem;
  font-weight: 700;
  margin: 0.6rem 0 1.4rem;
}
.plan .price small { font-size: 1rem; color: var(--muted); font-weight: 400; }
.plan ul { flex: 1; margin-bottom: 1.8rem; }
.plan li {
  padding: 0.45rem 0;
  font-size: 0.94rem;
  color: var(--muted);
  display: flex;
  gap: 0.6rem;
}
.plan li::before { content: "→"; color: var(--cyan); }

/* ---------- Página: Sobre nosotros ---------- */
.about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: start;
}
.about-grid .prose p { color: var(--muted); margin-bottom: 1.2rem; }
.values { display: flex; flex-direction: column; gap: 1.2rem; }

.team {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.5rem;
}
.member { text-align: center; padding: 2.4rem 1.5rem; }
.member .avatar {
  width: 84px;
  height: 84px;
  margin: 0 auto 1.2rem;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  font-size: 1.7rem;
  font-weight: 700;
  color: #0a0a12;
  background: var(--gradient);
}
.member h3 { font-size: 1.1rem; }
.member p { font-size: 0.88rem; }

/* ---------- Página: Contacto ---------- */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 4rem;
  align-items: start;
}
.contact-channels { display: flex; flex-direction: column; gap: 1.1rem; margin-top: 2rem; }
.channel {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.1rem 1.3rem;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: var(--surface);
}
.channel-icon { display: grid; place-items: center; flex-shrink: 0; }
.channel-icon svg { width: 26px; height: 26px; }
.channel strong { font-family: var(--font-display); font-size: 0.95rem; display: block; }
.channel a, .channel span.detail { color: var(--muted); font-size: 0.9rem; }
.channel a:hover { color: var(--cyan); }

.form-card { padding: 2.5rem; }
.form-success {
  display: none;
  text-align: center;
  padding: 3rem 1rem;
}
.form-success.show { display: block; }
.form-success .check {
  font-size: 3rem;
  display: block;
  margin-bottom: 1rem;
}

/* ---------- Página: Privacidad ---------- */
.legal {
  max-width: 760px;
}
.legal h2 {
  font-size: 1.45rem;
  margin: 2.6rem 0 0.9rem;
}
.legal p, .legal li { color: var(--muted); margin-bottom: 0.9rem; }
.legal ul { padding-left: 1.3rem; list-style: disc; }
.legal .updated {
  font-size: 0.88rem;
  border: 1px solid var(--border);
  border-radius: 99px;
  display: inline-block;
  padding: 0.4rem 1.1rem;
  margin-bottom: 2rem;
}

/* ---------- Responsive ---------- */
@media (max-width: 980px) {
  .hero-grid, .demo-grid, .about-grid, .contact-grid { grid-template-columns: 1fr; gap: 3rem; }
  .hero { min-height: auto; padding-top: calc(var(--nav-h) + 4rem); padding-bottom: 3rem; }
  .bento { grid-template-columns: 1fr 1fr; }
  .steps, .plans { grid-template-columns: 1fr; }
  .persona-tabs { flex-direction: row; flex-wrap: wrap; }
  .persona-tab { flex: 1 1 200px; }
}
@media (max-width: 600px) {
  .bento { grid-template-columns: 1fr; }
  .bento .card.wide { grid-column: span 1; }
  .offer-item { grid-template-columns: 1fr; gap: 0.8rem; }
}
