/* PixVino WooCommerce Styling – header, dark/light theme, content */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Oswald:wght@400;500;600;700&display=swap');

:root {
  --pixvino-bg: #0a0a1a;
  --pixvino-bg-secondary: #12121f;
  --pixvino-card: #1a1a2e;
  --pixvino-pink: #ff006e;
  --pixvino-purple: #8338ec;
  --pixvino-cyan: #00d9ff;
  --pixvino-text: #ffffff;
  --pixvino-text-secondary: #a0a0b0;
  --pixvino-text-muted: #6a6a7a;
  --pixvino-border: rgba(255, 255, 255, 0.1);
  --pixvino-shadow: rgba(255, 0, 110, 0.3);
  --pixvino-wc-header-height: 6rem;
}

@media (min-width: 768px) {
  :root {
    --pixvino-wc-header-height: 7rem;
  }
}

@media (min-width: 1024px) {
  :root {
    --pixvino-wc-header-height: 8rem;
  }
}

/* Light theme – matches app [data-theme="light"] */
[data-theme="light"] {
  --pixvino-bg: #f1f5f9;
  --pixvino-bg-secondary: #ffffff;
  --pixvino-card: #ffffff;
  --pixvino-pink: #16a34a;
  --pixvino-purple: #7c3aed;
  --pixvino-cyan: #22c55e;
  --pixvino-text: #0f172a;
  --pixvino-text-secondary: #475569;
  --pixvino-text-muted: #64748b;
  --pixvino-border: rgba(15, 23, 42, 0.12);
  --pixvino-shadow: rgba(22, 163, 74, 0.25);
}

/* Hide Astra/theme chrome on WooCommerce pages so PixVino shell is the only one */
.pixvino-wc-page .site-header,
.pixvino-wc-page #masthead,
.pixvino-wc-page .main-header-bar-wrap,
.pixvino-wc-page .ast-mobile-header-wrap,
.pixvino-wc-page .ast-above-header-wrap,
.pixvino-wc-page .ast-below-header-wrap,
.pixvino-wc-page #colophon,
.pixvino-wc-page .site-footer,
.pixvino-wc-page .site-title,
.pixvino-wc-page .site-description,
.pixvino-wc-page .site-branding,
.pixvino-wc-page .ast-site-title-wrap,
.pixvino-wc-page .ast-site-identity,
.pixvino-wc-page .wp-block-site-title,
.pixvino-wc-page .wp-block-site-tagline,
.pixvino-wc-page [class*="site-title"],
.pixvino-wc-page [id*="site-title"],
.pixvino-wc-page header:not(.pixvino-wc-header),
.pixvino-wc-page footer {
  display: none !important;
}

/* ── ORDER-PAY PAGE SPECIFIC ─────────────────────────────────────
   Hide the Astra page-title/hero banner completely.
   The "PAY FOR ORDER" title will be re-shown inside our card box. */

/* Hide PayPal Pay Later / messaging banners injected by ppcp plugin */
body.woocommerce-order-pay .ppcp-messages,
body.woocommerce-order-pay .ppcp-message,
body.woocommerce-order-pay [data-pp-message],
body.woocommerce-order-pay .ppcpBnpl,
body.woocommerce-order-pay .ppcp-bnpl-product-hook,
body.woocommerce-order-pay #ppcp-messages,
body.woocommerce-order-pay .wc-ppcp-gateway-banner,
/* The "PayPal / Learn more" banner above the payment form */
body.woocommerce-order-pay .ppcp-credit-messaging,
body.woocommerce-order-pay .ppcp-gateway-banner-wrapper,
body.woocommerce-order-pay [id^="ppcp-"][id$="-message"] {
  display: none !important;
}

body.woocommerce-order-pay .ast-page-title-area,
body.woocommerce-order-pay .ast-breadcrumbs-wrapper,
body.woocommerce-order-pay .ast-single-entry-banner,
body.woocommerce-order-pay .ast-hero-section,
body.woocommerce-order-pay .page-header,
body.woocommerce-order-pay .entry-header,
body.woocommerce-order-pay .page-title-wrap,
body.woocommerce-order-pay .ast-archive-description {
  display: none !important;
}

/* Hide the cart icon in the PixVino WC header on the order-pay page */
body.woocommerce-order-pay .pixvino-wc-cart-link {
  display: none !important;
}

/* Centre the WooCommerce order-pay container and wrap it in a card box */
body.woocommerce-order-pay .woocommerce {
  max-width: 640px !important;
  margin: 2rem auto !important;
  background: var(--pixvino-card) !important;
  border: 1px solid var(--pixvino-border) !important;
  border-radius: 1.5rem !important;
  padding: 0 !important;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.25), inset 0 0 0 1px rgba(255,255,255,0.04) !important;
  overflow: hidden !important;
}

/* Title bar at the top of the card – recreates "Pay for order" heading */
body.woocommerce-order-pay .woocommerce::before {
  content: "PAY FOR ORDER";
  display: block;
  font-family: 'Oswald', sans-serif;
  font-size: clamp(1.5rem, 4vw, 2.25rem);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--pixvino-text);
  text-align: center;
  padding: 2rem 2rem 1.5rem;
  border-bottom: 1px solid var(--pixvino-border);
  background: radial-gradient(ellipse 80% 60% at 50% 0%, color-mix(in srgb, var(--pixvino-pink) 16%, transparent), transparent 70%);
}

[data-theme="light"] body.woocommerce-order-pay .woocommerce::before {
  color: var(--pixvino-text);
  background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(22, 163, 74, 0.14), transparent 70%);
}

/* Inner padding for the form content */
body.woocommerce-order-pay .woocommerce > * {
  padding-left: 2rem !important;
  padding-right: 2rem !important;
}
body.woocommerce-order-pay .woocommerce > *:last-child {
  padding-bottom: 2rem !important;
}

