:root {
  --color-bg: #f3eada;
  --color-bg-light: #fbf9f3;
  --color-bg-beige: #f2ead7;
  --color-bg-cream-warm: #f2e9d8;
  --color-bg-white: #ffffff;
  --color-text: #212529;
  --color-text-darkest: #141412;
  --color-text-near-black: #1d1d1d;
  --color-text-muted: #4a5859;
  --color-accent-sage: #b4c4ae;
  --color-accent-sage-hover: #9fb199;
  --color-accent-brown: #af806e;
  --color-accent-yellow: #efdd8d;
  --color-border-subtle: #e8e8e8;
  --color-error: var(--color-accent-brown);
  --color-error-red: #fb2c36;
  --color-accent-yellow-hover: #decd83;
  --color-accent-sage-active: #8aa086;
  --color-overlay-subtle: rgba(33, 37, 41, 0.04);
  --color-primary-hover: #2d3237;
  --color-primary-active: #1a1d20;
  --font-display:
    "Platform", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  --font-body: "Recoleta", Georgia, "Times New Roman", serif;
  --fs-h1: 90px;
  --lh-h1: 1;
  --fs-h2: 60px;
  --lh-h2: 1;
  --fs-h3: 40px;
  --lh-h3: 1.1;
  --fs-h4: 32px;
  --lh-h4: 1.1;
  --fs-h5: 28px;
  --lh-h5: 1.1;
  --fs-h6: 20px;
  --lh-h6: 1.1;
  --fs-body-20: 20px;
  --fs-body-16: 16px;
  --fs-body-14: 14px;
  --fs-caption: 12px;
  --fs-nav: 16px;
  --lh-nav: 1.1;
  --fs-button-l: 20px;
  --lh-button: 24px;
  --fs-h1-mob: 40px;
  --lh-h1-mob: 50px;
  --fs-h2-mob: 32px;
  --fs-h3-mob: 28px;
  --fs-h4-mob: 24px;
  --fs-h5-mob: 20px;
  --fs-h6-mob: 16px;
  --fs-body-blog-mob: 18px;
  --fs-button-mob: 16px;
  --space-2: 2px;
  --space-4: 4px;
  --space-5: 5px;
  --space-8: 8px;
  --space-10: 10px;
  --space-12: 12px;
  --space-14: 14px;
  --space-16: 16px;
  --space-20: 20px;
  --space-24: 24px;
  --space-32: 32px;
  --space-40: 40px;
  --space-48: 48px;
  --space-64: 64px;
  --space-80: 80px;
  --space-96: 96px;
  --space-128: 128px;
  --radius-card: 20px;
  --radius-pill: 50px;
  --radius-tag: 9999px;
  --radius-full: 9999px;
  --radius-section: 50px;
  --shadow-popover: 0 4px 24px rgba(0, 0, 0, 0.08);
  --shadow-drawer: 0 -8px 32px rgba(0, 0, 0, 0.12);
  --transition-fast: 0.1s ease;
  --transition-normal: 0.16s ease;
  --transition-slow: 0.22s ease;
  --transition-panel: 0.28s cubic-bezier(0.22, 1, 0.36, 1);
  --bp-mobile-max: 639px;
  --bp-tablet-min: 640px;
  --bp-tablet-max: 1023px;
  --bp-desktop-min: 1024px;
  --z-base: 0;
  --z-dropdown: 10;
  --z-sticky: 20;
  --z-fixed: 30;
  --z-backdrop: 40;
  --z-modal: 100;
  --z-drawer: 100;
  --z-tooltip: 110;
  --z-toast: 120;
}
*,
*:before,
*:after {
  box-sizing: border-box;
}
html {
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  text-size-adjust: 100%;
  line-height: 1.15;
}
body {
  margin: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
  display: block;
  max-width: 100%;
}
img {
  height: auto;
}
h1,
h2,
h3,
h4,
h5,
h6,
p,
figure,
blockquote,
dl,
dd {
  margin: 0;
}
button,
input,
select,
textarea {
  font: inherit;
  color: inherit;
}
button {
  cursor: pointer;
  border: none;
  background: transparent;
}
ul,
ol {
  padding: 0;
  margin: 0;
  list-style: none;
}
a {
  color: inherit;
  text-decoration: 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;
  }
}
html {
  scroll-behavior: smooth;
}
body {
  font-family: var(--font-body);
  font-size: var(--fs-body-16);
  line-height: 1.5;
  color: var(--color-text);
  background: var(--color-bg-light);
}
@media (max-width: 1023px) {
  html,
  body {
    overflow-x: hidden;
  }
}
*:focus-visible {
  outline: 2px solid var(--color-accent-sage);
  outline-offset: 2px;
  border-radius: var(--radius-pill);
}
.container {
  width: 100%;
  max-width: 1920px;
  margin-inline: auto;
  padding-inline: var(--space-24);
}
@media (min-width: 640px) {
  .container {
    padding-inline: var(--space-32);
  }
}
@media (min-width: 1024px) {
  .container {
    padding-inline: 60px;
  }
}
.visually-hidden {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.skip-link {
  position: absolute;
  top: -100px;
  left: 0;
  padding: var(--space-8) var(--space-16);
  background: var(--color-text);
  color: var(--color-bg-beige);
  z-index: 100;
  font-family: var(--font-display);
  font-size: var(--fs-nav);
}
.skip-link:focus-visible {
  top: 0;
}
@font-face {
  font-family: Platform;
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src:
    url(../fonts/Platform-Medium.woff2) format("woff2"),
    url(../fonts/Platform-Medium.woff) format("woff");
}
@font-face {
  font-family: Recoleta;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src:
    url(../fonts/Recoleta-Regular.woff2) format("woff2"),
    url(../fonts/Recoleta-Regular.woff) format("woff");
}
body {
  font-synthesis-weight: auto;
  font-synthesis-style: auto;
}
.h1 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h1);
  line-height: var(--lh-h1);
  color: var(--color-text);
}
@media (max-width: 639px) {
  .h1 {
    font-size: var(--fs-h1-mob);
    line-height: calc(var(--lh-h1-mob) / var(--fs-h1-mob));
  }
}
.h2 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h2);
  line-height: var(--lh-h2);
  color: var(--color-text);
}
@media (max-width: 639px) {
  .h2 {
    font-size: var(--fs-h2-mob);
  }
}
.h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h3);
  line-height: var(--lh-h3);
  color: var(--color-text);
}
@media (max-width: 639px) {
  .h3 {
    font-size: var(--fs-h3-mob);
    line-height: 1;
  }
}
.h4 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h4);
  line-height: var(--lh-h4);
  color: var(--color-text);
}
@media (max-width: 639px) {
  .h4 {
    font-size: var(--fs-h4-mob);
  }
}
.h5 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h5);
  line-height: var(--lh-h5);
  color: var(--color-text);
}
@media (max-width: 639px) {
  .h5 {
    font-size: var(--fs-h5-mob);
  }
}
.h6 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h6);
  line-height: var(--lh-h6);
  color: var(--color-text);
}
@media (max-width: 639px) {
  .h6 {
    font-size: var(--fs-h6-mob);
  }
}
h1 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h1);
  line-height: var(--lh-h1);
}
h2 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h2);
  line-height: var(--lh-h2);
}
h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h3);
  line-height: var(--lh-h3);
}
h4 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h4);
  line-height: var(--lh-h4);
}
h5 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h5);
  line-height: var(--lh-h5);
}
h6 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h6);
  line-height: var(--lh-h6);
}
.body-20 {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: var(--fs-body-20);
  line-height: 1.4;
  color: var(--color-text);
}
.body-16 {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: var(--fs-body-16);
  line-height: 1.5;
  color: var(--color-text);
}
.body-14 {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: var(--fs-body-14);
  line-height: 1.5;
  color: var(--color-text);
}
.caption {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: var(--fs-caption);
  line-height: 1.4;
  color: var(--color-text);
}
.caption--muted {
  color: var(--color-text-muted);
}
.nav-text {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-nav);
  line-height: var(--lh-nav);
  color: var(--color-text);
}
.button-text-l {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-button-l);
  line-height: var(--lh-button);
}
.prose {
  max-width: 680px;
  line-height: 1.6;
}
.prose p + p {
  margin-top: 1em;
}
.prose h2 {
  margin-top: 2em;
  margin-bottom: 0.5em;
}
.prose h3 {
  margin-top: 1.5em;
  margin-bottom: 0.4em;
}
.prose h4 {
  margin-top: 1.2em;
  margin-bottom: 0.3em;
}
.prose a {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.prose ul,
.prose ol {
  padding-left: 1.5em;
}
.prose ul {
  list-style: disc;
}
.prose ol {
  list-style: decimal;
}
.prose li + li {
  margin-top: 0.4em;
}
@media (max-width: 639px) {
  .prose,
  .body-blog {
    font-size: var(--fs-body-blog-mob);
    line-height: 1.6;
  }
}
.icon {
  display: inline-block;
  vertical-align: middle;
  flex-shrink: 0;
  fill: currentColor;
  stroke: currentColor;
  line-height: 1;
}
.btn .icon,
.icon-btn .icon {
  vertical-align: -0.125em;
}
.product-card__stars .icon--star-fill,
.review-card__stars .icon--star-fill,
.cross-sell__stars .icon--star-fill {
  color: var(--color-accent-yellow);
  fill: var(--color-accent-yellow);
  stroke: none;
}
.product-card__stars .icon--star-empty,
.review-card__stars .icon--star-empty,
.cross-sell__stars .icon--star-empty {
  color: color-mix(in srgb, var(--color-accent-yellow) 40%, white);
  fill: none;
  stroke: currentColor;
}
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-8);
  font-family: var(--font-display);
  font-weight: 500;
  line-height: var(--lh-button);
  border: 2px solid transparent;
  border-radius: var(--radius-pill);
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition:
    background-color var(--transition-normal),
    color var(--transition-normal),
    border-color var(--transition-normal),
    transform var(--transition-fast);
  user-select: none;
}
.btn[data-size="s"] {
  padding: 6px var(--space-24);
  font-size: var(--fs-body-16);
  line-height: 24px;
}
.btn[data-size="m"] {
  padding: 9px var(--space-32);
  font-size: var(--fs-button-l);
  line-height: var(--lh-button);
}
.btn[data-size="l"] {
  padding: 16px 48px;
  font-size: var(--fs-button-l);
  line-height: var(--lh-button);
}
@media (max-width: 767px) {
  .btn[data-size="m"] {
    padding: 6px var(--space-24);
    font-size: var(--fs-button-mob);
  }
  .btn[data-size="l"] {
    padding: 9px var(--space-32);
    font-size: var(--fs-button-mob);
  }
  .filter-drawer .btn[data-size="l"],
  .woocommerce-cart .btn[data-size="l"],
  .woocommerce-cart button[type="submit"],
  .woocommerce-cart .button,
  .minicart .btn[data-size="l"],
  .minicart .button {
    padding: 9px var(--space-24);
    font-size: var(--fs-button-mob);
    line-height: var(--lh-button);
  }
}
.btn[data-variant="primary"] {
  background: var(--color-text);
  color: var(--color-bg-beige);
  border-color: var(--color-text);
}
.btn[data-variant="primary"]:hover:not(:disabled):not([aria-disabled="true"]) {
  background: var(--color-primary-hover);
  border-color: var(--color-primary-hover);
}
.btn[data-variant="primary"]:active:not(:disabled):not([aria-disabled="true"]) {
  background: var(--color-primary-active);
  border-color: var(--color-primary-active);
}
.btn[data-variant="secondary"] {
  background: var(--color-accent-sage);
  color: var(--color-text);
  border-color: var(--color-accent-sage);
  height: auto;
  min-height: 44px;
  padding: 10px 24px;
  font-size: 16px;
  line-height: 24px;
}
.btn[data-variant="secondary"]:hover:not(:disabled):not(
    [aria-disabled="true"]
  ) {
  background: var(--color-accent-sage-hover);
  border-color: var(--color-accent-sage-hover);
}
.btn[data-variant="secondary"]:active:not(:disabled):not(
    [aria-disabled="true"]
  ) {
  background: var(--color-accent-sage-active);
  border-color: var(--color-accent-sage-active);
}
.btn[data-variant="outline"] {
  background: transparent;
  color: var(--color-text);
  border-color: var(--color-text);
}
.btn[data-variant="outline"]:hover:not(:disabled):not([aria-disabled="true"]) {
  background: var(--color-text);
  color: var(--color-bg-beige);
}
.btn[data-variant="outline"]:active:not(:disabled):not([aria-disabled="true"]) {
  background: var(--color-primary-active);
  border-color: var(--color-primary-active);
  color: var(--color-bg-beige);
}
.btn[data-variant="ghost"] {
  background: transparent;
  color: var(--color-text);
  border-color: transparent;
}
.btn[data-variant="ghost"]:hover:not(:disabled):not([aria-disabled="true"]) {
  text-decoration: underline;
  text-underline-offset: 4px;
}
.btn:active:not(:disabled):not([aria-disabled="true"]) {
  transform: translateY(1px);
}
.btn:disabled,
.btn[aria-disabled="true"] {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}
.btn:focus-visible {
  outline: 2px solid var(--color-accent-sage);
  outline-offset: 2px;
}
.input-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  width: 100%;
}
.input-field__label {
  font-family: var(--font-body);
  font-size: var(--fs-caption);
  color: var(--color-text);
}
.input-field__required {
  color: var(--color-error);
  margin-left: 2px;
}
.input {
  width: 100%;
  height: 52px;
  padding: var(--space-12) var(--space-16);
  background: var(--color-bg-white);
  border: 2px solid var(--color-accent-sage);
  border-radius: var(--radius-pill);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-16);
  color: var(--color-text);
  outline: none;
  transition: border-color 0.16s ease;
}
.input::placeholder {
  color: var(--color-accent-sage);
  font-family: var(--font-display);
  font-weight: 500;
  opacity: 1;
}
.input:focus {
  border-color: var(--color-text-muted);
}
.input:focus::placeholder {
  color: var(--color-text-muted);
}
.input[aria-invalid="true"] {
  border-color: #fb2c36;
  background: var(--color-bg-light);
}
.input[aria-invalid="true"]::placeholder {
  color: var(--color-text-muted);
}
.input:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  background: var(--color-bg-light);
  border-color: transparent;
}
.input:disabled::placeholder {
  color: var(--color-text-muted);
}
.input-field__error {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
  color: #fb2c36;
  margin: 0;
}
.input-field__help {
  font-family: var(--font-body);
  font-size: var(--fs-caption);
  color: var(--color-text-muted);
  margin: 0;
}
.link {
  color: var(--color-text);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  transition: color 0.16s ease;
}
.link:hover {
  color: var(--color-accent-sage-hover);
}
.link:focus-visible {
  outline: 2px solid var(--color-accent-sage);
  outline-offset: 2px;
  border-radius: 2px;
}
.link--nav {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-nav);
  line-height: var(--lh-nav);
  color: var(--color-text);
  text-decoration: none;
}
.link--nav:hover {
  color: var(--color-accent-sage-hover);
}
.link--footer {
  font-family: var(--font-body);
  font-size: var(--fs-body-14);
  color: var(--color-text);
  text-decoration: none;
}
.link--footer:hover {
  text-decoration: underline;
}
.icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  border-radius: var(--radius-full);
  color: var(--color-text);
  text-decoration: none;
  cursor: pointer;
  transition:
    background-color 0.16s ease,
    transform 0.1s ease;
  position: relative;
}
.icon-btn[data-size="xs"],
.icon-btn[data-size="s"] {
  width: 24px;
  height: 24px;
}
.icon-btn[data-size="m"] {
  width: 36px;
  height: 36px;
}
.icon-btn[data-size="l"] {
  width: 48px;
  height: 48px;
}
.icon-btn:hover:not(:disabled):not([aria-disabled="true"]) {
  background: var(--color-bg-beige);
}
.icon-btn--accent {
  background: var(--color-accent-yellow);
}
.icon-btn--accent:hover:not(:disabled):not([aria-disabled="true"]) {
  background: #decd83;
}
.icon-btn--utility {
  background: var(--color-accent-yellow);
}
.icon-btn--utility:hover:not(:disabled):not([aria-disabled="true"]),
.icon-btn--utility.is-hover {
  background: var(--color-bg-beige);
}
.icon-btn--utility .icon--delete {
  color: var(--color-accent-brown);
}
.icon-btn--menu {
  width: 48px;
  height: 48px;
  background: var(--color-accent-yellow);
}
.icon-btn--menu:hover:not(:disabled):not([aria-disabled="true"]),
.icon-btn--menu.is-hover {
  background: var(--color-accent-yellow);
}
.icon-btn--social {
  background: transparent;
  color: var(--color-text);
}
.icon-btn--social:hover:not(:disabled):not([aria-disabled="true"]),
.icon-btn--social.is-hover {
  background: var(--color-accent-sage-hover);
}
.icon-btn.is-hover.icon-btn--accent {
  background: #decd83;
}
.icon-btn:active,
.icon-btn.is-pressed {
  transform: scale(0.95);
}
.icon-btn:disabled,
.icon-btn[aria-disabled="true"] {
  opacity: 0.5;
  cursor: not-allowed;
}
.icon-btn:focus-visible {
  outline: 2px solid var(--color-accent-sage);
  outline-offset: 2px;
}
.icon-btn .icon {
  display: inline-flex;
}
.picker-group {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  padding: 0 12px;
  border: none;
  margin: 0;
}
.picker {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--color-bg-beige);
  border-radius: var(--radius-full);
  cursor: pointer;
  font-family: var(--font-display);
  font-weight: 500;
  line-height: 24px;
  background: transparent;
  color: var(--color-text);
  transition:
    border-color 0.16s ease,
    background-color 0.16s ease,
    color 0.16s ease;
  user-select: none;
  box-sizing: border-box;
}
.picker-group[data-size="l"] .picker {
  width: 32px;
  height: 32px;
  font-size: 16px;
}
.picker-group[data-size="s"] .picker {
  width: 24px;
  height: 24px;
  font-size: 12px;
  border-width: 0;
}
.picker:hover:not([data-state="inactive"]) {
  border-width: 2px;
  border-color: var(--color-text);
}
.picker:has(.picker__input:checked) {
  background: var(--color-text);
  color: var(--color-bg-light);
  border-color: var(--color-text);
  border-width: 2px;
}
.picker:active:not([data-state="inactive"]):has(.picker__input:checked) {
  background: #1a1d20;
  border-color: #1a1d20;
}
.picker[data-state="inactive"] {
  color: #2125294d;
  border-color: transparent;
  cursor: not-allowed;
  text-decoration: line-through;
}
.picker[data-state="inactive"]:hover,
[data-picker-type="colour"] .picker {
  border-color: transparent;
}
[data-picker-type="colour"] .picker[data-state="selected"],
[data-picker-type="colour"] .picker:has(.picker__input:checked) {
  border-color: var(--color-text);
  outline: 2px solid var(--color-bg-light);
  outline-offset: -4px;
}
[data-picker-type="colour"] .picker:has(.picker__input:checked) {
  background: inherit;
}
.picker:has(.picker__input:focus-visible) {
  outline: 2px solid var(--color-accent-sage);
  outline-offset: 2px;
}
.checkbox-wrapper {
  display: inline-flex;
  align-items: center;
  gap: var(--space-8);
  cursor: pointer;
  font-family: var(--font-body);
  font-size: var(--fs-body-16);
  color: var(--color-text);
  user-select: none;
}
.checkbox-wrapper:has(.checkbox-input:disabled) {
  cursor: not-allowed;
}
.checkbox {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  background: transparent;
  border: 0;
  padding: 0;
}
.checkbox:before {
  content: "";
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: transparent;
  border: 1.5px solid var(--color-text);
  box-sizing: border-box;
  transition:
    background-color 0.16s ease,
    border-color 0.16s ease;
}
.checkbox .icon {
  position: absolute;
  width: 14px;
  height: 14px;
  color: var(--color-bg-light);
  opacity: 0;
  transition: opacity 0.1s ease;
  pointer-events: none;
}
.checkbox-input:checked + .checkbox:before {
  background: var(--color-text);
  border-color: var(--color-text);
}
.checkbox-input:checked + .checkbox .icon {
  opacity: 1;
}
.checkbox[data-state="indeterminate"]:before {
  background: var(--color-text);
  border-color: var(--color-text);
}
.checkbox[data-state="indeterminate"] .icon {
  opacity: 1;
}
.checkbox-input:disabled + .checkbox:before {
  background: var(--color-accent-sage);
  border-color: var(--color-accent-sage);
}
.checkbox-input:disabled + .checkbox .icon {
  opacity: 1;
}
.checkbox[data-state="warning"]:before {
  background: transparent;
  border-color: #fb2c36;
  border-width: 1.5px;
}
.checkbox[data-state="warning"] .icon {
  opacity: 0;
}
.checkbox-input:checked + .checkbox[data-state="warning"]:before {
  background: transparent;
  border-color: #fb2c36;
}
.checkbox-input:checked + .checkbox[data-state="warning"] .icon {
  opacity: 0;
}
.checkbox-wrapper:hover:not(:has(.checkbox-input:disabled))
  .checkbox-input:not(:checked)
  + .checkbox:not([data-state="warning"]):before {
  border-color: var(--color-text);
  background: #2125290a;
}
.checkbox-input:focus-visible + .checkbox:before {
  outline: 2px solid var(--color-text);
  outline-offset: 2px;
}
.radio-wrapper {
  display: inline-flex;
  align-items: center;
  gap: var(--space-8);
  cursor: pointer;
  font-family: var(--font-body);
  font-size: var(--fs-body-16);
  color: var(--color-text);
  user-select: none;
}
.radio-wrapper:has(.radio-input:disabled) {
  cursor: not-allowed;
}
.radio {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  background: transparent;
}
.radio:before {
  content: "";
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: transparent;
  border: 1.5px solid var(--color-text);
  box-sizing: border-box;
  transition:
    background-color 0.16s ease,
    border-color 0.16s ease;
}
.radio:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-bg-light);
  opacity: 0;
  transition: opacity 0.15s ease;
  pointer-events: none;
}
.radio-input:checked + .radio:before {
  background: var(--color-text);
  border-color: var(--color-text);
}
.radio-input:checked + .radio:after {
  opacity: 1;
}
.radio-input:disabled:checked + .radio:before {
  background: var(--color-accent-sage);
  border-color: var(--color-accent-sage);
}
.radio-input:disabled:not(:checked) + .radio:before {
  background: transparent;
  border-color: var(--color-accent-sage);
}
.radio[data-state="warning"]:before {
  background: transparent;
  border-color: #fb2c36;
}
.radio[data-state="warning"]:after {
  opacity: 0;
}
.radio-input:checked + .radio[data-state="warning"]:before {
  background: transparent;
  border-color: #fb2c36;
}
.radio-input:checked + .radio[data-state="warning"]:after {
  opacity: 0;
}
.radio-wrapper:hover:not(:has(.radio-input:disabled))
  .radio-input:not(:checked)
  + .radio:not([data-state="warning"]):before {
  background: #2125290a;
}
.radio-input:focus-visible + .radio:before {
  outline: 2px solid var(--color-text);
  outline-offset: 2px;
}
.tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  height: 24px;
  background: var(--color-text-muted);
  color: var(--color-bg-beige);
  border: 2px solid transparent;
  border-radius: var(--radius-tag);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 14px;
  line-height: 24px;
  white-space: nowrap;
}
.tag[data-variant="outline"] {
  background: transparent;
  border-color: var(--color-text);
  color: var(--color-text);
}
.tag[data-color="yellow"] {
  background: var(--color-accent-yellow);
  color: var(--color-text);
}
.tag[data-color="brown"] {
  background: var(--color-accent-brown);
  color: var(--color-bg-beige);
}
.tag[data-color="sage"] {
  background: var(--color-accent-sage);
  color: var(--color-text);
}
.tag[data-color="muted"] {
  background: var(--color-text-muted);
  color: var(--color-bg-beige);
}
.tag[data-variant="outline"][data-color="yellow"] {
  border-color: var(--color-accent-yellow);
  color: var(--color-accent-brown);
}
.tag[data-variant="outline"][data-color="brown"] {
  border-color: var(--color-accent-brown);
  color: var(--color-accent-brown);
}
.tag[data-variant="outline"][data-color="sage"] {
  border-color: var(--color-accent-sage);
  color: var(--color-accent-sage-hover);
}
.rating {
  display: flex;
  align-items: center;
  gap: var(--space-8);
}
.rating__stars {
  display: flex;
  gap: 2px;
}
.rating__stars svg {
  color: var(--color-accent-yellow);
}
.rating__value {
  font-family: var(--font-body);
  font-size: var(--fs-caption);
  line-height: 1;
  color: var(--color-text-darkest);
}
.newsletter {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  max-width: 360px;
  height: 52px;
  background: var(--color-bg-white);
  border: 2px solid var(--color-accent-sage);
  border-radius: var(--radius-pill);
  padding: 0 4px 0 16px;
  box-sizing: border-box;
  transition:
    border-color 0.16s ease,
    background-color 0.16s ease;
}
.newsletter:focus-within {
  border-color: var(--color-text-muted);
}
.newsletter:focus-within .newsletter__submit {
  background: var(--color-text);
}
.newsletter[data-state="error"] {
  border-color: #fb2c36;
  background: var(--color-bg-light);
}
.newsletter__input {
  flex: 1;
  min-width: 0;
  border: none;
  background: transparent;
  padding: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-16);
  color: var(--color-text);
  outline: none;
}
.newsletter__input::placeholder {
  color: var(--color-accent-sage);
  font-family: var(--font-display);
  font-weight: 500;
  opacity: 1;
}
.newsletter:focus-within .newsletter__input::placeholder {
  color: var(--color-text-muted);
}
.newsletter__submit {
  width: 44px;
  height: 44px;
  flex-shrink: 0;
  background: var(--color-accent-sage);
  color: var(--color-text);
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.16s ease;
}
.newsletter__submit:hover {
  background: var(--color-accent-sage-hover);
}
.newsletter[data-state="error"] .newsletter__submit {
  background: var(--color-text);
  opacity: 0.5;
}
.newsletter__submit:focus-visible {
  outline: 2px solid var(--color-text-muted);
  outline-offset: 2px;
}
.newsletter__legal {
  position: absolute;
  top: calc(100% + var(--space-8));
  left: 0;
  right: 0;
  margin: 0;
}
.dropdown {
  position: relative;
  display: inline-block;
  min-width: 240px;
}
.dropdown__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-8);
  width: 100%;
  height: 52px;
  padding: 0 var(--space-16);
  background: var(--color-bg-white);
  border: 2px solid var(--color-accent-sage);
  border-radius: var(--radius-pill);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-16);
  color: var(--color-text-muted);
  cursor: pointer;
  transition: border-color 0.16s ease;
  box-sizing: border-box;
}
.dropdown__trigger:focus-visible,
.dropdown__trigger[aria-expanded="true"] {
  border-color: var(--color-text-muted);
  outline: none;
}
.dropdown__trigger .icon {
  transition: transform 0.2s ease;
}
.dropdown__trigger[aria-expanded="true"] .icon {
  transform: rotate(180deg);
}
.dropdown__panel {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  background: var(--color-bg-white);
  border: 2px solid var(--color-accent-sage);
  border-radius: var(--radius-card);
  padding: var(--space-8);
  margin: 0;
  list-style: none;
  z-index: var(--z-dropdown);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition:
    opacity 0.16s ease,
    visibility 0.16s ease,
    transform 0.16s ease;
  box-shadow: var(--shadow-popover);
  max-height: 300px;
  overflow-y: auto;
}
.dropdown[data-state="open"] .dropdown__panel {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.dropdown__option {
  padding: var(--space-12) var(--space-16);
  border-radius: var(--radius-pill);
  font-family: var(--font-display);
  font-weight: 500;
  color: var(--color-text);
  cursor: pointer;
  transition: background-color 0.16s ease;
}
.dropdown__option:hover,
.dropdown__option:focus-visible {
  background: var(--color-bg-beige);
  outline: none;
}
.dropdown__option[aria-selected="true"] {
  background: var(--color-accent-sage);
}
.search-form {
  display: flex;
  align-items: center;
  gap: var(--space-12);
  width: 100%;
  height: 52px;
  padding: 0 var(--space-16);
  background: var(--color-bg-white);
  border: 2px solid var(--color-accent-sage);
  border-radius: var(--radius-pill);
  transition: border-color 0.16s ease;
}
.search-form:focus-within {
  border-color: var(--color-text-muted);
}
.search-form .icon {
  color: var(--color-text-muted);
}
.search-form__input {
  flex: 1;
  min-width: 0;
  border: none;
  background: transparent;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-16);
  color: var(--color-text);
  outline: none;
}
.search-form__input::placeholder {
  color: var(--color-text-muted);
}
.accordion {
  border: 2px solid var(--color-bg-beige);
  border-radius: 10px;
  background: transparent;
  overflow: hidden;
  transition: border-color 0.16s ease;
  interpolate-size: allow-keywords;
}
.accordion + .accordion {
  margin-top: 12px;
}
.accordion::details-content {
  height: 0;
  overflow: clip;
  opacity: 0;
  transition:
    height 0.35s cubic-bezier(0.32, 0.72, 0, 1),
    opacity 0.25s ease,
    content-visibility 0.35s cubic-bezier(0.32, 0.72, 0, 1) allow-discrete;
}
.accordion[open]::details-content {
  height: auto;
  opacity: 1;
}
@media (prefers-reduced-motion: reduce) {
  .accordion::details-content {
    transition: none;
  }
}
.accordion__summary {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-16);
  cursor: pointer;
  padding: 12px 20px;
  min-height: 52px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 20px;
  line-height: 1.1;
  color: var(--color-text);
  transition: background-color 0.16s ease;
  box-sizing: border-box;
}
.accordion__summary::-webkit-details-marker {
  display: none;
}
.accordion__summary:hover {
  background: var(--color-bg-light);
}
.accordion__summary:focus-visible {
  outline: 2px solid var(--color-accent-sage);
  outline-offset: 2px;
  border-radius: 10px;
}
.accordion[data-size="l"] .accordion__summary {
  padding: 16px 20px;
  font-size: 24px;
  min-height: 60px;
}
.accordion__icon {
  position: relative;
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.accordion__icon:before,
.accordion__icon:after {
  content: "";
  position: absolute;
  background: currentColor;
  border-radius: 2px;
  transition: transform 0.35s cubic-bezier(0.32, 0.72, 0, 1);
}
.accordion__icon:before {
  inset: 50% 4px;
  height: 2px;
  transform: translateY(-50%);
}
.accordion__icon:after {
  inset: 4px 50%;
  width: 2px;
  transform: translate(-50%);
}
.accordion[open] .accordion__icon:after {
  transform: translate(-50%) rotate(90deg);
}
.accordion__content {
  padding: 0 20px 20px;
  font-family: var(--font-body);
  font-size: var(--fs-body-16);
  line-height: 1.6;
  color: var(--color-text);
}
[data-component="arrow"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.2s ease;
}
[data-component="arrow"]:hover {
  transform: translate(4px);
}
[data-component="arrow"][data-direction="left"]:hover {
  transform: translate(-4px);
}
[data-component="arrow"][data-direction="up"]:hover {
  transform: translateY(-4px);
}
[data-component="arrow"][data-direction="down"]:hover {
  transform: translateY(4px);
}
.qty-stepper {
  display: inline-flex;
  align-items: stretch;
  width: 119px;
  height: 33px;
  border: 2px solid var(--color-accent-sage);
  border-radius: var(--radius-pill);
  background: var(--color-bg-white);
  overflow: hidden;
  transition: border-color 0.16s ease;
}
.qty-stepper:focus-within {
  border-color: var(--color-accent-sage-hover);
}
.qty-stepper__btn {
  width: 42px;
  border: none;
  background: transparent;
  color: var(--color-text);
  cursor: pointer;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-20);
  line-height: 1;
  transition: background-color 0.12s ease;
}
.qty-stepper__btn:hover:not(:disabled) {
  background: var(--color-bg-beige);
}
.qty-stepper__btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}
.qty-stepper__btn:focus-visible {
  outline: 2px solid var(--color-accent-sage);
  outline-offset: -2px;
}
.qty-stepper__input {
  flex: 1;
  min-width: 0;
  border: none;
  background: transparent;
  text-align: center;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-16);
  color: var(--color-text);
  outline: none;
  -moz-appearance: textfield;
}
.qty-stepper__input::-webkit-outer-spin-button,
.qty-stepper__input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.progress {
  width: 93px;
  height: 5px;
  background: transparent;
  border-radius: var(--radius-full);
  overflow: visible;
  display: inline-flex;
}
.progress__bar {
  width: 5px !important;
  height: 5px;
  background: var(--color-accent-sage);
  border-radius: inherit;
  box-shadow:
    22px 0 0 var(--color-accent-sage),
    44px 0 0 var(--color-accent-sage),
    66px 0 0 var(--color-accent-sage),
    88px 0 0 var(--color-accent-sage);
}
.slider {
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
.slider__track {
  display: flex;
  gap: 30px;
  overflow-x: auto;
  overflow-y: visible;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  padding-block: 8px;
  padding-left: var(--space-24);
  scroll-padding-left: var(--space-24);
  padding-right: 0;
}
.slider__track::-webkit-scrollbar {
  display: none;
}
.slider__track > * {
  flex-shrink: 0;
  scroll-snap-align: start;
}
.slider__track > .product-card,
.slider__track .product-card {
  min-height: 460px;
}
.slider__track .product-card-slot {
  height: 460px;
}
@media (max-width: 1023px) {
  .slider__track > .product-card,
  .slider__track .product-card {
    min-height: 400px;
  }
  .slider__track .product-card-slot {
    height: 400px;
  }
}
@media (min-width: 640px) {
  .slider__track {
    padding-left: var(--space-32);
    scroll-padding-left: var(--space-32);
  }
}
@media (min-width: 1024px) {
  .slider__track {
    padding-left: max(48px, calc((100vw - 1920px) / 2 + 48px));
    scroll-padding-left: max(48px, calc((100vw - 1920px) / 2 + 48px));
  }
}
.slider__controls {
  width: 100%;
  max-width: 1920px;
  margin-inline: auto;
  margin-top: 32px;
  padding-inline: var(--space-24);
  box-sizing: border-box;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  column-gap: 24px;
}
@media (min-width: 640px) {
  .slider__controls {
    padding-inline: var(--space-32);
  }
}
@media (min-width: 1024px) {
  .slider__controls {
    padding-inline: var(--space-48);
  }
}
.slider__dots {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 15px;
  align-items: center;
  grid-column: 1;
  justify-self: start;
}
.slider__dot {
  border: 0;
  background: var(--color-accent-sage);
  cursor: pointer;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  padding: 0;
  transition: background-color 0.2s ease;
}
.slider__dot.is-active {
  background: var(--color-text-muted);
}
.slider__arrows {
  display: flex;
  align-items: center;
  gap: 8px;
  grid-column: 2;
  justify-self: center;
}
.slider__cta {
  grid-column: 3;
  justify-self: end;
}
.slider__arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border: 0;
  border-radius: 9999px;
  background: var(--color-bg-beige);
  color: var(--color-text);
  cursor: pointer;
  transition:
    background-color 0.16s ease,
    color 0.16s ease,
    transform 0.1s ease;
}
.slider__arrow:hover:not(:disabled) {
  background: var(--color-accent-sage);
  color: var(--color-bg-beige);
}
.slider__arrow:active {
  transform: scale(0.95);
}
.slider__arrow svg {
  width: 20px;
  height: 20px;
  pointer-events: none;
}
.slider__arrow:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
@media (max-width: 1023px) {
  .slider__controls {
    grid-template-columns: 1fr auto;
    row-gap: 16px;
  }
  .slider__dots {
    grid-column: 1;
    justify-self: start;
  }
  .slider__arrows {
    grid-column: 2;
    justify-self: end;
  }
  .slider__cta {
    grid-column: 1 / -1;
    justify-self: center;
  }
  .slider__arrow {
    width: 48px;
    height: 48px;
    flex: 0 0 48px;
  }
}
.cookie-banner {
  position: fixed;
  bottom: var(--space-20);
  left: var(--space-20);
  right: var(--space-20);
  z-index: 1000;
  max-width: 720px;
  margin-inline: auto;
  padding: var(--space-20);
  background: var(--color-bg-white);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-popover);
  transform: translateY(calc(100% + var(--space-20)));
  opacity: 0;
  transition:
    transform 0.3s cubic-bezier(0.25, 0.1, 0.25, 1),
    opacity 0.3s ease;
}
.cookie-banner--visible {
  transform: translateY(0);
  opacity: 1;
}
.cookie-banner--leaving {
  transform: translateY(calc(100% + var(--space-20)));
  opacity: 0;
}
.cookie-banner__inner {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-24);
  align-items: center;
}
@media (max-width: 767px) {
  .cookie-banner__inner {
    grid-template-columns: 1fr;
    gap: var(--space-16);
  }
}
.cookie-banner__title {
  margin: 0 0 var(--space-8);
}
.cookie-banner__desc {
  margin: 0;
  color: var(--color-text-muted);
}
.cookie-banner__desc .link {
  color: var(--color-text);
}
.cookie-banner__actions {
  display: flex;
  gap: var(--space-8);
  flex-wrap: wrap;
  align-items: center;
}
@media (max-width: 479px) {
  .cookie-banner__actions {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
  }
  .cookie-banner__actions .btn {
    justify-content: center;
    width: 100%;
  }
}
@media (prefers-reduced-motion: reduce) {
  .cookie-banner {
    transition: opacity 0.2s ease;
    transform: none;
  }
  .cookie-banner--visible,
  .cookie-banner--leaving {
    transform: none;
  }
}
.filter-drawer {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal, 1000);
}
.filter-drawer[hidden] {
  display: none;
}
.filter-drawer__backdrop {
  position: absolute;
  inset: 0;
  background: #0006;
  opacity: 0;
  transition: opacity 0.22s ease;
}
.filter-drawer[data-state="open"] .filter-drawer__backdrop {
  opacity: 1;
}
.filter-drawer__panel {
  position: absolute;
  top: 0;
  left: 0;
  width: 390px;
  max-width: 100%;
  height: 100%;
  background: var(--color-bg-light);
  display: flex;
  flex-direction: column;
  transform: translate(-100%);
  transition: transform 0.28s cubic-bezier(0.22, 1, 0.36, 1);
  box-shadow: 8px 0 24px #00000014;
}
.filter-drawer[data-state="open"] .filter-drawer__panel {
  transform: translate(0);
}
.filter-drawer__form {
  display: flex;
  flex-direction: column;
  height: 100%;
  margin: 0;
}
.filter-drawer__header {
  height: 58px;
  padding: 0 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}
