:root {
    --shop-bg: #f6f5fb;
    --shop-panel: #ffffff;
    --shop-text: #202332;
    --shop-muted: #6f7688;
    --shop-border: #eceaf3;
    --shop-primary: #6c5ce7;
    --shop-primary-dark: #5847d7;
    --shop-green: #4aa36f;
    --shop-radius: 18px;
    --shop-shadow: 0 20px 50px rgba(30, 29, 55, 0.08);
}

/* Premium client storefront */
body.sr-client {
    background: var(--shop-bg, #ffffff);
    color: var(--shop-text, #171717);
    font-family: var(--sr-client-font, "Inter", "Helvetica Neue", Arial, sans-serif);
    font-size: var(--sr-base-font-size, 16px);
    line-height: var(--sr-line-height, 1.5);
}

body.sr-client h1,
body.sr-client h2,
body.sr-client h3,
body.sr-client h4 {
    font-family: var(--sr-heading-font, var(--sr-client-font, "Inter", "Helvetica Neue", Arial, sans-serif));
}

body.sr-menu-open,
body.sr-modal-open,
body.sr-search-open {
    overflow: hidden;
}

.sr-header {
    position: sticky;
    top: 0;
    z-index: 40;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    align-items: center;
    min-height: 88px;
    padding: 12px clamp(18px, 4vw, 64px);
    border-bottom: 1px solid #e8e8e8;
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(14px);
    color: #171717;
    transition: transform 220ms ease, background 220ms ease, color 220ms ease, border-color 220ms ease;
    will-change: transform;
}

.sr-header.is-hidden {
    transform: translateY(-100%);
}

.sr-header.is-hero {
    position: fixed;
    inset-inline: 0;
    border-bottom: 0;
    background: transparent;
    backdrop-filter: none;
    color: #ffffff;
}

.sr-header.is-hero.is-scrolled,
.sr-header.is-hero:focus-within,
.sr-header.is-hero:hover {
    border-bottom: 1px solid #e8e8e8;
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(14px);
    color: #171717;
}

.sr-header-side,
.sr-header-actions,
.sr-header-search {
    display: flex;
    align-items: center;
    gap: 15px;
}

.sr-header-actions {
    justify-content: flex-end;
}

.sr-language-form {
    display: inline-flex;
    align-items: center;
    margin: 0;
}

.sr-menu-language-form {
    display: none;
}

.sr-language-form label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: inherit;
    font-size: 12px;
    font-weight: 500;
}

.sr-language-form label > span {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
}

.sr-language-form select {
    min-height: 30px;
    padding: 0 26px 0 10px;
    border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
    border-radius: 999px;
    background: transparent;
    color: inherit;
    font: inherit;
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
}

.sr-language-segment {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    min-height: 32px;
    padding: 3px;
    border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
    border-radius: 999px;
    background: color-mix(in srgb, currentColor 6%, transparent);
}

.sr-language-option {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-height: 24px;
    padding: 0 8px;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: inherit;
    cursor: pointer;
    font: inherit;
    font-size: 11px;
    font-weight: 500;
}

.sr-language-option.is-active {
    background: #ffffff;
    color: #171717;
}

.sr-language-flag {
    display: inline-block;
    width: 18px;
    height: 12px;
    overflow: hidden;
    border-radius: 2px;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.12);
}