/* Payment section inside order-pay card */
body.woocommerce-order-pay #payment {
  background: color-mix(in srgb, var(--pixvino-bg) 40%, transparent) !important;
  border: 1px solid var(--pixvino-border) !important;
  border-radius: 1rem !important;
  margin: 0.5rem 0 1rem !important;
}
body.woocommerce-order-pay #payment ul.payment_methods {
  border-bottom: 1px solid var(--pixvino-border) !important;
}
body.woocommerce-order-pay #payment ul.payment_methods li label {
  color: var(--pixvino-text) !important;
  font-weight: 600 !important;
}
body.woocommerce-order-pay #payment div.payment_box {
  background: color-mix(in srgb, var(--pixvino-card) 90%, transparent) !important;
  border: 1px solid var(--pixvino-border) !important;
  color: var(--pixvino-text-secondary) !important;
}
body.woocommerce-order-pay #payment div.payment_box::before {
  border-bottom-color: color-mix(in srgb, var(--pixvino-card) 90%, transparent) !important;
}
body.woocommerce-order-pay #payment .place-order {
  padding-top: 1rem !important;
}
body.woocommerce-order-pay #payment #place_order {
  width: 100% !important;
  min-height: 48px;
  border-radius: 10px !important;
  font-size: 0.93rem !important;
  letter-spacing: 0.07em !important;
}

/* Order summary table inside card */
body.woocommerce-order-pay .shop_table.order_details {
  margin-top: 1rem !important;
  border: 1px solid var(--pixvino-border) !important;
  border-radius: 0.75rem !important;
  background: transparent !important;
}
body.woocommerce-order-pay .shop_table.order_details th,
body.woocommerce-order-pay .shop_table.order_details td {
  color: var(--pixvino-text) !important;
}

/* ── END ORDER-PAY ───────────────────────────────────────────── */

/* ── ORDER-RECEIVED / THANK-YOU PAGE ─────────────────────────── */
body.woocommerce-order-received .ast-page-title-area,
body.woocommerce-order-received .ast-breadcrumbs-wrapper,
body.woocommerce-order-received .ast-single-entry-banner,
body.woocommerce-order-received .ast-hero-section,
body.woocommerce-order-received .page-header,
body.woocommerce-order-received .entry-header,
body.woocommerce-order-received .page-title-wrap,
body.woocommerce-order-received .ast-archive-description {
  display: none !important;
}

body.woocommerce-order-received .woocommerce {
  max-width: 980px !important;
  margin: 2rem auto !important;
}

body.woocommerce-order-received .woocommerce-thankyou-order-received,
body.woocommerce-order-received .woocommerce-thankyou-order-failed,
body.woocommerce-order-received .woocommerce-thankyou-order-failed-actions {
  display: none !important;
}

body.woocommerce-order-received .woocommerce-order {
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--pixvino-pink) 14%, transparent), transparent 45%),
    linear-gradient(180deg, color-mix(in srgb, var(--pixvino-card) 92%, #ffffff 8%), var(--pixvino-card));
  border: 1px solid var(--pixvino-border) !important;
  border-radius: 1.5rem !important;
  padding: 1.75rem !important;
  box-shadow: 0 20px 46px rgba(0, 0, 0, 0.24), inset 0 0 0 1px rgba(255,255,255,0.04);
}

body.woocommerce-order-received ul.order_details {
  display: none !important;
}

body.woocommerce-order-received .woocommerce-order-details,
body.woocommerce-order-received .woocommerce-customer-details {
  margin-top: 1.5rem;
}

body.woocommerce-order-received .woocommerce-customer-details address {
  border: 1px solid var(--pixvino-border);
  border-radius: 1rem;
  background: color-mix(in srgb, var(--pixvino-bg) 28%, transparent);
  color: var(--pixvino-text);
  padding: 1rem 1.15rem;
  overflow-wrap: anywhere;
  word-break: break-word;
}

body.woocommerce-order-received .woocommerce-customer-details address p,
body.woocommerce-order-received .woocommerce-customer-details address a {
  overflow-wrap: anywhere;
  word-break: break-word;
}

body.woocommerce-order-received .woocommerce-customer-details .woocommerce-customer-details--email {
  display: none !important;
}

.pixvino-wc-status-card {
  --pixvino-status-accent: var(--pixvino-cyan);
  max-width: 980px;
  margin: 0 auto 1.5rem;
  padding: 2rem;
  border-radius: 1.6rem;
  border: 1px solid var(--pixvino-border);
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--pixvino-status-accent) 18%, transparent), transparent 44%),
    radial-gradient(circle at top left, color-mix(in srgb, var(--pixvino-pink) 12%, transparent), transparent 38%),
    linear-gradient(180deg, color-mix(in srgb, var(--pixvino-card) 94%, #ffffff 6%), var(--pixvino-card));
  box-shadow: 0 22px 52px rgba(0, 0, 0, 0.28), inset 0 0 0 1px rgba(255,255,255,0.04);
  position: relative;
  overflow: hidden;
}

.pixvino-wc-status-card--success {
  --pixvino-status-accent: var(--pixvino-cyan);
}

.pixvino-wc-status-card--pending {
  --pixvino-status-accent: #f59e0b;
}

.pixvino-wc-status-card--error {
  --pixvino-status-accent: var(--pixvino-pink);
}

.pixvino-wc-status-card__hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.pixvino-wc-status-card__emoji {
  width: 4.25rem;
  height: 4.25rem;
  border-radius: 1.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.2), transparent 45%),
    linear-gradient(135deg, color-mix(in srgb, var(--pixvino-status-accent) 78%, var(--pixvino-pink)), color-mix(in srgb, var(--pixvino-status-accent) 48%, var(--pixvino-cyan)));
  box-shadow: 0 16px 36px color-mix(in srgb, var(--pixvino-status-accent) 28%, transparent);
  animation: pixvino-status-float 3.8s ease-in-out infinite;
}

.pixvino-wc-status-card__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  min-height: 2rem;
  padding: 0.3rem 0.8rem;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--pixvino-status-accent) 52%, transparent);
  background: color-mix(in srgb, var(--pixvino-status-accent) 14%, transparent);
  color: var(--pixvino-status-accent);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.pixvino-wc-status-card__badge-icon {
  font-size: 0.95rem;
}

.pixvino-wc-status-card__eyebrow {
  margin: 1rem 0 0.4rem;
  color: var(--pixvino-text-secondary);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.pixvino-wc-status-card__title {
  margin: 0;
  font-family: 'Oswald', sans-serif;
  font-size: clamp(2rem, 4vw, 3.5rem);
  line-height: 1;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--pixvino-text);
}

.pixvino-wc-status-card__title-main {
  color: var(--pixvino-text);
}

