/*
Theme Name: DNB Vinyl
Theme URI: https://www.dnbvinyl.co.uk/
Author: DNB Vinyl
Description: A standalone WooCommerce theme for fast record digging, built around vinyl cards, record metadata, filters, and audio-preview focused browsing.
Version: 1.0.11
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: dnb-vinyl
*/

:root {
  --dnb-bg: #090d0b;
  --dnb-panel: #111812;
  --dnb-panel-2: #151c17;
  --dnb-line: #28322b;
  --dnb-text: #f4efe6;
  --dnb-muted: #c4baaa;
  --dnb-soft: #e6e0d2;
  --dnb-chip: #232c24;
  --dnb-green: #6faf82;
  --dnb-red: #d7453f;
  --dnb-gold: #d9b04a;
  --dnb-blue: #8ebcff;
  --dnb-radius: 8px;
  --dnb-shadow: 0 18px 45px rgba(0, 0, 0, 0.32);
  color-scheme: dark;
}

* {
  box-sizing: border-box;
}

html {
  background: var(--dnb-bg);
  font-size: 16px;
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.015), transparent 360px),
    var(--dnb-bg);
  color: var(--dnb-text);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.5;
}

a {
  color: inherit;
  text-decoration: none;
}

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

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

.screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.dnb-site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(9, 13, 11, 0.88);
  backdrop-filter: blur(16px);
}

.dnb-header-inner {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 24px;
  align-items: center;
  max-width: 1860px;
  margin: 0 auto;
  padding: 18px clamp(16px, 3vw, 42px);
}

.dnb-brand {
  display: inline-flex;
  gap: 12px;
  align-items: center;
  min-width: 0;
}

.dnb-brand-mark {
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #030504;
  box-shadow: inset 0 0 0 9px #060806, inset 0 0 0 13px var(--dnb-gold);
}

.dnb-brand-name {
  font-size: 0.9rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.dnb-nav {
  display: flex;
  justify-content: center;
  gap: 22px;
  color: var(--dnb-muted);
  font-weight: 700;
}

.dnb-nav a:hover,
.dnb-nav .current-menu-item > a {
  color: var(--dnb-text);
}

.dnb-header-actions {
  display: inline-flex;
  gap: 10px;
  align-items: center;
}

.dnb-cart-link,
.dnb-account-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  border: 1px solid var(--dnb-line);
  border-radius: var(--dnb-radius);
  background: var(--dnb-panel);
  color: var(--dnb-text);
  font-weight: 850;
  padding: 9px 12px;
}

.dnb-cart-count {
  display: inline-grid;
  place-items: center;
  min-width: 22px;
  height: 22px;
  margin-left: 8px;
  border-radius: 999px;
  background: var(--dnb-red);
  color: #fff;
  font-size: 0.78rem;
}

.dnb-main {
  min-height: 70vh;
}

.dnb-home {
  min-height: 100vh;
  background: #000;
  overflow-x: hidden;
}

.dnb-home-hero {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  isolation: isolate;
  min-height: calc(100vh - 76px);
  padding: clamp(24px, 4vw, 46px) clamp(16px, 4vw, 42px) 58px;
  overflow: hidden;
}

.dnb-home-hero::before {
  position: absolute;
  inset: 0;
  z-index: -2;
  content: "";
  background:
    linear-gradient(rgba(0, 0, 0, 0.38), rgba(0, 0, 0, 0.38)),
    var(--dnb-home-hero-image, linear-gradient(transparent, transparent)),
    radial-gradient(circle at 50% 38%, rgba(255, 255, 255, 0.22), transparent 11%),
    radial-gradient(circle at 50% 43%, rgba(111, 175, 130, 0.52), transparent 22%),
    radial-gradient(circle at 12% 48%, rgba(205, 124, 55, 0.65), transparent 18%),
    radial-gradient(circle at 88% 48%, rgba(205, 124, 55, 0.65), transparent 18%),
    repeating-radial-gradient(circle at 50% 44%, rgba(255, 255, 255, 0.18) 0 2px, transparent 2px 20px),
    linear-gradient(90deg, #111, #242826 18%, #020403 50%, #242826 82%, #111);
  background-position: center;
  background-size: cover;
  filter: saturate(1.05);
}

.dnb-home-hero::after {
  position: absolute;
  inset: 0;
  z-index: -1;
  content: "";
  background: rgba(0, 0, 0, 0.47);
  backdrop-filter: blur(3px);
}

.dnb-home-inner {
  width: min(1220px, 100%);
  margin-right: auto;
  margin-left: auto;
  text-align: center;
}

.dnb-home-search {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr) 54px;
  width: min(1220px, 100%);
  margin: 0 auto clamp(42px, 6vw, 62px);
  border-radius: 2px;
  overflow: hidden;
  box-shadow: 0 18px 50px rgba(0, 0, 0, 0.36);
}

