/*
Theme Name: De Belg Waterloo
Theme URI: https://example.com/de-belg-waterloo
Author: QoQ
Author URI: https://qoq.nl
Description: Donker, warm WordPress thema voor De Belg Waterloo met WooCommerce ondersteuning voor shop, productpagina, winkelwagen, checkout en account.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: de-belg-waterloo
Tags: custom-background, custom-logo, custom-menu, e-commerce, woocommerce, responsive-layout
*/

:root {
  --dbw-surface-variant: #353436;
  --dbw-surface-dim: #131314;
  --dbw-on-surface-variant: #d0c6ab;
  --dbw-on-tertiary-container: #735615;
  --dbw-primary-fixed-dim: #e9c400;
  --dbw-surface-container-highest: #353436;
  --dbw-on-secondary-container: #ffcdca;
  --dbw-background: #131314;
  --dbw-error-container: #93000a;
  --dbw-on-primary-container: #6b5900;
  --dbw-surface-container-lowest: #0e0e0f;
  --dbw-on-primary: #3a3000;
  --dbw-surface: #131314;
  --dbw-surface-container: #1f1f20;
  --dbw-primary-fixed: #ffe16d;
  --dbw-on-tertiary-fixed-variant: #5d4201;
  --dbw-tertiary: #ffedd1;
  --dbw-tertiary-container: #f6cd81;
  --dbw-error: #ffb4ab;
  --dbw-on-secondary: #68000f;
  --dbw-tertiary-fixed: #ffdea5;
  --dbw-on-tertiary: #412d00;
  --dbw-surface-bright: #39393a;
  --dbw-inverse-on-surface: #303031;
  --dbw-secondary: #ffb3b0;
  --dbw-on-background: #e5e2e3;
  --dbw-inverse-primary: #705d00;
  --dbw-on-secondary-fixed: #410006;
  --dbw-secondary-container: #bf0124;
  --dbw-outline-variant: #4d4632;
  --dbw-on-surface: #e5e2e3;
  --dbw-on-error-container: #ffdad6;
  --dbw-on-primary-fixed-variant: #544600;
  --dbw-surface-container-high: #2a2a2b;
  --dbw-on-secondary-fixed-variant: #930019;
  --dbw-surface-container-low: #1b1b1c;
  --dbw-outline: #999078;
  --dbw-inverse-surface: #e5e2e3;
  --dbw-tertiary-fixed-dim: #e9c176;
  --dbw-on-tertiary-fixed: #261900;
  --dbw-primary: #ffefba;
  --dbw-surface-tint: #e9c400;
  --dbw-on-error: #690005;
  --dbw-on-primary-fixed: #221b00;
  --dbw-secondary-fixed: #ffdad8;
  --dbw-primary-container: #f7d000;
  --dbw-secondary-fixed-dim: #ffb3b0;
  --dbw-red: #ef3340;
  --dbw-whatsapp: #25d366;
  --dbw-gold-line: #c5a059;
  --dbw-max: 1280px;
  --dbw-mobile: 20px;
  --dbw-desktop: 64px;
  --dbw-sm: 16px;
  --dbw-md: 24px;
  --dbw-lg: 48px;
  --dbw-xl: 80px;
  --dbw-radius: 12px;
  --dbw-font-heading: "Vollkorn", Georgia, serif;
  --dbw-font-body: "Work Sans", Arial, sans-serif;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  min-height: 100vh;
  background: var(--dbw-background);
  color: var(--dbw-on-surface);
  font-family: var(--dbw-font-body);
  font-size: 16px;
  line-height: 1.6;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

body.admin-bar .dbw-site-header { top: 32px; }

a { color: var(--dbw-primary); text-decoration: none; transition: color .2s ease, opacity .2s ease, border-color .2s ease, background .2s ease; }
a:hover { color: var(--dbw-primary-fixed-dim); }

img { max-width: 100%; height: auto; display: block; }

button, input, textarea, select { font-family: inherit; }

.screen-reader-text,
.skip-link {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  word-wrap: normal !important;
}

.skip-link:focus {
  clip: auto;
  clip-path: none;
  display: block;
  height: auto;
  left: 16px;
  top: 16px;
  width: auto;
  z-index: 100000;
  background: var(--dbw-primary-fixed);
  color: var(--dbw-on-primary-fixed);
  padding: 10px 14px;
  border-radius: 8px;
}

.material-symbols-outlined {
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
  vertical-align: middle;
  line-height: 1;
}

.dbw-container {
  width: 100%;
  max-width: var(--dbw-max);
  margin: 0 auto;
  padding-left: var(--dbw-mobile);
  padding-right: var(--dbw-mobile);
}

.dbw-site-wrap { min-height: 100vh; display: flex; flex-direction: column; }
.dbw-main { flex: 1 0 auto; }

.dbw-site-header {
  background: rgba(19, 19, 20, .92);
  border-bottom: 1px solid var(--dbw-outline-variant);
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
  backdrop-filter: blur(14px);
  position: sticky;
  top: 0;
  z-index: 50;
}

.dbw-header-top,
.dbw-header-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--dbw-sm);
  flex-wrap: wrap;
}