.pixvino-wc-status-card__title-accent {
  color: var(--pixvino-status-accent);
  background: linear-gradient(135deg, var(--pixvino-status-accent), var(--pixvino-pink));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.pixvino-wc-status-card__thanks {
  max-width: 50rem;
  margin: 1rem 0 0;
  padding: 1rem 1.15rem;
  border-radius: 1rem;
  border: 1px solid color-mix(in srgb, var(--pixvino-status-accent) 30%, var(--pixvino-border));
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--pixvino-status-accent) 14%, transparent), transparent 70%),
    color-mix(in srgb, var(--pixvino-bg) 20%, transparent);
  color: var(--pixvino-text);
  font-size: 1.02rem;
  line-height: 1.75;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.02);
}

.pixvino-wc-status-card__thanks-emoji {
  margin-right: 0.45rem;
}

.pixvino-wc-status-card__thanks-name {
  color: var(--pixvino-status-accent);
  font-weight: 700;
}

.pixvino-wc-status-card__thanks-brand {
  color: var(--pixvino-pink);
  font-weight: 700;
}

.pixvino-wc-status-card__message {
  max-width: 46rem;
  margin: 0.9rem 0 0;
  color: var(--pixvino-text-secondary);
  font-size: 1rem;
  line-height: 1.7;
}

.pixvino-wc-status-card__meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 0.85rem;
  margin-top: 1.4rem;
}

.pixvino-wc-status-card__meta-item {
  padding: 0.95rem 1rem;
  border-radius: 0.95rem;
  border: 1px solid var(--pixvino-border);
  background: color-mix(in srgb, var(--pixvino-bg) 34%, transparent);
  transition: transform 0.18s ease, border-color 0.18s ease, background-color 0.18s ease;
}

.pixvino-wc-status-card__meta-item:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--pixvino-status-accent) 34%, var(--pixvino-border));
  background: color-mix(in srgb, var(--pixvino-status-accent) 10%, var(--pixvino-card));
}

.pixvino-wc-status-card__meta-label {
  display: block;
  margin-bottom: 0.35rem;
  color: var(--pixvino-text-muted);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.pixvino-wc-status-card__meta-item strong {
  color: var(--pixvino-text);
  font-size: 1rem;
  font-weight: 700;
}

.pixvino-wc-status-card__guest-note {
  margin-top: 1.4rem;
  padding: 1.1rem 1.15rem;
  border-radius: 1.15rem;
  border: 1px solid color-mix(in srgb, var(--pixvino-pink) 24%, var(--pixvino-border));
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--pixvino-pink) 10%, transparent), color-mix(in srgb, var(--pixvino-purple) 8%, transparent)),
    color-mix(in srgb, var(--pixvino-card) 92%, transparent);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.02);
}

.pixvino-wc-status-card__guest-note-title {
  margin: 0;
  color: var(--pixvino-text);
  font-size: 1rem;
  font-weight: 700;
}

.pixvino-wc-status-card__guest-note-text {
  margin: 0.45rem 0 0;
  color: var(--pixvino-text-secondary);
  font-size: 0.95rem;
  line-height: 1.65;
}

.pixvino-wc-status-card__guest-note-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1rem;
}

.pixvino-wc-status-card__guest-note-actions .button {
  min-width: 190px;
  text-align: center;
}

.pixvino-wc-status-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  margin-top: 1.45rem;
}

.pixvino-wc-status-card__actions .button {
  min-width: 190px;
  text-align: center;
}

.pixvino-wc-status-card__button-secondary {
  background: transparent !important;
  border: 1px solid var(--pixvino-border) !important;
  box-shadow: none !important;
  color: var(--pixvino-text) !important;
}

.pixvino-wc-status-card__button-secondary:hover {
  background: color-mix(in srgb, var(--pixvino-status-accent) 12%, transparent) !important;
  transform: none !important;
  box-shadow: none !important;
}

[data-theme="light"] body.woocommerce-order-received .woocommerce-order {
  background:
    radial-gradient(circle at top right, rgba(34, 197, 94, 0.18), transparent 48%),
    linear-gradient(180deg, #ffffff, #f8fbff);
  border-color: rgba(124, 58, 237, 0.22) !important;
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.08);
}

[data-theme="light"] body.woocommerce-order-received .woocommerce-customer-details address,
[data-theme="light"] .pixvino-wc-status-card__meta-item {
  background: rgba(255, 255, 255, 0.78);
  border-color: rgba(15, 23, 42, 0.12);
}

[data-theme="light"] .pixvino-wc-status-card {
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.08);
}

[data-theme="light"] .pixvino-wc-status-card__guest-note {
  background:
    linear-gradient(135deg, rgba(22, 163, 74, 0.08), rgba(124, 58, 237, 0.06)),
    rgba(255, 255, 255, 0.85);
  border-color: rgba(22, 163, 74, 0.2);
}

@keyframes pixvino-status-float {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-6px);
  }
}

@keyframes pixvino-wc-badge-pulse {
  0%,
  100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.08);
  }
}

@media (max-width: 782px) {
  .pixvino-wc-status-card,
  body.woocommerce-order-received .woocommerce-order {
    padding: 1.25rem !important;
    border-radius: 1.2rem !important;
  }

  .pixvino-wc-status-card__hero {
    align-items: flex-start;
  }

  .pixvino-wc-status-card__emoji {
    width: 3.4rem;
    height: 3.4rem;
    font-size: 1.6rem;
  }

  .pixvino-wc-status-card__actions .button {
    width: 100%;
    min-width: 0;
  }
}

/* ── END ORDER-RECEIVED / THANK-YOU PAGE ─────────────────────── */

/* Hard-reset ALL button/link styles inside the header so Astra/WP themes can't add borders or backgrounds */
.pixvino-wc-header button,
.pixvino-wc-header a,
.pixvino-wc-header input[type="button"],
.pixvino-wc-header input[type="submit"] {
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  text-decoration: none !important;
  background-image: none !important;
}

/* PixVino header bar – fixed, matches app header look; icons/text use theme colors */
.pixvino-wc-header {
  position: fixed;
  top: 0 !important;
  left: 0;
  right: 0;
  width: 100% !important;
  max-width: 100vw;
  box-sizing: border-box;
  z-index: 9999;
  background: var(--pixvino-bg);
  border-bottom: none;
  font-family: 'Inter', sans-serif;
  box-shadow: none;
  color: var(--pixvino-text);
}

[data-theme="light"] .pixvino-wc-header {
  background: linear-gradient(to top, rgba(236, 253, 243, 0.42), transparent);
  border-bottom-color: rgba(15, 23, 42, 0.22);
  backdrop-filter: blur(12px) saturate(1.1);
  -webkit-backdrop-filter: blur(12px) saturate(1.1);
}

