/* Loom Theme — base.css
   Light minimalist design system. Typography comes from theme settings.
   Colors via CSS vars defined in layout/theme.liquid <style> block.
*/

/* ── Color Schemes ──────────────────────────────────────────────────── */
/* Applied via class="color-scheme--{name}" on section wrappers,        */
/* header, and footer. Overrides the semantic CSS vars for that scope.   */

.color-scheme--background-1 {
    --bg: var(--color-bg-1);
    --gradient-background: var(--gradient-bg-1, var(--color-bg-1));
    --text: var(--color-text);
    --foreground: var(--color-text);
    --text-secondary: color-mix(in srgb, var(--color-text) 55%, transparent);
    --text-muted: color-mix(in srgb, var(--color-text) 40%, transparent);
    --text-subtle: color-mix(in srgb, var(--color-text) 28%, transparent);
    --scheme-bg: var(--color-bg-1);
    --scheme-text: var(--color-text);
    --scheme-btn-bg: var(--color-accent-1);
    --scheme-btn-label: var(--color-btn-label);
    --scheme-btn-outline: var(--color-outline-btn);
    --border: color-mix(in srgb, var(--color-text) 8%, transparent);
    --border-dark: color-mix(in srgb, var(--color-text) 15%, transparent);
    --primary: var(--color-accent-1);
    background: var(--gradient-background, var(--bg));
    color: var(--text);
}

.color-scheme--background-2 {
    --bg: var(--color-bg-2);
    --gradient-background: var(--gradient-bg-2, var(--color-bg-2));
    --text: var(--color-text);
    --foreground: var(--color-text);
    --text-secondary: color-mix(in srgb, var(--color-text) 55%, transparent);
    --text-muted: color-mix(in srgb, var(--color-text) 40%, transparent);
    --text-subtle: color-mix(in srgb, var(--color-text) 28%, transparent);
    --scheme-bg: var(--color-bg-2);
    --scheme-text: var(--color-text);
    --scheme-btn-bg: var(--color-accent-1);
    --scheme-btn-label: var(--color-btn-label);
    --scheme-btn-outline: var(--color-outline-btn);
    --border: color-mix(in srgb, var(--color-text) 8%, transparent);
    --border-dark: color-mix(in srgb, var(--color-text) 15%, transparent);
    --primary: var(--color-accent-1);
    background: var(--gradient-background, var(--bg));
    color: var(--text);
}

.color-scheme--accent-1 {
    --bg: var(--color-accent-1);
    --gradient-background: var(--gradient-accent-1, var(--color-accent-1));
    --text: var(--color-btn-label);
    --foreground: var(--color-btn-label);
    --text-secondary: color-mix(in srgb, var(--color-btn-label) 70%, transparent);
    --text-muted: color-mix(in srgb, var(--color-btn-label) 50%, transparent);
    --text-subtle: color-mix(in srgb, var(--color-btn-label) 38%, transparent);
    --scheme-bg: var(--color-accent-1);
    --scheme-text: var(--color-btn-label);
    --scheme-btn-bg: var(--color-btn-label);
    --scheme-btn-label: var(--color-accent-1);
    --scheme-btn-outline: var(--color-btn-label);
    --border: color-mix(in srgb, var(--color-btn-label) 20%, transparent);
    --border-dark: color-mix(in srgb, var(--color-btn-label) 35%, transparent);
    --primary: var(--color-btn-label);
    background: var(--gradient-background, var(--bg));
    color: var(--text);
}

.color-scheme--accent-2 {
    --bg: var(--color-accent-2);
    --gradient-background: var(--gradient-accent-2, var(--color-accent-2));
    --text: var(--color-btn-label);
    --foreground: var(--color-btn-label);
    --text-secondary: color-mix(in srgb, var(--color-btn-label) 70%, transparent);
    --text-muted: color-mix(in srgb, var(--color-btn-label) 50%, transparent);
    --text-subtle: color-mix(in srgb, var(--color-btn-label) 38%, transparent);
    --scheme-bg: var(--color-accent-2);
    --scheme-text: var(--color-btn-label);
    --scheme-btn-bg: var(--color-btn-label);
    --scheme-btn-label: var(--color-accent-2);
    --scheme-btn-outline: var(--color-btn-label);
    --border: color-mix(in srgb, var(--color-btn-label) 20%, transparent);
    --border-dark: color-mix(in srgb, var(--color-btn-label) 35%, transparent);
    --primary: var(--color-btn-label);
    background: var(--gradient-background, var(--bg));
    color: var(--text);
}

.color-scheme--inverse {
    --bg: var(--color-text);
    --gradient-background: var(--color-text);
    --text: var(--color-bg-1);
    --foreground: var(--color-bg-1);
    --text-secondary: color-mix(in srgb, var(--color-bg-1) 70%, transparent);
    --text-muted: color-mix(in srgb, var(--color-bg-1) 50%, transparent);
    --text-subtle: color-mix(in srgb, var(--color-bg-1) 38%, transparent);
    --scheme-bg: var(--color-text);
    --scheme-text: var(--color-bg-1);
    --scheme-btn-bg: var(--color-bg-1);
    --scheme-btn-label: var(--color-text);
    --scheme-btn-outline: var(--color-bg-1);
    --border: color-mix(in srgb, var(--color-bg-1) 20%, transparent);
    --border-dark: color-mix(in srgb, var(--color-bg-1) 35%, transparent);
    --primary: var(--color-bg-1);
    background: var(--gradient-background, var(--bg));
    color: var(--text);
}

*,
*::before,
*::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    font-size: var(--font-body-size, 16px);
}

