/* =========================
   PRACTICA · Mundo Bhakti
========================= */

.practice-page{ background:var(--cream); }

/* ================= HERO ================= */

.practice-hero{
  position:relative;
  min-height:88vh;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  overflow:hidden;
  padding:0 0 72px;
}

.practice-hero-bg{
  position:absolute;
  inset:0;
  background:
  radial-gradient(1200px 600px at 30% 25%, rgba(201,163,93,.18), rgba(0,0,0,0) 60%),
  linear-gradient(to bottom,
    rgba(246,241,232,.05),
    rgba(246,241,232,.40),
    rgba(246,241,232,.88)
  ),
  url("/assets/img/hero-practica.jpg") center/cover no-repeat;
  filter:saturate(.85);
  transform:scale(1.06);
}

.practice-hero-vignette{
  position:absolute;
  inset:0;
  background:linear-gradient(to bottom,
    rgba(246,241,232,.10),
    rgba(246,241,232,.55),
    rgba(246,241,232,.92)
  );
}

.practice-hero-inner{
  position:relative;
  text-align:center;
  max-width:880px;
  z-index:2;
}

.practice-kicker{
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(0,0,0,.55);
  margin:0 0 10px;
}

.practice-title{
  font-family:"Crimson Text", serif;
  font-size:48px;
  line-height:1.08;
  margin:0 0 14px;
}

.practice-sub{
  margin:0 auto 26px;
  max-width:720px;
  color:var(--muted);
  font-size:15px;
  line-height:1.75;
}

.practice-hero-actions{
  display:flex;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
}

/* ================= INTRO ================= */

.practice-intro-card{
  max-width:860px;
  margin:0 auto;
  border-radius:var(--radius);
  background:rgba(255,255,255,.82);
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 22px 70px rgba(0,0,0,.06);
  padding:28px 24px;
}

.practice-lead{
  font-family:"Crimson Text", serif;
  font-size:22px;
  line-height:1.55;
  margin:0 0 10px;
}

.practice-body{
  margin:0;
  color:var(--muted);
  line-height:1.8;
}

/* ================= PILARES ================= */

.pillars-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:18px;
}

.pillar-card{
  position:relative;
  overflow:hidden;
  border-radius:var(--radius);
  padding:26px 22px;
  background:linear-gradient(180deg, rgba(255,255,255,.70), rgba(255,255,255,.55));
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 18px 60px rgba(0,0,0,.06);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

/* Decoración (NO interfiere con clicks) */
.pillar-card::before{
  content:"";
  position:absolute;
  inset:-40%;
  background:radial-gradient(circle at 20% 20%, rgba(201,163,93,.16), transparent 55%);
  opacity:.75;
  pointer-events:none;
  transform:translateY(10px);
}

/* 🔒 BLINDAJE: todo el contenido real por encima del decorado */
.pillar-card *{
  position:relative;
  z-index:2;
}

.pillar-card:hover{
  transform:translateY(-4px);
  box-shadow:0 26px 90px rgba(0,0,0,.09);
  border-color:rgba(0,0,0,.14);
}

.pillar-top{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:10px;
  margin-bottom:8px;
}

.pillar-badge{
  font-size:11px;
  letter-spacing:.16em;
  color:rgba(0,0,0,.55);
}

.pillar-card h3{
  font-family:"Crimson Text", serif;
  font-size:26px;
  margin:0;
}

.pillar-sub{
  margin:0 0 14px;
  color:var(--muted);
  line-height:1.7;
}

.pillar-mini{
  margin-top:12px;
}

.mini-kicker{
  display:inline-block;
  font-size:10px;
  letter-spacing:.16em;
  text-transform:uppercase;
  opacity:.55;
  margin-bottom:6px;
}

.pillar-mini p{
  margin:0;
  color:rgba(0,0,0,.72);
  line-height:1.7;
}

/* 🔑 BOTÓN: z-index alto para click 100% fiable */
/* CTA Pilar — unificado para <a> y <button> */
.pillar-more{
  display:inline-flex;
  align-items:center;
  justify-content:center;

  margin-top:16px;
  padding:10px 12px;

  border:none;
  border-radius:999px;
  background:rgba(0,0,0,.06);

  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(0,0,0,.7);

  cursor:pointer;
  text-decoration:none;      /* 🔑 para <a> */
  appearance:none;           /* 🔑 para <button> */
  -webkit-appearance:none;

  transition:
    background .2s ease,
    transform .2s ease;
}

/* Hover idéntico */
.pillar-more:hover{
  background:rgba(0,0,0,.09);
  transform:translateY(-1px);
}

/* Focus accesible y elegante */
.pillar-more:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(201,163,93,.25);
}

