/*
Theme Name:  Web Demente Digital
Theme URI:   https://web.demente.digital
Author:      Demente Digital
Author URI:  https://demente.digital
Description: Tema de servicios web — web.demente.digital. Sistema de diseño dark purple/lavender.
Version:     1.0.0
Requires at least: 6.0
Tested up to:      6.7
Requires PHP:      7.4
License:     Proprietary — Todos los derechos reservados
Text Domain: web-demente-digital
*/
:root {
  --dark:          #0B0114;
  --dark-2:        #540D6E;
  --dark-3:        #3A0852;
  --light:         #F5F0FC;
  --light-2:       #E8DFFA;
  --white:         #FEFFFE;
  --gold:          #b18bee;
  --gold-light:    #C4B0E4;
  --gold-dim:      rgba(178,152,220,0.12);
  --gold-border:   rgba(178,152,220,0.3);
  --primary:       #B298DC;
  --primary-light: #C4B0E4;
  --primary-dim:   rgba(178,152,220,0.12);
  --bg:            #0B0114;
  --bg-2:          #130221;
  --surface:       #1A0430;
  --surface-2:     #2A0648;
  --surface-3:     #3A0852;
  --border:        rgba(178,152,220,0.18);
  --border-subtle: rgba(178,152,220,0.07);
  --border-dark:   rgba(178,152,220,0.1);
  --border-light:  rgba(11,1,20,0.1);
  --text:          #FEFFFE;
  --text-muted:    rgba(254,255,254,0.65);
  --text-dim:      rgba(254,255,254,0.32);
  --text-dark:     #0B0114;
  --text-dark-m:   rgba(11,1,20,0.6);
  --text-dark-d:   rgba(11,1,20,0.35);
  --text-light:    #FEFFFE;
  --text-light-m:  rgba(254,255,254,0.65);
  --text-light-d:  rgba(254,255,254,0.32);
  --success:       #10B981;
  --error:         #E11414;
  --warning:       #F59E0B;
  --radius:        10px;
  --radius-sm:     6px;
  --radius-lg:     18px;
  --radius-xl:     24px;
  --transition:    0.25s ease;
  --font:          'Work Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* ── Layout ── */
.dd-container { max-width: 1200px; margin: 0 auto; padding: 0 32px; }
@media (max-width: 768px) { .dd-container { padding: 0 20px; } }

/* ── Shared buttons ── */
.dd-btn { display: inline-flex; align-items: center; gap: 8px; padding: 14px 30px; border-radius: var(--radius); font-size: 0.8rem; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; text-decoration: none; cursor: pointer; transition: all var(--transition); border: 1px solid transparent; }
.dd-btn-white { background: var(--white); color: var(--text-dark); border-color: var(--white); }
.dd-btn-white:hover { background: transparent; color: var(--white); border-color: var(--white); }
.dd-btn-gold { background: var(--gold); color: var(--dark); border-color: var(--gold); }
.dd-btn-gold:hover { background: var(--gold-light); border-color: var(--gold-light); }

/* ── Navigation ── */
body.admin-bar .dd-nav { top: 32px; }
@media screen and (max-width: 782px) { body.admin-bar .dd-nav { top: 46px; } }
.dd-nav { position: fixed; top: 0; left: 0; right: 0; z-index: 9999; background: rgba(11,1,20,0.92); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); border-bottom: 1px solid var(--border-dark); padding: 18px 0; transition: padding var(--transition); }
.dd-nav.scrolled { padding: 12px 0; }
.dd-nav-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.dd-logo { font-size: 1.1rem; font-weight: 800; letter-spacing: -0.02em; text-decoration: none; color: var(--text-light); white-space: nowrap; }
.dd-logo-dot { color: var(--gold); }
.dd-logo-web { color: var(--gold); opacity: 0.7; font-weight: 400; }
.dd-nav-links { display: flex; align-items: center; gap: 0; list-style: none; }
.dd-nav-links a { color: var(--text-light-m); text-decoration: none; font-size: 0.72rem; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; padding: 8px 14px; transition: color var(--transition); }
.dd-nav-links a:hover { color: var(--gold); }
.dd-nav-right { display: flex; align-items: center; gap: 12px; }
.dd-hamburger { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 4px; }
.dd-hamburger span { display: block; width: 22px; height: 1.5px; background: var(--text-light); border-radius: 1px; transition: all 0.25s; }
.dd-hamburger.open span:nth-child(1) { transform: rotate(45deg) translate(4.5px, 4.5px); }
.dd-hamburger.open span:nth-child(2) { opacity: 0; }
.dd-hamburger.open span:nth-child(3) { transform: rotate(-45deg) translate(4.5px, -4.5px); }
.dd-mobile-menu { display: none; position: fixed; inset: 0; z-index: 9998; background: var(--dark); flex-direction: column; align-items: flex-start; justify-content: center; padding: 80px 40px; gap: 4px; }
.dd-mobile-menu.open { display: flex; }
.dd-mobile-menu a { color: var(--text-light); font-size: 2rem; font-weight: 800; letter-spacing: -0.02em; padding: 10px 0; border-bottom: 1px solid var(--border-dark); width: 100%; transition: color var(--transition); }
.dd-mobile-menu a:hover { color: var(--gold); }
.dd-mobile-menu .dd-btn { margin-top: 24px; font-size: 0.78rem; }
@media (max-width: 768px) { .dd-hamburger { display: flex; } .dd-nav-links, .dd-nav-right .dd-btn { display: none; } }

