:root {
  /* Brand Colors */
  --color-background: #FFF7E9;
  --color-background-alt: #F3E9D7;
  --color-green-primary: #3F6B3A;
  --color-green-dark: #435239;
  --color-wine-red: #7A1F2B;
  --color-wine-highlight: #9B2C3A;
  --color-wood: #B0895A;
  --color-brass: #8A6A2F;
  --color-gold-primary: #C6A64B;
  --color-gold-dark: #9E7C2F;
  /* Semantic Colors */
  --color-primary: #7A1F2B;
  --color-secondary: #3F6B3A;
  --color-accent: #C6A64B;
  --color-text: #2A2420;
  --color-text-light: #5A524D;
  --color-text-muted: #7A706A;
  --color-border: #E8D8C0;
  --color-surface: #FFFFFF;
  /* Button Colors */
  --color-button-text: #2A2420;
  --color-button-bg: transparent;
  --color-button-border: rgba(42, 36, 32, 0.45);
  /* Typography */
  --font-primary: 'EB Garamond', Georgia, serif;
  --font-secondary: 'EB Garamond', Georgia, serif;
  --font-heading: 'EB Garamond', Georgia, serif;
  --font-body: 'EB Garamond', Georgia, serif;
  --font-size-base: 1rem;
  --font-size-small: 0.875rem;
  --font-size-large: 1.125rem;
  --font-size-xl: 1.25rem;
  --font-size-2xl: 1.5rem;
  --font-size-3xl: 2rem;
  --font-size-4xl: 2.5rem;
  --line-height-base: 1.6;
  --line-height-tight: 1.2;
  /* Spacing */
  --spacing-xs: 0.25rem;
  --spacing-sm: 0.5rem;
  --spacing-md: 1rem;
  --spacing-lg: 2rem;
  --spacing-xl: 3rem;
  --spacing-2xl: 4.5rem;
  /* Layout */
  --container-max-width: 1600px;
  --content-max-width: 1100px;
  --sidebar-width: 300px;
  --border-radius: 0;
  --border-radius-lg: 0;
  --box-shadow: 0 1px 4px rgba(42, 36, 32, 0.05);
  --box-shadow-lg: 0 2px 12px rgba(42, 36, 32, 0.08);
  --transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  /* Wine-Specific */
  --color-wine-type-red: #7A1F2B;
  --color-wine-type-white: #F4E8D0;
  --color-wine-type-rose: #E8B4B8;
  --color-wine-type-sparkling: #C6A64B;
  --wine-card-width: 235px;
  --producer-card-width: 320px;
  --social-color: var(--color-green-dark);
  --social-color-hover: var(--color-gold-primary);
  --header-height: 70px;
  --header-height-mobile: 60px;
  --header-logo-height: 44px;
  --header-logo-height-mobile: 30px;
  --header-padding-v: 0;
  --header-padding-h: var(--spacing-lg);
  --header-z-index: 1000;
  --header-transition: background-color 0.3s ease, box-shadow 0.3s ease, color 0.3s ease;
  --header-solid-bg: #FFF7E9;
  --header-solid-color: #2A2420;
  --header-solid-border: #E8D8C0;
  --header-solid-shadow: 0 2px 8px rgba(42, 36, 32, 0.1);
  --header-overlay-bg: transparent;
  --header-overlay-color: #ffffff;
  --header-revealed-solid-bg: #FFF7E9;
  --header-revealed-solid-color: #2A2420;
  --header-revealed-solid-shadow: 0 2px 12px rgba(42, 36, 32, 0.15);
  --header-revealed-glass-bg: rgba(42, 36, 32, 0.7);
  --header-revealed-glass-blur: 12px;
  --header-revealed-glass-color: #ffffff;
  --header-mobile-menu-bg: #7A1F2B;
  --header-mobile-menu-color: #ffffff;
  --header-mobile-menu-shadow: -4px 0 24px rgba(42, 36, 32, 0.3);
  --header-nav-font-size: 1rem;
  --header-nav-font-weight: 500;
  --header-nav-letter-spacing: 0.08em;
  --header-nav-gap: var(--spacing-lg);
}
.site-footer {
  --footer-colophon-bg: var(--color-primary);
  --footer-colophon-text: var(--color-surface, #ffffff);
  --footer-link-hover: #a18433;
}
body.footer-dark .site-footer {
  --footer-bg: #1E1A17;
  --footer-border: rgba(255, 255, 255, 0.1);
  --footer-text: #E8DFD0;
  --footer-text-muted: #B0A090;
  --footer-link: #E8DFD0;
  --footer-link-hover: #C6A64B;
  --footer-title: #F3E9D7;
  --footer-divider: rgba(255, 255, 255, 0.12);
  --footer-logo-opacity: 0.9;
  --footer-colophon-bg: #161310;
  --footer-colophon-text: #7A706A;
}
body.header-style-overlay {
  --header-logo-height: 20px;
}
body.header-style-solid {
  --header-logo-height: 25px;
}
html {
  font-size: 112.5%;
}
@media (max-width: 640px) {
  html {
    font-size: 125%;
  }
}
body {
  font-family: var(--font-primary);
  font-size: 1.25rem;
  line-height: var(--line-height-base);
  color: var(--color-text);
  background-color: var(--color-background);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--font-primary);
  line-height: var(--line-height-tight);
  color: var(--color-text);
  margin-top: 0;
  margin-bottom: var(--spacing-md);
  font-weight: 600;
  letter-spacing: -0.01em;
}
h1 {
  font-size: clamp(2.5rem, 5vw, 4rem);
}
h2 {
  font-size: clamp(2rem, 4vw, 3rem);
}
h3 {
  font-size: clamp(1.5rem, 3vw, 2rem);
}
h4 {
  font-size: var(--font-size-xl);
}
h5 {
  font-size: var(--font-size-large);
}
h6 {
  font-size: var(--font-size-small);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-text-muted);
}
h1,
h2,
h3 {
  text-align: center;
}
:is(h1, h2, h3):is(.page-title, .entry-title, .wp-block-post-title) {
  margin-bottom: var(--spacing-md);
}
.wine-card h1,
.producer-card h1,
.ds-producer-card__info h1,
.producer-connect h1,
.story__text h1,
.producer-intro h1,
.producer-highlights h1,
.wine-card__expand-inner h1,
.producer-hero__identity h1,
.site-footer h1,
.widget h1,
.wine-card h2,
.producer-card h2,
.ds-producer-card__info h2,
.producer-connect h2,
.story__text h2,
.producer-intro h2,
.producer-highlights h2,
.wine-card__expand-inner h2,
.producer-hero__identity h2,
.site-footer h2,
.widget h2,
.wine-card h3,
.producer-card h3,
.ds-producer-card__info h3,
.producer-connect h3,
.story__text h3,
.producer-intro h3,
.producer-highlights h3,
.wine-card__expand-inner h3,
.producer-hero__identity h3,
.site-footer h3,
.widget h3,
.wine-card h4,
.producer-card h4,
.ds-producer-card__info h4,
.producer-connect h4,
.story__text h4,
.producer-intro h4,
.producer-highlights h4,
.wine-card__expand-inner h4,
.producer-hero__identity h4,
.site-footer h4,
.widget h4,
.wine-card h5,
.producer-card h5,
.ds-producer-card__info h5,
.producer-connect h5,
.story__text h5,
.producer-intro h5,
.producer-highlights h5,
.wine-card__expand-inner h5,
.producer-hero__identity h5,
.site-footer h5,
.widget h5,
.wine-card h6,
.producer-card h6,
.ds-producer-card__info h6,
.producer-connect h6,
.story__text h6,
.producer-intro h6,
.producer-highlights h6,
.wine-card__expand-inner h6,
.producer-hero__identity h6,
.site-footer h6,
.widget h6 {
  text-align: left;
}
p {
  margin-top: 0;
  margin-bottom: var(--spacing-md);
  line-height: var(--line-height-base);
}
.lead,
.intro-text {
  font-family: var(--font-primary);
  line-height: 1.5;
}
a {
  color: var(--color-wine-red);
  text-decoration: none;
  transition: var(--transition);
}
a:hover {
  color: var(--color-wine-highlight);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.display-text {
  font-family: var(--font-primary);
  font-style: italic;
  font-size: clamp(1.75rem, 4vw, 3rem);
  line-height: 1.3;
  font-weight: 400;
}
.pull-quote {
  font-family: var(--font-primary);
  font-style: italic;
  font-size: clamp(1.25rem, 2.5vw, 1.75rem);
  line-height: 1.4;
  color: var(--color-wine-red);
  font-weight: 400;
}
.section-label {
  font-family: var(--font-primary);
  font-size: var(--font-size-small);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--color-text-muted);
  display: block;
  margin-bottom: var(--spacing-xs);
}
ul,
ol {
  margin-bottom: var(--spacing-md);
  padding-left: var(--spacing-lg);
}
li {
  margin-bottom: var(--spacing-xs);
}
.list-highlights {
  list-style: none;
  padding-left: 0;
}
.list-highlights li {
  padding-left: var(--spacing-lg);
  position: relative;
  margin-bottom: var(--spacing-sm);
}
.list-highlights li::before {
  content: '\27BA';
  position: absolute;
  left: 0;
  color: var(--color-gold-primary);
  font-family: var(--font-primary);
}
strong,
b {
  font-weight: 700;
  color: var(--color-wine-red);
}
h1 strong,
h2 strong,
h3 strong,
h4 strong,
h5 strong,
h6 strong,
h1 b,
h2 b,
h3 b,
h4 b,
h5 b,
h6 b {
  color: inherit;
  font-weight: inherit;
}
em,
i {
  font-style: italic;
}
blockquote {
  margin: var(--spacing-xl) 0;
  padding: var(--spacing-lg);
  border-left: 3px solid var(--color-gold-primary);
  background: var(--color-background-alt);
}
blockquote p {
  font-family: var(--font-primary);
  font-style: italic;
  font-size: var(--font-size-xl);
  margin: 0;
}
.location-text {
  font-family: var(--font-primary);
  font-size: var(--font-size-large);
  font-weight: 400;
  color: var(--color-text-light);
  letter-spacing: 0.02em;
}
.wine-name {
  font-family: var(--font-primary);
  font-size: var(--font-size-large);
  font-weight: 600;
}
.wine-vintage {
  font-family: var(--font-primary);
  font-size: var(--font-size-small);
  font-weight: 700;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.text-on-dark {
  color: #FFFFFF;
}
.text-on-dark h1,
.text-on-dark h2,
.text-on-dark h3,
.text-on-dark h4 {
  color: #FFFFFF;
}
.text-on-dark p {
  color: rgba(255, 255, 255, 0.9);
}
.text-on-dark .location-text {
  color: rgba(255, 255, 255, 0.75);
}
.container {
  max-width: var(--container-max-width);
  margin: 0 auto;
  padding: 0 var(--spacing-md);
}
@media (max-width: 768px) {
  .container {
    padding: 0 var(--spacing-sm);
  }
}
.container--narrow {
  max-width: var(--content-max-width);
}
.grid {
  display: grid;
  gap: var(--spacing-lg);
}
.grid--2-col {
  grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 768px) {
  .grid--2-col {
    grid-template-columns: 1fr;
  }
}
.grid--3-col {
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 1024px) {
  .grid--3-col {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 640px) {
  .grid--3-col {
    grid-template-columns: 1fr;
  }
}
.grid--auto-fill {
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}
.flex {
  display: flex;
  gap: var(--spacing-md);
}
.flex--center {
  justify-content: center;
  align-items: center;
}
.flex--between {
  justify-content: space-between;
  align-items: center;
}
.flex--column {
  flex-direction: column;
}
.flex--wrap {
  flex-wrap: wrap;
}
.mt-0 {
  margin-top: 0;
}
.mt-sm {
  margin-top: var(--spacing-sm);
}
.mt-md {
  margin-top: var(--spacing-md);
}
.mt-lg {
  margin-top: var(--spacing-lg);
}
.mt-xl {
  margin-top: var(--spacing-xl);
}
.mb-0 {
  margin-bottom: 0;
}
.mb-sm {
  margin-bottom: var(--spacing-sm);
}
.mb-md {
  margin-bottom: var(--spacing-md);
}
.mb-lg {
  margin-bottom: var(--spacing-lg);
}
.mb-xl {
  margin-bottom: var(--spacing-xl);
}
.p-sm {
  padding: var(--spacing-sm);
}
.p-md {
  padding: var(--spacing-md);
}
.p-lg {
  padding: var(--spacing-lg);
}
.p-xl {
  padding: var(--spacing-xl);
}
@media (max-width: 768px) {
  .hide-mobile {
    display: none;
  }
}
@media (min-width: 769px) {
  .hide-desktop {
    display: none;
  }
}
.section:not(.fullwidth) {
  padding-left: max(var(--spacing-xl), calc((100% - var(--container-max-width)) / 2));
  padding-right: max(var(--spacing-xl), calc((100% - var(--container-max-width)) / 2));
}
@media (max-width: 640px) {
  .section:not(.fullwidth) {
    padding-left: var(--spacing-lg);
    padding-right: var(--spacing-lg);
  }
}
.section.section--narrow {
  padding-left: max(var(--spacing-xl), calc((100% - var(--content-max-width)) / 2));
  padding-right: max(var(--spacing-xl), calc((100% - var(--content-max-width)) / 2));
}
@media (max-width: 640px) {
  .section.section--narrow {
    padding-left: var(--spacing-lg);
    padding-right: var(--spacing-lg);
  }
}
.front-page-content > .wp-block-group:not(.fullwidth) {
  padding-left: max(var(--spacing-xl), calc((100% - var(--container-max-width)) / 2));
  padding-right: max(var(--spacing-xl), calc((100% - var(--container-max-width)) / 2));
}
@media (max-width: 640px) {
  .front-page-content > .wp-block-group:not(.fullwidth) {
    padding-left: var(--spacing-lg);
    padding-right: var(--spacing-lg);
  }
}
.front-page-content > .wp-block-group.section--narrow {
  padding-left: max(var(--spacing-xl), calc((100% - var(--content-max-width)) / 2));
  padding-right: max(var(--spacing-xl), calc((100% - var(--content-max-width)) / 2));
}
@media (max-width: 640px) {
  .front-page-content > .wp-block-group.section--narrow {
    padding-left: var(--spacing-lg);
    padding-right: var(--spacing-lg);
  }
}
.button,
.btn,
.wp-block-button__link {
  color: var(--color-button-text);
  background-color: var(--color-button-bg);
  border: 1px solid var(--color-button-border);
  border-radius: 0;
  box-shadow: none;
  padding: 0.65em 2.5em;
  font-size: 1rem;
  font-weight: 400;
  font-family: var(--font-primary);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
  text-align: center;
  display: inline-block;
  cursor: pointer;
  transition: var(--transition);
}
.button:hover,
.btn:hover,
.wp-block-button__link:hover {
  color: var(--color-wine-red);
  border-color: var(--color-wine-red);
  background-color: transparent;
  text-decoration: none;
  transform: none;
}
.button:active,
.btn:active,
.wp-block-button__link:active {
  transform: none;
}
.button--primary {
  color: var(--color-background);
  background-color: var(--color-wine-red);
  border-color: var(--color-wine-red);
}
.button--primary:hover {
  color: var(--color-wine-red);
  background-color: transparent;
  border-color: var(--color-wine-red);
}
.button--accent {
  color: var(--color-text);
  background-color: transparent;
  border-color: var(--color-gold-primary);
}
.button--accent:hover {
  color: var(--color-gold-dark);
  border-color: var(--color-gold-dark);
}
.button--ghost-light {
  color: rgba(255, 255, 255, 0.85);
  background-color: transparent;
  border-color: rgba(255, 255, 255, 0.5);
}
.button--ghost-light:hover {
  color: #fff;
  background-color: transparent;
  border-color: #fff;
}
.card {
  background: var(--color-surface);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--box-shadow);
  padding: var(--spacing-lg);
  transition: var(--transition);
}
.card:hover {
  box-shadow: var(--box-shadow-lg);
  transform: translateY(-2px);
}
.card__title {
  margin-top: 0;
  margin-bottom: var(--spacing-sm);
  font-size: var(--font-size-xl);
  color: var(--color-wine-red);
}
.card__content {
  color: var(--color-text);
}
.card__footer {
  margin-top: var(--spacing-md);
  padding-top: var(--spacing-md);
  border-top: 1px solid var(--color-border);
}
input[type="search"]:focus,
input[type="search"]:focus-visible {
  outline: none;
  box-shadow: none;
}
::selection {
  background: #e3d3a5;
  color: var(--color-text);
}
::-webkit-search-cancel-button {
  -webkit-appearance: none;
  appearance: none;
  width: 14px;
  height: 14px;
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath fill='%237A1F2B' d='M4.293 4.293a1 1 0 0 1 1.414 0L10 8.586l4.293-4.293a1 1 0 1 1 1.414 1.414L11.414 10l4.293 4.293a1 1 0 0 1-1.414 1.414L10 11.414l-4.293 4.293a1 1 0 0 1-1.414-1.414L8.586 10 4.293 5.707a1 1 0 0 1 0-1.414z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
input[type="text"],
input[type="email"],
input[type="url"],
input[type="search"],
input[type="tel"],
input[type="number"],
input[type="password"],
textarea {
  width: 100%;
  padding: var(--spacing-sm) 0;
  border: none;
  border-bottom: 1px solid var(--color-border);
  border-radius: 0;
  background: transparent;
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  color: var(--color-text);
  transition: border-color 0.2s ease;
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="search"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
input[type="password"]:focus,
textarea:focus,
input[type="text"]:focus-visible,
input[type="email"]:focus-visible,
input[type="url"]:focus-visible,
input[type="search"]:focus-visible,
input[type="tel"]:focus-visible,
input[type="number"]:focus-visible,
input[type="password"]:focus-visible,
textarea:focus-visible {
  outline: none;
  box-shadow: none;
}
input[type="text"]::placeholder,
input[type="email"]::placeholder,
input[type="url"]::placeholder,
input[type="search"]::placeholder,
input[type="tel"]::placeholder,
input[type="number"]::placeholder,
input[type="password"]::placeholder,
textarea::placeholder {
  color: var(--color-text-muted);
  font-style: italic;
}
textarea {
  resize: vertical;
  min-height: 120px;
  padding-top: var(--spacing-sm);
}
button,
input[type="submit"],
input[type="button"],
input[type="reset"] {
  color: var(--color-button-text);
  background-color: var(--color-button-bg);
  border: 1px solid var(--color-button-border);
  border-radius: 0;
  box-shadow: none;
  padding: 0.65em 2.5em;
  font-size: 1rem;
  font-weight: 400;
  font-family: var(--font-primary);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: var(--transition);
}
button:hover,
input[type="submit"]:hover,
input[type="button"]:hover,
input[type="reset"]:hover {
  color: var(--color-wine-red);
  border-color: var(--color-wine-red);
  background-color: transparent;
  text-decoration: none;
}
button:focus-visible,
input[type="submit"]:focus-visible,
input[type="button"]:focus-visible,
input[type="reset"]:focus-visible {
  outline: 2px solid var(--color-wine-red);
  outline-offset: 2px;
}
.form-group {
  margin-bottom: var(--spacing-md);
}
.form-label {
  display: block;
  margin-bottom: var(--spacing-xs);
  font-weight: 600;
  color: var(--color-text);
}
.form-input,
.form-select,
.form-textarea {
  width: 100%;
  padding: var(--spacing-sm) 0;
  border: none;
  border-bottom: 1px solid var(--color-border);
  border-radius: 0;
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  color: var(--color-text);
  background: transparent;
  transition: var(--transition);
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline: none;
  border-color: var(--color-wine-red);
  box-shadow: none;
}
.form-textarea {
  resize: vertical;
  min-height: 120px;
}
.main-navigation a {
  border-bottom: none !important;
  color: var(--color-text);
  font-weight: 500;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: var(--spacing-sm) var(--spacing-md);
}
.main-navigation a:hover,
.main-navigation a.current-menu-item {
  color: var(--color-wine-red);
  border-bottom: none !important;
  text-decoration: none;
}
.badge {
  display: inline-block;
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--border-radius);
  font-size: var(--font-size-small);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.badge--primary {
  background: var(--color-wine-red);
  color: var(--color-background);
}
.badge--secondary {
  background: var(--color-green-primary);
  color: var(--color-background);
}
.badge--accent {
  background: var(--color-accent);
  color: var(--color-text);
}
#page {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
.site-main {
  flex: 1;
  padding-bottom: var(--spacing-2xl);
}
.single-dswg_wine .site-main,
.tax-dswg_country .site-main,
.post-type-archive-dswg_producer .site-main {
  padding-top: 0;
}
.single-dswg_producer .site-main {
  padding-top: 0;
  padding-bottom: 0;
}
.page-template-default .site-main {
  padding-top: var(--spacing-lg);
}
.overlay-card {
  position: relative;
  overflow: hidden;
  border-radius: var(--border-radius);
  cursor: pointer;
}
.overlay-card__image {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  display: block;
  transition: transform 0.6s ease;
}
.overlay-card:hover .overlay-card__image {
  transform: scale(1.05);
}
.overlay-card__glass {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.1) 0%, rgba(0, 0, 0, 0.2) 40%, rgba(0, 0, 0, 0.65) 100%);
  transition: var(--transition);
}
.overlay-card:hover .overlay-card__glass {
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.15) 0%, rgba(0, 0, 0, 0.3) 40%, rgba(0, 0, 0, 0.75) 100%);
}
.overlay-card__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--spacing-md);
  color: #FFFFFF;
}
.overlay-card__logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -60%);
  max-width: 70%;
  max-height: 45%;
  object-fit: contain;
  filter: brightness(0) invert(1);
  opacity: 0.92;
  transition: var(--transition);
}
.overlay-card:hover .overlay-card__logo {
  opacity: 1;
}
.overlay-card__country {
  font-family: var(--font-primary);
  font-size: var(--font-size-small);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(255, 255, 255, 0.8);
  display: block;
  margin-bottom: 4px;
}
.overlay-card__name {
  font-family: var(--font-primary);
  font-size: var(--font-size-xl);
  font-weight: 600;
  color: #FFFFFF;
  margin: 0;
  line-height: 1.2;
}
.hero {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.hero__image {
  width: 100%;
  height: 85vh;
  min-height: 500px;
  object-fit: cover;
  object-position: center;
  display: block;
}
.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.25) 0%, rgba(0, 0, 0, 0.35) 60%, rgba(0, 0, 0, 0.55) 100%);
}
.hero__content {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--spacing-xl);
  color: #FFFFFF;
}
.hero__logo {
  max-width: 220px;
  margin-bottom: var(--spacing-lg);
}
.hero--fullbleed .hero__logo {
  filter: brightness(0) invert(1);
  max-width: 50vw;
  max-height: 30vh;
}
.hero__tagline {
  font-family: var(--font-primary);
  font-style: italic;
  font-size: clamp(1.5rem, 3.5vw, 2.5rem);
  font-weight: 400;
  color: #FFFFFF;
  max-width: 768px;
  line-height: 1.35;
  margin: 0;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
}
.producer-hero {
  position: relative;
  width: 100%;
  height: 60vh;
  min-height: 400px;
  overflow: hidden;
}
.producer-hero__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.producer-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.2) 0%, rgba(0, 0, 0, 0.5) 100%);
}
.producer-hero__logo-wrap {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-md);
}
.producer-hero__logo {
  display: block;
  width: 280px;
  height: auto;
  max-height: 200px;
  object-fit: contain;
  filter: brightness(0) invert(1);
  opacity: 0.95;
}
.producer-hero .producer-coming-soon {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-3xl);
  font-weight: 400;
  font-style: italic;
  text-transform: none;
  letter-spacing: 0;
  color: rgba(255, 255, 255, 0.9);
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.4);
}
.producer-hero__logo-text {
  width: 280px;
  font-family: var(--font-primary);
  font-size: clamp(1.25rem, 3vw, 2rem);
  font-weight: 400;
  color: rgba(255, 255, 255, 0.92);
  text-align: center;
  line-height: 1.25;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-shadow: 0 1px 6px rgba(0, 0, 0, 0.4);
  word-break: break-word;
}
.producer-hero--no-image {
  background-color: var(--color-wine-red);
}
.producer-hero--no-image .producer-hero__overlay {
  display: none;
}
.producer-hero__identity {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--spacing-md) var(--spacing-xl);
  background: rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(10px) saturate(180%);
  -webkit-backdrop-filter: blur(10px) saturate(180%);
  border: 0;
  border-radius: 0;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: var(--spacing-xl);
}
@media (max-width: 768px) {
  .producer-hero__identity {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-md);
  }
}
.producer-hero__identity-left {
  flex: 1;
  text-align: left;
}
.producer-hero__name {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 4vw, 3.5rem);
  font-weight: 700;
  color: #FFFFFF;
  margin: 0 0 var(--spacing-xs) 0;
  line-height: 1.1;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
}
.producer-hero__location {
  font-family: var(--font-primary);
  font-size: clamp(1rem, 2vw, 1.25rem);
  font-weight: 400;
  color: rgba(255, 255, 255, 0.95);
  letter-spacing: 0.05em;
  margin: 0;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
}
.producer-hero--overlay .producer-hero__logo-wrap {
  top: 40%;
}
.producer-identity {
  background: var(--color-background);
  padding: var(--spacing-lg) var(--spacing-md);
  text-align: center;
  border-bottom: none;
}
.producer-identity__name {
  font-family: var(--font-primary);
  font-size: clamp(3rem, 6vw, 5rem);
  font-weight: 400;
  color: var(--color-text);
  margin: 0 0 var(--spacing-xs) 0;
  line-height: 1.1;
  letter-spacing: 0.02em;
}
.producer-identity__location {
  font-family: var(--font-primary);
  font-style: italic;
  font-size: var(--font-size-xl);
  font-weight: 400;
  color: var(--color-text-light);
  letter-spacing: 0.04em;
  margin: 0;
}
.subheading {
  font-family: var(--font-primary);
  font-style: italic;
  font-size: var(--font-size-xl);
  font-weight: 400;
  color: var(--color-text-light);
  letter-spacing: 0.04em;
  margin: 0;
}
.section {
  padding: var(--spacing-lg) 0;
}
@media (max-width: 768px) {
  .section {
    padding: var(--spacing-md) 0;
  }
}
.section--alt {
  background: var(--color-background-alt);
}
.wp-block-group.section.carosection {
  background-color: var(--color-background-alt);
  padding-bottom: 10px;
}
.ds-producer-carousel-wrapper {
  padding-left: 0;
  padding-right: 0;
}
.carosection p {
  text-align: center;
}
.wp-block-group {
  padding: var(--spacing-lg) 0;
}
.section + .section--alt,
.section--alt + .section,
.section + .producer-connect-section,
.section--alt + .producer-connect-section {
  padding-top: var(--spacing-2xl);
}
.section:has(+ .section--alt),
.section:has(+ .producer-connect-section) {
  padding-bottom: var(--spacing-2xl);
}
.producer-connect-section {
  background: var(--color-background-alt);
  padding-top: var(--spacing-2xl);
  padding-bottom: var(--spacing-2xl);
}
.section--dark {
  background: var(--color-green-dark);
  color: #FFFFFF;
}
.section--dark h1,
.section--dark h2,
.section--dark h3 {
  color: #FFFFFF;
}
.section--dark p {
  color: rgba(255, 255, 255, 0.85);
}
.section-header {
  text-align: center;
  margin-bottom: var(--spacing-2xl);
}
.section-header__label {
  font-family: var(--font-primary);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--color-text-muted);
  display: block;
  margin-bottom: var(--spacing-md);
}
.section-header__title {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 600;
  color: var(--color-text);
  margin: 0 0 var(--spacing-md) 0;
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 400;
  letter-spacing: 0.02em;
}
.section-header__desc {
  max-width: 800px;
  margin: 0 auto;
  color: var(--color-text-light);
  font-size: var(--font-size-large);
  font-style: italic;
}
.photo-grid {
  display: grid;
  gap: 4px;
}
.photo-grid--2x2 {
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
}
.photo-grid--single-column {
  grid-template-columns: 1fr;
  gap: var(--spacing-md);
}
.photo-grid--left-large {
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
}
.photo-grid--left-large .photo-grid__item:first-child {
  grid-row: span 2;
}
.photo-grid__item {
  overflow: hidden;
  aspect-ratio: 1;
}
.photo-grid__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
  filter: grayscale(20%);
}
.photo-grid__item img:hover {
  transform: scale(1.03);
}
.producer-intro-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--spacing-xl);
  align-items: start;
}
@media (max-width: 768px) {
  .producer-intro-grid {
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
  }
}
.producer-intro-selfie {
  display: grid;
  grid-template-columns: 60% 1fr;
  align-items: stretch;
  margin-bottom: var(--spacing-lg);
}
@media (max-width: 768px) {
  .producer-intro-selfie {
    grid-template-columns: 1fr;
  }
}
.producer-intro-selfie__message {
  background: var(--color-background-alt);
  padding: var(--spacing-xl);
  display: flex;
  flex-direction: column;
  justify-content: center;
  font-style: italic;
}
.producer-intro-selfie__message .lead p {
  font-style: italic;
  margin: 0 0 var(--spacing-sm);
}
.producer-intro-selfie__message .lead p:last-child {
  margin-bottom: 0;
}
@media (max-width: 768px) {
  .producer-intro-selfie__message {
    padding: var(--spacing-lg);
  }
}
.producer-intro-selfie__eyebrow {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-small);
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--color-wine-red);
  margin-bottom: var(--spacing-sm);
}
.producer-intro-selfie__image {
  position: relative;
  overflow: hidden;
  min-height: 300px;
}
@media (max-width: 768px) {
  .producer-intro-selfie__image {
    aspect-ratio: 1 / 1;
    min-height: unset;
  }
}
.producer-intro-selfie__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}
.producer-highlights--below {
  margin-top: var(--spacing-md);
}
.producer-intro-selfie > .producer-highlights {
  align-self: center;
  padding: var(--spacing-lg);
}
.story__grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--spacing-xl);
  transition: grid-template-columns 0.4s ease;
}
@media (max-width: 768px) {
  .story__grid {
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
  }
}
.story__grid--text-only {
  grid-template-columns: 1fr;
}
.story__body {
  position: relative;
  max-height: 500px;
  overflow: hidden;
  transition: max-height 0.5s ease;
}
.story__body.is-expanded {
  max-height: 9999px;
}
.story__body.is-expanded .story__grid {
  grid-template-columns: 1fr;
}
.story__body.is-expanded .story__photos .photo-grid {
  grid-template-columns: repeat(var(--photo-cols, 3), 1fr);
  gap: var(--spacing-sm);
}
@media (max-width: 768px) {
  .story__body.is-expanded .story__photos .photo-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 480px) {
  .story__body.is-expanded .story__photos .photo-grid {
    grid-template-columns: 1fr;
  }
}
.story__body:not(.is-expanded)::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 120px;
  background: linear-gradient(transparent, var(--color-background));
  pointer-events: none;
}
.story__toggle {
  background: none;
  border: none;
  padding: 0;
  color: var(--color-wine-red);
  font-family: var(--font-primary);
  font-style: italic;
  font-size: var(--font-size-large);
  cursor: pointer;
  margin-top: var(--spacing-md);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  transition: var(--transition);
  text-transform: inherit;
  letter-spacing: inherit;
}
.story__toggle::after {
  content: '↓';
  transition: transform 0.3s ease;
}
.story__toggle.is-expanded::after {
  transform: rotate(180deg);
}
.story__toggle:hover {
  color: var(--color-wine-highlight);
}
.producer-connect__label {
  display: none;
  text-align: center;
  font-size: clamp(1.5rem, 3vw, 2.5rem);
  font-weight: 400;
  font-style: italic;
  letter-spacing: 0.02em;
  font-family: var(--font-primary);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 600;
  color: var(--color-text);
  margin: 0 0 var(--spacing-md) 0;
  margin-bottom: var(--spacing-lg);
}
.producer-connect {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
  gap: var(--spacing-xl);
  align-items: start;
}
@media (max-width: 768px) {
  .producer-connect {
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
  }
}
.producer-connect__logo-col {
  text-align: center;
}
.producer-connect__identity {
  text-align: left;
}
.producer-connect__logo {
  max-height: 200px;
  width: auto !important;
  height: auto !important;
  margin: 0 auto;
  display: block;
}
.producer-connect__logo-text {
  font-family: var(--font-primary);
  font-size: clamp(1rem, 2vw, 1.4rem);
  font-weight: 400;
  color: var(--color-text);
  text-align: center;
  line-height: 1.3;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  word-break: break-word;
}
.producer-connect__name {
  font-size: var(--font-size-xl);
  font-weight: 600;
  margin: 0 0 var(--spacing-xs) 0;
}
.producer-connect__location {
  font-size: var(--font-size-base);
  color: var(--color-text-light);
  margin: 0;
  padding-bottom: var(--spacing-md);
}
.producer-connect__address {
  font-style: normal;
  font-size: var(--font-size-small);
  line-height: 1.6;
  padding-top: var(--spacing-md);
  border-top: 1px solid var(--color-border);
}
.producer-connect__col {
  min-width: 0;
}
.producer-connect__col p {
  margin: 0 0 var(--spacing-xs) 0;
  font-size: var(--font-size-small);
}
.producer-connect__col a {
  color: var(--color-text);
  text-decoration: none;
}
.producer-connect__col a:hover {
  color: var(--color-wine-red);
  text-decoration: underline;
}
.producer-connect__social {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
  margin-top: var(--spacing-md);
  padding-top: var(--spacing-md);
  border-top: 1px solid var(--color-border);
}
.producer-connect__social a {
  font-size: var(--font-size-small);
}
.producer-connect__downloads-heading {
  font-size: var(--font-size-small);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-text-muted);
  margin: 0 0 var(--spacing-sm) 0;
}
.producer-connect__download-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}
.producer-connect__download-item {
  display: block;
}
.producer-connect__download-link {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  font-size: var(--font-size-small);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  line-height: 1.2em;
  color: var(--color-text);
  text-decoration: none;
  padding: var(--spacing-xs) 0;
}
.producer-connect__download-link:hover {
  color: var(--color-gold-primary);
  text-decoration: none;
}
.producer-connect__download-icon {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  width: auto;
  height: 2rem;
  color: var(--color-gold-dark, #9E7C2F);
}
.producer-connect__download-icon svg {
  height: 100%;
  width: auto;
}
.producer-connect__map {
  grid-column: span 2;
  min-width: 0;
}
@media (max-width: 768px) {
  .producer-connect__map {
    grid-column: span 1;
  }
}
.producer-connect__map iframe {
  display: block;
  width: 100%;
  border-radius: var(--border-radius);
}
.site-footer h1,
.site-footer h2,
.site-footer h3,
.site-footer h4,
.site-footer h5,
.site-footer h6 {
  text-align: left;
}
.footer-logo {
  display: block;
  width: 250px;
}
@media (max-width: 768px) {
  .footer-logo {
    width: auto;
    max-width: 70vw;
  }
}
.footer-logo__img {
  filter: none !important;
}
.site-colophon p {
  letter-spacing: 1.5px;
}
.site-colophon a:hover {
  color: var(--footer-colophon-text);
}
.footer-widget p {
  font-size: 1rem;
}
.ds-socials {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}
.ds-socials__link,
.site-footer .ds-socials__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--social-color);
  text-decoration: none;
  transition: color var(--transition);
}
.ds-socials__link:hover,
.site-footer .ds-socials__link:hover {
  color: var(--social-color-hover);
  text-decoration: none;
}
.ds-socials span.ds-socials__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: inherit;
}
.ds-socials span.ds-socials__icon svg {
  width: 100%;
  height: 100%;
  display: block;
  fill: currentColor;
}
.footer-dark .ds-socials__link {
  color: rgba(255, 255, 255, 0.7);
}
.footer-dark .ds-socials__link:hover {
  color: var(--color-gold-primary);
}
.footer-widget h3 {
  font-size: var(--font-size-base);
  letter-spacing: 0.1em;
  margin: 0 0 var(--spacing-sm) 0;
  font-family: var(--font-secondary, sans-serif);
}
#address-ftr p {
  line-height: 1.4em;
  margin: 0;
}
footer#colophon {
  margin-top: 0;
  padding-top: 0;
}
.footer-widget figure.wp-block-image.size-full {
  margin-top: -25px;
}
.hero__tagline {
  font-size: clamp(1.75rem, 4vw, 3rem);
  max-width: 900px;
  font-weight: 400;
}
.hero--fullbleed .hero__headline {
  text-align: center;
}
.hero__headline {
  font-size: clamp(1.6rem, 4vw, 2.5rem);
}
.hero--split {
  align-items: stretch;
}
.hero__image-col {
  height: 100%;
}
.site-header {
  border-bottom: none;
}
.site-description {
  display: none;
}
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
:focus-visible {
  outline: none;
}
:root {
  --header-mobile-menu-bg: rgba(122, 31, 43, 0.82);
  --header-mobile-menu-color: #FFF7E9;
  --header-mobile-menu-shadow: -4px 0 32px rgba(42, 36, 32, 0.4);
}
.site-header.header--mobile-nav .header-nav {
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
@media (min-width: 769px) {
  .site-header.header--mobile-nav .header-nav {
    width: min(400px, 50vw);
  }
}
.site-header.header--desktop-nav .header-nav a:hover {
  text-decoration: underline;
  text-underline-offset: 13px;
}
.site-header.header--mobile-nav .header-nav a {
  font-family: var(--font-primary);
  font-size: 1.5rem;
  letter-spacing: 0.02em;
  color: var(--color-background) !important;
  border-bottom-color: rgba(198, 166, 75, 0.25) !important;
  padding: var(--spacing-md) 0;
}
.site-header.header--mobile-nav .header-nav li ul a {
  font-size: 1.1rem;
  color: var(--color-background) !important;
  padding: var(--spacing-sm) 0;
}
body.mobile-menu-open .hamburger-bar,
.site-header.mobile-menu-open .hamburger-bar {
  background-color: currentColor;
}
@media (max-width: 768px) {
  .site-header.header--mobile-nav .header-nav {
    padding: var(--spacing-xl) var(--spacing-lg);
    width: min(320px, 85vw);
  }
}
.nav-overlay {
  position: fixed;
  inset: 0;
  z-index: calc(var(--header-z-index) + 4);
  background: var(--color-background);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.35s cubic-bezier(0.4, 0, 0.2, 1), visibility 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}
body.mobile-menu-open {
  overflow: hidden;
}
body.mobile-menu-open .nav-overlay {
  opacity: 1;
  visibility: visible;
}
body:not(.mobile-menu-open) .nav-overlay a {
  tabindex: -1;
}
.nav-overlay__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(1rem, 2vh, 3rem);
  padding: clamp(1.5rem, 4vh, 4.5rem) var(--spacing-xl);
  width: 100%;
  max-width: 640px;
  max-height: 100dvh;
  overflow-y: auto;
  box-sizing: border-box;
  text-align: center;
}
.nav-overlay__logo-link {
  display: block;
}
.nav-overlay__logo {
  height: auto;
  max-height: clamp(60px, 30vh, 280px);
  width: auto;
  max-width: min(50vw, 280px);
  object-fit: contain;
}
.nav-overlay__menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  width: 100%;
}
.nav-overlay__menu li {
  width: 100%;
  text-align: center;
}
.nav-overlay__menu a {
  display: block;
  font-family: var(--font-primary);
  font-size: clamp(1.4rem, min(4vw, 5vh), 2.8rem);
  font-weight: 400;
  letter-spacing: 0.04em;
  color: var(--color-text);
  padding: clamp(0.4rem, 1.2vh, 1rem) 0;
  border-bottom: 1px solid var(--color-border);
  text-decoration: none;
  transition: color 0.2s ease;
  width: 100%;
}
.nav-overlay__menu a:hover {
  color: var(--color-wine-red);
}
.nav-overlay__menu li:last-child a {
  border-bottom: none;
}
.nav-overlay__menu ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.nav-overlay__menu ul a {
  font-size: 1.1rem;
  color: var(--color-text-light);
  padding: var(--spacing-sm) 0;
  border-bottom: none;
}
.site-header.header--mobile-nav .header-nav {
  transform: translateX(100%) !important;
  transition: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}