.dnb-home-search select,
.dnb-home-search input {
  min-height: 52px;
  border: 0;
  background: #fff;
  color: #1f241f;
  border-radius: 0;
  padding: 0 14px;
}

.dnb-home-search select {
  border-right: 1px solid #d8d8d8;
  color: #505650;
  font-weight: 800;
}

.dnb-home-search button {
  display: grid;
  place-items: center;
  border: 0;
  background: #bb5d37;
  color: #fff;
  cursor: pointer;
  font-size: 1.6rem;
  font-weight: 950;
}

.dnb-home-intro {
  width: min(980px, 100%);
  margin: 0 auto 24px;
  text-align: center;
}

.dnb-home-intro h1 {
  margin: 0;
  color: #fff;
  font-size: clamp(2rem, 3.6vw, 3.4rem);
  font-weight: 950;
  line-height: 1.22;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-shadow: 0 4px 18px rgba(0, 0, 0, 0.82);
}

.dnb-home-cats {
  display: grid;
  grid-template-columns: repeat(4, minmax(150px, 1fr));
  gap: 24px;
  width: min(1220px, 100%);
  margin: 0 auto 24px;
  justify-content: center;
}

.dnb-home-cat {
  position: relative;
  display: grid;
  min-height: 190px;
  overflow: hidden;
  border-radius: 0;
  background:
    radial-gradient(circle at 55% 20%, rgba(255, 255, 255, 0.55), transparent 16%),
    linear-gradient(135deg, #1580a6, #111 58%, #c66a28);
  box-shadow: 0 22px 44px rgba(0, 0, 0, 0.36);
}

.dnb-home-cat img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.25s ease;
}

.dnb-home-cat:hover img {
  transform: scale(1.04);
}

.dnb-home-cat::after {
  position: absolute;
  inset: auto 0 0;
  height: 72px;
  content: "";
  background: rgba(0, 0, 0, 0.82);
}

.dnb-home-cat-fallback {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
}

.dnb-home-cat-fallback::before {
  width: 110px;
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle, #d8b14b 0 14%, #101211 15% 22%, #000 23% 72%, rgba(255, 255, 255, 0.05) 73%);
  content: "";
  box-shadow: 0 22px 42px rgba(0, 0, 0, 0.42);
}

.dnb-home-cat-text {
  position: relative;
  z-index: 1;
  align-self: end;
  padding: 0 14px 16px;
  text-align: center;
  text-transform: uppercase;
}

.dnb-home-cat-title {
  display: block;
  color: #fff;
  font-size: clamp(1rem, 1.4vw, 1.25rem);
  font-weight: 950;
  line-height: 1.05;
}

.dnb-home-cat-count {
  display: block;
  margin-top: 4px;
  color: #fff;
  font-size: 0.86rem;
  font-weight: 850;
}

.dnb-home-stock {
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(1220px, 100%);
  min-height: 52px;
  margin: 0 auto 56px;
  border-radius: var(--dnb-radius);
  background: #72b63f;
  color: #fff;
  font-size: 1.25rem;
  font-weight: 950;
  text-transform: uppercase;
}