/* ── Footer ── */
.dd-footer { background: var(--dark); border-top: 1px solid var(--border-dark); padding: 36px 0 20px; }
.dd-footer-inner { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 56px; }
.dd-footer-brand .dd-logo { display: block; margin-bottom: 16px; }
.dd-footer-brand p { font-size: 0.86rem; color: var(--text-light-d); line-height: 1.7; max-width: 220px; }
.dd-footer-col h4 { font-size: 0.68rem; font-weight: 600; letter-spacing: 2.5px; text-transform: uppercase; color: var(--gold); padding-bottom: 16px; border-bottom: 1px solid var(--gold-border); margin-bottom: 20px; }
.dd-footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 12px; padding: 0; }
.dd-footer-col ul a { font-size: 0.86rem; color: var(--text-light-m); transition: color var(--transition); }
.dd-footer-col ul a:hover { color: var(--gold); }
.dd-footer-bottom { padding-top: 28px; border-top: 1px solid var(--border-dark); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; }
.dd-footer-copy { font-size: 0.78rem; color: var(--text-light-d); }
.dd-footer-legal { display: flex; gap: 24px; }
.dd-footer-legal a { font-size: 0.78rem; color: var(--text-light-d); transition: color var(--transition); }
.dd-footer-legal a:hover { color: var(--text-light-m); }
@media (max-width: 900px) { .dd-footer-inner { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .dd-footer-inner { grid-template-columns: 1fr; gap: 32px; } }

/* ══════════════════════════════════════════════════
   BASE — applies to all pages (WooCommerce etc.)
══════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body {
  font-family: var(--font);
  background: var(--dark);
  color: var(--text-light);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  margin: 0;
}
a { color: inherit; text-decoration: none; }

/* ── WooCommerce page layout ── */
body.woocommerce #main,
body.woocommerce-page #main,
body.woocommerce-cart #main,
body.woocommerce-checkout #main,
body.woocommerce-account #main {
  padding-top: 80px;
  padding-bottom: 56px;
  min-height: 60vh;
}
body.admin-bar.woocommerce #main,
body.admin-bar.woocommerce-page #main,
body.admin-bar.woocommerce-cart #main,
body.admin-bar.woocommerce-checkout #main,
body.admin-bar.woocommerce-account #main { padding-top: 112px; }

body.woocommerce .woocommerce,
body.woocommerce-page .woocommerce,
body.woocommerce-cart .woocommerce,
body.woocommerce-checkout .woocommerce,
body.woocommerce-account .woocommerce {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 32px;
}
@media (max-width: 768px) {
  body.woocommerce .woocommerce,
  body.woocommerce-page .woocommerce,
  body.woocommerce-cart .woocommerce,
  body.woocommerce-checkout .woocommerce,
  body.woocommerce-account .woocommerce { padding: 0 20px; }
}

