@layer resets, tokens, utilities, components, shoelace, main, overrides;

@layer shoelace {

  :root,
  :host,
  .sl-theme-light {
    color-scheme: light;

    --sl-color-gray-50: hsl(0 0% 97.5%);
    --sl-color-gray-100: hsl(240 4.8% 95.9%);
    --sl-color-gray-200: hsl(240 5.9% 90%);
    --sl-color-gray-300: hsl(240 4.9% 83.9%);
    --sl-color-gray-400: hsl(240 5% 64.9%);
    --sl-color-gray-500: hsl(240 3.8% 46.1%);
    --sl-color-gray-600: hsl(240 5.2% 33.9%);
    --sl-color-gray-700: hsl(240 5.3% 26.1%);
    --sl-color-gray-800: hsl(240 3.7% 15.9%);
    --sl-color-gray-900: hsl(240 5.9% 10%);
    --sl-color-gray-950: hsl(240 7.3% 8%);

    --sl-color-red-50: hsl(0 85.7% 97.3%);
    --sl-color-red-100: hsl(0 93.3% 94.1%);
    --sl-color-red-200: hsl(0 96.3% 89.4%);
    --sl-color-red-300: hsl(0 93.5% 81.8%);
    --sl-color-red-400: hsl(0 90.6% 70.8%);
    --sl-color-red-500: hsl(0 84.2% 60.2%);
    --sl-color-red-600: hsl(0 72.2% 50.6%);
    --sl-color-red-700: hsl(0 73.7% 41.8%);
    --sl-color-red-800: hsl(0 70% 35.3%);
    --sl-color-red-900: hsl(0 62.8% 30.6%);
    --sl-color-red-950: hsl(0 60% 19.6%);

    --sl-color-orange-50: hsl(33.3 100% 96.5%);
    --sl-color-orange-100: hsl(34.3 100% 91.8%);
    --sl-color-orange-200: hsl(32.1 97.7% 83.1%);
    --sl-color-orange-300: hsl(30.7 97.2% 72.4%);
    --sl-color-orange-400: hsl(27 96% 61%);
    --sl-color-orange-500: hsl(24.6 95% 53.1%);
    --sl-color-orange-600: hsl(20.5 90.2% 48.2%);
    --sl-color-orange-700: hsl(17.5 88.3% 40.4%);
    --sl-color-orange-800: hsl(15 79.1% 33.7%);
    --sl-color-orange-900: hsl(15.3 74.6% 27.8%);
    --sl-color-orange-950: hsl(15.2 69.1% 19%);

    --sl-color-amber-50: hsl(48 100% 96.1%);
    --sl-color-amber-100: hsl(48 96.5% 88.8%);
    --sl-color-amber-200: hsl(48 96.6% 76.7%);
    --sl-color-amber-300: hsl(45.9 96.7% 64.5%);
    --sl-color-amber-400: hsl(43.3 96.4% 56.3%);
    --sl-color-amber-500: hsl(37.7 92.1% 50.2%);
    --sl-color-amber-600: hsl(32.1 94.6% 43.7%);
    --sl-color-amber-700: hsl(26 90.5% 37.1%);
    --sl-color-amber-800: hsl(22.7 82.5% 31.4%);
    --sl-color-amber-900: hsl(21.7 77.8% 26.5%);
    --sl-color-amber-950: hsl(22.9 74.1% 16.7%);

    --sl-color-yellow-50: hsl(54.5 91.7% 95.3%);
    --sl-color-yellow-100: hsl(54.9 96.7% 88%);
    --sl-color-yellow-200: hsl(52.8 98.3% 76.9%);
    --sl-color-yellow-300: hsl(50.4 97.8% 63.5%);
    --sl-color-yellow-400: hsl(47.9 95.8% 53.1%);
    --sl-color-yellow-500: hsl(45.4 93.4% 47.5%);
    --sl-color-yellow-600: hsl(40.6 96.1% 40.4%);
    --sl-color-yellow-700: hsl(35.5 91.7% 32.9%);
    --sl-color-yellow-800: hsl(31.8 81% 28.8%);
    --sl-color-yellow-900: hsl(28.4 72.5% 25.7%);
    --sl-color-yellow-950: hsl(33.1 69% 13.9%);

    --sl-color-lime-50: hsl(78.3 92% 95.1%);
    --sl-color-lime-100: hsl(79.6 89.1% 89.2%);
    --sl-color-lime-200: hsl(80.9 88.5% 79.6%);
    --sl-color-lime-300: hsl(82 84.5% 67.1%);
    --sl-color-lime-400: hsl(82.7 78% 55.5%);
    --sl-color-lime-500: hsl(83.7 80.5% 44.3%);
    --sl-color-lime-600: hsl(84.8 85.2% 34.5%);
    --sl-color-lime-700: hsl(85.9 78.4% 27.3%);
    --sl-color-lime-800: hsl(86.3 69% 22.7%);
    --sl-color-lime-900: hsl(87.6 61.2% 20.2%);
    --sl-color-lime-950: hsl(86.5 60.6% 13.9%);

    --sl-color-green-50: hsl(138.5 76.5% 96.7%);
    --sl-color-green-100: hsl(140.6 84.2% 92.5%);
    --sl-color-green-200: hsl(141 78.9% 85.1%);
    --sl-color-green-300: hsl(141.7 76.6% 73.1%);
    --sl-color-green-400: hsl(141.9 69.2% 58%);
    --sl-color-green-500: hsl(142.1 70.6% 45.3%);
    --sl-color-green-600: hsl(142.1 76.2% 36.3%);
    --sl-color-green-700: hsl(142.4 71.8% 29.2%);
    --sl-color-green-800: hsl(142.8 64.2% 24.1%);
    --sl-color-green-900: hsl(143.8 61.2% 20.2%);
    --sl-color-green-950: hsl(144.3 60.7% 12%);

    --sl-color-emerald-50: hsl(151.8 81% 95.9%);
    --sl-color-emerald-100: hsl(149.3 80.4% 90%);
    --sl-color-emerald-200: hsl(152.4 76% 80.4%);
    --sl-color-emerald-300: hsl(156.2 71.6% 66.9%);
    --sl-color-emerald-400: hsl(158.1 64.4% 51.6%);
    --sl-color-emerald-500: hsl(160.1 84.1% 39.4%);
    --sl-color-emerald-600: hsl(161.4 93.5% 30.4%);
    --sl-color-emerald-700: hsl(162.9 93.5% 24.3%);
    --sl-color-emerald-800: hsl(163.1 88.1% 19.8%);
    --sl-color-emerald-900: hsl(164.2 85.7% 16.5%);
    --sl-color-emerald-950: hsl(164.3 87.5% 9.4%);

    --sl-color-teal-50: hsl(166.2 76.5% 96.7%);
    --sl-color-teal-100: hsl(167.2 85.5% 89.2%);
    --sl-color-teal-200: hsl(168.4 83.8% 78.2%);
    --sl-color-teal-300: hsl(170.6 76.9% 64.3%);
    --sl-color-teal-400: hsl(172.5 66% 50.4%);
    --sl-color-teal-500: hsl(173.4 80.4% 40%);
    --sl-color-teal-600: hsl(174.7 83.9% 31.6%);
    --sl-color-teal-700: hsl(175.3 77.4% 26.1%);
    --sl-color-teal-800: hsl(176.1 69.4% 21.8%);
    --sl-color-teal-900: hsl(175.9 60.8% 19%);
    --sl-color-teal-950: hsl(176.5 58.6% 11.4%);

    --sl-color-cyan-50: hsl(183.2 100% 96.3%);
    --sl-color-cyan-100: hsl(185.1 95.9% 90.4%);
    --sl-color-cyan-200: hsl(186.2 93.5% 81.8%);
    --sl-color-cyan-300: hsl(187 92.4% 69%);
    --sl-color-cyan-400: hsl(187.9 85.7% 53.3%);
    --sl-color-cyan-500: hsl(188.7 94.5% 42.7%);
    --sl-color-cyan-600: hsl(191.6 91.4% 36.5%);
    --sl-color-cyan-700: hsl(192.9 82.3% 31%);
    --sl-color-cyan-800: hsl(194.4 69.6% 27.1%);
    --sl-color-cyan-900: hsl(196.4 63.6% 23.7%);
    --sl-color-cyan-950: hsl(196.8 61% 16.1%);

    --sl-color-sky-50: hsl(204 100% 97.1%);
    --sl-color-sky-100: hsl(204 93.8% 93.7%);
    --sl-color-sky-200: hsl(200.6 94.4% 86.1%);
    --sl-color-sky-300: hsl(199.4 95.5% 73.9%);
    --sl-color-sky-400: hsl(198.4 93.2% 59.6%);
    --sl-color-sky-500: hsl(198.6 88.7% 48.4%);
    --sl-color-sky-600: hsl(200.4 98% 39.4%);
    --sl-color-sky-700: hsl(201.3 96.3% 32.2%);
    --sl-color-sky-800: hsl(201 90% 27.5%);
    --sl-color-sky-900: hsl(202 80.3% 23.9%);
    --sl-color-sky-950: hsl(202.3 73.8% 16.5%);

    --sl-color-blue-50: hsl(213.8 100% 96.9%);
    --sl-color-blue-100: hsl(214.3 94.6% 92.7%);
    --sl-color-blue-200: hsl(213.3 96.9% 87.3%);
    --sl-color-blue-300: hsl(211.7 96.4% 78.4%);
    --sl-color-blue-400: hsl(213.1 93.9% 67.8%);
    --sl-color-blue-500: hsl(217.2 91.2% 59.8%);
    --sl-color-blue-600: hsl(221.2 83.2% 53.3%);
    --sl-color-blue-700: hsl(224.3 76.3% 48%);
    --sl-color-blue-800: hsl(225.9 70.7% 40.2%);
    --sl-color-blue-900: hsl(224.4 64.3% 32.9%);
    --sl-color-blue-950: hsl(226.2 55.3% 18.4%);

    --sl-color-indigo-50: hsl(225.9 100% 96.7%);
    --sl-color-indigo-100: hsl(226.5 100% 93.9%);
    --sl-color-indigo-200: hsl(228 96.5% 88.8%);
    --sl-color-indigo-300: hsl(229.7 93.5% 81.8%);
    --sl-color-indigo-400: hsl(234.5 89.5% 73.9%);
    --sl-color-indigo-500: hsl(238.7 83.5% 66.7%);
    --sl-color-indigo-600: hsl(243.4 75.4% 58.6%);
    --sl-color-indigo-700: hsl(244.5 57.9% 50.6%);
    --sl-color-indigo-800: hsl(243.7 54.5% 41.4%);
    --sl-color-indigo-900: hsl(242.2 47.4% 34.3%);
    --sl-color-indigo-950: hsl(243.5 43.6% 22.9%);

    --sl-color-violet-50: hsl(250 100% 97.6%);
    --sl-color-violet-100: hsl(251.4 91.3% 95.5%);
    --sl-color-violet-200: hsl(250.5 95.2% 91.8%);
    --sl-color-violet-300: hsl(252.5 94.7% 85.1%);
    --sl-color-violet-400: hsl(255.1 91.7% 76.3%);
    --sl-color-violet-500: hsl(258.3 89.5% 66.3%);
    --sl-color-violet-600: hsl(262.1 83.3% 57.8%);
    --sl-color-violet-700: hsl(263.4 70% 50.4%);
    --sl-color-violet-800: hsl(263.4 69.3% 42.2%);
    --sl-color-violet-900: hsl(263.5 67.4% 34.9%);
    --sl-color-violet-950: hsl(265.1 61.5% 21.4%);

    --sl-color-purple-50: hsl(270 100% 98%);
    --sl-color-purple-100: hsl(268.7 100% 95.5%);
    --sl-color-purple-200: hsl(268.6 100% 91.8%);
    --sl-color-purple-300: hsl(269.2 97.4% 85.1%);
    --sl-color-purple-400: hsl(270 95.2% 75.3%);
    --sl-color-purple-500: hsl(270.7 91% 65.1%);
    --sl-color-purple-600: hsl(271.5 81.3% 55.9%);
    --sl-color-purple-700: hsl(272.1 71.7% 47.1%);
    --sl-color-purple-800: hsl(272.9 67.2% 39.4%);
    --sl-color-purple-900: hsl(273.6 65.6% 32%);
    --sl-color-purple-950: hsl(276 59.5% 16.5%);

    --sl-color-fuchsia-50: hsl(289.1 100% 97.8%);
    --sl-color-fuchsia-100: hsl(287 100% 95.5%);
    --sl-color-fuchsia-200: hsl(288.3 95.8% 90.6%);
    --sl-color-fuchsia-300: hsl(291.1 93.1% 82.9%);
    --sl-color-fuchsia-400: hsl(292 91.4% 72.5%);
    --sl-color-fuchsia-500: hsl(292.2 84.1% 60.6%);
    --sl-color-fuchsia-600: hsl(293.4 69.5% 48.8%);
    --sl-color-fuchsia-700: hsl(294.7 72.4% 39.8%);
    --sl-color-fuchsia-800: hsl(295.4 70.2% 32.9%);
    --sl-color-fuchsia-900: hsl(296.7 63.6% 28%);
    --sl-color-fuchsia-950: hsl(297.1 56.8% 14.5%);

    --sl-color-pink-50: hsl(327.3 73.3% 97.1%);
    --sl-color-pink-100: hsl(325.7 77.8% 94.7%);
    --sl-color-pink-200: hsl(325.9 84.6% 89.8%);
    --sl-color-pink-300: hsl(327.4 87.1% 81.8%);
    --sl-color-pink-400: hsl(328.6 85.5% 70.2%);
    --sl-color-pink-500: hsl(330.4 81.2% 60.4%);
    --sl-color-pink-600: hsl(333.3 71.4% 50.6%);
    --sl-color-pink-700: hsl(335.1 77.6% 42%);
    --sl-color-pink-800: hsl(335.8 74.4% 35.3%);
    --sl-color-pink-900: hsl(335.9 69% 30.4%);
    --sl-color-pink-950: hsl(336.2 65.4% 15.9%);

    --sl-color-rose-50: hsl(355.7 100% 97.3%);
    --sl-color-rose-100: hsl(355.6 100% 94.7%);
    --sl-color-rose-200: hsl(352.7 96.1% 90%);
    --sl-color-rose-300: hsl(352.6 95.7% 81.8%);
    --sl-color-rose-400: hsl(351.3 94.5% 71.4%);
    --sl-color-rose-500: hsl(349.7 89.2% 60.2%);
    --sl-color-rose-600: hsl(346.8 77.2% 49.8%);
    --sl-color-rose-700: hsl(345.3 82.7% 40.8%);
    --sl-color-rose-800: hsl(343.4 79.7% 34.7%);
    --sl-color-rose-900: hsl(341.5 75.5% 30.4%);
    --sl-color-rose-950: hsl(341.3 70.1% 17.1%);

    --sl-color-primary-50: var(--sl-color-sky-50);
    --sl-color-primary-100: var(--sl-color-sky-100);
    --sl-color-primary-200: var(--sl-color-sky-200);
    --sl-color-primary-300: var(--sl-color-sky-300);
    --sl-color-primary-400: var(--sl-color-sky-400);
    --sl-color-primary-500: var(--sl-color-sky-500);
    --sl-color-primary-600: var(--sl-color-sky-600);
    --sl-color-primary-700: var(--sl-color-sky-700);
    --sl-color-primary-800: var(--sl-color-sky-800);
    --sl-color-primary-900: var(--sl-color-sky-900);
    --sl-color-primary-950: var(--sl-color-sky-950);

    --sl-color-success-50: var(--sl-color-green-50);
    --sl-color-success-100: var(--sl-color-green-100);
    --sl-color-success-200: var(--sl-color-green-200);
    --sl-color-success-300: var(--sl-color-green-300);
    --sl-color-success-400: var(--sl-color-green-400);
    --sl-color-success-500: var(--sl-color-green-500);
    --sl-color-success-600: var(--sl-color-green-600);
    --sl-color-success-700: var(--sl-color-green-700);
    --sl-color-success-800: var(--sl-color-green-800);
    --sl-color-success-900: var(--sl-color-green-900);
    --sl-color-success-950: var(--sl-color-green-950);

    --sl-color-warning-50: var(--sl-color-amber-50);
    --sl-color-warning-100: var(--sl-color-amber-100);
    --sl-color-warning-200: var(--sl-color-amber-200);
    --sl-color-warning-300: var(--sl-color-amber-300);
    --sl-color-warning-400: var(--sl-color-amber-400);
    --sl-color-warning-500: var(--sl-color-amber-500);
    --sl-color-warning-600: var(--sl-color-amber-600);
    --sl-color-warning-700: var(--sl-color-amber-700);
    --sl-color-warning-800: var(--sl-color-amber-800);
    --sl-color-warning-900: var(--sl-color-amber-900);
    --sl-color-warning-950: var(--sl-color-amber-950);

    --sl-color-danger-50: var(--sl-color-red-50);
    --sl-color-danger-100: var(--sl-color-red-100);
    --sl-color-danger-200: var(--sl-color-red-200);
    --sl-color-danger-300: var(--sl-color-red-300);
    --sl-color-danger-400: var(--sl-color-red-400);
    --sl-color-danger-500: var(--sl-color-red-500);
    --sl-color-danger-600: var(--sl-color-red-600);
    --sl-color-danger-700: var(--sl-color-red-700);
    --sl-color-danger-800: var(--sl-color-red-800);
    --sl-color-danger-900: var(--sl-color-red-900);
    --sl-color-danger-950: var(--sl-color-red-950);

    --sl-color-neutral-50: var(--sl-color-gray-50);
    --sl-color-neutral-100: var(--sl-color-gray-100);
    --sl-color-neutral-200: var(--sl-color-gray-200);
    --sl-color-neutral-300: var(--sl-color-gray-300);
    --sl-color-neutral-400: var(--sl-color-gray-400);
    --sl-color-neutral-500: var(--sl-color-gray-500);
    --sl-color-neutral-600: var(--sl-color-gray-600);
    --sl-color-neutral-700: var(--sl-color-gray-700);
    --sl-color-neutral-800: var(--sl-color-gray-800);
    --sl-color-neutral-900: var(--sl-color-gray-900);
    --sl-color-neutral-950: var(--sl-color-gray-950);

    --sl-color-neutral-0: hsl(0, 0%, 100%);
    --sl-color-neutral-1000: hsl(0, 0%, 0%);

    --sl-border-radius-small: 0.1875rem;
    --sl-border-radius-medium: 0.25rem;
    --sl-border-radius-large: 0.5rem;
    --sl-border-radius-x-large: 1rem;

    --sl-border-radius-circle: 50%;
    --sl-border-radius-pill: 9999px;

    --sl-shadow-x-small: 0 1px 2px hsl(240 3.8% 46.1% / 6%);
    --sl-shadow-small: 0 1px 2px hsl(240 3.8% 46.1% / 12%);
    --sl-shadow-medium: 0 2px 4px hsl(240 3.8% 46.1% / 12%);
    --sl-shadow-large: 0 2px 8px hsl(240 3.8% 46.1% / 12%);
    --sl-shadow-x-large: 0 4px 16px hsl(240 3.8% 46.1% / 12%);

    --sl-spacing-3x-small: 0.125rem;
    --sl-spacing-2x-small: 0.25rem;
    --sl-spacing-x-small: 0.5rem;
    --sl-spacing-small: 0.75rem;
    --sl-spacing-medium: 1rem;
    --sl-spacing-large: 1.25rem;
    --sl-spacing-x-large: 1.75rem;
    --sl-spacing-2x-large: 2.25rem;
    --sl-spacing-3x-large: 3rem;
    --sl-spacing-4x-large: 4.5rem;

    --sl-transition-x-slow: 1000ms;
    --sl-transition-slow: 500ms;
    --sl-transition-medium: 250ms;
    --sl-transition-fast: 150ms;
    --sl-transition-x-fast: 50ms;

    --sl-font-mono:
      SFMono-Regular, Consolas, 'Liberation Mono', Menlo, monospace;
    --sl-font-sans:
      -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial,
      sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol';
    --sl-font-serif: Georgia, 'Times New Roman', serif;

    --sl-font-size-2x-small: 0.625rem;
    --sl-font-size-x-small: 0.75rem;
    --sl-font-size-small: 0.875rem;
    --sl-font-size-medium: 1rem;
    --sl-font-size-large: 1.25rem;
    --sl-font-size-x-large: 1.5rem;
    --sl-font-size-2x-large: 2.25rem;
    --sl-font-size-3x-large: 3rem;
    --sl-font-size-4x-large: 4.5rem;

    --sl-font-weight-light: 300;
    --sl-font-weight-normal: 400;
    --sl-font-weight-semibold: 500;
    --sl-font-weight-bold: 700;

    --sl-letter-spacing-denser: -0.03em;
    --sl-letter-spacing-dense: -0.015em;
    --sl-letter-spacing-normal: normal;
    --sl-letter-spacing-loose: 0.075em;
    --sl-letter-spacing-looser: 0.15em;

    --sl-line-height-denser: 1;
    --sl-line-height-dense: 1.4;
    --sl-line-height-normal: 1.8;
    --sl-line-height-loose: 2.2;
    --sl-line-height-looser: 2.6;

    --sl-focus-ring-color: var(--sl-color-primary-600);
    --sl-focus-ring-style: solid;
    --sl-focus-ring-width: 3px;
    --sl-focus-ring: var(--sl-focus-ring-style) var(--sl-focus-ring-width) var(--sl-focus-ring-color);
    --sl-focus-ring-offset: 1px;

    --sl-button-font-size-small: var(--sl-font-size-x-small);
    --sl-button-font-size-medium: var(--sl-font-size-small);
    --sl-button-font-size-large: var(--sl-font-size-medium);

    --sl-input-height-small: 1.875rem;
    --sl-input-height-medium: 2.5rem;
    --sl-input-height-large: 3.125rem;

    --sl-input-background-color: var(--sl-color-neutral-0);
    --sl-input-background-color-hover: var(--sl-input-background-color);
    --sl-input-background-color-focus: var(--sl-input-background-color);
    --sl-input-background-color-disabled: var(--sl-color-neutral-100);
    --sl-input-border-color: var(--sl-color-neutral-300);
    --sl-input-border-color-hover: var(--sl-color-neutral-400);
    --sl-input-border-color-focus: var(--sl-color-primary-500);
    --sl-input-border-color-disabled: var(--sl-color-neutral-300);
    --sl-input-border-width: 1px;
    --sl-input-required-content: '*';
    --sl-input-required-content-offset: -2px;
    --sl-input-required-content-color: var(--sl-input-label-color);

    --sl-input-border-radius-small: var(--sl-border-radius-medium);
    --sl-input-border-radius-medium: var(--sl-border-radius-medium);
    --sl-input-border-radius-large: var(--sl-border-radius-medium);

    --sl-input-font-family: var(--sl-font-sans);
    --sl-input-font-weight: var(--sl-font-weight-normal);
    --sl-input-font-size-small: var(--sl-font-size-small);
    --sl-input-font-size-medium: var(--sl-font-size-medium);
    --sl-input-font-size-large: var(--sl-font-size-large);
    --sl-input-letter-spacing: var(--sl-letter-spacing-normal);

    --sl-input-color: var(--sl-color-neutral-700);
    --sl-input-color-hover: var(--sl-color-neutral-700);
    --sl-input-color-focus: var(--sl-color-neutral-700);
    --sl-input-color-disabled: var(--sl-color-neutral-900);
    --sl-input-icon-color: var(--sl-color-neutral-500);
    --sl-input-icon-color-hover: var(--sl-color-neutral-600);
    --sl-input-icon-color-focus: var(--sl-color-neutral-600);
    --sl-input-placeholder-color: var(--sl-color-neutral-500);
    --sl-input-placeholder-color-disabled: var(--sl-color-neutral-600);
    --sl-input-spacing-small: var(--sl-spacing-small);
    --sl-input-spacing-medium: var(--sl-spacing-medium);
    --sl-input-spacing-large: var(--sl-spacing-large);

    --sl-input-focus-ring-color: hsl(198.6 88.7% 48.4% / 40%);
    --sl-input-focus-ring-offset: 0;

    --sl-input-filled-background-color: var(--sl-color-neutral-100);
    --sl-input-filled-background-color-hover: var(--sl-color-neutral-100);
    --sl-input-filled-background-color-focus: var(--sl-color-neutral-100);
    --sl-input-filled-background-color-disabled: var(--sl-color-neutral-100);
    --sl-input-filled-color: var(--sl-color-neutral-800);
    --sl-input-filled-color-hover: var(--sl-color-neutral-800);
    --sl-input-filled-color-focus: var(--sl-color-neutral-700);
    --sl-input-filled-color-disabled: var(--sl-color-neutral-800);

    --sl-input-label-font-size-small: var(--sl-font-size-small);
    --sl-input-label-font-size-medium: var(--sl-font-size-medium);
    --sl-input-label-font-size-large: var(--sl-font-size-large);
    --sl-input-label-color: inherit;

    --sl-input-help-text-font-size-small: var(--sl-font-size-x-small);
    --sl-input-help-text-font-size-medium: var(--sl-font-size-small);
    --sl-input-help-text-font-size-large: var(--sl-font-size-medium);
    --sl-input-help-text-color: var(--sl-color-neutral-500);

    --sl-toggle-size-small: 0.875rem;
    --sl-toggle-size-medium: 1.125rem;
    --sl-toggle-size-large: 1.375rem;

    --sl-overlay-background-color: hsl(240 3.8% 46.1% / 33%);

    --sl-panel-background-color: var(--sl-color-neutral-0);
    --sl-panel-border-color: var(--sl-color-neutral-200);
    --sl-panel-border-width: 1px;

    --sl-tooltip-border-radius: var(--sl-border-radius-medium);
    --sl-tooltip-background-color: var(--sl-color-neutral-800);
    --sl-tooltip-color: var(--sl-color-neutral-0);
    --sl-tooltip-font-family: var(--sl-font-sans);
    --sl-tooltip-font-weight: var(--sl-font-weight-normal);
    --sl-tooltip-font-size: var(--sl-font-size-small);
    --sl-tooltip-line-height: var(--sl-line-height-dense);
    --sl-tooltip-padding: var(--sl-spacing-2x-small) var(--sl-spacing-x-small);
    --sl-tooltip-arrow-size: 6px;

    --sl-z-index-drawer: 700;
    --sl-z-index-dialog: 800;
    --sl-z-index-dropdown: 900;
    --sl-z-index-toast: 950;
    --sl-z-index-tooltip: 1000;
  }

  @supports (scrollbar-gutter: stable) {
    .sl-scroll-lock {
      scrollbar-gutter: var(--sl-scroll-lock-gutter) !important;
    }

    .sl-scroll-lock body {
      overflow: hidden !important;
    }
  }

  @supports not (scrollbar-gutter: stable) {
    .sl-scroll-lock body {
      padding-right: var(--sl-scroll-lock-size) !important;
      overflow: hidden !important;
    }
  }

  .sl-toast-stack {
    position: fixed;
    top: 0;
    inset-inline-end: 0;
    z-index: var(--sl-z-index-toast);
    width: 28rem;
    max-width: 100%;
    max-height: 100%;
    overflow: auto;
  }

  .sl-toast-stack sl-alert {
    margin: var(--sl-spacing-medium);
  }

  .sl-toast-stack sl-alert::part(base) {
    box-shadow: var(--sl-shadow-large);
  }
}