.filter-drawer__title-wrap {
  display: flex;
  align-items: center;
  gap: 4px;
}
.filter-drawer__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 20px;
  line-height: 1;
  color: var(--color-text);
}
.filter-drawer__count {
  background: var(--color-text-muted, #4a5859);
  color: var(--color-bg-light);
  width: 16px;
  height: 16px;
  border-radius: 50px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 12px;
  line-height: 1;
}
.filter-drawer__count[hidden] {
  display: none;
}
.filter-drawer__close {
  width: 18px;
  height: 18px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--color-text);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.filter-drawer__close svg {
  width: 18px;
  height: 18px;
  display: block;
}
.filter-drawer__body {
  flex: 1 1 auto;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}
.filter-section {
  padding: 12px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.filter-section__title {
  margin: 0;
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 16px;
  line-height: 1;
  color: var(--color-text);
}
.filter-price {
  display: flex;
  flex-direction: column;
  gap: 13px;
  align-items: center;
  width: 100%;
}
.filter-price__track {
  position: relative;
  width: 100%;
  height: 16px;
}
.filter-price__track:before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  height: 8px;
  border: 1px solid var(--color-text);
  border-radius: 21px;
  background: transparent;
}
.filter-price__fill {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  height: 8px;
  background: var(--color-text);
  border-radius: 21px;
  pointer-events: none;
  left: 0;
  right: 0;
}
.filter-price__range {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 16px;
  background: transparent;
  pointer-events: none;
  -webkit-appearance: none;
  appearance: none;
  margin: 0;
}
.filter-price__range::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--color-bg-light);
  border: 1px solid var(--color-text);
  cursor: pointer;
  pointer-events: auto;
  box-shadow: 0 0 0 1px var(--color-text);
}
.filter-price__range::-moz-range-thumb {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--color-bg-light);
  border: 1px solid var(--color-text);
  cursor: pointer;
  pointer-events: auto;
  box-shadow: 0 0 0 1px var(--color-text);
}
.filter-price__range::-webkit-slider-runnable-track,
.filter-price__range::-moz-range-track {
  background: transparent;
  border: 0;
}
.filter-price__label {
  margin: 0;
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1;
  color: var(--color-text);
  letter-spacing: 0.03em;
  text-align: center;
}
.filter-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.filter-list__item {
  margin: 0;
}
.filter-checkbox,
.filter-radio {
  display: inline-flex;
  align-items: center;
  gap: 1px;
  padding: 2px 13px 2px 2px;
  border-radius: 149px;
  cursor: pointer;
  user-select: none;
  color: var(--color-text);
  text-decoration: none;
}
.filter-checkbox input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.filter-checkbox__box,
.filter-radio__dot {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.filter-checkbox__box:before,
.filter-radio__dot:before {
  content: "";
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 1.5px solid var(--color-text);
  box-sizing: border-box;
  transition: background-color 0.12s ease;
}
.filter-checkbox__box svg,
.filter-radio__dot svg {
  position: absolute;
  width: 14px;
  height: 14px;
  color: var(--color-bg-light);
  opacity: 0;
  transition: opacity 0.12s ease;
}
.filter-checkbox input:checked ~ .filter-checkbox__box:before,
.filter-radio[data-state="checked"] .filter-radio__dot:before {
  background: var(--color-text);
}
.filter-checkbox input:checked ~ .filter-checkbox__box svg,
.filter-radio[data-state="checked"] .filter-radio__dot svg {
  opacity: 1;
}
.filter-checkbox__label,
.filter-radio__label {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  line-height: 1;
}
.filter-sizes {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  width: 100%;
}
.filter-size {
  width: 32px;
  height: 32px;
  border-radius: 100px;
  border: 2px solid var(--color-bg-beige);
  background: transparent;
  box-sizing: border-box;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  line-height: 1;
  transition:
    background-color 0.12s ease,
    color 0.12s ease,
    border-color 0.12s ease;
}
.filter-size input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.filter-size[data-state="checked"],
.filter-size:has(input:checked) {
  background: var(--color-text);
  color: var(--color-bg-light);
  border-color: var(--color-text);
}
.filter-colors {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  width: 100%;
}
.filter-color {
  width: 32px;
  height: 32px;
  border-radius: 100px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  border: 2px solid transparent;
  transition: border-color 0.12s ease;
}
.filter-color input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.filter-color__swatch {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  box-shadow: inset 0 0 0 1px #0000000d;
}
.filter-color[data-state="checked"],
.filter-color:has(input:checked) {
  border-color: var(--color-text);
}
.filter-drawer__footer {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 10px 20px;
  background: var(--color-bg-light);
}
.filter-drawer__apply,
.filter-drawer__clear {
  width: 100%;
  justify-content: center;
}
body.has-filter-drawer-open {
  overflow: hidden;
}
@media (max-width: 480px) {
  .filter-drawer__panel {
    width: 100%;
  }
}
.minicart {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal, 1000);
}
.minicart[hidden] {
  display: none;
}
.minicart__backdrop {
  position: absolute;
  inset: 0;
  background: #0006;
  opacity: 0;
  transition: opacity 0.22s ease;
}
.minicart[data-state="open"] .minicart__backdrop {
  opacity: 1;
}
.minicart__panel {
  position: absolute;
  top: 0;
  right: 0;
  width: 390px;
  max-width: 100%;
  height: 100%;
  background: var(--color-bg-light);
  display: flex;
  flex-direction: column;
  transform: translate(100%);
  transition: transform 0.28s cubic-bezier(0.22, 1, 0.36, 1);
  box-shadow: -8px 0 24px #00000014;
}
.minicart[data-state="open"] .minicart__panel {
  transform: translate(0);
}
.minicart__header {
  height: 58px;
  padding: 0 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}
.minicart__title-wrap {
  display: flex;
  align-items: center;
  gap: 4px;
}
.minicart__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 20px;
  line-height: 1;
  color: var(--color-text);
}
.minicart__count {
  background: var(--color-text-muted, #4a5859);
  color: var(--color-bg-light);
  width: 16px;
  height: 16px;
  border-radius: 50px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 12px;
  line-height: 1;
}
.minicart__count[hidden] {
  display: none;
}
.minicart__close {
  width: 18px;
  height: 18px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--color-text);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.minicart__close svg {
  width: 18px;
  height: 18px;
  display: block;
}
.minicart__body {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 0;
}
.minicart__items {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.minicart__empty {
  margin: 0;
  padding: 40px 20px;
  text-align: center;
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: 16px;
}
.minicart__item {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  padding: 20px;
}
.minicart__item-thumb {
  flex-shrink: 0;
  width: 93px;
  height: 93px;
  border-radius: 10px;
  overflow: hidden;
  display: block;
}
.minicart__item-thumb img,
.minicart__item-thumb-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.minicart__item-body {
  flex: 1 1 0;
  min-width: 0;
  align-self: stretch;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 8px;
}
.minicart__item-info {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.minicart__item-title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  line-height: 1.25;
  color: var(--color-text);
}
.minicart__item-title a {
  color: inherit;
  text-decoration: none;
}
.minicart__item-title a:hover {
  text-decoration: underline;
}
.minicart__item-price {
  margin: 0;
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1;
  color: var(--color-text);
}
.minicart__item-price .amount {
  font-weight: 400;
}
.minicart__item-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.minicart__qty {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  height: 33px;
  padding: 0 5px;
  border: 2px solid var(--color-bg-beige);
  border-radius: 50px;
  box-sizing: border-box;
}
.minicart__qty-btn {
  width: 24px;
  height: 24px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--color-text);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
}
.minicart__qty-btn:hover {
  background: var(--color-bg-beige);
}
.minicart__qty-btn[disabled] {
  opacity: 0.4;
  cursor: not-allowed;
}
.minicart__qty-btn svg {
  width: 16px;
  height: 16px;
  display: block;
}
.minicart__qty-value {
  min-width: 16px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  line-height: 1;
  color: var(--color-text);
  text-align: center;
}
.minicart__item-remove {
  width: 24px;
  height: 24px;
  color: var(--color-text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  text-decoration: none;
  flex-shrink: 0;
}
.minicart__item-remove:hover {
  background: var(--color-bg-beige);
}
.minicart__item-remove svg {
  width: 16px;
  height: 16px;
  display: block;
}
.minicart__total {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 20px;
  border-top: 1px solid var(--color-bg-beige);
  color: var(--color-text);
  font-size: 18px;
  letter-spacing: 0.03em;
}
.minicart__total-label {
  font-family: var(--font-display);
  font-weight: 500;
}
.minicart__total-value {
  font-family: var(--font-body);
  font-weight: 400;
}
.minicart__footer {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 10px 20px;
  background: var(--color-bg-light);
}
.minicart__cta-primary,
.minicart__cta-secondary {
  width: 100%;
  justify-content: center;
}
body.has-minicart-open {
  overflow: hidden;
}
@media (max-width: 480px) {
  .minicart__panel {
    width: 100%;
  }
}
.size-guide-drawer {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal, 1000);
}
.size-guide-drawer[hidden] {
  display: none;
}
.size-guide-drawer__backdrop {
  position: absolute;
  inset: 0;
  background: #0006;
  opacity: 0;
  transition: opacity 0.22s ease;
}
.size-guide-drawer[data-state="open"] .size-guide-drawer__backdrop {
  opacity: 1;
}
.size-guide-drawer__panel {
  position: absolute;
  top: 0;
  right: 0;
  width: 390px;
  max-width: 100%;
  height: 100%;
  max-height: 100dvh;
  background: var(--color-bg-light);
  border-radius: 0 !important;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transform: translate(100%);
  transition: transform 0.28s cubic-bezier(0.22, 1, 0.36, 1);
  box-shadow: -8px 0 24px #00000014;
  outline: 0;
}
.size-guide-drawer[data-state="open"] .size-guide-drawer__panel {
  transform: translate(0);
}
.size-guide-drawer__header {
  min-height: 58px;
  padding: 20px 24px 0;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  flex-shrink: 0;
}
.size-guide-drawer__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 500;
  line-height: 1.05;
  color: var(--color-text);
}
.size-guide-drawer__close {
  width: 42px;
  height: 42px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--color-text);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}