/* ── WooCommerce typography ── */
.woocommerce h1, .woocommerce h2, .woocommerce h3,
.woocommerce h4, .woocommerce h5 {
  color: var(--text-light);
  font-family: var(--font);
  letter-spacing: -0.02em;
  line-height: 1.15;
}
.woocommerce p, .woocommerce li { color: var(--text-light-m); }

/* ── Single product layout — override WooCommerce floats ── */
.woocommerce div.product div.images,
.woocommerce div.product div.summary { float: none !important; width: auto !important; }
.woocommerce div.product::after,
.woocommerce div.product::before { content: none !important; display: none !important; }

.woocommerce div.product {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr) !important;
  gap: 56px;
  align-items: start;
  clear: both;
}
@media (max-width: 900px) { .woocommerce div.product { grid-template-columns: 1fr !important; gap: 32px; } }

/* ── Product gallery ── */
.woocommerce div.product .woocommerce-product-gallery,
.woocommerce div.product div.images {
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--surface);
  padding: 32px;
  width: 100% !important;
}
.woocommerce div.product .woocommerce-product-gallery__image img,
.woocommerce div.product div.images img {
  width: 100% !important; height: auto; display: block;
  border-radius: var(--radius-lg);
}

/* ── Product summary ── */
.woocommerce div.product .summary { display: flex; flex-direction: column; gap: 0; padding-top: 12px; }
.woocommerce div.product .product_title {
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: 800;
  color: var(--text-light);
  margin-bottom: 16px;
  line-height: 1.1;
}
.woocommerce div.product .woocommerce-product-rating { margin-bottom: 20px; }
.woocommerce div.product .star-rating { color: var(--gold); }
.woocommerce div.product .price {
  font-size: 2.8rem;
  font-weight: 800;
  color: var(--gold);
  letter-spacing: -0.03em;
  margin-bottom: 24px;
  display: block;
  line-height: 1;
}
.woocommerce div.product .price del {
  color: var(--text-light-d);
  font-size: 1.6rem;
  font-weight: 500;
  margin-right: 10px;
}
.woocommerce div.product .price ins { text-decoration: none; }
.woocommerce div.product .woocommerce-product-details__short-description {
  margin-bottom: 28px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--border-subtle);
}
.woocommerce div.product .woocommerce-product-details__short-description p {
  color: var(--text-light-m);
  font-size: 1rem;
  line-height: 1.8;
  margin-bottom: 10px;
}

/* ── Add to cart ── */
.woocommerce div.product form.cart { margin-bottom: 28px; display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.woocommerce div.product form.cart .qty {
  width: 84px; padding: 16px 14px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); color: var(--text-light);
  font-family: var(--font); font-size: 1.1rem; font-weight: 600;
  text-align: center;
}
.woocommerce div.product form.cart .qty:focus { outline: none; border-color: var(--gold); }
.woocommerce div.product form.cart .single_add_to_cart_button { font-size: 0.9rem; padding: 16px 40px; }
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce a.button.alt {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 30px; border-radius: var(--radius);
  font-size: 0.8rem; font-weight: 600; font-family: var(--font);
  letter-spacing: 1px; text-transform: uppercase;
  background: var(--gold); color: var(--dark);
  border: 1px solid var(--gold);
  cursor: pointer; transition: all var(--transition);
  text-decoration: none;
}
.woocommerce #respond input#submit:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover,
.woocommerce a.button.alt:hover {
  background: var(--gold-light); border-color: var(--gold-light);
}
.woocommerce button.button:disabled,
.woocommerce input.button:disabled { opacity: 0.5; cursor: not-allowed; }

/* ── Product meta (SKU, categories) ── */
.woocommerce div.product .product_meta {
  font-size: 0.82rem; color: var(--text-light-d);
  padding-top: 20px; border-top: 1px solid var(--border-subtle);
}
.woocommerce div.product .product_meta a { color: var(--gold); }
.woocommerce div.product .product_meta a:hover { color: var(--gold-light); }