.dnb-home-contact {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  width: min(1220px, 100%);
  margin: 0 auto;
  overflow: hidden;
  border-radius: var(--dnb-radius);
  background: #fff;
  color: #070a08;
}

.dnb-home-contact-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 28px;
  align-items: center;
  min-height: 220px;
  padding: clamp(28px, 4vw, 52px);
}

.dnb-home-contact-card + .dnb-home-contact-card {
  border-left: 1px solid #ddd;
}

.dnb-home-contact-icon {
  display: grid;
  place-items: center;
  width: 70px;
  height: 70px;
  color: #253041;
  font-size: 1.2rem;
  font-weight: 950;
  letter-spacing: 0.04em;
  border: 3px solid #253041;
  border-radius: 50%;
}

.dnb-home-contact-card h2 {
  margin: 0 0 10px;
  font-size: clamp(1.28rem, 2vw, 1.6rem);
  line-height: 1.15;
}

.dnb-home-contact-card p {
  margin: 0 0 24px;
  font-size: 1.08rem;
}

.dnb-home-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  border-radius: 999px;
  background: #72b63f;
  color: #fff;
  font-weight: 950;
  padding: 9px 22px;
}

.dnb-home-footerline {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  width: min(1220px, 100%);
  margin: 44px auto 0;
  color: #fff;
  font-weight: 850;
}

.home .dnb-page-shell,
.front-page .dnb-page-shell {
  max-width: 1220px;
  margin-right: auto;
  margin-left: auto;
  text-align: center;
}

.home .entry-content,
.front-page .entry-content {
  max-width: 1220px;
  margin-right: auto;
  margin-left: auto;
  text-align: center;
}

.home .entry-content > *,
.front-page .entry-content > * {
  margin-right: auto;
  margin-left: auto;
}

.home .wp-block-woocommerce-product-categories,
.home .wc-block-product-categories,
.home .products,
.front-page .wp-block-woocommerce-product-categories,
.front-page .wc-block-product-categories,
.front-page .products {
  display: grid;
  grid-template-columns: repeat(4, minmax(150px, 1fr));
  gap: 24px;
  width: min(1220px, 100%);
  margin-right: auto;
  margin-left: auto;
  padding-left: 0;
  list-style: none;
  text-align: center;
}

.home .wp-block-woocommerce-product-categories li,
.home .wc-block-product-categories li,
.home .products li,
.front-page .wp-block-woocommerce-product-categories li,
.front-page .wc-block-product-categories li,
.front-page .products li {
  float: none;
  width: auto;
  margin: 0;
}

.home .entry-content img,
.front-page .entry-content img {
  margin-right: auto;
  margin-left: auto;
}

.dnb-page-shell {
  max-width: 1860px;
  margin: 0 auto;
  padding: clamp(30px, 5vw, 70px) clamp(16px, 3vw, 42px) 64px;
}

.dnb-shop-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(300px, 0.9fr);
  gap: clamp(28px, 8vw, 140px);
  align-items: end;
  margin-bottom: 40px;
}

.dnb-kicker {
  margin: 0 0 10px;
  color: var(--dnb-muted);
  font-size: clamp(0.78rem, 1vw, 0.95rem);
  font-weight: 950;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.dnb-shop-hero h1,
.dnb-page-title {
  max-width: 900px;
  margin: 0;
  font-size: clamp(3.4rem, 7vw, 7.2rem);
  line-height: 0.95;
  font-weight: 950;
  letter-spacing: 0;
}

.dnb-shop-copy {
  max-width: 700px;
  margin: 0;
  color: var(--dnb-muted);
  font-size: clamp(1.05rem, 1.5vw, 1.42rem);
  line-height: 1.55;
}

.dnb-shop-layout {
  display: grid;
  grid-template-columns: 340px minmax(0, 1fr);
  gap: 32px;
  align-items: start;
}

.dnb-filter-panel {
  position: sticky;
  top: 92px;
  border: 1px solid var(--dnb-line);
  border-radius: var(--dnb-radius);
  background: var(--dnb-panel);
  padding: 24px;
}

.dnb-filter-field {
  margin-bottom: 22px;
}

.dnb-filter-field label,
.dnb-price-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
  color: var(--dnb-muted);
  font-size: 1rem;
  font-weight: 780;
}

