/* ============================================================
   Duende Sounds — theme glue
   Buttons, cards, logo, header/responsive, CTA band,
   WooCommerce on-brand styling. All via DS tokens.
   ============================================================ */

a { color: inherit; }
img { max-width: 100%; height: auto; }

/* ---- Buttons ---- */
.ds-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-family: var(--font-display); font-weight: var(--weight-medium); font-size: var(--text-sm);
  line-height: 1; text-decoration: none; cursor: pointer;
  border: 1px solid transparent; border-radius: var(--radius-pill); padding: 12px 20px;
  transition: background var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out),
              border-color var(--dur-base) var(--ease-out), transform var(--dur-fast) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.ds-btn svg { width: 18px; height: 18px; }
.ds-btn:active { transform: scale(0.97); }
.ds-btn--primary { background: var(--accent); color: var(--accent-contrast); box-shadow: var(--shadow-sm); }
.ds-btn--primary:hover { background: var(--accent-hover); }
.ds-btn--secondary { background: transparent; color: var(--text); border-color: var(--hairline-strong); }
.ds-btn--secondary:hover { background: var(--accent-soft); border-color: var(--accent); color: var(--accent); }
.ds-btn--lg { font-size: var(--text-base); padding: 15px 26px; }
.ds-btn--sm { padding: 8px 15px; }

.ds-iconbtn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; flex: none; border-radius: var(--radius-pill);
  border: 1px solid var(--hairline); background: var(--surface); color: var(--text-muted);
  cursor: pointer; text-decoration: none;
  transition: background var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out);
}
.ds-iconbtn:hover { color: var(--accent); border-color: var(--accent); background: var(--accent-soft); }

.wsite-navlink, .wsite-textlink, .wsite-logo { text-decoration: none; }

/* ---- Logo ---- */
.dlogo { display: inline-flex; align-items: center; gap: 11px; }
.dlogo__mark { width: 30px; height: 30px; flex: none; display: inline-flex; }
.dlogo__word { font-family: var(--font-display); font-weight: 600; font-size: 19px; letter-spacing: -0.01em; line-height: 1; color: var(--text); }
.dlogo__word span { color: var(--text-muted); font-weight: 500; }

/* ---- Theme toggle icon swap ---- */
.duende-toggle .i-sun, .duende-toggle .i-moon { display: inline-flex; align-items: center; }
.duende-toggle .i-sun { display: none; }
@media (prefers-color-scheme: dark) { .duende-toggle .i-sun { display: inline-flex; } .duende-toggle .i-moon { display: none; } }
[data-theme="dark"] .duende-toggle .i-sun { display: inline-flex; } [data-theme="dark"] .duende-toggle .i-moon { display: none; }
[data-theme="light"] .duende-toggle .i-moon { display: inline-flex; } [data-theme="light"] .duende-toggle .i-sun { display: none; }

/* ---- Product card surface ---- */
.wsite-cc.duende-card { background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); padding: 14px; display: flex; flex-direction: column; gap: 11px; transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out); }
.wsite-cc.duende-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lift); }
.wsite-cc__art { position: relative; display: block; aspect-ratio: 1 / 1; border-radius: var(--radius-md); overflow: hidden; }
.wsite-cc__art img { width: 100%; height: 100%; object-fit: cover; display: block; }
.duende-price { font-family: var(--font-display); font-weight: 600; font-size: var(--text-base); color: var(--text); }
.duende-price del { color: var(--text-faint); font-weight: 400; margin-right: 6px; }
.duende-price ins { text-decoration: none; }

/* ---- CTA band ---- */
.duende-band { position: relative; overflow: hidden; background: var(--surface-2); border: 1px solid var(--hairline); border-radius: var(--radius-2xl); padding: clamp(44px, 7vw, 92px) 24px; text-align: center; }
.duende-band__inner { position: relative; max-width: 640px; margin: 0 auto; }
.duende-band .wsite-hero__glow { top: -30%; }

/* ---- Header extras / responsive ---- */
.duende-burger { display: none; }
.duende-mobile-nav { position: fixed; top: 60px; left: 0; right: 0; z-index: 39; background: color-mix(in srgb, var(--base) 96%, transparent); backdrop-filter: blur(var(--blur-glass)); -webkit-backdrop-filter: blur(var(--blur-glass)); border-bottom: 1px solid var(--hairline); display: none; flex-direction: column; padding: 8px clamp(16px,5vw,40px) 14px; }
.duende-mobile-nav.is-open { display: flex; }
.duende-mobile-nav a { padding: 13px 12px; color: var(--text); font-family: var(--font-display); font-weight: 500; border-radius: var(--radius-sm); text-decoration: none; }
.duende-mobile-nav a:hover { background: var(--accent-soft); color: var(--accent); }
@media (max-width: 860px) { .wsite-cta-desktop { display: none; } }
@media (max-width: 720px) { .duende-burger { display: inline-flex; } }

/* ---- Footer ---- */
.wsite-footer__brand { max-width: 320px; }

/* ---- Generic page / prose ---- */
.duende-page { max-width: 820px; margin: 0 auto; padding: clamp(40px, 7vw, 90px) clamp(20px, 5vw, 56px); }
.duende-page > h1 { font-family: var(--font-display); font-weight: var(--weight-medium); font-size: var(--text-h1); letter-spacing: var(--tracking-snug); margin: 0 0 24px; }
.duende-prose { font-size: var(--text-base); line-height: var(--leading-relaxed); color: var(--text); }
.duende-prose h2 { font-family: var(--font-display); font-weight: var(--weight-medium); font-size: var(--text-h2); margin: 1.6em 0 0.5em; }
.duende-prose h3 { font-family: var(--font-display); font-weight: var(--weight-medium); font-size: var(--text-h3); margin: 1.4em 0 0.4em; }
.duende-prose a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }
.duende-prose img { border-radius: var(--radius-md); }
.duende-archive-list { display: grid; gap: 20px; }
.duende-archive-item { padding-bottom: 20px; border-bottom: 1px solid var(--hairline); }
.duende-archive-item h2 { font-family: var(--font-display); font-weight: 500; font-size: var(--text-h3); margin: 0 0 6px; }
.duende-archive-item a { text-decoration: none; }