.size-guide-drawer__close svg {
  width: 42px;
  height: 42px;
  display: block;
  stroke-width: 1.6;
}
.size-guide-drawer__body {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  padding: 40px 24px 56px;
}
.size-guide-drawer__intro {
  max-width: 300px;
  margin: 0 auto 44px;
  text-align: center;
}
.size-guide-drawer__heading {
  margin: 0 0 20px;
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 500;
  line-height: 0.98;
  color: var(--color-text);
}
.size-guide-drawer__lead {
  margin: 0;
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.25;
  color: var(--color-text);
}
.size-guide-drawer__steps {
  list-style: none;
  margin: 0 0 46px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 42px;
}
.size-guide-drawer__step {
  display: grid;
  grid-template-columns: 90px minmax(0, 1fr);
  align-items: center;
  gap: 18px;
}
.size-guide-drawer__step-icon {
  width: 90px;
  max-height: 91px;
  object-fit: contain;
  display: block;
}
.size-guide-drawer__step-content {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.size-guide-drawer__step-number {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 500;
  line-height: 1;
  color: var(--color-text);
}
.size-guide-drawer__step-text {
  margin: 0;
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.25;
  color: var(--color-text);
}
.size-guide-drawer__section {
  margin-top: 32px;
}
.size-guide-drawer__section-title {
  margin: 0 0 18px;
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 500;
  line-height: 1.15;
  color: var(--color-text);
}
.size-guide-drawer__table-wrap {
  overflow-x: auto;
  border: 1px solid var(--color-border-subtle);
  border-radius: 8px;
}
.size-guide-drawer__table {
  width: 100%;
  min-width: 320px;
  border-collapse: collapse;
  background: transparent;
}
.size-guide-drawer__table th,
.size-guide-drawer__table td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--color-border-subtle);
  border-right: 1px solid var(--color-border-subtle);
  text-align: left;
  color: var(--color-text);
}
.size-guide-drawer__table th {
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 500;
  line-height: 1.15;
}
.size-guide-drawer__table td {
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.2;
}
.size-guide-drawer__table th:last-child,
.size-guide-drawer__table td:last-child {
  border-right: 0;
}
.size-guide-drawer__table tbody tr:last-child td {
  border-bottom: 0;
}
.size-guide-drawer__info-list {
  margin: 0;
  padding-left: 18px;
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.35;
  color: var(--color-text);
}
.size-guide-drawer__info-list li + li {
  margin-top: 6px;
}
body.has-size-guide-drawer-open {
  overflow: hidden;
}
@media (max-width: 480px) {
  .size-guide-drawer__panel {
    width: 100%;
  }
  .size-guide-drawer__header {
    padding: 20px 22px 0;
  }
  .size-guide-drawer__body {
    padding: 36px 22px 52px;
  }
  .size-guide-drawer__step {
    grid-template-columns: 84px minmax(0, 1fr);
    gap: 16px;
  }
  .size-guide-drawer__step-icon {
    width: 84px;
  }
}
.hero--home {
  position: relative;
  overflow: hidden;
  background: var(--color-bg-light);
  padding-block: 60px;
}
.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
}
.hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.hero__inner {
  position: relative;
  z-index: 1;
  max-width: 1920px;
  margin-inline: auto;
  padding-inline: 20px;
  display: flex;
  justify-content: flex-start;
}
.hero__panel {
  position: relative;
  width: max-content;
  max-width: 100%;
  aspect-ratio: 7 / 6;
  padding: 96px;
  box-sizing: border-box;
  background-image: url(../images/herbatnik-hero.svg);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-position: center;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hero__panel-content {
  display: flex;
  flex-direction: column;
  gap: 28px;
  align-items: flex-start;
  text-align: left;
  max-width: 500px;
}
.hero__rating {
  display: flex;
  align-items: center;
  gap: 8px;
}
.hero__stars {
  height: 32px;
  width: auto;
  display: block;
}
.hero__rating-value {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 14px;
  line-height: 1;
  color: var(--color-text-darkest);
  padding-top: 4px;
}
.hero__heading {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 60px;
  line-height: 1;
  color: var(--color-text);
  max-width: 500px;
}
.hero__description {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 20px;
  line-height: 1.4;
  color: var(--color-text);
  max-width: 500px;
}
.hero__description p {
  margin: 0;
}
.hero__description p + p {
  margin-top: 0;
}
.hero__cta {
  display: flex;
}
.hero__bottom-cutout,
.hero__mobile-card {
  display: none;
}
@media (max-width: 1023px) {
  .hero--home {
    padding: 0;
    overflow: visible;
    background: var(--color-bg-light);
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
  }
  .hero__bg,
  .hero__inner {
    display: none;
  }
  .hero__mobile-card {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
  }
  .hero__mobile-bottom {
    flex: 0 0 auto;
  }
  .hero__mobile-img {
    position: relative;
    flex: 1 1 auto;
    min-height: 240px;
    overflow: hidden;
    margin-bottom: -40px;
  }
  .hero__mobile-img picture {
    display: block;
    position: absolute;
    inset: 0;
  }
  .hero__mobile-img img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .hero__mobile-bottom {
    position: relative;
    z-index: 2;
    font-size: 0;
    line-height: 0;
  }
  .hero__scallop {
    display: block;
    width: 100%;
    height: auto;
    position: relative;
    z-index: 1;
    margin-bottom: -1px;
    vertical-align: bottom;
  }
  .hero__mobile-body {
    font-size: initial;
    line-height: initial;
    background: var(--color-accent-sage);
    padding: 24px 24px 32px;
    display: flex;
    flex-direction: column;
    gap: 18px;
    align-items: flex-start;
  }
  .hero__mobile-body .hero__rating {
    gap: 6px;
  }
  .hero__mobile-body .hero__stars {
    height: 24px;
  }
  .hero__mobile-body .hero__heading {
    font-size: var(--fs-h1-mob);
    line-height: 1;
    max-width: none;
    margin: 0;
  }
  .hero__mobile-body .hero__description {
    font-size: 16px;
    max-width: none;
  }
}
.product-card-slot {
  position: relative;
  height: 500px;
  width: 100%;
  max-width: 307px;
}
.product-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  background: var(--color-bg-white);
  border-radius: 20px;
  padding-bottom: 10px;
  overflow: hidden;
  width: 100%;
  max-width: 307px;
  min-height: 460px;
  box-sizing: border-box;
  cursor: pointer;
  position: relative;
  z-index: 1;
}
.product-card-slot .product-card {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
}
.product-card:hover {
  z-index: 2;
}
.product-card__image-wrap {
  display: block;
  position: relative;
  aspect-ratio: 1 / 1;
  padding: 5px;
  box-sizing: border-box;
}
.product-card__image,
.product-card__image--placeholder {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 20px;
  display: block;
}
.product-card__image--placeholder {
  background: linear-gradient(
    135deg,
    var(--color-bg-beige) 0%,
    var(--color-accent-sage) 100%
  );
}
.product-card__image--hover {
  position: absolute;
  inset: 5px;
  width: calc(100% - 10px);
  height: calc(100% - 10px);
  opacity: 0;
  transition: opacity 0.3s ease;
}
.product-card:hover .product-card__image--hover {
  opacity: 1;
}
.product-card__tags {
  position: absolute;
  top: 9px;
  left: 10px;
  display: flex;
  gap: 4px;
  z-index: 1;
  transition: opacity 0.2s ease;
}
.product-card:hover .product-card__tags {
  opacity: 0;
}
.product-card__body {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 0;
  text-align: center;
}
.product-card__rating {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.product-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h6);
  line-height: var(--lh-h6);
  color: var(--color-text);
  padding: 0 16px;
}
.product-card__title a {
  color: inherit;
  text-decoration: none;
}
.product-card__price {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.4;
  color: var(--color-text);
  padding: 0 16px;
}
.product-card__price del {
  color: var(--color-text-muted);
  font-size: 12px;
  margin-right: 4px;
}
.product-card__price ins {
  text-decoration: none;
  color: var(--color-text);
  font-weight: 400;
}
.product-card__omnibus {
  margin: 0;
  font-size: 11px;
}
.product-card__sizes {
  margin-top: 0;
  display: block;
  opacity: 0;
  transition: opacity 0.18s ease;
}
.product-card:hover .product-card__sizes,
.product-card:focus-within .product-card__sizes {
  opacity: 1;
}
.product-card__sizes .picker {
  cursor: pointer;
}
.product-card__sizes-link {
  display: none;
  border: 0;
  background: none;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 14px;
  color: var(--color-text-muted);
  text-decoration: underline;
  text-underline-offset: 3px;
  cursor: pointer;
  padding: 0;
}
@media (max-width: 1023px) {
  .product-card__sizes {
    display: none !important;
  }
  .product-card__sizes-link {
    display: inline-block;
  }
}
.size-drawer {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: flex-end;
  visibility: hidden;
  pointer-events: none;
}
.size-drawer[aria-hidden="false"] {
  visibility: visible;
  pointer-events: auto;
}
.size-drawer__overlay {
  position: absolute;
  inset: 0;
  background: #0006;
  opacity: 0;
  transition: opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.size-drawer[aria-hidden="false"] .size-drawer__overlay {
  opacity: 1;
}
.size-drawer__panel {
  position: relative;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  background: var(--color-bg-white);
  border-radius: 20px 20px 0 0;
  padding: 24px;
  transform: translateY(100%);
  transition: transform 0.4s cubic-bezier(0.32, 0.72, 0, 1);
}
.size-drawer[aria-hidden="false"] .size-drawer__panel {
  transform: translateY(0);
}
.size-drawer__close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 0;
  background: none;
  cursor: pointer;
  color: var(--color-text);
}
.size-drawer__product {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 16px;
  align-items: start;
  margin-bottom: 24px;
}
.size-drawer__thumb {
  position: relative;
  aspect-ratio: 1;
  border-radius: 16px;
  overflow: hidden;
}
.size-drawer__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.size-drawer__info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: 8px;
}
.size-drawer__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 18px;
  line-height: 1.2;
  color: var(--color-text);
}
.size-drawer__price {
  margin: 0;
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--color-text);
}
.size-drawer__count {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--color-text-muted);
}
.size-drawer__picker {
  margin-bottom: 24px;
}
.size-drawer__picker-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 12px;
}
.size-drawer__picker-label {
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--color-text);
}
.size-drawer__guide {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 14px;
  color: var(--color-text);
  text-decoration: none;
}
.size-drawer__picker .picker-group {
  gap: 8px;
  padding: 0;
}
.size-drawer__picker .picker {
  width: 44px;
  height: 44px;
  font-size: 16px;
  border: 2px solid var(--color-border-subtle, #e0ddd5);
  border-radius: var(--radius-full);
}
.size-drawer__picker .picker:hover:not([data-state="inactive"]) {
  border-color: var(--color-text);
}
.size-drawer__picker-group .picker {
  cursor: pointer;
}
.size-drawer__actions {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.size-drawer__atc {
  width: 100%;
  justify-content: center;
  padding: 16px 24px;
  border-radius: var(--radius-pill);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 18px;
  background: var(--color-text);
  color: var(--color-bg-beige);
  border: 0;
  cursor: pointer;
}
.size-drawer__link {
  display: block;
  text-align: center;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  color: var(--color-text);
  text-decoration: none;
  padding: 12px 0;
}
@media (max-width: 1023px) {
  .product-card-slot {
    height: auto;
  }
  .product-card {
    position: relative;
    min-height: auto;
  }
}
.product-card[data-variant="compact"] .product-card__body {
  padding-block: 0;
}
.product-card[data-variant="compact"] .product-card__sizes {
  display: none;
}
@media (max-width: 639px) {
  .product-card {
    border-radius: 14px;
    gap: 8px;
    padding-bottom: 12px;
  }
  .product-card__image-wrap {
    padding: 4px;
  }
  .product-card__image,
  .product-card__image--placeholder {
    border-radius: 14px;
  }
  .product-card__image--hover {
    inset: 4px;
    width: calc(100% - 8px);
    height: calc(100% - 8px);
    border-radius: 14px;
  }
  .product-card__body {
    gap: 8px;
  }
  .product-card__rating {
    gap: 5px;
  }
  .product-card__title {
    font-size: 16px;
    line-height: 1.1;
    padding-inline: 8px;
  }
  .product-card__price {
    font-size: 14px;
    line-height: 1.25;
    padding-inline: 8px;
  }
  .product-card[data-variant="2-col"] {
    max-width: 172px;
  }
  .product-card[data-variant="2-col"] .product-card__title {
    font-size: var(--fs-body-16);
  }
  .product-card[data-variant="2-col"] .product-card__sizes {
    display: none;
  }
}
.blog-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-self: flex-start;
  background: transparent;
  border-radius: 20px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: background-color 0.32s cubic-bezier(0.22, 1, 0.36, 1);
}
.blog-card__image-wrap {
  display: block;
  overflow: hidden;
  border-radius: 20px;
  background: var(--color-bg-beige);
}
.blog-card__image,
.blog-card__image--placeholder {
  width: 100%;
  display: block;
}
.blog-card__image--placeholder {
  background: linear-gradient(
    135deg,
    var(--color-accent-brown) 0%,
    var(--color-accent-sage) 100%
  );
}
.blog-card:hover,
.blog-card:focus-within {
  background: #fff;
}
.blog-card__body {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 0 15px 15px;
}
.blog-card__meta {
  display: flex;
  align-items: center;
  gap: 10px;
}
.blog-card__date {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 14px;
  color: var(--color-text-muted);
}
.blog-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h5);
  line-height: var(--lh-h5);
  color: var(--color-text);
}
.blog-card__title a {
  color: inherit;
  text-decoration: none;
}
.blog-card__excerpt {
  margin: 0;
  color: var(--color-text-muted);
  line-height: 1.5;
  font-size: var(--fs-body-14);
}
.blog-card__image--placeholder {
  height: 280px;
}
.category-card {
  position: relative;
  display: block;
  aspect-ratio: 592 / 420;
  border-radius: var(--radius-card);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  background: var(--color-bg-beige);
}
.category-card__image,
.category-card__image--placeholder {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.category-card__image--placeholder {
  background: linear-gradient(
    135deg,
    var(--color-accent-sage) 0%,
    var(--color-accent-brown) 100%
  );
}
.category-card__overlay {
  position: absolute;
  inset: auto 0 0;
  padding: var(--space-24);
  background: linear-gradient(to top, #1414128c, #14141200 80%);
}
.category-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h3);
  line-height: 1;
  color: var(--color-bg-beige);
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
  transition: transform 0.36s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
}
.category-card:hover .category-card__title,
.category-card:focus-visible .category-card__title {
  transform: translateY(-10px);
}
@media (max-width: 639px) {
  .category-card__title {
    font-size: var(--fs-h4);
  }
}
.review-card {
  box-sizing: border-box;
}
.review-card--quote {
  height: 420px;
  width: 351px;
  border-radius: 20px;
  padding: 30px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 22px;
  text-align: center;
}
.review-card--bg-sage {
  background: var(--color-accent-sage);
}
.review-card--bg-brown {
  background: var(--color-accent-brown);
}
.review-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h5);
  line-height: var(--lh-h5);
  color: var(--color-text);
}
.review-card__quote {
  margin: 0;
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 20px;
  line-height: 1.4;
  color: var(--color-text);
}
.review-card__quote p {
  margin: 0;
}
.review-card__footer {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  margin-top: auto;
}
.review-card__author {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 20px;
  line-height: 1.4;
  color: var(--color-text);
  font-style: normal;
}
.review-card__product {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--color-text);
  opacity: 0.7;
}
.review-card--photo {
  margin: 0;
  height: 420px;
  width: 351px;
  overflow: hidden;
  border-radius: 20px;
}
.review-card--photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.review-card--rotated {
  transform: rotate(-2.16deg);
}
.reviews-section {
  padding-block: var(--space-80);
  background: var(--color-bg-beige);
}
.reviews-section__title {
  margin: 0 0 var(--space-48);
  text-align: center;
}
.reviews-section__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--space-24);
}
.usp {
  padding-block: var(--space-64);
  text-align: center;
}
.usp__heading {
  margin: 0 0 var(--space-48);
}
.usp__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-48);
}
.usp__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-16);
  padding: var(--space-24);
}
.usp__icon {
  width: 64px;
  height: 64px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-accent-sage);
  background: var(--color-bg-beige);
  border-radius: var(--radius-full);
  font-size: 28px;
}
.usp__item-title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h5);
}
.usp__item-desc {
  margin: 0;
  color: var(--color-text-muted);
  line-height: 1.5;
}
.newsletter-section {
  padding-block: var(--space-96);
  background: var(--color-accent-sage);
  color: var(--color-text);
}
.newsletter-section__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-16);
  text-align: center;
  max-width: 640px;
}
.newsletter-section__title {
  margin: 0;
  line-height: 1.05;
}
.newsletter-section__subtitle {
  margin: 0;
  color: var(--color-text);
  opacity: 0.85;
}
.newsletter-section__form {
  margin-top: var(--space-24);
  width: 100%;
  display: flex;
  justify-content: center;
  position: relative;
}
.newsletter-section .newsletter {
  background: var(--color-bg-white);
  border-color: var(--color-bg-white);
}
.newsletter-section *:focus-visible {
  outline-color: var(--color-text);
}
.omnibus-label {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-8);
  margin: 0;
  padding: var(--space-8) var(--space-16);
  background: var(--color-bg-beige);
  border-radius: var(--radius-pill);
  font-family: var(--font-body);
  font-size: var(--fs-body-14);
  line-height: 1.3;
  color: var(--color-text-muted);
}
.omnibus-label__text strong {
  color: var(--color-text);
  font-weight: 500;
}
.omnibus-label__info {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: var(--radius-full);
  color: var(--color-accent-sage);
  cursor: help;
}
.omnibus-label__tooltip {
  position: absolute;
  bottom: calc(100% + 6px);
  left: 50%;
  transform: translate(-50%);
  background: var(--color-text);
  color: var(--color-bg-beige);
  padding: var(--space-8) var(--space-12);
  border-radius: var(--radius-card);
  font-size: var(--fs-caption);
  min-width: 240px;
  max-width: 320px;
  text-align: left;
  line-height: 1.4;
  opacity: 0;
  visibility: hidden;
  transition:
    opacity 0.16s ease,
    visibility 0.16s ease;
  z-index: var(--z-tooltip);
  pointer-events: none;
}
.omnibus-label__info:hover .omnibus-label__tooltip,
.omnibus-label__info:focus-visible .omnibus-label__tooltip {
  opacity: 1;
  visibility: visible;
}
.cart-item {
  display: grid;
  grid-template-columns: 80px 1fr auto;
  gap: var(--space-16);
  align-items: center;
  padding: var(--space-16) 0;
  border-bottom: 1px solid var(--color-border-subtle);
}
.cart-item__image-wrap {
  display: block;
  width: 80px;
  height: 80px;
  border-radius: 12px;
  overflow: hidden;
}
.cart-item__image,
.cart-item__image--placeholder {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.cart-item__image--placeholder {
  background: var(--color-bg-beige);
}
.cart-item__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  min-width: 0;
}
.cart-item__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h6);
  line-height: 1.2;
}
.cart-item__title a {
  color: inherit;
  text-decoration: none;
}
.cart-item__title a:hover {
  color: var(--color-accent-sage-hover);
}
.cart-item__variant {
  margin: 0;
  font-size: var(--fs-caption);
}
.cart-item__qty {
  margin-top: var(--space-8);
}
.cart-item__price-wrap {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: var(--space-8);
}
.cart-item__price {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-16);
  color: var(--color-text);
  white-space: nowrap;
}
.cart-item__remove {
  color: var(--color-text-muted);
}
.cart-item__remove:hover {
  background: transparent;
  color: var(--color-error);
}
.cross-sell {
  padding: var(--space-20);
  background: var(--color-bg-white);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-popover);
  max-width: 350px;
}
.cross-sell__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-12);
  margin-bottom: var(--space-16);
}
.cross-sell__title {
  margin: 0;
}
.cross-sell__products {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
}
.cross-sell__product {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
  text-decoration: none;
  color: inherit;
  border-radius: 12px;
  padding: var(--space-4);
  transition: background-color 0.16s ease;
}
.cross-sell__product:hover {
  background: var(--color-bg-beige);
}
.cross-sell__product-image,
.cross-sell__product-image--placeholder {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 8px;
  object-fit: cover;
  display: block;
}
.cross-sell__product-image--placeholder {
  background: linear-gradient(
    135deg,
    var(--color-bg-beige),
    var(--color-accent-sage)
  );
}
.cross-sell__product-body {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.cross-sell__rating {
  display: inline-flex;
  align-items: center;
  gap: var(--space-4);
}
.cross-sell__stars {
  display: inline-flex;
  gap: 1px;
  color: var(--color-accent-yellow);
}
.cross-sell__product-title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-caption);
  color: var(--color-text);
  line-height: 1.2;
}
.cross-sell__product-price {
  font-family: var(--font-body);
  font-size: var(--fs-caption);
  color: var(--color-text);
}
.location-item {
  display: flex;
  gap: var(--space-16);
  padding: var(--space-16);
  border-radius: var(--radius-card);
  transition: background-color 0.16s ease;
  cursor: pointer;
}
.location-item:hover,
.location-item[data-state="active"] {
  background: var(--color-bg-beige);
}
.location-item__pin {
  display: inline-flex;
  align-items: flex-start;
  justify-content: center;
  width: 36px;
  height: 36px;
  color: var(--color-accent-sage);
  flex-shrink: 0;
  font-size: 20px;
}
.location-item__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  min-width: 0;
}
.location-item__name {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-16);
  color: var(--color-text);
}
.location-item__address {
  margin: 0;
  color: var(--color-text-muted);
  line-height: 1.4;
}
.location-item__hours {
  margin: 0;
}
.location-item__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-16);
  margin-top: var(--space-8);
}
.thumbnail-gallery {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: var(--space-16);
  align-items: start;
}
@media (max-width: 639px) {
  .thumbnail-gallery {
    grid-template-columns: 1fr;
    grid-template-rows: 1fr auto;
  }
  .thumbnail-gallery__rail {
    grid-row: 2;
    order: 2;
  }
  .thumbnail-gallery__rail {
    flex-direction: row;
    overflow-x: auto;
  }
}
.thumbnail-gallery__rail {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
  list-style: none;
  margin: 0;
  padding: 0;
}
.thumbnail-gallery__thumb {
  width: 83px;
  height: 83px;
  padding: 0;
  border: 2px solid transparent;
  border-radius: 12px;
  overflow: hidden;
  cursor: pointer;
  transition: border-color 0.16s ease;
  background: none;
}
.thumbnail-gallery__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.thumbnail-gallery__thumb[data-state="active"] {
  border-color: var(--color-text);
}
.thumbnail-gallery__thumb:hover {
  border-color: var(--color-accent-sage);
}
.thumbnail-gallery__thumb:focus-visible {
  outline: 2px solid var(--color-accent-sage);
  outline-offset: 2px;
}
.thumbnail-gallery__main {
  aspect-ratio: 1 / 1;
  border-radius: var(--radius-card);
  overflow: hidden;
  background: var(--color-bg-beige);
}
.thumbnail-gallery__main-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.breadcrumbs {
  padding-block: var(--space-16) var(--space-12);
  font-family: var(--font-body);
  font-size: var(--fs-caption);
  color: var(--color-text-muted);
}
.breadcrumbs__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  font-size: 16px;
}
.breadcrumbs__item {
  display: inline-flex;
  align-items: center;
  gap: var(--space-4);
  min-height: 20px;
}
.breadcrumbs__link {
  color: var(--color-text-muted);
  text-decoration: none;
  transition: color 0.16s ease;
}
.breadcrumbs__link:hover {
  color: var(--color-text);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.breadcrumbs__current {
  color: var(--color-text);
  font-weight: 500;
}
.breadcrumbs__sep {
  display: inline-flex;
  color: var(--color-text-muted);
  opacity: 0.5;
}
@media (max-width: 1023px) {
  .breadcrumbs__list {
    justify-content: flex-start;
  }
}
.woocommerce-page .breadcrumbs {
  margin-bottom: var(--space-24);
}
.site-header {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  background: var(--color-bg-light);
}
.navbar__inner {
  width: 100%;
  max-width: 1920px;
  margin-inline: auto;
  padding: var(--space-20);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-20);
}
@media (min-width: 640px) {
  .navbar__inner {
    padding-inline: var(--space-32);
  }
}
@media (min-width: 1024px) {
  .navbar__inner {
    padding-inline: 60px;
  }
}
.navbar__logo {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  text-decoration: none;
  color: var(--color-text);
}
.navbar__logo img {
  display: block;
  height: 42px;
  width: auto;
}
.navbar__menu {
  display: none;
  list-style: none;
  margin: 0;
  padding: 0;
  align-items: center;
  gap: var(--space-10);
}
.navbar__menu a,
.navbar__secondary a {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-nav);
  line-height: var(--lh-nav);
  color: var(--color-text);
  text-decoration: none;
  padding: 2px 11px;
  border-radius: var(--radius-full);
  transition: background-color 0.16s ease;
  white-space: nowrap;
}
.navbar__menu a:hover,
.navbar__secondary a:hover {
  background: var(--color-bg-beige);
}
.navbar__right {
  display: flex;
  align-items: center;
  gap: var(--space-10);
}
.navbar__secondary {
  display: none;
  list-style: none;
  margin: 0;
  padding: 0;
  align-items: center;
  gap: var(--space-10);
}
.navbar__actions {
  display: flex;
  align-items: center;
  gap: var(--space-10);
}
.navbar__cart-count {
  position: absolute;
  top: -2px;
  left: 25px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  background: var(--color-text-muted);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 12px;
  line-height: 16px;
  border-radius: var(--radius-full);
}
.navbar__hamburger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 0;
  background: transparent;
  color: var(--color-text);
  cursor: pointer;
  border-radius: var(--radius-full);
  transition: background-color 0.16s ease;
}
.navbar__hamburger:hover {
  background: var(--color-bg-beige);
}
@media (min-width: 1024px) {
  .navbar__menu,
  .navbar__secondary {
    display: flex;
  }
  .navbar__hamburger {
    display: none;
  }
}
.navbar__right {
  position: relative;
  flex-wrap: nowrap;
}
.navbar__search-wrap {
  position: relative;
  width: 36px;
  min-width: 36px;
  height: 36px;
  min-height: 36px;
  flex-grow: 0;
  flex-shrink: 0;
  flex-basis: 36px;
}
.navbar__search {
  position: absolute;
  top: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-pill);
  overflow: hidden;
  background: var(--color-accent-yellow);
  border: 2px solid transparent;
  transition:
    width 0.4s cubic-bezier(0.25, 0.1, 0.25, 1),
    background-color 0.3s ease,
    border-color 0.3s ease;
  z-index: var(--z-dropdown);
}
.navbar__search.is-open {
  width: 360px;
  justify-content: flex-end;
  background: var(--color-bg-white);
  border-color: var(--color-accent-yellow);
}
.navbar__search-form {
  display: flex;
  align-items: center;
  gap: var(--space-8);
  flex-grow: 0;
  flex-shrink: 0;
  flex-basis: 0%;
  width: 0;
  min-width: 0;
  height: 100%;
  padding-left: 0;
  pointer-events: none;
  opacity: 0;
  overflow: hidden;
  transition: opacity 0.25s ease 80ms;
}
.navbar__search.is-open .navbar__search-form {
  flex-grow: 1;
  flex-shrink: 1;
  flex-basis: auto;
  padding-left: var(--space-12);
  pointer-events: auto;
  opacity: 1;
}
.navbar__search [data-live-search-toggle] {
  flex-shrink: 0;
  width: 32px !important;
  height: 32px !important;
  padding: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}