.pixvino-wc-header.is-scrolled {
  border-bottom: 1px solid var(--pixvino-border);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.2);
}

[data-theme="light"] .pixvino-wc-header.is-scrolled {
  border-bottom-color: rgba(15, 23, 42, 0.22);
}

.pixvino-wc-header-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1rem;
  height: var(--pixvino-wc-header-height);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}

@media (min-width: 640px) {
  .pixvino-wc-header-inner {
    padding: 0 1.5rem;
  }
}

@media (min-width: 1024px) {
  .pixvino-wc-header-inner {
    padding: 0 3rem;
  }
}

@media (min-width: 1280px) {
  .pixvino-wc-header-inner {
    padding: 0 4rem;
  }
}

.pixvino-wc-logo {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex: 0 0 auto;
  min-width: 0;
  text-decoration: none;
  color: inherit;
  position: relative;
  z-index: 10;
}

.pixvino-wc-logo,
.pixvino-wc-logo:hover,
.pixvino-wc-logo:focus,
.pixvino-wc-logo:focus-visible {
  background: transparent !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
}

.pixvino-wc-logo::before,
.pixvino-wc-logo::after {
  content: none !important;
  display: none !important;
}

.pixvino-wc-logo-image {
  width: auto;
  height: 2.25rem !important;
  max-height: 2.25rem !important;
  max-width: 12rem !important;
  object-fit: contain;
  display: block;
  flex: 0 0 auto;
  transition: transform 0.3s ease;
}

.pixvino-wc-logo:hover .pixvino-wc-logo-image {
  transform: scale(1.05);
}

.pixvino-wc-logo img {
  width: auto !important;
  max-width: 12rem !important;
  height: 2.25rem !important;
  max-height: 2.25rem !important;
}

@media (min-width: 768px) {
  .pixvino-wc-logo {
    gap: 1rem;
  }

  .pixvino-wc-logo-image,
  .pixvino-wc-logo img {
    height: 2.5rem !important;
    max-height: 2.5rem !important;
  }
}

@media (min-width: 1024px) {
  .pixvino-wc-logo-image,
  .pixvino-wc-logo img {
    height: 3rem !important;
    max-height: 3rem !important;
  }
}

.pixvino-wc-logo-text {
  font-family: 'Oswald', sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1;
  letter-spacing: 0.05em;
  white-space: nowrap;
}

@media (min-width: 768px) {
  .pixvino-wc-logo-text {
    font-size: 1.5rem;
  }
}

@media (min-width: 1024px) {
  .pixvino-wc-logo-text {
    font-size: 1.875rem;
  }
}

.pixvino-wc-logo-pix { color: var(--pixvino-text); }
.pixvino-wc-logo-vino { color: var(--pixvino-pink); }

.pixvino-wc-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-left: auto;
}

@media (min-width: 768px) {
  .pixvino-wc-actions {
    gap: 1rem;
  }
}

/* Scoped to PixVino WC header so theme cannot override */
.pixvino-wc-header .pixvino-wc-icon-button {
  width: 3rem !important;
  height: 3rem !important;
  min-width: 3rem !important;
  min-height: 3rem !important;
  box-sizing: border-box !important;
  padding: 0 !important;
  border-radius: 0.75rem;
  border: none !important;
  background: transparent !important;
  color: var(--pixvino-text) !important;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  text-decoration: none;
  line-height: 1 !important;
  transition: transform 0.3s ease, background-color 0.3s ease;
  box-shadow: none !important;
}

@media (min-width: 768px) {
  .pixvino-wc-header .pixvino-wc-icon-button {
    width: 3.5rem !important;
    height: 3.5rem !important;
    min-width: 3.5rem !important;
    min-height: 3.5rem !important;
  }
}

.pixvino-wc-header .pixvino-wc-icon-button:hover {
  transform: scale(1.1);
  background-color: rgba(255, 255, 255, 0.1) !important;
}

[data-theme="dark"] .pixvino-wc-header .pixvino-wc-icon-button:active,
[data-theme="light"] .pixvino-wc-header .pixvino-wc-icon-button:active,
.pixvino-wc-header .pixvino-wc-icon-button:active {
  transform: scale(0.95);
}

[data-theme="light"] .pixvino-wc-header .pixvino-wc-icon-button:hover {
  background-color: rgba(0, 0, 0, 0.05) !important;
}

.pixvino-wc-header .pixvino-wc-icon-button:focus,
.pixvino-wc-header .pixvino-wc-icon-button:focus-visible {
  outline: none !important;
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--pixvino-pink) 40%, transparent) !important;
}

.pixvino-wc-header .pixvino-wc-icon-button > .pixvino-wc-icon-svg {
  width: 55px !important;
  height: 55px !important;
  display: block;
  color: var(--pixvino-text);
  stroke: var(--pixvino-text);
  transition: transform 0.3s ease, color 0.3s ease, stroke 0.3s ease;
}

.pixvino-wc-header .pixvino-wc-cart-link > .pixvino-wc-icon-svg {
  width: 48px !important;
  height: 48px !important;
  flex: 0 0 auto;
}

/* Keep the native WooCommerce order-pay / thank-you header aligned with the
   app header scale. These pages render the WC header, not the React header. */
body.woocommerce-order-pay .pixvino-wc-header .pixvino-wc-icon-button > .pixvino-wc-icon-svg,
body.woocommerce-order-received .pixvino-wc-header .pixvino-wc-icon-button > .pixvino-wc-icon-svg {
  width: 2rem !important;
  height: 2rem !important;
}

body.woocommerce-order-pay .pixvino-wc-header .pixvino-wc-cart-link > .pixvino-wc-icon-svg,
body.woocommerce-order-received .pixvino-wc-header .pixvino-wc-cart-link > .pixvino-wc-icon-svg {
  width: 2rem !important;
  height: 2rem !important;
}

