/* ================================================================
   VPNUK — WooCommerce + My Account styles
   ================================================================ */

/* ── Break out of Customizr Pro column constraints ───────────── */
/* Target ONLY the specific Customizr Pro / Bootstrap column      */
/* classes that narrow layout. We do NOT use .site-main > *       */
/* because that would also strip padding from .woo-wrapper.       */
.site-main,
.czr-woo-main-cnt,
.tc-content-wrap,
.tc-blog-grid,
.content-area,
#content {
  float: none !important;
  width: 100% !important;
  max-width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}
/* Also catch Bootstrap column classes used by Customizr Pro */
.woocommerce-page .col-sm-8,
.woocommerce-page .col-sm-9,
.woocommerce-page .span8,
.woocommerce-page .span9 {
  float: none !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* ── Wrapper / container ─────────────────────────────────────── */
/* .woo-wrapper is a direct child of .site-main — with the broad  */
/* wildcard removed, its padding is no longer zeroed out.         */
.woo-wrapper {
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 28px;
  float: none;
  box-sizing: border-box;
}

/* ── Global form element resets ──────────────────────────────── */
input,
select,
textarea {
  border: 1px solid #aaaaaa;
}

input[type="radio"],
input[type="checkbox"] {
  vertical-align: middle;
  margin: 0 0.4em 0.4em 0;
  border: 1px solid #000;
  background: -webkit-linear-gradient(#fcfcfc, #dadada);
  -webkit-appearance: checkbox;
  -webkit-transition: box-shadow 200ms;
  box-shadow: inset 1px 1px 0 #fff, 0 1px 1px rgba(0, 0, 0, 0.1);
}

h6 {
  color: #777;
  text-transform: none;
}

/* ── WooCommerce variation DL ────────────────────────────────── */
dl dt::before { display: none; }

.woocommerce-cart table.cart tbody .product-name dt { display: none !important; }
.woocommerce-cart table.cart tbody .product-name dd { display: inline-block !important; }
.woocommerce td.product-name dl.variation dt { display: none; }

/* ── Alert / notice boxes (custom) ──────────────────────────── */
.isa_info,
.isa_success,
.isa_warning,
.isa_error {
  margin: 10px 0;
  padding: 12px;
  border-radius: .5em;
}
.isa_info    { color: #00529b; background-color: #bde5f8; }
.isa_success { color: #4f8a10; background-color: #dff2bf; }
.isa_warning { color: #9f6000; background-color: #feefb3; }
.isa_error   { color: #d8000c; background-color: #ffd2d2; }

.isa_info i,
.isa_success i,
.isa_warning i,
.isa_error i {
  margin: 10px 22px;
  font-size: 14px;
  vertical-align: middle;
}

#isa-head { font-size: 18px; color: #000; }

.alert {
  padding: 15px;
  background-color: #c2f0c2;
  color: #000;
  margin-bottom: 10px;
  border-radius: 10px;
}
.alerthead { font-size: 24px; font-weight: bold; }

.closebtn { margin-left: 15px; float: right; font-size: 22px; line-height: 20px; cursor: pointer; transition: 0.3s; }
.closebtn:hover { color: black; }

/* ── WooCommerce notices ─────────────────────────────────────── */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  border-radius: 10px;
  padding: 14px 20px;
  margin-bottom: 20px;
  font-size: 0.9rem;
  list-style: none;
}
.woocommerce-message { background: #f0fdf4; border-left: 4px solid #22c55e; color: #166534; }
.woocommerce-info    { background: #eff6ff; border-left: 4px solid #3b82f6; color: #1e40af; }
.woocommerce-error   { background: #fef2f2; border-left: 4px solid #ef4444; color: #991b1b; }

.woocommerce-message a.button,
.woocommerce-info a.button {
  float: right;
  background: var(--blue, #1c63d5);
  color: #fff;
  border-radius: 8px;
  padding: 8px 18px;
  font-size: 0.85rem;
  font-weight: 600;
  text-decoration: none;
}

/* ── Buttons ─────────────────────────────────────────────────── */
/* Override ALL WooCommerce button variants incl. .alt (Order Now uses .alt) */
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce button.button.alt,
.woocommerce a.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt,
.woocommerce-page a.button,
.woocommerce-page button.button,
.woocommerce-page a.button.alt,
.woocommerce-page button.button.alt {
  background: var(--blue, #1c63d5) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 10px;
  padding: 12px 26px;
  font-weight: 700;
  font-size: 0.95rem;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
  transition: background .15s;
  line-height: 1.4;
}
.woocommerce #respond input#submit:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce button.button.alt:hover,
.woocommerce a.button.alt:hover,
.woocommerce input.button.alt:hover,
.woocommerce #respond input#submit.alt:hover,
.woocommerce-page a.button:hover,
.woocommerce-page button.button:hover,
.woocommerce-page a.button.alt:hover,
.woocommerce-page button.button.alt:hover {
  background: var(--navy, #0d2045) !important;
  color: #fff !important;
  text-decoration: none;
}

.woocommerce button.button.disabled,
.woocommerce button.button:disabled {
  background: #9ca3af !important;
  cursor: not-allowed;
}

/* ── Product archive grid ─────────────────────────────────────── */
/* WooCommerce's woocommerce-layout.css floats li.product items   */
/* at ~30% each. We replace that entirely with CSS grid.          */
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 32px !important;
  list-style: none !important;
  margin: 24px 0 0 !important;
  padding: 0 !important;
  float: none !important;
  width: 100% !important;
  clear: both;
}
/* Neutralise WooCommerce's own floats on archive product items */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  float: none !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  background: #fff;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 14px;
  overflow: hidden;
  display: flex !important;
  flex-direction: column;
  transition: box-shadow .2s, transform .2s;
}
.woocommerce ul.products li.product:hover,
.woocommerce-page ul.products li.product:hover {
  box-shadow: 0 8px 28px rgba(30,58,95,.1);
  transform: translateY(-2px);
}
/* Full globe images — use contain so the shield/logo isn't cropped */
.woocommerce ul.products li.product img,
.woocommerce-page ul.products li.product img {
  width: 100% !important;
  height: 220px !important;
  object-fit: contain !important;
  background: #f8fafc;
  display: block;
  padding: 12px;
  box-sizing: border-box;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product .woocommerce-loop-product__title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--navy, #0d2045);
  padding: 14px 18px 4px;
  margin: 0;
  flex: 1;
}
.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price {
  display: block;
  padding: 4px 18px 10px;
  font-size: 1rem;
  font-weight: 700;
  color: var(--blue, #1c63d5);
}
.woocommerce ul.products li.product .button,
.woocommerce-page ul.products li.product .button {
  display: block !important;
  margin: 0 18px 18px;
  text-align: center;
}
/* Responsive archive grid:                                        */
/* 3-col on desktop (matches original Customizr Pro behaviour)     */
/* 2-col on narrow tablet / large phone                            */
/* 1-col on small phone                                            */
@media (max-width: 640px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 16px !important;
  }
}
@media (max-width: 420px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  .woocommerce ul.products li.product img,
  .woocommerce-page ul.products li.product img {
    height: 160px !important;
  }
}

/* ── Single product ───────────────────────────────────────────── */
/* WooCommerce's woocommerce-layout.css floats images/summary at  */
/* 48.8% each. We replace that with a clean CSS grid.             */
.woocommerce div.product,
.woocommerce-page div.product {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 48px !important;
  align-items: start;
  width: 100% !important;
  max-width: 1000px;
  margin: 0 auto;
}
/* Neutralise WooCommerce's own floats so grid takes over */
.woocommerce div.product div.images,
.woocommerce-page div.product div.images,
.woocommerce div.product div.summary,
.woocommerce-page div.product div.summary {
  float: none !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: 100% !important;
}
/* Tabs (description/reviews) and related/up-sell products are     */
/* WooCommerce's 3rd/4th direct children of div.product — they     */
/* fall into the 2-col grid as items 3 & 4 (side by side).        */
/* Force them to span the entire row width.                        */
.woocommerce div.product .woocommerce-tabs,
.woocommerce-page div.product .woocommerce-tabs,
.woocommerce div.product section.related,
.woocommerce-page div.product section.related,
.woocommerce div.product .up-sells,
.woocommerce-page div.product .up-sells {
  grid-column: 1 / -1 !important;
  width: 100% !important;
}
/* Related products inside a single product: 4 columns on desktop */
.woocommerce div.product section.related > ul.products,
.woocommerce-page div.product section.related > ul.products,
.woocommerce div.product .up-sells > ul.products,
.woocommerce-page div.product .up-sells > ul.products {
  grid-template-columns: repeat(4, 1fr) !important;
}
@media (max-width: 900px) {
  .woocommerce div.product section.related > ul.products,
  .woocommerce-page div.product section.related > ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 540px) {
  .woocommerce div.product section.related > ul.products,
  .woocommerce-page div.product section.related > ul.products {
    grid-template-columns: 1fr !important;
  }
}
@media (max-width: 680px) {
  .woocommerce div.product,
  .woocommerce-page div.product {
    grid-template-columns: 1fr !important;
  }
}
.woocommerce div.product .product_title {
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--navy, #0d2045);
  margin: 0 0 12px;
  line-height: 1.2;
}
.woocommerce div.product .price {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--blue, #1c63d5);
  margin: 0 0 20px;
}
.woocommerce div.product .woocommerce-product-details__short-description {
  color: #4b5563;
  line-height: 1.7;
  margin-bottom: 24px;
}

/* ── Cart table ───────────────────────────────────────────────── */
.shop_table { background-color: #f2f2f2; }

.woocommerce table.shop_table {
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--border, #e2e8f0);
  border-collapse: separate;
  border-spacing: 0;
  width: 100%;
  background: #fff;
}
.woocommerce table.shop_table th {
  background: var(--bg-alt2, #f8fafc);
  color: var(--navy, #0d2045);
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  padding: 14px 20px;
  border-bottom: 1px solid var(--border, #e2e8f0);
}
.woocommerce table.shop_table td {
  padding: 14px 20px;
  border-bottom: 1px solid var(--border, #e2e8f0);
  color: #374151;
  vertical-align: middle;
}
.woocommerce table.shop_table td:last-child,
.woocommerce table.shop_table th:last-child {
  border-right: none;
}

.woocommerce-cart .cart-collaterals {
  margin-top: 32px;
}
.woocommerce-cart .cart_totals {
  float: right;
  width: 100%;
  max-width: 420px;
  background: var(--bg-alt2, #f8fafc);
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 14px;
  padding: 24px;
}
.woocommerce-cart .cart_totals h2 {
  font-size: 1.1rem;
  margin-bottom: 16px;
  color: var(--navy, #0d2045);
}
.woocommerce-cart .cart_totals table th,
.woocommerce-cart .cart_totals table td {
  padding: 10px 0;
  border: none;
  border-bottom: 1px solid var(--border, #e2e8f0);
  background: none;
  font-size: 0.9rem;
}
.woocommerce-cart .cart_totals .wc-proceed-to-checkout {
  margin-top: 20px;
}
.woocommerce-cart .cart_totals .checkout-button {
  display: block;
  width: 100%;
  text-align: center;
  font-size: 1rem;
  padding: 14px;
  border-radius: 12px;
}

/* ── Checkout ────────────────────────────────────────────────── */
/* The [woocommerce_checkout] shortcode may or may not wrap its   */
/* output in a .woocommerce div depending on WC version.         */
/* Either way: neutralise that div so it doesn't create its own  */
/* grid / float context that would fight the form's grid below.  */
.woocommerce-checkout .woocommerce {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
}

/* Two-column grid lives on the form element — the direct parent  */
/* of #customer_details, #order_review_heading, #order_review.   */
form.woocommerce-checkout {
  display: grid;
  grid-template-columns: 1fr 420px;
  column-gap: 48px;
  row-gap: 0;
  align-items: start;
}

/* ── Grid row assignments ──────────────────────────────────── */
/* Row 1: notices / coupon — full width                          */
form.woocommerce-checkout > .woocommerce-notices-wrapper,
form.woocommerce-checkout > .woocommerce-message,
form.woocommerce-checkout > .woocommerce-info,
form.woocommerce-checkout > .woocommerce-error,
form.woocommerce-checkout > ul.woocommerce-error,
form.woocommerce-checkout > .woocommerce-form-coupon-toggle,
form.woocommerce-checkout > .checkout_coupon {
  grid-column: 1 / -1;
  grid-row: 1;
}

/* Row 2+: billing (left, spans all remaining rows)              */
form.woocommerce-checkout > #customer_details {
  grid-column: 1;
  grid-row: 2 / span 99;   /* span to keep level with right col */
  float: none;
  width: 100%;
}

/* Row 2: "Your order" heading (right) */
form.woocommerce-checkout > #order_review_heading {
  grid-column: 2;
  grid-row: 2;
  margin: 0 0 16px;
}

/* Row 3: order table + payment (right) */
form.woocommerce-checkout > #order_review {
  grid-column: 2;
  grid-row: 3;
  float: none;
  width: 100%;
}

/* ── Billing sub-columns: single column ───────────────────── */
/* WooCommerce splits #customer_details into .col-1 (billing)   */
/* and .col-2 (additional info) at ~48% each.  That's too       */
/* narrow inside the left grid column — make both full-width.   */
.woocommerce-checkout .col2-set { display: block; }
.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2 {
  float: none;
  width: 100%;
  padding: 0;
}
.woocommerce-checkout .col2-set .col-2 { margin-top: 24px; }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 860px) {
  form.woocommerce-checkout {
    grid-template-columns: 1fr;
    column-gap: 0;
  }
  form.woocommerce-checkout > #customer_details {
    grid-column: 1;
    grid-row: 2;
  }
  form.woocommerce-checkout > #order_review_heading {
    grid-column: 1;
    grid-row: 3;
    margin-top: 32px;
  }
  form.woocommerce-checkout > #order_review {
    grid-column: 1;
    grid-row: 4;
  }
}

/* ── Stripe UPE: ensure card iframe renders on mobile ────────── */
/* Without a min-height the Stripe resize observer can fire with  */
/* a 0-height container on mobile — only the tab header renders.  */
.wc-stripe-upe-element {
  display: block;
  min-height: 220px;
}
@media (max-width: 480px) {
  .wc-stripe-upe-element { min-height: 260px; }
}

.woocommerce form .form-row label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--navy, #0d2045);
  margin-bottom: 5px;
  display: block;
}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea {
  border: 1px solid #aaaaaa;
  border-radius: 8px;
  padding: 10px 14px;
  font-size: 0.9rem;
  width: 100%;
  box-sizing: border-box;
  transition: border-color .15s;
  background: #fff;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus,
.woocommerce form .form-row textarea:focus {
  outline: none;
  border-color: var(--blue, #1c63d5);
  box-shadow: 0 0 0 3px rgba(28,99,213,.1);
}

#order_review_heading {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--navy, #0d2045);
  margin-bottom: 16px;
}
#order_review {
  background: var(--bg-alt2, #f8fafc);
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 14px;
  padding: 24px;
}

/* ── My Account layout ──────────────────────────────────────── */
.woocommerce-account .woocommerce {
  display: flex;
  gap: 40px;
  align-items: flex-start;
}
@media (max-width: 740px) {
  .woocommerce-account .woocommerce { flex-direction: column; }
}

.woocommerce-MyAccount-navigation {
  width: 220px;
  flex-shrink: 0;
}
.woocommerce-MyAccount-navigation ul {
  list-style: none;
  margin: 0;
  padding: 0;
  background: #fff;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 12px;
  overflow: hidden;
}
.woocommerce-MyAccount-navigation ul li {
  border-bottom: 1px solid var(--border, #e2e8f0);
}
.woocommerce-MyAccount-navigation ul li:last-child { border-bottom: none; }
.woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 12px 18px;
  color: var(--navy, #0d2045);
  text-decoration: none;
  font-size: 0.88rem;
  font-weight: 500;
  transition: background .15s, color .15s;
}
.woocommerce-MyAccount-navigation ul li a:hover {
  background: #f1f5f9;
  color: var(--navy, #0d2045) !important;
  text-decoration: none;
}
.woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--active a {
  background: #f1f5f9 !important;
  color: var(--navy, #0d2045) !important;
  font-weight: 600;
  border-left: 3px solid var(--blue, #1c63d5);
  padding-left: 15px;
  text-decoration: none;
}

.woocommerce-MyAccount-content {
  flex: 1;
  min-width: 0;
}
.woocommerce-MyAccount-content p { margin-bottom: 12px; line-height: 1.7; }
.woocommerce-MyAccount-content h2,
.woocommerce-MyAccount-content h3 {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--navy, #0d2045);
  margin: 24px 0 14px;
}

/* My Account — orders table */
.woocommerce-orders-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
  font-size: 0.88rem;
}
.woocommerce-orders-table th {
  background: var(--bg-alt2, #f8fafc);
  color: var(--navy, #0d2045);
  font-weight: 700;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: .04em;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border, #e2e8f0);
}
.woocommerce-orders-table td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border, #e2e8f0);
  vertical-align: middle;
  color: #374151;
}
.woocommerce-orders-table tr:last-child td { border-bottom: none; }
.woocommerce-orders-table .woocommerce-button {
  font-size: 0.82rem;
  padding: 7px 14px;
  border-radius: 8px;
  white-space: nowrap;
}

/* Order status badges */
.woocommerce-order-status-active,
mark.order-status { background: none; }

.order-status.status-active,
.subscription-status.subscription-status--active { color: #16a34a; font-weight: 700; }
.order-status.status-on-hold                     { color: #d97706; font-weight: 700; }
.order-status.status-cancelled,
.order-status.status-failed                       { color: #dc2626; font-weight: 700; }
.order-status.status-processing,
.order-status.status-completed                    { color: #1c63d5; font-weight: 700; }

/* ── WooCommerce Subscriptions ──────────────────────────────── */
.woocommerce-orders-table--subscriptions .subscription-id a { font-weight: 700; }

.subscription-details {
  background: #fff;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 24px;
}
.subscription-details table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
}
.subscription-details table th {
  background: var(--bg-alt2, #f8fafc);
  padding: 12px 16px;
  text-align: left;
  font-weight: 700;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--navy, #0d2045);
  border-bottom: 1px solid var(--border, #e2e8f0);
}
.subscription-details table td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border, #e2e8f0);
  vertical-align: middle;
}
.subscription-details table tr:last-child td { border-bottom: none; }

.wcs-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 16px; }
.wcs-actions a,
.wcs-actions button { font-size: 0.85rem; padding: 9px 18px; border-radius: 8px; }

.subscription_renewal_date { color: var(--text-muted, #64748b); font-size: 0.82rem; }

/* Subscription status labels */
.woocommerce-subscriptions-status.active  { color: #16a34a; font-weight: 700; }
.woocommerce-subscriptions-status.expired,
.woocommerce-subscriptions-status.cancelled { color: #dc2626; font-weight: 700; }
.woocommerce-subscriptions-status.on-hold  { color: #d97706; font-weight: 700; }

/* ── Account address boxes ──────────────────────────────────── */
.woocommerce-account .addresses .title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.woocommerce-account .addresses .title h3 { margin: 0; font-size: 1rem; }
.woocommerce-account address {
  background: var(--bg-alt2, #f8fafc);
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 10px;
  padding: 16px 20px;
  font-style: normal;
  font-size: 0.88rem;
  line-height: 1.8;
  color: #374151;
}

/* ── Lost password / login form ─────────────────────────────── */
.woocommerce-account .u-columns { display: flex; gap: 40px; flex-wrap: wrap; }
.woocommerce-account .u-columns .col-1,
.woocommerce-account .u-columns .col-2 { flex: 1; min-width: 260px; }

.woocommerce form.woocommerce-form-login,
.woocommerce form.register {
  background: #fff;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 14px;
  padding: 28px;
}
.woocommerce form.woocommerce-form-login h2,
.woocommerce form.register h2 { font-size: 1.2rem; margin-bottom: 20px; }

/* ── Payment methods ────────────────────────────────────────── */
.woocommerce-PaymentMethods,
.payment_methods {
  list-style: none;
  margin: 0 0 20px;
  padding: 0;
}
.payment_methods li {
  padding: 12px;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 10px;
  margin-bottom: 8px;
  background: #fff;
}
.payment_methods li label { font-weight: 600; cursor: pointer; }
.payment_box {
  padding: 12px 0 4px;
  font-size: 0.88rem;
  color: #6b7280;
}

/* ── Coupon / promo code ────────────────────────────────────── */
.woocommerce-cart .coupon {
  display: flex;
  gap: 10px;
  align-items: center;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.woocommerce-cart .coupon input[type="text"] {
  border: 1px solid #aaaaaa;
  border-radius: 8px;
  padding: 10px 14px;
  font-size: 0.9rem;
  max-width: 240px;
}

/* ── Responsive tweaks ───────────────────────────────────────── */
@media (max-width: 860px) {
  /* Single product: stack image above summary on tablet */
  .woocommerce div.product,
  .woocommerce-page div.product {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }
}
@media (max-width: 600px) {
  .woocommerce-MyAccount-navigation { width: 100%; }
  .woocommerce table.shop_table th,
  .woocommerce table.shop_table td { padding: 10px 12px; font-size: 0.82rem; }
  /* Single product: tighter on small screens */
  .woocommerce div.product,
  .woocommerce-page div.product {
    gap: 20px !important;
  }
}