/* ============================================================
   WooCommerce — on-brand defaults (until dedicated templates)
   ============================================================ */
.duende-wc .woocommerce-products-header__title,
.woocommerce .product_title,
.woocommerce-page .product_title { font-family: var(--font-display); font-weight: var(--weight-medium); letter-spacing: var(--tracking-snug); color: var(--text); }

.woocommerce .button, .woocommerce a.button, .woocommerce button.button,
.woocommerce #respond input#submit, .woocommerce-page a.button, .woocommerce-page button.button,
.woocommerce input.button, .woocommerce input.button.alt, .woocommerce button.button.alt {
  background: var(--accent); color: var(--accent-contrast); border: 0; border-radius: var(--radius-pill);
  font-family: var(--font-display); font-weight: var(--weight-medium); font-size: var(--text-sm);
  padding: 12px 22px; transition: background var(--dur-base) var(--ease-out); text-shadow: none; box-shadow: var(--shadow-sm);
}
.woocommerce .button:hover, .woocommerce a.button:hover, .woocommerce button.button:hover,
.woocommerce #respond input#submit:hover, .woocommerce button.button.alt:hover { background: var(--accent-hover); color: var(--accent-contrast); }

.woocommerce ul.products { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; margin: 0 0 32px; padding: 0; list-style: none; }
.woocommerce ul.products::before, .woocommerce ul.products::after { display: none; }
.woocommerce ul.products li.product { width: auto !important; margin: 0 !important; float: none !important; background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); padding: 14px; text-align: left; transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out); }
.woocommerce ul.products li.product:hover { transform: translateY(-3px); box-shadow: var(--shadow-lift); }
.woocommerce ul.products li.product a img { border-radius: var(--radius-md); margin-bottom: 12px; }
.woocommerce ul.products li.product .woocommerce-loop-product__title { font-family: var(--font-display); font-size: var(--text-lg); font-weight: var(--weight-medium); color: var(--text); padding: 0 0 4px; }
.woocommerce ul.products li.product .price { color: var(--text); font-family: var(--font-display); font-weight: var(--weight-semibold); font-size: var(--text-base); }
.woocommerce ul.products li.product .price del { color: var(--text-faint); font-weight: 400; }
.woocommerce ul.products li.product .price ins { text-decoration: none; }
.woocommerce ul.products li.product .button { margin-top: 12px; }
.woocommerce .onsale { background: var(--accent); color: var(--accent-contrast); border-radius: var(--radius-pill); border: 0; font-family: var(--font-display); font-weight: 600; }

/* single product */
.woocommerce div.product { font-family: var(--font-body); }
.woocommerce div.product .product_title { font-size: var(--text-display-lg); font-weight: var(--weight-light); line-height: var(--leading-tight); }
.woocommerce div.product p.price, .woocommerce div.product span.price { color: var(--text); font-family: var(--font-display); font-weight: var(--weight-light); font-size: 30px; }
.woocommerce div.product .woocommerce-product-gallery__image img, .woocommerce div.product div.images img { border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); }
.woocommerce div.product .woocommerce-tabs ul.tabs li { background: var(--surface-2); border-radius: var(--radius-pill); border: 1px solid var(--hairline); }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active { background: var(--surface); border-color: var(--accent); }
.woocommerce .quantity .qty { border: 1px solid var(--hairline); border-radius: var(--radius-sm); background: var(--surface); color: var(--text); padding: 10px; }

/* cart / checkout / account on-brand surfaces */
.woocommerce table.shop_table { border-radius: var(--radius-lg); border-color: var(--hairline); }
.woocommerce-cart .cart-collaterals .cart_totals, .woocommerce .cart_totals { border-radius: var(--radius-lg); }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .woocommerce form .form-row select,
.woocommerce-page form .form-row input.input-text { border: 1px solid var(--hairline); border-radius: var(--radius-sm); background: var(--surface); color: var(--text); padding: 11px 12px; }
.woocommerce-message, .woocommerce-info, .woocommerce-error { border-top-color: var(--accent); border-radius: var(--radius-md); background: var(--surface-2); }
.woocommerce-message::before, .woocommerce-info::before { color: var(--accent); }

@media (max-width: 1080px) { .woocommerce ul.products { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 720px) { .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); } }

/* ---- Primary (alt) buttons incl. Proceed to checkout — kill WC default purple ---- */
.woocommerce a.button.alt, .woocommerce-page a.button.alt,
.woocommerce a.button.alt.wc-forward, .woocommerce input.button.alt,
.woocommerce .wc-proceed-to-checkout a.checkout-button,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button.button.alt {
  background: var(--accent); color: var(--accent-contrast); border: 0; box-shadow: var(--shadow-sm);
}
.woocommerce a.button.alt:hover, .woocommerce-page a.button.alt:hover,
.woocommerce input.button.alt:hover,
.woocommerce .wc-proceed-to-checkout a.checkout-button:hover,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button.button.alt:hover {
  background: var(--accent-hover); color: var(--accent-contrast);
}

/* ============================================================
   Cart page
   ============================================================ */