/* ── Product tabs ── */
.woocommerce div.product .woocommerce-tabs { grid-column: 1 / -1; margin-top: 16px; }
.woocommerce div.product .woocommerce-tabs ul.tabs {
  display: flex; gap: 0; list-style: none;
  border-bottom: 1px solid var(--border); margin-bottom: 0; padding: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  border: none; background: transparent; margin: 0;
  border-radius: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-family: var(--font); font-size: 0.78rem; font-weight: 600;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--text-light-d); padding: 14px 20px;
  display: block; transition: color var(--transition);
  border-bottom: 2px solid transparent; margin-bottom: -1px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover { color: var(--gold); }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  color: var(--gold); border-bottom-color: var(--gold); background: transparent;
}
.woocommerce div.product .woocommerce-tabs .panel {
  background: var(--surface); border: 1px solid var(--border-subtle);
  border-top: none; border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  padding: 32px; color: var(--text-light-m);
}
.woocommerce div.product .woocommerce-tabs .panel h2 { display: none; }
.woocommerce div.product .woocommerce-tabs .panel p,
.woocommerce div.product .woocommerce-tabs .panel li { color: var(--text-light-m); font-size: 0.92rem; line-height: 1.75; }
.woocommerce div.product .woocommerce-tabs .panel ul { list-style: disc; padding-left: 20px; }

/* ── Related / upsell sections ── */
.woocommerce .related, .woocommerce .upsells {
  clear: both;
  margin-top: 48px; padding-top: 36px;
  border-top: 1px solid var(--border-subtle);
}
.woocommerce .related h2, .woocommerce .upsells h2 {
  font-size: 1.3rem; font-weight: 800; margin-bottom: 24px; color: var(--text-light);
}

/* Override WooCommerce float loop with grid */
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)) !important;
  gap: 20px !important;
  list-style: none !important;
  padding: 0 !important; margin: 0 !important;
  float: none !important; clear: both;
}
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  float: none !important;
  width: auto !important; margin: 0 !important;
  background: var(--surface); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-xl); padding: 24px;
  transition: border-color var(--transition), transform var(--transition);
  display: flex !important; flex-direction: column;
}
.woocommerce ul.products li.product:hover { border-color: var(--gold-border); transform: translateY(-3px); }
.woocommerce ul.products li.product a.woocommerce-loop-product__link {
  display: flex; flex-direction: column; flex: 1;
  text-decoration: none;
}
.woocommerce ul.products li.product img {
  border-radius: var(--radius-lg); margin-bottom: 16px;
  width: 100% !important; height: 180px; object-fit: contain;
  background: var(--surface-2); padding: 16px;
  float: none !important;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-size: 1rem; font-weight: 700; color: var(--text-light);
  margin-bottom: 8px; letter-spacing: -0.01em; line-height: 1.35;
}
.woocommerce ul.products li.product .price {
  font-size: 1.25rem; font-weight: 700; color: var(--gold);
  margin-bottom: 16px; display: block; flex: 1;
}
.woocommerce ul.products li.product .button {
  width: 100% !important; justify-content: center; white-space: nowrap;
  padding: 12px 16px !important; font-size: 0.75rem !important;
  margin-top: auto;
}

/* ── WooCommerce notices ── */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
  border-radius: var(--radius); padding: 16px 20px;
  font-family: var(--font); font-size: 0.88rem;
  list-style: none; margin-bottom: 20px; display: flex;
  align-items: center; gap: 10px;
}
.woocommerce-message { background: rgba(16,185,129,0.1); border: 1px solid rgba(16,185,129,0.3); color: var(--success); }
.woocommerce-info { background: var(--gold-dim); border: 1px solid var(--gold-border); color: var(--gold); }
.woocommerce-error { background: rgba(225,20,20,0.1); border: 1px solid rgba(225,20,20,0.3); color: var(--error); }

