.elementor-220 .elementor-element.elementor-element-ae736fa{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--margin-top:35px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}.elementor-220 .elementor-element.elementor-element-3a6e4f6{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-220 .elementor-element.elementor-element-c649fb8{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-220 .elementor-element.elementor-element-39da696{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-220 .elementor-element.elementor-element-3454f81{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}:root{--page-title-display:none;}@media(min-width:768px){.elementor-220 .elementor-element.elementor-element-3a6e4f6{--width:25%;}.elementor-220 .elementor-element.elementor-element-c649fb8{--width:25%;}.elementor-220 .elementor-element.elementor-element-39da696{--width:25%;}.elementor-220 .elementor-element.elementor-element-3454f81{--width:25%;}}/* Start custom CSS for html, class: .elementor-element-8b96183 */.membership-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px,1fr));
  gap: 30px;
  margin: 40px auto; /* Changed to auto for horizontal centering */
  max-width: 1200px; /* Limit max width */
  padding: 0 20px; /* Add padding for mobile */
}
.membership-card {
  background: #fff;
  border-radius: 12px;
  padding: 30px 25px;
  text-align: center;
  box-shadow: 0 4px 20px rgba(0,0,0,0.08);
  transition: transform .3s ease, box-shadow .3s ease;
  position: relative;
}
.membership-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 30px rgba(0,0,0,0.12);
}
.membership-card h3 {
  font-size: 26px;
  margin-bottom: 10px;
  color: #1a1a1a;
  font-weight: 600;
}
.price {
  font-size: 36px;
  font-weight: bold;
  color: #ff6b35;
  margin-bottom: 20px;
}
.price span { 
  font-size: 16px; 
  color: #666;
  font-weight: normal;
}
.badge {
  position: absolute;
  top: -10px;
  right: 20px;
  background: #ff6b35;
  color: white;
  padding: 5px 15px;
  border-radius: 20px;
  font-size: 13px;
  font-weight: bold;
}
.features h4 {
  font-size: 16px;
  color: #333;
  margin-bottom: 15px;
  line-height: 1.4;
}
.features ul {
  list-style: none;
  padding: 0;
  margin: 20px 0 30px;
  text-align: left;
}
.features li {
  margin: 10px 0;
  color: #555;
  font-size: 14px;
  line-height: 1.5;
}
.subscribe-btn {
  background: #ff6b35;
  color: #fff;
  border: none;
  border-radius: 25px;
  padding: 14px 35px;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  transition: background .3s ease;
  width: 100%;
  max-width: 200px;
}
.subscribe-btn:hover {
  background: #e55a2b;
}
.subscribe-btn:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