.woocommerce-cart .woocommerce { max-width: 1080px; margin: 0 auto; }
.woocommerce-cart table.shop_table {
  background: var(--surface); border: 1px solid var(--hairline);
  border-collapse: separate; border-spacing: 0; overflow: hidden; margin-bottom: 24px;
  table-layout: fixed; width: 100%;
}
.woocommerce-cart table.shop_table thead th {
  font-family: var(--font-display); color: var(--text-muted); font-weight: 600;
  font-size: var(--text-sm); letter-spacing: var(--tracking-wide); text-transform: uppercase;
  padding: 16px 18px; border: 0; border-bottom: 1px solid var(--hairline); background: var(--surface-2);
}
.woocommerce-cart table.shop_table td {
  padding: 18px; border: 0; border-top: 1px solid var(--hairline); vertical-align: middle; color: var(--text);
}
/* fixed column widths — stop the remove column from eating all the slack */
.woocommerce-cart table.shop_table th.product-remove,
.woocommerce-cart table.shop_table td.product-remove { width: 5%; text-align: center; padding-left: 14px; padding-right: 0; }
.woocommerce-cart table.shop_table th.product-thumbnail,
.woocommerce-cart table.shop_table td.product-thumbnail { width: 9%; }
.woocommerce-cart table.shop_table th.product-name,
.woocommerce-cart table.shop_table td.product-name { width: 45%; }
.woocommerce-cart table.shop_table th.product-price,
.woocommerce-cart table.shop_table td.product-price { width: 13%; text-align: right; }
.woocommerce-cart table.shop_table th.product-quantity,
.woocommerce-cart table.shop_table td.product-quantity { width: 14%; text-align: center; }
.woocommerce-cart table.shop_table th.product-subtotal,
.woocommerce-cart table.shop_table td.product-subtotal { width: 14%; text-align: right; }
.woocommerce-cart table.shop_table td.product-thumbnail img { width: 60px; height: auto; border-radius: var(--radius-sm); }
.woocommerce-cart table.shop_table td.product-name a { color: var(--text); font-family: var(--font-display); font-weight: var(--weight-medium); text-decoration: none; }
.woocommerce-cart table.shop_table td.product-name a:hover { color: var(--accent); }
.woocommerce-cart a.remove { color: var(--text-faint) !important; font-weight: 400; border: 1px solid var(--hairline); }
.woocommerce-cart a.remove:hover { color: var(--accent-contrast) !important; background: var(--accent) !important; border-color: var(--accent); }
.woocommerce-cart .actions { display: flex; flex-wrap: wrap; gap: 12px; justify-content: space-between; align-items: center; padding: 4px 0 8px; }
.woocommerce-cart .actions .coupon { display: flex; gap: 8px; flex: 1 1 auto; }
.woocommerce-cart .actions .coupon .input-text { min-width: 200px; flex: 0 1 240px; }
.woocommerce-cart .actions .button, .woocommerce-cart .actions .coupon .button { white-space: nowrap; }

/* cart layout: items table above, then cross-sells + totals side by side */
.woocommerce-cart .cart-collaterals { display: grid !important; grid-template-columns: 1.3fr 1fr; grid-auto-flow: row; gap: 36px; align-items: start; width: 100%; }
.woocommerce-cart .cart-collaterals .cross-sells,
.woocommerce-cart .cart-collaterals .cart_totals { width: auto !important; float: none !important; margin: 0; }
.woocommerce-cart .cart-collaterals .cross-sells { grid-column: 1 !important; grid-row: 1 !important; }
.woocommerce-cart .cart-collaterals .cart_totals { grid-column: 2 !important; grid-row: 1 !important; }

/* cross-sells ("You may be interested in") */
.woocommerce-cart .cross-sells > h2 { font-family: var(--font-display); font-size: var(--text-h3); font-weight: var(--weight-medium); margin: 0 0 18px; color: var(--text); }
.woocommerce-cart .cross-sells ul.products { grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 16px; margin: 0; }
.woocommerce-cart .cross-sells ul.products li.product { padding: 14px; }
.woocommerce-cart .cross-sells ul.products li.product .woocommerce-loop-product__title { font-size: var(--text-base); }
.woocommerce-cart .cross-sells ul.products li.product .button { display: inline-block; width: auto; white-space: normal; margin-top: 12px; padding: 10px 18px; border-radius: var(--radius-pill); }

/* cart totals */
.woocommerce-cart .cart_totals { background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); padding: 26px; }
.woocommerce-cart .cart_totals h2 { font-family: var(--font-display); font-size: var(--text-h3); font-weight: var(--weight-medium); margin: 0 0 16px; color: var(--text); }
.woocommerce-cart .cart_totals table { margin: 0; border: 0; }
.woocommerce-cart .cart_totals table th, .woocommerce-cart .cart_totals table td { padding: 13px 0; border: 0; border-bottom: 1px solid var(--hairline); background: transparent; }
.woocommerce-cart .cart_totals table tr.order-total th, .woocommerce-cart .cart_totals table tr.order-total td { font-family: var(--font-display); font-size: var(--text-lg); color: var(--text); border-bottom: 0; }
.woocommerce-cart .cart_totals .woocommerce-Price-amount { font-variant-numeric: tabular-nums; }
.woocommerce-cart .wc-proceed-to-checkout { padding: 20px 0 0; }
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button { display: block; text-align: center; font-size: var(--text-base); padding: 16px 26px; border-radius: var(--radius-pill); }

@media (max-width: 860px) {
  .woocommerce-cart .cart-collaterals { grid-template-columns: 1fr; gap: 28px; }
  .woocommerce-cart .actions .coupon { flex-wrap: wrap; }
}

/* ============================================================
   Layer Mixer (.ds-mixer) — four-channel "build your cue"
   ============================================================ */
.ds-mixer { background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); padding: 20px 22px; font-family: var(--font-body); width: 100%; --wave-unplayed: var(--hairline-strong); --mixer-track: var(--hairline-strong); }
.ds-mixer--bare { background: transparent; border: 0; box-shadow: none; padding: 0; }

