/* ====== Base & Helpers ====== */
:root{
  --primary-color:#12214d;
  --primary-dark:#9a7502;
  --text-dark:#2c3e50;
  --text-light:#6c757d;
  --bg-soft:#f6f8fb;
  --white:#fff;
  --radius:14px;
  --shadow:0 8px 24px rgba(18,33,77,.08);
  --shadow-lg:0 14px 36px rgba(18,33,77,.12);
}

.page-hero{
  background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-lighter) 100%);
  color:#fff; padding:4rem 0 2rem; text-align:center;
}
.page-hero h1{
  color:var(--white);
  font-weight: 700;
  letter-spacing:.2px;
  margin:0 0 10px;
}
.page-hero p{
  color:var(--white);
  max-width:760px;
  margin:0 auto;
  font-size:1.05rem;
}

/* ====== Intro ====== */
.membership-intro{
  padding: 56px 0;
}
.membership-intro h2{
  color:var(--primary-color);
  font-weight:700;
  margin-bottom:14px;
}
.membership-intro p{
  color:var(--text-dark);
}
.benefits-list{
  margin:18px 0 0;
  padding:0;
  list-style:none;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px 18px;
}
.benefits-list li{
  position:relative;
  padding-left:28px;
  color:#334155;
}
.benefits-list li::before{
  content:"";
  position:absolute; left:0; top:8px;
  width:14px; height:14px; border-radius:50%;
  background: radial-gradient(circle at 30% 30%, #ffd766, #c29a28);
  box-shadow:0 0 0 3px rgba(154,117,2,.12);
}
.membership-intro .img-fluid{
  box-shadow:var(--shadow);
  border-radius:var(--radius);
}

/* ====== Plans ====== */
.membership-plans{
  padding: 40px 0 20px;
}
.membership-plans h2{
  color:var(--primary-color);
  font-weight:800;
}
.membership-card{
  background:var(--white);
  border:1px solid #e9edf5;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  height:100%;
  display:flex; flex-direction:column;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.membership-card:hover{
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color:#dfe6f2;
}
.membership-card .card-header{
  padding:20px 22px 10px;
}
.membership-card h3{
  margin:0 0 6px;
  color:#0f172a;
  font-weight:700;
}
.price{
  display:flex; align-items:flex-end; gap:6px;
  color:var(--primary-color);
  margin:6px 0 6px;
}
.price .currency{ font-size:1.2rem; font-weight:700; line-height:1; }
.price .amount{ font-size:2.4rem; font-weight:800; line-height:.9; }
.price .period{ color:var(--text-light); font-size:.95rem; }

.plan-description{
  color:var(--text-light);
  margin:4px 0 0;
  font-size:.95rem;
}

.membership-card .card-body{
  padding: 6px 22px 10px;
}
.features-list{
  margin:0; padding:0; list-style:none;
  display:grid; gap:8px;
}
.features-list li{
  color:#334155;
  display:flex; gap:10px; align-items:flex-start;
}
.features-list i{ color:#16a34a; margin-top:3px; }

.comparison-table {
    margin: 0 auto;              /* Centra horizontalmente */
    max-width: 900px;            /* Evita que se expanda demasiado */
    width: 100%;
    background: var(--white);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow);
    text-align: center;          /* Centra el contenido de las celdas */
}

.comparison-table th,
.comparison-table td {
    text-align: center;          /* Centra el texto en celdas */
    vertical-align: middle;
}
/* ===== Centrar Preguntas Frecuentes ===== */
.membership-faq {
    display: flex;
    justify-content: center;
}

.membership-faq .container {
    max-width: 900px;            /* Mismo ancho que la tabla */
    width: 100%;
}

.faq-accordion {
    width: 900px;
}

.faq-item {
    background: var(--white);
    border: 1px solid #e9edf5;
    border-radius: var(--radius);
    padding: 16px 18px;
    box-shadow: var(--shadow);
}

.faq-question {
    border-radius: var(--radius);
    margin: 0 0 8px;
    color: var(--white);
    font-weight: 700;
}

.faq-answer {
    margin: 0;
    color: #334155;
}