.navbar__search [data-live-search-toggle]:hover {
  background: transparent !important;
}
.navbar__search.is-open [data-live-search-toggle] {
  display: none;
}
.navbar__search-input {
  flex-grow: 1;
  flex-shrink: 1;
  min-width: 0;
  border: none;
  background: transparent;
  -webkit-appearance: none;
  appearance: none;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-14);
  color: var(--color-text);
  outline: none;
  height: 100%;
}
.navbar__search-input::placeholder {
  color: var(--color-text-muted);
}
.navbar__search-input::-webkit-search-cancel-button {
  -webkit-appearance: none;
  display: none;
}
.navbar__search-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  margin-right: 3px;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--color-text-muted);
  cursor: pointer;
  border-radius: var(--radius-full);
  transition: background-color 0.16s ease;
  flex-shrink: 0;
}
.navbar__search-close:hover {
  background: var(--color-bg-beige);
}
.navbar__secondary {
  transition:
    opacity 0.3s ease,
    visibility 0.3s ease;
}
.navbar__secondary.is-search-open {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.navbar__search-results {
  position: absolute;
  top: calc(100% + var(--space-8));
  right: 0;
  width: 360px;
  z-index: var(--z-dropdown);
  max-height: 420px;
  overflow-y: auto;
  background: var(--color-bg-white);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-popover);
  padding: var(--space-8);
}
.navbar__search-item {
  display: flex;
  align-items: center;
  gap: var(--space-12);
  padding: var(--space-8);
  border-radius: 12px;
  text-decoration: none;
  color: var(--color-text);
  transition: background-color 0.12s ease;
}
.navbar__search-item:hover {
  background: var(--color-bg-light);
}
.navbar__search-thumb {
  width: 64px;
  height: 64px;
  object-fit: cover;
  border-radius: 8px;
  flex-shrink: 0;
  background: var(--color-bg-light);
}
.navbar__search-item-info {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  min-width: 0;
}
.navbar__search-item-title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-16);
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.navbar__search-item-price {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-14);
  color: var(--color-text-muted);
}
.navbar__search-empty {
  padding: var(--space-24) var(--space-16);
  text-align: center;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-16);
  color: var(--color-text-muted);
}
@media (max-width: 1023px) {
  .navbar__inner {
    padding: var(--space-20) var(--space-8) var(--space-20) var(--space-20);
  }
  .navbar__logo img {
    height: 31.5px;
  }
  .icon-btn.navbar__account {
    display: none;
  }
  .navbar__search.is-open,
  .navbar__search-results {
    width: 270px;
  }
}
.nav-mobile {
  position: fixed;
  inset: 0;
  z-index: var(--z-drawer);
  overflow: hidden;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.2s ease;
}
.nav-mobile[data-state="open"] {
  pointer-events: auto;
  opacity: 1;
}
.nav-mobile__backdrop {
  position: absolute;
  inset: 0;
  background: #14141238;
}
.nav-mobile__drawer {
  position: absolute;
  inset: 0 0 0 auto;
  display: flex;
  flex-direction: column;
  width: 100vw;
  min-height: 100dvh;
  max-height: 100dvh;
  background: var(--color-bg-light);
  overflow: hidden;
  transform: translate(100%);
  transition: transform 0.28s cubic-bezier(0.32, 0.72, 0, 1);
}
.nav-mobile[data-state="closed"] .nav-mobile__drawer {
  display: none;
}
.nav-mobile[data-state="open"] .nav-mobile__drawer {
  display: flex;
  transform: translate(0);
}
.nav-mobile__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex: 0 0 80px;
  min-height: 80px;
  padding: 0 15px 0 20px;
  background: var(--color-bg-light);
}
.nav-mobile__logo {
  display: inline-flex;
  align-items: center;
  color: var(--color-text);
  text-decoration: none;
}
.nav-mobile__logo img {
  display: block;
  width: 128px;
  height: auto;
}
.nav-mobile__close {
  color: var(--color-text);
}
.nav-mobile__panels {
  position: relative;
  flex: 1 1 0;
  min-height: 0;
  overflow: hidden auto;
  padding: 0 24px 12px;
  overscroll-behavior: contain;
}
@media (max-width: 480px) {
  .nav-mobile__panels {
    padding-inline: 20px;
  }
}
.nav-mobile__panel {
  display: none;
}
.nav-mobile__panel.is-active {
  display: block;
  animation: navMobilePanelIn 0.22s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.nav-mobile__panel--root {
  padding-top: 24px;
}
.nav-mobile__panel--root.is-active {
  display: flex;
  flex-direction: column;
  min-height: 100%;
}
.nav-mobile__panel[hidden] {
  display: none !important;
}
.nav-mobile__panel:not(.nav-mobile__panel--root) {
  padding-top: 24px;
}
.nav-mobile__panel:not(.nav-mobile__panel--root) .nav-mobile__list {
  padding-left: 30px;
}
@keyframes navMobilePanelIn {
  0% {
    opacity: 0;
    transform: translate(14px);
  }
  to {
    opacity: 1;
    transform: translate(0);
  }
}
.nav-mobile__list {
  display: flex;
  flex-direction: column;
  gap: 22px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.nav-mobile__list-item {
  margin: 0;
}
.nav-mobile__list-item--heading {
  margin-top: 10px;
}
.nav-mobile__item,
.nav-mobile__return {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  border: 0;
  border-radius: 50px;
  background: transparent;
  color: var(--color-text);
  font-family: var(--font-display);
  font-weight: 500;
  text-decoration: none;
  cursor: pointer;
  transition:
    background-color 0.18s ease,
    transform 0.18s ease;
}
.nav-mobile__item {
  display: flex;
  justify-content: space-between;
  width: 100%;
  min-height: auto;
  padding: 0;
  font-size: 16px;
  line-height: 1.3;
}
.nav-mobile__panel--root
  > .nav-mobile__list
  > .nav-mobile__list-item:nth-child(-n + 4)
  > .nav-mobile__item {
  min-height: auto;
  font-size: 28px;
  line-height: 1.1;
  font-weight: 500;
}
.nav-mobile__panel--root
  > .nav-mobile__list
  > .nav-mobile__list-item:nth-child(4) {
  margin-bottom: 8px;
}
.nav-mobile__panel--root
  > .nav-mobile__list
  > .nav-mobile__list-item:nth-child(n + 5)
  > .nav-mobile__item {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.2;
  min-height: 28px;
}
.nav-mobile__panel--root
  > .nav-mobile__list
  > .nav-mobile__list-item:nth-child(n + 5)
  .nav-mobile__chevron {
  width: 28px;
  height: 28px;
  flex-basis: 28px;
}
.nav-mobile__return:hover,
.nav-mobile__return:focus-visible {
  background: var(--color-bg-beige);
  outline: none;
}
.nav-mobile__item:hover,
.nav-mobile__item:focus-visible {
  background: transparent;
  outline: none;
}
.nav-mobile__item:active,
.nav-mobile__return:active {
  transform: scale(0.98);
}
.nav-mobile__item--has-children {
  text-align: left;
}
.nav-mobile__section-title {
  margin: 0;
  padding: 0;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 500;
  line-height: 1.1;
}
.nav-mobile__chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  flex: 0 0 36px;
  margin-left: 8px;
  color: var(--color-text);
}
.nav-mobile__return {
  min-height: 48px;
  margin: 0 0 20px;
  padding: 6px 20px 6px 12px;
  background: var(--color-bg-beige);
  font-size: 16px;
  line-height: 1.3;
}
.nav-mobile__return-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  margin-right: 0;
}
.nav-mobile__feature {
  position: relative;
  display: flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  height: 160px;
  min-height: 160px;
  margin: 20px 0 0;
  padding: 20px;
  overflow: hidden;
  border-radius: 14px;
  background:
    linear-gradient(180deg, #21252926, #2125298c),
    url(../images/menu/lookbook-bestsellery.webp) center / cover no-repeat;
  color: var(--color-bg-light);
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 500;
  line-height: 1.1;
  text-align: center;
  text-decoration: none;
}
.nav-mobile:not([data-active-panel="nav-mobile-panel-root"])
  .nav-mobile__feature {
  display: none;
}
.nav-mobile__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex: 0 0 auto;
  gap: 8px;
  padding: 0 24px 24px;
  background: var(--color-bg-light);
}
.nav-mobile__quick-links {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 0;
  min-width: 0;
}
.nav-mobile__quick-link {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 8px;
  border-radius: 50px;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 500;
  line-height: 1.2;
  text-decoration: none;
  white-space: nowrap;
  transition: background-color 0.18s ease;
}
.nav-mobile__quick-link:first-child {
  padding-left: 0;
}
.nav-mobile__quick-link:hover,
.nav-mobile__quick-link:focus-visible {
  background: var(--color-bg-beige);
  outline: none;
}
.nav-mobile__quick-link .icon {
  margin-right: 5px;
}
.nav-mobile__social {
  display: flex;
  align-items: center;
  gap: 2px;
}
@media (min-width: 640px) {
  .nav-mobile__drawer {
    box-shadow: var(--shadow-drawer);
  }
}
@media (max-width: 389px) {
  .nav-mobile__top {
    padding-inline: 16px 12px;
  }
  .nav-mobile__panels {
    padding-inline: 20px;
  }
  .nav-mobile__panel--root {
    padding-top: 16px;
  }
  .nav-mobile__panel:not(.nav-mobile__panel--root) {
    padding-top: 16px;
  }
  .nav-mobile__feature {
    margin-inline: 0;
  }
  .nav-mobile__bottom {
    padding-inline: 16px;
  }
}
.mega-menu {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  width: 100%;
  background: var(--color-bg-light);
  z-index: var(--z-dropdown);
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  pointer-events: none;
  transition:
    opacity 0.22s ease,
    transform 0.26s cubic-bezier(0.22, 1, 0.36, 1),
    visibility 0s linear 0.22s;
}
.mega-menu[hidden] {
  display: block;
}
.site-header.is-mega-open .mega-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
  transition:
    opacity 0.22s ease,
    transform 0.26s cubic-bezier(0.22, 1, 0.36, 1),
    visibility 0s linear 0s;
}
.mega-menu__panel {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 35px 60px 27px;
  box-sizing: border-box;
  max-width: 1440px;
  margin-inline: auto;
  width: 100%;
  opacity: 0;
  transform: translateY(-6px);
  transition:
    opacity 0.24s ease 60ms,
    transform 0.32s cubic-bezier(0.22, 1, 0.36, 1) 60ms;
}
.site-header.is-mega-open .mega-menu__panel {
  opacity: 1;
  transform: translateY(0);
}
.mega-menu__cols {
  display: flex;
  gap: 30px;
  align-items: flex-start;
}
.mega-menu__col {
  width: 195px;
  display: flex;
  flex-direction: column;
  gap: 30px;
  flex-shrink: 0;
}
.mega-menu__col-title {
  margin: 0;
  padding: 2px 11px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 20px;
  line-height: 1.1;
  color: var(--color-text);
}
.mega-menu__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.mega-menu__list a {
  display: inline-flex;
  align-items: center;
  padding: 2px 11px;
  border-radius: 149px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  line-height: normal;
  color: var(--color-text);
  text-decoration: none;
  transition: background-color 0.16s ease;
}
.mega-menu__list a:hover {
  background: var(--color-bg-beige);
}
.mega-menu__lookbook {
  position: relative;
  display: block;
  width: 291px;
  height: 366px;
  border-radius: 20px;
  overflow: hidden;
  flex-shrink: 0;
  text-decoration: none;
}
.mega-menu__lookbook img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
}
.mega-menu__lookbook:after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, #0000 50%, #0006);
  pointer-events: none;
}
.mega-menu__lookbook-title {
  position: absolute;
  bottom: 15px;
  left: 50%;
  transform: translate(-50%);
  width: calc(100% - 20px);
  padding: 0 10px;
  box-sizing: border-box;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 28px;
  line-height: 1.1;
  color: var(--color-bg-light);
  text-align: center;
  z-index: 1;
}
.mega-menu__scallop {
  display: block;
  width: 100%;
  height: 76px;
  transform: scaleY(-1);
  pointer-events: none;
}
@media (max-width: 1023px) {
  .mega-menu,
  .mega-menu__panel,
  .mega-menu__cols {
    display: none !important;
  }
}
@media (prefers-reduced-motion: reduce) {
  .mega-menu,
  .mega-menu__panel {
    transition: none;
  }
}
.site-footer {
  background: var(--color-bg-light);
  padding: 60px;
}
.site-footer__panel {
  width: 100%;
  max-width: 1920px;
  margin-inline: auto;
  overflow: hidden;
  border-radius: 20px;
}
.site-footer__scallop {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 1320 / 70;
  position: relative;
  z-index: 1;
  margin-bottom: -1px;
}
.site-footer__body {
  background: var(--color-accent-sage);
  padding: 30px 30px 27px;
  border-radius: 0 0 20px 20px;
}
.site-footer__content {
  display: flex;
  flex-direction: column;
  gap: 33px;
}
.site-footer__cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 40px;
  row-gap: 40px;
  align-items: start;
}
.site-footer__links {
  display: flex;
  justify-content: space-between;
  gap: 24px;
}
.site-footer__col--newsletter {
  margin-right: clamp(40px, 8vw, 140px);
}
.site-footer__col {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.site-footer__col--newsletter {
  max-width: 369px;
}
.site-footer__heading {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 28px;
  line-height: 1.1;
  color: var(--color-text);
}
.site-footer__form {
  position: relative;
  display: flex;
  align-items: center;
  background: var(--color-bg-light);
  border: 2px solid transparent;
  border-radius: 50px;
  height: 52px;
  padding: 4px 4px 4px 16px;
  overflow: hidden;
}
.site-footer__input {
  flex: 1;
  border: 0;
  background: transparent;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  color: var(--color-text);
  outline: none;
}
.site-footer__input::placeholder {
  color: var(--color-accent-sage);
}
.site-footer__submit {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 50px;
  background: var(--color-accent-sage);
  color: var(--color-text);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.16s ease;
}
.site-footer__submit:hover {
  background: var(--color-accent-sage-hover);
}
.site-footer__submit svg {
  width: 24px;
  height: 24px;
}
.site-footer__consent {
  gap: 4px;
}
.site-footer__consent-text {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 14px;
  line-height: 1.4;
  color: var(--color-text);
}
.site-footer__consent-text a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.site-footer__col-toggle {
  display: none;
}
.site-footer__col-title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 20px;
  line-height: 1.1;
  color: var(--color-text);
  padding: 2px 11px;
}
.site-footer__menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.site-footer__menu a {
  display: inline-flex;
  align-items: center;
  padding: 2px 11px;
  border-radius: 149px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  line-height: normal;
  color: var(--color-text);
  text-decoration: none;
  transition: background-color 0.16s ease;
}
.site-footer__menu a:hover {
  background: var(--color-accent-sage-hover);
}
.site-footer__social {
  display: flex;
  gap: 2px;
  margin-top: 8px;
}
.site-footer__social-link {
  width: 48px;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  color: var(--color-text);
  text-decoration: none;
  transition: background-color 0.16s ease;
}
.site-footer__social-link:hover {
  background: var(--color-accent-sage-hover);
}
.site-footer__social-link svg {
  width: 24px;
  height: 24px;
}
.site-footer__lockup {
  display: block;
  width: 100%;
  margin-top: 33px;
  color: var(--color-text);
  text-decoration: none;
}
.site-footer__lockup img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 1259 / 381.804;
}
@media (max-width: 1023px) {
  .site-footer {
    padding: 30px 16px;
  }
  .site-footer__body {
    padding: 24px;
  }
  .site-footer__cols {
    grid-template-columns: 1fr 1fr;
    column-gap: 24px;
    row-gap: 32px;
  }
  .site-footer__col--newsletter {
    grid-column: 1 / -1;
    max-width: none;
  }
  .site-footer__links {
    grid-column: 1 / -1;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 24px;
  }
  .site-footer__heading {
    font-size: 24px;
  }
}
@media (max-width: 639px) {
  .site-footer {
    padding: 20px;
  }
  .site-footer__panel {
    border-radius: 0 0 20px 20px;
  }
  .site-footer__body {
    padding: 20px;
  }
  .site-footer__content {
    gap: 33px;
  }
  .site-footer__cols {
    display: flex;
    flex-direction: column;
    gap: 48px;
  }
  .site-footer__links {
    display: contents;
  }
  .site-footer__col {
    gap: 16px;
  }
  .site-footer__col--newsletter {
    order: 1;
  }
  .site-footer__col--contact {
    order: 2;
    padding-left: 0;
  }
  .site-footer__col--categories {
    order: 3;
    width: 100%;
    margin-top: -38px;
  }
  .site-footer__col--shop {
    order: 4;
    width: 100%;
    margin-top: -38px;
  }
  .site-footer__heading {
    max-width: 310px;
    font-size: 22px;
    line-height: 1.1;
  }
  .site-footer__form {
    width: 100%;
    height: 52px;
    padding: 4px 4px 4px 16px;
    border-radius: 999px;
  }
  .site-footer__input {
    font-size: 16px;
  }
  .site-footer__submit {
    width: 44px;
    height: 44px;
  }
  .site-footer__consent {
    align-items: center;
    gap: 9px;
    margin-top: 0;
    padding-left: 11px;
  }
  .site-footer__consent .checkbox {
    width: 32px;
    height: 32px;
  }
  .site-footer__consent .checkbox:before {
    background: var(--color-text);
    border-color: var(--color-text);
  }
  .site-footer__consent .checkbox .icon {
    opacity: 1;
  }
  .site-footer__consent-text {
    font-size: 13px;
    line-height: 1.2;
    white-space: nowrap;
  }
  .site-footer__col-title {
    position: relative;
    width: 100%;
    margin: 0;
    padding: 2px 11px;
    font-size: 20px;
    line-height: 1.1;
  }
  .site-footer__col--categories .site-footer__col-title,
  .site-footer__col--shop .site-footer__col-title {
    display: none;
  }
  .site-footer__col-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    min-height: 31px;
    padding: 2px 4px 2px 11px;
    border: 0;
    background: transparent;
    cursor: pointer;
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 20px;
    line-height: 1.1;
    color: var(--color-text);
  }
  .site-footer__toggle-icon {
    position: relative;
    width: 24px;
    height: 24px;
    flex-shrink: 0;
  }
  .site-footer__toggle-icon:before,
  .site-footer__toggle-icon:after {
    content: "";
    position: absolute;
    background: var(--color-text);
    border-radius: 2px;
    transition: transform 0.35s cubic-bezier(0.32, 0.72, 0, 1);
  }
  .site-footer__toggle-icon:before {
    inset: 50% 4px;
    height: 2px;
    transform: translateY(-50%);
  }
  .site-footer__toggle-icon:after {
    inset: 4px 50%;
    width: 2px;
    transform: translate(-50%);
  }
  .site-footer__col-toggle[aria-expanded="true"]
    .site-footer__toggle-icon:after {
    transform: translate(-50%) rotate(90deg);
  }
  .site-footer__col--categories .site-footer__menu-wrap,
  .site-footer__col--shop .site-footer__menu-wrap {
    display: grid;
    grid-template-rows: 0fr;
    overflow: hidden;
    transition: grid-template-rows 0.32s cubic-bezier(0.22, 1, 0.36, 1);
  }
  .site-footer__col--categories.is-open .site-footer__menu-wrap,
  .site-footer__col--shop.is-open .site-footer__menu-wrap {
    grid-template-rows: 1fr;
  }
  .site-footer__col--categories .site-footer__menu,
  .site-footer__col--shop .site-footer__menu {
    min-height: 0;
  }
  .site-footer__menu {
    gap: 5px;
  }
  .site-footer__menu a {
    padding: 2px 11px;
    font-size: 16px;
    line-height: normal;
  }
  .site-footer__menu a:hover,
  .site-footer__social-link:hover {
    background: transparent;
  }
  .site-footer__submit:hover {
    background: var(--color-accent-sage);
  }
  .site-footer__col--contact .site-footer__menu a {
    font-size: 16px;
    font-weight: 500;
    line-height: 1.2;
  }
  .site-footer__social {
    gap: 3px;
    margin-top: 0;
  }
  .site-footer__social-link {
    width: 48px;
    height: 48px;
  }
  .site-footer__social-link svg {
    width: 31px;
    height: 31px;
  }
  .site-footer__lockup {
    margin-top: -14px;
    overflow: hidden;
  }
  .site-footer__lockup img {
    width: 100%;
    max-width: none;
  }
}
.front-page {
  background: var(--color-bg-light);
}
.front-page > .hero {
  margin-top: 0;
}
.front-page__section-title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h2);
  line-height: 1;
  color: var(--color-text);
  text-align: center;
}
.front-page__section-title--left {
  text-align: left;
}
@media (max-width: 1023px) {
  .front-page {
    display: flex;
    flex-direction: column;
  }
  .front-page > .hero {
    order: 1;
  }
  .front-page__categories {
    order: 2;
  }
  .front-page__bestsellers {
    order: 3;
  }
  .front-page__reviews {
    order: 4;
  }
  .front-page__collections {
    order: 5;
  }
  .front-page__blog {
    order: 6;
  }
  .front-page__intro {
    order: 7;
  }
  .front-page__instagram {
    order: 8;
  }
  .front-page__section-title {
    font-size: var(--fs-h2-mob);
  }
}
.front-page__cta {
  display: flex;
  justify-content: center;
  margin-top: 42px;
}
.front-page__categories {
  padding: 80px 0;
}
.front-page__categories .container {
  display: flex;
  flex-direction: column;
  gap: 42px;
  align-items: center;
}
.front-page__categories-layout {
  display: grid;
  grid-template-columns: 419fr 868fr;
  gap: 30px;
  width: 100%;
  height: 653px;
}
.front-page__categories-big > .category-card {
  height: 100%;
  aspect-ratio: auto;
}
.front-page__categories-small {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 30px;
}
.front-page__categories-small > .category-card {
  height: 100%;
  aspect-ratio: auto;
}
.front-page__categories-mobile-slider {
  display: none;
}
.front-page__categories .category-card,
.front-page__collections .category-card {
  border-radius: 20px;
}
.front-page__categories .category-card__overlay,
.front-page__collections .category-card__overlay {
  inset: 0;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 15px 10px;
  background: linear-gradient(to bottom, #0000 50%, #0006);
}
.front-page__categories .category-card__title,
.front-page__collections .category-card__title {
  text-align: center;
  text-shadow: none;
  color: var(--color-bg-light);
  font-size: var(--fs-h3);
  line-height: 1.1;
}
@media (max-width: 1023px) {
  .front-page__categories {
    padding: 60px 0;
    overflow: hidden;
  }
  .front-page__categories .container {
    align-items: stretch;
    gap: 32px;
  }
  .front-page__categories .front-page__section-title {
    text-align: left;
  }
  .front-page__categories-layout {
    display: none;
  }
  .front-page__categories-mobile-slider {
    display: block;
  }
  .front-page__categories-mobile-track {
    gap: 16px;
  }
  .front-page__categories-mobile-track > .category-card {
    flex: 0 0 clamp(325px, 76vw, 444px);
    width: clamp(325px, 76vw, 444px);
    height: auto;
    aspect-ratio: 444 / 550;
  }
  .front-page__categories .front-page__cta {
    display: none;
  }
}
.front-page__intro {
  padding: 80px 0;
}
.front-page__intro .container {
  display: flex;
  flex-direction: column;
  gap: 48px;
  align-items: center;
}
.front-page__intro-text {
  display: flex;
  flex-direction: column;
  gap: 24px;
  max-width: 870px;
  align-items: center;
  text-align: center;
}
.front-page__intro-heading {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h2);
  line-height: 1;
  color: var(--color-text);
  max-width: 805px;
}
.front-page__intro-desc {
  margin: 0;
  font-family: var(--font-body);
  font-size: 18px;
  line-height: 1.5;
  color: var(--color-text);
  max-width: 870px;
}
.front-page__benefits {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  width: 100%;
}
.front-page__benefit {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 19px;
  padding: 20px 30px;
  text-align: center;
}
.front-page__benefit-icon {
  height: 80px;
  width: auto;
  display: block;
  mix-blend-mode: darken;
}
.front-page__benefit-title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 28px;
  line-height: 1.1;
  color: var(--color-text);
}
@media (max-width: 1023px) {
  .front-page__intro-heading {
    font-size: var(--fs-h2-mob);
  }
  .front-page__intro-desc {
    font-size: 16px;
  }
  .front-page__benefits {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .front-page__benefit {
    flex-direction: row;
    align-items: center;
    text-align: left;
    gap: 20px;
    padding: 20px 0;
  }
  .front-page__benefit-icon {
    flex-shrink: 0;
  }
  .front-page__benefit-title {
    font-size: 16px;
  }
}
@media (max-width: 639px) {
  .front-page__intro {
    padding: 86px 0 90px;
  }
  .front-page__intro .container {
    gap: 76px;
    align-items: center;
    padding-inline: 20px;
  }
  .front-page__intro-text {
    align-items: center;
    text-align: center;
    gap: 30px;
    width: 100%;
  }
  .front-page__intro-text:before {
    content: "Dlaczego Mido?";
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 20px;
    line-height: 1.1;
    color: var(--color-text);
  }
  .front-page__intro-heading {
    font-size: 34px;
    line-height: 1.25;
    max-width: 351px;
    text-align: center;
  }
  .front-page__intro-desc {
    display: none;
  }
  .front-page__benefits {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 58px;
    width: 100%;
    max-width: 351px;
  }
  .front-page__benefit {
    flex-direction: column;
    align-items: center;
    text-align: center;
    min-height: 0;
    padding: 0;
    gap: 24px;
    width: 100%;
  }
  .front-page__benefit-icon {
    width: auto;
    height: auto;
    max-height: 80px;
    object-fit: contain;
    mix-blend-mode: normal;
  }
  .front-page__benefit-title {
    max-width: 320px;
    font-size: 24px;
    line-height: 1.05;
    text-align: center;
  }
  .front-page__intro .front-page__cta {
    display: none;
  }
}
.front-page__bestsellers {
  padding: 80px 0;
}
.front-page__bestsellers .container {
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.front-page__bestsellers-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}
.front-page__bestsellers-track > .product-card-slot {
  flex: 0 0 307px;
  width: 307px;
  max-width: 307px;
  height: 460px;
  overflow: visible;
}
.front-page__bestsellers-track .product-card {
  max-width: none;
  width: 100%;
}
.front-page__bestsellers-slider,
.front-page__bestsellers-track {
  overflow-y: visible;
}
.front-page__bestsellers-track {
  align-items: flex-start;
}
@media (max-width: 1023px) {
  .front-page__bestsellers-header {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
  }
  .front-page__bestsellers-header .front-page__section-title {
    flex: 1 1 auto;
    min-width: 0;
  }
  .front-page__bestsellers-header .btn {
    flex: 0 0 auto;
  }
  .front-page__bestsellers-track > .product-card-slot {
    flex: 0 0 280px;
    width: 280px;
    max-width: 280px;
    height: 400px;
  }
}
.front-page__reviews {
  padding: 80px 0;
}
.front-page__reviews .container {
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: center;
}
.front-page__reviews-eyebrow {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 20px;
  line-height: 1.1;
  color: var(--color-text);
  text-align: center;
}
.front-page__reviews-heading-wrap {
  position: relative;
  width: 100%;
  display: flex;
  justify-content: center;
}
.front-page__reviews-heading {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h2);
  line-height: 1;
  color: var(--color-text-near-black);
  text-align: center;
  max-width: 800px;
  z-index: 1;
}
.front-page__reviews-decor {
  display: none;
}
.front-page__reviews-decor--left-1 {
  left: 18%;
  top: -30px;
  transform: rotate(-145deg);
}
.front-page__reviews-decor--left-2 {
  left: 23%;
  top: 60px;
  transform: rotate(80deg);
}
.front-page__reviews-decor--right-1 {
  right: 22%;
  top: -50px;
  transform: rotate(-180deg) scaleY(-1) rotate(139deg);
}
.front-page__reviews-decor--right-2 {
  right: 17%;
  top: 30px;
  transform: rotate(4deg);
}
.front-page__reviews-marquee {
  margin-top: 32px;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  overflow: hidden;
}
.front-page__reviews-track {
  display: flex;
  gap: 30px;
  align-items: flex-start;
  width: max-content;
  padding-top: 16px;
  padding-bottom: 28px;
  animation: mido-reviews-marquee 44s linear infinite;
  will-change: transform;
}
.front-page__reviews-item {
  flex: 0 0 351px;
  width: 351px;
}
@keyframes mido-reviews-marquee {
  0% {
    transform: translate(0);
  }
  to {
    transform: translate(calc(-50% - 15px));
  }
}
@media (prefers-reduced-motion: reduce) {
  .front-page__reviews-track {
    animation: none;
    transform: none;
  }
}
@media (max-width: 1023px) {
  .front-page__reviews-heading {
    font-size: var(--fs-h2-mob);
  }
  .front-page__reviews-decor {
    display: none;
  }
  .front-page__reviews-item {
    flex-basis: 325px;
    width: 325px;
  }
  .front-page__reviews-item > .review-card--photo,
  .front-page__reviews-item > .review-card--quote {
    width: 325px;
  }
}
.front-page__collections {
  background: var(--color-bg-cream-warm);
  padding: 80px 57px 80px 59px;
  box-sizing: border-box;
}
.front-page__collections .container {
  display: flex;
  flex-direction: column;
  gap: 45px;
  align-items: center;
  max-width: none;
  padding: 0;
  margin: 0 auto;
  width: 100%;
}
.front-page__collections-panel,
.front-page__collections > .container > .front-page__section-title,
.front-page__collections-toggle {
  flex-shrink: 0;
}
.front-page__collections > .container > .front-page__section-title {
  margin-bottom: -21px;
}
.front-page__collections-toggle {
  display: flex;
  align-items: center;
  width: 472px;
  height: 60px;
  background: var(--color-bg-light);
  border-radius: 50px;
  padding: 10px;
  gap: 0;
  box-sizing: border-box;
}
.front-page__collections-toggle-btn {
  flex: 1;
  height: 40px;
  border: 0;
  background: transparent;
  cursor: pointer;
  border-radius: 30px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 20px;
  line-height: 24px;
  color: var(--color-text);
  transition: background-color 0.16s ease;
}
.front-page__collections-toggle-btn.is-active {
  background: var(--color-accent-yellow);
  color: var(--color-text);
}
.front-page__collections-panel[hidden],
.front-page__collections-mobile-slider {
  display: none;
}
.front-page__collections-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  align-items: start;
  gap: clamp(24px, 2vw, 33px);
  width: 100%;
  box-sizing: border-box;
}
.front-page__collection-card {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: 20px;
  text-decoration: none;
  color: inherit;
  flex-shrink: 0;
}
.front-page__collection-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.front-page__collection-card--big {
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
}
.front-page__collections-grid-right {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(24px, 2vw, 33px);
  width: 100%;
}
.front-page__collections-grid-right .front-page__collection-card {
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
}
.front-page__collection-cart {
  position: absolute;
  z-index: 2;
}
.front-page__collection-popup {
  position: absolute;
  left: clamp(120px, calc(var(--popup-x, 50%) + 24px), calc(100% - 120px));
  top: auto;
  bottom: calc(100% - var(--popup-y, 50%) + 26px);
  width: 220px;
  background: var(--color-accent-yellow);
  border-radius: 20px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  z-index: 3;
  box-sizing: border-box;
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, 8px);
  transition:
    opacity 0.22s ease,
    transform 0.32s cubic-bezier(0.22, 1, 0.36, 1);
}
.front-page__collection-popup:before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  height: 32px;
  background: transparent;
}
.front-page__collection-popup:after {
  content: "";
  position: absolute;
  bottom: -18px;
  left: 50%;
  transform: translate(-50%);
  width: 28px;
  height: 18px;
  background: var(--color-accent-yellow);
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}
.front-page__collection-cart:hover + .front-page__collection-popup,
.front-page__collection-cart:focus-visible + .front-page__collection-popup,
.front-page__collection-popup:hover,
.front-page__collection-card.is-popup-open .front-page__collection-popup {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%);
}
.front-page__collection-popup-title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 20px;
  line-height: 1.1;
  color: var(--color-text);
  text-align: center;
  width: 100%;
}
.front-page__collection-popup-price {
  margin: 0;
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.4;
  color: var(--color-text);
  text-align: center;
  width: 100%;
}
.front-page__collection-popup-cta {
  margin-top: 8px;
  background: var(--color-text);
  color: var(--color-bg-beige);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 20px;
  line-height: 24px;
  height: 40px;
  padding: 0 32px;
  border-radius: 50px;
  width: 100%;
  text-align: center;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
}
@media (max-width: 1399px) {
  .front-page__collections-grid {
    grid-template-columns: 1fr;
    width: 100%;
    gap: 30px;
  }
  .front-page__collection-card--big {
    width: 100%;
    max-width: 644px;
    height: auto;
    aspect-ratio: 1 / 1;
  }
  .front-page__collections-grid-right {
    width: 100%;
    max-width: 644px;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: 30px;
  }
  .front-page__collections-grid-right .front-page__collection-card {
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
  }
}
@media (max-width: 1023px) {
  .front-page__collections {
    padding: 60px 0;
    overflow: hidden;
  }
  .front-page__collections .container {
    gap: 32px;
    padding-inline: var(--space-24);
    box-sizing: border-box;
  }
  .front-page__collections > .container > .front-page__section-title {
    margin-bottom: -8px;
    text-align: center;
    width: 100%;
  }
  .front-page__collections-toggle {
    width: 100%;
    max-width: 472px;
  }
  .front-page__collections-grid {
    display: none;
  }
  .front-page__collections-mobile-slider {
    display: block;
    margin-top: 0;
  }
  .front-page__collections-mobile-track {
    gap: 16px;
  }
  .front-page__collections-mobile-track > .front-page__collection-card {
    flex: 0 0 min(478px, calc(100vw - 48px));
    width: min(478px, calc(100vw - 48px));
    aspect-ratio: 478 / 641;
    scroll-snap-align: start;
  }
  .front-page__collection-card--mobile .front-page__collection-popup {
    inset: auto auto 20px 50%;
    width: calc(100% - 40px);
    max-width: 444px;
    min-height: 118px;
    padding: 20px 28px 24px;
    border-radius: 20px;
    gap: 6px;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translate(-50%);
  }
  .front-page__collection-card--mobile .front-page__collection-popup:after {
    display: none;
  }
  .front-page__collection-card--mobile .front-page__collection-popup-title {
    font-size: 20px;
  }
  .front-page__collection-card--mobile .front-page__collection-popup-cta {
    height: 40px;
    font-size: 20px;
    margin-top: 8px;
  }
  .front-page__collections .slider__arrow {
    background: var(--color-bg-light);
  }
  .front-page__collections .front-page__cta {
    display: none;
  }
}
.front-page__blog {
  padding: 80px 0;
}
.front-page__blog .container {
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.front-page__blog-header {
  display: grid;
  grid-template-columns: 631fr 412fr;
  gap: 60px;
  align-items: flex-start;
}
.front-page__blog-tagline {
  margin: 0;
  font-family: var(--font-body);
  font-size: 18px;
  line-height: 1.5;
  color: var(--color-text);
}
.front-page__blog-mobile-cta {
  display: none;
}
.front-page__blog-track > .blog-card {
  flex: 0 0 clamp(320px, calc((min(100vw, 1920px) - 180px) / 3), 580px);
  width: clamp(320px, calc((min(100vw, 1920px) - 180px) / 3), 580px);
}
.front-page__blog-track > .blog-card .blog-card__image-wrap {
  height: auto;
  aspect-ratio: 420 / 320;
}
.front-page__blog-track
  > .blog-card[data-variant="tall"]
  .blog-card__image-wrap {
  height: auto;
  aspect-ratio: 420 / 436;
}
@media (max-width: 1023px) {
  .front-page__blog-track > .blog-card {
    flex: 0 0 320px;
    width: 320px;
  }
}
.front-page__blog-cta-row {
  display: flex;
  justify-content: flex-end;
  margin-top: 16px;
}
@media (max-width: 1023px) {
  .front-page__blog-header {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .front-page__blog-mobile-cta {
    display: flex;
    justify-content: flex-start;
    margin-top: -12px;
  }
  .front-page__blog-slider .slider__cta {
    display: none;
  }
  .front-page__blog-track {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    margin-inline: calc(-1 * var(--space-24));
    padding-inline: var(--space-24);
  }
  .front-page__blog-track::-webkit-scrollbar {
    display: none;
  }
  .front-page__blog-track > * {
    flex: 0 0 320px;
    scroll-snap-align: start;
    transform: none !important;
  }
  .front-page__blog-cta-row {
    justify-content: center;
  }
}
.front-page__instagram {
  padding: 80px 0;
}
.front-page__instagram .container {
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: center;
}
.front-page__instagram .front-page__section-title {
  font-size: var(--fs-h3);
}
.front-page__instagram .front-page__section-title a {
  color: inherit;
  text-decoration: none;
}
.front-page__instagram .front-page__section-title a:hover {
  text-decoration: underline;
}
.front-page__instagram-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 30px;
  width: 100%;
}
.front-page__instagram-item {
  display: block;
  aspect-ratio: 308 / 404;
  overflow: hidden;
  border-radius: 20px;
}
.front-page__instagram-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.front-page__instagram-item:hover img {
  transform: scale(1.04);
}
@media (max-width: 1023px) {
  .front-page__instagram-grid {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    margin-inline: calc(-1 * var(--space-24));
    padding-inline: var(--space-24);
  }
  .front-page__instagram-grid::-webkit-scrollbar {
    display: none;
  }
  .front-page__instagram-item {
    flex: 0 0 154px;
    scroll-snap-align: start;
  }
}
.page-generic {
  padding-block: var(--space-64) var(--space-96);
}
.page-generic__header {
  text-align: center;
  margin-bottom: var(--space-48);
  max-width: 800px;
}
.page-generic__title {
  margin: 0 0 var(--space-16);
}
.page-generic__lead {
  color: var(--color-text-muted);
  margin: 0;
}
.page-generic__thumbnail {
  margin: 0 0 var(--space-48);
  border-radius: var(--radius-card);
  overflow: hidden;
}
.page-generic__thumbnail img {
  width: 100%;
  height: auto;
  display: block;
}
.page-generic__body {
  max-width: 760px;
}
.page-generic__pagination {
  display: flex;
  gap: var(--space-8);
  justify-content: center;
  margin-top: var(--space-48);
}
.single-post {
  padding-block: 0;
}
.single-post__topbar {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding-top: var(--space-24);
  padding-bottom: var(--space-24);
}
.single-post__back {
  display: inline-flex;
  align-items: center;
  gap: var(--space-8);
  padding: 6px 20px 6px 12px;
  border-radius: var(--radius-pill);
  background: var(--color-bg-beige);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-16);
  line-height: 1.1;
  color: var(--color-text);
  text-decoration: none;
  transition: background-color 0.16s ease;
}
.single-post__back:hover {
  background: var(--color-accent-yellow);
}
.single-post__back svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}
.single-post__article {
  max-width: none;
}
.single-post__header {
  text-align: center;
  margin-bottom: var(--space-48);
  max-width: 866px;
  margin-inline: auto;
  padding-top: var(--space-32);
}
.single-post__meta-top {
  display: inline-flex;
  align-items: center;
  gap: var(--space-10);
  margin-bottom: var(--space-24);
}
.single-post__date {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-14);
  line-height: 24px;
  color: var(--color-text-muted);
}
.single-post__title {
  margin: 0 0 var(--space-24);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h2);
  line-height: 1;
  color: var(--color-text);
}
.single-post__lead {
  max-width: 737px;
  margin: 0 auto;
  font-family: var(--font-body);
  font-size: var(--fs-body-20);
  line-height: 1.4;
  color: var(--color-text);
}
.single-post__thumbnail {
  margin: 0 auto;
  max-width: 768px;
  aspect-ratio: 768 / 574;
  overflow: hidden;
  mask: url(../images/post-mask.svg) center / contain no-repeat;
  -webkit-mask: url(../images/post-mask.svg) center / contain no-repeat;
}
.single-post__thumbnail img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
}
.single-post__body.prose {
  max-width: 650px;
  margin-inline: auto;
  padding-left: 0;
  padding-right: 0;
  padding-bottom: var(--space-48);
}
.single-post__duo-images {
  display: flex;
  gap: var(--space-32);
  margin: var(--space-48) 0;
}
.single-post__product-image {
  position: relative;
  flex: 1;
  margin: 0;
  border-radius: var(--radius-card);
  overflow: hidden;
}
.single-post__product-image img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  display: block;
  border-radius: var(--radius-card);
}
.single-post__product-link {
  position: absolute;
  bottom: var(--space-16);
  left: var(--space-16);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--color-accent-yellow);
  color: var(--color-text);
  transition:
    transform 0.16s ease,
    background-color 0.16s ease;
}
.single-post__product-link:hover {
  transform: scale(1.1);
  background: #e6d47e;
}
.single-post__product-link svg {
  width: 24px;
  height: 24px;
}
.single-post__figure {
  margin: var(--space-48) 0;
}
.single-post__figure img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--radius-card);
}
.single-post__figure figcaption {
  margin-top: var(--space-12);
  font-family: var(--font-body);
  font-size: var(--fs-body-16);
  color: var(--color-text);
}
.single-post__highlight {
  margin: var(--space-48) 0;
  padding: var(--space-32);
  background: var(--color-accent-yellow);
  border-radius: var(--radius-card);
  text-align: center;
}
.single-post__highlight p {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h5);
  line-height: var(--lh-h5);
  color: var(--color-text);
  margin: 0;
}
.single-post__body.prose h2 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h4);
  line-height: var(--lh-h4);
  margin-top: var(--space-48);
  margin-bottom: var(--space-40);
}
.single-post__body.prose h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h3);
  line-height: var(--lh-h3);
  margin-top: var(--space-48);
  margin-bottom: var(--space-40);
  text-align: center;
}
.single-post__body.prose p {
  font-family: var(--font-body);
  font-size: var(--fs-body-20);
  line-height: 1.4;
  color: var(--color-text);
}
.single-post__body.prose a {
  text-decoration: underline;
  text-decoration-style: dotted;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  color: var(--color-text);
}
.single-post__body.prose a:hover {
  text-decoration-style: solid;
}
.single-post__body.prose .wp-block-image {
  margin: var(--space-48) calc(-1 * var(--space-20));
}
.single-post__body.prose .wp-block-image img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-card);
  display: block;
}
.single-post__body.prose .wp-block-image figcaption {
  margin-top: var(--space-12);
  font-family: var(--font-body);
  font-size: var(--fs-body-16);
  color: var(--color-text);
}
.single-post__body.prose .wp-block-gallery {
  display: flex;
  gap: var(--space-32);
  margin: var(--space-48) 0;
}
.single-post__body.prose .wp-block-gallery .wp-block-image {
  margin: 0;
  flex: 1;
}
.single-post__body.prose .wp-block-gallery .wp-block-image img {
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: var(--radius-card);
}
.single-post__body.prose blockquote,
.single-post__body.prose .wp-block-quote {
  margin: var(--space-48) 0;
  padding: var(--space-32);
  background: var(--color-accent-yellow);
  border: 0;
  border-radius: var(--radius-card);
  text-align: center;
}
.single-post__body.prose blockquote p,
.single-post__body.prose .wp-block-quote p {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h5);
  line-height: var(--lh-h5);
  color: var(--color-text);
  margin: 0;
}
.single-post__body.prose blockquote cite,
.single-post__body.prose .wp-block-quote cite {
  display: none;
}
.single-post__footer {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-24);
  max-width: 650px;
  margin: 0 auto var(--space-80);
  padding-top: var(--space-24);
}
.single-post__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-8);
  justify-content: center;
}
.single-post__share {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  padding: 0 20px;
  border: 2px solid var(--color-text);
  border-radius: var(--radius-pill);
  background: transparent;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-16);
  line-height: 24px;
  color: var(--color-text);
  cursor: pointer;
  transition:
    background-color 0.16s ease,
    color 0.16s ease;
}
.single-post__share:hover {
  background: var(--color-text);
  color: var(--color-bg-beige);
}
.single-post__products {
  background: var(--color-bg-beige);
  border-radius: var(--radius-card);
  max-width: 1920px;
  margin: 0 auto var(--space-80);
  padding: var(--space-64);
}
.single-post__products-inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-32);
  align-items: center;
}
.single-post__products-title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h5);
  line-height: var(--lh-h5);
  color: var(--color-text);
  text-align: center;
}
.single-post__products-grid {
  display: flex;
  gap: 30px;
  justify-content: center;
  flex-wrap: wrap;
  padding-bottom: 12px;
}
.single-post__related {
  margin-top: 0;
  padding-top: var(--space-80);
  padding-bottom: var(--space-80);
  border-top: none;
  width: 1920px;
  max-width: 100%;
  margin-inline: auto;
}
.single-post__related-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-32);
}
.single-post__related-title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h2);
  line-height: 1;
  color: var(--color-text);
  text-align: left;
}
.single-post__related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  align-items: start;
}
.single-post__related-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: var(--space-48);
  position: relative;
}
.single-post__related-dots {
  position: absolute;
  left: 0;
  display: flex;
  gap: var(--space-8);
  align-items: center;
}
.single-post__related-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--color-text);
  opacity: 0.2;
  cursor: pointer;
  transition: opacity 0.16s ease;
}
.single-post__related-dot.is-active {
  opacity: 1;
}
.single-post__related-arrows {
  display: flex;
  gap: var(--space-12);
}
.single-post__related-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1.5px solid var(--color-text);
  background: transparent;
  color: var(--color-text);
  cursor: pointer;
  transition:
    background-color 0.16s ease,
    color 0.16s ease;
}
.single-post__related-arrow:hover {
  background: var(--color-text);
  color: var(--color-bg-beige);
}
.btn--sage {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 46px;
  padding: 0 var(--space-32);
  border-radius: var(--radius-pill);
  border: 0;
  background: var(--color-accent-sage);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-button-l);
  line-height: var(--lh-button);
  color: var(--color-text);
  text-decoration: none;
  cursor: pointer;
  transition: background-color 0.16s ease;
}
.btn--sage:hover {
  background: var(--color-accent-sage-hover);
}
.btn--outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 20px;
  border: 2px solid var(--color-text);
  border-radius: var(--radius-pill);
  background: transparent;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-16);
  color: var(--color-text);
  cursor: pointer;
  text-decoration: none;
  transition:
    background-color 0.16s ease,
    color 0.16s ease;
}
.btn--outline:hover {
  background: var(--color-text);
  color: var(--color-bg-beige);
}
@media (max-width: 1023px) {
  .single-post__header {
    max-width: 100%;
    padding-top: var(--space-24);
  }
  .single-post__title {
    font-size: var(--fs-h2-mob);
  }
  .single-post__lead {
    font-size: var(--fs-body-16);
  }
  .single-post__body.prose h3 {
    font-size: var(--fs-h3-mob);
  }
  .single-post__products {
    padding: var(--space-40) var(--space-24);
    margin-inline: var(--space-20);
    border-radius: var(--radius-card);
  }
  .single-post__products-grid {
    gap: var(--space-20);
  }
  .single-post__related-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-16);
  }
  .single-post__related-title {
    font-size: var(--fs-h2-mob);
  }
  .single-post__related-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-24);
  }
}
@media (max-width: 639px) {
  .single-post__article {
    display: flex;
    flex-direction: column;
  }
  .single-post__topbar {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-12);
    padding-top: 24px;
    padding-bottom: 24px;
  }
  .single-post__header {
    order: 2;
    padding-top: 28px;
    margin-bottom: 32px;
    text-align: left;
  }
  .single-post__thumbnail {
    order: 1;
    width: calc(100vw - 40px);
    max-width: 351px;
    aspect-ratio: 351 / 332;
    margin-inline: auto;
  }
  .single-post__meta-top {
    margin-bottom: var(--space-16);
    justify-content: flex-start;
  }
  .single-post__title {
    font-size: 26px;
    line-height: 1;
    margin-bottom: 20px;
  }
  .single-post__lead {
    font-size: var(--fs-body-16);
    margin: 0;
  }
  .single-post__separator {
    margin: var(--space-32) auto;
  }
  .single-post__body.prose {
    order: 3;
    max-width: 100%;
    width: calc(100vw - 40px);
    padding-bottom: 32px;
  }
  .single-post__body.prose h2,
  .single-post__body.prose h3 {
    font-size: var(--fs-h4-mob);
    margin-top: var(--space-32);
    margin-bottom: var(--space-24);
  }
  .single-post__body.prose p {
    font-size: var(--fs-body-blog-mob);
  }
  .single-post__body.prose .wp-block-image {
    margin-inline: 0;
  }
  .single-post__duo-images,
  .single-post__body.prose .wp-block-gallery {
    flex-direction: column;
    gap: var(--space-16);
  }
  .single-post__body.prose blockquote,
  .single-post__body.prose .wp-block-quote {
    padding: var(--space-24);
  }
  .single-post__body.prose blockquote p,
  .single-post__body.prose .wp-block-quote p {
    font-size: var(--fs-h5-mob);
  }
  .single-post__footer {
    order: 4;
    margin-bottom: var(--space-48);
  }
  .single-post__products {
    padding: var(--space-32) var(--space-16);
    margin-inline: var(--space-16);
  }
  .single-post__products-title {
    font-size: var(--fs-h5-mob);
  }
  .single-post__products-grid {
    flex-direction: column;
    align-items: center;
  }
  .single-post__related-grid {
    grid-template-columns: 1fr;
  }
  .single-post__related-title {
    font-size: var(--fs-h3-mob);
  }
}
.single-post__pagination {
  margin-top: var(--space-32);
  display: flex;
  gap: var(--space-8);
  justify-content: center;
}
.blog-index,
.blog-archive {
  padding-block: var(--space-64) 300px;
}
.poradniki-template {
  background: var(--color-bg-light);
  overflow-x: hidden;
}
.poradniki-template .guide-section {
  display: flex;
  flex-direction: column;
  gap: var(--space-32);
  margin-bottom: var(--space-80);
}
.poradniki-template .section-title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h2);
  line-height: var(--lh-h2);
  color: var(--color-text);
  text-align: center;
}
.poradniki-template .guide-section__lead {
  margin: calc(var(--space-16) * -1) auto var(--space-16);
  max-width: 760px;
  font-family: var(--font-body);
  font-size: var(--fs-body-20);
  line-height: 1.45;
  color: var(--color-text);
  text-align: center;
}
.poradniki-template .text-img-section {
  position: relative;
  isolation: isolate;
  overflow: visible;
}
.poradniki-template .text-img-section__mobile-card {
  display: none;
}
.poradniki-template .text-img-section__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr);
  align-items: start;
  gap: 0;
  min-height: clamp(520px, 42vw, 760px);
}
.poradniki-template .text-img-section__content {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--space-24);
  min-height: clamp(440px, 32vw, 528px);
  padding: clamp(32px, 3vw, 42px) clamp(160px, 22vw, 320px)
    clamp(32px, 3vw, 42px) clamp(32px, 2vw, 38px);
  margin-top: clamp(40px, 5vw, 100px);
  background: var(--color-accent-yellow);
  border-radius: var(--radius-card);
  color: var(--color-text);
}
.poradniki-template .text-img-section__content > * {
  max-width: 100%;
  overflow-wrap: break-word;
}
.poradniki-template .text-img-section__meta {
  display: flex;
  align-items: center;
  gap: var(--space-24);
  font-family: var(--font-display);
  font-size: var(--fs-body-14);
  font-weight: 500;
  line-height: 1;
  color: var(--color-text-muted);
}
.poradniki-template .text-img-section__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0 var(--space-16);
  border-radius: var(--radius-pill);
  background: var(--color-text-muted);
  color: #f2ead7;
}
.poradniki-template .text-img-section__content h2 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h2);
  line-height: 0.95;
  color: var(--color-text);
  max-width: 560px;
}
.poradniki-template .text-img-section__content p {
  margin: 0;
  max-width: 560px;
  font-family: var(--font-body);
  font-size: var(--fs-body-20);
  line-height: 1.45;
  color: var(--color-text);
}
.poradniki-template .text-img-section__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-12);
  align-items: center;
  margin-top: var(--space-4);
}
.poradniki-template .text-img-section__actions .btn {
  border-color: var(--color-text);
  color: var(--color-text);
  background: transparent;
}
.poradniki-template .text-img-section__media {
  position: relative;
  z-index: 2;
  margin-left: clamp(-260px, -14vw, -120px);
  height: auto;
  aspect-ratio: 740 / 575;
  overflow: hidden;
  mask: url(../images/herbatnik-maska-yellow.svg) center / 100% 100% no-repeat;
  -webkit-mask: url(../images/herbatnik-maska-yellow.svg) center / 100% 100%
    no-repeat;
}
.poradniki-template .text-img-section__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.blog-index__header,
.blog-archive__header {
  text-align: center;
  margin-bottom: var(--space-48);
  max-width: 800px;
}
.blog-index__title,
.blog-archive__title {
  margin: 0 0 var(--space-16);
}
.blog-index__lead,
.blog-archive__description {
  color: var(--color-text-muted);
  margin: 0;
}
.blog-index__grid,
.blog-archive__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-24);
}
.poradniki-template .blog-index__grid-wrap {
  margin-top: calc(var(--space-80) + clamp(32px, 5vw, 100px));
}
.poradniki-template .blog-index__grid {
  align-items: start;
  gap: var(--space-64) 30px;
}
@media (max-width: 1140px) {
  .blog-index__grid,
  .blog-archive__grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .poradniki-template .guide-section {
    gap: var(--space-32);
    margin-bottom: var(--space-64);
  }
  .poradniki-template .section-title {
    font-size: var(--fs-h2-mob);
    line-height: 1.05;
    text-align: left;
  }
  .poradniki-template .guide-section__lead {
    margin: calc(var(--space-8) * -1) 0 var(--space-16);
    font-size: var(--fs-body-16);
    text-align: left;
  }
  .poradniki-template .breadcrumbs__list {
    justify-content: flex-start;
  }
  .poradniki-template .text-img-section {
    border-radius: 0;
  }
  .poradniki-template .text-img-section__layout {
    display: none;
  }
  .poradniki-template .text-img-section__mobile-card {
    display: block;
    border-radius: 20px;
    overflow: hidden;
  }
  .poradniki-template .text-img-section__mobile-img {
    position: relative;
    z-index: 1;
    height: 380px;
    overflow: hidden;
    margin-bottom: -40px;
  }
  .poradniki-template .text-img-section__mobile-img img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .poradniki-template .text-img-section__scallop {
    display: block;
    width: 100%;
    height: auto;
    position: relative;
    z-index: 1;
    margin-bottom: -1px;
    vertical-align: bottom;
  }
  .poradniki-template .text-img-section__mobile-bottom {
    position: relative;
    z-index: 2;
    font-size: 0;
    line-height: 0;
  }
  .poradniki-template .text-img-section__mobile-body {
    font-size: initial;
    line-height: initial;
  }
  .poradniki-template .text-img-section__mobile-body {
    background: var(--color-accent-yellow);
    padding: 24px 24px 32px;
    display: flex;
    flex-direction: column;
    gap: var(--space-24);
  }
  .poradniki-template .text-img-section__mobile-body h2 {
    margin: 0;
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 32px;
    line-height: 0.95;
    color: var(--color-text);
  }
  .poradniki-template .text-img-section__mobile-body .text-img-section__meta {
    gap: var(--space-12);
  }
}
@media (max-width: 639px) {
  .poradniki-template .container {
    max-width: none;
    width: 100%;
    padding-inline: 20px;
    box-sizing: border-box;
  }
  .blog-index,
  .blog-archive {
    padding-block: 0;
  }
  .blog-index__header,
  .blog-archive__header {
    margin-bottom: 32px;
    text-align: left;
  }
  .blog-index__title,
  .blog-archive__title {
    font-size: 40px;
    line-height: 0.95;
  }
  .blog-index__grid,
  .blog-archive__grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .poradniki-template .guide-section {
    margin-bottom: var(--space-48);
  }
  .poradniki-template
    .text-img-section__mobile-body
    .text-img-section__actions {
    align-items: flex-start;
  }
  .poradniki-template
    .text-img-section__mobile-body
    .text-img-section__actions
    .btn {
    width: auto;
  }
}
.blog-index__pagination,
.blog-archive__pagination,
.search-results__pagination {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-4);
  margin: var(--space-64) 0;
}
.blog-index__pagination a,
.blog-index__pagination span,
.blog-archive__pagination a,
.blog-archive__pagination span,
.search-results__pagination a,
.search-results__pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 var(--space-12);
  border-radius: var(--radius-pill);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-14);
  color: var(--color-text);
  text-decoration: none;
  background: var(--color-bg-light);
  transition: background-color 0.16s ease;
}
.blog-index__pagination a:hover,
.blog-archive__pagination a:hover,
.search-results__pagination a:hover {
  background: var(--color-accent-sage);
}
.blog-index__pagination .current,
.blog-archive__pagination .current,
.search-results__pagination .current {
  background: var(--color-text);
  color: var(--color-bg-beige);
}
.blog-index__empty,
.blog-archive__empty {
  text-align: center;
  padding: var(--space-64) 0;
  color: var(--color-text-muted);
}
main.woocommerce-page {
  padding-block: var(--space-64) var(--space-96);
}
body.single-product main.woocommerce-page {
  padding-block: 0;
}
body.post-type-archive-product main.woocommerce-page,
body.tax-product_cat main.woocommerce-page {
  padding-block: 0 var(--space-96);
}
body.woocommerce-cart .mido-cart,
body.woocommerce-cart .mido-cart__cross-sells,
body.woocommerce-checkout .mido-checkout,
body.woocommerce-order-received main.woocommerce-page > article,
body.woocommerce-account main.woocommerce-page > article {
  max-width: 1440px;
  margin-inline: auto;
  box-sizing: border-box;
}
body.woocommerce-order-received main.woocommerce-page > article,
body.woocommerce-account main.woocommerce-page > article {
  padding-inline: 60px;
}
body.woocommerce-cart .woocommerce-notices-wrapper,
body.woocommerce-checkout .woocommerce-notices-wrapper,
body.woocommerce-order-received .woocommerce-notices-wrapper,
body.woocommerce-account .woocommerce-notices-wrapper {
  max-width: 1440px;
}
body.woocommerce-cart .cart-empty,
body.woocommerce-cart .return-to-shop,
body.woocommerce-checkout .cart-empty,
body.woocommerce-checkout .return-to-shop {
  max-width: 1440px;
  margin-inline: auto;
  box-sizing: border-box;
}
body.woocommerce-cart .cart-empty,
body.woocommerce-checkout .cart-empty,
body.woocommerce-cart .return-to-shop,
body.woocommerce-checkout .return-to-shop {
  padding-inline: 60px;
}
@media (max-width: 1023px) {
  body.woocommerce-order-received main.woocommerce-page > article,
  body.woocommerce-account main.woocommerce-page > article {
    padding-inline: 20px;
  }
  body.woocommerce-cart .cart-empty,
  body.woocommerce-cart .return-to-shop,
  body.woocommerce-checkout .cart-empty,
  body.woocommerce-checkout .return-to-shop {
    padding-inline: 20px;
  }
}
.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-notice {
  padding: var(--space-16) var(--space-20);
  border-radius: var(--radius-card);
  margin-bottom: var(--space-24);
  display: flex;
  align-items: center;
  gap: var(--space-12);
  font-family: var(--font-body);
  font-size: var(--fs-body-16);
  list-style: none;
}
.woocommerce-message {
  background: var(--color-accent-sage);
  color: var(--color-text);
}
.woocommerce-info {
  background: var(--color-bg-beige);
  color: var(--color-text);
}
.woocommerce-error {
  background: color-mix(in srgb, var(--color-accent-yellow) 60%, white);
  color: var(--color-text);
}
ul.woocommerce-error,
.woocommerce-checkout .woocommerce-error {
  display: block;
}
.woocommerce-error li {
  margin: 0;
}
.woocommerce-error li + li {
  margin-top: var(--space-8);
}
.woocommerce-checkout form.checkout > .woocommerce-NoticeGroup,
.woocommerce-checkout form.checkout > .woocommerce-NoticeGroup-checkout {
  grid-column: 1 / -1;
  width: 100%;
}
.woocommerce-message .button,
.woocommerce-info .button,
.woocommerce-error .button {
  margin-left: auto;
}
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce .button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-8);
  padding: var(--space-12) var(--space-24);
  border-radius: var(--radius-pill);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-14);
  line-height: 1;
  background: var(--color-text);
  color: var(--color-bg-beige);
  border: 2px solid var(--color-text);
  cursor: pointer;
  text-decoration: none;
  transition:
    background-color var(--transition-normal),
    color var(--transition-normal),
    transform var(--transition-fast);
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce .button:hover {
  background: var(--color-primary-hover);
  border-color: var(--color-primary-hover);
}
.woocommerce .button.alt {
  background: var(--color-accent-sage);
  color: var(--color-text);
  border-color: var(--color-accent-sage);
}
.woocommerce .button.alt:hover {
  background: var(--color-text);
  color: var(--color-bg-beige);
  border-color: var(--color-text);
}
body.woocommerce-page.tax-product_cat,
body.woocommerce-page.post-type-archive-product {
  background: var(--color-bg-light);
}
.wc-archive__header {
  margin: 0;
  width: 100%;
}
.wc-archive__header-inner {
  background: var(--color-bg-beige);
  padding: 60px 60px 40px;
}
.wc-archive__header-inner .breadcrumbs {
  max-width: 1920px;
  margin: 0 auto;
  text-align: left;
}
.wc-archive__header-inner .breadcrumbs__list {
  justify-content: flex-start;
}
.wc-archive__header-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  align-items: end;
  gap: 60px;
  max-width: 1920px;
  margin: 0 auto;
}
.wc-archive__header-separator {
  display: block;
  width: 100%;
  height: auto;
  margin: 0;
  padding: 0;
  line-height: 0;
}
.wc-archive__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 80px;
  line-height: 1;
  color: var(--color-text);
}
.wc-archive__intro {
  font-family: var(--font-body);
  font-size: 18px;
  line-height: 1.4;
  color: var(--color-text);
  max-width: 540px;
  justify-self: end;
}
.wc-archive__intro p {
  margin: 0;
}
.wc-archive__toolbar {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 16px;
  padding: 12px 0 24px;
  border: 0;
}
.wc-archive__filter-trigger {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px 8px 12px;
  background: transparent;
  border: 0;
  cursor: pointer;
  color: var(--color-text);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  line-height: 1;
  border-radius: 50px;
}
.wc-archive__filter-trigger:hover {
  background: var(--color-bg-beige);
}
.wc-archive__filter-trigger svg {
  display: block;
}
.wc-archive__chips {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}
.filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px 6px 10px;
  background: var(--color-bg-beige);
  color: var(--color-text);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 14px;
  line-height: 1;
  border-radius: 50px;
  text-decoration: none;
  transition: background-color 0.12s ease;
}
.filter-chip:hover {
  background: var(--color-accent-sage);
}
.filter-chip svg {
  width: 12px;
  height: 12px;
}
.wc-archive__clear {
  color: var(--color-text);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 14px;
  line-height: 1;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.wc-archive__count {
  margin: 0 0 0 auto;
  color: var(--color-text-muted);
  font-family: var(--font-body);
  font-size: 14px;
}
.wc-archive__count span {
  font-weight: 500;
  color: var(--color-text);
}
.woocommerce ul.products {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  column-gap: 30px;
  row-gap: 16px;
  align-items: start;
  width: 100%;
}
@media (max-width: 1199px) {
  .woocommerce ul.products {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    column-gap: 24px;
    row-gap: 12px;
  }
}
@media (max-width: 767px) {
  .woocommerce ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 16px;
    row-gap: 8px;
  }
}
.woocommerce ul.products > li.product,
.woocommerce ul.products > .product-card-slot {
  list-style: none;
  margin: 0;
  float: none !important;
  clear: none !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0;
}
.woocommerce ul.products > li.product .product-card-slot,
.woocommerce ul.products > .product-card-slot {
  width: 100% !important;
  max-width: none !important;
  height: auto !important;
}
.woocommerce ul.products > li.product .product-card,
.woocommerce ul.products > .product-card-slot .product-card {
  background: var(--color-bg-white, #ffffff);
  border-radius: 20px;
  overflow: hidden;
  max-width: none !important;
  width: 100% !important;
  min-height: 0 !important;
  position: relative;
}
.woocommerce ul.products > li.product .product-card-slot .product-card,
.woocommerce ul.products > .product-card-slot .product-card {
  position: relative !important;
}
.wc-archive__pagination {
  margin-top: 60px;
}
.wc-archive__bottom {
  margin-top: 80px;
  padding: 40px 0;
  max-width: 686px;
  margin-inline: auto;
  text-align: left;
}
.wc-archive__bottom-title {
  margin: 0 0 20px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 28px;
  line-height: 1.2;
  color: var(--color-text);
}
.wc-archive__bottom-text {
  position: relative;
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  color: var(--color-text);
  max-height: 160px;
  overflow: hidden;
  transition: max-height 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.wc-archive__bottom:not([data-state="expanded"])
  .wc-archive__bottom-text:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 60px;
  background: linear-gradient(to bottom, transparent, var(--color-bg-light));
  pointer-events: none;
}
.wc-archive__bottom[data-state="expanded"] .wc-archive__bottom-text {
  max-height: 2000px;
}
.wc-archive__bottom-text p {
  margin: 0 0 12px;
}
.wc-archive__bottom-toggle {
  display: inline-block;
  margin-top: 12px;
  padding: 0;
  border: 0;
  background: none;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  color: var(--color-text);
  cursor: pointer;
  text-decoration: none;
}
@media (max-width: 767px) {
  body.post-type-archive-product main.woocommerce-page,
  body.tax-product_cat main.woocommerce-page {
    padding-bottom: 60px;
  }
  .wc-archive__header-inner {
    padding: 28px 20px 20px;
  }
  .wc-archive__header-inner .breadcrumbs {
    display: none;
  }
  .wc-archive__header-grid {
    grid-template-columns: 1fr;
    gap: 16px;
    min-height: 115px;
    align-items: center;
  }
  .wc-archive__intro {
    justify-self: start;
    font-size: 16px;
    max-height: 68px;
    overflow: hidden;
  }
  .wc-archive__title {
    font-size: 40px;
    line-height: 0.95;
  }
  .wc-archive__toolbar {
    padding: 24px 0 20px;
    align-items: center;
  }
  .wc-archive__filter-trigger {
    padding-inline: 0;
    font-size: 16px;
  }
  .wc-archive__count {
    margin-left: auto;
    width: auto;
    font-size: 14px;
  }
  .woocommerce ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }
  .wc-archive__bottom {
    width: 100%;
    max-width: none;
    margin-top: 60px;
    padding: 0;
  }
  .wc-archive__bottom-title {
    font-size: 31px;
    line-height: 1;
  }
  .wc-archive__bottom-text {
    font-size: 16px;
    line-height: 1.45;
  }
}
.wc-archive__pagination {
  margin-top: var(--space-48);
}
.woocommerce-pagination ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-4);
}
.woocommerce-pagination a,
.woocommerce-pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 var(--space-12);
  border-radius: var(--radius-pill);
  font-family: var(--font-display);
  font-size: var(--fs-body-14);
  color: var(--color-text);
  text-decoration: none;
  background: var(--color-bg-light);
}
.woocommerce-pagination a:hover {
  background: var(--color-accent-sage);
}
.woocommerce-pagination span.current {
  background: var(--color-text);
  color: var(--color-bg-beige);
}
.single-product-page__main {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-64);
  margin-bottom: var(--space-96);
}
@media (max-width: 1023px) {
  .single-product-page__main {
    grid-template-columns: 1fr;
    gap: var(--space-48);
  }
}
.single-product-page__gallery {
  min-width: 0;
}
.woocommerce-product-gallery {
  position: relative;
}
.woocommerce-product-gallery__image img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--radius-card);
}
.flex-control-thumbs {
  list-style: none;
  padding: 0;
  margin: var(--space-16) 0 0;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-8);
}
.flex-control-thumbs li img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 8px;
  cursor: pointer;
  opacity: 0.6;
  transition: opacity 0.16s ease;
}
.flex-control-thumbs li img.flex-active,
.flex-control-thumbs li img:hover {
  opacity: 1;
}
.single-product-page__summary {
  display: flex;
  flex-direction: column;
  gap: var(--space-20);
}
.single-product-page .product_title {
  margin: 0;
}
.single-product-page .price {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h4);
  color: var(--color-text);
  margin: 0;
  display: flex;
  align-items: baseline;
  gap: var(--space-12);
}
.single-product-page .price del {
  color: var(--color-text-muted);
  font-size: var(--fs-body-20);
  text-decoration: line-through;
}
.single-product-page .price ins {
  background: none;
  text-decoration: none;
  color: var(--color-accent-brown);
}
.single-product-page .woocommerce-product-rating {
  display: inline-flex;
  align-items: center;
  gap: var(--space-8);
}
.single-product-page .star-rating {
  font-size: var(--fs-body-14);
}
.single-product-page form.cart {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-12);
  align-items: center;
  margin: var(--space-16) 0;
}
.single-product-page .variations {
  border: none;
  border-collapse: collapse;
  margin: 0;
}
.single-product-page .variations td {
  padding: var(--space-8) 0;
}
.single-product-page .variations label {
  font-family: var(--font-display);
  font-weight: 500;
}
.single-product-page .woocommerce-product-details__short-description {
  color: var(--color-text-muted);
  font-size: var(--fs-body-16);
  line-height: 1.6;
}
.single-product-page__details {
  border-top: 1px solid var(--color-border-subtle);
  padding-top: var(--space-48);
}
.woocommerce-tabs ul.tabs {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-32);
  display: flex;
  gap: var(--space-24);
  border-bottom: 2px solid var(--color-border-subtle);
}
.woocommerce-tabs ul.tabs li a {
  display: inline-block;
  padding: var(--space-12) 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-16);
  color: var(--color-text-muted);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
}
.woocommerce-tabs ul.tabs li.active a {
  color: var(--color-text);
  border-bottom-color: var(--color-text);
}
.woocommerce-Tabs-panel h2 {
  margin: 0 0 var(--space-16);
}
.related.products,
.upsells.products {
  margin-top: var(--space-64);
  padding-top: var(--space-48);
  border-top: 1px solid var(--color-border-subtle);
}
.related.products > h2,
.upsells.products > h2 {
  text-align: center;
  margin: 0 0 var(--space-32);
}
.navbar--checkout {
  border-bottom: 1px solid var(--color-border-subtle);
}
.navbar--checkout .navbar__inner {
  justify-content: space-between;
}
.navbar-checkout__phone {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  color: var(--color-text);
  text-decoration: none;
}
.navbar-checkout__phone:hover {
  color: var(--color-accent-brown);
}
.checkout-progress {
  max-width: 600px;
  margin: 0 auto 48px;
}
.checkout-progress__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
}
.checkout-progress__step {
  flex-shrink: 0;
}
.checkout-progress__label {
  display: inline-block;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 28px;
  line-height: 1.2;
  color: var(--color-text-muted);
  text-decoration: none;
  transition: color 0.2s ease;
}
.checkout-progress a.checkout-progress__label:hover {
  color: var(--color-text);
}
.checkout-progress a.checkout-progress__label:focus-visible {
  outline: 2px solid var(--color-accent-sage);
  outline-offset: 4px;
  border-radius: 4px;
}
.checkout-progress__step[data-state="active"] .checkout-progress__label,
.checkout-progress__step[data-state="done"] .checkout-progress__label {
  color: var(--color-text);
}
.checkout-progress__line {
  flex: 1;
  height: 2px;
  background: var(--color-text-muted);
  margin: 0 20px;
  min-width: 60px;
}
.checkout-progress__line[data-state="done"] {
  background: var(--color-text);
}
.woocommerce-cart
  .woocommerce-page
  > .woocommerce
  > .woocommerce-notices-wrapper
  + h1,