.ds-mixer__master { display: flex; align-items: center; gap: 16px; padding-bottom: 18px; border-bottom: 1px solid var(--hairline); }
.ds-mixer__play { flex: none; width: 46px; height: 46px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; background: var(--accent); color: var(--accent-contrast); border: 0; cursor: pointer; box-shadow: var(--shadow-sm); transition: background var(--dur-base) var(--ease-out), transform var(--dur-fast) var(--ease-out); }
.ds-mixer__play:hover { background: var(--accent-hover); }
.ds-mixer__play:active { transform: scale(0.94); }
.ds-mixer__play svg { width: 18px; height: 18px; }
.ds-mixer__headtext { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.ds-mixer__title { font-family: var(--font-display); font-size: var(--text-lg); font-weight: var(--weight-medium); color: var(--text); }
.ds-mixer__metaline { font-size: var(--text-xs); color: var(--text-muted); }
.ds-mixer__actions { display: flex; align-items: center; gap: 14px; flex: none; }
.ds-mixer__newmix { display: inline-flex; align-items: center; gap: 8px; background: transparent; border: 1px solid var(--hairline-strong); color: var(--text); border-radius: var(--radius-pill); padding: 8px 16px; font-family: var(--font-display); font-weight: var(--weight-medium); font-size: var(--text-sm); cursor: pointer; transition: all var(--dur-base) var(--ease-out); }
.ds-mixer__newmix:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }
.ds-mixer__newmix svg { width: 15px; height: 15px; }
.ds-mixer__mastervol { display: flex; align-items: center; gap: 8px; color: var(--text-muted); }
.ds-mixer__mastervol svg { width: 18px; height: 18px; flex: none; }

.ds-mixer__channels { display: flex; flex-direction: column; }
.ds-mixer__channel { display: grid; grid-template-columns: 150px 1fr auto; align-items: center; gap: 18px; padding: 16px 0; transition: opacity var(--dur-base) var(--ease-out); }
.ds-mixer__channel + .ds-mixer__channel { border-top: 1px solid var(--hairline); }
.ds-mixer__chlabel { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.ds-mixer__chname { font-family: var(--font-display); font-size: var(--text-base); font-weight: var(--weight-semibold); color: var(--text); }
.ds-mixer__chsound { font-size: var(--text-xs); color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; display: block; max-width: 100%; text-decoration: none; transition: color var(--dur-base) var(--ease-out); }
.ds-mixer__chsound.is-linked { cursor: pointer; }
.ds-mixer__chsound.is-linked:hover { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }
.ds-mixer--ondark .ds-mixer__chsound.is-linked:hover { color: #fff; }
.ds-mixer__bars { display: flex; align-items: center; gap: 2px; height: 34px; min-width: 0; transition: opacity 140ms; }
.ds-mixer__bar { flex: 1; min-width: 2px; border-radius: 2px; background: var(--wave-unplayed); transition: background 120ms linear; }
.ds-mixer__bar--played { background: var(--accent); }
.ds-mixer__bar--head { background: var(--accent-hover); }
.ds-mixer__ctrls { display: flex; align-items: center; gap: 12px; flex: none; }
.ds-mixer__mute, .ds-mixer__reload { width: 34px; height: 34px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; background: transparent; color: var(--text-muted); border: 0; cursor: pointer; transition: background var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out); }
.ds-mixer__mute:hover, .ds-mixer__reload:hover { background: var(--accent-soft); color: var(--accent); }
.ds-mixer__mute svg { width: 18px; height: 18px; }
.ds-mixer__reload svg { width: 17px; height: 17px; transition: transform var(--dur-base) var(--ease-out); }
.ds-mixer__reload:active svg { transform: rotate(-180deg); }

.ds-mixer__volicon { display: inline-flex; align-items: center; }
.ds-mixer__volicon svg { width: 18px; height: 18px; }
.ds-mixer__range { -webkit-appearance: none; appearance: none; width: 96px; height: 5px; border-radius: 3px; background: var(--mixer-track); cursor: pointer; outline: none; }
.ds-mixer__range::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 14px; height: 14px; border-radius: 50%; background: var(--accent); cursor: pointer; border: 2px solid var(--surface); box-shadow: var(--shadow-sm); margin-top: -1px; }
.ds-mixer__range::-moz-range-thumb { width: 14px; height: 14px; border-radius: 50%; background: var(--accent); cursor: pointer; border: 2px solid var(--surface); }
.ds-mixer--ondark .ds-mixer__range::-webkit-slider-thumb { border-color: rgba(255,255,255,0.85); }
.ds-mixer--ondark .ds-mixer__range::-moz-range-thumb { border-color: rgba(255,255,255,0.85); }

.ds-mixer__channel.is-muted { opacity: 0.45; }
.ds-mixer__channel.is-muted .ds-mixer__mute { color: var(--accent); }
.ds-mixer__channel.is-loading .ds-mixer__bars { opacity: 0.35; }

@media (max-width: 640px) {
  .ds-mixer__channel { grid-template-columns: 104px 1fr; grid-template-areas: "label bars" "ctrls ctrls"; gap: 8px 12px; }
  .ds-mixer__chlabel { grid-area: label; } .ds-mixer__bars { grid-area: bars; } .ds-mixer__ctrls { grid-area: ctrls; justify-content: flex-end; }
  .ds-mixer__master { flex-wrap: wrap; }
}

