/**
 * Gecko public design system foundation.
 * Bootstrap target: 3.3.5. Do not edit Bootstrap core files.
 * Naming: reusable BEM-style `.ui-*` classes; use `.js-*`/`data-*` for behavior hooks.
 */

:root {
  /* Color tokens */
  --ui-color-primary: #111111;
  --ui-color-text: #3D3D3D;
  --ui-color-secondary: #888888;
  --ui-color-surface: #FFFFFF;
  --ui-color-canvas: #FAFAF8;
  --ui-color-surface-muted: #F2F1EF;
  --ui-color-surface-2: #ECEAE6;
  --ui-color-cream: #F5F0E8;
  --ui-color-border: #E0DED9;
  --ui-color-accent: #1E6FD9;
  --ui-color-accent-hover: #1557B0;
  --ui-color-info-bg: #EBF3FF;
  --ui-color-success: #346538;
  --ui-color-warning: #956400;
  --ui-color-error: #9F2F2D;
  --ui-color-info: #1F6C9F;

  /* Typography tokens */
  --ui-font-sans: "Helvetica Neue", Arial, sans-serif;
  --ui-font-mono: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
  --ui-line-height-body: 1.6;
  --ui-line-height-heading: 1.2;

  /* 8pt spacing scale */
  --ui-space-1: 8px;
  --ui-space-2: 16px;
  --ui-space-3: 24px;
  --ui-space-4: 32px;
  --ui-space-5: 40px;
  --ui-space-6: 48px;

  /* Radius tokens */
  --ui-radius-sm: 4px;
  --ui-radius-md: 6px;
  --ui-radius-lg: 8px;
  --ui-radius-card: 12px;

  /* Motion tokens */
  --ui-motion-fast: 120ms;
  --ui-motion-default: 200ms;
  --ui-motion-slow: 300ms;
  --ui-motion-ease: ease-in-out;

  /* Elevation tokens */
  --ui-elevation-sm: 0 1px 2px rgba(17, 17, 17, 0.06);
  --ui-elevation-md: 0 4px 12px rgba(17, 17, 17, 0.08);
  --ui-elevation-lg: 0 12px 32px rgba(17, 17, 17, 0.10);
  --ui-elevation-card-hover: 0 8px 24px rgba(30, 111, 217, 0.10);

  /* Layout tokens */
  --ui-container-max: 1200px;
  --ui-container-gutter: 24px;

  /* Z-index scale */
  --ui-z-base: 0;
  --ui-z-sticky: 100;
  --ui-z-header: 200;
  --ui-z-dropdown: 300;
  --ui-z-overlay: 700;
  --ui-z-modal: 800;
  --ui-z-toast: 900;
  --ui-z-debug: 1000;
}

/* Layout helpers */
.ui-page {
  min-height: 100vh;
  background: var(--ui-color-canvas);
  color: var(--ui-color-text);
  display: flex;
  flex-direction: column;
  font-family: var(--ui-font-sans);
  line-height: var(--ui-line-height-body);
}

.ui-page__header,
.ui-page__main {
  background: var(--ui-color-canvas);
}

.ui-page .container {
  box-sizing: border-box;
  max-width: var(--ui-container-max);
  padding-left: var(--ui-container-gutter);
  padding-right: var(--ui-container-gutter);
  width: 100%;
}

.ui-page__main {
  flex: 1 0 auto;
}

.ui-page__main--home {
  padding: 24px 0;
}

.ui-page__footer {
  flex-shrink: 0;
}

.ui-page__header,
.ui-page__main,
.ui-page__footer {
  position: relative;
}

.ui-page__header {
  z-index: var(--ui-z-header);
}

