@font-face {
    font-family: 'GoodTimes';
    src: url('/assets/fonts/GoodTimesRg-Bold.woff2') format('woff2');
    font-display: block;
    font-style: normal;
    font-weight: 700;
}

@font-face {
    font-family: 'FuturaCustom';
    src: url('/assets/fonts/FuturaLT-Book.woff2') format('woff2');
    font-display: block;
    font-style: normal;
    font-weight: 400;
}

@font-face {
    font-family: 'FuturaCustom';
    src: url('/assets/fonts/FuturaLT.woff2') format('woff2');
    font-display: block;
    font-style: normal;
    font-weight: 500;
}

@font-face {
    font-family: 'FuturaCustom';
    src: url('/assets/fonts/FuturaLT-Bold.woff2') format('woff2');
    font-display: block;
    font-style: normal;
    font-weight: 700;
}

@font-face {
    font-family: 'FuturaCustom';
    src: url('/assets/fonts/FuturaLT-Heavy.woff2') format('woff2');
    font-display: block;
    font-style: normal;
    font-weight: 800;
}

@font-face {
    font-family: 'FuturaCustom';
    src: url('/assets/fonts/FuturaLT-BookOblique.woff2') format('woff2');
    font-display: block;
    font-style: italic;
    font-weight: 400;
}

:root {
    --heroics-ink: #111827;
    --heroics-purple: #5b21b6;
    --heroics-cyan: #06b6d4;
    --heroics-yellow: #facc15;
    --heroics-system-font: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    --heroics-body-font: 'FuturaCustom', var(--heroics-system-font);
    --heroics-title-font: 'GoodTimes', 'Arial Black', Impact, var(--heroics-system-font);
}

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

html {
    font-size-adjust: 0.5;
    overflow-x: clip;
}

body {
    background: #f8fafc;
    color: var(--heroics-ink);
    font-family: var(--heroics-body-font);
    margin: 0;
    overflow-x: clip;
}

html.cart-open {
    overflow: hidden;
}

body.cart-open {
    overflow: hidden;
    touch-action: none;
}

html:has(.checkout-page),
body:has(.checkout-page) {
    overflow-x: clip;
}

img {
    max-width: 100%;
}

h1,
h2,
h3,
.hero-title,
.section-title {
    font-family: var(--heroics-title-font);
    letter-spacing: 1px;
}

.navbar,
.navbar * {
    font-family: var(--heroics-body-font);
}

.heroics-navbar {
    background-color: #5D2AA2;
}

.heroics-header {
    background: #5D2AA2;
    z-index: 1040;
}

.heroics-header.is-scrolled {
    backdrop-filter: blur(14px);
    box-shadow: 0 12px 30px rgba(20, 5, 35, 0.16);
}

.heroics-navbar > .container-xl {
    display: flex;
    align-items: center;
}

.heroics-subbar {
    background: rgba(37, 16, 79, 0.92);
}

.offcanvas:not(.show):not(.showing):not(.hiding) {
    display: none;
}

.offcanvas.show,
.offcanvas.showing,
.offcanvas.hiding {
    display: block;
}

@media (min-width: 992px) {
    .site-header,
    .storefront-header,
    .heroics-header,
    .heroics-navbar {
        position: sticky;
        top: 0;
        z-index: 1040;
    }

    .heroics-header {
        transition: box-shadow 180ms ease, backdrop-filter 180ms ease;
    }
}

.heroics-footer {
    background: linear-gradient(180deg, #2F163D 0%, #23102f 100%);
    color: #fff;
    position: relative;
}

.heroics-footer::before {
    background: linear-gradient(90deg, #7C3AA2, #E5C142, #4865EE);
    content: "";
    height: 3px;
    inset: 0 0 auto 0;
    position: absolute;
}

.heroics-footer .row {
    align-items: flex-start;
}

.heroics-footer a {
    color: rgba(255, 255, 255, 0.68);
    display: inline-block;
    text-decoration: none;
    transition: color 0.18s ease, transform 0.18s ease;
}

.heroics-footer a:hover {
    color: #E5C142;
    transform: translateX(2px);
}

.heroics-footer-title {
    color: #fff;
    font-size: 0.9rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    margin-bottom: 1rem;
    text-transform: uppercase;
}

.heroics-footer-title::after {
    background: #E5C142;
    content: "";
    display: block;
    height: 2px;
    margin-top: 0.55rem;
    width: 28px;
}

.heroics-footer-bottom {
    background: rgba(0, 0, 0, 0.16);
    border-top: 1px solid rgba(255, 255, 255, 0.12);
    font-size: 0.9rem;
}

.heroics-footer-logo {
    max-height: 48px;
    object-fit: contain;
    width: auto;
}

.heroics-footer-brand {
    color: #fff;
    font-family: var(--heroics-title-font);
    font-size: 1.35rem;
    font-weight: 800;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.heroics-footer-brand-text {
    max-width: 360px;
}

.heroics-footer-newsletter {
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.08);
    max-width: 340px;
    padding: 1.1rem !important;
    width: 100%;
}

.heroics-footer-social {
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 8px;
    color: #fff !important;
    height: 34px;
    width: 34px;
}

.heroics-footer-social svg {
    fill: none;
    height: 17px;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2;
    width: 17px;
}

.heroics-footer-social[aria-label="Facebook"] svg,
.heroics-footer-social[aria-label="TikTok"] svg {
    fill: currentColor;
    stroke: none;
}

.heroics-footer-social:hover {
    background: #E5C142;
    color: #2F163D !important;
    transform: translateY(-2px);
}

.heroics-footer .form-control {
    border-radius: 4px;
    min-height: 46px;
}

.heroics-footer-newsletter .form-control,
.heroics-footer-newsletter .btn {
    min-height: 44px;
}

.heroics-footer-payments {
    white-space: nowrap;
}

.heroics-floating-cart {
    background: #E5C142;
    border: 0;
    border-radius: 50%;
    bottom: 24px;
    box-shadow: 0 18px 38px rgba(47, 22, 61, 0.28);
    color: #2F163D;
    height: 58px;
    right: 24px;
    transition: background 160ms ease, bottom 250ms ease, color 160ms ease, transform 160ms ease;
    width: 58px;
    z-index: 1040;
}

.heroics-floating-cart.has-sticky,
.floating-cart.has-sticky {
    bottom: var(--sticky-add-offset, 104px);
}

@keyframes heroicsCartBounce {
    0% {
        transform: scale(1);
    }

    35% {
        transform: scale(1.12) translateY(-4px);
    }

    65% {
        transform: scale(0.96);
    }

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

@keyframes heroicsCartPulse {
    0% {
        box-shadow: 0 18px 38px rgba(47, 22, 61, 0.28), 0 0 0 0 rgba(229, 193, 66, 0.45);
    }

    100% {
        box-shadow: 0 18px 38px rgba(47, 22, 61, 0.28), 0 0 0 16px rgba(229, 193, 66, 0);
    }
}

@keyframes heroicsCartCountPop {
    0% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.25);
    }

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

.heroics-floating-cart.is-bouncing {
    animation: heroicsCartBounce 0.42s ease;
}

.heroics-floating-cart.is-pulsing {
    animation: heroicsCartPulse 0.65s ease;
}

.heroics-floating-cart.is-bouncing .heroics-floating-cart-count {
    animation: heroicsCartCountPop 0.42s ease;
}

.heroics-floating-cart-icon {
    fill: none;
    height: 25px;
    filter: drop-shadow(0 1px 0 rgba(0, 0, 0, 0.2));
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2.4;
    width: 25px;
}

.heroics-floating-cart:hover {
    background: #4865EE;
    color: #fff;
}

.heroics-floating-cart-count {
    align-items: center;
    background: #7C3AA2;
    border-radius: 999px;
    color: #fff;
    display: flex;
    font-size: 0.75rem;
    font-weight: 800;
    height: 24px;
    justify-content: center;
    min-width: 24px;
    position: absolute;
    right: -6px;
    top: -6px;
}

.heroics-cart-drawer {
    display: flex;
    flex-direction: column;
    height: 100vh;
    height: 100dvh;
    max-height: 100vh;
    max-height: 100dvh;
    overflow: hidden;
    overscroll-behavior: contain;
    width: min(460px, 100vw) !important;
}

.heroics-cart-drawer.offcanvas {
    bottom: 0;
}

.heroics-cart-drawer-header {
    align-items: center;
    background: #fff;
    border-bottom: 1px solid rgba(47, 22, 61, 0.1);
    flex: 0 0 auto;
    min-height: 64px;
}

.heroics-cart-drawer-content {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    height: auto;
    min-height: 0;
    overflow: hidden;
    overscroll-behavior: contain;
}

.cart-drawer-body {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
}

.heroics-cart-drawer-items {
    flex: 1 1 auto;
    height: auto;
    min-height: 0;
    overflow-y: auto;
    overscroll-behavior: contain;
    padding: 0.875rem 1rem;
}

.heroics-cart-drawer-content > .offcanvas-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
}

.cart-items-scroll {
    scrollbar-width: thin;
    scrollbar-color: rgba(124, 58, 162, 0.35) transparent;
}

.heroics-cart-drawer-items::-webkit-scrollbar {
    width: 6px;
}

.heroics-cart-drawer-items::-webkit-scrollbar-thumb {
    background: rgba(124, 58, 162, 0.35);
    border-radius: 999px;
}

.heroics-cart-drawer-footer {
    background: #fff;
    border-bottom: 0;
    border-top: 1px solid rgba(47, 22, 61, 0.1);
    box-shadow: none;
    flex: 0 0 auto;
    padding: 1rem 1rem calc(20px + env(safe-area-inset-bottom, 0px));
    position: sticky;
    bottom: 0;
    z-index: 2;
}

.cart-drawer-checkout {
    margin-bottom: 0;
}

.cart-drawer-secondary {
    margin-top: 0.65rem;
}

.heroics-mini-cart-item {
    background: #fbfafc;
    border: 1px solid rgba(47, 22, 61, 0.08);
    padding: 0.7rem !important;
}

.cart-line {
    display: flex;
    gap: 10px;
    max-height: 220px;
    overflow: hidden;
    transition: background-color 0.18s ease, border-color 0.18s ease, transform 0.18s ease, opacity 0.18s ease, max-height 0.22s ease, margin 0.22s ease, padding 0.22s ease;
}

.cart-line-info {
    flex: 1 1 auto;
    min-width: 0;
}

.cart-line-info > strong {
    display: -webkit-box !important;
    line-clamp: 3;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    line-height: 1.22;
    overflow: hidden;
}

.cart-line-pricing {
    align-items: flex-end;
    display: flex;
    flex: 0 0 72px;
    flex-direction: column;
    justify-content: space-between;
    min-width: 72px;
    text-align: right;
}

.cart-line.is-updating {
    background: rgba(0, 0, 0, 0.025);
}

.cart-line.cart-line-updated {
    background: #f7f3fa;
    border-color: rgba(124, 58, 162, 0.2);
}

.cart-line.is-removing {
    margin-bottom: 0 !important;
    max-height: 0 !important;
    opacity: 0;
    padding-bottom: 0 !important;
    padding-top: 0 !important;
    transform: translateX(12px);
}

.cart-line-error {
    color: #8a3b2f;
    line-height: 1.35;
}

.cart-line-total,
.cart-summary-value {
    display: inline-block;
    transition: opacity 0.14s ease, transform 0.14s ease;
}

.cart-line-total {
    color: #000;
    font-size: clamp(1.1rem, 1rem + 0.35vw, 1.2rem);
    font-weight: 600;
    line-height: 1.15;
    white-space: nowrap;
}

.cart-line-unit-price {
    color: #6c757d;
    font-size: 0.9rem;
    line-height: 1.35;
}

.cart-page {
    padding-bottom: 2.5rem;
}

.cart-page-header {
    margin-bottom: 2rem;
}

.cart-page-continue {
    flex: 0 0 auto;
}

.cart-page-item {
    align-items: stretch;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.04);
    border-radius: 18px;
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.06);
    display: grid;
    gap: 24px;
    grid-template-columns: 1fr auto;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.cart-page-item:hover {
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.08);
    transform: translateY(-2px);
}

.cart-item-main {
    align-items: flex-start;
    display: flex;
    gap: 1rem;
    min-width: 0;
}

.cart-item-side {
    align-items: flex-end;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-width: 120px;
}

.cart-item-side .heroics-cart-remove {
    align-self: flex-end;
    height: 34px;
    width: 34px;
}

.cart-page-item .cart-remove {
    align-items: center;
    background: rgba(0, 0, 0, 0.04);
    border-radius: 10px;
    display: flex;
    justify-content: center;
    transition: background 0.15s ease, color 0.15s ease, transform 0.15s ease;
}

.cart-item-side .heroics-cart-remove:hover,
.cart-item-side .heroics-cart-remove:focus-visible {
    background: rgba(220, 53, 69, 0.1);
    color: #dc3545;
}

.cart-item-side .cart-line-total {
    font-size: 1.25rem;
    font-weight: 700;
    margin-top: 24px;
}

.qty-row {
    align-items: center;
    display: flex;
    gap: 12px;
}

.cart-page-item .qty-control {
    background: rgba(0, 0, 0, 0.03);
    border-radius: 10px;
    padding: 4px;
}

.cart-unit-price {
    color: #6c757d;
    font-size: 0.85rem;
}

.cart-item-thumb {
    background: #f4f1f7;
    flex: 0 0 92px;
    height: 92px;
    object-fit: cover;
    width: 92px;
}

.cart-page-summary {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    box-shadow: 0 16px 36px rgba(15, 23, 42, 0.08);
    padding: 20px 22px;
    position: sticky;
    top: 96px;
}

.cart-page-summary .btn {
    font-weight: 600;
    min-height: 48px;
}

.cart-summary-total {
    font-size: 1.35rem;
    font-weight: 700;
}

.cart-summary-coupon .form-control,
.cart-summary-coupon .btn {
    border-radius: 14px;
    min-height: 44px;
}

.cart-summary-coupon .form-control {
    flex: 1 1 auto;
    min-width: 0;
}

.cart-summary-coupon .btn {
    flex: 0 0 92px;
    padding-left: 0.75rem;
    padding-right: 0.75rem;
}

.cart-trust-line {
    line-height: 1.4;
    text-align: left;
}

.shop-page {
    background: #f4f4f5;
}

.shop-layout {
    align-items: start;
    display: grid;
    gap: 28px;
    grid-template-columns: 220px minmax(0, 1fr);
}

.shop-sidebar,
.shop-filter-drawer .offcanvas-body {
    min-width: 0;
}

.shop-filter-form {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.05);
    border-radius: 4px;
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.035);
    padding: 14px;
}

.shop-breadcrumb {
    align-items: center;
    color: #6b7280;
    display: flex;
    flex-wrap: wrap;
    font-size: 0.82rem;
    font-weight: 700;
    gap: 0.45rem;
    margin-bottom: 0.85rem;
    text-transform: uppercase;
}

.shop-breadcrumb a {
    color: #5b21b6;
    text-decoration: none;
}

.shop-breadcrumb a:hover {
    color: #2F163D;
}

.filter-group + .filter-group {
    border-top: 1px solid rgba(15, 23, 42, 0.06);
    margin-top: 0.85rem;
    padding-top: 0.85rem;
}

.filter-title {
    align-items: center;
    background: transparent;
    border: 0;
    color: #111827;
    display: flex;
    font-size: 0.84rem;
    font-weight: 800;
    justify-content: space-between;
    padding: 0;
    text-align: left;
    width: 100%;
}

.filter-title::after {
    color: #6c757d;
    content: "+";
    font-weight: 700;
}

.filter-title[aria-expanded="true"]::after {
    content: "-";
}

.filter-options {
    padding-top: 0.55rem;
}

.filter-options .form-control {
    border-radius: 4px;
    font-size: 0.85rem;
    min-height: 36px;
}

.shop-filter-active-chips {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
    margin-bottom: .85rem;
}

.filter-option {
    align-items: center;
    cursor: pointer;
    display: flex;
    font-size: 0.83rem;
    gap: 0.5rem;
    margin-bottom: 0.42rem;
}

.category-filter-item {
    align-items: center;
    border-radius: 10px;
    color: #111827;
    display: flex;
    gap: 10px;
    justify-content: space-between;
    padding: .44rem .5rem;
    text-decoration: none;
    transition: background .16s ease, color .16s ease, transform .16s ease;
    width: 100%;
}

.category-filter-item:hover,
.category-filter-item.is-active {
    background: rgba(91, 33, 182, .08);
    color: #2F163D;
}

.category-filter-item:hover {
    transform: translateX(2px);
}

.category-filter-name {
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.category-filter-meta {
    align-items: center;
    display: inline-flex;
    flex: 0 0 auto;
    gap: 8px;
}

.category-filter-check {
    color: #5b21b6;
    flex: 0 0 auto;
    font-weight: 700;
}

.category-filter-count {
    align-items: center;
    background: rgba(124, 58, 237, .12);
    border-radius: 999px;
    color: #5b21b6;
    display: inline-flex;
    flex: 0 0 22px;
    font-size: 12px;
    font-weight: 700;
    height: 22px;
    justify-content: center;
    line-height: 1;
    min-width: 0;
    padding: 0;
    width: 22px;
}

.filter-option input {
    accent-color: #5b21b6;
    flex: 0 0 auto;
}

.filter-option--color,
.filter-option--toggle,
.filter-option--image,
.filter-option--icon {
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 999px;
    padding: .45rem .65rem;
    transition: background .16s ease, border-color .16s ease, color .16s ease;
}

.filter-option--image {
    border-radius: 14px;
}

.filter-option--color.is-active,
.filter-option--toggle.is-active,
.filter-option--image.is-active,
.filter-option--icon.is-active {
    background: rgba(91, 33, 182, .08);
    border-color: rgba(91, 33, 182, .42);
    color: #2F163D;
}

.filter-option--color input,
.filter-option--toggle input,
.filter-option--image input,
.filter-option--icon input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.shop-filter-swatch,
.shop-filter-image,
.shop-filter-icon {
    align-items: center;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .12);
    display: inline-flex;
    flex: 0 0 auto;
    justify-content: center;
}

.shop-filter-swatch {
    border-radius: 999px;
    height: 22px;
    width: 22px;
}

.filter-option--color.is-active .shop-filter-swatch {
    box-shadow: 0 0 0 3px #fff, 0 0 0 5px rgba(91, 33, 182, .72);
}

.shop-filter-image {
    border-radius: 10px;
    color: #5b21b6;
    font-size: .68rem;
    font-weight: 800;
    height: 38px;
    overflow: hidden;
    width: 38px;
}

.shop-filter-image img {
    display: block;
    height: 100%;
    object-fit: contain;
    width: 100%;
}

.shop-filter-icon {
    border-radius: 999px;
    color: #5b21b6;
    height: 28px;
    width: 28px;
}

.shop-filter-toggle {
    background: #cbd5e1;
    border-radius: 999px;
    display: inline-flex;
    flex: 0 0 auto;
    height: 20px;
    position: relative;
    width: 36px;
}

.shop-filter-toggle::after {
    background: #fff;
    border-radius: 999px;
    content: "";
    height: 16px;
    left: 2px;
    position: absolute;
    top: 2px;
    transition: transform .16s ease;
    width: 16px;
}

.filter-option.is-active .shop-filter-toggle {
    background: #5b21b6;
}

.filter-option.is-active .shop-filter-toggle::after {
    transform: translateX(16px);
}

.filter-tree-children {
    border-left: 1px solid rgba(91, 33, 182, .18);
    display: grid;
    gap: .15rem;
    margin: -.1rem 0 .45rem .55rem;
    padding-left: .75rem;
}

.filter-option span:nth-child(2) {
    flex: 1 1 auto;
    min-width: 0;
}

.filter-option span.filter-option-label {
    flex: 1 1 auto;
    min-width: 0;
}

.filter-option .shop-filter-swatch,
.filter-option .shop-filter-image,
.filter-option .shop-filter-icon,
.filter-option .shop-filter-toggle {
    flex: 0 0 auto;
}

.filter-count {
    align-items: center;
    background: rgba(91, 33, 182, 0.08);
    border-radius: 999px;
    color: #5b21b6;
    display: inline-flex;
    flex: 0 0 auto;
    font-size: 0.75rem;
    font-weight: 700;
    height: 24px;
    justify-content: center;
    line-height: 1;
    min-width: 28px;
    padding: 0 0.5rem;
    text-align: center;
    width: auto;
}

.filter-count-badge,
.category-count-badge {
    flex: 0 0 auto;
    width: auto;
}

.filter-group-muted {
    color: #6c757d;
}

.shop-filter-actions {
    bottom: 0;
    display: grid;
    gap: 0.65rem;
    margin-top: 1rem;
}

.shop-filters-enhanced .shop-sidebar [data-shop-filter-submit] {
    display: none;
}

[data-shop-products] {
    transition: opacity 0.16s ease;
}

[data-shop-products].is-loading {
    opacity: 0.55;
    pointer-events: none;
}

.product-card,
.heroics-product-card {
    will-change: transform, opacity;
}

.product-grid.is-loading .product-card,
.product-grid.is-loading .heroics-product-card {
    opacity: 0.35;
}

.product-card.card-enter,
.heroics-product-card.card-enter {
    opacity: 0;
    transform: translateY(10px);
}

.product-card.card-enter-active,
.heroics-product-card.card-enter-active {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.28s ease, transform 0.28s ease;
}

@media (prefers-reduced-motion: reduce) {
    .product-card.card-enter,
    .product-card.card-enter-active,
    .heroics-product-card.card-enter,
    .heroics-product-card.card-enter-active {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }
}

.shop-toolbar {
    align-items: flex-end;
    display: flex;
    gap: 16px;
    justify-content: space-between;
    margin-bottom: 18px;
}

.shop-sort-form {
    min-width: 178px;
}

.shop-sort-form .form-select {
    border-radius: 3px;
    font-size: 0.82rem;
    min-height: 34px;
}

.shop-active-filters {
    min-height: 0;
}

.shop-filter-chip {
    align-items: center;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 999px;
    color: #111827;
    display: inline-flex;
    font-size: 0.85rem;
    font-weight: 700;
    gap: 0.35rem;
    padding: 0.45rem 0.75rem;
    text-decoration: none;
}

.shop-filter-chip:hover {
    background: rgba(91, 33, 182, 0.08);
    color: #5b21b6;
}

.shop-filter-chip-clear {
    background: #111827;
    color: #fff;
}

.product-grid {
    align-items: stretch;
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-bottom: 24px;
}

.shop-load-more {
    display: flex;
    justify-content: center;
    margin-top: 28px;
}

.shop-load-sentinel {
    height: 1px;
}

.shop-loading {
    align-items: center;
    display: flex;
    gap: 10px;
    justify-content: center;
    margin: 32px 0;
}

.shop-loading[hidden],
.shop-load-complete[hidden],
.shop-load-more-fallback[hidden] {
    display: none !important;
}

.shop-loading-spinner {
    animation: heroicsAddSpin 0.7s linear infinite;
    border: 2px solid #6f42c1;
    border-radius: 999px;
    border-right-color: transparent;
    display: inline-block;
    height: 18px;
    width: 18px;
}

.shop-load-more-fallback {
    margin: 28px auto 0;
}

.shop-end-state {
    background: rgba(15, 23, 42, 0.04);
    border-radius: 999px;
    color: rgba(15, 23, 42, 0.55);
    font-size: 0.85rem;
    font-weight: 600;
    margin: 36px auto 0;
    max-width: 100%;
    padding: 10px 18px;
    text-align: center;
    width: fit-content;
}

.shop-load-more .btn {
    border-radius: 3px;
    font-size: 0.82rem;
    font-weight: 900;
    min-width: 150px;
    padding-bottom: 0.58rem;
    padding-top: 0.58rem;
    text-transform: uppercase;
}

.shop-empty-state {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 18px;
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.06);
    padding: 3rem 1.5rem;
}

.shop-empty-icon {
    align-items: center;
    background: rgba(91, 33, 182, 0.08);
    border-radius: 50%;
    color: #5b21b6;
    display: inline-flex;
    font-size: 2rem;
    height: 64px;
    justify-content: center;
    margin-bottom: 1rem;
    width: 64px;
}

.shop-filter-drawer {
    height: 100dvh;
    max-height: 100dvh;
}

.shop-filter-drawer .offcanvas-body {
    max-height: calc(100dvh - 62px);
    overflow-y: auto;
    padding-bottom: 0;
}

.shop-filter-drawer .shop-filter-form {
    border: 0;
    border-radius: 0;
    box-shadow: none;
    display: flex;
    flex-direction: column;
    min-height: 100%;
    padding: 0;
}

.shop-filter-drawer .shop-filter-actions {
    background: #fff;
    border-top: 1px solid rgba(15, 23, 42, 0.08);
    margin-left: -1rem;
    margin-right: -1rem;
    margin-top: auto;
    padding: 1rem 1rem calc(1rem + env(safe-area-inset-bottom));
    position: sticky;
    bottom: 0;
    z-index: 2;
}

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

.cart-cross-sell .owl-stage {
    display: flex;
    gap: 16px;
}

.cart-cross-sell .owl-item {
    display: flex;
}

.cart-cross-sell .product-card,
.cart-cross-sell .heroics-product-card {
    transition: transform 0.18s ease, box-shadow 0.18s ease;
    width: 100%;
}

.cart-cross-sell .product-card:hover,
.cart-cross-sell .heroics-product-card:hover {
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.08) !important;
    transform: translateY(-4px);
}

.cart-cross-sell .heroics-latest-products-carousel {
    padding-top: 0;
}

.cart-cross-sell .carousel-wrapper {
    padding-left: 8px;
    padding-right: 8px;
}

.checkout-page {
    background: #f8fafc;
    overflow: visible;
}

.checkout-page-header h1 {
    font-family: var(--heroics-title-font);
}

.checkout-trust-row span {
    background: rgba(91, 33, 182, 0.08);
    border-radius: 999px;
    color: #4c1d95;
    font-size: 0.85rem;
    font-weight: 700;
    padding: 0.4rem 0.75rem;
}

.checkout-progress {
    background: rgba(0, 0, 0, 0.05);
    border-radius: 999px;
    height: 6px;
    max-width: 520px;
    overflow: hidden;
}

.checkout-progress-bar {
    background: #6f42c1;
    border-radius: inherit;
    height: 100%;
    transition: width 0.3s ease;
}

.checkout-layout {
    align-items: stretch;
    display: grid;
    gap: clamp(2rem, 4vw, 3rem);
    grid-template-columns: minmax(0, 1fr) 340px;
    overflow: visible;
}

.checkout-main,
.checkout-sidebar {
    min-width: 0;
    overflow: visible;
}

.checkout-main {
    align-self: start;
}

.checkout-sidebar {
    align-self: start;
    min-height: 0;
    position: sticky;
    top: 96px;
}

.checkout-step,
.checkout-summary {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 20px;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.06);
}