.dnb-filter-field input[type="search"],
.dnb-filter-field select {
  width: 100%;
  min-height: 50px;
  border: 1px solid var(--dnb-line);
  border-radius: var(--dnb-radius);
  background: #0b100d;
  color: var(--dnb-text);
  padding: 0 14px;
  outline: none;
}

.dnb-filter-field input[type="search"]:focus,
.dnb-filter-field select:focus {
  border-color: var(--dnb-green);
  box-shadow: 0 0 0 3px rgba(111, 175, 130, 0.18);
}

.dnb-checkbox {
  display: inline-flex;
  gap: 12px;
  align-items: center;
  color: var(--dnb-muted);
  font-weight: 760;
}

.dnb-checkbox input {
  width: 22px;
  height: 22px;
  accent-color: var(--dnb-green);
}

.dnb-range {
  width: 100%;
  accent-color: var(--dnb-blue);
}

.dnb-filter-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.dnb-button,
.button,
.woocommerce button.button,
.woocommerce a.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  border: 0;
  border-radius: var(--dnb-radius);
  background: var(--dnb-red);
  color: #fff;
  cursor: pointer;
  font-weight: 950;
  line-height: 1.1;
  padding: 12px 18px;
  text-align: center;
}

.dnb-button:hover,
.button:hover,
.woocommerce button.button:hover,
.woocommerce a.button:hover,
.woocommerce input.button:hover {
  filter: brightness(1.07);
}

.dnb-button-secondary {
  background: var(--dnb-chip);
  color: var(--dnb-text);
}

.dnb-shop-main {
  min-width: 0;
}

.dnb-shop-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
  margin-bottom: 28px;
}

.dnb-result-count {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 850;
}

.dnb-sort-tabs {
  display: inline-flex;
  overflow: hidden;
  border: 1px solid var(--dnb-line);
  border-radius: var(--dnb-radius);
  background: var(--dnb-panel);
}

.dnb-sort-tabs a {
  display: inline-flex;
  align-items: center;
  min-height: 48px;
  border-right: 1px solid var(--dnb-line);
  color: var(--dnb-muted);
  font-weight: 850;
  padding: 0 18px;
}

.dnb-sort-tabs a:last-child {
  border-right: 0;
}

.dnb-sort-tabs a.is-active {
  background: var(--dnb-green);
  color: #031006;
}