.woocommerce-cart .entry-title {
  display: none;
}
.mido-cart {
  max-width: 1920px;
  margin: 0 auto;
  padding: 40px 60px 0;
  box-sizing: border-box;
}
.mido-cart__layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 550px;
  gap: 40px;
  align-items: start;
}
.mido-cart__main {
  min-width: 0;
}
.mido-cart__sidebar {
  position: sticky;
  top: 100px;
}
.woocommerce-cart .woocommerce-cart-form {
  margin-bottom: 0;
}
.woocommerce-cart table.shop_table {
  width: 100%;
  border-collapse: collapse;
  border: none;
  background: transparent;
}
.woocommerce-cart table.shop_table thead th {
  padding: 16px 12px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  color: var(--color-text);
  text-align: left;
  border-bottom: 1px solid var(--color-border-subtle);
  background: transparent;
  text-transform: none;
  letter-spacing: 0;
}
.woocommerce-cart table.shop_table thead th.product-remove,
.woocommerce-cart table.shop_table thead th.product-thumbnail {
  width: 40px;
  padding: 16px 4px;
}
.woocommerce-cart table.shop_table tbody td {
  padding: 20px 12px;
  border-bottom: 1px solid var(--color-border-subtle);
  vertical-align: middle;
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--color-text);
}
.woocommerce-cart table.shop_table .product-thumbnail {
  width: 70px;
  padding-left: 0;
  padding-right: 8px;
}
.woocommerce-cart table.shop_table .product-thumbnail img {
  width: 70px;
  height: 70px;
  object-fit: cover;
  border-radius: 12px;
}
.woocommerce-cart table.shop_table .product-name a {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  color: var(--color-text);
  text-decoration: none;
}
.woocommerce-cart table.shop_table .product-name a:hover {
  color: var(--color-accent-brown);
}
.woocommerce-cart table.shop_table .product-name .variation {
  display: block;
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 14px;
  color: var(--color-text-muted);
  margin-top: 2px;
}
.woocommerce-cart table.shop_table .product-name dl.variation dt,
.woocommerce-cart table.shop_table .product-name dl.variation dd {
  display: inline;
  margin: 0;
  font-size: 14px;
  color: var(--color-text-muted);
}
.woocommerce-cart table.shop_table .product-name dl.variation dd p {
  margin: 0;
  display: inline;
}
.woocommerce-cart table.shop_table .product-remove {
  width: 30px;
  padding-right: 4px;
}
.woocommerce-cart table.shop_table .product-remove a.remove {
  display: inline-flex;
  width: 24px;
  height: 24px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: transparent;
  color: var(--color-text-muted);
  text-decoration: none;
  font-size: 18px;
  line-height: 1;
  transition: color 0.16s ease;
}
.woocommerce-cart table.shop_table .product-remove a.remove:hover {
  color: var(--color-text);
  background: transparent;
}
.woocommerce-cart table.shop_table .product-quantity .quantity input {
  width: 50px;
  height: 36px;
  text-align: center;
  border: 1px solid var(--color-border-subtle);
  border-radius: 8px;
  font-family: var(--font-body);
  font-size: 16px;
}
.mido-cart__coupon-row {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 24px;
  flex-wrap: wrap;
}
.mido-cart__coupon {
  display: flex;
  gap: 12px;
  align-items: center;
  flex: 1;
}
.mido-cart__coupon .input-text {
  flex: 1;
  max-width: 300px;
  padding: 14px 20px;
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-pill);
  font-family: var(--font-body);
  font-size: 16px;
  background: transparent;
  color: var(--color-text);
}
.mido-cart__coupon .input-text::placeholder {
  color: var(--color-text-muted);
}
.mido-cart__coupon .btn {
  padding: 14px 32px;
  border-radius: var(--radius-pill);
}
.mido-cart__update {
  margin-left: auto;
  font-size: 14px;
  color: var(--color-text-muted);
  text-decoration: underline;
  text-underline-offset: 3px;
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font-display);
  font-weight: 500;
  padding: 8px 0;
}
.mido-cart__update:hover {
  color: var(--color-text);
}
.cart_totals {
  background: var(--color-bg-beige);
  padding: 32px;
  border-radius: var(--radius-card);
  width: 100%;
  max-width: 550px;
  margin-left: 0;
  margin-right: 0;
}
.cart_totals h2 {
  margin: 0 0 20px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 24px;
  color: var(--color-text);
}
.cart_totals table.shop_table_responsive {
  display: block;
  width: 100%;
  border: none;
}
.cart_totals table.shop_table_responsive tbody {
  display: block;
  width: 100%;
}
.cart_totals table.shop_table_responsive td,
.cart_totals table.shop_table_responsive th {
  padding: 12px 0;
  border: 0 !important;
  text-align: left;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  color: var(--color-text);
}
.cart_totals table.shop_table_responsive tr {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  width: 100%;
  border: 0 !important;
}
.cart_totals table.shop_table_responsive tr th,
.cart_totals table.shop_table_responsive tr td {
  display: block;
  min-width: 0;
}
.cart_totals table.shop_table_responsive td {
  text-align: right;
}
.cart_totals table.shop_table_responsive .order-total th,
.cart_totals table.shop_table_responsive .order-total td {
  border-bottom: none;
  padding-top: 16px;
  font-size: 18px;
}
.cart_totals table.shop_table_responsive .order-total .amount {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 18px;
  color: var(--color-text);
}
.cart_totals .checkout-button {
  width: 100%;
  margin-top: 24px;
  justify-content: center;
  height: 56px;
  font-size: 20px !important;
  border-radius: var(--radius-pill);
  background: var(--color-text) !important;
  color: var(--color-bg-white) !important;
  border-color: var(--color-text) !important;
}
.cart_totals .checkout-button:hover {
  background: #2d3237 !important;
  border-color: #2d3237 !important;
  color: var(--color-bg-white) !important;
}
.cart_totals table.shop_table_responsive .shipping td {
  text-align: left;
  padding-left: 0;
}
.cart_totals table.shop_table_responsive tr.shipping {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0;
}
.cart_totals table.shop_table_responsive tr.shipping th,
.cart_totals table.shop_table_responsive tr.shipping td {
  display: block;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
  text-align: left;
}
.cart_totals table.shop_table_responsive tr.shipping th {
  font-size: 18px;
}
.cart_totals #shipping_method {
  list-style: none;
  margin: 18px 0 0;
  padding: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.cart_totals #shipping_method li {
  position: relative;
  display: flex;
  align-items: center;
  gap: 16px;
  width: 100%;
  margin: 0;
  font-size: 18px;
  line-height: 1.2;
}
.cart_totals #shipping_method li label {
  cursor: pointer;
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  flex: 1 1 auto;
  gap: 16px;
  margin: 0;
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 400;
  line-height: 1.2;
  color: var(--color-text);
}
.cart_totals #shipping_method li input[type="radio"] {
  appearance: none;
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  margin: 0;
  flex: 0 0 20px;
  border: 1.5px solid var(--color-text);
  border-radius: 50%;
  background: transparent;
  box-sizing: border-box;
  cursor: pointer;
}
.cart_totals #shipping_method li input[type="radio"]:checked {
  border-color: var(--color-text);
  background: radial-gradient(
    circle at center,
    var(--color-bg-light) 0 4px,
    var(--color-text) 4.5px
  );
}
.cart_totals #shipping_method li input[type="radio"]:focus-visible {
  outline: 2px solid var(--color-text);
  outline-offset: 2px;
}
.cart_totals #shipping_method .amount {
  margin-left: auto;
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 400;
  white-space: nowrap;
}
.cart_totals .woocommerce-shipping-destination,
.cart_totals .shipping-calculator-button {
  display: block;
  width: 100%;
  font-size: 13px;
  line-height: 1.35;
  color: var(--color-text-muted);
  margin-top: 8px;
  white-space: normal !important;
  overflow-wrap: anywhere;
}
.woocommerce-page .woocommerce-notices-wrapper {
  max-width: 1920px;
  margin: 0 auto;
  padding: 0 60px 16px;
  box-sizing: border-box;
}
@media (max-width: 1023px) {
  .woocommerce-page .woocommerce-notices-wrapper {
    padding: 0 20px 12px;
  }
}
.mido-cart__cross-sells {
  padding-block: 60px 80px;
  overflow: visible;
}
.mido-cart__cross-sells-title {
  margin: 0 0 32px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 28px;
  line-height: 1.1;
  color: var(--color-text);
}
.mido-cart__cross-sells .slider__track {
  padding-left: var(--space-24);
  scroll-padding-left: var(--space-24);
}
@media (min-width: 640px) {
  .mido-cart__cross-sells .slider__track {
    padding-left: var(--space-32);
    scroll-padding-left: var(--space-32);
  }
}
@media (min-width: 1024px) {
  .mido-cart__cross-sells .slider__track {
    padding-left: max(60px, calc((100vw - 1440px) / 2 + 60px));
    scroll-padding-left: max(60px, calc((100vw - 1440px) / 2 + 60px));
  }
}
@media (min-width: 1024px) {
  .mido-cart__cross-sells .slider__controls {
    padding-inline: 60px;
  }
}
.mido-cart__cross-sells .slider__slide {
  width: 280px;
}
@media (min-width: 1024px) {
  .mido-cart__cross-sells .slider__slide {
    width: 300px;
  }
}
@media (max-width: 1023px) {
  .mido-cart {
    padding: 24px 20px 0;
  }
  .mido-cart__layout {
    grid-template-columns: 1fr;
    gap: 32px;
    max-width: 100%;
  }
  .mido-cart__layout > *,
  .mido-cart__main,
  .woocommerce-cart .woocommerce-cart-form,
  .woocommerce-cart table.shop_table,
  .cart_totals {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
  }
  .mido-cart__sidebar {
    position: static;
  }
  .checkout-progress__label {
    font-size: 20px;
  }
  .checkout-progress__line {
    min-width: 30px;
    margin: 0 12px;
  }
  .mido-cart__cross-sells {
    padding-block: 40px 60px;
  }
}
@media (max-width: 767px) {
  .mido-cart {
    padding: 24px 16px 0;
    overflow-x: hidden;
  }
  .woocommerce-cart table.shop_table thead {
    display: none;
  }
  .woocommerce-cart table.shop_table,
  .woocommerce-cart table.shop_table tbody,
  .woocommerce-cart table.shop_table tr,
  .woocommerce-cart table.shop_table td {
    display: block;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
  }
  .woocommerce-cart table.shop_table tbody tr {
    margin-bottom: 16px;
    border: 0;
    border-radius: 16px;
    padding: 16px;
    position: relative;
    box-sizing: border-box;
  }
  .woocommerce-cart table.shop_table td {
    border: 0 !important;
    padding: 0;
    box-sizing: border-box;
  }
  .woocommerce-cart table.shop_table td.product-remove {
    position: absolute;
    top: 12px;
    right: 12px;
    width: auto;
    padding: 0;
  }
  .woocommerce-cart table.shop_table td.product-thumbnail {
    margin-bottom: 12px;
  }
  .woocommerce-cart table.shop_table .product-thumbnail,
  .woocommerce-cart table.shop_table .product-thumbnail img {
    width: 76px;
    height: 76px;
  }
  .woocommerce-cart table.shop_table .product-name a {
    display: block;
    max-width: calc(100% - 36px);
    font-size: 16px;
    line-height: 1.2;
    margin-bottom: 14px;
  }
  .woocommerce-cart table.shop_table .product-price,
  .woocommerce-cart table.shop_table .product-quantity,
  .woocommerce-cart table.shop_table .product-subtotal {
    display: grid;
    grid-template-columns: minmax(90px, auto) minmax(0, 1fr);
    align-items: center;
    column-gap: 12px;
    font-size: 18px;
    padding: 5px 0;
    border: 0 !important;
  }
  .woocommerce-cart table.shop_table .product-price .amount,
  .woocommerce-cart table.shop_table .product-subtotal .amount,
  .woocommerce-cart table.shop_table .product-quantity .quantity {
    justify-self: end;
    text-align: right;
  }
  .woocommerce-cart table.shop_table .product-price .amount,
  .woocommerce-cart table.shop_table .product-subtotal .amount {
    display: inline !important;
    width: auto !important;
    font-size: 18px;
    line-height: 1.2;
  }
  .woocommerce-cart table.shop_table .product-quantity .quantity input {
    width: 56px;
    height: 42px;
  }
  .woocommerce-cart table.shop_table td:before {
    content: attr(data-title);
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 18px;
    color: var(--color-text-muted);
    display: inline-block;
    min-width: 0;
    margin-right: 0;
  }
  .woocommerce-cart table.shop_table td.product-name:before,
  .woocommerce-cart table.shop_table td.product-thumbnail:before,
  .woocommerce-cart table.shop_table td.product-remove:before {
    content: none;
  }
  .mido-cart__coupon-row {
    flex-direction: column;
    align-items: stretch;
  }
  .mido-cart__coupon {
    flex-direction: column;
    align-items: center;
  }
  .mido-cart__coupon .input-text {
    max-width: min(100%, 270px);
    width: 100%;
    text-align: center;
  }
  .mido-cart__coupon .btn {
    width: auto;
    min-width: 148px;
  }
  .mido-cart__update {
    margin-left: 0;
    text-align: center;
    font-size: 18px;
  }
}
@media (max-width: 1023px) {
  .mido-cart__sidebar .cart-collaterals .cart_totals,
  .cart_totals {
    width: 100%;
    max-width: none;
    padding: 20px;
    border-radius: 16px;
  }
  .cart_totals > h2,
  .woocommerce-checkout #order_review_heading {
    font-size: 32px;
    line-height: 1.1;
    margin: 0 0 24px;
    padding: 0;
  }
  .woocommerce-cart table.cart tbody td.product-name,
  .woocommerce-cart table.cart tbody td.product-price,
  .woocommerce-cart table.cart tbody td.product-quantity,
  .woocommerce-cart table.cart tbody td.product-subtotal,
  .woocommerce-cart table.cart tbody td.product-thumbnail {
    padding-top: 0;
    padding-bottom: 0;
  }
  .woocommerce-cart table.cart tbody td.product-subtotal {
    border: 0;
  }
  .woocommerce-cart table.cart .product-subtotal .woocommerce-Price-amount {
    width: 100%;
    display: inline-block;
  }
  .cart_totals table.shop_table_responsive,
  .woocommerce-checkout table.shop_table_responsive {
    display: block;
    width: 100%;
  }
  .cart_totals table.shop_table_responsive tbody,
  .woocommerce-checkout table.shop_table_responsive tbody {
    display: block;
  }
  .cart_totals table.shop_table_responsive tr,
  .woocommerce-checkout table.shop_table_responsive tr {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 0;
    margin: 0;
  }
  .cart_totals table.shop_table_responsive tr {
    gap: 10px;
    padding: 16px 0;
  }
  .woocommerce-checkout table.shop_table_responsive tr {
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  }
  .cart_totals table.shop_table_responsive tr:last-child,
  .woocommerce-checkout table.shop_table_responsive tr:last-child {
    border-bottom: 0;
  }
  .cart_totals table.shop_table_responsive tr th,
  .cart_totals table.shop_table_responsive tr td,
  .woocommerce-checkout table.shop_table_responsive tr th,
  .woocommerce-checkout table.shop_table_responsive tr td {
    display: block;
    padding: 0;
    border: 0;
    background: transparent;
    text-align: left;
    font-size: 15px;
    font-family: var(--font-display);
    font-weight: 500;
    white-space: normal;
  }
  .cart_totals table.shop_table_responsive tr th,
  .cart_totals table.shop_table_responsive tr td {
    font-size: 18px;
    line-height: 1.25;
  }
  .cart_totals table.shop_table_responsive tr td,
  .woocommerce-checkout table.shop_table_responsive tr td {
    text-align: right;
    white-space: nowrap;
    flex-shrink: 0;
    width: auto;
  }
  .cart_totals table.shop_table_responsive tr td {
    min-width: 0;
    max-width: 100%;
    overflow-wrap: anywhere;
    text-align: right;
  }
  .cart_totals tr.order-total th,
  .cart_totals tr.order-total td,
  .woocommerce-checkout tr.order-total th,
  .woocommerce-checkout tr.order-total td {
    font-size: 18px;
    font-weight: 600;
  }
  .cart_totals table.shop_table_responsive td:before,
  .woocommerce-checkout table.shop_table_responsive td:before {
    content: none;
  }
  .woocommerce-checkout table.shop_table_responsive tr.cart_item {
    align-items: center;
  }
  .woocommerce-checkout
    table.shop_table_responsive
    tr.cart_item
    td.product-name {
    flex: 1 1 auto;
    text-align: left;
    white-space: normal;
    word-break: break-word;
    font-weight: 500;
  }
  .woocommerce-checkout
    table.shop_table_responsive
    tr.cart_item
    td.product-total {
    flex: 0 0 auto;
    text-align: right;
    white-space: nowrap;
  }
  .cart_totals tr.shipping,
  .woocommerce-checkout tr.shipping {
    flex-direction: column;
    align-items: stretch;
  }
  .cart_totals tr.shipping {
    gap: 0;
  }
  .cart_totals tr.shipping th {
    font-size: 18px;
  }
  .cart_totals tr.shipping td,
  .woocommerce-checkout tr.shipping td {
    text-align: left;
    white-space: normal;
  }
  .cart_totals tr.shipping td {
    overflow: visible;
  }
  .cart_totals tr.shipping td ul,
  .woocommerce-checkout tr.shipping td ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
  }
  .cart_totals #shipping_method {
    margin-top: 18px;
    gap: 22px;
  }
  .cart_totals #shipping_method li {
    align-items: center;
    gap: 12px;
    font-size: 18px;
    min-width: 0;
  }
  .cart_totals #shipping_method li label {
    min-width: 0;
    gap: 10px;
    font-size: 18px;
    line-height: 1.2;
  }
  .cart_totals #shipping_method .amount {
    margin-left: auto;
    font-size: 18px;
    white-space: nowrap;
  }
  .cart_totals .woocommerce-shipping-destination,
  .cart_totals .shipping-calculator-button {
    max-width: 100%;
    overflow-wrap: anywhere;
    font-size: 14px;
    line-height: 1.35;
  }
  .mido-cart__sidebar > h2:has(+ .cart-collaterals),
  .mido-cart__sidebar > h2:has(+ .cart_totals),
  .mido-checkout__sidebar > h2:has(+ #order_review) {
    display: none;
  }
}
@media (max-width: 389px) {
  .checkout-progress__list .checkout-progress__step a.checkout-progress__label,
  .checkout-progress__list
    .checkout-progress__step
    span.checkout-progress__label {
    font-size: 16px;
  }
}
@media (max-width: 479px) {
  .checkout-progress__list .checkout-progress__step a.checkout-progress__label,
  .checkout-progress__list
    .checkout-progress__step
    span.checkout-progress__label {
    font-size: 16px;
  }
  .woocommerce-checkout .woocommerce-billing-fields > h3 {
    font-size: 32px;
  }
  .woocommerce-checkout-review-order {
    padding: 24px;
  }
  .woocommerce-checkout-review-order-table tfoot .woocommerce-shipping-totals {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }
  .woocommerce-checkout-review-order-table
    tfoot
    .woocommerce-shipping-totals
    th {
    flex: 0 0 auto;
    width: 100%;
    text-align: left;
    white-space: normal;
  }
  .woocommerce-checkout-review-order-table
    tfoot
    .woocommerce-shipping-totals
    td {
    flex: 1 1 auto;
    width: 100%;
    text-align: left;
    white-space: normal;
  }
}
.mido-checkout {
  margin-bottom: var(--space-48);
}
.woocommerce-checkout label.checkbox,
.woocommerce-checkout label.woocommerce-form__label-for-checkbox {
  width: auto;
  height: auto;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: var(--space-8);
  cursor: pointer;
  position: relative;
}
.woocommerce-checkout label.checkbox:before,
.woocommerce-checkout label.checkbox:after,
.woocommerce-checkout label.woocommerce-form__label-for-checkbox:before,
.woocommerce-checkout label.woocommerce-form__label-for-checkbox:after {
  content: "";
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
}
.woocommerce-checkout label.checkbox:before,
.woocommerce-checkout label.woocommerce-form__label-for-checkbox:before {
  width: 18px;
  height: 18px;
  border: 1.5px solid var(--color-text);
  border-radius: 50%;
  background: transparent;
  transition:
    background-color 0.16s ease,
    border-color 0.16s ease;
}
.woocommerce-checkout label.checkbox:after,
.woocommerce-checkout label.woocommerce-form__label-for-checkbox:after {
  position: absolute;
  left: 2px;
  top: 2px;
  width: 14px;
  height: 14px;
  opacity: 0;
  background: center / 14px 14px no-repeat
    url("data:image/svg+xml,%3Csvg width='14' height='14' viewBox='0 0 14 14' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 7.2 5.8 10 11 4' fill='none' stroke='%23F3EADA' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  pointer-events: none;
}
.woocommerce-checkout input[type="checkbox"] {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}
.woocommerce-checkout label.checkbox:has(input[type="checkbox"]:checked):before,
.woocommerce-checkout
  label.woocommerce-form__label-for-checkbox:has(
    input[type="checkbox"]:checked
  ):before {
  border-color: var(--color-text);
  background: radial-gradient(
    circle at center,
    var(--color-bg-light) 0 4px,
    var(--color-text) 4.5px
  );
}
.woocommerce-checkout label.checkbox:has(input[type="checkbox"]:checked):after,
.woocommerce-checkout
  label.woocommerce-form__label-for-checkbox:has(
    input[type="checkbox"]:checked
  ):after {
  opacity: 0;
}
.woocommerce-checkout
  label.checkbox:has(input[type="checkbox"]:focus-visible):before,
.woocommerce-checkout
  label.woocommerce-form__label-for-checkbox:has(
    input[type="checkbox"]:focus-visible
  ):before {
  outline: 2px solid var(--color-text);
  outline-offset: 2px;
}
.woocommerce-checkout
  label.checkbox:hover:not(:has(input[type="checkbox"]:checked)):before,
.woocommerce-checkout
  label.woocommerce-form__label-for-checkbox:hover:not(
    :has(input[type="checkbox"]:checked)
  ):before {
  background-color: #2125290a;
}
.woocommerce-checkout form.checkout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 502px;
  column-gap: 60px;
  row-gap: 0;
  align-items: start;
}
.woocommerce-checkout #customer_details {
  grid-column: 1;
  display: block;
  margin-bottom: var(--space-32);
}
.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2 {
  width: 100%;
  float: none;
}
.woocommerce-checkout .woocommerce-billing-fields > h3,
.woocommerce-checkout .woocommerce-additional-fields > h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 40px;
  line-height: 1.1;
  margin: 0 0 var(--space-32);
  color: var(--color-text);
}
.woocommerce-checkout .woocommerce-additional-fields > h3 {
  margin-top: var(--space-48);
}
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 26px var(--space-32);
}
.woocommerce-checkout form .form-row {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}
.woocommerce-checkout form .form-row-wide {
  grid-column: 1 / -1;
}
.woocommerce-checkout form .form-row-first {
  grid-column: 1;
}
.woocommerce-checkout form .form-row-last {
  grid-column: 2;
}
.woocommerce-checkout form .form-row > label {
  position: static;
  width: auto;
  height: auto;
  padding: 0;
  margin: 0;
  overflow: visible;
  clip: auto;
  border: 0;
  font-family: var(--font-body);
  font-size: var(--fs-body-16);
  font-weight: 400;
  line-height: 1.25;
  color: var(--color-text);
}
.woocommerce-checkout form .form-row > label .required {
  color: inherit;
  text-decoration: none;
}
.woocommerce-checkout #billing_address_2_field > label {
  display: none;
}
.woocommerce-checkout #shipping_first_name_field,
.woocommerce-checkout #shipping_country_field,
.woocommerce-checkout .shipping_address .woocommerce-shipping-fields__field-wrapper .address-field {
  margin-top: 30px;
}
.woocommerce-checkout #shipping_last_name_field,
.woocommerce-checkout #shipping_company_field {
  margin-top: 20px;
}
.woocommerce-checkout
  .shipping_address
  .woocommerce-shipping-fields__field-wrapper
  .address-field:nth-child(6) {
  margin-top: 0;
}
.woocommerce-checkout #billing_email_field {
  margin-bottom: 30px;
}
.woocommerce-checkout
  form
  .form-row
  input:not([type="checkbox"]):not([type="radio"]),