/* ── Cart page ── */
.woocommerce table.shop_table {
  width: 100%; border-collapse: collapse;
  background: var(--surface); border-radius: var(--radius-lg);
  overflow: hidden; border: 1px solid var(--border-subtle);
}
.woocommerce table.shop_table th {
  background: var(--surface-2); color: var(--text-light-d);
  font-size: 0.72rem; font-weight: 600; letter-spacing: 1.5px;
  text-transform: uppercase; padding: 14px 20px; text-align: left;
  border-bottom: 1px solid var(--border);
}
.woocommerce table.shop_table td {
  padding: 16px 20px; border-bottom: 1px solid var(--border-subtle);
  color: var(--text-light-m); vertical-align: middle; font-size: 0.9rem;
}
.woocommerce table.shop_table tr:last-child td { border-bottom: none; }
.woocommerce table.shop_table .product-name a { color: var(--text-light); font-weight: 600; }
.woocommerce table.shop_table .product-name a:hover { color: var(--gold); }
.woocommerce table.shop_table .amount { color: var(--gold); font-weight: 700; }
.woocommerce .cart-collaterals { margin-top: 32px; }
.woocommerce .cart_totals h2 { font-size: 1.2rem; margin-bottom: 16px; }
.woocommerce .cart_totals table th,
.woocommerce .cart_totals table td { padding: 12px 16px; }
.woocommerce .wc-proceed-to-checkout .checkout-button { width: 100%; justify-content: center; margin-top: 16px; }

/* ── WooCommerce buttons ── */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 11px 22px; border-radius: var(--radius);
  font-size: 0.78rem; font-weight: 600; letter-spacing: 1px; text-transform: uppercase;
  font-family: var(--font); cursor: pointer; transition: all var(--transition);
  background: var(--surface-2); color: var(--text-light) !important;
  border: 1px solid var(--border); text-decoration: none; line-height: 1;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover { background: var(--surface-3); color: var(--text-light) !important; }
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce a.checkout-button,
.woocommerce button.checkout-button {
  background: var(--primary); color: var(--dark) !important; border-color: var(--primary);
}
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover,
.woocommerce a.checkout-button:hover,
.woocommerce button.checkout-button:hover {
  background: var(--primary-light); border-color: var(--primary-light); color: var(--dark) !important;
}

/* ── Cart: quantity input ── */
.woocommerce .quantity { display: flex; align-items: center; }
.woocommerce .quantity input.qty {
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text-light);
  font-family: var(--font); font-size: 0.9rem;
  padding: 8px 10px; width: 64px; text-align: center;
}
.woocommerce .quantity input.qty:focus { outline: none; border-color: var(--gold); }

/* ── Cart: remove button ── */
.woocommerce table.cart .product-remove a.remove {
  color: var(--text-light-d) !important; font-size: 1.3rem; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 50%;
  transition: color var(--transition), background var(--transition);
}
.woocommerce table.cart .product-remove a.remove:hover {
  color: var(--error) !important; background: rgba(225,20,20,0.12);
}

/* ── Cart: product thumbnail ── */
.woocommerce table.cart td.product-thumbnail img {
  width: 64px; height: 64px; object-fit: cover;
  border-radius: var(--radius-sm); border: 1px solid var(--border-subtle);
}

/* ── Cart: coupon + actions row ── */
.woocommerce table.cart td.actions { background: var(--surface-2); padding: 14px 20px; }
.woocommerce .coupon { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.woocommerce .coupon input#coupon_code {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text-light);
  font-family: var(--font); font-size: 0.85rem;
  padding: 9px 14px; width: 200px; max-width: 100%;
}
.woocommerce .coupon input#coupon_code::placeholder { color: var(--text-light-d); }
.woocommerce .coupon input#coupon_code:focus { outline: none; border-color: var(--gold); }
.woocommerce table.cart td.actions .button[name="update_cart"] { float: right; }

/* ── Cart: totals ── */
.woocommerce .cart-collaterals { display: flex; justify-content: flex-end; margin-top: 32px; }
.woocommerce .cart_totals { width: 100%; max-width: 420px; }
.woocommerce .cart_totals h2 { font-size: 1.1rem; font-weight: 700; margin-bottom: 16px; color: var(--text-light); }
.woocommerce .cart_totals .order-total .amount { color: var(--gold); font-size: 1.1rem; font-weight: 700; }
.woocommerce .wc-proceed-to-checkout { margin-top: 16px; }
.woocommerce .wc-proceed-to-checkout a.checkout-button {
  display: flex; width: 100%; justify-content: center;
  padding: 14px 24px; font-size: 0.9rem;
}