body {
    font-family: var(--font-body, 'Inter'), 'Helvetica Neue', Helvetica, system-ui, sans-serif;
    background-color: var(--bg, #ffffff);
    color: var(--text, #0a0a0a);
    font-size: 1rem;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: var(--font-heading, 'Inter'), 'Helvetica Neue', Helvetica, system-ui, sans-serif;
    line-height: 1.2;
    letter-spacing: var(--font-heading-letter-spacing, 0);
    color: var(--text, #0a0a0a);
}

h1 {
    font-size: calc(2.5rem * var(--font-heading-scale, 1));
    line-height: 1.1;
}

h2 {
    font-size: calc(2rem * var(--font-heading-scale, 1));
    line-height: 1.15;
}

h3 {
    font-size: calc(1.5rem * var(--font-heading-scale, 1));
    line-height: 1.2;
}

h4 {
    font-size: calc(1.25rem * var(--font-heading-scale, 1));
    line-height: 1.25;
}

h5 {
    font-size: calc(1rem * var(--font-heading-scale, 1));
    line-height: 1.3;
}

h6 {
    font-size: calc(0.875rem * var(--font-heading-scale, 1));
    line-height: 1.35;
}

.rte {
    font-size: 1rem;
}

.rte h1 {
    font-size: calc(1.75rem * var(--font-heading-scale, 1));
}

.rte h2 {
    font-size: calc(1.375rem * var(--font-heading-scale, 1));
}

.rte h3 {
    font-size: calc(1.125rem * var(--font-heading-scale, 1));
}

/* Theme typography bridge for older sections that still use fixed utility or inline sizes. */
:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size:10px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size: 10px"] {
    font-size: var(--font-size-10) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size:11px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size: 11px"] {
    font-size: var(--font-size-11) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size:12px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size: 12px"] {
    font-size: var(--font-size-12) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size:13px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size: 13px"] {
    font-size: var(--font-size-13) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size:14px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size: 14px"] {
    font-size: var(--font-size-14) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size:15px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size: 15px"] {
    font-size: var(--font-size-15) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size:16px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size: 16px"] {
    font-size: var(--font-size-16) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size:18px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size: 18px"] {
    font-size: var(--font-size-18) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size:20px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size: 20px"] {
    font-size: var(--font-size-20) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size:22px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size: 22px"] {
    font-size: var(--font-size-22) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size:24px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size: 24px"] {
    font-size: var(--font-size-24) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size:28px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size: 28px"] {
    font-size: var(--font-size-28) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size:30px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size: 30px"] {
    font-size: var(--font-size-30) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size:32px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size: 32px"] {
    font-size: var(--font-size-32) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size:36px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size: 36px"] {
    font-size: var(--font-size-36) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size:40px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size: 40px"] {
    font-size: var(--font-size-40) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size:48px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu, .cart-drawer, .cart-notification) [style*="font-size: 48px"] {
    font-size: var(--font-size-48) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size:16px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size: 16px"] {
    font-size: var(--font-heading-size-16) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size:18px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size: 18px"] {
    font-size: var(--font-heading-size-18) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size:20px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size: 20px"] {
    font-size: var(--font-heading-size-20) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size:22px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size: 22px"] {
    font-size: var(--font-heading-size-22) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size:24px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size: 24px"] {
    font-size: var(--font-heading-size-24) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size:26px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size: 26px"] {
    font-size: var(--font-heading-size-26) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size:28px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size: 28px"] {
    font-size: var(--font-heading-size-28) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size:30px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size: 30px"] {
    font-size: var(--font-heading-size-30) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size:32px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size: 32px"] {
    font-size: var(--font-heading-size-32) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size:36px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size: 36px"] {
    font-size: var(--font-heading-size-36) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size:40px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size: 40px"] {
    font-size: var(--font-heading-size-40) !important;
}

:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size:48px"],
:where(.theme-main, .site-header, .site-footer, #mobile-menu) :is(h1, h2, h3, h4, h5, h6)[style*="font-size: 48px"] {
    font-size: var(--font-heading-size-48) !important;
}

a {
    color: var(--link, inherit);
    text-decoration: none;
}

img {
    display: block;
    max-width: 100%;
}

button {
    font-family: inherit;
}

/* ─── Layout ─── */
.container {
    width: 100%;
    max-width: var(--page-width, var(--container, 1200px));
    margin: 0 auto;
    padding: 0 1.5rem;
}

.loom-container {
    width: 100%;
    max-width: var(--page-width, var(--container, 1200px));
    margin-left: auto;
    margin-right: auto;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

@media (max-width: 640px) {

    .container,
    .loom-container {
        padding: 0 1rem;
    }
}

.theme-main>section+section {
    margin-top: var(--section-spacing, 0px);
}

.theme-main .grid,
.theme-main .loom-grid {
    column-gap: var(--grid-horizontal-spacing, 8px);
    row-gap: var(--grid-vertical-spacing, 8px);
}

/* ─── Buttons ─── */
.btn,
.button,
button.btn,
a.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.75rem 1.75rem;
    min-height: 2.75rem;
    border-radius: var(--buttons-radius, 0) !important;
    font-weight: 500;
    font-size: 0.875rem;
    letter-spacing: 0.01em;
    cursor: pointer;
    transition: opacity 0.15s ease, background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
    border: var(--buttons-border-width, 1px) solid var(--buttons-border-color, transparent) !important;
    box-shadow: var(--buttons-shadow-horizontal, 0) var(--buttons-shadow-vertical, 0) var(--buttons-shadow-blur, 0) var(--buttons-shadow-color, transparent) !important;
    white-space: nowrap;
    text-decoration: none;
    appearance: none;
    -webkit-appearance: none;
}

.btn-primary,
.button--primary,
.button:not(.button--secondary):not(.button--outline),
.shopify-payment-button__button {
    background: var(--scheme-btn-bg, var(--primary, #0a0a0a));
    color: var(--scheme-btn-label, var(--primary-text, #ffffff));
    --buttons-border-color: color-mix(in srgb, var(--scheme-btn-bg, var(--primary, #0a0a0a)) var(--buttons-border-opacity, 100%), transparent);
}

.btn-primary:hover,
.button--primary:hover,
.button:not(.button--secondary):not(.button--outline):hover,
.shopify-payment-button__button:hover {
    opacity: 0.88;
}

.btn-outline,
.button--secondary,
.button--outline {
    background: transparent;
    color: var(--scheme-btn-outline, var(--text, #0a0a0a));
    --buttons-border-color: color-mix(in srgb, var(--scheme-btn-outline, var(--text, #0a0a0a)) var(--buttons-border-opacity, 100%), transparent);
}

.btn-outline:hover,
.button--secondary:hover,
.button--outline:hover {
    border-color: var(--scheme-btn-outline, var(--text, #0a0a0a));
    opacity: 0.75;
}

.btn-ghost,
.button--tertiary {
    background: transparent;
    color: var(--foreground, var(--text, #0a0a0a));
    padding: 0.5rem 0.75rem;
    border-color: transparent;
    box-shadow: none;
}

.btn-ghost:hover,
.button--tertiary:hover {
    background: var(--surface, var(--surface-raised, #f5f5f5));
}

.btn-sm,
.button--small {
    padding: 0.5rem 1.25rem;
    min-height: 2.25rem;
    font-size: 0.8125rem;
}

.btn-lg,
.button--large {
    padding: 1rem 2.25rem;
    min-height: 3.25rem;
    font-size: 1rem;
}

.btn:disabled,
.button:disabled,
.btn[aria-disabled="true"],
.button[aria-disabled="true"] {
    opacity: 0.5;
    cursor: not-allowed;
}

/* ─── Cart drawer and notification ─── */
.cart-notification {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 120;
    display: flex;
    align-items: center;
    gap: 1rem;
    width: min(360px, calc(100vw - 2rem));
    padding: 1rem;
    border: 1px solid var(--border, rgba(10, 10, 10, 0.08));
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.16);
    transform: translateY(-12px);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.cart-notification.is-open {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.cart-notification__content {
    flex: 1;
    min-width: 0;
}

.cart-notification__title {
    margin: 0 0 0.25rem;
    font-weight: 600;
    color: var(--foreground);
}

.cart-notification__item {
    margin: 0;
    font-size: 0.875rem;
    color: var(--text-secondary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.cart-drawer-overlay {
    position: fixed;
    inset: 0;
    z-index: 118;
    background: rgba(0, 0, 0, 0.36);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
}

.cart-drawer-overlay.is-open {
    opacity: 1;
    pointer-events: auto;
}

.cart-drawer {
    position: fixed;
    top: 0;
    right: 0;
    z-index: 119;
    width: min(420px, 100vw);
    height: 100vh;
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.24s ease;
    box-shadow: -16px 0 48px rgba(0, 0, 0, 0.18);
    background: var(--bg);
}

.cart-drawer.is-open {
    transform: translateX(0);
}

.cart-drawer__header,
.cart-drawer__footer {
    padding: 1.25rem;
    border-color: var(--border);
}

.cart-drawer__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid var(--border);
}

.cart-drawer__header h2 {
    margin: 0;
    font-size: 1.25rem;
}

.cart-drawer__close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    background: transparent;
    border: 0;
    color: var(--foreground);
    cursor: pointer;
}

.cart-drawer__body {
    flex: 1;
    overflow: auto;
    padding: 0;
}

.cart-drawer__empty {
    padding: 2rem 1.25rem;
    color: var(--text-secondary);
}

.cart-drawer__item {
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr);
    gap: 1rem;
    padding: 1.25rem;
    border-bottom: 1px solid var(--border);
}

.cart-drawer__item img,
.cart-drawer__item-image-placeholder {
    width: 72px;
    height: 72px;
    background: var(--surface);
}

.cart-drawer__item img {
    object-fit: cover;
}

.cart-drawer__item-title {
    margin: 0 0 0.375rem;
    font-weight: 500;
    color: var(--foreground);
}

.cart-drawer__item-meta {
    margin: 0 0 0.5rem;
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

.cart-drawer__item-price {
    margin: 0;
    font-size: 0.875rem;
    color: var(--foreground);
}

.cart-drawer__footer {
    border-top: 1px solid var(--border);
}

.cart-drawer__subtotal {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1rem;
}

.cart-drawer__checkout {
    width: 100%;
}

.cart-drawer__view-cart {
    display: block;
    margin-top: 0.875rem;
    text-align: center;
    color: var(--text-secondary);
    text-decoration: none;
}

/* ─── Cards ─── */
.card {
    background: var(--bg, #ffffff);
    border: 1px solid var(--border, rgba(10, 10, 10, 0.08));
    border-radius: 0;
    overflow: hidden;
}

/* ─── Shopify theme setting surfaces ─── */
.content-container,
.collapsible-content details {
    border: var(--content-container-border-width, 0) solid var(--content-container-border-color, transparent);
    border-radius: var(--content-container-radius, 0);
    box-shadow: var(--content-container-shadow-horizontal, 0) var(--content-container-shadow-vertical, 0) var(--content-container-shadow-blur, 0) var(--content-container-shadow-color, transparent);
    overflow: hidden;
}

.content-container--padded {
    padding: clamp(1.25rem, 3vw, 2.5rem);
}

.theme-media,
.image-with-text__media,
.slideshow__media,
.product-gallery-main,
.product-thumb,
.article-main__media,
.page-header__media,
.video-section__media,
.map__media,
.rich-text__media,
.multi-column__media,
.logo-list__media,
.testimonial-media,
.cart-card-img {
    border: var(--media-border-width, 0) solid var(--media-border-color, transparent);
    border-radius: var(--media-radius, 0);
    box-shadow: var(--media-shadow-horizontal, 0) var(--media-shadow-vertical, 0) var(--media-shadow-blur, 0) var(--media-shadow-color, transparent);
    overflow: hidden;
}

.theme-media img,
.theme-media video,
.theme-media iframe,
.image-with-text__media img,
.slideshow__media img,
.product-gallery-main img,
.article-main__media img,
.page-header__media img,
.video-section__media video,
.video-section__media iframe,
.map__media iframe,
.rich-text__media img,
.multi-column__media img,
.logo-list__media img,
.testimonial-media img {
    border-radius: max(0px, calc(var(--media-radius, 0px) - var(--media-border-width, 0px)));
}

/* ─── Product cards ─── */
.product-card {
    --product-card-border-color: color-mix(in srgb, var(--foreground, #0a0a0a) var(--product-card-border-opacity, 10%), transparent);
    --product-card-shadow-color: color-mix(in srgb, var(--foreground, #0a0a0a) var(--product-card-shadow-opacity, 0%), transparent);
    background: transparent;
    border: 0 solid transparent;
    border-radius: var(--product-card-radius, 0);
    overflow: hidden;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.product-card--card {
    background: var(--gradient-background, var(--bg, #ffffff));
    border: var(--product-card-border-width, 0) solid var(--product-card-border-color);
    box-shadow: var(--product-card-shadow-horizontal, 0) var(--product-card-shadow-vertical, 0) var(--product-card-shadow-blur, 0) var(--product-card-shadow-color);
}

.product-card>a {
    display: block;
    color: inherit;
    height: 100%;
}

.product-card__media {
    background: var(--surface, #f5f5f5);
    border-radius: var(--product-card-radius, 0);
    padding: var(--product-card-image-padding, 0);
}

.product-card--card .product-card__media {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.product-card img {
    transition: transform 0.5s ease;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: max(0px, calc(var(--product-card-radius, 0px) - var(--product-card-image-padding, 0px)));
}

.product-card:hover img {
    transform: scale(1.04);
}

.product-card__content {
    padding: 0.875rem;
}

.product-card--standard .product-card__content {
    padding-left: 0;
    padding-right: 0;
}

.product-card__vendor {
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-secondary, rgba(10, 10, 10, 0.6));
    margin-bottom: 0.25rem;
}

.product-card__title {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--foreground, var(--text, #0a0a0a));
    margin-bottom: 0.375rem;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.product-card__price {
    font-size: 0.875rem;
    color: var(--text-muted, rgba(10, 10, 10, 0.6));
}

.product-card__compare-price {
    text-decoration: line-through;
    color: var(--text-subtle, rgba(10, 10, 10, 0.35));
    margin-right: 0.375rem;
}

.product-card__badge {
    position: absolute;
    top: 0.75rem;
    left: 0.75rem;
    background: var(--scheme-badge-bg, var(--foreground, #0a0a0a));
    color: var(--scheme-badge-fg, var(--background, #ffffff));
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    padding: 0.1875rem 0.5rem;
    border-radius: max(0px, calc(var(--product-card-radius, 0px) * 0.5));
}

.product-card__badge--sale {
    background: var(--badge-sale-bg, var(--scheme-badge-bg, var(--foreground, #0a0a0a)));
    color: var(--badge-sale-fg, var(--scheme-badge-fg, var(--background, #ffffff)));
}

.product-card__badge--sold-out {
    background: var(--badge-sold-out-bg, var(--scheme-badge-bg, var(--foreground, #0a0a0a)));
    color: var(--badge-sold-out-fg, var(--scheme-badge-fg, var(--background, #ffffff)));
}

.product-card__badge--top-left {
    top: 0.75rem;
    right: auto;
    bottom: auto;
    left: 0.75rem;
}

.product-card__badge--top-right {
    top: 0.75rem;
    right: 0.75rem;
    bottom: auto;
    left: auto;
}

.product-card__badge--bottom-left {
    top: auto;
    right: auto;
    bottom: 0.75rem;
    left: 0.75rem;
}

.product-card__badge--bottom-right {
    top: auto;
    right: 0.75rem;
    bottom: 0.75rem;
    left: auto;
}

.product-card__price-row>* {
    justify-content: inherit;
}

.product-card[style*="text-align: center"] .product-card__price-row>* {
    justify-content: center;
}

.product-card[style*="text-align: right"] .product-card__price-row>* {
    justify-content: flex-end;
}

.product-card__rating {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    margin-top: 0.375rem;
}

.product-card[style*="text-align: center"] .product-card__rating {
    justify-content: center;
}

.product-card[style*="text-align: right"] .product-card__rating {
    justify-content: flex-end;
}

/* ─── Mobile card layouts ─── */
.mobile-layout-grid {
    display: grid;
    grid-template-columns: repeat(var(--mobile-columns, 1), minmax(0, 1fr));
    column-gap: var(--mobile-gap-x, var(--grid-horizontal-spacing, 24px));
    row-gap: var(--mobile-gap-y, var(--grid-vertical-spacing, 24px));
    align-items: start;
}

@media (max-width: 767px) {
    .mobile-layout-grid--swipe {
        grid-template-columns: none !important;
        grid-auto-flow: column;
        grid-auto-columns: var(--mobile-swipe-card-width, 85%);
        overflow-x: auto;
        overscroll-behavior-x: contain;
        scroll-snap-type: x proximity;
        scrollbar-width: none;
        padding-bottom: 0.25rem;
    }

    .mobile-layout-grid--swipe::-webkit-scrollbar {
        display: none;
    }

    .mobile-layout-grid--swipe>* {
        scroll-snap-align: start;
        min-width: 0;
    }

    .mobile-layout-grid--columns-1 {
        --mobile-swipe-card-width: 85%;
    }

    .mobile-layout-grid--columns-2 {
        --mobile-swipe-card-width: calc((100% - var(--mobile-gap-x, 16px)) / 2);
    }
}

@media (min-width: 768px) {
    .mobile-layout-grid {
        grid-template-columns: repeat(var(--desktop-columns, 3), minmax(0, 1fr));
    }
}

/* ─── Featured products ─── */
.featured-products__grid {
    --mobile-columns: var(--featured-products-columns-mobile, 2);
    --desktop-columns: var(--featured-products-columns-desktop, 4);
    --mobile-gap-x: var(--featured-products-gap-x, 24px);
    --mobile-gap-y: var(--featured-products-gap-y, 24px);
}

@media (max-width: 480px) {
    .featured-products__grid {
        column-gap: min(var(--featured-products-gap-x, 24px), 14px);
        row-gap: min(var(--featured-products-gap-y, 24px), 22px);
    }

    .featured-products__grid .product-card__content {
        padding-top: 0.625rem;
    }

    .featured-products__grid .product-card__title {
        font-size: 0.875rem;
        line-height: 1.3;
    }
}

/* ─── Collection cards ─── */
.collection-card {
    --collection-card-border-color: color-mix(in srgb, var(--foreground, #0a0a0a) var(--collection-card-border-opacity, 10%), transparent);
    --collection-card-shadow-color: color-mix(in srgb, var(--foreground, #0a0a0a) var(--collection-card-shadow-opacity, 0%), transparent);
    display: block;
    color: inherit;
    background: transparent;
    border: 0 solid transparent;
    border-radius: var(--collection-card-radius, 0);
    overflow: hidden;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.collection-card--card {
    background: var(--gradient-background, var(--bg, #ffffff));
    border: var(--collection-card-border-width, 0) solid var(--collection-card-border-color);
    box-shadow: var(--collection-card-shadow-horizontal, 0) var(--collection-card-shadow-vertical, 0) var(--collection-card-shadow-blur, 0) var(--collection-card-shadow-color);
}

.collection-card__media {
    position: relative;
    overflow: hidden;
    background: var(--surface, #f5f5f5);
    border-radius: var(--collection-card-radius, 0);
    padding: var(--collection-card-image-padding, 0);
}

.collection-card--card .collection-card__media {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.collection-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.7s ease;
    border-radius: max(0px, calc(var(--collection-card-radius, 0px) - var(--collection-card-image-padding, 0px)));
}

.collection-card__placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--border, rgba(10, 10, 10, 0.08));
}

.collection-card__overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: flex-end;
    padding: 2rem;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.1), transparent);
}

.collection-card[style*="text-align: center"] .collection-card__overlay {
    justify-content: center;
}

.collection-card[style*="text-align: right"] .collection-card__overlay {
    justify-content: flex-end;
}

.collection-card__overlay-title {
    color: #ffffff;
    font-size: 1.25rem;
    font-weight: 600;
    margin-bottom: 0.25rem;
}

.collection-card__overlay-link,
.collection-card__link {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.875rem;
    font-weight: 500;
}

.collection-card__overlay-link {
    color: rgba(255, 255, 255, 0.7);
}

.collection-card__content {
    padding: 1rem;
}

.collection-card--standard .collection-card__content {
    padding-left: 0;
    padding-right: 0;
}

.collection-card__title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--foreground, var(--text, #0a0a0a));
    margin-bottom: 0.375rem;
}

.collection-card__link {
    color: var(--text-secondary, rgba(10, 10, 10, 0.6));
}

/* ─── Blog cards ─── */
.blog-card {
    display: block;
    color: inherit;
    background: transparent;
    border: 0 solid transparent;
    border-radius: var(--blog-card-radius, 0);
    overflow: hidden;
    text-align: left;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.blog-card--align-center {
    text-align: center;
}

.blog-card--align-right {
    text-align: right;
}

.blog-card--card {
    background: var(--gradient-background, var(--bg, #ffffff));
    border: var(--blog-card-border-width, 0) solid var(--blog-card-border-color, transparent);
    box-shadow: var(--blog-card-shadow-horizontal, 0) var(--blog-card-shadow-vertical, 0) var(--blog-card-shadow-blur, 0) var(--blog-card-shadow-color, transparent);
}

.blog-card__media {
    aspect-ratio: 16 / 9;
    background: var(--surface, #f5f5f5);
    border-radius: var(--blog-card-radius, 0);
    overflow: hidden;
    padding: var(--blog-card-image-padding, 0);
}

.blog-card--card .blog-card__media {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.blog-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
    border-radius: max(0px, calc(var(--blog-card-radius, 0px) - var(--blog-card-image-padding, 0px)));
}

.blog-card:hover .blog-card__media img {
    transform: scale(1.04);
}

.blog-card__placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--border, rgba(10, 10, 10, 0.08));
}

.blog-card__placeholder svg {
    width: 3rem;
    height: 3rem;
    color: var(--text-subtle, rgba(10, 10, 10, 0.35));
}

.blog-card__content {
    padding: 1rem;
}

.blog-card--standard .blog-card__content {
    padding-left: 0;
    padding-right: 0;
}

.blog-card__meta {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    flex-wrap: wrap;
    font-size: 0.75rem;
    color: var(--text-secondary, rgba(10, 10, 10, 0.6));
    margin-bottom: 0.5rem;
}

.blog-card--align-center .blog-card__meta {
    justify-content: center;
}

.blog-card--align-right .blog-card__meta {
    justify-content: flex-end;
}

.blog-card__title {
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.35;
    color: var(--foreground, var(--text, #0a0a0a));
    margin-bottom: 0.5rem;
}

.blog-card__title a {
    color: inherit;
}

.blog-card__excerpt {
    font-size: 0.875rem;
    line-height: 1.6;
    color: var(--text-secondary, rgba(10, 10, 10, 0.6));
}

.blog-posts__header {
    text-align: center;
    margin-bottom: 3.5rem;
}

.blog-posts__heading {
    font-size: var(--font-heading-size-36, 2.25rem);
    font-weight: 600;
    color: var(--foreground, var(--text, #0a0a0a));
    margin-bottom: 1rem;
}

.blog-posts__subheading {
    max-width: 42rem;
    margin: 0 auto;
    color: var(--text-secondary, rgba(10, 10, 10, 0.6));
}

/* ─── Badges ─── */
.badge {
    display: inline-block;
    padding: 0.2rem 0.6rem;
    border-radius: 0;
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.badge-sale {
    background: #0a0a0a;
    color: #ffffff;
}

.badge-new {
    background: var(--surface-raised, #f5f5f5);
    color: var(--text, #0a0a0a);
    border: 1px solid var(--border, rgba(10, 10, 10, 0.08));
}

.badge-out {
    background: transparent;
    color: var(--text-subtle, rgba(10, 10, 10, 0.35));
    border: 1px solid var(--border, rgba(10, 10, 10, 0.08));
}

/* ─── Form elements ─── */
.input {
    width: 100%;
    padding: 0.75rem 1rem;
    background: var(--bg, #ffffff);
    border: 1px solid var(--border-strong, rgba(10, 10, 10, 0.15));
    border-radius: 0;
    color: var(--text, #0a0a0a);
    font-size: 0.9375rem;
    font-family: inherit;
    outline: none;
    transition: border-color 0.15s ease;
}

.input::placeholder {
    color: var(--text-subtle, rgba(10, 10, 10, 0.35));
}

.input:focus {
    border-color: var(--text, #0a0a0a);
}

.label {
    display: block;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--text-muted, rgba(10, 10, 10, 0.6));
    margin-bottom: 0.5rem;
    letter-spacing: 0.01em;
}

select.input {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='rgba(10,10,10,0.4)'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    background-size: 1.1rem;
    padding-right: 2.5rem;
}

/* ─── Dividers ─── */
.divider {
    border: none;
    border-top: 1px solid var(--border, rgba(10, 10, 10, 0.08));
}

/* ─── Section spacing ─── */
.section {
    padding: clamp(3rem, 5vw, 5rem) 0;
}

.section-sm {
    padding: clamp(2rem, 3vw, 3rem) 0;
}

.section-lg {
    padding: clamp(4rem, 7vw, 7rem) 0;
}

.section-title {
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 0.75rem;
    letter-spacing: -0.03em;
}

.section-subtitle {
    color: var(--text-muted, rgba(10, 10, 10, 0.6));
    font-size: 1.0625rem;
}

/* ─── Header ─── */
.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    background: var(--bg, rgba(255, 255, 255, 0.92));
    color: var(--text, #0a0a0a);
    border-bottom: 1px solid var(--border, rgba(10, 10, 10, 0.08));
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    transition: transform 0.3s ease, background 0.2s ease;
}

/* Sticky modes */
.site-header.header--static {
    position: relative;
}

.site-header.header--sticky-always {
    position: sticky;
    top: 0;
}

.site-header.header--sticky-scroll {
    position: sticky;
    top: 0;
}

.site-header.header--sticky-scroll.header--hidden {
    transform: translateY(-100%);
}

.site-header.header--sticky-scroll.header--visible {
    transform: translateY(0);
}

.site-header.transparent {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background: transparent;
    border-bottom-color: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.site-header.transparent.scrolled {
    background: color-mix(in srgb, var(--bg, #ffffff) 92%, transparent);
    border-bottom-color: var(--border, rgba(10, 10, 10, 0.08));
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 64px;
}

.header-logo {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text, #0a0a0a);
    letter-spacing: -0.01em;
}

.header-logo img {
    height: 36px;
    width: auto;
    object-fit: contain;
}

.desktop-nav {
    display: none;
    align-items: center;
    gap: 2rem;
    height: 100%;
}

@media (min-width: 768px) {
    .desktop-nav {
        display: flex;
    }
}

.nav-item {
    position: relative;
    display: flex;
    align-items: center;

}

@media (min-width: 768px) {
    .nav-item {
        height: 100%;
    }
}

@media (max-width: 768px) {
    .nav-item {
        height: auto;
    }
}

.nav-link {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-muted, rgba(10, 10, 10, 0.6));
    transition: color 0.15s ease;
    position: relative;
    padding: 0.5rem 0;
}

.nav-link:hover {
    color: var(--text, #0a0a0a);
}

.nav-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 200px;
    padding-top: 0;
    display: none;
    z-index: 100;
}

.nav-dropdown-inner {
    background: var(--bg, #ffffff);
    border: 1px solid var(--border, rgba(10, 10, 10, 0.08));
    border-radius: 8px;
    padding: 0.375rem;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1), 0 1px 3px rgba(0, 0, 0, 0.06);
    overflow: visible;
}

.nav-item:hover .nav-dropdown {
    display: block;
}

.nav-dropdown a {
    display: block;
    padding: 0.5rem 0.75rem;
    font-size: 0.8125rem;
    color: var(--text-muted, rgba(10, 10, 10, 0.6));
    border-radius: 6px;
    transition: background 0.1s, color 0.1s;
    white-space: nowrap;
}

.nav-dropdown a:hover {
    background: var(--surface-raised, #f5f5f5);
    color: var(--text, #0a0a0a);
}

.nav-submenu-item {
    position: relative;
}

.nav-dropdown a.nav-submenu-trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    cursor: pointer;
}

.nav-submenu-trigger svg {
    opacity: 0.4;
    flex-shrink: 0;
}

.nav-submenu-item:hover>.nav-submenu-trigger {
    background: var(--surface-raised, #f5f5f5);
    color: var(--text, #0a0a0a);
}

.nav-submenu-item:hover>.nav-submenu-trigger svg {
    opacity: 1;
}

.nav-flyout {
    position: absolute;
    top: -0.375rem;
    left: 100%;
    padding-left: 0.25rem;
    display: none;
    z-index: 101;
}

.nav-submenu-item:hover>.nav-flyout {
    display: block;
}

.nav-flyout-inner {
    background: var(--bg, #ffffff);
    border: 1px solid var(--border, rgba(10, 10, 10, 0.08));
    border-radius: 8px;
    padding: 0.375rem;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1), 0 1px 3px rgba(0, 0, 0, 0.06);
    min-width: 180px;
}

.nav-flyout a:hover {
    background: var(--surface-raised, #f5f5f5);
    color: var(--text, #0a0a0a);
}

.header-actions {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.header-icon {
    color: var(--text-muted, rgba(10, 10, 10, 0.6));
    transition: color 0.15s ease;
    display: flex;
    align-items: center;
}

.header-icon:hover {
    color: var(--text, #0a0a0a);
}

.header-icon svg {
    width: 20px;
    height: 20px;
}

/* ─── Announcement bar ─── */
.announcement-bar {
    text-align: center;
    padding: 0.625rem 1rem;
    font-size: 0.8125rem;
    font-weight: 500;
}

.announcement-bar a:hover {
    text-decoration: underline;
}

/* ─── Mobile nav ─── */
#mobile-menu {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 200;
    background: var(--bg, #ffffff);
    flex-direction: column;
    padding: 1.5rem;
    overflow-y: auto;
}

#mobile-menu.open {
    display: flex;
}

#mobile-menu .menu-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid var(--border, rgba(10, 10, 10, 0.08));
    margin-bottom: 1.5rem;
}

#mobile-menu .close-btn {
    background: var(--surface-raised, #f5f5f5);
    border: none;
    cursor: pointer;
    padding: 0.5rem;
    border-radius: 0;
    color: var(--text, #0a0a0a);
    display: flex;
    align-items: center;
}

#mobile-menu nav a {
    display: flex;
    align-items: center;
    padding: 1rem 0;
    font-size: 1.125rem;
    font-weight: 500;
    color: var(--text, #0a0a0a);
    border-bottom: 1px solid var(--border, rgba(10, 10, 10, 0.06));
}

#mobile-menu nav a:last-child {
    border-bottom: none;
}

#mobile-menu nav a:hover {
    color: var(--text-muted, rgba(10, 10, 10, 0.6));
}

body.menu-open {
    overflow: hidden;
}

/* ─── Footer ─── */
.site-footer {
    background: var(--bg, #fafafa);
    color: var(--text, var(--foreground, #0a0a0a));
    border-top: 1px solid var(--border, rgba(10, 10, 10, 0.08));
    margin-top: 5rem;
}

.section-footer {
    margin-top: 0;
}

.section-footer>.container {
    padding-top: var(--footer-section-padding-top, 40px);
    padding-bottom: var(--footer-section-padding-bottom, 40px);
}

.section-footer .footer-grid {
    padding-top: 0;
}

.footer-grid {
    display: grid;
    gap: 2.5rem;
    padding: 4rem 0;
}

@media (min-width: 768px) {
    .footer-grid {
        grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    }
}

.footer-brand {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
}

.footer-brand-logo {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
}

.footer-brand-logo img {
    display: block;
    width: min(var(--footer-brand-logo-width, 100px), 100%);
    height: auto;
    object-fit: contain;
}

.footer-brand-name {
    font-family: var(--font-heading-family, inherit);
    font-size: var(--font-heading-size-18, 1.125rem);
    font-weight: 700;
    color: var(--text, var(--foreground, #0a0a0a));
}

.footer-brand-description,
.footer-text,
.footer-newsletter-text {
    max-width: 34rem;
    font-size: var(--font-body-size-15, 0.9375rem);
    line-height: 1.65;
    color: var(--text-secondary, var(--text-muted, rgba(10, 10, 10, 0.6)));
}

.footer-newsletter-heading {
    font-family: var(--font-heading-family, inherit);
    font-size: var(--font-heading-size-24, 1.5rem);
    font-weight: 700;
    margin-bottom: 0.5rem;
}

.footer-newsletter-text {
    margin-bottom: 1.5rem;
}

.footer-col-title {
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-secondary, var(--text-muted, rgba(10, 10, 10, 0.6)));
    margin-bottom: 1rem;
}

.footer-links {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
}

.footer-links a {
    font-size: 0.9375rem;
    color: var(--text-secondary, var(--text-muted, rgba(10, 10, 10, 0.6)));
    transition: color 0.15s ease;
}

.footer-links a:hover {
    color: var(--text, var(--foreground, #0a0a0a));
}

.footer-bottom {
    border-top: 1px solid var(--border, rgba(10, 10, 10, 0.06));
    padding: 1.5rem 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem;
    font-size: 0.8125rem;
    color: var(--text-secondary, var(--text-muted, rgba(10, 10, 10, 0.6)));
}

.footer-legal {
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
}

.footer-policies,
.footer-payment-icons {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5rem 0.875rem;
    list-style: none;
}

.footer-policies a {
    color: var(--text-secondary, var(--text-muted, rgba(10, 10, 10, 0.6)));
    text-decoration: underline;
    text-underline-offset: 0.18em;
    transition: color 0.15s ease;
}

.footer-policies a:hover {
    color: var(--text, var(--foreground, #0a0a0a));
}

.footer-payment-icons li {
    border: 1px solid var(--border, rgba(10, 10, 10, 0.12));
    border-radius: 4px;
    padding: 0.25rem 0.5rem;
    color: var(--text-secondary, var(--text-muted, rgba(10, 10, 10, 0.6)));
    background: color-mix(in srgb, var(--bg, #fff) 82%, var(--text, #000) 18%);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0;
}

.social-links {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    flex-wrap: wrap;
}

.social-links a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary, var(--text-muted, rgba(10, 10, 10, 0.6)));
    transition: color 0.15s ease;
}

.social-links a:hover {
    color: var(--text, var(--foreground, #0a0a0a));
}

.social-links svg {
    width: 18px;
    height: 18px;
}

.footer-brand-social {
    margin-top: 0.25rem;
}

/* ─── Newsletter block (in footer) ─── */
.newsletter-block {
    padding: 3.5rem 0;
    border-bottom: 1px solid var(--border, rgba(10, 10, 10, 0.08));
}

.newsletter-form {
    display: flex;
    gap: 0.75rem;
    max-width: 440px;
}

.newsletter-form .input {
    flex: 1;
    background: color-mix(in srgb, var(--bg, #ffffff) 88%, var(--text, #0a0a0a) 12%);
    border-color: var(--border-dark, var(--border, rgba(10, 10, 10, 0.15)));
    color: var(--text, var(--foreground, #0a0a0a));
}

.newsletter-form .input::placeholder {
    color: var(--text-secondary, var(--text-muted, rgba(10, 10, 10, 0.6)));
}

.newsletter-form .input:hover {
    border-color: color-mix(in srgb, var(--text, #0a0a0a) 45%, transparent);
}

.newsletter-form .input:focus {
    border-color: var(--text, var(--foreground, #0a0a0a));
    box-shadow: 0 0 0 1px var(--text, var(--foreground, #0a0a0a));
}

@media (max-width: 480px) {
    .newsletter-form {
        flex-direction: column;
    }
}

/* ─── Contact form ─── */
.contact-form__field {
    width: 100%;
    background: color-mix(in srgb, var(--scheme-bg, var(--bg, #ffffff)) 80%, var(--scheme-text, var(--text, #0a0a0a)) 20%);
    color: var(--scheme-text, var(--text, #0a0a0a));
    border: 1px solid color-mix(in srgb, var(--scheme-text, var(--text, #0a0a0a)) 20%, transparent);
}

.contact-form__field::placeholder {
    color: color-mix(in srgb, var(--scheme-text, var(--text, #0a0a0a)) 60%, transparent);
}

.contact-form__field:focus {
    border-color: var(--scheme-text, var(--text, #0a0a0a));
}

/* ─── Rich text content (product descriptions, metafields) ─── */
.rte h1 {
    font-size: 1.75rem;
    font-weight: 700;
    margin: 1.25rem 0 0.75rem;
    letter-spacing: -0.02em;
}

.rte h2 {
    font-size: 1.375rem;
    font-weight: 600;
    margin: 1.125rem 0 0.625rem;
    letter-spacing: -0.01em;
}

.rte h3 {
    font-size: 1.125rem;
    font-weight: 600;
    margin: 1rem 0 0.5rem;
}

.rte p {
    margin: 0 0 0.75rem;
}

.rte p:last-child {
    margin-bottom: 0;
}

.rte ul,
.rte ol {
    margin: 0.5rem 0 0.75rem 1.5rem;
}

.rte ul {
    list-style: disc;
}

.rte ol {
    list-style: decimal;
}

.rte li {
    margin-bottom: 0.25rem;
}

.rte li p {
    margin-bottom: 0.25rem;
}

.rte blockquote {
    border-left: 3px solid var(--border-strong, rgba(10, 10, 10, 0.15));
    padding: 0.5rem 0 0.5rem 1rem;
    margin: 0.75rem 0;
    color: var(--text-muted, rgba(10, 10, 10, 0.6));
    font-style: italic;
}

.rte strong,
.rte b {
    font-weight: 600;
}

.rte em,
.rte i {
    font-style: italic;
}

.rte u {
    text-decoration: underline;
}

.rte a {
    color: var(--text, #0a0a0a);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.rte a:hover {
    opacity: 0.7;
}

.rte img {
    margin: 0.75rem 0;
    border-radius: 0;
}

.rte hr {
    border: none;
    border-top: 1px solid var(--border, rgba(10, 10, 10, 0.08));
    margin: 1rem 0;
}

.rte code {
    font-size: 0.875em;
    background: var(--surface-raised, #f5f5f5);
    padding: 0.15em 0.35em;
}

.rte pre {
    background: var(--surface-raised, #f5f5f5);
    padding: 1rem;
    margin: 0.75rem 0;
    overflow-x: auto;
    font-size: 0.875rem;
}

/* ─── Animations ─── */
.animate-fade {
    animation: fadeIn 0.35s ease-out both;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

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

/* ─── Transparent header: first section pads for the fixed header ─── */
.has-transparent-header>div:first-child section {
    padding-top: calc(64px + 3rem);
}

/* ─── Editor mode overlays ─── */
[data-section-id] {
    position: relative;
    transition: outline 0.15s;
}

[data-section-id].editor-hover {
    outline: 2px dashed rgba(99, 102, 241, 0.5);
    outline-offset: -2px;
}

[data-section-id].editor-selected {
    outline: 2px solid #6366f1;
    outline-offset: -2px;
    z-index: 10;
}

.editor-section-label {
    position: absolute;
    top: 0;
    left: 0;
    background: #6366f1;
    color: #fff;
    font-size: 11px;
    font-family: system-ui;
    padding: 2px 8px;
    z-index: 11;
    pointer-events: none;
    border-radius: 0;
}

[data-block-id] {
    position: relative;
}

[data-block-id].editor-block-hover {
    outline: 2px dashed rgba(139, 92, 246, 0.4);
    outline-offset: -1px;
}

[data-block-id].editor-block-selected {
    outline: 2px solid #8b5cf6;
    outline-offset: -1px;
    z-index: 12;
}

.editor-block-label {
    position: absolute;
    top: 0;
    right: 0;
    background: #8b5cf6;
    color: #fff;
    font-size: 10px;
    font-family: system-ui;
    padding: 1px 6px;
    z-index: 13;
    pointer-events: none;
    border-radius: 0;
}

/* Hamburger button: visible on mobile, hidden on desktop for non-drawer modes */
.hamburger-btn {
    display: flex;
    align-items: center;
}

@media (min-width: 768px) {
    .site-header:not(.header--drawer) .hamburger-btn {
        display: none;
    }
}

/* Drawer mode: hide desktop nav, always show hamburger */
.header--drawer .desktop-nav {
    display: none !important;
}

/* ─── Mega menu panel ─── */
.mega-menu-panel {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    min-width: 600px;
    max-width: 900px;
    width: max-content;
    padding-top: 0;
    display: none;
    z-index: 100;
}

.nav-item:hover .mega-menu-panel {
    display: block;
}

.mega-menu-inner {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 1.5rem;
    background: var(--bg, #ffffff);
    border: 1px solid var(--border, rgba(10, 10, 10, 0.08));
    border-radius: 12px;
    padding: 1.5rem 2rem;
    box-shadow: 0 12px 48px rgba(0, 0, 0, 0.12), 0 2px 6px rgba(0, 0, 0, 0.06);
}

.mega-menu-col {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.mega-menu-heading {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--text, #0a0a0a);
    padding-bottom: 0.375rem;
    margin-bottom: 0.25rem;
    border-bottom: 1px solid var(--border, rgba(10, 10, 10, 0.06));
}

.mega-menu-col a:not(.mega-menu-heading) {
    font-size: 0.8125rem;
    color: var(--text-muted, rgba(10, 10, 10, 0.6));
    padding: 0.25rem 0;
    transition: color 0.15s ease;
}

.mega-menu-col a:not(.mega-menu-heading):hover {
    color: var(--text, #0a0a0a);
}

/* ─── Loom utility layer ───────────────────────────────────────────────
   Theme-owned replacements for the Tailwind CDN utilities used by Loom.
   Keep this layer small and predictable; section-specific CSS should still
   live beside the section that owns it.
*/
.antialiased {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}

.static {
    position: static;
}

.fixed {
    position: fixed;
}

.absolute {
    position: absolute;
}

.relative {
    position: relative;
}

.sticky {
    position: sticky;
}

.inset-0 {
    inset: 0;
}

.top-0 {
    top: 0;
}

.top-1\/2 {
    top: 50%;
}

.top-5 {
    top: 1.25rem;
}

.right-0 {
    right: 0;
}

.right-3 {
    right: 0.75rem;
}

.right-6 {
    right: 1.5rem;
}

.-right-2 {
    right: -0.5rem;
}

.bottom-6 {
    bottom: 1.5rem;
}

.left-0 {
    left: 0;
}

.left-1\/2 {
    left: 50%;
}

.-top-2 {
    top: -0.5rem;
}

.z-0 {
    z-index: 0;
}

.z-10 {
    z-index: 10;
}

.z-50 {
    z-index: 50;
}

.z-\[1\] {
    z-index: 1;
}

.z-\[2\] {
    z-index: 2;
}

.z-\[90\] {
    z-index: 90;
}

.z-\[100\] {
    z-index: 100;
}

.block {
    display: block;
}

.inline-block {
    display: inline-block;
}

.inline-flex {
    display: inline-flex;
}

.flex {
    display: flex;
}

.inline-grid {
    display: inline-grid;
}

.grid {
    display: grid;
}

.hidden {
    display: none;
}

.contents {
    display: contents;
}

.flex-row {
    flex-direction: row;
}

.flex-col {
    flex-direction: column;
}

.flex-wrap {
    flex-wrap: wrap;
}

.flex-1 {
    flex: 1 1 0%;
}

.flex-shrink-0,
.shrink-0 {
    flex-shrink: 0;
}

.items-start {
    align-items: flex-start;
}

.items-left {
    align-items: flex-start;
}

.items-center {
    align-items: center;
}

.items-right {
    align-items: flex-end;
}

.items-end {
    align-items: flex-end;
}

.items-stretch {
    align-items: stretch;
}

.justify-start {
    justify-content: flex-start;
}

.justify-center {
    justify-content: center;
}

.justify-end {
    justify-content: flex-end;
}

.justify-between {
    justify-content: space-between;
}

.justify-self-center {
    justify-self: center;
}

.order-1 {
    order: 1;
}

.order-2 {
    order: 2;
}

.gap-0\.5 {
    gap: 0.125rem;
}

.gap-1 {
    gap: 0.25rem;
}

.gap-1\.5 {
    gap: 0.375rem;
}

.gap-2 {
    gap: 0.5rem;
}

.gap-3 {
    gap: 0.75rem;
}

.gap-4 {
    gap: 1rem;
}

.gap-5 {
    gap: 1.25rem;
}

.gap-6 {
    gap: 1.5rem;
}

.gap-8 {
    gap: 2rem;
}

.gap-10 {
    gap: 2.5rem;
}

.gap-12 {
    gap: 3rem;
}

.grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
}

.grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.grid-cols-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.grid-cols-6 {
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.col-span-1 {
    grid-column: span 1 / span 1;
}

.col-span-2 {
    grid-column: span 2 / span 2;
}

.col-span-3 {
    grid-column: span 3 / span 3;
}

.col-span-4 {
    grid-column: span 4 / span 4;
}

.col-span-5 {
    grid-column: span 5 / span 5;
}

.col-span-6 {
    grid-column: span 6 / span 6;
}

.row-span-1 {
    grid-row: span 1 / span 1;
}

.row-span-2 {
    grid-row: span 2 / span 2;
}

.row-span-3 {
    grid-row: span 3 / span 3;
}

.row-span-4 {
    grid-row: span 4 / span 4;
}

.row-span-5 {
    grid-row: span 5 / span 5;
}

.row-span-6 {
    grid-row: span 6 / span 6;
}

.aspect-square {
    aspect-ratio: 1 / 1;
}

.aspect-video {
    aspect-ratio: 16 / 9;
}

.aspect-\[4\/3\] {
    aspect-ratio: 4 / 3;
}

.aspect-\[4\/5\] {
    aspect-ratio: 4 / 5;
}

.h-0\.5 {
    height: 0.125rem;
}

.h-3 {
    height: 0.75rem;
}

.h-4 {
    height: 1rem;
}

.h-5 {
    height: 1.25rem;
}

.h-6 {
    height: 1.5rem;
}

.h-7 {
    height: 1.75rem;
}

.h-10 {
    height: 2.5rem;
}

.h-12 {
    height: 3rem;
}

.h-14 {
    height: 3.5rem;
}

.h-16 {
    height: 4rem;
}

.h-20 {
    height: 5rem;
}

.h-auto {
    height: auto;
}

.h-full {
    height: 100%;
}

.h-screen {
    height: 100vh;
}

.h-\[200px\] {
    height: 200px;
}

.h-\[400px\] {
    height: 400px;
}

.h-\[600px\] {
    height: 600px;
}

.min-h-\[200px\] {
    min-height: 200px;
}

.max-h-\[calc\(100\%-56px\)\] {
    max-height: calc(100% - 56px);
}

.w-3 {
    width: 0.75rem;
}

.w-4 {
    width: 1rem;
}

.w-5 {
    width: 1.25rem;
}

.w-6 {
    width: 1.5rem;
}

.w-7 {
    width: 1.75rem;
}

.w-10 {
    width: 2.5rem;
}

.w-12 {
    width: 3rem;
}

.w-14 {
    width: 3.5rem;
}

.w-16 {
    width: 4rem;
}

.w-20 {
    width: 5rem;
}

.w-32 {
    width: 8rem;
}

.w-48 {
    width: 12rem;
}

.w-72 {
    width: 18rem;
}

.w-80 {
    width: 20rem;
}

.w-1\/2 {
    width: 50%;
}

.w-3\/4 {
    width: 75%;
}

.w-auto {
    width: auto;
}

.w-full {
    width: 100%;
}

.w-px {
    width: 1px;
}

.max-w-xs {
    max-width: 20rem;
}

.max-w-md {
    max-width: 28rem;
}

.max-w-lg {
    max-width: 32rem;
}

.max-w-xl {
    max-width: 36rem;
}

.max-w-2xl {
    max-width: 42rem;
}

.max-w-3xl {
    max-width: 48rem;
}

.max-w-4xl {
    max-width: 56rem;
}

.max-w-6xl {
    max-width: 72rem;
}

.max-w-full {
    max-width: 100%;
}

.max-w-none {
    max-width: none;
}

.min-w-\[200px\] {
    min-width: 200px;
}

.m-0 {
    margin: 0;
}

.mx-auto {
    margin-left: auto;
    margin-right: auto;
}

.mx-2 {
    margin-left: 0.5rem;
    margin-right: 0.5rem;
}

.my-6 {
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
}

.mt-0\.5 {
    margin-top: 0.125rem;
}

.mt-1 {
    margin-top: 0.25rem;
}

.mt-2 {
    margin-top: 0.5rem;
}

.mt-3 {
    margin-top: 0.75rem;
}

.mt-4 {
    margin-top: 1rem;
}

.mt-6 {
    margin-top: 1.5rem;
}

.mt-8 {
    margin-top: 2rem;
}

.mt-12 {
    margin-top: 3rem;
}

.mb-1 {
    margin-bottom: 0.25rem;
}

.mb-1\.5 {
    margin-bottom: 0.375rem;
}

.mb-2 {
    margin-bottom: 0.5rem;
}

.mb-3 {
    margin-bottom: 0.75rem;
}

.mb-4 {
    margin-bottom: 1rem;
}

.mb-5 {
    margin-bottom: 1.25rem;
}

.mb-6 {
    margin-bottom: 1.5rem;
}

.mb-8 {
    margin-bottom: 2rem;
}

.mb-10 {
    margin-bottom: 2.5rem;
}

.mb-12 {
    margin-bottom: 3rem;
}

.mb-14 {
    margin-bottom: 3.5rem;
}

.ml-0\.5 {
    margin-left: 0.125rem;
}

.ml-1 {
    margin-left: 0.25rem;
}

.ml-2 {
    margin-left: 0.5rem;
}

.p-4 {
    padding: 1rem;
}

.p-5 {
    padding: 1.25rem;
}

.p-6 {
    padding: 1.5rem;
}

.p-8 {
    padding: 2rem;
}

.px-1 {
    padding-left: 0.25rem;
    padding-right: 0.25rem;
}

.px-2 {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.px-3 {
    padding-left: 0.75rem;
    padding-right: 0.75rem;
}

.px-4 {
    padding-left: 1rem;
    padding-right: 1rem;
}

.px-5 {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
}

.px-6 {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

.px-8 {
    padding-left: 2rem;
    padding-right: 2rem;
}

.px-10 {
    padding-left: 2.5rem;
    padding-right: 2.5rem;
}

.py-0\.5 {
    padding-top: 0.125rem;
    padding-bottom: 0.125rem;
}

.py-1 {
    padding-top: 0.25rem;
    padding-bottom: 0.25rem;
}

.py-1\.5 {
    padding-top: 0.375rem;
    padding-bottom: 0.375rem;
}

.py-2 {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

.py-2\.5 {
    padding-top: 0.625rem;
    padding-bottom: 0.625rem;
}

.py-3 {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}

.py-4 {
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.py-5 {
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
}

.py-6 {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
}

.py-8 {
    padding-top: 2rem;
    padding-bottom: 2rem;
}

.py-12 {
    padding-top: 3rem;
    padding-bottom: 3rem;
}

.py-16 {
    padding-top: 4rem;
    padding-bottom: 4rem;
}

.py-20 {
    padding-top: 5rem;
    padding-bottom: 5rem;
}

.pt-1 {
    padding-top: 0.25rem;
}

.pt-2 {
    padding-top: 0.5rem;
}

.pt-3 {
    padding-top: 0.75rem;
}

.pt-6 {
    padding-top: 1.5rem;
}

.pt-8 {
    padding-top: 2rem;
}

.pb-4 {
    padding-bottom: 1rem;
}

.pb-5 {
    padding-bottom: 1.25rem;
}

.pb-6 {
    padding-bottom: 1.5rem;
}

.pb-12 {
    padding-bottom: 3rem;
}

.pb-px {
    padding-bottom: 1px;
}

.pl-3 {
    padding-left: 0.75rem;
}

.pl-4 {
    padding-left: 1rem;
}

.pl-6 {
    padding-left: 1.5rem;
}

.pl-8 {
    padding-left: 2rem;
}

.pr-8 {
    padding-right: 2rem;
}

.pr-12 {
    padding-right: 3rem;
}

.space-y-0\.5>*+* {
    margin-top: 0.125rem;
}

.space-y-1>*+* {
    margin-top: 0.25rem;
}

.space-y-2>*+* {
    margin-top: 0.5rem;
}

.space-y-3>*+* {
    margin-top: 0.75rem;
}

.space-y-4>*+* {
    margin-top: 1rem;
}

.overflow-hidden {
    overflow: hidden;
}

.overflow-y-auto {
    overflow-y: auto;
}

.resize-none {
    resize: none;
}

.object-cover {
    object-fit: cover;
}

.object-contain {
    object-fit: contain;
}

.pointer-events-none {
    pointer-events: none;
}

.cursor-pointer {
    cursor: pointer;
}

.border {
    border: 1px solid var(--border, rgba(10, 10, 10, 0.08));
}

.border-2 {
    border-width: 2px;
}

.border-t {
    border-top: 1px solid var(--border, rgba(10, 10, 10, 0.08));
}

.border-current {
    border-color: currentColor;
}

.rounded-md {
    border-radius: 0.375rem;
}

.rounded {
    border-radius: 0.25rem;
}

.rounded-none {
    border-radius: 0;
}

.rounded-lg {
    border-radius: 0.5rem;
}

.rounded-xl {
    border-radius: 0.75rem;
}

.rounded-full {
    border-radius: 9999px;
}

.shadow-lg {
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);
}

.shadow-xl {
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);
}

.shadow-2xl {
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, .25);
}

.bg-white {
    background-color: #fff;
}

.bg-white\/10 {
    background-color: rgba(255, 255, 255, .1);
}

.bg-black\/40 {
    background-color: rgba(0, 0, 0, .4);
}

.bg-green-500 {
    background-color: #22c55e;
}

.bg-gradient-to-t {
    background-image: linear-gradient(to top, var(--loom-gradient-stops));
}

.from-black\/60 {
    --loom-gradient-from: rgba(0, 0, 0, .6);
    --loom-gradient-stops: var(--loom-gradient-from), var(--loom-gradient-to, transparent);
}

.from-black\/70 {
    --loom-gradient-from: rgba(0, 0, 0, .7);
    --loom-gradient-stops: var(--loom-gradient-from), var(--loom-gradient-to, transparent);
}

.via-black\/10 {
    --loom-gradient-stops: var(--loom-gradient-from), rgba(0, 0, 0, .1), var(--loom-gradient-to, transparent);
}

.to-transparent {
    --loom-gradient-to: transparent;
}

.backdrop-blur-sm {
    backdrop-filter: blur(4px);
}

.backdrop-blur-md {
    backdrop-filter: blur(12px);
}

.text-left {
    text-align: left;
}

.text-center {
    text-align: center;
}

.text-right {
    text-align: right;
}

.text-xs {
    font-size: calc(0.75rem * var(--font-body-scale, 1));
    line-height: 1rem;
}

.text-sm {
    font-size: calc(0.875rem * var(--font-body-scale, 1));
    line-height: 1.25rem;
}

.text-base {
    font-size: calc(1rem * var(--font-body-scale, 1));
    line-height: 1.5rem;
}

.text-lg {
    font-size: calc(1.125rem * var(--font-body-scale, 1));
    line-height: 1.75rem;
}

.text-xl {
    font-size: calc(1.25rem * var(--font-body-scale, 1));
    line-height: 1.75rem;
}

.text-2xl {
    font-size: calc(1.5rem * var(--font-body-scale, 1));
    line-height: 2rem;
}

.text-3xl {
    font-size: calc(1.875rem * var(--font-body-scale, 1));
    line-height: 2.25rem;
}

.text-4xl {
    font-size: calc(2.25rem * var(--font-body-scale, 1));
    line-height: 2.5rem;
}

.text-5xl {
    font-size: calc(3rem * var(--font-body-scale, 1));
    line-height: 1;
}

.text-6xl {
    font-size: calc(3.75rem * var(--font-body-scale, 1));
    line-height: 1;
}

.text-7xl {
    font-size: calc(4.5rem * var(--font-body-scale, 1));
    line-height: 1;
}

.text-8xl {
    font-size: calc(6rem * var(--font-body-scale, 1));
    line-height: 1;
}

.text-9xl {
    font-size: calc(8rem * var(--font-body-scale, 1));
    line-height: 1;
}

.font-mono {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

.font-normal {
    font-weight: 400;
}

.font-medium {
    font-weight: 500;
}

.font-semibold {
    font-weight: 600;
}

.font-bold {
    font-weight: 700;
}

.font-extrabold {
    font-weight: 800;
}

.italic {
    font-style: italic;
}

.not-italic {
    font-style: normal;
}

.uppercase {
    text-transform: uppercase;
}

.capitalize {
    text-transform: capitalize;
}

.tracking-wider {
    letter-spacing: 0.05em;
}

.tracking-wide {
    letter-spacing: 0.025em;
}

.tracking-widest {
    letter-spacing: 0.1em;
}

.leading-tight {
    line-height: 1.25;
}

.leading-relaxed {
    line-height: 1.625;
}

.tabular-nums {
    font-variant-numeric: tabular-nums;
}

.whitespace-nowrap {
    white-space: nowrap;
}

.underline {
    text-decoration-line: underline;
}

.no-underline {
    text-decoration-line: none;
}

.line-through {
    text-decoration-line: line-through;
}

.underline-offset-2 {
    text-underline-offset: 2px;
}

.text-white {
    color: #fff;
}

.text-white\/70 {
    color: rgba(255, 255, 255, .7);
}

.text-green-600 {
    color: #16a34a;
}

.text-current {
    color: currentColor;
}

.fill-current {
    fill: currentColor;
}

.opacity-0 {
    opacity: 0;
}

.opacity-40 {
    opacity: .4;
}

.opacity-50 {
    opacity: .5;
}

.opacity-60 {
    opacity: .6;
}

.opacity-80 {
    opacity: .8;
}

.opacity-90 {
    opacity: .9;
}

.opacity-100 {
    opacity: 1;
}

.line-clamp-2,
.line-clamp-3 {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.line-clamp-2 {
    -webkit-line-clamp: 2;
}

.line-clamp-3 {
    -webkit-line-clamp: 3;
}

.list-none {
    list-style: none;
}

.list-disc {
    list-style: disc;
}

.list-decimal {
    list-style: decimal;
}

.transform {
    transform: translate(var(--tw-translate-x, 0), var(--tw-translate-y, 0)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.-translate-x-1\/2 {
    --tw-translate-x: -50%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y, 0)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.-translate-x-3 {
    --tw-translate-x: -0.75rem;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y, 0)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.-translate-x-4 {
    --tw-translate-x: -1rem;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y, 0)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.-translate-x-px {
    --tw-translate-x: -1px;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y, 0)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.-translate-y-1\/2 {
    --tw-translate-y: -50%;
    transform: translate(var(--tw-translate-x, 0), var(--tw-translate-y)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.translate-x-3 {
    --tw-translate-x: 0.75rem;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y, 0)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.translate-x-4 {
    --tw-translate-x: 1rem;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y, 0)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.translate-x-full {
    --tw-translate-x: 100%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y, 0)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.transition {
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
    transition-duration: 150ms;
    transition-timing-function: ease;
}

.transition-all {
    transition-property: all;
    transition-duration: 150ms;
    transition-timing-function: ease;
}

.transition-colors {
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
    transition-duration: 150ms;
    transition-timing-function: ease;
}

.transition-opacity {
    transition-property: opacity;
    transition-duration: 150ms;
    transition-timing-function: ease;
}

.transition-transform {
    transition-property: transform;
    transition-duration: 150ms;
    transition-timing-function: ease;
}

.duration-300 {
    transition-duration: 300ms;
}

.duration-500 {
    transition-duration: 500ms;
}

.duration-700 {
    transition-duration: 700ms;
}

.ease-in-out {
    transition-timing-function: ease-in-out;
}

.ease-out {
    transition-timing-function: ease-out;
}

.hover\:-translate-y-0\.5:hover {
    --tw-translate-y: -0.125rem;
    transform: translate(var(--tw-translate-x, 0), var(--tw-translate-y)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.hover\:bg-green-600:hover {
    background-color: #16a34a;
}

.hover\:bg-white\/10:hover {
    background-color: rgba(255, 255, 255, .1);
}

.hover\:bg-white\/20:hover {
    background-color: rgba(255, 255, 255, .2);
}

.hover\:opacity-70:hover {
    opacity: .7;
}

.hover\:opacity-80:hover {
    opacity: .8;
}

.hover\:opacity-90:hover {
    opacity: .9;
}

.hover\:opacity-100:hover {
    opacity: 1;
}

.hover\:scale-105:hover,
.group:hover .group-hover\:scale-105 {
    --tw-scale-x: 1.05;
    --tw-scale-y: 1.05;
    transform: translate(var(--tw-translate-x, 0), var(--tw-translate-y, 0)) scale(var(--tw-scale-x), var(--tw-scale-y));
}

.hover\:scale-110:hover {
    --tw-scale-x: 1.1;
    --tw-scale-y: 1.1;
    transform: translate(var(--tw-translate-x, 0), var(--tw-translate-y, 0)) scale(var(--tw-scale-x), var(--tw-scale-y));
}

.hover\:shadow-lg:hover {
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);
}

.hover\:text-current:hover {
    color: currentColor;
}

.hover\:underline:hover {
    text-decoration-line: underline;
}

.group:hover .group-hover\:opacity-70 {
    opacity: .7;
}

.group[open] .group-open\:rotate-180 {
    transform: rotate(180deg);
}

.focus\:outline-none:focus {
    outline: 2px solid transparent;
    outline-offset: 2px;
}

.focus\:border-current:focus {
    border-color: currentColor;
}

@media (min-width: 640px) {
    .sm\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .sm\:px-6 {
        padding-left: 1.5rem;
        padding-right: 1.5rem;
    }
}

@media (min-width: 768px) {
    .md\:block {
        display: block;
    }

    .md\:flex {
        display: flex;
    }

    .md\:hidden {
        display: none;
    }

    .md\:inline-flex {
        display: inline-flex;
    }

    .md\:flex-row {
        flex-direction: row;
    }

    .md\:flex-row-reverse {
        flex-direction: row-reverse;
    }

    .md\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .md\:grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .md\:grid-cols-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .md\:grid-cols-5 {
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }

    .md\:grid-cols-6 {
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }

    .md\:col-span-1 {
        grid-column: span 1 / span 1;
    }

    .md\:col-span-2 {
        grid-column: span 2 / span 2;
    }

    .md\:gap-4 {
        gap: 1rem;
    }

    .md\:gap-16 {
        gap: 4rem;
    }

    .md\:px-8 {
        padding-left: 2rem;
        padding-right: 2rem;
    }

    .md\:px-16 {
        padding-left: 4rem;
        padding-right: 4rem;
    }

    .md\:py-3 {
        padding-top: 0.75rem;
        padding-bottom: 0.75rem;
    }

    .md\:py-16 {
        padding-top: 4rem;
        padding-bottom: 4rem;
    }

    .md\:py-20 {
        padding-top: 5rem;
        padding-bottom: 5rem;
    }

    .md\:py-32 {
        padding-top: 8rem;
        padding-bottom: 8rem;
    }

    .md\:py-40 {
        padding-top: 10rem;
        padding-bottom: 10rem;
    }

    .md\:mb-6 {
        margin-bottom: 1.5rem;
    }

    .md\:mb-8 {
        margin-bottom: 2rem;
    }

    .md\:max-w-sm {
        max-width: 24rem;
    }

    .md\:w-1\/2 {
        width: 50%;
    }

    .md\:w-96 {
        width: 24rem;
    }

    .md\:text-sm {
        font-size: calc(0.875rem * var(--font-body-scale, 1));
        line-height: 1.25rem;
    }

    .md\:text-lg {
        font-size: calc(1.125rem * var(--font-body-scale, 1));
        line-height: 1.75rem;
    }

    .md\:text-xl {
        font-size: calc(1.25rem * var(--font-body-scale, 1));
        line-height: 1.75rem;
    }

    .md\:text-2xl {
        font-size: calc(1.5rem * var(--font-body-scale, 1));
        line-height: 2rem;
    }

    .md\:text-3xl {
        font-size: calc(1.875rem * var(--font-body-scale, 1));
        line-height: 2.25rem;
    }

    .md\:text-4xl {
        font-size: calc(2.25rem * var(--font-body-scale, 1));
        line-height: 2.5rem;
    }

    .md\:text-5xl {
        font-size: calc(3rem * var(--font-body-scale, 1));
        line-height: 1;
    }

    .md\:text-6xl {
        font-size: calc(3.75rem * var(--font-body-scale, 1));
        line-height: 1;
    }

    .md\:text-7xl {
        font-size: calc(4.5rem * var(--font-body-scale, 1));
        line-height: 1;
    }

    .md\:text-8xl {
        font-size: calc(6rem * var(--font-body-scale, 1));
        line-height: 1;
    }

    .md\:text-9xl {
        font-size: calc(8rem * var(--font-body-scale, 1));
        line-height: 1;
    }
}

@media (min-width: 1024px) {
    .lg\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .lg\:grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .lg\:grid-cols-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .lg\:grid-cols-5 {
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }

    .lg\:grid-cols-6 {
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }

    .lg\:order-1 {
        order: 1;
    }

    .lg\:order-2 {
        order: 2;
    }

    .lg\:px-8 {
        padding-left: 2rem;
        padding-right: 2rem;
    }

    .lg\:px-24 {
        padding-left: 6rem;
        padding-right: 6rem;
    }
}


/* ─── Loom custom utility aliases (generated from section migration)
   These are Loom-owned class names used by files in sections/*.liquid.
   Do not add Tailwind CDN back; add new section classes here or in section CSS.
*/
/* ─── Loom utility layer ───────────────────────────────────────────────
   Theme-owned replacements for the Tailwind CDN utilities used by Loom.
   Keep this layer small and predictable; section-specific CSS should still
   live beside the section that owns it.
*/
.loom-antialiased {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.loom-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}

.loom-static {
    position: static;
}

.loom-fixed {
    position: fixed;
}

.loom-absolute {
    position: absolute;
}

.loom-relative {
    position: relative;
}

.loom-sticky {
    position: sticky;
}

.loom-inset-0 {
    inset: 0;
}

.loom-top-0 {
    top: 0;
}

.loom-top-1-2 {
    top: 50%;
}

.loom-top-5 {
    top: 1.25rem;
}

.loom-right-0 {
    right: 0;
}

.loom-right-3 {
    right: 0.75rem;
}

.loom-right-6 {
    right: 1.5rem;
}

.loom-neg-right-2 {
    right: -0.5rem;
}

.loom-bottom-6 {
    bottom: 1.5rem;
}

.loom-left-0 {
    left: 0;
}

.loom-left-1-2 {
    left: 50%;
}

.loom-neg-top-2 {
    top: -0.5rem;
}

.loom-z-0 {
    z-index: 0;
}

.loom-z-10 {
    z-index: 10;
}

.loom-z-50 {
    z-index: 50;
}

.loom-z-1 {
    z-index: 1;
}

.loom-z-2 {
    z-index: 2;
}

.loom-z-90 {
    z-index: 90;
}

.loom-z-100 {
    z-index: 100;
}

.loom-block {
    display: block;
}

.loom-inline-block {
    display: inline-block;
}

.loom-inline-flex {
    display: inline-flex;
}

.loom-flex {
    display: flex;
}

.loom-inline-grid {
    display: inline-grid;
}

.loom-grid {
    display: grid;
}

.loom-hidden {
    display: none;
}

.loom-contents {
    display: contents;
}

.loom-flex-row {
    flex-direction: row;
}

.loom-flex-col {
    flex-direction: column;
}

.loom-flex-wrap {
    flex-wrap: wrap;
}

.loom-flex-1 {
    flex: 1 1 0%;
}

.loom-flex-shrink-0,
.loom-shrink-0 {
    flex-shrink: 0;
}

.loom-items-start {
    align-items: flex-start;
}

.loom-items-left {
    align-items: flex-start;
}

.loom-items-center {
    align-items: center;
}

.loom-items-right {
    align-items: flex-end;
}

.loom-items-end {
    align-items: flex-end;
}

.loom-items-stretch {
    align-items: stretch;
}

.loom-justify-start {
    justify-content: flex-start;
}

.loom-justify-center {
    justify-content: center;
}

.loom-justify-end {
    justify-content: flex-end;
}

.loom-justify-between {
    justify-content: space-between;
}

.loom-justify-self-center {
    justify-self: center;
}

.loom-order-1 {
    order: 1;
}

.loom-order-2 {
    order: 2;
}

.loom-gap-0_5 {
    gap: 0.125rem;
}

.loom-gap-1 {
    gap: 0.25rem;
}

.loom-gap-1_5 {
    gap: 0.375rem;
}

.loom-gap-2 {
    gap: 0.5rem;
}

.loom-gap-3 {
    gap: 0.75rem;
}

.loom-gap-4 {
    gap: 1rem;
}

.loom-gap-5 {
    gap: 1.25rem;
}

.loom-gap-6 {
    gap: 1.5rem;
}

.loom-gap-8 {
    gap: 2rem;
}

.loom-gap-10 {
    gap: 2.5rem;
}

.loom-gap-12 {
    gap: 3rem;
}

.loom-grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
}

.loom-grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.loom-grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.loom-grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.loom-grid-cols-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.loom-grid-cols-6 {
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.loom-col-span-1 {
    grid-column: span 1 / span 1;
}

.loom-col-span-2 {
    grid-column: span 2 / span 2;
}

.loom-col-span-3 {
    grid-column: span 3 / span 3;
}

.loom-col-span-4 {
    grid-column: span 4 / span 4;
}

.loom-col-span-5 {
    grid-column: span 5 / span 5;
}

.loom-col-span-6 {
    grid-column: span 6 / span 6;
}

.loom-row-span-1 {
    grid-row: span 1 / span 1;
}

.loom-row-span-2 {
    grid-row: span 2 / span 2;
}

.loom-row-span-3 {
    grid-row: span 3 / span 3;
}

.loom-row-span-4 {
    grid-row: span 4 / span 4;
}

.loom-row-span-5 {
    grid-row: span 5 / span 5;
}

.loom-row-span-6 {
    grid-row: span 6 / span 6;
}

.loom-aspect-square {
    aspect-ratio: 1 / 1;
}

.loom-aspect-video {
    aspect-ratio: 16 / 9;
}

.loom-aspect-4-3 {
    aspect-ratio: 4 / 3;
}

.loom-aspect-4-5 {
    aspect-ratio: 4 / 5;
}

.loom-h-0_5 {
    height: 0.125rem;
}

.loom-h-3 {
    height: 0.75rem;
}

.loom-h-4 {
    height: 1rem;
}

.loom-h-5 {
    height: 1.25rem;
}

.loom-h-6 {
    height: 1.5rem;
}

.loom-h-7 {
    height: 1.75rem;
}

.loom-h-10 {
    height: 2.5rem;
}

.loom-h-12 {
    height: 3rem;
}

.loom-h-14 {
    height: 3.5rem;
}

.loom-h-16 {
    height: 4rem;
}

.loom-h-20 {
    height: 5rem;
}

.loom-h-auto {
    height: auto;
}

.loom-h-full {
    height: 100%;
}

.loom-h-screen {
    height: 100vh;
}

.loom-h-200px {
    height: 200px;
}

.loom-h-400px {
    height: 400px;
}

.loom-h-600px {
    height: 600px;
}

.loom-min-h-200px {
    min-height: 200px;
}

.loom-max-h-calc100pct-56px {
    max-height: calc(100% - 56px);
}

.loom-w-3 {
    width: 0.75rem;
}

.loom-w-4 {
    width: 1rem;
}

.loom-w-5 {
    width: 1.25rem;
}

.loom-w-6 {
    width: 1.5rem;
}

.loom-w-7 {
    width: 1.75rem;
}

.loom-w-10 {
    width: 2.5rem;
}

.loom-w-12 {
    width: 3rem;
}

.loom-w-14 {
    width: 3.5rem;
}

.loom-w-16 {
    width: 4rem;
}

.loom-w-20 {
    width: 5rem;
}

.loom-w-32 {
    width: 8rem;
}

.loom-w-48 {
    width: 12rem;
}

.loom-w-72 {
    width: 18rem;
}

.loom-w-80 {
    width: 20rem;
}

.loom-w-1-2 {
    width: 50%;
}

.loom-w-3-4 {
    width: 75%;
}

.loom-w-auto {
    width: auto;
}

.loom-w-full {
    width: 100%;
}

.loom-w-px {
    width: 1px;
}

.loom-max-w-xs {
    max-width: 20rem;
}

.loom-max-w-md {
    max-width: 28rem;
}

.loom-max-w-lg {
    max-width: 32rem;
}

.loom-max-w-xl {
    max-width: 36rem;
}

.loom-max-w-2xl {
    max-width: 42rem;
}

.loom-max-w-3xl {
    max-width: 48rem;
}

.loom-max-w-4xl {
    max-width: 56rem;
}

.loom-max-w-6xl {
    max-width: 72rem;
}

.loom-max-w-full {
    max-width: 100%;
}

.loom-max-w-none {
    max-width: none;
}

.loom-min-w-200px {
    min-width: 200px;
}

.loom-m-0 {
    margin: 0;
}

.loom-mx-auto {
    margin-left: auto;
    margin-right: auto;
}

.loom-mx-2 {
    margin-left: 0.5rem;
    margin-right: 0.5rem;
}

.loom-my-6 {
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
}

.loom-mt-0_5 {
    margin-top: 0.125rem;
}

.loom-mt-1 {
    margin-top: 0.25rem;
}

.loom-mt-2 {
    margin-top: 0.5rem;
}

.loom-mt-3 {
    margin-top: 0.75rem;
}

.loom-mt-4 {
    margin-top: 1rem;
}

.loom-mt-6 {
    margin-top: 1.5rem;
}

.loom-mt-8 {
    margin-top: 2rem;
}

.loom-mt-12 {
    margin-top: 3rem;
}

.loom-mb-1 {
    margin-bottom: 0.25rem;
}

.loom-mb-1_5 {
    margin-bottom: 0.375rem;
}

.loom-mb-2 {
    margin-bottom: 0.5rem;
}

.loom-mb-3 {
    margin-bottom: 0.75rem;
}

.loom-mb-4 {
    margin-bottom: 1rem;
}

.loom-mb-5 {
    margin-bottom: 1.25rem;
}

.loom-mb-6 {
    margin-bottom: 1.5rem;
}

.loom-mb-8 {
    margin-bottom: 2rem;
}

.loom-mb-10 {
    margin-bottom: 2.5rem;
}

.loom-mb-12 {
    margin-bottom: 3rem;
}

.loom-mb-14 {
    margin-bottom: 3.5rem;
}

.loom-ml-0_5 {
    margin-left: 0.125rem;
}

.loom-ml-1 {
    margin-left: 0.25rem;
}

.loom-ml-2 {
    margin-left: 0.5rem;
}

.loom-p-4 {
    padding: 1rem;
}

.loom-p-5 {
    padding: 1.25rem;
}

.loom-p-6 {
    padding: 1.5rem;
}

.loom-p-8 {
    padding: 2rem;
}

.loom-px-1 {
    padding-left: 0.25rem;
    padding-right: 0.25rem;
}

.loom-px-2 {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.loom-px-3 {
    padding-left: 0.75rem;
    padding-right: 0.75rem;
}

.loom-px-4 {
    padding-left: 1rem;
    padding-right: 1rem;
}

.loom-px-5 {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
}

.loom-px-6 {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

.loom-px-8 {
    padding-left: 2rem;
    padding-right: 2rem;
}

.loom-px-10 {
    padding-left: 2.5rem;
    padding-right: 2.5rem;
}

.loom-py-0_5 {
    padding-top: 0.125rem;
    padding-bottom: 0.125rem;
}

.loom-py-1 {
    padding-top: 0.25rem;
    padding-bottom: 0.25rem;
}

.loom-py-1_5 {
    padding-top: 0.375rem;
    padding-bottom: 0.375rem;
}

.loom-py-2 {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

.loom-py-2_5 {
    padding-top: 0.625rem;
    padding-bottom: 0.625rem;
}

.loom-py-3 {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}

.loom-py-4 {
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.loom-py-5 {
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
}

.loom-py-6 {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
}

.loom-py-8 {
    padding-top: 2rem;
    padding-bottom: 2rem;
}

.loom-py-12 {
    padding-top: 3rem;
    padding-bottom: 3rem;
}

.loom-py-16 {
    padding-top: 4rem;
    padding-bottom: 4rem;
}

.loom-py-20 {
    padding-top: 5rem;
    padding-bottom: 5rem;
}

.loom-pt-1 {
    padding-top: 0.25rem;
}

.loom-pt-2 {
    padding-top: 0.5rem;
}

.loom-pt-3 {
    padding-top: 0.75rem;
}

.loom-pt-6 {
    padding-top: 1.5rem;
}

.loom-pt-8 {
    padding-top: 2rem;
}

.loom-pb-4 {
    padding-bottom: 1rem;
}

.loom-pb-5 {
    padding-bottom: 1.25rem;
}

.loom-pb-6 {
    padding-bottom: 1.5rem;
}

.loom-pb-12 {
    padding-bottom: 3rem;
}

.loom-pb-px {
    padding-bottom: 1px;
}

.loom-pl-3 {
    padding-left: 0.75rem;
}

.loom-pl-4 {
    padding-left: 1rem;
}

.loom-pl-6 {
    padding-left: 1.5rem;
}

.loom-pl-8 {
    padding-left: 2rem;
}

.loom-pr-8 {
    padding-right: 2rem;
}

.loom-pr-12 {
    padding-right: 3rem;
}

.loom-space-y-0_5>*+* {
    margin-top: 0.125rem;
}

.loom-space-y-1>*+* {
    margin-top: 0.25rem;
}

.loom-space-y-2>*+* {
    margin-top: 0.5rem;
}

.loom-space-y-3>*+* {
    margin-top: 0.75rem;
}

.loom-space-y-4>*+* {
    margin-top: 1rem;
}

.loom-overflow-hidden {
    overflow: hidden;
}

.loom-overflow-y-auto {
    overflow-y: auto;
}

.loom-resize-none {
    resize: none;
}

.loom-object-cover {
    object-fit: cover;
}

.loom-object-contain {
    object-fit: contain;
}

.loom-pointer-events-none {
    pointer-events: none;
}

.loom-cursor-pointer {
    cursor: pointer;
}

.loom-border {
    border: 1px solid var(--border, rgba(10, 10, 10, 0.08));
}

.loom-border-2 {
    border-width: 2px;
}

.loom-border-t {
    border-top: 1px solid var(--border, rgba(10, 10, 10, 0.08));
}

.loom-border-current {
    border-color: currentColor;
}

.loom-rounded-md {
    border-radius: 0.375rem;
}

.loom-rounded {
    border-radius: 0.25rem;
}

.loom-rounded-none {
    border-radius: 0;
}

.loom-rounded-lg {
    border-radius: 0.5rem;
}

.loom-rounded-xl {
    border-radius: 0.75rem;
}

.loom-rounded-full {
    border-radius: 9999px;
}

.loom-shadow-lg {
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);
}

.loom-shadow-xl {
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);
}

.loom-shadow-2xl {
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, .25);
}

.loom-bg-white {
    background-color: #fff;
}

.loom-bg-white-10 {
    background-color: rgba(255, 255, 255, .1);
}

.loom-bg-black-40 {
    background-color: rgba(0, 0, 0, .4);
}

.loom-bg-green-500 {
    background-color: #22c55e;
}

.loom-bg-gradient-to-t {
    background-image: linear-gradient(to top, var(--loom-gradient-stops));
}

.loom-from-black-60 {
    --loom-gradient-from: rgba(0, 0, 0, .6);
    --loom-gradient-stops: var(--loom-gradient-from), var(--loom-gradient-to, transparent);
}

.loom-from-black-70 {
    --loom-gradient-from: rgba(0, 0, 0, .7);
    --loom-gradient-stops: var(--loom-gradient-from), var(--loom-gradient-to, transparent);
}

.loom-via-black-10 {
    --loom-gradient-stops: var(--loom-gradient-from), rgba(0, 0, 0, .1), var(--loom-gradient-to, transparent);
}

.loom-to-transparent {
    --loom-gradient-to: transparent;
}

.loom-backdrop-blur-sm {
    backdrop-filter: blur(4px);
}

.loom-backdrop-blur-md {
    backdrop-filter: blur(12px);
}

.loom-text-left {
    text-align: left;
}

.loom-text-center {
    text-align: center;
}

.loom-text-right {
    text-align: right;
}

.loom-text-xs {
    font-size: calc(0.75rem * var(--font-body-scale, 1));
    line-height: 1rem;
}

.loom-text-sm {
    font-size: calc(0.875rem * var(--font-body-scale, 1));
    line-height: 1.25rem;
}

.loom-text-base {
    font-size: calc(1rem * var(--font-body-scale, 1));
    line-height: 1.5rem;
}

.loom-text-lg {
    font-size: calc(1.125rem * var(--font-body-scale, 1));
    line-height: 1.75rem;
}

.loom-text-xl {
    font-size: calc(1.25rem * var(--font-body-scale, 1));
    line-height: 1.75rem;
}

.loom-text-2xl {
    font-size: calc(1.5rem * var(--font-body-scale, 1));
    line-height: 2rem;
}

.loom-text-3xl {
    font-size: calc(1.875rem * var(--font-body-scale, 1));
    line-height: 2.25rem;
}

.loom-text-4xl {
    font-size: calc(2.25rem * var(--font-body-scale, 1));
    line-height: 2.5rem;
}

.loom-text-5xl {
    font-size: calc(3rem * var(--font-body-scale, 1));
    line-height: 1;
}

.loom-text-6xl {
    font-size: calc(3.75rem * var(--font-body-scale, 1));
    line-height: 1;
}

.loom-text-7xl {
    font-size: calc(4.5rem * var(--font-body-scale, 1));
    line-height: 1;
}

.loom-text-8xl {
    font-size: calc(6rem * var(--font-body-scale, 1));
    line-height: 1;
}

.loom-text-9xl {
    font-size: calc(8rem * var(--font-body-scale, 1));
    line-height: 1;
}

.loom-font-mono {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

.loom-font-normal {
    font-weight: 400;
}

.loom-font-medium {
    font-weight: 500;
}

.loom-font-semibold {
    font-weight: 600;
}

.loom-font-bold {
    font-weight: 700;
}

.loom-font-extrabold {
    font-weight: 800;
}

.loom-italic {
    font-style: italic;
}

.loom-not-italic {
    font-style: normal;
}

.loom-uppercase {
    text-transform: uppercase;
}

.loom-capitalize {
    text-transform: capitalize;
}

.loom-tracking-wider {
    letter-spacing: 0.05em;
}

.loom-tracking-wide {
    letter-spacing: 0.025em;
}

.loom-tracking-widest {
    letter-spacing: 0.1em;
}

.loom-leading-tight {
    line-height: 1.25;
}

.loom-leading-relaxed {
    line-height: 1.625;
}

.loom-tabular-nums {
    font-variant-numeric: tabular-nums;
}

.loom-whitespace-nowrap {
    white-space: nowrap;
}

.loom-underline {
    text-decoration-line: underline;
}

.loom-no-underline {
    text-decoration-line: none;
}

.loom-line-through {
    text-decoration-line: line-through;
}

.loom-underline-offset-2 {
    text-underline-offset: 2px;
}

.loom-text-white {
    color: #fff;
}

.loom-text-white-70 {
    color: rgba(255, 255, 255, .7);
}

.loom-text-green-600 {
    color: #16a34a;
}

.loom-text-current {
    color: currentColor;
}

.loom-fill-current {
    fill: currentColor;
}

.loom-opacity-0 {
    opacity: 0;
}

.loom-opacity-40 {
    opacity: .4;
}

.loom-opacity-50 {
    opacity: .5;
}

.loom-opacity-60 {
    opacity: .6;
}

.loom-opacity-80 {
    opacity: .8;
}

.loom-opacity-90 {
    opacity: .9;
}

.loom-opacity-100 {
    opacity: 1;
}

.loom-line-clamp-2,
.loom-line-clamp-3 {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.loom-line-clamp-2 {
    -webkit-line-clamp: 2;
}

.loom-line-clamp-3 {
    -webkit-line-clamp: 3;
}

.loom-list-none {
    list-style: none;
}

.loom-list-disc {
    list-style: disc;
}

.loom-list-decimal {
    list-style: decimal;
}

.loom-transform {
    transform: translate(var(--tw-translate-x, 0), var(--tw-translate-y, 0)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.loom-neg-translate-x-1-2 {
    --tw-translate-x: -50%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y, 0)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.loom-neg-translate-x-3 {
    --tw-translate-x: -0.75rem;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y, 0)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.loom-neg-translate-x-4 {
    --tw-translate-x: -1rem;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y, 0)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.loom-neg-translate-x-px {
    --tw-translate-x: -1px;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y, 0)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.loom-neg-translate-y-1-2 {
    --tw-translate-y: -50%;
    transform: translate(var(--tw-translate-x, 0), var(--tw-translate-y)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.loom-translate-x-3 {
    --tw-translate-x: 0.75rem;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y, 0)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.loom-translate-x-4 {
    --tw-translate-x: 1rem;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y, 0)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.loom-translate-x-full {
    --tw-translate-x: 100%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y, 0)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.loom-transition {
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
    transition-duration: 150ms;
    transition-timing-function: ease;
}

.loom-transition-all {
    transition-property: all;
    transition-duration: 150ms;
    transition-timing-function: ease;
}

.loom-transition-colors {
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
    transition-duration: 150ms;
    transition-timing-function: ease;
}

.loom-transition-opacity {
    transition-property: opacity;
    transition-duration: 150ms;
    transition-timing-function: ease;
}

.loom-transition-transform {
    transition-property: transform;
    transition-duration: 150ms;
    transition-timing-function: ease;
}

.loom-duration-300 {
    transition-duration: 300ms;
}

.loom-duration-500 {
    transition-duration: 500ms;
}

.loom-duration-700 {
    transition-duration: 700ms;
}

.loom-ease-in-out {
    transition-timing-function: ease-in-out;
}

.loom-ease-out {
    transition-timing-function: ease-out;
}

.hover\:-translate-y-0\.loom-5:hover {
    --tw-translate-y: -0.125rem;
    transform: translate(var(--tw-translate-x, 0), var(--tw-translate-y)) scale(var(--tw-scale-x, 1), var(--tw-scale-y, 1));
}

.loom-hover-bg-green-600:hover {
    background-color: #16a34a;
}

.loom-hover-bg-white-10:hover {
    background-color: rgba(255, 255, 255, .1);
}

.loom-hover-bg-white-20:hover {
    background-color: rgba(255, 255, 255, .2);
}

.loom-hover-opacity-70:hover {
    opacity: .7;
}

.loom-hover-opacity-80:hover {
    opacity: .8;
}

.loom-hover-opacity-90:hover {
    opacity: .9;
}

.loom-hover-opacity-100:hover {
    opacity: 1;
}

.loom-hover-scale-105:hover,
.loom-group:hover .loom-group-hover-scale-105 {
    --tw-scale-x: 1.05;
    --tw-scale-y: 1.05;
    transform: translate(var(--tw-translate-x, 0), var(--tw-translate-y, 0)) scale(var(--tw-scale-x), var(--tw-scale-y));
}

.loom-hover-scale-110:hover {
    --tw-scale-x: 1.1;
    --tw-scale-y: 1.1;
    transform: translate(var(--tw-translate-x, 0), var(--tw-translate-y, 0)) scale(var(--tw-scale-x), var(--tw-scale-y));
}

.loom-hover-shadow-lg:hover {
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);
}

.loom-hover-text-current:hover {
    color: currentColor;
}

.loom-hover-underline:hover {
    text-decoration-line: underline;
}

.loom-group:hover .loom-group-hover-opacity-70 {
    opacity: .7;
}

.loom-group[open] .loom-group-open-rotate-180 {
    transform: rotate(180deg);
}

.loom-focus-outline-none:focus {
    outline: 2px solid transparent;
    outline-offset: 2px;
}

.loom-focus-border-current:focus {
    border-color: currentColor;
}

.loom-sm-grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.loom-sm-px-6 {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

.loom-md-block {
    display: block;
}

.loom-md-flex {
    display: flex;
}

.loom-md-hidden {
    display: none;
}

.loom-md-inline-flex {
    display: inline-flex;
}

.loom-md-flex-row {
    flex-direction: row;
}

.loom-md-flex-row-reverse {
    flex-direction: row-reverse;
}

.loom-md-grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.loom-md-grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.loom-md-grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.loom-md-grid-cols-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.loom-md-grid-cols-6 {
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.loom-md-col-span-1 {
    grid-column: span 1 / span 1;
}

.loom-md-col-span-2 {
    grid-column: span 2 / span 2;
}

.loom-md-gap-4 {
    gap: 1rem;
}

.loom-md-gap-16 {
    gap: 4rem;
}

.loom-md-px-8 {
    padding-left: 2rem;
    padding-right: 2rem;
}

.loom-md-px-16 {
    padding-left: 4rem;
    padding-right: 4rem;
}

.loom-md-py-3 {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}

.loom-md-py-16 {
    padding-top: 4rem;
    padding-bottom: 4rem;
}

.loom-md-py-20 {
    padding-top: 5rem;
    padding-bottom: 5rem;
}

.loom-md-py-32 {
    padding-top: 8rem;
    padding-bottom: 8rem;
}

.loom-md-py-40 {
    padding-top: 10rem;
    padding-bottom: 10rem;
}

.loom-md-mb-6 {
    margin-bottom: 1.5rem;
}

.loom-md-mb-8 {
    margin-bottom: 2rem;
}

.loom-md-max-w-sm {
    max-width: 24rem;
}

.loom-md-w-1-2 {
    width: 50%;
}

.loom-md-w-96 {
    width: 24rem;
}

.loom-md-text-sm {
    font-size: calc(0.875rem * var(--font-body-scale, 1));
    line-height: 1.25rem;
}

.loom-md-text-lg {
    font-size: calc(1.125rem * var(--font-body-scale, 1));
    line-height: 1.75rem;
}

.loom-md-text-xl {
    font-size: calc(1.25rem * var(--font-body-scale, 1));
    line-height: 1.75rem;
}

.loom-md-text-2xl {
    font-size: calc(1.5rem * var(--font-body-scale, 1));
    line-height: 2rem;
}

.loom-md-text-3xl {
    font-size: calc(1.875rem * var(--font-body-scale, 1));
    line-height: 2.25rem;
}

.loom-md-text-4xl {
    font-size: calc(2.25rem * var(--font-body-scale, 1));
    line-height: 2.5rem;
}

.loom-md-text-5xl {
    font-size: calc(3rem * var(--font-body-scale, 1));
    line-height: 1;
}

.loom-md-text-6xl {
    font-size: calc(3.75rem * var(--font-body-scale, 1));
    line-height: 1;
}

.loom-md-text-7xl {
    font-size: calc(4.5rem * var(--font-body-scale, 1));
    line-height: 1;
}

.loom-md-text-8xl {
    font-size: calc(6rem * var(--font-body-scale, 1));
    line-height: 1;
}

.loom-md-text-9xl {
    font-size: calc(8rem * var(--font-body-scale, 1));
    line-height: 1;
}

:where(h1, h2, h3, h4, h5, h6):is(.text-xs, .loom-text-xs) {
    font-size: calc(0.75rem * var(--font-heading-scale, 1));
}

:where(h1, h2, h3, h4, h5, h6):is(.text-sm, .loom-text-sm) {
    font-size: calc(0.875rem * var(--font-heading-scale, 1));
}

:where(h1, h2, h3, h4, h5, h6):is(.text-base, .loom-text-base) {
    font-size: calc(1rem * var(--font-heading-scale, 1));
}

:where(h1, h2, h3, h4, h5, h6):is(.text-lg, .loom-text-lg) {
    font-size: calc(1.125rem * var(--font-heading-scale, 1));
}

:where(h1, h2, h3, h4, h5, h6):is(.text-xl, .loom-text-xl) {
    font-size: calc(1.25rem * var(--font-heading-scale, 1));
}

:where(h1, h2, h3, h4, h5, h6):is(.text-2xl, .loom-text-2xl) {
    font-size: calc(1.5rem * var(--font-heading-scale, 1));
}

:where(h1, h2, h3, h4, h5, h6):is(.text-3xl, .loom-text-3xl) {
    font-size: calc(1.875rem * var(--font-heading-scale, 1));
}

:where(h1, h2, h3, h4, h5, h6):is(.text-4xl, .loom-text-4xl) {
    font-size: calc(2.25rem * var(--font-heading-scale, 1));
}

:where(h1, h2, h3, h4, h5, h6):is(.text-5xl, .loom-text-5xl) {
    font-size: calc(3rem * var(--font-heading-scale, 1));
}

:where(h1, h2, h3, h4, h5, h6):is(.text-6xl, .loom-text-6xl) {
    font-size: calc(3.75rem * var(--font-heading-scale, 1));
}

:where(h1, h2, h3, h4, h5, h6):is(.text-7xl, .loom-text-7xl) {
    font-size: calc(4.5rem * var(--font-heading-scale, 1));
}

:where(h1, h2, h3, h4, h5, h6):is(.text-8xl, .loom-text-8xl) {
    font-size: calc(6rem * var(--font-heading-scale, 1));
}

:where(h1, h2, h3, h4, h5, h6):is(.text-9xl, .loom-text-9xl) {
    font-size: calc(8rem * var(--font-heading-scale, 1));
}

@media (min-width: 768px) {
    :where(h1, h2, h3, h4, h5, h6):is(.md\:text-sm, .loom-md-text-sm) {
        font-size: calc(0.875rem * var(--font-heading-scale, 1));
    }

    :where(h1, h2, h3, h4, h5, h6):is(.md\:text-lg, .loom-md-text-lg) {
        font-size: calc(1.125rem * var(--font-heading-scale, 1));
    }

    :where(h1, h2, h3, h4, h5, h6):is(.md\:text-xl, .loom-md-text-xl) {
        font-size: calc(1.25rem * var(--font-heading-scale, 1));
    }

    :where(h1, h2, h3, h4, h5, h6):is(.md\:text-2xl, .loom-md-text-2xl) {
        font-size: calc(1.5rem * var(--font-heading-scale, 1));
    }

    :where(h1, h2, h3, h4, h5, h6):is(.md\:text-3xl, .loom-md-text-3xl) {
        font-size: calc(1.875rem * var(--font-heading-scale, 1));
    }

    :where(h1, h2, h3, h4, h5, h6):is(.md\:text-4xl, .loom-md-text-4xl) {
        font-size: calc(2.25rem * var(--font-heading-scale, 1));
    }

    :where(h1, h2, h3, h4, h5, h6):is(.md\:text-5xl, .loom-md-text-5xl) {
        font-size: calc(3rem * var(--font-heading-scale, 1));
    }

    :where(h1, h2, h3, h4, h5, h6):is(.md\:text-6xl, .loom-md-text-6xl) {
        font-size: calc(3.75rem * var(--font-heading-scale, 1));
    }

    :where(h1, h2, h3, h4, h5, h6):is(.md\:text-7xl, .loom-md-text-7xl) {
        font-size: calc(4.5rem * var(--font-heading-scale, 1));
    }

    :where(h1, h2, h3, h4, h5, h6):is(.md\:text-8xl, .loom-md-text-8xl) {
        font-size: calc(6rem * var(--font-heading-scale, 1));
    }

    :where(h1, h2, h3, h4, h5, h6):is(.md\:text-9xl, .loom-md-text-9xl) {
        font-size: calc(8rem * var(--font-heading-scale, 1));
    }
}

.loom-lg-grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.loom-lg-grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.loom-lg-grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.loom-lg-grid-cols-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.loom-lg-grid-cols-6 {
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.loom-lg-order-1 {
    order: 1;
}

.loom-lg-order-2 {
    order: 2;
}

.loom-lg-px-8 {
    padding-left: 2rem;
    padding-right: 2rem;
}

.loom-lg-px-24 {
    padding-left: 6rem;
    padding-right: 6rem;
}

/* Theme layout settings: keep these after utility aliases so global layout
   controls remain consistent across merchant pages and templates. */
.theme-main>section+section {
    margin-top: var(--section-spacing, 0px);
}

.theme-main .grid,
.theme-main .loom-grid {
    column-gap: var(--grid-horizontal-spacing, 8px);
    row-gap: var(--grid-vertical-spacing, 8px);
}