/* Spacing helpers: use sparingly where Bootstrap 3 has no core utility. */
.ui-stack-sm > * + * { margin-top: var(--ui-space-1); }
.ui-stack-md > * + * { margin-top: var(--ui-space-2); }
.ui-stack-lg > * + * { margin-top: var(--ui-space-3); }
.ui-section { padding-top: var(--ui-space-5); padding-bottom: var(--ui-space-5); }
.ui-section--compact { padding-top: var(--ui-space-3); padding-bottom: var(--ui-space-3); }
.ui-section__title {
  color: var(--ui-color-primary);
  display: flex;
  flex-direction: column;
  font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 800;
  gap: 12px;
  letter-spacing: -0.025em;
  line-height: var(--ui-line-height-heading);
  margin: 0 auto var(--ui-space-3);
  text-align: center;
}
.ui-section__title::after {
  align-self: center;
  background: var(--ui-color-accent);
  border-radius: 2px;
  content: "";
  display: block;
  height: 3px;
  width: 40px;
}

/* Text helpers */
.ui-text-muted { color: var(--ui-color-secondary); }
.ui-text-success { color: var(--ui-color-success); }
.ui-text-warning { color: var(--ui-color-warning); }
.ui-text-error { color: var(--ui-color-error); }
.ui-text-info { color: var(--ui-color-info); }
.ui-kbd {
  background: var(--ui-color-surface-muted);
  border: 1px solid var(--ui-color-border);
  border-radius: var(--ui-radius-sm);
  color: var(--ui-color-primary);
  font-family: var(--ui-font-mono);
  padding: 0 var(--ui-space-1);
}

/* Elevation helpers */
.ui-elevation-sm { box-shadow: var(--ui-elevation-sm); }
.ui-elevation-md { box-shadow: var(--ui-elevation-md); }
.ui-elevation-lg { box-shadow: var(--ui-elevation-lg); }

/* Z-index helpers */
.ui-z-sticky { z-index: var(--ui-z-sticky); }
.ui-z-header { z-index: var(--ui-z-header); }
.ui-z-dropdown { z-index: var(--ui-z-dropdown); }
.ui-z-overlay { z-index: var(--ui-z-overlay); }
.ui-z-modal { z-index: var(--ui-z-modal); }
.ui-z-toast { z-index: var(--ui-z-toast); }

/* Brand card surface */
.card {
  background: var(--ui-color-surface);
  border: 1px solid var(--ui-color-border);
  border-radius: var(--ui-radius-card);
  color: var(--ui-color-text);
  padding: 28px;
  transition: border-color var(--ui-motion-default) ease,
    box-shadow var(--ui-motion-default) ease,
    transform var(--ui-motion-default) ease;
}

.card:hover,
.card:focus-within {
  border-color: var(--ui-color-accent);
  box-shadow: var(--ui-elevation-card-hover);
  transform: translateY(-3px);
}

/* Component naming contracts for later phases. */
.ui-card {
  background: var(--ui-color-surface);
  border: 1px solid var(--ui-color-border);
  border-radius: var(--ui-radius-md);
  color: var(--ui-color-text);
  transition: border-color var(--ui-motion-default) var(--ui-motion-ease),
    box-shadow var(--ui-motion-default) var(--ui-motion-ease),
    transform var(--ui-motion-default) var(--ui-motion-ease);
}

.ui-card__media { display: block; }
.ui-card__body { padding: var(--ui-space-3); }
.ui-card__title {
  color: var(--ui-color-primary);
  line-height: var(--ui-line-height-heading);
  margin: 0 0 var(--ui-space-1);
}
.ui-card__text { color: var(--ui-color-secondary); }
.ui-card--interactive:hover {
  border-color: var(--ui-color-accent);
  box-shadow: var(--ui-elevation-sm);
}

.ui-empty {
  background: var(--ui-color-surface-muted);
  border: 1px solid var(--ui-color-border);
  border-radius: var(--ui-radius-md);
  padding: var(--ui-space-4);
  text-align: center;
}
.ui-empty__title { margin: 0 0 var(--ui-space-1); }
.ui-empty__text { color: var(--ui-color-secondary); margin: 0; }

