/* Brand List Container */
.brand-list {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 15px;
}

.brand-list,
.brand-list *,
.brand-list *::before,
.brand-list *::after {
  box-sizing: border-box;
}

.brand-list strong {
  font-weight: 700;
}

/* Brand Card - default template */
#brand-card-default.brand-card {
  display: grid;
  grid-template-areas: "intro description benefits rating payment cta";
  grid-template-columns: 120px 1.5fr 1.2fr 0.8fr 1fr 180px;
  background: #fff;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  padding: 20px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  gap: 20px;
  box-sizing: border-box;
  margin: 20px 0;
  align-items: center;
  position: relative;
}

#brand-card-default .list-number {
  position: absolute;
  top: -10px;
  left: -10px;
  background-color: #ff5a7a;
  color: #fff;
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 16px;
}

/* Grid Areas */
#brand-card-default .brand-intro { 
  grid-area: intro;
}

#brand-card-default .brand-description { 
  grid-area: description;
}

#brand-card-default .brand-cta-block { 
  grid-area: benefits;
}

#brand-card-default .brand-rating { 
  grid-area: rating;
}

#brand-card-default .brand-payment { 
  grid-area: payment;
}

#brand-card-default .brand-cta { 
  grid-area: cta;
}

/* Logo Section */
#brand-card-default .brand-logo {
  width: 100%;
  height: 80px;
  padding: 10px;
  border-radius: 6px;
  border: 1px solid #e0e0e0;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
}

#brand-card-default .brand-intro img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* Description/Offer */
#brand-card-default .brand-description p {
  font-size: 18px;
  font-weight: 700;
  color: #333;
  padding: 0;
  margin: 0;
  line-height: 1.3;
}

/* Benefits List */
#brand-card-default .brand-cta-block ul {
  display: flex;
  flex-direction: column;
  gap: 8px;
  list-style: none;
  margin: 0;
  padding: 0;
}

#brand-card-default .brand-cta-block li {
  font-size: 13px;
  color: #2d7a3d;
  display: flex;
  align-items: center;
  line-height: 1.4;
}

#brand-card-default .brand-cta-block li::before {
  content: "✓";
  margin-right: 8px;
  color: #2d7a3d;
  font-weight: bold;
  font-size: 14px;
}

/* Rating Section */
#brand-card-default .brand-rating h3 {
  margin: 0 0 5px 0;
  font-size: 16px;
  color: var(--brand-title, #333);
  font-weight: 700;
}

#brand-card-default .brand-rating p {
  margin: 0;
  font-size: 14px;
  color: #666;
}

#brand-card-default .brand-rating p strong {
  color: #333;
}

/* Payment Methods */
#brand-card-default .brand-payment h3 {
  margin: 0 0 5px 0;
  font-weight: 600;
  font-size: 14px;
  color: #333;
}

#brand-card-default .brand-payment p {
  margin: 0;
  font-size: 13px;
  color: #666;
}

/* CTA Button */
#brand-card-default .brand-cta {
  text-align: center;
}

#brand-card-default .brand-link {
  display: inline-block;
  width: 100%;
  max-width: 160px;
  font-size: 16px;
  color: #fff !important;
  padding: 12px 20px;
  border-radius: 6px;
  font-weight: 600;
  text-decoration: none !important;
  transition: all 0.2s ease-in-out;
  text-align: center;
  background: var(--bg-color);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

#brand-card-default .brand-link:hover {
  box-shadow: 0 3px 6px rgba(30, 29, 29, 0.4);
  background: var(--hover-color);
}

/* No Brands Message */
#brand-card-default .no-brands-message {
  text-align: center;
  padding: 40px 20px;
  color: #666;
  font-size: 16px;
}

/* RESPONSIVE TABLET */
@media (max-width: 968px) {
  #brand-card-default.brand-card {
    grid-template-areas:
      "intro description benefits"
      "rating payment cta";
    grid-template-columns: 100px 1fr 1fr;
    grid-template-rows: auto auto;
    gap: 15px 15px;
    padding: 15px;
  }

  #brand-card-default .brand-intro {
    grid-row: 1 / 2;
    align-self: start;
  }

  #brand-card-default .brand-cta {
    grid-row: 2 / 3;
    align-self: start;
    justify-self: end;
  }

  #brand-card-default .brand-description p {
    font-size: 16px;
  }

  #brand-card-default .brand-cta-block {
    justify-self: end;
  }

  #brand-card-default .brand-cta-block li {
    font-size: 12px;
  }
}

