/* WooCommerce overrides — enqueued on is_woocommerce() | is_cart() | is_checkout() | is_account_page() */

/* ── Breadcrumb ────────────────────────────────────────────────────────────── */

.woocommerce-breadcrumb {
  font-family: var(--font-ui);
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text3);
  margin-bottom: 32px;
}
.woocommerce-breadcrumb a { color: var(--text2); text-decoration: none; }
.woocommerce-breadcrumb a:hover { color: var(--accent); }

/* ── Notices ───────────────────────────────────────────────────────────────── */

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  clip-path: var(--blade-xs);
  color: var(--text);
  font-family: var(--font-ui);
  font-size: .82rem;
  list-style: none;
  padding: 14px 20px;
  margin-bottom: 20px;
}
.woocommerce-error { border-left-color: #f87171; }
.woocommerce-message a.button,
.woocommerce-error a.button {
  float: right;
  margin-top: -4px;
}

/* ── .store-card ────────────────────────────────────────────────────────────── */

.store-card {
  cursor: pointer;
  background: var(--bg3);
  clip-path: var(--blade-md);
  position: relative;
  display: flex;
  flex-direction: column;
  transition: background .3s;
}
.store-card:hover { background: var(--bg4); }

/* Blade corner stroke (matches .card::after) */
.store-card::after {
  content: '';
  position: absolute;
  top: 0; right: 0;
  width: 1px; height: 30px;
  background: var(--acc25);
  transform: rotate(-45deg);
  transform-origin: top right;
  pointer-events: none;
}

/* Image fills the top of the card — no inner clip since the card already clips */
.store-card .product-img {
  clip-path: none;
  margin-bottom: 0;
  flex-shrink: 0;
}
/* Scale on hover uses the product-card rule from style.css, re-declared for .store-card */
.store-card:hover .product-img { transform: scale(1.02); }

/* Text area padding */
.store-card .product-cat  { padding: 12px 16px 0; }
.store-card .product-name { padding: 4px 16px 0; }
.store-card .product-footer {
  padding: 14px 16px 16px;
  margin-top: auto;
}

/* ── Result count + ordering bar ───────────────────────────────────────────── */

.store-loop-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 24px;
}

.woocommerce-result-count {
  font-family: var(--font-ui);
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text3);
  margin: 0;
  float: none;
}

.woocommerce-ordering {
  margin: 0;
  float: none;
}

.woocommerce-ordering select,
.woocommerce-ordering .orderby {
  appearance: none;
  -webkit-appearance: none;
  background-color: #141414; /* --bg3 literal so option elements inherit it */
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23666' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  border: 1px solid rgba(255,255,255,.07);
  color: #8a8a8a; /* --text2 literal */
  font-family: var(--font-ui, 'Rajdhani', sans-serif);
  font-size: .72rem;
  padding: 8px 32px 8px 12px;
  border-radius: 6px;
  cursor: pointer;
  transition: border-color .2s, color .2s;
  min-width: 160px;
}
.woocommerce-ordering select:focus,
.woocommerce-ordering .orderby:focus {
  border-color: #FFF300;
  outline: none;
  color: #f0f0f0;
}
.woocommerce-ordering select:hover,
.woocommerce-ordering .orderby:hover {
  border-color: rgba(255,255,255,.12);
  color: #f0f0f0;
}
.woocommerce-ordering select option,
.woocommerce-ordering .orderby option {
  background: #141414;
  color: #f0f0f0;
}

/* ── Pagination ─────────────────────────────────────────────────────────────── */