.checkout-step {
    margin-bottom: 24px;
    opacity: 0.6;
    padding: 32px;
    transform: translateY(4px);
    transition: opacity 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.checkout-step.is-active {
    opacity: 1;
    transform: translateY(0);
}

.checkout-step.is-complete {
    opacity: 0.9;
}

.checkout-step.is-complete .step-number {
    background: #28a745;
}

.checkout-step.has-error {
    border-color: rgba(220, 53, 69, 0.4);
    box-shadow: 0 18px 45px rgba(220, 53, 69, 0.08);
    opacity: 1;
}

.checkout-step-header {
    align-items: flex-start;
    display: flex;
    gap: 14px;
    margin-bottom: 22px;
}

.step-number {
    align-items: center;
    background: #0f172a;
    border-radius: 999px;
    color: #fff;
    display: inline-flex;
    flex: 0 0 36px;
    font-weight: 800;
    height: 36px;
    justify-content: center;
    width: 36px;
}

.step-title,
.step-subtitle {
    display: block;
}

.step-title {
    color: #0f172a;
    font-size: 1.1rem;
    font-weight: 800;
}

.step-subtitle {
    color: #6c757d;
    font-size: 0.92rem;
}

.checkout-step .form-label {
    color: #334155;
    font-size: 0.86rem;
    font-weight: 600;
}

.checkout-step .form-control,
.checkout-step .form-select,
.checkout-coupon .form-control,
.checkout-coupon .btn {
    border-radius: 14px;
    min-height: 48px;
}

.checkout-step .form-control,
.checkout-step .form-select,
.checkout-coupon .form-control {
    padding-left: 16px;
    padding-right: 16px;
    transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.checkout-step .form-control::placeholder,
.checkout-coupon .form-control::placeholder {
    color: #adb5bd;
}

.checkout-step .form-control:focus,
.checkout-step .form-select:focus,
.checkout-coupon .form-control:focus {
    border-color: #6f42c1;
    box-shadow: 0 0 0 4px rgba(111, 66, 193, 0.12);
}

.checkout-step .form-control.is-invalid,
.checkout-step .form-select.is-invalid {
    border-color: #dc3545;
    box-shadow: 0 0 0 4px rgba(220, 53, 69, 0.1);
}

.checkout-step .form-control.is-valid,
.checkout-step .form-select.is-valid {
    border-color: #28a745;
}

.checkout-step .form-control.is-filled,
.checkout-coupon .form-control.is-filled {
    background: rgba(0, 0, 0, 0.02);
}

.checkout-field {
    position: relative;
}

.checkout-field .form-label {
    transition: color 0.15s ease, transform 0.15s ease;
}

.checkout-field:focus-within .form-label,
.checkout-field:has(.form-control.is-filled) .form-label {
    color: #6f42c1;
}

.checkout-field-error {
    color: #dc3545;
    font-size: 0.8rem;
    margin-top: 0.35rem;
}

.checkout-option {
    align-items: center;
    border: 2px solid rgba(15, 23, 42, 0.08);
    border-radius: 16px;
    cursor: pointer;
    display: flex;
    gap: 14px;
    margin-bottom: 10px;
    padding: 15px;
    transition: all 0.15s ease;
}

.checkout-option:hover {
    background: rgba(111, 66, 193, 0.04);
    border-color: #6f42c1;
    transform: translateY(-1px);
}

.checkout-option:has(input:checked),
.checkout-option.is-selected {
    background: rgba(111, 66, 193, 0.06);
    border-color: #6f42c1;
    box-shadow: 0 12px 28px rgba(111, 66, 193, 0.12);
    transform: scale(1.006);
}

.checkout-option-main {
    display: grid;
    flex: 1 1 auto;
    gap: 0.2rem;
    min-width: 0;
}

.checkout-option-main small {
    color: #6c757d;
}

.checkout-option-price {
    flex: 0 0 auto;
    text-align: right;
}

.checkout-payment-option {
    align-items: center;
    min-height: 64px;
}

.checkout-payment-option__icon {
    align-items: center;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.1);
    border-radius: 12px;
    color: #2d143d;
    display: inline-flex;
    flex: 0 0 44px;
    font-size: 0.78rem;
    font-weight: 800;
    height: 44px;
    justify-content: center;
    letter-spacing: 0.02em;
    width: 44px;
}

.checkout-payment-option__icon img {
    max-height: 30px;
    max-width: 30px;
    object-fit: contain;
}

.checkout-payment-option__content strong,
.checkout-payment-option__content small {
    overflow: hidden;
    text-overflow: ellipsis;
}

.checkout-payment-option__radio {
    flex: 0 0 auto;
    margin-left: auto;
}

.checkout-summary {
    align-self: flex-start;
    box-shadow: 0 22px 55px rgba(15, 23, 42, 0.08);
    padding: 24px;
    position: sticky;
    top: 96px;
}

.checkout-summary-details > summary {
    align-items: center;
    cursor: default;
    display: none;
    font-weight: 800;
    justify-content: space-between;
    list-style: none;
}

.checkout-summary-details > summary::-webkit-details-marker {
    display: none;
}

.checkout-summary-item {
    align-items: center;
    display: grid;
    gap: 12px;
    grid-template-columns: 54px minmax(0, 1fr) auto;
    padding: 10px 0;
}

.product-line {
    align-items: center;
    display: flex;
    gap: 10px;
}

.checkout-summary-item img,
.checkout-summary-thumb {
    background: #f4f1f7;
    border-radius: 12px;
    height: 54px;
    object-fit: cover;
    width: 54px;
}

.product-line img,
.product-line .checkout-summary-thumb {
    border-radius: 8px;
    height: 40px;
    width: 40px;
}

.checkout-summary-thumb {
    align-items: center;
    color: #5b21b6;
    display: inline-flex;
    justify-content: center;
}

.checkout-summary-info {
    display: grid;
    flex: 1 1 auto;
    gap: 0.1rem;
    min-width: 0;
}

.product-line-price {
    flex: 0 0 auto;
    font-weight: 600;
}

.checkout-summary-info strong,
.checkout-summary-info small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.checkout-summary-info small {
    color: #6c757d;
}

.checkout-coupon summary {
    color: #5b21b6;
    cursor: pointer;
    font-weight: 800;
}

.checkout-summary-row,
.checkout-summary-total {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-bottom: 0.55rem;
}

.checkout-summary-total {
    border-top: 1px solid rgba(15, 23, 42, 0.08);
    font-size: 1.35rem;
    font-weight: 800;
    margin-top: 0.85rem;
    padding-top: 0.85rem;
}

.checkout-pay-button {
    border-radius: 14px;
    font-weight: 800;
    min-height: 52px;
}

.btn-checkout {
    border-radius: 14px;
    font-size: 1.05rem;
    font-weight: 800;
    letter-spacing: 0.2px;
    min-height: 56px;
    transition: transform 0.15s ease, box-shadow 0.15s ease, opacity 0.15s ease;
}

.btn-checkout:hover:not(:disabled) {
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.12);
    transform: translateY(-1px);
}

.checkout-pay-button:disabled {
    cursor: not-allowed;
    opacity: 0.6;
}

.checkout-spinner {
    animation: heroicsAddSpin 0.7s linear infinite;
    border: 2px solid currentColor;
    border-radius: 50%;
    border-right-color: transparent;
    display: inline-block;
    height: 1em;
    margin-right: 0.35rem;
    vertical-align: -0.12em;
    width: 1em;
}

.checkout-trust,
.checkout-summary-trust {
    color: #6c757d;
    font-size: 0.85rem;
    line-height: 1.55;
    margin-top: 10px;
    text-align: center;
}

.checkout-trust div {
    color: #64748b;
}

.checkout-trust div::first-letter {
    color: #28a745;
    font-weight: 800;
}

.checkout-mobile-bar {
    display: none;
}

@media (max-width: 991.98px) {
    .cart-page-summary {
        position: static;
    }

    .cart-item-thumb {
        flex-basis: 82px;
        height: 82px;
        width: 82px;
    }

    .shop-layout {
        display: block;
    }

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

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

    .checkout-layout {
        display: flex;
        flex-direction: column;
    }

    .checkout-sidebar {
        order: -1;
        position: static;
        width: 100%;
    }

    .checkout-summary {
        position: static;
        width: 100%;
    }

    .checkout-summary-details > summary {
        display: flex;
    }

    .checkout-summary-details > summary::after {
        color: #6c757d;
        content: "+";
        font-size: 1.2rem;
        margin-left: 0.75rem;
    }

    .checkout-summary-details[open] > summary::after {
        content: "-";
    }

    .checkout-summary-content {
        margin-top: 16px;
    }

    .checkout-steps {
        width: 100%;
    }
}

@media (max-width: 575.98px) {
    .cart-page-header {
        align-items: stretch !important;
        flex-direction: column;
        margin-bottom: 1.75rem;
    }

    .cart-page-continue {
        width: 100%;
    }

    .cart-page-item {
        align-items: stretch;
        gap: 0.75rem;
        grid-template-columns: 1fr auto;
        padding: 0.85rem !important;
    }

    .cart-item-main {
        gap: 0.75rem;
    }

    .cart-item-side {
        min-width: 78px;
    }

    .cart-page-item .cart-item-thumb {
        flex-basis: 72px;
        height: 72px;
        width: 72px;
    }

    .cart-page-item .cart-line-total {
        margin-top: 18px;
    }

    .cart-page-item .heroics-qty-btn,
    .cart-page-item .heroics-mini-qty-input {
        height: 38px;
        width: 38px;
    }

    .cart-page-item .cart-line-total {
        font-size: 1.1rem;
    }

    .cart-page-summary .btn {
        width: 100%;
    }

    .product-card .product-card-add {
        border-radius: 50%;
        height: 44px;
        padding-left: 0;
        padding-right: 0;
        width: 44px;
    }

    .product-card .product-card-add-text {
        clip: rect(0, 0, 0, 0);
        height: 1px;
        overflow: hidden;
        position: absolute;
        white-space: nowrap;
        width: 1px;
    }

    .shop-mobile-controls {
        flex-direction: column;
    }

    .shop-toolbar {
        margin-bottom: 18px;
    }

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

    .shop-end-state {
        font-size: 0.8rem;
        margin-top: 28px;
    }

    .checkout-page {
        padding-bottom: 6rem !important;
    }

    .checkout-step,
    .checkout-summary {
        border-radius: 16px;
        padding: 18px;
    }

    .checkout-step {
        margin-bottom: 18px;
    }

    .checkout-step-header {
        margin-bottom: 16px;
    }

    .checkout-option {
        align-items: flex-start;
        padding: 14px;
    }

    .checkout-option-price {
        margin-left: auto;
    }

    .checkout-payment-option {
        align-items: center;
        gap: 0.85rem;
    }

    .checkout-payment-option__content {
        min-width: 0;
    }

    .checkout-payment-option__content strong,
    .checkout-payment-option__content small {
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
    }

    .checkout-summary-item {
        grid-template-columns: 48px minmax(0, 1fr) auto;
    }

    .checkout-summary-item img,
    .checkout-summary-thumb {
        height: 48px;
        width: 48px;
    }

    .checkout-summary .checkout-pay-button {
        display: none;
    }

    .checkout-mobile-bar {
        align-items: center;
        background: #fff;
        border-top: 1px solid rgba(15, 23, 42, 0.08);
        bottom: 0;
        box-shadow: 0 -12px 32px rgba(15, 23, 42, 0.12);
        display: flex;
        gap: 12px;
        justify-content: space-between;
        left: 0;
        padding: 12px 16px calc(12px + env(safe-area-inset-bottom));
        position: fixed;
        right: 0;
        z-index: 1040;
    }

    .checkout-mobile-bar .btn {
        flex: 0 0 auto;
        min-height: 46px;
        min-width: 132px;
    }

    .product-detail-page {
        padding-bottom: 82px;
    }

    .product-detail-card {
        border-radius: 18px;
        padding: 18px;
    }

    .product-detail-info {
        padding-right: 0;
    }

    .product-gallery-thumbs {
        margin-left: -2px;
        padding: 0 2px 6px;
    }

    .product-meta {
        grid-template-columns: 1fr;
    }

    .product-add-row {
        grid-template-columns: 1fr;
    }

    .product-quantity {
        width: 100%;
    }

    .product-quantity input {
        flex: 1 1 auto;
    }

    .product-info-tabs {
        margin-top: 32px;
        padding: 22px;
    }

    .product-tab-list {
        overflow-x: auto;
    }

    .product-tab-list button {
        flex: 0 0 auto;
        white-space: nowrap;
    }

    .product-tab-layout {
        gap: 18px;
        grid-template-columns: 1fr;
    }

    .spec-grid {
        grid-template-columns: 1fr;
    }

    .product-trust-card {
        padding: 16px;
    }

    .product-related-section {
        margin-top: 38px;
    }

    .sticky-add {
        gap: 10px;
    }

    .sticky-add-product img {
        display: none;
    }

    .sticky-add .btn {
        min-width: 132px;
    }

}

.cart-value-updating {
    opacity: 0.55;
    transform: translateY(-1px);
}

.heroics-cart-drawer-thumb {
    background: #f4f1f7;
    border-radius: 10px;
    color: #7C3AA2;
    flex: 0 0 56px;
    height: 56px;
    max-height: 56px;
    max-width: 56px;
    object-fit: cover;
    width: 56px;
}

.heroics-cart-remove {
    align-items: center;
    background: #f4f1f7;
    border: 0;
    border-radius: 4px;
    color: #2F163D;
    display: inline-flex;
    font-size: 1rem;
    font-weight: 800;
    height: 28px;
    justify-content: center;
    line-height: 1;
    padding: 0;
    width: 28px;
}

.heroics-cart-remove:hover {
    background: #2F163D;
    color: #fff;
}

.js-cart-drawer-form.is-loading {
    opacity: 0.65;
    pointer-events: none;
}

.heroics-cart-feedback {
    margin-bottom: 0.75rem;
}

.heroics-qty-btn {
    align-items: center;
    background: transparent;
    border: 0;
    color: #2F163D;
    display: inline-flex;
    font-size: 1rem;
    font-weight: 800;
    height: 30px;
    justify-content: center;
    line-height: 1;
    padding: 0;
    width: 30px;
}

.heroics-qty-btn:hover {
    background: #7C3AA2;
    color: #fff;
}

.heroics-mini-qty {
    align-items: center;
    background: #f4f1f7;
    border-radius: 6px;
    display: inline-flex;
    overflow: hidden;
    position: relative;
    transition: background-color 0.25s ease, opacity 0.25s ease;
}

.heroics-mini-qty-value,
.heroics-qty-count,
.heroics-mini-qty-input {
    align-items: center;
    background: transparent;
    border: 0;
    color: #2F163D;
    display: inline-flex;
    font-size: 0.875rem;
    height: 30px;
    justify-content: center;
    line-height: 1;
    min-width: 32px;
    padding: 0;
    text-align: center;
    font-weight: 800;
    width: 42px;
}

.heroics-mini-qty-input:focus {
    box-shadow: inset 0 0 0 2px rgba(124, 58, 162, 0.35);
    outline: 0;
}

.heroics-mini-qty-input::-webkit-outer-spin-button,
.heroics-mini-qty-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.heroics-mini-qty-input[type="number"] {
    -moz-appearance: textfield;
}

.heroics-mini-coupon {
    background: #fbfafc;
    border: 1px dashed rgba(124, 58, 162, 0.35);
    border-radius: 10px;
    padding: 0.75rem;
}

.heroics-mini-coupon .form-control {
    border-radius: 4px;
    min-width: 0;
}

.heroics-mini-coupon .form-control,
.heroics-mini-coupon .btn {
    min-height: 42px;
}

.heroics-cart-total {
    background: rgba(124, 58, 162, 0.05);
    border-top: 1px solid rgba(47, 22, 61, 0.1);
    border-radius: 6px;
    font-size: 1rem;
    padding: 0.65rem 0.75rem;
}

.heroics-cart-summary {
    font-size: 0.9rem;
}

.heroics-cart-summary .text-muted {
    font-size: 0.8rem;
}

.heroics-cart-total strong:last-child {
    font-size: 1.15rem;
}

@media (max-height: 740px) {
    .heroics-cart-drawer-footer {
        padding-top: 0.75rem;
        padding-bottom: calc(20px + env(safe-area-inset-bottom, 0px));
    }

    .heroics-mini-coupon {
        margin-bottom: 0.65rem !important;
        padding: 0.55rem;
    }

    .heroics-mini-coupon .form-label {
        margin-bottom: 0.35rem;
    }

    .heroics-mini-coupon .form-control,
    .heroics-mini-coupon .btn {
        min-height: 38px;
    }

    .heroics-cart-summary {
        margin-top: 0.65rem !important;
    }
}

@media (max-width: 575.98px) {
    .heroics-cart-drawer {
        width: 100vw !important;
    }

    .heroics-cart-drawer-header {
        min-height: 58px;
        padding: 0.85rem 1rem;
    }

    .heroics-cart-drawer-items {
        padding: 0.75rem;
    }

    .heroics-cart-drawer-footer {
        border-bottom: 0;
        box-shadow: none;
        padding: 1rem 1rem calc(20px + env(safe-area-inset-bottom, 0px));
    }

    .heroics-mini-cart-item {
        padding: 0.65rem !important;
    }

    .heroics-mini-coupon .d-flex {
        flex-direction: column;
    }

    .heroics-mini-coupon .btn,
    .heroics-cart-drawer-footer > .btn {
        min-height: 44px;
        width: 100%;
    }

    .heroics-cart-drawer-footer .cart-drawer-checkout {
        margin-bottom: 0;
    }

    .heroics-cart-drawer-footer .cart-drawer-secondary {
        display: none;
    }
}

.heroics-estimate-shipping-link {
    color: #7C3AA2;
    font-weight: 700;
    text-decoration: none;
}

.heroics-estimate-shipping-link:hover {
    color: #2F163D;
    text-decoration: underline;
}

.heroics-navbar a:hover {
    opacity: 0.85;
}

.heroics-brand {
    font-family: var(--heroics-title-font);
    letter-spacing: 0;
    min-width: fit-content;
}

.navbar-brand,
.navbar-brand .fw-bold {
    font-family: var(--heroics-title-font);
    letter-spacing: 1px;
}

.navbar-brand small {
    font-family: var(--heroics-body-font);
    letter-spacing: 0;
}

.heroics-logo,
.heroics-navbar-logo {
    max-height: 38px;
    width: 175px;
    object-fit: contain;
}

.heroics-logo-mark {
    background: rgba(255, 255, 255, 0.16);
    border: 1px solid rgba(255, 255, 255, 0.22);
    height: 40px;
    width: 40px;
}

.heroics-search {
    max-width: 960px;
}

.heroics-search-dropdown {
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 18px 45px rgba(0, 0, 0, 0.18);
    left: 0;
    overflow: hidden;
    position: absolute;
    right: 0;
    top: calc(100% + 8px);
    z-index: 1050;
}

.heroics-search-result {
    align-items: center;
    color: #111;
    display: flex;
    gap: 0.75rem;
    min-width: 0;
    padding: 0.75rem;
    text-decoration: none;
    transition: background 0.15s ease;
}

.heroics-search-result:hover {
    background: #f6f3fb;
    color: #111;
    opacity: 1;
}

.heroics-search-thumb {
    align-items: center;
    background: #fff;
    border: 1px solid rgba(17, 24, 39, 0.08);
    border-radius: 12px;
    display: flex;
    height: 48px;
    justify-content: center;
    overflow: hidden;
    width: 48px;
    flex: 0 0 48px;
}

.heroics-search-thumb img {
    height: 100%;
    width: 100%;
}

.search-result-thumb {
    background: #fff;
    border-radius: 12px;
    height: 48px;
    object-fit: contain;
    width: 48px;
}

.heroics-search-result strong {
    font-size: 0.95rem;
}

.heroics-search-result small {
    color: #777;
    font-size: 0.75rem;
}

.heroics-search-result-content,
.search-suggestion-content {
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
}