.ui-skeleton {
  background: var(--ui-color-surface-2);
  border-radius: var(--ui-radius-sm);
  min-height: var(--ui-space-2);
  overflow: hidden;
}
.ui-skeleton--text { height: var(--ui-space-2); }
.ui-skeleton--media { min-height: calc(var(--ui-space-6) * 4); }
.ui-skeleton--card { min-height: calc(var(--ui-space-6) * 5); }


/* Buttons */
.ui-btn {
  align-items: center;
  border-radius: var(--ui-radius-md);
  display: inline-flex;
  font-weight: 600;
  justify-content: center;
  line-height: var(--ui-line-height-heading);
  padding: var(--ui-space-1) var(--ui-space-2);
  text-decoration: none;
  transition: background-color var(--ui-motion-default) var(--ui-motion-ease),
    border-color var(--ui-motion-default) var(--ui-motion-ease),
    color var(--ui-motion-default) var(--ui-motion-ease),
    opacity var(--ui-motion-default) var(--ui-motion-ease),
    transform var(--ui-motion-fast) var(--ui-motion-ease);
}
.ui-btn:hover,
.ui-btn:focus {
  text-decoration: none;
}
.ui-btn:active {
  transform: scale(0.98);
}
.ui-btn[disabled],
.ui-btn.disabled {
  cursor: not-allowed;
  opacity: 0.55;
  pointer-events: none;
}
.ui-btn--primary {
  background: var(--ui-color-primary);
  border: 1px solid var(--ui-color-primary);
  color: var(--ui-color-surface);
}
.ui-btn--primary:hover,
.ui-btn--primary:focus {
  background: var(--ui-color-accent-hover);
  border-color: var(--ui-color-accent-hover);
  color: var(--ui-color-surface);
}
.ui-btn--secondary {
  background: var(--ui-color-surface);
  border: 1px solid var(--ui-color-border);
  color: var(--ui-color-primary);
}
.ui-btn--secondary:hover,
.ui-btn--secondary:focus {
  border-color: var(--ui-color-accent);
  color: var(--ui-color-primary);
}
.ui-btn--ghost {
  background: transparent;
  border: 1px solid transparent;
  color: var(--ui-color-primary);
}
.ui-btn--ghost:hover,
.ui-btn--ghost:focus {
  background: var(--ui-color-cream);
  color: var(--ui-color-primary);
}

/* Forms */
.ui-form-group {
  margin-bottom: var(--ui-space-2);
}
.ui-label {
  color: var(--ui-color-primary);
  font-weight: 600;
  margin-bottom: var(--ui-space-1);
}
.ui-input,
.ui-select,
.ui-textarea {
  background: var(--ui-color-surface);
  border: 1px solid var(--ui-color-border);
  border-radius: var(--ui-radius-md);
  color: var(--ui-color-text);
  min-height: var(--ui-space-5);
  padding: var(--ui-space-1) var(--ui-space-2);
  transition: border-color var(--ui-motion-default) var(--ui-motion-ease),
    box-shadow var(--ui-motion-default) var(--ui-motion-ease);
}
.ui-input:focus,
.ui-select:focus,
.ui-textarea:focus {
  border-color: var(--ui-color-accent);
  outline: 2px solid var(--ui-color-info-bg);
  outline-offset: 0;
}
.ui-input::placeholder,
.ui-textarea::placeholder {
  color: var(--ui-color-secondary);
}
.ui-field-error {
  color: var(--ui-color-error);
  display: block;
  margin-top: var(--ui-space-1);
}
.ui-field-help {
  color: var(--ui-color-secondary);
  display: block;
  margin-top: var(--ui-space-1);
}

/* Badges and semantic labels */
.ui-badge {
  border: 1px solid transparent;
  border-radius: var(--ui-radius-sm);
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  line-height: var(--ui-line-height-heading);
  padding: 2px var(--ui-space-1);
  text-transform: uppercase;
}
.ui-badge--success { background: var(--ui-color-surface-muted); color: var(--ui-color-success); }
.ui-badge--warning { background: var(--ui-color-surface-muted); color: var(--ui-color-warning); }
.ui-badge--error { background: var(--ui-color-surface-muted); color: var(--ui-color-error); }
.ui-badge--info { background: var(--ui-color-info-bg); color: var(--ui-color-accent); }