.woocommerce-pagination { clear: both; margin-top: 40px; }
.woocommerce-pagination ul {
  display: flex;
  gap: 6px;
  list-style: none;
  padding: 0;
  margin: 0;
  justify-content: center;
}
.woocommerce-pagination ul li { margin: 0; }
.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span {
  font-family: var(--font-h);
  font-size: .8rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: var(--bg3);
  color: var(--text2);
  clip-path: var(--blade-xs);
  text-decoration: none;
  transition: background .2s, color .2s;
}
.woocommerce-pagination ul li a:hover { background: var(--acc10); color: var(--accent); }
.woocommerce-pagination ul li span.current { background: var(--accent); color: #000; }

/* ── No products found ──────────────────────────────────────────────────────── */

.woocommerce-no-products-found p {
  text-align: center;
  color: var(--text3);
  padding: 60px 0;
  font-family: var(--font-ui);
  font-size: .875rem;
}

/* ── WooCommerce buttons ────────────────────────────────────────────────────── */

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
  font-family: var(--font-ui);
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  background: var(--bg5);
  color: var(--text);
  padding: 9px 18px;
  clip-path: var(--blade-xs);
  border: none;
  border-radius: 0;
  cursor: pointer;
  transition: background .2s, color .2s;
  text-decoration: none;
  display: inline-block;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover {
  background: var(--acc10);
  color: var(--accent);
}

/* Primary / alt buttons (checkout, place order) */
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt,
.woocommerce #payment #place_order,
.woocommerce-checkout #payment #place_order {
  background: var(--accent);
  color: #000;
  font-weight: 900;
  clip-path: var(--blade-sm);
}
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover,
.woocommerce #respond input#submit.alt:hover,
.woocommerce #payment #place_order:hover {
  background: #ffef00;
  color: #000;
}
.woocommerce a.button.disabled,
.woocommerce a.button:disabled {
  opacity: .4;
  cursor: not-allowed;
}

/* Proceed to checkout */
.wc-proceed-to-checkout { padding: 0; }
.wc-proceed-to-checkout .checkout-button {
  width: 100%;
  display: block;
  text-align: center;
  font-size: .78rem;
  padding: 14px 24px;
  clip-path: var(--blade-sm);
  background: var(--accent);
  color: #000;
  font-weight: 900;
}
.wc-proceed-to-checkout .checkout-button:hover { background: #ffef00; }

/* Add to cart in loop */
.woocommerce a.button.add_to_cart_button,
.woocommerce a.button.product_type_variable,
.woocommerce a.button.product_type_grouped,
.woocommerce a.button.product_type_external {
  font-size: .65rem;
  padding: 7px 14px;
  clip-path: var(--blade-xs);
  background: var(--bg5);
  color: var(--text);
}
.woocommerce a.button.add_to_cart_button:hover,
.woocommerce a.button.product_type_variable:hover,
.woocommerce a.button.product_type_grouped:hover,
.woocommerce a.button.add_to_cart_button.added {
  background: var(--acc10);
  color: var(--accent);
}

/* ── Single product layout ──────────────────────────────────────────────────── */

.store-product-detail { padding-top: 32px; }

.store-product-detail article.product {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}

.store-product-detail .store-product-below {
  grid-column: 1 / -1;
  margin-top: 40px;
}

/* Gallery */
.woocommerce-product-gallery .woocommerce-product-gallery__image img {
  width: 100%;
  clip-path: var(--blade-md);
  border: 1px solid var(--border);
  display: block;
}
.woocommerce-product-gallery .flex-control-thumbs {
  display: flex;
  gap: 8px;
  margin-top: 10px;
  padding: 0;
  list-style: none;
}
.woocommerce-product-gallery .flex-control-thumbs img {
  clip-path: var(--blade-xs);
  border: 1px solid var(--border);
  cursor: pointer;
  opacity: .55;
  transition: opacity .2s, border-color .2s;
}
.woocommerce-product-gallery .flex-control-thumbs img.flex-active {
  opacity: 1;
  border-color: var(--accent);
}

/* Summary typography */
.store-product-detail .product_title {
  font-size: 1.6rem;
  margin-bottom: 8px;
}
.store-product-detail .woocommerce-review-link {
  font-family: var(--font-ui);
  font-size: .72rem;
  color: var(--text3);
  text-decoration: none;
}
.store-product-detail .price {
  font-family: var(--font-h);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--accent);
  margin: 14px 0 20px;
  display: block;
}
.store-product-detail .price del {
  color: var(--text3);
  font-size: 1rem;
  margin-right: 10px;
}
.store-product-detail .price ins { text-decoration: none; }
.store-product-detail .woocommerce-product-details__short-description {
  color: var(--text2);
  font-size: .875rem;
  line-height: 1.75;
  margin-bottom: 24px;
}

/* Qty + add to cart */
.store-product-detail .quantity {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
}
.store-product-detail .quantity .qty {
  width: 64px;
  background: var(--bg3);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: var(--font-h);
  font-size: .9rem;
  padding: 9px 12px;
  text-align: center;
  transition: border-color .2s;
  border-radius: 0;
}
.store-product-detail .quantity .qty:focus { border-color: var(--accent); outline: none; }