.dbw-header-top { padding-top: 12px; padding-bottom: 12px; }
.dbw-header-main { padding-top: 14px; padding-bottom: 18px; border-top: 1px solid rgba(77,70,50,.45); }

.dbw-badge {
  background: var(--dbw-primary-fixed);
  color: var(--dbw-on-primary-fixed);
  border: 1px solid var(--dbw-primary-container);
  box-shadow: 0 4px 14px rgba(0,0,0,.22);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .05em;
  padding: 4px 16px;
  text-transform: uppercase;
  overflow: hidden;
  position: relative;
}

.dbw-badge:after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.22), transparent);
  transform: translateX(-100%);
  animation: dbw-shine 5s ease-in-out infinite;
}

@keyframes dbw-shine { 0%, 60% { transform: translateX(-100%); } 100% { transform: translateX(100%); } }

.dbw-brand { display: flex; align-items: center; gap: 14px; min-width: 220px; }
.dbw-brand-title { font-family: var(--dbw-font-heading); color: var(--dbw-primary); font-size: 30px; font-weight: 700; line-height: 1.1; }
.dbw-brand-title:hover { color: var(--dbw-primary); opacity: .86; }
.dbw-custom-logo { width: auto; max-height: 56px; }

.dbw-nav-wrap { display: flex; align-items: center; gap: 16px; }
.dbw-menu-toggle { display: none; }

.dbw-menu,
.dbw-footer-menu { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; align-items: center; gap: 24px; }
.dbw-menu a,
.dbw-footer-menu a {
  color: var(--dbw-on-surface-variant);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.dbw-menu a:hover,
.dbw-footer-menu a:hover { color: var(--dbw-on-surface); text-decoration: underline; text-decoration-color: var(--dbw-primary); }

.dbw-actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }

.dbw-btn,
.wp-element-button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce #payment #place_order,
.woocommerce-page #payment #place_order,
button.single_add_to_cart_button,
.added_to_cart {
  appearance: none;
  border: 0;
  border-radius: 8px;
  background: var(--dbw-red);
  color: #fff !important;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: var(--dbw-font-body);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .05em;
  line-height: 1.2;
  padding: 12px 16px;
  text-transform: uppercase;
  transition: transform .2s ease, opacity .2s ease, background .2s ease, box-shadow .2s ease;
}

.dbw-btn:hover,
.wp-element-button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce #payment #place_order:hover,
.woocommerce-page #payment #place_order:hover,
button.single_add_to_cart_button:hover,
.added_to_cart:hover {
  opacity: .92;
  transform: translateY(-1px);
  color: #fff !important;
}

.dbw-btn-secondary,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
  background: var(--dbw-primary-fixed);
  color: var(--dbw-on-primary-fixed) !important;
}

.dbw-cart-link {
  border: 1px solid var(--dbw-gold-line);
  color: var(--dbw-primary);
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  font-weight: 700;
}
.dbw-cart-link:hover { background: var(--dbw-surface-container-highest); color: var(--dbw-primary); }
.dbw-cart-count {
  background: var(--dbw-red);
  color: #fff;
  min-width: 22px;
  min-height: 22px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  padding: 0 6px;
}