/* ── Checkout page ── */
/* Grid lives on the form, not the outer .woocommerce div */
.woocommerce-checkout form.woocommerce-checkout {
  display: grid;
  grid-template-columns: 1fr 380px;
  grid-template-areas: "notices notices" "billing order";
  gap: 40px; align-items: start;
}
@media (max-width: 900px) {
  .woocommerce-checkout form.woocommerce-checkout {
    grid-template-columns: 1fr;
    grid-template-areas: "notices" "billing" "order";
  }
}
.woocommerce-checkout form.woocommerce-checkout > .woocommerce-notices-wrapper { grid-area: notices; }
.woocommerce-checkout form.woocommerce-checkout #customer_details { grid-area: billing; }
.woocommerce-checkout form.woocommerce-checkout #order_review_heading { display: none; }
.woocommerce-checkout form.woocommerce-checkout #order_review { grid-area: order; }

/* Billing + shipping side by side inside #customer_details */
.woocommerce-checkout #customer_details.col2-set {
  display: grid; grid-template-columns: 1fr 1fr; gap: 32px;
}
@media (max-width: 680px) {
  .woocommerce-checkout #customer_details.col2-set { grid-template-columns: 1fr; }
}
.woocommerce-checkout .woocommerce h3 { font-size: 1.05rem; font-weight: 700; margin-bottom: 20px; padding-bottom: 10px; border-bottom: 1px solid var(--border-subtle); }
.woocommerce form .form-row { margin-bottom: 16px; }
.woocommerce form .form-row label { font-size: 0.78rem; font-weight: 600; letter-spacing: 0.5px; color: var(--text-light-d); display: block; margin-bottom: 6px; text-transform: uppercase; }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  width: 100%; padding: 12px 16px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); color: var(--text-light);
  font-family: var(--font); font-size: 0.9rem;
  transition: border-color var(--transition);
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus { outline: none; border-color: var(--gold); }
.woocommerce form .form-row input.input-text::placeholder,
.woocommerce form .form-row textarea::placeholder { color: var(--text-light-d); }
.woocommerce form .form-row select { appearance: none; cursor: pointer; }

/* Ship to different address checkbox */
.woocommerce-shipping-fields h3#ship-to-different-address { display: flex; align-items: center; gap: 10px; cursor: pointer; }
.woocommerce-shipping-fields h3#ship-to-different-address input[type="checkbox"] {
  width: 17px; height: 17px; accent-color: var(--gold); cursor: pointer; flex-shrink: 0;
}

/* Coupon notice + inline coupon form */
.woocommerce-info.woocommerce-checkout-coupon { display: flex; align-items: center; gap: 8px; }
.woocommerce-info.woocommerce-checkout-coupon a.showcoupon { color: var(--gold); font-weight: 600; }
.woocommerce form.checkout_coupon {
  background: var(--surface); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg); padding: 20px;
  display: flex; gap: 12px; align-items: flex-end; flex-wrap: wrap;
  margin-bottom: 28px;
}
.woocommerce form.checkout_coupon p { margin: 0 !important; flex: 1; min-width: 180px; }

/* Order review: sticky sidebar */
.woocommerce #order_review {
  background: var(--surface); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-xl); padding: 28px;
  position: sticky; top: 100px;
}
.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td { padding: 10px 16px !important; }
.woocommerce-checkout-review-order-table .order-total .amount { color: var(--gold); font-weight: 700; }

