/* =========================================================
   HortiCard — checkout box (payment top hook)
   ========================================================= */
.horticard-box {
  margin: 16px 0;
  padding: 0;
  border: 1px solid #c8dfa8;
  border-radius: 8px;
  background: #f3f8ec;
}
.horticard-box-inner {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  padding: 16px;
}
.horticard-box-icon {
  flex: 0 0 110px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.horticard-box-icon img {
  display: block;
  max-width: 100%;
  height: auto;
  border-radius: 4px;
}
.horticard-box-text {
  flex: 1 1 auto;
}
.horticard-box-text strong {
  display: block;
  margin-bottom: 6px;
  font-size: 16px;
  color: #1c2e10;
}
.horticard-box-text p {
  margin: 0 0 12px;
  color: #2c4220;
}
.horticard-checkbox-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 0;
  cursor: pointer;
  font-weight: 500;
  color: #1c2e10;
}
.horticard-checkbox-row input {
  margin-top: 3px;
  accent-color: #5f8f3a;
}
.horticard-box-link {
  margin-top: 10px !important;
  font-size: 13px;
}
.horticard-box-link a {
  color: #3d7320;
  text-decoration: underline;
}
.horticard-box-link a:hover {
  color: #1c2e10;
}
.horticard-status {
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 4px;
  font-size: 14px;
}
.horticard-box--success .horticard-status {
  background: #e6f6e6;
  color: #245b24;
}
.horticard-box--error .horticard-status {
  background: #fdeaea;
  color: #8a1f1f;
}
@media (max-width: 767px) {
  .horticard-box-inner {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  .horticard-box-icon {
    flex-basis: auto;
    max-width: 160px;
  }
  .horticard-checkbox-row {
    text-align: left;
  }
}

/* =========================================================
   HortiCard — product page banner (matches Horticola.ro greens)
   ========================================================= */
.horticard-product-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin: 14px 0;
  padding: 14px 18px;
  background: #f3f8ec;
  border: 1px solid #c8dfa8;
  border-radius: 8px;
}
.horticard-product-banner__text {
  flex: 1 1 auto;
  min-width: 0;
  font-size: 14px;
  line-height: 1.4;
  color: #2c4220;
}
.horticard-product-banner__title {
  margin: 0 0 4px;
  font-size: 15px;
  font-weight: 700;
  color: #1c2e10;
}
.horticard-product-banner__discount {
  margin: 0 0 8px;
  font-size: 14px;
  font-weight: 400;
  color: #2c4220;
}
.horticard-product-banner__link {
  display: inline-block;
  font-size: 13px;
  font-weight: 500;
  color: #3d7320;
  text-decoration: underline;
}
.horticard-product-banner__link:hover,
.horticard-product-banner__link:focus {
  color: #1c2e10;
  text-decoration: underline;
}
.horticard-product-banner__logo {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
.horticard-product-banner__logo img {
  display: block;
  width: auto;
  max-width: 120px;
  max-height: 70px;
  height: auto;
  border-radius: 4px;
}
@media (max-width: 575px) {
  .horticard-product-banner {
    flex-direction: column-reverse;
    text-align: center;
    padding: 14px;
  }
  .horticard-product-banner__logo img {
    max-width: 140px;
  }
}

/* =========================================================
   HortiCard — My Account card (displayCustomerAccount hook)
   ========================================================= */
.horticard-account-card {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin: 16px 0;
  padding: 18px 20px;
  background: #f3f8ec;
  border: 1px solid #c8dfa8;
  border-radius: 8px;
}
.horticard-account-card__logo {
  flex: 0 0 auto;
}
.horticard-account-card__logo img {
  display: block;
  width: 100px;
  height: auto;
  border-radius: 4px;
}
.horticard-account-card__body {
  flex: 1 1 auto;
  min-width: 0;
}
.horticard-account-card__title {
  margin: 0 0 6px;
  font-size: 17px;
  font-weight: 700;
  color: #1c2e10;
}
.horticard-account-card__status {
  margin: 0 0 4px;
  font-size: 14px;
  font-weight: 500;
}
.horticard-account-card__status--active {
  color: #3d7320;
}
.horticard-account-card__status--inactive {
  color: #5b6552;
}
.horticard-account-card__hint {
  margin: 0 0 12px;
  font-size: 13px;
  color: #5b6552;
}
.horticard-account-card__btn {
  display: inline-block;
  padding: 8px 16px;
  font-size: 13px;
  font-weight: 500;
  border-radius: 4px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background .2s ease, border-color .2s ease, color .2s ease;
}
.horticard-account-card__btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.horticard-account-card__btn--join {
  background: #5f8f3a;
  color: #fff;
  border-color: #5f8f3a;
}
.horticard-account-card__btn--join:hover:not(:disabled) {
  background: #3d7320;
  border-color: #3d7320;
}
.horticard-account-card__btn--leave {
  background: #fff;
  color: #8a1f1f;
  border-color: #d8a8a8;
}
.horticard-account-card__btn--leave:hover:not(:disabled) {
  background: #fdeaea;
  border-color: #c97070;
  color: #8a1f1f;
}
.horticard-account-card__link {
  margin: 10px 0 0;
  font-size: 12px;
}
.horticard-account-card__link a {
  color: #3d7320;
  text-decoration: underline;
}
.horticard-account-card__link a:hover {
  color: #1c2e10;
}
.horticard-account-card__status-msg {
  margin-top: 10px;
  padding: 8px 12px;
  border-radius: 4px;
  font-size: 13px;
}
.horticard-account-card__status-msg--success {
  background: #e6f6e6;
  color: #245b24;
}
.horticard-account-card__status-msg--error {
  background: #fdeaea;
  color: #8a1f1f;
}
@media (max-width: 575px) {
  .horticard-account-card {
    flex-direction: column;
    text-align: center;
  }
  .horticard-account-card__logo {
    align-self: center;
  }
}