.dbw-front-main { padding-top: 48px; padding-bottom: 80px; display: flex; flex-direction: column; gap: 80px; }
.dbw-hero-copy { max-width: 880px; margin: 0 auto; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 16px; }
.dbw-display-title { margin: 0; font-family: var(--dbw-font-heading); font-size: clamp(42px, 6vw, 74px); line-height: 1.04; font-weight: 700; color: var(--dbw-primary); }
.dbw-subtitle { margin: 0; font-family: var(--dbw-font-heading); font-size: clamp(24px, 3vw, 34px); line-height: 1.3; font-weight: 600; color: var(--dbw-on-surface-variant); font-style: italic; }

.dbw-hero-banner {
  width: 100%;
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(77,70,50,.45);
  box-shadow: 0 20px 50px rgba(0,0,0,.5);
  background: var(--dbw-surface-container-lowest);
}
.dbw-hero-banner:before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid rgba(197,160,89,.32);
  border-radius: 12px;
  z-index: 2;
  pointer-events: none;
}
.dbw-hero-banner img { width: 100%; min-height: 260px; object-fit: cover; object-position: center; transform: scale(1); transition: transform 20s ease-out; }
.dbw-hero-banner:hover img { transform: scale(1.05); }

.dbw-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; }
.dbw-card {
  background: var(--dbw-surface-container);
  border: 1px solid rgba(153,144,120,.3);
  border-radius: 12px;
  box-shadow: 0 4px 24px rgba(0,0,0,.4);
  overflow: hidden;
}
.dbw-card-high { background: var(--dbw-surface-container-high); }
.dbw-card-inner { padding: 24px; }
.dbw-card-title { margin: 0 0 16px; font-family: var(--dbw-font-heading); color: var(--dbw-primary); font-size: 28px; line-height: 1.3; font-weight: 600; display: flex; gap: 8px; align-items: center; }
.dbw-card p { color: var(--dbw-on-surface-variant); margin-top: 0; }

.dbw-app-card { position: relative; display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: center; }
.dbw-app-card:before { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(255,239,186,.06), transparent); opacity: 0; transition: opacity .4s ease; }
.dbw-app-card:hover:before { opacity: 1; }
.dbw-app-buttons { display: flex; flex-direction: column; gap: 16px; position: relative; z-index: 1; }
.dbw-outline-btn { border: 1px solid var(--dbw-gold-line); border-radius: 8px; color: var(--dbw-primary); display: flex; align-items: center; justify-content: center; gap: 8px; padding: 14px 16px; font-size: 14px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; }
.dbw-outline-btn:hover { background: var(--dbw-surface-container-highest); color: var(--dbw-primary); }