@media (min-width: 768px) {
  .pixvino-wc-header .pixvino-wc-icon-button > .pixvino-wc-icon-svg {
    width: 2.5rem !important;
    height: 2.5rem !important;
  }

  .pixvino-wc-header .pixvino-wc-cart-link > .pixvino-wc-icon-svg {
    width: 2.2rem !important;
    height: 2.2rem !important;
  }

  body.woocommerce-order-pay .pixvino-wc-header .pixvino-wc-icon-button > .pixvino-wc-icon-svg,
  body.woocommerce-order-received .pixvino-wc-header .pixvino-wc-icon-button > .pixvino-wc-icon-svg {
    width: 2.5rem !important;
    height: 2.5rem !important;
  }

  body.woocommerce-order-pay .pixvino-wc-header .pixvino-wc-cart-link > .pixvino-wc-icon-svg,
  body.woocommerce-order-received .pixvino-wc-header .pixvino-wc-cart-link > .pixvino-wc-icon-svg {
    width: 2.2rem !important;
    height: 2.2rem !important;
  }
}

.pixvino-wc-menu-toggle:hover .pixvino-wc-icon-svg {
  transform: rotate(12deg);
}

.pixvino-wc-account-toggle:hover .pixvino-wc-icon-svg {
  transform: scale(1.1);
}

.pixvino-wc-theme-toggle:hover .pixvino-wc-icon-svg,
.pixvino-wc-cart-link:hover .pixvino-wc-icon-svg {
  transform: scale(1.05);
}

.pixvino-wc-dropdown-wrap {
  position: relative;
}

.pixvino-wc-dropdown {
  position: absolute;
  right: 0;
  top: calc(100% + 0.5rem);
  min-width: 220px;
  border-radius: 0.75rem;
  border: 1px solid var(--pixvino-border);
  padding: 0.5rem 0;
  background: var(--pixvino-bg);
  color: var(--pixvino-text);
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.25);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
  z-index: 100;
}

.pixvino-wc-dropdown.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

/* Section header inside dropdowns – matches app's "Account" divider */
.pixvino-wc-dropdown-section-label {
  padding: 0.5rem 1rem;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--pixvino-text-muted);
  border-bottom: 1px solid var(--pixvino-border);
  margin-bottom: 0.25rem;
}

.pixvino-wc-dropdown-item {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.25rem;
  text-decoration: none;
  color: var(--pixvino-text) !important;
  font-family: 'Inter', sans-serif;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  transition: opacity 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}

.pixvino-wc-dropdown-item:hover {
  color: var(--pixvino-text) !important;
  background: transparent;
  opacity: 0.9;
}

.pixvino-wc-dropdown-item .pixvino-wc-dropdown-item-icon,
.pixvino-wc-dropdown-item .pixvino-wc-icon-svg {
  color: var(--pixvino-text-secondary);
  stroke: var(--pixvino-text-secondary);
}

.pixvino-wc-dropdown-item:hover .pixvino-wc-dropdown-item-icon,
.pixvino-wc-dropdown-item:hover .pixvino-wc-icon-svg {
  color: var(--pixvino-text-secondary);
  stroke: var(--pixvino-text-secondary);
}

.pixvino-wc-dropdown-item-icon {
  width: 1.25rem !important;
  height: 1.25rem !important;
  flex: 0 0 auto;
}

/* Account button gets a pink tint when its dropdown is open – matches app */
.pixvino-wc-dropdown-wrap:has(.pixvino-wc-account-dropdown.is-open) > button {
  background-color: color-mix(in srgb, var(--pixvino-pink) 12%, transparent) !important;
}

.pixvino-wc-cart-badge {
  position: absolute;
  top: -0.125rem;
  right: -0.125rem;
  min-width: 20px;
  height: 20px;
  padding: 0 0.2rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.625rem;
  font-weight: 700;
  color: #fff;
  background: var(--pixvino-pink);
  line-height: 1;
  animation: pixvino-wc-badge-pulse 1.8s ease-in-out infinite;
}

@media (min-width: 768px) {
  .pixvino-wc-cart-badge {
    min-width: 22px;
    height: 22px;
    font-size: 0.75rem;
  }
}

.pixvino-wc-theme-toggle .pixvino-wc-theme-icon.moon {
  display: none;
}

.pixvino-wc-theme-toggle .pixvino-wc-theme-icon.sun {
  display: block;
}

[data-theme="light"] .pixvino-wc-theme-toggle .pixvino-wc-theme-icon.moon {
  display: block;
}

[data-theme="light"] .pixvino-wc-theme-toggle .pixvino-wc-theme-icon.sun {
  display: none;
}

/* Spacer so main content is not under fixed header */
.pixvino-wc-page .site-content,
.pixvino-wc-page main,
.pixvino-wc-page #content,
.pixvino-wc-page .content-area,
.pixvino-wc-page .woocommerce {
  padding-top: var(--pixvino-wc-header-height) !important;
}
/* Keep header fully in bounds when WordPress admin bar is visible */
body.admin-bar .pixvino-wc-header {
  top: 32px !important;
}
body.admin-bar.pixvino-wc-page .site-content,
body.admin-bar.pixvino-wc-page main,
body.admin-bar.pixvino-wc-page #content,
body.admin-bar.pixvino-wc-page .content-area,
body.admin-bar.pixvino-wc-page .woocommerce {
  padding-top: calc(var(--pixvino-wc-header-height) + 32px) !important;
}
@media (max-width: 782px) {
  body.admin-bar .pixvino-wc-header {
    top: 46px !important;
  }
  body.admin-bar.pixvino-wc-page .site-content,
  body.admin-bar.pixvino-wc-page main,
  body.admin-bar.pixvino-wc-page #content,
  body.admin-bar.pixvino-wc-page .content-area,
  body.admin-bar.pixvino-wc-page .woocommerce {
    padding-top: calc(var(--pixvino-wc-header-height) + 46px) !important;
  }
}
.pixvino-wc-page .ast-container,
.pixvino-wc-page .site-content .ast-container {
  max-width: 1220px !important;
  padding-left: 1rem !important;
  padding-right: 1rem !important;
}
.pixvino-wc-page .entry-content,
.pixvino-wc-page .site-content {
  background: transparent !important;
}

/* Full page background on WooCommerce pages */
body.pixvino-wc-page {
  background-color: var(--pixvino-bg) !important;
  color: var(--pixvino-text);
  font-family: 'Inter', sans-serif;
  position: relative;
  overflow-x: hidden;
  margin: 0 !important;
}

/* Global WooCommerce Wrapper */
.woocommerce-page,
body.pixvino-wc-page .woocommerce {
  background-color: transparent;
  color: var(--pixvino-text);
  font-family: 'Inter', sans-serif;
  position: relative;
  z-index: 1;
}

#pixvino-wc-particles {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
  opacity: 0.78;
}
[data-theme="light"] #pixvino-wc-particles {
  opacity: 0.5;
}