/* RESPONSIVE MOBILE */
@media (max-width: 640px) {
  #brand-card-default .brand-list {
    padding: 0 10px;
  }

  #brand-card-default.brand-card {
    grid-template-areas:
      "intro description"
      "benefits benefits"
      "rating payment"
      "cta cta";
    grid-template-columns: 100px 1fr;
    grid-template-rows: auto auto auto auto;
    padding: 15px;
    gap: 12px;
    margin-bottom: 12px;
  }

  /* Center logo */
  #brand-card-default .brand-intro {
    text-align: center;
  }

  #brand-card-default .brand-logo {
    height: 70px;
    padding: 8px;
  }

  /* Center description */
  #brand-card-default .brand-description {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
  }

  #brand-card-default .brand-description p {
    font-size: 15px;
  }

  /* Center benefits */
  #brand-card-default .brand-cta-block {
    text-align: center;
    justify-self: unset;
  }

  #brand-card-default .brand-cta-block ul {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    justify-items: self-start;
  }

  #brand-card-default .brand-cta-block li {
    font-size: 12px;
    justify-content: center;
  }

  /* Center rating and payment */
  #brand-card-default .brand-rating,
  #brand-card-default .brand-payment {
    text-align: center;
  }

  #brand-card-default .brand-rating h3,
  #brand-card-default .brand-payment h3 {
    font-size: 14px;
  }

  #brand-card-default .brand-rating p,
  #brand-card-default .brand-payment p {
    font-size: 12px;
  }

  /* CTA full width */

  #brand-card-default .brand-cta {
    grid-row: 4 / 4;
    justify-self: unset;
  }

  #brand-card-default .brand-link {
    max-width: 100%;
    width: 100%;
    padding: 14px 20px;
    font-size: 15px;
  }
}

/* RESPONSIVE SMALL MOBILE (480px and below) */
@media (max-width: 480px) {
  #brand-card-default .brand-list {
    padding: 0 8px;
  }

  #brand-card-default.brand-card {
    grid-template-areas:
      "intro"
      "description"
      "benefits"
      "rating"
      "payment"
      "cta";
    grid-template-columns: 1fr;
    padding: 12px;
    gap: 12px;
    margin-bottom: 10px;
  }

  /* Center everything on small mobile */
  #brand-card-default .brand-intro {
    text-align: center;
  }

  #brand-card-default .brand-logo {
    margin: 0 auto;
    max-width: 140px;
    height: 80px;
  }

  #brand-card-default .brand-description {
    text-align: center;
  }

  #brand-card-default .brand-description p {
    font-size: 16px;
  }

  #brand-card-default .brand-cta-block {
    text-align: center;
  }

  #brand-card-default .brand-cta-block ul {
    grid-template-columns: 1fr;
    justify-items: center;
  }

  #brand-card-default .brand-cta-block li {
    font-size: 12px;
  }

  #brand-card-default .brand-rating,
  #brand-card-default .brand-payment {
    text-align: center;
  }

  #brand-card-default .brand-rating h3,
  #brand-card-default .brand-payment h3 {
    font-size: 15px;
  }

  #brand-card-default .brand-rating p,
  #brand-card-default .brand-payment p {
    font-size: 13px;
  }

  #brand-card-default .brand-cta {
    grid-row: 6 / 6;
    text-align: center;
    margin-top: 8px;
  }

  #brand-card-default .brand-link {
    padding: 16px 24px;
    font-size: 16px;
    font-weight: 700;
  }
}

/* Brand Card - Promo template */

#brand-card-promo.brand-card {
    display: grid;
    grid-template-areas:
      "intro offer benefits cta"
      "payment payment payment payment";
    grid-template-columns: 120px 1fr 1fr 1fr;
    grid-template-rows: auto auto;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    padding: 15px 15px 0 15px;
    margin: 15px 0;
    gap: 12px;
    margin-bottom: 12px;
    align-items: center;
    border: 1px solid #e0e0e0;
    border-radius: 2px;
}

#brand-card-promo.brand-card .brand-intro {
   grid-area: intro;
}

#brand-card-promo.brand-card .brand-logo {
   height: 90px;
   width: 120px;
   display: flex;
   overflow: hidden;
}