.dbw-contact-card { border-top: 2px solid var(--dbw-gold-line); }
.dbw-contact-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.dbw-contact-box { background: var(--dbw-surface-container-low); border: 1px solid rgba(77,70,50,.5); border-radius: 8px; padding: 16px; transition: border-color .2s ease; }
.dbw-contact-box:hover { border-color: rgba(197,160,89,.65); }
.dbw-contact-box h3 { margin: 0 0 8px; color: var(--dbw-on-surface-variant); font-size: 14px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.dbw-phone { display: flex; align-items: center; gap: 12px; color: var(--dbw-primary); font-size: 16px; }
.dbw-phone .material-symbols-outlined { color: var(--dbw-whatsapp); background: var(--dbw-surface); border-radius: 999px; padding: 8px; transition: transform .2s ease; }
.dbw-phone:hover .material-symbols-outlined { transform: scale(1.1); }

.dbw-featured { padding-bottom: 80px; }
.dbw-section-head { margin-bottom: 24px; display: flex; align-items: end; justify-content: space-between; gap: 16px; }
.dbw-section-title { margin: 0; font-family: var(--dbw-font-heading); color: var(--dbw-primary); font-size: clamp(32px, 4vw, 46px); line-height: 1.15; }
.dbw-section-text { color: var(--dbw-on-surface-variant); max-width: 640px; margin: 8px 0 0; }

.dbw-page { padding-top: 48px; padding-bottom: 80px; }
.dbw-page-hero { max-width: 900px; margin: 0 auto 32px; text-align: center; }
.dbw-page-title { margin: 0; color: var(--dbw-primary); font-family: var(--dbw-font-heading); font-size: clamp(38px, 5vw, 64px); line-height: 1.08; }
.dbw-page-intro { margin: 12px auto 0; color: var(--dbw-on-surface-variant); max-width: 720px; }
.dbw-content-card { padding: 32px; }
.dbw-entry-content > *:first-child { margin-top: 0; }
.dbw-entry-content h1,
.dbw-entry-content h2,
.dbw-entry-content h3,
.dbw-entry-content h4 { color: var(--dbw-primary); font-family: var(--dbw-font-heading); line-height: 1.2; }
.dbw-entry-content h2 { font-size: 34px; }
.dbw-entry-content h3 { font-size: 26px; }
.dbw-entry-content p,
.dbw-entry-content li { color: var(--dbw-on-surface); }
.dbw-entry-content blockquote { border-left: 4px solid var(--dbw-gold-line); margin-left: 0; padding: 12px 0 12px 20px; color: var(--dbw-on-surface-variant); }

.dbw-post-meta { color: var(--dbw-on-surface-variant); font-size: 14px; margin-top: 8px; }
.dbw-post-list { display: grid; gap: 24px; }
.dbw-post-card { display: grid; grid-template-columns: minmax(0, 260px) 1fr; gap: 24px; align-items: center; }
.dbw-post-card img { border-radius: 10px; aspect-ratio: 4/3; object-fit: cover; }
.dbw-post-card h2 { margin: 0 0 8px; font-family: var(--dbw-font-heading); font-size: 28px; }

.dbw-site-footer { background: var(--dbw-surface-container-lowest); border-top: 1px solid var(--dbw-outline-variant); margin-top: auto; }
.dbw-footer-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; padding-top: 48px; padding-bottom: 48px; }
.dbw-footer-brand { font-family: var(--dbw-font-heading); color: var(--dbw-primary); font-size: 28px; font-weight: 600; }
.dbw-copyright { color: var(--dbw-tertiary-fixed); font-size: 16px; text-align: right; }

input[type="text"], input[type="email"], input[type="url"], input[type="password"], input[type="search"], input[type="tel"], input[type="number"], textarea, select,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
  width: 100%;
  background: var(--dbw-surface-container-lowest);
  color: var(--dbw-on-surface);
  border: 1px solid rgba(153,144,120,.5);
  border-radius: 8px;
  padding: 12px 14px;
  min-height: 46px;
}

textarea { min-height: 140px; }
label, .woocommerce form .form-row label { color: var(--dbw-on-surface-variant); font-weight: 700; }
input:focus, textarea:focus, select:focus { outline: 2px solid rgba(233,196,0,.35); border-color: var(--dbw-primary-fixed-dim); }