.woocommerce-page h1,
.woocommerce-page h2,
.woocommerce-page h3,
.woocommerce-page h4 {
  font-family: 'Oswald', sans-serif;
  color: var(--pixvino-text);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

/* Links */
.woocommerce-page a {
  color: var(--pixvino-cyan);
}
.woocommerce-page a:hover {
  color: var(--pixvino-pink);
}

/* Buttons */
.woocommerce button.button,
.woocommerce a.button,
.woocommerce #respond input#submit,
.woocommerce input.button,
.woocommerce .woocommerce-button {
  background: linear-gradient(135deg, var(--pixvino-pink), var(--pixvino-purple)) !important;
  color: white !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 12px 24px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  transition: all 0.3s ease !important;
  box-shadow: 0 4px 15px var(--pixvino-shadow);
}

.woocommerce button.button:hover,
.woocommerce a.button:hover,
.woocommerce input.button:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px var(--pixvino-shadow);
  background: linear-gradient(135deg, var(--pixvino-cyan), var(--pixvino-purple)) !important;
}

/* Inputs */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea {
  background-color: var(--pixvino-card) !important;
  border: 1px solid var(--pixvino-border) !important;
  color: var(--pixvino-text) !important;
  border-radius: 8px !important;
  padding: 12px !important;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
  border-color: var(--pixvino-pink) !important;
  outline: none;
}

/* Notices / Alerts */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  background-color: var(--pixvino-bg-secondary) !important;
  color: var(--pixvino-text) !important;
  border-top: 3px solid var(--pixvino-pink) !important;
}
.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before {
  color: var(--pixvino-pink) !important;
}

/* My Account Navigation */
.woocommerce-account .woocommerce-MyAccount-navigation {
  background-color: var(--pixvino-card);
  border-radius: 12px;
  padding: 20px;
  border: 1px solid var(--pixvino-border);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li {
  margin-bottom: 10px;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 10px 15px;
  border-radius: 6px;
  color: var(--pixvino-text-secondary);
  text-decoration: none;
  transition: all 0.2s;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
  background-color: var(--pixvino-bg);
  color: var(--pixvino-text);
  border-left: 3px solid var(--pixvino-pink);
}

/* My Account Content */
.woocommerce-account .woocommerce-MyAccount-content {
  background-color: var(--pixvino-card);
  padding: 30px;
  border-radius: 12px;
  border: 1px solid var(--pixvino-border);
}

/* Password reset / lost password pages */
body.woocommerce-lost-password .woocommerce,
body.woocommerce-account:not(.logged-in) .woocommerce {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}

.woocommerce form.lost_reset_password,
.woocommerce .woocommerce-ResetPassword.lost_reset_password {
  max-width: 620px;
  margin: 1.5rem auto 2.5rem;
  padding: 2rem;
  border-radius: 1rem;
  border: 1px solid var(--pixvino-border);
  background:
    radial-gradient(circle at top right, rgba(255, 0, 110, 0.14), transparent 45%),
    linear-gradient(180deg, color-mix(in srgb, var(--pixvino-card) 90%, #ffffff 10%), var(--pixvino-card));
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.22);
}

.woocommerce form.lost_reset_password p,
.woocommerce .woocommerce-ResetPassword.lost_reset_password p {
  color: var(--pixvino-text-secondary);
  line-height: 1.6;
}

.woocommerce form.lost_reset_password label,
.woocommerce .woocommerce-ResetPassword.lost_reset_password label {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 600;
  color: var(--pixvino-text);
}

.woocommerce form.lost_reset_password input.input-text,
.woocommerce .woocommerce-ResetPassword.lost_reset_password input.input-text {
  width: 100%;
}

.woocommerce form.lost_reset_password .woocommerce-Button.button,
.woocommerce .woocommerce-ResetPassword.lost_reset_password .woocommerce-Button.button {
  width: 100%;
  min-height: 3rem;
  margin-top: 0.6rem;
}

/* My Account - light theme explicit palette */
[data-theme="light"] .woocommerce-account .woocommerce-MyAccount-navigation {
  background: linear-gradient(180deg, #ecfdf3, #f5f3ff);
  border: 1px solid rgba(34, 197, 94, 0.28);
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
}
[data-theme="light"] .woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  color: #0f172a;
  border: 1px solid transparent;
  border-radius: 10px;
  transition: all 0.25s ease;
}
[data-theme="light"] .woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.14), rgba(124, 58, 237, 0.12));
  border-color: rgba(124, 58, 237, 0.25);
  color: #111827;
  transform: translateX(4px);
}
[data-theme="light"] .woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
  background: linear-gradient(135deg, rgba(34, 197, 94, 0.2), rgba(124, 58, 237, 0.16));
  border-color: rgba(34, 197, 94, 0.45);
  color: #0b1220;
  border-left: 3px solid #22c55e;
  box-shadow: 0 8px 18px rgba(34, 197, 94, 0.18);
}
[data-theme="light"] .woocommerce-account .woocommerce-MyAccount-content {
  background: linear-gradient(170deg, #ffffff, #f8fbff);
  border: 1px solid rgba(124, 58, 237, 0.2);
  box-shadow: 0 16px 36px rgba(15, 23, 42, 0.08);
}
[data-theme="light"] .woocommerce-account .woocommerce-MyAccount-content .woocommerce-MyAccount-dashboard,
[data-theme="light"] .woocommerce-account .woocommerce-MyAccount-content p,
[data-theme="light"] .woocommerce-account .woocommerce-MyAccount-content li,
[data-theme="light"] .woocommerce-account .woocommerce-MyAccount-content strong {
  color: #0f172a;
}
[data-theme="light"] .woocommerce-account .woocommerce-MyAccount-content a {
  color: #2563eb;
}
[data-theme="light"] .woocommerce-account .woocommerce-MyAccount-content a:hover {
  color: #7c3aed;
}

[data-theme="light"] .woocommerce form.lost_reset_password,
[data-theme="light"] .woocommerce .woocommerce-ResetPassword.lost_reset_password {
  border: 1px solid rgba(124, 58, 237, 0.25);
  background:
    radial-gradient(circle at top right, rgba(34, 197, 94, 0.18), transparent 48%),
    linear-gradient(180deg, #ffffff, #f8fbff);
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.1);
}

[data-theme="light"] .woocommerce form.lost_reset_password p,
[data-theme="light"] .woocommerce .woocommerce-ResetPassword.lost_reset_password p {
  color: #475569;
}

/* Tables (Orders, etc) */
.woocommerce table.shop_table {
  border: 1px solid var(--pixvino-border) !important;
  border-radius: 8px;
  border-collapse: separate;
  border-spacing: 0;
  background-color: var(--pixvino-bg-secondary);
}

.woocommerce table.shop_table th {
  background-color: var(--pixvino-bg);
  color: var(--pixvino-text-secondary);
  text-transform: uppercase;
  font-size: 0.85em;
  padding: 15px;
}

.woocommerce table.shop_table td {
  background-color: var(--pixvino-card);
  border-top: 1px solid var(--pixvino-border);
  padding: 15px;
  color: var(--pixvino-text);
}

/* Cart / Checkout totals */
.cart_totals, 
.woocommerce-checkout-review-order {
  background-color: var(--pixvino-card);
  padding: 20px;
  border-radius: 12px;
  border: 1px solid var(--pixvino-border);
}

/* Checkout page: structured PixVino layout (classic shortcode checkout) */
body.pixvino-wc-page.woocommerce-checkout .woocommerce {
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
}

body.pixvino-wc-page.woocommerce-checkout .woocommerce h1.entry-title,
body.pixvino-wc-page.woocommerce-checkout .woocommerce h2,
body.pixvino-wc-page.woocommerce-checkout .woocommerce h3 {
  color: var(--pixvino-text);
}

/* "Pay for order" / checkout page title: solid black (light) or white (dark), not transparent */
body.pixvino-wc-page .woocommerce h1.entry-title,
body.pixvino-wc-page .woocommerce h1,
body.pixvino-wc-page .entry-title,
body.woocommerce-checkout .woocommerce h1.entry-title,
body.woocommerce-checkout .woocommerce h1,
body.woocommerce-order-pay .woocommerce h1.entry-title,
body.woocommerce-order-pay .woocommerce h1,
.woocommerce .entry-header .entry-title,
.woocommerce main h1 {
  color: #ffffff !important;
  opacity: 1 !important;
  font-weight: 700 !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
  -webkit-font-smoothing: antialiased;
}

[data-theme="light"] body.pixvino-wc-page .woocommerce h1.entry-title,
[data-theme="light"] body.pixvino-wc-page .woocommerce h1,
[data-theme="light"] body.pixvino-wc-page .entry-title,
[data-theme="light"] body.woocommerce-checkout .woocommerce h1.entry-title,
[data-theme="light"] body.woocommerce-checkout .woocommerce h1,
[data-theme="light"] body.woocommerce-order-pay .woocommerce h1.entry-title,
[data-theme="light"] body.woocommerce-order-pay .woocommerce h1,
[data-theme="light"] .woocommerce .entry-header .entry-title,
[data-theme="light"] .woocommerce main h1 {
  color: #0f172a !important;
  opacity: 1 !important;
  text-shadow: none !important;
}

body.pixvino-wc-page.woocommerce-checkout form.checkout {
  display: block;
  max-width: 980px;
  margin: 0 auto;
}

body.pixvino-wc-page.woocommerce-checkout form.checkout::after {
  content: '';
  display: block;
  clear: both;
}

body.pixvino-wc-page.woocommerce-checkout #customer_details {
  float: none;
  width: 100%;
  margin: 0 auto;
  max-width: 920px;
  clear: both;
}