@layer resets {
  * {
    box-sizing: border-box;
  }

  *[hidden] {
    display: none !important;
  }

  h1,
  h2,
  h3,
  h4,
  h5,
  h6,
  p {
    margin: 0;
    padding: 0;
    font-size: inherit;
    font-family: inherit;
  }

  a {
    text-decoration: underline;
    text-underline-offset: 2px;
    color: inherit;
  }

  ul {
    list-style: none;
    margin: 0;
  }

  button svg {
    pointer-events: none;
  }
}

@layer components {

  /* Typography */
  .gw-header {
    font-family: var(--header-font-family);
    font-size: 18px;
    font-style: normal;
    font-weight: var(--header-font-weight);
    line-height: 20px;
  }

  .gw-header--large {
    font-size: 24px;
    line-height: 30px;
  }

  .gw-body {
    font-size: 14px;
    font-style: normal;
    font-weight: var(--body-font-weight);
    line-height: 18px;
  }

  .gw-body--strong {
    font-weight: 600;
  }

  .gw-body--small {
    font-size: 12px;
  }

  .gw-small-text {
    font-size: 13px;
    font-style: normal;
    font-weight: var(--body-font-weight);
    line-height: 1.2;
  }

  .gw-uppercase-text {
    font-size: 11px;
    font-style: normal;
    font-weight: var(--body-font-weight);
    line-height: 14px;
    text-transform: uppercase;
  }

  .gw-button-text {
    font-size: 11px;
    font-style: normal;
    font-weight: var(--button-font-weight);
    line-height: 14px;
    letter-spacing: 2.2px;
    text-transform: uppercase;
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Buttons */
  .gw-button {
    font-family: var(--button-font-family);
    font-size: 11px;
    font-style: normal;
    font-weight: var(--button-font-weight);
    line-height: 14px;
    letter-spacing: 2.2px;
    text-transform: var(--text-case-button);
    border-radius: var(--corner-radius-button);

    width: 100%;
    padding: 13px;
    border: none;
    cursor: pointer;
  }

  .gw-button--solid {
    background-color: var(--color-solid-button-background);
    color: var(--color-solid-button-text);
    border: var(--thickness-button) solid var(--color-solid-button-border);
    transition:
      background-color 0.3s,
      color 0.3s,
      border-color 0.3s;
  }

  .gw-button--solid:hover {
    border-color: var(--color-solid-button-hover-border);
    background-color: var(--color-solid-button-hover-background);
    color: var(--color-solid-button-hover-text);
  }

  .gw-button--stroke {
    border: var(--thickness-button) solid var(--color-stroke-button-border);
    background-color: var(--color-stroke-button-background);
    color: var(--color-stroke-button-text);
    transition:
      background-color 0.3s,
      color 0.3s,
      border-color 0.3s;
  }

  .gw-button--stroke:hover {
    background-color: var(--color-stroke-button-hover-background);
    color: var(--color-stroke-button-hover-text);
    border-color: var(--color-stroke-button-hover-border);
  }

  .gw-button--disabled {
    cursor: not-allowed;
    background-color: var(--color-disabled-button-background);
    color: var(--color-disabled-button-text);
  }

  .gw-button--text {
    padding: 5px;
    color: var(--color-text-subdued);
    background-color: transparent;
    text-decoration-line: underline;
  }

  .gw-button svg {
    pointer-events: none;
  }
}

@layer utilities {
  .gw-unstyled-link {
    text-decoration: none;
    color: inherit;
  }

  .gw-button[href] {
    display: block;
    text-align: center;
    text-decoration: none;
  }

  .gw-empty-button {
    background: transparent;
    border: none;
    cursor: pointer;
    font: inherit;
  }

  .gw-main-content-container {
    display: flex;
    flex-direction: column;
    gap: var(--tab-panel-vertical-gap);
    padding-bottom: var(--tab-panel-vertical-gap);
  }

  .gw-main-content-container--small-gap {
    --tab-panel-vertical-gap: 16px;
  }

  .gw-empty-list {
    padding: 0 var(--tab-panel-edge-padding);
    text-align: center;
  }

  .gw-empty-list-inner {
    padding: 30px;
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
  }

  .gw-error-message {
    font-size: 13px;
    color: #a50000;
    margin-top: 8px;
  }

  .gw-error-message ul {
    padding: 0 0 0 var(--tab-panel-edge-padding);
  }

  .gw-error-message ul li {
    list-style-type: disc;
    padding-block: 2px;
  }

  .gw-info-message {
    font-size: 13px;
    color: var(--color-text);
  }

  .gw-loader-container {
    --loader-size: 14px;
    --loader-border-weight: 1px;
    position: relative;
  }

  .gw-loader-container--block {
    display: block;
    width: var(--loader-size);
    height: var(--loader-size);
    margin: 24px auto;
  }

  .gw-loader-container--large {
    --loader-size: 24px;
    --loader-border-weight: 3px;
  }

  .gw-loader {
    width: var(--loader-size);
    height: var(--loader-size);
    position: absolute;
    left: 8px;
    border: var(--loader-border-weight) solid transparent;
    border-bottom-color: inherit;
    border-radius: 50%;
    display: inline-block;
    box-sizing: border-box;
    animation: rotation 1s linear infinite;
  }

  .gw-loader-container--block .gw-loader {
    left: 0;
  }

  .gw-loader--white {
    border: 2px solid var(--border-color);
    border-bottom-color: var(--color-text);
  }

  .visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
  }

  @keyframes rotation {
    0% {
      transform: rotate(0deg);
    }

    100% {
      transform: rotate(360deg);
    }
  }
}