#brand-card-promo.brand-card .brand-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

#brand-card-promo.brand-card .brand-offer {
    grid-area: offer;
}

#brand-card-promo.brand-card .brand-offer h2 {
    font-size: 18px;
    font-weight: 600;
    margin: 0;
    color: var(--brand-title, #333);
}

#brand-card-promo.brand-card .brand-offer h3 {
    font-size: 24px;
    line-height: 26px;
    font-weight: 600;
    margin: 5px 0;
}

#brand-card-promo.brand-card .brand-offer strong {
  line-height: 0;
}

#brand-card-promo.brand-card .brand-offer .offer-rating {
  display: flex;
  gap: 2px;
  align-items: center;
  margin: 5px 0;
}

#brand-card-promo.brand-card .brand-offer .offer-rating svg {
  width: 15px;
  height: 15px;
  fill: #f5a623;
}

#brand-card-promo.brand-card .payment {
  grid-area: payment;
  display: flex;
  align-items: center;
  padding: 5px 0;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  border-top: 1px solid #e0e0e0;
}

#brand-card-promo.brand-card .payment h4 {
    font-size: 16px;
    line-height: 26px;
    font-weight: 600;
    margin: 0;
}

#brand-card-promo.brand-card .payment p {
  margin: 0;
}

#brand-card-promo .benefits {
  display: flex;
  flex-direction: column;
  gap: 8px;
  list-style: none;
  margin: 0;
  padding: 0;
}

#brand-card-promo .benefits li {
  font-size: 16px;
  color: #2d7a3d;
  display: flex;
  align-items: center;
  line-height: 1.4;
}

#brand-card-promo .benefits li::before {
  content: "✓";
  margin-right: 5px;
  color: #2d7a3d;
  font-weight: bold;
  font-size: 18px;
}

#brand-card-promo .brand-cta {
  text-align: center;
}

#brand-card-promo .brand-link {
  display: inline-block;
  width: 100%;
  max-width: 160px;
  font-size: 16px;
  color: #fff !important;
  padding: 12px 20px;
  border-radius: 2px;
  font-weight: 600;
  background: var(--bg-color);
  text-decoration: none !important;
  transition: all 0.2s ease-in-out;
  text-align: center;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

#brand-card-promo .brand-link:hover {
 transform: translateY(-2px);
 background: var(--hover-color);
}

#brand-card-promo .payment h4 {
  font-size: 14px;
}

#brand-card-promo .payment p {
  font-size: 14px;
  color: #666;
}

/* PROMO TEMPLATE - RESPONSIVE TABLET (968px and below) */
@media (max-width: 968px) {
  #brand-card-promo.brand-card {
    grid-template-areas:
      "intro offer cta"
      "benefits benefits payment";
    grid-template-columns: 1fr 1fr 1fr;
    grid-template-rows: auto auto;
    gap: 15px;
    padding: 15px;
  }

  #brand-card-promo .brand-logo {
    height: 80px;
    width: 100px;
  }

  #brand-card-promo .brand-offer h2 {
    font-size: 16px;
  }

  #brand-card-promo .brand-offer h3 {
    font-size: 20px;
    line-height: 22px;
  }

  #brand-card-promo .benefits li {
    font-size: 14px;
  }

  #brand-card-promo .payment {
    padding: 10px 0;
    border-top: unset !important;
  }

  #brand-card-promo .payment h4 {
    font-size: 14px;
  }

  #brand-card-promo .brand-cta {
    grid-area: cta;
  }

  #brand-card-promo .brand-link {
    max-width: 140px;
    padding: 10px 16px;
    font-size: 15px;
  }
}