/* Plan accents */
.basic    { border-top: 4px solid #4CAF50; }
.quarterly{ border-top: 4px solid #2196F3; }
.quarterly .badge { background: #2196F3; }
.semi-annual { border-top: 4px solid #FF9800; }
.semi-annual .badge { background: #FF9800; }
.yearly   { border-top: 4px solid #9C27B0; }
.yearly .badge { background: #9C27B0; }

/* Center grid when less than 4 cards */
@media (min-width: 1200px) {
  .membership-grid {
    grid-template-columns: repeat(4, minmax(250px, 300px));
    justify-content: center;
  }
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .membership-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .membership-card {
    max-width: 400px;
    margin: 0 auto;
  }
}/* End custom CSS */
/* Start custom CSS *//* =========================
   MEMBERSHIP CARD CONTAINER
   ========================= */

.membership-card {
  background: #fff;
  border-radius: 18px;
  border-top: 4px solid #b69a55;
  /* Increased top padding for badge */
  padding: 54px 24px 28px 24px;
  text-align: center;
  box-shadow: 0 4px 20px rgba(0,0,0,0.07);
  position: relative;
  width: 100%;
  box-sizing: border-box;
  margin-bottom: 42px;
  transition: box-shadow 0.3s, transform 0.3s;
  min-width: 260px;
  max-width: 350px;
  display: inline-block;
  margin-right: 16px;
}
.membership-card:last-child { margin-right: 0; }

.membership-card:hover {
  box-shadow: 0 8px 32px rgba(182,154,85,0.18);
  transform: translateY(-4px) scale(1.03);
  z-index: 2;
}

/* ====================
   BADGE / PROMO BANNER
   ==================== */
.badge {
  position: absolute;
  top: -32px; /* Raised badge up for more clearance */
  left: 50%;
  transform: translateX(-50%);
  background: #b69a55 !important;
  color: #fff !important;
  padding: 7px 28px;
  border-radius: 22px;
  font-size: 14px;
  font-weight: 700;
  border: none;
  letter-spacing: 0.5px;
  box-shadow: 0 2px 8px rgba(182,154,85,0.15);
  z-index: 2;
}

/* ==========
   HEADINGS
   ========== */
.membership-card h3 {
  font-size: 1.75rem;
  margin: 18px 0 12px 0;
  color: #1a1a1a;
  font-weight: 700;
  letter-spacing: 0.2px;
}

/* ==========
   PRICE BLOCK
   ========== */
.price {
  font-size: 2.2rem;
  font-weight: 800;
  color: #b69a55;
  margin: 7px 0 0 0;
  line-height: 1.15;
}
.price span {
  font-size: 0.98rem;
  color: #444;
  margin-left: 2px;
  font-weight: 400;
}

/* ========
   FEATURES
   ======== */
.features h4 {
  font-size: 1.01rem;
  color: #222;
  margin: 20px auto 15px auto;
  font-weight: 600;
  line-height: 1.3;
}
.features ul {
  list-style: none;
  padding: 0;
  margin: 12px 0 0 0;
  text-align: left;
  display: inline-block;
}
.features li {
  margin: 9px 0 7px 0;
  color: #555;
  font-size: 0.98rem;
  line-height: 1.47;
  padding-left: 22px;
  position: relative;
  letter-spacing: 0.04em;
}
.features li:before {
  content: "✓";
  position: absolute;
  left: 0;
  color: #b69a55;
  font-weight: bold;
  font-size: 1.13em;
}

/* ===================
   RENEWAL INFO NOTICE
   =================== */
.renewal-info {
  font-size: 0.90rem;
  color: #aa9c7a;
  font-style: italic;
  margin: 17px 0 0 0;
  line-height: 1.36;
  letter-spacing: 0.02em;
}

/* ===============
   JOIN BUTTON
   =============== */
.subscribe-btn {
  background: #b69a55;
  color: #fff;
  border: none;
  border-radius: 30px;
  padding: 15px 36px;
  font-size: 1.16rem;
  font-weight: 700;
  cursor: pointer;
  margin-top: 22px;
  width: 90%;
  max-width: 250px;
  box-shadow: 0 2px 8px rgba(182,154,85,0.10);
  letter-spacing: 1px;
  transition: background 0.23s, box-shadow 0.23s;
}
.subscribe-btn:hover {
  background: #9d8347;
  color: #fff;
  box-shadow: 0 4px 18px rgba(182,154,85,0.17);
}
/* Disabled Button Styling */
.subscribe-btn:disabled, .subscribe-btn[aria-disabled="true"] {
  opacity: 0.7;
  cursor: not-allowed;
}

/* Responsive Mobile */
@media (max-width: 1020px) {
  .membership-card { display: block; margin: 0 auto 35px auto; max-width: 97%; }
}

@media (max-width: 600px) {
  .membership-card {
    padding: 36px 7px 18px 7px; /* extra top padding on small screens */
    min-width: unset;
    box-shadow: 0 2px 10px rgba(182,154,85,0.12);
  }
  .badge { font-size: 11px; padding: 5px 15px; top: -19px; }
  .membership-card h3 { font-size: 1.33rem; }
  .price { font-size: 1.45rem; }
  .features ul { font-size: 0.97rem; }
  .subscribe-btn { font-size: 1.01rem; padding: 11px 8px; }
}

/* For all badges: center, allow text to break only if needed */
.badge {
  white-space: nowrap;
  text-align: center;
}

/* Force .badge to two lines only for Best Value Save 66% */
.badge:contains("Best Value Save 66%") {
  white-space: normal;  /* allow wrapping */
  width: 106px;         /* just enough for two lines; tweak as needed */
  min-height: 48px;     /* visually matches other badges */
  line-height: 1.18;
  padding-top: 10px;
  padding-bottom: 10px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* Responsive adjustment for mobile screens */
@media (max-width: 600px) {
  .badge:contains("Best Value Save 66%") {
    width: 80px;
    min-height: 38px;
    font-size: 11px;
    padding-top: 6px;
    padding-bottom: 6px;
  }
}/* End custom CSS */