@layer main {
  :host {
    --sl-input-font-size-medium: 14px;
    --sl-font-size-medium: 14px;
    --tab-panel-edge-padding: 20px;
    --tab-panel-vertical-gap: 24px;

    all: initial;
    position: relative;
    z-index: 2147483647;

    font-family: var(--body-font-family);
    font-size: 14px;
    font-style: normal;
    font-weight: var(--body-font-weight);
    line-height: 18px;
    color: var(--color-text);
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Drawers */

  sl-drawer {
    --size: var(--drawer-width);
    --body-spacing: 0;
    --header-spacing: 20px;
  }

  sl-drawer::part(close-button) {
    display: none;
  }

  sl-drawer[main-drawer]::part(body) {
    display: flex;
    flex-direction: column;
    background-color: var(--color-drawer-background);
  }

  sl-drawer[main-drawer]::part(header) {
    background-color: var(--color-drawer-header-background);
  }

  /* When inner drawer opens, main drawer header is blocking the inner drawer header on iPhones
    to fix this, I am hiding the main drawer header when inner drawer is open */
  sl-drawer[main-drawer].inner-drawer-open::part(header) {
    display: none;
  }

  sl-drawer[main-drawer].inner-drawer-open sl-tab-group::part(nav) {
    display: none;
  }

  sl-drawer[main-drawer].inner-drawer-open gw-customer-accounts-sign-in {
    display: none;
  }

  sl-drawer[main-drawer] sl-tab {
    background-color: var(--color-drawer-footer-background);
  }

  .gw-customer-accounts-drawer__header {
    display: flex;
    align-items: center;
    gap: 8px;
  }

  .gw-secondary-drawer__header {
    display: flex;
    align-items: center;
    gap: 8px;

    background-color: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    color: var(--color-text);
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Product Card */
  .gw-product-card {
    width: 100%;
    position: relative;
  }

  .gw-product-card--splitted {
    display: flex;
    flex-direction: row-reverse;
    align-items: center;
    gap: 16px;
  }

  .gw-product-card--splitted .gw-product-card__image-container {
    flex-shrink: 0;
  }

  .gw-product-card--reversed {
    display: flex;
    flex-direction: column-reverse;
  }

  .gw-product-card--removing::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.5);
    z-index: 1;
  }

  .gw-product-card--splitted .gw-product-card__image-container {
    width: 120px;
  }

  .gw-product-card__image-container::after {
    content: '';
    width: 100%;
    display: block;
    padding-bottom: var(--product-card-image-ratio);
  }

  .gw-product-card__info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 8px;
  }

  .gw-product-card__info--no-gap {
    gap: 0;
  }

  .gw-product-card__link {
    width: 100%;
    display: block;
  }

  .gw-product-card__link:focus {
    outline: 2px solid rgb(0, 95, 204);
  }

  .gw-product-card__link::after {
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
  }

  .gw-product-card__link--hide-after::after {
    content: none;
  }

  .gw-product-card__image-container {
    width: 100%;
    position: relative;
    border: 1px solid var(--border-color);
  }

  .gw-product-card__image {
    width: 100%;
    height: 100%;
    object-fit: contain;

    position: absolute;
    top: 0;
    left: 0;
  }

  .gw-product-card__info {
    margin-top: 8px;
  }

  .gw-product-card__form {
    display: flex;
    flex-direction: column;
    gap: 10px;
  }

  .gw-product-card__actions {
    display: flex;
  }

  .gw-product-card__variant-selector {
    width: 100%;
    padding: 4px 8px;
    border: 1px solid var(--border-color);
    border-radius: 0;
    color: var(--color-text);
  }

  .gw-product-card__price {
    font-size: 13px;
    font-style: normal;
    font-weight: var(--body-font-weight);
    line-height: 1.2;

    display: flex;
    gap: 4px;
  }

  .gw-product-card__price-compare {
    text-decoration: line-through;
  }

  .gw-product-card__price--sale {
    color: #c70100;
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Alert */
  .gw-notifications {
    position: fixed;
    bottom: 54px;
    left: 20px;
    z-index: 900;
  }

  .gw-notifications sl-alert::part(base) {
    width: 100%;
    min-width: 300px;
    border: none;
    background-color: var(--color-notifications-background);
    border-radius: var(--border-radius);
  }

  .gw-notifications * {
    font-family: var(--body-font-family);
    font-size: 16px;
    color: var(--color-notifications-label);
  }

  .gw-notifications [data-notification-message] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Orders */
  .gw-customer-accounts-orders__empty {
    text-align: center;
    padding: 40px var(--tab-panel-edge-padding) 0;
  }

  .gw-customer-accounts-order__carousel::part(base) {
    display: block;
  }

  .gw-customer-accounts-order__header {
    padding: 0 var(--tab-panel-edge-padding);
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Order Detail*/
  .gw-order-detail {
    padding-bottom: var(--tab-panel-vertical-gap);
  }

  .gw-order-detail__line-items,
  .gw-order-detail__payment,
  .gw-order-detail__delivery,
  .gw-order-detail__integrations {
    display: flex;
    flex-direction: column;
    gap: var(--tab-panel-vertical-gap);
    padding: 0 var(--tab-panel-edge-padding);
  }

  .gw-order-detail__integrations {
    gap: 8px;
  }

  .gw-order-detail__line-item {
    display: flex;
    gap: 16px;
    align-items: center;
  }

  .gw-order-detail__line-item:first-child {
    margin-top: 16px;
  }

  .gw-order-detail__status {
    padding: 12px var(--tab-panel-edge-padding);
    background-color: #a13818;
    color: #ffffff;

    display: flex;
    align-items: center;
    gap: 8px;
  }

  .gw-order-detail__line-item-image-container {
    width: 120px;
    flex-shrink: 0;
    position: relative;
    border: 1px solid var(--border-color);
  }

  .gw-order-detail__line-item-image-container::after {
    content: '';
    width: 100%;
    display: block;
    padding-bottom: var(--product-card-image-ratio);
  }

  .gw-order-detail__line-item-image {
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: var(--border-radius);

    position: absolute;
    top: 0;
    left: 0;
  }

  .gw-order-detail__line-item-quantity {
    position: absolute;
    transform: translate(50%, -50%);
    top: 0;
    right: 0;

    background-color: var(--color-text);
    padding: 2px 7px;
    border-radius: 50%;

    font-size: 10px;
    font-weight: 600;
    line-height: 14px;
    color: #ffffff;
  }

  .gw-order-detail__line-item-price {
    margin-left: auto;
  }

  .gw-order-detail__price-breakdown {
    display: flex;
    flex-direction: column;
    padding: var(--tab-panel-vertical-gap) var(--tab-panel-edge-padding) 0;
    border-top: 1px solid var(--border-color);
    border-bottom: 1px solid var(--border-color);
  }

  .gw-order-detail__price-breakdown-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  .gw-order-detail__price-breakdown-item+.gw-order-detail__price-breakdown-item {
    margin-top: 14px;
  }

  .gw-order-detail__price-breakdown-item--total {
    padding: var(--tab-panel-vertical-gap) 0;
    margin-top: var(--tab-panel-vertical-gap) !important;
    border-top: 1px solid var(--border-color);
  }

  .gw-order-detail__discount-title {
    text-transform: uppercase;
  }

  .gw-order-detail__payment-info p:first-child,
  .gw-order-detail__delivery-info p:first-child {
    margin-bottom: 10px;
  }

  .gw-order-detail__additional-info {
    padding: 0 var(--tab-panel-edge-padding);
  }

  .gw-order-detail__additional-info p:not(:last-child) {
    margin-bottom: 8px;
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Icons */
  .gw-icon--close {
    width: 18px;
    height: 18px;

    display: flex;
    justify-content: center;
    align-items: center;
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Form */
  sl-input,
  sl-select {
    position: relative;
    font-family: var(--form-font-family);
    color: var(--color-text);
    font-weight: var(--form-font-weight);
    text-transform: var(--form-elements-text-case);
  }

  sl-select.input--empty::part(form-control-label),
  sl-input.input--empty::part(form-control-label) {
    font-size: 14px;
    padding-top: 17px;
  }

  sl-input.input--focus::part(form-control-label),
  sl-input::part(form-control-label),
  sl-select::part(form-control-label) {
    position: absolute;
    z-index: 1;
    padding-top: 6px;
    padding-left: 12px;
    font-size: 10px;
    transition: 0.3s ease all;
  }

  sl-input::part(base) {
    height: 50px;
    position: relative;
    border-radius: var(--form-elements-corner-radius);
    border: var(--form-elements-thickness) solid var(--border-color);
  }

  sl-input::part(input) {
    height: 50px;
    padding-top: 12px;
    padding-left: 12px;
  }

  sl-input[data-user-invalid]::part(base) {
    --border-color: #a50000;
  }

  sl-select::part(combobox) {
    height: 50px;
    border-radius: var(--form-elements-corner-radius);
    border: var(--form-elements-thickness) solid var(--border-color);
  }

  sl-select::part(display-input) {
    top: 8px;
  }

  sl-checkbox::part(base) {
    align-items: center;
  }

  sl-checkbox::part(control) {
    --toggle-size: 16px;
    --sl-focus-ring: solid 2px #000000;
    border-color: #181818;
    border-radius: 0;
  }

  sl-checkbox[checked]::part(control) {
    background-color: #000000;
    color: #ffffff;
  }

  sl-option[value='---'] {
    display: none;
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Recently Viewed Collections */
  .gw-recently-viewed-collections sl-carousel::part(scroll-container) {
    grid-auto-columns: auto;
    justify-content: flex-start;
  }

  .gw-recently-viewed-collection {
    padding: 8px 18px;
    border: 1px solid #000000;
    white-space: nowrap;
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Saved from Cart & Favorites & Recently Viewed Items */
  .gw-saved-from-cart-tab {
    display: flex;
    flex-direction: column;
    gap: var(--tab-panel-vertical-gap);
    padding: 0 var(--tab-panel-edge-padding) var(--tab-panel-vertical-gap);
  }

  .gw-favorites-tab {
    --space-to-account-for-menu-bar: 40px;

    display: flex;
    flex-direction: column;
    gap: var(--tab-panel-vertical-gap);
    padding: 0 var(--tab-panel-edge-padding) calc(var(--tab-panel-vertical-gap) + var(--space-to-account-for-menu-bar, 0px));
  }

  .gw-recently-viewed-items-tab {
    display: grid;
    grid-template-columns: 1fr 1fr;
    padding: 0 var(--tab-panel-edge-padding) var(--tab-panel-vertical-gap);
    gap: 24px 16px;
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Quick Links */
  .gw-quick-links {
    display: flex;
    flex-direction: column;
    padding: 0 var(--tab-panel-edge-padding);
    margin: 0;
    list-style: none;
    gap: 12px;
  }

  .gw-quick-link {
    display: flex;
    align-items: center;
    gap: 8px;
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Card */
  .gw-card__item {
    display: flex;
    flex-direction: column;
    padding: 0 var(--tab-panel-edge-padding);
    gap: 8px;
    position: relative;
  }

  .gw-card__item a {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10;
  }

  .gw-card__item-image-wrapper {
    width: 100%;
    overflow: hidden;
  }

  .gw-card__item-image {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    transition: transform 0.5s ease;
  }

  .gw-card__item:hover .gw-card__item-image {
    transform: scale(1.05);
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Sign In */
  .gw-sign-in {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 0 var(--tab-panel-edge-padding);
    margin-bottom: 24px;
  }

  .gw-sign-in__form button[type='submit'] {
    margin-top: 16px;
  }

  .gw-sign-in__form sl-input+sl-input {
    margin-top: 8px;
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Verify Code */
  .gw-verify-code {
    text-align: center;
    margin-bottom: 24px;
  }

  .gw-verify-code .input-code-group {
    display: flex;
    justify-content: center;
    margin: 35px 0 16px;
    gap: 8px;
  }

  .gw-verify-code .code-input {
    width: 56px;
    height: 68px;
    border: 1px solid var(--border-color);
    background: white;
    text-align: center;
    font-size: 22px;
    font-weight: 600;
    font-family: var(--form-font-family);

    appearance: textfield;
    -moz-appearance: textfield;
  }

  .gw-verify-code .code-input::-webkit-inner-spin-button,
  .gw-verify-code .code-input::-webkit-outer-spin-button {
    -webkit-appearance: none;
  }

  .gw-verify-code__actions .gw-error-message {
    margin: 16px 0;
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* My Preferences */
  .my-preferences {
    padding: 0 var(--tab-panel-edge-padding);
  }

  .my-preferences__header {
    display: flex;
    align-items: center;
    margin-bottom: 22px;
    gap: 8px;
    cursor: pointer;
  }

  .my-preferences__field {
    display: flex;
    flex-direction: column;
    padding: 16px 20px;
    border: 1px solid var(--border-color);
  }

  .my-preferences__field+.my-preferences__field {
    border-top: 0;
  }

  .my-preferences__fields+.my-preferences__fields {
    margin-top: 22px;
  }

  .my-preferences__fields {
    cursor: pointer;
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* My Preference Details */
  .gw-preference-details__notification {
    display: flex;
    flex-direction: column;
    gap: var(--tab-panel-vertical-gap);
    padding: 0 var(--tab-panel-edge-padding) var(--tab-panel-vertical-gap);
    border-bottom: 1px solid var(--border-color);
  }

  .gw-preference-details__email {
    display: flex;
    flex-direction: column;
    gap: 16px;
  }

  .gw-preference-details__email sl-input::part(form-control-help-text) {
    margin-top: 8px;
  }

  .gw-preference-details__email sl-checkbox::part(base) {
    align-items: center;
  }

  .gw-preference-details__email sl-checkbox::part(control) {
    --sl-focus-ring: solid 2px #000000;
    border-color: #181818;
    border-radius: 0;
  }

  .gw-preference-details__email sl-checkbox[checked]::part(control) {
    background-color: #000000;
    color: #ffffff;
  }

  .gw-preference-details__phone {
    display: flex;
    flex-direction: column;
    gap: 16px;
  }

  .gw-preference-details__phone sl-checkbox::part(form-control-help-text) {
    margin-top: 8px;
  }

  .gw-preference-details__personal-info {
    display: flex;
    flex-direction: column;
    gap: var(--tab-panel-vertical-gap);
    padding: var(--tab-panel-vertical-gap) var(--tab-panel-edge-padding);
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* My Addresses */
  .gw-address {
    border-bottom: 1px solid var(--border-color);
    padding: var(--tab-panel-vertical-gap) var(--tab-panel-edge-padding);
    cursor: pointer;
  }

  .gw-address p:first-child {
    margin-bottom: 8px;
  }

  .gw-address-edit,
  .gw-address-add {
    padding: var(--tab-panel-vertical-gap) var(--tab-panel-edge-padding);
  }

  .gw-address__icon {
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
  }

  .gw-button-wrapper {
    padding: 0 var(--tab-panel-edge-padding);
  }

  .my-addresses {
    cursor: pointer;
  }

  .my-addresses sl-carousel::part(scroll-container) {
    grid-auto-columns: auto;
  }

  .my-addresses__header {
    display: flex;
    align-items: center;
    margin-bottom: 22px;
    padding: 0 var(--tab-panel-edge-padding);
    gap: 8px;
    cursor: pointer;
  }

  .my-addresses__list--single {
    padding: 0 var(--tab-panel-edge-padding);
  }

  .my-addresses__address {
    min-width: 270px;
    min-height: 160px;
    padding: 16px 20px;
    border: 1px solid var(--border-color);
  }

  .my-addresses__address p:first-child {
    margin-bottom: 8px;
  }

  .my-addresses__default-badge {
    padding: 2px 8px;
    background-color: var(--border-color);
    white-space: nowrap;
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Latest Order */
  .gw-latest-order-wrapper {
    padding: 0 20px;
  }

  .gw-latest-order {
    display: flex;
    gap: 16px;
    padding: 16px;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.1);
    box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.1);
    cursor: pointer;
  }

  .gw-latest-order__image-container {
    width: 56px;
    flex-shrink: 0;
    position: relative;
  }

  .gw-latest-order__image-container::after {
    content: '';
    width: 100%;
    display: block;
    padding-bottom: var(--product-card-image-ratio);
  }

  .gw-latest-order__image {
    width: 100%;
    height: 100%;
    object-fit: cover;

    position: absolute;
    top: 0;
    left: 0;
  }

  .gw-latest-order__info {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 4px;
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Tabs */

  sl-tab-group {
    --indicator-color: var(--color-text);
    --track-color: var(--border-color);
    --track-width: 2px;

    padding-bottom: 50px;
  }

  sl-tab-group::part(base),
  sl-tab-group::part(body) {
    height: 100%;
  }

  sl-tab-group::part(nav) {
    padding: 0;
    width: 100%;
    position: absolute;
    bottom: 0;
    z-index: 10;
  }

  sl-tab-group sl-tab-panel {
    height: 100%;
  }

  sl-tab-group sl-tab-panel::part(base) {
    height: 100%;
    padding: 0;
  }

  sl-tab-group sl-tab {
    width: calc(100% / 3);
    padding: 16px 0;
    text-align: center;
    cursor: pointer;
  }

  sl-tab-group sl-tab::part(base) {
    all: unset;
  }

  /* --- Collections */
  .gw-collections {
    display: flex;
    gap: 8px;
  }

  .gw-collections sl-skeleton {
    --border-radius: 0;

    width: 90px;
    height: 30px;
    flex-shrink: 0;
  }

  .gw-collections sl-skeleton:nth-child(odd) {
    width: 120px;
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* --- Card Carousel */
  .gw-products-carousel {
    display: flex;
    flex-direction: column;
    gap: 24px;
  }

  .gw-products-carousel__header-wrapper {
    padding: 0 20px;
  }

  .gw-products-carousel__header {
    display: flex;
    gap: 8px;
    align-items: center;
    cursor: pointer;
  }

  .gw-products-carousel__feed {
    padding: 0 0 0 20px;
    display: flex;
    gap: 8px;
  }

  .gw-products-carousel sl-skeleton {
    --border-radius: 0;

    width: 115px;
    flex-shrink: 0;
  }

  .gw-products-carousel sl-skeleton::after {
    content: '';
    width: 100%;
    display: block;
    padding-bottom: var(--product-card-image-ratio);
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Carousels */
  sl-carousel::part(base) {
    gap: 0;
  }

  sl-carousel::part(navigation-button) {
    width: 32px;
    height: 42px;

    display: flex;
    justify-content: center;
    align-items: center;

    position: absolute;
    opacity: 0;
    z-index: 10;
    transition: 0.3s ease all;
    background-color: #ffffff;
  }

  sl-carousel::part(navigation-button):hover {
    scale: 1.1;
  }

  sl-carousel::part(navigation-button--previous) {
    left: 0;
    border: 1px solid var(--border-color);
    border-radius: 0 8px 8px 0;
    border-left: none;
  }

  sl-carousel::part(navigation-button--next) {
    right: 0;
    border-right: none;
    border: 1px solid var(--border-color);
    border-radius: 8px 0 0 8px;
  }

  sl-carousel:focus::part(navigation-button),
  sl-carousel:focus-within::part(navigation-button),
  sl-carousel:hover::part(navigation-button) {
    opacity: 1;
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Wishlist */
  gw-wishlist-button {
    position: absolute;
    bottom: 0;
    right: 4px;
    z-index: 10;
  }

  gw-wishlist-button[processing]::part(button) {
    pointer-events: none;
    opacity: 0.5;
  }

  gw-wishlist-button:active::part(button) {
    transform: scale(0.9);
  }

  gw-wishlist-button::part(button) {
    width: 14px;
    height: 14px;
    padding: 0;

    background-color: transparent;
    border: none;
    cursor: pointer;
    color: var(--color-text);
    transition: 200ms cubic-bezier(0.39, 0.575, 0.565, 1);
  }

  gw-wishlist-button::part(icon),
  gw-wishlist-button::part(filled-icon) {
    position: absolute;
    top: 0;
    left: 0;
    transition: opacity 0.3s;
    display: block;
  }

  gw-wishlist-button:hover::part(icon),
  gw-wishlist-button::part(filled-icon) {
    opacity: 0;
  }

  gw-wishlist-button[saved]::part(filled-icon),
  gw-wishlist-button:hover::part(filled-icon) {
    opacity: 1;
  }

  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* - */
  /* Integration */
  gw-integrations-loyalty-points {
    padding: 0 var(--tab-panel-edge-padding);
  }

  .gw-loyalty-points__link {
    min-height: 54px;
    display: flex;
    align-items: center;
    gap: 8px;

    border-radius: var(--border-radius);
    padding: 16px;
    background-color: var(--background-color);
    color: var(--text-color);
  }

  .gw-loyalty-points__link:hover .gw-loyalty-points__link-label {
    transform: translateX(0);
  }

  .gw-loyalty-points__link-label {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-left: auto;
    transform: translateX(-5px);
    transition: transform 0.3s ease-in-out;
  }

  .gw-loyalty-points__id-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    gap: 8px;
  }

  .gw-loyalty-points__copy-button {
    background-color: transparent;
    border: none;
    cursor: pointer;
    font-family: var(--body-font-family);
    color: var(--color-text);

    display: flex;
    align-items: center;
    gap: 4px;
  }

  .gw-loyalty-points__copy-button svg {
    width: 12px;
    height: 12px;
  }

  /* Credit Drawer */
  .gw-credit-drawer__content {
    display: flex;
    flex-direction: column;
    padding-top: var(--tab-panel-vertical-gap);
  }

  .gw-credit-drawer__section {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 2px 0;
  }

  .gw-credit-drawer__section:last-child {
    border: none;
    padding-bottom: 0;
  }

  .gw-credit-drawer__label {
    color: var(--color-text);
    font-style: italic;
    margin: 0;
  }

  .gw-credit-drawer__code {
    font-weight: 700;
    font-style: italic;
    margin-bottom: 12px;
  }

  .gw-credit-drawer__value {
    margin: 0;
  }

  .gw-credit-drawer__copy-button:hover {
    opacity: 0.7;
  }

  .gw-credit-drawer__copy-button svg {
    display: block;
  }

  .gw-credit-card {
    padding: 24px var(--tab-panel-edge-padding);
  }

  .gw-credit-card:first-child {
    padding-top: 0;
  }

  /* Drawer Button Styling */
  gw-integrations-loyalty-points button[data-open-drawer] {
    background: transparent;
    border: none;
    padding: 0;
    cursor: pointer;
    width: 100%;
    text-align: left;
    font-family: inherit;
  }

  gw-integrations-loyalty-points button[data-open-drawer]:hover {
    opacity: 0.9;
  }
}