/* Layer Mixer on dark imagery (.ds-mixer--ondark) — white-on-dark text/controls */
.ds-mixer--ondark { --wave-unplayed: rgba(255,255,255,0.24); --mixer-track: rgba(255,255,255,0.34); }
.ds-mixer--ondark .ds-mixer__title { color: #ECEEF2; }
.ds-mixer--ondark .ds-mixer__metaline, .ds-mixer--ondark .ds-mixer__chsound { color: rgba(236,238,242,0.74); }
.ds-mixer--ondark .ds-mixer__chname { color: #ECEEF2; }
.ds-mixer--ondark .ds-mixer__master { border-bottom-color: rgba(255,255,255,0.16); }
.ds-mixer--ondark .ds-mixer__channel + .ds-mixer__channel { border-top-color: rgba(255,255,255,0.12); }
.ds-mixer--ondark .ds-mixer__newmix { border-color: rgba(255,255,255,0.32); color: #ECEEF2; }
.ds-mixer--ondark .ds-mixer__newmix:hover { background: rgba(255,255,255,0.12); border-color: rgba(255,255,255,0.55); color: #fff; }
.ds-mixer--ondark .ds-mixer__mute, .ds-mixer--ondark .ds-mixer__reload, .ds-mixer--ondark .ds-mixer__mastervol { color: rgba(236,238,242,0.82); }
.ds-mixer--ondark .ds-mixer__mute:hover, .ds-mixer--ondark .ds-mixer__reload:hover { background: rgba(255,255,255,0.12); color: #fff; }

/* Glassy hero mixer — the hero video shows through the blur */
.wsite-hero__mixer { margin-top: 30px; max-width: 780px; background: color-mix(in srgb, #0E1116 40%, transparent); -webkit-backdrop-filter: blur(16px) saturate(1.1); backdrop-filter: blur(16px) saturate(1.1); border: 1px solid rgba(255,255,255,0.14); border-radius: var(--radius-lg); box-shadow: var(--shadow-xl); padding: 14px 20px; }
.wsite-hero__mixer .ds-mixer__channel { padding: 12px 0; }
.wsite-hero__mixer .ds-mixer__chlabel { width: 124px; }
.wsite-hero__mixer .ds-mixer__channel { grid-template-columns: 124px 1fr auto; }
@media (max-width: 980px) { .wsite-hero__mixer { max-width: none; } }

/* ============================================================
   Bundle product page (.wsite-bundle)
   ============================================================ */
.wsite-bundle__lead { color: var(--text-muted); max-width: 56ch; }
.wsite-bundle__lead p { margin: 0 0 8px; }
.wsite-bundle__packs { margin-top: 56px; border-top: 1px solid var(--hairline); padding-top: 8px; }
.wsite-bundle__packshead { margin: 12px 0 4px; }
.wsite-bundle__pack { padding: 30px 0; border-bottom: 1px solid var(--hairline); }
.wsite-bundle__packhead { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 12px; }
.wsite-bundle__packname { font-family: var(--font-display); font-size: var(--text-h3); font-weight: var(--weight-medium); color: var(--text); text-decoration: none; letter-spacing: var(--tracking-snug); }
.wsite-bundle__packname:hover { color: var(--accent); }
.wsite-bundle__packdesc { color: var(--text-muted); font-size: var(--text-sm); line-height: var(--leading-relaxed); max-width: 72ch; margin-bottom: 18px; }
.wsite-bundle__packdesc p { margin: 0 0 6px; }
.wsite-bundle__packdesc ul { margin: 0; padding-left: 18px; }
.wsite-bundle__packplayer { width: 100%; }
.wsite-bundle__packplayer .ds-wave, .wsite-bundle__packplayer .ds-wave--product { width: 100%; }

/* ============================================================
   Starter Bundle landing page (.wsite-starter)
   ============================================================ */
.wsite-starter__hero { position: relative; overflow: hidden; background-size: cover; background-position: center; padding: clamp(76px, 13vh, 150px) clamp(20px, 5vw, 56px); text-align: center; }
.wsite-starter__scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(8,10,13,0.52) 0%, rgba(8,10,13,0.74) 100%); }
.wsite-starter__heroinner { position: relative; max-width: 760px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; }
.wsite-starter__title { font-family: var(--font-display); font-weight: 300; font-size: clamp(40px, 6vw, 72px); line-height: 1.05; letter-spacing: -0.025em; color: #F4F3EF; margin: 12px 0 0; text-wrap: balance; }
.wsite-starter__lead { font-size: var(--text-lg); line-height: var(--leading-relaxed); color: rgba(244,243,239,0.82); max-width: 56ch; margin: 18px 0 0; }
.wsite-starter__price { margin-top: 24px; font-family: var(--font-display); font-size: 30px; color: #F4F3EF; }
.wsite-starter__price del { opacity: 0.55; font-weight: 400; margin-right: 10px; font-size: 22px; }
.wsite-starter__price ins { text-decoration: none; }
.wsite-starter__cta { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; margin-top: 26px; }
.wsite-starter__trust { margin-top: 18px; font-size: var(--text-sm); color: rgba(244,243,239,0.6); }

.wsite-starter__inc { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 18px; }
.wsite-starter__card { background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); overflow: hidden; display: flex; flex-direction: column; transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out); }
.wsite-starter__card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lift); }
.wsite-starter__cardart { display: block; aspect-ratio: 1 / 1; overflow: hidden; }
.wsite-starter__cardart img { width: 100%; height: 100%; object-fit: cover; display: block; }
.wsite-starter__cardbody { padding: 16px; display: flex; flex-direction: column; gap: 8px; }
.wsite-starter__cardname { font-family: var(--font-display); font-weight: var(--weight-medium); font-size: var(--text-base); color: var(--text); text-decoration: none; line-height: 1.25; }
.wsite-starter__cardname:hover { color: var(--accent); }
.wsite-starter__cardtext { font-size: var(--text-xs); line-height: var(--leading-relaxed); color: var(--text-muted); margin: 0; }

.wsite-starter__players { display: flex; flex-direction: column; gap: 32px; }
.wsite-starter__playername { display: inline-block; font-family: var(--font-display); font-weight: var(--weight-medium); font-size: var(--text-h3); letter-spacing: var(--tracking-snug); color: var(--text); text-decoration: none; margin-bottom: 12px; }
.wsite-starter__playername:hover { color: var(--accent); }
.wsite-starter__player .ds-wave { width: 100%; }

/* ============================================================
   Logged-out My Account = centered login card
   (.woocommerce is flex row for the logged-in nav+content layout —
    override to a centered single card when logged out)
   ============================================================ */
body:not(.logged-in).woocommerce-account .woocommerce { display: block !important; max-width: 440px; margin: 8px auto 0; }
body:not(.logged-in).woocommerce-account .woocommerce > h2 { text-align: center; font-family: var(--font-display); font-weight: var(--weight-medium); font-size: var(--text-h2); margin: 0 0 18px; color: var(--text); }
body:not(.logged-in).woocommerce-account .woocommerce-form-login { background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); padding: 30px; margin: 0; }
body:not(.logged-in).woocommerce-account .woocommerce-form-login .form-row { margin: 0 0 16px; }
body:not(.logged-in).woocommerce-account .woocommerce-form-login label:not(.woocommerce-form-login__rememberme) { display: block; margin-bottom: 6px; font-family: var(--font-display); font-size: var(--text-sm); font-weight: var(--weight-medium); color: var(--text); }
body:not(.logged-in).woocommerce-account .woocommerce-form-login input.input-text { width: 100%; }
body:not(.logged-in).woocommerce-account .woocommerce-form-login .woocommerce-form-login__submit { width: 100%; justify-content: center; margin-top: 4px; }
body:not(.logged-in).woocommerce-account .woocommerce-form-login__rememberme { display: inline-flex; align-items: center; gap: 8px; margin: 14px 0 0; font-size: var(--text-sm); color: var(--text-muted); }
body:not(.logged-in).woocommerce-account .woocommerce-form-login__rememberme input { margin: 0; }
body:not(.logged-in).woocommerce-account .woocommerce-LostPassword { margin: 16px 0 0; font-size: var(--text-sm); }
body:not(.logged-in).woocommerce-account .woocommerce-LostPassword a { color: var(--accent); }

/* checkout is pinned to light (FunnelKit) — hide the theme toggle there so it can't be flipped */
body.woocommerce-checkout #duende-theme-toggle { display: none; }

/* ============================================================
   Cleanup + bespoke track-detail (single product)
   ============================================================ */
/* kill the stray default widget dump */
#sidebar, #secondary.widget-area, .wp-block-group.is-layout-flow > #sidebar { display: none !important; }
/* tidy cookie consent button overlap */
#cmplz-manage-consent, .cmplz-manage-consent { z-index: 30 !important; }

/* track-detail art */
.wsite-detail__art { background: var(--surface-2); }
.wsite-detail__art img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }

/* badges */
.ds-badge { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-display); font-size: var(--text-xs); font-weight: 500; color: var(--text-muted); background: var(--surface-2); border: 1px solid var(--hairline); border-radius: var(--radius-pill); padding: 5px 12px; }
.ds-badge__dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); flex: none; }