/* Product/card adapters */
.ui-card--product {
  height: 100%;
  overflow: hidden;
}
.ui-card--product .caption {
  padding: var(--ui-space-2);
}
.ui-card--product img {
  margin-left: auto;
  margin-right: auto;
}
.ui-card--product .price {
  margin-bottom: 0;
}
.ui-card--product .price-new,
.ui-price--current {
  color: var(--ui-color-error);
}
.ui-price--old {
  color: var(--ui-color-secondary);
  margin-right: var(--ui-space-1);
}
.ui-card-grid {
  align-items: stretch;
  display: flex;
  flex-wrap: wrap;
}
.ui-card-grid > [class*="col-"] {
  display: flex;
}
.ui-card-grid .ui-card {
  width: 100%;
}


/* Tracking helpers: replace inline styles required by noscript pixels. */
.ui-tracking-frame,
.ui-tracking-pixel {
  display: none;
  visibility: hidden;
}
.ui-tracking-inline {
  display: inline;
}
.ui-tracking-borderless {
  border-style: none;
}

/* Bootstrap 3 breakpoint policy:
 * mobile < 768px; tablet 768-991px; desktop 992-1199px; large desktop >= 1200px.
 * Manual visual review widths: 375, 768, 992, 1200, 1440, 1920.
 */
@media (min-width: 1200px) {
  .ui-readable-container {
  }
}

/* Contact page redesign: premium industrial minimalism */
.gecko-contact-page {
  --gecko-contact-canvas: var(--ui-color-canvas);
  --gecko-contact-surface: var(--ui-color-surface);
  --gecko-contact-ink: var(--ui-color-primary);
  --gecko-contact-text: var(--ui-color-text);
  --gecko-contact-muted: var(--ui-color-secondary);
  --gecko-contact-border: var(--ui-color-border);
  --gecko-contact-bone: var(--ui-color-surface-muted);
  --gecko-contact-accent: var(--ui-color-accent);
  --gecko-contact-accent-hover: var(--ui-color-accent-hover);
  --gecko-contact-info-bg: var(--ui-color-info-bg);
  --gecko-contact-accent-text: var(--ui-color-accent);
  background: var(--gecko-contact-canvas);
  color: var(--gecko-contact-ink);
  font-family: "Helvetica Neue", "SF Pro Display", "Switzer", sans-serif;
  margin: 0 auto;
  overflow-x: hidden;
  padding: 72px 24px 88px;
}

.gecko-contact-page a {
  color: inherit;
}

.gecko-contact-kicker,
.gecko-contact-card > p,
.gecko-contact-map__heading > p {
  color: var(--gecko-contact-muted);
  font-family: "Geist Mono", "SF Mono", "JetBrains Mono", monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  line-height: 1;
  margin: 0 0 18px;
  text-transform: uppercase;
}

.gecko-contact-hero {
  background: var(--gecko-contact-surface);
  border: 1px solid var(--gecko-contact-border);
  padding: clamp(28px, 5vw, 56px);
}

.gecko-contact-hero__grid {
  align-items: stretch;
  display: grid;
  gap: 28px;
  grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.65fr);
}

.gecko-contact-hero__copy h1 {
  color: var(--gecko-contact-ink);
  font-family: "Newsreader", "Playfair Display", Georgia, serif;
  font-size: clamp(42px, 7vw, 84px);
  font-weight: 700;
  letter-spacing: -0.045em;
  line-height: 0.96;
  margin: 0;
  max-width: 760px;
}

.gecko-contact-hero__copy > p {
  color: var(--gecko-contact-text);
  font-size: clamp(17px, 2vw, 21px);
  line-height: 1.65;
  margin: 24px 0 0;
  max-width: 620px;
}

.gecko-contact-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 30px;
}