body.mobile-menu-open::before {
  display: none !important;
}
@media (max-width: 640px) {
  .nav-overlay__logo {
    max-width: 220px;
  }
}
body.mobile-menu-open .site-header,
.site-header.mobile-menu-open {
  position: fixed;
  transform: none;
  z-index: calc(var(--header-z-index) + 5);
  background: transparent !important;
  box-shadow: none !important;
  border-bottom: none !important;
  pointer-events: none;
}
body.mobile-menu-open .site-header .header-hamburger,
.site-header.mobile-menu-open .header-hamburger {
  pointer-events: auto;
  position: relative;
  z-index: calc(var(--header-z-index) + 20);
}
body.mobile-menu-open .header-logo,
.site-header.mobile-menu-open .header-logo {
  opacity: 0;
  pointer-events: none;
}
body.mobile-menu-open .site-header .header-search-toggle,
.site-header.mobile-menu-open .header-search-toggle {
  opacity: 0;
  pointer-events: none;
}
.split-feature .wp-block-columns {
  gap: 30px !important;
  margin-bottom: 30px !important;
  align-items: stretch;
}
.split-feature .wp-block-columns .wp-block-column {
  padding: 0 !important;
}
.split-feature .wp-block-columns:last-child {
  margin-bottom: 0 !important;
}
.split-feature .wp-block-column:not(:has(.wp-block-cover)) {
  background: var(--color-background-alt);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-2xl) !important;
}
.split-feature .wp-block-column:not(:has(.wp-block-cover)) h2.wp-block-heading {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 4vw, 3.5rem);
  font-weight: 400;
  font-style: italic;
  color: var(--color-text);
  line-height: 1.2;
  margin: 0;
  text-align: center;
}
.split-feature .wp-block-column:not(:has(.wp-block-cover)) p {
  font-family: var(--font-primary);
  font-size: clamp(1rem, 1.6vw, 1.2rem);
  color: var(--color-text-light);
  line-height: 1.75;
  margin: 0;
  text-align: center;
  max-width: 36ch;
}
.split-feature .wp-block-cover {
  width: 100%;
  height: 100%;
  min-height: 360px !important;
}
.split-feature .wp-block-cover span.wp-block-cover__background.has-background-dim {
  background-color: var(--color-text) !important;
}
.split-feature .wp-block-cover .wp-block-cover__inner-container p {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 4vw, 3.5rem);
  font-style: italic;
  font-weight: 400;
  color: var(--color-background);
  line-height: 1.2;
  margin: 0;
  text-align: center;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
}
@media (max-width: 768px) {
  .split-feature .wp-block-columns {
    flex-direction: column !important;
  }
  .split-feature .wp-block-columns:nth-child(odd) {
    flex-direction: column-reverse !important;
  }
  .split-feature .wp-block-cover {
    min-height: 260px !important;
  }
  .split-feature .wp-block-column:not(:has(.wp-block-cover)) {
    padding: var(--spacing-xl) var(--spacing-lg) !important;
  }
}
#patmessage > .wp-block-group__inner-container {
  background: var(--color-background-alt);
  padding: var(--spacing-xl);
}
@media (max-width: 768px) {
  #patmessage > .wp-block-group__inner-container {
    padding: var(--spacing-xl) var(--spacing-lg);
  }
}
@media (max-width: 640px) {
  #patmessage > .wp-block-group__inner-container {
    padding: var(--spacing-lg) var(--spacing-md);
  }
}
#patmessage p {
  font-style: italic;
  line-height: 1.75;
}
#patmessage .patsig {
  color: var(--color-wine-red);
  font-style: italic;
}
#patmessage .wp-block-image {
  margin-left: var(--spacing-lg);
  margin-bottom: var(--spacing-md);
}
@media (max-width: 640px) {
  #patmessage .wp-block-image.patpic {
    margin: 0 auto;
  }
  #patmessage .wp-block-image.patpic figure {
    float: none;
    margin: 0 auto;
  }
  #patmessage .wp-block-image.patpic img {
    width: 100%;
  }
}
.photo-carousel {
  overflow: hidden;
}
.photo-carousel .swiper {
  width: 100%;
  overflow: hidden;
}
.photo-carousel .wp-block-gallery {
  flex-wrap: nowrap !important;
  gap: 0 !important;
  align-items: stretch;
}
.photo-carousel .swiper-wrapper {
  display: flex;
  align-items: stretch;
}
.photo-carousel .swiper-slide {
  width: auto;
  flex-shrink: 0;
  margin: 0;
}
.photo-carousel .swiper-slide img {
  height: 340px;
  width: auto;
  object-fit: cover;
  display: block;
}
@media (max-width: 768px) {
  .photo-carousel .swiper-slide img {
    height: 260px;
  }
}
.photo-carousel figcaption {
  display: none;
}
body.page-about .entry-header {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.dist-grid {
  gap: var(--spacing-xl) var(--spacing-2xl) !important;
}
.dist-grid > .wp-block-group {
  background: var(--color-background-alt);
  padding: var(--spacing-lg);
}
.dist-grid h3 {
  font-family: var(--font-primary);
  font-size: var(--font-size-xl);
  font-weight: 700;
  color: var(--color-wine-red);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: var(--spacing-sm);
  padding-bottom: var(--spacing-sm);
  border-bottom: 1px solid var(--color-border);
}
.dist-grid h3 strong {
  font-weight: inherit;
}
.dist-grid ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.dist-grid li {
  padding: var(--spacing-xs) 0;
  border-bottom: 1px solid var(--color-border);
}
.dist-grid li:last-child {
  border-bottom: none;
}
.dist-grid a {
  color: var(--color-text);
  text-decoration: none;
  font-size: var(--font-size-large);
  transition: color 0.2s ease;
}
.dist-grid a:hover {
  color: var(--color-wine-red);
}
@media (max-width: 640px) {
  .dist-grid {
    display: block !important;
  }
  .dist-grid > .wp-block-group {
    margin-bottom: var(--spacing-xl);
  }
  .dist-grid > .wp-block-group:last-child {
    margin-bottom: 0;
  }
}
.search-results-page__header {
  margin-bottom: var(--spacing-2xl);
  text-align: left;
}
.search-results-page__heading {
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 400;
  margin-bottom: var(--spacing-sm);
}
.search-results-page__query {
  font-style: italic;
  color: var(--color-wine-red);
}
.search-results-page__count {
  display: none;
  color: var(--color-text-muted);
  font-size: var(--font-size-small);
  margin: 0;
}
.search-results-page__no-results {
  text-align: center;
}
.search-results-page__no-results p {
  color: var(--color-text-light);
  margin-bottom: var(--spacing-lg);
}
form.search-form {
  display: flex;
  flex-direction: row;
  justify-content: center;
  gap: var(--spacing-md);
}
form.search-form .search-field {
  min-width: 30ch;
}
@media (max-width: 768px) {
  form.search-form {
    flex-direction: column;
    align-items: center;
  }
}
.search-results-page__form {
  display: flex;
  justify-content: center;
}
.search-results-page__form-row {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  gap: var(--spacing-md);
}
@media (max-width: 768px) {
  .search-results-page__form-row {
    flex-direction: column;
    align-items: center;
  }
}
.search-results-page__input {
  flex: 1;
  min-width: 280px;
  padding: var(--spacing-sm) 0;
  border: none;
  border-bottom: 1px solid var(--color-border);
  border-radius: 0;
  background: transparent;
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  color: var(--color-text);
  outline: none;
}
.search-results-page__input:focus,
.search-results-page__input:focus-visible {
  outline: none;
  border-bottom-color: var(--color-wine-red);
  box-shadow: none;
}
.search-results-page__input::-webkit-search-decoration,
.search-results-page__input::-webkit-search-results-button,
.search-results-page__input::-webkit-search-results-decoration {
  display: none;
}
.search-results-page__input::placeholder {
  color: var(--color-text-muted);
  font-style: italic;
}
.search-results-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--spacing-lg);
  align-items: start;
}
@media (max-width: 640px) {
  .search-results-grid {
    grid-template-columns: 1fr;
  }
}
.search-result-card {
  border-left: 3px solid transparent;
  padding: 0 var(--spacing-md) 0 calc(var(--spacing-md) + 2px);
}
.search-result-card__label {
  display: block;
  font-family: var(--font-primary);
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 0.35rem;
}
.search-result-card__title {
  font-size: var(--font-size-large);
  font-weight: 400;
  margin: 0 0 0.3rem;
  line-height: 1.3;
  text-align: left;
}
.search-result-card__title a {
  color: var(--color-text);
  text-decoration: none;
  transition: color 0.2s ease;
}
.search-result-card__title a:hover {
  color: var(--color-wine-red);
}
.search-result-card__meta {
  font-size: var(--font-size-small);
  color: var(--color-text-light);
  margin: 0;
  line-height: 1.5;
}
.search-result-card--producer {
  border-left-color: var(--color-green-primary);
}
.search-result-card--producer .search-result-card__label {
  color: var(--color-green-primary);
}
.search-result-card--wine {
  border-left-color: var(--color-wine-red);
}
.search-result-card--wine .search-result-card__label {
  color: var(--color-wine-red);
}
.search-result-card--page {
  border-left-color: var(--color-gold-primary);
}
.search-result-card--page .search-result-card__label {
  color: var(--color-gold-dark);
}
.header-right {
  display: flex;
  align-items: center;
  gap: var(--header-nav-gap, 2rem);
}
.site-header.header--mobile-nav .header-right {
  gap: var(--spacing-md);
}
.header-search-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  flex-shrink: 0;
  color: var(--header-active-color, #ffffff);
  text-transform: none;
  letter-spacing: normal;
  font-size: inherit;
  transition: opacity 0.2s ease;
  z-index: calc(var(--header-z-index) + 10);
}
.header-search-toggle:hover {
  opacity: 0.7;
  color: var(--header-active-color, #ffffff);
  background: none;
  border: none;
}
.header-search-toggle:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 4px;
  border-radius: 2px;
}
.header-search-toggle svg {
  width: 20px;
  height: 20px;
  display: block;
  fill: currentColor;
}
.search-overlay {
  position: fixed;
  inset: 0;
  background: rgba(42, 36, 32, 0.65);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-lg);
  box-sizing: border-box;
  opacity: 0;
  transition: opacity 0.3s ease;
}
.search-overlay[hidden] {
  display: none;
}
.search-overlay.is-open {
  opacity: 1;
}
body.search-overlay-open {
  overflow: hidden;
}
.search-overlay__card {
  position: relative;
  width: 100%;
  max-width: 520px;
  background: var(--color-background, #FFF7E9);
  padding: var(--spacing-xl) var(--spacing-2xl);
  box-shadow: 0 8px 40px rgba(42, 36, 32, 0.25);
  animation: searchSlideUp 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-sizing: border-box;
}
@media (max-width: 480px) {
  .search-overlay__card {
    padding: var(--spacing-xl) var(--spacing-lg);
  }
}
@keyframes searchSlideUp {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.search-overlay__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-3xl);
  font-weight: 400;
  color: var(--color-text);
  text-align: left;
  margin: 0 0 var(--spacing-sm);
  letter-spacing: 0.02em;
}
.search-overlay__close {
  position: absolute;
  top: var(--spacing-md);
  right: var(--spacing-md);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  text-transform: none;
  letter-spacing: normal;
  color: var(--color-text-muted);
  transition: color 0.2s ease;
}
.search-overlay__close:hover {
  color: var(--color-text);
}
.search-overlay__close:focus-visible {
  outline: 2px solid var(--color-wine-red);
  outline-offset: 2px;
  border-radius: 2px;
}
.search-overlay__close svg {
  display: block;
  fill: currentColor;
}
.search-overlay__input-wrap {
  display: flex;
  align-items: center;
  border-bottom: 1px solid var(--color-text-muted);
  gap: var(--spacing-sm);
}
.search-overlay__input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  font-family: var(--font-primary);
  font-size: var(--font-size-xl);
  font-weight: 400;
  color: var(--color-text);
  padding: var(--spacing-sm) 0;
  min-width: 0;
}
.search-overlay__input:focus,
.search-overlay__input:focus-visible {
  outline: none;
  border: none;
}
.search-overlay__input::-webkit-search-decoration,
.search-overlay__input::-webkit-search-results-button,
.search-overlay__input::-webkit-search-results-decoration {
  display: none;
}
.search-overlay__input::placeholder {
  color: var(--color-text-muted);
  font-style: italic;
}
input#search-overlay-input {
  border-bottom: none;
}
.search-overlay__submit {
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--spacing-xs);
  text-transform: none;
  letter-spacing: normal;
  color: var(--color-text-muted);
  flex-shrink: 0;
  transition: color 0.2s ease;
}
.search-overlay__submit:hover {
  color: var(--color-wine-red);
}
.search-overlay__submit:focus-visible {
  outline: 2px solid var(--color-wine-red);
  outline-offset: 2px;
  border-radius: 2px;
}
.search-overlay__submit svg {
  width: 22px;
  height: 22px;
  display: block;
  fill: currentColor;
}
.pagination {
  display: flex;
  justify-content: center;
  margin-top: var(--spacing-2xl);
}
.pagination .nav-links {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
}
.page-numbers {
  padding: 0;
  border: none;
  background: none;
  color: var(--color-text-muted);
  text-decoration: none;
  font-size: inherit;
  letter-spacing: 0.05em;
  transition: color 0.2s ease;
}
.page-numbers:hover {
  background: none;
  border: none;
  color: var(--color-text);
  text-decoration: none;
}
.page-numbers.current {
  background: none;
  border: none;
  color: var(--color-wine-red);
  font-weight: 700;
}
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .button,
  .card {
    transition: background-color 0.1s ease, color 0.1s ease !important;
  }
}
:focus {
  outline: 2px solid var(--color-wine-red);
  outline-offset: 2px;
}
:focus:not(:focus-visible) {
  outline: none;
}
:focus-visible {
  outline: 2px solid var(--color-wine-red);
  outline-offset: 2px;
}
.filter-group:focus-within {
  outline: 2px solid var(--color-wine-red);
  outline-offset: 4px;
  border-radius: var(--border-radius);
}
a:focus-visible {
  outline: 2px solid var(--color-wine-red);
  outline-offset: 2px;
  text-decoration: underline;
  text-decoration-thickness: 2px;
}
.button:focus-visible,
button:focus-visible {
  outline: 2px solid var(--color-wine-red);
  outline-offset: 3px;
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline: 2px solid var(--color-wine-red);
  outline-offset: 0;
  box-shadow: 0 0 0 4px rgba(122, 31, 43, 0.1);
}
.skip-link {
  position: absolute;
  top: -100%;
  left: 0;
  background: var(--color-wine-red);
  color: var(--color-background);
  padding: var(--spacing-sm) var(--spacing-md);
  font-weight: 600;
  text-decoration: none;
  z-index: 9999;
  border-radius: 0 0 var(--border-radius) 0;
}
.skip-link:focus {
  top: 0;
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}
.sr-only,
.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-width: 0;
}
.sr-only-focusable:active,
.sr-only-focusable:focus {
  position: static;
  width: auto;
  height: auto;
  overflow: visible;
  clip: auto;
  white-space: normal;
}
@media (prefers-contrast: high) {
  * {
    border-color: currentColor !important;
  }
  .button,
  .card,
  .wine-card,
  .producer-card {
    border: 2px solid currentColor;
  }
}
.wine-card:focus-within,
.producer-card:focus-within {
  outline: 2px solid var(--color-wine-red);
  outline-offset: 4px;
}
.light-text-on-dark {
  color: var(--color-background);
  background: var(--color-text);
}
.dark-text-on-light {
  color: var(--color-text);
  background: var(--color-background);
}
.live-region {
  position: absolute;
  left: -10000px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
.producer-card {
  height: max-content;
  container-type: inline-size;
  background: var(--color-surface);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--box-shadow);
  overflow: hidden;
  transition: var(--transition);
}
.producer-card:hover {
  box-shadow: var(--box-shadow-lg);
  transform: translateY(-2px);
}
.producer-card__image {
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
.producer-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transition);
}
.producer-card:hover .producer-card__image img {
  transform: scale(1.05);
}
.producer-card__content {
  padding: var(--spacing-md);
}
.producer-card__title {
  margin: 0 0 var(--spacing-xs) 0;
  font-size: var(--font-size-xl);
  color: var(--color-wine-red);
}
.producer-card__country {
  display: inline-block;
  margin-bottom: var(--spacing-sm);
  padding: var(--spacing-xs) var(--spacing-sm);
  background: var(--color-green-primary);
  color: var(--color-background);
  border-radius: var(--border-radius);
  font-size: var(--font-size-small);
  font-weight: 600;
  text-transform: uppercase;
}
.producer-card__excerpt {
  margin: var(--spacing-sm) 0;
  color: var(--color-text-light);
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
}
.producer-card__meta {
  display: flex;
  gap: var(--spacing-sm);
  align-items: center;
  margin-top: var(--spacing-md);
  padding-top: var(--spacing-md);
  border-top: 1px solid var(--color-border);
  font-size: var(--font-size-small);
  color: var(--color-text-muted);
}
.producer-card__wine-count::before {
  content: '🍷 ';
}
.wine-card {
  background: transparent;
  border: none;
  box-shadow: none;
  overflow: visible;
  transition: var(--transition);
}
.wine-card:is(:hover, :focus-within) {
  box-shadow: none;
  transform: none;
  outline: none;
}
.wine-card__toggle {
  display: block;
  width: 100%;
  background: none;
  border: none;
  border-radius: 0;
  padding: 0;
  margin: 0;
  text-align: center;
  cursor: pointer;
  color: inherit;
  font: inherit;
  letter-spacing: inherit;
  text-transform: capitalize;
  -webkit-appearance: none;
  appearance: none;
  box-shadow: none;
}
.wine-card__toggle:focus-visible {
  outline: none;
}
.wine-card__toggle:hover {
  opacity: 1;
}
.wine-card__bottle {
  aspect-ratio: 2 / 3;
  background: radial-gradient(circle, #ffffff 50%, transparent 50%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-md);
  transition: background-size 0.25s ease;
}
.wine-card--expandable:hover .wine-card__bottle {
  background: radial-gradient(circle, #ffffff 55%, transparent 55%);
}
.wine-card--active .wine-card__bottle-img {
  filter: grayscale(0.5);
}
.wine-card__bottle-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  mix-blend-mode: multiply;
}
.wine-card__bottle-img--placeholder {
  opacity: 0.35;
  mix-blend-mode: normal;
}
.wine-card__info {
  padding: var(--spacing-sm) var(--spacing-xs) 0;
  text-align: center;
}
.wine-card .wine-card__title {
  margin: 0 0 var(--spacing-xs) 0;
  font-size: var(--font-size-large);
  color: var(--color-wine-red);
  font-family: var(--font-primary);
  font-weight: 400;
  text-align: center;
}
.wine-card__subtitle {
  margin: 0;
  font-size: var(--font-size-base);
  color: var(--color-text);
}
.country-card {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.country-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
}
@media (max-width: 900px) {
  .country-card {
    aspect-ratio: 4 / 3;
  }
}
.country-card__image {
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center bottom;
  background-repeat: no-repeat;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: relative;
}
.country-card__image::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.1) 0%, rgba(0, 0, 0, 0.2) 50%, rgba(0, 0, 0, 0.4) 100%);
  pointer-events: none;
  z-index: 1;
}
.country-card__info {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  padding: 1.25rem 1.5rem;
  background: #c6a64b4f;
  backdrop-filter: blur(4px) saturate(120%);
  -webkit-backdrop-filter: blur(4px) saturate(120%);
  text-align: center;
  z-index: 2;
}
.country-card__label {
  display: block;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: rgba(255, 255, 255, 0.95);
  margin-bottom: 0.35rem;
  font-weight: 600;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
  font-family: var(--font-secondary);
  text-align: center;
}
.country-card__name {
  color: #ffffff;
  font-size: 2rem;
  margin: 0 0 0.1em 0;
  font-weight: 600;
  line-height: 1.2;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
  text-align: center;
}
.country-card__link {
  position: absolute;
  inset: 0;
  z-index: 10;
  cursor: pointer;
}
.country-card__link:focus {
  outline: 3px solid rgba(255, 255, 255, 0.8);
  outline-offset: -4px;
}
.country-card--no-image .country-card__image {
  background: linear-gradient(145deg, var(--color-wine-red) 0%, color-mix(in srgb, var(--color-wine-red) 60%, #000) 100%);
}
.country-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-md);
}
.country-grid .country-card:last-child:nth-child(odd) {
  grid-column: 1 / -1;
  aspect-ratio: 21 / 7;
}
@media (max-width: 768px) {
  .country-grid {
    grid-template-columns: 1fr;
  }
  .country-grid .country-card:last-child:nth-child(odd) {
    grid-column: 1;
    aspect-ratio: 16 / 9;
  }
}
.producer-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(var(--producer-card-width), 1fr));
  gap: var(--spacing-md);
}
@media (max-width: 768px) {
  .producer-grid {
    grid-template-columns: 1fr;
  }
}
.wine-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(var(--wine-card-width), 1fr));
  gap: var(--spacing-lg);
}
@media (max-width: 768px) {
  .wine-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 480px) {
  .wine-grid {
    grid-template-columns: 1fr;
  }
}
.filter-sidebar {
  position: sticky;
  top: var(--spacing-lg);
  background: var(--color-surface);
  border-radius: var(--border-radius-lg);
  padding: var(--spacing-lg);
}
.filter-group {
  margin-bottom: var(--spacing-lg);
}
.filter-group:last-child {
  margin-bottom: 0;
}
.filter-group__title {
  margin: 0 0 var(--spacing-sm) 0;
  font-size: var(--font-size-large);
  font-weight: 600;
  color: var(--color-text);
}
.filter-option {
  display: block;
  margin-bottom: var(--spacing-xs);
}
.filter-option input[type="checkbox"],
.filter-option input[type="radio"] {
  margin-right: var(--spacing-xs);
}
.filter-option label {
  cursor: pointer;
  color: var(--color-text-light);
}
.filter-option label:hover {
  color: var(--color-text);
}
.download-list {
  list-style: none;
  padding: 0;
  margin: var(--spacing-md) 0;
}
.download-item {
  margin-bottom: var(--spacing-sm);
}
.download-link {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm) var(--spacing-md);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius);
  color: var(--color-text);
  text-decoration: none;
  transition: var(--transition);
}
.download-link:hover {
  background: var(--color-wine-red);
  color: var(--color-background);
  border-color: var(--color-wine-red);
  transform: translateX(4px);
}
.download-link::before {
  content: '📄';
  font-size: 1.2em;
}
.producer-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--spacing-md);
  margin: var(--spacing-lg) 0;
}
.producer-gallery__item {
  aspect-ratio: 1 / 1;
  overflow: hidden;
  border-radius: var(--border-radius);
}
.producer-gallery__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transition);
}
.producer-gallery__item:hover img {
  transform: scale(1.1);
}
.producer-social {
  display: flex;
  gap: var(--spacing-sm);
  margin: var(--spacing-md) 0;
}
.social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 50%;
  color: var(--color-text);
  transition: var(--transition);
}
.social-link:hover {
  background: var(--color-wine-red);
  color: var(--color-background);
  border-color: var(--color-wine-red);
  transform: translateY(-2px);
}
.wine-row-panel {
  grid-column: 1 / -1;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  container-type: inline-size;
}
.wine-row-panel::before {
  content: '';
  position: absolute;
  top: 0;
  left: var(--caret-x, 50%);
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-bottom: 10px solid var(--color-gold-primary);
  opacity: 0;
  transition: opacity 0.2s ease 0.15s;
}
.wine-row-panel--open {
  max-height: 600px;
}
.wine-row-panel--open::before {
  opacity: 1;
}
.wine-row-panel__inner {
  display: grid;
  grid-template-columns: 200px 1fr auto;
  gap: var(--spacing-lg) var(--spacing-xl);
  align-items: start;
  padding: var(--spacing-xl) var(--spacing-lg) var(--spacing-lg);
  margin-top: var(--spacing-sm);
  border: 1px solid var(--color-border);
  background: transparent;
}
@container (max-width: 675px) {
  .wine-row-panel__inner {
    grid-template-columns: 140px 1fr;
  }
  .wine-row-panel__inner .wine-panel__sidebar {
    display: none;
  }
}
@container (max-width: 650px) {
  .wine-row-panel__inner {
    grid-template-columns: 1fr;
  }
  .wine-row-panel__inner .wine-panel__bottle {
    display: none;
  }
  .wine-row-panel__inner .wine-panel__field--tasting {
    display: none;
  }
}
.wine-panel__bottle {
  aspect-ratio: 2 / 3;
  background: radial-gradient(circle, #ffffff 50%, transparent 50%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-sm);
}
.wine-panel__bottle-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  mix-blend-mode: multiply;
}
.wine-panel__bottle-img--placeholder {
  opacity: 0.35;
  mix-blend-mode: normal;
}
.wine-panel__details {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}
.wine-panel__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-2xl);
  font-weight: 400;
  color: var(--color-text);
  margin: 0;
  text-align: left;
}
.wine-panel__subtitle {
  font-size: var(--font-size-base);
  color: var(--color-text-muted);
  margin: 0;
}
.wine-panel__field {
  padding-bottom: var(--spacing-sm);
  border-bottom: 1px solid rgba(198, 166, 75, 0.2);
}
.wine-panel__field:last-of-type {
  border-bottom: none;
}
.wine-panel__eyebrow {
  display: block;
  font-size: var(--font-size-small);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-text-muted);
  margin-bottom: var(--spacing-xs);
}
.wine-panel__field-value {
  font-size: 1rem;
  color: var(--color-text);
  margin: 0;
  line-height: 1.6;
}
.wine-panel__full-link {
  align-self: flex-start;
  margin-top: var(--spacing-xs);
}
.wine-panel__sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
  min-width: 0;
  width: 160px;
}
.wine-panel__meta {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
  padding-bottom: var(--spacing-sm);
  border-bottom: 1px solid var(--color-border);
}
.wine-panel__meta-type {
  font-size: var(--font-size-small);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-text-muted);
}
.wine-panel__meta-abv {
  font-size: var(--font-size-small);
  color: var(--color-text-light);
  margin: 0;
}
.wine-panel__downloads-heading {
  font-size: var(--font-size-small);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-text-muted);
  margin: 0 0 var(--spacing-sm) 0;
}
.wine-panel__download-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}
.wine-panel__download-item {
  display: block;
}
.wine-panel__download-link {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-xs);
  font-size: var(--font-size-small);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  line-height: 1.2em;
  color: var(--color-text);
  text-decoration: none;
  padding: var(--spacing-xs) 0;
  word-break: break-word;
}
.wine-panel__download-link:hover {
  color: var(--color-gold-primary);
}
.wine-panel__download-icon {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  width: auto;
  height: 2rem;
  color: var(--color-gold-dark, #9E7C2F);
}
.wine-panel__download-icon svg {
  height: 100%;
  width: auto;
}
.no-image-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--color-surface) 0%, var(--color-border) 100%);
  color: var(--color-text-muted);
  font-size: var(--font-size-3xl);
}
.ds-producer-card {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  border-radius: 0;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.ds-producer-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
}
.ds-producer-card__image {
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: relative;
}
.ds-producer-card__image::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.1) 0%, rgba(0, 0, 0, 0.2) 50%, rgba(0, 0, 0, 0.4) 100%);
  pointer-events: none;
  z-index: 1;
}
.ds-producer-card__logo {
  position: absolute;
  top: 40%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  width: 60%;
  height: 40%;
  max-width: 60%;
  max-height: 40%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
}
.ds-producer-card__logo .producer-coming-soon {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--font-size-3xl);
  font-weight: 400;
  font-style: italic;
  text-transform: none;
  letter-spacing: 0;
  color: rgba(255, 255, 255, 0.9);
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.5);
  flex-shrink: 0;
}
.ds-producer-card__logo img {
  max-width: 100%;
  max-height: 100%;
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: brightness(0) invert(1);
}
.ds-producer-card__info {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  padding: 1.25rem 1.5rem;
  background: #c6a64b4f;
  backdrop-filter: blur(4px) saturate(120%);
  -webkit-backdrop-filter: blur(4px) saturate(120%);
  text-align: left;
  z-index: 2;
  border-top: 0;
}
.ds-producer-card__country {
  display: block;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: rgba(255, 255, 255, 0.95);
  margin-bottom: 0.35rem;
  font-weight: 600;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
  font-family: var(--font-secondary);
}
.ds-producer-card__name {
  color: #ffffff;
  font-size: 1.5rem;
  margin: 0;
  font-weight: 600;
  line-height: 1.2;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}