.store-product-detail .single_add_to_cart_button {
  font-family: var(--font-ui);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  background: var(--accent);
  color: #000;
  border: none;
  clip-path: var(--blade-sm);
  padding: 14px 32px;
  cursor: pointer;
  transition: background .2s;
}
.store-product-detail .single_add_to_cart_button:hover { background: #ffef00; }

/* Product meta */
.store-product-detail .product_meta {
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
  font-family: var(--font-ui);
  font-size: .72rem;
  color: var(--text3);
  line-height: 1.9;
}
.store-product-detail .product_meta .sku,
.store-product-detail .product_meta .posted_in,
.store-product-detail .product_meta .tagged_as { display: block; }
.store-product-detail .product_meta span.sku,
.store-product-detail .product_meta a { color: var(--text2); }
.store-product-detail .product_meta a:hover { color: var(--accent); }

/* Star rating */
.woocommerce .star-rating { color: var(--accent); }
.woocommerce .star-rating span::before { color: var(--accent); }
.comment-form-rating .stars a { color: var(--accent); }

/* ── Tabs ───────────────────────────────────────────────────────────────────── */

.woocommerce-tabs ul.tabs {
  display: flex;
  gap: 2px;
  border-bottom: 1px solid var(--border);
  margin: 0;
  padding: 0;
  list-style: none;
}
.woocommerce-tabs ul.tabs::before { display: none; }
.woocommerce-tabs ul.tabs li {
  background: transparent;
  border: none;
  border-radius: 0;
  margin: 0;
  padding: 0;
}
.woocommerce-tabs ul.tabs li a {
  display: block;
  padding: 10px 20px;
  font-family: var(--font-ui);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text3);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: color .2s, border-color .2s;
}
.woocommerce-tabs ul.tabs li a:hover { color: var(--text); }
.woocommerce-tabs ul.tabs li.active a {
  color: var(--accent);
  border-bottom-color: var(--accent);
  background: transparent;
}
.woocommerce-tabs .panel {
  padding: 28px 0;
  border: none;
  background: transparent;
  color: var(--text2);
  font-size: .875rem;
  line-height: 1.75;
  margin: 0;
}
.woocommerce-tabs .panel h2 { display: none; }
.woocommerce-tabs .panel h3 {
  font-size: 1rem;
  margin-bottom: 14px;
  color: var(--text);
}

/* Reviews */
#reviews #comments .commentlist { list-style: none; padding: 0; }
#reviews #comments .commentlist .comment {
  background: var(--bg3);
  border: 1px solid var(--border);
  clip-path: var(--blade-sm);
  padding: 20px 24px;
  margin-bottom: 14px;
}
#reviews #comments .commentlist .comment .meta { color: var(--text3); font-size: .75rem; }
#reviews #comments .commentlist .comment .description { color: var(--text2); font-size: .875rem; margin-top: 8px; }

/* Related / upsells */
.related.products > h2,
.up-sells.upsells > h2 {
  font-family: var(--font-h);
  font-size: .85rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: 20px;
  color: var(--text);
}
.related.products ul.products,
.up-sells.upsells ul.products {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 16px;
  list-style: none;
  padding: 0;
  margin: 0;
}

/* ── Cart table ─────────────────────────────────────────────────────────────── */