body.pixvino-wc-page.woocommerce-checkout #customer_details .col-1,
body.pixvino-wc-page.woocommerce-checkout #customer_details .col-2 {
  float: none;
  width: 100%;
  margin: 0 0 1rem 0;
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--pixvino-pink) 14%, transparent), transparent 48%),
    linear-gradient(180deg, color-mix(in srgb, var(--pixvino-card) 92%, #ffffff 8%), var(--pixvino-card));
  border: 1px solid var(--pixvino-border);
  border-radius: 14px;
  padding: 1.1rem 1.1rem 0.5rem;
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.16);
}

body.pixvino-wc-page.woocommerce-checkout #customer_details h3 {
  margin: 0 0 0.9rem;
  font-size: 1.25rem;
  letter-spacing: 0.04em;
}

body.pixvino-wc-page.woocommerce-checkout .woocommerce-billing-fields,
body.pixvino-wc-page.woocommerce-checkout .woocommerce-shipping-fields,
body.pixvino-wc-page.woocommerce-checkout .woocommerce-additional-fields {
  margin-bottom: 0.6rem;
}

body.pixvino-wc-page.woocommerce-checkout .woocommerce form .form-row {
  margin: 0 0 0.85rem;
}

body.pixvino-wc-page.woocommerce-checkout .woocommerce form .form-row label {
  display: block;
  margin-bottom: 0.32rem;
  color: var(--pixvino-text);
  font-weight: 600;
}

body.pixvino-wc-page.woocommerce-checkout .woocommerce form .form-row .required {
  color: var(--pixvino-pink);
}

body.pixvino-wc-page.woocommerce-checkout .woocommerce form .form-row input.input-text,
body.pixvino-wc-page.woocommerce-checkout .woocommerce form .form-row textarea,
body.pixvino-wc-page.woocommerce-checkout .woocommerce form .form-row select {
  min-height: 44px;
}

body.pixvino-wc-page.woocommerce-checkout .woocommerce form .form-row textarea {
  min-height: 104px;
}

/* Select2 fields used by WooCommerce country/state selectors */
body.pixvino-wc-page.woocommerce-checkout .select2-container--default .select2-selection--single {
  background: var(--pixvino-card) !important;
  border: 1px solid var(--pixvino-border) !important;
  border-radius: 8px !important;
  height: 44px !important;
}

body.pixvino-wc-page.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--pixvino-text) !important;
  line-height: 42px !important;
  padding-left: 12px !important;
}

body.pixvino-wc-page.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 42px !important;
}

/* Right column: order summary + payment */
body.pixvino-wc-page.woocommerce-checkout #order_review_heading,
body.pixvino-wc-page.woocommerce-checkout #order_review {
  float: none;
  width: 100%;
  max-width: 920px;
  margin-left: auto;
  margin-right: auto;
  clear: both;
}

body.pixvino-wc-page.woocommerce-checkout #order_review_heading {
  margin-top: 0.35rem;
  margin-bottom: 0.75rem;
  font-size: 1.22rem;
}