/* buy area inside the detail info column */
.wsite-detail__buy { margin-top: 26px; display: flex; flex-direction: column; gap: 16px; }
.wsite-detail__buy .price { margin: 0; }
.wsite-detail__buy .quantity { margin-right: 10px; }
.wsite-detail__info .ds-display { letter-spacing: var(--tracking-tight); }

/* "what's included" list (from the pack's kadence bullet list) */
.duende-includes ul { list-style: none; padding: 0; margin: 14px 0 0; display: grid; gap: 11px; }
.duende-includes li { display: flex; align-items: flex-start; gap: 9px; color: var(--text-muted); font-size: var(--text-sm); line-height: var(--leading-normal); }
.duende-includes li::before { content: ""; flex: none; width: 16px; height: 16px; margin-top: 3px; border-radius: 4px; background: var(--accent-soft); background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236E8CA0' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: center; }
.duende-includes .kt-svg-icon-list, .duende-includes ul.kt-svg-icon-list { display: grid; gap: 11px; }
.duende-includes svg { display: none; }

/* details / attributes */
.duende-meta table { width: 100%; border-collapse: collapse; margin-top: 14px; }
.duende-meta th, .duende-meta td { text-align: left; padding: 10px 0; border-bottom: 1px solid var(--hairline); font-size: var(--text-sm); }
.duende-meta th { color: var(--text-muted); font-weight: 500; width: 40%; }

/* detail player container (full width, glassy on dark works via card surface) */
.wsite-detail__player .ds-wave { box-shadow: var(--shadow-md); }

@media (max-width: 720px) {
  .wsite-detail__top { grid-template-columns: 1fr; }
}

/* ============================================================
   Sale badge (design accent, replaces the olive default)
   ============================================================ */
.duende-sale { position: absolute; top: 14px; left: 14px; z-index: 3; background: var(--accent); color: var(--accent-contrast); font-family: var(--font-display); font-weight: 600; font-size: var(--text-2xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; padding: 4px 10px; border-radius: var(--radius-pill); box-shadow: var(--shadow-sm); }
.woocommerce span.onsale, .woocommerce .onsale { background: var(--accent) !important; color: var(--accent-contrast) !important; border-radius: var(--radius-pill) !important; font-family: var(--font-display); font-weight: 600; min-height: 0; min-width: 0; line-height: 1; padding: 5px 12px; top: 12px; left: 12px; margin: 0; }

/* ============================================================
   Bespoke catalog / shop grid
   ============================================================ */
.wsite-catalog__head .ds-h1 { margin-top: 6px; }
.wsite-catalog__controls { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-top: 22px; }
.wsite-catalog__controls .woocommerce-result-count { margin: 0; color: var(--text-muted); font-size: var(--text-sm); }
.wsite-catalog .woocommerce-ordering select, .wsite-catalog select.orderby { border: 1px solid var(--hairline); border-radius: var(--radius-pill); background: var(--surface); color: var(--text); padding: 9px 14px; font-family: var(--font-display); font-size: var(--text-sm); }
.wsite-catalog .woocommerce-pagination { margin-top: 40px; }
.wsite-catalog .woocommerce-pagination ul,
.woocommerce nav.woocommerce-pagination ul { display: inline-flex; gap: 4px; list-style: none; padding: 0; margin: 0; border: 0; }
.woocommerce nav.woocommerce-pagination ul li { border: 0; margin: 0; overflow: visible; }
/* plain numbers — no boxes */
.wsite-catalog .woocommerce-pagination a, .wsite-catalog .woocommerce-pagination span,
.woocommerce nav.woocommerce-pagination ul li a, .woocommerce nav.woocommerce-pagination ul li span {
  border: 0 !important; background: none !important; border-radius: 0; padding: 8px 12px;
  color: var(--text-muted); font-family: var(--font-display); font-weight: var(--weight-medium);
  font-variant-numeric: tabular-nums; min-width: 0; line-height: 1; transition: color var(--dur-base) var(--ease-out);
}
.wsite-catalog .woocommerce-pagination a:hover,
.woocommerce nav.woocommerce-pagination ul li a:hover { color: var(--accent); background: none !important; }
.wsite-catalog .woocommerce-pagination .current,
.woocommerce nav.woocommerce-pagination ul li span.current {
  background: none !important; color: var(--accent); border: 0 !important; font-weight: var(--weight-semibold);
}
.wsite-cat-chips { display: flex; gap: 8px; flex-wrap: wrap; }
.wsite-cat-chips a { font-family: var(--font-display); font-size: var(--text-sm); font-weight: 500; color: var(--text-muted); border: 1px solid var(--hairline); border-radius: var(--radius-pill); padding: 7px 14px; text-decoration: none; transition: all var(--dur-base) var(--ease-out); }
.wsite-cat-chips a:hover { color: var(--text); border-color: var(--hairline-strong); }
.wsite-cat-chips a.is-active { color: var(--accent); border-color: var(--accent); background: var(--accent-soft); }

/* desktop-app tab download buttons */
.duende-app-dl { display: flex; gap: 14px; flex-wrap: wrap; }

/* homepage "Hear the library" preview cards */
.duende-previews { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
.duende-preview { background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); padding: 18px; display: flex; flex-direction: column; gap: 14px; }
.duende-preview__head { display: flex; align-items: center; gap: 14px; }
.duende-preview__art { width: 72px; height: 72px; flex: none; border-radius: var(--radius-md); overflow: hidden; position: relative; display: block; }
.duende-preview__art img { width: 100%; height: 100%; object-fit: cover; }
.duende-preview__meta { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.duende-preview__meta .wsite-cc__title { font-size: var(--text-lg); }
.duende-preview .ds-wave { background: transparent; border: 0; box-shadow: none; padding: 0; }
.duende-preview .ds-wave__list { max-height: 230px; }
@media (max-width: 860px) { .duende-previews { grid-template-columns: 1fr; } }

/* homepage testimonials */
.duende-tmgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.duende-tm { margin: 0; background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); padding: 24px; display: flex; flex-direction: column; gap: 14px; }
.duende-tm__stars { color: var(--accent); letter-spacing: 2px; font-size: var(--text-sm); }
.duende-tm blockquote { margin: 0; font-size: var(--text-lg); line-height: 1.5; color: var(--text); }
.duende-tm figcaption { margin-top: auto; font-family: var(--font-display); font-weight: 600; font-size: var(--text-sm); color: var(--text-muted); }
@media (max-width: 980px) { .duende-tmgrid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .duende-tmgrid { grid-template-columns: 1fr; } }

/* homepage FAQ accordion */
.duende-faq { max-width: 820px; margin: 0 auto; display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--hairline); }
.duende-faq__item { border-bottom: 1px solid var(--hairline); }
.duende-faq__item summary { cursor: pointer; list-style: none; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 20px 4px; font-family: var(--font-display); font-weight: 600; font-size: var(--text-lg); color: var(--text); transition: color var(--dur-base) var(--ease-out); }
.duende-faq__item summary::-webkit-details-marker { display: none; }
.duende-faq__item summary:hover { color: var(--accent); }
.duende-faq__item summary::after { content: "+"; flex: none; font-weight: 300; font-size: 24px; line-height: 1; color: var(--text-muted); transition: transform var(--dur-base) var(--ease-out); }
.duende-faq__item[open] summary::after { content: "\2212"; color: var(--accent); }
.duende-faq__a { padding: 0 4px 22px; color: var(--text-muted); font-size: var(--text-base); line-height: 1.6; max-width: 70ch; }

/* wider container for cart / checkout / account pages */
.woocommerce-cart .duende-page, .woocommerce-checkout .duende-page, .woocommerce-account .duende-page { max-width: 1080px; }

/* ============================================================
   My Account
   ============================================================ */
.woocommerce-account .woocommerce { display: flex; gap: 40px; flex-wrap: wrap; align-items: flex-start; }
.woocommerce-MyAccount-navigation { flex: 0 0 230px; }
.woocommerce-MyAccount-navigation ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.woocommerce-MyAccount-navigation li a { display: block; padding: 11px 14px; border-radius: var(--radius-sm); color: var(--text-muted); font-family: var(--font-display); font-weight: 500; font-size: var(--text-sm); text-decoration: none; transition: background var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out); }
.woocommerce-MyAccount-navigation li a:hover { color: var(--text); background: var(--surface-2); }
.woocommerce-MyAccount-navigation li.is-active a { background: var(--accent-soft); color: var(--accent); }
.woocommerce-MyAccount-content { flex: 1; min-width: 0; background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-lg); padding: 28px 30px; box-shadow: var(--shadow-sm); }
.woocommerce-MyAccount-content a { color: var(--accent); }
/* login / register */
.woocommerce-account .woocommerce form.login, .woocommerce-account .woocommerce form.register { background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--radius-lg); padding: 30px; box-shadow: var(--shadow-sm); }
.woocommerce .col2-set { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; width: 100%; }
.woocommerce .col2-set .col-1, .woocommerce .col2-set .col-2 { width: auto; float: none; }
.woocommerce-account h2, .woocommerce-account .u-column1 h2, .woocommerce-account .u-column2 h2 { font-family: var(--font-display); font-weight: 500; font-size: var(--text-h3); }
@media (max-width: 720px) { .woocommerce-account .woocommerce { flex-direction: column; } .woocommerce .col2-set { grid-template-columns: 1fr; } }