.woocommerce table.shop_table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid var(--border);
  color: var(--text);
}
.woocommerce table.shop_table th {
  font-family: var(--font-ui);
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--text3);
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  text-align: left;
  background: var(--bg2);
}
.woocommerce table.shop_table td {
  padding: 16px;
  border-bottom: 1px solid var(--border);
  font-size: .875rem;
  vertical-align: middle;
  background: var(--bg2);
}
.woocommerce table.shop_table tr:last-child td { border-bottom: none; }
.woocommerce table.shop_table tbody tr:hover td { background: var(--bg3); }
.woocommerce table.shop_table a { color: var(--text); text-decoration: none; }
.woocommerce table.shop_table a:hover { color: var(--accent); }
.woocommerce table.shop_table .product-name a { font-weight: 500; }
.woocommerce table.shop_table .product-remove a {
  color: var(--text3);
  font-size: 1.1rem;
  text-decoration: none;
  transition: color .2s;
}
.woocommerce table.shop_table .product-remove a:hover { color: #f87171; }

/* Cart qty input */
.woocommerce table.shop_table input.qty {
  width: 60px;
  background: var(--bg3);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: var(--font-h);
  font-size: .85rem;
  padding: 6px 10px;
  text-align: center;
  transition: border-color .2s;
  border-radius: 0;
}
.woocommerce table.shop_table input.qty:focus { border-color: var(--accent); outline: none; }

/* Update cart button */
.woocommerce .cart_totals .wc-proceed-to-checkout { padding-top: 0; }

/* Cart totals sidebar */
.cart-collaterals .cart_totals,
.cart-collaterals .cross-sells { margin-bottom: 32px; }
.cart_totals {
  background: var(--bg2);
  border: 1px solid var(--border);
  clip-path: var(--blade-md);
  padding: 28px 32px;
}
.cart_totals h2 {
  font-family: var(--font-h);
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: 20px;
  color: var(--text);
}
.cart_totals table.shop_table { border: none; background: transparent; }
.cart_totals table.shop_table th,
.cart_totals table.shop_table td {
  background: transparent;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
}
.cart_totals table.shop_table tr:last-child th,
.cart_totals table.shop_table tr:last-child td { border-bottom: none; }
.cart_totals .order-total th,
.cart_totals .order-total td {
  color: var(--accent);
  font-family: var(--font-h);
  font-size: 1.1rem;
  font-weight: 700;
}

/* ── Checkout ───────────────────────────────────────────────────────────────── */

.woocommerce-checkout h3 {
  font-family: var(--font-h);
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: 20px;
  color: var(--text);
}
.woocommerce-checkout .form-row { margin-bottom: 16px; }
.woocommerce-checkout .form-row label {
  font-family: var(--font-ui);
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text3);
  margin-bottom: 6px;
  display: block;
}
.woocommerce-checkout .form-row .input-text,
.woocommerce-checkout .form-row input[type="text"],
.woocommerce-checkout .form-row input[type="email"],
.woocommerce-checkout .form-row input[type="tel"],
.woocommerce-checkout .form-row textarea,
.woocommerce-checkout .form-row select {
  background: var(--bg2);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: var(--font-ui);
  font-size: .82rem;
  padding: 10px 14px;
  width: 100%;
  transition: border-color .2s;
  border-radius: 0;
}
.woocommerce-checkout .form-row .input-text:focus,
.woocommerce-checkout .form-row input:focus,
.woocommerce-checkout .form-row textarea:focus {
  border-color: var(--accent);
  outline: none;
  box-shadow: none;
}

.woocommerce-checkout-payment {
  background: var(--bg2);
  border: 1px solid var(--border);
  clip-path: var(--blade-sm);
  padding: 24px;
  margin-top: 24px;
}
.woocommerce-checkout-payment ul.payment_methods {
  list-style: none;
  padding: 0;
  margin-bottom: 20px;
  border-bottom: 1px solid var(--border);
  padding-bottom: 16px;
}
.woocommerce-checkout-payment ul.payment_methods li label {
  font-size: .875rem;
  color: var(--text);
  letter-spacing: normal;
  text-transform: none;
  font-weight: 400;
  cursor: pointer;
}
.woocommerce-checkout-payment .payment_box {
  background: var(--bg3);
  border: 1px solid var(--border);
  padding: 14px;
  font-size: .82rem;
  color: var(--text2);
  margin-top: 8px;
}

/* Order summary on checkout */
#order_review table.shop_table { margin-top: 0; }
#order_review_heading {
  font-family: var(--font-h);
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: 16px;
  color: var(--text);
}

/* ── Account ────────────────────────────────────────────────────────────────── */

.woocommerce-MyAccount-navigation { margin-bottom: 32px; }
.woocommerce-MyAccount-navigation ul {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 0;
}
.woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 8px 16px;
  font-family: var(--font-ui);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  background: var(--bg3);
  color: var(--text2);
  clip-path: var(--blade-xs);
  text-decoration: none;
  transition: background .2s, color .2s;
}
.woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-MyAccount-navigation ul li.is-active a {
  background: var(--acc10);
  color: var(--accent);
}
.woocommerce-MyAccount-content h2 {
  font-size: 1.1rem;
  margin-bottom: 20px;
  color: var(--text);
}
.woocommerce-MyAccount-content .woocommerce-orders-table,
.woocommerce-MyAccount-content .woocommerce-table { margin-top: 0; }

/* ── WooCommerce form inputs (general) ──────────────────────────────────────── */