/* ================= RITMO ================= */

.rhythm-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:18px;
}

.rhythm-card{
  border-radius:var(--radius);
  padding:26px 22px;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 18px 60px rgba(0,0,0,.06);
}

.rhythm-card .rk{
  display:inline-block;
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(0,0,0,.62);
  margin-bottom:8px;
}

.rhythm-card p{
  margin:0;
  color:var(--muted);
  line-height:1.75;
}

.practice-closer{
  text-align:center;
  max-width:820px;
  margin:26px auto 0;
  font-family:"Crimson Text", serif;
  font-size:20px;
  line-height:1.6;
}

/* ================= VIDA ================= */

.practice-life .life-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:18px;
}

.life-card{
  border-radius:var(--radius);
  padding:26px 22px;
  background:rgba(255,255,255,.70);
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 18px 60px rgba(0,0,0,.06);
  transition:transform .25s ease, box-shadow .25s ease;
}

.life-card:hover{
  transform:translateY(-3px);
  box-shadow:0 26px 90px rgba(0,0,0,.09);
}

.life-card h3{
  font-family:"Crimson Text", serif;
  font-size:24px;
  margin:0 0 8px;
}

.life-card p{
  margin:0;
  color:var(--muted);
  line-height:1.75;
}

/* ================= NOTA ================= */

.note-card{
  max-width:900px;
  margin:0 auto;
  border-radius:var(--radius);
  padding:34px 26px;
  background:linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.70));
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 22px 70px rgba(0,0,0,.06);
  text-align:center;
}

.note-card h2{
  font-family:"Crimson Text", serif;
  font-size:34px;
  margin:0 0 10px;
}

.note-card p{
  margin:0 auto 18px;
  max-width:760px;
  color:var(--muted);
  line-height:1.8;
}

.note-actions{
  display:flex;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
}

/* ================= OVERLAY PILAR ================= */

.pillar-overlay{
  position:fixed;
  inset:0;
  z-index:120;
  background:rgba(14,15,18,.22);
  display:none; /* 👈 en vez de hidden */
  align-items:flex-end;
  justify-content:center;
  padding:18px;
  opacity:0;
  transform:translateY(8px);
  transition:opacity .18s ease, transform .18s ease;
}

.pillar-overlay.is-open{
  opacity:1;
  transform:none;
}

.pillar-modal{
  width:min(720px, 100%);
  border-radius:24px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(0,0,0,.10);
  box-shadow:0 26px 120px rgba(0,0,0,.18);
  padding:18px 18px 16px;
}

.pm-close{
  border:none;
  background:none;
  font-size:22px;
  opacity:.45;
  cursor:pointer;
  float:right;
}

.pm-close:hover{ opacity:.85; }

.pm-body{ padding:10px 6px 6px; }

.pm-kicker{
  font-size:10px;
  letter-spacing:.16em;
  text-transform:uppercase;
  opacity:.55;
  margin:0 0 6px;
}

.pm-title{
  font-family:"Crimson Text", serif;
  font-size:28px;
  margin:0 0 8px;
}

.pm-text{
  margin:0 0 14px;
  color:var(--muted);
  line-height:1.8;
}

.pm-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

/* ================= RESPONSIVE ================= */

@media (max-width: 980px){
  .practice-title{ font-size:40px; }
  .pillars-grid,
  .rhythm-grid,
  .practice-life .life-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width: 640px){
  .practice-hero{ min-height:80vh; padding-bottom:56px; }
  .practice-title{ font-size:34px; }
  .practice-sub{ font-size:14px; }
}