.gecko-contact-button {
  align-items: center;
  border-radius: 8px;
  display: inline-flex;
  font-size: 13px;
  font-weight: 700;
  gap: 8px;
  justify-content: center;
  letter-spacing: 0.04em;
  line-height: 1;
  min-height: 48px;
  padding: 13px 28px;
  text-decoration: none;
  text-transform: uppercase;
  transition: background 0.2s var(--ui-motion-ease), box-shadow 0.2s var(--ui-motion-ease), transform 0.15s var(--ui-motion-ease);
}

.gecko-contact-button--primary {
  background: var(--gecko-contact-ink);
  border: 1.5px solid var(--gecko-contact-ink);
  color: #ffffff !important;
}

.gecko-contact-button--primary:hover,
.gecko-contact-button--primary:focus {
  background: #2a2a2a;
  border-color: #2a2a2a;
  box-shadow: 0 6px 20px rgba(0,0,0,0.2);
  color: #ffffff !important;
  text-decoration: none;
  transform: translateY(-1px);
}

.gecko-contact-button--secondary {
  background: transparent;
  border: 1.5px solid var(--ui-color-border);
  color: var(--gecko-contact-text) !important;
  font-size: 14px;
  font-weight: 600;
  padding: 12px 26px;
}

.gecko-contact-button--secondary:hover,
.gecko-contact-button--secondary:focus {
  background: transparent;
  border-color: var(--gecko-contact-ink);
  color: var(--gecko-contact-ink) !important;
  text-decoration: none;
  transform: translateY(-1px);
}

.gecko-contact-button:active {
  transform: translateY(0);
}

.gecko-contact-button svg {
  color: currentColor;
  flex: 0 0 auto;
  height: 16px;
  stroke-width: 1.5;
  width: 16px;
}

.gecko-contact-button:focus-visible,
.gecko-contact-card a:focus-visible {
  outline: 2px solid var(--gecko-contact-accent);
  outline-offset: 3px;
}

.gecko-contact-proof {
  background: var(--gecko-contact-info-bg);
  border: 1px solid var(--gecko-contact-accent);
  color: var(--gecko-contact-accent-text) !important;
  display: inline-block;
  font-size: 13px !important;
  font-weight: 700;
  line-height: 1.4 !important;
  margin-top: 18px !important;
  padding: 8px 10px;
}

.gecko-contact-quote {
  background: var(--gecko-contact-ink);
  color: #ffffff;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 100%;
  padding: 28px;
}

.gecko-contact-quote h2 {
  color: #ffffff;
  font-size: clamp(24px, 3vw, 34px);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.05;
  margin: 0 0 26px;
}