.woocommerce .input-text,
.woocommerce input[type="text"]:not(.search-field),
.woocommerce input[type="email"],
.woocommerce input[type="password"],
.woocommerce textarea {
  background: var(--bg2);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: var(--font-ui);
  font-size: .82rem;
  padding: 10px 14px;
  transition: border-color .2s;
  border-radius: 0;
}
.woocommerce .input-text:focus,
.woocommerce input[type="text"]:focus,
.woocommerce input[type="email"]:focus,
.woocommerce input[type="password"]:focus,
.woocommerce textarea:focus {
  border-color: var(--accent);
  outline: none;
  box-shadow: none;
}
.woocommerce .input-text::placeholder,
.woocommerce input::placeholder { color: var(--text3); }

/* Select2 */
.select2-container--default .select2-selection--single {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 0;
  height: auto;
  padding: 10px 14px;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--text2);
  font-family: var(--font-ui);
  font-size: .82rem;
  padding: 0;
  line-height: 1.4;
}
.select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 100%;
  top: 0;
}
.select2-dropdown {
  background: var(--bg3);
  border: 1px solid var(--borderl);
  border-radius: 0;
}
.select2-container--default .select2-results__option--highlighted[aria-selected] {
  background: var(--acc10);
  color: var(--accent);
}
.select2-search--dropdown .select2-search__field {
  background: var(--bg2);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 6px 10px;
}

/* ── Responsive ─────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  .store-product-detail article.product {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .store-product-detail .store-product-below {
    grid-column: 1;
    margin-top: 28px;
  }
  .woocommerce-tabs ul.tabs { flex-wrap: wrap; }
  .woocommerce-MyAccount-navigation ul { flex-direction: column; }
}


/* ═══════════════════════════════════════════════════════════════════════════
   PMPro (Paid Memberships Pro) — checkout form
   ═══════════════════════════════════════════════════════════════════════════ */

#pmpro_form input[type="text"],
#pmpro_form input[type="email"],
#pmpro_form input[type="tel"],
#pmpro_form input[type="password"],
#pmpro_form input[type="number"],
#pmpro_form input[type="url"],
#pmpro_form textarea,
#pmpro_form select {
  display: block;
  width: 100%;
  background: var(--bg2);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: var(--font-ui);
  font-size: .875rem;
  padding: 10px 14px;
  border-radius: 8px;
  line-height: 1.5;
  transition: border-color .15s;
  outline: none;
  -webkit-appearance: none;
  appearance: none;
}

#pmpro_form input[type="text"]:focus,
#pmpro_form input[type="email"]:focus,
#pmpro_form input[type="tel"]:focus,
#pmpro_form input[type="password"]:focus,
#pmpro_form select:focus,
#pmpro_form textarea:focus {
  border-color: var(--accent);
  outline: none;
  box-shadow: none;
}

#pmpro_form label,
#pmpro_form .pmpro_label {
  display: block;
  font-family: var(--font-ui);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--text3);
  margin-bottom: 6px;
}

#pmpro_form .pmpro_checkout-field,
#pmpro_form .pmpro-field-wrap {
  margin-bottom: 16px;
}

#pmpro_form h3,
#pmpro_form .pmpro_section_title {
  font-family: var(--font-h);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text2);
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 20px;
}

#pmpro_form input[type="submit"],
#pmpro_form .pmpro_btn,
#pmpro_form button[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--accent);
  color: #080808;
  border: none;
  border-radius: 6px;
  padding: 14px 28px;
  font-family: var(--font-h);
  font-size: .82rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: opacity .15s;
}

#pmpro_form input[type="submit"]:hover,
#pmpro_form .pmpro_btn:hover {
  opacity: .88;
}

.pmpro_message,
#pmpro_message {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 16px;
  font-size: .82rem;
  color: var(--text2);
  margin-bottom: 20px;
  line-height: 1.6;
}

.pmpro_message.pmpro_error,
#pmpro_message.pmpro_error   { border-color: rgba(248,113,113,.4); color: #f87171; }
.pmpro_message.pmpro_success,
#pmpro_message.pmpro_success { border-color: rgba(74,222,128,.3);  color: #4ade80; }

#pmpro_payment_information_fields {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 20px;
  margin-top: 16px;
}

.pmpro_checkout table,
#pmpro_form table {
  width: 100%;
  border-collapse: collapse;
  font-size: .85rem;
}

.pmpro_checkout table th,
.pmpro_checkout table td,
#pmpro_form table th,
#pmpro_form table td {
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
  color: var(--text);
}