body.pixvino-wc-page.woocommerce-checkout #order_review {
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--pixvino-cyan) 11%, transparent), transparent 45%),
    linear-gradient(180deg, color-mix(in srgb, var(--pixvino-card) 94%, #ffffff 6%), var(--pixvino-card));
  border: 1px solid var(--pixvino-border);
  border-radius: 14px;
  padding: 1rem;
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.16);
}

body.pixvino-wc-page.woocommerce-checkout #order_review .shop_table {
  margin: 0 0 0.85rem;
}

body.pixvino-wc-page.woocommerce-checkout #order_review .shop_table th,
body.pixvino-wc-page.woocommerce-checkout #order_review .shop_table td {
  padding: 0.82rem 0.72rem !important;
}

body.pixvino-wc-page.woocommerce-checkout #payment {
  background: color-mix(in srgb, var(--pixvino-bg) 35%, transparent) !important;
  border: 1px solid var(--pixvino-border) !important;
  border-radius: 12px !important;
  margin-top: 0.6rem !important;
}

body.pixvino-wc-page.woocommerce-checkout #payment ul.payment_methods {
  border-bottom: 1px solid var(--pixvino-border) !important;
}

body.pixvino-wc-page.woocommerce-checkout #payment ul.payment_methods li {
  color: var(--pixvino-text);
}

body.pixvino-wc-page.woocommerce-checkout #payment ul.payment_methods li label {
  color: var(--pixvino-text);
  font-weight: 600;
}

body.pixvino-wc-page.woocommerce-checkout #payment div.payment_box {
  background: color-mix(in srgb, var(--pixvino-card) 90%, transparent) !important;
  border: 1px solid var(--pixvino-border) !important;
  color: var(--pixvino-text-secondary) !important;
}

body.pixvino-wc-page.woocommerce-checkout #payment div.payment_box::before {
  border-bottom-color: color-mix(in srgb, var(--pixvino-card) 90%, transparent) !important;
}

body.pixvino-wc-page.woocommerce-checkout #payment .payment_method_stripe .wc-stripe-elements-field,
body.pixvino-wc-page.woocommerce-checkout #payment .payment_method_stripe input[type="text"] {
  background: var(--pixvino-card) !important;
  border: 1px solid var(--pixvino-border) !important;
  color: var(--pixvino-text) !important;
  border-radius: 8px !important;
}

body.pixvino-wc-page.woocommerce-checkout #payment .place-order {
  padding-top: 1rem !important;
}

body.pixvino-wc-page.woocommerce-checkout #payment #place_order {
  width: 100% !important;
  min-height: 48px;
  border-radius: 10px !important;
  font-size: 0.93rem !important;
  letter-spacing: 0.07em !important;
}

body.pixvino-wc-page.woocommerce-checkout .woocommerce-privacy-policy-text,
body.pixvino-wc-page.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper {
  color: var(--pixvino-text-secondary);
  font-size: 0.92rem;
}

body.pixvino-wc-page.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper a,
body.pixvino-wc-page.woocommerce-checkout .woocommerce-privacy-policy-text a {
  color: var(--pixvino-cyan);
}

/* Checkout page: WooCommerce Blocks support */
body.pixvino-wc-page .wc-block-checkout,
body.pixvino-wc-page .wc-block-cart {
  color: var(--pixvino-text);
}

body.pixvino-wc-page .wc-block-components-sidebar-layout {
  display: block !important;
  max-width: 980px;
  margin: 0 auto;
}

body.pixvino-wc-page .wc-block-components-sidebar-layout .wc-block-components-main,
body.pixvino-wc-page .wc-block-components-sidebar-layout .wc-block-components-sidebar {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--pixvino-card) 96%, transparent), var(--pixvino-card));
  border: 1px solid var(--pixvino-border);
  border-radius: 14px;
  padding: 1rem;
}

body.pixvino-wc-page .wc-block-components-sidebar-layout .wc-block-components-sidebar {
  margin-top: 1rem;
}

body.pixvino-wc-page .wc-block-components-text-input input,
body.pixvino-wc-page .wc-block-components-address-form input,
body.pixvino-wc-page .wc-block-components-address-form select {
  background: var(--pixvino-card) !important;
  border: 1px solid var(--pixvino-border) !important;
  color: var(--pixvino-text) !important;
}

body.pixvino-wc-page .wc-block-components-button,
body.pixvino-wc-page .wc-block-checkout__actions_row .wc-block-components-button {
  background: linear-gradient(135deg, var(--pixvino-pink), var(--pixvino-purple)) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 10px !important;
}

/* Light-theme checkout refinements */
[data-theme="light"] body.pixvino-wc-page.woocommerce-checkout #customer_details .col-1,
[data-theme="light"] body.pixvino-wc-page.woocommerce-checkout #customer_details .col-2,
[data-theme="light"] body.pixvino-wc-page.woocommerce-checkout #order_review {
  background:
    radial-gradient(circle at top right, rgba(34, 197, 94, 0.17), transparent 52%),
    linear-gradient(180deg, #ffffff, #f8fbff);
  border: 1px solid rgba(124, 58, 237, 0.22);
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.09);
}

[data-theme="light"] body.pixvino-wc-page.woocommerce-checkout #payment {
  background: rgba(255, 255, 255, 0.88) !important;
  border-color: rgba(2, 6, 23, 0.14) !important;
}

[data-theme="light"] body.pixvino-wc-page.woocommerce-checkout .woocommerce form .form-row label,
[data-theme="light"] body.pixvino-wc-page.woocommerce-checkout #payment ul.payment_methods li label {
  color: #0f172a;
}

[data-theme="light"] body.pixvino-wc-page .select2-container--default .select2-selection--single,
[data-theme="light"] body.pixvino-wc-page .select2-container--default .select2-selection--single .select2-selection__rendered {
  color: #0f172a !important;
}

/* Mobile checkout layout */
@media (max-width: 980px) {
  body.pixvino-wc-page.woocommerce-checkout #order_review_heading {
    margin-top: 0.2rem;
  }
}

@media (max-width: 900px) {
  .pixvino-wc-header-inner {
    padding: 0 0.75rem;
  }
  .pixvino-wc-logo-text {
    font-size: 1.25rem;
  }
  .pixvino-wc-logo-image {
    height: 2.25rem !important;
    max-height: 2.25rem !important;
    max-width: 12rem !important;
  }
  .pixvino-wc-actions {
    gap: 0.5rem;
  }
}