/* PROMO TEMPLATE - RESPONSIVE MOBILE (640px and below) */
@media (max-width: 640px) {
  #brand-card-promo.brand-card {
    grid-template-areas:
      "intro"
      "offer"
      "benefits"
      "cta"
      "payment";
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto auto auto;
    padding: 12px;
    gap: 12px;
    margin-bottom: 12px;
  }

  #brand-card-promo .brand-logo {
    height: 70px;
    width: 180px;
    justify-self: center;
  }

  #brand-card-promo .brand-offer {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }

  #brand-card-promo .brand-offer h2 {
    font-size: 14px;
  }

  #brand-card-promo .brand-offer h3 {
    font-size: 18px;
    line-height: 20px;
    margin: 3px 0;
  }

  #brand-card-promo .benefits {
    text-align: center;
  }

  #brand-card-promo .benefits {
    display: flex;
    flex-direction: column;
    gap: 8px;
    justify-content: center;
    align-items: center;
  }

  #brand-card-promo .benefits li {
    font-size: 13px;
  }

  #brand-card-promo .benefits li::before {
    font-size: 16px;
  }

  #brand-card-promo .brand-cta {
    text-align: center;
  }

  #brand-card-promo .brand-link {
    max-width: 100%;
    width: 100%;
    padding: 14px 20px;
    font-size: 16px;
  }

  #brand-card-promo .payment {
    padding: 10px 0;
    gap: 8px;
    border-top: 1px solid #e0e0e0;
  }

  #brand-card-promo .payment h4 {
    font-size: 13px;
    line-height: 20px;
  }
}

/* PROMO TEMPLATE - RESPONSIVE SMALL MOBILE (480px and below) */
@media (max-width: 480px) {
  #brand-card-promo.brand-card {
    grid-template-areas:
      "intro"
      "offer"
      "benefits"
      "cta"
      "payment";
    grid-template-columns: 1fr;
    padding: 12px;
    gap: 12px;
    margin-bottom: 10px;
  }

  #brand-card-promo .brand-intro {
    text-align: center;
  }

  #brand-card-promo .brand-logo {
    margin: 0 auto;
    height: 80px;
    width: 120px;
  }

  #brand-card-promo .brand-offer {
    text-align: center;
  }

  #brand-card-promo .brand-offer h2 {
    font-size: 15px;
  }

  #brand-card-promo .brand-offer h3 {
    font-size: 20px;
    line-height: 22px;
  }

  #brand-card-promo .benefits {
    text-align: center;
  }

  #brand-card-promo .benefits {
    grid-template-columns: 1fr;
    justify-items: center;
  }

  #brand-card-promo .benefits li {
    font-size: 14px;
    justify-content: center;
  }

  #brand-card-promo .brand-cta {
    text-align: center;
    margin-top: 8px;
  }

  #brand-card-promo .brand-link {
    padding: 16px 24px;
    font-size: 17px;
    font-weight: 700;
  }

  #brand-card-promo .payment {
    padding: 12px 0;
    flex-direction: column;
    text-align: center;
    gap: 5px;
  }

  #brand-card-promo .payment h4 {
    font-size: 14px;
    margin: 0;
  }
}


/* FLIP TEMPLATE - STYLES */

#brand-card-flip.brand-card {
    perspective: 1000px;
    width: 100%;
    max-width: 800px;
    height: 350px;
    margin: 20px auto;
    position: relative;
    cursor: pointer;
    border-radius: 12px;
    transition: all 0.3s ease-in-out;
    transform-style: preserve-3d;
}

#brand-card-flip.brand-card.flipped {
    transform: rotateY(180deg);
}

/* Front and Back Card Faces */
#brand-card-flip .front,
#brand-card-flip .details {
    position: absolute;
    width: 100%;
    height: 100%;
    backface-visibility: hidden;
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
    background: #fff;
    overflow: hidden;
}

#brand-card-flip .front {
    transform: rotateY(0deg);
    display: grid;
    grid-template-areas:
        "header header header header"
        "logo offer cta cta";
    grid-template-columns: 200px 1fr 200px 200px;
    grid-template-rows: auto 1fr;
    z-index: 2;
}

#brand-card-flip .details {
    transform: rotateY(180deg);
    display: grid;
    grid-template-areas:
        "header header"
        "benefits payment"
        "showless showless";
    grid-template-columns: 2fr 1fr;
    grid-template-rows: auto 1fr auto;
}

/* Header with Brand Name */
#brand-card-flip .header {
    grid-area: header;
    background: var(--bg-header-color, linear-gradient(135deg, #667eea 0%, #764ba2 100%));
    padding: 16px 24px;
    text-align: center;
    border-top-left-radius: 12px;
    border-top-right-radius: 12px;
}

#brand-card-flip .header h2 {
    margin: 0;
    font-size: 22px;
    font-weight: 700;
    color: var(--color-text, #fff);
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    letter-spacing: 0.5px;
}

/* Front - Logo Section (Left Side) */
#brand-card-flip .front .brand-intro {
    grid-area: logo;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

#brand-card-flip .front .brand-logo {
    width: 160px;
    height: 160px;
    background: #fff;
    border-radius: 12px;
    padding: 20px;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s ease;
}