.dnb-products-grid,
.woocommerce ul.products {
  display: grid;
  grid-template-columns: repeat(3, minmax(240px, 1fr));
  gap: 22px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.dnb-shop-pagination {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  align-items: center;
  justify-content: center;
  margin: 26px 0;
}

.dnb-shop-pagination-top {
  margin-top: 0;
}

.dnb-shop-pagination .page-numbers {
  display: inline-grid;
  place-items: center;
  min-width: 40px;
  height: 40px;
  border: 2px solid var(--dnb-line);
  border-radius: 999px;
  background: #0d120f;
  color: var(--dnb-text);
  font-weight: 950;
  line-height: 1;
  padding: 0 12px;
}

.dnb-shop-pagination .page-numbers.current {
  border-color: var(--dnb-green);
  background: var(--dnb-green);
  color: #061008;
}

.dnb-shop-pagination a.page-numbers:hover {
  border-color: var(--dnb-green);
}

.woocommerce ul.products::before,
.woocommerce ul.products::after {
  display: none;
}

.woocommerce ul.products li.product,
.dnb-product-card {
  float: none;
  width: auto;
  margin: 0;
}

.dnb-record-card {
  position: relative;
  overflow: hidden;
  min-height: 100%;
  border: 1px solid var(--dnb-line);
  border-radius: var(--dnb-radius);
  background: var(--dnb-panel);
  box-shadow: var(--dnb-shadow);
}

.dnb-record-visual {
  position: relative;
  display: grid;
  place-items: center;
  aspect-ratio: 1.14 / 1;
  overflow: hidden;
  background:
    radial-gradient(circle at 55% 48%, rgba(255, 255, 255, 0.2), transparent 8%),
    linear-gradient(135deg, #eee8d8, #cfcabd);
}

.dnb-record-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.dnb-record-fallback {
  position: relative;
  width: min(58%, 300px);
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle, var(--dnb-label, #68a87d) 0 13%, #101211 14% 21%, #000 22% 70%, rgba(255, 255, 255, 0.04) 71%, #000 74%);
  box-shadow: 0 30px 40px rgba(0, 0, 0, 0.28);
}

.dnb-record-grade,
.dnb-stock-pill {
  position: absolute;
  z-index: 2;
  border-radius: 999px;
  font-weight: 950;
  line-height: 1;
  white-space: nowrap;
}

.dnb-record-grade {
  top: 16px;
  left: 16px;
  background: #030605;
  color: var(--dnb-text);
  padding: 10px 13px;
}

.dnb-stock-pill {
  right: 16px;
  bottom: 16px;
  background: var(--dnb-gold);
  color: #060604;
  padding: 11px 14px;
  font-size: 0.9rem;
}

.dnb-record-info {
  padding: 20px;
}

.dnb-record-title {
  display: block;
  margin: 0 0 8px;
  color: var(--dnb-text);
  font-size: clamp(1.05rem, 1.1vw, 1.32rem);
  font-weight: 950;
  line-height: 1.18;
}

.dnb-meta-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}

.dnb-meta-chip {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  max-width: 100%;
  border-radius: 999px;
  background: var(--dnb-chip);
  color: var(--dnb-muted);
  font-weight: 760;
  line-height: 1.1;
  padding: 6px 12px;
}

.dnb-record-price,
.woocommerce ul.products li.product .price {
  display: block;
  margin: 0 0 16px;
  color: var(--dnb-text);
  font-size: 1.05rem;
  font-weight: 950;
}

.dnb-card-actions {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: stretch;
}

.dnb-play-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 54px;
  min-height: 50px;
  border-radius: var(--dnb-radius);
  background: var(--dnb-chip);
  color: var(--dnb-text);
  font-weight: 850;
  padding: 10px 12px;
}

.dnb-play-button.is-disabled {
  cursor: default;
  opacity: 0.85;
}

.dnb-add-to-cart .button,
.dnb-add-to-cart a.added_to_cart {
  width: 100%;
  min-height: 50px;
}

.dnb-add-to-cart .button.added {
  display: none;
}

.dnb-add-to-cart a.added_to_cart {
  justify-content: flex-start;
  width: auto;
  margin-top: 0;
  background: transparent;
  color: var(--dnb-text);
  font-size: 1rem;
  font-weight: 950;
  text-transform: uppercase;
  padding-right: 0;
  padding-left: 0;
}

.dnb-add-to-cart a.added_to_cart:hover {
  color: var(--dnb-green);
}

.woocommerce-notices-wrapper {
  margin: 0 0 20px;
}

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  border: 1px solid var(--dnb-line);
  border-radius: var(--dnb-radius);
  background: var(--dnb-panel);
  color: var(--dnb-text);
  padding: 16px 18px;
}

.woocommerce-error {
  border-color: rgba(215, 69, 63, 0.55);
}

.dnb-content,
.entry-content,
.woocommerce-cart,
.woocommerce-checkout,
.woocommerce-account {
  max-width: 1180px;
  margin: 0 auto;
}

.dnb-content a,
.entry-content a {
  color: var(--dnb-green);
  font-weight: 800;
}

.dnb-site-footer {
  position: relative;
  background: #000;
  color: #fff;
}

.dnb-maintenance-page {
  display: grid;
  place-items: center;
  min-height: 100vh;
  padding: 28px;
  background:
    radial-gradient(circle at 50% 30%, rgba(217, 176, 74, 0.12), transparent 34%),
    var(--dnb-bg);
}