.gecko-contact-quote ul {
  display: grid;
  gap: 12px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.gecko-contact-quote li {
  border-top: 1px solid rgba(255, 255, 255, 0.18);
  color: rgba(255, 255, 255, 0.82);
  font-size: 15px;
  line-height: 1.45;
  padding-top: 12px;
}

.gecko-contact-bento {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 16px;
}

.gecko-contact-card {
  background: var(--gecko-contact-surface);
  border: 1px solid var(--gecko-contact-border);
  min-width: 0;
  padding: 24px;
}

.gecko-contact-card--primary {
  background: var(--gecko-contact-info-bg);
  border-color: var(--gecko-contact-accent);
}

.gecko-contact-card h2 {
  color: var(--gecko-contact-ink);
  font-size: clamp(20px, 2vw, 26px);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.1;
  margin: 0;
  overflow-wrap: anywhere;
}

.gecko-contact-card h2 a {
  text-decoration: underline;
  text-decoration-color: var(--gecko-contact-accent);
  text-underline-offset: 5px;
}

.gecko-contact-card h2 a:hover,
.gecko-contact-card h2 a:focus {
  text-decoration-color: var(--gecko-contact-accent-hover);
}

.gecko-contact-card span {
  color: var(--gecko-contact-muted);
  display: block;
  font-size: 14px;
  line-height: 1.55;
  margin-top: 14px;
}

.gecko-contact-map {
  background: var(--gecko-contact-surface);
  border: 1px solid var(--gecko-contact-border);
  margin-top: 16px;
  overflow: hidden;
}

.gecko-contact-map__heading {
  align-items: end;
  display: flex;
  justify-content: space-between;
  gap: 18px;
  padding: 24px;
}

.gecko-contact-map__heading h2 {
  color: var(--gecko-contact-ink);
  font-size: clamp(24px, 3vw, 36px);
  font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 1.05;
  margin: 0;
}

.gecko-contact-map iframe {
  display: block;
  filter: grayscale(1) contrast(0.92) brightness(1.04);
  max-width: 100%;
}

@media (prefers-reduced-motion: no-preference) {
  .gecko-contact-card,
  .gecko-contact-map,
  .gecko-contact-hero {
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
  }

  .gecko-contact-card:hover {
    border-color: var(--gecko-contact-accent);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
  }
}

@media (max-width: 991px) {
  .gecko-contact-page {
    padding: 48px 16px 64px;
  }

  .gecko-contact-hero__grid,
  .gecko-contact-bento {
    grid-template-columns: 1fr 1fr;
  }

  .gecko-contact-hero__copy {
    grid-column: 1 / -1;
  }

  .gecko-contact-quote {
    grid-column: 1 / -1;
  }
}

@media (max-width: 640px) {
  .gecko-contact-page {
    padding: 32px 12px 48px;
  }

  .gecko-contact-hero {
    padding: 24px 18px;
  }

  .gecko-contact-hero__grid,
  .gecko-contact-bento {
    grid-template-columns: 1fr;
  }

  .gecko-contact-actions {
    flex-direction: column;
  }

  .gecko-contact-button {
    width: 100%;
  }

  .gecko-contact-card,
  .gecko-contact-quote,
  .gecko-contact-map__heading {
    padding: 20px;
  }

  .gecko-contact-map__heading {
    align-items: start;
    flex-direction: column;
  }

  .gecko-contact-map iframe {
    height: 360px;
  }
}

/* Public frontend heading baseline. */
h2 {
  color: var(--ui-color-primary);
  display: flex;
  font-family: var(--ui-font-sans);
  font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 800;
  gap: 12px;
  letter-spacing: -0.025em;
  line-height: var(--ui-line-height-heading);
  margin: 0 0 var(--ui-space-3);
  text-align: left;
}

h2::after {
  align-self: center;
  background: var(--ui-color-accent);
  border-radius: 2px;
  content: "";
  display: block;
  flex-shrink: 0;
  height: 3px;
  width: 40px;
}

#gecko-home-hero-title {
  font-weight: 900 !important;
  text-transform: uppercase;
  font-family: var(--ui-font-sans) !important;
  font-size: 2.5rem;
}

#gecko-home-hero-title::after {
  content: none;
  display: none;
}