/* Payment methods */
.woocommerce #payment { background: var(--surface-2); border-radius: var(--radius-lg); padding: 24px; margin-top: 24px; }
.woocommerce #payment ul.payment_methods { list-style: none; padding: 0; margin-bottom: 20px; }
.woocommerce #payment ul.payment_methods li {
  padding: 10px 0; border-bottom: 1px solid var(--border-subtle);
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.woocommerce #payment ul.payment_methods li:last-child { border-bottom: none; }
.woocommerce #payment ul.payment_methods li input[type="radio"] { accent-color: var(--gold); flex-shrink: 0; }
.woocommerce #payment ul.payment_methods li label { color: var(--text-light-m); font-size: 0.9rem; cursor: pointer; }
.woocommerce #payment div.payment_box { background: var(--surface-3); border-radius: var(--radius); padding: 14px; margin-top: 10px; font-size: 0.84rem; color: var(--text-light-d); width: 100%; }
.woocommerce #payment #place_order {
  display: flex; width: 100%; justify-content: center;
  padding: 14px 24px; font-size: 0.9rem; margin-top: 8px;
  background: var(--primary) !important; color: var(--dark) !important; border-color: var(--primary) !important;
}
.woocommerce #payment #place_order:hover {
  background: var(--primary-light) !important; border-color: var(--primary-light) !important;
}

/* ── Select2 dark theme ── */
.woocommerce .select2-container .select2-selection--single {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); height: 46px; display: flex; align-items: center;
}
.woocommerce .select2-container .select2-selection--single .select2-selection__rendered {
  color: var(--text-light); font-family: var(--font); font-size: 0.9rem; padding: 0 16px; line-height: 1;
}
.woocommerce .select2-container .select2-selection--single .select2-selection__arrow { height: 44px; right: 10px; }
.woocommerce .select2-container .select2-selection--single .select2-selection__arrow b { border-color: var(--text-light-d) transparent transparent; }
.woocommerce .select2-container--open .select2-selection--single { border-color: var(--gold) !important; }
.select2-dropdown { background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--radius); }
.select2-results__option { color: var(--text-light-m); font-family: var(--font); font-size: 0.88rem; padding: 10px 14px; }
.select2-results__option--highlighted[aria-selected] { background: var(--primary-dim) !important; color: var(--gold) !important; }
.select2-search--dropdown .select2-search__field {
  background: var(--surface); border: 1px solid var(--border);
  color: var(--text-light); border-radius: var(--radius-sm);
  padding: 8px 12px; font-family: var(--font);
}

/* ── My Account page ── */
.woocommerce-account .woocommerce { display: grid; grid-template-columns: 220px 1fr; gap: 40px; align-items: start; }
@media (max-width: 768px) { .woocommerce-account .woocommerce { grid-template-columns: 1fr; } }
.woocommerce-account .woocommerce-MyAccount-navigation { background: var(--surface); border: 1px solid var(--border-subtle); border-radius: var(--radius-xl); padding: 8px 0; position: sticky; top: 100px; }
.woocommerce-account .woocommerce-MyAccount-navigation ul { list-style: none; padding: 0; }
.woocommerce-account .woocommerce-MyAccount-navigation li a { display: block; padding: 12px 20px; font-size: 0.82rem; font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase; color: var(--text-light-d); transition: color var(--transition), background var(--transition); border-radius: var(--radius); }
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover { color: var(--gold); background: var(--gold-dim); }
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a { color: var(--gold); background: var(--gold-dim); }
.woocommerce-account .woocommerce-MyAccount-content { min-width: 0; }
.woocommerce-account .woocommerce-MyAccount-content h2 { font-size: 1.3rem; margin-bottom: 20px; }

/* ── WooCommerce breadcrumb ── */
.woocommerce .woocommerce-breadcrumb { font-size: 0.78rem; color: var(--text-light-d); margin-bottom: 28px; }
.woocommerce .woocommerce-breadcrumb a { color: var(--gold); }
.woocommerce .woocommerce-breadcrumb a:hover { color: var(--gold-light); }

/* ── Shop archive ── */
.woocommerce-shop #main { padding-top: 100px; padding-bottom: 72px; }
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering { font-size: 0.82rem; color: var(--text-light-d); margin-bottom: 24px; }
.woocommerce .woocommerce-ordering select { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); color: var(--text-light); padding: 8px 14px; font-family: var(--font); }
