:root {
  --ink: #071318;
  --navy: #082838;
  --navy-2: #06313d;
  --green: #08313d;
  --green-2: #08313d;
  --surface: #ffffff;
  --surface-cool: #f6f9f8;
  --line: #dfe7e4;
  --muted: #66757b;
  --soft: #edf3f0;
  --gold: #c7952a;
  --danger: #c42727;
  --shadow: 0 14px 34px rgba(8, 40, 56, 0.1);
  --shadow-soft: 0 8px 22px rgba(8, 40, 56, 0.08);
  --radius: 8px;
  --max: 1360px;
  --cp-motion-fast: 160ms;
  --cp-motion-medium: 260ms;
  --cp-motion-slow: 520ms;
  --cp-motion-ease: cubic-bezier(0.2, 0.82, 0.22, 1);
  --cp-motion-ease-soft: cubic-bezier(0.22, 0.72, 0.18, 1);
  --cp-site-scenic-background:
    linear-gradient(180deg, rgba(229, 244, 248, 0.5) 0%, rgba(238, 248, 250, 0.82) 46%, rgba(247, 251, 252, 1) 100%),
    url("../images/backgrounds/home-background-desktop.jpg") center top / cover no-repeat,
    linear-gradient(135deg, #e0f0f4 0%, #f5fbfc 54%, #e6f2f6 100%);
}
* {
  box-sizing: border-box;
}
html {
  scroll-behavior: smooth;
}
body {
  margin: 0;
  font-family: "Roboto", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-weight: 400;
  color: var(--ink);
  background: var(--surface);
  overflow-x: hidden;
}
a {
  color: inherit;
  text-decoration: none;
}
button,
input,
select {
  font: inherit;
}
button {
  cursor: pointer;
}
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.top-strip {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  padding: 8px clamp(20px, 6vw, 92px);
  color: #e8f4f0;
  background: var(--navy);
  font-size: 13px;
  line-height: 1.4;
}
.site-header {
  position: sticky;
  top: 0;
  z-index: 10;
  display: grid;
  grid-template-columns: minmax(240px, auto) minmax(0, 1fr) auto;
  align-items: center;
  gap: clamp(18px, 3vw, 44px);
  padding: 18px clamp(20px, 6vw, 92px);
  background: rgba(255, 255, 255, 0.94);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(14px);
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-weight: 800;
  font-size: 20px;
  letter-spacing: 0;
  color: var(--navy);
  white-space: nowrap;
}
.brand-logo-img {
  display: block;
  width: auto;
  height: auto;
  max-width: 100%;
  object-fit: contain;
}
.brand-logo-img--header {
  width: 78px;
  height: 78px;
  transform: scale(1.22);
  transform-origin: left center;
}
.brand-logo-img--footer {
  width: clamp(188px, 13vw, 216px);
  height: auto;
  object-position: left center;
}
.brand-logo-img--account {
  width: 146px;
  height: 146px;
}
.brand-logo-img--login {
  width: 120px;
  height: 120px;
}
.brand-logo-img--shop {
  width: 120px;
  height: 120px;
}
.brand-logo-img--contact {
  width: 156px;
  height: 156px;
}
.brand-logo-img--loader {
  width: clamp(150px, 13vw, 208px);
  height: auto;
}
.main-nav {
  position: absolute;
  left: 50%;
  top: 50%;
  display: flex;
  justify-content: center;
  width: 520px;
  gap: 8px;
  align-items: center;
  transform: translate(-50%, -50%);
  color: #1a2d33;
  font-size: 14px;
  font-weight: 500;
  white-space: nowrap;
  pointer-events: none;
}
.main-nav ul,
.site-footer ul {
  display: contents;
  margin: 0;
  padding: 0;
  list-style: none;
}
.main-nav li,
.site-footer li {
  list-style: none;
}
.main-nav a {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 16px;
  overflow: hidden;
  border: 1px solid transparent;
  border-radius: 999px;
  color: inherit;
  text-decoration: none;
  transition:
    color 180ms ease,
    background 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease;
  isolation: isolate;
  pointer-events: auto;
}
.main-nav a::before {
  position: absolute;
  inset: 0;
  z-index: 0;
  content: "";
  background:
    linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.42) 46%, transparent 70%),
    rgba(255, 255, 255, 0.18);
  opacity: 0;
  transform: translateX(-34%);
  transition:
    opacity 180ms ease,
    transform 320ms ease;
}
.main-nav a:hover {
  color: #08313d;
  border-color: rgba(8, 49, 61, 0.12);
  background: rgba(8, 49, 61, 0.06);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.82),
    0 12px 24px rgba(8, 40, 56, 0.08);
  transform: translateY(-1px);
  backdrop-filter: blur(10px);
}
.main-nav a:hover::before {
  opacity: 1;
  transform: translateX(18%);
}
.main-nav a.is-active,
.main-nav a[aria-current="page"] {
  color: #fff;
  border-color: rgba(199, 149, 42, 0.36);
  background: #153548;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 16px 30px rgba(8, 40, 56, 0.16);
}
.main-nav a.is-active::before,
.main-nav a[aria-current="page"]::before,
.main-nav a.is-active:hover::before,
.main-nav a[aria-current="page"]:hover::before {
  opacity: 0;
  transform: none;
}
.main-nav a.is-active:hover,
.main-nav a[aria-current="page"]:hover {
  color: #fff;
  border-color: rgba(217, 237, 207, 0.42);
  background: #153548;
}
.icon-button {
  display: grid;
  place-items: center;
  border: 0;
  background: transparent;
  color: var(--ink);
}
.header-actions svg {
  width: 22px;
  height: 22px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.header-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}
.icon-button {
  position: relative;
  width: 42px;
  height: 42px;
  overflow: hidden;
  border: 1px solid transparent;
  border-radius: 999px;
  transition:
    color 180ms ease,
    background 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease;
}
.cart-button {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 42px;
  overflow: hidden;
  border: 1px solid transparent;
  border-radius: 999px;
  padding: 0 13px 0 4px;
  color: var(--ink);
  background: transparent;
  text-decoration: none;
  transition:
    color 180ms ease,
    background 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease;
  isolation: isolate;
}
.icon-button::before,
.cart-button::before {
  position: absolute;
  inset: 0;
  z-index: 0;
  content: "";
  background:
    linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.42) 46%, transparent 70%),
    rgba(255, 255, 255, 0.18);
  opacity: 0;
  transform: translateX(-34%);
  transition:
    opacity 180ms ease,
    transform 320ms ease;
}
.icon-button:hover,
.cart-button:hover {
  color: #08313d;
  border-color: rgba(8, 49, 61, 0.12);
  background: rgba(8, 49, 61, 0.06);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.82),
    0 12px 24px rgba(8, 40, 56, 0.08);
  transform: translateY(-1px);
  backdrop-filter: blur(10px);
}
.icon-button:hover::before,
.cart-button:hover::before {
  opacity: 1;
  transform: translateX(18%);
}
.icon-button:hover svg,
.icon-button:focus-visible svg,
.cart-button:hover .cart-icon svg,
.cart-button:focus-visible .cart-icon svg {
  transform: translateY(-1px) scale(1.04);
}
.icon-button svg,
.cart-button .cart-icon svg {
  transition: transform var(--cp-motion-fast) var(--cp-motion-ease);
}
.icon-button.is-active,
.cart-button.is-active,
.icon-button[aria-current="page"],
.cart-button[aria-current="page"] {
  color: #fff;
  border-color: rgba(199, 149, 42, 0.36);
  background: #153548;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 16px 30px rgba(8, 40, 56, 0.16);
}
.icon-button.is-active::before,
.cart-button.is-active::before,
.icon-button[aria-current="page"]::before,
.cart-button[aria-current="page"]::before,
.icon-button.is-active:hover::before,
.cart-button.is-active:hover::before,
.icon-button[aria-current="page"]:hover::before,
.cart-button[aria-current="page"]:hover::before {
  opacity: 0;
  transform: none;
}
.icon-button.is-active:hover,
.cart-button.is-active:hover,
.icon-button[aria-current="page"]:hover,
.cart-button[aria-current="page"]:hover {
  color: #fff;
  border-color: rgba(217, 237, 207, 0.42);
  background: #153548;
}
.icon-button svg,
.cart-icon,
.cart-button strong {
  position: relative;
  z-index: 1;
}
.cp-header-account-icon {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
}
.cp-header-auth-stack {
  position: relative;
  z-index: 1;
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1px;
  line-height: 1.05;
  text-align: center;
  white-space: nowrap;
}
.cart-icon {
  position: relative;
  display: grid;
  width: 42px;
  height: 42px;
  place-items: center;
}
.cart-count {
  position: absolute;
  top: 1px;
  right: 0;
  z-index: 2;
  box-sizing: border-box;
  min-width: 19px;
  height: 19px;
  padding: 0 5px;
  border: 2px solid #fff;
  border-radius: 999px;
  color: #fff;
  background: #153548;
  font-size: 11px;
  font-weight: 800;
  line-height: 15px;
}
.icon-button.is-active,
.cart-button.is-active .cart-count,
.cart-button[aria-current="page"] .cart-count {
  border-color: rgba(255, 255, 255, 0.82);
}
.cart-button.is-active .cart-count,
.cart-button[aria-current="page"] .cart-count {
  color: #08313d;
  background: #d9edcf;
}
.cart-button.is-cart-syncing .cart-count {
  animation: cp-cart-count-sync 360ms cubic-bezier(0.2, 0.82, 0.22, 1) both;
}
.cart-button.is-cart-feedback {
  animation: cp-cart-button-feedback 2600ms cubic-bezier(0.2, 0.82, 0.22, 1) both;
}
.cart-button.is-cart-feedback .cart-count {
  animation: cp-cart-count-added 2600ms cubic-bezier(0.2, 0.82, 0.22, 1) both;
}

@keyframes cp-cart-count-sync {
  0%,
  100% {
    transform: scale(1);
  }

  45% {
    transform: scale(1.16);
  }
}
@keyframes cp-cart-button-feedback {
  0%,
  100% {
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.18),
      0 12px 26px rgba(21, 53, 72, 0.18);
    transform: translateY(0) scale(1);
  }

  18%,
  62% {
    background:
      radial-gradient(circle at 32% 24%, rgba(255, 255, 255, 0.74), transparent 36%),
      linear-gradient(135deg, rgba(217, 237, 207, 0.44), rgba(117, 181, 203, 0.28));
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.44),
      0 0 0 5px rgba(217, 237, 207, 0.5),
      0 0 0 9px rgba(117, 181, 203, 0.18),
      0 22px 38px rgba(21, 53, 72, 0.3);
    transform: translateY(-2px) scale(1.045);
  }
}
@keyframes cp-cart-count-added {
  0%,
  100% {
    transform: scale(1);
  }

  18% {
    transform: scale(1.42);
  }

  62% {
    transform: scale(1.22);
  }
}
.screen-reader-text {
  position: absolute !important;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
  word-wrap: normal !important;
}
.hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  min-height: 590px;
  padding: 34px clamp(20px, 5.8vw, 86px) 34px;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 42%, rgba(15, 86, 96, 0.13), transparent 29%),
    linear-gradient(90deg, #ffffff 0%, #f8fbf8 48%, #ffffff 100%);
}
.hero::after {
  position: absolute;
  inset: auto 0 0;
  height: 1px;
  background: var(--line);
  content: "";
}
.hero h1 {
  max-width: 680px;
  margin: 0 0 18px;
  font-size: clamp(38px, 2.8vw, 46px);
  line-height: 1.08;
  letter-spacing: 0;
  text-wrap: balance;
}
.hero p {
  max-width: 450px;
  margin: 0;
  color: #52666d;
  font-size: 18px;
  line-height: 1.6;
}
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 26px;
  border-radius: 7px;
  border: 1px solid transparent;
  font-weight: 700;
  transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease;
}
.button:hover {
  transform: translateY(-1px);
}
.button.primary {
  color: #fff;
  background: #153548;
  box-shadow: 0 10px 18px rgba(11, 70, 80, 0.18);
}
.button.primary:hover {
  background: #153548;
}
.button.secondary {
  color: var(--ink);
  background: #fff;
  border-color: #98aaa4;
}
.hero-slider {
  position: relative;
  width: 100%;
  max-width: 100%;
  min-height: 520px;
  overflow: hidden;
  border-radius: 8px;
  background:
    radial-gradient(circle at 50% 42%, rgba(218, 172, 66, 0.18), transparent 23%),
    linear-gradient(136deg, rgba(255, 255, 255, 0) 0 58%, rgba(246, 248, 246, 0.95) 58% 100%),
    linear-gradient(125deg, #082838 0%, #061923 59%, #f4f6f3 59%, #ffffff 100%);
  box-shadow: 0 30px 70px rgba(8, 40, 56, 0.2);
  isolation: isolate;
}
.hero-slider::before {
  position: absolute;
  inset: 22px 22px auto auto;
  width: 126px;
  height: 126px;
  border: 1px solid rgba(218, 172, 66, 0.34);
  border-radius: 50%;
  content: "";
}
.hero-slider::after {
  position: absolute;
  inset: auto -80px -130px auto;
  width: 340px;
  height: 340px;
  border: 1px solid rgba(15, 86, 96, 0.2);
  border-radius: 50%;
  content: "";
}
.hero-slider-viewport {
  position: absolute;
  inset: 0;
}
.hero-slide {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr;
  padding: 48px 48px 42px;
  opacity: 0;
  pointer-events: none;
  transform: translateX(18px);
  transition: opacity 420ms ease, transform 420ms ease;
}
.hero-slide.is-active {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(0);
}
.hero-slider-controls,
.hero-slider-dots {
  position: absolute;
  z-index: 4;
  display: flex;
  align-items: center;
}
.hero-slider-controls {
  top: 20px;
  right: 20px;
  gap: 8px;
}
.hero-arrow {
  display: inline-flex;
  width: 42px;
  height: 42px;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(8, 40, 56, 0.14);
  border-radius: 50%;
  color: var(--navy);
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 10px 24px rgba(8, 40, 56, 0.14);
  transition: transform 180ms ease, background 180ms ease, color 180ms ease;
}
.hero-arrow:hover,
.hero-arrow:focus-visible {
  color: #fff;
  background: #153548;
  transform: translateY(-1px);
}
.hero-arrow svg {
  width: 22px;
  height: 22px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.hero-slider-dots {
  right: 24px;
  bottom: 24px;
  gap: 9px;
}
.hero-slider-dots button {
  width: 9px;
  height: 9px;
  border: 0;
  border-radius: 50%;
  padding: 0;
  background: rgba(8, 40, 56, 0.22);
  transition: width 180ms ease, background 180ms ease;
}
.hero-slider-dots button[aria-current="true"] {
  width: 28px;
  border-radius: 999px;
  background: #153548;
}
.hero-slider-static .hero-slider-controls,
.hero-slider-static .hero-slider-dots {
  display: none;
}
.home-market {
  padding: 24px clamp(20px, 4vw, 48px) 0;
  background:
    linear-gradient(180deg, #f7faf9 0%, #ffffff 88%),
    linear-gradient(126deg, transparent 0 12%, rgba(255, 255, 255, 0.55) 12% 18%, transparent 18%);
}
.home-market-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  max-width: 1384px;
  margin: 0 auto;
  align-items: stretch;
}
.home-market .hero {
  min-height: auto;
  padding: 0;
  background: transparent;
}
.home-market .hero::after {
  display: none;
}
.home-market .hero-slider {
  min-height: 390px;
}
.home-market .hero-slider {
  box-shadow: 0 22px 46px rgba(8, 40, 56, 0.16);
}
.home-market .hero-slide {
  padding: 34px 36px 34px;
}
.category-panel {
  scrollbar-width: none;
}
.category-panel::-webkit-scrollbar {
  display: none;
}
.catalog {
  display: grid;
  grid-template-columns: 1fr;
  gap: 22px;
  width: calc(100% - clamp(20px, 4vw, 48px) - clamp(20px, 4vw, 48px));
  max-width: 1384px;
  margin: 0 auto;
  padding: 16px 0 18px;
}
.category-panel,
.product-card,
.order-flow {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow-soft);
}
.category-panel {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  border-color: rgba(8, 40, 56, 0.22);
  padding: 10px;
  overflow-x: auto;
  color: #eef6f3;
  background:
    radial-gradient(circle at 0% 0%, rgba(199, 149, 42, 0.12), transparent 16rem),
    linear-gradient(135deg, #082838 0%, #061923 62%, #0b3443 100%);
}
.category-panel h2 {
  flex: 0 0 auto;
  margin: 0 8px 0 0;
  color: #fff;
  font-size: 15px;
}
.category-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: auto;
  min-height: 42px;
  border: 0;
  border-radius: 6px;
  padding: 0 14px;
  text-align: center;
  color: rgba(238, 246, 243, 0.82);
  background: transparent;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
  transition: color 160ms ease, background-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}
.category-button:hover,
.category-button.active,
.category-button[aria-pressed="true"] {
  color: #d9edcf;
  background: rgba(255, 255, 255, 0.1);
  box-shadow: inset 0 0 0 1px rgba(217, 237, 207, 0.22), 0 8px 18px rgba(6, 25, 35, 0.2);
}
.category-button.active,
.category-button[aria-pressed="true"] {
  color: #fff;
  background: #153548;
}
.category-button:active {
  transform: translateY(1px);
}

@media (min-width: 821px) {
.category-panel .category-button.active,
.category-panel .category-button[aria-pressed="true"],
.category-panel .category-button.active:hover,
.category-panel .category-button[aria-pressed="true"]:hover {
    color: #fff;
    background: #153548;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.18),
      inset 0 0 0 1px rgba(199, 149, 42, 0.42),
      0 10px 20px rgba(0, 0, 0, 0.18),
      0 0 18px rgba(21, 53, 72, 0.22);
  }
}
.section-head {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: end;
  margin-bottom: 18px;
}
.product-area {
  min-width: 0;
  padding-inline: clamp(12px, 1.5vw, 22px);
}
.section-head h2,
.order-flow h2 {
  margin: 0;
  font-size: 26px;
  letter-spacing: 0;
}
.section-head p {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 14px;
}
.section-controls {
  display: flex;
  align-items: center;
  gap: 10px;
}
.section-controls select {
  height: 40px;
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 0 12px;
  background: #fff;
  font-weight: 500;
}
.cp-live-product-search {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  width: min(260px, 36vw);
  min-width: 218px;
  height: 42px;
  padding: 0 14px;
  border: 1px solid rgba(21, 53, 72, 0.16);
  border-radius: 999px;
  color: #153548;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.82), rgba(239, 248, 250, 0.62));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.82),
    0 8px 18px rgba(21, 53, 72, 0.07);
  transition:
    border-color 180ms ease,
    box-shadow 180ms ease,
    background-color 180ms ease,
    transform 180ms ease;
}
.cp-live-product-search:focus-within,
.cp-live-product-search.is-live-searching {
  border-color: rgba(21, 53, 72, 0.28);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.9), rgba(239, 248, 250, 0.72));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.9),
    0 10px 22px rgba(21, 53, 72, 0.1),
    0 0 0 3px rgba(217, 237, 207, 0.24);
}
.cp-live-product-search svg {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
  opacity: 0.78;
}
.cp-live-product-search input[type="search"] {
  width: 100%;
  min-width: 0;
  border: 0;
  color: #153548;
  background: transparent;
  box-shadow: none;
  font: inherit;
  font-size: 14px;
  font-weight: 800;
  outline: none;
}
.cp-live-product-search input[type="search"]::placeholder {
  color: rgba(21, 53, 72, 0.44);
  font-weight: 800;
}
.text-link {
  display: inline-flex;
  align-items: center;
  height: 40px;
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 7px;
  color: var(--green-2);
  font-weight: 700;
}
.product-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 248px));
  justify-content: start;
  gap: 16px;
  will-change: opacity, transform;
  transition: opacity 135ms ease-out, transform 135ms ease-out;
}
.products[data-product-grid] {
  transition: opacity 135ms ease-out, transform 135ms ease-out;
}

:is(.product-grid, .products[data-product-grid]).is-filtering {
  opacity: 0.78;
  pointer-events: none;
  transform: translateY(1px);
}

:is(.product-grid, .products[data-product-grid]).has-filtered:not(.is-reordering) .product-card:not([hidden]) {
  animation: cp-product-filter-in 240ms cubic-bezier(0.2, 0.8, 0.2, 1) both;
}

:is(.product-grid, .products[data-product-grid]).is-reordering .product-card:not([hidden]) {
  animation: none;
}
.product-card[hidden],
.empty-state[hidden] {
  display: none !important;
}
.empty-state {
  grid-column: 1 / -1;
  display: grid;
  min-height: 220px;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  color: var(--muted);
  background: var(--surface-cool);
  font-weight: 500;
  text-align: center;
}

@keyframes cp-product-filter-in {
  from {
    opacity: 0;
    transform: translateY(6px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.product-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 418px;
  padding: 0;
  border: 1px solid #153548;
  overflow: hidden;
  isolation: isolate;
  background:
    linear-gradient(180deg, #ffffff 0%, #ffffff 58%, #f8fbfa 100%);
  box-shadow: 0 14px 34px rgba(8, 40, 56, 0.08);
  transition:
    transform var(--cp-motion-medium) var(--cp-motion-ease),
    box-shadow var(--cp-motion-medium) ease,
    border-color var(--cp-motion-fast) ease,
    background-color var(--cp-motion-fast) ease;
}
.product-card::before {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 22% 12%, rgba(226, 244, 249, 0.48), transparent 34%),
    radial-gradient(circle at 92% 8%, rgba(21, 53, 72, 0.08), transparent 28%),
    linear-gradient(135deg, rgba(21, 53, 72, 0.1), transparent 42%, rgba(15, 86, 96, 0.08));
  content: "";
  opacity: 0;
  transition: opacity var(--cp-motion-medium) ease;
}
.product-card::after {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background: linear-gradient(115deg, transparent 0 42%, rgba(255, 255, 255, 0.5) 50%, transparent 58% 100%);
  content: "";
  opacity: 0;
  transform: translateX(-135%);
  transition: opacity 220ms ease, transform 520ms ease;
}
.product-card:hover,
.product-card:focus-within {
  transform: translateY(-5px);
  border-color: #153548;
  box-shadow: 0 22px 48px rgba(8, 40, 56, 0.14);
}
.product-card:hover::before,
.product-card:focus-within::before {
  opacity: 1;
}
.product-card:hover::after,
.product-card:focus-within::after {
  opacity: 0.78;
  transform: translateX(135%);
}
.product-card > * {
  position: relative;
  z-index: 1;
}
.favorite {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 4;
  display: grid;
  width: 32px;
  height: 32px;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 50%;
  color: #43545a;
  background: #fff;
  transition:
    color var(--cp-motion-fast) ease,
    background var(--cp-motion-fast) ease,
    border-color var(--cp-motion-fast) ease,
    box-shadow var(--cp-motion-fast) ease,
    transform var(--cp-motion-fast) var(--cp-motion-ease);
}
.favorite:hover,
.favorite:focus-visible,
.product-card:focus-within .favorite {
  color: #fff;
  border-color: rgba(226, 244, 249, 0.56);
  background: #153548;
  box-shadow:
    0 10px 20px rgba(21, 53, 72, 0.16),
    0 0 0 4px rgba(226, 244, 249, 0.24);
  transform: translateY(-1px) scale(1.04);
}
.favorite svg {
  width: 17px;
  height: 17px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
}
.product-art {
  position: relative;
  display: grid;
  min-height: 258px;
  place-items: center;
  margin: 0;
  border-radius: 0 0 18px 18px;
  overflow: hidden;
  background: #fff;
  box-shadow: none;
}
.product-art::before {
  position: absolute;
  inset: 14px;
  border-radius: 18px;
  background:
    radial-gradient(circle at 50% 54%, rgba(21, 53, 72, 0.08), transparent 46%),
    linear-gradient(145deg, rgba(226, 244, 249, 0.34), rgba(255, 255, 255, 0));
  content: "";
  opacity: 0;
  transform: scale(0.96);
  transition:
    opacity var(--cp-motion-medium) ease,
    transform var(--cp-motion-medium) var(--cp-motion-ease);
}
.product-art img {
  position: relative;
  z-index: 1;
  max-width: 88%;
  max-height: 222px;
  width: auto;
  height: auto;
  object-fit: contain;
  transition:
    transform var(--cp-motion-medium) var(--cp-motion-ease),
    filter var(--cp-motion-fast) ease;
}
.product-card:hover .product-art::before,
.product-card:focus-within .product-art::before {
  opacity: 1;
  transform: scale(1);
}
.product-card:hover .product-art img,
.product-card:focus-within .product-art img {
  transform: var(--cp-product-card-media-hover-transform, translateY(-7px) scale(1.03));
}
.product-card-body {
  position: relative;
  display: flex;
  flex: 1;
  flex-direction: column;
  padding: 16px 18px 18px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), #ffffff 52%, #f9fcfb);
}
.product-card h3 {
  margin: 0 0 7px;
  font-size: 18px;
  line-height: 1.22;
  overflow-wrap: anywhere;
}
.price-row {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
  margin-bottom: 12px;
  min-width: 0;
}
.price-row strong {
  min-width: 0;
  color: var(--green-2);
  font-size: 20px;
  line-height: 1.05;
  overflow-wrap: anywhere;
}
.price-row del,
.price-row ins,
.price-row .amount,
.price-row .woocommerce-Price-amount {
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  overflow-wrap: anywhere;
}
.price-row .amount,
.price-row .woocommerce-Price-amount {
  white-space: nowrap;
}
.add-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  border: 0;
  border-radius: 6px;
  color: #fff;
  background: #153548;
  font-weight: 800;
  transform-origin: center;
}
.add-button:hover {
  background: #153548;
}
.product-card .added_to_cart.wc-forward,
[data-product-card] .added_to_cart.wc-forward,
.cp-related-card .added_to_cart.wc-forward {
  display: none !important;
  flex: 0 0 0 !important;
  width: 0 !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: hidden !important;
}
.order-flow {
  max-width: var(--max);
  margin: 0 auto 0;
  padding: clamp(20px, 2.8vw, 28px) clamp(18px, 4vw, 42px);
  background: linear-gradient(180deg, #ffffff, #f5f9f7);
}
.order-flow h2 {
  margin-bottom: 22px;
  text-align: center;
}
.flow-steps {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 18px;
}
.flow-steps article {
  display: grid;
  gap: 8px;
  text-align: center;
}
.flow-steps span {
  display: grid;
  width: 44px;
  height: 44px;
  place-items: center;
  margin: 0 auto;
  border: 8px solid #e5f0e1;
  border-radius: 50%;
  color: var(--green-2);
  background: #fff;
  font-weight: 800;
}
.flow-steps strong {
  font-size: 14px;
}
.flow-steps p {
  max-width: 160px;
  margin: 0 auto;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}
.site-footer {
  --footer-inline-pad: clamp(20px, 6vw, 92px);
  display: grid;
  grid-template-columns: 1.5fr 0.75fr 0.75fr 1.1fr 1.15fr;
  gap: 34px;
  margin-top: 30px;
  padding: 34px var(--footer-inline-pad) 0;
  color: #f3f8f8;
  background: #153548;
}
.site-footer h2 {
  margin: 0 0 14px;
  color: #fff;
  font-size: 16px;
}
.site-footer a,
.site-footer p {
  display: block;
  margin: 0 0 10px;
  color: #edf4f5;
  font-size: 14px;
  line-height: 1.55;
}
.wp-page-shell {
  max-width: var(--max);
  margin: 0 auto;
  padding: 56px clamp(20px, 6vw, 92px);
}
.wp-page-content {
  max-width: 840px;
}
.wp-page-content h1,
.woo-page-shell h1 {
  margin: 0 0 24px;
  font-size: clamp(34px, 4vw, 52px);
  line-height: 1.08;
}
.woo-page-shell .woocommerce {
  color: var(--ink);
}
.woo-page-shell {
  max-width: none;
  padding: 0;
}
.cp-single-product {
  max-width: var(--max);
  margin: 0 auto;
  padding: 30px clamp(20px, 6vw, 92px) 54px;
}
.cp-breadcrumb {
  margin-bottom: 18px;
  color: var(--muted);
  font-size: 13px;
}
.cp-breadcrumb a {
  color: #42575d;
}
.cp-breadcrumb .woocommerce-breadcrumb {
  margin: 0;
}
.cp-product-hero {
  display: grid;
  grid-template-columns: minmax(360px, 0.95fr) minmax(420px, 1.05fr);
  gap: clamp(36px, 5vw, 72px);
  align-items: start;
}
.cp-product-gallery {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: linear-gradient(180deg, #ffffff, #f7faf9);
  box-shadow: var(--shadow-soft);
}
.cp-product-gallery::after {
  position: absolute;
  top: 22px;
  right: 22px;
  display: grid;
  width: 46px;
  height: 46px;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 50%;
  color: var(--ink);
  background: #fff;
  content: "";
  box-shadow: 0 8px 22px rgba(8, 40, 56, 0.08);
  pointer-events: none;
}
.cp-product-gallery .woocommerce-product-gallery {
  width: 100% !important;
  margin: 0 !important;
  float: none !important;
}
.cp-product-gallery .woocommerce-product-gallery__wrapper {
  margin: 0;
}
.cp-product-gallery .woocommerce-product-gallery__image {
  display: grid;
  min-height: 520px;
  place-items: center;
}
.cp-product-gallery .woocommerce-product-gallery__image a {
  display: grid;
  width: 100%;
  place-items: center;
}
.cp-product-gallery .woocommerce-product-gallery__image img {
  width: auto !important;
  max-width: 78%;
  max-height: 500px;
  object-fit: contain;
}
.cp-product-gallery .flex-control-thumbs {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 0;
  padding: 0 22px 22px !important;
  list-style: none;
}
.cp-product-gallery .flex-control-thumbs li {
  width: auto !important;
  margin: 0 !important;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: #fff;
  overflow: hidden;
}
.cp-product-gallery .flex-control-thumbs img {
  width: 100%;
  height: 80px;
  object-fit: contain;
  padding: 8px;
}
.cp-product-gallery .flex-control-thumbs img.flex-active {
  border: 1px solid var(--green);
}
.cp-product-notices {
  margin: 0 0 22px;
}
.cp-product-notices .woocommerce-message,
.cp-product-notices .woocommerce-info,
.cp-product-notices .woocommerce-error {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  min-height: 62px;
  margin: 0;
  padding: 14px 18px;
  border: 1px solid #cddbd8;
  border-radius: 8px;
  color: #10262e;
  background: #fff;
  box-shadow: var(--shadow-soft);
}
.cp-product-notices .woocommerce-error {
  align-items: flex-start;
  border-color: #efcaca;
  background: #fff8f8;
}
.cp-product-notices .button {
  flex: 0 0 auto;
  min-height: 42px;
  padding: 0 18px !important;
  border: 1px solid #78a66e !important;
  border-radius: 7px !important;
  color: var(--green-2) !important;
  background: #fff !important;
  font-size: 14px !important;
  font-weight: 800 !important;
}
.cp-product-summary {
  padding-top: 10px;
}
.cp-product-title {
  max-width: 620px;
  margin: 0 0 12px;
  color: var(--ink);
  font-size: clamp(36px, 4vw, 52px);
  line-height: 1.05;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}
.cp-rating-row {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 22px;
  margin-bottom: 14px;
  color: var(--muted);
  font-size: 13px;
}
.cp-rating-row .star-rating {
  float: none;
  margin: 0;
  color: #e2a626;
}
.cp-price-row {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 14px;
}
.cp-price-row strong {
  color: var(--green-2);
  font-size: 28px;
  line-height: 1.05;
  overflow-wrap: anywhere;
}
.cp-price-row .woocommerce-Price-amount,
.cp-price-row .amount,
.cp-price-row .woocommerce-Price-currencySymbol,
.cp-price-row ins,
.cp-price-row del {
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  overflow-wrap: anywhere;
}
.cp-price-row > span {
  color: var(--muted);
  font-size: 14px;
  font-weight: 500;
}
.cp-short-description {
  max-width: 620px;
  color: #3d5158;
  font-size: 16px;
  line-height: 1.7;
}
.cp-short-description p {
  margin: 0;
}
.cp-feature-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 18px;
  margin: 22px 0 28px;
  color: #274047;
  font-size: 14px;
  font-weight: 700;
}
.cp-feature-tags span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.cp-feature-tags span::before {
  width: 18px;
  height: 18px;
  border: 2px solid var(--green);
  border-radius: 50% 0 50% 0;
  content: "";
  transform: rotate(-18deg);
}
.cp-purchase-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 190px;
  gap: 14px;
  align-items: center;
  padding: 24px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.cp-purchase-panel form.cart {
  display: grid !important;
  grid-template-columns: 112px minmax(180px, 1fr);
  gap: 14px;
  align-items: center;
  margin: 0 !important;
}
.cp-purchase-panel .quantity {
  display: block;
}
.cp-purchase-panel .qty {
  width: 100% !important;
  height: 52px;
  border: 1px solid var(--line);
  border-radius: 7px;
  color: var(--ink);
  background: #fff;
  font-weight: 800;
  text-align: center;
}
.cp-purchase-panel .single_add_to_cart_button,
.cp-purchase-panel .button {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  min-height: 52px;
  border: 0 !important;
  border-radius: 7px !important;
  color: #fff !important;
  background: #153548 !important;
  box-shadow: 0 12px 22px rgba(11, 70, 80, 0.18);
  font-weight: 700 !important;
}
.cp-purchase-panel .single_add_to_cart_button span {
  min-width: 0;
}
.cp-purchase-panel .single_add_to_cart_button svg {
  flex: 0 0 auto;
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.add-button .cart-button-icon,
.cp-purchase-panel .single_add_to_cart_button .cart-button-icon {
  flex: 0 0 auto;
}
.add-button .cart-button-icon--check,
.cp-purchase-panel .single_add_to_cart_button .cart-button-icon--check {
  display: none;
}
.add-button.is-cart-add-success .cart-button-icon--cart,
.cp-purchase-panel .single_add_to_cart_button.is-cart-add-success .cart-button-icon--cart {
  display: none;
}
.add-button.is-cart-add-success .cart-button-icon--check,
.cp-purchase-panel .single_add_to_cart_button.is-cart-add-success .cart-button-icon--check {
  display: block;
}
.cp-favorite-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 52px;
  border: 1px solid var(--line);
  border-radius: 7px;
  color: var(--ink);
  background: #fff;
  font-weight: 800;
}
.cp-favorite-link svg,
.cp-mini-cart svg,
.cp-line-icon svg {
  width: 21px;
  height: 21px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cp-trust-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin: 24px 0;
}
.cp-trust-row div {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 3px 10px;
  align-items: center;
}
.cp-line-icon {
  grid-row: span 2;
  display: grid;
  width: 28px;
  height: 28px;
  place-items: center;
  color: var(--green);
}
.cp-trust-row strong {
  font-size: 12px;
}
.cp-trust-row small {
  color: var(--muted);
  font-size: 11px;
  line-height: 1.35;
}
.cp-meta-line {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  color: var(--muted);
  font-size: 12px;
}
.cp-meta-line a {
  color: #385c67;
}
.cp-product-info,
.cp-description,
.cp-related-products {
  margin-top: 28px;
}
.cp-product-info {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow-soft);
}
.cp-product-info h2 {
  margin: 0;
  padding: 18px 22px;
  border-bottom: 1px solid var(--line);
  font-size: 17px;
}
.cp-info-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0;
}
.cp-info-grid article {
  min-height: 120px;
  padding: 22px;
  border-right: 1px solid var(--line);
}
.cp-info-grid article:last-child {
  border-right: 0;
}
.cp-info-grid strong {
  display: block;
  margin-bottom: 8px;
  font-size: 13px;
}
.cp-info-grid p {
  margin: 0;
  color: #52666d;
  font-size: 13px;
  line-height: 1.55;
}
.cp-description {
  max-width: 880px;
  color: #40545b;
  line-height: 1.7;
}
.cp-description h2,
.cp-related-products h2 {
  margin: 0 0 16px;
  font-size: 24px;
}
.cp-description p {
  margin: 0 0 12px;
}
.cp-related-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}
.cp-related-card {
  position: relative;
  display: grid;
  grid-template-columns: 134px minmax(0, 1fr) 48px;
  gap: 16px;
  align-items: center;
  min-height: 166px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow-soft);
}
.cp-related-card > div {
  min-width: 0;
}
.cp-related-image {
  display: grid;
  min-height: 126px;
  place-items: center;
  border-radius: 6px;
  background: var(--surface-cool);
}
.cp-related-image img {
  max-width: 112px;
  max-height: 114px;
  width: auto;
  height: auto;
  object-fit: contain;
}
.cp-related-card h3 {
  margin: 0 0 16px;
  font-size: 15px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}
.cp-related-card strong {
  display: block;
  color: var(--ink);
  font-size: 16px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}
.cp-mini-cart {
  display: grid;
  justify-self: end;
  width: 48px;
  height: 48px;
  place-items: center;
  border-radius: 7px;
  color: #fff;
  background: #153548;
}
.cp-mini-cart svg {
  width: 22px;
  height: 22px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.1;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cp-cart-shell {
  max-width: var(--max);
  padding: 42px clamp(20px, 6vw, 92px) 54px;
}
.cp-cart-head {
  display: grid;
  grid-template-columns: minmax(180px, 0.35fr) minmax(520px, 0.65fr);
  gap: 34px;
  align-items: end;
  margin-bottom: 26px;
}
.cp-cart-head h1 {
  margin: 0;
  font-size: clamp(40px, 4.4vw, 58px);
  line-height: 1;
  letter-spacing: 0;
}
.cp-checkout-steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
  counter-reset: step;
}
.cp-checkout-steps li {
  position: relative;
  display: grid;
  gap: 9px;
  justify-items: center;
  color: #5d7076;
  font-size: 13px;
  font-weight: 700;
}
.cp-checkout-steps li::before {
  position: absolute;
  top: 16px;
  right: 50%;
  width: 100%;
  height: 1px;
  background: repeating-linear-gradient(90deg, #cbd8d4 0 5px, transparent 5px 10px);
  content: "";
  transform: translateX(-18px);
}
.cp-checkout-steps li:first-child::before {
  display: none;
}
.cp-checkout-steps span {
  position: relative;
  z-index: 1;
  display: grid;
  width: 34px;
  height: 34px;
  place-items: center;
  border: 1px solid #cbd8d4;
  border-radius: 50%;
  color: #33474e;
  background: #fff;
  font-weight: 800;
}
.cp-checkout-steps .active {
  color: var(--green-2);
}
.cp-checkout-steps .active span {
  border-color: var(--green-2);
  color: #fff;
  background: var(--green-2);
  box-shadow: 0 0 0 8px #e7f1e5;
}
.cp-checkout-steps .done {
  color: var(--green-2);
}
.cp-checkout-steps .done span {
  border-color: var(--green-2);
  color: #fff;
  background: var(--green-2);
}
.cp-checkout-guest-note {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0;
  align-items: center;
  margin-top: 26px;
  padding: clamp(22px, 2.2vw, 32px);
  border: 1px solid rgba(255, 255, 255, 0.68);
  border-radius: clamp(22px, 2vw, 32px);
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 255, 255, 0.74), transparent 42%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.72), rgba(226, 244, 249, 0.38));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.74),
    0 12px 28px rgba(21, 53, 72, 0.07);
}
.cp-checkout-guest-note span {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 10px;
  padding: 6px 10px;
  border: 1px solid rgba(21, 53, 72, 0.12);
  border-radius: 999px;
  color: var(--cp-flow-ink, #153548);
  background: rgba(255, 255, 255, 0.58);
  font-size: 12px;
  font-weight: 900;
}
.cp-checkout-guest-note h2 {
  margin: 0;
  max-width: 720px;
  color: var(--cp-flow-ink, #153548);
  font-size: clamp(22px, 2vw, 30px);
  line-height: 1.12;
}
.cp-checkout-guest-note p {
  max-width: 820px;
  margin: 10px 0 0;
  color: var(--cp-flow-muted, #5d737b);
  line-height: 1.65;
}
.cp-registration-check {
  position: absolute;
  left: -10000px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
.cp-cart-shell .woocommerce > h1,
.cp-cart-shell .entry-title,
.cp-cart-shell .wp-block-post-title,
.cp-cart-shell > h1:not(#cp-cart-title),
.cp-cart-shell > .page-title {
  display: none;
}
.cp-cart-shell .woocommerce,
.cp-cart-shell .wp-block-woocommerce-cart,
.cp-cart-content {
  width: 100%;
}
.cp-cart-content {
  max-width: none;
}
.cp-cart-content > h1,
.cp-cart-content .entry-title {
  display: none;
}
.cp-cart-shell .wc-block-cart {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 390px;
  gap: 28px;
  align-items: start;
}
.cp-cart-shell .wc-block-cart__main,
.cp-cart-shell .woocommerce-cart-form {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow-soft);
  overflow: hidden;
}
.cp-cart-shell .wc-block-cart-items,
.cp-cart-shell table.shop_table {
  width: 100%;
  border: 0 !important;
  border-collapse: collapse;
}
.cp-cart-shell .wc-block-cart-items thead,
.cp-cart-shell table.shop_table thead {
  color: #253b42;
  background: #fff;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}
.cp-cart-shell .wc-block-cart-items th,
.cp-cart-shell table.shop_table th {
  padding: 22px 24px !important;
  border-bottom: 1px solid var(--line) !important;
}
.cp-cart-shell .wc-block-cart-items__row,
.cp-cart-shell table.shop_table.cart tr.cart_item {
  border-bottom: 1px solid var(--line);
}
.cp-cart-shell .wc-block-cart-items__row:last-child,
.cp-cart-shell table.shop_table.cart tr.cart_item:last-child {
  border-bottom: 0;
}
.cp-cart-shell .wc-block-cart-items td,
.cp-cart-shell table.shop_table td {
  padding: 22px 24px !important;
  border: 0 !important;
  vertical-align: middle;
}
.cp-cart-shell .wc-block-cart-item__image img,
.cp-cart-shell table.cart img {
  width: 92px !important;
  height: 92px !important;
  object-fit: contain;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: var(--surface-cool);
  padding: 8px;
}
.cp-cart-shell .wc-block-components-product-name,
.cp-cart-shell table.cart .product-name a {
  color: var(--ink);
  font-size: 15px;
  font-weight: 700;
  line-height: 1.35;
}
.cp-cart-shell .wc-block-components-product-metadata,
.cp-cart-shell .product-name dl,
.cp-cart-shell .product-name .variation {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.55;
}
.cp-cart-shell .wc-block-components-quantity-selector,
.cp-cart-shell .quantity {
  display: inline-grid;
  grid-template-columns: 34px 44px 34px;
  align-items: center;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: #fff;
  overflow: hidden;
}
.cp-cart-shell .wc-block-components-quantity-selector__button,
.cp-cart-shell .quantity button {
  width: 34px;
  min-height: 38px;
  border: 0;
  color: var(--ink);
  background: transparent;
  font-weight: 700;
}
.cp-cart-shell .wc-block-components-quantity-selector__input,
.cp-cart-shell .quantity .qty {
  width: 44px !important;
  min-height: 38px;
  border: 0;
  border-right: 1px solid var(--line);
  border-left: 1px solid var(--line);
  color: var(--ink);
  background: #fff;
  font-weight: 800;
  text-align: center;
}
.cp-cart-shell .woocommerce-cart-form .quantity:not(:has(button)) {
  grid-template-columns: minmax(54px, 64px);
  width: max-content;
}
.cp-cart-shell .woocommerce-cart-form .quantity:not(:has(button)) .qty {
  width: 64px !important;
  border-inline: 0 !important;
  padding-inline: 10px !important;
}
.cp-cart-shell .wc-block-cart-item__remove-link,
.cp-cart-shell table.cart .product-remove a {
  display: inline-grid !important;
  width: 38px;
  height: 38px;
  place-items: center;
  border: 1px solid transparent;
  border-radius: 7px;
  color: #52666d !important;
  background: transparent;
  font-size: 18px;
  text-decoration: none !important;
}
.cp-cart-shell .wc-block-cart-item__remove-link:hover,
.cp-cart-shell table.cart .product-remove a:hover {
  border-color: #f0c5c5;
  color: var(--danger) !important;
  background: #fff7f7;
}
.cp-cart-shell .wc-block-cart__sidebar,
.cp-cart-shell .cart-collaterals .cart_totals {
  position: sticky;
  top: 96px;
  width: 100% !important;
  float: none !important;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow-soft);
  overflow: hidden;
}
.cp-cart-shell .wc-block-cart__sidebar {
  padding: 0;
}
.cp-cart-shell .wp-block-woocommerce-cart-order-summary-block,
.cp-cart-shell .cart_totals {
  padding: 22px;
}
.cp-cart-shell .wc-block-cart__totals-title,
.cp-cart-shell .cart_totals h2 {
  margin: 0 0 18px;
  padding: 0;
  color: var(--ink);
  font-size: 22px;
  font-weight: 800;
  text-align: left;
}
.cp-cart-shell .wc-block-components-totals-wrapper,
.cp-cart-shell .cart_totals tr {
  border-top: 1px solid var(--line);
}
.cp-cart-shell .wc-block-components-totals-wrapper:first-child {
  border-top: 0;
}
.cp-cart-shell .wc-block-components-totals-item,
.cp-cart-shell .cart_totals th,
.cp-cart-shell .cart_totals td {
  padding: 14px 0 !important;
  color: #2a4148;
  font-size: 14px;
}
.cp-cart-shell .wc-block-components-totals-footer-item,
.cp-cart-shell .order-total {
  align-items: baseline;
  font-size: 18px;
  font-weight: 800;
}
.cp-cart-shell .wc-block-components-totals-footer-item .wc-block-components-totals-item__value,
.cp-cart-shell .order-total .amount {
  color: var(--green-2);
  font-size: 24px;
  font-weight: 800;
}
.cp-cart-shell .wc-block-components-button,
.cp-cart-shell .checkout-button,
.cp-cart-shell button[name="update_cart"] {
  min-height: 48px;
  border: 0 !important;
  border-radius: 7px !important;
  color: #fff !important;
  background: #153548 !important;
  box-shadow: 0 12px 22px rgba(11, 70, 80, 0.18);
  font-weight: 700 !important;
  text-decoration: none !important;
}
.cp-cart-shell .wc-block-cart__submit-button,
.cp-cart-shell .checkout-button {
  width: 100%;
  margin-top: 12px;
}
.cp-cart-shell .wc-block-components-button:hover,
.cp-cart-shell .checkout-button:hover,
.cp-cart-shell button[name="update_cart"]:hover {
  background: #153548 !important;
}
.cp-cart-shell .wc-block-components-text-input input {
  min-height: 48px;
  border: 1px solid var(--line) !important;
  border-radius: 7px !important;
  padding: 0 14px !important;
  color: var(--ink);
  background: #fff;
}
.cp-cart-shell .actions {
  padding: 0 !important;
  border-top: 1px solid var(--line);
}
body.woocommerce-cart.cp-cart-auto-update .cp-cart-shell .actions {
  display: none !important;
  padding: 0 !important;
  border: 0 !important;
}
.cp-cart-shell .cart-collaterals {
  margin-top: 0;
}
.cp-cart-shell .wc-block-components-sidebar-layout {
  display: contents;
}
.cp-cart-shell .wc-block-components-main {
  width: auto;
  padding-right: 0;
}
.cp-cart-shell .wc-block-components-sidebar {
  width: auto;
  padding-left: 0;
}
.cp-cart-service-band {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  margin-top: 28px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow-soft);
}
.cp-cart-service-band div {
  display: flex;
  align-items: center;
  gap: 16px;
  min-height: 90px;
  padding: 22px 28px;
  border-right: 1px solid var(--line);
}
.cp-cart-service-band div:last-child {
  border-right: 0;
}
.cp-cart-service-band svg {
  flex: 0 0 auto;
  width: 34px;
  height: 34px;
  fill: none;
  stroke: var(--green);
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cp-cart-service-band span {
  display: grid;
  gap: 4px;
}
.cp-cart-service-band strong {
  font-size: 15px;
}
.cp-cart-service-band small {
  color: var(--muted);
  font-size: 13px;
}
.cp-checkout-shell {
  max-width: var(--max);
  padding: 42px clamp(20px, 6vw, 92px) 54px;
}
.cp-checkout-shell .wp-block-woocommerce-checkout,
.cp-checkout-shell .wc-block-checkout,
.cp-checkout-shell .woocommerce-checkout {
  width: 100%;
}
.cp-checkout-shell .wc-block-checkout,
.cp-checkout-shell form.checkout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 390px;
  gap: 28px;
  align-items: start;
}
.cp-checkout-shell .wc-block-checkout__main,
.cp-checkout-shell #customer_details,
.cp-checkout-shell .woocommerce-billing-fields,
.cp-checkout-shell .woocommerce-shipping-fields {
  min-width: 0;
}
.cp-checkout-shell .wc-block-checkout__main,
.cp-checkout-shell #customer_details {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow-soft);
  overflow: hidden;
}
.cp-checkout-shell .wc-block-components-checkout-step,
.cp-checkout-shell .woocommerce-billing-fields,
.cp-checkout-shell .woocommerce-shipping-fields,
.cp-checkout-shell .woocommerce-additional-fields {
  margin: 0 !important;
  padding: 24px !important;
  border-top: 1px solid var(--line);
}
.cp-checkout-shell .wc-block-components-checkout-step:first-child,
.cp-checkout-shell .woocommerce-billing-fields:first-child,
.cp-checkout-shell .woocommerce-shipping-fields:first-child {
  border-top: 0;
}
.cp-checkout-shell #customer_details.cp-checkout-customer-details {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 0.92fr);
  align-items: start;
}
.cp-checkout-shell #customer_details.cp-checkout-customer-details.is-billing-open {
  align-items: stretch;
}
.cp-checkout-shell #customer_details.cp-checkout-customer-details > .col-1,
.cp-checkout-shell #customer_details.cp-checkout-customer-details > .col-2 {
  float: none !important;
  width: 100% !important;
  min-width: 0;
}
.cp-checkout-shell #customer_details.cp-checkout-customer-details.is-billing-open > .col-1,
.cp-checkout-shell #customer_details.cp-checkout-customer-details.is-billing-open > .col-2 {
  display: flex;
  flex-direction: column;
}
.cp-checkout-shell #customer_details.cp-checkout-customer-details > .cp-checkout-delivery-column {
  grid-column: 1;
  grid-row: 1;
}
.cp-checkout-shell #customer_details.cp-checkout-customer-details > .cp-checkout-invoice-column {
  grid-column: 2;
  grid-row: 1;
}
.cp-checkout-shell .cp-checkout-delivery-column {
  align-self: start;
  border-right: 1px solid var(--line);
}
.cp-checkout-shell #customer_details.cp-checkout-customer-details.is-billing-open .cp-checkout-delivery-column,
.cp-checkout-shell #customer_details.cp-checkout-customer-details.is-billing-open .cp-checkout-invoice-column {
  align-self: stretch;
}
.cp-checkout-shell #customer_details.cp-checkout-customer-details.is-billing-open .cp-checkout-delivery-fields,
.cp-checkout-shell #customer_details.cp-checkout-customer-details.is-billing-open .cp-checkout-invoice-fields {
  flex: 1 1 auto;
}
.cp-checkout-shell #customer_details.cp-checkout-customer-details.is-billing-open .woocommerce-shipping-fields__field-wrapper,
.cp-checkout-shell #customer_details.cp-checkout-customer-details.is-billing-open .woocommerce-billing-fields__field-wrapper {
  height: 100%;
}
.cp-checkout-shell #customer_details.cp-checkout-customer-details.is-billing-open .cp-checkout-address-ui {
  min-height: 100%;
}
.cp-checkout-shell #customer_details.cp-checkout-customer-details.is-guest-checkout.is-billing-open {
  align-items: start;
}
.cp-checkout-shell #customer_details.cp-checkout-customer-details.is-guest-checkout.is-billing-open > .col-1,
.cp-checkout-shell #customer_details.cp-checkout-customer-details.is-guest-checkout.is-billing-open > .col-2 {
  display: block;
}
.cp-checkout-shell #customer_details.cp-checkout-customer-details.is-guest-checkout.is-billing-open .cp-checkout-delivery-fields,
.cp-checkout-shell #customer_details.cp-checkout-customer-details.is-guest-checkout.is-billing-open .cp-checkout-invoice-fields {
  flex: none;
}
.cp-checkout-shell #customer_details.cp-checkout-customer-details.is-guest-checkout.is-billing-open .woocommerce-shipping-fields__field-wrapper,
.cp-checkout-shell #customer_details.cp-checkout-customer-details.is-guest-checkout.is-billing-open .woocommerce-billing-fields__field-wrapper {
  height: auto;
  align-content: start;
}
.cp-checkout-shell .cp-checkout-invoice-column .woocommerce-billing-fields,
.cp-checkout-shell .cp-checkout-invoice-column .woocommerce-additional-fields,
.cp-checkout-shell .cp-checkout-delivery-column .woocommerce-shipping-fields {
  border-top: 0;
}
.cp-checkout-shell .cp-checkout-billing-address.is-collapsed,
.cp-checkout-shell .cp-checkout-billing-address[hidden] {
  display: none !important;
}
.cp-checkout-shell .cp-checkout-guest-billing-main {
  margin-bottom: 16px;
  height: auto !important;
  align-content: start;
}
.cp-checkout-shell .cp-checkout-billing-toggle {
  margin: 0 0 16px;
  padding: 14px 16px;
  border: 1px solid rgba(21, 53, 72, 0.13);
  border-radius: 14px;
  background:
    radial-gradient(circle at 8% 0%, rgba(255, 255, 255, 0.82), transparent 46%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.74), rgba(226, 244, 249, 0.36));
}
.cp-checkout-shell .cp-checkout-billing-toggle .woocommerce-form__label-for-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin: 0;
  color: #153548 !important;
  font-size: 13px !important;
  font-weight: 900;
  cursor: pointer;
}
.cp-checkout-shell .cp-checkout-billing-toggle input[type="checkbox"] {
  width: 16px;
  min-width: 16px;
  height: 16px;
  accent-color: #153548;
}
.cp-checkout-shell #customer_details.cp-checkout-guest-layout {
  grid-template-columns: minmax(0, 1fr) minmax(300px, 0.92fr);
  align-items: start;
}
.cp-checkout-shell #customer_details.cp-checkout-guest-layout.is-billing-open {
  align-items: stretch;
}
.cp-checkout-shell .cp-checkout-guest-heading,
.cp-checkout-shell .cp-checkout-guest-toggle-cell,
.cp-checkout-shell .cp-checkout-guest-main-fields,
.cp-checkout-shell .cp-checkout-guest-side-spacer,
.cp-checkout-shell .cp-checkout-guest-shipping-fields,
.cp-checkout-shell .cp-checkout-guest-billing-address-cell,
.cp-checkout-shell .cp-checkout-guest-account-column {
  min-width: 0;
  padding: 24px;
}
.cp-checkout-shell .cp-checkout-guest-heading {
  grid-column: 1;
  grid-row: 1;
  border-right: 1px solid var(--line);
}
.cp-checkout-shell .cp-checkout-guest-toggle-cell {
  grid-column: 2;
  grid-row: 1;
}
.cp-checkout-shell .cp-checkout-guest-main-fields {
  grid-column: 1;
  grid-row: 2;
  border-top: 1px solid var(--line);
  border-right: 1px solid var(--line);
}
.cp-checkout-shell .cp-checkout-guest-side-spacer {
  grid-column: 2;
  grid-row: 2;
  display: flex;
  align-items: center;
  border-top: 1px solid var(--line);
  background:
    radial-gradient(circle at 16% 0%, rgba(255, 255, 255, 0.76), transparent 42%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.3), rgba(226, 244, 249, 0.2));
}
.cp-checkout-shell .cp-checkout-guest-side-spacer .woocommerce-additional-fields {
  width: 100%;
  margin: 0 !important;
  padding: 0 !important;
  border-top: 0 !important;
  background: transparent !important;
}
.cp-checkout-shell .cp-checkout-guest-shipping-fields {
  grid-column: 1;
  grid-row: 2;
  border-top: 1px solid var(--line);
  border-right: 1px solid var(--line);
}
.cp-checkout-shell #customer_details.cp-checkout-guest-layout:not(.is-billing-open) .cp-checkout-guest-shipping-fields {
  grid-column: 1 / -1;
  border-right: 0;
}
.cp-checkout-shell .cp-checkout-guest-billing-address-cell {
  grid-column: 2;
  grid-row: 2;
  border-top: 1px solid var(--line);
}
.cp-checkout-shell .cp-checkout-guest-account-column {
  grid-column: 1 / -1;
  grid-row: 3;
  display: grid;
  gap: 18px;
  border-top: 1px solid var(--line);
}
.cp-checkout-shell .cp-checkout-guest-side-spacer {
  grid-column: 1 / -1;
  grid-row: 4;
  display: block;
  align-items: initial;
}
.cp-checkout-shell .cp-checkout-guest-heading h3 {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 !important;
  color: var(--ink);
  font-size: 20px;
  font-weight: 800;
  line-height: 1.15;
}
.cp-checkout-shell .cp-checkout-guest-layout .cp-checkout-billing-toggle {
  margin: 0;
}
.cp-checkout-shell .cp-checkout-guest-layout .woocommerce-account-fields,
.cp-checkout-shell .cp-checkout-guest-layout .cp-checkout-order-notes {
  min-width: 0;
}
.cp-checkout-shell .cp-checkout-guest-layout .woocommerce-account-fields .create-account:not(.form-row),
.cp-checkout-shell .cp-checkout-guest-layout .woocommerce-additional-fields__field-wrapper {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 16px;
}
.cp-checkout-shell .cp-checkout-guest-side-spacer .woocommerce-additional-fields__field-wrapper {
  grid-template-columns: 1fr;
}
.cp-checkout-shell .cp-checkout-guest-side-spacer #order_comments_field {
  grid-column: 1 / -1;
}
.cp-checkout-shell .cp-checkout-guest-side-spacer #order_comments_field textarea {
  min-height: 136px !important;
}
.cp-checkout-shell #customer_details.cp-checkout-guest-layout.is-billing-open
  #cp_checkout_billing_address
  .form-row:has([data-cp-required-when-open="1"])
  .optional {
  display: none;
}
.cp-checkout-shell #customer_details.cp-checkout-guest-layout.is-billing-open
  #cp_checkout_billing_address
  .form-row:has([data-cp-required-when-open="1"])
  label:not(.screen-reader-text)::after {
  content: " *";
  color: #b42318;
}
@media (min-width: 821px) {
  .cp-checkout-shell #customer_details.cp-checkout-guest-layout.is-billing-open
    :is(.cp-checkout-guest-shipping-fields, .cp-checkout-guest-billing-address-cell)
    :is(#shipping_country_field, #billing_country_field, #shipping_state_field, #billing_state_field) {
    min-height: 78px;
  }
}
.cp-checkout-shell .wc-block-components-checkout-step__heading,
.cp-checkout-shell .woocommerce-billing-fields h3,
.cp-checkout-shell .woocommerce-shipping-fields h3,
.cp-checkout-shell .cp-checkout-guest-shipping-fields h3,
.cp-checkout-shell .cp-checkout-guest-billing-address-cell h3,
.cp-checkout-shell .woocommerce-additional-fields h3,
.cp-checkout-shell #order_review_heading {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 18px !important;
  color: var(--ink);
  font-size: 20px;
  font-weight: 800;
}
.cp-checkout-shell .wc-block-components-checkout-step__container,
.cp-checkout-shell .woocommerce-billing-fields__field-wrapper,
.cp-checkout-shell .woocommerce-shipping-fields__field-wrapper {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 16px;
}
.cp-checkout-address-ui {
  display: none;
}
@media (min-width: 821px) {
  .cp-checkout-shell .woocommerce-shipping-fields__field-wrapper:not(.cp-checkout-address-fields):has(> .cp-saved-address-field),
  .cp-checkout-shell .woocommerce-billing-fields__field-wrapper:not(.cp-checkout-address-fields):has(> .cp-saved-address-field) {
    min-height: 188px;
  }

  .cp-checkout-shell .woocommerce-shipping-fields__field-wrapper:not(.cp-checkout-address-fields):has(> .cp-saved-address-field)::before,
  .cp-checkout-shell .woocommerce-billing-fields__field-wrapper:not(.cp-checkout-address-fields):has(> .cp-saved-address-field)::before {
    grid-column: 1 / -1;
    min-height: 178px;
    border: 1px solid rgba(21, 53, 72, 0.12);
    border-radius: 18px;
    background:
      radial-gradient(circle at 8% 0%, rgba(255, 255, 255, 0.82), transparent 44%),
      linear-gradient(145deg, rgba(255, 255, 255, 0.66), rgba(226, 244, 249, 0.34));
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.82),
      0 10px 22px rgba(21, 53, 72, 0.055);
    content: "";
  }

  .cp-checkout-shell .woocommerce-shipping-fields__field-wrapper:not(.cp-checkout-address-fields):has(> .cp-saved-address-field) > .form-row,
  .cp-checkout-shell .woocommerce-billing-fields__field-wrapper:not(.cp-checkout-address-fields):has(> .cp-saved-address-field) > .form-row {
    display: none !important;
  }

  .cp-checkout-shell .cp-checkout-address-ui {
    display: grid;
    grid-column: 1 / -1;
    gap: 12px;
    align-content: start;
    padding: 16px;
    border: 1px solid rgba(21, 53, 72, 0.13);
    border-radius: 18px;
    background:
      radial-gradient(circle at 8% 0%, rgba(255, 255, 255, 0.82), transparent 44%),
      linear-gradient(145deg, rgba(255, 255, 255, 0.68), rgba(226, 244, 249, 0.36));
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.84),
      0 12px 26px rgba(21, 53, 72, 0.07);
  }

  .cp-checkout-shell .cp-checkout-address-ui-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
  }

  .cp-checkout-shell .cp-checkout-address-ui h4 {
    margin: 0;
    color: #153548;
    font-size: 17px;
    font-weight: 950;
    line-height: 1.15;
  }

  .cp-checkout-shell .cp-checkout-address-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
  }

  .cp-checkout-shell .cp-checkout-address-actions button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 12px;
    border: 1px solid rgba(21, 53, 72, 0.18);
    border-radius: 999px;
    color: #153548;
    background: rgba(255, 255, 255, 0.58);
    font-size: 12px;
    font-weight: 900;
    cursor: pointer;
  }

  .cp-checkout-shell .cp-checkout-address-add {
    color: #fff !important;
    background: #153548 !important;
  }

  .cp-checkout-shell .cp-checkout-address-summary {
    display: none;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    width: 100%;
    min-width: 0;
    padding: 14px 16px;
    border: 1px solid rgba(21, 53, 72, 0.13);
    border-radius: 14px;
    color: #153548;
    background:
      linear-gradient(145deg, rgba(255, 255, 255, 0.76), rgba(237, 249, 252, 0.46));
    text-align: left;
    cursor: pointer;
  }

  .cp-checkout-shell .cp-checkout-address-summary-text {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 6px 10px;
    align-items: center;
    min-width: 0;
  }

  .cp-checkout-shell .cp-checkout-address-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 24px;
    padding: 0 9px;
    border-radius: 999px;
    color: #fff;
    background: #153548;
    font-size: 12px;
    font-weight: 900;
    line-height: 1;
  }

  .cp-checkout-shell .cp-checkout-address-summary strong {
    min-width: 0;
    overflow-wrap: anywhere;
    color: #102f40;
    font-size: 15px;
    font-weight: 950;
  }

  .cp-checkout-shell .cp-checkout-address-summary-lines {
    display: grid;
    grid-column: 1 / -1;
    gap: 3px;
    color: rgba(21, 53, 72, 0.76);
    font-size: 13px;
    font-weight: 750;
    line-height: 1.35;
  }

  .cp-checkout-shell .cp-checkout-address-summary-lines span {
    overflow-wrap: anywhere;
  }

  .cp-checkout-shell .cp-checkout-address-chevron {
    display: grid;
    place-items: center;
    width: 30px;
    height: 30px;
    border-radius: 999px;
    color: #153548;
    background: rgba(255, 255, 255, 0.62);
    font-size: 24px;
    font-weight: 500;
    line-height: 1;
  }

  .cp-checkout-shell .cp-checkout-address-list {
    display: grid;
    align-content: start;
    gap: 8px;
  }

  .cp-checkout-shell .cp-checkout-address-ui.is-list-open .cp-checkout-address-list {
    display: grid;
  }

  .cp-checkout-shell .cp-checkout-address-option {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    width: 100%;
    padding: 12px 14px;
    border: 1px solid rgba(21, 53, 72, 0.12);
    border-radius: 14px;
    color: #153548;
    background: rgba(255, 255, 255, 0.56);
    text-align: left;
  }

  .cp-checkout-shell .cp-checkout-address-select {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    width: 100%;
    min-width: 0;
    padding: 0;
    border: 0;
    color: inherit;
    background: transparent;
    text-align: left;
    font: inherit;
    cursor: pointer;
  }

  .cp-checkout-shell .cp-checkout-address-option.is-active {
    border-color: rgba(21, 53, 72, 0.54);
    background:
      linear-gradient(145deg, rgba(21, 53, 72, 0.14), rgba(21, 53, 72, 0.055)),
      rgba(255, 255, 255, 0.82);
    box-shadow:
      inset 0 0 0 1px rgba(21, 53, 72, 0.13),
      0 0 0 2px rgba(21, 53, 72, 0.08),
      0 8px 18px rgba(21, 53, 72, 0.08);
  }

  .cp-checkout-shell .cp-checkout-address-option-text,
  .cp-checkout-shell .cp-checkout-address-option-lines,
  .cp-checkout-shell .cp-checkout-address-option-contact {
    display: grid;
    gap: 3px;
    min-width: 0;
  }

  .cp-checkout-shell .cp-checkout-address-option strong {
    min-width: 0;
    overflow-wrap: anywhere;
    font-size: 14px;
    font-weight: 950;
  }

  .cp-checkout-shell .cp-checkout-address-option-lines {
    color: rgba(21, 53, 72, 0.72);
    font-size: 12px;
    font-weight: 750;
    line-height: 1.35;
  }

  .cp-checkout-shell .cp-checkout-address-option-contact {
    margin-top: 4px;
    padding-top: 7px;
    border-top: 1px solid rgba(21, 53, 72, 0.1);
    color: rgba(21, 53, 72, 0.8);
    font-size: 12px;
    font-weight: 850;
    line-height: 1.35;
  }

  .cp-checkout-shell .cp-checkout-address-option-contact span {
    overflow-wrap: anywhere;
  }

  .cp-checkout-shell .cp-checkout-address-option-meta {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 0 9px;
    border-radius: 999px;
    color: #153548;
    background: rgba(21, 53, 72, 0.08);
    font-size: 11px;
    font-weight: 900;
    white-space: nowrap;
  }

  .cp-checkout-shell .cp-checkout-address-edit {
    display: inline-grid;
    width: 34px;
    height: 34px;
    place-items: center;
    border: 1px solid rgba(21, 53, 72, 0.14);
    border-radius: 999px;
    color: #153548;
    background: rgba(255, 255, 255, 0.64);
    transition: background 180ms ease, box-shadow 180ms ease, transform 180ms ease;
  }

  .cp-checkout-shell .cp-checkout-address-edit:hover,
  .cp-checkout-shell .cp-checkout-address-edit:focus-visible {
    background: #153548;
    color: #fff;
    box-shadow: 0 10px 18px rgba(21, 53, 72, 0.16);
    transform: translateY(-1px);
  }

  .cp-checkout-shell .cp-checkout-address-edit svg {
    width: 16px;
    height: 16px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  .cp-checkout-shell .cp-checkout-native-address-select {
    display: none !important;
  }

  .cp-checkout-shell .cp-checkout-address-fields.is-collapsed > .form-row:not(#billing_email_field):not(.cp-checkout-native-address-select) {
    display: none !important;
  }

  .cp-checkout-shell .cp-checkout-address-fields.is-collapsed > #billing_email_field {
    grid-column: 1 / -1;
  }
}
@media (max-width: 820px) {
  .cp-checkout-shell .cp-checkout-address-ui {
    display: grid;
    grid-column: 1 / -1;
    gap: 10px;
    align-content: start;
    padding: 14px;
    border: 1px solid rgba(21, 53, 72, 0.13);
    border-radius: 16px;
    background:
      radial-gradient(circle at 8% 0%, rgba(255, 255, 255, 0.82), transparent 44%),
      linear-gradient(145deg, rgba(255, 255, 255, 0.7), rgba(226, 244, 249, 0.4));
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.84),
      0 10px 22px rgba(21, 53, 72, 0.06);
  }

  .cp-checkout-shell .cp-checkout-address-ui-head {
    display: grid;
    gap: 10px;
  }

  .cp-checkout-shell .cp-checkout-address-ui h4 {
    margin: 0;
    color: #153548;
    font-size: 16px;
    font-weight: 950;
    line-height: 1.15;
  }

  .cp-checkout-shell .cp-checkout-address-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }

  .cp-checkout-shell .cp-checkout-address-actions button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 12px;
    border: 1px solid rgba(21, 53, 72, 0.18);
    border-radius: 999px;
    color: #153548;
    background: rgba(255, 255, 255, 0.58);
    font-size: 12px;
    font-weight: 900;
    cursor: pointer;
  }

  .cp-checkout-shell .cp-checkout-address-add {
    color: #fff !important;
    background: #153548 !important;
  }

  .cp-checkout-shell .cp-checkout-address-summary {
    display: none;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    width: 100%;
    min-width: 0;
    padding: 13px 14px;
    border: 1px solid rgba(21, 53, 72, 0.13);
    border-radius: 14px;
    color: #153548;
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.76), rgba(237, 249, 252, 0.46));
    text-align: left;
    cursor: pointer;
  }

  .cp-checkout-shell .cp-checkout-address-summary-text {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 6px 10px;
    align-items: center;
    min-width: 0;
  }

  .cp-checkout-shell .cp-checkout-address-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 24px;
    padding: 0 9px;
    border-radius: 999px;
    color: #fff;
    background: #153548;
    font-size: 12px;
    font-weight: 900;
    line-height: 1;
  }

  .cp-checkout-shell .cp-checkout-address-summary strong {
    min-width: 0;
    overflow-wrap: anywhere;
    color: #102f40;
    font-size: 14px;
    font-weight: 950;
  }

  .cp-checkout-shell .cp-checkout-address-summary-lines {
    display: grid;
    grid-column: 1 / -1;
    gap: 3px;
    color: rgba(21, 53, 72, 0.76);
    font-size: 12px;
    font-weight: 750;
    line-height: 1.35;
  }

  .cp-checkout-shell .cp-checkout-address-summary-lines span {
    overflow-wrap: anywhere;
  }

  .cp-checkout-shell .cp-checkout-address-chevron {
    display: none;
    place-items: center;
    width: 30px;
    height: 30px;
    border-radius: 999px;
    color: #153548;
    background: rgba(255, 255, 255, 0.62);
    font-size: 24px;
    font-weight: 500;
    line-height: 1;
  }

  .cp-checkout-shell .cp-checkout-address-list {
    display: grid;
    align-content: start;
    gap: 8px;
  }

  .cp-checkout-shell .cp-checkout-address-ui.is-list-open .cp-checkout-address-list {
    display: grid;
  }

  .cp-checkout-shell .cp-checkout-address-option {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: start;
    width: 100%;
    padding: 12px 14px;
    border: 1px solid rgba(21, 53, 72, 0.12);
    border-radius: 14px;
    color: #153548;
    background: rgba(255, 255, 255, 0.56);
    text-align: left;
  }

  .cp-checkout-shell .cp-checkout-address-select {
    display: grid;
    gap: 8px;
    width: 100%;
    min-width: 0;
    padding: 0;
    border: 0;
    color: inherit;
    background: transparent;
    text-align: left;
    font: inherit;
    cursor: pointer;
  }

  .cp-checkout-shell .cp-checkout-address-option.is-active {
    border-color: rgba(21, 53, 72, 0.54);
    background:
      linear-gradient(145deg, rgba(21, 53, 72, 0.14), rgba(21, 53, 72, 0.055)),
      rgba(255, 255, 255, 0.82);
    box-shadow:
      inset 0 0 0 1px rgba(21, 53, 72, 0.13),
      0 0 0 2px rgba(21, 53, 72, 0.08),
      0 8px 18px rgba(21, 53, 72, 0.08);
  }

  .cp-checkout-shell .cp-checkout-address-option-text,
  .cp-checkout-shell .cp-checkout-address-option-lines,
  .cp-checkout-shell .cp-checkout-address-option-contact {
    display: grid;
    gap: 3px;
    min-width: 0;
  }

  .cp-checkout-shell .cp-checkout-address-option strong {
    min-width: 0;
    overflow-wrap: anywhere;
    font-size: 14px;
    font-weight: 950;
  }

  .cp-checkout-shell .cp-checkout-address-option-lines {
    color: rgba(21, 53, 72, 0.72);
    font-size: 12px;
    font-weight: 750;
    line-height: 1.35;
  }

  .cp-checkout-shell .cp-checkout-address-option-contact {
    margin-top: 4px;
    padding-top: 7px;
    border-top: 1px solid rgba(21, 53, 72, 0.1);
    color: rgba(21, 53, 72, 0.8);
    font-size: 12px;
    font-weight: 850;
    line-height: 1.35;
  }

  .cp-checkout-shell .cp-checkout-address-option-contact span {
    overflow-wrap: anywhere;
  }

  .cp-checkout-shell .cp-checkout-address-option-meta {
    justify-self: start;
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 0 9px;
    border-radius: 999px;
    color: #153548;
    background: rgba(21, 53, 72, 0.08);
    font-size: 11px;
    font-weight: 900;
    white-space: nowrap;
  }

  .cp-checkout-shell .cp-checkout-address-edit {
    display: inline-grid;
    width: 34px;
    height: 34px;
    place-items: center;
    border: 1px solid rgba(21, 53, 72, 0.14);
    border-radius: 999px;
    color: #153548;
    background: rgba(255, 255, 255, 0.64);
  }

  .cp-checkout-shell .cp-checkout-address-edit svg {
    width: 16px;
    height: 16px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  .cp-checkout-shell .cp-checkout-native-address-select {
    display: none !important;
  }

  .cp-checkout-shell .cp-checkout-address-fields.is-collapsed > .form-row:not(#billing_email_field):not(.cp-checkout-native-address-select) {
    display: none !important;
  }

  .cp-checkout-shell .cp-checkout-address-fields.is-collapsed > #billing_email_field {
    grid-column: 1 / -1;
  }
}
.cp-checkout-shell .wc-block-components-checkout-step__content,
.cp-checkout-shell .form-row-wide,
.cp-checkout-shell #billing_address_1_field,
.cp-checkout-shell #shipping_address_1_field,
.cp-checkout-shell #billing_country_field,
.cp-checkout-shell #shipping_country_field,
.cp-checkout-shell #billing_email_field,
.cp-checkout-shell #order_comments_field {
  grid-column: 1 / -1;
}
.cp-checkout-shell .wc-block-components-text-input,
.cp-checkout-shell .wc-block-components-combobox,
.cp-checkout-shell .form-row {
  margin: 0 !important;
}
.cp-checkout-shell .form-row-first,
.cp-checkout-shell .form-row-last {
  float: none !important;
  width: auto !important;
}
.cp-checkout-shell .wc-block-components-text-input input,
.cp-checkout-shell .wc-block-components-combobox .wc-block-components-combobox-control input,
.cp-checkout-shell input.input-text,
.cp-checkout-shell select,
.cp-checkout-shell textarea {
  width: 100% !important;
  min-height: 48px !important;
  box-sizing: border-box;
  border: 1px solid #cfdad7 !important;
  border-radius: 7px !important;
  color: var(--ink);
  background: #fff !important;
  box-shadow: none !important;
  font-size: 14px;
}
.cp-checkout-shell textarea {
  min-height: 96px !important;
  padding: 12px 14px !important;
}
.cp-checkout-shell label,
.cp-checkout-shell .wc-block-components-text-input label,
.cp-checkout-shell .wc-block-components-combobox label {
  color: #40545b !important;
  font-size: 12px !important;
  font-weight: 700;
}
.cp-customer-type-field .optional,
.cp-address-email-field .optional,
.cp-individual-field .optional,
.cp-corporate-field .optional {
  display: none !important;
}
.cp-corporate-field.cp-is-required label:not(.screen-reader-text)::after,
.cp-corporate-field:has(:required) label:not(.screen-reader-text)::after {
  content: " *";
  color: #b42318;
}
.form-row.cp-required-highlight input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
.form-row.cp-required-highlight select,
.form-row.cp-required-highlight textarea,
.woocommerce-form-row.cp-required-highlight input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
.woocommerce-form-row.cp-required-highlight select,
.woocommerce-form-row.cp-required-highlight textarea {
  border-color: rgba(180, 35, 24, 0.72) !important;
  background:
    linear-gradient(0deg, rgba(180, 35, 24, 0.035), rgba(180, 35, 24, 0.035)),
    rgba(255, 255, 255, 0.94) !important;
  box-shadow:
    0 0 0 3px rgba(180, 35, 24, 0.1),
    0 12px 24px rgba(180, 35, 24, 0.08) !important;
}
.form-row.cp-required-highlight .select2-container .select2-selection,
.woocommerce-form-row.cp-required-highlight .select2-container .select2-selection {
  border-color: rgba(180, 35, 24, 0.72) !important;
  box-shadow:
    0 0 0 3px rgba(180, 35, 24, 0.1),
    0 12px 24px rgba(180, 35, 24, 0.08) !important;
}
.checkout-inline-error-message {
  display: none !important;
}
.form-row.cp-required-highlight input:focus,
.form-row.cp-required-highlight select:focus,
.form-row.cp-required-highlight textarea:focus,
.woocommerce-form-row.cp-required-highlight input:focus,
.woocommerce-form-row.cp-required-highlight select:focus,
.woocommerce-form-row.cp-required-highlight textarea:focus {
  border-color: rgba(180, 35, 24, 0.82) !important;
  box-shadow:
    0 0 0 4px rgba(180, 35, 24, 0.14),
    0 14px 28px rgba(180, 35, 24, 0.1) !important;
}
.cp-checkout-shell .select2-hidden-accessible {
  width: 1px !important;
  min-width: 1px !important;
  max-width: 1px !important;
  height: 1px !important;
  left: 0 !important;
  right: auto !important;
  margin: -1px !important;
  overflow: hidden !important;
}
.cp-checkout-shell .select2-container {
  max-width: 100% !important;
}
.cp-checkout-shell .wc-block-components-checkbox,
.cp-checkout-shell .woocommerce-form__label-for-checkbox {
  margin-top: 12px;
  color: #30474e;
  font-size: 13px;
  font-weight: 700;
}
.cp-checkout-shell .wc-block-checkout__sidebar,
.cp-checkout-shell #order_review {
  position: sticky;
  top: 96px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow-soft);
  overflow: hidden;
}
.cp-checkout-shell .wc-block-components-sidebar-layout {
  display: contents;
}
.cp-checkout-shell .wc-block-components-main {
  width: auto;
  padding-right: 0;
}
.cp-checkout-shell .wc-block-components-sidebar {
  width: auto;
  padding-left: 0;
}
.cp-checkout-shell .wp-block-woocommerce-checkout-order-summary-block,
.cp-checkout-shell #order_review {
  padding: 22px;
}
.cp-checkout-shell .wc-block-components-order-summary,
.cp-checkout-shell .shop_table.woocommerce-checkout-review-order-table {
  border: 0 !important;
}
.cp-checkout-shell .wc-block-components-order-summary__button-text,
.cp-checkout-shell .wc-block-components-title,
.cp-checkout-shell #order_review_heading {
  color: var(--ink);
  font-size: 22px;
  font-weight: 800;
}
.cp-checkout-shell #order_review > #order_review_heading {
  justify-content: center;
  margin: 0 0 18px;
  padding: 2px 0 0;
  text-align: center;
}
.cp-checkout-shell .wc-block-components-order-summary-item {
  align-items: center;
  padding: 16px 0 !important;
  border-top: 1px solid var(--line);
}
.cp-checkout-shell .wc-block-components-order-summary-item:first-child {
  border-top: 0;
}
.cp-checkout-shell .wc-block-components-order-summary-item__image img,
.cp-checkout-shell .shop_table img {
  width: 68px !important;
  height: 68px !important;
  object-fit: contain;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: var(--surface-cool);
  padding: 6px;
}
.cp-checkout-shell .wc-block-components-order-summary-item__description,
.cp-checkout-shell .product-name {
  color: var(--ink);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.35;
}
.cp-checkout-shell .wc-block-components-order-summary-item__quantity {
  color: #fff;
  background: var(--green-2);
}
.cp-checkout-shell .wc-block-components-totals-wrapper,
.cp-checkout-shell .shop_table tr {
  border-top: 1px solid var(--line);
}
.cp-checkout-shell .wc-block-components-totals-item,
.cp-checkout-shell .shop_table th,
.cp-checkout-shell .shop_table td {
  padding: 14px 0 !important;
  color: #2a4148;
  font-size: 14px;
}
.cp-checkout-shell .wc-block-components-totals-footer-item,
.cp-checkout-shell .order-total {
  font-size: 18px;
  font-weight: 800;
}
.cp-checkout-shell .wc-block-components-totals-footer-item .wc-block-components-totals-item__value,
.cp-checkout-shell .order-total .amount {
  color: var(--green-2);
  font-size: 24px;
  font-weight: 800;
}
.cp-checkout-shell .wc-block-components-radio-control__option,
.cp-checkout-shell .woocommerce-checkout-payment li,
.cp-checkout-shell .wc-block-checkout__shipping-option {
  border: 1px solid var(--line) !important;
  border-radius: 7px !important;
  margin-bottom: 10px !important;
  padding: 14px !important;
  background: #fff;
}
.cp-checkout-shell .wc-block-components-radio-control__option-checked,
.cp-checkout-shell .wc-block-checkout__shipping-option--selected {
  border-color: var(--green) !important;
  background: #f5faf3 !important;
}
.cp-checkout-shell .wc-block-components-notice-banner,
.cp-checkout-shell .woocommerce-error,
.cp-checkout-shell .woocommerce-info,
.cp-checkout-shell .woocommerce-message {
  border-radius: clamp(18px, 1.6vw, 24px) !important;
  font-size: 13px;
}
.cp-checkout-shell .woocommerce-form-login-toggle {
  margin: clamp(14px, 1.5vw, 22px) 0 clamp(20px, 2.2vw, 30px);
}
.cp-checkout-shell .woocommerce-form-login-toggle .woocommerce-info {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  min-height: 64px;
  margin: 0 !important;
  border: 1px solid rgba(255, 255, 255, 0.68) !important;
  border-left: 4px solid #153548 !important;
  border-radius: clamp(18px, 1.7vw, 26px) !important;
  padding: 16px clamp(18px, 2vw, 24px) !important;
  color: var(--cp-flow-ink, #153548);
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 255, 255, 0.74), transparent 38%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.7), rgba(226, 244, 249, 0.36)) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.74),
    0 12px 28px rgba(21, 53, 72, 0.07) !important;
}
.cp-checkout-shell .woocommerce-form-login-toggle .woocommerce-info::before {
  content: "i";
  display: grid;
  width: 32px;
  height: 32px;
  place-items: center;
  border: 1px solid rgba(21, 53, 72, 0.12);
  border-radius: 50%;
  color: var(--cp-flow-ink, #153548);
  background: rgba(255, 255, 255, 0.66);
  font-size: 13px;
  font-weight: 900;
}
.cp-checkout-shell .woocommerce-form-login-toggle .woocommerce-info a {
  color: var(--cp-flow-ink, #153548);
  font-weight: 950;
  text-decoration: none;
}
.cp-checkout-shell .woocommerce-form-login-toggle .woocommerce-info a:hover {
  text-decoration: underline;
}
.cp-checkout-shell .wc-block-components-checkout-place-order-button,
.cp-checkout-shell #place_order {
  width: 100%;
  min-height: 52px;
  border: 0 !important;
  border-radius: 7px !important;
  color: #fff !important;
  background: #153548 !important;
  box-shadow: 0 12px 22px rgba(11, 70, 80, 0.18);
  font-weight: 800 !important;
}
.cp-checkout-shell .wc-block-components-checkout-place-order-button:hover,
.cp-checkout-shell #place_order:hover {
  background: #153548 !important;
}
.cp-checkout-shell .wc-block-checkout__actions,
.cp-checkout-shell .place-order {
  padding-top: 20px;
  border-top: 1px solid var(--line);
}
.cp-checkout-legal {
  display: grid;
  gap: 12px;
  margin: 18px 0 4px;
  padding: 18px;
  border: 1px solid rgba(8, 49, 61, 0.18);
  border-radius: 7px;
  background: linear-gradient(135deg, #f8fbfa, #f1f7ef);
}
.cp-checkout-legal h3 {
  margin: 0;
  color: var(--ink);
  font-size: 16px;
  line-height: 1.3;
}
.cp-checkout-legal-note {
  margin: 0;
  color: #52666d;
  font-size: 12px;
  line-height: 1.6;
}
.cp-checkout-legal a {
  color: #08313d;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.cp-checkout-legal-check {
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  color: #213940;
  font-size: 13px;
  font-weight: 500;
  line-height: 1.55;
}
.cp-checkout-legal-check input {
  width: 18px !important;
  height: 18px !important;
  margin: 2px 0 0 !important;
  accent-color: #2f6725;
}
.cp-account-shell {
  max-width: var(--max);
  padding: 42px clamp(20px, 6vw, 92px) 54px;
}
.cp-account-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  gap: 28px;
  align-items: end;
  margin-bottom: 28px;
}
.cp-account-head h1 {
  margin: 0;
  font-size: clamp(40px, 4.4vw, 58px);
  line-height: 1;
  letter-spacing: 0;
}
.cp-account-head p {
  max-width: 640px;
  margin: 14px 0 0;
  color: var(--muted);
  font-size: 17px;
  line-height: 1.6;
}
.cp-account-content {
  max-width: none;
}
.cp-account-shell .woocommerce {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 28px;
  align-items: start;
  width: 100%;
  color: var(--ink);
}
.cp-account-shell .woocommerce::before,
.cp-account-shell .woocommerce::after {
  display: none;
}
.cp-account-shell .woocommerce > h1,
.cp-account-shell .entry-title,
.cp-account-shell .wp-block-post-title,
.cp-account-shell > h1:not(#cp-account-title),
.cp-account-content > h1,
.cp-account-content .entry-title {
  display: none;
}
.cp-account-shell .woocommerce-notices-wrapper,
.cp-account-shell .woocommerce-message,
.cp-account-shell .woocommerce-info,
.cp-account-shell .woocommerce-error {
  grid-column: 1 / -1;
}
body.woocommerce-account:not(.logged-in) .cp-account-shell .woocommerce:has(.cp-login-layout) > .woocommerce-notices-wrapper,
body.woocommerce-account:not(.logged-in) .cp-account-shell .woocommerce:has(.cp-login-layout) > :is(.cp-wc-notice, .woocommerce-message, .woocommerce-info, .woocommerce-error) {
  grid-column: 1 / -1;
  width: min(100%, 980px);
  max-width: 980px;
  margin-right: auto;
  margin-left: auto;
  justify-self: center;
}
body.woocommerce-account:not(.logged-in) .cp-account-shell .woocommerce:has(.cp-login-layout) > .woocommerce-notices-wrapper > :is(.cp-wc-notice, .woocommerce-message, .woocommerce-info, .woocommerce-error) {
  grid-column: 1 / -1;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}
.cp-account-shell .woocommerce-message,
.cp-account-shell .woocommerce-info,
.cp-account-shell .woocommerce-error,
.cp-account-shell .woocommerce-noreviews,
.cp-account-shell p.no-comments {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  min-height: 72px;
  margin: 0 0 22px;
  padding: 18px 22px;
  border: 1px solid #d9e6d6;
  border-left: 5px solid var(--green-2);
  border-radius: var(--radius);
  color: #253b42;
  background: #f7fbf6;
  box-shadow: var(--shadow-soft);
}
.cp-account-shell .woocommerce-error {
  align-items: flex-start;
  border-color: #f0d0d0;
  border-left-color: var(--danger);
  background: #fff8f8;
  list-style-position: inside;
}
.cp-account-shell .woocommerce-message::before,
.cp-account-shell .woocommerce-info::before {
  color: var(--green-2);
}
.cp-account-shell .woocommerce-message .button,
.cp-account-shell .woocommerce-info .button,
.cp-account-shell .woocommerce-error .button {
  order: 2;
  float: none !important;
  min-height: 48px;
  padding: 0 22px;
  border: 0 !important;
  border-radius: 7px !important;
  color: #fff !important;
  background: #153548 !important;
  box-shadow: 0 12px 22px rgba(11, 70, 80, 0.18);
  font-size: 14px;
  font-weight: 700 !important;
  text-decoration: none !important;
}
.cp-account-shell .woocommerce-MyAccount-navigation {
  position: sticky;
  top: 96px;
  float: none;
  width: auto;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow-soft);
}
.cp-account-shell .woocommerce-MyAccount-navigation ul {
  display: grid;
  gap: 6px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.cp-account-shell .woocommerce-MyAccount-navigation-link a {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 46px;
  padding: 0 14px 0 42px;
  border: 1px solid transparent;
  border-radius: 7px;
  color: #31484f;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  transition: background 180ms ease, color 180ms ease, border-color 180ms ease;
}
.cp-account-shell .woocommerce-MyAccount-navigation-link a::before {
  position: absolute;
  left: 14px;
  width: 14px;
  height: 14px;
  border: 2px solid currentColor;
  border-radius: 4px;
  content: "";
  opacity: 0.72;
}
.cp-account-shell .woocommerce-MyAccount-navigation-link a:hover,
.cp-account-shell .woocommerce-MyAccount-navigation-link.is-active a {
  border-color: #d7e6d4;
  color: var(--green-2);
  background: #f2f8f0;
}
.cp-account-shell .woocommerce-MyAccount-navigation-link.is-active a::before {
  background: currentColor;
  box-shadow: inset 0 0 0 3px #f2f8f0;
  opacity: 1;
}
.cp-account-shell .woocommerce-MyAccount-content {
  float: none;
  width: auto;
  min-width: 0;
  padding: clamp(22px, 3vw, 34px);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow-soft);
}
.cp-account-shell .woocommerce-MyAccount-content p {
  max-width: 760px;
  margin: 0 0 16px;
  color: #2a4148;
  font-size: 15px;
  line-height: 1.7;
}
.cp-account-shell .woocommerce-MyAccount-content p:last-child {
  margin-bottom: 0;
}
.cp-account-shell .woocommerce-MyAccount-content a {
  color: var(--green-2);
  font-weight: 700;
  text-decoration: none;
}
.cp-account-shell .woocommerce-MyAccount-content a:hover {
  color: #285a20;
}
.cp-account-shell .woocommerce-MyAccount-content h2,
.cp-account-shell .woocommerce-MyAccount-content h3,
.cp-account-shell .woocommerce-Address-title h3,
.cp-account-shell .woocommerce-column__title {
  margin: 0 0 18px;
  color: var(--ink);
  font-size: clamp(22px, 2.4vw, 30px);
  line-height: 1.15;
}
.cp-account-shell .woocommerce-MyAccount-content mark {
  padding: 3px 7px;
  border-radius: 6px;
  color: var(--green-2);
  background: #e8f2e5;
  font-weight: 700;
}
.cp-account-shell .woocommerce-Addresses,
.cp-account-shell .woocommerce-customer-details .addresses {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.cp-account-shell .woocommerce-Address,
.cp-account-shell .woocommerce-column--billing-address,
.cp-account-shell .woocommerce-column--shipping-address {
  padding: 20px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-cool);
}
.cp-account-shell address {
  color: #2a4148;
  font-style: normal;
  line-height: 1.7;
}
.cp-account-shell .woocommerce-Address-title {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}
.cp-account-shell .woocommerce-Address-title .edit {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 7px;
  color: #fff !important;
  background: #153548;
  font-size: 13px;
  font-weight: 700;
}
.cp-account-shell table.shop_table,
.cp-account-shell .woocommerce-orders-table {
  width: 100%;
  border: 1px solid var(--line) !important;
  border-collapse: separate;
  border-spacing: 0;
  border-radius: var(--radius);
  background: #fff;
  overflow: hidden;
}
.cp-account-shell table.shop_table th,
.cp-account-shell table.shop_table td,
.cp-account-shell .woocommerce-orders-table th,
.cp-account-shell .woocommerce-orders-table td {
  padding: 16px 18px !important;
  border: 0 !important;
  border-bottom: 1px solid var(--line) !important;
  color: #2a4148;
  font-size: 14px;
  vertical-align: middle;
}
.cp-account-shell table.shop_table tr:last-child td,
.cp-account-shell .woocommerce-orders-table tr:last-child td {
  border-bottom: 0 !important;
}
.cp-account-shell table.shop_table th,
.cp-account-shell .woocommerce-orders-table th {
  color: #253b42;
  background: var(--surface-cool);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}
.cp-account-shell .woocommerce-button,
.cp-account-shell .button,
.cp-account-shell button.button,
.cp-account-shell input.button,
.cp-account-shell .woocommerce-Button {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 18px !important;
  border: 0 !important;
  border-radius: 7px !important;
  color: #fff !important;
  background: #153548 !important;
  box-shadow: 0 12px 22px rgba(11, 70, 80, 0.18);
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  text-decoration: none !important;
}
.cp-account-shell .woocommerce-button:hover,
.cp-account-shell .button:hover,
.cp-account-shell button.button:hover,
.cp-account-shell input.button:hover,
.cp-account-shell .woocommerce-Button:hover {
  background: #153548 !important;
}
.cp-account-shell form.login,
.cp-account-shell form.register,
.cp-account-shell .woocommerce-form-login,
.cp-account-shell .woocommerce-form-register,
.cp-account-shell .woocommerce-EditAccountForm,
.cp-account-shell form.woocommerce-address-fields {
  padding: clamp(22px, 3vw, 30px);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow-soft);
}
.cp-account-shell .u-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}
.cp-account-shell .u-column1,
.cp-account-shell .u-column2 {
  float: none;
  width: auto;
}
.cp-account-shell .form-row {
  margin: 0 0 16px;
}
.cp-account-shell label {
  display: block;
  margin-bottom: 7px;
  color: #253b42;
  font-size: 13px;
  font-weight: 700;
}
.cp-account-shell input.input-text,
.cp-account-shell input[type="text"],
.cp-account-shell input[type="email"],
.cp-account-shell input[type="password"],
.cp-account-shell input[type="tel"],
.cp-account-shell select,
.cp-account-shell textarea {
  width: 100%;
  min-height: 48px;
  padding: 0 14px;
  border: 1px solid #d7e1de;
  border-radius: 7px;
  color: var(--ink);
  background: #fff;
  font: inherit;
  transition: border-color 180ms ease, box-shadow 180ms ease;
}
.cp-account-shell textarea {
  min-height: 120px;
  padding-top: 12px;
}
.cp-account-shell input.input-text:focus,
.cp-account-shell input[type="text"]:focus,
.cp-account-shell input[type="email"]:focus,
.cp-account-shell input[type="password"]:focus,
.cp-account-shell input[type="tel"]:focus,
.cp-account-shell select:focus,
.cp-account-shell textarea:focus {
  outline: none;
  border-color: var(--green-2);
  box-shadow: 0 0 0 4px #e7f1e5;
}
.cp-account-shell .cp-account-readonly-field {
  cursor: default;
}
.cp-account-shell fieldset {
  margin: 24px 0 0;
  padding: 20px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-cool);
}
.cp-account-shell legend {
  padding: 0 8px;
  color: var(--ink);
  font-weight: 800;
}
.cp-account-shell .woocommerce-form-login__rememberme,
.cp-account-shell .woocommerce-form__label-for-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 4px 0 16px;
  color: #2a4148;
  font-size: 14px;
  font-weight: 700;
}
.footer-brand {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.footer-logo {
  position: relative;
  display: inline-flex;
  width: fit-content;
  color: #fff;
  margin-bottom: 0;
  isolation: isolate;
}
.footer-logo::before {
  position: absolute;
  inset: 6.55%;
  z-index: 2;
  border: 2px solid rgba(255, 255, 255, 0.82);
  border-radius: 999px;
  background: transparent;
  content: "";
  filter: none;
  pointer-events: none;
}
.footer-logo .brand-logo-img {
  position: relative;
  z-index: 1;
}
.footer-brand p {
  max-width: 290px;
}
.footer-bottom {
  position: relative;
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin: 4px 0 0;
  padding: 15px clamp(16px, 2.4vw, 24px) 16px;
  border: 1px solid rgba(255, 255, 255, 0.30);
  border-bottom: 0;
  border-radius: 22px 22px 0 0;
  color: #153548;
  background: #eef6f8;
  box-shadow:
    0 -8px 18px rgba(5, 31, 40, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 0.88);
  font-size: 13px;
}
.footer-bottom-copy {
  color: #153548;
  font-weight: 700;
}
.footer-payment-methods {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}
.footer-payment-logo {
  display: grid;
  width: 54px;
  height: 24px;
  place-items: center;
  opacity: 1;
}
.footer-payment-logo img {
  display: block;
  width: 54px;
  height: auto;
  max-height: 22px;
  object-fit: contain;
}
.footer-payment-logo--secure {
  width: 132px;
}
.footer-payment-logo--secure img {
  width: 132px;
  max-height: 24px;
}
@media (max-width: 520px) {
  .footer-payment-methods {
    gap: 6px;
  }

  .footer-payment-logo--secure {
    width: 112px;
  }

  .footer-payment-logo--secure img {
    width: 112px;
    max-height: 22px;
  }
}
.toast {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 1200;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  max-width: min(380px, calc(100vw - 32px));
  min-height: 48px;
  transform: translate3d(0, 16px, 0) scale(0.98);
  padding: 12px 15px 12px 12px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 16px;
  color: #fff;
  background:
    radial-gradient(circle at 12% 14%, rgba(255, 255, 255, 0.18), transparent 36%),
    linear-gradient(135deg, #051f28 0%, #08313d 48%, #153548 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 20px 42px rgba(5, 31, 40, 0.28);
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease, transform 220ms cubic-bezier(0.2, 0.82, 0.22, 1);
}
.toast.visible {
  transform: translate3d(0, 0, 0) scale(1);
  opacity: 1;
}
.toast-icon {
  display: inline-grid;
  flex: 0 0 auto;
  width: 28px;
  height: 28px;
  place-items: center;
  border: 1px solid rgba(217, 237, 207, 0.44);
  border-radius: 999px;
  color: #d9edcf;
  background: rgba(255, 255, 255, 0.08);
  font-size: 16px;
  font-weight: 900;
  line-height: 1;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2);
}
.toast-message {
  min-width: 0;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.35;
}
.toast--cart {
  border-color: rgba(217, 237, 207, 0.34);
}
.cart-feedback-popover {
  position: fixed;
  z-index: 1250;
  display: inline-flex;
  align-items: center;
  gap: 11px;
  width: max-content;
  max-width: min(340px, calc(100vw - 24px));
  min-height: 58px;
  transform: translate3d(0, -5px, 0) scale(0.98);
  transform-origin: var(--cart-feedback-arrow-x, 50%) 0;
  padding: 12px 15px 12px 12px;
  border: 1px solid rgba(217, 237, 207, 0.32);
  border-radius: 17px;
  color: #fff;
  background:
    radial-gradient(circle at 12% 12%, rgba(255, 255, 255, 0.18), transparent 35%),
    linear-gradient(135deg, #051f28 0%, #08313d 46%, #153548 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 18px 38px rgba(5, 31, 40, 0.26);
  opacity: 0;
  pointer-events: none;
  transition:
    opacity 170ms ease,
    transform 220ms cubic-bezier(0.2, 0.82, 0.22, 1);
}
.cart-feedback-popover::before {
  position: absolute;
  top: -6px;
  left: var(--cart-feedback-arrow-x, 50%);
  width: 12px;
  height: 12px;
  border-top: 1px solid rgba(217, 237, 207, 0.28);
  border-left: 1px solid rgba(217, 237, 207, 0.28);
  background: #061f29;
  content: "";
  transform: translateX(-50%) rotate(45deg);
}
.cart-feedback-popover.is-visible {
  transform: translate3d(0, 0, 0) scale(1);
  opacity: 1;
}
.cart-feedback-popover-icon {
  position: relative;
  z-index: 1;
  display: inline-grid;
  flex: 0 0 auto;
  width: 31px;
  height: 31px;
  place-items: center;
  border: 1px solid rgba(217, 237, 207, 0.5);
  border-radius: 999px;
  color: #d9edcf;
  background: rgba(255, 255, 255, 0.09);
  font-size: 17px;
  font-weight: 900;
  line-height: 1;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2);
}
.cart-feedback-popover-copy {
  position: relative;
  z-index: 1;
  display: grid;
  min-width: 0;
  gap: 2px;
}
.cart-feedback-popover-title {
  max-width: 250px;
  overflow: hidden;
  font-size: 13.5px;
  font-weight: 900;
  line-height: 1.22;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cart-feedback-popover-subtitle {
  color: rgba(232, 245, 239, 0.78);
  font-size: 11.5px;
  font-weight: 700;
  line-height: 1.2;
}
@media (max-width: 620px) {
  .toast {
    right: 16px;
    bottom: 16px;
    left: 16px;
    max-width: none;
    justify-content: flex-start;
  }
  .cart-feedback-popover {
    max-width: calc(100vw - 24px);
    min-height: 54px;
    padding: 11px 13px 11px 11px;
  }
  .cart-feedback-popover-title {
    max-width: min(248px, calc(100vw - 96px));
    font-size: 13px;
  }
}
.site-loader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  grid-template-rows: auto auto;
  gap: clamp(20px, 2vw, 26px);
  align-content: center;
  justify-items: center;
  padding: 32px;
  background:
    radial-gradient(circle at 50% 43%, rgba(255, 255, 255, 0.92) 0, rgba(229, 244, 250, 0.76) 30%, rgba(186, 218, 231, 0.28) 57%, transparent 74%),
    radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.7), transparent 34%),
    radial-gradient(circle at 82% 76%, rgba(117, 181, 203, 0.18), transparent 38%),
    linear-gradient(135deg, rgba(240, 249, 252, 0.98), rgba(218, 236, 245, 0.94));
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
  isolation: isolate;
  opacity: 0;
  overflow: hidden;
  pointer-events: none;
  transform: translateZ(0);
  transition: opacity 140ms ease, visibility 140ms ease;
  visibility: hidden;
  will-change: opacity;
}
.site-loader::before,
.site-loader::after {
  position: absolute;
  z-index: 0;
  content: "";
  pointer-events: none;
}
.site-loader::before {
  inset: -18%;
  background:
    radial-gradient(circle at 50% 43%, rgba(255, 255, 255, 0.74), rgba(235, 248, 252, 0.44) 22%, rgba(157, 203, 222, 0.14) 46%, transparent 64%),
    radial-gradient(circle at 22% 28%, rgba(255, 255, 255, 0.42), transparent 30%),
    radial-gradient(circle at 78% 22%, rgba(197, 232, 241, 0.28), transparent 34%);
}
.site-loader::after {
  inset: 0;
  background:
    linear-gradient(118deg, transparent 0 36%, rgba(255, 255, 255, 0.38) 42%, rgba(255, 255, 255, 0.12) 47%, transparent 54%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.12), transparent 42%, rgba(21, 53, 72, 0.035));
  opacity: 0.82;
}
.site-loader[hidden] {
  display: none;
}
.cp-site-loading .site-loader {
  opacity: 1;
  pointer-events: none;
  visibility: visible;
}
.site-loader-orbit {
  position: relative;
  z-index: 1;
  display: grid;
  width: clamp(224px, 24vw, 380px);
  aspect-ratio: 1;
  place-items: center;
  border-radius: 50%;
  isolation: isolate;
}
.site-loader-orbit::before,
.site-loader-orbit::after,
.site-loader-ring {
  position: absolute;
  border-radius: 50%;
  content: "";
  inset: 0;
}
.site-loader-orbit::before {
  border: 1px solid rgba(255, 255, 255, 0.82);
  background:
    radial-gradient(circle at 32% 24%, rgba(255, 255, 255, 0.94), rgba(242, 250, 253, 0.66) 32%, rgba(194, 223, 235, 0.24) 70%, rgba(255, 255, 255, 0.42)),
    linear-gradient(145deg, rgba(255, 255, 255, 0.42), rgba(216, 236, 244, 0.36)),
    rgba(232, 245, 250, 0.5);
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
  box-shadow:
    0 30px 72px rgba(21, 53, 72, 0.14),
    0 0 0 1px rgba(255, 255, 255, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.92),
    inset 0 -18px 48px rgba(132, 184, 204, 0.13),
    inset 0 0 78px rgba(255, 255, 255, 0.22);
}
.site-loader-orbit::after {
  inset: clamp(18px, 2vw, 24px);
  border: 1px solid rgba(255, 255, 255, 0.9);
  background:
    radial-gradient(circle at 38% 24%, rgba(255, 255, 255, 0.22), transparent 34%),
    radial-gradient(circle at 50% 50%, transparent 54%, rgba(255, 255, 255, 0.2) 55%, transparent 70%);
  box-shadow:
    0 0 0 1px rgba(21, 53, 72, 0.045),
    inset 0 0 34px rgba(255, 255, 255, 0.32);
  opacity: 0.94;
}
.site-loader-ring {
  animation: cp-loader-orbit var(--cp-loader-orbit-duration, 900ms) linear infinite;
  animation-delay: var(--cp-loader-orbit-offset, -180ms);
  backface-visibility: hidden;
  contain: paint;
  transform: translate3d(0, 0, 0) rotate(0deg);
  transform-origin: 50% 50%;
  will-change: transform;
}
.site-loader-ring-svg {
  display: block;
  height: 100%;
  overflow: visible;
  transform: rotate(-90deg);
  width: 100%;
}
.site-loader-ring-arc {
  fill: none;
  stroke: #153548;
  stroke: url("#cp-loader-ring-gradient");
  stroke-dasharray: 58 42;
  stroke-linecap: round;
  stroke-width: 1.75;
}
.site-loader-ring::after {
  position: absolute;
  top: 77%;
  left: 18%;
  width: clamp(9px, 0.85vw, 12px);
  aspect-ratio: 1;
  border: 2px solid #487838;
  border-radius: 50%;
  background: #f8fdff;
  opacity: 1;
  box-shadow:
    0 0 0 3px rgba(197, 232, 241, 0.74),
    0 5px 14px rgba(21, 53, 72, 0.18);
  transform: scale(1);
}
.site-loader-logo {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  filter: drop-shadow(0 14px 24px rgba(21, 53, 72, 0.18));
}
.cp-site-loading .site-loader-logo {
  animation: cp-loader-settle 900ms ease-out both;
}
.site-loader-logo img,
.site-loader-logo svg {
  grid-area: 1 / 1;
  backface-visibility: hidden;
  display: block;
  transform: translateZ(0);
}
.site-loader-logo-mark {
  opacity: 1;
  filter: saturate(0.96) contrast(1.02);
}
.site-loader-text {
  position: relative;
  z-index: 1;
  margin-left: 0.28em;
  color: #153548;
  font-size: clamp(12px, 1vw, 15px);
  font-weight: 700;
  letter-spacing: 0.28em;
  line-height: 1;
  text-shadow: 0 1px 16px rgba(255, 255, 255, 0.9);
  text-transform: uppercase;
}

@keyframes cp-loader-orbit {
  to {
    transform: translate3d(0, 0, 0) rotate(360deg);
  }
}

@keyframes cp-loader-settle {
  0% {
    transform: scale(0.985);
  }

  100% {
    transform: scale(1);
  }
}

@supports not ((-webkit-backdrop-filter: blur(1px)) or (backdrop-filter: blur(1px))) {
.site-loader {
    background: rgba(229, 242, 248, 0.96);
  }
.site-loader-orbit::before {
    background: rgba(239, 248, 252, 0.94);
  }
}

@media (max-width: 560px) {
.site-loader {
    gap: 20px;
    padding: 24px;
  }
.site-loader-orbit {
    width: min(64vw, 252px);
  }
.brand-logo-img--loader {
    width: min(38vw, 142px);
  }
}

@media (max-width: 1360px) {
.main-nav {
    display: none;
  }
.site-header {
    grid-template-columns: auto minmax(260px, 1fr) auto;
  }
}

@media (max-width: 1180px) {
.site-header {
    grid-template-columns: auto 1fr auto;
  }
.hero {
    grid-template-columns: 1fr;
  }
.hero-slider {
    min-height: 470px;
  }
.home-market .hero-slider {
    min-height: 400px;
  }
.catalog {
    grid-template-columns: 1fr;
  }
.product-grid {
    grid-template-columns: repeat(3, minmax(0, 240px));
  }
.cp-product-hero {
    grid-template-columns: 1fr;
  }
.cp-info-grid,
.cp-trust-row,
.cp-related-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
.cp-info-grid article:nth-child(2n) {
    border-right: 0;
  }
.cp-cart-head {
    grid-template-columns: 1fr;
    gap: 24px;
  }
.cp-cart-shell .wc-block-cart {
    grid-template-columns: 1fr;
  }
.cp-checkout-shell .wc-block-checkout,
.cp-checkout-shell form.checkout {
    grid-template-columns: 1fr;
  }
.cp-cart-shell .wc-block-cart__sidebar,
.cp-cart-shell .cart-collaterals .cart_totals,
.cp-checkout-shell .wc-block-checkout__sidebar,
.cp-checkout-shell #order_review {
    position: static;
  }
.cp-account-head,
.cp-account-shell .woocommerce {
    grid-template-columns: 1fr;
  }
.cp-account-shell .woocommerce-MyAccount-navigation {
    position: static;
  }
.cp-account-shell .woocommerce-MyAccount-navigation ul {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
.cp-cart-service-band {
    grid-template-columns: 1fr;
  }
.cp-cart-service-band div {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }
.cp-cart-service-band div:last-child {
    border-bottom: 0;
  }
}

@media (max-width: 820px) {
.top-strip {
    display: none;
  }
.site-header {
    position: static;
    grid-template-columns: 1fr auto;
    gap: 12px;
  }
.main-nav {
    position: static;
    grid-column: 1 / -1;
    order: 4;
    display: flex;
    justify-content: flex-start;
    width: 100%;
    gap: 8px;
    padding: 6px;
    overflow-x: auto;
    border: 1px solid rgba(217, 237, 207, 0.18);
    border-radius: 8px;
    color: #eef6f3;
    background:
      radial-gradient(circle at 0% 0%, rgba(199, 149, 42, 0.12), transparent 16rem),
      linear-gradient(135deg, #082838 0%, #061923 62%, #0b3443 100%);
    box-shadow: 0 14px 28px rgba(8, 40, 56, 0.13);
    font-size: 13px;
    transform: none;
    pointer-events: auto;
    scrollbar-width: none;
  }
.main-nav::-webkit-scrollbar {
    display: none;
  }
.main-nav a {
    flex: 0 0 auto;
    min-height: 36px;
    padding: 0 12px;
    border-color: rgba(255, 255, 255, 0.08);
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    color: rgba(238, 246, 243, 0.84);
    background: rgba(255, 255, 255, 0.07);
    font-weight: 800;
  }
.main-nav a:hover {
    color: #d9edcf;
    border-color: rgba(217, 237, 207, 0.2);
    background: rgba(255, 255, 255, 0.12);
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.16),
      0 10px 18px rgba(0, 0, 0, 0.16);
  }
.main-nav a.is-active,
.main-nav a[aria-current="page"] {
    color: #fff;
    border-color: rgba(199, 149, 42, 0.62);
    background: #153548;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.18),
      0 0 0 1px rgba(217, 237, 207, 0.1),
      0 12px 22px rgba(0, 0, 0, 0.22),
      0 0 18px rgba(21, 53, 72, 0.24);
  }
.main-nav a.is-active:hover,
.main-nav a[aria-current="page"]:hover {
    color: #fff;
    border-color: rgba(217, 237, 207, 0.78);
    background: #153548;
  }
.brand {
    font-size: 18px;
  }
.cart-button strong {
    display: none;
  }
.hero {
    min-height: auto;
    padding-top: 34px;
  }
.home-market {
    padding-top: 18px;
  }
.home-market .hero {
    padding-top: 0;
  }
.home-market .hero-slider {
    min-height: 420px;
  }
.hero h1 {
    font-size: 42px;
  }
.hero-slider {
    min-height: 420px;
  }
.hero-slide {
    grid-template-columns: 1fr;
    padding: 24px 22px 72px;
  }
.hero-slider-controls {
    top: 16px;
    right: 26px;
  }
.catalog {
    grid-template-columns: 1fr;
    padding-top: 16px;
  }
.category-panel {
    display: flex;
    overflow-x: auto;
    gap: 8px;
    padding: 10px;
  }
.category-panel h2 {
    display: none;
  }
.category-button {
    width: auto;
    white-space: nowrap;
  }
.section-head {
    align-items: start;
    flex-direction: column;
  }
.product-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
.product-card {
    min-height: 390px;
    padding: 0;
  }
.product-art {
    min-height: 212px;
  }
.product-art img {
    max-height: 174px;
  }
.flow-steps,
.site-footer {
    grid-template-columns: 1fr;
  }
.footer-brand,
.footer-logo {
    align-items: center;
    justify-content: center;
  }
.brand-logo-img--footer {
    width: 182px;
    height: auto;
    object-position: center;
  }
.footer-bottom {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
.footer-payment-methods {
    justify-content: center;
  }
.cp-single-product {
    padding-top: 22px;
  }
.cp-product-gallery .woocommerce-product-gallery__image {
    min-height: 380px;
  }
.cp-product-gallery .woocommerce-product-gallery__image img {
    max-height: 350px;
  }
.cp-product-title {
    font-size: 34px;
  }
.cp-purchase-panel {
    grid-template-columns: 1fr;
  }
.cp-info-grid,
.cp-trust-row,
.cp-related-grid {
    grid-template-columns: 1fr;
  }
.cp-info-grid article {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }
.cp-info-grid article:last-child {
    border-bottom: 0;
  }
.cp-related-card {
    grid-template-columns: 118px minmax(0, 1fr) 46px;
    min-height: 154px;
  }
.cp-cart-shell {
    padding-top: 28px;
  }
.cp-checkout-steps {
    gap: 8px;
  }
.cp-checkout-steps li {
    font-size: 11px;
  }
.cp-checkout-steps li::before {
    display: none;
  }
.cp-cart-shell .wc-block-cart-items thead,
.cp-cart-shell table.shop_table thead {
    display: none;
  }
.cp-cart-shell .wc-block-cart-items__row,
.cp-cart-shell table.shop_table.cart tr.cart_item {
    display: grid;
    grid-template-columns: 92px 1fr;
    gap: 14px;
    padding: 18px;
  }
.cp-cart-shell .wc-block-cart-items td,
.cp-cart-shell table.shop_table td {
    display: block;
    padding: 0 !important;
  }
.cp-cart-shell .wc-block-cart-item__image,
.cp-cart-shell table.cart .product-thumbnail {
    grid-row: span 4;
  }
.cp-cart-shell .wc-block-cart-item__image img,
.cp-cart-shell table.cart img {
    width: 84px !important;
    height: 84px !important;
  }
.cp-checkout-shell {
    padding-top: 28px;
  }
.cp-checkout-shell .wc-block-components-checkout-step__container,
.cp-checkout-shell .woocommerce-billing-fields__field-wrapper,
.cp-checkout-shell .woocommerce-shipping-fields__field-wrapper {
    grid-template-columns: 1fr;
  }
.cp-checkout-shell .wc-block-components-checkout-step,
.cp-checkout-shell .woocommerce-billing-fields,
.cp-checkout-shell .woocommerce-shipping-fields,
.cp-checkout-shell .woocommerce-additional-fields {
    padding: 18px !important;
  }
.cp-account-shell {
    padding-top: 28px;
  }
.cp-account-head {
    align-items: start;
    gap: 20px;
  }
.cp-account-shell .woocommerce-MyAccount-navigation ul,
.cp-account-shell .u-columns,
.cp-account-shell .woocommerce-Addresses,
.cp-account-shell .woocommerce-customer-details .addresses {
    grid-template-columns: 1fr;
  }
.cp-account-shell .woocommerce-MyAccount-navigation-link a {
    min-height: 44px;
  }
.cp-account-shell .woocommerce-message,
.cp-account-shell .woocommerce-info,
.cp-account-shell .woocommerce-error {
    align-items: flex-start;
    flex-direction: column;
  }
.cp-account-shell .woocommerce-message .button,
.cp-account-shell .woocommerce-info .button,
.cp-account-shell .woocommerce-error .button {
    order: 0;
    width: 100%;
  }
}

@media (max-width: 520px) {
.hero h1 {
    max-width: 330px;
    font-size: 30px;
    line-height: 1.08;
  }
.hero p {
    max-width: 330px;
    font-size: 16px;
  }
.hero-slider {
    min-height: 370px;
  }
.home-market .hero-slider {
    min-height: 370px;
  }
.hero-slide {
    padding: 22px 18px 62px;
  }
.hero-arrow {
    width: 36px;
    height: 36px;
  }
.hero-slider-controls {
    right: 70px;
    gap: 6px;
  }
.hero-slider-dots {
    right: 54px;
    bottom: 18px;
  }
.product-grid {
    grid-template-columns: minmax(0, 340px);
  }
.product-card {
    min-height: 372px;
  }
.product-art {
    min-height: 206px;
  }
.cp-purchase-panel form.cart {
    grid-template-columns: 1fr;
  }
.cp-product-gallery .flex-control-thumbs {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
.cp-related-card {
    grid-template-columns: 92px minmax(0, 1fr) 42px;
    gap: 12px;
    min-height: 132px;
    padding: 12px;
  }
.cp-mini-cart {
    width: 42px;
    height: 42px;
    grid-column: auto;
  }
.cp-cart-head h1 {
    font-size: 40px;
  }
.cp-account-head h1 {
    font-size: 40px;
  }
.cp-checkout-steps span {
    width: 30px;
    height: 30px;
  }
.cp-cart-shell .wc-block-components-quantity-selector,
.cp-cart-shell .quantity {
    grid-template-columns: 32px 40px 32px;
  }
.cp-cart-service-band div {
    align-items: flex-start;
    padding: 18px;
  }
}
/* Accepted card-inspired account dashboard concept. */
.cp-account-shell {
  position: relative;
  max-width: none;
  padding: 0 0 12px;
  overflow: hidden;
}
.cp-account-shell::before {
  position: absolute;
  inset: 0 0 auto;
  z-index: -1;
  height: 214px;
  background:
    linear-gradient(126deg, transparent 0 11%, rgba(255, 255, 255, 0.46) 11% 16%, transparent 16% 35%, rgba(255, 255, 255, 0.5) 35% 41%, transparent 41% 62%, rgba(255, 255, 255, 0.52) 62% 68%, transparent 68%),
    linear-gradient(180deg, #eef3f5, #f7fafb);
  border-bottom: 1px solid #e3ebed;
  content: "";
}
.cp-account-head {
  display: block;
  max-width: var(--max);
  margin: 0 auto;
  padding: 38px clamp(20px, 6vw, 92px) 24px;
}
.cp-account-head h1 {
  max-width: 720px;
  margin: 0;
  color: #06141b;
  font-size: clamp(42px, 4.4vw, 58px);
  line-height: 0.98;
  letter-spacing: 0;
}
.cp-account-head p {
  max-width: 700px;
  margin: 14px 0 0;
  color: #1d333b;
  font-size: 16px;
  line-height: 1.55;
}
.cp-account-content {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 clamp(20px, 6vw, 92px);
}
.cp-account-shell .woocommerce {
  display: grid;
  grid-template-columns: 282px minmax(0, 1fr);
  gap: 30px;
  align-items: start;
  width: 100%;
  max-width: 1148px;
  margin: 0 auto;
}
.cp-account-shell .woocommerce-notices-wrapper,
.cp-account-shell .woocommerce-message,
.cp-account-shell .woocommerce-info,
.cp-account-shell .woocommerce-error {
  grid-column: 2;
}
.cp-account-shell .woocommerce-message,
.cp-account-shell .woocommerce-info,
.cp-account-shell .woocommerce-error {
  min-height: 68px;
  margin: 0 0 12px;
  padding: 14px 18px 14px 58px;
  border: 1px solid #cddbd8;
  border-left: 0;
  border-radius: 8px;
  color: #273d45;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 8px 24px rgba(8, 40, 56, 0.06);
}
.cp-account-shell .woocommerce-message::before,
.cp-account-shell .woocommerce-info::before {
  top: 50%;
  left: 18px;
  display: grid;
  width: 34px;
  height: 34px;
  place-items: center;
  border-radius: 50%;
  color: #fff;
  background: var(--green-2);
  transform: translateY(-50%);
}
.cp-account-shell .woocommerce-error {
  border-color: #efcaca;
  background: #fff8f8;
}
.cp-account-shell .woocommerce-message .button,
.cp-account-shell .woocommerce-info .button,
.cp-account-shell .woocommerce-error .button {
  min-height: 42px;
  padding: 0 18px !important;
  border: 1px solid #78a66e !important;
  border-radius: 7px !important;
  color: var(--green-2) !important;
  background: #fff !important;
  box-shadow: none;
  font-size: 14px !important;
  font-weight: 800 !important;
}
.cp-account-shell .woocommerce-MyAccount-navigation.cp-account-nav {
  position: sticky;
  top: 96px;
  width: auto;
  padding: 0;
  border: 1px solid #d4dee0;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 14px 34px rgba(8, 40, 56, 0.1);
  overflow: hidden;
}
.cp-account-nav-hero {
  min-height: 252px;
  padding: 24px 22px 20px;
  color: #fff;
  background:
    radial-gradient(circle at 52% 32%, rgba(50, 89, 100, 0.62), transparent 34%),
    linear-gradient(145deg, #062532, #082838 62%, #04151c);
}
.cp-account-nav-logo {
  position: relative;
  display: grid;
  width: 150px;
  height: 150px;
  margin: 0 auto 18px;
  place-items: center;
}
.cp-account-nav-logo .brand-logo-img {
  filter: drop-shadow(0 16px 22px rgba(3, 14, 20, 0.26));
}
.cp-account-nav-logo svg {
  width: 132px;
  height: 132px;
}
.cp-account-nav-logo circle {
  fill: #082838;
  stroke: rgba(255, 255, 255, 0.12);
  stroke-width: 1;
}
.cp-account-nav-logo path {
  fill: var(--green);
  stroke: #fff;
  stroke-width: 2.7;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cp-account-nav-logo path:last-of-type {
  fill: none;
  stroke: #fff;
  stroke-width: 2.5;
}
.cp-account-nav-logo rect {
  fill: #fff;
  stroke: #d3dde0;
  stroke-width: 1;
}
.cp-account-nav-logo strong {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 31px;
  color: var(--navy);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 16px;
  font-weight: 700;
  text-align: center;
}
.cp-account-nav-greeting,
.cp-account-nav-name {
  display: block;
}
.cp-account-nav-greeting {
  margin-top: 4px;
  color: #dce9e6;
  font-size: 15px;
}
.cp-account-nav-name {
  margin-top: 3px;
  color: #fff;
  font-size: 19px;
  font-weight: 800;
  line-height: 1.2;
  overflow-wrap: anywhere;
}
.cp-account-shell .woocommerce-MyAccount-navigation ul {
  display: grid;
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
}
.cp-account-shell .woocommerce-MyAccount-navigation-link a {
  display: flex;
  align-items: center;
  gap: 14px;
  min-height: 58px;
  padding: 0 20px;
  border: 0;
  border-radius: 0;
  color: #071b24;
  background: #fff;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
}
.cp-account-shell .woocommerce-MyAccount-navigation-link a::before {
  display: none;
}
.cp-account-nav-icon {
  display: grid;
  width: 24px;
  height: 24px;
  place-items: center;
  color: var(--navy);
}
.cp-account-nav-icon svg {
  width: 23px;
  height: 23px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cp-account-shell .woocommerce-MyAccount-navigation-link a:hover,
.cp-account-shell .woocommerce-MyAccount-navigation-link.is-active a {
  color: #1f5e19;
  background: linear-gradient(90deg, #eff7e9, #fbfdf8);
}
.cp-account-shell .woocommerce-MyAccount-navigation-link.is-active .cp-account-nav-icon {
  color: var(--green-2);
}
.cp-account-shell .woocommerce-MyAccount-content {
  width: auto;
  min-width: 0;
  padding: 0;
  border: 1px solid #d4dee0;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 14px 34px rgba(8, 40, 56, 0.1);
  overflow: hidden;
}
.cp-account-dashboard {
  padding: 14px;
}
.cp-account-welcome {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr) minmax(160px, 220px);
  gap: 18px;
  align-items: center;
  margin-bottom: 14px;
  padding: 20px 22px;
  border: 1px solid #e0e8e6;
  border-radius: 8px;
  background: #fff;
}
.cp-account-leaf {
  display: grid;
  width: 68px;
  height: 68px;
  place-items: center;
  border-radius: 50%;
  color: var(--green-2);
  background: #eef5eb;
}
.cp-account-leaf svg {
  width: 42px;
  height: 42px;
  fill: currentColor;
  stroke: #fff;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cp-account-leaf path:last-child {
  fill: none;
  stroke: currentColor;
  stroke-width: 2.2;
}
.cp-account-welcome h2 {
  margin: 0 0 8px;
  color: var(--ink);
  font-size: clamp(22px, 2vw, 28px);
  line-height: 1.15;
}
.cp-account-welcome p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.55;
}
.cp-account-order-count {
  display: grid;
  grid-template-columns: 56px 1fr;
  column-gap: 14px;
  align-items: center;
  justify-self: end;
  min-width: 188px;
}
.cp-account-order-count .cp-line-icon {
  grid-row: span 3;
  width: 56px;
  height: 56px;
  background: #f3f6f6;
}
.cp-account-order-count small {
  color: var(--muted);
  font-size: 13px;
}
.cp-account-order-count strong {
  color: var(--ink);
  font-size: 26px;
  font-weight: 800;
  line-height: 1;
}
.cp-account-order-count a {
  color: var(--navy);
  font-size: 13px;
  font-weight: 800;
}
.cp-line-icon {
  display: grid;
  width: 36px;
  height: 36px;
  place-items: center;
  border-radius: 50%;
  color: var(--navy);
}
.cp-line-icon svg {
  width: 24px;
  height: 24px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cp-account-dashboard-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 1.05fr);
  gap: 12px;
}
.cp-account-panel {
  min-width: 0;
  padding: 18px;
  border: 1px solid #e0e8e6;
  border-radius: 8px;
  background: #fff;
}
.cp-account-panel > header {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  margin-bottom: 14px;
  padding-bottom: 14px;
  border-bottom: 1px solid #e2e9e7;
}
.cp-account-panel h2,
.cp-account-panel h3 {
  margin: 0;
  color: var(--ink);
  line-height: 1.2;
}
.cp-account-panel h2 {
  font-size: 18px;
  font-weight: 800;
}
.cp-account-panel h3 {
  font-size: 14px;
  font-weight: 800;
}
.cp-account-panel header a {
  color: var(--green-2);
  font-size: 13px;
  font-weight: 700;
  white-space: nowrap;
}
.cp-account-orders-preview table {
  width: 100%;
  border: 1px solid #dce6e3;
  border-collapse: separate;
  border-spacing: 0;
  border-radius: 6px;
  overflow: hidden;
}
.cp-account-orders-preview th,
.cp-account-orders-preview td {
  padding: 13px 12px;
  border-bottom: 1px solid #e5ecea;
  color: #263c44;
  font-size: 13px;
  text-align: left;
}
.cp-account-orders-preview th {
  color: #445a61;
  background: #f8faf9;
  font-size: 12px;
  font-weight: 800;
}
.cp-account-orders-preview tr:last-child td {
  border-bottom: 0;
}
.cp-status-pill {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 10px;
  border: 1px solid #d9e6d6;
  border-radius: 999px;
  color: var(--green-2);
  background: #f0f8ed;
  font-size: 12px;
  font-weight: 700;
}
.cp-row-link {
  color: var(--navy);
  font-size: 20px;
  font-weight: 800;
}
.cp-outline-button,
.cp-solid-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 7px;
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}
.cp-outline-button {
  margin-top: 14px;
  border: 1px solid #78a66e;
  color: var(--green-2) !important;
  background: #fff;
}
.cp-solid-button {
  color: #fff !important;
  background: #153548;
  box-shadow: 0 12px 22px rgba(11, 70, 80, 0.18);
}
.cp-address-book {
  display: grid;
  gap: 18px;
}
.cp-address-book-group {
  display: grid;
  gap: 16px;
  padding: clamp(18px, 2vw, 26px);
  border: 1px solid #e0e8e6;
  border-radius: 8px;
  background: #fff;
}
.cp-address-book-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 14px;
  border-bottom: 1px solid #e2e9e7;
}
.cp-address-book-kicker {
  display: block;
  margin-bottom: 4px;
  color: rgba(21, 53, 72, 0.58);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.cp-address-book-heading h2 {
  margin: 0;
  color: var(--ink);
  font-size: clamp(22px, 2vw, 28px);
  line-height: 1.1;
}
.cp-address-book-add,
.cp-address-book-actions button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
  white-space: nowrap;
}
.cp-address-book-add {
  padding: 0 16px;
  border: 1px solid rgba(21, 53, 72, 0.16);
  color: #fff !important;
  background: #153548;
  box-shadow: 0 10px 20px rgba(21, 53, 72, 0.14);
}
.cp-address-book-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
}
.cp-address-book-card {
  display: grid;
  gap: 14px;
  min-width: 0;
  padding: 18px;
  border: 1px solid rgba(21, 53, 72, 0.12);
  border-radius: 18px;
  background:
    radial-gradient(circle at 8% 0%, rgba(255, 255, 255, 0.74), transparent 42%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.68), rgba(226, 244, 249, 0.32));
}
.cp-address-book-card.is-default {
  border-color: rgba(199, 149, 42, 0.46);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.76),
    0 12px 24px rgba(21, 53, 72, 0.08);
}
.cp-address-book-card > header {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr) 38px;
  gap: 12px;
  align-items: center;
}
.cp-address-book-icon,
.cp-address-book-edit {
  display: grid;
  place-items: center;
  border-radius: 14px;
}
.cp-address-book-icon {
  width: 40px;
  height: 40px;
  color: #153548;
  background: rgba(255, 255, 255, 0.58);
}
.cp-address-book-icon svg,
.cp-address-book-edit svg {
  width: 22px;
  height: 22px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cp-address-book-card h3 {
  margin: 0;
  color: #153548;
  font-size: 18px;
  line-height: 1.15;
}
.cp-address-book-defaults {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 8px;
}
.cp-address-book-default {
  display: inline-flex;
  margin-top: 5px;
  color: #7c6a23;
  font-size: 12px;
  font-weight: 900;
}
.cp-address-book-edit {
  width: 38px;
  height: 38px;
  color: #153548;
  background: rgba(255, 255, 255, 0.46);
}
.cp-address-book-card address {
  display: grid;
  gap: 6px;
  min-height: 84px;
  margin: 0;
  color: #273d45;
  font-style: normal;
  font-size: 13px;
  line-height: 1.45;
}
.cp-address-book-card address span {
  overflow-wrap: anywhere;
}
.cp-address-book-contact {
  display: grid;
  gap: 4px;
  margin-top: -4px;
  padding-top: 10px;
  border-top: 1px solid rgba(21, 53, 72, 0.1);
  color: rgba(21, 53, 72, 0.82);
  font-size: 13px;
  font-weight: 850;
  line-height: 1.4;
}
.cp-address-book-contact span {
  overflow-wrap: anywhere;
}
.cp-address-book-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.cp-address-book-actions form {
  margin: 0;
}
.cp-address-book-actions button {
  min-height: 36px;
  padding: 0 13px;
  border: 1px solid rgba(21, 53, 72, 0.16);
  color: #153548;
  background: rgba(255, 255, 255, 0.52);
  cursor: pointer;
}
.cp-address-book-actions .cp-address-book-delete {
  color: #9b1c1c;
}
.cp-address-book-empty {
  padding: 18px;
  border: 1px dashed rgba(21, 53, 72, 0.2);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.42);
}
.cp-address-book-empty strong,
.cp-address-book-empty p {
  display: block;
  margin: 0;
}
.cp-address-book-empty p {
  margin-top: 6px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}
.cp-address-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.cp-address-columns article + article {
  padding-left: 18px;
  border-left: 1px solid #e2e9e7;
}
.cp-address-columns p {
  position: relative;
  margin: 10px 0 0;
  padding-left: 20px;
  color: #273d45;
  font-size: 13px;
  line-height: 1.45;
}
.cp-address-columns p::before {
  position: absolute;
  top: 0.55em;
  left: 2px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--navy);
  content: "";
}
.cp-account-empty {
  display: grid;
  gap: 10px;
  padding: 20px;
  border: 1px dashed #cbd8d4;
  border-radius: 8px;
  background: var(--surface-cool);
}
.cp-account-empty strong {
  color: var(--ink);
}
.cp-account-empty p {
  margin: 0;
  color: var(--muted);
}
.cp-account-quick-row {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}
.cp-account-details-card,
.cp-account-support-card {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 16px 20px;
  border: 1px solid #e0e8e6;
  border-radius: 8px;
  background: #fff;
}
.cp-account-details-card .cp-line-icon {
  width: 48px;
  height: 48px;
  color: #fff;
  background: var(--navy);
}
.cp-account-details-card strong,
.cp-account-support-card strong {
  display: block;
  margin-bottom: 4px;
  color: var(--ink);
  font-size: 16px;
  font-weight: 800;
}
.cp-account-details-card p,
.cp-account-support-card p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}
.cp-account-support-card {
  grid-template-columns: 56px minmax(0, 1fr) minmax(360px, 0.95fr);
}
.cp-support-contact {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.cp-support-contact span {
  display: grid;
  gap: 3px;
  color: var(--navy);
  font-size: 14px;
  font-weight: 800;
}
.cp-support-contact small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 500;
}
.cp-account-extra-hooks {
  display: none;
}
.cp-account-shell form.login,
.cp-account-shell form.register,
.cp-account-shell .woocommerce-form-login,
.cp-account-shell .woocommerce-form-register,
.cp-account-shell .woocommerce-EditAccountForm,
.cp-account-shell form.woocommerce-address-fields {
  border-radius: 8px;
}

@media (max-width: 1180px) {
.cp-account-shell .woocommerce {
    grid-template-columns: 260px minmax(0, 1fr);
    max-width: none;
  }
.cp-account-welcome,
.cp-account-dashboard-grid,
.cp-account-support-card {
    grid-template-columns: 1fr;
  }
.cp-account-order-count {
    justify-self: stretch;
  }
.cp-solid-button {
    width: 100%;
  }
}

@media (max-width: 820px) {
.cp-account-shell::before {
    height: 240px;
  }
.cp-account-head {
    padding-top: 30px;
  }
.cp-account-shell .woocommerce {
    grid-template-columns: 1fr;
  }
.cp-account-shell .woocommerce-notices-wrapper,
.cp-account-shell .woocommerce-message,
.cp-account-shell .woocommerce-info,
.cp-account-shell .woocommerce-error {
    grid-column: 1;
  }
.cp-account-shell .woocommerce-MyAccount-navigation.cp-account-nav {
    position: static;
  }
.cp-account-nav-hero {
    min-height: 210px;
  }
.cp-account-shell .woocommerce-MyAccount-navigation ul {
    grid-template-columns: 1fr;
  }
.cp-address-columns,
.cp-support-contact {
    grid-template-columns: 1fr;
  }
.cp-address-columns article + article {
    padding-top: 16px;
    padding-left: 0;
    border-top: 1px solid #e2e9e7;
    border-left: 0;
  }
.cp-account-details-card,
.cp-account-support-card {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 520px) {
.cp-account-head h1 {
    font-size: 40px;
  }
.cp-account-content {
    padding: 0 14px;
  }
.cp-account-dashboard {
    padding: 10px;
  }
.cp-account-welcome,
.cp-account-panel,
.cp-account-details-card,
.cp-account-support-card {
    padding: 16px;
  }
.cp-account-orders-preview.has-orders {
    overflow-x: auto;
  }
.cp-account-orders-preview.has-orders table {
    min-width: 560px;
  }
}
/* Airier account dashboard refinement based on the business card direction. */
.cp-account-shell {
  padding-bottom: 36px;
}
.cp-account-shell::before {
  height: 272px;
  background:
    linear-gradient(126deg, transparent 0 10%, rgba(255, 255, 255, 0.48) 10% 15%, transparent 15% 36%, rgba(255, 255, 255, 0.52) 36% 42%, transparent 42% 64%, rgba(255, 255, 255, 0.5) 64% 70%, transparent 70%),
    linear-gradient(180deg, #edf3f5 0%, #f8fbfb 100%);
}
.cp-account-head {
  padding-top: 54px;
  padding-bottom: 42px;
}
.cp-account-head h1 {
  font-size: clamp(46px, 4.6vw, 64px);
  line-height: 1;
}
.cp-account-head p {
  max-width: 620px;
  margin-top: 18px;
  color: #354a51;
  font-size: 17px;
  line-height: 1.7;
}
.cp-account-content {
  padding-bottom: 24px;
}
.cp-account-shell .woocommerce {
  grid-template-columns: 320px minmax(0, 1fr);
  gap: clamp(28px, 3vw, 48px);
  max-width: 1220px;
}
.cp-account-shell .woocommerce-message,
.cp-account-shell .woocommerce-info,
.cp-account-shell .woocommerce-error {
  min-height: 76px;
  margin-bottom: 22px;
  padding: 18px 22px 18px 66px;
  box-shadow: 0 14px 34px rgba(8, 40, 56, 0.07);
}
.cp-account-shell .woocommerce-message::before,
.cp-account-shell .woocommerce-info::before {
  left: 22px;
  width: 36px;
  height: 36px;
}
.cp-account-shell .woocommerce-MyAccount-navigation.cp-account-nav {
  border-color: #cfdbdd;
  box-shadow: 0 22px 48px rgba(8, 40, 56, 0.12);
}
.cp-account-nav-hero {
  min-height: 294px;
  padding: 34px 28px 28px;
  background:
    radial-gradient(circle at 52% 30%, rgba(77, 121, 130, 0.5), transparent 34%),
    linear-gradient(145deg, #06222e 0%, #082838 60%, #04141b 100%);
}
.cp-account-nav-logo {
  margin-bottom: 26px;
}
.cp-account-nav-greeting {
  margin-top: 0;
  font-size: 14px;
  letter-spacing: 0;
}
.cp-account-nav-name {
  margin-top: 8px;
  font-size: 22px;
  line-height: 1.25;
}
.cp-account-shell .woocommerce-MyAccount-navigation ul {
  padding: 10px;
}
.cp-account-shell .woocommerce-MyAccount-navigation-link a {
  min-height: 62px;
  gap: 16px;
  padding: 0 18px;
  border-radius: 7px;
  font-size: 15px;
}
.cp-account-shell .woocommerce-MyAccount-navigation-link + .woocommerce-MyAccount-navigation-link {
  margin-top: 4px;
}
.cp-account-shell .woocommerce-MyAccount-content {
  border-color: #cfdbdd;
  box-shadow: 0 22px 48px rgba(8, 40, 56, 0.1);
}
.cp-account-dashboard {
  padding: clamp(22px, 2.2vw, 34px);
}
.cp-account-welcome {
  grid-template-columns: 86px minmax(0, 1fr) minmax(190px, 240px);
  gap: 26px;
  margin-bottom: 26px;
  padding: clamp(28px, 3vw, 40px);
  border-color: #dce7e5;
  background:
    linear-gradient(135deg, #ffffff 0%, #ffffff 58%, #f6faf7 100%);
}
.cp-account-leaf {
  width: 78px;
  height: 78px;
}
.cp-account-leaf svg {
  width: 48px;
  height: 48px;
}
.cp-account-welcome h2 {
  margin-bottom: 12px;
  font-size: clamp(26px, 2.3vw, 34px);
  line-height: 1.12;
}
.cp-account-welcome p {
  max-width: 560px;
  font-size: 15px;
  line-height: 1.75;
}
.cp-account-order-count {
  min-width: 210px;
}
.cp-account-order-count .cp-line-icon {
  width: 62px;
  height: 62px;
}
.cp-account-order-count strong {
  font-size: 30px;
}
.cp-account-dashboard-grid {
  grid-template-columns: minmax(0, 1fr);
  gap: 26px;
}
.cp-account-panel {
  position: relative;
  padding: clamp(24px, 2.4vw, 32px);
  border-color: #dce7e5;
  background:
    linear-gradient(180deg, #ffffff 0%, #ffffff 72%, #f8fbfa 100%);
  box-shadow: 0 14px 34px rgba(8, 40, 56, 0.07);
  overflow: hidden;
}
.cp-account-panel::before {
  position: absolute;
  inset: 0 0 auto;
  height: 4px;
  background: linear-gradient(90deg, #153548, rgba(21, 53, 72, 0.72), rgba(21, 53, 72, 0));
  content: "";
  opacity: 0.82;
}
.cp-account-panel > header {
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 12px;
  margin-bottom: 24px;
  padding-bottom: 20px;
}
.cp-account-panel > header .cp-line-icon {
  grid-row: auto;
  align-self: center;
  justify-self: start;
  width: 48px;
  height: 48px;
  margin: 0;
  color: #fff;
  background:
    radial-gradient(circle at 32% 18%, rgba(255, 255, 255, 0.18), transparent 34%),
    linear-gradient(135deg, #051f28, #08313d 55%, #153548);
}
.cp-account-panel > header .cp-line-icon svg {
  width: 22px;
  height: 22px;
}
.cp-account-panel h2 {
  align-self: center;
  font-size: 21px;
  min-width: 0;
  overflow-wrap: anywhere;
}
.cp-account-panel h3 {
  font-size: 15px;
}
@media (min-width: 621px) {
  .cp-account-orders-preview > header h2,
  .cp-account-address-preview > header h2 {
    transform: translateY(3px);
  }
}
.cp-account-panel header a {
  align-self: center;
  justify-self: end;
  font-size: 14px;
  line-height: 1.35;
  white-space: nowrap;
  overflow-wrap: anywhere;
}
.cp-account-orders-preview {
  overflow: hidden;
}
.cp-account-orders-preview.has-orders {
  overflow-x: auto;
  overflow-y: hidden;
}
.cp-account-orders-preview th,
.cp-account-orders-preview td {
  padding: 16px 14px;
  font-size: 14px;
}
.cp-account-orders-preview th {
  font-size: 12px;
}
.cp-address-columns {
  gap: 24px;
}
.cp-account-address-preview {
  background:
    linear-gradient(135deg, #ffffff 0%, #ffffff 64%, #f4f8f5 100%);
}
.cp-address-columns article + article {
  padding-left: 24px;
}
.cp-address-columns p {
  margin-top: 13px;
  font-size: 14px;
  line-height: 1.65;
}
.cp-account-empty {
  gap: 12px;
  padding: 28px;
}
.cp-account-quick-row {
  gap: 18px;
  margin-top: 24px;
}
.cp-account-details-card,
.cp-account-support-card {
  gap: 20px;
  padding: 26px 28px;
  border-color: #dce7e5;
}
.cp-account-details-card > *,
.cp-account-support-card > * {
  min-width: 0;
}
.cp-account-details-card strong,
.cp-account-support-card strong {
  margin-bottom: 8px;
  font-size: 18px;
}
.cp-account-details-card p,
.cp-account-support-card p {
  font-size: 14px;
  line-height: 1.65;
}
.cp-support-contact {
  gap: 22px;
}
.cp-support-contact span {
  gap: 6px;
  font-size: 15px;
  overflow-wrap: anywhere;
}
.cp-support-contact small {
  font-size: 12px;
}
.cp-account-shell form.login,
.cp-account-shell form.register,
.cp-account-shell .woocommerce-form-login,
.cp-account-shell .woocommerce-form-register,
.cp-account-shell .woocommerce-EditAccountForm,
.cp-account-shell form.woocommerce-address-fields {
  padding: clamp(24px, 3vw, 36px);
}

@media (max-width: 1180px) {
.cp-account-shell .woocommerce {
    grid-template-columns: 292px minmax(0, 1fr);
    gap: 28px;
  }
.cp-account-welcome,
.cp-account-dashboard-grid,
.cp-account-support-card {
    gap: 22px;
  }
}

@media (max-width: 940px) {
.cp-account-dashboard-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 820px) {
.cp-account-shell::before {
    height: 268px;
  }
.cp-account-head {
    padding-top: 42px;
    padding-bottom: 34px;
  }
.cp-account-shell .woocommerce {
    grid-template-columns: 1fr;
  }
.cp-account-nav-hero {
    min-height: 232px;
    padding: 28px 24px 24px;
  }
.cp-account-shell .woocommerce-MyAccount-navigation ul {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }
.cp-account-shell .woocommerce-MyAccount-navigation-link + .woocommerce-MyAccount-navigation-link {
    margin-top: 0;
  }
.cp-account-welcome {
    grid-template-columns: 1fr;
  }
.cp-account-panel > header {
    grid-template-columns: 48px minmax(0, 1fr);
  }
.cp-account-panel header a {
    grid-column: 2;
    justify-self: start;
    white-space: normal;
  }
.cp-account-order-count {
    justify-self: start;
  }
}

@media (max-width: 520px) {
.cp-account-shell {
    padding-bottom: 24px;
  }
.cp-account-head {
    grid-template-columns: minmax(0, 1fr);
    padding-right: 22px;
    padding-left: 22px;
  }
.cp-account-head > div {
    min-width: 0;
    max-width: min(100%, 300px);
  }
.cp-account-head h1 {
    font-size: 42px;
  }
.cp-account-head p {
    max-width: 300px;
    font-size: 15px;
    overflow-wrap: anywhere;
    word-break: break-word;
  }
.cp-account-content {
    padding: 0 16px 18px;
  }
.cp-account-dashboard {
    padding: 16px;
  }
.cp-account-shell .woocommerce-MyAccount-navigation ul {
    grid-template-columns: 1fr;
  }
.cp-account-shell .woocommerce-MyAccount-navigation-link a {
    min-height: 58px;
  }
.cp-account-welcome,
.cp-account-panel,
.cp-account-details-card,
.cp-account-support-card {
    padding: 22px;
  }
}
/* Airier account address endpoint cards. */
.cp-account-shell .cp-account-address-note {
  max-width: 760px;
  margin: 24px 0 0;
  padding: 22px 24px;
  border: 1px solid #dce7e5;
  border-radius: 8px;
  color: #314850;
  background:
    linear-gradient(135deg, #ffffff 0%, #ffffff 62%, #f5f9f7 100%);
  box-shadow: 0 12px 28px rgba(8, 40, 56, 0.06);
  font-size: 15px;
  line-height: 1.72;
  overflow-wrap: anywhere;
}
.cp-account-shell .woocommerce-Addresses,
.cp-account-shell .woocommerce-customer-details .addresses {
  width: 100%;
  grid-template-columns: minmax(0, 1fr);
  gap: 22px;
}
.cp-account-shell .woocommerce-Addresses::before,
.cp-account-shell .woocommerce-Addresses::after {
  display: none !important;
  content: none !important;
}
.cp-account-shell .woocommerce-Address,
.cp-account-shell .woocommerce-column--billing-address,
.cp-account-shell .woocommerce-column--shipping-address {
  position: relative;
  float: none !important;
  clear: both;
  width: 100% !important;
  min-width: 0;
  max-width: none;
  margin: 0 !important;
  padding: clamp(24px, 2.4vw, 32px);
  border-color: #dce7e5;
  border-radius: 8px;
  background:
    linear-gradient(180deg, #ffffff 0%, #ffffff 70%, #f8fbfa 100%);
  box-shadow: 0 14px 34px rgba(8, 40, 56, 0.07);
  overflow: hidden;
}
.cp-account-shell .woocommerce-Address::before,
.cp-account-shell .woocommerce-column--billing-address::before,
.cp-account-shell .woocommerce-column--shipping-address::before {
  position: absolute;
  inset: 0 0 auto;
  height: 4px;
  background: linear-gradient(90deg, #153548, rgba(21, 53, 72, 0.72), rgba(21, 53, 72, 0));
  content: "";
  opacity: 0.82;
}
.cp-account-shell .woocommerce-Address-title {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: center;
  margin-bottom: 22px;
  padding-bottom: 18px;
  border-bottom: 1px solid #e2e9e7;
}
.cp-account-shell .woocommerce-Address-title::before {
  display: grid;
  width: 44px;
  height: 44px;
  place-items: center;
  border-radius: 50%;
  color: var(--green-2);
  background:
    radial-gradient(circle at 50% 50%, currentColor 0 4px, transparent 5px),
    radial-gradient(circle at 50% 50%, transparent 0 10px, rgba(8, 49, 61, 0.08) 11px 12px, transparent 13px),
    #eef5eb;
  content: "";
  flex: 0 0 auto;
  box-shadow: inset 0 0 0 1px rgba(8, 49, 61, 0.08);
}
.cp-account-shell .woocommerce-Address-title h2,
.cp-account-shell .woocommerce-Address-title h3 {
  flex: 1 1 260px;
  min-width: 0;
  margin: 0;
  color: var(--ink);
  font-size: clamp(21px, 2vw, 26px);
  font-weight: 800;
  line-height: 1.12;
  overflow-wrap: anywhere;
}
.cp-account-shell .woocommerce-Address-title .edit {
  flex: 0 0 auto;
  margin-left: auto;
  min-height: 42px;
  padding: 0 18px;
  line-height: 1.2;
  text-align: center;
  white-space: nowrap;
}
.cp-account-shell .woocommerce-Address address,
.cp-account-shell .woocommerce-column--billing-address address,
.cp-account-shell .woocommerce-column--shipping-address address {
  min-height: 124px;
  margin: 0;
  padding: 22px 24px;
  border: 1px solid #e0e8e6;
  border-radius: 8px;
  color: #273d45;
  background:
    linear-gradient(135deg, #fbfdfc 0%, #ffffff 100%);
  font-size: 15px;
  line-height: 1.85;
}

@media (max-width: 820px) {
.cp-account-shell .woocommerce-Address-title {
    align-items: flex-start;
  }
.cp-account-shell .woocommerce-Address-title .edit {
    margin-left: 60px;
    white-space: normal;
  }
}

@media (max-width: 560px) {
.cp-account-shell .woocommerce-Address-title .edit {
    width: auto;
    max-width: 100%;
    margin-left: 0;
    padding-right: 16px;
    padding-left: 16px;
  }
}
/* Premium logged-out account access surface. */
.cp-account-shell .woocommerce > .cp-login-layout {
  grid-column: 1 / -1;
}
.cp-login-layout {
  display: grid;
  grid-template-columns: minmax(320px, 0.88fr) minmax(0, 1.12fr);
  gap: clamp(24px, 3vw, 42px);
  width: 100%;
  max-width: 1120px;
  margin: 0 auto;
  align-items: stretch;
  min-width: 0;
}
.cp-login-layout--with-register {
  max-width: 1220px;
  grid-template-columns: minmax(300px, 0.78fr) minmax(0, 1.22fr);
}
.cp-login-intro,
.cp-login-panel {
  min-width: 0;
  border: 1px solid #d6e2e2;
  border-radius: 8px;
  overflow: hidden;
}
.cp-login-intro {
  position: relative;
  display: flex;
  min-height: 520px;
  flex-direction: column;
  justify-content: flex-end;
  padding: clamp(30px, 3vw, 42px);
  color: #fff;
  background:
    radial-gradient(circle at 22% 12%, rgba(126, 164, 99, 0.34), transparent 30%),
    linear-gradient(138deg, rgba(255, 255, 255, 0.06) 0 12%, transparent 12% 42%, rgba(255, 255, 255, 0.05) 42% 50%, transparent 50%),
    linear-gradient(150deg, #062635 0%, #083241 58%, #04171f 100%);
  box-shadow: 0 24px 54px rgba(8, 40, 56, 0.18);
}
.cp-login-intro::after {
  content: "";
  position: absolute;
  inset: auto -80px -120px auto;
  width: 260px;
  height: 260px;
  border: 1px solid rgba(184, 213, 161, 0.3);
  border-radius: 50%;
  opacity: 0.7;
}
.cp-login-brand-mark {
  position: absolute;
  top: 30px;
  right: 30px;
  display: grid;
  width: 120px;
  height: 120px;
  place-items: center;
  border: 0;
  border-radius: 0;
  background: transparent;
  opacity: 0.34;
  pointer-events: none;
  z-index: 0;
  filter: drop-shadow(0 16px 24px rgba(3, 14, 20, 0.3));
}
.cp-login-brand-mark .brand-logo-img {
  width: 120px;
  height: 120px;
}
.cp-login-intro h2 {
  position: relative;
  z-index: 1;
  max-width: 410px;
  margin: 0;
  color: #fff;
  font-size: clamp(32px, 3.2vw, 46px);
  font-weight: 800;
  line-height: 1.05;
  overflow-wrap: anywhere;
}
.cp-login-intro p {
  position: relative;
  z-index: 1;
  max-width: 420px;
  margin: 18px 0 0;
  color: rgba(255, 255, 255, 0.78);
  font-size: 16px;
  line-height: 1.75;
  overflow-wrap: anywhere;
}
.cp-login-benefits {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 12px;
  margin: 30px 0 0;
  padding: 0;
  list-style: none;
}
.cp-login-benefits li {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
  min-height: 48px;
  padding: 10px 12px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.06);
  color: rgba(255, 255, 255, 0.88);
  font-size: 14px;
  font-weight: 800;
}
.cp-login-benefits span {
  min-width: 0;
  overflow-wrap: anywhere;
}
.cp-login-benefits svg {
  flex: 0 0 auto;
  width: 22px;
  height: 22px;
  fill: none;
  stroke: #9fcb8a;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cp-login-forms {
  display: grid;
  gap: 18px;
  align-content: center;
  min-width: 0;
}
.cp-login-layout--with-register .cp-login-forms {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-content: stretch;
}
.cp-login-panel {
  display: flex;
  flex-direction: column;
  padding: clamp(28px, 3vw, 42px);
  background:
    linear-gradient(180deg, #fff 0%, #fff 74%, #f7faf9 100%);
  box-shadow: 0 22px 48px rgba(8, 40, 56, 0.1);
}
.cp-login-panel-head {
  margin-bottom: 28px;
  padding-bottom: 22px;
  border-bottom: 1px solid #e0e9e8;
}
.cp-login-panel-head h2 {
  margin: 0;
  color: var(--ink);
  font-size: clamp(28px, 2.7vw, 38px);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}
.cp-login-panel-head p,
.cp-login-note {
  max-width: 520px;
  margin: 12px 0 0;
  color: #53686f;
  font-size: 15px;
  line-height: 1.7;
  overflow-wrap: anywhere;
}
.cp-account-shell .cp-login-panel form.login,
.cp-account-shell .cp-login-panel form.register,
.cp-account-shell .cp-login-panel .woocommerce-form-login,
.cp-account-shell .cp-login-panel .woocommerce-form-register {
  flex: 1;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}
.cp-login-panel .form-row {
  margin-bottom: 18px;
}
.cp-login-panel label {
  margin-bottom: 9px;
  color: #17313a;
  font-size: 13px;
  font-weight: 800;
}
.cp-login-panel input.input-text,
.cp-login-panel input[type="text"],
.cp-login-panel input[type="email"],
.cp-login-panel input[type="tel"],
.cp-login-panel input[type="password"] {
  min-height: 56px;
  padding: 0 16px;
  border-color: #cfdbdd;
  border-radius: 8px;
  background: #fbfdfd;
  font-size: 15px;
}
.cp-login-panel input.input-text:focus,
.cp-login-panel input[type="text"]:focus,
.cp-login-panel input[type="email"]:focus,
.cp-login-panel input[type="tel"]:focus,
.cp-login-panel input[type="password"]:focus {
  border-color: var(--green-2);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(111, 151, 83, 0.18);
}
.cp-register-name-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}
.cp-register-name-grid .form-row {
  float: none !important;
  width: 100% !important;
  max-width: none !important;
  margin-bottom: 0;
}
.cp-register-name-grid input.input-text {
  width: 100% !important;
}
.cp-login-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin: 4px 0 22px;
}
.cp-account-shell .cp-login-actions .woocommerce-form-login__rememberme,
.cp-account-shell .cp-login-actions .woocommerce-form__label-for-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin: 0;
  color: #334a51;
  font-size: 14px;
  font-weight: 800;
}
.cp-login-actions input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--green-2);
}
.cp-login-lost {
  color: var(--green-2);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}
.cp-login-lost:hover {
  color: #285a20;
  text-decoration: underline;
}
.cp-login-submit-row {
  margin: 0;
}
.cp-account-shell .cp-login-submit-row .button,
.cp-account-shell .cp-login-submit-row button.button {
  width: 100%;
  min-height: 54px;
  justify-content: center;
  border-radius: 8px !important;
  font-size: 15px !important;
}
.cp-login-panel--track {
  grid-column: 1 / -1;
}
body.woocommerce-account .cp-account-shell .cp-login-panel--track > .woocommerce {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 18px;
  width: 100%;
  max-width: none;
  align-items: stretch;
}
.cp-login-panel--track .track_order {
  display: grid;
  grid-template-columns: repeat(2, minmax(240px, 1fr));
  gap: 16px;
  width: 100%;
  justify-self: stretch;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}
.cp-login-panel--track .cp-order-tracking-intro,
.cp-login-panel--track .clear,
.cp-login-panel--track .cp-order-tracking-submit,
.cp-order-tracking-result {
  grid-column: 1 / -1;
}
.cp-login-panel--track .cp-order-tracking-intro {
  margin: 0;
  color: #53686f;
  line-height: 1.65;
}
.cp-login-panel--track .track_order .form-row {
  display: grid;
  min-width: 0;
  margin: 0;
}
.cp-login-panel--track .track_order .form-row-first,
.cp-login-panel--track .track_order .form-row-last {
  float: none !important;
  clear: none !important;
  width: 100% !important;
}
.cp-login-panel--track .track_order label {
  display: block;
  min-height: 2.45em;
  margin-bottom: 10px;
  line-height: 1.35;
}
.cp-login-panel--track .track_order input.input-text {
  width: 100%;
  min-width: 0;
}
.cp-login-panel--track .track_order .button {
  width: 100%;
  min-height: 54px;
  justify-content: center;
  border-radius: 8px !important;
  font-size: 15px !important;
}
.cp-order-tracking-check {
  position: absolute;
  left: -10000px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
.cp-order-tracking-result {
  display: grid;
  gap: 18px;
  margin-top: 20px;
  border: 1px solid rgba(21, 53, 72, 0.1);
  border-radius: 22px;
  padding: clamp(18px, 2vw, 26px);
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 255, 255, 0.74), transparent 42%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.64), rgba(226, 244, 249, 0.34));
}
.cp-order-tracking-result-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: start;
}
.cp-order-tracking-kicker {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 10px;
  border: 1px solid rgba(21, 53, 72, 0.12);
  border-radius: 999px;
  padding: 6px 10px;
  color: var(--cp-flow-ink, #153548);
  background: rgba(255, 255, 255, 0.62);
  font-size: 12px;
  font-weight: 900;
}
.cp-order-tracking-result h3,
.cp-order-tracking-result h4 {
  margin: 0;
  color: var(--cp-flow-ink, #153548);
}
.cp-order-tracking-result h3 {
  font-size: clamp(24px, 2.4vw, 34px);
  line-height: 1.1;
}
.cp-order-tracking-result p {
  margin: 10px 0 0;
  color: var(--cp-flow-muted, #5d737b);
  line-height: 1.65;
}
.cp-order-tracking-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  border-radius: 999px;
  padding: 0 14px;
  color: #fff;
  background: var(--cp-flow-ink, #153548);
  font-size: 13px;
  font-weight: 900;
  white-space: nowrap;
}
.cp-order-tracking-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin: 0;
}
.cp-order-tracking-meta div {
  display: grid;
  gap: 4px;
  min-width: 0;
  border: 1px solid rgba(21, 53, 72, 0.09);
  border-radius: 16px;
  padding: 12px 14px;
  background: rgba(255, 255, 255, 0.5);
}
.cp-order-tracking-meta dt {
  color: rgba(21, 53, 72, 0.62);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.cp-order-tracking-meta dd {
  margin: 0;
  color: var(--cp-flow-ink, #153548);
  font-weight: 900;
  overflow-wrap: anywhere;
}
.cp-order-tracking-items {
  display: grid;
  gap: 12px;
}
.cp-order-tracking-items ul,
.cp-order-tracking-notes ol {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.cp-order-tracking-items li {
  display: flex;
  gap: 12px;
  justify-content: space-between;
  border-top: 1px solid rgba(21, 53, 72, 0.1);
  padding-top: 10px;
  color: var(--cp-flow-ink, #153548);
}
.cp-order-tracking-items li span {
  min-width: 0;
  overflow-wrap: anywhere;
}
.cp-order-tracking-items li strong {
  flex: 0 0 auto;
}
.cp-order-tracking-notes {
  display: grid;
  gap: 12px;
}
.cp-order-tracking-notes li {
  border-left: 3px solid rgba(21, 53, 72, 0.28);
  padding-left: 12px;
}
.cp-order-tracking-notes time {
  display: block;
  margin-bottom: 4px;
  color: rgba(21, 53, 72, 0.64);
  font-size: 12px;
  font-weight: 900;
}
.cp-order-tracking-notes p {
  margin: 0;
}
.cp-order-tracking-privacy {
  border-top: 1px solid rgba(21, 53, 72, 0.1);
  padding-top: 14px;
  font-size: 13px;
}

@media (max-width: 1020px) {
.cp-login-layout,
.cp-login-layout--with-register {
    grid-template-columns: 1fr;
    max-width: 760px;
  }
.cp-login-intro {
    min-height: 360px;
  }
.cp-login-layout--with-register .cp-login-forms {
    grid-template-columns: 1fr;
  }
.cp-login-panel--track .track_order {
    grid-template-columns: 1fr;
  }
.cp-order-tracking-meta {
    grid-template-columns: 1fr;
  }
.cp-order-tracking-result-head {
    grid-template-columns: 1fr;
  }
.cp-order-tracking-status {
    justify-self: start;
  }
}

@media (max-width: 620px) {
.cp-checkout-guest-note {
    grid-template-columns: 1fr;
  }
.cp-account-shell .woocommerce,
.cp-login-layout,
.cp-login-forms,
.cp-login-intro,
.cp-login-panel {
    width: 100%;
    max-width: calc(100vw - 32px);
    min-width: 0;
  }
.cp-login-intro,
.cp-login-panel {
    padding: 24px;
  }
.cp-login-intro {
    min-height: 430px;
  }
.cp-login-brand-mark {
    top: 24px;
    right: 24px;
    width: 86px;
    height: 86px;
    opacity: 0.3;
  }
.cp-login-brand-mark .brand-logo-img {
    width: 86px;
    height: 86px;
  }
.cp-login-intro h2 {
    font-size: 32px;
    max-width: min(100%, 300px);
    word-break: break-word;
  }
.cp-login-intro p,
.cp-login-benefits {
    max-width: min(100%, 300px);
  }
.cp-login-benefits li {
    max-width: 300px;
  }
.cp-login-panel-head h2 {
    font-size: 30px;
  }
.cp-login-intro p,
.cp-login-panel-head p,
.cp-login-note {
    max-width: 100%;
  }
.cp-login-actions {
    align-items: flex-start;
    flex-direction: column;
  }
.cp-register-name-grid {
    grid-template-columns: 1fr;
  }
}
/* Card-inspired WooCommerce product archive. */
.cp-shop-shell {
  position: relative;
  max-width: none;
  padding: 0;
  overflow: hidden;
}
.cp-shop-shell::before {
  position: absolute;
  inset: 0 0 auto;
  z-index: -1;
  height: 196px;
  background:
    linear-gradient(126deg, transparent 0 11%, rgba(255, 255, 255, 0.48) 11% 16%, transparent 16% 35%, rgba(255, 255, 255, 0.52) 35% 41%, transparent 41% 62%, rgba(255, 255, 255, 0.5) 62% 68%, transparent 68%),
    linear-gradient(180deg, #edf3f5, #f8fafb);
  border-bottom: 1px solid #e3ebed;
  content: "";
}
.cp-shop-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 440px);
  gap: 40px;
  align-items: center;
  max-width: var(--max);
  margin: 0 auto;
  padding: 40px clamp(20px, 6vw, 92px) 26px;
}
.cp-shop-hero h1 {
  margin: 0;
  color: #06141b;
  font-size: clamp(42px, 4.4vw, 58px);
  line-height: 0.98;
  letter-spacing: 0;
}
.cp-shop-hero p {
  max-width: 660px;
  margin: 16px 0 0;
  color: #1d333b;
  font-size: 16px;
  line-height: 1.55;
}
.cp-shop-brand-signal {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  justify-self: end;
  width: min(100%, 380px);
  min-height: 132px;
}
.cp-shop-brand-signal::before {
  flex: 1 1 auto;
  height: 2px;
  max-width: 214px;
  margin-right: 22px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(21, 53, 72, 0), rgba(21, 53, 72, 0.38) 58%, rgba(21, 53, 72, 0.72));
  content: "";
}
.cp-shop-medallion {
  position: relative;
  flex: 0 0 auto;
  display: grid;
  width: 126px;
  height: 126px;
  place-items: center;
  filter: drop-shadow(0 16px 24px rgba(8, 40, 56, 0.16));
}
.cp-shop-medallion .brand-logo-img {
  width: 126px;
  height: 126px;
}
.cp-shop-medallion svg {
  width: 112px;
  height: 112px;
}
.cp-shop-medallion circle {
  fill: var(--navy);
  stroke: rgba(255, 255, 255, 0.16);
  stroke-width: 1;
}
.cp-shop-medallion path {
  fill: var(--green);
  stroke: #fff;
  stroke-width: 2.7;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cp-shop-medallion path:last-of-type {
  fill: none;
  stroke: #fff;
  stroke-width: 2.5;
}
.cp-shop-medallion rect {
  fill: #fff;
  stroke: #d3dde0;
  stroke-width: 1;
}
.cp-shop-medallion strong {
  position: absolute;
  right: 0;
  bottom: 31px;
  left: 0;
  color: var(--navy);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 13px;
  font-weight: 700;
  text-align: center;
}
.cp-shop-layout {
  display: grid;
  grid-template-columns: 252px minmax(0, 1fr);
  gap: 24px;
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 clamp(20px, 4vw, 58px) 46px;
}
.cp-shop-sidebar {
  display: grid;
  gap: 20px;
  align-content: start;
}
.cp-shop-category-panel,
.cp-shop-trust-panel {
  border: 1px solid #d4dee0;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 14px 34px rgba(8, 40, 56, 0.08);
  overflow: hidden;
}
.cp-shop-category-panel {
  border-color: rgba(8, 40, 56, 0.18);
  color: #eef6f3;
  background:
    radial-gradient(circle at 0% 0%, rgba(199, 149, 42, 0.12), transparent 16rem),
    linear-gradient(135deg, #082838 0%, #061923 62%, #0b3443 100%);
}
.cp-shop-category-panel h2 {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 52px;
  margin: 0;
  padding: 0 20px;
  color: #fff;
  background: linear-gradient(145deg, #062532, #082838);
  font-size: 16px;
  font-weight: 800;
}
.cp-shop-category-panel h2 svg {
  width: 23px;
  height: 23px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  opacity: 0.86;
}
.cp-shop-category-panel nav {
  display: grid;
  padding: 10px;
}
.cp-shop-category-panel nav a {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  min-height: 52px;
  padding: 0 14px 0 12px;
  border-radius: 7px;
  color: rgba(238, 246, 243, 0.84);
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
}
.cp-shop-category-panel nav a.active,
.cp-shop-category-panel nav a:hover {
  color: #d9edcf;
  background: rgba(255, 255, 255, 0.1);
  box-shadow: inset 0 0 0 1px rgba(217, 237, 207, 0.18);
}
.cp-shop-filter-icon {
  display: grid;
  width: 24px;
  height: 24px;
  place-items: center;
}
.cp-shop-filter-icon svg {
  width: 23px;
  height: 23px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cp-shop-trust-panel {
  display: grid;
  gap: 0;
  padding: 12px 18px;
}
.cp-shop-trust-panel div {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 48px;
  color: #0f252d;
  font-size: 14px;
  font-weight: 700;
}
.cp-shop-trust-panel svg {
  width: 25px;
  height: 25px;
  fill: none;
  stroke: var(--navy);
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cp-shop-main {
  min-width: 0;
}
.cp-shop-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  min-height: 64px;
  margin-bottom: 18px;
  padding: 12px 14px;
  border: 1px solid #d4dee0;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 24px rgba(8, 40, 56, 0.06);
}
.cp-shop-count {
  display: flex;
  align-items: center;
  gap: 12px;
  color: #273d45;
  font-size: 15px;
  font-weight: 700;
}
.cp-shop-grid-icon {
  display: grid;
  width: 38px;
  height: 38px;
  place-items: center;
  border: 1px solid #d9e3e0;
  border-radius: 7px;
  color: var(--navy);
  background: #f8faf9;
}
.cp-shop-grid-icon svg {
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cp-shop-sort {
  display: flex;
  align-items: center;
  gap: 12px;
  color: #344b52;
  font-size: 13px;
  font-weight: 700;
}
.cp-shop-sort .woocommerce-ordering {
  margin: 0;
}
.cp-shop-sort .cp-live-product-search {
  flex: 0 1 248px;
}
.cp-shop-sort select,
.cp-shop-sort .orderby {
  min-width: 210px;
  height: 42px;
  padding: 0 42px 0 14px;
  border: 1px solid #d4dee0;
  border-radius: 7px;
  color: #172c34;
  background: #fff;
  font-size: 14px;
  font-weight: 700;
}
.cp-shop-shell ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 236px));
  justify-content: start;
  gap: 20px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none;
}
.cp-shop-shell ul.products::before,
.cp-shop-shell ul.products::after {
  display: none !important;
}
.cp-shop-shell ul.products li.product {
  float: none !important;
  width: auto !important;
  margin: 0 !important;
}
/* Solid brand CTA buttons. */
.add-button,
.cp-purchase-panel .single_add_to_cart_button,
.cp-cart-shell .wc-block-cart__submit-button,
.cp-cart-shell .checkout-button,
.cp-checkout-shell .wc-block-components-checkout-place-order-button,
.cp-checkout-shell #place_order,
.cp-account-shell .woocommerce-info .woocommerce-Button.wc-forward,
.cp-account-shell .woocommerce-info .button.wc-forward,
.cp-account-shell .cp-login-panel--login .cp-login-submit-row .button,
.cp-account-shell .cp-login-panel--track .cp-order-tracking-submit .button,
.section-controls .text-link,
.cp-account-empty > .button,
.cp-account-dashboard .cp-outline-button,
.cp-account-details-card .cp-solid-button,
.cp-account-shell .woocommerce-Address-title .edit,
.cp-account-shell .woocommerce-EditAccountForm button.button,
.cp-account-shell .woocommerce-EditAccountForm .woocommerce-Button,
.cp-account-shell .woocommerce-EditAccountForm input.button,
.cp-account-shell .cp-login-panel--register .cp-login-submit-row .button {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  border: 1px solid rgba(199, 149, 42, 0.36) !important;
  color: #fff !important;
  background: #153548 !important;
  box-shadow: 0 16px 30px rgba(5, 31, 40, 0.22), inset 0 0 0 1px rgba(255, 255, 255, 0.08) !important;
  transition: background-position 220ms ease, box-shadow 180ms ease, filter 180ms ease, transform 160ms ease;
}
.add-button::before,
.cp-purchase-panel .single_add_to_cart_button::before,
.cp-cart-shell .wc-block-cart__submit-button::before,
.cp-cart-shell .checkout-button::before,
.cp-checkout-shell .wc-block-components-checkout-place-order-button::before,
.cp-checkout-shell #place_order::before,
.cp-account-shell .woocommerce-info .woocommerce-Button.wc-forward::before,
.cp-account-shell .woocommerce-info .button.wc-forward::before,
.cp-account-shell .cp-login-panel--login .cp-login-submit-row .button::before,
.cp-account-shell .cp-login-panel--track .cp-order-tracking-submit .button::before,
.section-controls .text-link::before,
.cp-account-empty > .button::before,
.cp-account-dashboard .cp-outline-button::before,
.cp-account-details-card .cp-solid-button::before,
.cp-account-shell .woocommerce-Address-title .edit::before,
.cp-account-shell .woocommerce-EditAccountForm button.button::before,
.cp-account-shell .woocommerce-EditAccountForm .woocommerce-Button::before,
.cp-account-shell .woocommerce-EditAccountForm input.button::before,
.cp-account-shell .cp-login-panel--register .cp-login-submit-row .button::before {
  position: absolute;
  z-index: 0;
  inset: -1px;
  background: transparent;
  content: "";
  opacity: 0;
  pointer-events: none;
  transform: translateX(-48%);
  transition: opacity 180ms ease, transform 360ms ease;
}
.add-button:hover,
.cp-purchase-panel .single_add_to_cart_button:hover,
.cp-cart-shell .wc-block-cart__submit-button:hover,
.cp-cart-shell .checkout-button:hover,
.cp-checkout-shell .wc-block-components-checkout-place-order-button:hover,
.cp-checkout-shell #place_order:hover,
.cp-account-shell .woocommerce-info .woocommerce-Button.wc-forward:hover,
.cp-account-shell .woocommerce-info .button.wc-forward:hover,
.cp-account-shell .cp-login-panel--login .cp-login-submit-row .button:hover,
.cp-account-shell .cp-login-panel--track .cp-order-tracking-submit .button:hover,
.section-controls .text-link:hover,
.cp-account-empty > .button:hover,
.cp-account-dashboard .cp-outline-button:hover,
.cp-account-details-card .cp-solid-button:hover,
.cp-account-shell .woocommerce-Address-title .edit:hover,
.cp-account-shell .woocommerce-EditAccountForm button.button:hover,
.cp-account-shell .woocommerce-EditAccountForm .woocommerce-Button:hover,
.cp-account-shell .woocommerce-EditAccountForm input.button:hover,
.cp-account-shell .cp-login-panel--register .cp-login-submit-row .button:hover {
  background: #153548 !important;
  box-shadow: 0 19px 34px rgba(5, 31, 40, 0.27), 0 0 0 1px rgba(199, 149, 42, 0.18) !important;
  filter: saturate(1.04);
  transform: translateY(-1px);
}
.section-controls .text-link,
.section-controls .text-link:hover {
  background: #153548 !important;
}
.section-controls .text-link::before,
.section-controls .text-link:hover::before {
  opacity: 0;
  transform: none;
}

@media (min-width: 821px) {
.product-card .add-button:hover,
.product-card .add-button:focus-visible {
    border: 1px solid #153548 !important;
    color: #153548 !important;
    background: #fff !important;
    box-shadow:
      inset 0 0 0 1px rgba(21, 53, 72, 0.1),
      0 16px 30px rgba(5, 31, 40, 0.18) !important;
  }
.product-card .add-button:hover::before,
.product-card .add-button:focus-visible::before {
    opacity: 0;
    transform: none;
  }
}
.add-button:hover::before,
.cp-purchase-panel .single_add_to_cart_button:hover::before,
.cp-cart-shell .wc-block-cart__submit-button:hover::before,
.cp-cart-shell .checkout-button:hover::before,
.cp-checkout-shell .wc-block-components-checkout-place-order-button:hover::before,
.cp-checkout-shell #place_order:hover::before,
.cp-account-shell .woocommerce-info .woocommerce-Button.wc-forward:hover::before,
.cp-account-shell .woocommerce-info .button.wc-forward:hover::before,
.cp-account-shell .cp-login-panel--login .cp-login-submit-row .button:hover::before,
.cp-account-shell .cp-login-panel--track .cp-order-tracking-submit .button:hover::before,
.section-controls .text-link:hover::before,
.cp-account-empty > .button:hover::before,
.cp-account-dashboard .cp-outline-button:hover::before,
.cp-account-details-card .cp-solid-button:hover::before,
.cp-account-shell .woocommerce-Address-title .edit:hover::before,
.cp-account-shell .woocommerce-EditAccountForm button.button:hover::before,
.cp-account-shell .woocommerce-EditAccountForm .woocommerce-Button:hover::before,
.cp-account-shell .woocommerce-EditAccountForm input.button:hover::before,
.cp-account-shell .cp-login-panel--register .cp-login-submit-row .button:hover::before {
  opacity: 1;
  transform: translateX(42%);
}
.add-button.is-cart-added-feedback,
.cp-mini-cart.is-cart-added-feedback,
.cp-purchase-panel .single_add_to_cart_button.is-cart-added-feedback {
  position: relative;
  overflow: hidden;
  animation: cp-add-button-cart-success 1180ms cubic-bezier(0.2, 0.82, 0.22, 1) both;
}
.add-button.is-cart-add-pending,
.add-button.is-cart-add-success,
.cp-purchase-panel .single_add_to_cart_button.is-cart-add-pending,
.cp-purchase-panel .single_add_to_cart_button.is-cart-add-success {
  cursor: default;
  user-select: none;
}
.add-button.is-cart-add-success,
.cp-purchase-panel .single_add_to_cart_button.is-cart-add-success {
  filter: saturate(1.14) brightness(1.05);
}
.add-button.is-cart-add-success span,
.cp-purchase-panel .single_add_to_cart_button.is-cart-add-success span {
  animation: cp-add-button-label-confirm 260ms cubic-bezier(0.2, 0.82, 0.22, 1) both;
}
.add-button.is-cart-add-success .cart-button-icon--check,
.cp-purchase-panel .single_add_to_cart_button.is-cart-add-success .cart-button-icon--check {
  opacity: 1;
  animation: cp-cart-check-icon-pop 360ms cubic-bezier(0.2, 0.82, 0.22, 1) both;
}
.add-button.is-cart-added-feedback::after,
.cp-mini-cart.is-cart-added-feedback::after,
.cp-purchase-panel .single_add_to_cart_button.is-cart-added-feedback::after {
  position: absolute;
  inset: -1px;
  z-index: 0;
  pointer-events: none;
  content: "";
  background:
    linear-gradient(112deg, transparent 0%, rgba(255, 255, 255, 0.72) 43%, rgba(217, 237, 207, 0.46) 56%, transparent 74%);
  opacity: 0;
  transform: translateX(-72%) skewX(-14deg);
  animation: cp-add-button-cart-shine 920ms cubic-bezier(0.2, 0.82, 0.22, 1) both;
}
.cp-purchase-panel .single_add_to_cart_button.added::after {
  display: none !important;
  content: "" !important;
}
.cp-purchase-panel .single_add_to_cart_button.is-cart-added-feedback::after {
  display: block !important;
  content: "" !important;
}
.add-button.is-cart-added-feedback > *,
.cp-mini-cart.is-cart-added-feedback > *,
.cp-purchase-panel .single_add_to_cart_button.is-cart-added-feedback > * {
  position: relative;
  z-index: 1;
}

@keyframes cp-add-button-cart-success {
  0%,
  100% {
    box-shadow: 0 16px 30px rgba(5, 31, 40, 0.22), inset 0 0 0 1px rgba(255, 255, 255, 0.08);
    filter: saturate(1);
    transform: translateY(0) scale(1);
  }

  38% {
    box-shadow:
      0 0 0 5px rgba(217, 237, 207, 0.44),
      0 0 0 9px rgba(117, 181, 203, 0.18),
      0 22px 38px rgba(5, 31, 40, 0.34),
      inset 0 0 0 1px rgba(255, 255, 255, 0.22);
    filter: saturate(1.18) brightness(1.05);
    transform: translateY(-1px) scale(1.018);
  }
}

@keyframes cp-add-button-cart-shine {
  0% {
    opacity: 0;
    transform: translateX(-72%) skewX(-14deg);
  }

  25% {
    opacity: 1;
  }

  100% {
    opacity: 0;
    transform: translateX(72%) skewX(-14deg);
  }
}

@keyframes cp-add-button-label-confirm {
  0% {
    opacity: 0.62;
    transform: translateY(2px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes cp-cart-check-icon-pop {
  0% {
    opacity: 0;
    transform: translateY(2px) scale(0.72);
  }

  58% {
    opacity: 1;
    transform: translateY(-1px) scale(1.16);
  }

  100% {
    opacity: 1;
    transform: translateY(-1px) scale(1.04);
  }
}

@media (prefers-reduced-motion: reduce) {
  .add-button.is-cart-add-success span,
  .cp-purchase-panel .single_add_to_cart_button.is-cart-add-success span,
  .add-button.is-cart-add-success .cart-button-icon--check,
  .cp-purchase-panel .single_add_to_cart_button.is-cart-add-success .cart-button-icon--check {
    animation: none;
  }
}
/* Navy depth layer for a more premium surface rhythm. */
body {
  background:
    radial-gradient(circle at 0% 18%, rgba(8, 40, 56, 0.04), transparent 18rem),
    radial-gradient(circle at 100% 42%, rgba(15, 86, 96, 0.034), transparent 20rem),
    linear-gradient(180deg, #f7faf9 0%, #ffffff 340px, #f4f8f7 100%);
}
.home-market,
.cp-shop-shell,
.cp-product-hero,
.cp-cart-shell,
.cp-checkout-shell {
  background:
    radial-gradient(circle at 8% 6%, rgba(8, 40, 56, 0.05), transparent 18rem),
    radial-gradient(circle at 92% 28%, rgba(15, 86, 96, 0.035), transparent 20rem),
    linear-gradient(180deg, rgba(248, 251, 250, 0.9) 0%, rgba(255, 255, 255, 0.86) 300px, rgba(245, 249, 248, 0.78) 100%);
}
.catalog {
  position: relative;
  background:
    linear-gradient(135deg, rgba(8, 40, 56, 0.048) 0 28%, transparent 28% 100%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.7), rgba(245, 249, 248, 0.52));
}
.product-art {
  margin: 9px 9px 0;
  border: 1px solid rgba(8, 40, 56, 0.14);
  border-radius: 8px;
  background: #f7faf9;
  box-shadow: none;
}
.product-card-body {
  margin: 9px;
  border: 1px solid rgba(8, 40, 56, 0.12);
  border-radius: 8px;
  background:
    linear-gradient(180deg, #ffffff 0%, #ffffff 50%, #f6faf8 100%);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.72),
    0 12px 24px rgba(8, 40, 56, 0.035);
}
.product-card:hover .product-art,
.product-card:hover .product-card-body {
  border-color: rgba(15, 86, 96, 0.24);
}
.order-flow {
  border-color: rgba(8, 40, 56, 0.18);
  color: #eef6f3;
  background:
    radial-gradient(circle at 18% 0%, rgba(199, 149, 42, 0.14), transparent 20rem),
    linear-gradient(135deg, #082838 0%, #061923 62%, #0b3443 100%);
  box-shadow: 0 18px 42px rgba(8, 40, 56, 0.13);
}
.order-flow h2,
.order-flow strong {
  color: #fff;
}
.order-flow p {
  color: rgba(232, 244, 240, 0.78);
}
.flow-steps span {
  border-color: rgba(217, 237, 207, 0.32);
  color: #d9edcf;
  background: rgba(255, 255, 255, 0.08);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.12);
}

@media (min-width: 821px) {
body {
    background:
      radial-gradient(circle at 0% 18%, rgba(8, 40, 56, 0.055), transparent 24rem),
      radial-gradient(circle at 100% 42%, rgba(15, 86, 96, 0.045), transparent 28rem),
      linear-gradient(180deg, #f5f8f7 0%, #ffffff 360px, #f1f6f5 100%);
  }
.site-header {
    background: rgba(250, 252, 251, 0.96);
    box-shadow: 0 12px 32px rgba(8, 40, 56, 0.055);
  }
.catalog {
    margin-top: 18px;
    margin-bottom: 22px;
    border-radius: 10px;
    background:
      linear-gradient(135deg, rgba(8, 40, 56, 0.075) 0 30%, transparent 30% 100%),
      linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(242, 247, 246, 0.56));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82), 0 24px 60px rgba(8, 40, 56, 0.055);
  }
.category-panel,
.cp-shop-toolbar,
.cp-shop-category-panel,
.cp-shop-trust-panel,
.cp-cart-service-band {
    border-color: rgba(8, 40, 56, 0.13);
    box-shadow: 0 16px 36px rgba(8, 40, 56, 0.075);
  }
.product-card {
    border-color: #153548;
    box-shadow: 0 18px 42px rgba(8, 40, 56, 0.105);
  }
.order-flow {
    box-shadow: 0 24px 58px rgba(8, 40, 56, 0.16);
  }
}
.cp-shop-placeholder {
  min-height: 432px;
  border: 2px dashed #d8e2df;
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.64), rgba(248, 250, 249, 0.64));
}
.cp-shop-shell .woocommerce-pagination {
  margin-top: 28px;
}
.cp-shop-shell .woocommerce-pagination ul {
  display: flex;
  justify-content: center;
  gap: 8px;
  border: 0 !important;
}
.cp-shop-shell .woocommerce-pagination li {
  border: 0 !important;
}
.cp-shop-shell .woocommerce-pagination a,
.cp-shop-shell .woocommerce-pagination span {
  display: grid;
  min-width: 38px;
  height: 38px;
  place-items: center;
  border: 1px solid #d4dee0;
  border-radius: 7px;
  color: var(--navy);
  background: #fff;
  font-weight: 700;
}
.cp-shop-shell .woocommerce-pagination span.current {
  color: #fff;
  background: #153548;
}
.cp-shop-empty {
  padding: 28px;
  border: 1px dashed #cbd8d4;
  border-radius: 8px;
  background: #fff;
}

@media (max-width: 1180px) {
.cp-shop-layout {
    grid-template-columns: 240px minmax(0, 1fr);
    gap: 22px;
  }
.cp-shop-shell ul.products {
    grid-template-columns: repeat(2, minmax(0, 236px));
  }
}

@media (max-width: 820px) {
.cp-shop-shell::before {
    height: 260px;
  }
.cp-shop-hero,
.cp-shop-layout {
    grid-template-columns: 1fr;
  }
.cp-shop-brand-signal {
    justify-self: start;
    justify-content: flex-start;
    width: min(100%, 360px);
  }
.cp-shop-sidebar {
    order: 2;
  }
.cp-shop-main {
    order: 1;
  }
.cp-shop-toolbar {
    align-items: flex-start;
    flex-direction: column;
  }
.cp-shop-sort {
    width: 100%;
    flex-wrap: wrap;
  }
.cp-shop-sort .woocommerce-ordering,
.cp-shop-sort select,
.cp-shop-sort .cp-live-product-search {
    flex: 1 1 180px;
  }
.cp-shop-shell ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 520px) {
.cp-shop-hero h1 {
    font-size: 40px;
  }
.cp-shop-brand-signal {
    min-height: 112px;
  }
.cp-shop-brand-signal::before {
    max-width: 150px;
    margin-right: 16px;
  }
.cp-shop-medallion,
.cp-shop-medallion .brand-logo-img {
    width: 104px;
    height: 104px;
  }
.cp-shop-shell ul.products {
    grid-template-columns: minmax(0, 340px);
  }
.cp-shop-placeholder {
    display: none !important;
  }
}
.cp-contact-card {
  position: relative;
  min-height: 380px;
  border-radius: 8px;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 40%, rgba(218, 172, 66, 0.16), transparent 28%),
    linear-gradient(135deg, #082838 0%, #061923 58%, #f4f6f3 58%, #ffffff 100%);
  box-shadow: 0 28px 64px rgba(8, 40, 56, 0.18);
}
.cp-contact-layout {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  max-width: 1220px;
  margin: 0 auto;
  padding: 0 clamp(20px, 4vw, 42px) 72px;
}
.cp-contact-list,
.cp-contact-note {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-soft);
}
.cp-contact-note h2 {
  margin: 0 0 12px;
  color: var(--ink);
  font-size: 24px;
  line-height: 1.15;
}
.cp-contact-note p {
  margin: 0;
  color: #52666d;
  font-size: 15px;
  line-height: 1.75;
}
/* About page: homepage-inspired ice-blue glass surface. */
.cp-about-page {
  --cp-about-ink: #153548;
  --cp-about-muted: #425d68;
  --cp-about-line: rgba(255, 255, 255, 0.68);
  --cp-about-glass: rgba(255, 255, 255, 0.58);
  --cp-about-glass-soft: rgba(226, 244, 249, 0.48);
  position: relative;
  isolation: isolate;
  overflow: hidden;
  min-height: 100vh;
  padding: clamp(30px, 3.6vw, 58px) 0 72px;
  color: var(--cp-about-ink);
  background:
    linear-gradient(180deg, rgba(229, 244, 248, 0.62) 0%, rgba(238, 248, 250, 0.86) 42%, rgba(247, 251, 252, 1) 100%),
    url("../images/backgrounds/home-background-desktop.jpg") center 68% / cover no-repeat,
    linear-gradient(135deg, #e0f0f4 0%, #f5fbfc 54%, #e6f2f6 100%);
}
.cp-about-page::before {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(circle at 11% 8%, rgba(255, 255, 255, 0.64), transparent 18rem),
    radial-gradient(circle at 88% 12%, rgba(110, 176, 193, 0.22), transparent 23rem),
    radial-gradient(circle at 58% 56%, rgba(21, 53, 72, 0.08), transparent 28rem),
    repeating-linear-gradient(103deg, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px 78px);
  content: "";
}
.cp-about-hero,
.cp-about-identity,
.cp-about-principles,
.cp-about-process {
  width: calc(100% - clamp(28px, 5vw, 72px));
  max-width: 1560px;
  margin-inline: auto;
}
.cp-about-hero {
  display: grid;
  grid-template-columns: minmax(0, 0.96fr) minmax(360px, 0.58fr);
  gap: clamp(20px, 2.8vw, 42px);
  align-items: stretch;
  min-height: clamp(310px, 26vw, 420px);
  border: 1px solid var(--cp-about-line);
  border-radius: clamp(28px, 3vw, 44px);
  padding: clamp(24px, 3.2vw, 48px);
  overflow: hidden;
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 255, 255, 0.72), transparent 32%),
    radial-gradient(circle at 82% 14%, rgba(255, 255, 255, 0.46), transparent 26%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.58), rgba(226, 244, 249, 0.32));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.76),
    0 18px 42px rgba(21, 53, 72, 0.08);
}
.cp-about-hero-copy {
  display: grid;
  align-content: center;
  justify-items: start;
  min-width: 0;
}
.cp-about-kicker,
.cp-about-section-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
  color: rgba(21, 53, 72, 0.74);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.cp-about-kicker::before,
.cp-about-section-label::before {
  width: 34px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #153548, rgba(21, 53, 72, 0.78));
  content: "";
}
.cp-about-section-label--with-icon {
  gap: 9px;
}
.cp-about-section-label--with-icon::before {
  display: none;
}
.cp-about-section-icon {
  width: 24px;
  height: 24px;
  flex: 0 0 auto;
  border: 1px solid rgba(21, 53, 72, 0.18);
  border-radius: 999px;
  padding: 4px;
  color: #153548;
  background:
    radial-gradient(circle at 35% 20%, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.32) 58%, rgba(226, 244, 249, 0.2) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 6px 14px rgba(21, 53, 72, 0.08);
}
.cp-about-section-icon path,
.cp-about-section-icon circle {
  fill: currentColor;
}
.cp-about-hero h1 {
  max-width: 760px;
  margin: 0;
  color: var(--cp-about-ink);
  font-size: clamp(46px, 5.4vw, 82px);
  line-height: 0.96;
  letter-spacing: -0.055em;
}
.cp-about-hero p {
  max-width: 690px;
  margin: 18px 0 0;
  color: var(--cp-about-muted);
  font-size: clamp(16px, 1.16vw, 20px);
  line-height: 1.62;
}
.cp-about-hero-story {
  display: grid;
  gap: 14px;
  width: min(100%, 960px);
  margin-top: 18px;
}
.cp-about-hero-story p {
  max-width: none;
  margin: 0;
  color: rgba(21, 53, 72, 0.76);
  font-size: clamp(15px, 0.95vw, 17px);
  font-weight: 600;
  line-height: 1.72;
}
.cp-about-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}
.cp-about-actions .button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  border: 1px solid rgba(21, 53, 72, 0.28);
  border-radius: 14px;
  padding: 0 22px;
  color: #fff;
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.14), transparent 38%),
    linear-gradient(135deg, #051f28 0%, #08313d 52%, #153548 100%);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.09),
    0 12px 24px rgba(5, 31, 40, 0.16);
  font-weight: 900;
  text-decoration: none;
}
.cp-about-actions .button:not(.secondary):hover,
.cp-about-actions .button:not(.secondary):focus-visible {
  color: #fff;
  border-color: rgba(21, 53, 72, 0.34);
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.18), transparent 40%),
    linear-gradient(135deg, #062634 0%, #0a3a43 50%, #153548 100%);
}
.cp-about-actions .button.secondary {
  border-color: rgba(21, 53, 72, 0.2);
  color: var(--cp-about-ink);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.66), rgba(226, 244, 249, 0.34));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 10px 22px rgba(21, 53, 72, 0.06);
}
.cp-about-showcase {
  position: relative;
  isolation: isolate;
  display: grid;
  align-content: center;
  justify-items: center;
  min-height: 100%;
  padding: clamp(22px, 2.4vw, 34px);
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: clamp(24px, 2.5vw, 34px);
  overflow: hidden;
  text-align: center;
  background:
    radial-gradient(circle at 50% 28%, rgba(255, 255, 255, 0.76), transparent 30%),
    radial-gradient(circle at 58% 76%, rgba(21, 53, 72, 0.12), transparent 32%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.44), rgba(219, 240, 246, 0.34));
}
.cp-about-showcase::before,
.cp-about-showcase::after {
  position: absolute;
  pointer-events: none;
  content: "";
}
.cp-about-showcase::before {
  inset: 12%;
  z-index: -1;
  border: 1px solid rgba(255, 255, 255, 0.58);
  border-radius: 999px;
}
.cp-about-showcase::after {
  right: -20%;
  bottom: -20%;
  z-index: -1;
  width: 62%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(72, 120, 56, 0.16), transparent 62%);
}
.cp-about-brand-logo {
  display: grid;
  width: clamp(108px, 8.3vw, 146px);
  height: auto;
  place-items: center;
  margin: 0 0 14px;
  filter: none;
}
.cp-about-encay-logo {
  position: relative;
  z-index: 1;
  display: grid;
  width: min(310px, 82%);
  max-width: 100%;
  aspect-ratio: 1151 / 588;
  place-items: center;
  margin: clamp(24px, 2.4vw, 34px) auto 0;
  padding: 0;
}
.cp-about-encay-logo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: none;
}
.cp-about-brand-logo img,
.cp-about-brand-logo .brand-logo-img,
.brand-logo-img--about {
  width: 100%;
  height: auto;
  object-fit: contain;
}
.cp-about-showcase strong {
  max-width: 360px;
  color: var(--cp-about-ink);
  font-size: clamp(23px, 1.82vw, 31px);
  font-weight: 900;
  line-height: 1.05;
  text-wrap: balance;
}
.cp-about-showcase small {
  max-width: 310px;
  margin-top: 9px;
  color: var(--cp-about-muted);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.5;
  text-wrap: balance;
}
.cp-about-brand-lines {
  display: grid;
  gap: 8px;
  width: min(220px, 70%);
  margin-top: 18px;
}
.cp-about-brand-lines span {
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, rgba(21, 53, 72, 0.72), rgba(21, 53, 72, 0.42), transparent);
}
.cp-about-brand-lines span:last-child {
  width: 72%;
  margin-inline: auto;
  opacity: 0.52;
}
.cp-about-identity {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.52fr);
  gap: 22px;
  margin-top: 22px;
}
.cp-about-story-card,
.cp-about-info-card,
.cp-about-principle,
.cp-about-process {
  border: 1px solid rgba(255, 255, 255, 0.68);
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 255, 255, 0.66), transparent 34%),
    linear-gradient(145deg, var(--cp-about-glass), var(--cp-about-glass-soft));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.76),
    0 12px 26px rgba(21, 53, 72, 0.075);
}
.cp-about-story-card {
  min-height: 224px;
  border-radius: 26px;
  padding: clamp(22px, 2.6vw, 34px);
}
.cp-about-story-card h2,
.cp-about-process h2 {
  max-width: 980px;
  margin: 0;
  color: var(--cp-about-ink);
  font-size: clamp(26px, 2.25vw, 38px);
  line-height: 1.08;
  letter-spacing: -0.035em;
}
.cp-about-story-card p,
.cp-about-principle p,
.cp-about-steps small {
  color: var(--cp-about-muted);
  line-height: 1.72;
}
.cp-about-story-card p {
  max-width: 920px;
  margin: 14px 0 0;
  font-size: 15px;
}
.cp-about-story-mobile-copy {
  display: none;
}
.cp-about-info-card {
  display: grid;
  gap: 9px;
  align-content: start;
  border-radius: 26px;
  padding: 16px;
}
.cp-about-info-card div {
  display: grid;
  gap: 4px;
  min-height: 60px;
  align-content: center;
  border: 1px solid rgba(255, 255, 255, 0.58);
  border-radius: 18px;
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.44);
}
.cp-about-info-card span {
  color: rgba(21, 53, 72, 0.62);
  font-size: 12px;
  font-weight: 800;
}
.cp-about-info-card strong {
  color: var(--cp-about-ink);
  font-size: 15px;
  line-height: 1.35;
}
.cp-about-info-card a {
  color: inherit;
}
.cp-about-principles {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 22px;
}
.cp-about-principle {
  min-height: 182px;
  border-radius: 24px;
  padding: 20px;
}
.cp-about-principle span {
  display: inline-grid;
  width: 38px;
  height: 38px;
  place-items: center;
  border: 1px solid rgba(21, 53, 72, 0.16);
  border-radius: 50%;
  color: #fff;
  background: #153548;
  font-size: 13px;
  font-weight: 900;
}
.cp-about-principle h2 {
  margin: 18px 0 8px;
  color: var(--cp-about-ink);
  font-size: 20px;
  line-height: 1.16;
}
.cp-about-principle p {
  margin: 0;
  font-size: 15px;
}
.cp-about-process {
  margin-top: 22px;
  border-radius: 28px;
  padding: clamp(22px, 2.4vw, 32px);
}
.cp-about-process-head {
  max-width: 900px;
}
.cp-about-steps {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin: 24px 0 0;
  padding: 0;
  isolation: isolate;
  list-style: none;
}
.cp-about-steps::before {
  display: none;
  content: none;
}
.cp-about-steps li {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 10px;
  align-content: start;
  min-height: 138px;
  border: 1px solid rgba(255, 255, 255, 0.58);
  border-radius: 22px;
  padding: 14px;
  background: rgba(255, 255, 255, 0.46);
}
.cp-about-steps li:not(:last-child)::after {
  display: none;
  content: none;
}
.cp-about-steps span {
  position: relative;
  z-index: 1;
  display: inline-grid;
  width: 34px;
  height: 34px;
  place-items: center;
  border-radius: 50%;
  color: #fff;
  background:
    radial-gradient(circle at 32% 18%, rgba(255, 255, 255, 0.18), transparent 34%),
    linear-gradient(135deg, #051f28, #08313d 55%, #153548);
  box-shadow: 0 10px 20px rgba(21, 53, 72, 0.14);
  font-size: 13px;
  font-weight: 900;
}
.cp-about-steps strong {
  color: var(--cp-about-ink);
  font-size: 15px;
  line-height: 1.2;
}
.cp-about-steps small {
  font-size: 12.5px;
}

@media (max-width: 1180px) {
.cp-about-hero {
    grid-template-columns: 1fr;
  }
.cp-about-showcase {
    min-height: 360px;
  }
.cp-about-identity {
    grid-template-columns: 1fr;
  }
.cp-about-info-card {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
.cp-about-page {
    padding-top: 24px;
    background:
      linear-gradient(180deg, rgba(8, 44, 62, 0.18) 0%, rgba(51, 111, 132, 0.11) 25%, rgba(225, 241, 246, 0.76) 52%, rgba(238, 247, 249, 0.96) 100%),
      url("../images/backgrounds/home-background-desktop.jpg") center 56% / auto 520px no-repeat,
      linear-gradient(135deg, #dbeef4 0%, #eef7fa 42%, #d7e9ef 100%);
  }
.cp-about-hero,
.cp-about-identity,
.cp-about-principles,
.cp-about-process {
    width: calc(100% - 28px);
  }
.cp-about-hero {
    min-height: 0;
    border-radius: 28px;
    padding: 24px;
  }
.cp-about-hero h1 {
    font-size: clamp(42px, 11vw, 62px);
  }
.cp-about-hero p {
    font-size: 16px;
  }
.cp-about-showcase {
    min-height: 280px;
  }
.cp-about-encay-logo {
    width: min(286px, 84%);
  }
.cp-about-principles,
.cp-about-steps {
    grid-template-columns: 1fr;
  }
.cp-about-steps::before {
    display: none;
    content: none;
  }
.cp-about-steps li {
    min-height: 0;
    padding-left: 64px;
  }
.cp-about-steps li:not(:last-child)::after {
    display: none;
    content: none;
  }
.cp-about-steps span {
    position: absolute;
    top: 16px;
    left: 16px;
  }
}

@media (max-width: 620px) {
.cp-about-page {
    padding-bottom: 58px;
  }
.cp-about-hero {
    padding: 22px;
  }
.cp-about-kicker,
.cp-about-section-label {
    font-size: 11px;
    letter-spacing: 0.07em;
  }
.cp-about-actions {
    display: grid;
    grid-template-columns: 1fr;
    width: 100%;
  }
.cp-about-actions .button {
    width: 100%;
  }
.cp-about-showcase {
    min-height: 230px;
  }
.cp-about-encay-logo {
    width: min(244px, 86%);
    margin-top: 20px;
  }
.cp-about-brand-logo {
    width: 94px;
  }
.cp-about-info-card {
    grid-template-columns: 1fr;
  }
.cp-about-story-card,
.cp-about-info-card,
.cp-about-principle,
.cp-about-process {
    border-radius: 22px;
  }
.cp-about-story-card,
.cp-about-process {
    padding: 20px;
  }
.cp-about-story-card h2,
.cp-about-process h2 {
    font-size: clamp(25px, 8vw, 34px);
  }
}

@media (min-width: 621px) {
  .cp-about-identity,
  .cp-about-principles,
  .cp-about-process {
    display: none;
  }
}
.cp-contact-hero {
  grid-template-columns: minmax(0, 1fr) minmax(320px, 440px);
}
.cp-contact-card {
  isolation: isolate;
  display: grid;
  grid-auto-rows: max-content;
  gap: 10px;
  align-content: center;
  min-height: 320px;
  place-items: center;
  padding: 34px;
  text-align: center;
  background:
    radial-gradient(circle at 50% 35%, rgba(72, 120, 56, 0.2), transparent 31%),
    linear-gradient(145deg, #0a3443 0%, #061e29 68%, #04171f 100%);
}
.cp-contact-card::before {
  position: absolute;
  inset: 0 0 0 auto;
  z-index: -1;
  width: 20%;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(240, 244, 241, 0.88));
  clip-path: polygon(72% 0, 100% 0, 100% 100%, 0 100%);
  content: "";
  opacity: 0.92;
}
.cp-contact-logo {
  display: grid;
  width: 156px;
  height: 156px;
  place-items: center;
  margin-bottom: 6px;
  color: #d9edcf;
  filter: drop-shadow(0 18px 28px rgba(4, 18, 24, 0.28));
}
.cp-contact-logo img {
  width: 156px;
  height: 156px;
}

@media (max-width: 820px) {
.brand-logo-img--header {
    width: 72px;
    height: 72px;
    transform: scale(1.16);
  }
}
.cp-contact-card strong {
  position: relative;
  z-index: 1;
  max-width: 320px;
  color: #fff;
  font-size: 26px;
  font-weight: 800;
  line-height: 1.12;
  text-wrap: balance;
}
.cp-contact-card small {
  position: relative;
  z-index: 1;
  max-width: 250px;
  color: rgba(255, 255, 255, 0.78);
  font-size: 13px;
  font-weight: 500;
  line-height: 1.45;
  text-wrap: balance;
}
.cp-contact-layout {
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.62fr);
  align-items: start;
}
.cp-contact-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  overflow: hidden;
}
.cp-contact-list article {
  display: grid;
  gap: 8px;
  min-height: 132px;
  padding: 24px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.cp-contact-list article:nth-child(2n),
.cp-contact-list article:last-child {
  border-right: 0;
}
.cp-contact-list article:nth-last-child(-n + 1) {
  border-bottom: 0;
}
.cp-contact-list span {
  color: var(--green);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.cp-contact-list strong {
  color: var(--ink);
  font-size: 19px;
  line-height: 1.35;
}
.cp-contact-note {
  padding: 30px;
}
.cp-contact-legal-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px !important;
}
.cp-contact-legal-links a {
  display: inline-flex;
  padding: 9px 12px;
  border: 1px solid rgba(8, 49, 61, 0.16);
  border-radius: 999px;
  color: #08313d;
  background: #f4f8f5;
  font-size: 12px;
  font-weight: 700;
}
/* Legal and policy pages. */
.cp-legal-page {
  min-height: 70vh;
  padding-bottom: 88px;
  background: #f5f8f7;
}
.cp-legal-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 720px) minmax(320px, 420px);
  gap: clamp(32px, 5vw, 76px);
  justify-content: center;
  align-items: center;
  min-height: 350px;
  padding: clamp(52px, 6vw, 78px) max(24px, calc((100vw - 1240px) / 2));
  overflow: hidden;
  border-bottom: 1px solid rgba(8, 49, 61, 0.1);
  background:
    linear-gradient(124deg, rgba(238, 245, 242, 0.98) 0 61%, rgba(255, 255, 255, 0.98) 61% 100%);
}
.cp-legal-hero::before {
  position: absolute;
  inset: 0 auto 0 0;
  width: min(42vw, 620px);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.7), transparent 68%);
  clip-path: polygon(0 0, 74% 0, 42% 100%, 0 100%);
  content: "";
  pointer-events: none;
}
.cp-legal-hero-copy,
.cp-legal-seller-card {
  position: relative;
  z-index: 1;
}
.cp-legal-hero h1 {
  max-width: 720px;
  margin: 0 0 18px;
  color: var(--ink);
  font-size: clamp(38px, 4vw, 58px);
  line-height: 1.06;
  letter-spacing: 0;
  text-wrap: balance;
}
.cp-legal-hero p {
  max-width: 650px;
  margin: 0 0 18px;
  color: #52666d;
  font-size: 18px;
  line-height: 1.7;
}
.cp-legal-seller-card {
  display: grid;
  gap: 18px;
  padding: 28px;
  border: 1px solid rgba(199, 149, 42, 0.34);
  border-radius: 8px;
  color: rgba(255, 255, 255, 0.78);
  background: linear-gradient(135deg, #061f2a 0%, #0a3942 58%, #2f6725 120%);
  box-shadow: 0 24px 52px rgba(5, 31, 40, 0.2);
}
.cp-legal-seller-heading {
  display: grid;
  grid-template-columns: 66px minmax(0, 1fr);
  gap: 15px;
  align-items: center;
  padding-bottom: 17px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.14);
}
.cp-legal-seller-logo {
  width: 66px;
  height: 66px;
  filter: drop-shadow(0 10px 18px rgba(1, 12, 16, 0.26));
}
.cp-legal-seller-heading span {
  display: block;
  margin-bottom: 5px;
  color: #cfe3c6;
  font-size: 11px;
  font-weight: 700;
}
.cp-legal-seller-card strong {
  display: block;
  color: #fff;
  font-size: 16px;
  line-height: 1.35;
  text-wrap: balance;
}
.cp-legal-seller-details {
  display: grid;
  gap: 8px;
}
.cp-legal-seller-details span,
.cp-legal-seller-details a {
  color: rgba(255, 255, 255, 0.78);
  font-size: 13px;
  line-height: 1.55;
  overflow-wrap: anywhere;
}
.cp-legal-seller-details a {
  width: fit-content;
  color: #fff;
  font-weight: 700;
  text-decoration: underline;
  text-decoration-color: rgba(199, 149, 42, 0.48);
  text-underline-offset: 3px;
}
.cp-legal-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 30px;
  align-items: start;
  max-width: 1240px;
  margin: 0 auto;
  padding: 42px clamp(20px, 4vw, 42px) 0;
}
.cp-legal-content {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 20px 52px rgba(8, 40, 56, 0.09);
}
.cp-legal-content section {
  position: relative;
  padding: 34px 40px 36px 48px;
  border-bottom: 1px solid var(--line);
  scroll-margin-top: 120px;
}
.cp-legal-content section:last-child {
  border-bottom: 0;
}
.cp-legal-content section::before {
  position: absolute;
  top: 38px;
  left: 24px;
  width: 3px;
  height: 30px;
  border-radius: 2px;
  background: linear-gradient(180deg, #153548, rgba(21, 53, 72, 0.62));
  content: "";
}
.cp-legal-content h2 {
  margin: 0 0 15px;
  color: var(--ink);
  font-size: 22px;
  line-height: 1.28;
  text-wrap: balance;
}
.cp-legal-content p,
.cp-legal-content li {
  color: #40575f;
  font-size: 15px;
  line-height: 1.82;
}
.cp-legal-content p {
  margin: 0 0 15px;
}
.cp-legal-content p:last-child {
  margin-bottom: 0;
}
.cp-legal-content ul {
  display: grid;
  gap: 8px;
  margin: 0 0 16px;
  padding-left: 22px;
}
.cp-legal-content li::marker {
  color: #487838;
}
.cp-legal-content a {
  color: #0a4650;
  font-weight: 800;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.cp-legal-content .cp-legal-notice {
  background: linear-gradient(135deg, #eef6f0, #fbfcfb);
}
.cp-legal-content .cp-legal-notice::before {
  background: linear-gradient(180deg, #153548, rgba(21, 53, 72, 0.62));
}
.cp-legal-table-wrap {
  max-width: 100%;
  overflow-x: auto;
  margin: 4px 0 20px;
  border: 1px solid var(--line);
  border-radius: 8px;
}
.cp-legal-content table {
  width: 100%;
  min-width: 620px;
  border-collapse: collapse;
}
.cp-legal-content th,
.cp-legal-content td {
  padding: 14px 15px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  color: #40575f;
  text-align: left;
  vertical-align: top;
  font-size: 13px;
  line-height: 1.5;
}
.cp-legal-content th {
  color: var(--ink);
  background: #eef4f1;
  font-weight: 800;
}
.cp-legal-content th:last-child,
.cp-legal-content td:last-child {
  border-right: 0;
}
.cp-legal-content tbody tr:last-child td {
  border-bottom: 0;
}
.cp-legal-navigation {
  position: sticky;
  top: 126px;
  display: grid;
  gap: 7px;
  padding: 22px;
  border: 1px solid rgba(8, 49, 61, 0.12);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(8, 40, 56, 0.08);
}
.cp-legal-navigation h2 {
  margin: 0 0 11px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
  color: var(--ink);
  font-size: 18px;
}
.cp-legal-navigation a {
  display: block;
  padding: 11px 13px;
  border: 1px solid transparent;
  border-radius: 6px;
  color: #40575f;
  font-size: 13px;
  font-weight: 780;
  line-height: 1.4;
}
.cp-legal-navigation a:hover {
  color: #08313d;
  background: #f2f7f3;
  border-color: rgba(72, 120, 56, 0.16);
}
.cp-legal-navigation a.is-current {
  color: #fff;
  background: #153548;
  box-shadow: inset 0 0 0 1px rgba(199, 149, 42, 0.28);
}

@media (max-width: 980px) {
.cp-contact-hero,
.cp-contact-layout {
    grid-template-columns: 1fr;
  }
.cp-legal-hero,
.cp-legal-layout {
    grid-template-columns: 1fr;
  }
.cp-legal-hero {
    min-height: 0;
    padding-right: clamp(24px, 6vw, 54px);
    padding-left: clamp(24px, 6vw, 54px);
  }
.cp-legal-layout {
    gap: 22px;
  }
.cp-legal-navigation {
    position: static;
    order: -1;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
.cp-legal-navigation h2 {
    grid-column: 1 / -1;
  }
}

@media (max-width: 620px) {
.cp-contact-card {
    min-height: 280px;
  }
.cp-contact-card {
    padding: 30px 24px;
  }
.cp-contact-card::before {
    width: 13%;
  }
.cp-contact-list {
    grid-template-columns: 1fr;
  }
.cp-contact-list article,
.cp-contact-list article:nth-child(2n) {
    border-right: 0;
  }
.cp-legal-page {
    padding-bottom: 48px;
  }
.cp-legal-hero {
    gap: 28px;
    padding-top: 42px;
    padding-bottom: 42px;
    background: linear-gradient(145deg, #eef5f2 0 72%, #fff 72% 100%);
  }
.cp-legal-hero h1 {
    font-size: 36px;
  }
.cp-legal-hero p {
    font-size: 16px;
    line-height: 1.65;
  }
.cp-legal-seller-card {
    padding: 22px;
  }
.cp-legal-seller-heading {
    grid-template-columns: 58px minmax(0, 1fr);
  }
.cp-legal-seller-logo {
    width: 58px;
    height: 58px;
  }
.cp-legal-layout {
    padding-top: 24px;
  }
.cp-legal-content section {
    padding: 28px 22px 30px 34px;
  }
.cp-legal-content section::before {
    top: 31px;
    left: 17px;
    height: 26px;
  }
.cp-legal-content h2 {
    font-size: 20px;
  }
.cp-legal-content p,
.cp-legal-content li {
    font-size: 15px;
    line-height: 1.75;
  }
.cp-legal-navigation {
    grid-template-columns: none;
    grid-auto-flow: column;
    grid-auto-columns: minmax(168px, 0.78fr);
    overflow-x: auto;
    padding: 14px;
    scrollbar-width: thin;
    overscroll-behavior-inline: contain;
  }
.cp-legal-navigation h2 {
    display: none;
  }
.cp-legal-navigation a {
    display: grid;
    min-height: 48px;
    place-items: center;
    padding: 9px 12px;
    text-align: center;
  }
.cp-checkout-legal {
    padding: 15px;
  }
}
/* Glass readability pass: frosted light surfaces need dark text,
not the old dark-panel white copy. */
.category-panel,
.category-panel h2,
.category-button,
.cp-shop-category-panel,
.cp-shop-category-panel h2,
.cp-shop-category-panel nav a {
  color: #153548;
}
.category-button,
.cp-shop-category-panel nav a {
  border-color: rgba(21, 53, 72, 0.14);
  background: rgba(255, 255, 255, 0.62);
}
.category-button:hover,
.cp-shop-category-panel nav a:hover {
  color: #153548;
  border-color: rgba(21, 53, 72, 0.24);
  background: rgba(255, 255, 255, 0.82);
}
.category-button.active,
.category-button[aria-pressed="true"],
.category-button.active:hover,
.category-button[aria-pressed="true"]:hover,
.cp-shop-category-panel nav a.active,
.cp-shop-category-panel nav a.active:hover {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.34);
  background: #153548;
}

@media (max-width: 1360px) and (min-width: 821px) {
.site-header {
    grid-template-columns: auto minmax(260px, 1fr) auto;
    grid-template-areas:
      "brand search actions"
      "nav nav nav";
    row-gap: 10px;
  }
.brand {
    grid-area: brand;
  }
.header-actions {
    grid-area: actions;
    justify-self: end;
  }
.main-nav {
    position: static;
    grid-area: nav;
    display: flex;
    width: 100%;
    justify-content: center;
    transform: none;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
}

@media (max-width: 820px) {
.main-nav a {
    color: #153548;
    border-color: rgba(255, 255, 255, 0.28);
    background: rgba(255, 255, 255, 0.76);
  }
.main-nav a:hover {
    color: #153548;
    border-color: rgba(255, 255, 255, 0.46);
    background: rgba(255, 255, 255, 0.92);
  }
.main-nav a.is-active,
.main-nav a[aria-current="page"],
.main-nav a.is-active:hover,
.main-nav a[aria-current="page"]:hover {
    color: #fff;
    border-color: rgba(199, 149, 42, 0.62);
    background: #153548;
  }
}
/* Home concept fidelity pass: match the accepted glassy storefront concept more closely. */
.brand-name {
  display: inline-block;
  color: #153548;
  font-size: 25px;
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
}
body.home .top-strip {
  display: none;
}
body.home {
  position: relative;
  background:
    linear-gradient(118deg, rgba(21, 53, 72, 0.07) 0 12%, transparent 12% 100%),
    linear-gradient(180deg, #edf6f4 0%, #f8fcfb 44%, #ffffff 100%);
}
body.home::before {
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    linear-gradient(112deg, transparent 0 12%, rgba(72, 120, 56, 0.16) 12% 15%, transparent 15% 100%),
    linear-gradient(138deg, transparent 0 63%, rgba(21, 53, 72, 0.08) 63% 65%, transparent 65% 100%),
    repeating-linear-gradient(72deg, rgba(72, 120, 56, 0.07) 0 1px, transparent 1px 94px),
    linear-gradient(90deg, rgba(72, 120, 56, 0.16), transparent 22%, transparent 74%, rgba(72, 120, 56, 0.12)),
    linear-gradient(180deg, rgba(255, 255, 255, 0.42), rgba(255, 255, 255, 0));
  filter: blur(16px);
  opacity: 0.74;
  content: "";
}
body.home .site-header {
  top: 16px;
  width: auto;
  margin: 16px clamp(18px, 1.45vw, 24px) 0;
  grid-template-columns: minmax(260px, auto) minmax(360px, 1fr) minmax(280px, 360px) auto;
  padding: 9px clamp(22px, 3vw, 40px);
  border: 1px solid rgba(255, 255, 255, 0.58);
  border-radius: 13px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.4), rgba(255, 255, 255, 0.12));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.78),
    inset 0 -1px 0 rgba(255, 255, 255, 0.18),
    0 18px 52px rgba(21, 53, 72, 0.12);
  backdrop-filter: blur(30px) saturate(1.34);
}
body.home .brand {
  gap: 14px;
}
body.home .brand-logo-img--header {
  width: 46px;
  height: 46px;
  transform: none;
}
body.home .main-nav {
  position: static;
  left: auto;
  top: auto;
  justify-self: center;
  width: auto;
  gap: clamp(18px, 2vw, 34px);
  font-size: 16px;
  font-weight: 800;
  transform: none;
}
body.home .main-nav a {
  min-height: 40px;
  padding: 0 4px;
  border: 0;
  border-radius: 0;
  color: #153548;
  background: transparent;
  box-shadow: none;
}
body.home .main-nav a::before {
  display: none;
}
body.home .main-nav a:hover,
body.home .main-nav a.is-active,
body.home .main-nav a[aria-current="page"],
body.home .main-nav a.is-active:hover,
body.home .main-nav a[aria-current="page"]:hover {
  color: #153548;
  background: transparent;
  box-shadow: none;
  transform: none;
}
body.home .icon-button,
body.home .cart-button {
  border-color: rgba(255, 255, 255, 0.5);
  background: rgba(255, 255, 255, 0.32);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.7),
    0 10px 24px rgba(21, 53, 72, 0.08);
  backdrop-filter: blur(22px) saturate(1.16);
}
body.home .home-market {
  position: relative;
  margin-top: -92px;
  padding: 126px clamp(18px, 4vw, 70px) 82px;
  overflow: hidden;
  background:
    linear-gradient(116deg, rgba(72, 120, 56, 0.13) 0 8%, transparent 8% 100%),
    linear-gradient(132deg, transparent 0 31%, rgba(255, 255, 255, 0.32) 31% 46%, transparent 46% 100%),
    linear-gradient(180deg, rgba(232, 244, 242, 0.9), rgba(247, 251, 250, 0.42) 68%, rgba(255, 255, 255, 0));
}
body.home .home-market::before {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(82deg, transparent 0 4%, rgba(72, 120, 56, 0.2) 4% 6%, transparent 6% 100%),
    linear-gradient(102deg, transparent 0 16%, rgba(72, 120, 56, 0.14) 16% 18%, transparent 18% 100%),
    linear-gradient(90deg, rgba(72, 120, 56, 0.2), transparent 18%),
    linear-gradient(270deg, rgba(72, 120, 56, 0.13), transparent 22%);
  content: "";
  filter: blur(18px);
  opacity: 0.68;
}
body.home .home-market-grid {
  position: relative;
  z-index: 1;
  max-width: 1560px;
}
body.home .home-market .hero {
  display: grid;
  grid-template-columns: minmax(390px, 0.43fr) minmax(0, 0.57fr);
  gap: clamp(38px, 5vw, 74px);
  align-items: center;
  min-height: 452px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}
body.home .hero-slider {
  min-height: 444px;
  border: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}
body.home .hero-slider::before,
body.home .hero-slider::after,
body.home .hero-slider-viewport,
body.home .hero-slider-controls,
body.home .hero-slider-dots {
  display: none;
}
body.home .catalog {
  position: relative;
  isolation: isolate;
  z-index: 4;
  width: calc(100% - clamp(36px, 8vw, 140px));
  max-width: 1560px;
  margin-top: -54px;
  padding: 0 clamp(16px, 2.2vw, 34px) 34px;
  border: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}
body.home .catalog::before {
  position: absolute;
  inset: 34px 0 0;
  z-index: 0;
  pointer-events: none;
  border: 1px solid rgba(255, 255, 255, 0.58);
  border-radius: 24px;
  background:
    radial-gradient(circle at 8% 0%, rgba(255, 255, 255, 0.62), transparent 26%),
    radial-gradient(circle at 94% 16%, rgba(255, 255, 255, 0.28), transparent 24%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.46), rgba(255, 255, 255, 0.2));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.82),
    inset 0 -1px 0 rgba(255, 255, 255, 0.22),
    0 22px 58px rgba(21, 53, 72, 0.13);
  backdrop-filter: blur(30px) saturate(1.24);
  content: "";
}
body.home .category-panel,
body.home .product-area {
  position: relative;
  z-index: 1;
}
body.home .category-panel {
  position: relative;
  isolation: isolate;
  display: grid;
  grid-template-columns: repeat(5, minmax(128px, 1fr));
  gap: 0;
  min-height: 74px;
  margin-bottom: 28px;
  padding: 0;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.58);
  border-radius: 13px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.48), rgba(255, 255, 255, 0.18));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.78),
    inset 0 -1px 0 rgba(255, 255, 255, 0.18),
    0 18px 52px rgba(21, 53, 72, 0.12);
  backdrop-filter: blur(30px) saturate(1.34);
}
body.home .category-panel::before {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(circle at 13% 18%, rgba(255, 255, 255, 0.42), transparent 19%),
    radial-gradient(circle at 82% 8%, rgba(255, 255, 255, 0.22), transparent 23%),
    linear-gradient(112deg, transparent 0 34%, rgba(255, 255, 255, 0.16) 34% 47%, transparent 47% 100%),
    linear-gradient(90deg, rgba(72, 120, 56, 0.08), transparent 18%, transparent 82%, rgba(21, 53, 72, 0.06)),
    linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0));
  opacity: 0.72;
  content: "";
}
body.home .category-panel h2 {
  display: none;
}
body.home .category-button {
  position: relative;
  z-index: 1;
  display: inline-flex;
  min-height: 74px;
  gap: 12px;
  align-items: center;
  justify-content: center;
  border: 0;
  border-right: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 0;
  color: #153548;
  background: transparent;
  font-size: 16px;
  font-weight: 800;
  box-shadow:
    inset -1px 0 0 rgba(21, 53, 72, 0.05),
    inset 1px 0 0 rgba(255, 255, 255, 0.14);
}
body.home .category-button:last-child {
  border-right: 0;
}
body.home .category-button::before {
  content: "";
  display: inline-block;
  width: 24px;
  height: 24px;
  color: #153548;
  background: currentColor;
  mask:
    linear-gradient(#000 0 0) 4px 4px / 7px 7px no-repeat,
    linear-gradient(#000 0 0) 14px 4px / 7px 7px no-repeat,
    linear-gradient(#000 0 0) 4px 14px / 7px 7px no-repeat,
    linear-gradient(#000 0 0) 14px 14px / 7px 7px no-repeat;
}
body.home .category-button:nth-of-type(n + 2)::before {
  border-radius: 100% 0 100% 0;
  background: #153548;
  mask: none;
  transform: rotate(-18deg);
}
body.home .category-button:hover,
body.home .category-button.active,
body.home .category-button[aria-pressed="true"],
body.home .category-button.active:hover,
body.home .category-button[aria-pressed="true"]:hover {
  color: #153548;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.04));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.24),
    inset -1px 0 0 rgba(21, 53, 72, 0.05);
  backdrop-filter: blur(12px) saturate(1.1);
}
body.home .category-button.active::after,
body.home .category-button[aria-pressed="true"]::after {
  position: absolute;
  right: 16%;
  bottom: 0;
  left: 16%;
  height: 3px;
  border-radius: 999px 999px 0 0;
  background: #153548;
  content: "";
}
body.home .section-head {
  margin-bottom: 14px;
}
body.home .section-head h2 {
  color: #153548;
  font-size: 30px;
  font-weight: 800;
}
body.home .section-head p,
body.home .section-controls select {
  display: none;
}
body.home .section-controls {
  align-self: center;
  gap: 14px;
}
body.home .cp-live-product-search {
  width: min(250px, 28vw);
  min-width: 224px;
  height: 40px;
  border-color: rgba(21, 53, 72, 0.14);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.68), rgba(239, 248, 250, 0.42));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.78),
    0 8px 18px rgba(21, 53, 72, 0.06);
}
body.home .text-link {
  height: auto;
  padding: 0;
  border: 0 !important;
  color: #153548 !important;
  background: transparent !important;
  box-shadow: none !important;
  font-size: 15px;
  font-weight: 800;
  overflow: visible;
}
body.home .text-link::after {
  content: "";
  width: 9px;
  height: 9px;
  margin-left: 10px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(45deg);
}
@media (hover: hover) and (pointer: fine) and (min-width: 621px) {
  body.home .product-area#featured .section-controls .text-link:hover,
  body.home .product-area#featured .section-controls .text-link:focus-visible {
    color: #fff !important;
    background: #153548 !important;
  }
}
body.home .section-controls .text-link::before {
  display: none;
}
body.home .product-area {
  padding-inline: 0;
}
body.home .catalog .product-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
}
body.home .catalog .product-card,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .product-card,
body.woocommerce-cart .cp-empty-cart-featured-grid .product-card {
  min-height: 224px;
  border-color: rgba(21, 53, 72, 0.14);
  border-radius: 8px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.56), rgba(255, 255, 255, 0.24));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 14px 34px rgba(21, 53, 72, 0.08);
  backdrop-filter: blur(22px) saturate(1.16);
}
body.home .catalog .product-art,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .product-art,
body.woocommerce-cart .cp-empty-cart-featured-grid .product-art {
  margin: 12px 0 12px 12px;
  border: 0;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.38), rgba(255, 255, 255, 0.16));
  box-shadow: none;
}
body.home .catalog .product-card-body,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .product-card-body,
body.woocommerce-cart .cp-empty-cart-featured-grid .product-card-body {
  margin: 12px 12px 12px 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

@media (max-width: 1360px) and (min-width: 981px) {
body.home .site-header {
    grid-template-areas: none;
    grid-template-columns: minmax(226px, auto) minmax(320px, 1fr) minmax(240px, 320px) auto;
    row-gap: 0;
  }
body.home .brand {
    grid-area: auto;
  }
body.home .header-actions {
    grid-area: auto;
  }
body.home .main-nav {
    position: static;
    left: auto;
    top: auto;
    grid-area: auto;
    width: auto;
    transform: none;
  }
body.home .brand-name {
    font-size: 21px;
  }
}

@media (max-width: 1200px) {
body.home .home-market .hero {
    grid-template-columns: 1fr;
    min-height: auto;
  }
}

@media (max-width: 980px) {
body.home .site-header {
    position: static;
    top: 0;
    grid-template-columns: 1fr auto;
    grid-template-areas: none;
    gap: 12px;
    width: 100%;
    margin: 0;
    padding: 10px 14px 12px;
    border-radius: 0;
  }
body.home .brand {
    grid-area: auto;
  }
body.home .brand-name {
    display: none;
  }
body.home .header-actions {
    grid-area: auto;
  }
body.home .main-nav {
    position: static;
    left: auto;
    top: auto;
    grid-area: auto;
    grid-column: 1 / -1;
    order: 4;
    width: 100%;
    justify-content: flex-start;
    transform: none;
  }
body.home .home-market {
    margin-top: 0;
    padding: 26px 14px 76px;
  }
body.home .catalog {
    width: calc(100% - 28px);
    margin-top: -48px;
    padding: 0 0 26px;
  }
body.home .catalog::before {
    display: none;
  }
body.home .category-panel {
    grid-template-columns: none;
    grid-auto-flow: column;
    grid-auto-columns: minmax(142px, 0.62fr);
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
body.home .catalog .product-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
body.home .catalog .product-card,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .product-card,
body.woocommerce-cart .cp-empty-cart-featured-grid .product-card {
    width: 100%;
    min-width: 0;
  }
}

@media (max-width: 620px) {
body.home .catalog .product-grid {
    grid-template-columns: 1fr;
  }
body.home .catalog .product-card,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .product-card,
body.woocommerce-cart .cp-empty-cart-featured-grid .product-card {
    grid-template-columns: minmax(94px, 0.72fr) minmax(0, 1fr);
    min-height: 190px;
  }
body.home .catalog .product-art img,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .product-art img,
body.woocommerce-cart .cp-empty-cart-featured-grid .product-art img {
    max-height: 142px;
  }
body.home .catalog .product-card-body,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .product-card-body,
body.woocommerce-cart .cp-empty-cart-featured-grid .product-card-body {
    padding: 16px 14px;
  }
}
/* Soft Glassmorphism base + controlled Liquid Glass details. */
body.home {
  --soft-glass: rgba(255, 255, 255, 0.42);
  --soft-glass-strong: rgba(255, 255, 255, 0.58);
  --soft-glass-edge: rgba(255, 255, 255, 0.72);
  --soft-glass-line: rgba(255, 255, 255, 0.48);
  --soft-ink: #153548;
  --soft-muted: #425d68;
  --liquid-cyan: rgba(138, 201, 205, 0.34);
  --liquid-glint: rgba(255, 255, 255, 0.78);
  --liquid-shadow: 0 24px 70px rgba(21, 53, 72, 0.16);
  background:
    radial-gradient(circle at 7% 27%, rgba(72, 120, 56, 0.22), transparent 16%),
    radial-gradient(circle at 88% 12%, rgba(139, 194, 197, 0.3), transparent 25%),
    radial-gradient(circle at 56% 42%, rgba(255, 255, 255, 0.74), transparent 34%),
    linear-gradient(180deg, #e9f5f4 0%, #f7fbfb 45%, #ffffff 100%);
}
body.home::before {
  background:
    linear-gradient(100deg, rgba(21, 53, 72, 0.11), transparent 16%),
    linear-gradient(116deg, transparent 0 30%, rgba(255, 255, 255, 0.28) 30% 42%, transparent 42% 100%),
    radial-gradient(ellipse at 0% 45%, rgba(72, 120, 56, 0.34), transparent 26%),
    radial-gradient(ellipse at 100% 20%, rgba(72, 120, 56, 0.16), transparent 24%),
    repeating-linear-gradient(103deg, rgba(255, 255, 255, 0.12) 0 1px, transparent 1px 86px);
  filter: blur(18px);
  opacity: 0.88;
}
body.home .site-header {
  width: min(1560px, calc(100% - 44px));
  min-height: 102px;
  margin: 18px auto 0;
  grid-template-columns: minmax(250px, auto) minmax(350px, 1fr) minmax(278px, 360px) auto;
  padding: 13px 28px;
  border-color: var(--soft-glass-line);
  border-radius: 24px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.54), rgba(255, 255, 255, 0.2)),
    radial-gradient(circle at 8% 0%, rgba(255, 255, 255, 0.62), transparent 34%);
  box-shadow:
    inset 0 1px 0 var(--soft-glass-edge),
    inset 0 -1px 0 rgba(255, 255, 255, 0.24),
    0 18px 56px rgba(21, 53, 72, 0.14);
  backdrop-filter: blur(34px) saturate(1.36);
}
body.home .brand {
  gap: 13px;
}
body.home .brand-logo-img--header {
  width: 70px;
  height: 70px;
}
body.home .brand-name {
  max-width: 160px;
  font-size: 26px;
  line-height: 0.96;
  white-space: normal;
}
body.home .main-nav {
  gap: clamp(24px, 2.7vw, 48px);
  font-size: 17px;
  font-weight: 700;
}
body.home .main-nav a {
  min-height: 44px;
  color: rgba(21, 53, 72, 0.96);
}
body.home .icon-button,
body.home .cart-button {
  min-height: 58px;
  border-color: var(--soft-glass-line);
  border-radius: 12px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.4), rgba(255, 255, 255, 0.16));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.68),
    0 12px 30px rgba(21, 53, 72, 0.1);
}
body.home .icon-button {
  width: 82px;
  flex-direction: column;
  gap: 2px;
  padding: 7px 10px 6px;
}
body.home .icon-button::after {
  color: var(--soft-ink);
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  content: "Hesabım";
}
body.home .cart-button {
  gap: 8px;
  padding: 8px 14px;
}
body.home .home-market {
  margin-top: -120px;
  padding: 166px clamp(18px, 4.6vw, 76px) 88px;
  background:
    radial-gradient(ellipse at 82% 40%, rgba(181, 213, 213, 0.44), transparent 36%),
    radial-gradient(ellipse at 4% 36%, rgba(72, 120, 56, 0.22), transparent 26%),
    linear-gradient(180deg, rgba(231, 244, 243, 0.9), rgba(247, 251, 250, 0.42) 68%, rgba(255, 255, 255, 0));
}
body.home .home-market::before {
  background:
    linear-gradient(104deg, rgba(21, 53, 72, 0.08), transparent 20%),
    linear-gradient(112deg, transparent 0 30%, rgba(255, 255, 255, 0.32) 30% 43%, transparent 43% 100%),
    radial-gradient(circle at 2% 44%, rgba(72, 120, 56, 0.22), transparent 22%),
    radial-gradient(circle at 92% 18%, rgba(72, 120, 56, 0.13), transparent 20%);
  filter: blur(20px);
  opacity: 0.86;
}
body.home .home-market .hero {
  grid-template-columns: minmax(430px, 0.42fr) minmax(0, 0.58fr);
  gap: clamp(40px, 6vw, 92px);
  min-height: 462px;
}
body.home .category-panel {
  grid-template-columns: repeat(5, minmax(128px, 1fr));
  min-height: 90px;
  margin-bottom: 34px;
  padding: 14px clamp(18px, 4vw, 62px);
  border-color: var(--soft-glass-line);
  border-radius: 24px;
  background:
    radial-gradient(circle at 100% 50%, rgba(255, 255, 255, 0.7), transparent 12%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.5), rgba(255, 255, 255, 0.18));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.84),
    inset 0 -1px 0 rgba(255, 255, 255, 0.22),
    0 18px 54px rgba(21, 53, 72, 0.14);
}
body.home .category-panel::before {
  background:
    linear-gradient(106deg, transparent 0 76%, rgba(255, 255, 255, 0.44) 76% 88%, transparent 88% 100%),
    radial-gradient(circle at 96% 70%, rgba(138, 201, 205, 0.42), transparent 14%),
    linear-gradient(90deg, rgba(255, 255, 255, 0.26), transparent 24%, transparent 76%, rgba(255, 255, 255, 0.22));
  opacity: 0.82;
}
body.home .category-button {
  min-height: 58px;
  border-right: 1px solid rgba(21, 53, 72, 0.11);
  border-radius: 0;
  font-weight: 500;
  box-shadow: none;
}
body.home .category-button::before {
  width: 23px;
  height: 23px;
}
body.home .category-button:hover {
  color: var(--soft-ink);
  background: rgba(255, 255, 255, 0.2);
}
body.home .category-button.active,
body.home .category-button[aria-pressed="true"],
body.home .category-button.active:hover,
body.home .category-button[aria-pressed="true"]:hover {
  border-right-color: transparent;
  border-radius: 999px;
  color: #fff;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 42%),
    #153548;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.22),
    0 14px 28px rgba(21, 53, 72, 0.22);
}
body.home .category-button.active::before,
body.home .category-button[aria-pressed="true"]::before {
  color: #fff;
  background: currentColor;
}
body.home .category-button.active::after,
body.home .category-button[aria-pressed="true"]::after {
  display: none;
}
body.home .product-area {
  padding-top: 4px;
}
body.home .section-head {
  margin-bottom: 18px;
}
body.home .section-head h2 {
  font-size: clamp(28px, 2.3vw, 36px);
}
body.home .text-link {
  display: inline-flex;
  min-height: 40px;
  align-items: center;
  padding-inline: 2px;
  font-size: 15px;
}
body.home .catalog,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products,
body.woocommerce-cart .cp-empty-cart-featured-grid {
  --cp-product-card-media-width: 96%;
  --cp-product-card-media-max-width: 96%;
  --cp-product-card-media-transform: scale(1.18);
  --cp-product-card-media-hover-transform: translateY(-5px) scale(1.205);
  --cp-product-media-border: 0 solid transparent;
  --cp-product-media-radius: 8px;
  --cp-product-media-background:
    radial-gradient(circle at 50% 42%, rgba(255, 255, 255, 0.5) 0, rgba(255, 255, 255, 0.16) 34%, transparent 67%);
  --cp-product-media-shadow: none;
  --cp-product-card-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  --cp-product-card-min-height: 232px;
  --cp-product-media-margin: 4px 0 4px 4px;
  --cp-product-media-max-height: 236px;
  --cp-product-body-margin: 10px 10px 10px 0;
  --cp-product-body-padding: 15px 15px 14px;
}
body.home .catalog {
  --cp-product-grid-template: repeat(4, minmax(0, 1fr));
  --cp-product-grid-gap: 20px;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products {
  --cp-product-grid-template: repeat(3, minmax(0, 1fr));
  --cp-product-grid-gap: clamp(20px, 2vw, 28px);
}
body.home .catalog .product-grid {
  grid-template-columns: var(--cp-product-grid-template);
  gap: var(--cp-product-grid-gap);
}
body.home .catalog .product-card,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .product-card,
body.woocommerce-cart .cp-empty-cart-featured-grid .product-card {
  display: grid;
  grid-template-columns: var(--cp-product-card-columns);
  min-height: var(--cp-product-card-min-height);
  overflow: hidden;
  border-color: rgba(21, 53, 72, 0.13);
  border-radius: 10px;
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 255, 255, 0.66), transparent 34%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.5), rgba(255, 255, 255, 0.2));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.74),
    0 18px 46px rgba(21, 53, 72, 0.1);
}
body.home .catalog .product-card::after,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .product-card::after,
body.woocommerce-cart .cp-empty-cart-featured-grid .product-card::after {
  background:
    linear-gradient(125deg, rgba(255, 255, 255, 0.34), transparent 30%),
    radial-gradient(circle at 92% 8%, rgba(255, 255, 255, 0.34), transparent 18%);
}
body.home .catalog .product-art,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .product-art,
body.woocommerce-cart .cp-empty-cart-featured-grid .product-art {
  position: relative;
  min-height: 0;
  height: auto;
  margin: var(--cp-product-media-margin);
  border: var(--cp-product-media-border);
  border-radius: var(--cp-product-media-radius);
  overflow: visible;
  background: var(--cp-product-media-background);
  box-shadow: var(--cp-product-media-shadow);
}
body.home .catalog .product-art img,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .product-art img,
body.woocommerce-cart .cp-empty-cart-featured-grid .product-art img {
  position: relative;
  z-index: 1;
  width: var(--cp-product-card-media-width);
  max-width: var(--cp-product-card-media-max-width);
  max-height: var(--cp-product-media-max-height);
  transform: var(--cp-product-card-media-transform);
  transform-origin: center;
}
body.home .catalog .product-card:hover .product-art img,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .product-card:hover .product-art img,
body.woocommerce-cart .cp-empty-cart-featured-grid .product-card:hover .product-art img {
  transform: var(--cp-product-card-media-hover-transform);
}
body.home .catalog .product-card-body,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .product-card-body,
body.woocommerce-cart .cp-empty-cart-featured-grid .product-card-body {
  min-width: 0;
  margin: var(--cp-product-body-margin);
  padding: var(--cp-product-body-padding);
}
body.home .catalog .product-card h3,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .product-card h3,
body.woocommerce-cart .cp-empty-cart-featured-grid .product-card h3 {
  padding-right: 24px;
  font-size: 16px;
  line-height: 1.25;
}
body.home .catalog .price-row strong,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .price-row strong,
body.woocommerce-cart .cp-empty-cart-featured-grid .price-row strong {
  font-size: 20px;
}
body.home .catalog .product-card-summary,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .product-card-summary,
body.woocommerce-cart .cp-empty-cart-featured-grid .product-card-summary {
  display: -webkit-box;
  margin: 0 0 10px;
  overflow: hidden;
  color: #425865;
  font-size: 12px;
  line-height: 1.45;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}
body.home .catalog .add-button,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .add-button,
body.woocommerce-cart .cp-empty-cart-featured-grid .add-button {
  gap: 5px;
  min-width: 0;
  min-height: 42px;
  padding-inline: 7px;
  font-size: 12px;
  white-space: nowrap;
}
body.home .catalog .add-button span,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .add-button span,
body.woocommerce-cart .cp-empty-cart-featured-grid .add-button span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}
body.home .catalog .add-button svg,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .add-button svg,
body.woocommerce-cart .cp-empty-cart-featured-grid .add-button svg {
  flex: 0 0 auto;
  width: 16px;
  height: 16px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

@media (min-width: 1361px) {
body.home .catalog,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products,
body.woocommerce-cart .cp-empty-cart-featured-grid {
    --cp-product-card-columns: minmax(0, 0.88fr) minmax(0, 1.12fr);
    --cp-product-card-min-height: 292px;
    --cp-product-media-margin: 12px 0 12px 12px;
    --cp-product-media-max-height: 248px;
    --cp-product-body-margin: 12px 12px 12px 0;
    --cp-product-body-padding: 16px 16px 15px;
  }
body.home .catalog {
    --cp-product-grid-template: repeat(4, minmax(0, 1fr));
    --cp-product-grid-gap: 20px;
  }
body.home .catalog .product-card h3,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .product-card h3,
body.woocommerce-cart .cp-empty-cart-featured-grid .product-card h3 {
    font-size: 17px;
    line-height: 1.25;
  }
body.home .catalog .product-card-summary,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .product-card-summary,
body.woocommerce-cart .cp-empty-cart-featured-grid .product-card-summary {
    font-size: 13px;
  }
body.home .catalog .price-row,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .price-row,
body.woocommerce-cart .cp-empty-cart-featured-grid .price-row {
    margin-bottom: 12px;
  }
body.home .catalog .price-row strong,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .price-row strong,
body.woocommerce-cart .cp-empty-cart-featured-grid .price-row strong {
    font-size: 22px;
  }
body.home .catalog .add-button,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .add-button,
body.woocommerce-cart .cp-empty-cart-featured-grid .add-button {
    gap: 8px;
    min-height: 46px;
    padding-inline: 12px;
    font-size: 14px;
  }
body.home .catalog .add-button svg,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .add-button svg,
body.woocommerce-cart .cp-empty-cart-featured-grid .add-button svg {
    width: 18px;
    height: 18px;
  }
body.home .catalog .favorite,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .favorite,
body.woocommerce-cart .cp-empty-cart-featured-grid .favorite {
    top: 12px;
    right: 12px;
    width: 32px;
    height: 32px;
  }
}

@media (max-width: 1360px) and (min-width: 981px) {
body.home .site-header {
    grid-template-columns: minmax(226px, auto) minmax(290px, 1fr) minmax(238px, 318px) auto;
  }
body.home .brand-logo-img--header {
    width: 62px;
    height: 62px;
  }
body.home .brand-name {
    max-width: 142px;
    font-size: 23px;
  }
body.home .main-nav {
    gap: clamp(18px, 2vw, 32px);
    font-size: 15px;
  }
}

@media (max-width: 1200px) {
body.home .home-market .hero {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 980px) {
body.home .site-header {
    width: 100%;
    min-height: 0;
    margin: 0;
    border-radius: 0 0 22px 22px;
  }
body.home .brand-logo-img--header {
    width: 54px;
    height: 54px;
  }
body.home .home-market {
    margin-top: 0;
    padding-top: 28px;
  }
body.home .category-panel {
    grid-auto-columns: minmax(150px, 0.68fr);
    padding: 10px;
    border-radius: 20px;
  }
body.home .category-button {
    min-height: 56px;
  }
}

@media (max-width: 620px) {
body.home .catalog {
    margin-top: -42px;
  }
body.home .catalog .product-card,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .product-card,
body.woocommerce-cart .cp-empty-cart-featured-grid .product-card {
    min-height: 190px;
  }
body.home .catalog .price-row strong,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main .price-row strong,
body.woocommerce-cart .cp-empty-cart-featured-grid .price-row strong {
    font-size: 21px;
  }
}
body.home .main-nav a,
body.home .main-nav a:hover,
body.home .main-nav a.is-active,
body.home .main-nav a[aria-current="page"],
body.home .main-nav a.is-active:hover,
body.home .main-nav a[aria-current="page"]:hover {
  border-color: transparent !important;
  color: var(--soft-ink) !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}
body.home .main-nav a::before,
body.home .main-nav a:hover::before,
body.home .main-nav a.is-active::before,
body.home .main-nav a[aria-current="page"]::before {
  display: none !important;
}
.category-icon,
.cp-shop-filter-icon .category-icon {
  display: inline-grid;
  flex: 0 0 auto;
  width: 24px;
  height: 24px;
  place-items: center;
  color: currentColor;
  line-height: 1;
}
.category-icon svg,
.cp-shop-filter-icon .category-icon svg {
  display: block;
  width: 23px;
  height: 23px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.category-icon--glyph {
  font-size: 20px;
  font-weight: 700;
}
body.home .category-button::before,
body.home .category-button:nth-of-type(n + 2)::before,
body.home .category-button.active::before,
body.home .category-button[aria-pressed="true"]::before {
  display: none;
  content: none;
}
body.home .category-button .category-icon {
  color: #153548;
}
body.home .category-button.active .category-icon,
body.home .category-button[aria-pressed="true"] .category-icon {
  color: currentColor;
}
body.home .category-panel.has-category-indicator {
  --category-indicator-x: 14px;
  --category-indicator-y: 14px;
  --category-indicator-width: 180px;
  --category-indicator-height: 58px;
}
body.home .category-panel.has-category-indicator::after {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  width: var(--category-indicator-width);
  height: var(--category-indicator-height);
  border: 1px solid rgba(255, 255, 255, 0.4);
  border-radius: 999px;
  pointer-events: none;
  content: "";
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.14), transparent 46%),
    #153548;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.24),
    inset 0 -12px 22px rgba(255, 255, 255, 0.06),
    0 14px 30px rgba(21, 53, 72, 0.2);
  opacity: 1;
  transform: translate3d(var(--category-indicator-x), var(--category-indicator-y), 0);
  transition:
    width 360ms cubic-bezier(0.22, 0.72, 0.18, 1),
    height 360ms cubic-bezier(0.22, 0.72, 0.18, 1),
    transform 440ms cubic-bezier(0.22, 0.72, 0.18, 1),
    box-shadow 220ms ease,
    border-color 220ms ease;
}
body.home .category-panel.has-category-indicator .category-button.active,
body.home .category-panel.has-category-indicator .category-button[aria-pressed="true"],
body.home .category-panel.has-category-indicator .category-button.active:hover,
body.home .category-panel.has-category-indicator .category-button[aria-pressed="true"]:hover {
  color: #fff;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}

@media (hover: hover) and (pointer: fine) and (min-width: 821px) {
body.home .category-panel .category-button {
    overflow: hidden;
    border-right-color: transparent;
    border-radius: 999px;
    box-shadow: none;
    transition:
      color 180ms ease,
      background-color 180ms ease,
      border-color 180ms ease,
      box-shadow 180ms ease,
      transform 180ms ease;
  }
body.home .category-panel .category-button:not(.active):not([aria-pressed="true"]):hover {
    color: #153548;
    background:
      linear-gradient(145deg, rgba(255, 255, 255, 0.5), rgba(255, 255, 255, 0.18));
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.72),
      0 12px 24px rgba(21, 53, 72, 0.1);
    transform: translateY(-1px);
    backdrop-filter: blur(18px) saturate(1.16);
  }
body.home .category-panel .category-button::after {
    position: absolute;
    inset: -34% -58%;
    z-index: 0;
    display: block;
    pointer-events: none;
    content: "";
    background:
      linear-gradient(
        112deg,
        transparent 0%,
        transparent 31%,
        rgba(255, 255, 255, 0.1) 39%,
        rgba(255, 255, 255, 0.82) 48%,
        rgba(217, 237, 207, 0.34) 56%,
        transparent 69%,
        transparent 100%
      );
    opacity: 0;
    transform: translateX(-76%) skewX(-15deg);
    transition:
      opacity 180ms ease,
      transform 760ms cubic-bezier(0.22, 0.72, 0.18, 1);
  }
body.home .category-panel .category-button:hover::after {
    opacity: 1;
    transform: translateX(76%) skewX(-15deg);
  }
body.home .category-panel.has-category-indicator:has(.category-button.active:hover, .category-button[aria-pressed="true"]:hover)::after {
    border-color: rgba(255, 255, 255, 0.62);
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.32),
      inset 0 -12px 22px rgba(255, 255, 255, 0.08),
      0 18px 34px rgba(21, 53, 72, 0.24);
  }
}

@media (max-width: 820px) {
body.home .main-nav {
    color: var(--soft-ink);
    border-color: rgba(255, 255, 255, 0.48);
    background:
      linear-gradient(145deg, rgba(255, 255, 255, 0.5), rgba(255, 255, 255, 0.22));
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.72),
      0 12px 30px rgba(21, 53, 72, 0.1);
    backdrop-filter: blur(24px) saturate(1.18);
  }
body.home .main-nav a,
body.home .main-nav a:hover,
body.home .main-nav a.is-active,
body.home .main-nav a[aria-current="page"],
body.home .main-nav a.is-active:hover,
body.home .main-nav a[aria-current="page"]:hover {
    color: var(--soft-ink) !important;
    background: rgba(255, 255, 255, 0.24) !important;
    border-color: rgba(255, 255, 255, 0.34) !important;
  }
}

@media (max-width: 620px) {
body.home {
    overflow-x: hidden;
  }
body.home .site-header {
    position: relative;
    grid-template-columns: minmax(0, 1fr) auto;
    column-gap: 8px;
    overflow-x: clip;
    padding: 12px;
  }
body.home .site-header > *,
body.home .brand,
body.home .main-nav,
body.home .header-actions {
    min-width: 0;
  }
body.home .brand {
    width: 56px;
  }
body.home .header-actions {
    position: static;
    grid-column: 1 / -1;
    order: 2;
    justify-content: flex-end;
    gap: 8px;
  }
body.home .icon-button {
    width: 58px;
    min-height: 50px;
    padding: 6px 8px;
  }
body.home .icon-button svg {
    width: 21px;
    height: 21px;
  }
body.home .icon-button::after {
    font-size: 9px;
  }
body.home .cart-button {
    width: 52px;
    min-height: 50px;
    justify-content: center;
    padding: 6px 8px;
  }
body.home .cart-button strong {
    display: none;
  }
}
/* Header polish: keep the primary chrome calm and brand-first. */
.site-header {
  grid-template-columns: minmax(240px, auto) minmax(0, 1fr) auto;
}
.site-header .brand {
  min-width: 0;
}
.site-header .main-nav {
  justify-self: center;
}
.site-header .header-actions {
  justify-self: end;
}
body.home .site-header {
  min-height: 104px;
  grid-template-columns: minmax(330px, auto) minmax(0, 1fr) auto;
  gap: clamp(26px, 4.8vw, 78px);
  padding: 14px clamp(26px, 3.6vw, 54px);
}
body.home .brand {
  gap: 16px;
  min-width: max-content;
}
body.home .brand-logo-img--header {
  width: 78px;
  height: 78px;
}
body.home .brand-name {
  max-width: none;
  font-size: 28px;
  line-height: 1;
  white-space: nowrap;
}
body.home .main-nav {
  left: calc(50% + 34px);
  gap: clamp(26px, 3.6vw, 58px);
  font-size: 17px;
}
body.home .header-actions {
  gap: 12px;
}

@media (max-width: 1360px) and (min-width: 981px) {
body.home .site-header {
    grid-template-columns: minmax(300px, auto) minmax(0, 1fr) auto;
    gap: clamp(22px, 3.4vw, 48px);
  }
body.home .brand-logo-img--header {
    width: 70px;
    height: 70px;
  }
body.home .brand-name {
    max-width: none;
    font-size: 25px;
    line-height: 1;
    white-space: nowrap;
  }
body.home .main-nav {
    gap: clamp(20px, 2.6vw, 40px);
    font-size: 15px;
    transform: translateX(clamp(8px, 1.2vw, 16px));
  }
}

@media (max-width: 1360px) and (min-width: 821px) {
.site-header {
    grid-template-columns: minmax(250px, auto) minmax(0, 1fr) auto;
    grid-template-areas: "brand nav actions";
  }
.brand {
    grid-area: brand;
  }
.main-nav {
    position: static;
    grid-area: nav;
    display: flex;
    width: auto;
    justify-content: center;
    transform: none;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
.header-actions {
    grid-area: actions;
  }
}

@media (max-width: 980px) {
body.home .site-header {
    min-height: 0;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px 18px;
    padding: 12px 18px 14px;
  }
body.home .brand-logo-img--header {
    width: 64px;
    height: 64px;
  }
body.home .brand-name {
    max-width: 168px;
    font-size: 23px;
  }
body.home .main-nav {
    grid-column: 1 / -1;
    justify-self: stretch;
    width: 100%;
    justify-content: flex-start;
    overflow-x: auto;
  }
}

@media (max-width: 620px) {
body.home .site-header {
    position: relative;
    width: 100vw;
    max-width: 100vw;
    margin: 0;
    grid-template-columns: minmax(0, 1fr) auto;
    overflow: hidden;
    padding: 12px;
  }
body.home .brand {
    width: 58px;
    gap: 10px;
  }
body.home .brand-name {
    display: none;
  }
body.home .brand-logo-img--header {
    width: 58px;
    height: 58px;
  }
body.home .brand-name {
    max-width: 126px;
    font-size: 19px;
  }
body.home .header-actions {
    display: none;
  }
body.home .main-nav {
    order: 2;
    width: calc(100vw - 24px);
    max-width: calc(100vw - 24px);
  }
}

@media (max-width: 430px) {
body.home .brand-name {
    max-width: 102px;
    font-size: 17px;
  }
body.home .brand-logo-img--header {
    width: 52px;
    height: 52px;
  }
}
/* Header active state: keep page location visible on the glassy navigation. */
.site-header .main-nav a.is-active,
.site-header .main-nav a[aria-current="page"],
.site-header .main-nav a.is-active:hover,
.site-header .main-nav a[aria-current="page"]:hover {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.42);
  border-radius: 999px;
  background: #153548;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 12px 26px rgba(21, 53, 72, 0.18);
}
body.home .main-nav a.is-active,
body.home .main-nav a[aria-current="page"],
body.home .main-nav a.is-active:hover,
body.home .main-nav a[aria-current="page"]:hover {
  min-height: 42px;
  padding: 0 18px;
  color: #fff !important;
  border: 1px solid rgba(255, 255, 255, 0.42) !important;
  border-radius: 999px !important;
  background: #153548 !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 12px 26px rgba(21, 53, 72, 0.18) !important;
}
body.home .site-header .brand-name {
  position: relative;
}
body.home .site-header .brand-name::after {
  position: absolute;
  bottom: -9px;
  left: 50%;
  width: 78%;
  height: 2px;
  pointer-events: none;
  content: "";
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(21, 53, 72, 0.18) 12%,
    rgba(21, 53, 72, 0.72) 42%,
    rgba(21, 53, 72, 0.96) 52%,
    rgba(21, 53, 72, 0.72) 62%,
    rgba(21, 53, 72, 0.18) 88%,
    transparent 100%
  );
  box-shadow:
    0 0 9px rgba(21, 53, 72, 0.24),
    0 2px 17px rgba(21, 53, 72, 0.14);
  transform: translateX(-50%);
  transform-origin: center;
  animation: cp-brand-signature-arrive 700ms cubic-bezier(0.2, 0.75, 0.2, 1) both;
}

@keyframes cp-brand-signature-arrive {
  from {
    opacity: 0;
    transform: translateX(-50%) scaleX(0.35);
  }

  to {
    opacity: 1;
    transform: translateX(-50%) scaleX(1);
  }
}
.site-header .icon-button.is-active,
.site-header .cart-button.is-active,
.site-header .icon-button[aria-current="page"],
.site-header .cart-button[aria-current="page"],
.site-header .icon-button.is-active:hover,
.site-header .cart-button.is-active:hover,
.site-header .icon-button[aria-current="page"]:hover,
.site-header .cart-button[aria-current="page"]:hover {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.42);
  background: #153548;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 12px 26px rgba(21, 53, 72, 0.18);
}

@media (hover: hover) and (pointer: fine) and (min-width: 821px) {
.site-header .main-nav a,
.site-header .icon-button,
.site-header .cart-button {
    position: relative;
    overflow: hidden;
  }
.site-header .main-nav a,
body.home .main-nav a {
    min-height: 42px;
    padding: 0 18px;
    border: 1px solid transparent !important;
    border-radius: 999px !important;
    background: transparent !important;
    transition:
      color 180ms ease,
      border-color 180ms ease,
      background-color 180ms ease,
      box-shadow 180ms ease,
      transform 180ms ease;
  }
.site-header .main-nav a.is-active,
.site-header .main-nav a[aria-current="page"],
body.home .main-nav a.is-active,
body.home .main-nav a[aria-current="page"] {
    background: #153548 !important;
  }
body.home .main-nav a:not(.is-active):not([aria-current="page"]):hover,
.site-header .main-nav a:not(.is-active):not([aria-current="page"]):hover {
    color: #153548 !important;
    border-color: rgba(255, 255, 255, 0.52) !important;
    background:
      linear-gradient(145deg, rgba(255, 255, 255, 0.5), rgba(255, 255, 255, 0.2)) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.72),
      0 12px 26px rgba(21, 53, 72, 0.12) !important;
    backdrop-filter: blur(18px) saturate(1.18) !important;
    transform: translateY(-1px);
  }
.site-header .main-nav a::before,
.site-header .icon-button::before,
.site-header .cart-button::before {
    position: absolute;
    inset: -34% -58%;
    z-index: 0;
    display: block !important;
    pointer-events: none;
    content: "";
    background:
      linear-gradient(
        112deg,
        transparent 0%,
        transparent 31%,
        rgba(255, 255, 255, 0.1) 39%,
        rgba(255, 255, 255, 0.84) 48%,
        rgba(217, 237, 207, 0.36) 56%,
        transparent 69%,
        transparent 100%
      );
    opacity: 0;
    transform: translateX(-76%) skewX(-15deg);
    transition:
      opacity 180ms ease,
      transform 760ms cubic-bezier(0.22, 0.72, 0.18, 1);
  }
.site-header .main-nav a:hover::before,
.site-header .icon-button:hover::before,
.site-header .cart-button:hover::before {
    opacity: 1;
    transform: translateX(76%) skewX(-15deg);
  }
body.home .main-nav a.is-active:hover,
body.home .main-nav a[aria-current="page"]:hover,
.site-header .main-nav a.is-active:hover,
.site-header .main-nav a[aria-current="page"]:hover,
.site-header .icon-button.is-active:hover,
.site-header .cart-button.is-active:hover,
.site-header .icon-button[aria-current="page"]:hover,
.site-header .cart-button[aria-current="page"]:hover {
    border-color: rgba(255, 255, 255, 0.62) !important;
    background: #153548 !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.32),
      inset 0 -10px 22px rgba(255, 255, 255, 0.08),
      0 16px 32px rgba(21, 53, 72, 0.24) !important;
    transform: translateY(-1px);
  }
}

@media (max-width: 620px) {
body.home .main-nav a.is-active,
body.home .main-nav a[aria-current="page"],
body.home .main-nav a.is-active:hover,
body.home .main-nav a[aria-current="page"]:hover {
    min-height: 38px;
    padding: 0 14px;
  }
}

@media (prefers-reduced-motion: reduce) {
*,
*::before,
*::after {
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
  }
.site-loader-ring {
    animation: cp-loader-orbit var(--cp-loader-orbit-duration, 900ms) linear infinite !important;
    animation-delay: var(--cp-loader-orbit-offset, -180ms) !important;
  }
body.home .hero-banner-slide {
    transition:
      opacity 520ms ease,
      visibility 520ms ease,
      transform 1100ms cubic-bezier(0.22, 0.72, 0.18, 1) !important;
  }
body.home .hero-banner-slide.is-active .hero-banner-link img {
    animation: cp-hero-banner-zoom 5600ms linear forwards !important;
  }
}
/* Homepage viewport rhythm: keep the glass hero premium without pushing products below the fold. */
@media (min-width: 1201px) {
  body.home .home-market {
    padding-top: 142px;
    padding-bottom: 70px;
  }

  body.home .home-market .hero {
    min-height: 390px;
    gap: clamp(34px, 4.4vw, 68px);
  }

  body.home .hero-slider {
    height: 390px;
    min-height: 390px;
  }
}
body.home .category-panel {
  min-height: 68px;
  margin-bottom: 22px;
  padding: 7px clamp(14px, 3vw, 42px);
  border-radius: 20px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.9),
    inset 0 -1px 0 rgba(142, 205, 207, 0.2),
    0 13px 38px rgba(21, 53, 72, 0.12);
}
body.home .category-panel::before {
  background:
    linear-gradient(104deg, transparent 0 70%, rgba(255, 255, 255, 0.5) 78%, transparent 88%),
    radial-gradient(ellipse at 96% 50%, rgba(138, 201, 205, 0.3), transparent 18%),
    linear-gradient(90deg, rgba(255, 255, 255, 0.2), transparent 30%, transparent 72%, rgba(255, 255, 255, 0.22));
  opacity: 0.72;
}
body.home .category-button {
  min-height: 50px;
}
body.home .category-button::before {
  width: 21px;
  height: 21px;
}
body.home .category-panel {
  width: calc(100% - clamp(96px, 10vw, 180px));
  margin-right: auto;
  margin-left: auto;
  border-color: rgba(255, 255, 255, 0.58) !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.42), rgba(255, 255, 255, 0.16)) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.82),
    inset 0 -1px 0 rgba(142, 205, 207, 0.16),
    0 10px 24px rgba(21, 53, 72, 0.08) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
body.home .category-panel::before {
  display: none !important;
  content: none !important;
}
body.home .catalog::before {
  inset: 34px 0 0 !important;
}
body.home .section-head {
  margin-bottom: 14px;
}

@media (max-width: 980px) {
body.home .home-market .hero {
    gap: 24px;
  }
body.home .hero-slider {
    height: 350px;
    min-height: 350px;
  }
body.home .category-panel {
    min-height: 64px;
    margin-bottom: 20px;
    padding: 7px 9px;
  }
body.home .category-button {
    min-height: 48px;
  }
}

@media (max-width: 620px) {
body.home .site-header {
    grid-template-columns: auto minmax(0, 1fr);
    gap: 10px 12px;
  }
body.home .header-actions {
    display: flex;
    grid-column: 2;
    grid-row: 1;
    justify-self: end;
    gap: 7px;
  }
body.home .icon-button,
body.home .cart-button {
    width: 50px;
    min-height: 46px;
    padding: 6px 8px;
    border-radius: 12px;
  }
body.home .icon-button {
    gap: 0;
  }
body.home .icon-button::after,
body.home .cart-button strong {
    display: none;
  }
body.home .main-nav {
    grid-column: 1 / -1;
    grid-row: 2;
    order: initial;
  }
body.home .home-market {
    padding-top: 22px;
  }
body.home .hero-slider {
    height: 270px;
    min-height: 270px;
  }
body.home .catalog {
    margin-top: -96px;
  }
}

@media (max-width: 360px) {
}
/* Supplied Ençay campaign artwork replaces the temporary split hero composition. */
body.home .home-market .hero.hero-banner-shell {
  display: block;
  width: 100%;
  min-height: 0;
  grid-template-columns: none;
  gap: 0;
  align-items: stretch;
}
body.home .hero-banner-slider {
  position: relative;
  width: 100%;
  height: auto;
  aspect-ratio: 12 / 5;
  padding: 0;
  min-height: 0;
  overflow: hidden;
  isolation: isolate;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 26px;
  background: #dce9e8;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.88),
    0 24px 64px rgba(21, 53, 72, 0.18);
  contain: paint;
}
body.home .hero-banner-slider::before,
body.home .hero-banner-slider::after {
  display: none;
}
body.home .hero-banner-slider .hero-slider-viewport {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  contain: paint;
}
body.home .hero-banner-slide {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  padding: 0;
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  transform: scale(1.015);
  transition:
    opacity 520ms ease,
    visibility 520ms ease,
    transform 1100ms cubic-bezier(0.22, 0.72, 0.18, 1);
  pointer-events: none;
}
body.home .hero-banner-slide.is-active {
  z-index: 1;
  opacity: 1;
  visibility: visible;
  transform: scale(1);
  pointer-events: auto;
  will-change: opacity, transform;
}
body.home .hero-banner-link {
  display: block;
  width: 100%;
  height: 100%;
}
body.home .hero-banner-link img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transform: scale(1);
  transform-origin: center;
}
body.home .hero-banner-slide.is-active .hero-banner-link img {
  will-change: transform;
}

@media (min-width: 981px) {
body.home .hero-banner-slide.is-active .hero-banner-link img {
    animation: cp-hero-banner-zoom 5600ms linear forwards;
  }
}

@keyframes cp-hero-banner-zoom {
  from {
    transform: scale(1);
  }

  to {
    transform: scale(1.04);
  }
}

@media (prefers-reduced-motion: reduce) {
body.home .site-header .brand-name::after {
    animation: none;
  }
}
body.home .hero-banner-slider .hero-slider-controls {
  position: absolute;
  inset: 50% 18px auto;
  z-index: 4;
  display: flex !important;
  justify-content: space-between;
  transform: translateY(-50%);
  pointer-events: none;
}
body.home .hero-banner-slider .hero-arrow {
  width: 46px;
  height: 46px;
  border: 1px solid rgba(255, 255, 255, 0.7);
  color: #153548;
  background: rgba(255, 255, 255, 0.72);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.92),
    0 12px 28px rgba(5, 31, 40, 0.2);
  backdrop-filter: blur(16px) saturate(1.16);
  pointer-events: auto;
}
body.home .hero-banner-slider .hero-arrow:hover {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.72);
  background: #153548;
  transform: translateY(-1px);
}
body.home .hero-banner-slider .hero-slider-dots {
  position: absolute;
  left: 50%;
  right: auto;
  top: auto;
  bottom: 16px;
  z-index: 4;
  display: flex !important;
  width: auto;
  min-width: 0;
  height: auto;
  gap: 8px;
  align-items: center;
  padding: 8px 12px;
  border: 1px solid rgba(255, 255, 255, 0.54);
  border-radius: 999px;
  background: rgba(5, 31, 40, 0.46);
  box-shadow: 0 10px 24px rgba(5, 31, 40, 0.2);
  backdrop-filter: blur(14px) saturate(1.16);
  transform: translateX(-50%);
}
body.home .hero-banner-slider .hero-slider-dots button {
  width: 9px;
  height: 9px;
  border: 1px solid rgba(255, 255, 255, 0.78);
  background: rgba(255, 255, 255, 0.34);
}
body.home .hero-banner-slider .hero-slider-dots button[aria-current="true"] {
  width: 28px;
  border-color: #fff;
  background: #fff;
}
body.home .home-market--banner + .catalog {
  margin-top: -42px;
}

@media (max-width: 980px) {
body.home .hero-banner-slider {
    height: auto;
    min-height: 0;
    aspect-ratio: 12 / 5;
    border-radius: 20px;
  }
body.home .hero-banner-link img {
    object-fit: contain;
    object-position: center;
  }
body.home .home-market--banner + .catalog {
    margin-top: -28px;
  }
}

@media (max-width: 620px) {
body.home .hero-banner-slider {
    border-radius: 16px;
  }
body.home .hero-banner-slider .hero-slider-controls {
    inset-inline: 8px;
  }
body.home .hero-banner-slider .hero-arrow {
    width: 38px;
    height: 38px;
  }
body.home .hero-banner-slider .hero-slider-dots {
    bottom: 8px;
    gap: 6px;
    padding: 6px 9px;
  }
body.home .hero-banner-slider .hero-slider-dots button {
    width: 7px;
    height: 7px;
  }
body.home .hero-banner-slider .hero-slider-dots button[aria-current="true"] {
    width: 22px;
  }
}
/* Desktop-only scenic layer: the image is already soft,
so keep the veil light. */
@media (min-width: 981px) {
  body.home {
    background-color: #dcebee;
    background-image:
      linear-gradient(
        180deg,
        rgba(240, 248, 249, 0.36) 0%,
        rgba(235, 246, 247, 0.46) 46%,
        rgba(247, 251, 251, 0.74) 100%
      ),
      url("../images/backgrounds/home-background-desktop.jpg");
    background-repeat: no-repeat;
    background-position: center top;
    background-size: cover;
    background-attachment: scroll;
  }

  body.home::before {
    background:
      radial-gradient(ellipse at 12% 22%, rgba(255, 255, 255, 0.18), transparent 28%),
      radial-gradient(ellipse at 88% 18%, rgba(255, 255, 255, 0.12), transparent 24%),
      linear-gradient(90deg, rgba(21, 53, 72, 0.06), transparent 20%, transparent 78%, rgba(21, 53, 72, 0.05));
    filter: none;
    opacity: 1;
  }

  body.home .home-market {
    background: transparent;
  }

  body.home .home-market::before {
    display: none;
  }
}
/* Homepage order journey: one continuous soft/liquid glass rail. */
body.home .order-flow {
  position: relative;
  isolation: isolate;
  width: calc(100% - clamp(36px, 8vw, 140px));
  max-width: 1560px;
  margin: 28px auto 0;
  padding: clamp(34px, 3.4vw, 48px) clamp(24px, 4.6vw, 72px) clamp(36px, 3.8vw, 52px);
  overflow: hidden;
  color: #153548;
  border: 1px solid rgba(255, 255, 255, 0.68);
  border-radius: 24px;
  background:
    radial-gradient(circle at 8% 0%, rgba(255, 255, 255, 0.7), transparent 28%),
    radial-gradient(circle at 92% 18%, rgba(138, 201, 205, 0.2), transparent 24%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.52), rgba(235, 247, 249, 0.28));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.9),
    inset 0 -1px 0 rgba(255, 255, 255, 0.3),
    0 24px 64px rgba(21, 53, 72, 0.15);
  backdrop-filter: blur(30px) saturate(1.28);
}
body.home .order-flow::after {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    linear-gradient(112deg, transparent 0 22%, rgba(255, 255, 255, 0.24) 34%, transparent 48%),
    linear-gradient(90deg, rgba(21, 53, 72, 0.035), transparent 18%, transparent 82%, rgba(21, 53, 72, 0.035));
  content: "";
}
body.home .flow-steps {
  position: relative;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: clamp(18px, 2vw, 34px);
}
body.home .flow-steps::before {
  position: absolute;
  top: 28px;
  left: 10%;
  right: 10%;
  z-index: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(21, 53, 72, 0.14), rgba(21, 53, 72, 0.42), rgba(21, 53, 72, 0.14));
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.78);
  content: "";
}
body.home .flow-steps article {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: 56px auto 1fr;
  gap: 10px;
  min-width: 0;
  text-align: center;
}
body.home .flow-steps span {
  display: grid;
  width: 56px;
  height: 56px;
  place-items: center;
  margin: 0 auto 4px;
  border: 1px solid rgba(255, 255, 255, 0.54);
  border-radius: 50%;
  color: #fff;
  background:
    radial-gradient(circle at 32% 22%, rgba(255, 255, 255, 0.22), transparent 42%),
    linear-gradient(135deg, #051f28 0%, #08313d 48%, #153548 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.2),
    0 0 0 1px rgba(21, 53, 72, 0.16),
    0 10px 24px rgba(21, 53, 72, 0.16);
  font-size: 20px;
  font-weight: 700;
}
body.home .flow-steps strong {
  color: #153548;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.25;
}
body.home .flow-steps p {
  max-width: 210px;
  margin: 0 auto;
  color: #425d68;
  font-size: 13px;
  line-height: 1.5;
}

@media (max-width: 980px) {
body.home .order-flow {
    width: calc(100% - 28px);
    margin-top: 22px;
    padding: 26px 22px 8px;
    border-radius: 20px;
  }
body.home .flow-steps {
    grid-template-columns: 1fr;
    gap: 0;
  }
body.home .flow-steps::before {
    top: 24px;
    right: auto;
    bottom: 24px;
    left: 23px;
    width: 1px;
    height: auto;
    background: linear-gradient(180deg, rgba(21, 53, 72, 0.14), rgba(21, 53, 72, 0.4), rgba(21, 53, 72, 0.12));
  }
body.home .flow-steps article {
    grid-template-columns: 48px minmax(0, 1fr);
    grid-template-rows: auto auto;
    column-gap: 16px;
    row-gap: 4px;
    padding-bottom: 22px;
    text-align: left;
  }
body.home .flow-steps span {
    grid-row: 1 / span 2;
    width: 48px;
    height: 48px;
    margin: 0;
    font-size: 18px;
  }
body.home .flow-steps strong {
    align-self: center;
    font-size: 15px;
  }
body.home .flow-steps p {
    max-width: none;
    margin: 0;
    padding-right: 4px;
    font-size: 12px;
  }
}
/* Shop archive glass alignment: extend the accepted homepage visual system without changing WooCommerce behavior. */
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) {
  --cp-shop-ink: #153548;
  --cp-shop-muted: rgba(21, 53, 72, 0.64);
  --cp-shop-glass: rgba(255, 255, 255, 0.62);
  --cp-shop-glass-strong: rgba(255, 255, 255, 0.78);
  --cp-shop-border: rgba(255, 255, 255, 0.72);
  --cp-shop-shadow: 0 28px 72px rgba(21, 53, 72, 0.12);
  background:
    radial-gradient(circle at 18% 8%, rgba(255, 255, 255, 0.92) 0, rgba(255, 255, 255, 0.28) 22%, transparent 48%),
    radial-gradient(circle at 84% 12%, rgba(196, 232, 241, 0.54) 0, rgba(196, 232, 241, 0.18) 28%, transparent 56%),
    linear-gradient(135deg, #edf6f9 0%, #f7fbfc 36%, #e7f2f6 100%);
  color: var(--cp-shop-ink);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .top-strip {
  display: none;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .site-header {
  top: 16px;
  width: auto;
  margin: 0 clamp(18px, 3vw, 48px);
  padding: 13px clamp(18px, 2.3vw, 34px);
  grid-template-columns: minmax(205px, auto) minmax(360px, 1fr) minmax(250px, auto);
  gap: clamp(18px, 3vw, 42px);
  border: 1px solid var(--cp-shop-border);
  border-radius: 32px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.86), rgba(239, 248, 250, 0.66)),
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.82), transparent 42%);
  box-shadow:
    0 26px 74px rgba(21, 53, 72, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.78);
  backdrop-filter: blur(24px) saturate(142%);
  -webkit-backdrop-filter: blur(24px) saturate(142%);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .brand-logo-img--header {
  width: 46px;
  height: 46px;
  filter: drop-shadow(0 12px 20px rgba(21, 53, 72, 0.14));
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav a:hover {
  color: var(--cp-shop-ink);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav {
  position: static;
  justify-self: center;
  justify-content: center;
  width: auto;
  gap: clamp(16px, 2vw, 28px);
  transform: none;
  font-size: 0.92rem;
  letter-spacing: 0.035em;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav a {
  min-height: 40px;
  padding: 0 5px;
  border: 0;
  color: rgba(21, 53, 72, 0.76);
  background: transparent;
  box-shadow: none;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav a::before {
  display: none;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav a.is-active,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav a[aria-current="page"] {
  min-height: 40px;
  padding: 0 18px;
  border-radius: 999px;
  color: #fff;
  background: var(--cp-shop-ink);
  box-shadow: 0 14px 28px rgba(21, 53, 72, 0.22);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .icon-button,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cart-button {
  border-color: rgba(255, 255, 255, 0.82);
  background: rgba(255, 255, 255, 0.58);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.82),
    0 16px 34px rgba(21, 53, 72, 0.08);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-shell {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  margin-top: -92px;
  padding: 148px clamp(14px, 2.4vw, 34px) 84px;
  background: transparent;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  height: auto;
  background:
    linear-gradient(180deg, rgba(232, 244, 248, 0.18) 0%, rgba(247, 251, 252, 0.78) 48%, rgba(234, 244, 247, 0.94) 100%),
    radial-gradient(circle at 12% 16%, rgba(255, 255, 255, 0.9) 0, rgba(255, 255, 255, 0.2) 28%, transparent 54%),
    radial-gradient(circle at 86% 24%, rgba(150, 214, 230, 0.26) 0, transparent 46%);
  clip-path: none;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-shell::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.19) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.16) 1px, transparent 1px);
  background-size: 46px 46px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.34), transparent 68%);
  -webkit-mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.34), transparent 68%);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-hero,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-layout {
  max-width: 1560px;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-hero {
  grid-template-columns: minmax(0, 1fr) minmax(260px, 0.42fr);
  gap: clamp(24px, 4vw, 70px);
  align-items: center;
  margin: 0 auto 24px;
  padding: clamp(30px, 4.5vw, 62px);
  border: 1px solid var(--cp-shop-border);
  border-radius: clamp(30px, 4vw, 48px);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.76), rgba(235, 247, 250, 0.58)),
    radial-gradient(circle at 12% 0%, rgba(255, 255, 255, 0.92), transparent 44%),
    radial-gradient(circle at 100% 6%, rgba(171, 222, 235, 0.34), transparent 46%);
  box-shadow: var(--cp-shop-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.84);
  backdrop-filter: blur(22px) saturate(138%);
  -webkit-backdrop-filter: blur(22px) saturate(138%);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-hero h1 {
  max-width: 840px;
  color: var(--cp-shop-ink);
  font-size: clamp(2.45rem, 5.2vw, 5.25rem);
  line-height: 0.96;
  letter-spacing: -0.07em;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-hero p {
  max-width: 720px;
  margin-top: 18px;
  color: var(--cp-shop-muted);
  font-size: clamp(1rem, 1.28vw, 1.25rem);
  line-height: 1.8;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-brand-signal {
  justify-self: end;
  width: min(100%, 350px);
  min-height: 250px;
  padding: 28px;
  border: 1px solid var(--cp-shop-border);
  border-radius: 34px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.62), rgba(235, 247, 250, 0.38)),
    radial-gradient(circle at 30% 18%, rgba(255, 255, 255, 0.88), transparent 45%),
    radial-gradient(circle at 72% 88%, rgba(21, 53, 72, 0.12), transparent 48%);
  box-shadow:
    0 26px 62px rgba(21, 53, 72, 0.13),
    inset 0 1px 0 rgba(255, 255, 255, 0.82);
  backdrop-filter: blur(18px) saturate(136%);
  -webkit-backdrop-filter: blur(18px) saturate(136%);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-brand-signal::before {
  display: none;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-medallion {
  width: 118px;
  height: 118px;
  margin-bottom: 20px;
  border: 1px solid rgba(255, 255, 255, 0.82);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.92), rgba(225, 241, 246, 0.64)),
    radial-gradient(circle at 38% 24%, rgba(255, 255, 255, 0.9), transparent 54%);
  box-shadow:
    0 22px 42px rgba(21, 53, 72, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.92);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-medallion .brand-logo-img {
  width: 84px;
  height: 84px;
  object-fit: contain;
  filter: drop-shadow(0 10px 18px rgba(21, 53, 72, 0.12));
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-signal-copy strong,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-category-panel h2,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-trust-panel strong {
  color: var(--cp-shop-ink);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-signal-copy span,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-category-panel p,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-trust-panel p {
  color: var(--cp-shop-muted);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-layout {
  grid-template-columns: minmax(230px, 260px) minmax(0, 1fr);
  gap: clamp(18px, 2vw, 28px);
  margin: 0 auto;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-category-panel,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-trust-panel,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-toolbar,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-empty {
  border: 1px solid rgba(255, 255, 255, 0.7);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.64), rgba(232, 246, 249, 0.44)),
    radial-gradient(circle at 22% 0%, rgba(255, 255, 255, 0.82), transparent 46%);
  box-shadow:
    0 24px 60px rgba(21, 53, 72, 0.11),
    inset 0 1px 0 rgba(255, 255, 255, 0.82);
  backdrop-filter: blur(20px) saturate(136%);
  -webkit-backdrop-filter: blur(20px) saturate(136%);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-category-panel,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-trust-panel {
  border-radius: 28px;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-category-panel h2 {
  min-height: 58px;
  padding: 0 20px;
  color: var(--cp-shop-ink);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.52), rgba(228, 244, 248, 0.34)),
    radial-gradient(circle at 12% 0%, rgba(255, 255, 255, 0.84), transparent 48%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.76),
    0 1px 0 rgba(255, 255, 255, 0.48);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-category-panel h2 svg {
  stroke: currentColor;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-category-panel nav {
  gap: 7px;
  padding: 12px;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-category-panel nav a {
  min-height: 46px;
  border: 1px solid rgba(255, 255, 255, 0.66);
  border-radius: 14px;
  color: rgba(21, 53, 72, 0.74);
  background: rgba(255, 255, 255, 0.42);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.74),
    0 12px 24px rgba(21, 53, 72, 0.06);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-category-panel nav a:hover {
  color: var(--cp-shop-ink);
  background: rgba(255, 255, 255, 0.64);
  transform: translateX(3px);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-category-panel nav a.active {
  border-color: rgba(21, 53, 72, 0.16);
  color: #fff;
  background: linear-gradient(135deg, #051f28 0%, #08313d 52%, #153548 100%);
  box-shadow:
    0 18px 34px rgba(21, 53, 72, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.2);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-toolbar {
  align-items: center;
  margin-bottom: 20px;
  padding: 16px 18px;
  border-radius: 26px;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-grid-icon {
  border: 1px solid rgba(255, 255, 255, 0.72);
  color: var(--cp-shop-ink);
  background: rgba(255, 255, 255, 0.5);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.74);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-live-product-search--shop {
  width: min(268px, 24vw);
  min-width: 232px;
  height: 42px;
  border-radius: 16px;
  border-color: rgba(21, 53, 72, 0.14);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.74), rgba(239, 248, 250, 0.48));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.82),
    0 8px 18px rgba(21, 53, 72, 0.07);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products {
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: clamp(18px, 1.8vw, 26px);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-placeholder {
  display: none !important;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .woocommerce-info {
  border-color: rgba(255, 255, 255, 0.7);
  color: var(--cp-shop-ink);
  background: rgba(255, 255, 255, 0.58);
  box-shadow: 0 18px 42px rgba(21, 53, 72, 0.1);
}

@media (min-width: 981px) {
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) {
    background:
      linear-gradient(180deg, rgba(239, 248, 251, 0.68) 0%, rgba(239, 248, 251, 0.82) 45%, rgba(236, 246, 249, 0.96) 100%),
      url("../images/backgrounds/home-background-desktop.jpg") center top / cover no-repeat,
      linear-gradient(135deg, #edf6f9 0%, #f7fbfc 36%, #e7f2f6 100%);
  }
}

@media (max-width: 1180px) {
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .site-header {
    grid-template-columns: minmax(190px, auto) 1fr auto;
    gap: 16px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav {
    gap: 14px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-hero {
    grid-template-columns: 1fr;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-brand-signal {
    justify-self: stretch;
    width: 100%;
    min-height: 190px;
  }
}

@media (max-width: 980px) {
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .site-header {
    margin: 0 14px;
    padding: 12px 14px;
    border-radius: 26px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-shell {
    margin-top: -76px;
    padding-top: 128px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-layout {
    grid-template-columns: 1fr;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-sidebar {
    order: 0;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main {
    order: 1;
  }
}

@media (max-width: 720px) {
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-shell {
    padding-left: 12px;
    padding-right: 12px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-hero {
    padding: 26px 20px;
    border-radius: 30px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-brand-signal {
    min-height: 0;
    padding: 20px;
    border-radius: 26px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-medallion {
    width: 92px;
    height: 92px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-medallion .brand-logo-img {
    width: 66px;
    height: 66px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products {
    grid-template-columns: minmax(0, 1fr);
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-toolbar {
    align-items: stretch;
  }
}

@media (max-width: 820px) {
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .site-header {
    position: static;
    width: auto;
    margin: 10px 10px 0;
    padding: 12px;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    border-radius: 24px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .site-header > *,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .brand {
    min-width: 0;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .brand-logo-img--header {
    width: 42px;
    height: 42px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .header-actions {
    justify-self: end;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav {
    position: static;
    grid-column: 1 / -1;
    order: 4;
    display: flex;
    justify-content: flex-start;
    width: 100%;
    max-width: 100%;
    gap: 8px;
    padding: 6px;
    overflow-x: auto;
    border: 1px solid rgba(255, 255, 255, 0.66);
    border-radius: 18px;
    background:
      linear-gradient(135deg, rgba(255, 255, 255, 0.56), rgba(232, 246, 249, 0.34)),
      radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.82), transparent 48%);
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.76),
      0 14px 28px rgba(21, 53, 72, 0.09);
    transform: none;
    scrollbar-width: none;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav::-webkit-scrollbar {
    display: none;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav a {
    flex: 0 0 auto;
    min-height: 36px;
    padding: 0 13px;
    border: 1px solid rgba(255, 255, 255, 0.64);
    border-radius: 999px;
    color: rgba(21, 53, 72, 0.72);
    background: rgba(255, 255, 255, 0.38);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.62);
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav a.is-active,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav a[aria-current="page"] {
    min-height: 36px;
    padding: 0 16px;
    color: #fff;
    background: var(--cp-shop-ink);
    box-shadow: 0 10px 22px rgba(21, 53, 72, 0.2);
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-shell {
    margin-top: 0;
    padding-top: 24px;
  }
}
/* Shop page header/brand-card parity with the accepted homepage glass system. */
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .site-header {
  min-height: 104px;
  grid-template-columns: minmax(330px, auto) minmax(0, 1fr) auto;
  gap: clamp(26px, 4.8vw, 78px);
  padding: 14px clamp(26px, 3.6vw, 54px);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .brand {
  gap: 16px;
  min-width: max-content;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .brand-logo-img--header {
  width: 78px;
  height: 78px;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .brand-name {
  position: relative;
  max-width: none;
  color: #153548;
  font-size: 28px;
  line-height: 1;
  white-space: nowrap;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .brand-name::after {
  position: absolute;
  bottom: -9px;
  left: 50%;
  width: 78%;
  height: 2px;
  pointer-events: none;
  content: "";
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(21, 53, 72, 0.18) 12%,
    rgba(21, 53, 72, 0.72) 42%,
    rgba(21, 53, 72, 0.96) 52%,
    rgba(21, 53, 72, 0.72) 62%,
    rgba(21, 53, 72, 0.18) 88%,
    transparent 100%
  );
  box-shadow:
    0 0 9px rgba(21, 53, 72, 0.24),
    0 2px 17px rgba(21, 53, 72, 0.14);
  transform: translateX(-50%);
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav {
  position: static;
  justify-self: center;
  justify-content: center;
  width: auto;
  gap: clamp(26px, 3.6vw, 58px);
  transform: none;
  font-size: 17px;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav a,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav a:hover {
  min-height: 42px;
  padding: 0 18px;
  border: 1px solid transparent !important;
  border-radius: 999px !important;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav a.is-active,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav a[aria-current="page"],
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav a.is-active:hover,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav a[aria-current="page"]:hover {
  min-height: 42px;
  padding: 0 18px;
  color: #fff !important;
  border: 1px solid rgba(255, 255, 255, 0.42) !important;
  background: #153548 !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 12px 26px rgba(21, 53, 72, 0.18) !important;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .header-actions {
  gap: 12px;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-brand-signal {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 18px;
  min-height: 270px;
  text-align: center;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-medallion {
  width: 178px;
  height: 178px;
  margin: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  filter: drop-shadow(0 24px 34px rgba(21, 53, 72, 0.18));
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-medallion .brand-logo-img,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-medallion .brand-logo-img--shop {
  width: 178px;
  height: 178px;
  object-fit: contain;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-signal-copy {
  position: relative;
  z-index: 1;
  display: block;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-signal-copy strong {
  display: block;
  color: #153548;
  font-size: clamp(1.28rem, 1.8vw, 1.72rem);
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1.05;
}

@media (max-width: 1360px) and (min-width: 981px) {
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .site-header {
    grid-template-columns: minmax(300px, auto) minmax(0, 1fr) auto;
    gap: clamp(22px, 3.4vw, 48px);
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .brand-logo-img--header {
    width: 70px;
    height: 70px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .brand-name {
    font-size: 25px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav {
    gap: clamp(20px, 2.6vw, 40px);
    font-size: 15px;
  }
}

@media (max-width: 980px) {
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .site-header {
    min-height: 0;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px 18px;
    padding: 12px 18px 14px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .brand {
    min-width: 0;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .brand-logo-img--header {
    width: 64px;
    height: 64px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .brand-name {
    max-width: 168px;
    overflow: hidden;
    font-size: 23px;
    text-overflow: ellipsis;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav {
    grid-column: 1 / -1;
    justify-self: stretch;
    width: 100%;
    justify-content: flex-start;
    overflow-x: auto;
  }
}

@media (max-width: 620px) {
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) {
    overflow-x: hidden;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .site-header {
    position: relative;
    width: 100vw;
    max-width: 100vw;
    margin: 0;
    grid-template-columns: minmax(0, 1fr) auto;
    overflow: hidden;
    padding: 12px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .brand {
    width: 58px;
    gap: 10px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .brand-name {
    display: none;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .brand-logo-img--header {
    width: 58px;
    height: 58px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .header-actions {
    display: none;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .main-nav {
    order: 2;
    width: calc(100vw - 24px);
    max-width: calc(100vw - 24px);
  }
}

@media (max-width: 720px) {
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-brand-signal {
    gap: 14px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-medallion,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-medallion .brand-logo-img,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-medallion .brand-logo-img--shop {
    width: 132px;
    height: 132px;
  }
}
/* Canonical site header: the accepted homepage header is now inherited site-wide. */
.top-strip {
  display: none !important;
}
.site-header {
  top: 16px !important;
  width: min(1560px, calc(100% - 44px)) !important;
  min-height: 104px !important;
  margin: 18px auto 0 !important;
  grid-template-columns: minmax(330px, auto) minmax(0, 1fr) auto !important;
  gap: clamp(26px, 4.8vw, 78px) !important;
  padding: 14px clamp(26px, 3.6vw, 54px) !important;
  border: 1px solid rgba(255, 255, 255, 0.48) !important;
  border-radius: 24px !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.54), rgba(255, 255, 255, 0.2)),
    radial-gradient(circle at 8% 0%, rgba(255, 255, 255, 0.62), transparent 34%) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    inset 0 -1px 0 rgba(255, 255, 255, 0.24),
    0 18px 56px rgba(21, 53, 72, 0.14) !important;
  backdrop-filter: blur(34px) saturate(1.36) !important;
  -webkit-backdrop-filter: blur(34px) saturate(1.36) !important;
}
.site-header .brand {
  gap: 16px !important;
  min-width: max-content !important;
}
.site-header .brand-logo-img--header {
  width: 78px !important;
  height: 78px !important;
}
.site-header .brand-name {
  position: relative !important;
  display: inline-block;
  max-width: none !important;
  overflow: visible !important;
  color: #153548 !important;
  font-size: 28px !important;
  line-height: 1 !important;
  text-overflow: clip !important;
  white-space: nowrap !important;
}
.site-header .brand-name::after {
  position: absolute;
  bottom: -9px;
  left: 50%;
  width: 78%;
  height: 2px;
  pointer-events: none;
  content: "";
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(21, 53, 72, 0.18) 12%,
    rgba(21, 53, 72, 0.72) 42%,
    rgba(21, 53, 72, 0.96) 52%,
    rgba(21, 53, 72, 0.72) 62%,
    rgba(21, 53, 72, 0.18) 88%,
    transparent 100%
  );
  box-shadow:
    0 0 9px rgba(21, 53, 72, 0.24),
    0 2px 17px rgba(21, 53, 72, 0.14);
  transform: translateX(-50%);
}
.site-header .main-nav {
  position: static !important;
  justify-self: center !important;
  justify-content: center !important;
  width: auto !important;
  gap: clamp(26px, 3.6vw, 58px) !important;
  transform: none !important;
  font-size: 17px !important;
  font-weight: 700 !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}
.site-header .main-nav a,
.site-header .main-nav a:hover {
  min-height: 42px !important;
  padding: 0 18px !important;
  border: 1px solid transparent !important;
  border-radius: 999px !important;
}
.site-header .main-nav a.is-active,
.site-header .main-nav a[aria-current="page"],
.site-header .main-nav a.is-active:hover,
.site-header .main-nav a[aria-current="page"]:hover {
  min-height: 42px !important;
  padding: 0 18px !important;
  color: #fff !important;
  border: 1px solid rgba(255, 255, 255, 0.42) !important;
  background: #153548 !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 12px 26px rgba(21, 53, 72, 0.18) !important;
}
.site-header .header-actions {
  justify-self: end !important;
  gap: 12px !important;
}
.site-header .icon-button,
.site-header .cart-button {
  min-height: 58px !important;
  border-color: rgba(255, 255, 255, 0.48) !important;
  border-radius: 12px !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.4), rgba(255, 255, 255, 0.16)) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.68),
    0 12px 30px rgba(21, 53, 72, 0.1) !important;
}
.site-header .icon-button {
  width: 82px !important;
  flex-direction: column !important;
  gap: 2px !important;
  padding: 7px 10px 6px !important;
}
.site-header .icon-button::after {
  display: block;
  color: #153548;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  content: "Hesabım";
}
.site-header .cart-button {
  gap: 8px !important;
  padding: 8px 14px !important;
}
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .site-header .icon-button.is-active,
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .site-header .cart-button.is-active,
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .site-header .icon-button[aria-current="page"],
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .site-header .cart-button[aria-current="page"] {
  color: #fff !important;
  border-color: rgba(255, 255, 255, 0.42) !important;
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.14), transparent 38%),
    linear-gradient(135deg, #051f28 0%, #08313d 52%, #153548 100%) !important;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.09),
    0 14px 28px rgba(21, 53, 72, 0.2) !important;
}
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .site-header .icon-button.is-active::after,
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .site-header .icon-button[aria-current="page"]::after,
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .site-header .cart-button.is-active strong,
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .site-header .cart-button[aria-current="page"] strong {
  color: #fff !important;
}
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .site-header .cart-button.is-active .cart-count,
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .site-header .cart-button[aria-current="page"] .cart-count {
  color: #153548 !important;
  border-color: rgba(255, 255, 255, 0.82) !important;
  background: rgba(255, 255, 255, 0.92) !important;
}

@media (max-width: 1360px) and (min-width: 981px) {
.site-header {
    grid-template-columns: minmax(300px, auto) minmax(0, 1fr) auto !important;
    gap: clamp(22px, 3.4vw, 48px) !important;
  }
.site-header .brand-logo-img--header {
    width: 70px !important;
    height: 70px !important;
  }
.site-header .brand-name {
    font-size: 25px !important;
  }
.site-header .main-nav {
    gap: clamp(20px, 2.6vw, 40px) !important;
    font-size: 15px !important;
  }
}

@media (max-width: 980px) {
.site-header {
    top: 0 !important;
    width: 100% !important;
    min-height: 0 !important;
    margin: 0 !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 12px 18px !important;
    padding: 12px 18px 14px !important;
    border-radius: 0 0 22px 22px !important;
  }
.site-header .brand {
    min-width: 0 !important;
  }
.site-header .brand-logo-img--header {
    width: 64px !important;
    height: 64px !important;
  }
.site-header .brand-name {
    max-width: 168px !important;
    overflow: hidden !important;
    font-size: 23px !important;
    text-overflow: ellipsis !important;
  }
.site-header .main-nav {
    grid-column: 1 / -1 !important;
    justify-self: stretch !important;
    width: 100% !important;
    justify-content: flex-start !important;
    overflow-x: auto !important;
  }
}

@media (max-width: 620px) {
body {
    overflow-x: hidden;
  }
.site-header {
    position: relative !important;
    width: 100vw !important;
    max-width: 100vw !important;
    margin: 0 !important;
    grid-template-columns: auto minmax(0, 1fr) !important;
    gap: 10px 12px !important;
    overflow: hidden !important;
    padding: 12px !important;
  }
.site-header > *,
.site-header .brand,
.site-header .main-nav,
.site-header .header-actions {
    min-width: 0 !important;
  }
.site-header .brand {
    width: 58px !important;
    gap: 10px !important;
  }
.site-header .brand-name {
    display: none !important;
  }
.site-header .brand-logo-img--header {
    width: 58px !important;
    height: 58px !important;
  }
.site-header .header-actions {
    display: flex !important;
    grid-column: 2 !important;
    grid-row: 1 !important;
    justify-self: end !important;
    gap: 7px !important;
  }
.site-header .icon-button,
.site-header .cart-button {
    width: 50px !important;
    min-height: 46px !important;
    padding: 6px 8px !important;
    border-radius: 12px !important;
  }
.site-header .icon-button {
    gap: 0 !important;
  }
.site-header .icon-button::after,
.site-header .cart-button strong {
    display: none !important;
  }
.site-header .main-nav {
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
    order: initial !important;
    width: calc(100vw - 24px) !important;
    max-width: calc(100vw - 24px) !important;
  }
}
/* Shop scenic background: reuse the homepage landscape but keep a deeper blue veil. */
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) {
  position: relative;
  isolation: isolate;
  background:
    linear-gradient(180deg, rgba(8, 44, 62, 0.44) 0%, rgba(41, 96, 116, 0.28) 24%, rgba(197, 226, 235, 0.52) 48%, rgba(232, 244, 248, 0.9) 100%),
    radial-gradient(circle at 7% 24%, rgba(21, 53, 72, 0.28), transparent 18rem),
    radial-gradient(circle at 92% 10%, rgba(83, 151, 171, 0.28), transparent 24rem),
    linear-gradient(116deg, transparent 0 30%, rgba(255, 255, 255, 0.1) 30% 42%, transparent 42% 100%),
    repeating-linear-gradient(103deg, rgba(255, 255, 255, 0.07) 0 1px, transparent 1px 86px),
    url("../images/backgrounds/home-background-desktop.jpg") center top / cover no-repeat,
    linear-gradient(135deg, #dbeef4 0%, #eef7fa 42%, #d7e9ef 100%) !important;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag)::before {
  display: none !important;
  content: none !important;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-shell,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .site-footer {
  position: relative;
  z-index: 1;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-shell::before {
  display: none !important;
  content: none !important;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-shell::after {
  display: none !important;
  content: none !important;
}

@media (max-width: 980px) {
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) {
    background:
      linear-gradient(180deg, rgba(8, 44, 62, 0.34) 0%, rgba(51, 111, 132, 0.2) 28%, rgba(225, 241, 246, 0.78) 52%, rgba(238, 247, 249, 0.94) 100%),
      radial-gradient(circle at 8% 18%, rgba(21, 53, 72, 0.22), transparent 14rem),
      radial-gradient(circle at 90% 8%, rgba(83, 151, 171, 0.22), transparent 18rem),
      repeating-linear-gradient(103deg, rgba(255, 255, 255, 0.06) 0 1px, transparent 1px 72px),
      url("../images/backgrounds/home-background-desktop.jpg") center top / auto 520px no-repeat,
      linear-gradient(135deg, #dbeef4 0%, #eef7fa 42%, #d7e9ef 100%) !important;
  }
}
/* Shop grid only: product-card visuals come from the shared homepage catalog card rules above. */
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products {
  display: grid !important;
  grid-template-columns: var(--cp-product-grid-template) !important;
  gap: var(--cp-product-grid-gap) !important;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products::before,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products::after {
  display: none !important;
  content: none !important;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products li.product.product-card {
  float: none !important;
  width: auto !important;
  margin: 0 !important;
}
body :is(.product-grid, .products[data-product-grid]) > [data-product-card][hidden],
body :is(.product-grid, .products[data-product-grid]) > li.product.product-card[hidden] {
  display: none !important;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products li.product.product-card h3 {
  padding-right: 24px;
  font-size: 16px;
  line-height: 1.25;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products li.product.product-card .price-row,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products li.product.product-card .price-row .price,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products li.product.product-card .price-row .amount,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products li.product.product-card .price-row .woocommerce-Price-amount,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products li.product.product-card .price-row .woocommerce-Price-currencySymbol {
  color: var(--green-2);
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products li.product.product-card .price-row strong {
  color: var(--green-2);
  font-size: 20px;
  font-weight: 800;
  line-height: 1.05;
}

@media (max-width: 1180px) {
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products {
    --cp-product-grid-template: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1361px) {
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products li.product.product-card h3 {
    font-size: 17px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products li.product.product-card .price-row strong {
    font-size: 22px;
  }
}

@media (max-width: 520px) {
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products {
    --cp-product-grid-template: 1fr;
    --cp-product-media-margin: 10px 10px 0;
    --cp-product-media-max-height: 228px;
    --cp-product-body-margin: 0 10px 10px;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-sort {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    width: 100% !important;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-sort .woocommerce-ordering,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-sort select,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-sort .cp-live-product-search {
    width: 100% !important;
    min-width: 0 !important;
    flex: none !important;
  }
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-main ul.products li.product.product-card .price-row strong {
    font-size: 21px;
  }

}
/* Shop action color lock: avoid the older green-blue button feel on the new glass shop page. */
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-category-panel nav a.active,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-category-panel nav a.active:hover {
  color: #fff !important;
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.14), transparent 38%),
    linear-gradient(135deg, #051f28 0%, #08313d 52%, #153548 100%) !important;
}
/* Header interaction lock: keep the shared site header above shop glass/background layers. */
.site-header {
  position: sticky !important;
  z-index: 1000 !important;
  pointer-events: auto !important;
  isolation: isolate;
}
.site-header a,
.site-header button,
.site-header .main-nav,
.site-header .header-actions {
  pointer-events: auto !important;
}
/* Purchase and account refresh: carry the accepted ice-blue glass storefront language through WooCommerce flows. */
html:has(body:is(.single-product, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account)),
body.single-product,
body.woocommerce-cart,
body.woocommerce-checkout,
body.woocommerce-account {
  --cp-flow-ink: #153548;
  --cp-flow-muted: #425d68;
  --cp-flow-line: rgba(255, 255, 255, 0.68);
  --cp-flow-glass: rgba(255, 255, 255, 0.66);
  --cp-flow-glass-soft: rgba(226, 244, 249, 0.4);
  color: var(--cp-flow-ink);
  background:
    radial-gradient(circle at 10% 8%, rgba(255, 255, 255, 0.68), transparent 18rem),
    radial-gradient(circle at 90% 12%, rgba(110, 176, 193, 0.2), transparent 24rem),
    radial-gradient(circle at 55% 52%, rgba(21, 53, 72, 0.07), transparent 28rem),
    repeating-linear-gradient(103deg, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px 78px),
    linear-gradient(180deg, rgba(229, 244, 248, 0.66) 0%, rgba(238, 248, 250, 0.88) 42%, rgba(247, 251, 252, 1) 100%),
    url("../images/backgrounds/home-background-desktop.jpg") center top / cover no-repeat,
    linear-gradient(135deg, #e0f0f4 0%, #f5fbfc 54%, #e6f2f6 100%) !important;
}
body.single-product::before,
body.woocommerce-cart::before,
body.woocommerce-checkout::before,
body.woocommerce-account::before {
  display: none;
  content: none;
}
body.single-product .woo-page-shell,
body.woocommerce-cart .cp-cart-shell,
body.woocommerce-checkout .cp-checkout-shell,
body.woocommerce-account .cp-account-shell {
  position: relative;
  isolation: isolate;
  max-width: 1560px;
  margin-inline: auto;
  padding: clamp(34px, 4.4vw, 72px) clamp(18px, 2.5vw, 36px) 86px;
}
body.single-product .cp-single-product {
  max-width: 1560px;
  padding: 0;
}
body.single-product .cp-breadcrumb {
  width: calc(100% - clamp(4px, 1vw, 12px));
  margin: 0 auto 18px;
  color: rgba(21, 53, 72, 0.68);
  font-weight: 800;
}
body.single-product .cp-breadcrumb a {
  color: var(--cp-flow-ink);
}
body.single-product .cp-product-hero,
body.woocommerce-cart .cp-cart-head,
body.woocommerce-checkout .cp-cart-head,
body.woocommerce-account .cp-account-head {
  border: 1px solid var(--cp-flow-line);
  border-radius: clamp(28px, 3vw, 44px);
  padding: clamp(24px, 3.6vw, 54px);
  overflow: hidden;
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 255, 255, 0.74), transparent 32%),
    radial-gradient(circle at 86% 12%, rgba(255, 255, 255, 0.46), transparent 26%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.58), rgba(226, 244, 249, 0.32));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.76),
    0 18px 42px rgba(21, 53, 72, 0.08);
}
body.single-product .cp-product-hero {
  grid-template-columns: minmax(380px, 0.92fr) minmax(420px, 1fr);
  gap: clamp(24px, 3.4vw, 54px);
  align-items: stretch;
  min-height: clamp(480px, 41vw, 650px);
}
body.single-product .cp-product-gallery,
body.single-product .cp-product-info,
body.single-product .cp-related-card,
body.woocommerce-cart :is(.wc-block-cart__main, .woocommerce-cart-form, .wc-block-cart__sidebar, .cart-collaterals .cart_totals, .cp-cart-service-band),
body.woocommerce-checkout :is(.wc-block-checkout__main, #customer_details, .wc-block-checkout__sidebar, #order_review, .cp-cart-service-band),
body.woocommerce-account :is(.woocommerce-MyAccount-navigation.cp-account-nav, .woocommerce-MyAccount-content, .cp-account-welcome, .cp-account-panel, .cp-account-details-card, .cp-account-support-card, .cp-address-book-group, .cp-address-book-card, .cp-address-book-empty, .woocommerce-Address, .woocommerce-column--billing-address, .woocommerce-column--shipping-address, form.login, form.register, .woocommerce-form-login, .woocommerce-form-register, .woocommerce-EditAccountForm, form.woocommerce-address-fields, .cp-account-address-note) {
  border: 1px solid rgba(255, 255, 255, 0.68);
  border-radius: clamp(22px, 2vw, 32px);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.72), rgba(226, 244, 249, 0.38));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.74),
    0 12px 28px rgba(21, 53, 72, 0.07);
}
body.single-product .cp-product-gallery {
  display: grid;
  align-content: stretch;
  min-height: 100%;
}
body.single-product .cp-product-gallery .woocommerce-product-gallery {
  opacity: 1 !important;
}
body.single-product .cp-product-gallery--static {
  place-items: center;
  padding: clamp(30px, 4vw, 58px);
}
body.single-product .cp-product-main-image {
  position: relative;
  z-index: 1;
  display: grid;
  width: min(100%, 500px);
  min-height: clamp(420px, 34vw, 570px);
  place-items: center;
  border-radius: 24px;
  background:
    radial-gradient(circle at 50% 46%, rgba(255, 255, 255, 0.84), transparent 34%),
    radial-gradient(circle at 58% 72%, rgba(21, 53, 72, 0.1), transparent 32%);
  text-decoration: none;
}
body.single-product .cp-product-main-image img {
  display: block;
  width: auto;
  max-width: min(82%, 420px);
  max-height: clamp(360px, 30vw, 520px);
  object-fit: contain;
}
body.single-product .cp-product-thumbs {
  position: relative;
  z-index: 1;
  display: grid;
  width: 100%;
  grid-template-columns: repeat(auto-fit, minmax(76px, 96px));
  justify-content: center;
  gap: 12px;
  margin-top: 18px;
}
body.single-product .cp-product-thumbs a {
  display: grid;
  min-height: 86px;
  place-items: center;
  border: 1px solid rgba(21, 53, 72, 0.12);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.62);
}
body.single-product .cp-product-thumbs img {
  width: 76px;
  height: 76px;
  object-fit: contain;
}
body.single-product .cp-product-gallery::after {
  border-color: rgba(255, 255, 255, 0.72);
  background:
    radial-gradient(circle at 35% 20%, rgba(255, 255, 255, 0.84), transparent 34%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.62), rgba(226, 244, 249, 0.38));
  box-shadow: 0 10px 22px rgba(21, 53, 72, 0.08);
}
body.single-product .cp-product-gallery--static::after {
  display: none !important;
  content: none !important;
}
body.single-product .woocommerce-product-gallery__trigger,
body.single-product .zoomImg {
  display: none !important;
}
body.single-product .cp-product-main-image,
body.single-product .cp-product-thumbs a {
  cursor: pointer;
}
body.single-product .cp-product-main-image:focus-visible,
body.single-product .cp-product-thumbs a:focus-visible {
  outline: 3px solid rgba(117, 181, 203, 0.42);
  outline-offset: 4px;
}
body.single-product .cp-product-gallery .woocommerce-product-gallery__image {
  min-height: clamp(420px, 34vw, 570px);
  background:
    radial-gradient(circle at 50% 46%, rgba(255, 255, 255, 0.84), transparent 34%),
    radial-gradient(circle at 58% 72%, rgba(21, 53, 72, 0.1), transparent 32%);
}
body.single-product .cp-product-gallery .woocommerce-product-gallery__image img {
  max-width: 82%;
  filter: none;
}
body.single-product .cp-product-gallery .flex-control-thumbs li {
  border-color: rgba(21, 53, 72, 0.12);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.58);
}
body.cp-product-lightbox-open {
  overflow: hidden;
}
.cp-product-lightbox[hidden] {
  display: none !important;
}
.cp-product-lightbox {
  position: fixed;
  inset: 0;
  z-index: 999999;
  display: grid;
  place-items: center;
  padding: clamp(16px, 2.8vw, 42px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease;
}
.cp-product-lightbox.is-open {
  opacity: 1;
  pointer-events: auto;
}
.cp-product-lightbox__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background:
    radial-gradient(circle at 18% 14%, rgba(117, 181, 203, 0.16), transparent 28rem),
    radial-gradient(circle at 86% 78%, rgba(47, 103, 37, 0.14), transparent 26rem),
    rgba(3, 22, 29, 0.76);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  cursor: pointer;
}
.cp-product-lightbox__panel {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  width: min(1120px, calc(100vw - 32px));
  max-height: min(860px, calc(100dvh - 32px));
  border: 1px solid rgba(255, 255, 255, 0.46);
  border-radius: clamp(22px, 2.2vw, 34px);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.92), rgba(226, 244, 249, 0.72)),
    #f7fbfa;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 34px 90px rgba(0, 18, 26, 0.46);
  overflow: hidden;
  transform: translateY(12px) scale(0.985);
  transition: transform 220ms cubic-bezier(0.2, 0.82, 0.22, 1);
}
.cp-product-lightbox.is-open .cp-product-lightbox__panel {
  transform: translateY(0) scale(1);
}
.cp-product-lightbox__close,
.cp-product-lightbox__nav,
.cp-product-lightbox__thumb {
  font: inherit;
}
.cp-product-lightbox__close {
  position: absolute;
  top: clamp(14px, 1.8vw, 22px);
  right: clamp(14px, 1.8vw, 22px);
  z-index: 3;
  display: grid;
  width: 46px;
  height: 46px;
  place-items: center;
  border: 1px solid rgba(21, 53, 72, 0.12);
  border-radius: 50%;
  color: #153548;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 12px 28px rgba(5, 31, 40, 0.12);
  cursor: pointer;
}
.cp-product-lightbox__close svg,
.cp-product-lightbox__nav svg {
  width: 21px;
  height: 21px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cp-product-lightbox__stage {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr) 58px;
  gap: clamp(12px, 2vw, 24px);
  align-items: center;
  min-height: clamp(430px, 62vh, 660px);
  padding: clamp(26px, 4vw, 56px);
}
.cp-product-lightbox__figure {
  display: grid;
  min-width: 0;
  min-height: 0;
  gap: 16px;
  margin: 0;
}
.cp-product-lightbox__figure::before {
  grid-area: 1 / 1;
  min-height: clamp(310px, 52vh, 560px);
  border: 1px solid rgba(21, 53, 72, 0.1);
  border-radius: clamp(18px, 1.8vw, 28px);
  background:
    radial-gradient(circle at 50% 44%, rgba(255, 255, 255, 0.94), transparent 34%),
    radial-gradient(circle at 56% 76%, rgba(21, 53, 72, 0.12), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(240, 248, 247, 0.86));
  content: "";
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82);
}
.cp-product-lightbox__image {
  position: relative;
  grid-area: 1 / 1;
  align-self: center;
  justify-self: center;
  width: auto;
  max-width: min(84%, 620px);
  max-height: min(52vh, 560px);
  object-fit: contain;
  filter: drop-shadow(0 18px 28px rgba(5, 31, 40, 0.12));
}
.cp-product-lightbox__caption {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  color: #153548;
  font-size: 14px;
  font-weight: 800;
}
.cp-product-lightbox__caption small {
  flex: 0 0 auto;
  color: #5d7178;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
}
.cp-product-lightbox__nav {
  display: grid;
  width: 54px;
  height: 54px;
  place-items: center;
  border: 1px solid rgba(21, 53, 72, 0.12);
  border-radius: 50%;
  color: #153548;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 14px 34px rgba(5, 31, 40, 0.12);
  cursor: pointer;
  transition: transform 160ms ease, box-shadow 180ms ease, background 180ms ease;
}
.cp-product-lightbox__nav:hover,
.cp-product-lightbox__close:hover {
  background: #fff;
  box-shadow: 0 18px 38px rgba(5, 31, 40, 0.18);
  transform: translateY(-1px);
}
.cp-product-lightbox[data-has-multiple="false"] .cp-product-lightbox__nav,
.cp-product-lightbox[data-has-multiple="false"] .cp-product-lightbox__thumbs {
  display: none;
}
.cp-product-lightbox[data-has-multiple="false"] .cp-product-lightbox__stage {
  grid-template-columns: 1fr;
}
.cp-product-lightbox__thumbs {
  display: flex;
  gap: 10px;
  padding: 0 clamp(24px, 4vw, 56px) clamp(22px, 3vw, 34px);
  overflow-x: auto;
  scrollbar-width: thin;
}
.cp-product-lightbox__thumb {
  display: grid;
  flex: 0 0 82px;
  height: 76px;
  place-items: center;
  border: 1px solid rgba(21, 53, 72, 0.12);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.62);
  cursor: pointer;
  transition: border-color 160ms ease, transform 160ms ease, background 160ms ease;
}
.cp-product-lightbox__thumb[aria-current="true"] {
  border-color: rgba(21, 53, 72, 0.54);
  background: rgba(255, 255, 255, 0.92);
  transform: translateY(-1px);
}
.cp-product-lightbox__thumb img {
  width: 66px;
  height: 58px;
  object-fit: contain;
}
@media (max-width: 760px) {
  .cp-product-lightbox {
    padding: 10px;
  }
  .cp-product-lightbox__panel {
    width: calc(100vw - 20px);
    max-height: calc(100dvh - 20px);
    border-radius: 22px;
  }
  .cp-product-lightbox__stage {
    grid-template-columns: 1fr;
    min-height: 0;
    gap: 14px;
    padding: 72px 14px 18px;
  }
  .cp-product-lightbox__nav {
    position: absolute;
    top: 50%;
    z-index: 2;
    width: 44px;
    height: 44px;
    transform: translateY(-50%);
  }
  .cp-product-lightbox__nav:hover {
    transform: translateY(-50%);
  }
  .cp-product-lightbox__nav--prev {
    left: 14px;
  }
  .cp-product-lightbox__nav--next {
    right: 14px;
  }
  .cp-product-lightbox__figure::before {
    min-height: min(58vh, 430px);
  }
  .cp-product-lightbox__image {
    max-width: 82%;
    max-height: min(48vh, 400px);
  }
  .cp-product-lightbox__caption {
    align-items: flex-start;
    flex-direction: column;
    gap: 4px;
    padding-inline: 6px;
  }
  .cp-product-lightbox__thumbs {
    padding: 0 14px 18px;
  }
}
body.single-product .cp-product-summary {
  display: grid;
  align-content: center;
  min-width: 0;
  padding: clamp(6px, 1vw, 14px) 0;
}
body.single-product .cp-product-title,
body.woocommerce-cart .cp-cart-head h1,
body.woocommerce-checkout .cp-cart-head h1,
body.woocommerce-account .cp-account-head h1 {
  color: var(--cp-flow-ink);
  letter-spacing: -0.048em;
}
body.single-product .cp-product-title {
  max-width: 760px;
  font-size: clamp(44px, 5vw, 76px);
  line-height: 0.98;
}
body.single-product .cp-price-row strong {
  color: var(--cp-flow-ink);
  font-size: clamp(28px, 2.4vw, 38px);
}
body.single-product .cp-price-row > span {
  color: rgba(21, 53, 72, 0.64);
  font-weight: 800;
}
body.single-product .cp-short-description {
  color: var(--cp-flow-muted);
  font-size: 17px;
}
body.single-product .cp-feature-tags span {
  border: 1px solid rgba(21, 53, 72, 0.12);
  border-radius: 999px;
  padding: 8px 12px;
  color: var(--cp-flow-ink);
  background: rgba(255, 255, 255, 0.52);
}
body.single-product .cp-feature-tags span::before {
  width: 14px;
  height: 14px;
  border-color: #487838;
}
body.single-product .cp-purchase-panel {
  border-color: rgba(21, 53, 72, 0.12);
}
body.single-product .cp-purchase-panel .qty,
body.woocommerce-cart :is(.quantity, .wc-block-components-quantity-selector, .wc-block-components-text-input input, .shipping-calculator-form input.input-text, .shipping-calculator-form select),
body.woocommerce-checkout :is(input.input-text, select, textarea, .wc-block-components-text-input input, .wc-block-components-combobox .wc-block-components-combobox-control input),
body.woocommerce-account :is(input.input-text, input[type="text"], input[type="email"], input[type="password"], input[type="tel"], select, textarea) {
  border-color: rgba(21, 53, 72, 0.16) !important;
  border-radius: 14px !important;
  color: var(--cp-flow-ink);
  background: rgba(255, 255, 255, 0.68) !important;
}
body.woocommerce-account .cp-account-shell .cp-account-readonly-field {
  color: rgba(21, 53, 72, 0.74) !important;
  background: rgba(233, 244, 247, 0.62) !important;
}
body.woocommerce-cart :is(#calc_shipping_country_field),
body.woocommerce-checkout :is(#billing_country_field, #shipping_country_field),
body.woocommerce-account :is(#billing_country_field, #shipping_country_field) {
  width: 100%;
  justify-items: stretch;
}
body.woocommerce-cart #calc_shipping_country_field .woocommerce-input-wrapper,
body.woocommerce-checkout :is(#billing_country_field, #shipping_country_field) .woocommerce-input-wrapper,
body.woocommerce-account :is(#billing_country_field, #shipping_country_field) .woocommerce-input-wrapper {
  display: block;
  width: 100%;
  min-width: 0;
}
body.woocommerce-cart :is(select[data-cp-country-locked]:not(.select2-hidden-accessible), #calc_shipping_country_field .woocommerce-input-wrapper > strong),
body.woocommerce-checkout :is(select[data-cp-country-locked]:not(.select2-hidden-accessible), #billing_country_field .woocommerce-input-wrapper > strong, #shipping_country_field .woocommerce-input-wrapper > strong),
body.woocommerce-account :is(select[data-cp-country-locked]:not(.select2-hidden-accessible), #billing_country_field .woocommerce-input-wrapper > strong, #shipping_country_field .woocommerce-input-wrapper > strong) {
  position: relative;
  display: flex !important;
  align-items: center;
  justify-content: flex-start;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100%;
  height: 48px !important;
  min-height: 48px !important;
  padding: 0 40px 0 14px !important;
  border: 1px solid rgba(21, 53, 72, 0.16) !important;
  border-radius: 14px !important;
  color: rgba(21, 53, 72, 0.86) !important;
  background: rgba(255, 255, 255, 0.68) !important;
  box-shadow: none !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  line-height: 48px !important;
  text-align: left;
  text-align-last: left;
  white-space: nowrap;
  appearance: auto;
  cursor: default;
}
body.woocommerce-cart #calc_shipping_country_field .woocommerce-input-wrapper > strong::after,
body.woocommerce-checkout :is(#billing_country_field .woocommerce-input-wrapper > strong, #shipping_country_field .woocommerce-input-wrapper > strong),
body.woocommerce-account :is(#billing_country_field .woocommerce-input-wrapper > strong, #shipping_country_field .woocommerce-input-wrapper > strong) {
  pointer-events: none;
}
body.woocommerce-cart #calc_shipping_country_field .woocommerce-input-wrapper > strong::after,
body.woocommerce-checkout :is(#billing_country_field .woocommerce-input-wrapper > strong, #shipping_country_field .woocommerce-input-wrapper > strong)::after,
body.woocommerce-account :is(#billing_country_field .woocommerce-input-wrapper > strong, #shipping_country_field .woocommerce-input-wrapper > strong)::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 18px;
  width: 8px;
  height: 8px;
  border-right: 2px solid rgba(21, 53, 72, 0.58);
  border-bottom: 2px solid rgba(21, 53, 72, 0.58);
  transform: translateY(-65%) rotate(45deg);
}
body.woocommerce-cart :is(#calc_shipping_country_field .select2-container),
body.woocommerce-checkout :is(#billing_country_field .select2-container, #shipping_country_field .select2-container),
body.woocommerce-account :is(#billing_country_field .select2-container, #shipping_country_field .select2-container) {
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
}
body.woocommerce-cart :is(#calc_shipping_country_field .select2-selection--single),
body.woocommerce-checkout :is(#billing_country_field .select2-selection--single, #shipping_country_field .select2-selection--single),
body.woocommerce-account :is(#billing_country_field .select2-selection--single, #shipping_country_field .select2-selection--single) {
  display: flex !important;
  align-items: center !important;
  height: 48px !important;
  min-height: 48px !important;
  padding: 0 40px 0 14px !important;
  border-color: rgba(21, 53, 72, 0.16) !important;
  border-radius: 14px !important;
  background: rgba(255, 255, 255, 0.68) !important;
  box-shadow: none !important;
}
body.woocommerce-cart :is(#calc_shipping_country_field .select2-selection__rendered),
body.woocommerce-checkout :is(#billing_country_field .select2-selection__rendered, #shipping_country_field .select2-selection__rendered),
body.woocommerce-account :is(#billing_country_field .select2-selection__rendered, #shipping_country_field .select2-selection__rendered) {
  display: flex !important;
  align-items: center !important;
  height: 100% !important;
  padding-inline: 0 !important;
  color: rgba(21, 53, 72, 0.86) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  line-height: 1.2 !important;
}
body.woocommerce-cart :is(#calc_shipping_country_field .select2-selection__arrow),
body.woocommerce-checkout :is(#billing_country_field .select2-selection__arrow, #shipping_country_field .select2-selection__arrow),
body.woocommerce-account :is(#billing_country_field .select2-selection__arrow, #shipping_country_field .select2-selection__arrow) {
  display: block !important;
  right: 14px !important;
  height: 46px !important;
}
body.woocommerce-cart #calc_shipping_postcode_field .required {
  display: none !important;
}
body.single-product .cp-purchase-panel .single_add_to_cart_button,
body.single-product .cp-purchase-panel .button,
body.single-product .cp-mini-cart,
body.woocommerce-cart :is(.wc-block-components-button, .checkout-button, button[name="update_cart"], button[name="calc_shipping"]),
body.woocommerce-checkout :is(.wc-block-components-checkout-place-order-button, #place_order),
body.woocommerce-account :is(.woocommerce-button, .button, button.button, input.button, .woocommerce-Button, .cp-solid-button, .cp-account-shell .woocommerce-message .button, .cp-account-shell .woocommerce-info .button, .cp-account-shell .woocommerce-error .button) {
  border: 1px solid rgba(199, 149, 42, 0.36) !important;
  border-radius: 14px !important;
  color: #fff !important;
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.14), transparent 38%),
    linear-gradient(135deg, #051f28 0%, #08313d 52%, #153548 100%) !important;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.08),
    0 12px 24px rgba(5, 31, 40, 0.14) !important;
  font-weight: 900 !important;
}
body.single-product .cp-favorite-link,
body.woocommerce-account .cp-outline-button,
body.woocommerce-account .woocommerce-Address-title .edit {
  border: 1px solid rgba(21, 53, 72, 0.16);
  border-radius: 14px;
  color: var(--cp-flow-ink) !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.66), rgba(226, 244, 249, 0.34));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 10px 22px rgba(21, 53, 72, 0.06);
}
body.woocommerce-account .cp-account-dashboard .cp-outline-button {
  color: #fff !important;
  border-color: rgba(199, 149, 42, 0.36) !important;
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.14), transparent 38%),
    linear-gradient(135deg, #051f28 0%, #08313d 52%, #153548 100%) !important;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.09),
    0 12px 24px rgba(5, 31, 40, 0.16) !important;
}
body.woocommerce-account .woocommerce-Address-title .edit,
body.woocommerce-account .woocommerce-Address-title .edit:hover,
body.woocommerce-account .woocommerce-Address-title .edit:focus-visible {
  color: #fff !important;
  border-color: rgba(199, 149, 42, 0.36) !important;
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.14), transparent 38%),
    linear-gradient(135deg, #051f28 0%, #08313d 52%, #153548 100%) !important;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.09),
    0 12px 24px rgba(5, 31, 40, 0.16) !important;
}
body.single-product .cp-trust-row div {
  border: 1px solid rgba(21, 53, 72, 0.1);
  border-radius: 18px;
  padding: 14px;
  background: rgba(255, 255, 255, 0.48);
}
body.single-product .cp-line-icon,
body.woocommerce-account .cp-line-icon,
body.woocommerce-cart .cp-cart-service-band svg,
body.woocommerce-checkout .cp-cart-service-band svg {
  color: var(--cp-flow-ink);
  stroke: currentColor;
}
body.woocommerce-account .cp-account-details-card .cp-line-icon {
  color: #fff;
  background:
    radial-gradient(circle at 32% 18%, rgba(255, 255, 255, 0.18), transparent 34%),
    linear-gradient(135deg, #051f28, #08313d 55%, #153548);
}
body.woocommerce-account .cp-account-panel > header .cp-line-icon {
  width: 48px;
  height: 48px;
  color: #fff;
  background:
    radial-gradient(circle at 32% 18%, rgba(255, 255, 255, 0.18), transparent 34%),
    linear-gradient(135deg, #051f28, #08313d 55%, #153548);
}
body.woocommerce-account .cp-account-panel > header .cp-line-icon svg {
  width: 22px;
  height: 22px;
  color: #fff;
  stroke: currentColor;
}
body.woocommerce-account .cp-account-details-card .cp-line-icon svg {
  color: #fff;
  stroke: currentColor;
}
body.single-product .cp-product-info,
body.single-product .cp-description,
body.single-product .cp-related-products {
  max-width: none;
  margin-top: clamp(22px, 2.8vw, 42px);
}
body.single-product .cp-product-info {
  overflow: hidden;
}
body.single-product .cp-product-info h2,
body.single-product .cp-description h2,
body.single-product .cp-related-products h2 {
  color: var(--cp-flow-ink);
}
body.single-product .cp-info-grid article {
  border-color: rgba(21, 53, 72, 0.1);
  background: rgba(255, 255, 255, 0.32);
}
body.single-product .cp-description {
  border: 1px solid rgba(255, 255, 255, 0.68);
  border-radius: clamp(22px, 2vw, 32px);
  padding: clamp(24px, 2.4vw, 34px);
  color: var(--cp-flow-muted);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.72), rgba(226, 244, 249, 0.34));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.74),
    0 12px 28px rgba(21, 53, 72, 0.07);
}
body.single-product .cp-related-image {
  border-radius: 18px;
  background:
    radial-gradient(circle at 50% 42%, rgba(255, 255, 255, 0.82), transparent 42%),
    rgba(226, 244, 249, 0.34);
}
body.woocommerce-cart .cp-cart-head,
body.woocommerce-checkout .cp-cart-head,
body.woocommerce-account .cp-account-head {
  grid-template-columns: minmax(0, 0.42fr) minmax(520px, 0.58fr);
  align-items: center;
  margin-bottom: clamp(22px, 2.8vw, 36px);
}
body.woocommerce-account .cp-account-head {
  display: block;
}
body.woocommerce-account .cp-account-head p {
  color: var(--cp-flow-muted);
}
body.woocommerce-cart .cp-checkout-steps,
body.woocommerce-checkout .cp-checkout-steps {
  border: 1px solid rgba(255, 255, 255, 0.58);
  border-radius: 999px;
  padding: 12px;
  background: rgba(255, 255, 255, 0.44);
}
body.woocommerce-cart .cp-checkout-steps span,
body.woocommerce-checkout .cp-checkout-steps span {
  border-color: rgba(21, 53, 72, 0.16);
  background: rgba(255, 255, 255, 0.72);
}
body.woocommerce-cart .cp-checkout-steps :is(.active, .done) span,
body.woocommerce-checkout .cp-checkout-steps :is(.active, .done) span {
  border-color: rgba(199, 149, 42, 0.42);
  color: #fff;
  background: #153548;
  box-shadow: 0 0 0 7px rgba(255, 255, 255, 0.38);
}
body.woocommerce-cart :is(.wc-block-cart__main, .woocommerce-cart-form, .wc-block-cart__sidebar, .cart-collaterals .cart_totals),
body.woocommerce-checkout :is(.wc-block-checkout__main, #customer_details, .wc-block-checkout__sidebar, #order_review) {
  overflow: hidden;
}
body.woocommerce-cart :is(.wc-block-cart-items th, table.shop_table th),
body.woocommerce-account :is(table.shop_table th, .woocommerce-orders-table th) {
  color: rgba(21, 53, 72, 0.7);
  background: rgba(255, 255, 255, 0.42);
}
body.woocommerce-cart :is(.wc-block-cart-items__row, table.shop_table.cart tr.cart_item),
body.woocommerce-cart :is(.wc-block-components-totals-wrapper, .cart_totals tr),
body.woocommerce-checkout :is(.wc-block-components-checkout-step, .woocommerce-billing-fields, .woocommerce-shipping-fields, .woocommerce-additional-fields, .wc-block-components-order-summary-item, .wc-block-components-totals-wrapper, .shop_table tr),
body.woocommerce-account :is(table.shop_table th, table.shop_table td, .woocommerce-orders-table th, .woocommerce-orders-table td, .cp-account-panel > header, .woocommerce-Address-title) {
  border-color: rgba(21, 53, 72, 0.1) !important;
}
body.woocommerce-cart :is(.wc-block-cart-item__image img, table.cart img),
body.woocommerce-checkout :is(.wc-block-components-order-summary-item__image img, .shop_table img) {
  border-color: rgba(21, 53, 72, 0.1);
  border-radius: 16px;
  background:
    radial-gradient(circle at 50% 42%, rgba(255, 255, 255, 0.82), transparent 42%),
    rgba(226, 244, 249, 0.34);
}
body.woocommerce-cart :is(.wc-block-components-totals-footer-item .wc-block-components-totals-item__value, .order-total .amount),
body.woocommerce-checkout :is(.wc-block-components-totals-footer-item .wc-block-components-totals-item__value, .order-total .amount) {
  color: var(--cp-flow-ink);
}
@media (min-width: 821px) {
  body.woocommerce-cart .cp-cart-shell .cart-collaterals .cart_totals {
    padding: clamp(22px, 2.1vw, 30px) !important;
    border: 1px solid rgba(255, 255, 255, 0.74) !important;
    border-radius: 28px !important;
    background:
      radial-gradient(circle at 8% 0%, rgba(255, 255, 255, 0.82), transparent 38%),
      linear-gradient(145deg, rgba(255, 255, 255, 0.64), rgba(225, 243, 248, 0.38)) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.86),
      0 18px 42px rgba(21, 53, 72, 0.1) !important;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals h2 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 0 0 18px !important;
    padding: 0 0 16px !important;
    border-bottom: 1px solid rgba(21, 53, 72, 0.12);
    color: #153548 !important;
    font-size: clamp(23px, 1.6vw, 28px) !important;
    font-weight: 950 !important;
    line-height: 1.08 !important;
    letter-spacing: 0 !important;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals h2::after {
    width: 44px;
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg, #153548, rgba(21, 53, 72, 0.42));
    content: "";
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals table.shop_table,
  body.woocommerce-cart .cp-cart-shell .cart_totals tbody {
    display: grid !important;
    width: 100% !important;
    border: 0 !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    background: transparent !important;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals tbody {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals tr {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr);
    gap: 10px;
    align-content: start;
    align-items: start;
    min-height: 126px;
    padding: 17px 18px !important;
    border: 1px solid rgba(255, 255, 255, 0.64) !important;
    border-radius: 18px;
    background:
      linear-gradient(145deg, rgba(255, 255, 255, 0.56), rgba(236, 248, 251, 0.28)) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.78),
      0 9px 20px rgba(21, 53, 72, 0.055);
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals th,
  body.woocommerce-cart .cp-cart-shell .cart_totals td {
    display: block !important;
    width: auto !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    color: rgba(21, 53, 72, 0.72) !important;
    font-size: 14px !important;
    font-weight: 900 !important;
    line-height: 1.38 !important;
    text-align: left !important;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals td {
    color: #153548 !important;
    font-size: 15px !important;
    font-weight: 850 !important;
    text-align: left !important;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals tr.cart-subtotal td .amount,
  body.woocommerce-cart .cp-cart-shell .cart_totals tr.cart-subtotal td bdi {
    font-size: clamp(20px, 1.7vw, 24px) !important;
    line-height: 1.05 !important;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals td .amount,
  body.woocommerce-cart .cp-cart-shell .cart_totals td bdi {
    color: inherit !important;
    font-weight: 900 !important;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals tr.woocommerce-shipping-totals td {
    display: grid !important;
    gap: 8px;
    justify-items: start;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals .woocommerce-shipping-methods,
  body.woocommerce-cart .cp-cart-shell .cart_totals #shipping_method {
    display: grid;
    gap: 6px;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals .woocommerce-shipping-methods li,
  body.woocommerce-cart .cp-cart-shell .cart_totals #shipping_method li {
    margin: 0 !important;
    padding: 0 !important;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals .woocommerce-shipping-destination,
  body.woocommerce-cart .cp-cart-shell .cart_totals .woocommerce-shipping-calculator {
    max-width: 100%;
    margin: 0 !important;
    color: rgba(21, 53, 72, 0.75) !important;
    font-size: 13px !important;
    font-weight: 750 !important;
    line-height: 1.38 !important;
    text-align: left;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals .shipping-calculator-button {
    display: inline-flex !important;
    align-items: center;
    justify-content: flex-start;
    min-height: 28px;
    padding: 0 !important;
    color: #153548 !important;
    font-size: 13px !important;
    font-weight: 900 !important;
    text-decoration: none !important;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals tr.order-total {
    grid-column: 1 / -1;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    min-height: 66px;
    margin-top: 2px;
    border-color: rgba(199, 149, 42, 0.32) !important;
    background:
      radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.16), transparent 38%),
      linear-gradient(135deg, #051f28 0%, #08313d 52%, #153548 100%) !important;
    box-shadow:
      inset 0 0 0 1px rgba(255, 255, 255, 0.09),
      0 15px 30px rgba(5, 31, 40, 0.16);
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals tr.order-total th,
  body.woocommerce-cart .cp-cart-shell .cart_totals tr.order-total td,
  body.woocommerce-cart .cp-cart-shell .cart_totals tr.order-total .amount,
  body.woocommerce-cart .cp-cart-shell .cart_totals tr.order-total bdi {
    color: #fff !important;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals tr.order-total th {
    font-size: 15px !important;
    font-weight: 950 !important;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals tr.order-total td,
  body.woocommerce-cart .cp-cart-shell .cart_totals tr.order-total .amount,
  body.woocommerce-cart .cp-cart-shell .cart_totals tr.order-total bdi {
    font-size: clamp(22px, 2vw, 28px) !important;
    font-weight: 950 !important;
    line-height: 1 !important;
  }
}
@media (min-width: 821px) {
  body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary table.shop_table,
  body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary tbody {
    display: block !important;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary tbody {
    width: 100% !important;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary tr.order-total {
    display: flex !important;
    grid-column: auto;
    grid-template-columns: none;
    align-items: center;
    justify-content: space-between;
    min-height: 0;
    margin: 0;
    padding: clamp(16px, 1.5vw, 20px) !important;
    border-color: rgba(21, 53, 72, 0.12) !important;
    background:
      radial-gradient(circle at 12% 0%, rgba(255, 255, 255, 0.82), transparent 42%),
      linear-gradient(145deg, rgba(255, 255, 255, 0.62), rgba(232, 246, 250, 0.36)) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.82),
      0 10px 22px rgba(21, 53, 72, 0.07);
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary tr.order-total th,
  body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary tr.order-total td {
    display: block !important;
    width: auto !important;
    color: #153548 !important;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary tr.order-total th {
    font-size: 15px !important;
    font-weight: 950 !important;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary tr.order-total td,
  body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary tr.order-total .amount,
  body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary tr.order-total bdi {
    color: #153548 !important;
    font-size: clamp(24px, 2.1vw, 30px) !important;
    font-weight: 950 !important;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary .wc-proceed-to-checkout {
    margin-top: 16px !important;
  }
}
.cp-shipping-progress {
  display: grid;
  gap: 11px;
  margin: 0 0 16px;
  padding: 14px 15px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 18px;
  background:
    radial-gradient(circle at 6% 0%, rgba(255, 255, 255, 0.82), transparent 42%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.62), rgba(229, 246, 250, 0.38));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.82),
    0 10px 22px rgba(21, 53, 72, 0.07);
}
.cp-shipping-progress-copy {
  display: grid;
  gap: 4px;
}
.cp-shipping-progress-copy strong {
  color: #153548;
  font-size: 14px;
  font-weight: 950;
  line-height: 1.28;
}
.cp-shipping-progress-copy small {
  color: rgba(21, 53, 72, 0.66);
  font-size: 12px;
  font-weight: 750;
  line-height: 1.35;
}
.cp-shipping-progress-track {
  overflow: hidden;
  height: 8px;
  border-radius: 999px;
  background: rgba(21, 53, 72, 0.1);
  box-shadow:
    inset 0 1px 2px rgba(21, 53, 72, 0.08),
    inset 0 -1px 0 rgba(255, 255, 255, 0.72);
}
.cp-shipping-progress-track span {
  position: relative;
  overflow: hidden;
  display: block;
  width: var(--cp-shipping-progress, 0%);
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(21, 53, 72, 0.54) 0%, #214d5d 54%, #153548 100%);
  box-shadow:
    0 0 16px rgba(21, 53, 72, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
  transition:
    width 520ms cubic-bezier(0.22, 0.76, 0.22, 1),
    filter 240ms ease,
    box-shadow 240ms ease;
}
.cp-shipping-progress-track span::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.52) 48%, transparent 100%);
  opacity: 0;
  transform: translateX(-120%);
  pointer-events: none;
}
.cp-shipping-progress.is-updating .cp-shipping-progress-track span {
  filter: saturate(1.08) brightness(1.04);
  box-shadow:
    0 0 22px rgba(21, 53, 72, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.3);
}
.cp-shipping-progress.is-updating .cp-shipping-progress-track span::after {
  animation: cp-shipping-progress-shine 760ms ease-out;
}
.cp-shipping-progress.is-free .cp-shipping-progress-track span {
  background: #153548;
  box-shadow:
    0 0 20px rgba(21, 53, 72, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.24);
}
@keyframes cp-shipping-progress-shine {
  0% {
    opacity: 0;
    transform: translateX(-120%);
  }
  18% {
    opacity: 0.78;
  }
  100% {
    opacity: 0;
    transform: translateX(120%);
  }
}
@media (prefers-reduced-motion: reduce) {
  .cp-shipping-progress-track span {
    transition: none;
  }

  .cp-shipping-progress.is-updating .cp-shipping-progress-track span::after {
    animation: none;
  }
}
body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary tr.cp-cart-summary-line {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-height: 0;
  padding: 12px 0 !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(21, 53, 72, 0.1) !important;
  border-radius: 0;
  background: transparent !important;
  box-shadow: none;
}
body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary tr.cp-cart-summary-line th,
body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary tr.cp-cart-summary-line td {
  display: block !important;
  width: auto !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  color: rgba(21, 53, 72, 0.72) !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  line-height: 1.35 !important;
}
body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary tr.cp-cart-summary-line td,
body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary tr.cp-cart-summary-line td .amount,
body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary tr.cp-cart-summary-line td bdi {
  color: #153548 !important;
  font-size: 15px !important;
  font-weight: 950 !important;
  text-align: right !important;
}
body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary .cp-cart-shipping-value.is-free {
  color: #153548 !important;
}
body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary tr.order-total {
  margin-top: 12px !important;
}
body.woocommerce-checkout .cp-checkout-shell .cp-checkout-shipping-progress-row {
  border-top: 0 !important;
}
body.woocommerce-checkout .cp-checkout-shell .cp-checkout-shipping-progress-row td {
  padding: 10px 0 15px !important;
}
body.woocommerce-checkout .cp-checkout-shell .cp-checkout-shipping-progress-row .cp-shipping-progress {
  margin: 0;
}
@media (max-width: 640px) {
  .cp-shipping-progress {
    padding: 13px;
    border-radius: 16px;
  }

  .cp-shipping-progress-copy strong {
    font-size: 13px;
  }

  body.woocommerce-cart .cp-cart-shell .cart_totals.cp-cart-total-summary tr.cp-cart-summary-line {
    gap: 10px;
  }
}
body.woocommerce-checkout .cp-checkout-legal {
  border: 1px solid rgba(255, 255, 255, 0.68);
  border-radius: 18px;
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 255, 255, 0.72), transparent 42%),
    linear-gradient(135deg, rgba(232, 246, 240, 0.72), rgba(255, 255, 255, 0.54));
}
body.woocommerce-account .cp-account-shell .woocommerce {
  max-width: 1560px;
  grid-template-columns: 320px minmax(0, 1fr);
}
body.woocommerce-account .woocommerce-MyAccount-navigation.cp-account-nav {
  padding: 0;
  overflow: hidden;
}
body.woocommerce-account .cp-account-nav-hero {
  min-height: 258px;
  padding: 30px 26px 24px;
  color: var(--cp-flow-ink);
  text-align: center;
  background:
    radial-gradient(circle at 50% 28%, rgba(255, 255, 255, 0.82), transparent 32%),
    radial-gradient(circle at 58% 76%, rgba(21, 53, 72, 0.12), transparent 32%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.42), rgba(219, 240, 246, 0.32));
}
body.woocommerce-account .cp-account-nav-logo {
  display: grid;
  width: 124px;
  height: 124px;
  place-items: center;
  margin: 0 auto 18px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 50%;
  background:
    radial-gradient(circle at 35% 20%, rgba(255, 255, 255, 0.72), transparent 34%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.58), rgba(226, 244, 249, 0.34));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.78), 0 14px 28px rgba(21, 53, 72, 0.1);
}
body.woocommerce-account .cp-account-nav-logo .brand-logo-img {
  width: 74%;
  height: 74%;
  object-fit: contain;
}
body.woocommerce-account .cp-account-nav-greeting {
  color: rgba(21, 53, 72, 0.68);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
body.woocommerce-account .cp-account-nav-name {
  color: var(--cp-flow-ink);
}
body.woocommerce-account .woocommerce-MyAccount-navigation ul {
  padding: 12px;
}
body.woocommerce-account .woocommerce-MyAccount-navigation-link a {
  border-radius: 14px;
  color: var(--cp-flow-ink);
  background: rgba(255, 255, 255, 0.4);
}
body.woocommerce-account .woocommerce-MyAccount-navigation-link a::before {
  display: none;
}
body.woocommerce-account .woocommerce-MyAccount-navigation-link a:hover,
body.woocommerce-account .woocommerce-MyAccount-navigation-link.is-active a {
  border-color: rgba(199, 149, 42, 0.42);
  color: #fff;
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.14), transparent 38%),
    linear-gradient(135deg, #051f28 0%, #08313d 52%, #153548 100%);
}
body.woocommerce-account .woocommerce-MyAccount-navigation-link.is-active .cp-account-nav-icon,
body.woocommerce-account .woocommerce-MyAccount-navigation-link.is-active .cp-account-nav-icon svg,
body.woocommerce-account .woocommerce-MyAccount-navigation-link a:hover .cp-account-nav-icon,
body.woocommerce-account .woocommerce-MyAccount-navigation-link a:hover .cp-account-nav-icon svg {
  color: #fff;
  stroke: currentColor;
}
body.woocommerce-account .woocommerce-MyAccount-content {
  padding: clamp(22px, 2.4vw, 34px);
}
body.woocommerce-account .cp-account-dashboard {
  padding: 0;
}
body.woocommerce-account .cp-account-welcome {
  grid-template-columns: 82px minmax(0, 1fr) minmax(190px, 240px);
}
@media (min-width: 821px) {
  body.woocommerce-account .cp-account-dashboard > .cp-account-welcome {
    display: none;
  }
}
body.woocommerce-account .cp-account-panel::before,
body.woocommerce-account .woocommerce-Address::before,
body.woocommerce-account .woocommerce-column--billing-address::before,
body.woocommerce-account .woocommerce-column--shipping-address::before {
  background: linear-gradient(90deg, #153548, rgba(21, 53, 72, 0.72), rgba(21, 53, 72, 0));
}
body.woocommerce-account fieldset {
  border-color: rgba(21, 53, 72, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.42);
}
body.woocommerce-account .woocommerce-message,
body.woocommerce-account .woocommerce-info,
body.woocommerce-account .woocommerce-error,
body.single-product .cp-product-notices :is(.woocommerce-message, .woocommerce-info, .woocommerce-error) {
  border: 1px solid rgba(255, 255, 255, 0.68);
  border-left: 4px solid #153548;
  border-radius: 20px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.74), rgba(226, 244, 249, 0.42));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.74),
    0 12px 28px rgba(21, 53, 72, 0.07);
}

@media (max-width: 1180px) {
body.single-product .cp-product-hero,
body.woocommerce-cart .cp-cart-head,
body.woocommerce-checkout .cp-cart-head,
body.woocommerce-account .cp-account-head,
body.woocommerce-account .cp-account-shell .woocommerce {
    grid-template-columns: 1fr;
  }
body.woocommerce-account .cp-account-welcome {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
body.single-product,
body.woocommerce-cart,
body.woocommerce-checkout,
body.woocommerce-account {
    background:
      linear-gradient(180deg, rgba(230, 244, 248, 0.9), rgba(248, 252, 253, 1)),
      linear-gradient(135deg, #e0f0f4 0%, #f5fbfc 62%, #e6f2f6 100%);
  }
body.single-product .woo-page-shell,
body.woocommerce-cart .cp-cart-shell,
body.woocommerce-checkout .cp-checkout-shell,
body.woocommerce-account .cp-account-shell {
    padding: 28px 14px 58px;
  }
body.single-product .cp-product-hero,
body.woocommerce-cart .cp-cart-head,
body.woocommerce-checkout .cp-cart-head,
body.woocommerce-account .cp-account-head {
    border-radius: 28px;
    padding: 22px;
  }
body.single-product .cp-product-title,
body.woocommerce-cart .cp-cart-head h1,
body.woocommerce-checkout .cp-cart-head h1,
body.woocommerce-account .cp-account-head h1 {
    font-size: clamp(40px, 11vw, 58px);
  }
body.woocommerce-cart .cp-checkout-steps,
body.woocommerce-checkout .cp-checkout-steps {
    border-radius: 22px;
  }
}

@media (max-width: 620px) {
body.single-product .cp-product-gallery--static {
    padding: 18px;
  }
body.single-product .cp-product-main-image {
    width: 100%;
    min-height: 320px;
  }
body.single-product .cp-product-main-image img {
    max-width: 86%;
    max-height: 300px;
  }
body.single-product .cp-product-gallery .woocommerce-product-gallery__image {
    min-height: 320px;
  }
body.single-product .cp-purchase-panel form.cart {
    grid-template-columns: 1fr;
  }
body.single-product .cp-trust-row div {
    grid-template-columns: 34px 1fr;
  }
body.woocommerce-cart .cp-checkout-steps,
body.woocommerce-checkout .cp-checkout-steps {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
body.woocommerce-account .cp-account-nav-hero {
    min-height: 220px;
  }
body.woocommerce-account .cp-account-nav-logo {
    width: 104px;
    height: 104px;
  }
}
body.single-product .woocommerce-product-gallery__trigger {
  display: none !important;
}
body.woocommerce-account .cp-login-layout {
  display: grid;
  grid-template-columns: minmax(320px, 0.72fr) minmax(0, 1fr);
  gap: clamp(20px, 2.8vw, 42px);
  align-items: stretch;
}
body.woocommerce-account .cp-login-layout--forms-only {
  grid-template-columns: minmax(0, 1fr);
  max-width: min(100%, 760px);
  margin-inline: auto;
}
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register {
  max-width: min(100%, 760px);
}
body.woocommerce-account .cp-login-layout--forms-only .cp-login-forms {
  grid-column: 1;
  width: 100%;
  justify-self: center;
}
body.woocommerce-account .cp-account-shell {
  overflow: visible;
}
body.woocommerce-account .cp-account-shell::before {
  display: none;
  content: none;
}
body.woocommerce-account .cp-login-layout--single {
  grid-template-columns: minmax(0, 760px);
  justify-content: center;
}
body.woocommerce-account .cp-login-intro,
body.woocommerce-account .cp-login-panel {
  border: 1px solid rgba(255, 255, 255, 0.68);
  border-radius: clamp(22px, 2vw, 32px);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.72), rgba(226, 244, 249, 0.38));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.74),
    0 12px 28px rgba(21, 53, 72, 0.07);
  overflow: hidden;
}
body.woocommerce-account .cp-login-intro {
  position: relative;
  isolation: isolate;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 100%;
  padding: clamp(34px, 3.4vw, 54px) clamp(28px, 3.2vw, 48px);
  color: var(--cp-flow-ink);
}
body.woocommerce-account .cp-login-intro::before,
body.woocommerce-account .cp-login-intro::after {
  position: absolute;
  pointer-events: none;
  content: "";
}
body.woocommerce-account .cp-login-intro::before {
  inset: 9%;
  z-index: -1;
  border: 1px solid rgba(255, 255, 255, 0.58);
  border-radius: 999px;
}
body.woocommerce-account .cp-login-intro::after {
  right: -18%;
  bottom: -18%;
  z-index: -1;
  width: 60%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(72, 120, 56, 0.16), transparent 62%);
}
body.woocommerce-account .cp-login-brand-mark {
  position: relative;
  top: auto;
  right: auto;
  z-index: 1;
  display: grid;
  width: clamp(132px, 9vw, 164px);
  aspect-ratio: 1;
  place-items: center;
  margin: 0 auto clamp(34px, 3.6vw, 48px);
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  opacity: 1;
  pointer-events: none;
  filter: drop-shadow(0 14px 22px rgba(21, 53, 72, 0.12));
}
body.woocommerce-account .cp-login-brand-mark .brand-logo-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  opacity: 1;
  filter: none;
}
body.woocommerce-account .cp-login-intro h2 {
  max-width: 430px;
  margin: 0;
  color: var(--cp-flow-ink);
  font-size: clamp(34px, 3.2vw, 54px);
  line-height: 1.02;
  letter-spacing: -0.048em;
}
body.woocommerce-account .cp-login-intro p {
  max-width: 460px;
  margin: 18px 0 0;
  color: var(--cp-flow-muted);
  font-size: 16px;
  line-height: 1.7;
}
body.woocommerce-account .cp-login-benefits {
  display: grid;
  gap: 10px;
  margin: clamp(24px, 2.6vw, 34px) 0 0;
  padding: 0;
  list-style: none;
}
body.woocommerce-account .cp-login-benefits li {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  min-height: 52px;
  border: 1px solid rgba(21, 53, 72, 0.12);
  border-radius: 16px;
  padding: 12px 14px;
  color: var(--cp-flow-ink);
  background: rgba(255, 255, 255, 0.46);
  font-weight: 900;
}
body.woocommerce-account .cp-login-benefits svg {
  width: 24px;
  height: 24px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
body.woocommerce-account .cp-login-forms {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(18px, 2vw, 28px);
  align-items: stretch;
}
body.woocommerce-account .cp-login-panel {
  display: grid;
  align-content: start;
  padding: clamp(24px, 2.8vw, 38px);
}
body.woocommerce-account .cp-login-panel-head {
  margin-bottom: 24px;
  padding-bottom: 22px;
  border-bottom: 1px solid rgba(21, 53, 72, 0.1);
}
body.woocommerce-account .cp-login-panel h2 {
  margin: 0 0 12px;
  color: var(--cp-flow-ink);
  font-size: clamp(28px, 2.8vw, 42px);
  line-height: 1.08;
  letter-spacing: -0.04em;
}
body.woocommerce-account .cp-login-panel-head h2:last-child {
  margin-bottom: 0;
}
body.woocommerce-account .cp-login-panel p {
  color: var(--cp-flow-muted);
}
body.woocommerce-account .cp-login-panel form.login,
body.woocommerce-account .cp-login-panel form.register {
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}
body.woocommerce-account .cp-login-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
body.woocommerce-account .cp-login-lost {
  color: var(--cp-flow-ink) !important;
  font-weight: 900;
}
body.woocommerce-account .lost_reset_password {
  max-width: 720px;
  margin: 0 auto;
  border: 1px solid rgba(255, 255, 255, 0.68);
  border-radius: clamp(22px, 2vw, 32px);
  padding: clamp(24px, 3vw, 38px);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.72), rgba(226, 244, 249, 0.38));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.74),
    0 12px 28px rgba(21, 53, 72, 0.07);
}

@media (max-width: 1180px) {
body.woocommerce-account .cp-login-layout {
    grid-template-columns: 1fr;
  }
body.woocommerce-account .cp-login-forms {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
body.woocommerce-account .cp-login-forms {
    grid-template-columns: 1fr;
  }
body.woocommerce-account .cp-login-layout--forms-only,
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register {
    max-width: min(100%, 430px);
  }
body.woocommerce-account:not(.logged-in) .cp-account-shell .woocommerce:has(.cp-login-layout) > .woocommerce-notices-wrapper,
body.woocommerce-account:not(.logged-in) .cp-account-shell .woocommerce:has(.cp-login-layout) > :is(.cp-wc-notice, .woocommerce-message, .woocommerce-info, .woocommerce-error) {
    width: min(100%, 430px);
    max-width: 430px;
  }
}

@media (min-width: 821px) {
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register {
    max-width: min(100%, 980px);
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-forms {
    grid-template-areas:
      "login register"
      "track track";
    grid-template-rows: auto auto;
    align-items: start;
    column-gap: clamp(18px, 2vw, 28px);
    row-gap: 16px;
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--login {
    grid-area: login;
    align-self: stretch;
    grid-template-rows: auto minmax(0, 1fr);
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--login form.login {
    display: flex;
    min-height: 0;
    flex-direction: column;
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--login .cp-login-submit-row {
    margin-top: auto;
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register {
    grid-area: register;
    padding: clamp(22px, 2.2vw, 30px);
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register .cp-login-panel-head {
    margin-bottom: 16px;
    padding-bottom: 15px;
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register h2 {
    font-size: clamp(28px, 2.45vw, 36px);
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register form.register {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 12px;
    align-content: start;
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register .cp-register-name-grid,
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register form.register > p:has(#reg_username),
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register form.register > .woocommerce-privacy-policy-text,
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register form.register > .cp-login-note,
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register form.register > .cp-login-submit-row {
    grid-column: 1 / -1;
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register form.register > .form-row {
    float: none !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0;
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register .cp-register-name-grid {
    margin: 0;
    gap: 10px 12px;
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register label {
    margin-bottom: 7px;
    font-size: 12.5px;
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register input.input-text,
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register input[type="text"],
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register input[type="email"],
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register input[type="tel"],
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register input[type="password"] {
    min-height: 44px;
    padding-inline: 13px;
    border-radius: 14px;
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register .woocommerce-privacy-policy-text,
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register .woocommerce-privacy-policy-text p {
    margin: 0;
    font-size: 13px;
    line-height: 1.34;
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--register .cp-login-submit-row .button {
    min-height: 48px;
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--track {
    grid-area: track;
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: minmax(220px, 0.54fr) minmax(0, 1.46fr);
    gap: clamp(18px, 2vw, 30px);
    align-items: stretch;
    width: 100%;
    padding-block: clamp(18px, 2vw, 26px);
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--track > .woocommerce {
    align-self: stretch;
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--track .track_order {
    grid-template-columns: minmax(130px, 0.85fr) minmax(170px, 1fr) minmax(150px, 0.82fr);
    gap: 12px 16px;
    align-items: end;
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--track .cp-login-panel-head {
    margin: 0;
    padding: 0 clamp(18px, 2vw, 26px) 0 0;
    border-right: 1px solid rgba(21, 53, 72, 0.1);
    border-bottom: 0;
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--track h2 {
    font-size: clamp(26px, 2.2vw, 34px);
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--track .cp-login-panel-head p,
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--track .cp-order-tracking-intro {
    font-size: 14px;
    line-height: 1.48;
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--track .track_order label {
    min-height: 0;
  }
body.woocommerce-account .cp-login-layout--forms-only.cp-login-layout--with-register .cp-login-panel--track .cp-order-tracking-submit {
    grid-column: auto;
    align-self: end;
  }
}
/* Edge states refresh: 404,
empty commerce states,
notices and password flows. */
html:has(body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received)),
body.error404,
body.woocommerce-order-received,
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) {
  --cp-flow-ink: #153548;
  --cp-flow-muted: #5d737b;
  --cp-flow-line: rgba(21, 53, 72, 0.12);
  --cp-flow-glass: rgba(255, 255, 255, 0.72);
  background:
    radial-gradient(circle at 10% 8%, rgba(255, 255, 255, 0.68), transparent 18rem),
    radial-gradient(circle at 90% 12%, rgba(110, 176, 193, 0.2), transparent 24rem),
    radial-gradient(circle at 55% 52%, rgba(21, 53, 72, 0.07), transparent 28rem),
    repeating-linear-gradient(103deg, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px 78px),
    linear-gradient(180deg, rgba(229, 244, 248, 0.66) 0%, rgba(238, 248, 250, 0.88) 42%, rgba(247, 251, 252, 1) 100%),
    url("../images/backgrounds/home-background-desktop.jpg") center top / cover no-repeat,
    linear-gradient(135deg, #d9ecf2 0%, #f6fbfc 58%, #e0f0f4 100%) !important;
}
body.error404,
body.woocommerce-order-received,
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) {
  min-height: 100vh;
  color: var(--cp-flow-ink);
}
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .top-strip {
  display: none;
}
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .site-header {
  top: 16px;
  width: auto;
  margin: 0 clamp(18px, 3vw, 48px);
  padding: 13px clamp(18px, 2.3vw, 34px);
  grid-template-columns: minmax(205px, auto) minmax(360px, 1fr) minmax(250px, auto);
  gap: clamp(18px, 3vw, 42px);
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 32px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.86), rgba(239, 248, 250, 0.66)),
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.82), transparent 42%);
  box-shadow:
    0 26px 74px rgba(21, 53, 72, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.78);
  backdrop-filter: blur(24px) saturate(142%);
  -webkit-backdrop-filter: blur(24px) saturate(142%);
}
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .brand-logo-img--header {
  width: 46px;
  height: 46px;
  filter: drop-shadow(0 12px 20px rgba(21, 53, 72, 0.14));
}
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .brand-name {
  color: var(--cp-flow-ink);
}
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .main-nav {
  position: static;
  justify-self: center;
  justify-content: center;
  width: auto;
  gap: clamp(16px, 2vw, 28px);
  transform: none;
  font-size: 0.92rem;
  letter-spacing: 0.035em;
}
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .main-nav a {
  min-height: 40px;
  padding: 0 5px;
  border: 0;
  color: rgba(21, 53, 72, 0.76);
  background: transparent;
  box-shadow: none;
}
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .main-nav a::before {
  display: none;
}
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .main-nav a.is-active,
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .main-nav a[aria-current="page"] {
  min-height: 40px;
  padding: 0 18px;
  border-radius: 999px;
  color: #fff;
  background: var(--cp-flow-ink);
  box-shadow: 0 14px 28px rgba(21, 53, 72, 0.22);
}
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .icon-button,
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .cart-button {
  border-color: rgba(255, 255, 255, 0.82);
  background: rgba(255, 255, 255, 0.58);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.82),
    0 16px 34px rgba(21, 53, 72, 0.08);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .icon-button.is-active,
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .cart-button.is-active,
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .icon-button[aria-current="page"],
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .cart-button[aria-current="page"] {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.42);
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.14), transparent 38%),
    linear-gradient(135deg, #051f28 0%, #08313d 52%, #153548 100%);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.09),
    0 14px 28px rgba(21, 53, 72, 0.2);
}
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .icon-button.is-active:hover,
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .cart-button.is-active:hover,
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .icon-button[aria-current="page"]:hover,
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .cart-button[aria-current="page"]:hover {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.52);
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.18), transparent 40%),
    linear-gradient(135deg, #062634 0%, #0a3a43 50%, #153548 100%);
}
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .cart-button.is-active .cart-count,
body:is(.woocommerce-cart, .woocommerce-checkout, .woocommerce-account) .cart-button[aria-current="page"] .cart-count {
  color: #153548;
  border-color: rgba(255, 255, 255, 0.82);
  background: rgba(255, 255, 255, 0.92);
}
.cp-edge-shell,
body.woocommerce-order-received .wp-page-shell {
  --cp-flow-ink: #153548;
  --cp-flow-muted: #5d737b;
  --cp-flow-line: rgba(21, 53, 72, 0.12);
  --cp-flow-glass: rgba(255, 255, 255, 0.72);
}
.cp-edge-shell {
  display: grid;
  gap: clamp(22px, 2.5vw, 34px);
  padding: clamp(34px, 4vw, 64px) clamp(14px, 2.5vw, 36px) clamp(62px, 7vw, 110px);
}
.cp-edge-hero,
.cp-edge-state,
.cp-edge-form,
.cp-thankyou-hero,
.cp-thankyou-overview,
.cp-thankyou-details,
.cp-edge-service-band {
  border: 1px solid rgba(255, 255, 255, 0.68);
  border-radius: clamp(24px, 2.5vw, 42px);
  background:
    radial-gradient(circle at 5% 5%, rgba(255, 255, 255, 0.76), transparent 42%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.72), rgba(226, 244, 249, 0.38));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.76),
    0 16px 34px rgba(21, 53, 72, 0.08);
}
.cp-edge-hero,
.cp-edge-state,
.cp-thankyou-hero {
  display: grid;
  grid-template-columns: minmax(150px, 220px) minmax(0, 1fr);
  gap: clamp(24px, 4vw, 62px);
  align-items: center;
  padding: clamp(28px, 5vw, 78px);
}
.cp-edge-hero > *,
.cp-edge-state > *,
.cp-thankyou-hero > * {
  min-width: 0;
}
.cp-shop-empty .cp-edge-state {
  min-height: 420px;
}
.cp-edge-orb {
  position: relative;
  display: grid;
  width: clamp(132px, 14vw, 220px);
  height: clamp(132px, 14vw, 220px);
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 50%;
  background:
    radial-gradient(circle at 35% 24%, rgba(255, 255, 255, 0.78), transparent 32%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.5), rgba(206, 235, 242, 0.3));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 18px 48px rgba(21, 53, 72, 0.1);
}
.cp-edge-orb::before,
.cp-edge-orb::after {
  position: absolute;
  inset: 12%;
  border-radius: 50%;
  content: "";
  pointer-events: none;
}
.cp-edge-orb::before {
  border: 1px solid rgba(21, 53, 72, 0.08);
}
.cp-edge-orb::after {
  inset: 22%;
  background: radial-gradient(circle, rgba(72, 120, 56, 0.12), transparent 68%);
}
.cp-edge-orb img {
  position: relative;
  z-index: 1;
  width: 58%;
  height: 58%;
  object-fit: contain;
  filter: drop-shadow(0 12px 24px rgba(21, 53, 72, 0.13));
}
.cp-edge-code {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  margin-bottom: 14px;
  border: 1px solid rgba(21, 53, 72, 0.12);
  border-radius: 999px;
  padding: 8px 13px;
  color: var(--cp-flow-ink);
  background: rgba(255, 255, 255, 0.56);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.cp-edge-hero h1,
.cp-edge-state h2,
.cp-edge-form h2,
.cp-thankyou-hero h2 {
  max-width: 780px;
  margin: 0;
  color: var(--cp-flow-ink);
  font-size: clamp(34px, 5vw, 72px);
  line-height: 0.98;
  letter-spacing: -0.052em;
  overflow-wrap: anywhere;
}
.cp-edge-state h2,
.cp-edge-form h2,
.cp-thankyou-hero h2 {
  font-size: clamp(30px, 4vw, 58px);
}
.cp-edge-hero p,
.cp-edge-state p,
.cp-edge-form p,
.cp-thankyou-hero p {
  max-width: 720px;
  margin: 18px 0 0;
  color: var(--cp-flow-muted);
  font-size: clamp(16px, 1.4vw, 20px);
  line-height: 1.65;
}
.cp-edge-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}
.cp-edge-actions .button,
.cp-edge-state .button,
.cp-edge-form .button,
.cp-thankyou-flow .button,
.cp-wc-notice .button,
.woocommerce-message .button,
.woocommerce-info .button,
.woocommerce-error .button {
  display: inline-flex;
  min-height: 52px;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  border: 1px solid rgba(199, 149, 42, 0.32);
  border-radius: 13px;
  padding: 0 24px;
  color: #fff !important;
  background: linear-gradient(135deg, #051f28 0%, #08313d 42%, #153548 100%) !important;
  box-shadow: 0 14px 28px rgba(21, 53, 72, 0.18);
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
}
.cp-edge-actions .button.secondary,
.cp-edge-state .button.secondary,
.cp-thankyou-flow .button.secondary {
  border-color: rgba(21, 53, 72, 0.12);
  color: var(--cp-flow-ink) !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.76), rgba(226, 244, 249, 0.48)) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}
.cp-edge-service-band {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  overflow: hidden;
}
.cp-edge-service-band div {
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 14px;
  align-items: center;
  padding: clamp(22px, 2.4vw, 34px);
}
.cp-edge-service-band div + div {
  border-left: 1px solid rgba(21, 53, 72, 0.12);
}
.cp-edge-service-band svg {
  width: 32px;
  height: 32px;
  color: var(--cp-flow-ink);
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 1.8;
}
.cp-edge-service-band strong,
.cp-edge-service-band small {
  display: block;
}
.cp-edge-service-band strong {
  color: var(--cp-flow-ink);
  font-weight: 900;
}
.cp-edge-service-band small {
  margin-top: 3px;
  color: var(--cp-flow-muted);
  font-size: 13px;
}
.cp-account-created-card {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  width: 100%;
  margin: 0 0 22px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-left: 5px solid #153548;
  border-radius: 24px;
  padding: 18px 20px;
  color: var(--cp-flow-ink, #153548);
  background:
    radial-gradient(circle at 3% 0%, rgba(255, 255, 255, 0.8), transparent 40%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.76), rgba(226, 244, 249, 0.42));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.84),
    0 16px 34px rgba(21, 53, 72, 0.08);
}
.cp-account-created-card--thankyou {
  margin-bottom: 0;
}
.cp-account-created-icon {
  display: grid;
  width: 48px;
  height: 48px;
  place-items: center;
  border: 1px solid rgba(199, 149, 42, 0.32);
  border-radius: 50%;
  color: #fff;
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.2), transparent 36%),
    linear-gradient(135deg, #051f28 0%, #08313d 54%, #153548 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 12px 24px rgba(5, 31, 40, 0.18);
}
.cp-account-created-icon svg {
  width: 23px;
  height: 23px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2.4;
}
.cp-account-created-copy {
  display: grid;
  gap: 5px;
  min-width: 0;
}
.cp-account-created-copy strong {
  color: var(--cp-flow-ink, #153548);
  font-size: clamp(20px, 1.6vw, 26px);
  font-weight: 950;
  line-height: 1.12;
  letter-spacing: 0;
}
.cp-account-created-copy span {
  color: var(--cp-flow-muted, #5d737b);
  font-size: clamp(14px, 1vw, 16px);
  font-weight: 750;
  line-height: 1.55;
}
.cp-account-created-card .button {
  justify-self: end;
  min-height: 46px;
  white-space: nowrap;
}
.cp-wc-notice,
.woocommerce-notices-wrapper :is(.woocommerce-message, .woocommerce-info, .woocommerce-error),
.woocommerce :is(.woocommerce-message, .woocommerce-info, .woocommerce-error) {
  position: relative;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 15px;
  align-items: center;
  overflow: hidden;
  margin: 0 0 18px;
  border: 1px solid rgba(255, 255, 255, 0.74);
  border-left: 1px solid rgba(255, 255, 255, 0.74);
  border-radius: 24px;
  padding: 17px 20px;
  color: var(--cp-flow-ink, #153548);
  background:
    radial-gradient(circle at 4% 6%, rgba(255, 255, 255, 0.86), transparent 38%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.76), rgba(226, 244, 249, 0.46));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.86),
    0 16px 34px rgba(21, 53, 72, 0.08);
  list-style: none;
}
.cp-wc-notice::before,
.cp-wc-notice::after,
.woocommerce :is(.woocommerce-message, .woocommerce-info, .woocommerce-error)::before,
.woocommerce :is(.woocommerce-message, .woocommerce-info, .woocommerce-error)::after {
  content: none !important;
  display: none !important;
}
.cp-wc-notice-icon {
  display: grid;
  width: 38px;
  height: 38px;
  place-items: center;
  border: 1px solid rgba(199, 149, 42, 0.3);
  border-radius: 50%;
  color: #fff;
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.2), transparent 38%),
    linear-gradient(135deg, #051f28 0%, #08313d 54%, #153548 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 12px 24px rgba(5, 31, 40, 0.16);
}
.cp-wc-notice--error .cp-wc-notice-icon,
.woocommerce-error .cp-wc-notice-icon {
  border-color: rgba(160, 58, 47, 0.24);
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.2), transparent 38%),
    linear-gradient(135deg, #4d1d1a 0%, #7e2d27 56%, #a03a2f 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.16),
    0 12px 24px rgba(160, 58, 47, 0.13);
}
.cp-wc-notice-icon svg {
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
}
.cp-wc-notice-copy {
  display: flex;
  min-width: 0;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  color: var(--cp-flow-ink, #153548);
  font-weight: 800;
  line-height: 1.45;
}
.cp-wc-notice-list,
.cp-wc-notice--error .cp-wc-notice-copy {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
}
.cp-wc-notice li {
  margin: 0;
  color: var(--cp-flow-ink, #153548);
  font-weight: 800;
  line-height: 1.45;
  list-style: none;
}
.cp-wc-notice-copy a,
.woocommerce-message a,
.woocommerce-info a,
.woocommerce-error a {
  color: var(--cp-flow-ink, #153548);
  font-weight: 900;
  text-decoration-color: rgba(21, 53, 72, 0.34);
  text-underline-offset: 4px;
}
.cp-wc-notice .button,
.woocommerce-message .button,
.woocommerce-info .button,
.woocommerce-error .button {
  float: none !important;
  min-height: 42px;
  margin: 0 8px 0 0;
  border-radius: 13px;
}
@media (min-width: 821px) {
  body.woocommerce-account .cp-account-shell .cp-wc-notice--success {
    align-items: center;
  }
  body.woocommerce-account .cp-account-shell .cp-wc-notice--success .cp-wc-notice-copy {
    display: flex;
    min-height: 34px;
    align-items: center;
    line-height: 1.35;
  }
}
.cp-thankyou-flow {
  display: grid;
  gap: 22px;
}
.cp-thankyou-overview {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
}
.cp-thankyou-overview li {
  display: grid;
  gap: 8px;
  min-height: 116px;
  align-content: center;
  border-right: 1px solid rgba(21, 53, 72, 0.1);
  padding: 22px;
  color: var(--cp-flow-muted);
  font-size: 13px;
  font-weight: 800;
}
.cp-thankyou-overview li:last-child {
  border-right: 0;
}
.cp-thankyou-overview strong {
  color: var(--cp-flow-ink);
  font-size: 18px;
  font-weight: 900;
}
.cp-thankyou-details {
  padding: clamp(22px, 2.4vw, 34px);
}
.cp-thankyou-details :is(.woocommerce-order-details, .woocommerce-customer-details) {
  margin: 0;
}
.cp-thankyou-details :is(.woocommerce-order-details__title, .woocommerce-column__title) {
  color: var(--cp-flow-ink);
  font-size: clamp(22px, 2vw, 30px);
  letter-spacing: -0.03em;
}
.cp-thankyou-details table,
.cp-thankyou-details address {
  overflow: hidden;
  border: 1px solid rgba(21, 53, 72, 0.1);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.42);
}
.cp-edge-form {
  display: grid;
  max-width: 760px;
  margin: 0 auto;
  gap: 18px;
  padding: clamp(26px, 4vw, 52px);
}
.cp-edge-form-head {
  margin-bottom: 6px;
}
.cp-edge-form .form-row {
  display: grid;
  gap: 8px;
  margin: 0;
}
.cp-edge-form label {
  color: var(--cp-flow-ink);
  font-size: 13px;
  font-weight: 900;
}
.cp-edge-form input.input-text {
  width: 100%;
  min-height: 54px;
  border: 1px solid rgba(21, 53, 72, 0.14);
  border-radius: 14px;
  padding: 0 16px;
  color: var(--cp-flow-ink);
  background: rgba(255, 255, 255, 0.72);
  font: inherit;
  font-weight: 700;
  outline: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}
.cp-edge-submit-row .button {
  width: 100%;
}
body.woocommerce-account .lost_reset_password {
  width: min(100%, 760px);
}
body.woocommerce-account .cp-account-shell .woocommerce:has(.lost_reset_password) {
  grid-template-columns: minmax(0, 760px);
  justify-content: center;
}
body.woocommerce-account .cp-account-content:has(.lost_reset_password) {
  display: grid;
  justify-items: center;
}
body.woocommerce-account .cp-edge-form.lost_reset_password {
  width: min(100%, 760px);
  margin: clamp(18px, 3vw, 42px) auto;
}
body.woocommerce-cart .cart-empty.woocommerce-info {
  display: none;
}
body.woocommerce-cart .cp-edge-state--empty-cart {
  grid-template-columns: minmax(240px, 0.78fr) minmax(0, 1fr);
  justify-items: stretch;
  gap: clamp(24px, 4vw, 64px);
  min-height: 470px;
  overflow: hidden;
}
body.woocommerce-cart .cp-edge-state--empty-cart .cp-edge-state-copy {
  display: grid;
  width: min(100%, 620px);
  gap: clamp(16px, 2vw, 24px);
  justify-items: start;
}
body.woocommerce-cart .cp-edge-state--empty-cart #cp-empty-cart-title {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  text-align: left;
  line-height: 1.08;
}
body.woocommerce-cart .cp-edge-state--empty-cart .cp-edge-state-copy p {
  max-width: 560px;
  margin: 0;
  color: rgba(21, 53, 72, 0.72);
  font-size: clamp(16px, 1.35vw, 19px);
  font-weight: 700;
  line-height: 1.62;
}
body.woocommerce-cart .cp-empty-cart-visual {
  --cp-empty-cart-loop-duration: 6.8s;
  position: relative;
  display: grid;
  justify-self: center;
  width: min(100%, 390px);
  aspect-ratio: 1.35;
  place-items: center;
}
body.woocommerce-cart .cp-empty-cart-scene {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: auto;
  overflow: visible;
}
body.woocommerce-cart .cp-empty-cart-motion {
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}
body.woocommerce-cart .cp-empty-cart-motion {
  stroke: rgba(199, 149, 42, 0.42);
  stroke-dasharray: 7 11;
  stroke-width: 2.2;
  opacity: 0;
  animation: cp-empty-cart-motion var(--cp-empty-cart-loop-duration) ease-out infinite both;
}
body.woocommerce-cart .cp-empty-cart-motion--two {
  animation-delay: 0.34s;
}
body.woocommerce-cart .cp-empty-cart-motion--three {
  animation-delay: 0.72s;
}
body.woocommerce-cart .cp-empty-cart-packages {
  animation: cp-empty-cart-settle var(--cp-empty-cart-loop-duration) cubic-bezier(0.2, 0.86, 0.26, 1) infinite both;
}
body.woocommerce-cart .cp-empty-cart-cart {
  fill: none;
  stroke: url("#cp-empty-cart-ink");
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 8;
  animation: cp-empty-cart-settle var(--cp-empty-cart-loop-duration) cubic-bezier(0.2, 0.86, 0.26, 1) infinite both;
  filter: drop-shadow(0 13px 18px rgba(5, 31, 40, 0.12));
}
body.woocommerce-cart .cp-empty-cart-basket {
  fill: rgba(255, 255, 255, 0.16);
}
body.woocommerce-cart .cp-empty-cart-wheel {
  fill: rgba(255, 255, 255, 0.42);
}
body.woocommerce-cart .cp-empty-cart-package {
  fill: rgba(255, 255, 255, 0.1);
  stroke: #153548;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 3.8;
  opacity: 0;
  transform-box: fill-box;
  transform-origin: center;
  filter: drop-shadow(0 8px 10px rgba(5, 31, 40, 0.09));
}
body.woocommerce-cart .cp-empty-cart-package--pouch {
  animation: cp-empty-package-pouch var(--cp-empty-cart-loop-duration) cubic-bezier(0.16, 0.9, 0.23, 1) infinite both;
}
body.woocommerce-cart .cp-empty-cart-package--box {
  animation: cp-empty-package-box var(--cp-empty-cart-loop-duration) cubic-bezier(0.16, 0.9, 0.23, 1) 0.32s infinite both;
}
body.woocommerce-cart .cp-empty-cart-package--jar {
  animation: cp-empty-package-jar var(--cp-empty-cart-loop-duration) cubic-bezier(0.16, 0.9, 0.23, 1) 0.66s infinite both;
}
body.woocommerce-cart .cp-empty-cart-package--cube {
  animation: cp-empty-package-cube var(--cp-empty-cart-loop-duration) cubic-bezier(0.16, 0.9, 0.23, 1) 0.98s infinite both;
}
body.woocommerce-cart .cp-empty-cart-spark {
  fill: rgba(199, 149, 42, 0.56);
  opacity: 0;
  transform-box: fill-box;
  transform-origin: center;
  animation: cp-empty-cart-spark var(--cp-empty-cart-loop-duration) ease-out infinite both;
}
body.woocommerce-cart .cp-empty-cart-spark--two {
  animation-delay: 0.48s;
}
body.woocommerce-cart .cp-empty-cart-spark--three {
  animation-delay: 1.02s;
}
body.woocommerce-cart .cp-edge-state--empty-cart .cp-edge-actions {
  width: 100%;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  margin-top: 0;
}
body.woocommerce-cart .cp-edge-state--empty-cart .cp-edge-actions .button {
  position: relative;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  isolation: isolate;
  overflow: hidden;
  min-width: min(100%, 188px);
  min-height: 54px;
  border: 1px solid rgba(199, 149, 42, 0.36) !important;
  border-radius: 8px !important;
  padding-inline: 24px;
  color: #fff !important;
  background: linear-gradient(135deg, #051f28 0%, #08313d 48%, #153548 100%) !important;
  box-shadow:
    0 16px 30px rgba(5, 31, 40, 0.22),
    inset 0 0 0 1px rgba(255, 255, 255, 0.08) !important;
  font-size: 15px;
  font-weight: 900;
  line-height: 1.1;
  text-align: center;
  transition:
    background 180ms ease,
    border-color 180ms ease,
    color 180ms ease,
    transform 160ms ease,
    box-shadow 180ms ease,
    filter 180ms ease;
}
body.woocommerce-cart .cp-edge-state--empty-cart .cp-edge-actions .button::before {
  position: absolute;
  z-index: 0;
  inset: -1px;
  background: transparent;
  content: "";
  opacity: 0;
  pointer-events: none;
  transform: translateX(-48%);
  transition: opacity 180ms ease, transform 360ms ease;
}
body.woocommerce-cart .cp-edge-state--empty-cart .cp-edge-actions .button > * {
  position: relative;
  z-index: 1;
}
body.woocommerce-cart .cp-edge-state--empty-cart .cp-edge-actions .button.secondary {
  border-color: rgba(21, 53, 72, 0.14) !important;
  color: #153548 !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.86), rgba(226, 244, 249, 0.6)) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.82),
    0 12px 24px rgba(21, 53, 72, 0.1) !important;
}
body.woocommerce-cart .cp-edge-state--empty-cart .cp-edge-actions .button:hover,
body.woocommerce-cart .cp-edge-state--empty-cart .cp-edge-actions .button:focus-visible {
  border-color: rgba(21, 53, 72, 0.16) !important;
  color: #153548 !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.9), rgba(226, 244, 249, 0.68)) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.86),
    0 19px 34px rgba(21, 53, 72, 0.16),
    0 0 0 1px rgba(21, 53, 72, 0.08) !important;
  filter: saturate(1.02);
  transform: translateY(-1px);
  outline: none;
}
body.woocommerce-cart .cp-edge-state--empty-cart .cp-edge-actions .button:hover::before,
body.woocommerce-cart .cp-edge-state--empty-cart .cp-edge-actions .button:focus-visible::before {
  opacity: 0;
  transform: none;
}
body.woocommerce-cart .cp-empty-cart-featured {
  display: grid;
  gap: clamp(16px, 2vw, 24px);
  margin-top: clamp(22px, 3vw, 34px);
  border: 1px solid rgba(255, 255, 255, 0.68);
  border-radius: clamp(24px, 2.5vw, 38px);
  padding: clamp(18px, 2.5vw, 30px);
  background:
    radial-gradient(circle at 5% 0%, rgba(255, 255, 255, 0.72), transparent 34%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.62), rgba(226, 244, 249, 0.34));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.74),
    0 14px 32px rgba(21, 53, 72, 0.08);
}
body.woocommerce-cart .cp-empty-cart-featured-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
body.woocommerce-cart .cp-empty-cart-featured-head h2 {
  margin: 0;
  color: #153548;
  font-size: clamp(24px, 2vw, 34px);
  line-height: 1.08;
  letter-spacing: -0.035em;
}
body.woocommerce-cart .cp-empty-cart-featured-head a {
  display: inline-flex;
  min-height: 40px;
  align-items: center;
  border: 1px solid rgba(21, 53, 72, 0.12);
  border-radius: 999px;
  padding-inline: 16px;
  color: #153548;
  background: rgba(255, 255, 255, 0.58);
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}
body.woocommerce-cart .cp-empty-cart-featured-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none;
}
body.woocommerce-cart .cp-empty-cart-featured-grid::before,
body.woocommerce-cart .cp-empty-cart-featured-grid::after {
  display: none !important;
  content: none !important;
}
body.woocommerce-cart .cp-empty-cart-featured-grid .product-card {
  float: none !important;
  width: auto !important;
  margin: 0 !important;
}

@media (max-width: 1180px) {
  body.woocommerce-cart .cp-empty-cart-featured-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 620px) {
  body.woocommerce-cart .cp-empty-cart-featured {
    gap: 14px;
    margin-top: 18px;
    border-radius: 22px;
    padding: 14px;
  }

  body.woocommerce-cart .cp-empty-cart-featured-head {
    align-items: flex-start;
  }

  body.woocommerce-cart .cp-empty-cart-featured-head h2 {
    font-size: 24px;
  }

  body.woocommerce-cart .cp-empty-cart-featured-head a {
    min-height: 34px;
    padding-inline: 12px;
    font-size: 12px;
  }

  body.woocommerce-cart .cp-empty-cart-featured-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}

@keyframes cp-empty-package-pouch {
  0% {
    opacity: 0;
    transform: translate(-102px, -94px) rotate(-14deg) scale(0.9);
  }
  13% {
    opacity: 1;
  }
  31%,
  100% {
    opacity: 1;
    transform: translate(0, 0) rotate(0deg) scale(1);
  }
}

@keyframes cp-empty-package-box {
  0% {
    opacity: 0;
    transform: translate(-12px, -116px) rotate(12deg) scale(0.9);
  }
  12% {
    opacity: 1;
  }
  30%,
  100% {
    opacity: 1;
    transform: translate(0, 0) rotate(0deg) scale(1);
  }
}

@keyframes cp-empty-package-jar {
  0% {
    opacity: 0;
    transform: translate(92px, -86px) rotate(16deg) scale(0.9);
  }
  13% {
    opacity: 1;
  }
  31%,
  100% {
    opacity: 1;
    transform: translate(0, 0) rotate(0deg) scale(1);
  }
}

@keyframes cp-empty-package-cube {
  0% {
    opacity: 0;
    transform: translate(-52px, -130px) rotate(-10deg) scale(0.9);
  }
  12% {
    opacity: 1;
  }
  30%,
  100% {
    opacity: 1;
    transform: translate(0, 0) rotate(0deg) scale(1);
  }
}

@keyframes cp-empty-cart-settle {
  0%,
  72% {
    transform: translateX(0);
  }
  84% {
    transform: translateX(13px);
  }
  100% {
    transform: translateX(0);
  }
}

@keyframes cp-empty-cart-motion {
  0%,
  78% {
    opacity: 0;
    stroke-dashoffset: 32;
  }
  14%,
  42% {
    opacity: 0.74;
  }
  62%,
  100% {
    opacity: 0;
    stroke-dashoffset: 0;
  }
}

@keyframes cp-empty-cart-spark {
  0%,
  18%,
  100% {
    opacity: 0;
    transform: scale(0.75);
  }
  34% {
    opacity: 0.82;
    transform: scale(1);
  }
  58% {
    opacity: 0;
    transform: scale(1.24);
  }
}

@media (prefers-reduced-motion: reduce) {
  body.woocommerce-cart .cp-empty-cart-motion,
  body.woocommerce-cart .cp-empty-cart-packages,
  body.woocommerce-cart .cp-empty-cart-cart,
  body.woocommerce-cart .cp-empty-cart-package,
  body.woocommerce-cart .cp-empty-cart-spark {
    animation: none !important;
  }

  body.woocommerce-cart .cp-empty-cart-package {
    opacity: 1;
    transform: none;
  }

  body.woocommerce-cart .cp-empty-cart-motion,
  body.woocommerce-cart .cp-empty-cart-spark {
    opacity: 0;
  }
}

@media (max-width: 900px) {
body.error404,
body.woocommerce-order-received {
    background:
      linear-gradient(180deg, rgba(230, 244, 248, 0.9), rgba(248, 252, 253, 1)),
      linear-gradient(135deg, #e0f0f4 0%, #f5fbfc 62%, #e6f2f6 100%);
  }
.cp-edge-hero,
.cp-edge-state,
.cp-thankyou-hero {
    grid-template-columns: 1fr;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    padding: 24px;
  }
.cp-cart-content .cp-edge-state,
.cp-shop-empty .cp-edge-state {
    width: min(100%, calc(100vw - 28px));
    max-width: calc(100vw - 28px);
    overflow: hidden;
  }
body.woocommerce-cart .cp-edge-state--empty-cart {
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 18px;
    min-height: 0;
    padding: 24px;
    text-align: center;
  }
body.woocommerce-cart .cp-empty-cart-visual {
    width: min(100%, 300px);
    margin-top: -8px;
  }
body.woocommerce-cart .cp-edge-state--empty-cart .cp-edge-state-copy {
    justify-items: center;
    gap: 14px;
  }
body.woocommerce-cart .cp-edge-state--empty-cart #cp-empty-cart-title,
body.woocommerce-cart .cp-edge-state--empty-cart .cp-edge-state-copy p {
    justify-content: center;
    text-align: center;
  }
body.woocommerce-cart .cp-edge-state--empty-cart .cp-edge-actions {
    flex-direction: column;
    align-items: stretch;
  }
.cp-edge-state h2,
.cp-edge-hero h1,
.cp-thankyou-hero h2 {
    max-width: 100%;
    font-size: clamp(28px, 8.4vw, 40px);
    line-height: 1.05;
    word-break: normal;
    overflow-wrap: break-word;
  }
.cp-edge-state p,
.cp-edge-hero p,
.cp-thankyou-hero p {
    max-width: 100%;
    font-size: 16px;
  }
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .site-header {
    position: static;
    width: calc(100% - 20px) !important;
    max-width: calc(100% - 20px) !important;
    margin: 10px 10px 0 !important;
    padding: 12px;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    border-radius: 24px;
  }
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .brand-logo-img--header {
    width: 42px;
    height: 42px;
  }
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .brand-name {
    display: none;
  }
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .header-actions {
    justify-self: end;
    gap: 8px;
  }
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .icon-button {
    width: 48px;
    min-height: 46px;
    padding: 6px;
  }
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .cart-button {
    width: 52px;
    min-height: 46px;
    justify-content: center;
    padding: 6px 8px;
  }
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .cart-button strong {
    display: none;
  }
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .main-nav {
    position: static;
    grid-column: 1 / -1;
    order: 4;
    display: flex;
    justify-content: flex-start;
    width: 100% !important;
    max-width: 100% !important;
    gap: 8px;
    padding: 6px;
    overflow-x: auto !important;
    overflow-y: hidden;
    border: 1px solid rgba(255, 255, 255, 0.66);
    border-radius: 18px;
    background: rgba(5, 31, 40, 0.94);
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.12),
      0 14px 28px rgba(21, 53, 72, 0.12);
    transform: none;
    contain: paint;
    scrollbar-width: none;
  }
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .main-nav::-webkit-scrollbar {
    display: none;
  }
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .main-nav a {
    flex: 0 0 auto;
    min-height: 36px;
    border-radius: 999px;
    padding: 0 18px;
    color: rgba(238, 250, 252, 0.92);
    background: rgba(255, 255, 255, 0.12);
  }
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .main-nav a.is-active,
body:is(.error404, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received) .main-nav a[aria-current="page"] {
    min-height: 36px;
    color: var(--cp-flow-ink);
    background: rgba(255, 255, 255, 0.88);
    box-shadow: none;
  }
.cp-edge-orb {
    width: 128px;
    height: 128px;
  }
.cp-edge-service-band {
    grid-template-columns: 1fr;
  }
.cp-edge-service-band div + div {
    border-top: 1px solid rgba(21, 53, 72, 0.12);
    border-left: 0;
  }
.cp-edge-actions .button,
.cp-edge-state .button,
.cp-edge-form .button,
.cp-thankyou-flow .button {
    max-width: 100%;
    width: 100%;
  }
.cp-account-created-card {
    grid-template-columns: 48px minmax(0, 1fr);
    gap: 14px;
    border-radius: 22px;
    padding: 16px;
  }
.cp-account-created-icon {
    width: 44px;
    height: 44px;
  }
.cp-account-created-copy strong {
    font-size: clamp(19px, 5.4vw, 23px);
  }
.cp-account-created-copy span {
    font-size: 14px;
  }
.cp-account-created-card .button {
    grid-column: 1 / -1;
    justify-self: stretch;
    width: 100%;
  }
.cp-thankyou-overview {
    grid-template-columns: 1fr;
  }
.cp-thankyou-overview li {
    border-right: 0;
    border-bottom: 1px solid rgba(21, 53, 72, 0.1);
  }
}
/* Contact and legal refresh: extend the accepted ice-blue glass storefront system. */
html:has(body.cp-static-surface),
body.cp-static-surface {
  --cp-info-ink: #153548;
  --cp-info-muted: #425d68;
  --cp-info-soft: rgba(226, 244, 249, 0.48);
  --cp-info-glass: rgba(255, 255, 255, 0.62);
  --cp-info-line: rgba(255, 255, 255, 0.68);
  min-height: 100vh;
  background:
    radial-gradient(circle at 10% 8%, rgba(255, 255, 255, 0.66), transparent 18rem),
    radial-gradient(circle at 90% 12%, rgba(110, 176, 193, 0.2), transparent 24rem),
    radial-gradient(circle at 55% 52%, rgba(21, 53, 72, 0.07), transparent 28rem),
    repeating-linear-gradient(103deg, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px 78px),
    linear-gradient(180deg, rgba(229, 244, 248, 0.64) 0%, rgba(238, 248, 250, 0.86) 42%, rgba(247, 251, 252, 1) 100%),
    url("../images/backgrounds/home-background-desktop.jpg") center top / cover no-repeat,
    linear-gradient(135deg, #e0f0f4 0%, #f5fbfc 54%, #e6f2f6 100%);
}
.cp-static-surface .cp-about-page,
.cp-static-surface .cp-contact-page,
.cp-static-surface .cp-legal-page {
  background: transparent !important;
}
.cp-static-surface .cp-about-page::before,
.cp-static-surface .cp-contact-page::before,
.cp-static-surface .cp-legal-page::before {
  display: none !important;
}
/* Account-backed product favorites. */
.favorite,
.cp-favorite-link {
  appearance: none;
  cursor: pointer;
  font: inherit;
  text-decoration: none;
  transition:
    color 180ms ease,
    background 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease,
    opacity 180ms ease,
    transform 180ms ease;
}
.favorite:hover,
.favorite:focus-visible {
  border-color: #153548;
  color: #153548;
  box-shadow: 0 10px 20px rgba(21, 53, 72, 0.14);
  outline: none;
}
.favorite.is-favorite {
  border-color: #153548;
  color: #fff;
  background: #153548;
}
.favorite.is-favorite svg,
.cp-favorite-link.is-favorite svg {
  fill: currentColor;
}
.favorite.is-loading,
.cp-favorite-link.is-loading {
  cursor: progress;
  opacity: 0.72;
}
.cp-favorite-link {
  color: #153548;
}
.cp-favorite-link:hover,
.cp-favorite-link:focus-visible {
  border-color: #153548;
  color: #153548;
  box-shadow: 0 12px 22px rgba(21, 53, 72, 0.12);
  outline: none;
}
.cp-favorite-link.is-favorite {
  border-color: #153548;
  color: #fff;
  background: #153548;
}
.cp-favorite-link.is-favorite:hover,
.cp-favorite-link.is-favorite:focus-visible {
  color: #fff;
  background: #153548;
}
.cp-account-favorites {
  display: grid;
  gap: 22px;
  container-type: inline-size;
}
.cp-account-favorites-header {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  padding: clamp(20px, 2.4vw, 28px);
  border: 1px solid rgba(255, 255, 255, 0.78);
  border-radius: 24px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.82), rgba(228, 246, 250, 0.64)),
    rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 30px rgba(21, 53, 72, 0.1);
}
.cp-account-favorites-header h2 {
  margin: 0 0 7px;
}
.cp-account-favorites-header p {
  margin: 0;
  color: #496570;
}
.cp-account-favorites-icon,
.cp-account-favorites-empty > span {
  display: grid;
  width: 54px;
  height: 54px;
  place-items: center;
  border: 1px solid rgba(21, 53, 72, 0.16);
  border-radius: 50%;
  color: #153548;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82);
}
.cp-account-favorites-icon svg,
.cp-account-favorites-empty svg {
  width: 25px;
  height: 25px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cp-account-favorites-empty {
  display: grid;
  justify-items: center;
  gap: 12px;
  padding: clamp(30px, 4vw, 48px);
  border: 1px solid rgba(255, 255, 255, 0.82);
  border-radius: 24px;
  color: #153548;
  text-align: center;
  background:
    radial-gradient(circle at 50% 0%, rgba(255, 255, 255, 0.86), transparent 18rem),
    linear-gradient(135deg, rgba(255, 255, 255, 0.78), rgba(229, 246, 250, 0.66));
}
.cp-account-favorites-empty[hidden],
.cp-favorites-grid[hidden] {
  display: none !important;
}
.cp-account-favorites-empty strong {
  font-size: clamp(20px, 2vw, 26px);
  font-weight: 900;
}
.cp-account-favorites-empty p {
  max-width: 520px;
  margin: 0;
}
.cp-account-shell .cp-favorites-grid.products {
  display: grid !important;
  --cp-product-card-media-width: auto;
  --cp-product-card-media-max-width: 94%;
  --cp-product-card-media-transform: translateY(0) scale(1);
  --cp-product-card-media-hover-transform: translateY(-3px) scale(1.025);
  --cp-product-media-border: 0 solid transparent;
  --cp-product-media-radius: 8px;
  --cp-product-media-background:
    radial-gradient(circle at 50% 42%, rgba(255, 255, 255, 0.5) 0, rgba(255, 255, 255, 0.16) 34%, transparent 67%);
  --cp-product-media-shadow: none;
  --cp-product-card-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  --cp-product-card-min-height: 232px;
  --cp-product-media-margin: 4px 0 4px 4px;
  --cp-product-media-max-height: 236px;
  --cp-product-body-margin: 10px 10px 10px 0;
  --cp-product-body-padding: 15px 15px 14px;
  --cp-product-grid-template: 1fr;
  --cp-product-grid-gap: 20px;
  grid-template-columns: var(--cp-product-grid-template) !important;
  gap: var(--cp-product-grid-gap);
  margin: 0 !important;
  padding: 0 !important;
  list-style: none;
}
.cp-account-shell .cp-favorites-grid.products::before,
.cp-account-shell .cp-favorites-grid.products::after {
  display: none !important;
}
.cp-account-shell .cp-favorites-grid .product-card {
  display: grid;
  grid-template-columns: var(--cp-product-card-columns);
  min-width: 0;
  min-height: var(--cp-product-card-min-height);
  overflow: hidden;
  border-color: rgba(21, 53, 72, 0.13);
  border-radius: 10px;
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 255, 255, 0.66), transparent 34%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.5), rgba(255, 255, 255, 0.2));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.74),
    0 18px 46px rgba(21, 53, 72, 0.1);
  float: none !important;
  width: auto !important;
  margin: 0 !important;
}
.cp-account-shell .cp-favorites-grid .product-card::after {
  background:
    linear-gradient(125deg, rgba(255, 255, 255, 0.34), transparent 30%),
    radial-gradient(circle at 92% 8%, rgba(255, 255, 255, 0.34), transparent 18%);
}
.cp-account-shell .cp-favorites-grid .product-card a {
  color: inherit;
}
.cp-account-shell .cp-favorites-grid .product-art {
  position: relative;
  min-height: 0;
  height: auto;
  margin: var(--cp-product-media-margin);
  border: var(--cp-product-media-border);
  border-radius: var(--cp-product-media-radius);
  overflow: visible;
  background: var(--cp-product-media-background);
  box-shadow: var(--cp-product-media-shadow);
}
.cp-account-shell .cp-favorites-grid .product-art img {
  position: relative;
  z-index: 1;
  width: var(--cp-product-card-media-width);
  max-width: var(--cp-product-card-media-max-width);
  max-height: var(--cp-product-media-max-height);
  transform: var(--cp-product-card-media-transform);
  transform-origin: center;
}
.cp-account-shell .cp-favorites-grid .product-card:hover .product-art img {
  transform: var(--cp-product-card-media-hover-transform);
}
.cp-account-shell .cp-favorites-grid .product-card-body {
  min-width: 0;
  margin: var(--cp-product-body-margin);
  padding: var(--cp-product-body-padding);
}
.cp-account-shell .cp-favorites-grid .product-card h3 {
  padding-right: 24px;
  font-size: 16px;
  line-height: 1.25;
}
.cp-account-shell .cp-favorites-grid .price-row {
  margin-bottom: 12px;
}
.cp-account-shell .cp-favorites-grid .price-row strong {
  color: var(--green-2);
  font-size: 20px;
  font-weight: 800;
  line-height: 1.05;
}
.cp-account-shell .cp-favorites-grid .price-row .price,
.cp-account-shell .cp-favorites-grid .price-row .amount,
.cp-account-shell .cp-favorites-grid .price-row .woocommerce-Price-amount,
.cp-account-shell .cp-favorites-grid .price-row .woocommerce-Price-currencySymbol {
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
}
.cp-account-shell .cp-favorites-grid .product-card-summary {
  display: -webkit-box;
  margin: 0 0 10px;
  overflow: hidden;
  color: #425865;
  font-size: 12px;
  line-height: 1.45;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}
.cp-account-shell .cp-favorites-grid .add-button {
  gap: 5px;
  min-width: 0;
  min-height: 42px;
  padding-inline: 7px;
  font-size: 12px;
  white-space: nowrap;
}
.cp-account-shell .cp-favorites-grid .add-button span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cp-account-shell .cp-favorites-grid .product-card .add-button {
  color: #fff !important;
}
.cp-account-shell .cp-favorites-grid .add-button svg {
  flex: 0 0 auto;
  width: 16px;
  height: 16px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cp-account-shell .cp-favorites-grid .favorite {
  top: 12px;
  right: 12px;
  width: 32px;
  height: 32px;
}
.cp-account-shell .cp-favorites-grid .product-card.is-removing {
  opacity: 0;
  transform: scale(0.985);
  pointer-events: none;
}

@container (min-width: 780px) {
.cp-account-shell .cp-favorites-grid.products {
    --cp-product-grid-template: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1361px) {
.cp-account-shell .cp-favorites-grid.products {
    --cp-product-card-columns: minmax(0, 0.88fr) minmax(0, 1.12fr);
    --cp-product-card-min-height: 292px;
    --cp-product-media-margin: 12px 0 12px 12px;
    --cp-product-media-max-height: 248px;
    --cp-product-body-margin: 12px 12px 12px 0;
    --cp-product-body-padding: 16px 16px 15px;
  }
.cp-account-shell .cp-favorites-grid .product-card h3 {
    font-size: 17px;
    line-height: 1.25;
  }
.cp-account-shell .cp-favorites-grid .product-card-summary {
    font-size: 13px;
  }
.cp-account-shell .cp-favorites-grid .price-row strong {
    font-size: 22px;
  }
.cp-account-shell .cp-favorites-grid .add-button {
    gap: 8px;
    min-height: 46px;
    padding-inline: 12px;
    font-size: 14px;
  }
.cp-account-shell .cp-favorites-grid .add-button svg {
    width: 18px;
    height: 18px;
  }
}

@media (max-width: 900px) {
.cp-account-shell .cp-favorites-grid.products {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 520px) {
.cp-account-shell .cp-favorites-grid.products {
    --cp-product-grid-template: 1fr;
    --cp-product-media-margin: 10px 10px 0;
    --cp-product-media-max-height: 228px;
    --cp-product-body-margin: 0 10px 10px;
  }
.cp-account-shell .cp-favorites-grid .product-card {
    min-height: 190px;
  }
.cp-account-shell .cp-favorites-grid .price-row strong {
    font-size: 21px;
  }
}

@media (max-width: 640px) {
.cp-account-favorites-header {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
  }
}
/* Shop/category background continuity: use one continuous scenic surface,
like the static pages. */
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) {
  --cp-shop-ink: #153548;
  --cp-shop-muted: rgba(21, 53, 72, 0.64);
  --cp-shop-glass: rgba(255, 255, 255, 0.62);
  --cp-shop-glass-strong: rgba(255, 255, 255, 0.78);
  --cp-shop-border: rgba(255, 255, 255, 0.72);
  --cp-shop-shadow: 0 28px 72px rgba(21, 53, 72, 0.12);
  min-height: 100vh;
  background:
    linear-gradient(rgba(220, 242, 248, 0.42), rgba(220, 242, 248, 0.42)),
    radial-gradient(circle at 10% 8%, rgba(255, 255, 255, 0.58), transparent 18rem),
    radial-gradient(circle at 90% 12%, rgba(110, 176, 193, 0.2), transparent 24rem),
    radial-gradient(circle at 55% 52%, rgba(21, 53, 72, 0.07), transparent 28rem),
    repeating-linear-gradient(103deg, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px 78px),
    linear-gradient(rgba(229, 244, 248, 0.42), rgba(229, 244, 248, 0.42)),
    url("../images/backgrounds/home-background-desktop.jpg") center top / cover no-repeat,
    linear-gradient(135deg, #e0f0f4 0%, #f5fbfc 54%, #e6f2f6 100%) !important;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-shell {
  background: transparent !important;
}
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-shell::before,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-shell::after {
  display: none !important;
  content: none !important;
}

@media (max-width: 980px) {
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) {
    background:
      linear-gradient(rgba(220, 242, 248, 0.42), rgba(220, 242, 248, 0.42)),
      radial-gradient(circle at 10% 8%, rgba(255, 255, 255, 0.58), transparent 14rem),
      radial-gradient(circle at 90% 12%, rgba(110, 176, 193, 0.16), transparent 18rem),
      radial-gradient(circle at 55% 52%, rgba(21, 53, 72, 0.06), transparent 20rem),
      repeating-linear-gradient(103deg, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px 72px),
      linear-gradient(rgba(229, 244, 248, 0.42), rgba(229, 244, 248, 0.42)),
      url("../images/backgrounds/home-background-desktop.jpg") center top / auto 520px no-repeat,
      linear-gradient(135deg, #e0f0f4 0%, #f5fbfc 54%, #e6f2f6 100%) !important;
  }
}
.cp-contact-page,
.cp-legal-page {
  --cp-info-ink: #153548;
  --cp-info-muted: #425d68;
  --cp-info-soft: rgba(226, 244, 249, 0.48);
  --cp-info-glass: rgba(255, 255, 255, 0.62);
  --cp-info-line: rgba(255, 255, 255, 0.68);
  position: relative;
  isolation: isolate;
  overflow: hidden;
  min-height: 100vh;
  color: var(--cp-info-ink);
  background:
    linear-gradient(180deg, rgba(229, 244, 248, 0.64) 0%, rgba(238, 248, 250, 0.86) 42%, rgba(247, 251, 252, 1) 100%),
    url("../images/backgrounds/home-background-desktop.jpg") center top / cover no-repeat,
    linear-gradient(135deg, #e0f0f4 0%, #f5fbfc 54%, #e6f2f6 100%);
}
.cp-contact-page::before,
.cp-legal-page::before {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(circle at 10% 8%, rgba(255, 255, 255, 0.68), transparent 18rem),
    radial-gradient(circle at 90% 12%, rgba(110, 176, 193, 0.2), transparent 24rem),
    radial-gradient(circle at 55% 52%, rgba(21, 53, 72, 0.07), transparent 28rem),
    repeating-linear-gradient(103deg, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px 78px);
  content: "";
}
.cp-contact-hero,
.cp-contact-layout,
.cp-legal-hero,
.cp-legal-layout {
  width: calc(100% - clamp(28px, 5vw, 72px));
  max-width: 1560px;
  margin-inline: auto;
}
.cp-contact-page {
  padding: clamp(30px, 3.6vw, 58px) 0 72px;
}
.cp-contact-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(20px, 2.8vw, 42px);
  align-items: stretch;
  min-height: clamp(210px, 16vw, 280px);
  border: 1px solid var(--cp-info-line);
  border-radius: clamp(28px, 3vw, 44px);
  padding: clamp(24px, 3.2vw, 48px);
  overflow: hidden;
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 255, 255, 0.74), transparent 32%),
    radial-gradient(circle at 86% 12%, rgba(255, 255, 255, 0.46), transparent 26%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.58), rgba(226, 244, 249, 0.32));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.76),
    0 18px 42px rgba(21, 53, 72, 0.08);
}
.cp-contact-hero-copy {
  display: grid;
  align-content: center;
  justify-items: start;
  min-width: 0;
  max-width: 820px;
}
.cp-contact-section-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
  color: rgba(21, 53, 72, 0.74);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.cp-contact-section-label::before {
  width: 34px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #153548, rgba(21, 53, 72, 0.78));
  content: "";
}
.cp-contact-section-label--with-icon {
  gap: 9px;
}
.cp-contact-section-label--with-icon::before {
  display: none;
}
.cp-contact-section-icon {
  width: 24px;
  height: 24px;
  flex: 0 0 auto;
  border: 1px solid rgba(21, 53, 72, 0.18);
  border-radius: 999px;
  padding: 4px;
  color: #153548;
  background:
    radial-gradient(circle at 35% 20%, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.32) 58%, rgba(226, 244, 249, 0.2) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 6px 14px rgba(21, 53, 72, 0.08);
}
.cp-contact-section-icon path,
.cp-contact-section-icon circle {
  fill: currentColor;
}
.cp-contact-hero h1 {
  max-width: 760px;
  margin: 0;
  color: var(--cp-info-ink);
  font-size: clamp(46px, 5.2vw, 78px);
  line-height: 0.96;
  letter-spacing: -0.055em;
}
.cp-contact-hero p {
  max-width: 720px;
  margin: 18px 0 0;
  color: var(--cp-info-muted);
  font-size: clamp(16px, 1.14vw, 20px);
  line-height: 1.62;
}
.cp-contact-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}
.cp-contact-actions .button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  border: 1px solid rgba(21, 53, 72, 0.28);
  border-radius: 14px;
  padding: 0 22px;
  color: #fff;
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.14), transparent 38%),
    linear-gradient(135deg, #051f28 0%, #08313d 52%, #153548 100%);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.09),
    0 12px 24px rgba(5, 31, 40, 0.16);
  font-weight: 900;
  text-decoration: none;
}
.cp-contact-actions .button:not(.secondary):hover,
.cp-contact-actions .button:not(.secondary):focus-visible {
  color: #fff;
  border-color: rgba(21, 53, 72, 0.34);
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.18), transparent 40%),
    linear-gradient(135deg, #062634 0%, #0a3a43 50%, #153548 100%);
}
.cp-contact-actions .button.secondary {
  border-color: rgba(21, 53, 72, 0.2);
  color: var(--cp-info-ink);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.66), rgba(226, 244, 249, 0.34));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 10px 22px rgba(21, 53, 72, 0.06);
}
.cp-contact-brand-card {
  position: relative;
  isolation: isolate;
  display: grid;
  align-content: center;
  justify-items: center;
  min-height: 100%;
  padding: clamp(22px, 2.4vw, 34px);
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: clamp(24px, 2.5vw, 34px);
  overflow: hidden;
  text-align: center;
  background:
    radial-gradient(circle at 50% 28%, rgba(255, 255, 255, 0.76), transparent 30%),
    radial-gradient(circle at 58% 76%, rgba(21, 53, 72, 0.12), transparent 32%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.44), rgba(219, 240, 246, 0.34));
}
.cp-contact-brand-card::before,
.cp-contact-brand-card::after {
  position: absolute;
  pointer-events: none;
  content: "";
}
.cp-contact-brand-card::before {
  inset: 12%;
  z-index: -1;
  border: 1px solid rgba(255, 255, 255, 0.58);
  border-radius: 999px;
}
.cp-contact-brand-card::after {
  right: -20%;
  bottom: -20%;
  z-index: -1;
  width: 62%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(72, 120, 56, 0.16), transparent 62%);
}
.cp-contact-logo {
  display: grid;
  width: clamp(108px, 8.3vw, 146px);
  height: auto;
  place-items: center;
  margin: 0 0 14px;
  filter: none;
}
.cp-contact-logo img,
.cp-contact-logo .brand-logo-img {
  width: 100%;
  height: auto;
  object-fit: contain;
}
.cp-contact-brand-card strong {
  max-width: 360px;
  color: var(--cp-info-ink);
  font-size: clamp(23px, 1.82vw, 31px);
  font-weight: 900;
  line-height: 1.05;
  text-wrap: balance;
}
.cp-contact-brand-card small {
  max-width: 310px;
  margin-top: 9px;
  color: var(--cp-info-muted);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.5;
  text-wrap: balance;
}
.cp-contact-brand-lines {
  display: grid;
  gap: 8px;
  width: min(220px, 70%);
  margin-top: 20px;
}
.cp-contact-brand-lines span {
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, rgba(21, 53, 72, 0.72), rgba(21, 53, 72, 0.42), transparent);
}
.cp-contact-brand-lines span:last-child {
  width: 72%;
  margin-inline: auto;
  opacity: 0.52;
}
.cp-contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(16px, 1.8vw, 24px);
  align-items: start;
  padding: clamp(18px, 2.2vw, 32px) 0 0;
}
.cp-contact-list,
.cp-contact-note {
  border: 1px solid rgba(255, 255, 255, 0.68);
  border-radius: clamp(22px, 2vw, 32px);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.7), rgba(226, 244, 249, 0.38));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.74),
    0 12px 28px rgba(21, 53, 72, 0.07);
}
.cp-contact-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(14px, 1.5vw, 18px);
  align-items: stretch;
  border: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}
.cp-contact-group,
.cp-contact-list article,
.cp-contact-list article:nth-child(2n),
.cp-contact-list article:last-child,
.cp-contact-list article:nth-last-child(-n + 1) {
  position: relative;
  display: grid;
  gap: 14px;
  min-height: auto;
  padding: clamp(18px, 1.6vw, 24px);
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: clamp(20px, 1.8vw, 28px);
  overflow: hidden;
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 255, 255, 0.68), transparent 36%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.66), rgba(226, 244, 249, 0.42));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.76),
    0 12px 26px rgba(21, 53, 72, 0.07);
}
.cp-contact-group--company {
  grid-column: 1 / -1;
}
.cp-contact-list .cp-contact-note {
  position: relative;
  top: auto;
  display: grid;
  align-content: start;
  min-width: 0;
}
@media (min-width: 1181px) {
  .cp-contact-list .cp-contact-note {
    display: none;
  }

  .cp-contact-group--company {
    grid-column: auto;
  }

  .cp-contact-list > .cp-contact-group {
    height: 100%;
  }

  .cp-contact-group--company .cp-contact-group-list--compact {
    grid-template-columns: 1fr;
  }

  .cp-contact-group--company .cp-contact-group-list--compact > div:nth-child(2) {
    border-top: 1px solid rgba(21, 53, 72, 0.09);
    padding-top: 10px;
  }
}
.cp-contact-group-header {
  display: flex;
  gap: 14px;
  align-items: center;
  min-width: 0;
}
.cp-contact-group-header > div {
  display: grid;
  min-width: 0;
  min-height: 54px;
  align-content: center;
}
.cp-contact-group-icon {
  display: grid;
  flex: 0 0 auto;
  width: 54px;
  height: 54px;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.54);
  border-radius: 18px;
  color: #fff !important;
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.28), transparent 40%),
    linear-gradient(135deg, #051f28 0%, #08313d 48%, #153548 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.2),
    0 10px 20px rgba(21, 53, 72, 0.15);
}
.cp-contact-group-icon svg {
  width: 28px;
  height: 28px;
  color: #fff !important;
  fill: none;
}
.cp-contact-group-icon svg path,
.cp-contact-group-icon svg circle {
  fill: none;
  stroke: #fff;
  stroke-width: 1.85;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cp-contact-group-icon svg * {
  color: #fff !important;
}
.cp-contact-group--communication .cp-contact-group-icon {
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.28), transparent 40%),
    linear-gradient(135deg, #051f28 0%, #08313d 48%, #153548 100%);
}
.cp-contact-group--location .cp-contact-group-icon {
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.28), transparent 40%),
    linear-gradient(135deg, #062634 0%, #0b3e4a 48%, #153548 100%);
}
.cp-contact-group--company .cp-contact-group-icon {
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.26), transparent 40%),
    linear-gradient(135deg, #071c25 0%, #08313d 46%, #244b5c 100%);
}
.cp-contact-group-header > div > span {
  color: rgba(21, 53, 72, 0.68);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.cp-contact-group-header h2 {
  margin: 0;
  color: var(--cp-info-ink);
  font-size: clamp(20px, 1.3vw, 24px);
  line-height: 1.08;
  letter-spacing: -0.03em;
  text-wrap: balance;
}
.cp-contact-group-list {
  display: grid;
  gap: 0;
  margin: 0;
}
.cp-contact-group-list > div {
  display: grid;
  grid-template-columns: minmax(108px, 0.38fr) minmax(0, 1fr);
  gap: clamp(10px, 1vw, 14px);
  align-items: baseline;
  padding: 10px 0;
  border-top: 1px solid rgba(21, 53, 72, 0.09);
}
.cp-contact-group-list > div:first-child {
  border-top: 0;
  padding-top: 0;
}
.cp-contact-group-list > div:last-child {
  padding-bottom: 0;
}
.cp-contact-group-list dt {
  margin: 0;
  color: rgba(21, 53, 72, 0.58);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.35;
  text-transform: uppercase;
}
.cp-contact-group-list dd {
  margin: 0;
  color: var(--cp-info-ink);
  font-size: clamp(14px, 0.96vw, 16px);
  font-weight: 850;
  line-height: 1.42;
  overflow-wrap: anywhere;
}
.cp-contact-group-list dd a {
  color: inherit;
  text-decoration: none;
}
.cp-contact-group-list dd a:hover,
.cp-contact-group-list dd a:focus-visible {
  color: #08313d;
  text-decoration: underline;
  text-decoration-color: rgba(21, 53, 72, 0.35);
  text-underline-offset: 4px;
}
.cp-contact-group-list--compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: clamp(20px, 2.2vw, 34px);
}
.cp-contact-group-list--compact > div:nth-child(-n + 2) {
  border-top: 0;
  padding-top: 0;
}
.cp-contact-note {
  position: sticky;
  top: 126px;
  padding: clamp(20px, 1.7vw, 26px);
}
.cp-contact-note-header {
  display: flex;
  gap: 14px;
  align-items: center;
  min-width: 0;
  margin: 0 0 16px;
}
.cp-contact-note-icon {
  display: grid;
  flex: 0 0 auto;
  width: 48px;
  height: 48px;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.54);
  border-radius: 16px;
  color: #fff;
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.28), transparent 40%),
    linear-gradient(135deg, #051f28 0%, #08313d 48%, #153548 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.2),
    0 10px 20px rgba(21, 53, 72, 0.15);
}
.cp-contact-note-icon svg {
  width: 26px;
  height: 26px;
  color: #fff;
  fill: none;
}
.cp-contact-note-icon svg path,
.cp-contact-note-icon svg circle {
  fill: none;
  stroke: #fff;
  stroke-width: 1.85;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.cp-contact-note h2 {
  margin: 0;
  color: var(--cp-info-ink);
  font-size: clamp(24px, 1.65vw, 30px);
  line-height: 1.1;
  letter-spacing: -0.03em;
  text-wrap: balance;
}
.cp-contact-note p {
  margin: 0;
  color: var(--cp-info-muted);
  font-size: 14.5px;
  line-height: 1.68;
}
.cp-contact-legal-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px !important;
}
.cp-contact-legal-links a {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  border: 1px solid rgba(21, 53, 72, 0.16);
  border-radius: 999px;
  padding: 0 13px;
  color: #153548;
  background: rgba(255, 255, 255, 0.62);
  font-size: 12px;
  font-weight: 900;
}
.cp-contact-map {
  display: grid;
  grid-template-columns: minmax(280px, 0.36fr) minmax(0, 0.64fr);
  gap: clamp(16px, 2vw, 24px);
  align-items: stretch;
  width: calc(100% - clamp(28px, 5vw, 72px));
  max-width: 1560px;
  margin: 18px auto 0;
  padding: clamp(16px, 1.8vw, 24px);
  border: 1px solid rgba(255, 255, 255, 0.68);
  border-radius: clamp(24px, 2.4vw, 34px);
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 255, 255, 0.66), transparent 34%),
    radial-gradient(circle at 100% 8%, rgba(161, 211, 226, 0.24), transparent 30%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.58), rgba(226, 244, 249, 0.42));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.76),
    0 12px 26px rgba(21, 53, 72, 0.075);
}
.cp-contact-map-copy {
  display: grid;
  align-content: center;
  justify-items: start;
  min-width: 0;
  padding: clamp(8px, 1vw, 14px);
}
.cp-contact-map-copy h2 {
  margin: 0 0 12px;
  color: var(--cp-info-ink);
  font-size: clamp(26px, 2.35vw, 38px);
  line-height: 1.04;
  letter-spacing: -0.035em;
  text-wrap: balance;
}
.cp-contact-map-copy p {
  max-width: 430px;
  margin: 0 0 18px;
  color: var(--cp-info-muted);
  font-size: 15px;
  line-height: 1.64;
}
.cp-contact-map-copy .button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  border: 1px solid rgba(21, 53, 72, 0.2);
  border-radius: 14px;
  padding: 0 18px;
  color: var(--cp-info-ink);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.68), rgba(226, 244, 249, 0.36));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 10px 22px rgba(21, 53, 72, 0.06);
  font-weight: 900;
  text-decoration: none;
}
.cp-contact-map-copy .button:hover,
.cp-contact-map-copy .button:focus-visible {
  color: #fff;
  border-color: rgba(21, 53, 72, 0.34);
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.18), transparent 40%),
    linear-gradient(135deg, #062634 0%, #0a3a43 50%, #153548 100%);
}
.cp-contact-map-frame {
  position: relative;
  min-height: clamp(270px, 26vw, 380px);
  border: 1px solid rgba(255, 255, 255, 0.64);
  border-radius: clamp(18px, 2vw, 26px);
  overflow: hidden;
  background: rgba(255, 255, 255, 0.38);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.68),
    0 14px 32px rgba(21, 53, 72, 0.1);
}
.cp-contact-map-frame iframe {
  display: block;
  width: 100%;
  height: 100%;
  min-height: inherit;
  border: 0;
  filter: saturate(0.95) contrast(1.02);
}
.cp-legal-page {
  padding: clamp(34px, 4.4vw, 72px) 0 88px;
  background:
    linear-gradient(180deg, rgba(226, 242, 247, 0.68) 0%, rgba(238, 248, 250, 0.9) 36%, rgba(247, 251, 252, 1) 100%),
    url("../images/backgrounds/home-background-desktop.jpg") center top / cover no-repeat,
    linear-gradient(135deg, #dceef3 0%, #f5fbfc 54%, #e6f2f6 100%);
}
.cp-legal-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(360px, 0.48fr);
  gap: clamp(24px, 3.4vw, 54px);
  justify-content: initial;
  align-items: stretch;
  min-height: clamp(310px, 25vw, 420px);
  border: 1px solid var(--cp-info-line);
  border-radius: clamp(28px, 3vw, 44px);
  padding: clamp(28px, 4vw, 56px);
  overflow: hidden;
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 255, 255, 0.75), transparent 32%),
    radial-gradient(circle at 88% 12%, rgba(255, 255, 255, 0.46), transparent 26%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.6), rgba(226, 244, 249, 0.35));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.76),
    0 18px 42px rgba(21, 53, 72, 0.08);
}
.cp-legal-hero::before {
  inset: auto auto -24% -10%;
  width: 46%;
  aspect-ratio: 1;
  border-radius: 50%;
  clip-path: none;
  background: radial-gradient(circle, rgba(72, 120, 56, 0.12), transparent 62%);
}
.cp-legal-hero-copy,
.cp-legal-seller-card {
  position: relative;
  z-index: 1;
}
.cp-legal-hero-copy {
  display: grid;
  align-content: center;
  justify-items: start;
  min-width: 0;
}
.cp-legal-hero h1 {
  max-width: 880px;
  margin: 0;
  color: var(--cp-info-ink);
  font-size: clamp(42px, 4.8vw, 78px);
  line-height: 0.98;
  letter-spacing: -0.048em;
  text-wrap: balance;
}
.cp-legal-hero p {
  max-width: 760px;
  margin: 20px 0 18px;
  color: var(--cp-info-muted);
  font-size: clamp(16px, 1.18vw, 20px);
  line-height: 1.72;
}
.cp-legal-seller-card {
  align-self: stretch;
  display: grid;
  align-content: center;
  gap: 18px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: clamp(22px, 2vw, 30px);
  padding: clamp(22px, 2vw, 30px);
  color: var(--cp-info-muted);
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.68), transparent 38%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.58), rgba(226, 244, 249, 0.34));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.76),
    0 12px 28px rgba(21, 53, 72, 0.08);
}
.cp-legal-seller-heading {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(21, 53, 72, 0.12);
}
.cp-legal-seller-logo {
  width: 76px;
  height: 76px;
  filter: none;
}
.cp-legal-seller-heading span {
  display: block;
  margin-bottom: 6px;
  color: rgba(21, 53, 72, 0.68);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.cp-legal-seller-card strong {
  display: block;
  color: var(--cp-info-ink);
  font-size: 16px;
  line-height: 1.36;
  text-wrap: balance;
}
.cp-legal-seller-details {
  display: grid;
  gap: 8px;
}
.cp-legal-seller-details span,
.cp-legal-seller-details a {
  color: var(--cp-info-muted);
  font-size: 13px;
  line-height: 1.55;
  overflow-wrap: anywhere;
}
.cp-legal-seller-details a {
  width: fit-content;
  color: var(--cp-info-ink);
  font-weight: 900;
  text-decoration: underline;
  text-decoration-color: rgba(199, 149, 42, 0.5);
  text-underline-offset: 3px;
}
.cp-legal-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 314px;
  gap: clamp(18px, 2vw, 30px);
  align-items: start;
  padding: clamp(22px, 2.8vw, 42px) 0 0;
}
.cp-legal-content {
  min-width: 0;
  border: 1px solid rgba(255, 255, 255, 0.68);
  border-radius: clamp(22px, 2vw, 32px);
  overflow: hidden;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.76), rgba(226, 244, 249, 0.4));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.74),
    0 12px 30px rgba(21, 53, 72, 0.075);
}
.cp-legal-content section {
  position: relative;
  border-bottom: 1px solid rgba(21, 53, 72, 0.1);
  padding: 34px 42px 36px 50px;
  scroll-margin-top: 120px;
}
.cp-legal-content section::before {
  position: absolute;
  top: 38px;
  left: 24px;
  width: 3px;
  height: 30px;
  border-radius: 2px;
  background: linear-gradient(180deg, #153548, rgba(21, 53, 72, 0.62));
  content: "";
}
.cp-legal-content h2 {
  margin: 0 0 15px;
  color: var(--cp-info-ink);
  font-size: 22px;
  line-height: 1.28;
  text-wrap: balance;
}
.cp-legal-content p,
.cp-legal-content li {
  color: #40575f;
  font-size: 15px;
  line-height: 1.82;
}
.cp-legal-content a {
  color: #153548;
  font-weight: 900;
  text-decoration: underline;
  text-decoration-color: rgba(199, 149, 42, 0.5);
  text-underline-offset: 3px;
}
.cp-legal-content .cp-legal-notice {
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 255, 255, 0.74), transparent 42%),
    linear-gradient(135deg, rgba(232, 246, 240, 0.72), rgba(255, 255, 255, 0.54));
}
.cp-legal-table-wrap {
  max-width: 100%;
  overflow-x: auto;
  margin: 4px 0 20px;
  border: 1px solid rgba(21, 53, 72, 0.12);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.48);
}
.cp-legal-content th,
.cp-legal-content td {
  border-color: rgba(21, 53, 72, 0.1);
}
.cp-legal-content th {
  color: var(--cp-info-ink);
  background: rgba(226, 244, 249, 0.62);
}
.cp-legal-navigation {
  position: sticky;
  top: 126px;
  display: grid;
  gap: 7px;
  border: 1px solid rgba(255, 255, 255, 0.68);
  border-radius: clamp(20px, 1.8vw, 28px);
  padding: 20px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.72), rgba(226, 244, 249, 0.38));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.74),
    0 12px 28px rgba(21, 53, 72, 0.07);
}
.cp-legal-navigation-rail {
  display: grid;
  gap: 7px;
}
.cp-legal-navigation .cp-rail-affordance {
  display: none;
}
.cp-legal-navigation h2 {
  margin: 0 0 11px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(21, 53, 72, 0.1);
  color: var(--cp-info-ink);
  font-size: 18px;
}
.cp-legal-navigation a {
  display: block;
  min-height: 42px;
  border: 1px solid rgba(21, 53, 72, 0.1);
  border-radius: 14px;
  padding: 11px 13px;
  color: #40575f;
  background: rgba(255, 255, 255, 0.46);
  font-size: 13px;
  font-weight: 900;
  line-height: 1.4;
}
.cp-legal-navigation a:hover {
  color: #153548;
  border-color: rgba(21, 53, 72, 0.18);
  background: rgba(255, 255, 255, 0.72);
}
.cp-legal-navigation a.is-current {
  color: #fff;
  border-color: rgba(199, 149, 42, 0.42);
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.14), transparent 38%),
    linear-gradient(135deg, #051f28 0%, #08313d 52%, #153548 100%);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}
@media (min-width: 1181px) {
  .cp-legal-navigation h2 {
    display: none;
  }
}

@media (max-width: 1180px) {
.cp-contact-hero,
.cp-legal-hero,
.cp-contact-layout,
.cp-legal-layout {
    grid-template-columns: 1fr;
  }
.cp-contact-note,
.cp-legal-navigation {
    position: static;
  }
.cp-contact-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
.cp-contact-list .cp-contact-note {
    grid-column: 1 / -1;
  }
.cp-contact-map {
    grid-template-columns: 1fr;
  }
.cp-contact-map-copy {
    align-content: start;
  }
.cp-legal-navigation {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
.cp-legal-navigation-rail {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-column: 1 / -1;
    gap: 7px;
  }
.cp-legal-navigation h2 {
    grid-column: 1 / -1;
  }
}

@media (max-width: 900px) {
.cp-contact-page,
.cp-legal-page {
    padding-top: 28px;
    background:
      linear-gradient(180deg, rgba(230, 244, 248, 0.9), rgba(248, 252, 253, 1)),
      linear-gradient(135deg, #e0f0f4 0%, #f5fbfc 62%, #e6f2f6 100%);
  }
.cp-contact-hero,
.cp-contact-layout,
.cp-contact-map,
.cp-legal-hero,
.cp-legal-layout {
    width: calc(100% - 28px);
  }
.cp-contact-hero,
.cp-legal-hero {
    min-height: 0;
    border-radius: 28px;
    padding: 24px;
  }
.cp-contact-hero h1,
.cp-legal-hero h1 {
    font-size: clamp(42px, 11vw, 62px);
  }
.cp-contact-hero p,
.cp-legal-hero p {
    font-size: 16px;
  }
.cp-contact-group-list--compact {
    grid-template-columns: 1fr;
  }
.cp-contact-group-list--compact > div:nth-child(2) {
    border-top: 1px solid rgba(21, 53, 72, 0.09);
    padding-top: 13px;
  }
}

@media (max-width: 620px) {
.cp-contact-page,
.cp-legal-page {
    padding-bottom: 58px;
  }
.cp-contact-hero,
.cp-legal-hero {
    padding: 22px;
  }
.cp-contact-section-label {
    font-size: 11px;
    letter-spacing: 0.07em;
  }
.cp-contact-actions {
    display: grid;
    grid-template-columns: 1fr;
    width: 100%;
  }
.cp-contact-actions .button {
    width: 100%;
  }
.cp-contact-brand-card {
    min-height: 230px;
  }
.cp-contact-logo {
    width: 104px;
  }
.cp-contact-list {
    grid-template-columns: 1fr;
  }
.cp-contact-list article,
.cp-contact-list article:nth-child(2n),
.cp-contact-list article:last-child,
.cp-contact-list article:nth-last-child(-n + 1) {
    min-height: 96px;
    padding: 18px;
  }
.cp-contact-group-header {
    align-items: flex-start;
  }
.cp-contact-group-icon {
    width: 54px;
    height: 54px;
    border-radius: 18px;
  }
.cp-contact-group-icon svg {
    width: 28px;
    height: 28px;
  }
.cp-contact-group-list > div {
    grid-template-columns: 1fr;
    gap: 4px;
    padding: 12px 0;
  }
.cp-contact-group-list dt {
    font-size: 10px;
  }
.cp-contact-group-list dd {
    font-size: 16px;
  }
.cp-contact-note,
.cp-contact-map,
.cp-legal-content,
.cp-legal-navigation {
    border-radius: 22px;
  }
.cp-contact-map {
    padding: 16px;
  }
.cp-contact-map-frame {
    min-height: 250px;
    border-radius: 18px;
  }
.cp-contact-map-copy .button {
    width: 100%;
  }
.cp-legal-seller-heading {
    grid-template-columns: 62px minmax(0, 1fr);
  }
.cp-legal-seller-logo {
    width: 62px;
    height: 62px;
  }
.cp-legal-content section {
    padding: 28px 22px 30px 34px;
  }
.cp-legal-content section::before {
    top: 31px;
    left: 17px;
    height: 26px;
  }
.cp-legal-content h2 {
    font-size: 20px;
  }
.cp-legal-content p,
.cp-legal-content li {
    font-size: 15px;
    line-height: 1.75;
  }
.cp-legal-navigation {
    grid-template-columns: none;
    overflow-x: hidden;
    padding: 14px;
    scrollbar-width: thin;
    overscroll-behavior-inline: contain;
  }
.cp-legal-navigation-rail {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(168px, 0.78fr);
    gap: 7px;
    overflow-x: auto;
    scrollbar-width: thin;
    overscroll-behavior-inline: contain;
  }
.cp-legal-navigation h2 {
    display: none;
  }
.cp-legal-navigation a {
    display: grid;
    min-height: 48px;
    place-items: center;
    padding: 9px 12px;
    text-align: center;
  }
}

/* Unified scenic background engine: every revised storefront surface now inherits
   the same home-page photo and mist veil instead of page-specific fog stacks. */
html:has(body:is(.home, .cp-static-surface, .post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag, .single-product, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received, .error404)),
body:is(.home, .cp-static-surface, .post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag, .single-product, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account, .woocommerce-order-received, .error404) {
  min-height: 100vh;
  background: var(--cp-site-scenic-background) !important;
  background-attachment: scroll !important;
}

body.home::before,
body:is(.single-product, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account)::before,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag)::before,
body.cp-static-surface :is(.cp-about-page, .cp-contact-page, .cp-legal-page)::before,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-shell::before,
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-shell::after {
  display: none !important;
  content: none !important;
}

body.cp-static-surface :is(.cp-about-page, .cp-contact-page, .cp-legal-page),
body:is(.post-type-archive-product, .woocommerce-shop, .tax-product_cat, .tax-product_tag) .cp-shop-shell,
body:is(.single-product, .woocommerce-cart, .woocommerce-checkout, .woocommerce-account) :is(.woo-page-shell, .cp-cart-shell, .cp-checkout-shell, .cp-account-shell) {
  background: transparent !important;
}

/* Desktop guest account affordance: keep mobile's current icon-only rhythm intact. */
@media (min-width: 821px) {
  .site-header .cp-header-account.cp-header-account--guest {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 82px !important;
    min-width: 82px !important;
    min-height: 58px;
    padding: 7px 10px 6px !important;
    gap: 0 !important;
  }

  .site-header .cp-header-account.cp-header-account--guest::after {
    display: none !important;
    content: none !important;
  }

  .site-header .cp-header-account.cp-header-account--guest .cp-header-account-icon {
    display: none !important;
  }

  .site-header .cp-header-account.cp-header-account--guest .cp-header-auth-stack {
    display: flex !important;
    font-size: 12px;
    font-weight: 850;
    letter-spacing: -0.01em;
  }

  .site-header .cp-header-account.cp-header-account--guest .cp-header-auth-stack span:last-child {
    font-size: 11px;
    font-weight: 800;
    opacity: 0.78;
  }
}

/* Checkout login reminder: WooCommerce renders this through the notice template,
   but its checkout-specific selector used to overpower the unified notice skin. */
body.woocommerce-checkout .cp-checkout-shell .cp-checkout-login-card {
  margin: 0 0 20px;
}

body.woocommerce-checkout .cp-checkout-shell .cp-checkout-login-card.is-login-open {
  margin-top: clamp(14px, 1.5vw, 22px);
}

body.woocommerce-checkout .cp-checkout-shell .woocommerce-form-login-toggle .cp-wc-notice,
body.woocommerce-checkout .cp-checkout-shell .woocommerce-form-login-toggle .woocommerce-info {
  display: grid !important;
  grid-template-columns: 44px minmax(0, 1fr) !important;
  gap: 15px !important;
  align-items: center !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 17px 20px !important;
  border: 1px solid rgba(255, 255, 255, 0.74) !important;
  border-left: 1px solid rgba(255, 255, 255, 0.74) !important;
  border-radius: 24px !important;
  color: #153548 !important;
  background:
    radial-gradient(circle at 4% 6%, rgba(255, 255, 255, 0.86), transparent 38%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.76), rgba(226, 244, 249, 0.46)) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.86),
    0 16px 34px rgba(21, 53, 72, 0.08) !important;
}

body.woocommerce-checkout .cp-checkout-shell .cp-checkout-login-card.is-login-open .woocommerce-form-login-toggle {
  display: none !important;
}

body.woocommerce-checkout .cp-checkout-shell .woocommerce-form-login-toggle .cp-wc-notice::before,
body.woocommerce-checkout .cp-checkout-shell .woocommerce-form-login-toggle .cp-wc-notice::after,
body.woocommerce-checkout .cp-checkout-shell .woocommerce-form-login-toggle .woocommerce-info::before,
body.woocommerce-checkout .cp-checkout-shell .woocommerce-form-login-toggle .woocommerce-info::after {
  content: none !important;
  display: none !important;
}

body.woocommerce-checkout .cp-checkout-shell .woocommerce-form-login-toggle .cp-wc-notice-icon {
  display: grid !important;
  width: 38px !important;
  height: 38px !important;
  place-items: center !important;
}

body.woocommerce-checkout .cp-checkout-shell .woocommerce-form-login-toggle .cp-wc-notice-copy {
  display: flex !important;
  min-width: 0 !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  align-items: center !important;
  color: #153548 !important;
  font-size: 15px !important;
  font-weight: 850 !important;
  line-height: 1.45 !important;
  overflow-wrap: anywhere !important;
}

body.woocommerce-checkout .cp-checkout-shell .cp-checkout-login-form-shell[hidden] {
  display: none !important;
}

body.woocommerce-checkout .cp-checkout-shell .cp-checkout-login-form-shell {
  overflow: hidden;
  padding: clamp(18px, 2.2vw, 26px);
  border: 1px solid rgba(255, 255, 255, 0.74);
  border-radius: 24px;
  color: #153548;
  background:
    radial-gradient(circle at 4% 6%, rgba(255, 255, 255, 0.84), transparent 40%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.72), rgba(226, 244, 249, 0.42));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.86),
    0 16px 34px rgba(21, 53, 72, 0.08);
}

body.woocommerce-checkout .cp-checkout-shell .cp-checkout-login-form-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin: 0 0 16px;
}

body.woocommerce-checkout .cp-checkout-shell .cp-checkout-login-form-title {
  color: #153548;
  font-size: 16px;
  font-weight: 950;
  letter-spacing: -0.02em;
}

body.woocommerce-checkout .cp-checkout-shell .cp-checkout-login-collapse {
  display: grid;
  width: 42px;
  height: 42px;
  flex: 0 0 auto;
  place-items: center;
  border: 1px solid rgba(21, 53, 72, 0.14);
  border-radius: 999px;
  color: #153548;
  background: rgba(255, 255, 255, 0.72);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.76),
    0 10px 20px rgba(21, 53, 72, 0.08);
  cursor: pointer;
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    background 180ms ease;
}

body.woocommerce-checkout .cp-checkout-shell .cp-checkout-login-collapse:hover,
body.woocommerce-checkout .cp-checkout-shell .cp-checkout-login-collapse:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(21, 53, 72, 0.28);
  background: rgba(255, 255, 255, 0.9);
  outline: none;
}

body.woocommerce-checkout .cp-checkout-shell .cp-checkout-login-collapse svg {
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

body.woocommerce-checkout .cp-checkout-shell form.woocommerce-form-login.login {
  overflow: hidden;
  margin: -10px 0 24px;
  padding: clamp(18px, 2.2vw, 26px);
  border: 1px solid rgba(255, 255, 255, 0.74);
  border-radius: 24px;
  color: #153548;
  background:
    radial-gradient(circle at 4% 6%, rgba(255, 255, 255, 0.84), transparent 40%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.72), rgba(226, 244, 249, 0.42));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.86),
    0 16px 34px rgba(21, 53, 72, 0.08);
}

body.woocommerce-checkout .cp-checkout-shell .cp-checkout-login-card form.woocommerce-form-login.login {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

body.woocommerce-checkout .cp-checkout-shell form.woocommerce-form-login.login > p:first-child {
  margin: 0 0 16px;
  color: #536c75;
  font-size: 14px;
  font-weight: 750;
  line-height: 1.55;
}

body.woocommerce-checkout .cp-checkout-shell form.woocommerce-form-login.login .form-row-first,
body.woocommerce-checkout .cp-checkout-shell form.woocommerce-form-login.login .form-row-last {
  float: none;
  width: 100%;
  margin: 0 0 14px;
}

body.woocommerce-checkout .cp-checkout-shell form.woocommerce-form-login.login label {
  color: #536c75;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.02em;
}

body.woocommerce-checkout .cp-checkout-shell form.woocommerce-form-login.login input.input-text {
  width: 100%;
  min-height: 52px;
  border: 1px solid rgba(21, 53, 72, 0.16);
  border-radius: 16px;
  padding: 0 16px;
  color: #153548;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.78);
}

body.woocommerce-checkout .cp-checkout-shell form.woocommerce-form-login.login input.input-text:focus {
  border-color: rgba(21, 53, 72, 0.38);
  outline: none;
  box-shadow:
    0 0 0 4px rgba(21, 53, 72, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.78);
}

body.woocommerce-checkout .cp-checkout-shell form.woocommerce-form-login.login .form-row:not(.form-row-first):not(.form-row-last) {
  display: flex;
  flex-wrap: nowrap;
  gap: 14px;
  align-items: center;
  justify-content: space-between;
  margin: 4px 0 0;
}

body.woocommerce-checkout .cp-checkout-shell form.woocommerce-form-login.login .form-row:not(.form-row-first):not(.form-row-last) input[type="hidden"] {
  display: none !important;
}

body.woocommerce-checkout .cp-checkout-shell form.woocommerce-form-login.login .woocommerce-form-login__rememberme {
  display: inline-flex;
  min-height: 46px;
  gap: 9px;
  align-items: center;
  justify-self: start;
  margin: 0 !important;
  padding: 0 14px;
  border: 1px solid rgba(21, 53, 72, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.52);
  color: #153548;
  font-size: 13px;
  font-weight: 850;
}

body.woocommerce-checkout .cp-checkout-shell form.woocommerce-form-login.login .woocommerce-form-login__rememberme input {
  width: 16px;
  height: 16px;
  flex: 0 0 auto;
  accent-color: #153548;
}

body.woocommerce-checkout .cp-checkout-shell form.woocommerce-form-login.login .button {
  min-height: 46px;
  min-width: 148px;
  justify-self: end;
  margin-left: auto;
  border: 0;
  border-radius: 999px;
  padding: 0 22px;
  color: #fff;
  background: linear-gradient(135deg, #051f28 0%, #08313d 54%, #153548 100%);
  box-shadow: 0 12px 24px rgba(5, 31, 40, 0.15);
  font-weight: 900;
}

body.woocommerce-checkout .cp-checkout-shell form.woocommerce-form-login.login .lost_password {
  margin: 14px 0 0;
}

body.woocommerce-checkout .cp-checkout-shell form.woocommerce-form-login.login .lost_password a {
  color: #153548;
  font-weight: 900;
  text-decoration-color: rgba(21, 53, 72, 0.34);
  text-underline-offset: 4px;
}

@media (max-width: 640px) {
  body.woocommerce-checkout .cp-checkout-shell .woocommerce-form-login-toggle .cp-wc-notice,
  body.woocommerce-checkout .cp-checkout-shell .woocommerce-form-login-toggle .woocommerce-info {
    grid-template-columns: 38px minmax(0, 1fr) !important;
    gap: 12px !important;
    padding: 14px !important;
    border-radius: 20px !important;
  }

  body.woocommerce-checkout .cp-checkout-shell .woocommerce-form-login-toggle .cp-wc-notice-icon {
    width: 34px !important;
    height: 34px !important;
  }

  body.woocommerce-checkout .cp-checkout-shell .woocommerce-form-login-toggle .cp-wc-notice-copy {
    font-size: 14px !important;
    line-height: 1.42 !important;
  }

  body.woocommerce-checkout .cp-checkout-shell .cp-checkout-login-card {
    margin-bottom: 18px;
  }

  body.woocommerce-checkout .cp-checkout-shell .cp-checkout-login-form-shell {
    padding: 16px;
    border-radius: 20px;
  }

  body.woocommerce-checkout .cp-checkout-shell .cp-checkout-login-form-head {
    margin-bottom: 14px;
  }

  body.woocommerce-checkout .cp-checkout-shell .cp-checkout-login-collapse {
    width: 38px;
    height: 38px;
  }

  body.woocommerce-checkout .cp-checkout-shell form.woocommerce-form-login.login {
    margin: -3px 0 18px;
    padding: 16px;
    border-radius: 20px;
  }

  body.woocommerce-checkout .cp-checkout-shell form.woocommerce-form-login.login .form-row:not(.form-row-first):not(.form-row-last) {
    flex-direction: column;
    gap: 12px;
    align-items: stretch;
  }

  body.woocommerce-checkout .cp-checkout-shell form.woocommerce-form-login.login .woocommerce-form-login__rememberme {
    justify-content: center;
    justify-self: stretch;
  }

  body.woocommerce-checkout .cp-checkout-shell form.woocommerce-form-login.login .button {
    min-width: 0;
    margin-left: 0;
    width: 100%;
  }
}

/* Motion polish layer: subtle, performance-safe interaction feedback. */
body.cp-motion-ready .cp-motion-reveal {
  opacity: 0;
  transform: translate3d(0, 24px, 0);
  transition:
    opacity 640ms ease,
    transform 700ms var(--cp-motion-ease);
  transition-delay: var(--cp-reveal-delay, 0ms);
}

body.cp-motion-ready .cp-motion-reveal.is-motion-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

body.cp-motion-ready .product-card.cp-motion-reveal {
  transform: translate3d(0, 28px, 0) scale(0.975);
}

body.cp-motion-ready .product-card.cp-motion-reveal.is-motion-visible {
  transform: translate3d(0, 0, 0) scale(1);
}

body.cp-motion-ready .product-card.cp-motion-reveal.is-motion-visible:hover,
body.cp-motion-ready .product-card.cp-motion-reveal.is-motion-visible:focus-within {
  transform: translate3d(0, -5px, 0) scale(1);
}

.cp-checkout-address-ui,
.cp-address-book-card,
.cp-account-panel,
.cp-cart-service-band div,
.cp-contact-group,
.cp-legal-navigation a {
  transition:
    border-color var(--cp-motion-fast) ease,
    background-color var(--cp-motion-fast) ease,
    box-shadow var(--cp-motion-medium) ease,
    transform var(--cp-motion-fast) var(--cp-motion-ease);
}

.cp-checkout-address-summary,
.cp-checkout-address-option,
.cp-checkout-address-add,
.cp-checkout-address-actions button {
  transition:
    border-color var(--cp-motion-fast) ease,
    background var(--cp-motion-fast) ease,
    box-shadow var(--cp-motion-medium) ease,
    opacity var(--cp-motion-fast) ease,
    transform var(--cp-motion-fast) var(--cp-motion-ease);
}

.cp-checkout-address-summary:hover,
.cp-checkout-address-summary:focus-visible,
.cp-checkout-address-option:hover,
.cp-checkout-address-option:focus-within {
  border-color: rgba(21, 53, 72, 0.28);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.82),
    0 12px 24px rgba(21, 53, 72, 0.09);
  transform: translateY(-1px);
}

.cp-checkout-address-option.is-active {
  animation: cp-address-select-settle 360ms var(--cp-motion-ease) both;
}

.cp-checkout-address-option.is-selecting,
.cp-checkout-address-ui.is-address-changing .cp-checkout-address-summary {
  animation: cp-address-selection-pulse 440ms var(--cp-motion-ease) both;
}

.cp-checkout-address-ui.is-manual-opening {
  animation: cp-address-manual-open 420ms var(--cp-motion-ease) both;
}

.cp-checkout-address-chevron {
  transition:
    color var(--cp-motion-fast) ease,
    background var(--cp-motion-fast) ease,
    transform var(--cp-motion-medium) var(--cp-motion-ease);
}

.cp-checkout-address-ui.is-list-open .cp-checkout-address-chevron {
  transform: rotate(90deg);
}

.cp-checkout-address-add:hover,
.cp-checkout-address-add:focus-visible,
.cp-checkout-address-actions button:hover,
.cp-checkout-address-actions button:focus-visible {
  box-shadow: 0 12px 22px rgba(21, 53, 72, 0.14);
  transform: translateY(-1px);
}

.cp-address-book-card:hover,
.cp-address-book-card:focus-within {
  border-color: rgba(21, 53, 72, 0.28);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.82),
    0 18px 34px rgba(21, 53, 72, 0.11);
  transform: translateY(-2px);
}

.cp-address-book-card:hover .cp-address-book-icon,
.cp-address-book-card:focus-within .cp-address-book-icon,
.cp-address-book-edit:hover,
.cp-address-book-edit:focus-visible {
  color: #fff;
  background: #153548;
  box-shadow: 0 10px 18px rgba(21, 53, 72, 0.16);
  transform: translateY(-1px);
}

.cp-address-book-icon,
.cp-address-book-edit {
  transition:
    color var(--cp-motion-fast) ease,
    background var(--cp-motion-fast) ease,
    box-shadow var(--cp-motion-fast) ease,
    transform var(--cp-motion-fast) var(--cp-motion-ease);
}

.cp-address-book-add:hover,
.cp-address-book-add:focus-visible,
.cp-address-book-actions button:hover,
.cp-address-book-actions button:focus-visible {
  box-shadow: 0 12px 22px rgba(21, 53, 72, 0.14);
  transform: translateY(-1px);
}

.flow-steps article {
  transition:
    color var(--cp-motion-fast) ease,
    transform var(--cp-motion-fast) var(--cp-motion-ease);
}

.flow-steps span {
  transition:
    border-color var(--cp-motion-fast) ease,
    background var(--cp-motion-fast) ease,
    box-shadow var(--cp-motion-medium) ease,
    transform var(--cp-motion-fast) var(--cp-motion-ease);
}

.flow-steps article:hover {
  transform: translateY(-2px);
}

.flow-steps article:hover span {
  border-color: rgba(21, 53, 72, 0.16);
  box-shadow:
    0 0 0 5px rgba(217, 237, 207, 0.34),
    0 12px 22px rgba(21, 53, 72, 0.12);
  transform: scale(1.04);
}

.cp-checkout-shell .form-row,
.cp-account-shell .form-row,
.cp-login-panel .form-row,
.woocommerce-address-fields .form-row {
  transition:
    opacity var(--cp-motion-fast) ease,
    transform var(--cp-motion-fast) var(--cp-motion-ease);
}

.cp-checkout-shell :is(input.input-text, input[type="text"], input[type="email"], input[type="tel"], input[type="password"], input[type="number"], select, textarea),
.cp-account-shell :is(input.input-text, input[type="text"], input[type="email"], input[type="tel"], input[type="password"], input[type="number"], select, textarea),
.cp-login-panel :is(input.input-text, input[type="text"], input[type="email"], input[type="tel"], input[type="password"], input[type="number"], select, textarea),
.cp-checkout-shell .select2-container .select2-selection,
.cp-account-shell .select2-container .select2-selection {
  transition:
    border-color var(--cp-motion-fast) ease,
    background var(--cp-motion-fast) ease,
    box-shadow var(--cp-motion-medium) ease,
    transform var(--cp-motion-fast) var(--cp-motion-ease) !important;
}

.cp-checkout-shell :is(input.input-text, input[type="text"], input[type="email"], input[type="tel"], input[type="password"], input[type="number"], select, textarea):focus,
.cp-account-shell :is(input.input-text, input[type="text"], input[type="email"], input[type="tel"], input[type="password"], input[type="number"], select, textarea):focus,
.cp-login-panel :is(input.input-text, input[type="text"], input[type="email"], input[type="tel"], input[type="password"], input[type="number"], select, textarea):focus {
  border-color: rgba(21, 53, 72, 0.42) !important;
  background:
    linear-gradient(0deg, rgba(226, 244, 249, 0.28), rgba(226, 244, 249, 0.28)),
    rgba(255, 255, 255, 0.96) !important;
  box-shadow:
    0 0 0 4px rgba(21, 53, 72, 0.085),
    0 12px 24px rgba(21, 53, 72, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.78) !important;
  transform: translateY(-1px);
}

.cp-checkout-shell .form-row:focus-within label,
.cp-account-shell .form-row:focus-within label,
.cp-login-panel .form-row:focus-within label {
  color: #153548 !important;
}

.cp-cart-service-band div:hover,
.cp-contact-group:hover,
.cp-contact-group:focus-within,
.cp-legal-navigation a:hover,
.cp-legal-navigation a:focus-visible {
  transform: translateY(-1px);
}

@keyframes cp-address-select-settle {
  0% {
    transform: translateY(0) scale(0.992);
  }

  55% {
    transform: translateY(-1px) scale(1.012);
  }

  100% {
    transform: translateY(0) scale(1);
  }
}

@keyframes cp-address-selection-pulse {
  0%,
  100% {
    box-shadow:
      inset 0 0 0 1px rgba(21, 53, 72, 0.13),
      0 8px 18px rgba(21, 53, 72, 0.08);
  }

  48% {
    box-shadow:
      inset 0 0 0 1px rgba(21, 53, 72, 0.18),
      0 0 0 4px rgba(217, 237, 207, 0.34),
      0 16px 28px rgba(21, 53, 72, 0.13);
  }
}

@keyframes cp-address-manual-open {
  from {
    opacity: 0.74;
    transform: translateY(6px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  body.cp-motion-ready .cp-motion-reveal,
  body.cp-motion-ready .cp-motion-reveal.is-motion-visible,
  body.cp-motion-ready .product-card.cp-motion-reveal,
  body.cp-motion-ready .product-card.cp-motion-reveal.is-motion-visible {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .cp-checkout-address-option.is-active,
  .cp-checkout-address-option.is-selecting,
  .cp-checkout-address-ui.is-address-changing .cp-checkout-address-summary,
  .cp-checkout-address-ui.is-manual-opening {
    animation: none;
  }
}