.woocommerce-checkout form .form-row select:not(.select2-hidden-accessible),
.woocommerce-checkout form .form-row textarea {
  width: 100%;
  min-height: 58px;
  padding: 0 var(--space-20);
  border: 2px solid var(--color-accent-sage);
  border-radius: var(--radius-pill);
  background: transparent;
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 500;
  line-height: 1.2;
  color: var(--color-text);
  box-shadow: none;
  transition:
    border-color var(--transition-normal),
    box-shadow var(--transition-normal);
}
.woocommerce-checkout form .form-row input:focus,
.woocommerce-checkout form .form-row select:focus,
.woocommerce-checkout form .form-row textarea:focus {
  outline: none;
  border-color: var(--color-text-muted) !important;
}
.woocommerce-checkout form .form-row:focus-within input:not([type="checkbox"]):not([type="radio"]),
.woocommerce-checkout form .form-row:focus-within select:not(.select2-hidden-accessible),
.woocommerce-checkout form .form-row:focus-within textarea,
.woocommerce-checkout
  form
  .form-row:focus-within
  .select2-container--default
  .select2-selection--single {
  border-color: var(--color-text-muted) !important;
}
.woocommerce-checkout form .form-row input::placeholder,
.woocommerce-checkout form .form-row textarea::placeholder {
  color: color-mix(in srgb, var(--color-accent-sage) 82%, var(--color-text));
  opacity: 1;
}
.woocommerce-checkout form .form-row.woocommerce-invalid input:not([type="checkbox"]):not([type="radio"]),
.woocommerce-checkout form .form-row.woocommerce-invalid select:not(.select2-hidden-accessible),
.woocommerce-checkout form .form-row.woocommerce-invalid textarea {
  border-color: var(--color-error-red) !important;
}
.woocommerce-checkout form .form-row.woocommerce-invalid input:focus,
.woocommerce-checkout form .form-row.woocommerce-invalid select:focus,
.woocommerce-checkout form .form-row.woocommerce-invalid textarea:focus {
  border-color: var(--color-error-red) !important;
}
.woocommerce-checkout form .form-row.woocommerce-invalid:focus-within input:not([type="checkbox"]):not([type="radio"]),
.woocommerce-checkout form .form-row.woocommerce-invalid:focus-within select:not(.select2-hidden-accessible),
.woocommerce-checkout form .form-row.woocommerce-invalid:focus-within textarea,
.woocommerce-checkout
  form
  .form-row.woocommerce-invalid:focus-within
  .select2-container--default
  .select2-selection--single {
  border-color: var(--color-error-red) !important;
}
.woocommerce-checkout form .form-row.woocommerce-invalid label {
  color: var(--color-text);
}
.woocommerce-checkout form .form-row textarea {
  min-height: 118px;
  padding-top: var(--space-16);
  padding-bottom: var(--space-16);
  border-radius: 28px;
  resize: vertical;
}
.woocommerce-checkout form .form-row select.select2-hidden-accessible,
.woocommerce-checkout form .form-row .select2-hidden-accessible,
.woocommerce-checkout form .form-row:has(.select2-container) select {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  min-width: 1px !important;
  min-height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  clip-path: inset(50%) !important;
  border: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
  white-space: nowrap !important;
}
.woocommerce-checkout form .form-row .select2-container {
  display: block !important;
  width: 100% !important;
}
.woocommerce-checkout .select2-container--default .select2-selection--single {
  display: block;
  border: 2px solid var(--color-accent-sage);
  border-radius: var(--radius-pill);
  background: transparent;
  height: 58px;
  padding: 0 52px 0 var(--space-20);
  box-shadow: none;
  transition:
    border-color var(--transition-normal),
    box-shadow var(--transition-normal);
}
.woocommerce-checkout
  .select2-container--open
  .select2-selection--single,
.woocommerce-checkout
  .select2-container--focus
  .select2-selection--single,
.woocommerce-checkout
  .select2-container--default
  .select2-selection--single:focus {
  border-color: var(--color-text-muted) !important;
  outline: none;
}
.woocommerce-checkout
  .select2-container--default
  .select2-selection--single
  .select2-selection__rendered {
  padding-left: 0;
  padding-right: 0;
  line-height: 54px;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 500;
}
.woocommerce-checkout
  .select2-container--default
  .select2-selection--single
  .select2-selection__arrow {
  width: 52px;
  height: 54px;
  right: 0;
}
.woocommerce-checkout
  .select2-container--default
  .select2-selection--single
  .select2-selection__arrow
  b {
  border-color: var(--color-text) transparent transparent transparent;
}
.woocommerce-checkout
  .form-row.woocommerce-invalid
  .select2-container--default
  .select2-selection--single {
  border-color: var(--color-error-red) !important;
}
body.woocommerce-checkout .select2-container--open {
  z-index: 99999 !important;
}
body.woocommerce-checkout > .select2-container--open {
  box-sizing: border-box;
  z-index: 99999 !important;
}
body.woocommerce-checkout .select2-dropdown {
  width: 100% !important;
  box-sizing: border-box;
  overflow: hidden;
  margin-top: var(--space-8);
  border: 2px solid var(--color-text-muted);
  border-radius: 24px;
  background: #fbf9f3 !important;
  box-shadow: 0 12px 28px #00000014;
  z-index: 99999 !important;
}
body.woocommerce-checkout .select2-container--open .select2-dropdown {
  display: block !important;
}
body.woocommerce-checkout .select2-container--open .select2-dropdown,
body.woocommerce-checkout .select2-container--open .select2-search,
body.woocommerce-checkout .select2-container--open .select2-results,
body.woocommerce-checkout .select2-container--open .select2-results__options {
  isolation: isolate;
}
body.woocommerce-checkout .select2-dropdown--above {
  margin-top: 0;
  margin-bottom: var(--space-8);
}
body.woocommerce-checkout .select2-search--dropdown {
  box-sizing: border-box;
  width: 100%;
  padding: 0 0 var(--space-12) !important;
  background: #fbf9f3 !important;
}
body.woocommerce-checkout .select2-search--dropdown .select2-search__field {
  display: block;
  width: calc(100% - 32px) !important;
  box-sizing: border-box;
  margin: var(--space-16) var(--space-16) 0;
  min-height: 44px;
  padding: 0 var(--space-16);
  border: 1.5px solid var(--color-accent-sage);
  border-radius: var(--radius-pill);
  background: var(--color-bg-white);
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 500;
  color: var(--color-text);
  outline: none;
}
body.woocommerce-checkout .select2-search--dropdown .select2-search__field:focus {
  border-color: var(--color-text-muted);
}
body.woocommerce-checkout .select2-results {
  background: #fbf9f3 !important;
  margin: 0 !important;
  padding: 0 !important;
}
body.woocommerce-checkout .select2-results__options {
  box-sizing: border-box;
  max-height: 260px;
  overflow-y: auto;
  padding: var(--space-8) 0;
  margin: 0 !important;
  list-style: none !important;
  background: #fbf9f3 !important;
}
body.woocommerce-checkout .select2-results__option {
  display: block;
  box-sizing: border-box;
  width: 100%;
  padding: 9px var(--space-16);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.25;
  color: var(--color-text);
  background: #fbf9f3 !important;
}
body.woocommerce-checkout .select2-results__option--highlighted[aria-selected],
body.woocommerce-checkout .select2-results__option--highlighted[data-selected] {
  background: var(--color-accent-sage);
  color: var(--color-text);
}
body.woocommerce-checkout .select2-results__option[aria-selected="true"],
body.woocommerce-checkout .select2-results__option[data-selected="true"] {
  font-weight: 600;
  background: color-mix(in srgb, var(--color-accent-sage) 45%, transparent);
}
.woocommerce-checkout .woocommerce-shipping-fields {
  margin-top: var(--space-32);
}
.woocommerce-checkout .woocommerce-shipping-fields h3 {
  font-size: var(--fs-body-16);
  font-family: var(--font-body);
  font-weight: 400;
  margin: 0;
}
.woocommerce-checkout .woocommerce-shipping-fields h3 label.checkbox {
  width: auto;
  height: auto;
  display: inline-flex;
  align-items: center;
  gap: var(--space-8);
  cursor: pointer;
}
.woocommerce-checkout .woocommerce-additional-fields {
  margin-top: var(--space-48);
}
.woocommerce-checkout .woocommerce-additional-fields:before {
  content: "Dodatkowe informacje";
  display: block;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 28px;
  line-height: 1.1;
  color: var(--color-text);
  margin-bottom: var(--space-20);
}
.woocommerce-checkout .woocommerce-additional-fields textarea {
  min-height: 118px;
  resize: vertical;
}
.woocommerce-checkout h3#order_review_heading {
  display: none;
}
.woocommerce-checkout-review-order {
  grid-column: 2;
  grid-row: 1 / -1;
  background: var(--color-bg-beige);
  padding: 32px 42px 36px;
  border-radius: 24px;
  position: sticky;
  top: 100px;
  align-self: start;
  box-sizing: border-box;
  overflow-wrap: break-word;
}
.woocommerce-checkout-review-order:before {
  content: "Podsumowanie";
  display: block;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 42px;
  line-height: 1.05;
  color: var(--color-text);
  margin-bottom: 32px;
}
.woocommerce-checkout-review-order table.shop_table {
  width: 100%;
  border: none;
  border-collapse: separate;
  border-spacing: 0;
  table-layout: fixed;
  display: flex;
  flex-direction: column;
}
.woocommerce-checkout-review-order table.shop_table th,
.woocommerce-checkout-review-order table.shop_table td {
  padding: 10px var(--space-8);
  border-bottom: 0;
  font-size: 14px;
  line-height: 1.25;
  vertical-align: top;
}
.woocommerce-checkout-review-order table.shop_table thead,
.woocommerce-checkout-review-order table.shop_table tbody,
.woocommerce-checkout-review-order table.shop_table tfoot {
  display: flex;
  flex-direction: column;
  width: 100%;
}
.woocommerce-checkout-review-order table.shop_table thead tr,
.woocommerce-checkout-review-order table.shop_table tbody tr,
.woocommerce-checkout-review-order table.shop_table tfoot tr {
  display: flex;
  width: 100%;
  justify-content: space-between;
  gap: var(--space-16);
}
.woocommerce-checkout-review-order table.shop_table th:first-child,
.woocommerce-checkout-review-order table.shop_table td:first-child {
  padding-left: 0;
}
.woocommerce-checkout-review-order table.shop_table th:last-child,
.woocommerce-checkout-review-order table.shop_table td:last-child {
  padding-right: 0;
}
.woocommerce-checkout-review-order table.shop_table thead th {
  font-family: var(--font-display);
  font-weight: 500;
  color: var(--color-text);
  font-size: 18px;
  text-align: left;
  padding-top: 0;
  padding-bottom: 18px;
}
.woocommerce-checkout-review-order table.shop_table thead .product-total {
  display: none;
}
.woocommerce-checkout-review-order table.shop_table .product-name {
  font-weight: 500;
  flex: 1 1 auto;
}
.woocommerce-checkout-review-order table.shop_table tbody .product-name {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 14px;
}
.woocommerce-checkout-review-order
  table.shop_table
  tbody
  .product-name
  > strong,