#brand-card-flip .front .brand-logo:hover {
    transform: scale(1.05);
}

#brand-card-flip .front .brand-logo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

/* Front - Offer Section (Center) */
#brand-card-flip .front .brand-offer h3 {
  color:var(--color-offer, #fff);
}

#brand-card-flip .front .brand-offer {
    grid-area: offer;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

#brand-card-flip .front .brand-offer .offer-rating {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-bottom: 12px;
}

#brand-card-flip .front .brand-offer .offer-rating svg {
    width: 20px;
    height: 20px;
}

#brand-card-flip .front .brand-offer .offer-rating .star.filled {
    fill: #ffc107;
    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.2));
}

#brand-card-flip .front .brand-offer .offer-rating .star.empty {
    fill: #e0e0e0;
}

#brand-card-flip .front .brand-offer h3.offer {
    margin: 0;
    font-size: 20px;
    font-weight: 600;
    line-height: 1.4;
}

/* Front - CTA Section (Right Side) */
#brand-card-flip .front .brand-cta {
    grid-area: cta;
    padding: 24px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 16px;
    background: #f8f9fa;
    border-left: 1px solid #e9ecef;
}

#brand-card-flip .brand-link {
    display: block;
    width: 100%;
    max-width: 180px;
    padding: 14px 24px;
    background: var(--bg-color, #6dbb7e);
    color: #fff !important;
    text-align: center;
    text-decoration: none !important;
    border-radius: 8px;
    font-weight: 600;
    font-size: 16px;
    transition: all 0.3s ease;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

#brand-card-flip .brand-link:hover {
    background: var(--hover-color, #5aa86b);
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
}

#brand-card-flip .read-more {
    text-align: center;
}

#brand-card-flip .read-more a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;
}

#brand-card-flip .read-more a:hover {
    transform: scale(1.1);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

#brand-card-flip .read-more svg {
    width: 24px;
    height: 24px;
}

/* Back - Benefits Section (Left Side) */
#brand-card-flip .details .benefits {
    grid-area: benefits;
    list-style: none;
    padding: 30px 24px;
    margin: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px 16px;
    background: linear-gradient(180deg, #f8f9fa 0%, #ffffff 100%);
    overflow-y: auto;
    align-content: start;
}

#brand-card-flip .details .benefits li {
    font-size: 14px;
    line-height: 1.5;
    display: flex;
    align-items: flex-start;
    padding-left: 0;
}

#brand-card-flip .details .benefits li::before {
    content: "✓";
    margin-right: 8px;
    font-weight: bold;
    font-size: 16px;
    flex-shrink: 0;
}

/* Back - Payment Section (Right Side) */
#brand-card-flip .details .payment {
    grid-area: payment;
    padding: 30px 24px;
    background: #fff;
    border-left: 1px solid #e9ecef;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
}

#brand-card-flip .details .payment h4 {
    margin: 0 0 12px 0;
    font-size: 14px;
    font-weight: 600;
    color: #495057;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

#brand-card-flip .details .payment p {
    margin: 0;
    font-size: 14px;
    color: #6c757d;
    line-height: 1.6;
}

/* Back - Show Less Button */
#brand-card-flip .show-less {
    grid-area: showless;
    padding: 16px;
    background: #f8f9fa;
    border-top: 1px solid #e9ecef;
    text-align: center;
}

#brand-card-flip .show-less a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;
}

#brand-card-flip .show-less a:hover {
    transform: scale(1.1);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

#brand-card-flip .show-less svg {
    width: 24px;
    height: 24px;
}