.dnb-maintenance-card {
  width: min(680px, 100%);
  border: 1px solid var(--dnb-line);
  border-radius: var(--dnb-radius);
  background: var(--dnb-panel);
  box-shadow: var(--dnb-shadow);
  padding: clamp(28px, 5vw, 54px);
  text-align: center;
}

.dnb-maintenance-logo {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  max-width: min(360px, 90%);
  margin: 0 auto 26px;
}

.dnb-maintenance-logo img {
  width: auto;
  max-width: 100%;
  max-height: 110px;
  object-fit: contain;
}

.dnb-maintenance-wordmark {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: var(--dnb-text);
  font-size: 1.1rem;
  font-weight: 950;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.dnb-maintenance-card h1 {
  margin: 0 0 14px;
  font-size: clamp(2.4rem, 8vw, 5rem);
  line-height: 0.98;
}

.dnb-maintenance-card p {
  margin: 0 auto;
  max-width: 520px;
  color: var(--dnb-muted);
  font-size: 1.1rem;
}

.dnb-footer-contact {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  width: min(1220px, calc(100% - 32px));
  margin: -40px auto 0;
  overflow: hidden;
  border-radius: var(--dnb-radius);
  background: #fff;
  color: #070a08;
  box-shadow: 0 10px 32px rgba(0, 0, 0, 0.3);
}

.dnb-footer-contact-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 28px;
  align-items: center;
  min-height: 210px;
  padding: clamp(28px, 4vw, 52px);
}

.dnb-footer-contact-card + .dnb-footer-contact-card {
  border-left: 1px solid #ddd;
}

.dnb-footer-contact-icon {
  display: grid;
  place-items: center;
  width: 76px;
  height: 76px;
  border: 4px solid #253041;
  border-radius: 12px;
  color: #253041;
  font-size: 1.35rem;
  font-weight: 950;
}

.dnb-footer-contact-card h2 {
  margin: 0 0 10px;
  font-size: clamp(1.35rem, 2vw, 1.7rem);
  line-height: 1.15;
}

.dnb-footer-contact-card p {
  margin: 0 0 24px;
  font-size: 1.08rem;
}

.dnb-footer-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  border-radius: 999px;
  background: #72b63f;
  color: #fff;
  font-weight: 950;
  padding: 9px 22px;
  text-transform: uppercase;
}

.dnb-footer-main {
  padding: 44px 0 66px;
  background: #000;
}

.dnb-footer-inner {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) auto minmax(180px, 1fr);
  gap: 24px;
  align-items: center;
  max-width: 1220px;
  margin: 0 auto;
  padding: 0 16px;
  color: #fff;
}

.dnb-footer-note {
  margin: 0;
  color: #fff;
  font-size: 1.08rem;
  font-weight: 850;
}

.dnb-footer-inner strong {
  color: var(--dnb-text);
}

.dnb-footer-nav,
.dnb-footer-social {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  align-items: center;
  justify-content: center;
  color: var(--dnb-text);
  font-size: 0.95rem;
  font-weight: 950;
  text-transform: uppercase;
}

.dnb-footer-social {
  justify-content: flex-end;
  gap: 10px;
}

.dnb-footer-social a {
  display: inline-grid;
  place-items: center;
  min-width: 26px;
  height: 26px;
  color: var(--dnb-text);
  font-size: 0.95rem;
  font-weight: 950;
}

.dnb-site-footer ul,
.dnb-site-footer ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

.dnb-footer-utility {
  background: #505050;
  color: #d9d9d9;
}

.dnb-footer-utility-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 24px;
  align-items: center;
  max-width: 1220px;
  margin: 0 auto;
  padding: 22px 16px;
}

.dnb-footer-utility-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  margin-bottom: 10px;
  font-size: 0.9rem;
  font-weight: 850;
  text-transform: uppercase;
}

.dnb-footer-copy {
  margin: 0;
  color: #fff;
  font-weight: 850;
}

.dnb-footer-payments {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.dnb-footer-payments span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  border-radius: 5px;
  background: rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.82rem;
  font-weight: 900;
  padding: 6px 12px;
}