.search-suggestion-title {
    display: block;
    line-height: 1.22;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.search-suggestion-category {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.heroics-search-meta {
    text-align: right;
}

.heroics-search-price {
    color: #000;
    display: grid;
    gap: 2px;
    font-size: 1rem;
    font-weight: 800;
}

.search-suggestion-mobile-meta {
    display: none;
}

.search-suggestion-price-row,
.search-suggestion-badge-row {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.search-suggestion-price {
    color: var(--heroics-purple);
    font-weight: 800;
}

.search-suggestion-old-price {
    color: #6b7280;
    font-weight: 700;
    opacity: .58;
    text-decoration: line-through;
}

.heroics-stock-badge {
    align-items: center;
    border-radius: 999px;
    display: inline-flex;
    font-size: 0.72rem;
    font-weight: 700;
    justify-content: center;
    line-height: 1;
    padding: 3px 9px;
    white-space: nowrap;
}

.heroics-stock-badge--in {
    background: #7C3AA2;
    color: #fff;
}

.heroics-stock-badge--low {
    background: #E5C142;
    color: #2F163D;
}

.heroics-stock-badge--out {
    background: #2F163D;
    color: #fff;
}

.heroics-stock-badge--sale {
    background: rgba(124, 58, 162, .12);
    color: #5b21b6;
}

.heroics-search-all {
    border-top: 1px solid #eee7f7;
    color: #7C3AA2;
    display: block;
    font-weight: 600;
    padding: 0.75rem;
    text-align: center;
    text-decoration: none;
}

.heroics-search-all:hover {
    background: #f6f3fb;
    color: #7C3AA2;
    opacity: 1;
}

@media (max-width: 767.98px) {
    .heroics-search-mobile .heroics-search-dropdown {
        left: 0;
        max-height: min(420px, calc(100dvh - 180px));
        max-width: 100%;
        overflow-x: hidden;
        overflow-y: auto;
        right: 0;
        width: auto;
    }

    .search-suggestions,
    .mobile-search-results {
        left: 16px;
        max-width: calc(100vw - 32px);
        overflow: hidden;
        right: 16px;
        width: auto;
    }

    .heroics-search-mobile .heroics-search-result,
    .search-suggestion-item {
        align-items: center;
        display: flex;
        gap: 10px;
        min-width: 0;
        overflow: hidden;
    }

    .heroics-search-mobile .search-suggestion-title,
    .mobile-search-results .search-suggestion-title {
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
        line-height: 1.15;
        overflow-wrap: anywhere;
        white-space: normal;
        word-break: break-word;
    }

    .heroics-search-mobile .heroics-search-thumb {
        flex: 0 0 56px;
        height: 56px;
        width: 56px;
    }

    .heroics-search-mobile .heroics-search-meta {
        display: none;
    }

    .heroics-search-mobile .search-suggestion-mobile-meta {
        display: grid;
        gap: 5px;
        margin-top: 5px;
    }

    .heroics-search-mobile .search-suggestion-price {
        font-size: .9rem;
    }

    .heroics-search-mobile .search-suggestion-old-price,
    .heroics-search-mobile .heroics-stock-badge {
        font-size: .72rem;
    }

    .heroics-search-mobile .heroics-search-all {
        text-align: center;
    }
}

.heroics-search-empty,
.heroics-search-loading {
    color: #6b7280;
    padding: 0.75rem;
}

.heroics-cart-pill {
    background: transparent;
    border: 0;
    padding: 0;
}

.heroics-cart-pill:hover {
    background: transparent;
    transform: none;
}

.heroics-cart-link {
    min-width: auto;
    opacity: 1;
    padding: 0;
}

.heroics-cart-link:hover {
    color: #fff;
    opacity: 0.85;
}

.heroics-cart-icon {
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.45);
    color: #fff;
    font-size: 0.85rem;
    height: 30px;
    width: 30px;
}

.heroics-cart-btn {
    align-items: center;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 16px;
    color: #fff;
    display: inline-flex;
    height: 44px;
    justify-content: center;
    min-width: 44px;
    padding: 0;
    text-decoration: none;
    transition: background .2s ease, border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.heroics-cart-btn:hover,
.heroics-cart-btn:focus-visible,
.heroics-cart-btn:active {
    background: rgba(255,255,255,.11);
    border-color: rgba(245,200,47,.22);
    box-shadow: 0 0 0 4px rgba(106,77,255,.14);
    color: #fff;
    transform: translateY(-1px);
}

.heroics-cart-btn__icon {
    align-items: center;
    display: inline-flex;
    justify-content: center;
}

.heroics-cart-btn__icon svg {
    fill: none;
    height: 21px;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 1.9;
    width: 21px;
}

.heroics-cart-badge {
    background: var(--heroics-yellow);
    color: #111827;
    font-size: 0.68rem;
    line-height: 1;
    min-width: 18px;
    padding: .22rem .34rem;
    position: absolute;
    right: 0;
    top: -5px;
    transform: none;
}

.heroics-btn,
.heroics-theme .btn,
body .btn {
    border-radius: 4px;
    font-weight: 800;
    letter-spacing: 0.02em;
    padding: 0.7rem 1.05rem;
}

.heroics-btn-primary {
    background: #7C3AA2;
    border: 0;
    color: #fff;
}

.heroics-btn-primary:hover {
    background: #2F163D;
    color: #fff;
}

.heroics-btn-yellow {
    background: #E5C142;
    border: 0;
    color: #2F163D;
}

.heroics-btn-yellow:hover {
    background: #2F163D;
    color: #fff;
}

.login-page {
    background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
    padding: 48px 0 64px;
}

.login-shell {
    align-items: stretch;
    display: grid;
    gap: 32px;
    grid-template-columns: minmax(0, 1fr) minmax(420px, 0.82fr);
    min-height: 680px;
}

.login-visual {
    background:
        linear-gradient(135deg, rgba(111, 66, 193, 0.9), rgba(15, 23, 42, 0.8)),
        url("https://images.unsplash.com/photo-1612036782180-6f0b6cd846fe?auto=format&fit=crop&w=1200&q=85") center / cover;
    border-radius: 24px;
    box-shadow: 0 24px 70px rgba(47, 22, 61, 0.16);
    color: #fff;
    display: flex;
    min-height: 100%;
    overflow: hidden;
    padding: 46px;
    position: relative;
}

.login-visual::after {
    backdrop-filter: blur(1px);
    background:
        linear-gradient(135deg, rgba(111, 66, 193, 0.9), rgba(15, 23, 42, 0.8)),
        radial-gradient(circle at 24% 16%, rgba(229, 193, 66, 0.2), transparent 32%);
    content: "";
    inset: 0;
    opacity: 0.92;
    pointer-events: none;
    position: absolute;
}

.login-visual-content {
    align-self: center;
    max-width: 520px;
    position: relative;
    z-index: 1;
}

.login-eyebrow {
    color: #e5c142;
    display: inline-block;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    margin-bottom: 12px;
    text-transform: uppercase;
}

.login-visual h1 {
    font-family: var(--heroics-title-font);
    font-size: clamp(3rem, 6vw, 5.5rem);
    line-height: 0.92;
    margin-bottom: 18px;
}

.login-visual p {
    color: rgba(255, 255, 255, 0.9);
    font-size: 1.08rem;
    line-height: 1.65;
    margin-bottom: 28px;
}

.login-benefits {
    display: grid;
    gap: 12px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.login-benefits li {
    align-items: center;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 14px;
    display: flex;
    font-weight: 700;
    gap: 10px;
    padding: 12px 14px;
    width: fit-content;
}

.login-benefits span {
    align-items: center;
    background: rgba(229, 193, 66, 0.22);
    border-radius: 999px;
    color: #e5c142;
    display: inline-flex;
    height: 24px;
    justify-content: center;
    width: 24px;
}

.login-card {
    animation: fadeInUp 400ms ease;
    align-self: center;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 22px;
    box-shadow: 0 30px 90px rgba(15, 23, 42, 0.14);
    padding: 34px;
    transform: translateY(0);
    transition: box-shadow 200ms ease, transform 200ms ease;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(14px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.login-card:hover {
    transform: translateY(-2px);
}

.login-card-header {
    margin-bottom: 20px;
}

.login-card-header h2 {
    color: #0f172a;
    font-size: clamp(2rem, 4vw, 2.7rem);
    font-weight: 800;
    line-height: 1;
    margin-bottom: 10px;
}

.login-card-header p {
    color: #64748b;
    line-height: 1.6;
    margin: 0;
}

.login-feedback {
    border-radius: 14px;
    font-size: 0.9rem;
    font-weight: 700;
    margin-bottom: 16px;
    padding: 11px 13px;
}

.login-feedback-info {
    background: rgba(72, 101, 238, 0.08);
    color: #3047b5;
}

.login-social {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-bottom: 18px;
}

.login-social-button,
.btn-social {
    align-items: center;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.1);
    border-radius: 12px;
    color: #0f172a;
    display: inline-flex;
    font-weight: 600;
    gap: 9px;
    height: 46px;
    justify-content: center;
    transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.login-social-button:hover,
.btn-social:hover {
    border-color: #6f42c1;
    box-shadow: 0 12px 26px rgba(15, 23, 42, 0.08);
    transform: translateY(-1px);
}

.login-social-icon {
    align-items: center;
    background: rgba(15, 23, 42, 0.05);
    border-radius: 999px;
    display: inline-flex;
    height: 24px;
    justify-content: center;
    width: 24px;
}

.login-divider {
    align-items: center;
    color: #adb5bd;
    display: flex;
    font-size: 0.75rem;
    font-weight: 700;
    gap: 12px;
    margin-bottom: 18px;
    text-transform: uppercase;
}

.login-divider::before,
.login-divider::after {
    background: rgba(15, 23, 42, 0.08);
    content: "";
    flex: 1;
    height: 1px;
}

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

.login-field {
    display: grid;
    gap: 7px;
}

.login-field .form-label,
.login-label-row .form-label {
    color: #0f172a;
    font-size: 0.9rem;
    font-weight: 800;
    margin: 0;
}

.login-label-row {
    align-items: center;
    display: flex;
    gap: 12px;
    justify-content: space-between;
}

.login-label-row a {
    color: #6f42c1;
    font-size: 0.86rem;
    font-weight: 800;
    text-decoration: none;
}

.login-card .form-control {
    border: 1px solid rgba(15, 23, 42, 0.12);
    border-radius: 14px;
    height: 48px;
    padding: 0 15px;
    transition: border-color 150ms ease, box-shadow 150ms ease, background 150ms ease;
}

.login-card .form-control::placeholder {
    color: #adb5bd;
}

.login-card .form-control:focus {
    border-color: #6f42c1;
    box-shadow: 0 0 0 4px rgba(111, 66, 193, 0.12);
}

.login-card .form-control.is-filled {
    background: rgba(0, 0, 0, 0.02);
}

.login-card .form-control.is-invalid {
    border-color: #dc3545;
}

.login-password-wrap {
    position: relative;
}

.login-password-wrap .form-control {
    padding-right: 58px;
}

.login-password-toggle {
    align-items: center;
    background: rgba(111, 66, 193, 0.08);
    border: 0;
    border-radius: 999px;
    color: #6f42c1;
    display: inline-flex;
    font-size: 1.05rem;
    font-weight: 800;
    height: 34px;
    justify-content: center;
    padding: 0;
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    transition: background 150ms ease, color 150ms ease;
    width: 34px;
}

.login-password-toggle i,
.login-password-toggle span {
    align-items: center;
    display: inline-flex;
    justify-content: center;
    line-height: 1;
}

.login-password-toggle:hover,
.login-password-toggle:focus-visible {
    background: rgba(111, 66, 193, 0.14);
}

.login-field-error {
    color: #dc3545;
    font-size: 0.82rem;
    font-weight: 700;
}

.login-submit,
.btn-login {
    border-radius: 14px;
    font-size: 1.05rem;
    font-weight: 800;
    height: 52px;
    letter-spacing: 0.3px;
    margin-top: 2px;
    transition: box-shadow 160ms ease, transform 160ms ease;
}

.login-submit:hover,
.btn-login:hover {
    box-shadow: 0 14px 28px rgba(15, 23, 42, 0.15);
    transform: translateY(-1px);
}

.login-submit:disabled {
    opacity: 0.72;
}

.login-register-button,
.btn-outline {
    border: 1px solid rgba(111, 66, 193, 0.24);
    border-radius: 14px;
    color: #4c1d95;
    font-weight: 800;
    height: 48px;
    margin-top: 12px;
    width: 100%;
    transition: background 160ms ease, border-color 160ms ease, color 160ms ease;
}

.login-register-button:hover,
.btn-outline:hover {
    background: #6f42c1;
    border-color: #6f42c1;
    color: #fff;
}

.login-guest-link {
    color: #6f42c1;
    display: block;
    font-size: 0.9rem;
    font-weight: 600;
    margin-top: 14px;
    text-align: center;
    text-decoration: none;
}

.login-guest-link:hover {
    color: #4c1d95;
    text-decoration: underline;
}

.login-trust {
    border-top: 1px solid rgba(15, 23, 42, 0.08);
    color: #64748b;
    display: grid;
    gap: 8px;
    list-style: none;
    margin: 12px 0 0;
    padding-top: 16px;
    padding-left: 0;
}

.login-trust li {
    align-items: center;
    display: flex;
    font-size: 0.86rem;
    gap: 8px;
}

.login-trust strong {
    color: #198754;
}

.register-visual {
    background:
        linear-gradient(135deg, rgba(111, 66, 193, 0.9), rgba(15, 23, 42, 0.8)),
        url("https://images.unsplash.com/photo-1608889825205-eebdb9fc5806?auto=format&fit=crop&w=1200&q=85") center / cover;
}

.login-helper {
    color: #94a3b8;
    font-size: 0.8rem;
    font-weight: 700;
}

.password-strength {
    align-items: center;
    display: grid;
    gap: 9px;
    grid-template-columns: minmax(0, 1fr) auto;
    margin-top: 2px;
}

.password-strength-bar {
    background: rgba(15, 23, 42, 0.08);
    border-radius: 999px;
    display: block;
    height: 4px;
    overflow: hidden;
}

.password-strength-bar i {
    background: #dc3545;
    border-radius: inherit;
    display: block;
    height: 100%;
    transition: background 180ms ease, width 250ms ease;
    width: 32%;
}

.password-strength strong,
.password-strength-text {
    color: #64748b;
    font-size: 0.75rem;
    font-weight: 600;
}

.password-strength[data-level="goed"] .password-strength-bar i {
    background: #e5c142;
    width: 66%;
}

.password-strength[data-level="sterk"] .password-strength-bar i {
    background: #198754;
    width: 100%;
}

@media (max-width: 991.98px) {
    .account-page {
        padding: 24px 0 48px;
    }

    .account-layout {
        display: grid;
        gap: 18px;
        grid-template-columns: 1fr;
    }

    .account-sidebar {
        display: flex;
        gap: 8px;
        overflow-x: auto;
        padding: 10px;
        position: static;
        white-space: nowrap;
    }

    .account-sidebar a {
        flex: 0 0 auto;
    }

    .account-sidebar-logout {
        border-left: 1px solid rgba(15, 23, 42, 0.08);
        border-top: 0;
        margin-left: 4px;
        margin-top: 0;
        padding-top: 12px !important;
    }

    .account-welcome-card {
        grid-template-columns: 48px minmax(0, 1fr);
    }

    .account-welcome-card .btn {
        grid-column: 1 / -1;
        width: 100%;
    }

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

    .account-dashboard-grid {
        grid-template-columns: 1fr;
    }

    .account-quick-grid {
        grid-template-columns: 1fr;
    }

    .account-order-row {
        align-items: start;
        grid-template-columns: 1fr;
    }

    .account-order-action {
        background: rgba(111, 66, 193, 0.08);
        border-radius: 12px;
        display: block;
        padding: 10px 12px;
        text-align: center;
        width: 100%;
    }

    .account-orders-header {
        align-items: stretch;
        flex-direction: column;
    }

    .account-orders-header .btn {
        width: 100%;
    }

    .address-grid {
        grid-template-columns: 1fr;
    }

    .address-card-actions .btn {
        flex: 1 1 180px;
    }

    .address-form-grid,
    .address-form-grid-address,
    .address-row {
        grid-template-columns: 1fr;
    }

    .address-form-card {
        border-radius: 18px;
        padding: 20px 20px 0;
    }

    .form-actions {
        align-items: stretch;
        flex-direction: column-reverse;
        margin: 0 -20px;
        padding: 12px 20px calc(12px + env(safe-area-inset-bottom));
    }

    .form-actions .btn {
        width: 100%;
    }

    .profile-hero,
    .profile-section,
    .profile-form-grid,
    .profile-actions-grid,
    .password-row {
        grid-template-columns: 1fr;
    }

    .profile-hero {
        justify-items: start;
    }

    .profile-hero .btn,
    .profile-form-actions .btn,
    .profile-account-actions .btn {
        width: 100%;
    }

    .profile-form-card {
        border-radius: 18px;
        padding: 20px 20px 0;
    }

    .profile-form-actions {
        align-items: stretch;
        flex-direction: column-reverse;
        margin: 0 -20px;
        padding: 12px 20px calc(12px + env(safe-area-inset-bottom));
    }

    .returns-start-card {
        align-items: stretch;
        justify-items: stretch;
        min-width: 0;
    }

    .returns-start-card small {
        max-width: none;
        text-align: left;
    }

    .order-filters {
        grid-template-columns: 1fr;
    }

    .order-top,
    .order-bottom,
    .order-body {
        align-items: stretch;
        flex-direction: column;
    }

    .return-card-top,
    .return-card-bottom {
        align-items: stretch;
        flex-direction: column;
    }

    .return-card-body,
    .return-flow-grid,
    .return-conditions-card {
        grid-template-columns: 1fr;
    }

    .return-create-header,
    .return-form-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .return-order-summary {
        min-width: 0;
        text-align: left;
    }

    .return-guidance,
    .product-return-item {
        grid-template-columns: 1fr;
    }

    .return-item-stepper {
        justify-items: stretch;
    }

    .return-item-stepper label {
        text-align: left;
    }

    .quantity-stepper {
        justify-content: space-between;
        width: 100%;
    }

    .quantity-stepper button,
    .quantity-stepper input {
        height: 44px;
    }

    .quantity-stepper button {
        width: 44px;
    }

    .return-form-actions > div {
        align-items: stretch;
        justify-items: stretch;
    }

    .return-form-actions .btn {
        width: 100%;
    }

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

    .return-card-bottom .btn,
    .empty-return-actions .btn {
        width: 100%;
    }

    .order-bottom .btn {
        width: 100%;
    }

    .order-detail-heading {
        align-items: stretch;
        flex-direction: column;
    }

    .order-detail-total {
        justify-items: start;
    }

    .order-detail-grid {
        grid-template-columns: 1fr;
    }

    .order-detail-item {
        grid-template-columns: 56px minmax(0, 1fr);
    }

    .order-detail-item > strong {
        grid-column: 1 / -1;
        justify-self: end;
    }

    .order-actions-card .btn {
        width: 100%;
    }

    .login-page {
        padding: 28px 0 44px;
    }

    .login-shell {
        display: block;
        min-height: 0;
    }

    .login-visual {
        display: none;
    }

    .login-card {
        margin: 0 auto;
        max-width: 560px;
    }
}

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

    .account-panel,
    .account-recommendations,
    .account-welcome-card {
        padding: 18px;
    }

    .login-card {
        border-radius: 18px;
        padding: 20px;
    }

    .login-page {
        padding-inline: 0;
    }

    .login-social {
        grid-template-columns: 1fr;
    }

    .login-card-header h2 {
        font-size: 2rem;
    }

    .login-submit,
    .login-register-button {
        width: 100%;
    }
}

.heroics-mobile-toggle {
    align-items: center;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 16px;
    color: #fff;
    display: inline-flex;
    height: 44px;
    justify-content: center;
    margin: 0;
    padding: 0;
    width: 44px;
    transition: background .2s ease, border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.heroics-mobile-toggle:hover,
.heroics-mobile-toggle:focus,
.heroics-mobile-toggle:focus-visible,
.heroics-mobile-toggle:active {
    background: rgba(106,77,255,.22);
    border-color: rgba(255,255,255,.18);
    box-shadow: 0 0 0 4px rgba(106,77,255,.14);
    color: #fff;
    outline: 0;
    transform: translateY(-1px);
}

.heroics-mobile-toggle .navbar-toggler-icon {
    background-image: none;
    filter: none;
    height: 18px;
    position: relative;
    width: 20px;
}

.heroics-mobile-toggle .navbar-toggler-icon::before,
.heroics-mobile-toggle .navbar-toggler-icon::after,
.heroics-mobile-toggle .navbar-toggler-icon {
    border-top: 2px solid currentColor;
}

.heroics-mobile-toggle .navbar-toggler-icon::before,
.heroics-mobile-toggle .navbar-toggler-icon::after {
    content: "";
    left: 0;
    position: absolute;
    width: 20px;
}

.heroics-mobile-toggle .navbar-toggler-icon::before {
    top: 6px;
}

.heroics-mobile-toggle .navbar-toggler-icon::after {
    top: 14px;
}

.heroics-search-mobile {
    max-width: none;
    width: 100%;
}

.heroics-search-mobile .form-control {
    border-radius: 16px;
    min-height: 46px;
}

@media (max-width: 991.98px) {
    .heroics-navbar .d-lg-flex,
    .heroics-navbar .d-none.d-lg-flex {
        display: none !important;
    }

    .heroics-navbar .d-lg-none {
        display: inline-flex !important;
    }

    .heroics-navbar {
        padding: .65rem 1rem .85rem !important;
    }

    .heroics-navbar > .container-xl {
        align-items: center;
        flex-wrap: nowrap;
        gap: .65rem;
    }

    .heroics-navbar-logo {
        max-height: 36px;
        width: min(42vw, 150px);
    }

    .heroics-search-mobile {
        display: flex !important;
        margin-top: .7rem !important;
    }
}

@media (min-width: 992px) {
    .heroics-navbar .d-lg-none {
        display: none !important;
    }

    .heroics-navbar .d-lg-flex {
        display: flex !important;
    }
}

.heroics-mobile-menu {
    bottom: 0;
    display: flex;
    flex-direction: column;
    height: 100dvh;
    max-width: 100vw;
    position: fixed;
    right: 0;
    top: 0;
    transform: translateX(100%);
    visibility: hidden;
    width: min(92vw, 430px);
    background: var(--heroics-purple, #5D2AA2) !important;
    background-color: var(--heroics-purple, #5D2AA2) !important;
    background-image: none !important;
    border-left: 1px solid rgba(255, 255, 255, .08);
    box-shadow: -24px 0 80px rgba(12, 5, 20, .32);
    color: #fff;
    backdrop-filter: none;
    overflow: hidden;
}

.heroics-mobile-menu::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: .16;
    background-image:
        linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
    background-size: 28px 28px;
    mask-image: linear-gradient(180deg, #000, transparent 84%);
    -webkit-mask-image: linear-gradient(180deg, #000, transparent 84%);
}

.heroics-mobile-menu.offcanvas {
    display: flex;
    flex-direction: column;
    height: 100dvh;
    max-height: 100dvh;
    overflow: hidden;
    opacity: 1 !important;
    transition: transform .42s cubic-bezier(.22, 1, .36, 1), visibility .42s ease;
}

.heroics-mobile-menu.show {
    display: flex;
    transform: translateX(0);
    visibility: visible;
}

.heroics-mobile-menu-backdrop {
    position: fixed;
    inset: 0;
    z-index: 1040;
    border: 0;
    background: var(--heroics-purple, #5D2AA2);
    opacity: 1;
    transition: none;
    backdrop-filter: none;
}

body.heroics-mobile-menu-active .offcanvas-backdrop,
body.heroics-mobile-menu-opening .offcanvas-backdrop,
body.heroics-mobile-menu-closing .offcanvas-backdrop {
    background: var(--heroics-purple, #5D2AA2) !important;
    opacity: 1 !important;
    transition: none !important;
    backdrop-filter: none !important;
}

.heroics-mobile-menu {
    z-index: 1045;
}

body.heroics-mobile-menu-open {
    overflow: hidden;
}

html.mobile-menu-open,
body.mobile-menu-open {
    height: 100%;
    overflow: hidden;
    overscroll-behavior: none;
    touch-action: none;
}

html.mobile-menu-open .heroics-mobile-menu,
body.mobile-menu-open .heroics-mobile-menu {
    touch-action: pan-y;
}

.heroics-mobile-menu:not(.show) {
    opacity: 1;
}

.heroics-mobile-menu__header {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    flex: 0 0 auto;
    padding: calc(1.1rem + env(safe-area-inset-top, 0px)) 1.15rem .85rem;
    border-bottom: 1px solid rgba(255,255,255,.08);
}

.heroics-mobile-menu__brand {
    min-width: 0;
    padding-top: .25rem;
}

.heroics-mobile-menu__brand h2 {
    font-family: 'GoodTimes', 'Arial Black', Impact, sans-serif;
    font-size: clamp(1.35rem, 7vw, 2rem);
    line-height: 1;
    letter-spacing: 0;
    text-transform: uppercase;
}

.heroics-mobile-menu__brand small {
    position: relative;
    display: inline-block;
    margin-top: .55rem;
    padding-top: .6rem;
    color: rgba(255,255,255,.68);
    font-size: .92rem;
}

.heroics-mobile-menu__brand small::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 56px;
    height: 3px;
    border-radius: 999px;
    background: #f5c82f;
    box-shadow: 0 0 18px rgba(245,200,47,.45);
}

.heroics-mobile-close {
    margin-left: auto;
    width: 48px;
    height: 48px;
    min-width: 44px;
    min-height: 44px;
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 18px;
    background: rgba(255,255,255,.06);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    transition: transform .22s ease, background .22s ease, border-color .22s ease, box-shadow .22s ease;
}

.heroics-mobile-close:hover,
.heroics-mobile-close:focus-visible {
    background: rgba(255,255,255,.11);
    border-color: rgba(245,200,47,.42);
    box-shadow: 0 0 0 4px rgba(245,200,47,.10), 0 12px 32px rgba(0,0,0,.24);
    transform: translateY(-1px);
}

.heroics-mobile-close svg,
.heroics-mobile-icon svg,
.heroics-mobile-trust svg {
    width: 20px;
    height: 20px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.9;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.heroics-mobile-menu__body {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: .8rem;
    flex: 1 1 auto;
    height: auto;
    max-height: 100dvh;
    padding: .9rem 1rem calc(24px + env(safe-area-inset-bottom, 0px));
    min-height: 0;
    overflow: hidden;
    overscroll-behavior: none;
}

.heroics-mobile-menu__scroll {
    display: flex;
    flex-direction: column;
    gap: .85rem;
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    overscroll-behavior: contain;
    padding: .05rem .15rem .4rem;
    scrollbar-width: thin;
    scrollbar-color: rgba(245,200,47,.38) transparent;
}

.heroics-mobile-menu__scroll::-webkit-scrollbar {
    width: 6px;
}

.heroics-mobile-menu__scroll::-webkit-scrollbar-thumb {
    background: rgba(245,200,47,.38);
    border-radius: 999px;
}

.heroics-mobile-shop-link,
.heroics-mobile-category,
.heroics-mobile-action {
    min-height: 46px;
    color: #fff;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: .85rem;
    border: 1px solid rgba(255,255,255,.06);
    background: rgba(255,255,255,.04);
    border-radius: 18px;
    transition: transform .22s ease, background .22s ease, border-color .22s ease, box-shadow .22s ease;
}

.heroics-mobile-shop-link {
    min-height: 60px;
    padding: .72rem .85rem;
    background:
        linear-gradient(135deg, rgba(106,77,255,.28), rgba(255,255,255,.045));
    border-color: rgba(245,200,47,.16);
}

.heroics-mobile-shop-link strong,
.heroics-mobile-shop-link small {
    display: block;
}

.heroics-mobile-shop-link small {
    color: rgba(255,255,255,.62);
    margin-top: .1rem;
}

.heroics-mobile-section-title {
    color: rgba(255,255,255,.58);
    font-size: .78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
    display: flex;
    align-items: center;
    gap: .55rem;
    margin: 0 0 .65rem .2rem;
}

.heroics-mobile-category-list {
    display: grid;
    gap: .48rem;
}

.heroics-mobile-category {
    position: relative;
    width: 100%;
    max-width: 100%;
    padding: .62rem .78rem;
    overflow: hidden;
    animation: heroicsMobileItemIn .42s cubic-bezier(.22, 1, .36, 1) both;
    animation-delay: calc(var(--item-index, 0) * 42ms);
}

.heroics-mobile-category::before {
    content: "";
    position: absolute;
    inset: .85rem auto .85rem 0;
    width: 3px;
    border-radius: 999px;
    background: rgba(245,200,47,.42);
}

.heroics-mobile-category.is-active {
    background: linear-gradient(135deg, rgba(106,77,255,.96), rgba(74,38,147,.88));
    border-color: rgba(245,200,47,.32);
    box-shadow: 0 18px 46px rgba(70,35,140,.38), inset 0 1px 0 rgba(255,255,255,.12);
}

.heroics-mobile-category:hover,
.heroics-mobile-category:focus-visible,
.heroics-mobile-shop-link:hover,
.heroics-mobile-shop-link:focus-visible,
.heroics-mobile-action:hover,
.heroics-mobile-action:focus-visible {
    color: #fff;
    transform: translateY(-2px);
    background: rgba(255,255,255,.075);
    border-color: rgba(245,200,47,.24);
    box-shadow: 0 16px 38px rgba(0,0,0,.22);
}

.heroics-mobile-icon {
    width: 32px;
    height: 32px;
    border-radius: 11px;
    color: #f5c82f;
    background: rgba(255,255,255,.06);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

.heroics-mobile-menu__actions {
    flex: 0 0 auto;
    display: grid;
    gap: .7rem;
    margin: 24px 0 calc(28px + env(safe-area-inset-bottom, 0px));
    padding: 14px;
    border: 1px solid rgba(255,255,255,.10);
    border-radius: 18px;
    background: rgba(30, 8, 45, 0.35);
    box-shadow: 0 -12px 30px rgba(10,4,18,.14);
}

.heroics-mobile-action-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.heroics-mobile-action {
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.14);
    color: #fff;
    height: 64px;
    min-height: 66px;
    padding: 10px 12px;
    justify-content: flex-start;
    border-radius: 18px;
    font-size: 15px;
    line-height: 1.1;
    min-width: 0;
    white-space: nowrap;
    width: 100%;
}

.heroics-mobile-action span:last-child {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
}

.heroics-mobile-action--cart {
    background: rgba(255,255,255,0.08);
    border-color: rgba(255,255,255,0.14);
    color: #fff;
    box-shadow: none;
}

.heroics-mobile-action--cart:hover,
.heroics-mobile-action--cart:focus-visible {
    color: #fff;
    background: rgba(255,255,255,0.13);
}

.heroics-mobile-action:hover,
.heroics-mobile-action:focus-visible {
    background: rgba(255,255,255,0.13);
}

.heroics-mobile-action .heroics-mobile-icon,
.heroics-mobile-action--cart .heroics-mobile-icon {
    color: #FFD230;
    background: rgba(255, 210, 48, 0.14);
    flex: 0 0 34px;
    height: 34px;
    width: 34px;
}

.heroics-mobile-cart-pill {
    align-items: center;
    background: #FFD230;
    border-radius: 999px;
    color: #2A093B;
    display: inline-flex;
    flex: 0 0 auto;
    font-size: .76rem;
    font-weight: 800;
    justify-content: center;
    line-height: 1;
    margin-left: auto;
    min-height: 26px;
    overflow: visible;
    padding: 0 .58rem;
    text-overflow: clip;
    white-space: nowrap;
}

.heroics-mobile-trust {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
    color: rgba(255,255,255,.62);
    font-size: .68rem;
    line-height: 1;
}

.heroics-mobile-trust span {
    min-height: 28px;
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .34rem .46rem;
    border-radius: 999px;
    background: rgba(255,255,255,.045);
    border: 1px solid rgba(255,255,255,.055);
}

.heroics-mobile-trust svg {
    width: 14px;
    height: 14px;
    color: #f5c82f;
}

@keyframes heroicsMobileItemIn {
    from {
        opacity: 0;
        transform: translateX(18px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@media (max-width: 380px) {
    .heroics-mobile-menu {
        width: 100vw;
    }

    .heroics-mobile-menu__header {
        padding-inline: 1rem;
    }

    .heroics-mobile-menu__body {
        padding-inline: .85rem;
    }

    .heroics-mobile-action {
        gap: .45rem;
        padding-inline: .52rem;
        font-size: .84rem;
    }
}

@media (max-width: 480px) {
    .heroics-mobile-action-grid,
    .mobile-menu-quicklinks {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .heroics-mobile-menu__actions {
        margin-bottom: calc(28px + env(safe-area-inset-bottom, 0px));
        padding: 14px;
    }

    .heroics-mobile-action {
        border-radius: 15px;
        font-size: 15px;
        height: 66px;
        min-height: 66px;
        padding: 10px 12px;
    }

    .heroics-mobile-action .heroics-mobile-icon {
        height: 34px;
        width: 34px;
    }
}

@media (max-width: 340px) {
    .heroics-mobile-action-grid,
    .mobile-menu-quicklinks {
        grid-template-columns: 1fr;
    }
}

@media (max-height: 760px) {
    .heroics-mobile-menu__brand small {
        margin-top: .4rem;
        padding-top: .45rem;
        font-size: .82rem;
    }

    .heroics-mobile-shop-link {
        min-height: 52px;
    }

    .heroics-mobile-trust {
        display: none;
    }
}

@supports not (height: 100dvh) {
    .heroics-mobile-menu {
        height: 100vh;
    }
}

.filter-bar .form-select {
    min-width: 170px;
}

.heroics-hero {
    background:
        linear-gradient(120deg, rgba(17, 24, 39, 0.96), rgba(91, 33, 182, 0.86)),
        url("https://images.unsplash.com/photo-1542751371-adc38448a05e?auto=format&fit=crop&w=1800&q=80") center/cover;
}

.heroics-console {
    background: rgba(15, 23, 42, 0.82);
    border: 1px solid rgba(255, 255, 255, 0.16);
}

.collection-hero {
    background:
        linear-gradient(120deg, rgba(17, 24, 39, 0.94), rgba(91, 33, 182, 0.76)),
        url("https://images.unsplash.com/photo-1511512578047-dfb367046420?auto=format&fit=crop&w=1800&q=80") center/cover;
}

.collection-hero-copy {
    max-width: 760px;
}

.category-intro,
.category-content-block {
    margin-bottom: 1.25rem;
}

.category-content-block {
    margin-top: clamp(28px, 4vw, 48px);
}

.category-intro-card,
.category-content-card {
    align-items: stretch;
    background: #fff;
    border: 1px solid rgba(124, 58, 237, 0.1);
    border-radius: 22px;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.07);
    display: grid;
    gap: 1.25rem;
    grid-template-columns: minmax(0, 1fr);
    overflow: hidden;
    padding: clamp(18px, 3vw, 28px);
}

.category-intro.has-image .category-intro-card,
.category-content-block.has-image .category-content-card {
    grid-template-columns: minmax(0, 1.35fr) minmax(220px, 0.65fr);
}

.category-intro-banner,
.category-content-banner {
    border-radius: 22px 22px 0 0;
    max-height: 220px;
    overflow: hidden;
}

.category-intro-banner + .category-intro-card,
.category-content-banner + .category-content-card {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
}

.category-intro-banner img,
.category-intro-media img,
.category-content-banner img,
.category-content-media img {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.category-intro-media,
.category-content-media {
    background: #f8f5ff;
    border-radius: 18px;
    min-height: 190px;
    overflow: hidden;
}

.category-intro-copy,
.category-content-copy {
    align-self: center;
    min-width: 0;
}

.category-intro-description,
.category-content-description {
    color: #4b5563;
    font-size: 1rem;
    line-height: 1.7;
    margin: 0 0 1rem;
    max-width: 72ch;
}

.category-intro-description p,
.category-intro-description ul,
.category-intro-description ol,
.category-content-description p,
.category-content-description ul,
.category-content-description ol {
    margin-bottom: 0.75rem;
}

.category-intro-description > :last-child,
.category-content-description > :last-child {
    margin-bottom: 0;
}

.category-content-kicker {
    color: var(--heroics-purple);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: uppercase;
}

@media (max-width: 991.98px) {
    .category-intro.has-image .category-intro-card,
    .category-content-block.has-image .category-content-card {
        grid-template-columns: minmax(0, 1fr);
    }

    .category-intro-media,
    .category-content-media {
        min-height: 170px;
    }
}

.heroics-home-hero {
    background: #f8fafc;
}

.heroics-hero-grid {
    align-items: stretch;
    display: grid;
    gap: 1.5rem;
    grid-template-columns: minmax(0, 1fr);
    min-height: 520px;
}

.heroics-hero-slider-col,
.heroics-hero-feature-col {
    display: flex;
    min-height: 0;
    min-width: 0;
    width: 100%;
}

.heroics-hero-slider-col > *,
.heroics-hero-feature-col > * {
    min-width: 0;
}

.heroics-promo-mask {
    isolation: isolate;
    max-width: 100%;
    overflow: hidden !important;
    position: relative;
    width: 100%;
}

.heroics-promo-mask .owl-stage-outer {
    overflow: hidden !important;
}

.heroics-promo-mask .owl-stage {
    overflow: hidden;
}

.heroics-promo-carousel {
    border-radius: 24px;
    contain: layout paint;
    height: 100%;
    max-width: 100%;
    overflow: hidden !important;
    position: relative;
    width: 100% !important;
}

.heroics-promo-carousel .owl-stage-outer {
    border-radius: 24px;
    clip-path: inset(0 4px 0 0 round 24px);
    overflow: hidden !important;
    width: 100%;
}

.heroics-promo-carousel .owl-stage {
    display: flex;
}

.heroics-promo-carousel .owl-item {
    display: flex;
    min-height: 520px;
    overflow: hidden;
}

.heroics-promo-carousel .heroics-promo-slide {
    display: flex;
    width: 100%;
}

.heroics-promo-slide {
    background: linear-gradient(135deg, #7C3AA2 0%, #5D2AA2 55%, #2F163D 100%);
    border-radius: 24px;
    min-height: 520px;
    min-width: 100%;
    overflow: hidden;
    padding: clamp(2rem, 4vw, 4rem) !important;
    position: relative;
    width: 100%;
}

.heroics-feature-card {
    background: #fff;
    border: 1px solid rgba(47, 22, 61, 0.08) !important;
    box-shadow: 0 18px 42px rgba(47, 22, 61, 0.08);
    display: flex;
    flex-direction: column;
    height: 100%;
    max-height: 520px;
    min-height: 520px;
    overflow: visible;
    position: relative;
    transition: box-shadow 180ms ease, transform 180ms ease;
}

.heroics-feature-card:hover {
    box-shadow: 0 24px 54px rgba(47, 22, 61, 0.12);
    transform: translateY(-2px);
}

.hero-featured-product-panel {
    height: 100%;
    min-height: 0;
    overflow: visible;
    position: relative;
}

.hero-featured-product-panel .heroics-hero-feature-carousel {
    overflow: visible !important;
}

.hero-featured-product-panel .heroics-hero-feature-carousel .owl-stage-outer {
    border-radius: 14px;
    overflow: hidden !important;
    width: calc(100% - 4px);
}

.hero-featured-product-panel .heroics-product-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    max-height: 100%;
    min-height: 520px;
}

.hero-featured-product-panel .heroics-hero-feature-carousel,
.hero-featured-product-panel .heroics-hero-feature-carousel .owl-stage-outer,
.hero-featured-product-panel .heroics-hero-feature-carousel .owl-stage,
.hero-featured-product-panel .heroics-hero-feature-carousel .owl-item,
.hero-featured-product-panel .heroics-hero-feature-slide {
    height: 100%;
}

.hero-featured-product-panel .heroics-hero-feature-carousel .owl-stage {
    display: flex;
}

.hero-featured-product-panel .heroics-hero-feature-carousel .owl-item {
    display: flex;
}

.hero-featured-product-panel .heroics-hero-feature-slide {
    display: flex;
    width: 100%;
}

.hero-featured-product-panel .heroics-hero-feature-carousel .owl-nav {
    display: inline-flex;
    gap: 6px;
    justify-content: space-between;
    left: -22px;
    pointer-events: none;
    position: absolute;
    right: -22px;
    top: min(42%, 210px);
    transform: translateY(-50%);
    z-index: 4;
}

.hero-featured-product-panel .heroics-hero-feature-carousel .owl-nav button {
    align-items: center;
    background: transparent !important;
    border: 0 !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    height: 44px;
    justify-content: center;
    margin: 0 !important;
    padding: 0 !important;
    pointer-events: auto;
    transition: transform .18s ease, opacity .18s ease;
    width: 44px;
}

.hero-featured-product-panel .heroics-hero-feature-carousel .owl-nav button.owl-prev {
    margin-left: 0 !important;
}

.hero-featured-product-panel .heroics-hero-feature-carousel .owl-nav button.owl-next {
    margin-right: 0 !important;
}

.hero-featured-product-panel .heroics-hero-feature-carousel .owl-nav button:hover,
.hero-featured-product-panel .heroics-hero-feature-carousel .owl-nav button:focus-visible {
    opacity: .92;
    transform: translateY(-1px);
}

.hero-featured-product-panel .heroics-hero-feature-carousel .owl-nav button.disabled {
    opacity: .35;
    pointer-events: none;
}

.hero-featured-product-panel .heroics-hero-feature-carousel .owl-nav .heroics-carousel-arrow-img {
    filter: drop-shadow(0 10px 18px rgba(72, 101, 238, .24));
    height: 44px;
    width: 44px;
}

.hero-featured-product-panel .heroics-hero-feature-carousel .owl-dots {
    display: none !important;
}

@media (max-width: 767.98px) {
    .hero-featured-product-panel .heroics-hero-feature-carousel .owl-nav {
        left: -18px;
        right: -18px;
        top: min(42%, 190px);
    }

    .hero-featured-product-panel .heroics-hero-feature-carousel .owl-nav button {
        min-height: 44px;
        min-width: 44px;
    }
}

.hero-featured-product-panel .heroics-product-image {
    aspect-ratio: 1 / 1;
    align-self: center;
    flex: 0 0 auto;
    height: auto;
    max-height: none;
    min-height: 0;
    width: min(100%, 300px);
}

.hero-featured-product-panel .heroics-product-image img {
    object-fit: contain;
}

.hero-featured-product-panel .product-badge:not(.product-badge-sale) {
    left: auto;
    right: 12px;
    top: 12px;
    z-index: 5;
}

.hero-featured-product-panel .product-badge-sale {
    right: 12px;
    top: 42px;
    z-index: 5;
}

.hero-featured-product-panel .heroics-product-body,
.hero-featured-product-panel .heroics-product-card:not(.is-sold-out) .heroics-product-body,
.hero-featured-product-panel .heroics-product-card:hover .heroics-product-body {
    flex: 1 1 auto;
    justify-content: space-between;
    margin-bottom: 0;
    min-height: 0;
    overflow: hidden;
    padding: 14px;
    transform: none;
}

.hero-featured-product-panel .heroics-product-title {
    -webkit-line-clamp: 2;
    margin-bottom: 0.5rem !important;
}

.hero-featured-product-panel .heroics-product-price {
    margin-bottom: 0.65rem;
}

.hero-featured-product-panel .product-card-actions,
.hero-featured-product-panel .heroics-product-cta.product-card-actions {
    opacity: 1;
    pointer-events: auto;
    transform: none;
    visibility: visible;
}

.hero-featured-product-panel .heroics-product-actions {
    margin-top: auto !important;
}

.hero-featured-product-panel .product-card-actions,
.hero-featured-product-panel .heroics-product-cta.product-card-actions {
    margin-top: auto !important;
}

.hero-featured-product-label {
    background: linear-gradient(135deg, #7C3AA2 0%, #5D2AA2 100%);
    border-radius: 0 0 12px 0;
    box-shadow: 0 12px 26px rgba(47, 22, 61, 0.22);
    color: #fff;
    left: 0;
    min-width: 150px;
    padding: 0.5rem 0.75rem;
    position: absolute;
    top: 0;
    z-index: 4;
}

.hero-featured-product-label span,
.hero-featured-product-label strong {
    display: block;
    line-height: 1;
    text-transform: uppercase;
}

.hero-featured-product-label span {
    font-size: 0.58rem;
    font-weight: 700;
    opacity: 0.68;
}

.hero-featured-product-label strong {
    font-size: 0.88rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    margin-top: 0.2rem;
}

.heroics-feature-carousel,
.heroics-feature-carousel .owl-stage-outer,
.heroics-feature-carousel .owl-stage,
.heroics-feature-carousel .owl-item {
    height: 100%;
    max-height: 520px;
    min-height: 520px;
}

.heroics-feature-carousel {
    border-radius: 24px;
    contain: layout paint;
    max-width: 100%;
    overflow: hidden !important;
    width: 100% !important;
}

.heroics-feature-carousel .owl-stage-outer {
    border-radius: 24px;
    clip-path: inset(0 4px 0 0 round 24px);
    overflow: hidden !important;
    width: 100%;
}

.heroics-feature-carousel .owl-stage {
    display: flex;
    overflow: hidden;
}

.heroics-feature-carousel .owl-item {
    display: flex;
    overflow: hidden;
}

.heroics-feature-carousel .owl-item > .heroics-feature-card {
    min-width: 100%;
    width: 100%;
}

.heroics-feature-image {
    align-items: center;
    aspect-ratio: 1 / 1;
    background: #fbfafc;
    display: flex;
    flex: 0 0 auto;
    justify-content: center;
    max-height: 300px;
    padding: 1rem;
    min-height: 0;
    overflow: hidden;
    position: relative;
}

.heroics-feature-image img {
    height: 100%;
    object-fit: contain;
    transition: opacity 180ms ease, transform 220ms ease;
    width: 100%;
}

.heroics-feature-card:hover .heroics-feature-image img {
    transform: scale(1.015);
}

.heroics-feature-body {
    flex: 1;
    min-height: 0;
    overflow: hidden;
    padding: 1rem 1.15rem 1.15rem;
}

.heroics-feature-ribbon {
    background: linear-gradient(135deg, #7C3AA2 0%, #5D2AA2 100%);
    border-radius: 0 0 12px 0;
    box-shadow: 0 12px 26px rgba(47, 22, 61, 0.22);
    min-width: 150px;
    padding: 0.5rem 0.75rem;
    z-index: 3;
}

.heroics-feature-ribbon strong {
    font-size: 0.88rem;
    letter-spacing: 0.04em;
    line-height: 1;
}

.heroics-feature-ribbon .small {
    font-size: 0.58rem;
    line-height: 1;
}

.heroics-feature-body .small.text-muted {
    font-size: 0.85rem;
    margin-bottom: 0.5rem !important;
    opacity: 0.7;
}

.heroics-feature-title {
    display: -webkit-box;
    font-size: 1.1rem;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-height: 1.3;
    margin-bottom: 0.65rem;
    max-width: 18ch;
    overflow: hidden;
}

.heroics-feature-price {
    font-size: 1.2rem;
    font-weight: 800;
}

.heroics-feature-body .heroics-btn {
    min-height: 48px;
    padding-bottom: 0.58rem;
    padding-top: 0.58rem;
}

.heroics-feature-body .heroics-btn-primary:disabled {
    background: #7C3AA2;
    color: #fff;
    opacity: 0.55;
}

@media (min-width: 992px) {
    .heroics-home-hero .row.align-items-stretch > .heroics-hero-feature-col {
        align-items: stretch;
    }

    .heroics-feature-carousel,
    .heroics-feature-carousel .owl-stage-outer,
    .heroics-feature-carousel .owl-stage,
    .heroics-feature-carousel .owl-item,
    .heroics-feature-card {
        height: 100%;
        max-height: 520px;
        min-height: 520px;
    }

    .heroics-feature-image {
        flex: 0 0 auto;
    }
}

@media (min-width: 768px) and (max-width: 1199.98px) {
    .heroics-hero-grid {
        gap: 20px;
        min-height: 0;
    }

    .heroics-hero-feature-col {
        margin-bottom: 32px;
    }

    .heroics-promo-slide,
    .heroics-promo-carousel .owl-item {
        min-height: 420px;
    }

    .hero-featured-product-panel,
    .hero-featured-product-panel .heroics-hero-feature-carousel,
    .hero-featured-product-panel .heroics-hero-feature-carousel .owl-stage-outer,
    .hero-featured-product-panel .heroics-hero-feature-carousel .owl-stage,
    .hero-featured-product-panel .heroics-hero-feature-carousel .owl-item,
    .hero-featured-product-panel .heroics-hero-feature-slide {
        height: auto;
        max-height: none;
        min-height: 0;
    }

    .hero-featured-product-panel .heroics-hero-feature-slide,
    .hero-featured-product-panel .heroics-hero-feature-carousel .owl-item {
        align-items: stretch;
    }

    .hero-featured-product-panel .heroics-product-card {
        align-items: stretch;
        border-radius: 18px;
        display: flex;
        flex-direction: row;
        gap: 0;
        height: auto;
        max-height: none;
        min-height: 220px;
        overflow: hidden !important;
        width: 100%;
    }

    .hero-featured-product-panel .heroics-product-image {
        align-self: stretch;
        aspect-ratio: auto;
        background: #fbfafc;
        display: flex;
        flex: 0 0 38%;
        height: auto;
        max-height: none;
        max-width: none;
        min-height: 220px;
        width: 38%;
    }

    .hero-featured-product-panel .heroics-product-image-link {
        align-items: center;
        display: flex !important;
        height: 100%;
        justify-content: center;
        padding: 14px;
        width: 100%;
    }

    .hero-featured-product-panel .heroics-product-image img {
        max-height: 210px;
        object-fit: contain;
        width: 100%;
    }

    .hero-featured-product-panel .heroics-product-body,
    .hero-featured-product-panel .heroics-product-card:not(.is-sold-out) .heroics-product-body,
    .hero-featured-product-panel .heroics-product-card:hover .heroics-product-body {
        flex: 1 1 auto;
        justify-content: center;
        padding: 18px 20px;
    }

    .hero-featured-product-panel .heroics-product-actions {
        margin-top: 16px !important;
    }

    .hero-featured-product-panel .product-card-actions,
    .hero-featured-product-panel .heroics-product-cta.product-card-actions {
        max-width: 260px;
        width: 100%;
    }

    .hero-featured-product-panel .product-card-add {
        min-height: 44px;
    }

    .hero-featured-product-label {
        border-radius: 0 0 10px 0;
        min-width: 118px;
        padding: 0.42rem 0.62rem;
    }

    .hero-featured-product-label span {
        font-size: 0.52rem;
    }

    .hero-featured-product-label strong {
        font-size: 0.74rem;
    }
}

@media (min-width: 1200px) {
    .heroics-hero-grid {
        grid-template-columns: minmax(0, 2fr) minmax(300px, 1fr);
        min-height: 520px;
    }

    .heroics-promo-mask,
    .heroics-promo-carousel,
    .heroics-promo-carousel .owl-stage-outer,
    .heroics-promo-carousel .owl-stage,
    .heroics-promo-carousel .owl-item,
    .heroics-promo-carousel .heroics-promo-slide,
    .heroics-promo-slide,
    .heroics-feature-carousel,
    .heroics-feature-carousel .owl-stage-outer,
    .heroics-feature-carousel .owl-stage,
    .heroics-feature-carousel .owl-item,
    .heroics-feature-card {
        height: 520px;
        max-height: 520px;
        min-height: 520px;
    }
}

.heroics-promo-carousel .owl-dots {
    bottom: 24px;
    display: flex;
    gap: 0.5rem;
    margin: 0 !important;
    position: absolute;
    right: 17%;
    z-index: 10;
}

.heroics-promo-carousel .owl-dot span {
    background: rgba(255, 255, 255, 0.25) !important;
    border-radius: 999px;
    color: #fff;
    display: inline-flex !important;
    font-size: 0.7rem;
    font-weight: 700;
    height: auto !important;
    line-height: 1;
    margin: 0 !important;
    padding: 4px 9px;
    width: auto !important;
}

.heroics-promo-carousel .owl-dot:nth-child(1) span::before {
    content: "01";
}

.heroics-promo-carousel .owl-dot:nth-child(2) span::before {
    content: "02";
}

.heroics-promo-carousel .owl-dot:nth-child(3) span::before {
    content: "03";
}

.heroics-promo-carousel .owl-dot.active span {
    background: #E5C142 !important;
    color: #2F163D;
}

:root {
    --homepage-section-spacing: clamp(24px, 3.2vw, 44px);
}

.homepage-block {
    padding-block: var(--homepage-section-spacing);
}

.homepage-block-featured_products {
    padding-top: clamp(8px, 1.2vw, 18px);
}

.homepage-block-newest_products {
    padding-bottom: clamp(8px, 1.2vw, 16px);
}

.homepage-block-newest_products + .homepage-block-featured_products {
    padding-top: 0;
}

.homepage-hero-block {
    padding-block: clamp(24px, 4vw, 48px) calc(var(--homepage-section-spacing) * .7);
}

.heroics-promo-title {
    font-size: clamp(1.9rem, 3vw, 2.85rem);
    font-family: var(--heroics-title-font, inherit);
    line-height: 1.12;
    max-width: 520px;
}

.heroics-promo-content {
    justify-content: center !important;
    max-width: 48%;
    padding-top: 0;
    position: relative;
    z-index: 2;
}

.heroics-promo-bg {
    background-image: linear-gradient(rgba(47, 22, 61, .05), rgba(47, 22, 61, .05)), var(--heroics-slide-desktop);
    background-position: center;
    background-size: cover;
    clip-path: polygon(0 0, 100% 0, 100% 100%, 55% 100%);
    height: 100%;
    inset: 0 0 0 auto;
    max-width: 100%;
    overflow: hidden;
    position: absolute;
    right: 0;
    top: 0;
    width: 62%;
    z-index: 1;
}

.heroics-promo-bg::after {
    background: rgba(47, 22, 61, 0.15);
    content: "";
    inset: 0;
    position: absolute;
}

.heroics-home-products {
    background: #f8fafc;
    overflow-x: visible;
    overflow-y: visible;
}

.heroics-home-products > .container-xl > .d-flex.mb-4,
.heroics-home-categories > .container-xl > .d-flex.mb-4 {
    margin-bottom: clamp(1rem, 2vw, 1.25rem) !important;
}

.heroics-fandoms {
    background: #fff;
}

.heroics-fandom-card {
    align-items: center;
    background: #fff;
    border: 1px solid rgba(47, 22, 61, 0.08);
    border-radius: 12px;
    box-shadow: 0 10px 24px rgba(47, 22, 61, 0.08);
    display: flex;
    justify-content: center;
    min-height: 120px;
    padding: 1.25rem;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.heroics-fandom-card:hover {
    box-shadow: 0 18px 38px rgba(47, 22, 61, 0.14);
    transform: translateY(-4px);
}

.heroics-fandom-card img {
    max-height: 58px;
    max-width: 140px;
    object-fit: contain;
}

.heroics-fandom-card img + span {
    display: none;
}

.heroics-fandom-carousel .owl-stage {
    display: flex;
}

.heroics-fandom-carousel .owl-item {
    display: flex;
}

.heroics-fandom-carousel .owl-item > * {
    width: 100%;
}

.heroics-section-title {
    font-family: var(--heroics-title-font);
    letter-spacing: 1px;
}

.heroics-section-intro {
    max-width: 720px;
}

.heroics-latest-products-carousel .owl-stage {
    display: flex;
}

.heroics-latest-products-carousel {
    overflow: visible !important;
    padding-bottom: 0.75rem;
}

.heroics-latest-products-carousel .owl-nav {
    inset: 50% -18px auto -18px;
    pointer-events: none;
    position: absolute;
    z-index: 5;
}

.heroics-latest-products-carousel .owl-nav button.owl-prev,
.heroics-latest-products-carousel .owl-nav button.owl-next {
    align-items: center;
    background: transparent !important;
    border: 0 !important;
    display: inline-flex;
    height: 44px;
    justify-content: center;
    margin: 0 !important;
    padding: 0 !important;
    pointer-events: auto;
    position: absolute;
    transform: translateY(-50%);
    width: 36px;
}

.heroics-latest-products-carousel .owl-nav button.owl-prev {
    left: 0;
}

.heroics-latest-products-carousel .owl-nav button.owl-next {
    right: 0;
}

.heroics-carousel-arrow-img {
    display: block;
    height: 42px;
    object-fit: contain;
    transition: opacity 0.18s ease, transform 0.18s ease;
    width: 42px;
}

.heroics-carousel-arrow-img--next {
    transform: scaleX(-1);
}

.carousel-arrow {
    align-items: center;
    background: transparent;
    border: 0;
    display: inline-flex;
    height: 42px;
    justify-content: center;
    margin: 0;
    padding: 0;
    width: 42px;
}

.carousel-arrow .heroics-carousel-arrow-img {
    height: 42px;
    width: 42px;
}

.carousel-arrow::before,
.carousel-arrow::after {
    content: none !important;
}

.heroics-latest-products-carousel .owl-nav button:hover .heroics-carousel-arrow-img {
    opacity: 0.9;
    transform: translateY(-1px);
}

.heroics-latest-products-carousel .owl-nav button:hover .heroics-carousel-arrow-img--next {
    transform: scaleX(-1) translateY(-1px);
}

.heroics-latest-products-carousel .owl-nav button.disabled {
    opacity: 1;
    pointer-events: auto;
}

.heroics-latest-products-carousel .owl-item {
    align-items: flex-start;
    box-sizing: border-box;
    display: flex;
    padding: 0.65rem 0.55rem 1.25rem;
}

.heroics-latest-products-carousel .owl-stage-outer {
    margin-left: -0.55rem;
    margin-right: -0.55rem;
    margin-bottom: -1.25rem;
    margin-top: -0.65rem;
    overflow: hidden !important;
    padding-bottom: 1.25rem;
    padding-left: 0.55rem;
    padding-right: 0.55rem;
    padding-top: 0.65rem;
}

.heroics-latest-products-carousel .owl-item > * {
    width: 100%;
}

.heroics-product-card {
    border-radius: 14px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    position: relative;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
    width: 100%;
}

.product-grid .heroics-product-card {
    height: 100%;
}

.heroics-latest-products-carousel .heroics-product-card {
    height: auto !important;
}

.heroics-product-card:hover {
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.12) !important;
    transform: translateY(-4px);
}

.heroics-product-image {
    background: #e9e5ef;
    height: 250px;
    overflow: hidden;
    position: relative;
}

.product-image-wrapper {
    overflow: hidden;
    position: relative;
}

.heroics-product-image-link {
    height: 100%;
    overflow: hidden;
    position: relative;
}

.heroics-product-image img {
    height: 100%;
    object-fit: cover;
    transition: transform 0.25s ease;
    width: 100%;
}

.product-badge {
    border-radius: 999px;
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.12);
    font-size: 0.75rem;
    font-weight: 600;
    left: 10px;
    line-height: 1;
    padding: 4px 10px;
    position: absolute;
    top: 10px;
    z-index: 2;
}

.product-badge-neutral {
    background: rgba(17, 24, 39, 0.82);
    color: #fff;
}

.product-badge-low {
    background: #facc15;
    color: #2f163d;
}

.product-badge-sale {
    background: rgba(124, 58, 237, .92);
    color: #fff;
    left: auto;
    right: 10px;
}

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

.heroics-product-body {
    background: #fff;
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    height: auto;
    padding: 16px;
    position: relative;
    transition: transform 0.22s ease;
    z-index: 2;
}

.heroics-product-card:not(.is-sold-out) .heroics-product-body {
    margin-bottom: -54px;
}

.heroics-product-card:hover .heroics-product-body {
    transform: translateY(-48px);
}

.heroics-product-card.is-sold-out:hover .heroics-product-body {
    transform: none;
}

.product-card-actions,
.heroics-product-cta.product-card-actions {
    background: none;
    margin-top: 12px !important;
    opacity: 0;
    pointer-events: none;
    position: static;
    transform: translateY(8px);
    transition: opacity 0.18s ease, transform 0.18s ease;
}

.heroics-product-card:hover .product-card-actions,
.heroics-product-card:hover .heroics-product-cta.product-card-actions {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.heroics-product-cta .btn {
    padding-bottom: 0.58rem;
    padding-top: 0.58rem;
}

.product-card-add {
    align-items: center;
    border-radius: 12px;
    display: inline-flex;
    font-weight: 700;
    gap: 8px;
    height: 42px;
    justify-content: center;
    min-width: 42px;
    transition: background-color 0.15s ease, color 0.15s ease, opacity 0.25s ease, transform 0.25s ease;
    white-space: nowrap;
}

.product-card-add-icon {
    align-items: center;
    display: inline-flex;
    flex: 0 0 auto;
    font-size: 1rem;
    height: 1.1em;
    justify-content: center;
    line-height: 1;
    width: 1.1em;
}

.product-card-add.is-loading {
    opacity: 0.82;
    pointer-events: none;
}

.product-card-add.is-loading .product-card-add-icon {
    animation: heroicsAddSpin 0.7s linear infinite;
    border: 2px solid currentColor;
    border-right-color: transparent;
    border-radius: 50%;
}

.product-card-add.is-added {
    background: #198754 !important;
    border-color: #198754 !important;
    color: #fff !important;
}

@keyframes heroicsAddSpin {
    to {
        transform: rotate(360deg);
    }
}

.heroics-product-title {
    display: -webkit-box;
    font-family: var(--heroics-body-font);
    font-size: 0.95rem;
    font-weight: 600;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-height: 1.3;
    margin-bottom: 4px;
    min-height: 2.48rem;
    overflow: hidden;
}

.heroics-product-info {
    min-height: 0;
}

.heroics-product-price {
    color: #4c1d95;
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 0;
    margin-top: 10px;
    position: relative;
    z-index: 2;
}

.product-card-category {
    color: #6c757d;
    font-size: 0.75rem;
}

.product-card-title {
    margin-bottom: 4px;
}

.product-card-price {
    margin-bottom: 0;
    margin-top: 10px;
}

.product-card-price .product-price-old,
.cart-line-unit-price .product-price-old,
.checkout-summary-info .product-price-old {
    color: #94a3b8;
    font-size: .82rem;
    font-weight: 700;
    text-decoration: line-through;
}

.product-card-price .product-price-sale {
    color: #4c1d95;
    display: block;
    font-weight: 900;
}

.heroics-product-actions,
.heroics-product-actions.mt-auto {
    margin-top: 0 !important;
}

.heroics-shop-cta-card {
    background: linear-gradient(135deg, #7C3AA2, #2F163D);
    border-radius: 12px;
    color: #fff;
    min-height: 420px;
}

.heroics-latest-empty {
    background: #ffffff;
    border: 1px dashed #d7cbe2;
}

.heroics-editorial-feature {
    background: #f8fafc;
    overflow-x: hidden;
}

.heroics-editorial-card {
    background: #2F163D;
    box-shadow: 0 24px 55px rgba(47, 22, 61, 0.18);
    height: auto;
    max-height: 460px;
    min-height: 420px;
}

.heroics-editorial-label {
    left: 70px;
    min-width: 320px;
    position: absolute;
    top: 0;
    transform: translateY(-1px);
    z-index: 3;
}

.heroics-editorial-label h2 {
    font-size: 1.35rem;
}

.heroics-editorial-title {
    font-size: clamp(1.75rem, 3vw, 3rem);
    line-height: 1.08;
    max-width: 720px;
}

.heroics-editorial-price {
    font-size: 1.5rem;
    font-weight: 800;
}

.heroics-editorial-carousel {
    border-radius: 14px;
    height: 100%;
    overflow: hidden;
    transform: translateX(35px);
}

.heroics-editorial-carousel .owl-stage-outer,
.heroics-editorial-carousel .owl-stage,
.heroics-editorial-carousel .owl-item,
.heroics-editorial-slide {
    height: 100%;
}

.heroics-editorial-slide img {
    border-radius: 14px;
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.heroics-editorial-carousel .owl-dots {
    bottom: 16px;
    margin: 0 !important;
    position: absolute;
    right: 16px;
}

.heroics-editorial-carousel .owl-dot span {
    background: rgba(255, 255, 255, 0.45) !important;
}

.heroics-editorial-carousel .owl-dot.active span {
    background: #E5C142 !important;
}

.heroics-feature-showcase {
    background: #f8fafc;
    overflow-x: visible;
}

.featured-drops {
    background:
        radial-gradient(circle at 82% 12%, rgba(126, 64, 255, 0.22), transparent 34%),
        linear-gradient(180deg, rgba(51, 16, 77, 0.96), rgba(27, 10, 40, 0.98));
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 32px;
    box-shadow: 0 28px 60px rgba(47, 22, 61, 0.18);
    overflow: hidden;
    padding: clamp(20px, 3vw, 36px);
}

.featured-drops__header {
    align-items: center;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    margin-bottom: clamp(1rem, 2vw, 1.35rem);
}

.featured-drops__eyebrow {
    color: #f5c82f;
    display: inline-flex;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    margin-bottom: 0.65rem;
    position: relative;
    text-transform: uppercase;
}

.featured-drops__eyebrow::after {
    background: #f5c82f;
    border-radius: 999px;
    bottom: -0.35rem;
    content: "";
    height: 2px;
    left: 0;
    position: absolute;
    width: 42px;
}

.featured-drops__header h2 {
    color: #fff;
    font-family: var(--heroics-title-font, inherit);
    font-size: clamp(1.55rem, 2.4vw, 2.35rem);
    line-height: 1;
    margin: 0;
}

.featured-drops__grid {
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.homepage-product-desktop-grid {
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.featured-drops__footer {
    display: none;
    margin-top: 1.5rem;
}

.featured-drops .heroics-product-card {
    box-shadow: 0 20px 48px rgba(15, 23, 42, 0.18) !important;
}

.featured-drops__mobile-grid {
    display: none;
}

.homepage-category-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.homepage-category-grid.is-carousel {
    display: flex;
    overflow-x: auto;
    padding-bottom: .5rem;
    scroll-snap-type: x mandatory;
    scrollbar-width: thin;
}

.homepage-category-grid.is-carousel .homepage-category-card {
    flex: 0 0 min(280px, 24vw);
    scroll-snap-align: start;
}

.homepage-category-cta {
    display: none;
}

.homepage-category-card {
    background: #fff;
    border: 1px solid rgba(47, 22, 61, .08);
    border-radius: 20px;
    box-shadow: 0 18px 42px rgba(47, 22, 61, .08);
    color: #2f163d;
    display: flex;
    flex-direction: column;
    min-width: 0;
    overflow: hidden;
    text-decoration: none;
    transition: transform .18s ease, box-shadow .18s ease;
}

.homepage-category-card:hover {
    box-shadow: 0 22px 52px rgba(47, 22, 61, .14);
    color: #2f163d;
    transform: translateY(-3px);
}

.homepage-category-card__image {
    aspect-ratio: 4 / 3;
    background: #f6f2fb;
    display: block;
    overflow: hidden;
}

.homepage-category-card__image img {
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.homepage-category-card__body {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: .45rem;
    padding: 1rem;
}

.homepage-category-card__body strong {
    font-family: var(--heroics-heading-font);
    font-size: 1rem;
    line-height: 1.1;
}

.homepage-category-card__body small {
    color: #6b6474;
    display: -webkit-box;
    line-height: 1.35;
    min-height: 2.7em;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.homepage-category-card__body span {
    color: #7c3aed;
    font-size: .82rem;
    font-weight: 800;
    margin-top: auto;
}

.heroics-home-seo__shell {
    align-items: stretch;
    background:
        radial-gradient(circle at 12% 0%, rgba(124, 58, 237, .26), transparent 34%),
        linear-gradient(135deg, rgba(47, 22, 61, .98), rgba(27, 10, 40, .98));
    border: 1px solid rgba(255, 255, 255, .1);
    border-radius: 32px;
    box-shadow: 0 26px 70px rgba(47, 22, 61, .2);
    color: #fff;
    display: grid;
    gap: clamp(1.25rem, 3vw, 2rem);
    grid-template-columns: minmax(0, 1.35fr) minmax(280px, .65fr);
    overflow: hidden;
    padding: clamp(1.5rem, 4vw, 3rem);
    position: relative;
}

.heroics-home-seo__shell.is-content-only {
    grid-template-columns: minmax(0, 1fr);
}

.heroics-home-seo__shell::after {
    background: radial-gradient(circle, rgba(229, 193, 66, .16), transparent 68%);
    bottom: -140px;
    content: "";
    height: 300px;
    pointer-events: none;
    position: absolute;
    right: -90px;
    width: 300px;
}

.heroics-home-seo__content {
    max-width: 760px;
    min-width: 0;
    position: relative;
    z-index: 1;
}

.heroics-home-seo__eyebrow {
    color: #e5c142;
    display: inline-flex;
    font-family: var(--heroics-heading-font);
    font-size: .78rem;
    letter-spacing: 0;
    margin-bottom: .85rem;
    text-transform: uppercase;
}

.heroics-home-seo__content h2 {
    font-family: var(--heroics-heading-font);
    font-size: clamp(1.55rem, 3vw, 2.4rem);
    line-height: 1.08;
    margin: 0 0 1rem;
    max-width: 680px;
}

.heroics-home-seo__lead {
    color: rgba(255, 255, 255, .76);
    font-size: clamp(1rem, 1.6vw, 1.12rem);
    line-height: 1.65;
    margin: 0 0 1.35rem;
    max-width: 680px;
}

.heroics-home-seo__richtext {
    color: rgba(255, 255, 255, .78);
    font-size: 1.05rem;
    line-height: 1.8;
    margin-bottom: 1.35rem;
    max-width: 70ch;
}

.heroics-home-seo__richtext h3 {
    color: #fff;
    font-family: var(--heroics-heading-font);
    font-size: clamp(1rem, 1.6vw, 1.2rem);
    line-height: 1.2;
    margin: 1.25rem 0 .5rem;
}

.heroics-home-seo__richtext h3:first-child {
    margin-top: 0;
}

.heroics-home-seo__richtext p,
.heroics-home-seo__richtext ul,
.heroics-home-seo__richtext ol {
    margin: 0 0 1rem;
}

.homepage-seo-content .rich-text-content p {
    line-height: 1.7;
    margin-top: 0;
    margin-bottom: 1rem;
}

.homepage-seo-content .rich-text-content p:last-child,
.homepage-seo-content .rich-text-content ul:last-child,
.homepage-seo-content .rich-text-content ol:last-child {
    margin-bottom: 0;
}

.homepage-seo-content .rich-text-content p:has(> br:only-child) {
    margin-bottom: .6rem;
}

.heroics-home-seo__richtext a {
    color: #e5c142;
    font-weight: 700;
}

.heroics-home-seo__trust {
    display: grid;
    gap: .85rem;
    min-width: 0;
    position: relative;
    z-index: 1;
}

.heroics-home-seo__trust article {
    background: rgba(255, 255, 255, .07);
    border: 1px solid rgba(255, 255, 255, .11);
    border-radius: 22px;
    padding: 1.1rem;
}

.heroics-home-seo__trust h3 {
    color: #fff;
    font-family: var(--heroics-heading-font);
    font-size: .98rem;
    line-height: 1.18;
    margin: 0 0 .45rem;
}

.heroics-home-seo__trust p {
    color: rgba(255, 255, 255, .68);
    font-size: .92rem;
    line-height: 1.5;
    margin: 0;
}

.featured-carousel {
    background: #2F163D;
    border-radius: 24px;
    box-shadow: 0 24px 55px rgba(47, 22, 61, 0.18);
    overflow: visible;
    position: relative;
}

.featured-carousel__label {
    background: #fff;
    border-radius: 0 0 16px 16px;
    color: #201326;
    left: clamp(3rem, 6vw, 5rem);
    padding: 1.1rem 1.4rem;
    position: absolute;
    top: 0;
    z-index: 5;
}

.featured-carousel__label strong,
.featured-carousel__label span {
    display: block;
}

.featured-carousel__label strong {
    font-size: 1.05rem;
    font-weight: 800;
    line-height: 1;
    text-transform: uppercase;
}

.featured-carousel__label span {
    color: #6b5c72;
    font-size: 0.8rem;
    margin-top: 0.2rem;
}

.featured-carousel__viewport {
    overflow: hidden;
}

.featured-carousel__track {
    display: flex;
    transition: transform 350ms ease;
    width: 100%;
}

.featured-carousel__slide {
    align-items: center;
    display: grid;
    flex: 0 0 100%;
    gap: clamp(2rem, 5vw, 5rem);
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
    min-height: 560px;
    min-width: 0;
    padding: clamp(4.5rem, 6vw, 5.5rem) clamp(4rem, 7vw, 6rem) clamp(3rem, 5vw, 4rem);
    width: 100%;
}

.featured-carousel__slide.is-active {
    pointer-events: auto;
}

.featured-carousel__content {
    max-width: 520px;
    min-width: 0;
    padding-top: 1.5rem;
}

.featured-carousel__category {
    margin-bottom: 0.75rem;
    opacity: 0.72;
}

.featured-carousel__title {
    display: -webkit-box;
    font-size: clamp(2.2rem, 3vw, 3.8rem);
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    line-height: 0.98;
    margin-bottom: 1.5rem;
    max-width: 10ch;
    overflow: hidden;
    word-break: normal;
}

.featured-carousel__description {
    margin-bottom: 1.5rem;
    max-width: 34ch;
    opacity: 0.82;
}

.featured-carousel__price {
    font-size: 1.55rem;
    font-weight: 800;
    margin-bottom: 1.5rem;
}

.featured-carousel__cta {
    min-height: 48px;
    padding-inline: 1.35rem;
}

.featured-carousel__media {
    align-items: center;
    display: flex;
    justify-content: center;
    min-width: 0;
}

.featured-carousel__media img {
    display: block;
    filter: drop-shadow(0 24px 45px rgba(0, 0, 0, 0.28));
    max-height: 440px;
    max-width: 560px;
    object-fit: contain;
    width: 100%;
}

.featured-carousel__arrow {
    align-items: center;
    display: inline-flex;
    height: 42px;
    justify-content: center;
    margin: 0;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 42px;
    z-index: 6;
}

.featured-carousel__arrow::before,
.featured-carousel__arrow::after,
.featured-carousel__arrow--prev::before,
.featured-carousel__arrow--prev::after,
.featured-carousel__arrow--next::before,
.featured-carousel__arrow--next::after {
    content: none !important;
}

.featured-carousel__arrow--prev {
    left: -22px;
}

.featured-carousel__arrow--next {
    right: -22px;
}

.featured-carousel__arrow .heroics-carousel-arrow-img {
    height: 42px;
    pointer-events: none;
    width: 42px;
}

.featured-carousel__arrow:hover,
.featured-carousel__arrow:focus-visible {
    transform: translateY(calc(-50% - 1px));
}

.featured-carousel__arrow:hover .heroics-carousel-arrow-img,
.featured-carousel__arrow:focus-visible .heroics-carousel-arrow-img {
    opacity: 0.9;
    transform: translateY(-1px);
}

.featured-carousel__arrow:hover .heroics-carousel-arrow-img--next,
.featured-carousel__arrow:focus-visible .heroics-carousel-arrow-img--next {
    transform: scaleX(-1) translateY(-1px);
}

.featured-carousel__dots {
    align-items: center;
    display: inline-flex;
    gap: 0.4rem;
    left: 50%;
    position: absolute;
    bottom: 2rem;
    transform: translateX(-50%);
    z-index: 6;
}

.featured-carousel__dot {
    border: 0;
    background: rgba(255, 255, 255, 0.35);
    border-radius: 999px;
    height: 9px;
    opacity: 0.4;
    padding: 0;
    width: 9px;
}

.featured-carousel__dot.is-active {
    background: #f5c82f;
    opacity: 1;
    width: 24px;
}

.breadcrumb-dark a,
.breadcrumb-dark .breadcrumb-item {
    color: rgba(255, 255, 255, 0.72);
}

.breadcrumb-dark .active {
    color: #ffffff;
}

.collection-filters {
    border: 1px solid #e5e7eb;
    position: sticky;
    top: 104px;
}

.sort-form {
    min-width: min(100%, 220px);
}

.active-filters .badge {
    border: 1px solid #e5e7eb;
    font-size: 0.85rem;
    padding: 0.55rem 0.8rem;
}

.pagination-placeholder {
    background: #ffffff;
    border: 1px dashed #cbd5e1;
}

.collection-pagination .page-link {
    border-color: #e5e7eb;
    color: #111827;
    min-width: 42px;
    text-align: center;
}

.collection-pagination .page-item.active .page-link {
    background: #111827;
    border-color: #111827;
    color: #ffffff;
}

.product-card img {
    aspect-ratio: 4 / 3;
    object-fit: cover;
}

.product-card {
    transition: transform 160ms ease, box-shadow 160ms ease;
    overflow: hidden;
}

.product-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 22px 54px rgba(15, 23, 42, 0.16) !important;
}

.product-card-media {
    background: #e5e7eb;
}

.product-detail-page {
    background: #f8fafc;
}

.product-detail-card {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.05);
    border-radius: 22px;
    box-shadow: 0 20px 60px rgba(15, 23, 42, 0.08);
    padding: 34px;
}

.product-detail-gallery {
    display: grid;
    gap: 12px;
}

.product-gallery-main {
    background: #f4f1f7;
    border-radius: 18px;
    box-shadow: 0 20px 52px rgba(15, 23, 42, 0.1);
    overflow: hidden;
    position: relative;
}

.product-gallery-main-button {
    appearance: none;
    background: transparent;
    border: 0;
    cursor: zoom-in;
    display: block;
    padding: 0;
    position: relative;
    width: 100%;
}

.product-gallery-main-button:focus-visible {
    outline: 3px solid rgba(111, 66, 193, 0.36);
    outline-offset: 4px;
}

.product-gallery-main img,
.product-gallery-main-button img {
    aspect-ratio: 1 / 1;
    display: block;
    height: auto;
    object-fit: cover;
    transition: transform 400ms ease;
    width: 100%;
}

@media (hover: hover) and (pointer: fine) {
    .product-gallery-main-button:hover img {
        transform: scale(1.035);
    }

    .product-gallery-main-button:hover .product-gallery-zoom {
        opacity: 1;
        transform: translateY(0);
    }
}

.product-gallery-zoom {
    align-items: center;
    background: rgba(26, 16, 39, 0.76);
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 999px;
    bottom: 14px;
    color: #fff;
    display: inline-flex;
    font-size: 0.78rem;
    font-weight: 800;
    gap: 7px;
    opacity: 0;
    padding: 8px 12px;
    position: absolute;
    right: 14px;
    transform: translateY(4px);
    transition: opacity 200ms ease, transform 200ms ease;
}

.product-gallery-zoom svg {
    fill: none;
    height: 16px;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2;
    width: 16px;
}

.product-gallery-thumbs {
    display: flex;
    gap: 12px;
    margin-top: 18px;
    overflow-x: auto;
    padding: 2px 2px 4px;
}

.gallery-thumb {
    background: #fff;
    border: 2px solid rgba(15, 23, 42, 0.08);
    border-radius: 12px;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.06);
    flex: 0 0 82px;
    height: 82px;
    overflow: hidden;
    padding: 4px;
    transition: border-color 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}

.gallery-thumb:focus-visible {
    outline: 3px solid rgba(111, 66, 193, 0.28);
    outline-offset: 2px;
}

@media (hover: hover) and (pointer: fine) {
    .gallery-thumb:hover {
        transform: translateY(-1px);
    }
}

.gallery-thumb.is-active {
    border-color: #6f42c1;
    box-shadow: 0 10px 24px rgba(111, 66, 193, 0.16);
}

.gallery-thumb img {
    border-radius: 8px;
    height: 100%;
    object-fit: contain;
    width: 100%;
}

.product-gallery-lightbox .modal-dialog {
    margin-inline: auto;
    max-width: min(1120px, calc(100vw - 32px));
}

.product-gallery-lightbox .modal-content {
    background: rgba(18, 10, 29, 0.96);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 24px;
    box-shadow: 0 30px 90px rgba(2, 6, 23, 0.44);
    color: #fff;
    overflow: hidden;
}

.product-gallery-lightbox-header {
    display: flex;
    justify-content: flex-end;
    padding: 14px 14px 0;
}

.product-gallery-lightbox-close {
    align-items: center;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 16px;
    color: #fff;
    display: inline-flex;
    font-size: 1.6rem;
    height: 44px;
    justify-content: center;
    line-height: 1;
    width: 44px;
}

.product-gallery-lightbox-close:hover,
.product-gallery-lightbox-close:focus-visible {
    background: rgba(255, 255, 255, 0.14);
}

.product-gallery-lightbox-stage {
    align-items: center;
    display: grid;
    grid-template-columns: 52px minmax(0, 1fr) 52px;
    gap: 12px;
    padding: 16px 22px 24px;
}

.product-gallery-lightbox-stage img {
    background: #fff;
    border-radius: 20px;
    display: block;
    height: auto;
    justify-self: center;
    max-height: min(76vh, 820px);
    max-width: 100%;
    object-fit: contain;
    width: auto;
}

.product-gallery-lightbox-nav {
    align-items: center;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 18px;
    color: #fff;
    display: inline-flex;
    font-size: 2.1rem;
    height: 52px;
    justify-content: center;
    line-height: 1;
    width: 52px;
}

.product-gallery-lightbox-nav:hover,
.product-gallery-lightbox-nav:focus-visible {
    background: rgba(124, 58, 237, 0.5);
}

.product-gallery-lightbox-thumbs {
    display: flex;
    gap: 10px;
    justify-content: center;
    overflow-x: auto;
    padding: 0 22px 22px;
}

.product-gallery-lightbox-thumbs .gallery-thumb {
    flex-basis: 70px;
    height: 70px;
}

.contact-page {
    background: #f8fafc;
}

.contact-card {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .06);
    border-radius: 24px;
    box-shadow: 0 18px 48px rgba(15, 23, 42, .07);
    padding: clamp(22px, 3vw, 34px);
}

.contact-form .form-control {
    border-color: rgba(15, 23, 42, .12);
    border-radius: 16px;
    min-height: 46px;
}

.contact-form textarea.form-control {
    min-height: 150px;
}

.contact-submit {
    min-height: 46px;
    padding-inline: 28px;
}

.contact-hp {
    height: 0;
    left: -10000px;
    overflow: hidden;
    position: absolute;
    width: 0;
}

.contact-details-card {
    position: sticky;
    top: 98px;
}

@media (max-width: 767.98px) {
    .contact-card {
        border-radius: 20px;
        padding: 20px;
    }

    .contact-submit {
        width: 100%;
    }

    .contact-details-card {
        position: static;
    }
}

.faq-page {
    background: #f8fafc;
}

.faq-hero {
    padding: clamp(28px, 5vw, 64px) 0 clamp(18px, 3vw, 36px);
}

.faq-hero-card {
    position: relative;
    overflow: hidden;
    border-radius: 28px;
    padding: clamp(28px, 5vw, 56px);
    background:
        radial-gradient(circle at 86% 20%, rgba(250, 204, 21, .22), transparent 30%),
        linear-gradient(135deg, #2a0d3f 0%, #54208a 58%, #24102f 100%);
    color: #fff;
    box-shadow: 0 26px 70px rgba(36, 16, 47, .18);
}

.faq-hero-card h1 {
    margin: .35rem 0 .75rem;
    font-size: clamp(2rem, 4vw, 4rem);
}

.faq-hero-card p {
    max-width: 58ch;
    margin: 0;
    color: rgba(255, 255, 255, .78);
    font-size: clamp(1rem, 1.35vw, 1.18rem);
}

.faq-content-section {
    padding: 0 0 clamp(40px, 6vw, 78px);
}

.faq-card,
.faq-contact-card {
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 24px;
    background: #fff;
    box-shadow: 0 18px 52px rgba(15, 23, 42, .08);
}

.faq-card {
    padding: clamp(14px, 2vw, 22px);
}

.faq-accordion {
    display: grid;
    gap: .85rem;
}

.faq-accordion-item {
    border: 1px solid rgba(15, 23, 42, .08) !important;
    border-radius: 18px !important;
    overflow: hidden;
    background: #fff;
}

.faq-accordion .accordion-button {
    min-height: 58px;
    padding: 1rem 1.15rem;
    border-radius: 18px !important;
    color: #111827;
    font-weight: 800;
    box-shadow: none;
}

.faq-accordion .accordion-button:not(.collapsed) {
    background: rgba(124, 58, 237, .08);
    color: #3b0764;
}

.faq-accordion .accordion-body {
    padding: 0 1.15rem 1.15rem;
}

.faq-answer {
    color: #4b5563;
    line-height: 1.75;
}

.faq-answer p:last-child,
.faq-answer ul:last-child,
.faq-answer ol:last-child {
    margin-bottom: 0;
}

.faq-contact-card {
    position: sticky;
    top: 98px;
    padding: clamp(20px, 3vw, 28px);
}

.faq-contact-icon,
.faq-empty-icon {
    display: inline-flex;
    width: 46px;
    height: 46px;
    align-items: center;
    justify-content: center;
    border-radius: 16px;
    background: rgba(124, 58, 237, .1);
    color: #6d28d9;
    font-size: 1.25rem;
}

.faq-contact-icon {
    margin-bottom: 1rem;
    background: linear-gradient(135deg, #7c3aed, #4c1d95);
    color: #fff;
    box-shadow: 0 14px 28px rgba(76, 29, 149, .18);
}

.faq-contact-icon svg,
.faq-empty-icon svg {
    width: 21px;
    height: 21px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.faq-contact-card h2 {
    margin-bottom: .55rem;
}

.faq-contact-card p {
    color: #6b7280;
    line-height: 1.65;
    margin-bottom: 1.15rem;
}

.faq-empty {
    padding: clamp(34px, 6vw, 70px) 1rem;
}

.legal-page {
    background: #f8fafc;
}

.legal-hero {
    padding: clamp(28px, 5vw, 64px) 0 clamp(18px, 3vw, 36px);
}

.legal-hero .container,
.legal-container {
    max-width: 1000px;
}

.legal-hero-card {
    position: relative;
    overflow: hidden;
    border-radius: 24px;
    padding: clamp(24px, 4vw, 42px);
    background:
        radial-gradient(circle at 88% 18%, rgba(250, 204, 21, .18), transparent 30%),
        linear-gradient(135deg, #24102f 0%, #4c1d95 58%, #2a0d3f 100%);
    color: #fff;
    box-shadow: 0 26px 70px rgba(36, 16, 47, .18);
}

.legal-hero-card h1 {
    margin: .35rem 0 .75rem;
    font-size: clamp(2rem, 4vw, 4rem);
}

.legal-hero-card p {
    max-width: 64ch;
    margin: 0;
    color: rgba(255, 255, 255, .78);
    font-size: clamp(1rem, 1.35vw, 1.18rem);
}

.legal-content-section {
    padding: 0 0 clamp(58px, 7vw, 104px);
}

.legal-content-card,
.legal-contact-card {
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 24px;
    background: #fff;
    box-shadow: 0 18px 52px rgba(15, 23, 42, .08);
}

.legal-content-card {
    padding: clamp(22px, 4vw, 38px);
}

.legal-rich-text {
    color: #374151;
    font-size: 1.02rem;
    line-height: 1.78;
}

.legal-rich-text h2,
.legal-rich-text h3,
.legal-rich-text h4 {
    color: #111827;
    margin: 1.35rem 0 .65rem;
}

.legal-rich-text h2:first-child,
.legal-rich-text h3:first-child,
.legal-rich-text h4:first-child {
    margin-top: 0;
}

.legal-rich-text p,
.legal-rich-text ul,
.legal-rich-text ol {
    margin-bottom: 1rem;
}

.legal-rich-text p:last-child,
.legal-rich-text ul:last-child,
.legal-rich-text ol:last-child {
    margin-bottom: 0;
}

.legal-rich-text a {
    color: #6d28d9;
    font-weight: 800;
}

.legal-contact-card {
    position: sticky;
    top: 98px;
    padding: clamp(18px, 3vw, 24px);
}

.legal-contact-icon {
    display: inline-flex;
    width: 40px;
    height: 40px;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
    border-radius: 16px;
    background: linear-gradient(135deg, #7c3aed, #4c1d95);
    color: #fff;
    box-shadow: 0 14px 28px rgba(76, 29, 149, .18);
}

.legal-contact-icon svg {
    width: 20px;
    height: 20px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.legal-contact-card p {
    color: #6b7280;
    line-height: 1.65;
    margin-bottom: 1.15rem;
}

.heroics-cookie-consent {
    bottom: max(16px, env(safe-area-inset-bottom));
    left: 0;
    padding: 0 16px;
    position: fixed;
    right: 0;
    z-index: 1080;
}

.heroics-cookie-consent__panel {
    align-items: center;
    background: rgba(36, 16, 47, .96);
    border: 1px solid rgba(255, 255, 255, .12);
    border-radius: 24px;
    box-shadow: 0 24px 60px rgba(20, 5, 35, .28);
    color: #fff;
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 1fr) auto;
    margin: 0 auto;
    max-width: 1080px;
    padding: 18px;
}

.heroics-cookie-consent__eyebrow {
    color: #f5c82f;
    display: block;
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .04em;
    margin-bottom: .25rem;
    text-transform: uppercase;
}

.heroics-cookie-consent h2 {
    font-size: 1.05rem;
    margin: 0 0 .35rem;
}

.heroics-cookie-consent p {
    color: rgba(255, 255, 255, .78);
    line-height: 1.55;
    margin: 0;
}

.heroics-cookie-consent__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
}

.heroics-cookie-consent__actions .btn,
.heroics-cookie-modal .btn {
    min-height: 44px;
}

.heroics-cookie-btn-secondary,
.heroics-cookie-btn-ghost {
    align-items: center;
    border-radius: 999px;
    display: inline-flex;
    font-weight: 800;
    justify-content: center;
    padding: .65rem 1rem;
}

.heroics-cookie-btn-secondary {
    background: #fff;
    border: 1px solid rgba(255, 255, 255, .12);
    color: #24102f;
}

.heroics-cookie-btn-ghost {
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .14);
    color: #fff;
}

.heroics-cookie-category {
    align-items: center;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 18px;
    display: flex;
    gap: 14px;
    justify-content: space-between;
    margin-bottom: 12px;
    padding: 14px;
}

.heroics-cookie-category p {
    color: #6b7280;
    line-height: 1.5;
    margin: .25rem 0 0;
}

.heroics-cookie-category .form-check-input {
    height: 1.35rem;
    width: 2.55rem;
}

@media (max-width: 767.98px) {
    .faq-hero {
        padding-top: 20px;
    }

    .faq-hero-card,
    .faq-card,
    .faq-contact-card {
        border-radius: 20px;
    }

    .faq-accordion .accordion-button {
        min-height: 52px;
        padding: .9rem 1rem;
    }

    .faq-contact-card {
        position: static;
    }

    .legal-hero {
        padding-top: 20px;
    }

    .legal-hero-card,
    .legal-content-card,
    .legal-contact-card {
        border-radius: 20px;
    }

    .legal-content-section {
        padding-bottom: 52px;
    }

    .legal-contact-card {
        position: static;
    }

    .heroics-cookie-consent__panel {
        align-items: stretch;
        grid-template-columns: 1fr;
        padding: 16px;
    }

    .heroics-cookie-consent__actions {
        flex-direction: column;
    }

    .heroics-cookie-consent__actions .btn {
        width: 100%;
    }

    .heroics-cookie-category {
        align-items: flex-start;
    }
}

@media (max-width: 767.98px) {
    .product-gallery-zoom {
        opacity: 1;
        padding: 7px 10px;
        transform: none;
    }

    .product-gallery-thumbs {
        margin-top: 16px;
    }

    .gallery-thumb {
        flex-basis: 70px;
        height: 70px;
    }

    .product-gallery-lightbox .modal-dialog {
        max-width: calc(100vw - 16px);
    }

    .product-gallery-lightbox .modal-content {
        border-radius: 20px;
    }

    .product-gallery-lightbox-stage {
        grid-template-columns: 42px minmax(0, 1fr) 42px;
        gap: 6px;
        padding: 12px 10px 18px;
    }

    .product-gallery-lightbox-stage img {
        border-radius: 16px;
        max-height: 70vh;
    }

    .product-gallery-lightbox-nav {
        border-radius: 14px;
        font-size: 1.7rem;
        height: 44px;
        width: 42px;
    }

    .product-gallery-lightbox-thumbs {
        justify-content: flex-start;
        padding-inline: 12px;
    }
}

.product-detail-info {
    display: grid;
    gap: 18px;
    padding-right: 14px;
}

.product-detail-breadcrumb {
    align-items: center;
    color: #94a3b8;
    display: flex;
    flex-wrap: wrap;
    font-size: 0.84rem;
    gap: 8px;
}

.product-detail-breadcrumb a {
    color: #5b21b6;
    font-weight: 700;
    text-decoration: none;
}

.product-detail-kicker {
    color: #6f42c1;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    margin: 0;
    text-transform: uppercase;
}

.product-detail-info h1 {
    color: #0f172a;
    font-family: var(--heroics-title-font);
    font-size: clamp(2.2rem, 4vw, 4rem);
    line-height: 0.95;
    margin: 0;
}

.product-social-proof {
    align-items: center;
    color: #64748b;
    display: flex;
    flex-wrap: wrap;
    font-size: 0.9rem;
    gap: 6px 10px;
}

.product-reviews-list {
    display: grid;
    gap: 12px;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid rgba(15, 23, 42, .06);
}

.product-review-summary {
    align-items: center;
    background: rgba(15, 23, 42, .025);
    border: 1px solid rgba(15, 23, 42, .06);
    border-radius: 14px;
    color: #64748b;
    display: inline-flex;
    flex-wrap: wrap;
    font-size: .92rem;
    gap: 8px 12px;
    margin: 2px 0 18px;
    padding: 10px 14px;
}

.product-review-card,
.product-review-form {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 16px;
    box-shadow: 0 10px 22px rgba(15, 23, 42, .045);
    padding: 14px;
}

.product-review-card p {
    color: #475569;
    margin: 10px 0;
}

.product-review-form h3 {
    font-size: .98rem;
    font-weight: 900;
    margin-bottom: 10px;
}

.product-review-form .form-label {
    font-size: .86rem;
    margin-bottom: 5px;
}

.product-review-form .form-control,
.product-review-form .form-select {
    min-height: 40px;
}

.product-review-form textarea.form-control {
    min-height: 92px;
}

.product-review-form .heroics-btn {
    min-height: 42px;
}

.product-rating-stars {
    color: #f5b301;
    font-size: 0.96rem;
    letter-spacing: 0.02em;
}

.product-detail-meta {
    color: #64748b;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.product-detail-meta span {
    background: rgba(15, 23, 42, 0.04);
    border-radius: 999px;
    font-size: 0.84rem;
    padding: 6px 11px;
}

.product-detail-price {
    color: #4c1d95;
    display: inline-grid;
    font-size: clamp(2.25rem, 3.2vw, 3.35rem);
    font-weight: 950;
    letter-spacing: -0.01em;
    line-height: 0.94;
    margin: 8px 0 0;
    width: fit-content;
}

.product-detail-price-wrap {
    margin: 12px 0 14px;
}

.product-detail-price::before {
    color: #8b5cf6;
    content: "Prijs";
    font-family: var(--heroics-body-font);
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.12em;
    line-height: 1;
    margin-bottom: 7px;
    text-transform: uppercase;
}

.product-price-stack {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
}

.product-price-old {
    color: #94a3b8;
    font-size: 0.95rem;
    font-weight: 700;
    text-decoration: line-through;
}

.product-price-sale {
    color: #4c1d95;
}

.product-discount-badge {
    background: rgba(246, 203, 52, .22);
    border: 1px solid rgba(246, 203, 52, .36);
    border-radius: 999px;
    color: #6b4a00;
    font-size: .78rem;
    font-weight: 900;
    padding: 5px 9px;
}

.product-loyalty-card,
.checkout-loyalty-card,
.account-loyalty-card {
    background: rgba(124, 58, 237, .08);
    border: 1px solid rgba(124, 58, 237, .14);
    color: #2d123d;
}

.product-detail-price-wrap + .product-loyalty-card,
.product-detail-price + .product-loyalty-card {
    margin-top: 2px;
    margin-bottom: 0 !important;
}

@media (max-width: 767.98px) {
    .product-detail-price {
        font-size: clamp(2.05rem, 9vw, 2.55rem);
        margin-top: 6px;
    }
}

.loyalty-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: rgba(246, 203, 52, .22);
    color: #7c3aed;
    flex: 0 0 auto;
    font-weight: 800;
}

.product-urgency {
    background: rgba(245, 179, 1, 0.12);
    border: 1px solid rgba(245, 179, 1, 0.24);
    border-radius: 999px;
    color: #7a4d00;
    font-size: 0.9rem;
    font-weight: 700;
    margin: -6px 0 0;
    padding: 8px 12px;
    width: fit-content;
}

.product-detail-intro {
    color: #64748b;
    font-size: 1.02rem;
    line-height: 1.65;
    margin: 0;
    max-width: 680px;
}

.product-meta {
    background: rgba(248, 250, 252, .72);
    border: 1px solid rgba(15, 23, 42, 0.055);
    border-radius: 12px;
    display: grid;
    gap: 8px 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 0;
    padding: 10px 12px;
}

.product-meta div {
    align-items: start;
    display: grid;
    gap: 2px;
    min-width: 0;
}

.product-meta dt {
    color: #94a3b8;
    font-size: 0.64rem;
    font-weight: 800;
    letter-spacing: .02em;
    line-height: 1.1;
    text-transform: uppercase;
}

.product-meta dd {
    color: #0f172a;
    font-size: 0.8rem;
    font-weight: 600;
    line-height: 1.18;
    margin: 0;
    min-width: 0;
    overflow-wrap: anywhere;
}

#productSku {
    color: #475569;
    font-size: 0.86rem;
}

.product-detail-add {
    display: grid;
    gap: 12px;
}

.product-buy {
    margin-top: 14px;
}

.product-section-heading {
    align-items: end;
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px;
}

.product-section-heading h2 {
    font-size: 1rem;
    font-weight: 800;
    margin: 0;
}

.product-section-heading span {
    color: #64748b;
    font-size: 0.85rem;
}

.variant-grid {
    display: grid;
    gap: 10px;
}

.variant-option {
    align-items: flex-start;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 14px;
    cursor: pointer;
    display: flex;
    gap: 10px;
    padding: 13px;
    transition: background 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.variant-option:has(input:checked) {
    background: rgba(111, 66, 193, 0.06);
    border-color: #6f42c1;
    box-shadow: 0 10px 28px rgba(111, 66, 193, 0.12);
}

.variant-option.is-disabled {
    cursor: not-allowed;
    opacity: 0.5;
}

.variant-option-copy {
    display: grid;
    gap: 2px;
}

.variant-option-copy span {
    color: #64748b;
    font-size: 0.9rem;
}

.product-add-row {
    align-items: stretch;
    display: grid;
    gap: 12px;
    grid-template-columns: auto minmax(0, 1fr);
}

.quantity-stepper {
    align-items: center;
    border: 1px solid rgba(15, 23, 42, 0.12);
    border-radius: 14px;
    display: inline-flex;
    height: 48px;
    overflow: hidden;
}

.quantity-stepper button,
.quantity-stepper input {
    background: #fff;
    border: 0;
    height: 48px;
    text-align: center;
}

.quantity-stepper button {
    font-weight: 800;
    transition: background 140ms ease, transform 140ms ease;
    width: 46px;
}

.quantity-stepper button:hover {
    background: rgba(111, 66, 193, 0.07);
}

.quantity-stepper button:active {
    transform: scale(0.94);
}

.quantity-stepper input {
    border-left: 1px solid rgba(15, 23, 42, 0.08);
    border-right: 1px solid rgba(15, 23, 42, 0.08);
    width: 58px;
}

.quantity-stepper input.is-pulsing {
    animation: productQtyPulse 180ms ease;
}

@keyframes productQtyPulse {
    0% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.08);
    }
    100% {
        transform: scale(1);
    }
}

.product-cta {
    border-radius: 12px;
    font-weight: 800;
    height: 50px;
    letter-spacing: 0.2px;
    transition: transform 160ms ease, box-shadow 160ms ease;
}

.product-cta:hover {
    box-shadow: 0 12px 26px rgba(15, 23, 42, 0.12);
    transform: translateY(-1px);
}

.product-card-add.is-added {
    animation: productAddPulse 360ms ease;
}

@keyframes productAddPulse {
    0% {
        transform: scale(1);
    }
    45% {
        transform: scale(1.025);
    }
    100% {
        transform: scale(1);
    }
}

.product-bundle {
    background: linear-gradient(135deg, rgba(111, 66, 193, 0.075), rgba(255, 255, 255, 0.94));
    border: 1px solid rgba(111, 66, 193, 0.14);
    border-radius: 20px;
    display: grid;
    gap: 14px;
    padding: 16px;
}

.product-bundle-heading {
    display: grid;
    gap: 2px;
}

.product-bundle-heading strong {
    color: #0f172a;
    font-size: 1.02rem;
}

.product-bundle-heading span,
.product-bundle-feedback {
    color: #64748b;
    font-size: 0.86rem;
}

.product-bundle-builder {
    align-items: center;
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding-bottom: 3px;
    scrollbar-width: none;
}

.product-bundle-builder::-webkit-scrollbar {
    display: none;
}

.product-bundle-card {
    background: rgba(255, 255, 255, 0.86);
    border: 1px solid rgba(15, 23, 42, 0.07);
    border-radius: 16px;
    cursor: pointer;
    display: grid;
    flex: 0 0 128px;
    gap: 6px;
    min-height: 178px;
    padding: 10px;
    position: relative;
    transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}

.product-bundle-card:hover,
.product-bundle-card:focus-within,
.product-bundle-card.is-selected {
    border-color: rgba(124, 58, 237, 0.36);
    box-shadow: 0 12px 24px rgba(76, 29, 149, 0.09);
}

.product-bundle-card.is-main {
    cursor: default;
}

.product-bundle-card.is-disabled {
    cursor: default;
    opacity: .68;
}

.product-bundle-card.is-missing-variant {
    border-color: rgba(245, 158, 11, 0.55);
    box-shadow: 0 10px 22px rgba(245, 158, 11, 0.12);
}

.product-bundle-card-check {
    left: 8px;
    position: absolute;
    top: 8px;
    z-index: 2;
}

.product-bundle-card-check input {
    accent-color: #7c3aed;
    height: 18px;
    width: 18px;
}

.product-bundle-included {
    background: #4c1d95;
    border-radius: 999px;
    color: #fff;
    font-size: .62rem;
    font-weight: 900;
    left: 8px;
    padding: .16rem .42rem;
    position: absolute;
    top: 8px;
    z-index: 2;
}

.product-bundle-image-link {
    align-self: center;
    display: inline-flex;
    justify-self: center;
    line-height: 0;
}

.product-bundle-card img {
    align-self: center;
    border-radius: 10px;
    height: 76px;
    justify-self: center;
    object-fit: contain;
    width: 88px;
}

.product-bundle-title-link {
    color: #0f172a;
    display: -webkit-box;
    font-size: 0.78rem;
    font-weight: 900;
    line-height: 1.25;
    overflow: hidden;
    text-decoration: none;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.product-bundle-title-link:hover,
.product-bundle-title-link:focus {
    color: #5b21b6;
    text-decoration: underline;
}

.product-bundle-card small {
    color: #5b21b6;
    display: block;
    font-size: 0.82rem;
    font-weight: 900;
}

.product-bundle-status {
    align-items: center;
    display: grid;
    gap: 4px;
    justify-content: start;
    min-height: 18px;
    text-align: left;
}

.product-bundle-badge {
    background: rgba(124, 58, 237, 0.1);
    border-radius: 999px;
    color: #6d28d9;
    font-size: 0.68rem;
    font-weight: 800;
    padding: 0.18rem 0.5rem;
    white-space: nowrap;
}

.product-bundle-badge.is-muted {
    background: rgba(100, 116, 139, 0.12);
    color: #64748b;
}

.product-bundle-variant-select {
    appearance: none;
    background: rgba(124, 58, 237, 0.045);
    border: 1px solid rgba(124, 58, 237, 0.18);
    border-radius: 999px;
    color: #4c1d95;
    font-size: .68rem;
    font-weight: 800;
    max-width: 100%;
    min-height: 30px;
    padding: .24rem .56rem;
    width: 100%;
}

.product-bundle-variant-select:focus {
    border-color: rgba(124, 58, 237, .55);
    box-shadow: 0 0 0 3px rgba(124, 58, 237, .12);
    outline: 0;
}

.product-bundle-link {
    color: #6d28d9;
    font-size: 0.75rem;
    font-weight: 800;
    text-decoration: none;
}

.product-bundle-link:hover,
.product-bundle-link:focus {
    color: #4c1d95;
    text-decoration: underline;
}

.product-bundle-operator {
    color: #7c3aed;
    flex: 0 0 auto;
    font-size: 1.2rem;
    font-weight: 900;
}

.product-bundle-summary {
    background: #fff;
    border: 1px solid rgba(76, 29, 149, .12);
    border-radius: 16px;
    display: grid;
    flex: 0 0 170px;
    gap: 5px;
    padding: 12px;
    position: sticky;
    right: 0;
}

.product-bundle-summary > span {
    color: #64748b;
    font-size: .76rem;
    font-weight: 800;
}

.product-bundle-summary > strong {
    color: #4c1d95;
    font-size: 1.15rem;
    font-weight: 950;
}

.product-bundle-summary > small {
    color: #64748b;
    font-size: .76rem;
}

.product-bundle-warning {
    color: #b45309 !important;
    font-weight: 900;
}

.product-bundle-add {
    align-items: center;
    background: linear-gradient(135deg, #7c3aed, #5b21b6) !important;
    border: 1px solid rgba(91, 33, 182, .18) !important;
    border-radius: 999px;
    box-shadow: 0 10px 22px rgba(91, 33, 182, .18);
    color: #fff !important;
    display: inline-flex;
    font-weight: 800;
    justify-content: center;
    min-height: 44px;
    padding: .62rem 1rem;
    white-space: nowrap;
    width: 100%;
}

.product-bundle-add:hover,
.product-bundle-add:focus {
    background: linear-gradient(135deg, #8b5cf6, #6d28d9) !important;
    box-shadow: 0 14px 26px rgba(91, 33, 182, .24);
    color: #fff !important;
}

.product-bundle-add:disabled,
.product-bundle-add.disabled {
    background: rgba(124, 58, 237, .08) !important;
    border-color: rgba(124, 58, 237, .14) !important;
    box-shadow: none;
    color: rgba(76, 29, 149, .48) !important;
    cursor: not-allowed;
    opacity: 1;
}

@media (max-width: 575.98px) {
    .product-bundle {
        padding: 14px;
    }

    .product-bundle-builder {
        align-items: stretch;
        gap: 8px;
    }

    .product-bundle-card {
        flex-basis: 122px;
    }

    .product-bundle-summary {
        flex-basis: 168px;
    }
}

.product-trust-list {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-top: 14px;
}

.product-trust-list div {
    align-items: flex-start;
    background: rgba(248, 250, 252, .86);
    border: 1px solid rgba(15, 23, 42, .065);
    border-radius: 14px;
    display: flex;
    gap: 9px;
    min-width: 0;
    padding: 11px;
}

.product-trust-list div + div {
    border-top: 1px solid rgba(15, 23, 42, .065);
}

.product-trust-list span {
    color: #64748b;
    display: block;
    font-size: 0.82rem;
    min-width: 0;
}

.product-trust-list strong {
    color: #0f172a;
    display: block;
    font-size: 0.82rem;
    line-height: 1.22;
}

.product-trust-list small {
    color: #64748b;
    display: block;
    font-size: 0.74rem;
    line-height: 1.35;
    margin-top: 2px;
}

.product-trust-icon {
    align-items: center;
    background: rgba(124, 58, 237, .09);
    border: 1px solid rgba(124, 58, 237, .12);
    border-radius: 10px;
    color: #6d28d9 !important;
    display: inline-flex !important;
    flex: 0 0 28px;
    height: 28px;
    justify-content: center;
    width: 28px;
}

.product-trust-icon svg {
    fill: none;
    height: 17px;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 1.9;
    width: 17px;
}

.product-info-tabs {
    background: #fff;
    border-radius: 20px;
    box-shadow: 0 14px 40px rgba(15, 23, 42, 0.06);
    margin-top: 32px;
    padding: 24px;
}

.product-tab-list {
    background: rgba(15, 23, 42, 0.035);
    border-radius: 16px;
    display: flex;
    gap: 6px;
    margin-bottom: 22px;
    padding: 6px;
}

.product-tab-list button {
    background: transparent;
    border: 0;
    border-radius: 12px;
    color: #64748b;
    flex: 1 1 0;
    font-weight: 800;
    min-height: 42px;
    padding: 8px 12px;
    transition: background 160ms ease, color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.product-tab-list button:hover {
    background: rgba(255, 255, 255, 0.72);
    color: #5b21b6;
    transform: translateY(-1px);
}

.product-tab-list button.is-active {
    background: #fff;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.06);
    color: #0f172a;
}

.product-tab-panel {
    animation: productTabIn 250ms ease;
}

.product-tab-layout {
    align-items: start;
    display: grid;
    gap: 32px;
    grid-template-columns: 1.4fr 1fr;
}

.product-tab-main,
.product-tab-side {
    min-width: 0;
}

.product-tab-side {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.product-tab-panel h2 {
    font-size: 1.25rem;
    font-weight: 800;
    margin-bottom: 10px;
}

.product-tab-panel p {
    color: #475569;
    line-height: 1.7;
    margin: 0;
    max-width: 760px;
}

@keyframes productTabIn {
    from {
        opacity: 0;
        transform: translateY(6px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.product-highlight {
    background: rgba(15, 23, 42, 0.03);
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 14px;
    padding: 16px;
}

.product-highlight h3 {
    font-size: 1rem;
    font-weight: 800;
    margin-bottom: 10px;
}

.product-highlight ul,
.product-tab-specs {
    display: grid;
    gap: 9px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.product-highlight li {
    color: #475569;
    padding-left: 18px;
    position: relative;
}

.product-highlight li::before {
    color: #198754;
    content: "✓";
    font-weight: 900;
    left: 0;
    position: absolute;
    top: 0;
}

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

.spec-item {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 10px;
    box-shadow: 0 10px 26px rgba(15, 23, 42, 0.04);
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 12px;
}

.spec-item span {
    color: #64748b;
    font-size: 0.82rem;
    font-weight: 800;
}

.spec-item strong {
    color: #0f172a;
    text-align: right;
}

.product-trust-card {
    align-items: flex-start;
    background: rgba(15, 23, 42, 0.03);
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 16px;
    display: flex;
    gap: 14px;
    padding: 18px;
}

.product-trust-icon {
    align-items: center;
    background: rgba(25, 135, 84, 0.12);
    border-radius: 999px;
    color: #198754;
    display: inline-flex;
    flex: 0 0 34px;
    font-weight: 900;
    height: 34px;
    justify-content: center;
    width: 34px;
}

.product-trust-card ul {
    display: grid;
    gap: 8px;
    list-style: none;
    margin: 14px 0 0;
    padding: 0;
}

.product-trust-card li {
    color: #475569;
    padding-left: 18px;
    position: relative;
}

.product-trust-card li::before {
    color: #198754;
    content: "✓";
    font-weight: 900;
    left: 0;
    position: absolute;
    top: 0;
}

.product-quick-info {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 14px;
    box-shadow: 0 10px 26px rgba(15, 23, 42, 0.04);
    padding: 16px;
}

.product-quick-info h3 {
    font-size: 1rem;
    font-weight: 800;
    margin-bottom: 12px;
}

.product-quick-info dl {
    display: grid;
    gap: 9px;
    margin: 0;
}

.product-quick-info div {
    align-items: center;
    display: flex;
    justify-content: space-between;
    gap: 14px;
}

.product-quick-info dt {
    color: #64748b;
    font-size: 0.84rem;
    font-weight: 800;
}

.product-quick-info dd {
    color: #0f172a;
    font-weight: 800;
    margin: 0;
    text-align: right;
}

.product-details-list {
    background: #f8fafc;
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 16px;
    padding: 18px;
}

.product-details-list h3 {
    font-size: 1rem;
    font-weight: 800;
    margin-bottom: 12px;
}

.product-details-list ul {
    display: grid;
    gap: 9px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.product-details-list li {
    align-items: center;
    display: flex;
    gap: 12px;
    justify-content: space-between;
}

.product-details-list span {
    color: #64748b;
    font-size: 0.86rem;
}

.product-details-list strong {
    color: #0f172a;
    font-size: 0.9rem;
    text-align: right;
}

.product-related-section {
    margin-top: 40px;
}

.heroics-carousel-no-nav .owl-nav {
    display: none !important;
}

.sticky-add {
    align-items: center;
    background: #fff;
    border-top: 1px solid rgba(15, 23, 42, 0.08);
    bottom: 0;
    box-shadow: 0 -16px 42px rgba(15, 23, 42, 0.12);
    display: flex;
    gap: 16px;
    justify-content: space-between;
    left: 0;
    opacity: 0;
    padding: 10px 16px calc(10px + env(safe-area-inset-bottom));
    pointer-events: none;
    position: fixed;
    right: 0;
    transform: translateY(100%);
    transition: opacity 180ms ease, transform 180ms ease;
    z-index: 1040;
}

.sticky-add.is-visible {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.sticky-add-product {
    align-items: center;
    display: flex;
    gap: 12px;
    min-width: 0;
}

.sticky-add-product img {
    border-radius: 12px;
    flex: 0 0 52px;
    height: 52px;
    object-fit: cover;
    width: 52px;
}

.sticky-add-product span {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.sticky-add-product strong {
    color: #0f172a;
    font-size: 0.95rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.sticky-add-product small {
    color: #0f172a;
    font-size: 1rem;
    font-weight: 800;
}

.sticky-add .btn {
    border-radius: 12px;
    flex: 0 0 auto;
    font-weight: 800;
    min-height: 46px;
    min-width: 150px;
}

.cart-item-thumb {
    height: 56px;
    object-fit: cover;
    width: 56px;
}

.account-order-row {
    border: 1px solid #e5e7eb;
    color: #111827;
    margin-bottom: 0.75rem;
}

.account-order-row:hover {
    background: #fffbeb;
    border-color: var(--heroics-yellow);
}

.cart-panel,
.empty-state {
    background: #ffffff;
    border: 1px solid #e5e7eb;
}

.account-page {
    background: #f8fafc;
    padding: 42px 0 64px;
}

.account-layout {
    align-items: start;
    display: grid;
    gap: 30px;
    grid-template-columns: 260px minmax(0, 1fr);
}

.account-layout > * {
    min-width: 0;
}

.account-sidebar {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 18px;
    box-shadow: 0 16px 42px rgba(15, 23, 42, 0.06);
    display: grid;
    gap: 6px;
    padding: 16px;
    position: sticky;
    top: 96px;
}

.account-sidebar a {
    align-items: center;
    border-radius: 13px;
    color: #334155;
    display: flex;
    font-weight: 800;
    gap: 10px;
    padding: 12px 14px;
    text-decoration: none;
    transition: background 160ms ease, color 160ms ease, transform 160ms ease;
}

.account-sidebar-more {
    display: none;
}

.account-sidebar a:hover {
    background: rgba(111, 66, 193, 0.07);
    color: #4c1d95;
    transform: translateX(2px);
}

.account-sidebar a.is-active {
    background: linear-gradient(135deg, #6f42c1, #8a5cf6);
    color: #fff;
}

.account-sidebar-icon {
    align-items: center;
    background: rgba(15, 23, 42, 0.06);
    border-radius: 10px;
    display: inline-flex;
    flex: 0 0 28px;
    font-size: 0.78rem;
    height: 28px;
    justify-content: center;
    width: 28px;
}

.account-icon-svg {
    color: inherit;
    display: block;
    height: 18px;
    text-align: center;
    width: 18px;
}

.account-sidebar a.is-active .account-sidebar-icon {
    background: rgba(255, 255, 255, 0.18);
}

.account-sidebar-logout {
    border-top: 1px solid rgba(15, 23, 42, 0.08);
    margin-top: 8px;
    padding-top: 16px !important;
}

.account-content {
    display: grid;
    gap: 22px;
    min-width: 0;
}

.account-welcome-card,
.account-panel,
.card-stat,
.account-recommendations {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
    min-width: 0;
}

.account-welcome-card {
    align-items: center;
    border-radius: 20px;
    display: grid;
    gap: 18px;
    grid-template-columns: 64px minmax(0, 1fr) auto;
    padding: 26px;
}

.account-avatar {
    align-items: center;
    background: linear-gradient(135deg, #6f42c1, #4865ee);
    border-radius: 999px;
    color: #fff;
    display: inline-flex;
    font-weight: 900;
    height: 52px;
    justify-content: center;
    width: 52px;
}

.account-eyebrow {
    color: #6f42c1;
    font-size: 0.76rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    margin: 0 0 5px;
    text-transform: uppercase;
}

.account-welcome-card h1,
.account-panel h2,
.account-recommendations h2 {
    color: #0f172a;
    font-weight: 900;
    margin: 0;
}

.account-welcome-card h1 {
    font-size: clamp(1.8rem, 3vw, 2.5rem);
}

.account-welcome-card p:not(.account-eyebrow) {
    color: #64748b;
    margin: 0;
}

.account-welcome-card small {
    color: #94a3b8;
    display: block;
    font-weight: 700;
    margin-top: 4px;
}

.account-stats-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.card-stat {
    border-radius: 18px;
    display: grid;
    gap: 8px;
    padding: 22px;
    transition: box-shadow 160ms ease, transform 160ms ease;
}

.card-stat.is-highlight {
    background: linear-gradient(135deg, #6f42c1, #8a5cf6);
    color: #fff;
}

.card-stat:hover,
.account-panel:hover,
.account-recommendations:hover {
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
    transform: translateY(-2px);
}

.card-stat span {
    color: #64748b;
    display: block;
    font-size: 0.86rem;
    font-weight: 800;
}

.card-stat.is-highlight span,
.card-stat.is-highlight strong {
    color: #fff;
}

.card-stat-icon {
    align-items: center;
    background: rgba(111, 66, 193, 0.1);
    border-radius: 12px;
    color: #6f42c1 !important;
    display: inline-flex !important;
    height: 36px;
    justify-content: center;
    margin-bottom: 4px;
    width: 36px;
}

.card-stat.is-highlight .card-stat-icon {
    background: rgba(255, 255, 255, 0.18);
    color: #fff !important;
}

.card-stat strong {
    color: #0f172a;
    font-size: clamp(1.35rem, 2vw, 1.8rem);
    font-weight: 900;
}

.account-dashboard-grid {
    align-items: start;
    display: grid;
    gap: 22px;
    grid-template-columns: minmax(0, 1fr) 320px;
}

.account-quick-actions {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 18px;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
    padding: 22px;
}

.account-quick-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.account-quick-grid a {
    background: #f8fafc;
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 16px;
    color: #0f172a;
    display: grid;
    gap: 4px;
    padding: 16px;
    text-decoration: none;
    transition: background 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.account-quick-grid a:hover {
    background: #fffbeb;
    box-shadow: 0 14px 32px rgba(15, 23, 42, 0.08);
    transform: translateY(-2px);
}

.account-quick-grid span {
    align-items: center;
    background: rgba(111, 66, 193, 0.1);
    border-radius: 12px;
    color: #6f42c1;
    display: inline-flex;
    font-weight: 900;
    height: 34px;
    justify-content: center;
    margin-bottom: 6px;
    width: 34px;
}

.account-quick-grid strong {
    font-size: 0.95rem;
}

.account-quick-grid small {
    color: #64748b;
}

.account-panel,
.account-recommendations {
    border-radius: 18px;
    padding: 22px;
    transition: box-shadow 160ms ease, transform 160ms ease;
}

.account-recommendations .carousel-wrapper,
.account-recommendations .owl-carousel,
.account-recommendations .owl-stage-outer {
    max-width: 100%;
    min-width: 0;
}

.account-recommendations .owl-stage-outer {
    overflow: hidden;
}

.account-panel-header {
    align-items: center;
    display: flex;
    gap: 16px;
    justify-content: space-between;
    margin-bottom: 18px;
}

.account-order-list {
    display: grid;
    gap: 10px;
}

.account-order-row {
    align-items: center;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.07);
    border-radius: 15px;
    color: #0f172a;
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, 1.4fr) auto auto auto;
    padding: 14px;
    text-decoration: none;
    transition: background 160ms ease, border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.account-order-row:hover {
    background: #fffbeb;
    border-color: rgba(229, 193, 66, 0.55);
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.07);
    transform: translateY(-1px);
}

.account-order-main {
    display: grid;
    gap: 2px;
}

.account-order-main small {
    color: #64748b;
}

.order-status {
    background: rgba(111, 66, 193, 0.1);
    border-radius: 999px;
    color: #4c1d95;
    font-size: 0.75rem;
    font-weight: 900;
    padding: 4px 10px;
    white-space: nowrap;
}

.order-status-shipped {
    background: rgba(72, 101, 238, 0.12);
    color: #3047b5;
}

.order-status-completed {
    background: rgba(25, 135, 84, 0.12);
    color: #198754;
}

.order-status-cancelled {
    background: rgba(220, 53, 69, 0.1);
    color: #dc3545;
}

.account-order-total {
    font-weight: 900;
    white-space: nowrap;
}

.account-order-action {
    background: rgba(111, 66, 193, 0.08);
    border-radius: 12px;
    color: #6f42c1;
    font-size: 0.86rem;
    font-weight: 900;
    padding: 9px 12px;
    white-space: nowrap;
}

.account-empty-state {
    background: #f8fafc;
    border: 1px dashed rgba(15, 23, 42, 0.14);
    border-radius: 16px;
    padding: 30px;
    text-align: center;
}

.account-empty-state h3 {
    font-size: 1.1rem;
    font-weight: 900;
}

.account-empty-state p {
    color: #64748b;
}

.account-support-panel {
    display: grid;
    gap: 10px;
}

.account-support-icon {
    align-items: center;
    background: rgba(111, 66, 193, 0.1);
    border-radius: 14px;
    color: #6f42c1;
    display: inline-flex;
    font-weight: 900;
    height: 42px;
    justify-content: center;
    width: 42px;
}

.account-support-panel p {
    color: #64748b;
    margin: 0 0 6px;
}

@media (max-width: 991.98px) {
    .account-page {
        overflow-x: clip;
        padding: 14px 0 48px;
    }

    .account-layout,
    .account-dashboard-grid {
        display: grid;
        gap: 18px;
        grid-template-columns: minmax(0, 1fr);
        max-width: 100%;
        min-width: 0;
    }

    .account-content,
    .account-panel,
    .account-loyalty-card,
    .account-welcome-card,
    .account-quick-actions,
    .account-recommendations {
        max-width: 100%;
        min-width: 0;
    }

    .account-sidebar {
        align-items: center;
        background: rgba(248, 250, 252, .92);
        backdrop-filter: blur(14px);
        border-radius: 0;
        border-width: 0 0 1px;
        box-shadow: 0 10px 26px rgba(15, 23, 42, .06);
        display: grid;
        gap: 6px;
        grid-template-columns: minmax(0, 1fr) minmax(0, 1.14fr) minmax(0, 1fr) auto;
        margin-inline: calc(var(--bs-gutter-x, 1.5rem) * -.5);
        max-width: 100%;
        overflow: visible;
        padding: 8px max(8px, calc(var(--bs-gutter-x, 1.5rem) * .5));
        position: sticky;
        top: 0;
        white-space: nowrap;
        z-index: 20;
    }

    .account-sidebar::-webkit-scrollbar {
        display: none;
    }

    .account-sidebar-link--secondary {
        display: none !important;
    }

    .account-sidebar a,
    .account-sidebar-more__toggle {
        align-items: center;
        border: 1px solid rgba(15, 23, 42, .08);
        border-radius: 999px;
        color: #334155;
        display: inline-flex;
        font-size: .72rem;
        font-weight: 900;
        gap: 5px;
        justify-content: center;
        line-height: 1;
        min-height: 40px;
        min-width: 0;
        padding: 0 9px;
        text-decoration: none;
        transition: background 160ms ease, border-color 160ms ease, color 160ms ease, box-shadow 160ms ease;
        width: 100%;
    }

    .account-sidebar a:hover,
    .account-sidebar-more__toggle:hover,
    .account-sidebar-more__toggle:focus-visible,
    .account-sidebar-more__toggle.show {
        background: rgba(111, 66, 193, .07);
        color: #4c1d95;
        transform: none;
    }

    .account-sidebar a.is-active,
    .account-sidebar-more.is-active > .account-sidebar-more__toggle,
    .account-sidebar-more__toggle.show {
        background: linear-gradient(135deg, #6f42c1, #8a5cf6);
        border-color: transparent;
        box-shadow: 0 10px 22px rgba(111, 66, 193, .22);
        color: #fff;
    }

    .account-sidebar-icon {
        background: rgba(111, 66, 193, .08);
        border-radius: 999px;
        flex: 0 0 22px;
        height: 22px;
        width: 22px;
    }

    .account-icon-svg {
        height: 14px;
        width: 14px;
    }

    .account-sidebar a.is-active .account-sidebar-icon,
    .account-sidebar-more.is-active > .account-sidebar-more__toggle .account-sidebar-icon,
    .account-sidebar-more__toggle.show .account-sidebar-icon {
        background: rgba(255,255,255,.18);
    }

    .account-sidebar-more {
        display: block;
        position: relative;
    }

    .account-sidebar-more__toggle {
        appearance: none;
        background: rgba(255,255,255,.7);
        cursor: pointer;
        font-family: inherit;
    }

    .account-sidebar-more__toggle::after {
        display: none;
    }

    .account-sidebar-more__menu {
        background: #fff;
        border: 1px solid rgba(15, 23, 42, .08);
        border-radius: 16px;
        box-shadow: 0 18px 42px rgba(15, 23, 42, .14);
        gap: 6px;
        min-width: min(220px, calc(100vw - 24px));
        padding: 8px;
        z-index: 30;
    }

    .account-sidebar-more__menu.show {
        display: grid;
    }

    .account-sidebar-more__menu a {
        justify-content: flex-start;
        min-height: 42px;
        padding-inline: 10px;
    }

    .account-sidebar-logout {
        border-top: 0;
        margin-top: 0;
        padding-top: 0 !important;
    }

    .account-sidebar a span:last-child,
    .account-sidebar-more__toggle span:last-child {
        min-width: 0;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .account-sidebar a {
        white-space: nowrap;
    }

    .account-sidebar a {
        flex: 0 0 auto;
    }

    .account-order-row {
        align-items: start;
        grid-template-columns: minmax(0, 1fr);
    }

    .account-panel-header {
        align-items: flex-start;
        flex-wrap: wrap;
    }
}

@media (max-width: 575.98px) {
    .account-welcome-card {
        grid-template-columns: 48px minmax(0, 1fr);
    }

    .account-welcome-card .btn {
        grid-column: 1 / -1;
        width: 100%;
    }

    .account-stats-grid,
    .account-quick-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .account-panel,
    .account-recommendations,
    .account-welcome-card,
    .account-quick-actions {
        padding: 18px;
    }
}

.account-orders-page {
    gap: 18px;
}

.account-orders-header {
    align-items: center;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 20px;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
    display: flex;
    gap: 18px;
    justify-content: space-between;
    padding: 24px;
}

.account-orders-header h1 {
    color: #0f172a;
    font-weight: 900;
    margin: 0;
}

.account-orders-header p:not(.account-eyebrow) {
    color: #64748b;
    margin: 6px 0 0;
}

.order-filters {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 18px;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.05);
    display: grid;
    gap: 12px;
    grid-template-columns: minmax(0, 1fr) 190px 190px;
    padding: 14px;
}

.order-filters .form-control,
.order-filters .form-select {
    border: 1px solid rgba(15, 23, 42, 0.1);
    border-radius: 14px;
    min-height: 46px;
}

.order-filters .form-control:focus,
.order-filters .form-select:focus {
    border-color: #6f42c1;
    box-shadow: 0 0 0 4px rgba(111, 66, 193, 0.12);
}

.order-list {
    display: grid;
    gap: 16px;
}

.order-card {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 16px;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
    display: grid;
    gap: 16px;
    padding: 18px;
    transition: box-shadow 150ms ease, transform 150ms ease;
}

.order-card:hover {
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.09);
    transform: translateY(-2px);
}

.order-top,
.order-bottom {
    align-items: center;
    display: flex;
    gap: 16px;
    justify-content: space-between;
}

.order-top strong {
    color: #0f172a;
    display: block;
    font-weight: 900;
}

.order-top small {
    color: #64748b;
    display: block;
    margin-top: 2px;
}

.order-body {
    align-items: center;
    background: #f8fafc;
    border-radius: 14px;
    display: flex;
    gap: 18px;
    padding: 14px;
}

.product-preview {
    display: flex;
    min-width: 74px;
    padding-left: 8px;
}

.product-preview img,
.product-preview span {
    align-items: center;
    background: #fff;
    border: 2px solid #f8fafc;
    border-radius: 8px;
    box-shadow: 0 6px 14px rgba(15, 23, 42, 0.08);
    color: #6f42c1;
    display: inline-flex;
    font-size: 0.8rem;
    font-weight: 900;
    height: 40px;
    justify-content: center;
    margin-left: -8px;
    object-fit: cover;
    width: 40px;
}

.order-info {
    display: grid;
    gap: 2px;
}

.order-info strong {
    color: #0f172a;
}

.order-info span,
.order-bottom span {
    color: #64748b;
    font-size: 0.9rem;
}

.order-bottom > div {
    display: grid;
    gap: 2px;
}

.order-bottom strong {
    color: #0f172a;
    font-size: 1.15rem;
    font-weight: 900;
}

.order-bottom .btn {
    border-radius: 13px !important;
    font-weight: 800;
    min-height: 42px;
    padding-inline: 16px;
}

.order-status-paid,
.order-status-processing {
    background: rgba(111, 66, 193, 0.1);
    color: #4c1d95;
}

.order-status-pending {
    background: rgba(229, 193, 66, 0.18);
    color: #7a4d00;
}

.order-status-delivered {
    background: rgba(25, 135, 84, 0.12);
    color: #198754;
}

.order-status-failed,
.order-status-cancelled {
    background: rgba(220, 53, 69, 0.1);
    color: #dc3545;
}

.account-orders-empty,
.order-filter-empty {
    background: #fff;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.05);
}

.account-addresses-page {
    gap: 18px;
}

.addresses-header .btn {
    border-radius: 14px;
    font-weight: 900;
    min-height: 46px;
    padding-inline: 18px;
}

.address-toast {
    align-items: center;
    background: rgba(25, 135, 84, 0.1);
    border: 1px solid rgba(25, 135, 84, 0.16);
    border-radius: 14px;
    color: #198754;
    display: inline-flex;
    font-weight: 900;
    gap: 8px;
    justify-self: start;
    padding: 10px 14px;
}

.address-toast::before {
    content: "✓";
    font-weight: 900;
}

.empty-address,
.address-card {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
}

.empty-address {
    align-items: center;
    border-radius: 20px;
    display: grid;
    justify-items: center;
    padding: 44px 24px;
    text-align: center;
}

.empty-address-icon,
.address-card-icon {
    align-items: center;
    background: rgba(111, 66, 193, 0.1);
    color: #6f42c1;
    display: inline-flex;
    justify-content: center;
}

.empty-address-icon {
    border-radius: 18px;
    height: 58px;
    margin-bottom: 16px;
    width: 58px;
}

.empty-address-icon .account-icon-svg {
    height: 28px;
    width: 28px;
}

.empty-address h2 {
    color: #0f172a;
    font-weight: 900;
    margin: 0;
}

.empty-address p {
    color: #64748b;
    margin: 8px auto 22px;
    max-width: 460px;
}

.empty-address .btn {
    border-radius: 14px;
    font-weight: 900;
    min-height: 44px;
    padding-inline: 18px;
}

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

.address-card {
    border-radius: 16px;
    display: grid;
    gap: 18px;
    min-height: 260px;
    padding: 18px;
    position: relative;
    transition: border-color 150ms ease, box-shadow 150ms ease, transform 150ms ease;
}

.address-card:hover {
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.09);
    transform: translateY(-2px);
}

.address-card.is-default {
    border: 2px solid #6f42c1;
    box-shadow: 0 18px 44px rgba(111, 66, 193, 0.12);
}

.address-card-top {
    align-items: flex-start;
    display: flex;
    gap: 12px;
    justify-content: space-between;
}

.address-card-icon {
    border-radius: 14px;
    flex: 0 0 42px;
    height: 42px;
    width: 42px;
}

.address-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    justify-content: flex-end;
}

.address-badge {
    border-radius: 999px;
    font-size: 0.74rem;
    font-weight: 900;
    padding: 5px 10px;
    white-space: nowrap;
}

.address-badge-type {
    background: rgba(15, 23, 42, 0.06);
    color: #334155;
}

.address-badge-default {
    background: rgba(111, 66, 193, 0.1);
    color: #4c1d95;
}

.address-card-body {
    display: grid;
    gap: 4px;
}

.address-card-body h2 {
    color: #0f172a;
    font-size: 1.12rem;
    font-weight: 900;
    margin: 0 0 4px;
}

.address-card-body p {
    color: #334155;
    margin: 0;
}

.address-card-body .address-muted {
    color: #64748b;
}

.address-card-actions {
    align-items: center;
    align-self: end;
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
}

.address-card-actions form {
    display: contents;
}

.address-card-actions .btn {
    border-radius: 13px;
    font-size: 0.88rem;
    font-weight: 900;
    min-height: 40px;
    padding-inline: 14px;
}

.address-delete-modal {
    box-shadow: 0 24px 70px rgba(15, 23, 42, 0.16);
}

.address-form-page {
    padding-bottom: 64px;
}

.address-form-header .btn {
    border-radius: 14px;
    font-weight: 900;
    min-height: 44px;
    padding-inline: 18px;
}

.address-form-card {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 20px;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.07);
    display: grid;
    gap: 0;
    overflow: hidden;
    padding: 28px 28px 0;
}

.address-form-error {
    background: rgba(220, 53, 69, 0.08);
    border: 1px solid rgba(220, 53, 69, 0.18);
    border-radius: 14px;
    color: #b02a37;
    font-weight: 800;
    margin-bottom: 20px;
    padding: 12px 14px;
}

.form-section {
    border-bottom: 1px solid rgba(15, 23, 42, 0.06);
    display: grid;
    gap: 10px;
    margin-bottom: 20px;
    padding-bottom: 20px;
}

.form-section:last-of-type {
    border-bottom: 0;
}

.form-section-title {
    color: #6c757d;
    font-size: 0.85rem;
    font-weight: 900;
    letter-spacing: 0.06em;
    margin: 0;
    text-transform: uppercase;
}

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

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

.address-field {
    display: grid;
    gap: 7px;
    min-width: 0;
}

.address-field-wide {
    grid-column: 1 / -1;
}

.address-country-field {
    min-width: 100px;
}

.address-row {
    align-items: start;
    display: grid;
    gap: 16px;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) 140px;
}

.form-field {
    align-self: start;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.form-field > span {
    min-height: 20px;
}

.form-field .form-control,
.form-field .form-select {
    height: 48px;
}

.form-field small {
    margin-top: 6px;
}

.address-field > span {
    color: #334155;
    font-size: 0.86rem;
    font-weight: 800;
}

.address-field > span em {
    color: #94a3b8;
    font-style: normal;
    font-weight: 700;
}

.address-field .form-control,
.address-field .form-select {
    border: 1px solid rgba(15, 23, 42, 0.1);
    border-radius: 14px;
    color: #0f172a;
    min-height: 48px;
    padding: 0 16px;
    transition: background 150ms ease, border-color 150ms ease, box-shadow 150ms ease;
}

.address-field .form-control::placeholder {
    color: #adb5bd;
}

.address-field .form-control:focus,
.address-field .form-select:focus {
    border-color: #6f42c1;
    box-shadow: 0 0 0 4px rgba(111, 66, 193, 0.12);
}

.address-field .form-control.is-filled,
.address-field .form-select.is-filled {
    background: rgba(15, 23, 42, 0.025);
}

.address-field .form-control.is-invalid,
.address-field .form-select.is-invalid {
    border-color: #dc3545;
    box-shadow: 0 0 0 4px rgba(220, 53, 69, 0.08);
}

.address-field .form-control.is-valid,
.address-field .form-select.is-valid {
    border-color: #28a745;
}

.address-field small {
    color: #6c757d;
    font-size: 0.76rem;
    line-height: 1.35;
}

.address-field .helper-text {
    color: #6c757d;
    font-size: 0.75rem;
}

.address-field .error-text {
    color: #dc3545;
    font-weight: 700;
}

.address-default-toggle {
    align-items: center;
    background: #f8fafc;
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 16px;
    cursor: pointer;
    display: flex;
    gap: 12px;
    padding: 13px 14px;
    transition: background 150ms ease, border-color 150ms ease, box-shadow 150ms ease, transform 150ms ease;
}

.address-default-toggle:hover {
    background: rgba(111, 66, 193, 0.04);
    border-color: rgba(111, 66, 193, 0.18);
    box-shadow: 0 10px 24px rgba(111, 66, 193, 0.06);
}

.address-default-toggle .form-check-input {
    border-color: rgba(111, 66, 193, 0.35);
    flex: 0 0 auto;
    height: 22px;
    margin: 0;
    width: 42px;
}

.address-default-toggle .form-check-input:checked {
    background-color: #6f42c1;
    border-color: #6f42c1;
}

.address-default-toggle span {
    display: grid;
    gap: 2px;
}

.address-default-toggle strong {
    color: #0f172a;
    font-size: 0.9rem;
}

.address-default-toggle small {
    color: #64748b;
    font-size: 0.78rem;
}

.form-actions {
    align-items: center;
    background: #fff;
    border-top: 1px solid rgba(0, 0, 0, 0.05);
    bottom: 0;
    display: flex;
    gap: 12px;
    justify-content: space-between;
    margin: 0 -28px;
    padding: 14px 28px;
    position: sticky;
    z-index: 5;
}

.form-actions .btn {
    border-radius: 14px;
    font-weight: 900;
    min-height: 46px;
    padding-inline: 20px;
}

.form-actions .btn:disabled {
    opacity: 0.7;
}

.profile-settings-page {
    gap: 18px;
}

.profile-toast,
.profile-error {
    border-radius: 14px;
    font-weight: 900;
    justify-self: start;
    padding: 10px 14px;
}

.profile-toast {
    background: rgba(25, 135, 84, 0.1);
    border: 1px solid rgba(25, 135, 84, 0.16);
    color: #198754;
}

.profile-toast::before {
    content: "✓ ";
}

.profile-error {
    background: rgba(220, 53, 69, 0.08);
    border: 1px solid rgba(220, 53, 69, 0.18);
    color: #b02a37;
}

.profile-hero,
.profile-form-card,
.profile-action-card,
.profile-account-card {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
}

.profile-hero {
    align-items: center;
    border-radius: 20px;
    display: grid;
    gap: 18px;
    grid-template-columns: 76px minmax(0, 1fr);
    padding: 26px;
}

.profile-avatar {
    align-items: center;
    background: linear-gradient(135deg, #6f42c1, #4865ee);
    border-radius: 999px;
    color: #fff;
    display: inline-flex;
    font-size: 1.15rem;
    font-weight: 900;
    height: 64px;
    justify-content: center;
    width: 64px;
}

.profile-hero h1 {
    color: #0f172a;
    font-size: clamp(1.7rem, 3vw, 2.3rem);
    font-weight: 900;
    margin: 0;
}

.profile-hero p:not(.account-eyebrow) {
    color: #64748b;
    margin: 4px 0 0;
}

.profile-hero .btn {
    border-radius: 14px;
    font-weight: 900;
    min-height: 42px;
}

.profile-form-card {
    border-radius: 20px;
    overflow: hidden;
    padding: 28px 28px 0;
}

.profile-section {
    border-bottom: 1px solid rgba(15, 23, 42, 0.06);
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(180px, 0.42fr) minmax(0, 1fr);
    padding: 0 0 24px;
    margin-bottom: 24px;
}

.profile-section > div:first-child p {
    color: #64748b;
    margin: 7px 0 0;
}

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

.profile-field {
    display: grid;
    gap: 7px;
    min-width: 0;
}

.profile-field-wide {
    grid-column: 1 / -1;
}

.profile-field > span:first-child {
    color: #334155;
    font-size: 0.86rem;
    font-weight: 800;
}

.profile-field em {
    color: #94a3b8;
    font-style: normal;
    font-weight: 700;
}

.profile-field .form-control {
    border: 1px solid rgba(15, 23, 42, 0.1);
    border-radius: 14px;
    min-height: 48px;
    padding: 0 16px;
    transition: background 150ms ease, border-color 150ms ease, box-shadow 150ms ease;
}

.profile-field .form-control:focus {
    border-color: #6f42c1;
    box-shadow: 0 0 0 4px rgba(111, 66, 193, 0.12);
}

.profile-field .form-control.is-filled {
    background: rgba(15, 23, 42, 0.025);
}

.profile-field .form-control.is-valid {
    border-color: #28a745;
}

.profile-field .form-control.is-invalid {
    border-color: #dc3545;
    box-shadow: 0 0 0 4px rgba(220, 53, 69, 0.08);
}

.profile-field .error-text {
    color: #dc3545;
    font-size: 0.76rem;
    font-weight: 700;
}

.profile-password-wrap {
    display: block;
    position: relative;
}

.password-row {
    align-items: start;
    display: grid;
    gap: 16px;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.password-row .form-field {
    align-self: start;
}

.password-row .form-field > span:first-child {
    min-height: 20px;
}

.password-row .password-input-wrap,
.password-row .form-control {
    height: 48px;
}

.password-row .profile-strength,
.password-row small {
    margin-top: 6px;
}

.profile-password-wrap .form-control {
    padding-right: 48px;
    width: 100%;
}

.profile-password-toggle {
    align-items: center;
    background: rgba(15, 23, 42, 0.04);
    border: 0;
    border-radius: 10px;
    color: #64748b;
    display: inline-flex;
    height: 34px;
    justify-content: center;
    position: absolute;
    right: 7px;
    top: 7px;
    transition: background 150ms ease, color 150ms ease;
    width: 34px;
}

.profile-password-toggle i {
    line-height: 1;
}

.profile-password-toggle:hover {
    background: rgba(111, 66, 193, 0.1);
    color: #6f42c1;
}

.profile-strength {
    background: rgba(15, 23, 42, 0.06);
    border-radius: 999px;
    display: block;
    height: 4px;
    overflow: hidden;
}

.profile-strength i {
    background: #adb5bd;
    display: block;
    height: 100%;
    transition: background 180ms ease, width 180ms ease;
    width: 0;
}

.profile-strength[data-strength="zwak"] i {
    background: #dc3545;
    width: 34%;
}

.profile-strength[data-strength="goed"] i {
    background: #e5c142;
    width: 68%;
}

.profile-strength[data-strength="sterk"] i {
    background: #198754;
    width: 100%;
}

.profile-strength-text {
    color: #64748b;
    font-size: 0.76rem;
    font-weight: 800;
}

.profile-form-actions {
    align-items: center;
    background: #fff;
    border-top: 1px solid rgba(0, 0, 0, 0.05);
    bottom: 0;
    display: flex;
    gap: 12px;
    justify-content: space-between;
    margin: 0 -28px;
    padding: 14px 28px;
    position: sticky;
    z-index: 5;
}

.profile-form-actions .btn {
    border-radius: 14px;
    font-weight: 900;
    min-height: 46px;
    padding-inline: 20px;
}

.profile-form-actions .heroics-btn:hover {
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.12);
    transform: translateY(-1px);
}

.profile-actions-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.profile-action-card,
.profile-account-card {
    border-radius: 18px;
    padding: 20px;
}

.profile-action-card {
    color: #0f172a;
    display: grid;
    gap: 8px;
    text-decoration: none;
    transition: box-shadow 150ms ease, transform 150ms ease;
}

.profile-action-card:hover,
.profile-account-card:hover {
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.09);
    transform: translateY(-2px);
}

.profile-action-icon {
    align-items: center;
    background: rgba(111, 66, 193, 0.1);
    border-radius: 14px;
    color: #6f42c1;
    display: inline-flex;
    height: 42px;
    justify-content: center;
    width: 42px;
}

.profile-action-card strong,
.profile-account-card h2 {
    color: #0f172a;
    font-size: 1.08rem;
    font-weight: 900;
}

.profile-action-card small {
    color: #64748b;
}

.profile-account-card {
    border-color: rgba(220, 53, 69, 0.16);
    display: grid;
    gap: 12px;
}

.profile-account-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.profile-account-actions .btn {
    border-radius: 13px;
    font-weight: 900;
}

.profile-delete-modal {
    box-shadow: 0 24px 70px rgba(15, 23, 42, 0.16);
}

.account-returns-page {
    gap: 18px;
}

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

.returns-start-card {
    align-items: flex-end;
    display: grid;
    gap: 8px;
    justify-items: end;
    min-width: 220px;
}

.returns-start-card .btn {
    border-radius: 14px;
    font-weight: 900;
    min-height: 46px;
    padding-inline: 18px;
}

.returns-start-card small {
    color: #64748b;
    line-height: 1.35;
    max-width: 260px;
    text-align: right;
}

.empty-return-state,
.return-card,
.return-flow-card,
.return-conditions-card {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
}

.empty-return-state {
    align-items: center;
    border-radius: 20px;
    display: grid;
    justify-items: center;
    padding: 42px 24px;
    text-align: center;
}

.empty-return-icon {
    align-items: center;
    background: rgba(111, 66, 193, 0.1);
    border-radius: 18px;
    color: #6f42c1;
    display: inline-flex;
    height: 58px;
    justify-content: center;
    margin-bottom: 16px;
    width: 58px;
}

.empty-return-icon .account-icon-svg {
    height: 28px;
    width: 28px;
}

.empty-return-state h2,
.return-flow-card h2,
.return-conditions-card h2 {
    color: #0f172a;
    font-weight: 900;
    margin: 0;
}

.empty-return-state p {
    color: #64748b;
    margin: 8px auto 0;
    max-width: 560px;
}

.empty-return-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: center;
    margin-top: 22px;
}

.empty-return-actions .btn {
    border-radius: 14px;
    font-weight: 900;
    min-height: 44px;
    padding-inline: 18px;
}

.return-list {
    display: grid;
    gap: 16px;
}

.return-card {
    border-radius: 16px;
    display: grid;
    gap: 16px;
    padding: 18px;
    transition: box-shadow 150ms ease, transform 150ms ease;
}

.return-card:hover {
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.09);
    transform: translateY(-2px);
}

.return-card-top,
.return-card-bottom {
    align-items: center;
    display: flex;
    gap: 16px;
    justify-content: space-between;
}

.return-card-top strong {
    color: #0f172a;
    display: block;
    font-weight: 900;
}

.return-card-top small,
.return-card-bottom span {
    color: #64748b;
}

.return-card-body {
    background: #f8fafc;
    border-radius: 14px;
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    padding: 14px;
}

.return-card-body div {
    display: grid;
    gap: 3px;
}

.return-card-body span {
    color: #64748b;
    font-size: 0.84rem;
}

.return-card-body strong {
    color: #0f172a;
    font-weight: 900;
}

.return-card-bottom .btn {
    border-radius: 13px;
    font-weight: 900;
    min-height: 42px;
    padding-inline: 16px;
    white-space: nowrap;
}

.return-status {
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 900;
    padding: 5px 11px;
    white-space: nowrap;
}

.return-status-requested {
    background: rgba(111, 66, 193, 0.1);
    color: #4c1d95;
}

.return-status-approved {
    background: rgba(72, 101, 238, 0.12);
    color: #3047b5;
}

.return-status-received {
    background: rgba(229, 193, 66, 0.18);
    color: #7a4d00;
}

.return-status-refunded {
    background: rgba(25, 135, 84, 0.12);
    color: #198754;
}

.return-status-rejected {
    background: rgba(220, 53, 69, 0.1);
    color: #dc3545;
}

.return-status-closed {
    background: rgba(100, 116, 139, 0.12);
    color: #475569;
}

.return-flow-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.return-flow-card {
    border-radius: 16px;
    padding: 18px;
}

.return-flow-card span {
    align-items: center;
    background: linear-gradient(135deg, #6f42c1, #8a5cf6);
    border-radius: 12px;
    color: #fff;
    display: inline-flex;
    font-weight: 900;
    height: 34px;
    justify-content: center;
    margin-bottom: 14px;
    width: 34px;
}

.return-flow-card h2,
.return-conditions-card h2 {
    font-size: 1.05rem;
}

.return-flow-card p {
    color: #64748b;
    margin: 8px 0 0;
}

.return-conditions-card {
    align-items: start;
    border-radius: 18px;
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
    padding: 22px;
}

.return-conditions-card ul {
    display: grid;
    gap: 9px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.return-conditions-card li {
    align-items: center;
    color: #475569;
    display: flex;
    gap: 9px;
}

.return-conditions-card li::before {
    background: rgba(25, 135, 84, 0.12);
    border-radius: 999px;
    color: #198754;
    content: "✓";
    display: inline-flex;
    flex: 0 0 22px;
    font-size: 0.8rem;
    font-weight: 900;
    height: 22px;
    justify-content: center;
    width: 22px;
}

.return-create-content {
    gap: 24px;
}

.return-create-form {
    display: grid;
    gap: 24px;
}

.return-form-error,
.return-form-message {
    background: rgba(220, 53, 69, 0.08);
    border: 1px solid rgba(220, 53, 69, 0.18);
    border-radius: 14px;
    color: #b02a37;
    font-weight: 900;
    padding: 12px 14px;
}

.return-toast {
    align-items: center;
    background: rgba(25, 135, 84, 0.08);
    border: 1px solid rgba(25, 135, 84, 0.16);
    border-radius: 16px;
    color: #146c43;
    display: flex;
    font-weight: 900;
    gap: 9px;
    padding: 13px 15px;
}

.return-toast::before {
    color: #198754;
    content: "✓";
    font-weight: 900;
}

.return-toast-error {
    background: rgba(220, 53, 69, 0.08);
    border-color: rgba(220, 53, 69, 0.18);
    color: #b02a37;
}

.return-toast-error::before {
    color: #dc3545;
    content: "!";
}

.return-create-header,
.return-guidance,
.return-create-panel,
.return-form-actions {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
}

.return-create-header {
    align-items: center;
    border-radius: 20px;
    display: flex;
    gap: 20px;
    justify-content: space-between;
    padding: 24px;
}

.return-create-header h1 {
    color: #0f172a;
    font-weight: 900;
    margin: 0;
}

.return-create-header p:not(.account-eyebrow) {
    color: #64748b;
    margin: 6px 0 0;
}

.return-order-summary {
    background: #f8fafc;
    border-radius: 16px;
    display: grid;
    gap: 3px;
    min-width: 230px;
    padding: 14px 16px;
    text-align: right;
}

.return-order-summary span,
.return-order-summary small {
    color: #64748b;
}

.return-order-summary strong {
    color: #0f172a;
    font-size: 1.25rem;
    font-weight: 900;
}

.return-guidance {
    border-radius: 18px;
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    padding: 16px;
}

.return-guidance div {
    align-items: center;
    background: #f8fafc;
    border-radius: 14px;
    display: flex;
    gap: 10px;
    padding: 12px;
}

.return-guidance span {
    align-items: center;
    background: linear-gradient(135deg, #6f42c1, #8a5cf6);
    border-radius: 999px;
    color: #fff;
    display: inline-flex;
    font-weight: 900;
    height: 30px;
    justify-content: center;
    width: 30px;
}

.return-guidance strong {
    color: #0f172a;
    font-weight: 900;
}

.return-create-panel {
    border-radius: 20px;
    padding: 26px;
}

.return-items-list {
    display: grid;
    gap: 18px;
}

.product-return-item {
    align-items: center;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.07);
    border-radius: 14px;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.05);
    display: grid;
    gap: 14px;
    grid-template-columns: 72px minmax(0, 1fr) auto;
    padding: 14px;
    transition: border-color 150ms ease, box-shadow 150ms ease, transform 150ms ease;
}

.product-return-item.is-selected {
    border-color: rgba(111, 66, 193, 0.45);
    box-shadow: 0 16px 36px rgba(111, 66, 193, 0.1);
}

.product-return-item:hover {
    transform: translateY(-1px);
}

.product-return-item img,
.return-item-thumb {
    align-items: center;
    background: #f8fafc;
    border-radius: 12px;
    color: #6f42c1;
    display: inline-flex;
    font-weight: 900;
    height: 72px;
    justify-content: center;
    object-fit: cover;
    width: 72px;
}

.return-item-info {
    display: grid;
    gap: 3px;
}

.return-item-info strong {
    color: #0f172a;
    font-weight: 900;
}

.return-item-info small,
.return-item-info span,
.return-item-info em {
    color: #64748b;
    font-size: 0.88rem;
    font-style: normal;
}

.return-item-stepper {
    display: grid;
    gap: 7px;
    justify-items: end;
}

.return-item-stepper label {
    color: #64748b;
    font-size: 0.78rem;
    font-weight: 900;
}

.quantity-stepper {
    align-items: center;
    background: rgba(15, 23, 42, 0.04);
    border-radius: 14px;
    display: flex;
    gap: 6px;
    padding: 4px;
}

.quantity-stepper button {
    align-items: center;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 10px;
    color: #0f172a;
    display: inline-flex;
    font-weight: 900;
    height: 34px;
    justify-content: center;
    transition: background 150ms ease, color 150ms ease, transform 150ms ease;
    width: 34px;
}

.quantity-stepper button:not(:disabled):hover {
    background: #6f42c1;
    color: #fff;
    transform: translateY(-1px);
}

.quantity-stepper button:disabled {
    cursor: not-allowed;
    opacity: 0.45;
}

.quantity-stepper input {
    background: transparent;
    border: 0;
    color: #0f172a;
    font-weight: 700;
    height: 34px;
    text-align: center;
    width: 34px;
}

.return-qty-input::-webkit-outer-spin-button,
.return-qty-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.return-qty-input[type="number"] {
    -moz-appearance: textfield;
}

.return-qty-input:focus {
    outline: 0;
}

.return-reason-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: minmax(0, 1fr);
}

.return-field {
    display: grid;
    gap: 7px;
}

.return-field span {
    color: #334155;
    font-size: 0.86rem;
    font-weight: 900;
}

.return-field em {
    color: #94a3b8;
    font-style: normal;
}

.return-field .form-select,
.return-field .form-control {
    border: 1px solid rgba(15, 23, 42, 0.1);
    border-radius: 14px;
    min-height: 48px;
    padding: 0 16px;
}

.return-field textarea.form-control {
    min-height: 112px;
    padding-top: 13px;
}

.return-field .form-select:focus,
.return-field .form-control:focus {
    border-color: #6f42c1;
    box-shadow: 0 0 0 4px rgba(111, 66, 193, 0.12);
}

.return-form-actions {
    align-items: center;
    border-radius: 18px 18px 0 0;
    bottom: 0;
    display: flex;
    gap: 16px;
    justify-content: space-between;
    padding: 14px 18px calc(14px + env(safe-area-inset-bottom));
    position: sticky;
    z-index: 8;
}

.return-form-actions > div {
    align-items: end;
    display: grid;
    gap: 7px;
    justify-items: end;
}

.return-form-actions .btn {
    border-radius: 14px;
    font-weight: 900;
    min-height: 48px;
    padding-inline: 18px;
}

.return-trust {
    color: #64748b;
    display: flex;
    flex-wrap: wrap;
    font-size: 0.78rem;
    font-weight: 800;
    gap: 10px;
    justify-content: flex-end;
    list-style: none;
    margin: 0;
    padding: 0;
}

.return-trust li::before {
    color: #198754;
    content: "✓ ";
}

.order-detail-page {
    gap: 20px;
}

.order-detail-header {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 20px;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
    padding: 24px;
}

.order-back-link {
    color: #6f42c1;
    display: inline-block;
    font-weight: 900;
    margin-bottom: 16px;
    text-decoration: none;
}

.order-detail-heading {
    align-items: end;
    display: flex;
    gap: 18px;
    justify-content: space-between;
}

.order-detail-heading h1 {
    color: #0f172a;
    font-weight: 900;
    margin: 0;
}

.order-detail-heading p {
    color: #64748b;
    margin: 8px 0 0;
}

.order-detail-total {
    display: grid;
    gap: 6px;
    justify-items: end;
}

.order-detail-total span {
    color: #64748b;
    font-weight: 800;
}

.order-detail-total strong {
    color: #0f172a;
    font-size: 1.55rem;
    font-weight: 900;
}

.order-detail-total em {
    font-style: normal;
}

.order-timeline {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 18px;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.05);
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(5, minmax(150px, 1fr));
    overflow-x: auto;
    padding: 18px;
}

.timeline-step {
    color: #94a3b8;
    display: grid;
    gap: 8px;
    min-width: 150px;
    position: relative;
}

.timeline-step span {
    background: #e2e8f0;
    border-radius: 999px;
    height: 10px;
    width: 100%;
}

.timeline-step strong {
    font-size: 0.86rem;
}

.timeline-step small {
    color: #dc3545;
    font-size: 0.78rem;
    font-weight: 800;
}

.timeline-step.is-complete {
    color: #198754;
}

.timeline-step.is-complete span {
    background: #198754;
}

.timeline-step.is-active {
    color: #6f42c1;
}

.timeline-step.is-active span {
    background: linear-gradient(135deg, #6f42c1, #e5c142);
}

.timeline-step.is-failed {
    color: #dc3545;
}

.timeline-step.is-failed span {
    background: #dc3545;
}

.order-detail-grid {
    align-items: start;
    display: grid;
    gap: 22px;
    grid-template-columns: minmax(0, 1fr) 340px;
}

.order-detail-main,
.order-detail-side {
    display: grid;
    gap: 18px;
    min-width: 0;
}

.order-detail-items {
    display: grid;
    gap: 12px;
}

.order-detail-item {
    align-items: center;
    background: #f8fafc;
    border: 1px solid rgba(15, 23, 42, 0.05);
    border-radius: 15px;
    display: grid;
    gap: 14px;
    grid-template-columns: 64px minmax(0, 1fr) auto;
    padding: 12px;
}

.order-detail-item img,
.order-detail-item-thumb {
    align-items: center;
    background: #fff;
    border-radius: 12px;
    color: #6f42c1;
    display: inline-flex;
    font-weight: 900;
    height: 64px;
    justify-content: center;
    object-fit: cover;
    width: 64px;
}

.order-detail-item div {
    display: grid;
    gap: 3px;
}

.order-detail-item strong {
    color: #0f172a;
}

.order-detail-item small,
.order-detail-item span {
    color: #64748b;
}

.order-address-card address {
    color: #475569;
    display: grid;
    gap: 5px;
    margin: 0;
}

.order-address-card strong {
    color: #0f172a;
}

.order-status-card,
.order-totals-card,
.order-actions-card {
    display: grid;
    gap: 12px;
}

.order-status-card h2,
.order-totals-card h2,
.order-actions-card h2 {
    font-size: 1.1rem;
    font-weight: 900;
    margin: 0 0 4px;
}

.order-status-card div,
.order-totals-card div {
    align-items: center;
    display: flex;
    gap: 12px;
    justify-content: space-between;
}

.order-status-card div span,
.order-totals-card div span {
    color: #64748b;
}

.order-total-row {
    border-top: 1px solid rgba(15, 23, 42, 0.08);
    margin-top: 4px;
    padding-top: 12px;
}

.order-total-row strong {
    font-size: 1.35rem;
    font-weight: 900;
}

.order-actions-card .btn {
    border-radius: 13px !important;
    font-weight: 800;
    min-height: 44px;
}


.btn {
    font-family: var(--heroics-body-font);
    font-weight: 500;
}

.btn-primary {
    letter-spacing: 0.5px;
}

@media (max-width: 575.98px) {
    .heroics-hero .display-4 {
        font-size: 2.4rem;
    }

    .filter-bar,
    .filter-bar .form-select,
    .filter-bar .btn {
        width: 100%;
    }
}

@media (max-width: 991.98px) {
    .heroics-latest-products-carousel .owl-nav {
        inset: 50% 8px auto 8px;
    }

    .heroics-footer-newsletter {
        max-width: none;
    }

    .heroics-promo-carousel .owl-item {
        min-height: auto;
    }

    .heroics-promo-slide {
        min-height: auto;
    }

    .heroics-feature-card {
        height: auto;
        max-height: none;
        min-height: auto;
    }

    .hero-featured-product-panel .heroics-product-card {
        min-height: auto;
    }

    .hero-featured-product-panel .heroics-product-image {
        width: 100%;
    }

    .heroics-feature-carousel,
    .heroics-feature-carousel .owl-stage-outer,
    .heroics-feature-carousel .owl-stage,
    .heroics-feature-carousel .owl-item {
        height: auto;
        max-height: none;
    }

    .heroics-feature-image {
        aspect-ratio: auto;
        height: 240px;
        max-height: 240px;
        min-height: 240px;
    }

    .heroics-promo-carousel .owl-dots {
        bottom: auto;
        padding: 0 1.5rem 1.5rem;
        position: static;
        right: auto;
    }

    .heroics-promo-bg {
        background-image: linear-gradient(rgba(47, 22, 61, .05), rgba(47, 22, 61, .05)), var(--heroics-slide-mobile, var(--heroics-slide-desktop));
        clip-path: none;
        opacity: 0.22;
        width: 100%;
    }

    .heroics-promo-content {
        max-width: 100%;
    }

    .heroics-product-body,
    .heroics-product-card:hover .heroics-product-body {
        transform: none;
    }

    .heroics-product-image-link {
        display: block;
        height: 220px;
        overflow: hidden;
    }

    .product-card-actions,
    .heroics-product-cta.product-card-actions {
        background: none;
        margin-top: 12px !important;
        opacity: 1;
        overflow: visible;
        pointer-events: auto;
        position: static;
        transform: none;
    }

    .heroics-product-body,
    .heroics-product-card.is-sold-out .heroics-product-body {
        margin-bottom: 0;
        padding: 14px;
        transform: none !important;
    }

    .heroics-product-card .product-card-add {
        min-height: 44px;
    }

    .heroics-editorial-card {
        max-height: none;
        min-height: auto;
    }

    .heroics-editorial-label {
        left: auto;
        margin-bottom: 1.5rem;
        min-width: 0;
        position: static;
        top: auto;
        transform: none;
    }

    .heroics-editorial-carousel {
        height: 260px;
        transform: none;
    }

    .featured-carousel {
        min-height: 0;
    }

    .featured-carousel__label {
        left: 1.25rem;
        padding: 0.9rem 1.1rem;
    }

    .featured-carousel__slide {
        grid-template-columns: 1fr;
        min-height: auto;
        padding: 5rem 1.5rem 5.25rem;
    }

    .featured-carousel__content {
        max-width: none;
    }

    .featured-carousel__title {
        font-size: clamp(2rem, 10vw, 3rem);
        -webkit-line-clamp: 3;
        max-width: 100%;
    }

    .featured-carousel__media img {
        max-height: 320px;
    }

    .featured-carousel__arrow--prev,
    .featured-carousel__arrow--next {
        bottom: 1rem;
        top: auto;
        transform: none;
    }

    .featured-carousel__arrow--prev {
        left: 12px;
    }

    .featured-carousel__arrow--next {
        right: 12px;
    }

    .featured-carousel__arrow:hover,
    .featured-carousel__arrow:focus-visible {
        transform: translateY(-1px);
    }

    .featured-carousel__dots {
        bottom: 1.95rem;
    }

    .heroics-navbar-logo {
        max-height: 38px;
        width: 135px;
    }

    .buy-box {
        position: static;
    }
}

@media (max-width: 575.98px) {
    .heroics-feature-image {
        height: 220px;
        max-height: 220px;
        min-height: 220px;
    }

    .heroics-feature-title {
        max-width: none;
    }

    .heroics-floating-cart {
        bottom: 16px;
        height: 52px;
        right: 16px;
        width: 52px;
    }

}

@media (prefers-reduced-motion: reduce) {
    .heroics-floating-cart,
    .heroics-floating-cart-count {
        animation: none !important;
        transition: none !important;
    }
}

@media (max-width: 575.98px) {
    .product-meta {
        gap: 7px 9px;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        padding: 9px 10px;
    }

    .product-meta dt {
        font-size: .62rem;
    }

    .product-meta dd {
        font-size: .78rem;
    }

    .product-info-tabs {
        max-width: 100%;
        overflow: hidden;
        padding: 22px;
    }

    .product-tab-list {
        max-width: 100%;
        overflow-x: auto;
        overscroll-behavior-x: contain;
    }

    .product-tab-list button {
        flex: 0 0 auto;
        white-space: nowrap;
    }

    .product-tab-layout {
        gap: 18px;
        grid-template-columns: minmax(0, 1fr);
    }

    .product-tab-side,
    .product-quick-info,
    .product-details-list,
    .product-details-list li,
    .product-quick-info div {
        min-width: 0;
        max-width: 100%;
    }

    .product-details-list li,
    .product-quick-info div {
        align-items: start;
        display: grid;
        grid-template-columns: minmax(0, 1fr);
        justify-content: start;
    }

    .product-details-list strong,
    .product-quick-info dd {
        text-align: left;
    }

    .product-review-summary {
        display: flex;
        margin-bottom: 14px;
        width: 100%;
    }

    .product-review-card,
    .product-review-form {
        padding: 13px;
    }

    .product-review-form textarea.form-control {
        min-height: 84px;
    }
}

@media (max-width: 767.98px) {
    .product-trust-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .product-trust-list div {
        padding: 10px;
    }
}

@media (max-width: 380px) {
    .product-trust-list {
        grid-template-columns: minmax(0, 1fr);
    }
}

.owl-carousel,
.owl-stage-outer {
    max-width: 100%;
    overflow: hidden;
}

.homepage-product-mobile-grid {
    display: none;
}

.heroics-feature-carousel .owl-item > .heroics-product-card {
    min-width: 100%;
    width: 100%;
}

@media (max-width: 991.98px) {
    .homepage-block-header-cta {
        display: none !important;
    }

    .heroics-home-products .heroics-latest-products-carousel,
    .heroics-feature-showcase .heroics-latest-products-carousel,
    .heroics-home-products .homepage-product-desktop-grid,
    .heroics-feature-showcase .featured-drops__grid {
        display: none !important;
    }

    .homepage-mobile-carousel {
        display: flex;
        gap: 12px;
        margin-bottom: 24px;
        max-width: 100%;
        overflow-x: auto;
        overflow-y: hidden;
        padding-bottom: 2px;
        scroll-padding-left: 0;
        scroll-snap-type: x mandatory;
        scrollbar-width: none;
        -webkit-overflow-scrolling: touch;
    }

    .homepage-mobile-carousel::-webkit-scrollbar {
        display: none;
    }

    .homepage-mobile-carousel > .heroics-product-card,
    .homepage-mobile-carousel > .homepage-product-mobile-cta {
        flex: 0 0 calc(50% - 6px);
        max-width: calc(50% - 6px);
        min-width: 0;
        scroll-snap-align: start;
        width: auto;
    }

    .homepage-category-products-mobile-carousel {
        align-items: stretch;
        display: flex !important;
        gap: 12px;
        grid-template-columns: none !important;
        overflow-x: auto;
        overflow-y: hidden;
        scroll-snap-type: x mandatory;
    }

    .homepage-category-products-mobile-carousel > .heroics-product-card,
    .homepage-category-products-mobile-carousel > .homepage-product-mobile-cta {
        display: flex;
        flex: 0 0 calc(50% - 6px) !important;
        max-width: calc(50% - 6px) !important;
        min-width: 0 !important;
        scroll-snap-align: start;
        width: auto !important;
    }

    .homepage-mobile-carousel-dots {
        align-items: center;
        display: flex;
        gap: 7px;
        justify-content: center;
        margin: 12px 0 20px !important;
    }

    .homepage-mobile-carousel-dots button {
        background: transparent;
        border: 0;
        border-radius: 999px;
        margin: 0;
        padding: 0;
    }

    .homepage-mobile-carousel-dots span {
        background: rgba(91, 47, 144, .22) !important;
        border-radius: 999px;
        display: block;
        height: 7px !important;
        margin: 0 !important;
        transition: background .18s ease, width .18s ease;
        width: 7px !important;
    }

    .homepage-mobile-carousel-dots button.is-active span {
        background: #5b2f90 !important;
        width: 22px !important;
    }

    .homepage-mobile-carousel .homepage-product-mobile-cta {
        min-height: 100%;
    }
}

@media (min-width: 992px) {
    .heroics-footer-newsletter {
        margin-top: 6px;
    }
}

@media (max-width: 767.98px) {
    :root {
        --homepage-section-spacing: 24px;
    }

    .homepage-hero-block {
        padding-block: 18px calc(var(--homepage-section-spacing) * .7);
    }

    .homepage-hero-block + .homepage-block {
        margin-top: 0;
    }

    .homepage-block {
        padding-block: var(--homepage-section-spacing);
    }

    .homepage-block + .homepage-block .heroics-section-title,
    .homepage-block + .homepage-block .featured-drops__eyebrow {
        margin-top: 24px;
    }

    .homepage-block:last-of-type {
        margin-bottom: 32px;
    }

    .homepage-block-featured_products {
        padding-top: 8px;
    }

    .homepage-block-newest_products {
        padding-bottom: 8px;
    }

    .homepage-block-newest_products + .homepage-block-featured_products {
        padding-top: 0;
    }

    .heroics-home-products .d-flex.justify-content-between,
    .heroics-feature-showcase .section-header,
    .section-header {
        margin-bottom: 16px;
    }

    .heroics-promo-mask {
        position: relative;
    }

    .heroics-promo-carousel .owl-dots {
        align-items: center;
        bottom: 12px;
        display: flex;
        gap: 7px;
        justify-content: center;
        left: 50%;
        margin: 0 !important;
        padding: 0;
        position: absolute;
        right: auto;
        transform: translateX(-50%);
        width: auto;
    }

    .heroics-promo-carousel .owl-dot span {
        border-radius: 999px;
        height: 7px !important;
        min-height: 7px;
        min-width: 7px;
        overflow: hidden;
        padding: 0;
        text-indent: -9999px;
        width: 7px !important;
    }

    .heroics-promo-carousel .owl-dot span::before {
        content: none !important;
    }

    .heroics-promo-carousel .owl-dot.active span {
        width: 22px !important;
    }

    .heroics-home-products .heroics-latest-products-carousel,
    .heroics-feature-showcase .heroics-latest-products-carousel {
        display: none !important;
    }

    .homepage-product-mobile-grid:not(.homepage-mobile-carousel) {
        display: none;
    }

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

    .homepage-category-grid.is-carousel {
        display: grid;
        overflow: visible;
        padding-bottom: 0;
        scroll-snap-type: none;
    }

    .homepage-category-grid.is-carousel .homepage-category-card {
        flex: initial;
    }

    .homepage-category-grid:not(.homepage-mobile-carousel) .homepage-category-card:nth-of-type(n+4) {
        display: none;
    }

    .homepage-category-grid:not(.homepage-mobile-carousel) .homepage-category-cta {
        display: flex;
    }

    .homepage-category-card {
        border-radius: 16px;
    }

    .homepage-category-card__body {
        padding: 12px;
    }

    .homepage-category-card__body strong {
        font-size: .9rem;
    }

    .homepage-category-card__body small {
        font-size: .78rem;
    }

    .heroics-home-seo__shell {
        border-radius: 24px;
        gap: 18px;
        grid-template-columns: minmax(0, 1fr);
        padding: 22px;
    }

    .heroics-home-seo__content h2 {
        font-size: 1.45rem;
    }

    .heroics-home-seo__lead,
    .heroics-home-seo__richtext {
        font-size: .95rem;
    }

    .heroics-home-seo__trust {
        gap: 10px;
    }

    .heroics-home-seo__trust article {
        border-radius: 18px;
        padding: 14px;
    }

    .featured-drops {
        border-radius: 24px;
        padding: 18px;
    }

    .featured-drops__header {
        align-items: flex-start;
        flex-direction: column;
        margin-bottom: 16px;
    }

    .featured-drops__header > .btn {
        display: none;
    }

    .featured-drops__grid {
        display: none;
    }

    .featured-drops__mobile-grid:not(.homepage-mobile-carousel) {
        display: grid;
    }

    .featured-drops__footer {
        display: none;
    }

    .heroics-product-card:not(.is-sold-out) .heroics-product-body,
    .heroics-product-card:hover .heroics-product-body {
        margin-bottom: 0;
        transform: none !important;
    }

    .product-card-image,
    .product-card-media,
    .heroics-product-image {
        aspect-ratio: 1 / 1;
        background: #fff;
        border-radius: 18px 18px 0 0;
        height: auto;
        overflow: hidden;
        width: 100%;
    }

    .homepage-product-mobile-cta {
        align-items: flex-start;
        background:
            radial-gradient(circle at 80% 10%, rgba(245, 200, 47, 0.2), transparent 34%),
            linear-gradient(145deg, #4b1763 0%, #24102f 100%);
        border: 1px solid rgba(255, 255, 255, 0.12);
        border-radius: 18px;
        box-shadow: 0 18px 38px rgba(36, 16, 47, 0.18);
        color: #fff;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        min-height: 100%;
        min-width: 0;
        overflow: hidden;
        padding: 14px;
    }

    .homepage-product-mobile-cta span {
        color: #f5c82f;
        font-size: 0.68rem;
        font-weight: 800;
        letter-spacing: 0.04em;
        text-transform: uppercase;
    }

    .homepage-product-mobile-cta h3 {
        font-family: var(--heroics-title-font, inherit);
        font-size: 1rem;
        line-height: 1.12;
        margin: 8px 0 14px;
    }

    .homepage-product-mobile-cta .btn {
        align-self: stretch;
        border-radius: 10px;
        font-size: 0.72rem;
        min-height: 40px;
        padding-inline: 8px;
    }

    .product-card-image img,
    .product-card-media img,
    .heroics-product-image img {
        height: 100%;
        object-fit: contain;
        width: 100%;
    }

    .heroics-product-image-link {
        aspect-ratio: 1 / 1;
        display: block;
        height: auto;
        width: 100%;
    }

    .product-card-actions,
    .heroics-product-cta.product-card-actions {
        opacity: 1 !important;
        overflow: visible;
        pointer-events: auto !important;
        position: static;
        transform: none !important;
        visibility: visible !important;
    }

    .heroics-product-card .product-card-add {
        border-radius: 12px;
        min-height: 44px;
        width: 100%;
    }

    .heroics-product-card .product-card-add-text {
        clip: auto;
        height: auto;
        overflow: visible;
        position: static;
        white-space: normal;
        width: auto;
    }

    .featured-carousel__slide {
        padding: 5rem 1.5rem 5.75rem;
    }

    .featured-carousel__title {
        display: -webkit-box;
        font-size: clamp(1.85rem, 8vw, 2.55rem);
        line-height: 1.02;
        max-width: 11ch;
        overflow: hidden;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 3;
    }

    .featured-carousel__description {
        display: -webkit-box;
        max-width: 34ch;
        overflow: hidden;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
    }

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

    .featured-carousel__media img {
        max-height: 300px;
        max-width: min(78vw, 320px);
    }

    .featured-carousel__arrow--prev,
    .featured-carousel__arrow--next {
        bottom: auto;
        height: 44px;
        top: 50%;
        transform: translateY(-50%);
        width: 44px;
        z-index: 6;
    }

    .featured-carousel__arrow--prev {
        left: 8px;
    }

    .featured-carousel__arrow--next {
        right: 8px;
    }

    .featured-carousel__arrow:hover,
    .featured-carousel__arrow:focus-visible {
        transform: translateY(-50%) scale(1.02);
    }

    .featured-carousel__dots {
        bottom: 1rem;
        left: 50%;
        transform: translateX(-50%);
    }
}

@media (min-width: 768px) and (max-width: 991.98px) {
    .product-card-image,
    .product-card-media,
    .heroics-product-image {
        aspect-ratio: 1 / 1;
        background: #fff;
        border-radius: 18px 18px 0 0;
        height: auto;
        overflow: hidden;
        width: 100%;
    }

    .product-card-image img,
    .product-card-media img,
    .heroics-product-image img {
        height: 100%;
        object-fit: contain;
        width: 100%;
    }

    .heroics-product-image-link {
        aspect-ratio: 1 / 1;
        display: block;
        height: auto;
        width: 100%;
    }

    .heroics-promo-carousel .owl-dots {
        align-items: center;
        bottom: 12px;
        display: flex;
        gap: 7px;
        justify-content: center;
        left: 50%;
        margin: 0 !important;
        padding: 0;
        position: absolute;
        right: auto;
        transform: translateX(-50%);
        width: auto;
    }

    .heroics-promo-carousel .owl-dot span {
        border-radius: 999px;
        height: 7px !important;
        min-height: 7px;
        min-width: 7px;
        overflow: hidden;
        padding: 0;
        text-indent: -9999px;
        width: 7px !important;
    }

    .heroics-promo-carousel .owl-dot span::before {
        content: none !important;
    }

    .heroics-promo-carousel .owl-dot.active span {
        width: 22px !important;
    }

    .featured-carousel__arrow--prev,
    .featured-carousel__arrow--next {
        bottom: auto;
        height: 44px;
        top: 50%;
        transform: translateY(-50%);
        width: 44px;
        z-index: 6;
    }

    .featured-carousel__arrow--prev {
        left: 12px;
    }

    .featured-carousel__arrow--next {
        right: 12px;
    }

    .featured-carousel__arrow:hover,
    .featured-carousel__arrow:focus-visible {
        transform: translateY(-50%) scale(1.02);
    }

    .featured-carousel__dots {
        bottom: 1rem;
        left: 50%;
        transform: translateX(-50%);
    }
}