.woocommerce-checkout-review-order
  table.shop_table
  tbody
  .product-name
  .product-quantity {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 14px;
}
.woocommerce-checkout-review-order table.shop_table tbody .product-total {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 14px;
}
.woocommerce-checkout-review-order table.shop_table tbody .product-total bdi {
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: 18px;
}
.woocommerce-checkout-review-order table.shop_table .product-total,
.woocommerce-checkout-review-order table.shop_table td:last-child {
  text-align: right;
  flex: 0 0 auto;
  width: auto;
}
.woocommerce-checkout-review-order table.shop_table .cart-subtotal th,
.woocommerce-checkout-review-order table.shop_table .cart-subtotal td {
  padding-top: 24px;
}
.woocommerce-checkout-review-order table.shop_table .cart-subtotal th,
.woocommerce-checkout-review-order table.shop_table .woocommerce-shipping-totals th,
.woocommerce-checkout-review-order table.shop_table .order-total th {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 500;
}
.woocommerce-checkout-review-order table.shop_table .cart-subtotal td bdi {
  font-size: 16px;
}
.woocommerce-checkout-review-order table.shop_table .order-total td bdi {
  font-size: 15px;
  font-weight: 400;
}
.woocommerce-checkout-review-order table.shop_table .woocommerce-shipping-totals {
  flex-direction: column;
  gap: var(--space-8);
}
.woocommerce-checkout-review-order table.shop_table .woocommerce-shipping-totals th,
.woocommerce-checkout-review-order table.shop_table .woocommerce-shipping-totals td {
  width: 100%;
  padding-left: 0;
  padding-right: 0;
  text-align: left;
}
.woocommerce-checkout-review-order table.shop_table tfoot tr:last-child th,
.woocommerce-checkout-review-order table.shop_table tfoot tr:last-child td {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 14px;
  border-bottom: none;
  padding-top: 28px;
  padding-bottom: 28px;
}
.woocommerce-checkout-review-order table.shop_table tfoot th {
  text-align: left;
}
.mido-checkout-coupon {
  margin: 8px 0 32px;
}
.mido-checkout-coupon__toggle {
  margin: 0;
  font-family: var(--font-display);
  font-size: 16px;
  line-height: 1.35;
}
.mido-checkout-coupon__toggle-button {
  appearance: none;
  border: 0;
  padding: 0;
  margin-left: var(--space-12);
  background: transparent;
  font: inherit;
  color: var(--color-text);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.mido-checkout-coupon__toggle-button:hover {
  color: var(--color-accent-brown);
}
.mido-checkout-coupon__form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-8);
  margin-top: 16px;
}
.mido-checkout-coupon__form[hidden] {
  display: none;
}
.mido-checkout-coupon__form .input-text {
  height: 52px;
}
.mido-checkout-coupon__submit {
  height: 52px;
  min-width: 190px;
  margin: 0;
}
.mido-checkout-coupon__notice {
  grid-column: 1 / -1;
  min-height: 1em;
  margin: var(--space-12) 0 0;
  font-size: 12px;
  line-height: 1.35;
}
.mido-checkout-coupon__notice[data-state="error"] {
  color: #b42318;
}
.woocommerce-checkout-payment {
  background: transparent;
  padding: 0;
  border-radius: 0;
  margin-top: 0;
  border-top: 0;
}
.woocommerce-checkout-payment ul.payment_methods {
  list-style: none;
  padding: 0;
  margin: 0 0 32px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.woocommerce-checkout-payment ul.payment_methods li {
  padding: 0;
  border: none;
  border-radius: 0;
  display: flex;
  align-items: flex-start;
  gap: 8px;
}
.woocommerce-checkout-payment ul.payment_methods li label {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 18px;
  line-height: 1.2;
  cursor: pointer;
  display: inline;
}
.woocommerce-checkout input[type="radio"] {
  appearance: none;
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  margin: 0;
  flex: 0 0 20px;
  border: 1.5px solid var(--color-text);
  border-radius: 50%;
  background: transparent;
  box-sizing: border-box;
  cursor: pointer;
  transform: translateY(-1px);
}
.woocommerce-checkout input[type="radio"]:checked {
  border-color: var(--color-text);
  background: radial-gradient(
    circle at center,
    var(--color-bg-light) 0 4px,
    var(--color-text) 4.5px
  );
}
.woocommerce-checkout input[type="radio"]:focus-visible {
  outline: 2px solid var(--color-text);
  outline-offset: 2px;
}
.woocommerce-checkout #shipping_method {
  margin: 0;
  padding: 0;
  list-style: none;
}
.woocommerce-checkout #shipping_method li {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: nowrap;
  gap: 8px;
  text-align: left;
  margin: 0 0 10px;
  padding-top: 12px;
}
.woocommerce-checkout #shipping_method label {
  display: flex !important;
  justify-content: space-between;
  width: 100%;
  margin: 0;
  font-size: 16px;
}
.woocommerce-checkout #select-point-container {
  position: absolute;
  top: 40px;
  left: 0;
  width: 100% !important;
  min-height: 34px;
  padding-top: 6px;
  padding-bottom: 50px;
}
.woocommerce-checkout #shipping_method li:has(#select-point-container) + li {
  margin-top: 80px;
}
.woocommerce-checkout #select-point-label {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 6px 12px;
  border: 2px solid var(--color-text);
  border-radius: var(--radius-pill);
  font-family: var(--font-display);
  font-size: 14px;
  line-height: 1.2;
  color: var(--color-text);
}
.woocommerce-checkout #selected-point {
  margin-top: 12px;
  background-color: transparent;
  position: relative;
}
.woocommerce-checkout-payment .payment_box {
  padding: 14px 0 0 50px;
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.35;
  color: var(--color-text);
  background: transparent !important;
}
.woocommerce-checkout-payment .payment_box:before {
  display: none;
}
.woocommerce-checkout-payment .woocommerce-notice,
.woocommerce-checkout-payment .woocommerce-info,
.woocommerce-checkout-payment .woocommerce-error,
.woocommerce-checkout-payment .woocommerce-notice--info,
.woocommerce-checkout-payment .woocommerce-notice--error {
  font-size: 12px;
  line-height: 1.35;
}
.woocommerce-checkout-payment .wc_payment_methods li .woocommerce-info {
  padding-left: 0;
  padding-right: 0;
}
.woocommerce-checkout-payment .woocommerce-privacy-policy-text {
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.35;
  color: var(--color-text);
  margin-bottom: 22px;
}
.woocommerce-checkout-payment .woocommerce-privacy-policy-text--after-submit {
  margin: 18px 0 0;
}
.woocommerce-checkout-payment .woocommerce-privacy-policy-text a {
  text-decoration: underline;
}
.woocommerce-checkout-payment .woocommerce-terms-and-conditions-wrapper {
  margin-bottom: 22px;
}
.woocommerce-checkout-payment .woocommerce-terms-and-conditions-wrapper label {
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.25;
  display: inline-flex;
  align-items: flex-start;
  gap: 8px;
}
.woocommerce-checkout #place_order {
  width: 100%;
  min-height: 60px;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  background: var(--color-text) !important;
  color: var(--color-bg-white) !important;
  border: none !important;
  border-radius: 9999px;
  padding: 14px 32px;
  font-size: 20px !important;
  font-weight: 500;
  line-height: 1.2 !important;
  text-align: center;
  cursor: pointer;
  transition: opacity 0.2s ease;
  float: none !important;
}
.woocommerce-checkout #place_order:hover {
  opacity: 0.85;
}
.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info,
.mido-checkout > .woocommerce-form-coupon-toggle .woocommerce-info {
  background: var(--color-accent-yellow);
  border-radius: var(--radius-card);
  margin-bottom: var(--space-16);
}
.woocommerce-checkout form.woocommerce-form-login {
  width: 100%;
  max-width: 600px;
  margin: 0 0 var(--space-32);
  padding: var(--space-32);
  background: var(--color-bg-white);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-card);
  box-shadow: none;
}
.woocommerce-checkout form.woocommerce-form-login > p:first-child {
  margin: 0 0 var(--space-24);
  font-family: var(--font-body);
  font-size: var(--fs-body-16);
  line-height: 1.45;
  color: var(--color-text);
}
.woocommerce-checkout form.woocommerce-form-login .form-row {
  margin: 0 0 var(--space-20);
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}
.woocommerce-checkout form.woocommerce-form-login .form-row-first,
.woocommerce-checkout form.woocommerce-form-login .form-row-last {
  width: 100%;
  float: none;
}
.woocommerce-checkout form.woocommerce-form-login label {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-body-16);
  font-weight: 400;
  line-height: 1.25;
  color: var(--color-text);
}
.woocommerce-checkout form.woocommerce-form-login input.input-text {
  width: 100%;
  min-height: 58px;
  padding: 0 var(--space-20);
  border: 2px solid var(--color-accent-sage);
  border-radius: var(--radius-pill);
  background: transparent;
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 500;
  line-height: 1.2;
  color: var(--color-text);
  box-shadow: none;
}
.woocommerce-checkout form.woocommerce-form-login input.input-text:focus {
  outline: none;
  border-color: var(--color-text-muted);
}
.woocommerce-checkout form.woocommerce-form-login .clear {
  display: none;
}
.woocommerce-checkout form.woocommerce-form-login .woocommerce-form-login__rememberme {
  display: inline-flex;
  align-items: center;
  width: auto;
  margin: 0;
  gap: var(--space-8);
}
.woocommerce-checkout form.woocommerce-form-login .form-row:has(.woocommerce-form-login__submit) {
  margin-bottom: 0;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-16);
  flex-wrap: wrap;
}
.woocommerce-checkout form.woocommerce-form-login .woocommerce-form-login__submit {
  min-height: 48px;
  margin: 0;
  padding-inline: var(--space-32);
}
.woocommerce-checkout form.woocommerce-form-login .lost_password {
  margin: var(--space-16) 0 0;
}
.woocommerce-checkout form.woocommerce-form-login .lost_password a {
  color: var(--color-text);
  font-family: var(--font-display);
  font-weight: 500;
  text-decoration: underline;
  text-underline-offset: 3px;
}
@media (max-width: 1023px) {
  .woocommerce-checkout form.checkout {
    grid-template-columns: 1fr;
    column-gap: 0;
    row-gap: var(--space-32);
  }
  .woocommerce-checkout-review-order {
    grid-column: 1;
    grid-row: auto;
    position: static;
  }
  .woocommerce-checkout .woocommerce-billing-fields__field-wrapper {
    grid-template-columns: 1fr;
  }
  .woocommerce-checkout form .form-row-first,
  .woocommerce-checkout form .form-row-last {
    grid-column: 1;
  }
}
@media (max-width: 479px) {
  .woocommerce-checkout-review-order {
    padding: 24px;
  }
  .woocommerce-checkout-review-order:before {
    font-size: 32px;
  }
  .mido-checkout-coupon__toggle {
    text-align: center;
  }
  .woocommerce-checkout .woocommerce-billing-fields > h3 {
    font-size: 32px;
  }
  .woocommerce-checkout-review-order-table tfoot .woocommerce-shipping-totals {
    flex-direction: column;
    align-items: stretch;
  }
  .woocommerce-checkout-review-order-table
    tfoot
    .woocommerce-shipping-totals
    th,
  .woocommerce-checkout-review-order-table
    tfoot
    .woocommerce-shipping-totals
    td {
    width: 100%;
  }
}
.woocommerce-account .woocommerce-MyAccount-navigation {
  margin-bottom: var(--space-32);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-8);
  border-bottom: 2px solid var(--color-border-subtle);
  padding-bottom: var(--space-8);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  display: inline-block;
  padding: var(--space-8) var(--space-16);
  border-radius: var(--radius-pill);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-14);
  color: var(--color-text);
  text-decoration: none;
  background: var(--color-bg-light);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
  background: var(--color-accent-sage);
}
.woocommerce-account .woocommerce-MyAccount-content {
  padding: var(--space-32);
  background: var(--color-bg-white);
  border-radius: var(--radius-card);
}
.customer-login {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-32);
  max-width: 1100px;
  margin-inline: auto;
}
.customer-login--has-register {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.customer-login__card {
  background: var(--color-bg-white);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-card);
  padding: var(--space-40);
  box-shadow: none;
}
.customer-login__title {
  margin: 0 0 var(--space-24);
  color: var(--color-text);
}
.customer-login__form {
  display: flex;
  flex-direction: column;
  gap: var(--space-20);
  margin: 0;
}
.customer-login__form .input-field {
  gap: var(--space-8);
}
.customer-login__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-12);
  flex-wrap: wrap;
}
.customer-login__row .checkbox-wrapper {
  display: inline-flex;
  align-items: center;
  gap: var(--space-8);
  cursor: pointer;
  font-family: var(--font-body);
  font-size: var(--fs-body-14);
  color: var(--color-text);
}
.customer-login__lost {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-14);
  color: var(--color-text);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.customer-login__lost:hover {
  color: var(--color-accent-brown);
}
.customer-login__submit {
  width: 100%;
  margin-top: var(--space-8);
}
.customer-login__hint {
  margin: 0;
  color: var(--color-text-muted);
  font-family: var(--font-body);
  font-size: var(--fs-body-14);
  line-height: 1.5;
}
body.woocommerce-account #customer_login .u-column1,
body.woocommerce-account #customer_login .u-column2 {
  all: unset;
}
@media (max-width: 767px) {
  .customer-login--has-register {
    grid-template-columns: 1fr;
  }
  .customer-login__card {
    padding: var(--space-24);
  }
}
.woocommerce-mini-cart {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-12);
}
.woocommerce-mini-cart-item {
  display: grid;
  grid-template-columns: 60px 1fr auto;
  gap: var(--space-12);
  align-items: center;
  padding: var(--space-12) 0;
  border-bottom: 1px solid var(--color-border-subtle);
  position: relative;
}
.woocommerce-mini-cart-item img {
  width: 60px;
  height: 60px;
  object-fit: cover;
  border-radius: 8px;
}
.woocommerce-mini-cart-item a.remove {
  position: absolute;
  top: var(--space-12);
  right: 0;
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--color-bg-light);
  font-size: 16px;
  line-height: 1;
  text-decoration: none;
}
.woocommerce-mini-cart__total {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-top: var(--space-12);
  padding-top: var(--space-12);
  border-top: 2px solid var(--color-text);
  font-family: var(--font-display);
  font-weight: 500;
}
.woocommerce-mini-cart__total .amount {
  font-size: var(--fs-h5);
}
.woocommerce-mini-cart__buttons {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
  margin-top: var(--space-16);
}
.woocommerce-mini-cart__buttons a {
  justify-content: center;
  width: 100%;
}
.woocommerce-mini-cart__empty-message {
  text-align: center;
  padding: var(--space-32) 0;
  color: var(--color-text-muted);
}
.single-product-page {
  max-width: 1920px;
  margin-inline: auto;
  width: 100%;
  box-sizing: border-box;
}
.single-product-page__breadcrumbs {
  padding: 6px 60px 0;
}
.single-product-page__breadcrumbs .breadcrumbs {
  padding-block: 0;
  margin-bottom: 0;
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--color-text);
}
.single-product-page__breadcrumbs .breadcrumbs__list {
  justify-content: flex-start;
}
.single-product-page__top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 532px;
  gap: 28px;
  padding: 18px 60px 80px;
  align-items: flex-start;
}
.product-gallery {
  display: grid;
  grid-template-columns: 95px 1fr;
  gap: 12px;
  align-items: flex-start;
}
.product-gallery__rail {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 95px;
}
.product-gallery__thumb {
  display: block;
  width: 95px;
  height: 95px;
  margin: 0;
  padding: 6px;
  box-sizing: border-box;
  border: 2px solid transparent;
  background: transparent;
  border-radius: 20px;
  cursor: pointer;
  transition: border-color 0.16s ease;
}
.product-gallery__thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 14px;
}
.product-gallery__thumb:hover,
.product-gallery__thumb[data-state="active"] {
  border-color: var(--color-accent-sage);
}
.product-gallery__main-wrap {
  display: flex;
  flex-direction: column;
  gap: 0;
  align-items: center;
}
.product-gallery__main {
  width: 100%;
  aspect-ratio: 664 / 622;
  background: var(--color-bg-light);
  border-radius: 20px;
  overflow: hidden;
  position: relative;
}
.product-gallery__main img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.product-gallery__arrows {
  display: inline-flex;
  align-items: center;
  gap: 20px;
  margin-top: -24px;
  position: relative;
  z-index: 1;
}
.product-summary {
  background: #f9f5ed;
  border-radius: 20px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  box-sizing: border-box;
}
.product-summary__rating {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
}
.product-summary__rating-stars {
  display: inline-flex;
  gap: 4px;
  color: var(--color-accent-yellow);
}
.product-summary__rating-stars svg {
  width: 22px;
  height: 22px;
}
.product-summary__rating-value {
  font-family: var(--font-body);
  font-size: 12px;
  line-height: 1;
  color: var(--color-text-darkest);
}
.product-summary__heading {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.product-summary__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 32px;
  line-height: 1.1;
  color: var(--color-text);
}
.product-summary__price {
  margin: 0;
  font-family: var(--font-body);
  font-size: 20px;
  line-height: 1.5;
  color: var(--color-text);
}
.product-summary__price del {
  color: var(--color-text-muted);
  margin-right: 8px;
  font-size: 16px;
}
.product-summary__price ins {
  text-decoration: none;
  color: var(--color-text);
}
.product-summary__sizes {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.product-summary__sizes-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.product-summary__sizes-label {
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--color-text);
}
.product-summary__sizes-guide {
  background: transparent;
  border: 0;
  padding: 10px 16px;
  height: 36px;
  border-radius: 50px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  line-height: 24px;
  color: var(--color-text);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 4px;
}
.product-summary__sizes-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.product-summary__size {
  width: 32px;
  height: 32px;
  box-sizing: border-box;
  border: 2px solid var(--color-bg-beige);
  border-radius: 100px;
  background: transparent;
  color: var(--color-text);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  line-height: 24px;
  text-align: center;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition:
    background-color 0.16s ease,
    color 0.16s ease,
    border-color 0.16s ease;
}
.product-summary__size:hover {
  border-color: var(--color-text);
}
.product-summary__size.is-selected,
.product-summary__size[aria-pressed="true"] {
  background: var(--color-text);
  color: var(--color-bg-light);
  border-color: var(--color-text);
}
.product-summary__size:disabled {
  color: var(--color-accent-sage);
  cursor: not-allowed;
  text-decoration: line-through;
  border-color: var(--color-bg-beige);
}
.product-summary__form {
  margin: 0;
  padding: 0;
  width: 100%;
}
.product-summary__cta {
  width: 100%;
  height: 60px;
  border: 0;
  border-radius: 50px;
  background: var(--color-text);
  color: #f2ead7;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 20px;
  line-height: 24px;
  cursor: pointer;
  transition: background-color 0.16s ease;
  padding: 0 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  box-sizing: border-box;
  gap: 8px;
  text-decoration: none;
}
.product-summary__cta:hover {
  background: #2d3237;
}
.product-summary__cta:active {
  background: #1a1d20;
}
.product-summary__sticky-cta {
  display: none;
}
@media (max-width: 767px) {
  .product-summary__sticky-cta {
    display: block;
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 90;
    padding: 12px 16px calc(12px + env(safe-area-inset-bottom));
    background: var(--color-bg-light);
    box-shadow: 0 -8px 24px #00000014;
  }
  .product-summary__cta--sticky {
    height: 52px;
    font-size: 18px;
  }
  body.single-product {
    padding-bottom: 96px;
  }
  .product-summary__form > .product-summary__cta {
    display: none;
  }
}
.product-summary__cta.is-warning {
  animation: mido-shake 0.32s ease;
  background: var(--color-accent-brown);
}
@keyframes mido-shake {
  0%,
  to {
    transform: translate(0);
  }
  20% {
    transform: translate(-6px);
  }
  40% {
    transform: translate(6px);
  }
  60% {
    transform: translate(-4px);
  }
  80% {
    transform: translate(4px);
  }
}
.product-summary__shipping {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  align-items: start;
}
.product-summary__benefit {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 10px;
  border-radius: 20px;
  text-align: center;
}
.product-summary__benefit svg {
  width: 28px;
  height: 28px;
  color: var(--color-accent-brown);
}
.product-summary__benefit-label {
  margin: 0;
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.4;
  color: var(--color-text);
}
.product-summary__meta-block {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.product-summary__meta-row {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}
.product-summary__meta-row span,
.product-summary__meta-row a {
  font-family: var(--font-body);
  font-size: 12px;
  line-height: 1.5;
  color: var(--color-text);
  text-decoration: none;
}
.product-summary__meta-row a:hover {
  text-decoration: underline;
}
.product-summary__description {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.5;
  color: var(--color-text);
}
.product-summary__description p {
  margin: 0 0 1em;
}
.product-summary__description p:last-child {
  margin: 0;
}
.product-summary__accordions {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.product-summary__accordions .accordion {
  border-color: var(--color-bg-beige);
  border-radius: 20px;
  border-width: 2px;
}
.product-summary__details-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
  border: 1.5px solid var(--color-bg-beige);
  border-radius: 20px;
  font-size: 14px;
}
.product-summary__details-table th,
.product-summary__details-table td {
  padding: 16px 30px;
  border-bottom: 1.5px solid var(--color-bg-beige);
  text-align: left;
  vertical-align: middle;
  font-weight: 400;
}
.product-summary__details-table th {
  width: 50%;
  border-right: 1.5px solid var(--color-bg-beige);
}
.product-summary__details-table tr:last-child th,
.product-summary__details-table tr:last-child td {
  border-bottom: 0;
}
.sp-wyrozniki {
  padding: 80px 60px;
  display: flex;
  flex-direction: column;
  gap: 62px;
  align-items: center;
}
.sp-wyrozniki__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 60px;
  line-height: 1;
  color: var(--color-text);
  text-align: center;
  max-width: 805px;
}
.sp-wyrozniki__slider {
  width: 100%;
  margin-inline: 0;
}
.sp-wyrozniki__slider .slider__controls {
  display: none;
}
@media (max-width: 1023px) {
  .sp-wyrozniki__slider {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
  }
  .sp-wyrozniki__slider .slider__controls {
    display: grid;
  }
}
.sp-wyrozniki__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  width: 100%;
}
.sp-wyrozniki__card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  text-decoration: none;
}
.sp-wyrozniki__card-image {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 20px;
  overflow: hidden;
  display: block;
}
.sp-wyrozniki__card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.sp-wyrozniki__card-title {
  margin: 0;
  padding: 0 10px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 28px;
  line-height: 1.1;
  color: var(--color-text);
  text-align: center;
}
.sp-reviews {
  background: var(--color-bg-light);
  padding: 60px;
  display: flex;
  flex-direction: column;
  gap: 60px;
}
.sp-reviews__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 40px;
  line-height: 1.1;
  color: var(--color-text);
  text-align: center;
}
.sp-reviews__grid {
  display: grid;
  grid-template-columns: 306px 1fr;
  gap: 240px;
  align-items: flex-start;
}
.sp-reviews__aggregate {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  width: 306px;
}
.sp-reviews__rating-block {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.sp-reviews__rating-value {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 90px;
  line-height: 1;
  color: var(--color-text-near-black);
  text-align: center;
}
.sp-reviews__rating-stars {
  display: inline-flex;
  gap: 8px;
  color: var(--color-accent-yellow);
  margin: 4px 0;
}
.sp-reviews__rating-stars svg {
  width: 38px;
  height: 38px;
}
.sp-reviews__rating-count {
  font-family: var(--font-body);
  font-size: 12px;
  line-height: 1.5;
  color: var(--color-text-darkest);
}
.sp-reviews__add-btn {
  width: 100%;
  height: 46px;
  border: 2px solid var(--color-text);
  background: transparent;
  border-radius: 50px;
  padding: 12px 32px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 20px;
  line-height: 24px;
  color: var(--color-text);
  cursor: pointer;
  transition:
    background-color 0.16s ease,
    color 0.16s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
}
.sp-reviews__add-btn:hover {
  background: var(--color-text);
  color: var(--color-bg-light);
}
.sp-reviews__photos {
  display: grid;
  grid-template-columns: 147px 147px;
  gap: 10px;
}
.sp-reviews__photo {
  position: relative;
  height: 122px;
  border-radius: 10px;
  overflow: hidden;
  background: var(--color-bg-beige);
}
.sp-reviews__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.sp-reviews__photo--more:after {
  content: "";
  position: absolute;
  inset: 0;
  background: #0003;
}
.sp-reviews__photo-search {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 36px;
  height: 36px;
  background: var(--color-accent-yellow);
  border: 0;
  border-radius: 100px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--color-text);
  z-index: 1;
}
.sp-reviews__photo-search svg {
  width: 18px;
  height: 18px;
}
.sp-reviews__list-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.sp-reviews__list {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 30px;
  max-height: 815px;
  overflow: hidden;
  width: 100%;
}
.sp-reviews__list:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 94px;
  background: linear-gradient(
    to bottom,
    rgba(251, 249, 243, 0) 0%,
    var(--color-bg-light) 100%
  );
  pointer-events: none;
}
.sp-reviews__list-wrap.is-expanded .sp-reviews__list {
  max-height: none;
}
.sp-reviews__list-wrap.is-expanded .sp-reviews__list:after,
.sp-reviews__list-wrap.is-expanded .sp-reviews__more-btn {
  display: none;
}
.sp-reviews__more-btn {
  border: 0;
  background: transparent;
  padding: 10px 32px;
  height: 46px;
  border-radius: 50px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 20px;
  line-height: 24px;
  color: var(--color-text);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 4px;
}
.sp-scallop {
  padding: 0 60px;
  display: flex;
  flex-direction: column;
}
.sp-scallop__separator {
  display: block;
  width: 100%;
  height: auto;
  pointer-events: none;
  margin-bottom: -1px;
}
.sp-scallop__separator--bottom {
  margin-top: -1px;
  margin-bottom: 0;
}
.sp-scallop__inner {
  background: var(--color-bg-beige);
  padding: 35px 60px 27px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  box-sizing: border-box;
}
.sp-scallop__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 30px;
}
.sp-scallop__text {
  width: 614px;
  padding: 60px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  box-sizing: border-box;
}
.sp-scallop__heading {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 60px;
  line-height: 1;
  color: var(--color-text);
}
.sp-scallop__body {
  margin: 0;
  font-family: var(--font-body);
  font-size: 20px;
  line-height: 1.5;
  color: var(--color-text);
}
.sp-scallop__cta {
  align-self: flex-start;
}
.sp-scallop__image {
  width: 700px;
  aspect-ratio: 7 / 6;
  flex-shrink: 0;
}
.sp-scallop__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  -webkit-mask-image: url(../images/herbatnik-maska.svg);
  mask-image: url(../images/herbatnik-maska.svg);
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
}
.sp-scallop__row:not(.sp-scallop__row--reverse) .sp-scallop__image {
  transform: rotate(-3deg);
}
.sp-scallop__row--reverse .sp-scallop__image {
  transform: rotate(3deg);
}
.sp-faq {
  padding: 80px 60px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}