table,
.shop_table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid var(--dnb-line);
  background: var(--dnb-panel);
}

th,
td {
  border-bottom: 1px solid var(--dnb-line);
  padding: 14px;
  text-align: left;
}

input.input-text,
textarea,
select {
  border: 1px solid var(--dnb-line);
  border-radius: var(--dnb-radius);
  background: #0b100d;
  color: var(--dnb-text);
  padding: 12px 14px;
}

@media (max-width: 1280px) {
  .dnb-products-grid,
  .woocommerce ul.products {
    grid-template-columns: repeat(2, minmax(220px, 1fr));
  }

  .dnb-home-cats {
    gap: 16px;
  }
}

@media (max-width: 900px) {
  .dnb-header-inner {
    grid-template-columns: 1fr auto;
  }

  .dnb-nav {
    display: none;
  }

  .dnb-shop-hero,
  .dnb-shop-layout {
    grid-template-columns: 1fr;
  }

  .dnb-filter-panel {
    position: static;
  }

  .dnb-shop-toolbar {
    align-items: flex-start;
    flex-direction: column;
  }

  .dnb-home-cats,
  .dnb-home-contact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dnb-footer-contact,
  .dnb-footer-utility-inner {
    grid-template-columns: 1fr;
  }

  .dnb-footer-contact-card + .dnb-footer-contact-card {
    border-left: 0;
    border-top: 1px solid #ddd;
  }

  .dnb-footer-payments {
    justify-content: flex-start;
  }

  .dnb-home-contact-card + .dnb-home-contact-card {
    border-left: 0;
    border-top: 1px solid #ddd;
  }

  .dnb-home-contact-card {
    grid-column: 1 / -1;
  }
}

@media (max-width: 640px) {
  .dnb-page-shell {
    padding: 22px 12px 42px;
  }

  .dnb-shop-hero {
    margin-bottom: 26px;
  }

  .dnb-shop-hero h1,
  .dnb-page-title {
    font-size: clamp(3.1rem, 17vw, 4.8rem);
  }

  .dnb-shop-copy {
    display: none;
  }

  .dnb-products-grid,
  .woocommerce ul.products {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .dnb-record-visual {
    aspect-ratio: 1 / 0.86;
  }

  .dnb-record-fallback {
    width: 58%;
  }

  .dnb-record-info {
    padding: 22px;
  }

  .dnb-sort-tabs {
    width: 100%;
  }

  .dnb-sort-tabs a {
    flex: 1 1 0;
    justify-content: center;
    padding: 0 10px;
  }

  .dnb-filter-actions,
  .dnb-card-actions {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .dnb-home-hero {
    min-height: 0;
    padding: 18px 12px 42px;
  }

  .dnb-home-search {
    grid-template-columns: 64px minmax(0, 1fr) 50px;
    margin-bottom: 34px;
  }

  .dnb-home-intro h1 {
    font-size: clamp(1.8rem, 8vw, 2.6rem);
  }

  .dnb-home-cats,
  .dnb-home-contact {
    grid-template-columns: 1fr;
  }

  .dnb-home-cat {
    min-height: 205px;
  }

  .dnb-home-stock {
    margin-bottom: 28px;
    font-size: 1rem;
  }

  .dnb-home-contact-card {
    grid-template-columns: 1fr;
    gap: 14px;
    text-align: center;
  }

  .dnb-footer-contact {
    width: calc(100% - 24px);
    margin-top: -24px;
  }

  .dnb-footer-contact-card {
    grid-template-columns: 1fr;
    gap: 14px;
    min-height: 0;
    text-align: center;
  }

  .dnb-footer-contact-icon {
    margin: 0 auto;
  }

  .dnb-home-contact-icon {
    margin: 0 auto;
  }

  .dnb-home-footerline {
    flex-direction: column;
    text-align: center;
  }

  .dnb-footer-inner {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
  }

  .dnb-footer-social {
    justify-content: center;
  }

  .dnb-footer-utility-nav,
  .dnb-footer-payments {
    justify-content: center;
  }
}