.gecko-segment-section .gecko-section-kicker,
.gecko-product-grid-intro .section-eyebrow,
.gecko-product-grid-intro .gecko-section-kicker,
.gecko-instagram-proof .gecko-section-kicker,
body.ui-page .gecko-segment-section .gecko-section-kicker,
body.ui-page .gecko-product-grid-intro .section-eyebrow,
body.ui-page .gecko-product-grid-intro .gecko-section-kicker,
body.ui-page .gecko-instagram-proof .gecko-section-kicker{
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--color-accent, var(--gecko-accent, #1E6FD9));
  margin: 0 0 6px;
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 0;
}
.gecko-product-grid-intro > p:not(.section-eyebrow):not(.gecko-section-kicker),
.gecko-instagram-proof > p:not(.section-eyebrow):not(.gecko-section-kicker),
body.ui-page .gecko-product-grid-intro > p:not(.section-eyebrow):not(.gecko-section-kicker),
body.ui-page .gecko-instagram-proof > p:not(.section-eyebrow):not(.gecko-section-kicker){
  color: var(--gecko-muted);
  font-size: 15px;
  line-height: 1.7;
  margin: 0;
  text-align: left;
}

/* Cart empty state */
.page-cart .cart-empty-state {
  align-items: center;
  background: linear-gradient(180deg, #ffffff 0%, var(--ui-color-canvas) 100%);
  border: 1px solid var(--ui-color-border);
  border-radius: var(--ui-radius-card);
  box-shadow: var(--ui-elevation-sm);
  display: flex;
  flex-direction: column;
  margin: var(--ui-space-5) auto var(--ui-space-6);
  max-width: 640px;
  padding: var(--ui-space-6) var(--ui-space-4);
  text-align: center;
}

.page-cart .cart-empty-state__icon {
  align-items: center;
  background: var(--ui-color-primary);
  border-radius: 999px;
  color: #ffffff;
  display: flex;
  font-size: 34px;
  height: 88px;
  justify-content: center;
  margin-bottom: var(--ui-space-3);
  width: 88px;
}

.page-cart .cart-empty-state__title {
  color: var(--ui-color-primary);
  font-size: clamp(2.2rem, 4vw, 3.2rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: var(--ui-line-height-heading);
  margin: 0 0 var(--ui-space-1);
}

.page-cart .cart-empty-state__text {
  color: var(--ui-color-secondary);
  font-size: 16px;
  margin: 0 auto var(--ui-space-3);
  max-width: 440px;
}

.page-cart .cart-empty-state__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--ui-space-2);
  justify-content: center;
}

.page-cart .cart-empty-state__btn {
  min-height: 44px;
  min-width: 156px;
}

@media (max-width: 767px) {
  .page-cart .cart-empty-state {
    margin: var(--ui-space-4) auto;
    padding: var(--ui-space-5) var(--ui-space-3);
  }

  .page-cart .cart-empty-state__actions,
  .page-cart .cart-empty-state__btn {
    width: 100%;
  }
}

/* Cart page header */
.page-cart .cart-page-header {
  border-bottom: 1px solid var(--ui-color-border);
  margin: var(--ui-space-4) 0 var(--ui-space-5);
  padding-bottom: var(--ui-space-3);
}

.page-cart .cart-page-header__eyebrow {
  color: var(--ui-color-secondary);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.16em;
  line-height: 1.2;
  margin: 0 0 var(--ui-space-1);
  text-transform: uppercase;
}

.page-cart .cart-page-header h1 {
  color: var(--ui-color-primary);
  font-size: clamp(42px, 6vw, 72px);
  font-weight: 700 !important;
  letter-spacing: -0.055em !important;
  line-height: 0.98;
  margin: 0;
  max-width: 820px;
}

.page-cart .cart-page-header__text {
  color: var(--ui-color-secondary);
  font-size: 17px;
  line-height: 1.65;
  margin: var(--ui-space-2) 0 0;
  max-width: 560px;
}

@media (max-width: 767px) {
  .page-cart .cart-page-header {
    margin-top: var(--ui-space-3);
    padding-bottom: var(--ui-space-2);
  }

  .page-cart .cart-page-header h1 {
    font-size: clamp(34px, 12vw, 46px);
    letter-spacing: -0.05em !important;
  }

  .page-cart .cart-page-header__text {
    font-size: 15px;
  }
}

/* Empty cart: keep hierarchy below page H1 */
.page-cart .cart-empty-state {
  margin-top: var(--ui-space-4);
  max-width: 560px;
  padding: var(--ui-space-5) var(--ui-space-4);
}

.page-cart .cart-empty-state__icon {
  font-size: 26px;
  height: 64px;
  margin-bottom: var(--ui-space-2);
  width: 64px;
}

.page-cart .cart-empty-state__title {
  font-size: clamp(26px, 3vw, 36px);
  font-weight: 700;
  letter-spacing: -0.04em;
  max-width: none;
}

.page-cart .cart-empty-state__text {
  font-size: 15px;
  max-width: 380px;
}