.sp-faq__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 60px;
  line-height: 1;
  color: var(--color-text);
  text-align: center;
  max-width: 805px;
}
.sp-faq__intro {
  margin: 0;
  font-family: var(--font-body);
  font-size: 20px;
  line-height: 1.4;
  color: var(--color-text);
  text-align: center;
  max-width: 686px;
}
.sp-faq__list {
  width: 850px;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 16px;
}
.sp-faq__list .accordion {
  border-radius: 20px;
}
.sp-faq__list .accordion__summary:focus-visible {
  border-radius: 20px;
}
.sp-faq__list .accordion__content .btn[data-variant="outline"] {
  margin-top: 30px;
}
.sp-faq__cta {
  margin-top: 16px;
}
.sp-blog {
  padding: 80px 60px;
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.sp-blog__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 30px;
}
.sp-blog__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 40px;
  line-height: 1.1;
  color: var(--color-text);
  max-width: 631px;
}
.sp-blog__lede {
  margin: 0;
  font-family: var(--font-body);
  font-size: 20px;
  line-height: 1.4;
  color: var(--color-text);
  max-width: 412px;
}
.sp-blog__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  align-items: flex-start;
}
.sp-blog__grid > .blog-card:nth-child(2) {
  align-self: stretch;
}
.sp-blog__controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 16px;
}
.sp-blog__dots {
  display: inline-flex;
  align-items: center;
  gap: 17px;
}
.sp-blog__dots span {
  width: 5px;
  height: 5px;
  border-radius: 9999px;
  background: var(--color-accent-sage);
  transition: background-color 0.16s ease;
}
.sp-blog__dots span.is-active {
  background: var(--color-text-muted);
}
.sp-blog__arrows {
  display: inline-flex;
  gap: 20px;
}
.sp-blog__arrow {
  width: 48px;
  height: 48px;
  border: 0;
  background: var(--color-bg-beige);
  border-radius: 9999px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text);
  transition:
    background-color 0.16s ease,
    color 0.16s ease;
}
.sp-blog__arrow:hover {
  background: var(--color-accent-sage);
  color: var(--color-bg-beige);
}
.sp-blog__arrow svg {
  width: 24px;
  height: 24px;
}
.sp-related {
  background: var(--color-bg-beige);
  padding: 80px 60px;
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.sp-related__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 30px;
}
.sp-related__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 28px;
  line-height: 1.1;
  color: var(--color-text);
}
.sp-related__toggle {
  width: 472px;
  height: 60px;
  background: var(--color-bg-light);
  border-radius: 50px;
  padding: 10px 11px;
  display: flex;
  align-items: center;
  gap: 12px;
  box-sizing: border-box;
  align-self: flex-start;
}
.sp-related__toggle-btn {
  flex: 1;
  height: 40px;
  border: 0;
  background: transparent;
  border-radius: 30px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 20px;
  line-height: 1.2;
  color: var(--color-text);
  cursor: pointer;
  transition: background-color 0.16s ease;
  padding: 8px 16px;
}
.sp-related__toggle-btn.is-active {
  background: var(--color-accent-yellow);
}
.sp-related__panel[hidden] {
  display: none;
}
.sp-related__grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 30px;
  width: 100%;
}
.sp-related__grid > .product-card-slot {
  height: 460px;
  max-width: none;
}
.sp-related__grid .product-card {
  max-width: none;
  width: 100%;
}
.sp-related__controls {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  column-gap: 24px;
  width: 100%;
  margin-top: 16px;
}
.sp-related__dots {
  display: inline-flex;
  align-items: center;
  gap: 17px;
  grid-column: 1;
  justify-self: start;
}
.sp-related__dots span {
  width: 5px;
  height: 5px;
  border-radius: 9999px;
  background: var(--color-accent-sage);
}
.sp-related__dots span.is-active {
  background: var(--color-text-muted);
}
.sp-related__arrows {
  display: inline-flex;
  gap: 20px;
  grid-column: 2;
  justify-self: center;
}
.sp-related__arrow {
  width: 48px;
  height: 48px;
  border: 0;
  background: var(--color-bg-light);
  border-radius: 9999px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text);
  transition:
    background-color 0.16s ease,
    color 0.16s ease;
}
.sp-related__arrow:hover {
  background: var(--color-accent-sage);
  color: var(--color-bg-beige);
}
.sp-related__arrow svg {
  width: 24px;
  height: 24px;
}
.sp-related__slider .slider__track {
  padding-left: clamp(20px, 4vw, 60px);
  scroll-padding-left: clamp(20px, 4vw, 60px);
}
.sp-related__slider .slider__arrows {
  display: flex;
}
.sp-related__slider .slider__controls {
  padding-inline: clamp(20px, 4vw, 60px);
}
@media (max-width: 1023px) {
  .single-product-page {
    max-width: none;
  }
  .single-product-page__breadcrumbs {
    display: none;
  }
  .single-product-page__top {
    grid-template-columns: 1fr;
    padding: 20px 20px 60px;
    gap: 24px;
  }
  .product-gallery {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .product-gallery__rail {
    order: 2;
    display: flex;
    flex-direction: row;
    gap: 10px;
    width: 100%;
    overflow-x: auto;
    scrollbar-width: none;
  }
  .product-gallery__rail::-webkit-scrollbar {
    display: none;
  }
  .product-gallery__thumb {
    width: 50px;
    height: 50px;
    padding: 3px;
    border-radius: 12px;
    flex: 0 0 50px;
  }
  .product-gallery__thumb img {
    border-radius: 9px;
  }
  .product-gallery__main {
    aspect-ratio: 337 / 316;
    border-radius: 20px;
  }
  .product-gallery__arrows {
    display: none;
  }
  .product-summary {
    background: transparent;
    padding: 0;
    border-radius: 0;
    gap: 20px;
  }
  .product-summary__title {
    font-size: 26px;
    line-height: 1;
  }
  .product-summary__price {
    font-size: 16px;
    line-height: 1.35;
  }
  .product-summary__cta {
    height: 46px;
    font-size: 16px;
    padding: 0 24px;
  }
  .product-summary__shipping {
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
  }
  .product-summary__benefit {
    padding: 0;
    gap: 8px;
  }
  .product-summary__benefit-label {
    max-width: 110px;
    font-size: 18px;
    line-height: 1.15;
    text-wrap: balance;
    overflow-wrap: normal;
  }
  .product-summary__description {
    font-size: 16px;
    line-height: 1.45;
  }
  .sp-wyrozniki,
  .sp-reviews,
  .sp-faq,
  .sp-blog,
  .sp-related {
    padding: 60px 20px;
  }
  .sp-wyrozniki__title,
  .sp-faq__title,
  .sp-scallop__heading {
    font-size: 40px;
    line-height: 0.95;
  }
  .sp-blog__grid,
  .sp-related__grid {
    grid-template-columns: 1fr;
  }
  .sp-wyrozniki__grid {
    display: flex;
    gap: 16px;
  }
  .sp-blog__grid,
  .sp-related__grid {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    padding-inline: 20px;
    box-sizing: border-box;
  }
  .sp-blog__grid::-webkit-scrollbar,
  .sp-related__grid::-webkit-scrollbar {
    display: none;
  }
  .sp-blog__grid,
  .sp-wyrozniki__grid {
    gap: 16px;
  }
  .sp-wyrozniki__card {
    flex: 0 0 80vw;
    max-width: 351px;
    scroll-snap-align: start;
  }
  .sp-blog__head {
    flex-direction: column;
    gap: 12px;
  }
  .sp-blog__title {
    font-size: 40px;
    line-height: 0.95;
  }
  .sp-blog__lede {
    display: none;
  }
  .sp-blog__grid > .blog-card {
    flex: 0 0 320px;
    scroll-snap-align: start;
  }
  .sp-reviews__grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .sp-reviews__aggregate {
    width: 100%;
  }
  .sp-reviews__list {
    max-height: 650px;
  }
  .sp-scallop {
    padding: 0;
    overflow: hidden;
  }
  .sp-scallop__separator {
    width: 100vw;
    max-width: none;
    margin-left: calc(50% - 50vw);
  }
  .sp-scallop__inner {
    padding: 24px 20px;
  }
  .sp-scallop__row,
  .sp-scallop__row--reverse {
    flex-direction: column;
    gap: 24px;
  }
  .sp-scallop__image {
    order: -1;
  }
  .sp-scallop__row--reverse .sp-scallop__image {
    order: -1;
  }
  .sp-scallop__text {
    width: 100%;
    padding: 0;
    gap: 16px;
  }
  .sp-scallop__body {
    font-size: 16px;
    line-height: 1.45;
  }
  .sp-scallop__image {
    width: calc(100% - 24px);
    margin-inline: 12px;
    height: auto;
  }
  .sp-scallop__image img {
    width: 100%;
    height: 100%;
  }
  .sp-related__toggle {
    width: 100%;
  }
  .sp-related__grid {
    gap: 10px;
  }
  .sp-related__grid > .product-card-slot {
    flex: 0 0 187px;
    width: 187px;
    height: auto;
    scroll-snap-align: start;
  }
  .sp-related__controls,
  .sp-blog__controls {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
  }
  .sp-related__dots,
  .sp-blog__dots {
    justify-self: start;
  }
  .sp-related__arrows,
  .sp-blog__arrows {
    grid-column: 2;
    justify-self: end;
  }
}
.review-card--compact {
  width: 100%;
  background: var(--color-bg-light);
  border: 2px solid var(--color-accent-sage);
  border-radius: 20px;
  padding: 20px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: 10px;
  text-align: left;
  height: auto;
}
.review-card--compact .review-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
}
.review-card--compact .review-card__stars {
  gap: 4px;
}
.review-card--compact .review-card__stars svg {
  width: 22px;
  height: 22px;
}
.review-card--compact .review-card__date {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--color-text);
}
.review-card--compact .review-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 20px;
  line-height: 1.1;
  color: var(--color-text);
  text-align: left;
}
.review-card--compact .review-card__quote {
  font-size: 16px;
  line-height: 1.5;
  color: var(--color-text);
}
.review-card--compact .review-card__footer {
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  margin-top: 0;
  width: 100%;
  gap: 12px;
}
.review-card--compact .review-card__author {
  color: var(--color-text-muted);
  font-size: 16px;
}
.review-card--compact .review-card__verified {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--color-text);
}
.review-card--compact .review-card__verified-icon {
  width: 16px;
  height: 16px;
  color: var(--color-accent-yellow);
  background: var(--color-text);
  border-radius: 9999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.review-card--compact .review-card__verified-icon svg {
  width: 10px;
  height: 10px;
}
.review-card--compact .review-card__photos {
  display: flex;
  gap: 10px;
  margin-top: 4px;
}
.review-card--compact .review-card__photo {
  position: relative;
  width: 120px;
  height: 100px;
  border-radius: 10px;
  overflow: hidden;
  flex-shrink: 0;
}
.review-card--compact .review-card__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.review-card--compact .review-card__photo:after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, #0000 50%, #0006);
  pointer-events: none;
}
.page-contact {
  padding-block: 0 var(--space-96);
  background: var(--color-bg-light);
}
.page-contact__hero .wc-archive__header-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-32);
  background: var(--color-bg-beige);
  padding: 60px 60px 40px;
  text-align: center;
}
.page-contact__panel .container,
.page-contact__faq .container {
  max-width: 1440px;
}
.page-contact__hero .breadcrumbs {
  max-width: none;
  margin: 0;
}
.page-contact__hero .breadcrumbs__list {
  justify-content: center;
}
.page-contact__hero .wc-archive__title {
  font-size: 80px;
  line-height: 1;
  text-align: center;
}
.page-contact__header {
  text-align: center;
  max-width: 800px;
  margin-bottom: var(--space-64);
}
.page-contact__title {
  margin: 0 0 var(--space-16);
}
.page-contact__lead {
  color: var(--color-text-muted);
  margin: 0;
}
.page-contact__panel {
  background: var(--color-bg-light);
  padding: var(--space-80) 0 var(--space-128);
}
.page-contact__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(480px, 570px);
  align-items: start;
  gap: clamp(64px, 10vw, 180px);
  margin-bottom: var(--space-96);
}
@media (max-width: 1023px) {
  .page-contact__grid {
    grid-template-columns: 1fr;
    gap: var(--space-48);
  }
}
.page-contact__info {
  max-width: 500px;
  padding-top: var(--space-32);
}
.page-contact__info > h2,
.page-contact__form-card > h2 {
  margin: 0 0 var(--space-24);
  font-family: var(--font-display);
  font-weight: 500;
  color: var(--color-text);
}
.page-contact__info > h2 {
  font-size: var(--fs-h4);
  line-height: var(--lh-h4);
}
.page-contact__intro,
.page-contact__address,
.page-contact__email {
  margin: 0;
  font-family: var(--font-body);
  font-style: normal;
  font-size: var(--fs-body-20);
  line-height: 1.35;
  color: var(--color-text);
}
.page-contact__intro {
  max-width: 470px;
  margin-bottom: var(--space-32);
}
.page-contact__address {
  margin-bottom: var(--space-32);
}
.page-contact__email {
  margin-bottom: var(--space-24);
}
.page-contact__email a {
  color: inherit;
  text-decoration: none;
}
.page-contact__store-btn {
  min-width: 184px;
}
.page-contact__form-card {
  display: flex;
  flex-direction: column;
  padding: var(--space-40);
  border-radius: 20px;
  background: var(--color-accent-sage);
}
.page-contact__form-card > h2 {
  font-size: var(--fs-h3);
  line-height: var(--lh-h3);
}
.page-contact__form {
  display: flex;
  flex-direction: column;
  gap: var(--space-24);
}
.page-contact__form .input-field {
  gap: var(--space-8);
}
.page-contact__form .input-field__label {
  font-size: var(--fs-caption);
  line-height: 1.2;
}
.page-contact__form .input {
  height: 52px;
  border-color: transparent;
  background: var(--color-bg-light);
}
.page-contact__textarea {
  height: auto;
  min-height: 132px;
  resize: vertical;
  border-radius: 20px;
  line-height: 1.3;
}
.page-contact__consent {
  align-items: center;
  gap: var(--space-8);
  font-size: var(--fs-body-16);
}
.page-contact__consent a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.page-contact__submit {
  align-self: flex-start;
  min-width: 236px;
}
.page-contact__faq {
  position: relative;
  overflow: hidden;
  padding: 160px 0 170px;
  background: var(--color-bg-light);
  text-align: center;
}
.page-contact__faq-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.page-contact__faq h2 {
  margin: 0 0 var(--space-24);
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  font-weight: 500;
  line-height: var(--lh-h2);
  color: var(--color-text);
}
.page-contact__faq-inner > p {
  margin: 0 0 var(--space-32);
  font-family: var(--font-body);
  font-size: var(--fs-body-20);
  line-height: 1.35;
  color: var(--color-text);
}
.page-contact__faq-list {
  width: min(100%, 800px);
  text-align: left;
}
.page-contact__faq-list .accordion {
  border-color: var(--color-bg-beige);
  border-radius: 14px;
  background: transparent;
}
.page-contact__faq-list .accordion + .accordion {
  margin-top: var(--space-12);
}
.page-contact__faq-list .accordion__summary {
  min-height: 50px;
  padding: 12px 18px;
  font-size: var(--fs-body-20);
  line-height: 1.1;
}
.page-contact__faq-list .accordion__content {
  padding: 0 18px 18px;
  font-size: var(--fs-body-16);
  line-height: 1.45;
}
.page-contact__faq-list .accordion__content p {
  margin: 0 0 var(--space-24);
}
.page-contact__faq-list .accordion__content p:last-child {
  margin-bottom: 0;
}
.page-contact__faq-list .accordion__icon {
  width: 24px;
  height: 24px;
  border-radius: 50%;
}
.page-contact__faq-list .accordion[open] .accordion__icon {
  background: var(--color-bg-beige);
}
.page-contact__faq-guide {
  color: var(--color-text);
}
.page-contact__faq-cta {
  min-width: 170px;
  margin-top: var(--space-24);
}
@media (max-width: 767px) {
  .page-contact {
    padding-bottom: 60px;
  }
  .page-contact__hero .wc-archive__header-inner {
    align-items: flex-start;
    min-height: 77px;
    padding: 28px 20px 20px;
    text-align: left;
  }
  .page-contact__hero .breadcrumbs {
    display: none;
  }
  .page-contact__hero .wc-archive__title {
    font-size: 40px;
    line-height: 0.95;
    text-align: left;
  }
  .page-contact__panel {
    padding: 40px 0 60px;
  }
  .page-contact__grid {
    gap: 48px;
    margin-bottom: 0;
  }
  .page-contact__info {
    padding-top: 0;
    max-width: none;
  }
  .page-contact__info > h2 {
    font-size: 26px;
    line-height: 1;
    margin-bottom: 20px;
  }
  .page-contact__intro,
  .page-contact__address,
  .page-contact__email {
    font-size: 16px;
    line-height: 1.45;
  }
  .page-contact__intro,
  .page-contact__address {
    margin-bottom: 24px;
  }
  .page-contact__form-card {
    padding: 0;
    background: transparent;
    border-radius: 0;
  }
  .page-contact__form-card > h2 {
    font-size: 35px;
    line-height: 1;
    margin-bottom: 24px;
  }
  .page-contact__form {
    gap: 18px;
  }
  .page-contact__textarea {
    min-height: 112px;
  }
  .page-contact__submit,
  .page-contact__store-btn {
    width: auto;
  }
  .page-contact__faq {
    padding: 60px 0;
  }
  .page-contact__faq h2 {
    font-size: 38px;
    line-height: 1;
    margin-bottom: 12px;
  }
  .page-contact__faq-inner > p {
    font-size: var(--fs-body-16);
    margin-bottom: 28px;
  }
  .page-contact__faq-list .accordion__summary {
    font-size: var(--fs-body-16);
  }
  .page-contact__faq-list .accordion {
    border-radius: 20px;
  }
}
.page-contact__stores-title {
  text-align: center;
  margin: 0 0 var(--space-48);
}
.page-contact__stores-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-24);
}
@media (max-width: 767px) {
  .page-contact__stores-list {
    grid-template-columns: 1fr;
  }
}
.page-faq {
  padding-block: var(--space-64) var(--space-96);
}
.page-faq .single-product-page,
.page-faq .single-product-page__breadcrumbs {
  max-width: 1440px;
  margin-inline: auto;
}
.page-faq .sp-faq {
  width: min(1000px, calc(100vw - 120px));
  max-width: 1000px;
  margin: 0 auto;
  padding: 80px 0 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0;
}
.page-faq .sp-faq__title,
.page-faq .sp-faq__intro {
  width: 100%;
  text-align: center;
}
.page-faq .sp-faq__title {
  margin: 0 auto 24px;
}
.page-faq .sp-faq__intro {
  margin: 0 auto 40px;
}
.page-faq .sp-faq__list {
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
}
.page-faq .sp-faq__list .accordion {
  border-width: 1px;
  border-color: #efe1be;
  border-radius: 16px;
  background: transparent;
}
.page-faq .sp-faq__list .accordion + .accordion {
  margin-top: 16px;
}
.page-faq .sp-faq__list .accordion__summary {
  min-height: 56px;
  padding: 18px 24px;
  font-size: 22px;
  line-height: 1.1;
  text-align: left;
}
@media (max-width: 767px) {
  .page-faq .sp-faq__list .accordion__summary {
    font-size: 20px;
    line-height: 1.1;
    min-height: 52px;
    padding: 12px 20px;
  }
  .page-faq .sp-faq__list .accordion__content {
    font-size: var(--fs-body-16);
    padding: 0 20px 20px;
  }
}
.page-faq .sp-faq__list .accordion__summary:hover {
  background: transparent;
}
.page-faq .sp-faq__list .accordion__content {
  padding: 0 24px 20px;
  font-size: 16px;
  line-height: 1.45;
  text-align: left;
}
.page-faq .sp-faq__list .accordion__content p {
  margin: 0 0 16px;
}
.page-faq .sp-faq__list .accordion__content p:last-child {
  margin-bottom: 0;
}
.page-faq .sp-faq__list .accordion__content .btn {
  margin-top: 4px;
}
.page-faq .sp-faq__list .accordion__icon {
  width: 22px;
  height: 22px;
}
.page-faq .sp-faq__list .accordion[open] .accordion__icon {
  background: transparent;
}
@media (max-width: 767px) {
  .page-faq .sp-faq {
    width: min(100%, calc(100vw - 32px));
    padding-top: 48px;
  }
}
.page-faq__header {
  text-align: center;
  max-width: 800px;
  margin-bottom: var(--space-48);
}
.page-faq__title {
  margin: 0 0 var(--space-16);
}
.page-faq__lead {
  color: var(--color-text-muted);
  margin: 0;
}
.page-faq__prose {
  max-width: 800px;
  margin-bottom: var(--space-48);
}
.page-faq__list {
  max-width: 800px;
  display: flex;
  flex-direction: column;
  gap: var(--space-32);
}
.page-faq__group {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}
.page-faq__group-title {
  margin: 0 0 var(--space-12);
  padding-bottom: var(--space-8);
  border-bottom: 2px solid var(--color-accent-sage);
}
.page-faq__help-cta {
  max-width: 640px;
  text-align: center;
  margin-top: var(--space-80);
  padding: var(--space-48);
  background: var(--color-bg-beige);
  border-radius: var(--radius-card);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-16);
}
.page-find-store {
  padding-block: 0 0;
}
.find-store {
  display: grid;
  grid-template-columns: 412px 1fr;
  gap: var(--space-32);
  align-items: start;
  padding-top: 60px;
  padding-bottom: var(--space-80);
}
.find-store__sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--space-20);
}
.find-store__sidebar .breadcrumbs__list {
  justify-content: flex-start;
}
.find-store .find-store__sidebar nav {
  padding-top: 0;
}
.find-store__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h4);
  line-height: var(--lh-h4);
  color: var(--color-text);
}
.find-store__search {
  display: flex;
  flex-direction: column;
  gap: var(--space-10);
}
.find-store__input-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-12);
  height: 52px;
  padding: 0 var(--space-16);
  border: 2px solid var(--color-accent-sage);
  border-radius: var(--radius-pill);
  background: var(--color-bg-light);
  overflow: hidden;
}
.find-store__input-wrap svg {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  color: var(--color-text-muted);
}
.find-store__input {
  flex: 1;
  border: none;
  background: transparent;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-16);
  color: var(--color-text);
  outline: none;
  height: 100%;
}
.find-store__input::placeholder {
  color: var(--color-text-muted);
}
.find-store__geo-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-8);
  padding: var(--space-10) var(--space-16) var(--space-10) 0;
  border: none;
  border-radius: var(--radius-pill);
  background: transparent;
  cursor: pointer;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-16);
  color: var(--color-text);
  line-height: 24px;
  transition: background-color 0.16s ease;
}
.find-store__geo-btn:hover {
  background: transparent;
}
.find-store__geo-btn .radio {
  width: 20px;
  height: 20px;
}
.find-store__geo-btn .radio:before {
  width: 20px;
  height: 20px;
  border-width: 1.5px;
}
.find-store__geo-btn .radio:after {
  width: 10px;
  height: 10px;
  background: var(--color-text);
}
.find-store__geo-btn .radio-input:checked + .radio:before {
  background: transparent;
  border-color: var(--color-text);
}
.find-store__results {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  max-height: 580px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--color-accent-sage) transparent;
}
.find-store__item {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  padding: var(--space-20);
  border: none;
  border-radius: var(--radius-card);
  background: #f9f5ed;
  cursor: pointer;
  text-align: left;
  transition: background-color 0.16s ease;
  width: 100%;
}
.find-store__item:hover,
.find-store__item--active {
  background: #f3ead7;
}
.find-store__item-name {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-16);
  color: var(--color-text);
  line-height: 1.2;
}
.find-store__item-address {
  font-family: var(--font-body);
  font-size: var(--fs-body-14);
  color: var(--color-text);
  line-height: 1.4;
}
.find-store__main {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.find-store__map {
  height: 490px;
  border-radius: var(--radius-card);
  overflow: hidden;
  background: var(--color-bg-beige);
}
.find-store__map img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.find-store__map-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-16);
  color: var(--color-text-muted);
}
.find-store__map-placeholder svg {
  width: 48px;
  height: 48px;
  opacity: 0.5;
}
.find-store__map-placeholder p {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-body-16);
}
.find-store__detail {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-20);
  padding: var(--space-20);
  border-radius: var(--radius-card);
}
.find-store__detail-info {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.find-store__detail-name {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-body-16);
  color: var(--color-text);
  line-height: 1.2;
}
.find-store__detail-address,
.find-store__detail-hours {
  font-family: var(--font-body);
  font-size: var(--fs-body-14);
  color: var(--color-text);
  line-height: 1.4;
}
.find-store__detail-btn {
  flex-shrink: 0;
}
.find-store__cta {
  padding-bottom: var(--space-80);
}
.find-store__cta-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-24);
  padding: var(--space-80) var(--space-64);
  background: var(--color-bg-beige);
  border-radius: var(--radius-card);
  text-align: center;
}
.find-store__cta-title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h2);
  line-height: 1;
  color: var(--color-text);
}
.find-store__cta-text {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-body-20);
  color: var(--color-text);
}
@media (max-width: 1023px) {
  .find-store {
    grid-template-columns: 1fr;
    gap: var(--space-40);
  }
  .find-store__sidebar {
    order: 2;
  }
  .find-store__main {
    order: 1;
  }
  .find-store__title {
    font-size: var(--fs-h4-mob);
  }
  .find-store__results {
    max-height: none;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8);
  }
  .find-store__map {
    height: 400px;
  }
  .find-store__cta-title {
    font-size: var(--fs-h2-mob);
  }
}
@media (max-width: 639px) {
  .find-store {
    display: flex;
    flex-direction: column;
    padding-top: 28px;
    padding-bottom: 60px;
    gap: 24px;
  }
  .find-store__sidebar {
    display: contents;
  }
  .find-store__title {
    order: 1;
  }
  .find-store__search {
    order: 2;
  }
  .find-store__main {
    display: contents;
  }
  .find-store__map {
    order: 3;
  }
  .find-store__detail {
    order: 4;
  }
  .find-store__results {
    order: 5;
  }
  .find-store .breadcrumbs {
    display: none;
  }
  .find-store__title {
    font-size: 40px;
    line-height: 0.95;
    max-width: 351px;
  }
  .find-store__search {
    gap: 10px;
  }
  .find-store__search,
  .find-store__input-wrap {
    width: 100%;
    box-sizing: border-box;
  }
  .find-store__input-wrap {
    height: 52px;
    border-color: var(--color-bg-beige);
    background: var(--color-bg-light);
  }
  .find-store__geo-btn {
    padding: 0;
    font-size: 16px;
    align-self: flex-start;
  }
  .find-store__results {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .find-store__map {
    height: 385px;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    border-radius: 0;
  }
  .find-store__detail {
    flex-direction: column;
    align-items: flex-start;
    padding: 20px 0 0;
  }
  .find-store__detail-btn {
    width: auto;
    text-align: center;
  }
  .find-store__cta {
    padding-bottom: 60px;
  }
  .find-store__cta-box {
    padding: 48px 24px;
  }
  .find-store__cta-title {
    font-size: 36px;
  }
}
.page-about {
  padding-block: 0 0;
}
.about-hero {
  margin-bottom: var(--space-80);
}
.about-hero__layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  align-items: center;
  gap: 0;
  min-height: clamp(560px, 42vw, 760px);
}
.about-hero__mobile-card {
  display: none;
}
.about-hero__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-24);
  padding: clamp(32px, 3vw, 42px) clamp(40px, 7vw, 140px) clamp(32px, 3vw, 42px)
    clamp(32px, 2vw, 38px);
  background: var(--color-accent-sage);
  border-radius: var(--radius-card);
  min-height: clamp(440px, 32vw, 528px);
  justify-content: center;
  position: relative;
  z-index: 1;
  margin-top: clamp(40px, 5vw, 100px);
}
.about-hero__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h2);
  line-height: 1;
  color: var(--color-text);
}
.about-hero__text {
  font-family: var(--font-body);
  font-size: var(--fs-body-20);
  line-height: 1.45;
  color: var(--color-text);
  margin: 0;
}
.about-hero__media {
  position: relative;
  z-index: 2;
  margin-left: clamp(-200px, -10vw, -80px);
  margin-top: clamp(40px, 6vw, 100px);
  height: auto;
  aspect-ratio: 740 / 575;
  overflow: hidden;
  mask: url(../images/herbatnik-maska.svg) center / 100% 100% no-repeat;
  -webkit-mask: url(../images/herbatnik-maska.svg) center / 100% 100% no-repeat;
}
.about-hero__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.about-hero__media-placeholder {
  width: 100%;
  height: 100%;
  background: var(--color-bg-beige);
}
.about-intro {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 62px;
  padding: var(--space-80) 60px;
  max-width: 1920px;
  margin: 0 auto;
}
.about-intro__header {
  display: flex;
  flex-direction: column;
  gap: var(--space-24);
  align-items: center;
  text-align: center;
  max-width: 870px;
}
.about-intro__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h2);
  line-height: 1;
  color: var(--color-text);
}
.about-intro__text {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-body-20);
  line-height: 1.45;
  color: var(--color-text);
}
.about-intro__usps {
  display: flex;
  gap: 0;
  width: 100%;
}
.about-usp {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 19px;
  padding: 20px 30px;
  text-align: center;
}
.about-usp__icon {
  width: 80px;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.about-usp__icon svg {
  width: 48px;
  height: 48px;
}
.about-usp__icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.about-usp__text {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h5);
  line-height: 1.1;
  color: var(--color-text);
}
.about-blocks {
  display: flex;
  flex-direction: column;
  gap: 60px;
  padding-block: 35px 27px;
  max-width: 1920px;
}
.about-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 0;
  min-height: 528px;
}
.about-block--text-right {
  direction: rtl;
}
.about-block--text-right > * {
  direction: ltr;
}
.about-block__text {
  display: flex;
  flex-direction: column;
  gap: var(--space-24);
  padding: 60px;
  justify-content: center;
  min-height: 504px;
}
.about-block__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h2);
  line-height: 1;
  color: var(--color-text);
}
.about-block__desc {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-body-20);
  line-height: 1.45;
  color: var(--color-text);
}
.about-block__media {
  border-radius: var(--radius-card);
  overflow: hidden;
}
.about-block__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.about-block__media-placeholder {
  width: 100%;
  height: 100%;
  background: var(--color-bg-beige);
  border-radius: var(--radius-card);
}
@media (max-width: 1140px) {
  .about-hero__layout {
    display: none;
  }
  .about-hero__mobile-card {
    display: block;
    border-radius: 20px;
    overflow: hidden;
  }
  .about-hero__mobile-img {
    position: relative;
    z-index: 1;
    height: 380px;
    overflow: hidden;
    margin-bottom: -40px;
  }
  .about-hero__mobile-img img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .about-hero__scallop {
    display: block;
    width: 100%;
    height: auto;
    position: relative;
    z-index: 1;
    margin-bottom: -1px;
    vertical-align: bottom;
  }
  .about-hero__mobile-bottom {
    position: relative;
    z-index: 2;
    font-size: 0;
    line-height: 0;
  }
  .about-hero__mobile-body {
    font-size: initial;
    line-height: initial;
    background: var(--color-accent-sage);
    padding: 24px 24px 32px;
    display: flex;
    flex-direction: column;
    gap: var(--space-24);
  }
  .about-hero__mobile-body .about-hero__title {
    font-size: var(--fs-h2-mob);
  }
  .about-hero__mobile-body .about-hero__text {
    font-size: var(--fs-body-16);
  }
}
@media (max-width: 1023px) {
  .about-intro {
    padding: var(--space-64) var(--space-24);
    gap: var(--space-48);
  }
  .about-intro__title {
    font-size: var(--fs-h2-mob);
  }
  .about-intro__text {
    font-size: var(--fs-body-16);
  }
  .about-intro__usps {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-24);
  }
  .about-usp__text {
    font-size: var(--fs-body-16);
  }
  .about-block {
    grid-template-columns: 1fr;
    min-height: auto;
  }
  .about-block--text-right {
    direction: ltr;
  }
  .about-block__text {
    padding: var(--space-32);
    min-height: auto;
  }
  .about-block__title {
    font-size: var(--fs-h2-mob);
  }
  .about-block__desc {
    font-size: var(--fs-body-16);
  }
  .about-block__media {
    height: 350px;
  }
}
@media (max-width: 639px) {
  .about-hero__content {
    padding: var(--space-32) var(--space-24);
  }
  .about-hero__title {
    font-size: 40px;
  }
  .about-hero__media {
    height: 300px;
  }
  .about-intro__usps {
    grid-template-columns: 1fr;
  }
  .about-blocks {
    gap: var(--space-40);
  }
  .about-block__text {
    padding: var(--space-24) 0;
  }
  .about-block__media {
    height: 280px;
  }
  .about-block__title {
    font-size: var(--fs-h3-mob);
  }
}
.search-results {
  padding-block: var(--space-64) 0;
}
.search-results__header {
  text-align: center;
  margin-bottom: var(--space-48);
  max-width: 800px;
}
.search-results__title {
  margin: 0 0 var(--space-12);
}
.search-results__title em {
  font-style: italic;
  color: var(--color-accent-brown);
}
.search-results__count {
  margin: 0;
}
.search-results__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-12);
  max-width: 800px;
  margin-inline: auto;
}
.search-results__link {
  display: block;
  padding: var(--space-20);
  border-radius: var(--radius-card);
  background: var(--color-bg-light);
  text-decoration: none;
  color: inherit;
  transition:
    background-color 0.16s ease,
    transform 0.16s ease;
}
.search-results__link:hover {
  background: var(--color-accent-sage);
  transform: translate(2px);
}
.search-results__item-title {
  margin: 0 0 var(--space-4);
}
.search-results__item-type {
  display: inline-block;
  margin: 0 0 var(--space-8);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.search-results__item-excerpt {
  margin: 0;
  color: var(--color-text-muted);
}
.search-results__empty {
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
  padding: var(--space-48) 0;
}
.search-results__empty > p {
  margin-bottom: var(--space-24);
}
.not-found {
  padding-block: var(--space-128) var(--space-96);
}
.not-found__inner {
  max-width: 640px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-20);
}
.not-found__code {
  font-family: var(--font-display);
  font-size: 160px;
  line-height: 1;
  color: var(--color-accent-sage);
  margin: 0;
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
}
.not-found__title {
  margin: 0;
}
.not-found__lead {
  color: var(--color-text-muted);
  margin: 0;
}
.not-found__search {
  position: relative;
  width: 100%;
  max-width: 480px;
  margin: var(--space-12) 0;
}
.not-found__search-form {
  display: flex;
  align-items: center;
  gap: var(--space-8);
  background: var(--color-bg-white);
  border: 1px solid var(--color-bg-beige);
  border-radius: 999px;
  padding: 6px 6px 6px 20px;
  transition:
    border-color 0.16s ease,
    box-shadow 0.16s ease;
}
.not-found__search-form:focus-within {
  border-color: var(--color-accent-sage);
  box-shadow: 0 0 0 3px #b4c4ae40;
}
.not-found__search-input {
  flex: 1 1 auto;
  border: 0;
  outline: 0;
  background: transparent;
  font-family: var(--font-body);
  font-size: var(--fs-body-16);
  color: var(--color-text);
  padding: 10px 0;
  min-width: 0;
}
.not-found__search-input::placeholder {
  color: var(--color-text-muted);
}
.not-found__search-submit {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: 0;
  border-radius: 999px;
  background: var(--color-text);
  color: var(--color-bg-light);
  cursor: pointer;
  transition:
    background-color 0.16s ease,
    transform 0.1s ease;
}
.not-found__search-submit:hover {
  background: #2d3237;
}
.not-found__search-submit:active {
  transform: scale(0.96);
}
.not-found__search-submit svg {
  width: 20px;
  height: 20px;
}
.not-found__search .navbar__search-results {
  position: absolute;
  top: calc(100% + var(--space-8));
  left: 0;
  right: 0;
  width: auto;
  z-index: var(--z-dropdown);
}
.not-found__cta {
  margin-top: var(--space-12);
}
@media (max-width: 1023px) {
  .not-found__code {
    font-size: 120px;
  }
}
@media (max-width: 639px) {
  .not-found__code {
    font-size: 80px;
  }
}