/* FLIP TEMPLATE - RESPONSIVE TABLET (768px and below) */
@media (max-width: 968px) {
    #brand-card-flip.brand-card {
        max-width: 600px;
        height: 400px;
    }

    #brand-card-flip .front {
        grid-template-areas:
            "header header"
            "logo offer"
            "cta cta";
        grid-template-columns: 180px 1fr;
        grid-template-rows: auto 1fr auto;
    }

    #brand-card-flip .front .brand-logo {
        width: 140px;
        height: 140px;
        padding: 16px;
    }

    #brand-card-flip .front .brand-offer {
        padding: 20px;
        border-left: none;
    }

    #brand-card-flip .front .brand-offer h3.offer {
        font-size: 18px;
    }

    #brand-card-flip .front .brand-cta {
        padding: 20px;
        flex-direction: row;
        justify-content: space-around;
        border-left: none;
        border-top: 1px solid #e9ecef;
    }

    #brand-card-flip .brand-link {
        max-width: 200px;
        padding: 12px 20px;
        font-size: 15px;
    }

    #brand-card-flip .details {
        grid-template-areas:
            "header header"
            "benefits payment"
            "showless showless";
        grid-template-columns: 2fr 1fr;
    }

    #brand-card-flip .details .benefits {
        padding: 24px 20px;
        gap: 10px 14px;
    }

    #brand-card-flip .details .benefits li {
        font-size: 13px;
    }

    #brand-card-flip .details .payment {
        padding: 24px 20px;
    }
}

/* FLIP TEMPLATE - RESPONSIVE MOBILE (480px and below) - VERTICAL */
@media (max-width: 768px) {
    #brand-card-flip.brand-card {
        max-width: 340px;
        height: 500px;
        margin: 16px auto;
    }

    #brand-card-flip .front {
        display: flex;
        flex-direction: column;
    }

    #brand-card-flip .header {
        padding: 16px;
    }

    #brand-card-flip .header h2 {
        font-size: 18px;
    }

    #brand-card-flip .front .brand-intro {
        flex: 1;
        padding: 24px 16px;
    }

    #brand-card-flip .front .brand-logo {
        width: 140px;
        height: 140px;
        padding: 14px;
    }

    #brand-card-flip .front .brand-offer {
        padding: 16px;
        border-left: none;
        border-top: 1px solid #e9ecef;
    }

    #brand-card-flip .front .brand-offer .offer-rating svg {
        width: 18px;
        height: 18px;
    }

    #brand-card-flip .front .brand-offer h3.offer {
        font-size: 16px;
    }

    #brand-card-flip .front .brand-cta {
        padding: 16px;
        gap: 10px;
        border-left: none;
        border-top: 1px solid #e9ecef;
    }

    #brand-card-flip .brand-link {
        max-width: 100%;
        padding: 12px 18px;
        font-size: 14px;
    }

    #brand-card-flip .details {
        display: flex;
        flex-direction: column;
    }

    #brand-card-flip .details .benefits {
        flex: 1;
        padding: 20px 16px;
        gap: 10px;
        display: flex;
        flex-direction: column;
        grid-template-columns: 1fr;
    }

    #brand-card-flip .details .benefits li {
        font-size: 13px;
    }

    #brand-card-flip .details .benefits li::before {
        font-size: 16px;
    }

    #brand-card-flip .details .payment {
        padding: 16px;
        border-left: none;
        border-top: 1px solid #e9ecef;
    }

    #brand-card-flip .details .payment h4 {
        font-size: 13px;
    }

    #brand-card-flip .details .payment p {
        font-size: 13px;
    }

    #brand-card-flip .show-less {
        padding: 12px;
    }

    #brand-card-flip .read-more a,
    #brand-card-flip .show-less a {
        width: 36px;
        height: 36px;
    }

    #brand-card-flip .read-more svg,
    #brand-card-flip .show-less svg {
        width: 20px;
        height: 20px;
    }
}

/* FLIP TEMPLATE - RESPONSIVE SMALL MOBILE (360px and below) */
@media (max-width: 360px) {
    #brand-card-flip.brand-card {
        max-width: 310px;
        height: 480px;
    }

    #brand-card-flip .header h2 {
        font-size: 16px;
    }

    #brand-card-flip .front .brand-logo {
        width: 120px;
        height: 120px;
        padding: 12px;
    }

    #brand-card-flip .front .brand-offer h3.offer {
        font-size: 15px;
    }

    #brand-card-flip .brand-link {
        padding: 10px 16px;
        font-size: 13px;
    }

    #brand-card-flip .details .benefits {
        padding: 16px 14px;
    }

    #brand-card-flip .details .benefits li {
        font-size: 12px;
    }
}

/* Smooth animations */
#brand-card-flip.brand-card * {
    transition: all 0.3s ease;
}

/* Hover effects for desktop */
@media (min-width: 969px) {
    #brand-card-flip.brand-card:hover {
        box-shadow: 0 8px 30px rgba(0, 0, 0, 0.2);
    }
}