/* ============================================================
   Fluent Forms (license generation, etc.) -> design forms
   ============================================================ */
.fluentform .ff-el-group { margin-bottom: 18px; }
.fluentform .ff-el-input--label label, .fluentform label { font-family: var(--font-display); font-weight: 500; color: var(--text); font-size: var(--text-sm); margin-bottom: 6px; }
.fluentform .ff-el-input--content input[type="text"],
.fluentform .ff-el-input--content input[type="email"],
.fluentform .ff-el-input--content input[type="tel"],
.fluentform .ff-el-input--content input[type="number"],
.fluentform .ff-el-input--content input[type="url"],
.fluentform .ff-el-input--content textarea,
.fluentform .ff-el-input--content select,
.fluentform input.ff-el-form-control,
.fluentform select.ff-el-form-control,
.fluentform textarea.ff-el-form-control {
  background: var(--surface) !important; color: var(--text) !important;
  border: 1px solid var(--hairline) !important; border-radius: var(--radius-sm) !important;
  padding: 12px 13px !important; font-family: var(--font-body) !important; font-size: var(--text-base) !important;
  box-shadow: none !important; transition: border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.fluentform .ff-el-form-control:focus { border-color: var(--accent) !important; box-shadow: 0 0 0 3px var(--accent-ring) !important; outline: none !important; }
.fluentform .ff-el-form-control::placeholder { color: var(--text-faint); }
.fluentform .ff-btn-submit, .fluentform button.ff-btn-submit, .fluentform .ff-btn.ff-btn-submit {
  background: var(--accent) !important; color: var(--accent-contrast) !important; border: 0 !important;
  border-radius: var(--radius-pill) !important; font-family: var(--font-display) !important; font-weight: 500 !important;
  font-size: var(--text-sm) !important; padding: 13px 28px !important; box-shadow: var(--shadow-sm); transition: background var(--dur-base) var(--ease-out);
}
.fluentform .ff-btn-submit:hover { background: var(--accent-hover) !important; }
.fluentform .ff-el-progress-bar { background: var(--accent) !important; }
.ff-message-success, .ff_submit_success { background: var(--surface-2); border: 1px solid var(--hairline); border-radius: var(--radius-md); color: var(--text); padding: 18px 20px; }

/* Kadence form blocks -> design forms */
.kb-form input[type="text"], .kb-form input[type="email"], .kb-form input[type="tel"], .kb-form input[type="url"],
.kb-form input[type="number"], .kb-form textarea, .kb-form select, .kb-form .kb-field {
  background: var(--surface) !important; color: var(--text) !important; border: 1px solid var(--hairline) !important;
  border-radius: var(--radius-sm) !important; padding: 12px 13px !important; font-family: var(--font-body) !important; box-shadow: none !important;
  transition: border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.kb-form input:focus, .kb-form textarea:focus, .kb-form select:focus, .kb-form .kb-field:focus { border-color: var(--accent) !important; box-shadow: 0 0 0 3px var(--accent-ring) !important; outline: none !important; }
.kb-form label, .kb-form .kb-form-field-label { font-family: var(--font-display); font-weight: 500; color: var(--text); }
.kb-forms-submit, button.kb-forms-submit, .kb-form .kb-forms-submit {
  background: var(--accent) !important; background-image: none !important; color: var(--accent-contrast) !important; border: 0 !important;
  border-radius: var(--radius-pill) !important; font-family: var(--font-display) !important; font-weight: 500 !important;
  padding: 13px 28px !important; box-shadow: var(--shadow-sm); transition: background var(--dur-base) var(--ease-out);
}
.kb-forms-submit:hover { background: var(--accent-hover) !important; }

/* responsive video/embeds in prose (e.g. tutorial YouTube) */
.duende-prose iframe, .wsite-detail iframe { width: 100%; max-width: 100%; aspect-ratio: 16 / 9; height: auto; border: 0; border-radius: var(--radius-md); margin: 8px 0; }
.duende-prose .wp-block-embed__wrapper { margin: 8px 0; }
.duende-prose p:empty, .wsite-detail p:empty { display: none; }
/* defunct intro-sale countdown timers — we no longer run intro sales */
.wp-block-kadence-countdown, .kb-countdown, .kt-countdown { display: none !important; }

/* ============================================================
   Product Bundles — clean "what's inside" component table
   ============================================================ */
/* hide each component's full description/playlist (the wall of text + leaked playlist JSON) */
.bundled_product_excerpt, .bundle_form .product_excerpt, .bundled_product .details .product_excerpt, .bundled_product .wp-playlist { display: none !important; }
.bundle_form table.bundled_products, table.bundled_products { width: 100%; border-collapse: collapse; margin: 18px 0 4px; }
.bundle_form tr.bundled_product { border-bottom: 1px solid var(--hairline); background: transparent; }
.bundle_form .bundled_item_col { padding: 13px 8px; vertical-align: middle; border: 0; }
.bundle_form .bundled_item_images_col { width: 66px; }
.bundle_form .bundled_item_images_col img { width: 56px; height: 56px; object-fit: cover; border-radius: var(--radius-sm); display: block; }
.bundle_form .bundled_product_title_inner, .bundle_form .bundled_product_title, .bundle_form .bundled_item_details_col .bundled_product_title { font-family: var(--font-display); font-weight: 500; font-size: var(--text-base); color: var(--text); }
.bundle_form .bundled_item_qty_col { text-align: right; color: var(--text-muted); white-space: nowrap; }
.bundle_form .bundled_item_optional_checkbox { accent-color: var(--accent); }
.bundle_wrap .bundle_price, .bundle_form .bundle_price, .woocommerce div.product .bundle_price { font-family: var(--font-display); }
.bundle_form .bundle_data .bundle_price .price, .bundle_price .price { font-size: 26px; color: var(--text); }
.bundled_product_optional_suffix { color: var(--text-faint); font-size: var(--text-xs); }