.ds-producer-card__link {
  position: absolute;
  inset: 0;
  z-index: 10;
  cursor: pointer;
}
.ds-producer-card__link:focus {
  outline: 3px solid rgba(255, 255, 255, 0.8);
  outline-offset: -4px;
}
.ds-producer-card--no-image .ds-producer-card__image {
  background: linear-gradient(145deg, var(--color-wine-red) 0%, color-mix(in srgb, var(--color-wine-red) 60%, #000) 100%);
}
.producer-archive {
  padding-top: 0;
}
.producer-archive__header {
  position: relative;
  background-color: var(--color-wine-red);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
}
.producer-archive__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.2);
  z-index: 0;
}
.producer-archive__header-inner {
  position: relative;
  z-index: 1;
  width: 100%;
  padding: 0;
}
.producer-archive__header-inner .section-header__label {
  color: rgba(255, 255, 255, 0.75);
}
.producer-archive__header-inner .section-header__title,
.producer-archive__header-inner .section-header__desc {
  color: #fff;
}
.producer-archive__header-inner .section-header {
  margin: var(--spacing-2xl) var(--spacing-2xl) var(--spacing-xl);
}
.producer-archive__results.section {
  padding-top: var(--spacing-2xl);
  padding-bottom: var(--spacing-2xl);
}
.producer-archive__results.section .container {
  transition: opacity 0.2s ease;
}
.producer-grid__empty {
  color: var(--color-text-muted);
  font-style: italic;
  padding: var(--spacing-xl) 0;
  text-align: center;
  grid-column: 1 / -1;
}
.producer-archive__loading {
  align-items: center;
  justify-content: center;
  padding: var(--spacing-lg);
}
.producer-archive__loading:not([hidden]) {
  display: flex;
}
.producer-archive__spinner {
  width: 32px;
  height: 32px;
  border: 3px solid var(--color-border);
  border-top-color: var(--color-wine-red);
  border-radius: 50%;
  animation: dswg-spin 0.7s linear infinite;
}
@keyframes dswg-spin {
  to {
    transform: rotate(360deg);
  }
}
.producer-filter {
  padding: var(--spacing-md);
  background: rgba(255, 247, 233, 0.39);
  border: 1px solid rgba(255, 255, 255, 0.25);
  backdrop-filter: blur(4px) saturate(120%);
  width: auto;
  margin: 0 auto;
}
.producer-filter__inner {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: var(--spacing-lg);
  flex-wrap: wrap;
}
.producer-filter__field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 0 1 240px;
}
.producer-filter__label {
  font-size: var(--font-size-small, 0.8rem);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(255, 255, 255, 0.9);
  font-family: var(--font-secondary);
}
input.producer-filter__input,
select.producer-filter__select {
  padding: 0.4rem var(--spacing-sm);
  border: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.5);
  background: transparent;
  color: #fff;
  font-family: var(--font-primary);
  font-size: 1rem;
  border-radius: 0;
  transition: border-color 0.2s ease;
}
input.producer-filter__input::placeholder,
select.producer-filter__select::placeholder {
  color: rgba(255, 255, 255, 0.6);
  font-style: italic;
}
input.producer-filter__input option,
select.producer-filter__select option {
  color: var(--color-text);
  background: var(--color-background);
}
input.producer-filter__input:focus,
select.producer-filter__select:focus,
input.producer-filter__input:focus-visible,
select.producer-filter__select:focus-visible {
  outline: none;
  border-bottom-color: rgba(255, 255, 255, 0.9);
  box-shadow: none;
}
.producer-filter__count {
  font-size: var(--font-size-small, 0.8rem);
  color: rgba(255, 255, 255, 0.7);
  font-family: var(--font-secondary);
  padding-bottom: 0.4rem;
  white-space: nowrap;
  flex: 0 0 auto;
}
@media (max-width: 640px) {
  .producer-filter__inner {
    flex-direction: column;
    align-items: stretch;
  }
  .producer-filter__field {
    flex: 1 1 auto;
  }
}
.country-archive-wrapper {
  display: flex;
  flex-direction: column;
}
.country-archive__back {
  text-align: center;
}
.country-archive__map {
  text-align: center;
}
.country-archive__map-img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
}
.split-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 480px;
}
@media (max-width: 900px) {
  .split-hero {
    grid-template-columns: 1fr;
  }
}
.split-hero__image {
  position: relative;
  overflow: hidden;
  min-height: 360px;
}
.split-hero__image img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.split-hero__image-placeholder {
  position: absolute;
  inset: 0;
  background: var(--color-background-alt);
}
.split-hero__panel {
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: transparent;
  padding: var(--spacing-2xl) var(--spacing-xl);
}
.split-hero__label {
  display: block;
  font-size: var(--font-size-small);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--color-text-light);
  font-family: var(--font-secondary);
  margin-bottom: var(--spacing-sm);
}
.split-hero__title {
  font-family: var(--font-primary);
  color: var(--color-text);
  margin: 0 0 var(--spacing-md);
  line-height: 1.15;
  text-align: left;
}
.split-hero__desc {
  color: var(--color-text-light);
  line-height: 1.7;
  max-width: 55ch;
}
.split-hero__desc p {
  margin-bottom: var(--spacing-sm);
}
.split-hero__desc p:last-child {
  margin-bottom: 0;
}
.wine-single__layout {
  display: grid;
  grid-template-columns: 34% 1fr 200px;
  grid-template-areas: "bottle details sidebar";
  gap: var(--spacing-xl);
  align-items: start;
}
.wine-single__layout--no-sidebar {
  grid-template-columns: 34% 1fr;
  grid-template-areas: "bottle details";
}
@media (max-width: 900px) {
  .wine-single__layout {
    grid-template-columns: 250px 1fr;
    grid-template-areas: "bottle details" "bottle sidebar";
  }
}
@media (max-width: 640px) {
  .wine-single__layout {
    grid-template-columns: 1fr;
    grid-template-areas: "bottle" "details" "sidebar";
  }
}
.wine-single__bottle {
  grid-area: bottle;
  aspect-ratio: 2 / 3;
  background: radial-gradient(circle, #ffffff 55%, transparent 55%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.wine-single__bottle-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  mix-blend-mode: multiply;
}
.wine-single__bottle-img--placeholder {
  opacity: 0.4;
  mix-blend-mode: normal;
}
.wine-single__details {
  grid-area: details;
  padding-top: var(--spacing-sm);
}
.wine-single__producer-logo-wrap {
  margin-bottom: var(--spacing-md);
}
.wine-single__producer-logo {
  max-width: none;
  max-height: 100px;
  width: auto;
  height: auto;
  display: block;
}
.wine-single__title {
  font-family: var(--font-primary);
  font-size: var(--font-size-2xl);
  font-weight: 400;
  margin: 0 0 var(--spacing-xs) 0;
  text-align: left;
  line-height: 1.2;
}
@media (min-width: 641px) {
  .wine-single__title {
    font-size: clamp(1.5rem, 3vw, 2.25rem);
  }
}
.wine-single__producer-name {
  font-size: var(--font-size-small);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-text-light);
  margin: 0 0 var(--spacing-md) 0;
}
.wine-single__producer-name a {
  color: inherit;
  text-decoration: none;
}
.wine-single__producer-name a:hover {
  color: var(--color-gold-primary, #C6A64B);
}
.wine-single__vintage-subtitle {
  font-family: var(--font-primary);
  font-size: var(--font-size-xl);
  font-weight: 400;
  color: var(--color-text-light);
  margin: 0 0 var(--spacing-lg) 0;
}
.wine-single__eyebrow {
  display: block;
  font-size: var(--font-size-small);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-text-muted);
  font-family: var(--font-secondary, sans-serif);
  margin-bottom: var(--spacing-xs);
}
.wine-single__field {
  margin-bottom: var(--spacing-md);
  padding-bottom: var(--spacing-md);
  border-bottom: 1px solid rgba(198, 166, 75, 0.25);
}
.wine-single__field:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}
.wine-single__field-value {
  font-family: var(--font-primary);
  font-size: 1.05rem;
  color: var(--color-text);
  margin: 0;
  line-height: 1.5;
}
.wine-single__description {
  color: var(--color-text);
  line-height: 1.75;
  font-size: var(--font-size-base);
}
.wine-single__description p {
  margin-bottom: var(--spacing-sm);
}
.wine-single__description p:last-child {
  margin-bottom: 0;
}
.wine-single__meta {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
  padding-bottom: var(--spacing-md);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--spacing-md);
}
.wine-single__meta-type {
  font-size: var(--font-size-small);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-text-muted);
  font-family: var(--font-secondary, sans-serif);
}
.wine-single__meta-producer {
  font-family: var(--font-primary);
  font-size: 1.05rem;
  color: var(--color-text);
  margin: 0;
}
.wine-single__meta-producer a {
  color: inherit;
  text-decoration: none;
}
.wine-single__meta-producer a:hover {
  color: var(--color-gold-primary, #C6A64B);
}
.wine-single__meta-location {
  font-size: var(--font-size-small);
  color: var(--color-text-muted);
  margin: 0;
}
.wine-single__sidebar {
  grid-area: sidebar;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}
.wine-single__label-image {
  text-align: center;
}
.wine-single__label-img {
  display: block;
  width: auto;
  max-width: fit-content;
  height: auto;
  margin: 0 auto;
  border-radius: 2px;
}
.wine-single__downloads {
  padding-top: 0;
}
.wine-single__downloads-heading {
  font-size: var(--font-size-small);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-text-muted);
  margin: 0 0 var(--spacing-sm) 0;
  font-family: var(--font-secondary, sans-serif);
}
.wine-single__download-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}
.wine-single__download-item {
  display: block;
}
.wine-single__download-link {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  font-size: var(--font-size-small);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  line-height: 1.2em;
  color: var(--color-text);
  text-decoration: none;
  padding: var(--spacing-xs) 0;
}
.wine-single__download-link:hover {
  color: var(--color-gold-primary, #C6A64B);
}
.wine-single__download-icon {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  width: auto;
  height: 2rem;
  color: var(--color-gold-dark, #9E7C2F);
}
.wine-single__download-icon svg {
  width: auto;
  height: 100%;
  display: block;
  fill: currentColor;
}
.wine-single__description h2,
.wine-single__description h3,
.wine-single__description h4,
.wine-single__description h5,
.wine-single__description h6 {
  text-align: left;
  font-size: 1.3em;
  margin-top: var(--spacing-md);
  margin-bottom: var(--spacing-xs);
}
.wine-single__more .section-header {
  margin-bottom: var(--spacing-lg);
}
.wine-single__back-link {
  text-align: center;
  margin-top: var(--spacing-xl);
}
.wine-archive {
  padding-top: 0;
}
.post-type-archive-dswg_wine .site-main {
  padding-top: 0;
}
.wine-archive__header {
  position: relative;
  background-color: var(--color-wine-red);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
}
.wine-archive__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.2);
  z-index: 0;
}
.wine-archive__header-inner {
  position: relative;
  z-index: 1;
  width: 100%;
  padding: 0;
}
.wine-archive__header-inner .section-header__label {
  color: rgba(255, 255, 255, 0.75);
}
.wine-archive__header-inner .section-header__title,
.wine-archive__header-inner .section-header__desc {
  color: #fff;
}
.wine-archive__header-inner .section-header {
  margin: var(--spacing-2xl) var(--spacing-2xl) var(--spacing-xl);
}
.wine-archive__results.section {
  padding-top: var(--spacing-2xl);
  padding-bottom: var(--spacing-2xl);
}
.wine-grid__empty {
  color: var(--color-text-muted);
  font-style: italic;
  padding: var(--spacing-xl) 0;
  text-align: center;
  grid-column: 1 / -1;
}
.wine-card__producer {
  margin: 0;
  font-size: var(--font-size-base, 1rem);
  color: var(--color-text-muted);
  font-style: italic;
}
.wine-panel__field--producer {
  margin-bottom: var(--spacing-sm);
  padding-bottom: var(--spacing-sm);
  border-bottom: 1px solid var(--color-border);
}
.wine-panel__producer-link {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  color: var(--color-wine-red);
  text-decoration: none;
  font-weight: 600;
}
.wine-panel__producer-link:hover {
  text-decoration: underline;
}
.wine-panel__producer-loc {
  font-weight: 400;
  color: var(--color-text-muted);
}
.producer-filter__field--clear {
  flex: 0 0 auto;
  justify-content: flex-end;
  padding-bottom: 0;
}
.wine-filter__clear {
  padding: 0.4em 1.25em;
  font-size: var(--font-size-small, 0.8rem);
  letter-spacing: 0.1em;
  white-space: nowrap;
}
@keyframes dswg-shimmer {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}
.wine-grid--skeleton {
  pointer-events: none;
}
.wine-card--skeleton .wine-card__bottle--skeleton {
  background: linear-gradient(90deg, var(--color-background-alt) 25%, var(--color-border) 50%, var(--color-background-alt) 75%);
  background-size: 200% 100%;
  animation: dswg-shimmer 1.4s ease-in-out infinite;
}
.wine-card--skeleton .wine-card__skeleton-line {
  border-radius: 2px;
  background: linear-gradient(90deg, var(--color-background-alt) 25%, var(--color-border) 50%, var(--color-background-alt) 75%);
  background-size: 200% 100%;
  animation: dswg-shimmer 1.4s ease-in-out infinite;
}
.wine-card--skeleton .wine-card__skeleton-line--title {
  height: 10px;
  width: 80%;
  margin-bottom: 6px;
}
.wine-card--skeleton .wine-card__skeleton-line--sub {
  height: 8px;
  width: 55%;
}