.sr-language-flag.is-fr {
    background: linear-gradient(90deg, #244aa5 0 33.33%, #ffffff 33.33% 66.66%, #e5413c 66.66% 100%);
}

.sr-language-flag.is-en {
    background:
        linear-gradient(90deg, transparent 42%, #ffffff 42% 58%, transparent 58%),
        linear-gradient(0deg, transparent 38%, #ffffff 38% 62%, transparent 62%),
        linear-gradient(90deg, transparent 46%, #c8102e 46% 54%, transparent 54%),
        linear-gradient(0deg, transparent 43%, #c8102e 43% 57%, transparent 57%),
        #012169;
}

.sr-menu-button,
.sr-header-search,
.sr-theme-toggle,
.sr-modal-close {
    border: 0;
    background: transparent;
    color: inherit;
    cursor: pointer;
    font: inherit;
}

.sr-menu-button {
    display: grid;
    gap: 4px;
    width: 15px;
    padding: 4px 0;
}

.sr-menu-button span {
    display: block;
    height: 1.4px;
    background: currentColor;
}

.sr-menu-label,
.sr-header-actions a,
.sr-header-search,
.sr-theme-toggle {
    color: inherit;
    font-size: 12px;
    font-weight: 500;
    text-decoration: none;
}

.sr-header-search,
.sr-theme-toggle {
    padding: 0;
}

.sr-theme-toggle,
.sr-menu-theme-toggle {
    display: inline-flex;
    align-items: center;
    gap: 9px;
}

.sr-theme-label {
    display: none;
}

.sr-theme-switch {
    position: relative;
    display: inline-flex;
    align-items: center;
    width: 50px;
    height: 26px;
    border-radius: 999px;
    background: #bdbdbd;
    transition: background 180ms ease;
}

.sr-theme-knob {
    position: absolute;
    top: 3px;
    right: 3px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: #ffffff;
    transition: transform 180ms ease;
}

.sr-theme-icon {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    color: #ffffff;
    pointer-events: none;
}

.sr-theme-icon.is-sun {
    left: 14px;
    width: 4px;
    height: 4px;
    border: 2px solid currentColor;
    border-radius: 50%;
}

.sr-theme-icon.is-sun::before {
    content: "";
    position: absolute;
    inset: -8px;
    background:
        linear-gradient(currentColor 0 0) 50% 0 / 2px 4px no-repeat,
        linear-gradient(currentColor 0 0) 50% 100% / 2px 4px no-repeat,
        linear-gradient(currentColor 0 0) 0 50% / 4px 2px no-repeat,
        linear-gradient(currentColor 0 0) 100% 50% / 4px 2px no-repeat;
}

.sr-theme-icon.is-sun::after {
    content: "";
    position: absolute;
    inset: -7px;
    background:
        linear-gradient(45deg, transparent 44%, currentColor 44% 56%, transparent 56%) 0 0 / 6px 6px no-repeat,
        linear-gradient(-45deg, transparent 44%, currentColor 44% 56%, transparent 56%) 100% 0 / 6px 6px no-repeat,
        linear-gradient(-45deg, transparent 44%, currentColor 44% 56%, transparent 56%) 0 100% / 6px 6px no-repeat,
        linear-gradient(45deg, transparent 44%, currentColor 44% 56%, transparent 56%) 100% 100% / 6px 6px no-repeat;
}

.sr-theme-icon.is-moon {
    right: 3px;
    width: 13px;
    height: 13px;
    border-radius: 50%;
    box-shadow: -4px 1px 0 0 currentColor;
}

html[data-sr-theme="dark"] .sr-theme-switch {
    background: #151515;
}

html[data-sr-theme="dark"] .sr-theme-knob {
    transform: translateX(-24px);
}

.sr-brand {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: inherit;
    font-size: clamp(26px, 3vw, 40px);
    font-weight: 900;
    letter-spacing: 0.08em;
    text-align: center;
    text-decoration: none;
    text-transform: uppercase;
}

.sr-brand-logo {
    display: block;
    width: auto;
    max-width: min(280px, 36vw);
    max-height: 44px;
    object-fit: contain;
}

.sr-brand-logo-wrap {
    display: grid;
    place-items: center;
}

.sr-brand-logo-wrap .sr-brand-logo {
    grid-area: 1 / 1;
    transition: opacity 180ms ease;
}

.sr-brand.has-logo-pair .sr-brand-logo-light {
    opacity: 0;
}

.sr-header.is-hero:not(.is-scrolled):not(:focus-within):not(:hover) .sr-brand.has-logo-pair .sr-brand-logo-dark {
    opacity: 0;
}

.sr-header.is-hero:not(.is-scrolled):not(:focus-within):not(:hover) .sr-brand.has-logo-pair .sr-brand-logo-light {
    opacity: 1;
}

.sr-cart-link {
    position: relative;
}

.sr-header-icon-link,
.sr-cart-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
}

.sr-header-icon-link svg,
.sr-cart-link svg {
    display: block;
    width: 19px;
    height: 19px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.sr-cart-link span {
    position: absolute;
    top: -10px;
    right: -10px;
    display: grid;
    min-width: 16px;
    height: 16px;
    place-items: center;
    border-radius: 50%;
    background: #000000;
    color: #ffffff;
    font-size: 10px;
    font-weight: 800;
}

.sr-menu-theme-toggle {
    width: fit-content;
    padding: 0;
    border: 0;
    background: transparent;
    color: #565656;
    font: inherit;
    font-size: clamp(14px, 1.25vw, 20px);
    text-align: left;
    cursor: pointer;
}

.sr-header.is-hero .sr-cart-link span {
    background: #ffffff;
    color: #000000;
}

.sr-header.is-hero.is-scrolled .sr-cart-link span,
.sr-header.is-hero:focus-within .sr-cart-link span,
.sr-header.is-hero:hover .sr-cart-link span {
    background: #000000;
    color: #ffffff;
}

html[data-sr-theme="dark"] body.sr-client {
    --shop-bg: #050505;
    --shop-panel: #111111;
    --shop-text: #f7f7f7;
    --shop-muted: #b8b8b8;
    --shop-border: #2a2a2a;
    background: #050505;
    color: #f7f7f7;
}

html[data-sr-theme="dark"] ::selection {
    background: #f7f7f7;
    color: #050505;
}

html[data-sr-theme="dark"] .sr-header:not(.is-hero),
html[data-sr-theme="dark"] .sr-header.is-hero.is-scrolled,
html[data-sr-theme="dark"] .sr-header.is-hero:focus-within,
html[data-sr-theme="dark"] .sr-footer,
html[data-sr-theme="dark"] .sr-search-overlay,
html[data-sr-theme="dark"] .sr-menu-panel,
html[data-sr-theme="dark"] .sr-product-panel,
html[data-sr-theme="dark"] .sr-cart-modal-panel,
html[data-sr-theme="dark"] .sr-cart-summary,
html[data-sr-theme="dark"] .sr-status-summary,
html[data-sr-theme="dark"] .sr-payment-success-card,
html[data-sr-theme="dark"] .sr-contact-card,
html[data-sr-theme="dark"] .sr-legal-card,
html[data-sr-theme="dark"] .sr-about-grid article,
html[data-sr-theme="dark"] .sr-about-band,
html[data-sr-theme="dark"] .sr-guide-card,
html[data-sr-theme="dark"] .sr-guide-article,
html[data-sr-theme="dark"] .sr-guides-empty,
html[data-sr-theme="dark"] .account-sidebar,
html[data-sr-theme="dark"] .account-card,
html[data-sr-theme="dark"] .account-section {
    border-color: #2a2a2a;
    background: #050505;
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-product-media,
html[data-sr-theme="dark"] .sr-filter-bar,
html[data-sr-theme="dark"] .sr-search-result-card.is-category,
html[data-sr-theme="dark"] .sr-search-empty,
html[data-sr-theme="dark"] .sr-cart-page,
html[data-sr-theme="dark"] .sr-cart-item,
html[data-sr-theme="dark"] .sr-help-strip,
html[data-sr-theme="dark"] .sr-status-card,
html[data-sr-theme="dark"] .sr-status-line,
html[data-sr-theme="dark"] .account-body,
html[data-sr-theme="dark"] .account-main,
html[data-sr-theme="dark"] .account-stat-card,
html[data-sr-theme="dark"] .account-summary-list div,
html[data-sr-theme="dark"] .account-delivery-list article,
html[data-sr-theme="dark"] .account-address-grid address {
    border-color: #2a2a2a;
    background: #111111;
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-footer a,
html[data-sr-theme="dark"] .sr-footer p,
html[data-sr-theme="dark"] .sr-footer-bottom span,
html[data-sr-theme="dark"] .sr-menu-primary a,
html[data-sr-theme="dark"] .sr-search-product,
html[data-sr-theme="dark"] .sr-search-result-card,
html[data-sr-theme="dark"] .sr-search-close,
html[data-sr-theme="dark"] .sr-search-brand,
html[data-sr-theme="dark"] .sr-filter-bar input,
html[data-sr-theme="dark"] .sr-filter-bar select,
html[data-sr-theme="dark"] .sr-filter-bar a,
html[data-sr-theme="dark"] .sr-catalog-context span,
html[data-sr-theme="dark"] .account-sidebar a,
html[data-sr-theme="dark"] .account-sidebar button {
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-about-hero h1,
html[data-sr-theme="dark"] .sr-about-grid h2,
html[data-sr-theme="dark"] .sr-about-band h2,
html[data-sr-theme="dark"] .sr-guides-hero h1,
html[data-sr-theme="dark"] .sr-guide-card h2 a,
html[data-sr-theme="dark"] .sr-guide-article h1 {
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-footer-socials a {
    border-color: #2a2a2a;
}

html[data-sr-theme="dark"] .sr-catalog-hero p,
html[data-sr-theme="dark"] .sr-product-price-row p,
html[data-sr-theme="dark"] .sr-product-price-row del,
html[data-sr-theme="dark"] .sr-product-price del,
html[data-sr-theme="dark"] .sr-product-short,
html[data-sr-theme="dark"] .sr-product-ref,
html[data-sr-theme="dark"] .sr-choice-heading,
html[data-sr-theme="dark"] .sr-product-services p,
html[data-sr-theme="dark"] .sr-search-kicker,
html[data-sr-theme="dark"] .sr-search-title-row p,
html[data-sr-theme="dark"] .sr-search-product span,
html[data-sr-theme="dark"] .sr-search-result-card small,
html[data-sr-theme="dark"] .sr-search-result-card em,
html[data-sr-theme="dark"] .sr-contact-hero p,
html[data-sr-theme="dark"] .sr-legal-card p,
html[data-sr-theme="dark"] .sr-about-hero p,
html[data-sr-theme="dark"] .sr-about-grid p,
html[data-sr-theme="dark"] .sr-guides-hero p,
html[data-sr-theme="dark"] .sr-guide-card p,
html[data-sr-theme="dark"] .sr-guide-article header p,
html[data-sr-theme="dark"] .sr-guide-content,
html[data-sr-theme="dark"] .sr-status-line p,
html[data-sr-theme="dark"] .sr-cart-item p {
    color: #b8b8b8;
}

html[data-sr-theme="dark"] .sr-outline-button,
html[data-sr-theme="dark"] .sr-button.is-outline,
html[data-sr-theme="dark"] .sr-filter-toggle,
html[data-sr-theme="dark"] .sr-search-categories a,
html[data-sr-theme="dark"] .sr-category-strip a,
html[data-sr-theme="dark"] .account-body .shop-button.is-outline {
    border-color: #f7f7f7;
    background: #050505;
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-button.is-dark,
html[data-sr-theme="dark"] .sr-filter-bar button,
html[data-sr-theme="dark"] .sr-category-strip a.is-active,
html[data-sr-theme="dark"] .account-body .shop-button {
    border-color: #f7f7f7;
    background: #f7f7f7;
    color: #050505;
}

html[data-sr-theme="dark"] .sr-product-media img,
html[data-sr-theme="dark"] .sr-search-product img,
html[data-sr-theme="dark"] .sr-search-result-card img,
html[data-sr-theme="dark"] .sr-product-placeholder {
    background: #1b1b1b;
}

html[data-sr-theme="dark"] .sr-product-badges em {
    background: rgba(247, 247, 247, 0.92);
    color: #050505;
}

html[data-sr-theme="dark"] .sr-product-heart {
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-card-colors button,
html[data-sr-theme="dark"] .sr-product-colors button {
    border-color: rgba(255, 255, 255, 0.52);
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.78);
}

html[data-sr-theme="dark"] .sr-card-colors button:hover,
html[data-sr-theme="dark"] .sr-product-colors button.is-active {
    box-shadow: 0 0 0 4px #050505, 0 0 0 5px #f7f7f7;
}

html[data-sr-theme="dark"] .sr-filter-bar label {
    color: #b8b8b8;
}

html[data-sr-theme="dark"] .sr-filter-bar input,
html[data-sr-theme="dark"] .sr-filter-bar select,
html[data-sr-theme="dark"] .sr-newsletter input,
html[data-sr-theme="dark"] .sr-contact-form input,
html[data-sr-theme="dark"] .sr-contact-form select,
html[data-sr-theme="dark"] .sr-contact-form textarea {
    border-color: #555555;
    background: #111111;
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-newsletter input::placeholder,
html[data-sr-theme="dark"] .sr-contact-form input::placeholder,
html[data-sr-theme="dark"] .sr-contact-form textarea::placeholder,
html[data-sr-theme="dark"] .sr-filter-bar input::placeholder {
    color: #8e8e8e;
}

html[data-sr-theme="dark"] .sr-newsletter button,
html[data-sr-theme="dark"] .sr-menu-theme-toggle,
html[data-sr-theme="dark"] .sr-choice-heading strong {
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-search-form {
    border-color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-search-form input,
html[data-sr-theme="dark"] .sr-search-form button {
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-cart-modal-panel {
    border: 1px solid rgba(255, 255, 255, 0.22);
    background: #111111;
    box-shadow: 0 24px 90px rgba(0, 0, 0, 0.85), 0 0 0 1px rgba(255, 255, 255, 0.08);
}

html[data-sr-theme="dark"] .sr-cart-modal-panel .sr-button.is-dark {
    background: #f7f7f7;
    color: #050505;
}

html[data-sr-theme="dark"] .sr-cart-modal-panel .sr-button.is-outline {
    background: transparent;
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-checkout-page {
    background: #050505;
}

html[data-sr-theme="dark"] .sr-checkout-form {
    border: 1px solid #2a2a2a;
    background: #050505;
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-checkout-summary,
html[data-sr-theme="dark"] .sr-checkout-form fieldset {
    border-color: #2a2a2a;
    background: #111111;
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-checkout-guidance {
    border-color: #f4f4f4;
    background: #111111;
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-checkout-guidance strong {
    color: #ffffff;
}

html[data-sr-theme="dark"] .sr-checkout-guidance p {
    color: #d8d8d8;
}

html[data-sr-theme="dark"] .sr-checkout-form fieldset.is-required-focus {
    border-color: #f4f4f4;
    background: #0d0d0d;
    box-shadow: 0 0 0 3px rgba(244, 244, 244, 0.12);
}

html[data-sr-theme="dark"] .sr-checkout-form fieldset.is-required-focus input[required],
html[data-sr-theme="dark"] .sr-checkout-form fieldset.is-required-focus select[required] {
    border-color: #f4f4f4;
}

html[data-sr-theme="dark"] .sr-checkout-form label,
html[data-sr-theme="dark"] .sr-checkout-form legend,
html[data-sr-theme="dark"] .sr-checkout-summary p,
html[data-sr-theme="dark"] .sr-checkout-summary li,
html[data-sr-theme="dark"] .sr-checkout-form .account-muted {
    color: #d8d8d8;
}

html[data-sr-theme="dark"] .sr-checkout-line {
    border-color: #2a2a2a;
}

html[data-sr-theme="dark"] .sr-checkout-line-image {
    background: #1b1b1b;
}

html[data-sr-theme="dark"] .sr-checkout-line-body strong {
    color: #ffffff;
}

html[data-sr-theme="dark"] .sr-checkout-line-body span,
html[data-sr-theme="dark"] .sr-checkout-line-price {
    color: #d8d8d8;
}

html[data-sr-theme="dark"] .sr-checkout-form input,
html[data-sr-theme="dark"] .sr-checkout-form select,
html[data-sr-theme="dark"] .sr-checkout-form textarea {
    border-color: #4a4a4a;
    background: #050505;
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-checkout-form input::placeholder,
html[data-sr-theme="dark"] .sr-checkout-form textarea::placeholder {
    color: #858585;
}

.sr-hero {
    position: relative;
    min-height: 100svh;
    display: grid;
    place-items: end center;
    overflow: hidden;
    background: #111111;
}

.sr-hero video,
.sr-hero-fallback,
.sr-hero-fallback img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    background-position: center;
    background-size: cover;
}

.sr-hero-fallback {
    z-index: 0;
}

.sr-hero video {
    z-index: 1;
}

.sr-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.18), rgba(0, 0, 0, 0.08) 45%, rgba(0, 0, 0, 0.46));
    z-index: 2;
}

.sr-hero-copy {
    position: relative;
    z-index: 3;
    width: min(760px, calc(100% - 32px));
    padding: 0 0 clamp(48px, 8vh, 96px);
    color: #ffffff;
    text-align: center;
}

.sr-hero-copy h1 {
    margin: 8px 0 20px;
    font-size: clamp(21px, 3vw, 36px);
    font-weight: 500;
}

.sr-eyebrow {
    margin: 0 0 14px;
    color: inherit;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.sr-underlink {
    display: inline-flex;
    color: inherit;
    font-weight: 650;
    text-decoration: underline;
    text-underline-offset: 6px;
    text-decoration-thickness: 1px;
}

.sr-underlink.is-light {
    color: #ffffff;
}

.sr-optional-label {
    color: #8a8a8a;
    font-size: 12px;
    font-weight: 650;
}

.sr-section,
.sr-page {
    padding: clamp(48px, 7vw, 90px) clamp(18px, 5vw, 86px);
    background: var(--shop-bg, #ffffff);
}

.sr-section-heading {
    margin: 0 0 34px;
}

.sr-section-heading.is-centered,
.sr-catalog-hero {
    text-align: center;
}

.sr-section-heading h2,
.sr-catalog-hero h1 {
    margin: 0;
    font-size: clamp(15px, 2vw, 24px);
    font-weight: 500;
}

.sr-catalog-hero p {
    max-width: 640px;
    margin: 18px auto 0;
    color: #696969;
    line-height: 1.7;
}

.sr-product-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: clamp(18px, 2vw, 28px);
}

.sr-product-card {
    min-width: 0;
}

.sr-product-media {
    position: relative;
    display: block;
    aspect-ratio: 4 / 5;
    overflow: hidden;
    background: #f4f4f4;
    color: inherit;
    text-decoration: none;
}

.sr-product-media picture,
.sr-product-media img,
.sr-product-media video,
.sr-product-placeholder {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.sr-product-media video {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 180ms ease;
    background: #f4f4f4;
}

.sr-product-card:hover .sr-product-media video {
    opacity: 1;
}

.sr-product-placeholder {
    background: linear-gradient(135deg, #f3f3f3, #dedede);
}

.sr-product-heart,
.sr-product-badges {
    position: absolute;
    z-index: 1;
}

.sr-product-heart {
    top: 18px;
    right: 18px;
    font-size: 28px;
}

.sr-product-badges {
    top: 16px;
    left: 16px;
    display: grid;
    gap: 6px;
}

.sr-product-badges em {
    width: fit-content;
    padding: 6px 9px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.86);
    font-size: 11px;
    font-style: normal;
    font-weight: 800;
}

.sr-product-meta {
    padding: 18px 2px 0;
}

.sr-product-meta > a {
    color: inherit;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
}

.sr-product-price-row {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 12px;
    margin-top: 8px;
}

.sr-product-price-row p {
    display: grid;
    gap: 3px;
    margin: 0;
    color: #747474;
}

.sr-product-price-row del,
.sr-product-price del {
    color: #909090;
}

.sr-card-colors {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 7px;
    padding-top: 2px;
}

.sr-card-colors button,
.sr-product-colors button {
    width: 20px;
    height: 20px;
    border: 1px solid rgba(0, 0, 0, 0.18);
    border-radius: 50%;
    background: var(--swatch);
    cursor: pointer;
}

.sr-card-colors button:hover,
.sr-product-colors button.is-active {
    box-shadow: 0 0 0 4px #ffffff, 0 0 0 5px #111111;
}

.sr-centered-action {
    display: flex;
    justify-content: center;
    margin-top: 56px;
}

.sr-outline-button,
.sr-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    padding: 0 32px;
    border-radius: 999px;
    font: inherit;
    font-weight: 650;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
}

.sr-outline-button,
.sr-button.is-outline {
    border: 1px solid #111111;
    background: #ffffff;
    color: #111111;
}

.sr-button.is-dark {
    border: 1px solid #000000;
    background: #000000;
    color: #ffffff;
}

.sr-button.is-dark:hover {
    background: #252525;
}

.sr-button:disabled,
.sr-button.is-dark:disabled,
.shop-button:disabled {
    border-color: #dcdcdc;
    background: #eeeeee;
    color: #777777;
    cursor: not-allowed;
}

.sr-category-strip {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    margin: 36px 0 26px;
}

.sr-category-strip a {
    padding: 10px 18px;
    border: 1px solid #dedede;
    border-radius: 999px;
    color: #171717;
    text-decoration: none;
}

.sr-category-strip a.is-active {
    background: #111111;
    color: #ffffff;
}

.sr-catalog-context {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin: 34px 0 18px;
    padding: 0 2px;
}

.sr-catalog-context span {
    color: #686868;
    font-size: 13px;
    font-weight: 750;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.sr-filter-drawer {
    margin: 0 0 34px;
}

.sr-filter-toggle {
    display: none;
}

.sr-filter-bar {
    display: grid;
    grid-template-columns: 1.4fr repeat(5, minmax(120px, 1fr)) auto auto;
    gap: 12px;
    align-items: end;
    margin: 0;
    padding: 18px;
    background: #f6f6f6;
}

.sr-filter-bar label {
    display: grid;
    gap: 8px;
    color: #666666;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.sr-filter-bar input,
.sr-filter-bar select {
    min-height: 46px;
    width: 100%;
    border: 0;
    border-bottom: 1px solid #cfcfcf;
    background: transparent;
    color: #111111;
    font: inherit;
    outline: 0;
}

.sr-filter-bar button {
    min-height: 46px;
    border: 0;
    border-radius: 999px;
    background: #111111;
    color: #ffffff;
    font: inherit;
    font-weight: 700;
    cursor: pointer;
}

.sr-filter-bar a {
    min-height: 46px;
    display: inline-flex;
    align-items: center;
    color: #111111;
}

.sr-product-page {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 42vw);
    align-items: start;
    border-top: 1px solid #e8e8e8;
}

.sr-product-gallery {
    display: grid;
    background: #f4f4f4;
}

.sr-product-gallery picture,
.sr-product-gallery img {
    display: block;
    width: 100%;
}

.sr-product-gallery picture {
    aspect-ratio: 10 / 7;
    overflow: hidden;
}

.sr-product-gallery img {
    height: 100%;
    object-fit: cover;
    cursor: zoom-in;
}

.sr-product-gallery picture[hidden],
.sr-product-gallery img[hidden] {
    display: none !important;
}

.sr-product-panel {
    position: sticky;
    top: 86px;
    min-height: calc(100svh - 86px);
    display: flex;
    flex-direction: column;
    gap: 22px;
    padding: clamp(34px, 6vw, 76px) clamp(28px, 6vw, 96px);
    background: #ffffff;
}

.sr-product-ref {
    margin: 0;
    color: #696969;
    font-size: 12px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.sr-product-panel h1 {
    margin: -8px 0 0;
    font-size: clamp(15px, 2vw, 21px);
    font-weight: 500;
}

.sr-product-price {
    display: flex;
    gap: 10px;
    align-items: baseline;
    font-size: 20px;
}

.sr-product-short {
    color: #686868;
    line-height: 1.7;
}

.sr-product-choice,
.sr-size-panel {
    display: grid;
    gap: 14px;
}

.sr-size-panel[hidden] {
    display: none !important;
}

.sr-choice-heading {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    color: #616161;
}

.sr-choice-heading strong {
    color: #171717;
}

.sr-product-colors {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    padding: 8px 0;
}

.sr-product-colors button {
    width: 30px;
    height: 30px;
}

.sr-size-options {
    display: grid;
    grid-template-columns: repeat(6, minmax(48px, 1fr));
    gap: 8px;
}

.sr-size-options label {
    display: grid;
    place-items: center;
    min-height: 58px;
    border: 1px solid #d9d9d9;
    cursor: pointer;
}

.sr-size-options input {
    position: absolute;
    inline-size: 1px;
    block-size: 1px;
    opacity: 0;
}

.sr-size-options span {
    font-weight: 800;
}

.sr-size-options small {
    color: #777777;
    font-size: 11px;
}

.sr-size-options label:has(input:checked) {
    border-color: #000000;
    box-shadow: inset 0 0 0 1px #000000;
}

.sr-size-options label.is-disabled {
    color: #a0a0a0;
    background: #f4f4f4;
    text-decoration: line-through;
    cursor: not-allowed;
}

.sr-add-form {
    display: grid;
    gap: 16px;
}

.sr-stock-message {
    min-height: 20px;
    margin: 0;
    color: #b8612c;
    font-weight: 800;
}

.sr-gallery-modal[hidden] {
    display: none !important;
}

.sr-gallery-modal {
    position: fixed;
    inset: 0;
    z-index: 80;
}

.sr-gallery-backdrop {
    position: absolute;
    inset: 0;
    border: 0;
    background: rgba(0, 0, 0, 0.72);
    cursor: zoom-out;
}

.sr-gallery-panel {
    position: relative;
    z-index: 1;
    display: grid;
    width: 100%;
    height: 100%;
    place-items: center;
    padding: clamp(22px, 4vw, 72px);
}

.sr-gallery-panel img {
    max-width: min(1180px, 86vw);
    max-height: 86svh;
    object-fit: contain;
    background: #f5f5f5;
}

.sr-gallery-close,
.sr-gallery-nav {
    position: absolute;
    border: 1px solid #ffffff;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.92);
    color: #111111;
    cursor: pointer;
    font: inherit;
}

.sr-gallery-close {
    top: 28px;
    right: 28px;
    width: 46px;
    height: 46px;
    font-size: 28px;
}

.sr-gallery-nav {
    top: 50%;
    width: 54px;
    height: 54px;
    transform: translateY(-50%);
    font-size: 38px;
}

.sr-gallery-nav.is-prev {
    left: 28px;
}

.sr-gallery-nav.is-next {
    right: 28px;
}

.sr-gallery-counter {
    position: absolute;
    bottom: 28px;
    left: 50%;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.92);
    color: #111111;
    transform: translateX(-50%);
    font-size: 13px;
    font-weight: 800;
}

.sr-stock-message[hidden] {
    display: none;
}

.sr-product-services {
    display: grid;
    gap: 0;
    margin-top: 18px;
    border-top: 1px solid #e5e5e5;
}

.sr-product-services details {
    border-bottom: 1px solid #e5e5e5;
    padding: 18px 0;
}

.sr-product-services summary {
    cursor: pointer;
    font-weight: 650;
}

.sr-product-services p {
    color: #696969;
    line-height: 1.7;
}

.sr-cart-modal[hidden],
.sr-menu-overlay[hidden],
.sr-search-overlay[hidden] {
    display: none;
}

.sr-cart-modal,
.sr-menu-overlay,
.sr-search-overlay {
    position: fixed;
    inset: 0;
    z-index: 80;
}

.sr-search-overlay {
    z-index: 95;
    overflow-y: auto;
    background: #ffffff;
    color: #171717;
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 220ms ease, transform 220ms ease;
    pointer-events: none;
}

.sr-search-overlay.is-open {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.sr-search-shell {
    min-height: 100svh;
    padding: clamp(30px, 5vw, 72px) clamp(18px, 5vw, 72px) 70px;
}

.sr-search-close {
    position: fixed;
    top: 28px;
    right: 32px;
    z-index: 2;
    border: 0;
    background: transparent;
    color: #171717;
    font: inherit;
    font-size: 34px;
    line-height: 1;
    cursor: pointer;
}

.sr-search-brand {
    display: flex;
    justify-content: center;
    margin: 0 auto 38px;
    color: #171717;
    font-size: clamp(28px, 3vw, 42px);
    font-weight: 900;
    letter-spacing: 0.08em;
    text-decoration: none;
    text-transform: uppercase;
}

.sr-search-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    max-width: 1180px;
    min-height: 64px;
    margin: 0 auto clamp(36px, 5vw, 68px);
    padding: 0 22px 0 30px;
    border: 1px solid #9f9f9f;
    border-radius: 999px;
}

.sr-search-form input {
    width: 100%;
    border: 0;
    background: transparent;
    color: #171717;
    font: inherit;
    outline: 0;
}

.sr-search-form button {
    border: 0;
    background: transparent;
    color: #555555;
    font: inherit;
    cursor: pointer;
}

.sr-search-section {
    max-width: 1500px;
    margin: 0 auto clamp(40px, 5vw, 74px);
}

.sr-search-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 20px;
}

.sr-search-kicker,
.sr-search-title-row p {
    margin: 0;
    color: #6f6f6f;
    font-size: 13px;
    font-weight: 750;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.sr-search-categories {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.sr-search-categories a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 0 20px;
    border: 1px solid #d8d8d8;
    border-radius: 999px;
    color: #171717;
    text-decoration: none;
}

.sr-search-categories a:hover {
    border-color: #111111;
}

.sr-search-product-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: clamp(18px, 2vw, 28px);
}

.sr-search-product {
    display: grid;
    gap: 10px;
    color: #171717;
    text-decoration: none;
}

.sr-search-product img,
.sr-search-product .sr-product-placeholder {
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: contain;
    background: #f4f4f4;
}

.sr-search-product strong {
    font-weight: 650;
}

.sr-search-product span {
    color: #747474;
}

.sr-search-results {
    max-width: 1500px;
    margin: 0 auto;
}

.sr-search-results-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: clamp(18px, 2vw, 28px);
}

.sr-search-result-card {
    display: grid;
    gap: 12px;
    min-width: 0;
    color: #171717;
    text-decoration: none;
}

.sr-search-result-card img,
.sr-search-result-card .sr-product-placeholder {
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: contain;
    background: #f4f4f4;
}

.sr-search-result-card span,
.sr-search-result-card.is-category {
    display: grid;
    gap: 5px;
}

.sr-search-result-card small {
    color: #777777;
    font-size: 12px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.sr-search-result-card strong {
    font-size: 16px;
    font-weight: 650;
}

.sr-search-result-card em {
    color: #747474;
    font-style: normal;
}

.sr-search-result-card.is-category {
    align-content: center;
    min-height: 190px;
    padding: 28px;
    border: 1px solid #e5e5e5;
    background: #fafafa;
}

.sr-search-empty {
    grid-column: 1 / -1;
    margin: 0;
    padding: 42px;
    border: 1px solid #e5e5e5;
    background: #fafafa;
    color: #666666;
    text-align: center;
}

.sr-cart-modal-backdrop,
.sr-menu-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.72);
}

.sr-cart-modal-panel {
    position: absolute;
    top: 86px;
    right: 0;
    width: min(650px, 100%);
    padding: clamp(28px, 4vw, 64px);
    background: #ffffff;
}

.sr-modal-close {
    position: absolute;
    top: 24px;
    right: 28px;
    font-size: 34px;
}

.sr-cart-added-product {
    display: grid;
    grid-template-columns: 150px minmax(0, 1fr);
    gap: 24px;
    margin: 32px 0;
}

.sr-cart-added-product img {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    background: #f4f4f4;
}

.sr-cart-added-product div {
    display: grid;
    align-content: center;
    gap: 7px;
}

.sr-cart-added-product small {
    color: #696969;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.sr-cart-modal-panel .sr-button {
    width: 100%;
    margin-top: 12px;
}

.sr-menu-panel {
    position: relative;
    width: min(95vw, 1560px);
    min-height: 100%;
    background: #ffffff;
}

.sr-menu-close {
    position: absolute;
    top: 34px;
    left: 42px;
    z-index: 2;
    border: 0;
    background: transparent;
    font: inherit;
    cursor: pointer;
}

.sr-menu-layout {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    min-height: 100svh;
}

.sr-menu-primary,
.sr-menu-feature,
.sr-menu-products {
    padding: clamp(90px, 10vw, 150px) clamp(32px, 5vw, 70px) 50px;
    border-right: 1px solid #e5e5e5;
}

.sr-menu-primary {
    display: grid;
    align-content: start;
    gap: 16px;
}

.sr-menu-primary a {
    color: #565656;
    font-size: clamp(14px, 1.25vw, 20px);
    text-decoration: none;
}

.sr-menu-primary a:hover {
    color: #111111;
    text-decoration: underline;
    text-underline-offset: 7px;
}

.sr-menu-feature {
    display: grid;
    align-content: center;
    gap: 18px;
}

.sr-menu-feature h2 {
    margin: 0;
    font-size: clamp(22px, 2vw, 32px);
    font-weight: 500;
}

.sr-menu-products {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-content: start;
    padding-inline: 0;
}

.sr-menu-products a {
    display: grid;
    gap: 18px;
    min-height: 250px;
    padding: 0 0 24px;
    border-bottom: 1px solid #e5e5e5;
    color: #111111;
    text-align: center;
    text-decoration: none;
}

.sr-menu-products img,
.sr-menu-products .sr-product-placeholder {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    background: #f4f4f4;
}

.sr-footer {
    border-top: 1px solid #e5e5e5;
    background: #ffffff;
}

.sr-footer-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: clamp(28px, 5vw, 86px);
    padding: clamp(48px, 7vw, 86px) clamp(24px, 8vw, 160px);
}

.sr-footer section {
    display: grid;
    align-content: start;
    gap: 20px;
}

.sr-footer a {
    color: #1c1c1c;
    text-decoration: none;
}

.sr-footer-socials {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.sr-footer-socials a {
    border: 1px solid rgba(17, 17, 17, 0.14);
    border-radius: 999px;
    padding: 8px 12px;
    font-size: 13px;
    font-weight: 800;
}

.sr-footer p {
    margin: 0;
    color: #333333;
    line-height: 1.6;
}

.sr-newsletter {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
}

.sr-newsletter input {
    min-height: 44px;
    border: 0;
    border-bottom: 1px solid #111111;
    font: inherit;
}

.sr-newsletter button {
    border: 0;
    background: transparent;
    font: inherit;
    font-weight: 800;
    cursor: pointer;
}

.sr-footer-bottom {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 24px;
    align-items: center;
    padding: 30px clamp(24px, 8vw, 160px);
    border-top: 1px solid #e5e5e5;
}

.sr-footer-bottom strong {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.sr-footer-brand .sr-brand-logo {
    max-height: 46px;
}

.sr-footer-brand.has-logo-pair .sr-footer-logo-light {
    opacity: 0;
}

html[data-sr-theme="dark"] .sr-footer-brand.has-logo-pair .sr-footer-logo-dark {
    opacity: 0;
}

html[data-sr-theme="dark"] .sr-footer-brand.has-logo-pair .sr-footer-logo-light {
    opacity: 1;
}

.sr-footer-bottom span:last-child {
    text-align: right;
}

.sr-cart-page {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 34vw);
    min-height: calc(100svh - 86px);
    background: #f6f6f6;
}

.sr-cart-list {
    padding: clamp(28px, 5vw, 72px) clamp(22px, 7vw, 120px);
}

.sr-help-strip,
.sr-cart-item,
.sr-empty.is-large {
    background: #ffffff;
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.04);
}

.sr-help-strip {
    display: flex;
    gap: 10px;
    align-items: center;
    width: min(760px, 100%);
    padding: 24px 30px;
    border-radius: 6px;
}

.sr-cart-title {
    display: flex;
    align-items: baseline;
    gap: 14px;
    margin: 42px 0 28px;
}

.sr-cart-title h1 {
    margin: 0;
    font-size: 14px;
    font-weight: 500;
}

.sr-cart-items {
    display: grid;
    gap: 18px;
}

.sr-cart-item {
    display: grid;
    grid-template-columns: 300px minmax(0, 1fr) auto;
    gap: 30px;
    padding: 18px;
}

.sr-cart-item-media {
    display: block;
    background: #f4f4f4;
}

.sr-cart-item-media img {
    display: block;
    width: 100%;
    aspect-ratio: 1;
    object-fit: contain;
}

.sr-cart-item-info h2 {
    margin: 8px 0 12px;
    font-size: 20px;
    font-weight: 500;
}

.sr-cart-item-info a {
    color: inherit;
    text-decoration: none;
}

.sr-cart-item-info small,
.sr-cart-item-info p {
    color: #666666;
}

.sr-cart-item-actions {
    display: grid;
    align-content: end;
    justify-items: end;
    gap: 14px;
    min-width: 150px;
}

.sr-quantity-form {
    display: flex;
    gap: 8px;
    align-items: center;
}

.sr-quantity-form input {
    width: 72px;
    min-height: 38px;
    border: 1px solid #d7d7d7;
    text-align: center;
}

.sr-quantity-form button,
.sr-text-button {
    border: 0;
    background: transparent;
    color: #111111;
    font: inherit;
    text-decoration: underline;
    text-underline-offset: 4px;
    cursor: pointer;
}

.sr-cart-summary {
    position: sticky;
    top: 86px;
    min-height: calc(100svh - 86px);
    padding: clamp(34px, 6vw, 72px);
    background: #ffffff;
}

.sr-cart-summary h2 {
    margin: 0 0 28px;
    font-weight: 500;
}

.sr-cart-summary dl {
    display: grid;
    gap: 18px;
    margin: 0 0 28px;
}

.sr-cart-summary dl div {
    display: flex;
    justify-content: space-between;
    gap: 18px;
}

.sr-cart-summary .is-total {
    padding-top: 18px;
    border-top: 1px solid #e5e5e5;
    font-size: 24px;
}

.sr-cart-summary .sr-button {
    width: 100%;
    margin-bottom: 22px;
}

.sr-cart-summary .sr-underlink {
    display: flex;
    justify-content: center;
}

.sr-cart-reassurance {
    display: grid;
    gap: 22px;
    margin-top: 60px;
    padding-top: 36px;
    border-top: 1px solid #e5e5e5;
}

.sr-checkout-page {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    background: #f6f6f6;
    padding: clamp(30px, 6vw, 82px) clamp(18px, 6vw, 110px);
}

.sr-checkout-form {
    width: min(1120px, 100%);
    margin: 0 auto;
    padding: clamp(24px, 4vw, 56px);
    background: #ffffff;
}

.sr-checkout-form h1 {
    margin: 22px 0 30px;
    font-size: clamp(16px, 2vw, 26px);
    font-weight: 500;
}

.sr-checkout-summary {
    margin-bottom: 28px;
    padding: 22px;
    border: 1px solid transparent;
    background: #f7f7f7;
}

.sr-checkout-summary h2 {
    margin-top: 0;
}

.sr-checkout-lines {
    display: grid;
    gap: 14px;
}

.sr-checkout-line {
    display: grid;
    grid-template-columns: 82px minmax(0, 1fr) auto;
    align-items: center;
    gap: 16px;
    padding: 14px 0;
    border-bottom: 1px solid #e2e2e2;
}

.sr-checkout-line:last-child {
    border-bottom: 0;
}

.sr-checkout-line-image {
    width: 82px;
    aspect-ratio: 1;
    display: grid;
    place-items: center;
    overflow: hidden;
    background: #efefef;
}

.sr-checkout-line-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.sr-checkout-line-image span {
    width: 34px;
    height: 34px;
    border: 1px solid #cfcfcf;
}

.sr-checkout-line-body {
    display: grid;
    gap: 5px;
    min-width: 0;
}

.sr-checkout-line-body strong {
    color: #111111;
    font-size: 17px;
}

.sr-checkout-line-body span,
.sr-checkout-line-price {
    color: #555555;
}

.sr-checkout-line-price {
    font-weight: 750;
    white-space: nowrap;
}

.sr-checkout-guidance {
    display: grid;
    gap: 8px;
    margin: 0 0 24px;
    padding: 18px 20px;
    border: 1px solid #111111;
    background: #ffffff;
}

.sr-checkout-guidance strong {
    color: #111111;
    font-size: 18px;
    font-weight: 750;
}

.sr-checkout-guidance p {
    margin: 0;
    color: #555555;
    line-height: 1.55;
}

.sr-checkout-form form {
    display: grid;
    gap: 22px;
}

.sr-checkout-form fieldset {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    margin: 0;
    padding: 22px;
    border: 1px solid #e3e3e3;
}

.sr-checkout-form fieldset.is-required-focus {
    border-color: #111111;
    background: #fbfbfb;
    box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.06);
}

.sr-checkout-form fieldset.is-required-focus input[required],
.sr-checkout-form fieldset.is-required-focus select[required] {
    border-color: #111111;
}

.sr-checkout-form legend {
    padding: 0 8px;
    font-weight: 800;
}

.sr-checkout-form p {
    margin: 0;
}

.sr-checkout-form label {
    display: grid;
    gap: 8px;
    color: #555555;
    font-size: 13px;
    font-weight: 750;
}

.sr-checkout-form input,
.sr-checkout-form select,
.sr-checkout-form textarea {
    min-height: 48px;
    width: 100%;
    border: 1px solid #dcdcdc;
    background: #ffffff;
    color: #111111;
    font: inherit;
    padding: 10px 12px;
}

.sr-checkout-form textarea {
    min-height: 110px;
}

.sr-checkout-same-address {
    width: fit-content;
    max-width: 100%;
    margin: -4px 0 0;
}

.sr-status-page {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 34vw);
    min-height: calc(100svh - 86px);
    background: #f6f6f6;
}

.sr-status-main {
    padding: clamp(32px, 5vw, 76px) clamp(22px, 7vw, 120px);
}

.sr-status-hero {
    margin: 38px 0 34px;
}

.sr-status-hero h1 {
    max-width: 760px;
    margin: 0 0 18px;
    font-size: clamp(19px, 2.5vw, 33px);
    font-weight: 500;
}

.sr-status-hero p {
    max-width: 660px;
    margin: 0;
    color: #646464;
    font-size: 18px;
    line-height: 1.7;
}

.sr-status-card,
.sr-status-lines {
    background: #ffffff;
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.04);
}

.sr-status-card {
    display: grid;
    grid-template-columns: minmax(180px, 280px) minmax(0, 1fr);
    gap: 30px;
    align-items: center;
    padding: 18px;
}

.sr-status-media,
.sr-status-line-media {
    display: block;
    background: #f4f4f4;
}

.sr-status-media {
    aspect-ratio: 1;
}

.sr-status-media img,
.sr-status-line-media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.sr-status-details h2 {
    margin: 0 0 22px;
    font-size: clamp(24px, 3vw, 36px);
    font-weight: 500;
}

.sr-status-details dl,
.sr-status-summary dl {
    display: grid;
    gap: 16px;
    margin: 0;
}

.sr-status-details dl div,
.sr-status-summary dl div {
    display: flex;
    justify-content: space-between;
    gap: 18px;
}

.sr-status-details dt,
.sr-status-summary dt {
    color: #666666;
}

.sr-status-details dd,
.sr-status-summary dd {
    margin: 0;
    text-align: right;
}

.sr-status-lines {
    display: grid;
    gap: 0;
    margin-top: 24px;
    padding: 26px;
}

.sr-status-lines h2 {
    margin: 0 0 18px;
    font-size: 24px;
    font-weight: 500;
}

.sr-status-line {
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr) auto;
    gap: 20px;
    align-items: center;
    padding: 18px 0;
    border-top: 1px solid #e5e5e5;
}

.sr-status-line:first-of-type {
    border-top: 0;
}

.sr-status-line-media {
    aspect-ratio: 1;
}

.sr-status-line strong,
.sr-status-line span,
.sr-status-line small {
    display: block;
}

.sr-status-line span,
.sr-status-line small {
    margin-top: 4px;
    color: #666666;
}

.sr-status-line p {
    margin: 0;
    text-align: right;
}

.sr-status-summary {
    position: sticky;
    top: 86px;
    min-height: calc(100svh - 86px);
    padding: clamp(34px, 6vw, 72px);
    background: #ffffff;
}

.sr-status-summary h2 {
    margin: 0 0 28px;
    font-weight: 500;
}

.sr-status-summary .is-total {
    padding-top: 18px;
    border-top: 1px solid #e5e5e5;
    font-size: 24px;
}

.sr-status-summary form {
    margin: 30px 0 22px;
}

.sr-status-summary .sr-button {
    width: 100%;
}

.sr-status-summary > .sr-underlink {
    display: flex;
    justify-content: center;
}

.sr-status-reassurance {
    display: grid;
    gap: 22px;
    margin-top: 60px;
    padding-top: 36px;
    border-top: 1px solid #e5e5e5;
}

.sr-payment-success {
    display: grid;
    min-height: calc(100svh - 86px);
    place-items: center;
    padding: clamp(38px, 7vw, 92px) clamp(18px, 6vw, 110px);
    background: #f6f6f6;
}

.sr-payment-success-card {
    width: min(100%, 980px);
    padding: clamp(34px, 6vw, 76px);
    background: #ffffff;
}

.sr-payment-success-card h1 {
    max-width: 780px;
    margin: 0 0 22px;
    color: #171717;
    font-size: clamp(21px, 3vw, 38px);
    font-weight: 500;
    line-height: 1.02;
}

.sr-payment-success-card > p {
    max-width: 720px;
    margin: 0;
    color: #666666;
    font-size: 18px;
    line-height: 1.7;
}

.sr-payment-success-steps {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin: clamp(30px, 5vw, 56px) 0 28px;
}

.sr-payment-success-steps article {
    display: grid;
    gap: 10px;
    min-height: 160px;
    padding: 22px;
    border: 1px solid #e8e8e8;
    background: #f7f7f7;
}

.sr-payment-success-steps article > span {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: #d6d6d6;
}

.sr-payment-success-steps article.is-done {
    border-color: #cfe8d7;
    background: #eff8f2;
}

.sr-payment-success-steps article.is-done > span {
    background: #4aa36f;
}

.sr-payment-success-steps strong {
    color: #171717;
    font-size: 18px;
    font-weight: 650;
}

.sr-payment-success-steps small {
    color: #666666;
    font-size: 14px;
    line-height: 1.5;
}

.sr-payment-session {
    padding-top: 4px;
    font-size: 14px !important;
}

.sr-payment-success-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 22px;
    margin-top: 34px;
}

.sr-redirect-note {
    margin-top: 28px !important;
    color: #777777 !important;
    font-size: 14px !important;
}

.sr-legal-page {
    padding: clamp(38px, 7vw, 92px) clamp(18px, 6vw, 110px);
    background: var(--shop-bg, #f6f6f6);
}

.sr-legal-card {
    width: min(100%, 1080px);
    margin: 28px auto 0;
    padding: clamp(34px, 6vw, 76px);
    background: #ffffff;
}

.sr-legal-card h1 {
    max-width: 820px;
    margin: 0 0 32px;
    color: #171717;
    font-size: clamp(21px, 3vw, 38px);
    font-weight: 500;
    line-height: 1.02;
}

.sr-legal-content {
    max-width: 860px;
    color: #4f4f4f;
    font-size: 16px;
    line-height: 1.85;
}

.sr-contact-page {
    padding: clamp(38px, 7vw, 96px) clamp(18px, 6vw, 110px);
    background: var(--shop-bg, #f6f6f6);
}

.sr-contact-hero,
.sr-contact-card {
    width: min(100%, 1080px);
    margin-inline: auto;
}

.sr-contact-hero {
    padding: 28px 0 34px;
}

.sr-contact-hero h1 {
    max-width: 760px;
    margin: 0 0 18px;
    color: #171717;
    font-size: clamp(22px, 3.5vw, 41px);
    font-weight: 500;
    line-height: 1.02;
}

.sr-contact-hero p {
    max-width: 680px;
    margin: 0;
    color: #555555;
    font-size: 18px;
    line-height: 1.65;
}

.sr-contact-card {
    padding: clamp(24px, 5vw, 58px);
    background: #ffffff;
}

.sr-contact-form {
    display: grid;
    gap: 22px;
}

.sr-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.sr-contact-form label {
    display: grid;
    gap: 9px;
    color: #666666;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.sr-contact-form input,
.sr-contact-form select,
.sr-contact-form textarea {
    width: 100%;
    min-height: 52px;
    border: 1px solid #dedede;
    border-radius: 0;
    background: #ffffff;
    color: #171717;
    font: inherit;
    letter-spacing: 0;
    outline: 0;
}

.sr-contact-form input,
.sr-contact-form select {
    padding: 0 16px;
}

.sr-contact-form textarea {
    padding: 16px;
    resize: vertical;
}

.sr-contact-form input:focus,
.sr-contact-form select:focus,
.sr-contact-form textarea:focus {
    border-color: #171717;
}

.sr-about-page {
    padding: clamp(38px, 7vw, 96px) clamp(18px, 6vw, 110px);
    background: var(--shop-bg, #f6f6f6);
}

.sr-about-hero,
.sr-about-grid,
.sr-about-band {
    width: min(100%, 1180px);
    margin-inline: auto;
}

.sr-about-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(180px, 320px);
    align-items: center;
    gap: clamp(30px, 6vw, 92px);
    padding: 32px 0 clamp(42px, 7vw, 86px);
}

.sr-about-hero h1 {
    max-width: 760px;
    margin: 0 0 18px;
    color: #171717;
    font-size: clamp(34px, 7vw, 86px);
    font-weight: 900;
    letter-spacing: 0;
    line-height: 0.94;
}

.sr-about-hero p {
    max-width: 700px;
    margin: 0;
    color: #555555;
    font-size: clamp(17px, 2vw, 22px);
    line-height: 1.55;
}

.sr-about-mark {
    aspect-ratio: 1;
    border-radius: 24px;
    background: #171717;
    display: grid;
    place-items: center;
    padding: 32px;
}

.sr-about-mark img {
    display: block;
    max-width: 82%;
    max-height: 82%;
    object-fit: contain;
}

.sr-about-mark strong {
    color: #ffffff;
    font-size: clamp(44px, 7vw, 82px);
    font-weight: 900;
}

.sr-about-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.sr-about-grid article,
.sr-about-band {
    background: #ffffff;
    border: 1px solid rgba(17, 17, 17, 0.08);
}

.sr-about-grid article {
    min-height: 280px;
    padding: clamp(24px, 4vw, 38px);
}

.sr-about-grid span {
    display: block;
    margin-bottom: 34px;
    color: #777777;
    font-size: 13px;
    font-weight: 900;
    letter-spacing: 0.12em;
}

.sr-about-grid h2,
.sr-about-band h2 {
    margin: 0;
    color: #171717;
    font-size: clamp(22px, 3vw, 36px);
    font-weight: 800;
    line-height: 1.02;
}

.sr-about-grid p {
    margin: 18px 0 0;
    color: #555555;
    font-size: 16px;
    line-height: 1.7;
}

.sr-about-band {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 22px;
    margin-top: 18px;
    padding: clamp(24px, 5vw, 46px);
}

.sr-about-band h2 {
    max-width: 700px;
}

.sr-guides-page,
.sr-guide-page {
    padding: clamp(38px, 7vw, 96px) clamp(18px, 6vw, 110px);
    background: var(--shop-bg, #f6f6f6);
}

.sr-guides-hero,
.sr-guides-grid,
.sr-guides-empty,
.sr-guide-article {
    width: min(100%, 1180px);
    margin-inline: auto;
}

.sr-guides-hero {
    padding: 28px 0 clamp(34px, 6vw, 74px);
}

.sr-guides-hero h1,
.sr-guide-article h1 {
    max-width: 850px;
    margin: 0 0 18px;
    color: #171717;
    font-size: clamp(34px, 6vw, 76px);
    font-weight: 900;
    letter-spacing: 0;
    line-height: 0.96;
}

.sr-guides-hero p,
.sr-guide-article header p {
    max-width: 720px;
    margin: 0;
    color: #555555;
    font-size: clamp(17px, 2vw, 22px);
    line-height: 1.55;
}

.sr-guides-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.sr-guide-card,
.sr-guides-empty,
.sr-guide-article {
    border: 1px solid rgba(17, 17, 17, 0.08);
    background: #ffffff;
}

.sr-guide-card {
    display: grid;
    grid-template-rows: auto 1fr;
}

.sr-guide-card > div {
    display: grid;
    align-content: start;
    gap: 14px;
    padding: 24px;
}

.sr-guide-card-media {
    aspect-ratio: 4 / 3;
    background: #171717;
    color: #ffffff;
    display: grid;
    place-items: center;
    overflow: hidden;
    text-decoration: none;
}

.sr-guide-card-media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.sr-guide-card-media span {
    font-size: 13px;
    font-weight: 900;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.sr-guide-card h2 {
    margin: 0;
    font-size: clamp(20px, 2vw, 28px);
    line-height: 1.05;
}

.sr-guide-card h2 a {
    color: #171717;
    text-decoration: none;
}

.sr-guide-card p {
    margin: 0;
    color: #555555;
    line-height: 1.65;
}

.sr-guides-empty {
    padding: clamp(28px, 6vw, 64px);
}

.sr-guides-empty h2 {
    margin: 0 0 12px;
    font-size: clamp(24px, 4vw, 42px);
    line-height: 1.05;
}

.sr-guide-page > .sr-underlink {
    display: inline-flex;
    margin-bottom: 28px;
}

.sr-guide-article {
    padding: clamp(28px, 6vw, 74px);
}

.sr-guide-hero-image {
    display: block;
    width: 100%;
    max-height: 520px;
    margin: clamp(28px, 5vw, 54px) 0;
    object-fit: cover;
}

.sr-guide-content {
    max-width: 820px;
    color: #444444;
    font-size: 18px;
    line-height: 1.9;
}

.sr-form-alert {
    margin: 0 0 24px;
    padding: 16px 18px;
    font-weight: 700;
}

.sr-form-alert.is-success {
    background: #edf7ef;
    color: #2f7a50;
}

.sr-form-alert.is-error {
    background: #fff1eb;
    color: #b8612c;
}

.sr-warning,
.sr-alert.is-error {
    color: #b8612c;
}

.sr-alert {
    margin: 16px auto;
    max-width: 1180px;
    padding: 14px 18px;
    background: #f6f6f6;
    font-weight: 800;
}

.sr-alert.is-success {
    color: #2f7a50;
}

.sr-reveal {
    opacity: 0;
    transform: translateY(22px);
    transition: opacity 620ms ease, transform 620ms ease;
    will-change: opacity, transform;
}

.sr-reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
    .sr-reveal {
        opacity: 1;
        transform: none;
        transition: none;
    }
}

.sr-empty {
    padding: 48px;
    text-align: center;
}

.sr-empty.is-large {
    display: grid;
    justify-items: center;
    gap: 16px;
    padding: 80px 30px;
}

@media (max-width: 1180px) {
    .sr-product-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

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

@media (max-width: 920px) {
    .sr-header {
        grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
        min-height: 66px;
        padding: 14px 18px;
    }

    .sr-header-side {
        justify-content: flex-start;
    }

    .sr-header-actions {
        justify-content: flex-end;
    }

    .sr-menu-label,
    .sr-header-actions a:not(.sr-cart-link) {
        display: none;
    }

    .sr-header-actions .sr-language-form,
    .sr-header-search,
    .sr-theme-toggle {
        display: none;
    }

    .sr-menu-language-form {
        display: inline-flex;
        margin-top: 8px;
    }

    .sr-brand {
        font-size: 20px;
    }

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

    .sr-search-product-grid,
    .sr-search-results-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .sr-product-page,
    .sr-cart-page,
    .sr-status-page,
    .sr-about-hero,
    .sr-menu-layout {
        grid-template-columns: 1fr;
    }

    .sr-about-grid {
        grid-template-columns: 1fr;
    }

    .sr-guides-grid {
        grid-template-columns: 1fr;
    }

    .sr-about-mark {
        width: min(100%, 260px);
    }

    .sr-about-band {
        align-items: flex-start;
        flex-direction: column;
    }

    .sr-checkout-form fieldset {
        grid-template-columns: 1fr;
    }

    .sr-product-panel,
    .sr-cart-summary,
    .sr-status-summary {
        position: static;
        min-height: 0;
    }

    .sr-product-gallery img {
        flex: 0 0 100%;
        min-height: auto;
        aspect-ratio: 10 / 7;
        scroll-snap-align: start;
    }

    .sr-product-gallery {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        scrollbar-width: thin;
    }

    .sr-footer-grid,
    .sr-footer-bottom {
        grid-template-columns: 1fr;
    }

    .sr-footer-bottom,
    .sr-footer-bottom span:last-child {
        text-align: left;
    }

    .sr-menu-primary,
    .sr-menu-feature,
    .sr-menu-products {
        padding: 78px 28px 36px;
        border-right: 0;
        border-bottom: 1px solid #e5e5e5;
    }

    .sr-menu-products {
        grid-template-columns: 1fr 1fr;
    }

    .sr-cart-item {
        grid-template-columns: 130px minmax(0, 1fr);
    }

    .sr-status-card,
    .sr-status-line {
        grid-template-columns: 120px minmax(0, 1fr);
    }

    .sr-cart-item-actions {
        grid-column: 1 / -1;
        justify-items: start;
    }

    .sr-status-line p {
        grid-column: 2;
        text-align: left;
    }

    .sr-payment-success-steps {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 620px) {
    .sr-checkout-line {
        grid-template-columns: 70px minmax(0, 1fr);
        align-items: start;
    }

    .sr-checkout-line-image {
        width: 70px;
    }

    .sr-checkout-line-price {
        grid-column: 2;
    }

    .sr-filter-bar,
    .sr-size-options,
    .sr-menu-products {
        grid-template-columns: 1fr;
    }

    .sr-search-shell {
        padding: 26px 16px 44px;
    }

    .sr-search-close {
        top: 20px;
        right: 18px;
    }

    .sr-search-brand {
        margin-bottom: 26px;
        font-size: 24px;
    }

    .sr-search-form {
        min-height: 54px;
        margin-bottom: 32px;
        padding-inline: 18px;
    }

    .sr-search-title-row {
        align-items: flex-start;
        flex-direction: column;
    }

    .sr-catalog-context {
        align-items: flex-start;
        flex-direction: column;
    }

    .sr-search-product-grid,
    .sr-search-results-grid {
        gap: 14px;
    }

    .sr-search-result-card.is-category {
        min-height: 140px;
        padding: 20px;
    }

    .sr-product-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 14px;
    }

    .sr-product-meta {
        padding-top: 12px;
    }

    .sr-product-meta > a {
        font-size: 13px;
    }

    .sr-product-price-row {
        align-items: start;
        flex-direction: column;
        gap: 8px;
    }

    .sr-card-colors {
        justify-content: flex-start;
    }

    .sr-filter-toggle {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        min-height: 52px;
        padding: 0 18px;
        border: 1px solid #dedede;
        border-radius: 999px;
        background: #ffffff;
        color: #111111;
        font: inherit;
        font-weight: 750;
    }

    .sr-filter-toggle::after {
        content: "+";
        font-size: 20px;
        font-weight: 500;
    }

    .sr-filter-drawer.is-open .sr-filter-toggle::after {
        content: "−";
    }

    .sr-filter-toggle strong {
        display: grid;
        min-width: 22px;
        height: 22px;
        margin-left: auto;
        margin-right: 12px;
        place-items: center;
        border-radius: 50%;
        background: #111111;
        color: #ffffff;
        font-size: 12px;
    }

    .sr-filter-drawer .sr-filter-bar {
        display: none;
        margin-top: 12px;
    }

    .sr-filter-drawer.is-open .sr-filter-bar {
        display: grid;
    }

    .sr-hero {
        min-height: 86svh;
    }

    .sr-hero-fallback img {
        object-position: center top;
    }

    .sr-hero video {
        display: none;
    }

    .sr-section,
    .sr-page {
        padding-inline: 16px;
    }

    .sr-cart-list,
    .sr-cart-summary,
    .sr-status-main,
    .sr-status-summary,
    .sr-product-panel {
        padding-inline: 18px;
    }

    .sr-status-card,
    .sr-status-line {
        grid-template-columns: 1fr;
    }

    .sr-status-line p {
        grid-column: auto;
    }

    .sr-payment-success {
        padding-inline: 16px;
    }

    .sr-payment-success-card {
        padding: 28px 20px;
    }

    .sr-payment-success-card h1 {
        font-size: 21px;
    }

    .sr-payment-success-actions .sr-button,
    .sr-payment-success-actions .sr-underlink {
        width: 100%;
        justify-content: center;
    }

    .sr-legal-page {
        padding-inline: 16px;
    }

    .sr-legal-card {
        padding: 28px 20px;
    }

    .sr-legal-card h1 {
        font-size: 21px;
    }

    .sr-contact-page {
        padding-inline: 16px;
    }

    .sr-contact-card {
        padding: 28px 20px;
    }

    .sr-contact-hero h1 {
        font-size: 21px;
    }

    .sr-form-grid {
        grid-template-columns: 1fr;
    }

    .sr-cart-modal-panel {
        top: auto;
        bottom: 0;
    }

    .sr-cart-added-product {
        grid-template-columns: 96px minmax(0, 1fr);
    }

    .sr-gallery-panel {
        padding: 18px;
    }

    .sr-gallery-panel img {
        max-width: 100%;
        max-height: 78svh;
    }

    .sr-gallery-nav {
        top: auto;
        bottom: 24px;
        transform: none;
    }

    .sr-gallery-nav.is-prev {
        left: 18px;
    }

    .sr-gallery-nav.is-next {
        right: 18px;
    }
}

* {
    box-sizing: border-box;
}

body.shop-body {
    margin: 0;
    background: var(--shop-bg);
    color: var(--shop-text);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    letter-spacing: 0;
}

.shop-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 76px;
    padding: 20px clamp(18px, 5vw, 56px);
    background: var(--shop-panel);
    border-bottom: 1px solid var(--shop-border);
}

.shop-brand {
    color: var(--shop-primary);
    font-size: 24px;
    font-weight: 850;
    text-decoration: none;
}

.shop-nav {
    display: flex;
    gap: 16px;
}

.shop-nav a {
    color: var(--shop-muted);
    font-weight: 750;
    text-decoration: none;
}

.shop-main {
    padding: clamp(22px, 5vw, 54px);
}

.shop-product {
    display: grid;
    grid-template-columns: minmax(280px, 0.9fr) minmax(320px, 1.1fr);
    gap: 34px;
    max-width: 1180px;
    margin: 0 auto;
}

.shop-gallery,
.shop-info,
.shop-variants {
    border-radius: var(--shop-radius);
    background: var(--shop-panel);
    box-shadow: var(--shop-shadow);
}

.shop-gallery {
    display: grid;
    gap: 14px;
    align-content: start;
    padding: 18px;
}

.shop-gallery img {
    display: block;
    width: 100%;
    border-radius: 14px;
    object-fit: cover;
    background: #f0eef7;
}

.shop-gallery img[hidden] {
    display: none !important;
}

.shop-gallery img:first-child,
.shop-gallery img.is-featured {
    aspect-ratio: 4 / 5;
}

.shop-gallery img:not(:first-child):not(.is-featured) {
    aspect-ratio: 1;
}

.shop-info {
    padding: clamp(24px, 4vw, 42px);
}

.shop-breadcrumb {
    display: inline-flex;
    margin-bottom: 20px;
    color: var(--shop-muted);
    font-weight: 750;
    text-decoration: none;
}

.shop-info h1 {
    margin: 0;
    font-size: clamp(17px, 2.5vw, 28px);
    line-height: 1;
}

.shop-description {
    max-width: 640px;
    color: var(--shop-muted);
    font-size: 17px;
    line-height: 1.7;
}

.shop-price {
    margin: 22px 0;
    font-size: 26px;
    font-weight: 850;
}

.shop-alert {
    margin: 0 0 16px;
    padding: 13px 16px;
    border-radius: 12px;
    font-weight: 800;
}

.shop-alert.is-success {
    background: #eaf7ef;
    color: var(--shop-green);
}

.shop-alert.is-error {
    background: #fff0e8;
    color: #d96b43;
}

.shop-variants {
    margin-top: 24px;
    overflow: hidden;
}

.shop-variants h2 {
    margin: 0;
    padding: 22px 24px;
    font-size: 20px;
}

.shop-variant-list {
    display: grid;
    gap: 0;
}

.shop-color-options {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 0 24px 20px;
}

.shop-color-button {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    min-height: 42px;
    padding: 9px 14px;
    border: 1px solid var(--shop-border);
    border-radius: 999px;
    background: #ffffff;
    color: var(--shop-text);
    cursor: pointer;
    font: inherit;
    font-weight: 800;
}

.shop-color-button.is-active {
    border-color: var(--shop-primary);
    background: rgba(108, 92, 231, 0.1);
    color: var(--shop-primary);
}

.shop-color-swatch {
    width: 18px;
    height: 18px;
    border: 2px solid #ffffff;
    border-radius: 50%;
    box-shadow: 0 0 0 1px rgba(32, 35, 50, 0.12);
}

.shop-size-panel {
    padding: 0 24px 24px;
    border-top: 1px solid var(--shop-border);
}

.shop-variant-heading {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 0 14px;
}

.shop-variant-heading strong {
    font-size: 18px;
}

.shop-variant-heading span {
    color: var(--shop-muted);
    font-size: 14px;
    font-weight: 750;
}

.shop-size-options {
    display: grid;
    grid-template-columns: repeat(6, minmax(72px, 1fr));
    gap: 10px;
}

.shop-size-option {
    display: grid;
    gap: 4px;
    min-height: 70px;
    padding: 10px;
    border: 1px solid var(--shop-border);
    border-radius: 14px;
    background: #ffffff;
    cursor: pointer;
}

.shop-size-option input {
    position: absolute;
    inline-size: 1px;
    block-size: 1px;
    opacity: 0;
}

.shop-size-option span {
    color: var(--shop-text);
    font-size: 16px;
    font-weight: 900;
}

.shop-size-option small {
    color: var(--shop-muted);
    font-weight: 750;
}

.shop-size-option:has(input:checked) {
    border-color: var(--shop-primary);
    background: rgba(108, 92, 231, 0.1);
}

.shop-size-option.is-disabled {
    cursor: not-allowed;
    opacity: 0.48;
}

.shop-add-form.is-stacked {
    display: grid;
    gap: 18px;
}

.shop-add-row {
    display: flex;
    align-items: end;
    gap: 12px;
}

.shop-add-row label {
    display: grid;
    gap: 6px;
    color: var(--shop-muted);
    font-size: 13px;
    font-weight: 800;
}

.shop-variant {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 16px;
    align-items: center;
    padding: 18px 24px;
    border-top: 1px solid var(--shop-border);
}

.shop-variant strong {
    display: block;
    margin-bottom: 6px;
}

.shop-variant-meta {
    color: var(--shop-muted);
    font-size: 14px;
}

.shop-add-form {
    display: flex;
    gap: 10px;
    align-items: center;
}

.shop-add-form input {
    width: 78px;
    min-height: 42px;
    border: 1px solid var(--shop-border);
    border-radius: 12px;
    padding: 0 10px;
    font: inherit;
}

.shop-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 10px 18px;
    border: 0;
    border-radius: 12px;
    background: var(--shop-primary);
    color: #ffffff;
    font: inherit;
    font-size: 15px;
    font-weight: 800;
    line-height: 1.2;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
}

.shop-button:hover {
    background: var(--shop-primary-dark);
}

.shop-sold-out {
    color: #d96b43;
    font-weight: 800;
}

.account-main {
    max-width: 1240px;
    margin: 0 auto;
}

.account-shell {
    display: grid;
    grid-template-columns: 250px minmax(0, 1fr);
    gap: 24px;
}

.account-sidebar,
.account-card,
.account-auth-card {
    border-radius: var(--shop-radius);
    background: var(--shop-panel);
    box-shadow: var(--shop-shadow);
}

.account-sidebar {
    align-self: start;
    display: grid;
    gap: 8px;
    padding: 18px;
}

.account-sidebar a,
.account-sidebar button {
    display: flex;
    align-items: center;
    min-height: 44px;
    width: 100%;
    padding: 0 14px;
    border: 0;
    border-radius: 12px;
    background: var(--shop-panel-soft, #f8f7fc);
    color: var(--shop-muted);
    font: inherit;
    font-weight: 800;
    text-align: left;
    text-decoration: none;
    cursor: pointer;
}

.account-sidebar button {
    background: #fff0e8;
    color: #d96b43;
}

.account-card {
    overflow: hidden;
}

.account-card-header {
    padding: 30px 32px 22px;
}

.account-card-header h1,
.account-auth-card h1 {
    margin: 0;
    font-size: clamp(14px, 2vw, 21px);
    line-height: 1.05;
}

.account-card-header p,
.account-muted {
    color: var(--shop-muted);
}

.account-eyebrow {
    margin: 0 0 8px;
    color: var(--shop-muted);
    font-weight: 850;
}

.account-auth {
    display: grid;
    place-items: start center;
}

.account-auth-card {
    width: min(100%, 560px);
    padding: clamp(24px, 5vw, 42px);
}

.account-form {
    display: grid;
    gap: 16px;
    padding: 0 32px 32px;
}

.account-auth-card .account-form {
    padding: 0;
    margin-top: 24px;
}

.account-form h2 {
    margin: 8px 0 0;
    color: var(--shop-text);
    font-size: 20px;
}

.account-form-section {
    display: grid;
    gap: 14px;
    padding: 20px;
    border: 1px solid var(--shop-border);
    border-radius: 16px;
    background: #f8f7fc;
}

.account-form-section h2 {
    margin: 0;
}

.account-form-section .account-muted {
    margin: 6px 0 0;
    text-transform: none;
}

.account-form-grid,
.account-stat-grid,
.account-address-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.account-stat-grid {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    padding: 0 32px 24px;
}

.account-stat-grid div {
    padding: 18px;
    border-radius: 16px;
    background: #f8f7fc;
}

.account-stat-grid span {
    display: block;
    color: var(--shop-muted);
    font-size: 12px;
    font-weight: 850;
    text-transform: uppercase;
}

.account-stat-grid strong {
    display: block;
    margin-top: 8px;
    font-size: 22px;
}

.account-form label {
    display: grid;
    gap: 7px;
    color: var(--shop-muted);
    font-size: 12px;
    font-weight: 850;
    text-transform: uppercase;
}

.account-form input:not([type="checkbox"]),
.account-form select,
.account-form textarea {
    width: 100%;
    min-height: 46px;
    border: 1px solid var(--shop-border);
    border-radius: 12px;
    background: #ffffff;
    color: var(--shop-text);
    font: inherit;
    padding: 0 12px;
    outline: none;
}

.account-form textarea {
    min-height: 130px;
    padding: 14px;
    resize: vertical;
}

.sr-password-field {
    position: relative;
    display: block;
}

.account-form .sr-password-field input:not([type="checkbox"]),
.sr-password-field input:not([type="checkbox"]) {
    padding-right: 94px;
}

.sr-password-toggle {
    position: absolute;
    right: 8px;
    top: 50%;
    min-height: 32px;
    transform: translateY(-50%);
    border: 1px solid transparent;
    border-radius: 999px;
    background: #f0f0f0;
    color: #111111;
    cursor: pointer;
    font: inherit;
    font-size: 12px;
    font-weight: 850;
    padding: 0 12px;
}

.sr-password-toggle:hover {
    border-color: #111111;
}

.account-form input:focus,
.account-form select:focus,
.account-form textarea:focus {
    border-color: rgba(108, 92, 231, 0.45);
    box-shadow: 0 0 0 4px rgba(108, 92, 231, 0.08);
}

.account-check {
    display: flex !important;
    align-items: center;
    gap: 10px;
    min-height: 42px;
    padding: 10px 12px;
    border-radius: 12px;
    background: #f8f7fc;
}

.account-check input {
    width: 18px;
    height: 18px;
    accent-color: var(--shop-primary);
}

.account-return-options {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 14px;
}

.account-return-helper {
    margin: 0 0 14px;
    padding: 14px 16px;
    border: 1px solid rgba(108, 92, 231, 0.16);
    border-radius: 14px;
    background: #f4f1ff;
    color: #4d5668;
    font-size: 14px;
    font-weight: 750;
    line-height: 1.55;
}

.account-action-panel,
.account-timeline {
    margin: 0 32px 24px;
}

.account-verification-notice {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin: 0 32px 24px;
    padding: 18px 20px;
    border: 1px solid rgba(221, 159, 45, 0.24);
    background: #fff8ea;
}

.account-verification-notice div {
    display: grid;
    gap: 5px;
}

.account-verification-notice strong {
    color: #171717;
    font-size: 16px;
}

.account-verification-notice span {
    color: #666666;
    line-height: 1.5;
}

.account-verification-notice form {
    flex: 0 0 auto;
    margin: 0;
}

.account-action-panel {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 20px;
    border: 1px solid rgba(108, 92, 231, 0.16);
    border-radius: 18px;
    background: linear-gradient(135deg, #f4f1ff 0%, #eff7ff 100%);
}

.account-action-panel div {
    display: grid;
    gap: 6px;
}

.account-action-panel strong {
    color: var(--shop-text);
    font-size: 17px;
}

.account-action-panel span {
    color: var(--shop-muted);
    line-height: 1.55;
}

.account-return-guide {
    margin: 0 32px 24px;
    padding: 20px;
    border: 1px solid rgba(108, 92, 231, 0.16);
    border-radius: 18px;
    background: #f4f1ff;
}

.account-return-guide h2 {
    margin: 0 0 12px;
    font-size: 20px;
}

.account-return-guide ol {
    display: grid;
    gap: 10px;
    margin: 0;
    padding-left: 22px;
}

.account-return-guide li {
    color: #4d5668;
    line-height: 1.55;
}

.account-return-guide strong {
    color: var(--shop-text);
}

.account-status-callout {
    display: grid;
    gap: 6px;
    margin: 0 32px 24px;
    padding: 18px 20px;
    border-radius: 18px;
    border: 1px solid #bfe9cd;
    background: #eefaf2;
    color: #27663d;
}

.account-status-callout strong {
    color: #1f6f3c;
    font-size: 18px;
}

.account-status-callout span {
    line-height: 1.55;
}

.account-status-actions {
    display: grid;
    justify-items: start;
    gap: 10px;
}

.account-timeline {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 10px;
}

.account-timeline article {
    position: relative;
    display: grid;
    gap: 6px;
    min-height: 92px;
    padding: 16px;
    border-radius: 16px;
    background: #f8f7fc;
    color: var(--shop-muted);
}

.account-timeline article::before {
    content: "";
    width: 12px;
    height: 12px;
    border-radius: 999px;
    background: #d8dbe8;
}

.account-timeline article.is-done {
    background: #edf9f2;
    color: #427a57;
}

.account-timeline article.is-done::before {
    background: #48a567;
}

.account-timeline strong {
    color: var(--shop-text);
}

.account-timeline span {
    font-size: 13px;
    line-height: 1.35;
}

.account-section {
    margin: 0 32px 24px;
    padding: 20px;
    border-radius: 16px;
    background: #f8f7fc;
}

.account-form .account-section {
    margin: 0 0 16px;
}

.account-section h2 {
    margin: 0 0 16px;
    font-size: 20px;
}

.account-table-wrap {
    overflow-x: auto;
}

.account-table {
    width: 100%;
    min-width: 760px;
    border-collapse: separate;
    border-spacing: 0;
}

.account-table th {
    padding: 14px 16px;
    background: #ffffff;
    color: #3d4352;
    font-size: 13px;
    font-weight: 850;
    text-align: left;
}

.account-table td {
    padding: 16px;
    border-bottom: 1px solid var(--shop-border);
    color: #4d5668;
}

.account-order-product {
    display: grid;
    grid-template-columns: 58px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
}

.account-order-product img,
.account-order-product-placeholder {
    display: block;
    width: 58px;
    aspect-ratio: 1;
    border-radius: 12px;
    background: #f0eef7;
    object-fit: cover;
}

.account-table a,
.account-muted a {
    color: var(--shop-primary);
    font-weight: 850;
    text-decoration: none;
}

.account-table a.shop-button,
.account-muted a.shop-button {
    color: #ffffff;
}

.account-table a.shop-button:hover,
.account-muted a.shop-button:hover {
    color: #ffffff;
}

.account-row-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    min-width: 190px;
}

.account-small-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 10px 16px;
    border-radius: 12px;
    background: #ffffff;
    color: var(--shop-primary);
    font-size: 14px;
    font-weight: 850;
    line-height: 1.2;
    text-align: center;
    text-decoration: none;
    white-space: nowrap;
}

.account-small-button.is-primary {
    background: var(--shop-primary);
    color: #ffffff;
}

.account-badge {
    display: inline-flex;
    min-height: 30px;
    align-items: center;
    padding: 6px 10px;
    border-radius: 10px;
    background: #f0ecff;
    color: var(--shop-primary);
    font-size: 12px;
    font-weight: 850;
}

.account-inline-button {
    width: fit-content;
    max-width: 100%;
    white-space: nowrap;
    text-decoration: none;
}

.account-inline-button.is-disabled {
    background: #eef0f5;
    color: var(--shop-muted);
    cursor: not-allowed;
}

.account-summary-list,
.account-delivery-list {
    display: grid;
    gap: 10px;
}

.account-summary-list div,
.account-delivery-list article {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 16px;
    border-radius: 14px;
    background: #ffffff;
}

.account-summary-list span,
.account-delivery-list span {
    color: var(--shop-muted);
}

.account-summary-list .is-total {
    background: #f0ecff;
    color: var(--shop-primary);
}

.account-summary-list .is-total span,
.account-summary-list .is-total strong {
    color: var(--shop-primary);
}

.account-cart-empty {
    display: grid;
    gap: 14px;
    min-height: 280px;
    align-content: center;
    text-align: center;
}

.account-cart-list {
    display: grid;
    gap: 18px;
}

.account-cart-line {
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr) auto;
    gap: 18px;
    align-items: center;
    padding: 18px 0;
    border-bottom: 1px solid var(--shop-border);
}

.account-cart-line:first-child {
    padding-top: 0;
}

.account-cart-line:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.account-cart-thumb,
.account-cart-thumb img {
    display: block;
    width: 92px;
    aspect-ratio: 1;
}

.account-cart-thumb {
    overflow: hidden;
    background: #ffffff;
}

.account-cart-thumb img {
    object-fit: contain;
}

.account-cart-line small {
    display: block;
    margin-bottom: 6px;
    color: var(--shop-muted);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.account-cart-line strong {
    color: var(--shop-text);
}

.account-cart-line p {
    margin: 6px 0 0;
    color: var(--shop-muted);
}

.account-cart-total {
    display: grid;
    gap: 10px;
}

.account-cart-total div {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    padding: 14px 16px;
    background: #ffffff;
}

.account-cart-total span {
    color: var(--shop-muted);
}

.account-cart-total .is-total {
    background: #111111;
    color: #ffffff;
}

.account-cart-total .is-total span,
.account-cart-total .is-total strong {
    color: #ffffff;
}

.account-cart-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 22px;
}

.account-delivery-list article {
    align-items: flex-start;
    flex-direction: column;
}

.account-delivery-list a {
    color: var(--shop-primary);
    font-weight: 850;
    text-decoration: none;
}

.account-address-grid address {
    padding: 16px;
    border-radius: 14px;
    background: #ffffff;
    color: #4d5668;
    font-style: normal;
    line-height: 1.6;
}

@media (max-width: 880px) {
    .shop-product {
        grid-template-columns: 1fr;
    }

    .shop-variant {
        grid-template-columns: 1fr;
    }

    .shop-size-options {
        grid-template-columns: repeat(3, minmax(72px, 1fr));
    }

    .account-shell,
    .account-form-grid,
    .account-stat-grid,
    .account-address-grid,
    .account-timeline,
    .account-return-options {
        grid-template-columns: 1fr;
    }

    .account-sidebar {
        position: static;
    }

    .account-action-panel,
    .account-verification-notice {
        align-items: flex-start;
        flex-direction: column;
    }
}

@media (max-width: 620px) {
    .shop-add-row {
        align-items: stretch;
        flex-direction: column;
    }

    .shop-size-options {
        grid-template-columns: repeat(2, minmax(72px, 1fr));
    }

    .shop-header {
        align-items: flex-start;
        flex-direction: column;
        gap: 12px;
    }

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

    .account-card-header,
    .account-form,
    .account-stat-grid {
        padding-right: 18px;
        padding-left: 18px;
    }

    .account-section {
        margin-right: 18px;
        margin-left: 18px;
    }

    .account-form .account-section {
        margin-right: 0;
        margin-left: 0;
    }

    .account-action-panel,
    .account-timeline,
    .account-return-guide {
        margin-right: 18px;
        margin-left: 18px;
    }
}

/* Premium account area */
body.account-body {
    background: #f6f6f6;
    color: #171717;
}

.account-body .shop-button {
    min-height: 52px;
    padding: 0 30px;
    border: 1px solid #000000;
    border-radius: 999px;
    background: #000000;
    color: #ffffff;
    font-size: 15px;
    font-weight: 650;
}

.account-body .shop-button:hover {
    background: #252525;
}

.account-body .shop-alert {
    margin: 0 clamp(26px, 5vw, 78px) 24px;
    padding: 16px 18px;
    border: 1px solid #e8e8e8;
    background: #ffffff;
    color: #171717;
    font-weight: 650;
}

.account-body .shop-alert.is-success {
    border-color: #cfe8d7;
    background: #eff8f2;
    color: #336d4a;
}

.account-body .shop-alert.is-error {
    border-color: #f0d3c3;
    background: #fff5ef;
    color: #9b4f24;
}

.account-auth-card .shop-alert {
    margin: 18px 0;
}

.account-body .shop-button.is-disabled,
.account-body .account-inline-button.is-disabled {
    border-color: #e3e3e3;
    background: #f2f2f2;
    color: #777777;
    cursor: not-allowed;
}

.account-main {
    max-width: none;
    margin: 0;
    padding: clamp(28px, 5vw, 76px) clamp(18px, 5vw, 82px);
    background: #f6f6f6;
}

.account-shell {
    grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
    gap: clamp(22px, 3vw, 42px);
    width: min(1480px, 100%);
    margin: 0 auto;
}

.account-sidebar,
.account-card,
.account-auth-card {
    border-radius: 0;
    background: #ffffff;
    box-shadow: none;
}

.account-sidebar {
    position: sticky;
    top: 112px;
    gap: 0;
    min-height: calc(100svh - 150px);
    padding: 32px 30px;
}

.account-sidebar-title {
    margin: 0 0 22px;
    color: #707070;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.account-sidebar a,
.account-sidebar button {
    min-height: 58px;
    padding: 0;
    border-radius: 0;
    border-bottom: 1px solid #e8e8e8;
    background: transparent;
    color: #555555;
    font-size: 16px;
    font-weight: 500;
}

.account-sidebar a {
    justify-content: space-between;
    gap: 12px;
}

.account-nav-badge {
    display: inline-flex;
    min-width: 24px;
    height: 24px;
    align-items: center;
    justify-content: center;
    padding: 0 7px;
    border-radius: 999px;
    background: #d64535;
    color: #ffffff;
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
    text-decoration: none;
}

.account-nav-points {
    display: inline-flex;
    min-width: 24px;
    height: 24px;
    align-items: center;
    justify-content: center;
    padding: 0 7px;
    border-radius: 0;
    background: #111111;
    color: #ffffff;
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
    text-decoration: none;
}

.account-sidebar a:hover,
.account-sidebar a.is-active {
    color: #111111;
    text-decoration: none;
}

.account-sidebar a:hover > span:first-child,
.account-sidebar a.is-active > span:first-child {
    text-decoration: underline;
    text-underline-offset: 7px;
}

.account-sidebar a.is-active {
    font-weight: 800;
}

.account-sidebar form {
    margin-top: auto;
    padding-top: 28px;
}

.account-sidebar button {
    justify-content: center;
    min-height: 52px;
    border: 1px solid #111111;
    border-radius: 999px;
    color: #111111;
    font-weight: 650;
    text-align: center;
}

.account-danger-zone {
    margin: 0 clamp(26px, 5vw, 78px) 28px;
    padding: clamp(22px, 3vw, 34px);
    border: 1px solid #e8e8e8;
    background: #ffffff;
}

.account-danger-zone h2 {
    margin: 0 0 10px;
    color: #171717;
    font-size: 24px;
    font-weight: 500;
}

.account-danger-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    margin-top: 20px;
}

.account-danger-card {
    display: grid;
    align-content: start;
    gap: 12px;
    padding: 22px;
    border: 1px solid #e8e8e8;
    background: #f7f7f7;
}

.account-danger-card strong {
    color: #171717;
    font-size: 18px;
}

.account-danger-card p {
    margin: 0;
    color: #666666;
    line-height: 1.55;
}

.account-danger-card.is-danger {
    border-color: rgba(184, 51, 51, 0.28);
    background: rgba(184, 51, 51, 0.06);
}

.account-small-button.is-danger {
    border-color: #b83333;
    background: #b83333;
    color: #ffffff;
}

.account-small-button.is-danger:hover {
    background: #922727;
    color: #ffffff;
}

.account-loyalty-header {
    display: flex;
    justify-content: space-between;
    gap: 24px;
    align-items: flex-start;
}

.account-loyalty-header strong {
    color: #171717;
    font-size: clamp(34px, 5vw, 64px);
    font-weight: 500;
    line-height: 1;
}

.account-loyalty-progress {
    height: 8px;
    margin: 24px 0;
    overflow: hidden;
    background: #ececec;
}

.account-loyalty-progress span {
    display: block;
    height: 100%;
    background: #111111;
}

.account-loyalty-tiers {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 14px;
}

.account-loyalty-tier {
    display: grid;
    align-content: start;
    gap: 10px;
    min-height: 180px;
    padding: 18px;
    border: 1px solid #e5e5e5;
    background: #ffffff;
}

.account-loyalty-tier span {
    justify-self: start;
    padding: 6px 10px;
    border-radius: 999px;
    background: #f2f2f2;
    color: #707070;
    font-size: 11px;
    font-weight: 850;
    text-transform: uppercase;
}

.account-loyalty-tier strong {
    color: #171717;
    font-size: 22px;
}

.account-loyalty-tier h3 {
    margin: 0;
    color: #171717;
    font-size: 18px;
    font-weight: 650;
}

.account-loyalty-tier p {
    margin: 0;
    color: #666666;
    line-height: 1.45;
}

.account-loyalty-tier.is-reached {
    border-color: #cdebd4;
    background: #effaf2;
}

.account-loyalty-tier.is-reached span {
    background: #ffffff;
    color: #36764b;
}

.account-loyalty-tier.is-next {
    border-color: #111111;
}

.account-loyalty-path {
    position: relative;
    display: grid;
    gap: 28px;
    margin-top: 30px;
    padding: 8px 0;
}

.account-loyalty-path::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    width: 1px;
    background: #d8d8d8;
    transform: translateX(-50%);
}

.account-loyalty-path-node {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 72px minmax(0, 1fr);
    align-items: center;
}

.account-loyalty-path-dot {
    z-index: 1;
    grid-column: 2;
    justify-self: center;
    width: 18px;
    height: 18px;
    border: 2px solid #111111;
    background: #ffffff;
}

.account-loyalty-path-card {
    display: grid;
    gap: 16px;
    min-height: 160px;
    padding: 22px;
    border: 1px solid #e5e5e5;
    background: #ffffff;
}

.account-loyalty-path-node.is-left .account-loyalty-path-card {
    grid-column: 1;
}

.account-loyalty-path-node.is-right .account-loyalty-path-card {
    grid-column: 3;
}

.account-loyalty-image,
.account-loyalty-placeholder {
    width: 100%;
    aspect-ratio: 2 / 1;
    background: #f4f4f4;
}

.account-loyalty-image {
    display: block;
    object-fit: cover;
}

.account-loyalty-placeholder {
    display: grid;
    place-items: center;
    color: #171717;
    font-size: 32px;
    font-weight: 800;
}

.account-loyalty-copy {
    display: grid;
    gap: 10px;
}

.account-loyalty-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.account-loyalty-status,
.account-loyalty-points {
    padding: 6px 10px;
    background: #f2f2f2;
    color: #707070;
    font-size: 11px;
    font-weight: 850;
    text-transform: uppercase;
}

.account-loyalty-points {
    min-width: 38px;
    text-align: center;
}

.account-loyalty-copy strong {
    color: #171717;
    font-size: clamp(28px, 4vw, 48px);
    line-height: 1;
}

.account-loyalty-copy h3 {
    margin: 0;
    color: #171717;
    font-size: clamp(17px, 2vw, 24px);
    line-height: 1.1;
}

.account-loyalty-copy small {
    color: #707070;
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.account-loyalty-copy p {
    margin: 0;
    color: #666666;
    line-height: 1.5;
}

.account-loyalty-path-node.is-reached .account-loyalty-path-card {
    border-color: #cdebd4;
    background: #effaf2;
}

.account-loyalty-path-node.is-reached .account-loyalty-path-dot {
    border-color: #36764b;
    background: #36764b;
}

.account-loyalty-path-node.is-reached .account-loyalty-status,
.account-loyalty-path-node.is-reached .account-loyalty-points {
    background: #ffffff;
    color: #36764b;
}

.account-loyalty-path-node.is-next .account-loyalty-path-card {
    border-color: #111111;
}

.account-card {
    overflow: hidden;
}

.account-card-header {
    padding: clamp(34px, 5vw, 72px) clamp(26px, 5vw, 78px) 28px;
}

.account-card-header h1,
.account-auth-card h1 {
    color: #171717;
    font-size: clamp(21px, 3vw, 36px);
    font-weight: 500;
    letter-spacing: 0;
}

.account-card-header p,
.account-muted {
    color: #666666;
    line-height: 1.6;
}

.account-eyebrow {
    margin: 0 0 12px;
    color: #707070;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.account-auth {
    display: grid;
    min-height: calc(100svh - 86px);
    place-items: center;
    padding: clamp(34px, 6vw, 86px) 18px;
    background: #f6f6f6;
}

.account-auth-card {
    width: min(100%, 620px);
    padding: clamp(34px, 5vw, 64px);
}

.account-form {
    gap: 22px;
    padding: 0 clamp(26px, 5vw, 78px) clamp(34px, 5vw, 72px);
}

.account-auth-card .account-form {
    padding: 0;
}

.account-form h2,
.account-section h2,
.account-return-guide h2 {
    color: #171717;
    font-size: 24px;
    font-weight: 500;
}

.account-form-section,
.account-section,
.account-action-panel,
.account-return-guide,
.account-timeline article,
.account-stat-grid div {
    border: 1px solid #e8e8e8;
    border-radius: 0;
    background: #f7f7f7;
    box-shadow: none;
}

.account-form-section {
    gap: 18px;
    padding: clamp(22px, 3vw, 32px);
}

.account-stat-grid {
    gap: 14px;
    padding: 0 clamp(26px, 5vw, 78px) 28px;
}

.account-stat-grid div {
    min-height: 126px;
    padding: 24px;
}

.account-stat-grid span {
    color: #707070;
    font-size: 11px;
    letter-spacing: 0.12em;
}

.account-stat-grid strong {
    margin-top: 18px;
    color: #171717;
    font-size: clamp(24px, 3vw, 34px);
    font-weight: 500;
}

.account-form label {
    gap: 9px;
    color: #666666;
    font-size: 12px;
    letter-spacing: 0.08em;
}

.account-form input:not([type="checkbox"]),
.account-form select,
.account-form textarea,
.account-section input,
.account-section select,
.account-section textarea {
    min-height: 50px;
    border: 0;
    border-bottom: 1px solid #cfcfcf;
    border-radius: 0;
    background: #ffffff;
    color: #111111;
    font: inherit;
}

.account-section input,
.account-section select,
.account-section textarea {
    padding: 10px 12px;
}

.account-form input:focus,
.account-form select:focus,
.account-form textarea:focus,
.account-section input:focus,
.account-section select:focus,
.account-section textarea:focus {
    border-color: #111111;
    box-shadow: none;
    outline: 0;
}

.account-check {
    border: 1px solid #e8e8e8;
    border-radius: 0;
    background: #ffffff;
}

.account-check input {
    accent-color: #111111;
}

.account-action-panel,
.account-timeline,
.account-return-guide,
.account-section {
    margin: 0 clamp(26px, 5vw, 78px) 28px;
}

.account-action-panel {
    align-items: center;
    padding: clamp(22px, 3vw, 32px);
    background: #ffffff;
}

.account-action-panel strong {
    color: #171717;
    font-size: 20px;
    font-weight: 500;
}

.account-action-panel span {
    color: #666666;
}

.account-return-guide {
    padding: clamp(22px, 3vw, 32px);
    background: #ffffff;
}

.account-return-guide li {
    color: #555555;
}

.account-timeline {
    gap: 12px;
}

.account-timeline article {
    min-height: 130px;
    padding: 22px;
    color: #666666;
}

.account-timeline article::before {
    width: 10px;
    height: 10px;
    background: #cfcfcf;
}

.account-timeline article.is-done {
    border-color: #cfe8d7;
    background: #eff8f2;
    color: #336d4a;
}

.account-timeline strong {
    color: #171717;
    font-size: 17px;
    font-weight: 650;
}

.account-section {
    padding: clamp(22px, 3vw, 34px);
}

.account-form .account-section {
    margin: 0 0 18px;
}

.account-table th {
    padding: 16px 18px;
    background: #ffffff;
    color: #707070;
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.account-table td {
    padding: 20px 18px;
    border-bottom: 1px solid #e3e3e3;
    color: #4f4f4f;
}

.account-table a,
.account-muted a,
.account-delivery-list a {
    color: #111111;
    font-weight: 650;
    text-decoration: underline;
    text-underline-offset: 5px;
}

.account-body .account-table a.shop-button,
.account-body .account-muted a.shop-button {
    color: #ffffff;
    text-decoration: none;
}

.account-order-product {
    grid-template-columns: 76px minmax(0, 1fr);
    gap: 16px;
}

.account-order-product img,
.account-order-product-placeholder {
    width: 76px;
    border-radius: 0;
    background: #eeeeee;
    object-fit: contain;
}

.account-small-button {
    min-height: 42px;
    padding: 0 16px;
    border: 1px solid #d9d9d9;
    border-radius: 999px;
    background: #ffffff;
    color: #111111;
    font-size: 13px;
    font-weight: 650;
}

.account-small-button.is-primary {
    border-color: #000000;
    background: #000000;
    color: #ffffff;
}

.account-inline-form {
    display: flex;
    margin: 12px 0 0;
}

.account-inline-form .account-small-button,
.account-inline-form .shop-button {
    cursor: pointer;
}

.account-stat-grid .account-inline-form {
    margin-top: 18px;
}

.account-table .account-inline-form {
    margin-top: 10px;
}

.account-row-actions .account-inline-form {
    margin: 0;
}

.account-action-panel > .account-inline-form {
    margin-top: 0;
}

.account-payment-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-top: 18px;
    padding: 18px;
    border: 1px solid #e8e8e8;
    background: #ffffff;
}

.account-payment-actions span {
    color: #666666;
    font-size: 14px;
    line-height: 1.5;
}

.account-payment-actions .shop-button {
    flex: 0 0 auto;
}

.account-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    min-width: 128px;
    padding: 0 18px;
    border-radius: 999px;
    background: #ffffff;
    color: #171717;
    font-size: 12px;
    font-weight: 650;
    line-height: 1.15;
    text-align: center;
    white-space: nowrap;
}

.account-table th,
.account-table td {
    vertical-align: middle;
}

.account-same-address {
    margin: 2px 0 4px;
}

.account-summary-list div,
.account-delivery-list article,
.account-address-grid address {
    border-radius: 0;
    background: #ffffff;
}

.account-summary-list .is-total {
    background: #111111;
    color: #ffffff;
}

.account-summary-list .is-total span,
.account-summary-list .is-total strong {
    color: #ffffff;
}

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

    .account-sidebar {
        position: static;
        min-height: 0;
    }

    .account-sidebar form {
        margin-top: 18px;
    }
}

@media (max-width: 700px) {
    .account-main {
        padding-inline: 0;
    }

    .account-card-header,
    .account-form,
    .account-stat-grid {
        padding-right: 18px;
        padding-left: 18px;
    }

    .account-action-panel,
    .account-verification-notice,
    .account-timeline,
    .account-return-guide,
    .account-status-callout,
    .account-section,
    .account-danger-zone {
        margin-right: 18px;
        margin-left: 18px;
    }

    .account-card-header h1,
    .account-auth-card h1 {
        font-size: 21px;
    }

    .account-sidebar {
        padding: 24px 18px;
    }

    .account-sidebar a,
    .account-sidebar button {
        min-height: 50px;
    }

    .account-payment-actions,
    .account-verification-notice {
        align-items: stretch;
        flex-direction: column;
    }

    .account-payment-actions .shop-button {
        width: 100%;
    }

    .account-danger-grid,
    .account-loyalty-tiers {
        grid-template-columns: 1fr;
    }

    .account-loyalty-header {
        display: grid;
    }

    .account-loyalty-path {
        gap: 22px;
    }

    .account-loyalty-path::before {
        left: 12px;
        transform: none;
    }

    .account-loyalty-path-node {
        grid-template-columns: 28px minmax(0, 1fr);
        align-items: flex-start;
    }

    .account-loyalty-path-dot {
        grid-column: 1;
        margin-top: 28px;
    }

    .account-loyalty-path-node.is-left .account-loyalty-path-card,
    .account-loyalty-path-node.is-right .account-loyalty-path-card {
        grid-column: 2;
    }

    .account-loyalty-path-card {
        gap: 14px;
        min-height: 0;
        padding: 16px;
    }

    .account-loyalty-image,
    .account-loyalty-placeholder {
        width: 100%;
    }

    .account-loyalty-copy strong {
        font-size: 26px;
    }

    .account-loyalty-copy h3 {
        font-size: 16px;
    }
}

@media (min-width: 701px) and (max-width: 1100px) {
    .account-loyalty-tiers {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Dark mode: account area */
html[data-sr-theme="dark"] body.account-body,
html[data-sr-theme="dark"] .account-main,
html[data-sr-theme="dark"] .account-auth {
    background: #050505;
    color: #f4f4f4;
}

html[data-sr-theme="dark"] .account-sidebar,
html[data-sr-theme="dark"] .account-card,
html[data-sr-theme="dark"] .account-auth-card,
html[data-sr-theme="dark"] .account-form-section,
html[data-sr-theme="dark"] .account-section,
html[data-sr-theme="dark"] .account-action-panel,
html[data-sr-theme="dark"] .account-return-guide,
html[data-sr-theme="dark"] .account-status-callout,
html[data-sr-theme="dark"] .account-timeline article,
html[data-sr-theme="dark"] .account-stat-grid div,
html[data-sr-theme="dark"] .account-payment-actions,
html[data-sr-theme="dark"] .account-summary-list div,
html[data-sr-theme="dark"] .account-delivery-list article,
html[data-sr-theme="dark"] .account-address-grid address {
    border-color: #2b2b2b;
    background: #0d0d0d;
    color: #f4f4f4;
}

html[data-sr-theme="dark"] .account-card-header h1,
html[data-sr-theme="dark"] .account-auth-card h1,
html[data-sr-theme="dark"] .account-form h2,
html[data-sr-theme="dark"] .account-section h2,
html[data-sr-theme="dark"] .account-return-guide h2,
html[data-sr-theme="dark"] .account-status-callout strong,
html[data-sr-theme="dark"] .account-stat-grid strong,
html[data-sr-theme="dark"] .account-action-panel strong,
html[data-sr-theme="dark"] .account-timeline strong,
html[data-sr-theme="dark"] .account-order-product strong {
    color: #f4f4f4;
}

html[data-sr-theme="dark"] .account-card-header p,
html[data-sr-theme="dark"] .account-muted,
html[data-sr-theme="dark"] .account-eyebrow,
html[data-sr-theme="dark"] .account-sidebar-title,
html[data-sr-theme="dark"] .account-stat-grid span,
html[data-sr-theme="dark"] .account-form label,
html[data-sr-theme="dark"] .account-action-panel span,
html[data-sr-theme="dark"] .account-return-guide li,
html[data-sr-theme="dark"] .account-status-callout span,
html[data-sr-theme="dark"] .account-timeline span,
html[data-sr-theme="dark"] .account-payment-actions span,
html[data-sr-theme="dark"] .account-summary-list span,
html[data-sr-theme="dark"] .account-delivery-list span {
    color: #b8b8b8;
}

html[data-sr-theme="dark"] .account-sidebar a,
html[data-sr-theme="dark"] .account-sidebar button {
    border-color: #2b2b2b;
    color: #e8e8e8;
}

html[data-sr-theme="dark"] .account-sidebar a:hover,
html[data-sr-theme="dark"] .account-sidebar a.is-active {
    color: #ffffff;
}

html[data-sr-theme="dark"] .account-status-callout {
    border-color: #225c35;
    background: #071a10;
    color: #c7f3d4;
}

html[data-sr-theme="dark"] .account-status-callout strong {
    color: #86efac;
}

html[data-sr-theme="dark"] .account-status-callout span {
    color: #c7f3d4;
}

html[data-sr-theme="dark"] .account-sidebar button {
    border-color: #f4f4f4;
    color: #f4f4f4;
}

html[data-sr-theme="dark"] .account-sidebar button:hover {
    background: #f4f4f4;
    color: #050505;
}

html[data-sr-theme="dark"] .account-nav-badge {
    background: #e64d3c;
    color: #ffffff;
}

html[data-sr-theme="dark"] .account-nav-points {
    background: #f4f4f4;
    color: #050505;
}

html[data-sr-theme="dark"] .account-body .shop-button,
html[data-sr-theme="dark"] .account-body .account-small-button.is-primary,
html[data-sr-theme="dark"] .account-body .account-inline-button {
    border-color: #f4f4f4;
    background: #f4f4f4;
    color: #050505;
}

html[data-sr-theme="dark"] .account-body .shop-button:hover,
html[data-sr-theme="dark"] .account-body .account-small-button.is-primary:hover,
html[data-sr-theme="dark"] .account-body .account-inline-button:hover {
    background: #dcdcdc;
    color: #050505;
}

html[data-sr-theme="dark"] .account-body .shop-button.is-disabled,
html[data-sr-theme="dark"] .account-body .account-inline-button.is-disabled {
    border-color: #2b2b2b;
    background: #151515;
    color: #777777;
}

html[data-sr-theme="dark"] .account-danger-zone,
html[data-sr-theme="dark"] .account-danger-card,
html[data-sr-theme="dark"] .account-loyalty-tier {
    border-color: #2b2b2b;
    background: #0d0d0d;
    color: #f4f4f4;
}

html[data-sr-theme="dark"] .account-danger-zone h2,
html[data-sr-theme="dark"] .account-danger-card strong,
html[data-sr-theme="dark"] .account-loyalty-header strong,
html[data-sr-theme="dark"] .account-loyalty-tier strong,
html[data-sr-theme="dark"] .account-loyalty-tier h3 {
    color: #f4f4f4;
}

html[data-sr-theme="dark"] .account-danger-card p,
html[data-sr-theme="dark"] .account-loyalty-tier p {
    color: #b8b8b8;
}

html[data-sr-theme="dark"] .account-danger-card.is-danger {
    border-color: #6d2c1c;
    background: #240b05;
}

html[data-sr-theme="dark"] .account-small-button.is-danger {
    border-color: #b83333;
    background: #b83333;
    color: #ffffff;
}

html[data-sr-theme="dark"] .account-loyalty-progress {
    background: #2b2b2b;
}

html[data-sr-theme="dark"] .account-loyalty-progress span {
    background: #f4f4f4;
}

html[data-sr-theme="dark"] .account-loyalty-tier span {
    background: #1a1a1a;
    color: #b8b8b8;
}

html[data-sr-theme="dark"] .account-loyalty-tier.is-reached {
    border-color: #245d39;
    background: #092012;
}

html[data-sr-theme="dark"] .account-loyalty-tier.is-reached span {
    background: #0d0d0d;
    color: #9de0b5;
}

html[data-sr-theme="dark"] .account-loyalty-tier.is-next {
    border-color: #f4f4f4;
}

html[data-sr-theme="dark"] .account-loyalty-path::before {
    background: #2b2b2b;
}

html[data-sr-theme="dark"] .account-loyalty-path-dot {
    border-color: #f4f4f4;
    background: #050505;
}

html[data-sr-theme="dark"] .account-loyalty-path-card {
    border-color: #2b2b2b;
    background: #0d0d0d;
    color: #f4f4f4;
}

html[data-sr-theme="dark"] .account-loyalty-image,
html[data-sr-theme="dark"] .account-loyalty-placeholder {
    background: #151515;
}

html[data-sr-theme="dark"] .account-loyalty-placeholder,
html[data-sr-theme="dark"] .account-loyalty-copy strong,
html[data-sr-theme="dark"] .account-loyalty-copy h3 {
    color: #f4f4f4;
}

html[data-sr-theme="dark"] .account-loyalty-copy small,
html[data-sr-theme="dark"] .account-loyalty-copy p {
    color: #b8b8b8;
}

html[data-sr-theme="dark"] .account-loyalty-status,
html[data-sr-theme="dark"] .account-loyalty-points {
    background: #1a1a1a;
    color: #b8b8b8;
}

html[data-sr-theme="dark"] .account-loyalty-path-node.is-reached .account-loyalty-path-card {
    border-color: #245d39;
    background: #092012;
}

html[data-sr-theme="dark"] .account-loyalty-path-node.is-reached .account-loyalty-path-dot {
    border-color: #9de0b5;
    background: #9de0b5;
}

html[data-sr-theme="dark"] .account-loyalty-path-node.is-reached .account-loyalty-status,
html[data-sr-theme="dark"] .account-loyalty-path-node.is-reached .account-loyalty-points {
    background: #0d0d0d;
    color: #9de0b5;
}

html[data-sr-theme="dark"] .account-loyalty-path-node.is-next .account-loyalty-path-card {
    border-color: #f4f4f4;
}

html[data-sr-theme="dark"] .account-table th {
    background: #151515;
    color: #cfcfcf;
}

html[data-sr-theme="dark"] .account-table td {
    border-color: #2b2b2b;
    color: #d6d6d6;
}

html[data-sr-theme="dark"] .account-table a,
html[data-sr-theme="dark"] .account-muted a,
html[data-sr-theme="dark"] .account-delivery-list a {
    color: #ffffff;
}

html[data-sr-theme="dark"] .account-badge,
html[data-sr-theme="dark"] .account-small-button {
    border: 1px solid #2b2b2b;
    background: #151515;
    color: #f4f4f4;
}

html[data-sr-theme="dark"] .account-order-product img,
html[data-sr-theme="dark"] .account-order-product-placeholder {
    background: #1a1a1a;
}

html[data-sr-theme="dark"] .account-form input:not([type="checkbox"]),
html[data-sr-theme="dark"] .account-form select,
html[data-sr-theme="dark"] .account-form textarea,
html[data-sr-theme="dark"] .account-section input,
html[data-sr-theme="dark"] .account-section select,
html[data-sr-theme="dark"] .account-section textarea,
html[data-sr-theme="dark"] .account-check {
    border-color: #3a3a3a;
    background: #050505;
    color: #f4f4f4;
}

html[data-sr-theme="dark"] .account-form input::placeholder,
html[data-sr-theme="dark"] .account-form textarea::placeholder,
html[data-sr-theme="dark"] .account-section input::placeholder,
html[data-sr-theme="dark"] .account-section textarea::placeholder {
    color: #858585;
}

html[data-sr-theme="dark"] .account-form input:focus,
html[data-sr-theme="dark"] .account-form select:focus,
html[data-sr-theme="dark"] .account-form textarea:focus,
html[data-sr-theme="dark"] .account-section input:focus,
html[data-sr-theme="dark"] .account-section select:focus,
html[data-sr-theme="dark"] .account-section textarea:focus {
    border-color: #f4f4f4;
}

html[data-sr-theme="dark"] .account-check input {
    accent-color: #f4f4f4;
}

html[data-sr-theme="dark"] .sr-password-toggle {
    border-color: #3a3a3a;
    background: #171717;
    color: #f4f4f4;
}

html[data-sr-theme="dark"] .sr-password-toggle:hover {
    border-color: #f4f4f4;
}

html[data-sr-theme="dark"] .account-timeline article::before {
    background: #777777;
}

html[data-sr-theme="dark"] .account-timeline article.is-done {
    border-color: #245d39;
    background: #092012;
    color: #9de0b5;
}

html[data-sr-theme="dark"] .account-timeline article.is-done strong,
html[data-sr-theme="dark"] .account-timeline article.is-done span {
    color: #9de0b5;
}

html[data-sr-theme="dark"] .account-timeline article.is-done::before {
    background: #62b47d;
}

html[data-sr-theme="dark"] .account-summary-list .is-total {
    background: #f4f4f4;
    color: #050505;
}

html[data-sr-theme="dark"] .account-summary-list .is-total span,
html[data-sr-theme="dark"] .account-summary-list .is-total strong {
    color: #050505;
}

html[data-sr-theme="dark"] .account-body .shop-alert {
    border-color: #2b2b2b;
    background: #0d0d0d;
    color: #f4f4f4;
}

html[data-sr-theme="dark"] .account-body .shop-alert.is-success {
    border-color: #245d39;
    background: #092012;
    color: #9de0b5;
}

html[data-sr-theme="dark"] .account-body .shop-alert.is-error {
    border-color: #6d2c1c;
    background: #240b05;
    color: #ffb39d;
}

html[data-sr-theme="dark"] .account-verification-notice {
    border-color: #4a3a1a;
    background: #171207;
}

html[data-sr-theme="dark"] .account-verification-notice strong {
    color: #ffffff;
}

html[data-sr-theme="dark"] .account-verification-notice span {
    color: #c8c8c8;
}

/* Dark mode: final storefront refinements */
html[data-sr-theme="dark"] .sr-size-options label {
    border-color: #575757;
    background: #050505;
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-size-options label:has(input:checked) {
    border-color: #f7f7f7;
    box-shadow: inset 0 0 0 1px #f7f7f7;
}

html[data-sr-theme="dark"] .sr-size-options label:not(:has(input:checked)):hover {
    border-color: #8e8e8e;
}

html[data-sr-theme="dark"] .sr-size-options small {
    color: #9d9d9d;
}

html[data-sr-theme="dark"] .sr-size-options label.is-disabled {
    border-color: #262626;
    background: #111111;
    color: #6f6f6f;
}

html[data-sr-theme="dark"] .sr-cart-page {
    background: #050505;
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-help-strip,
html[data-sr-theme="dark"] .sr-cart-item,
html[data-sr-theme="dark"] .sr-empty.is-large {
    background: #111111;
    color: #f7f7f7;
    box-shadow: none;
}

html[data-sr-theme="dark"] .sr-empty.is-large h2,
html[data-sr-theme="dark"] .sr-cart-title h1,
html[data-sr-theme="dark"] .sr-cart-title span,
html[data-sr-theme="dark"] .sr-help-strip strong,
html[data-sr-theme="dark"] .sr-help-strip span,
html[data-sr-theme="dark"] .sr-cart-item-info h2,
html[data-sr-theme="dark"] .sr-cart-item-actions strong,
html[data-sr-theme="dark"] .sr-cart-summary h2,
html[data-sr-theme="dark"] .sr-cart-summary dd {
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-empty.is-large p,
html[data-sr-theme="dark"] .sr-cart-item-info small,
html[data-sr-theme="dark"] .sr-cart-item-info p,
html[data-sr-theme="dark"] .sr-cart-summary dt,
html[data-sr-theme="dark"] .sr-cart-reassurance p {
    color: #b8b8b8;
}

html[data-sr-theme="dark"] .sr-cart-item-media,
html[data-sr-theme="dark"] .sr-cart-item-media img {
    background: #1b1b1b;
}

html[data-sr-theme="dark"] .sr-quantity-form input {
    border-color: #555555;
    background: #050505;
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-quantity-form button,
html[data-sr-theme="dark"] .sr-text-button,
html[data-sr-theme="dark"] .sr-cart-summary .sr-underlink {
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-cart-summary .is-total,
html[data-sr-theme="dark"] .sr-cart-reassurance {
    border-color: #2a2a2a;
}

html[data-sr-theme="dark"] .sr-contact-hero h1 {
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-brand.has-logo-pair .sr-brand-logo-dark {
    opacity: 0;
}

html[data-sr-theme="dark"] .sr-brand.has-logo-pair .sr-brand-logo-light {
    opacity: 1;
}

html[data-sr-theme="dark"] .sr-header.is-hero:hover .sr-brand.has-logo-pair .sr-brand-logo-dark {
    opacity: 1;
}

html[data-sr-theme="dark"] .sr-header.is-hero:hover .sr-brand.has-logo-pair .sr-brand-logo-light {
    opacity: 0;
}

/* Final refinements: account cart, checkout guidance and payment success dark mode */
@media (max-width: 620px) {
    .account-cart-line {
        grid-template-columns: 72px minmax(0, 1fr);
    }

    .account-cart-line > strong {
        grid-column: 2;
    }

    .account-cart-thumb,
    .account-cart-thumb img {
        width: 72px;
    }

    .account-cart-actions .shop-button,
    .account-cart-actions .account-small-button {
        width: 100%;
    }
}

html[data-sr-theme="dark"] .account-cart-line {
    border-color: #2b2b2b;
}

html[data-sr-theme="dark"] .account-cart-thumb,
html[data-sr-theme="dark"] .account-cart-thumb img {
    background: #1a1a1a;
}

html[data-sr-theme="dark"] .account-cart-line small,
html[data-sr-theme="dark"] .account-cart-line p,
html[data-sr-theme="dark"] .account-cart-total span {
    color: #b8b8b8;
}

html[data-sr-theme="dark"] .account-cart-line strong {
    color: #f4f4f4;
}

html[data-sr-theme="dark"] .account-cart-total div {
    background: #151515;
}

html[data-sr-theme="dark"] .account-cart-total .is-total {
    background: #f4f4f4;
}

html[data-sr-theme="dark"] .account-cart-total .is-total span,
html[data-sr-theme="dark"] .account-cart-total .is-total strong {
    color: #050505;
}

html[data-sr-theme="dark"] .sr-payment-success {
    background: #050505;
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-payment-success-card h1,
html[data-sr-theme="dark"] .sr-payment-success-steps strong,
html[data-sr-theme="dark"] .sr-payment-success-card .sr-eyebrow {
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-payment-success-card > p,
html[data-sr-theme="dark"] .sr-payment-success-steps small,
html[data-sr-theme="dark"] .sr-payment-session,
html[data-sr-theme="dark"] .sr-redirect-note {
    color: #b8b8b8 !important;
}

html[data-sr-theme="dark"] .sr-payment-success-steps article {
    border-color: #2a2a2a;
    background: #111111;
}

html[data-sr-theme="dark"] .sr-payment-success-steps article.is-done {
    border-color: #245d39;
    background: #092012;
}

html[data-sr-theme="dark"] .sr-payment-success-actions .sr-underlink {
    color: #f7f7f7;
}

/* Jeux concours */
.sr-contest-nav-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    padding: 6px 12px;
    border-radius: 999px;
    background: #e8482e;
    color: #ffffff !important;
    font-size: 12px !important;
    font-weight: 600;
    text-decoration: none;
}

.sr-menu-contest-link {
    color: #e8482e !important;
}

.sr-contest-floating-cta {
    position: fixed;
    left: 32px;
    bottom: 32px;
    z-index: 35;
    display: grid;
    gap: 5px;
    min-width: 220px;
    max-width: min(320px, calc(100vw - 64px));
    padding: 16px 18px;
    background: #e8482e;
    color: #ffffff !important;
    text-decoration: none;
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.24);
}

.sr-contest-floating-cta span {
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.sr-contest-floating-cta strong {
    font-size: 16px;
    line-height: 1.2;
}

.sr-contest-floating-cta em {
    margin-top: 5px;
    font-style: normal;
    font-weight: 900;
    text-decoration: underline;
    text-underline-offset: 4px;
}

.sr-contest-page {
    min-height: 70vh;
    padding: clamp(56px, 7vw, 92px) clamp(18px, 6vw, 96px) clamp(30px, 4vw, 58px);
    background: var(--contest-bg, var(--shop-bg, #ffffff));
    color: var(--contest-text, var(--shop-text, #171717));
    font-family: var(--contest-body-font, inherit);
}

.sr-contest-page.has-contest-background {
    padding: 15px clamp(27px, 9vw, 144px);
    background-image: linear-gradient(rgba(255, 255, 255, 0.78), rgba(255, 255, 255, 0.78)), var(--contest-page-bg-image);
    background-position: center;
    background-size: cover;
}

.sr-contest-hero,
.sr-contest-shell,
.sr-contest-thanks {
    width: min(1180px, 100%);
    margin: 0 auto;
}

.sr-contest-hero {
    display: grid;
    gap: 18px;
    margin-bottom: 44px;
}

.sr-contest-hero h1,
.sr-contest-thanks h1 {
    max-width: 900px;
    margin: 0;
    color: inherit;
    font-size: clamp(14px, 2vw, 28px);
    line-height: 1.02;
    letter-spacing: 0;
}

.sr-contest-hero p,
.sr-contest-thanks p {
    max-width: 760px;
    margin: 0;
    color: color-mix(in srgb, currentColor 72%, transparent);
    font-size: clamp(18px, 2vw, 24px);
}

.sr-contest-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 22px;
    width: min(1180px, 100%);
    margin: 0 auto;
}

.sr-contest-list-card,
.sr-contest-card,
.sr-contest-thanks {
    border: 1px solid color-mix(in srgb, currentColor 12%, transparent);
    background: color-mix(in srgb, var(--contest-bg, #ffffff) 92%, #ffffff 8%);
}

.sr-contest-list-card {
    display: grid;
    gap: 16px;
    padding: clamp(24px, 4vw, 44px);
}

.sr-contest-list-card h2,
.sr-contest-card h1,
.sr-contest-card h2 {
    margin: 0;
    color: var(--contest-title, inherit);
    font-family: var(--contest-heading-font, inherit);
    font-size: clamp(12px, 1.5vw, 19px);
    line-height: 1.06;
}

.sr-contest-list-card p,
.sr-contest-card p {
    margin: 0;
    color: color-mix(in srgb, currentColor 72%, transparent);
}

.sr-contest-form {
    display: grid;
    gap: 22px;
}

.sr-contest-progress {
    display: grid;
    gap: 10px;
    color: inherit;
    font-size: 13px;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.sr-contest-progress > div:not(.sr-contest-progress-head) {
    height: 7px;
    overflow: hidden;
    border-radius: 999px;
    background: color-mix(in srgb, currentColor 10%, transparent);
}

.sr-contest-progress-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.sr-contest-progress-nav {
    display: inline-flex;
    gap: 8px;
    margin-left: auto;
}

.sr-contest-progress-nav button {
    width: 36px;
    height: 36px;
    border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
    border-radius: 999px;
    background: transparent;
    color: inherit;
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
}

.sr-contest-progress-nav button:disabled {
    opacity: 0.35;
    cursor: default;
}

.sr-contest-progress i {
    display: block;
    width: 0;
    height: 100%;
    border-radius: inherit;
    background: var(--contest-accent, #e8482e);
    transition: width 220ms ease;
}

.sr-contest-step[hidden] {
    display: none;
}

.sr-contest-card {
    display: grid;
    align-items: center;
    gap: 20px;
    min-height: auto;
    padding: clamp(22px, 4vw, 46px);
    position: relative;
    overflow: hidden;
}

.sr-contest-card.has-step-background {
    background-image: linear-gradient(rgba(255, 255, 255, 0.72), rgba(255, 255, 255, 0.72)), var(--contest-step-bg-image);
    background-position: center;
    background-size: cover;
}

.sr-contest-card.has-step-background > * {
    position: relative;
    z-index: 1;
}

.sr-contest-copy {
    display: grid;
    gap: 18px;
    justify-items: start;
    text-align: var(--contest-text-align, left);
}

.sr-contest-page.is-design-text-small .sr-contest-card h1,
.sr-contest-page.is-design-text-small .sr-contest-card h2 {
    font-size: clamp(11px, 1.3vw, 16px);
}

.sr-contest-page.is-design-text-large .sr-contest-card h1,
.sr-contest-page.is-design-text-large .sr-contest-card h2 {
    font-size: clamp(14px, 1.8vw, 23px);
}

.sr-contest-page.is-design-text-small .sr-contest-card p {
    font-size: 0.92em;
}

.sr-contest-page.is-design-text-large .sr-contest-card p {
    font-size: 1.12em;
}

.sr-contest-card.is-media-top .sr-contest-copy,
.sr-contest-card.is-media-bottom .sr-contest-copy,
.sr-contest-card.is-image-only .sr-contest-copy {
    justify-items: center;
    text-align: center;
}

.sr-contest-card.is-media-left,
.sr-contest-card.is-media-right {
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
}

.sr-contest-card.has-block-grid-layout {
    grid-template-columns: repeat(12, minmax(0, 1fr));
    align-items: var(--block-vertical-align, center);
    gap: var(--block-column-gap, 20px);
    margin-top: var(--block-margin-top, 0);
    margin-bottom: var(--block-margin-bottom, 0);
    padding: calc(clamp(22px, 4vw, 46px) + var(--block-padding, 0px));
    justify-self: var(--block-group-align, stretch);
    max-width: var(--block-max-width, none);
    border-radius: var(--block-radius, 0);
    background-color: var(--block-background, transparent);
}

.sr-contest-card.has-block-grid-layout .sr-contest-media,
.sr-contest-card.has-block-grid-layout .sr-contest-copy {
    min-width: 0;
    overflow: hidden;
}

.sr-contest-card.has-block-grid-layout .sr-contest-media {
    grid-column: var(--block-media-column, span var(--block-media-cols, 6));
    order: var(--block-media-order, 1);
    max-height: var(--block-media-max-height, none);
}

.sr-contest-card.has-block-grid-layout .sr-contest-copy {
    grid-column: var(--block-content-column, span var(--block-content-cols, 6));
    order: var(--block-content-order, 2);
    text-align: var(--block-text-align, left);
}

.sr-contest-card.has-block-grid-layout.is-media-top .sr-contest-media,
.sr-contest-card.has-block-grid-layout.is-media-top .sr-contest-copy,
.sr-contest-card.has-block-grid-layout.is-media-bottom .sr-contest-media,
.sr-contest-card.has-block-grid-layout.is-media-bottom .sr-contest-copy {
    grid-column: 1 / -1;
}

.sr-contest-card.has-block-grid-layout.has-page-elements {
    justify-self: stretch;
    max-width: none;
}

.sr-contest-card.has-block-grid-layout.has-page-elements .sr-contest-copy {
    grid-column: 1 / -1;
    width: 100%;
    overflow: visible;
}

.sr-contest-page-elements {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: clamp(14px, 2vw, 24px);
    width: 100%;
}

.sr-contest-builder-section-slot {
    grid-column: var(--page-section-column, 2 / span 10);
    display: grid;
    width: 100%;
    min-width: 0;
}

.sr-contest-builder-section {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: var(--page-section-gap, var(--block-column-gap, clamp(14px, 2vw, 24px)));
    width: 100%;
    justify-self: stretch;
    align-items: var(--page-section-vertical-align, center);
    margin-top: var(--page-section-margin-top, 0);
    margin-right: var(--page-section-margin-right, 0);
    margin-bottom: var(--page-section-margin-bottom, 0);
    margin-left: var(--page-section-margin-left, 0);
    padding: var(--page-section-padding, 0);
    border-radius: var(--page-section-radius, 0);
    background: var(--page-section-background, transparent);
}

.sr-contest-builder-column {
    grid-column: var(--page-column-start, auto) / span var(--page-column-span, 12);
    display: grid;
    gap: clamp(10px, 1.5vw, 18px);
    min-width: 0;
    align-content: center;
}

.sr-contest-builder-element {
    max-width: min(100%, var(--page-element-max-width, 100%));
    justify-self: var(--page-element-align, stretch);
    margin: 0;
    margin-top: var(--page-element-margin-top, 0);
    margin-right: var(--page-element-margin-right, 0);
    margin-bottom: var(--page-element-margin-bottom, 0);
    margin-left: var(--page-element-margin-left, 0);
    padding: var(--page-element-padding, 0);
    border-radius: var(--page-element-radius, 0);
    background: var(--page-element-background, transparent);
    text-align: var(--page-element-text-align, inherit);
    overflow-wrap: anywhere;
}

.sr-contest-builder-element.is-title {
    color: var(--contest-title, var(--contest-text));
    font-family: var(--contest-heading-font, inherit);
    font-size: clamp(26px, 4.2vw, 58px);
    line-height: 1.02;
}

.sr-contest-builder-element.is-text {
    color: color-mix(in srgb, var(--contest-text) 76%, transparent);
    font-size: clamp(16px, 1.7vw, 22px);
    line-height: 1.42;
}

.sr-contest-builder-element.is-button {
    justify-self: start;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    max-width: 100%;
    padding: 12px 24px;
    border-radius: var(--contest-button-radius);
    background: var(--contest-accent);
    color: var(--contest-button-text, #ffffff);
    font-weight: 850;
    line-height: 1.1;
}

.sr-contest-builder-element.is-image {
    min-height: clamp(180px, 24vw, 360px);
    display: grid;
    place-items: center;
    border: 1px dashed color-mix(in srgb, var(--contest-text) 22%, transparent);
    border-radius: var(--contest-image-radius);
    background: color-mix(in srgb, var(--contest-text) 5%, transparent);
    color: color-mix(in srgb, var(--contest-text) 58%, transparent);
    font-weight: 850;
    overflow: hidden;
}

.sr-contest-builder-element.is-image img {
    width: 100%;
    height: min(100%, var(--page-element-media-height, clamp(180px, 24vw, 360px)));
    object-fit: var(--page-element-media-fit, cover);
    object-position: var(--page-element-focal-x, 50%) var(--page-element-focal-y, 50%);
    transform: scale(var(--page-element-media-zoom, 1));
    transform-origin: var(--page-element-focal-x, 50%) var(--page-element-focal-y, 50%);
    filter: brightness(var(--page-element-brightness, 1));
    display: block;
}

.sr-contest-card.is-image-only {
    grid-template-columns: minmax(0, 1fr);
}

.sr-contest-card.is-media-right .sr-contest-media {
    order: 2;
}

.sr-contest-card.is-image-only .sr-contest-media {
    order: 0;
}

.sr-contest-card.is-media-bottom .sr-contest-media {
    order: 2;
}

.sr-contest-media {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    overflow: hidden;
}

.sr-contest-logo {
    display: flex;
    width: 100%;
    grid-column: 1 / -1;
    align-self: stretch;
}

.sr-contest-logo.is-left {
    justify-content: flex-start;
    justify-self: stretch;
}

.sr-contest-logo.is-center {
    justify-content: center;
    justify-self: center;
}

.sr-contest-logo.is-right {
    justify-content: flex-end;
    justify-self: stretch;
}

.sr-contest-logo img {
    display: block;
    width: auto;
    max-width: min(280px, 70vw);
    max-height: 110px;
    object-fit: contain;
}

.sr-contest-page-image {
    display: block;
    width: 100%;
    max-height: min(360px, 46vh);
    border-radius: var(--contest-image-radius, 0);
    background: #f4f4f4;
    object-fit: var(--block-media-fit, cover);
}

.sr-contest-card.is-media-left .sr-contest-media,
.sr-contest-card.is-media-right .sr-contest-media {
    height: min(54vh, 440px);
}

.sr-contest-card.is-media-left .sr-contest-page-image,
.sr-contest-card.is-media-right .sr-contest-page-image {
    height: 100%;
    max-height: none;
    aspect-ratio: 3 / 4;
    object-fit: var(--block-media-fit, cover);
}

.sr-contest-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
    margin-top: 10px;
}

.sr-contest-card.is-button-left .sr-contest-actions,
.sr-contest-card.is-button-left .sr-contest-copy {
    justify-content: flex-start;
    justify-items: start;
    text-align: left;
}

.sr-contest-card.is-button-center .sr-contest-actions,
.sr-contest-card.is-button-center .sr-contest-copy {
    justify-content: center;
    justify-items: center;
    text-align: center;
}

.sr-contest-card.is-button-right .sr-contest-actions,
.sr-contest-card.is-button-right .sr-contest-copy {
    justify-content: flex-end;
    justify-items: end;
    text-align: right;
}

.sr-contest-actions .sr-button {
    flex: 0 0 auto;
}

.sr-contest-card .sr-button,
.sr-contest-thanks .sr-button {
    width: auto;
    max-width: 100%;
    min-height: 44px;
    padding: 12px 24px;
    border-radius: var(--contest-button-radius, 999px);
}

.sr-contest-card .sr-button.is-dark,
.sr-contest-thanks .sr-button.is-dark {
    border-color: var(--contest-accent, #e8482e);
    background: var(--contest-accent, #e8482e);
    color: var(--contest-button-text, #ffffff);
}

.sr-contest-card .sr-button.is-dark:hover,
.sr-contest-thanks .sr-button.is-dark:hover {
    background: color-mix(in srgb, var(--contest-accent, #e8482e) 88%, #000000);
}

.sr-contest-card .sr-button.is-outline,
.sr-contest-thanks .sr-button.is-outline {
    border-color: var(--contest-accent, #e8482e);
    color: var(--contest-accent, #e8482e);
}

html[data-sr-theme="dark"] .sr-contest-card .sr-button.is-dark,
html[data-sr-theme="dark"] .sr-contest-thanks .sr-button.is-dark {
    border-color: var(--contest-accent, #e8482e);
    background: var(--contest-accent, #e8482e);
    color: var(--contest-button-text, #ffffff);
}

html[data-sr-theme="dark"] .sr-contest-card .sr-button.is-dark:hover,
html[data-sr-theme="dark"] .sr-contest-thanks .sr-button.is-dark:hover {
    background: color-mix(in srgb, var(--contest-accent, #e8482e) 88%, #000000);
}

html[data-sr-theme="dark"] .sr-contest-card .sr-button.is-outline,
html[data-sr-theme="dark"] .sr-contest-thanks .sr-button.is-outline {
    border-color: var(--contest-accent, #e8482e);
    background: transparent;
    color: var(--contest-accent, #e8482e);
}

.sr-contest-copy > .sr-button {
    justify-self: center;
}

.sr-contest-card.is-button-left .sr-contest-copy > .sr-button {
    justify-self: start;
}

.sr-contest-card.is-button-center .sr-contest-copy > .sr-button {
    justify-self: center;
}

.sr-contest-card.is-button-right .sr-contest-copy > .sr-button {
    justify-self: end;
}

.sr-contest-fields {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.sr-contest-fields label {
    display: grid;
    gap: 8px;
    color: var(--contest-question, inherit);
    font-weight: 900;
    text-align: var(--contest-question-align, left);
}

.sr-contest-page.is-design-question-small .sr-contest-fields label {
    font-size: 0.9em;
}

.sr-contest-page.is-design-question-large .sr-contest-fields label {
    font-size: 1.08em;
}

.sr-contest-fields input,
.sr-contest-fields select,
.sr-contest-fields textarea {
    width: 100%;
    min-height: 56px;
    padding: 15px 18px;
    border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
    border-radius: 0;
    background: transparent;
    color: inherit;
    font: inherit;
}

.sr-contest-fields textarea {
    min-height: 132px;
    resize: vertical;
}

.sr-contest-fields .sr-contest-check {
    align-self: end;
    box-sizing: border-box;
    grid-column: 2 / -1;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 14px;
    min-height: 56px;
    padding: 0 18px;
    border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
}

.sr-contest-fields .sr-contest-check input {
    width: 22px;
    min-height: 22px;
}

.sr-contest-block-card {
    min-height: min(501.7px, calc(100vh - 220px));
}

.sr-contest-block-card .sr-contest-copy {
    width: min(760px, 100%);
    margin-inline: auto;
}

.sr-contest-block-fields {
    display: grid;
    width: min(640px, 100%);
    gap: 14px;
    margin-top: 6px;
    color: var(--contest-question, inherit);
    text-align: var(--contest-question-align, left);
}

.sr-contest-block-fields label {
    display: grid;
    gap: 8px;
    color: inherit;
    font-weight: 900;
}

.sr-contest-block-fields input {
    width: 100%;
    min-height: 56px;
    padding: 15px 18px;
    border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
    border-radius: 0;
    background: transparent;
    color: inherit;
    font: inherit;
}

.sr-contest-block-choice {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    min-height: 58px;
    padding: 0 18px;
    border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
}

.sr-contest-block-choice input {
    width: 22px;
    min-height: 22px;
    padding: 0;
    accent-color: var(--contest-accent, #e8482e);
}

.sr-contest-opinion-scale {
    grid-template-columns: repeat(10, minmax(0, 1fr));
    gap: 8px;
}

.sr-contest-scale-choice {
    position: relative;
    display: grid;
    place-items: center;
    min-height: 52px;
    padding: 0;
    border: 1px solid color-mix(in srgb, var(--contest-accent, #e8482e) 28%, transparent);
    border-radius: 999px;
    cursor: pointer;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.sr-contest-scale-choice input {
    position: absolute;
    inset: 0;
    width: 100%;
    min-height: 100%;
    padding: 0;
    opacity: 0;
    cursor: pointer;
}

.sr-contest-scale-choice span {
    position: relative;
    z-index: 1;
    color: var(--contest-accent, #e8482e);
    font-weight: 900;
}

.sr-contest-scale-choice:has(input:checked) {
    border-color: var(--contest-accent, #e8482e);
    background: var(--contest-accent, #e8482e);
}

.sr-contest-scale-choice:has(input:checked) span {
    color: var(--contest-button-text, #ffffff);
}

.sr-contest-block-contact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.sr-contest-block-note {
    width: min(640px, 100%);
    padding: 16px 18px;
    border: 1px solid color-mix(in srgb, var(--contest-accent, #e8482e) 24%, transparent);
    background: color-mix(in srgb, var(--contest-accent, #e8482e) 8%, transparent);
}

.sr-contest-error {
    color: #d96b43;
    font-size: 13px;
    font-weight: 900;
}

.sr-contest-login-note {
    display: grid;
    gap: 6px;
    padding: 16px 18px;
    border: 1px solid color-mix(in srgb, var(--contest-accent, #e8482e) 35%, transparent);
    background: color-mix(in srgb, var(--contest-accent, #e8482e) 10%, transparent);
    color: inherit;
}

.sr-contest-login-note strong {
    font-size: 15px;
}

.sr-contest-login-note span {
    color: color-mix(in srgb, currentColor 72%, transparent);
}

.sr-contest-thanks {
    display: grid;
    gap: 20px;
}

html[data-sr-theme="dark"] .sr-contest-page {
    background: var(--contest-bg, #050505);
}

html[data-sr-theme="dark"] .sr-contest-page.has-contest-background {
    background-image: linear-gradient(rgba(0, 0, 0, 0.76), rgba(0, 0, 0, 0.76)), var(--contest-page-bg-image);
}

html[data-sr-theme="dark"] .sr-contest-card,
html[data-sr-theme="dark"] .sr-contest-list-card,
html[data-sr-theme="dark"] .sr-contest-thanks {
    background: #101010;
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-contest-card.has-step-background {
    background-image: linear-gradient(rgba(0, 0, 0, 0.72), rgba(0, 0, 0, 0.72)), var(--contest-step-bg-image);
}

html[data-sr-theme="dark"] .sr-contest-fields input,
html[data-sr-theme="dark"] .sr-contest-fields select,
html[data-sr-theme="dark"] .sr-contest-fields textarea,
html[data-sr-theme="dark"] .sr-contest-block-fields input,
html[data-sr-theme="dark"] .sr-contest-block-choice {
    border-color: #444444;
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .sr-contest-fields input::placeholder,
html[data-sr-theme="dark"] .sr-contest-fields textarea::placeholder,
html[data-sr-theme="dark"] .sr-contest-block-fields input::placeholder {
    color: #777777;
}

.account-contest-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 18px;
    margin-top: 28px;
}

.account-contest-card,
.account-contest-entry {
    display: grid;
    gap: 18px;
    padding: 28px;
    border: 1px solid #e6e6e6;
    background: #ffffff;
}

.account-contest-card h3 {
    margin: 0;
}

.account-contest-card h3,
.account-contest-entry h3 {
    font-size: clamp(24px, 2.2vw, 34px);
    line-height: 1;
}

.account-contest-entry h3 {
    font-size: clamp(12px, 1.1vw, 17px);
}

.account-contest-card p,
.account-contest-entry p {
    margin: 0;
    color: #707070;
    font-size: 16px;
    line-height: 1.5;
}

.account-contest-meta {
    color: #707070;
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.account-contest-status {
    justify-self: start;
    padding: 10px 14px;
    background: #f3f3f3;
    color: #111111;
    font-size: 13px;
    font-weight: 900;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.account-contest-status.is-winner {
    background: #eaf8ef;
    color: #2f7a48;
}

.account-contest-status.is-loser {
    background: #f7eeee;
    color: #9a3f37;
}

.account-contest-status.is-pending {
    background: #f5f5f5;
    color: #707070;
}

.account-answer-preview {
    display: grid;
    gap: 10px;
    margin: 0;
}

.account-answer-preview div {
    display: grid;
    grid-template-columns: minmax(110px, 0.35fr) minmax(0, 1fr);
    gap: 16px;
    padding-top: 10px;
    border-top: 1px solid #eeeeee;
}

.account-answer-preview dt {
    color: #707070;
    font-weight: 800;
}

.account-answer-preview dd {
    margin: 0;
}

html[data-sr-theme="dark"] .account-contest-card,
html[data-sr-theme="dark"] .account-contest-entry {
    border-color: #2c2c2c;
    background: #111111;
    color: #f7f7f7;
}

html[data-sr-theme="dark"] .account-contest-card p,
html[data-sr-theme="dark"] .account-contest-entry p,
html[data-sr-theme="dark"] .account-contest-meta,
html[data-sr-theme="dark"] .account-answer-preview dt {
    color: #b8b8b8;
}

html[data-sr-theme="dark"] .account-answer-preview div {
    border-top-color: #2c2c2c;
}

html[data-sr-theme="dark"] .account-contest-status.is-pending {
    background: #222222;
    color: #d8d8d8;
}

html[data-sr-theme="dark"] .account-contest-status.is-winner {
    background: #14331f;
    color: #9fe0b2;
}

html[data-sr-theme="dark"] .account-contest-status.is-loser {
    background: #351b18;
    color: #f1aaa3;
}

@media (max-width: 900px) {
    .sr-contest-nav-cta {
        display: none;
    }

    .sr-contest-fields {
        grid-template-columns: 1fr;
    }

    .sr-contest-fields .sr-contest-check {
        grid-column: 1 / -1;
    }

    .sr-contest-block-contact {
        grid-template-columns: 1fr;
    }

    .sr-contest-opinion-scale {
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }

    .sr-contest-card.is-media-left,
    .sr-contest-card.is-media-right,
    .sr-contest-card.has-block-grid-layout.is-mobile-stacked {
        grid-template-columns: 1fr;
    }

    .sr-contest-card.has-block-grid-layout.is-mobile-stacked .sr-contest-media,
    .sr-contest-card.has-block-grid-layout.is-mobile-stacked .sr-contest-copy {
        grid-column: 1 / -1;
    }

    .sr-contest-card.has-block-grid-layout:not(.is-mobile-stacked) {
        grid-template-columns: repeat(12, minmax(0, 1fr));
    }

    .sr-contest-card.has-block-grid-layout:not(.is-mobile-stacked) .sr-contest-media {
        grid-column: var(--block-media-column, span var(--block-media-cols, 6));
    }

    .sr-contest-card.has-block-grid-layout:not(.is-mobile-stacked) .sr-contest-copy {
        grid-column: var(--block-content-column, span var(--block-content-cols, 6));
    }

    .sr-contest-builder-section-slot,
    .sr-contest-builder-section {
        grid-column: 1 / -1;
    }

    .sr-contest-builder-section {
        grid-template-columns: 1fr;
    }

    .sr-contest-builder-column {
        grid-column: 1 / -1;
    }

    .sr-contest-card.is-media-right .sr-contest-media {
        order: 0;
    }

    .sr-contest-card.has-block-grid-layout:not(.is-mobile-stacked) .sr-contest-media {
        order: var(--block-media-order, 1);
    }

    .sr-contest-card.has-block-grid-layout:not(.is-mobile-stacked) .sr-contest-copy {
        order: var(--block-content-order, 2);
    }

    .sr-contest-card.is-media-left .sr-contest-media,
    .sr-contest-card.is-media-right .sr-contest-media {
        height: auto;
    }

    .sr-contest-card.is-media-left .sr-contest-page-image,
    .sr-contest-card.is-media-right .sr-contest-page-image {
        height: auto;
        max-height: min(360px, 46vh);
        aspect-ratio: auto;
    }
}

@media (max-width: 620px) {
    .sr-contest-floating-cta {
        right: 16px;
        left: 16px;
        bottom: 18px;
        max-width: none;
    }

    .sr-contest-page {
        padding-top: 40px;
        padding-right: 18px;
        padding-left: 18px;
    }

    .sr-contest-card,
    .sr-contest-thanks {
        padding: 24px;
    }

    .sr-contest-actions {
        display: flex;
        justify-content: center;
    }

    .account-answer-preview div {
        grid-template-columns: 1fr;
        gap: 4px;
    }
}