/* WooCommerce */
.woocommerce .woocommerce-breadcrumb { color: var(--dbw-on-surface-variant); margin-bottom: 20px; }
.woocommerce .woocommerce-breadcrumb a { color: var(--dbw-primary); }
.woocommerce .page-title { color: var(--dbw-primary); font-family: var(--dbw-font-heading); font-size: clamp(38px, 5vw, 64px); text-align: center; margin: 0 0 28px; }
.woocommerce-result-count, .woocommerce-ordering { color: var(--dbw-on-surface-variant); }
.woocommerce .woocommerce-ordering select { min-width: 240px; }
.woocommerce ul.products { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; margin-top: 28px; }
.woocommerce ul.products::before,
.woocommerce ul.products::after { display: none; }
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  width: auto !important;
  margin: 0 !important;
  float: none !important;
  background: var(--dbw-surface-container);
  border: 1px solid rgba(153,144,120,.28);
  border-radius: 12px;
  padding: 16px 16px 20px;
  box-shadow: 0 4px 24px rgba(0,0,0,.32);
  transition: transform .2s ease, border-color .2s ease;
}
.woocommerce ul.products li.product:hover { transform: translateY(-3px); border-color: rgba(197,160,89,.75); }
.woocommerce ul.products li.product a img { border-radius: 10px; margin: 0 0 16px; aspect-ratio: 1/1; object-fit: cover; background: var(--dbw-surface-container-lowest); }
.woocommerce ul.products li.product .woocommerce-loop-product__title { color: var(--dbw-primary); font-family: var(--dbw-font-heading); font-size: 24px; line-height: 1.2; padding: 0; }
.woocommerce ul.products li.product .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price { color: var(--dbw-tertiary-fixed) !important; font-size: 20px; font-weight: 700; }
.woocommerce span.onsale { background: var(--dbw-red); color: #fff; border-radius: 999px; min-width: 54px; min-height: 54px; line-height: 54px; padding: 0; font-weight: 700; }
.woocommerce .star-rating span::before,
.woocommerce .star-rating::before { color: var(--dbw-primary-fixed-dim); }
.woocommerce nav.woocommerce-pagination ul { border: 1px solid var(--dbw-outline-variant); border-radius: 8px; overflow: hidden; }
.woocommerce nav.woocommerce-pagination ul li { border-right: 1px solid var(--dbw-outline-variant); }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span { color: var(--dbw-primary); background: var(--dbw-surface-container); padding: 12px 15px; }
.woocommerce nav.woocommerce-pagination ul li span.current,
.woocommerce nav.woocommerce-pagination ul li a:hover { background: var(--dbw-primary-fixed); color: var(--dbw-on-primary-fixed); }

.woocommerce div.product { background: var(--dbw-surface-container); border: 1px solid rgba(153,144,120,.3); border-radius: 12px; padding: 24px; box-shadow: 0 4px 24px rgba(0,0,0,.36); }
.woocommerce div.product div.images img { border-radius: 12px; background: var(--dbw-surface-container-lowest); }
.woocommerce div.product .product_title { color: var(--dbw-primary); font-family: var(--dbw-font-heading); font-size: clamp(36px, 4vw, 56px); line-height: 1.08; margin-bottom: 12px; }
.woocommerce div.product .woocommerce-product-details__short-description { color: var(--dbw-on-surface-variant); }
.woocommerce div.product form.cart { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.woocommerce .quantity .qty { width: 90px; text-align: center; }
.woocommerce div.product .woocommerce-tabs ul.tabs { padding-left: 0; margin-top: 42px; }
.woocommerce div.product .woocommerce-tabs ul.tabs::before { border-bottom-color: var(--dbw-outline-variant); }
.woocommerce div.product .woocommerce-tabs ul.tabs li { background: var(--dbw-surface-container-high); border-color: var(--dbw-outline-variant); border-radius: 8px 8px 0 0; }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active { background: var(--dbw-primary-fixed); color: var(--dbw-on-primary-fixed); }
.woocommerce div.product .woocommerce-tabs ul.tabs li a { color: inherit; }
.woocommerce div.product .woocommerce-tabs .panel { color: var(--dbw-on-surface); }
.woocommerce table.shop_attributes th { color: var(--dbw-on-surface-variant); }
.woocommerce table.shop_attributes td { color: var(--dbw-on-surface); }
.related.products h2,
.upsells.products h2 { color: var(--dbw-primary); font-family: var(--dbw-font-heading); font-size: 34px; }

.woocommerce-cart-form,
.cart-collaterals .cart_totals,
.woocommerce-checkout-review-order,
.woocommerce-account .woocommerce-MyAccount-content,
.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-order,
.woocommerce-customer-details,
.woocommerce-billing-fields,
.woocommerce-shipping-fields,
.woocommerce-additional-fields {
  background: var(--dbw-surface-container);
  border: 1px solid rgba(153,144,120,.3);
  border-radius: 12px;
  padding: 24px;
  box-shadow: 0 4px 24px rgba(0,0,0,.32);
}
.woocommerce table.shop_table { border-color: var(--dbw-outline-variant); border-radius: 10px; overflow: hidden; color: var(--dbw-on-surface); }
.woocommerce table.shop_table th { color: var(--dbw-primary); background: var(--dbw-surface-container-high); }
.woocommerce table.shop_table td { border-top-color: var(--dbw-outline-variant); }
.woocommerce table.shop_table a { color: var(--dbw-primary); }
.woocommerce-cart table.cart img { border-radius: 8px; width: 78px; }
.woocommerce-cart .cart-collaterals .cart_totals h2,
.woocommerce-billing-fields h3,
.woocommerce-shipping-fields h3,
.woocommerce-additional-fields h3,
#order_review_heading,
.woocommerce-account h2,
.woocommerce-order h2 { color: var(--dbw-primary); font-family: var(--dbw-font-heading); font-size: 30px; }
.woocommerce form.checkout_coupon,
.woocommerce form.login,
.woocommerce form.register { border-color: var(--dbw-outline-variant); background: var(--dbw-surface-container-low); border-radius: 12px; }
.woocommerce-info,
.woocommerce-message,
.woocommerce-error { background: var(--dbw-surface-container-high); border-top-color: var(--dbw-primary-fixed-dim); color: var(--dbw-on-surface); }
.woocommerce-message::before,
.woocommerce-info::before { color: var(--dbw-primary-fixed-dim); }
.woocommerce-error::before { color: var(--dbw-error); }
.woocommerce-error li { color: var(--dbw-on-error-container); }
.woocommerce-checkout #payment { background: var(--dbw-surface-container-low); border-radius: 12px; }
.woocommerce-checkout #payment div.payment_box { background: var(--dbw-surface-container-high); color: var(--dbw-on-surface); }
.woocommerce-checkout #payment div.payment_box::before { border-bottom-color: var(--dbw-surface-container-high); }
.select2-dropdown { background: var(--dbw-surface-container); color: var(--dbw-on-surface); border-color: var(--dbw-outline-variant); }
.select2-container--default .select2-selection--single .select2-selection__rendered { color: var(--dbw-on-surface); line-height: 22px; }
.select2-container--default .select2-results__option--highlighted[aria-selected] { background: var(--dbw-primary-fixed); color: var(--dbw-on-primary-fixed); }
.woocommerce-MyAccount-navigation ul { margin: 0; padding: 0; list-style: none; display: grid; gap: 8px; }
.woocommerce-MyAccount-navigation a { display: block; padding: 12px 14px; border: 1px solid var(--dbw-outline-variant); border-radius: 8px; color: var(--dbw-primary); }
.woocommerce-MyAccount-navigation .is-active a,
.woocommerce-MyAccount-navigation a:hover { background: var(--dbw-primary-fixed); color: var(--dbw-on-primary-fixed); }
.woocommerce .woocommerce-customer-details address { border-color: var(--dbw-outline-variant); color: var(--dbw-on-surface); }

.wp-block-button__link { background: var(--dbw-red); color: #fff; border-radius: 8px; }
.wp-block-separator { border-color: var(--dbw-outline-variant); }
.wp-caption-text, figcaption { color: var(--dbw-on-surface-variant); font-size: 14px; }
.alignwide { max-width: 1100px; }
.alignfull { margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); max-width: 100vw; width: 100vw; }

@media (min-width: 768px) {
  .dbw-container { padding-left: var(--dbw-desktop); padding-right: var(--dbw-desktop); }
}

@media (max-width: 980px) {
  .dbw-header-main { align-items: flex-start; }
  .dbw-menu-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 8px;
    border: 1px solid var(--dbw-outline-variant);
    color: var(--dbw-primary);
    background: var(--dbw-surface-container);
  }
  .dbw-nav-wrap { width: 100%; justify-content: space-between; }
  .dbw-primary-nav { display: none; width: 100%; }
  .dbw-primary-nav.is-open { display: block; }
  .dbw-menu { flex-direction: column; align-items: stretch; gap: 8px; padding-top: 16px; }
  .dbw-menu a { display: block; border: 1px solid var(--dbw-outline-variant); border-radius: 8px; padding: 12px 14px; }
  .dbw-grid, .dbw-app-card { grid-template-columns: 1fr; }
  .woocommerce ul.products { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .dbw-post-card { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  body.admin-bar .dbw-site-header { top: 0; }
  .dbw-front-main, .dbw-page { padding-top: 32px; padding-bottom: 56px; gap: 48px; }
  .dbw-header-top, .dbw-header-main { padding-left: 0; padding-right: 0; }
  .dbw-actions { width: 100%; justify-content: stretch; }
  .dbw-actions .dbw-btn, .dbw-actions .dbw-cart-link { flex: 1 1 auto; }
  .dbw-contact-grid { grid-template-columns: 1fr; }
  .dbw-section-head { align-items: flex-start; flex-direction: column; }
  .woocommerce ul.products { grid-template-columns: 1fr; }
  .woocommerce div.product { padding: 16px; }
  .dbw-content-card { padding: 22px; }
  .dbw-footer-inner { align-items: flex-start; }
  .dbw-copyright { text-align: left; }
}
