/* Full-screen category accordion menu (hamburger + bottom nav) */

.fsm-overlay.categories-modal-overlay {
    display: flex !important;
    position: fixed;
    inset: 0;
    z-index: 2100;
    background: var(--bg-white);
    align-items: stretch;
    justify-content: stretch;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
        opacity 0.32s cubic-bezier(0.22, 1, 0.36, 1),
        visibility 0.32s cubic-bezier(0.22, 1, 0.36, 1),
        background-color 0.32s ease;
}
.fsm-overlay.categories-modal-overlay.active,
.fsm-overlay.categories-modal-overlay.fsm-is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}
.fsm-overlay.categories-modal-overlay.fsm-is-closing {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

.fsm-overlay .fsm-panel.categories-modal {
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 100%;
    height: 100%;
    height: 100dvh;
    max-height: none !important;
    margin: 0 !important;
    border-radius: 0 !important;
    overflow: hidden;
    background: var(--bg-white);
    animation: none !important;
    transform: translate3d(0, 100%, 0);
    opacity: 0.98;
    transition:
        transform 0.38s cubic-bezier(0.22, 1, 0.36, 1),
        opacity 0.32s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.38s ease;
    will-change: transform, opacity;
}
.fsm-overlay.active .fsm-panel.categories-modal,
.fsm-overlay.fsm-is-open .fsm-panel.categories-modal {
    transform: translate3d(0, 0, 0);
    opacity: 1;
}
.fsm-overlay.fsm-is-closing .fsm-panel.categories-modal {
    transform: translate3d(0, 100%, 0);
    opacity: 0.98;
}

.fsm-header.categories-modal-header {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 12px 20px 8px;
    border-bottom: 1px solid rgba(144, 30, 80, 0.12);
    background:
        linear-gradient(
            135deg,
            rgba(144, 30, 80, 0.07) 0%,
            rgba(184, 68, 114, 0.04) 38%,
            rgba(255, 255, 255, 0) 62%,
            rgba(144, 30, 80, 0.05) 100%
        ),
        linear-gradient(180deg, var(--brand-surface) 0%, var(--bg-white) 100%);
    position: sticky;
    top: 0;
    z-index: 2;
}
.fsm-header.categories-modal-header h3 {
    display: none;
}

.fsm-header-start {
    flex: 0 0 auto;
    min-width: 0;
    height: 56px;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    position: relative;
    flex-shrink: 0;
}

.fsm-header-start .fsm-drill-back {
    position: static;
    flex-shrink: 0;
    margin: 0;
}

.fsm-header-brand {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 56px;
    padding: 4px 0 2px;
}

.fsm-header-brand-medallion {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    text-decoration: none;
    background:
        radial-gradient(circle at 32% 28%, rgba(255, 255, 255, 0.95), rgba(243, 232, 237, 0.9) 55%, rgba(220, 190, 200, 0.85));
    box-shadow:
        0 4px 12px rgba(144, 30, 80, 0.18),
        inset 0 2px 4px rgba(255, 255, 255, 0.9),
        inset 0 -2px 6px rgba(144, 30, 80, 0.08);
}

.fsm-header-brand-icon {
    display: block;
    max-width: 42px;
    max-height: 30px;
    width: auto;
    height: auto;
    object-fit: contain;
}

.fsm-header-brand-mark {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    margin: 0 auto;
    line-height: 1;
}

.fsm-header-brand-img-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    line-height: 0;
    flex-shrink: 0;
}

.fsm-header-brand-img {
    display: block;
    width: auto;
    height: auto;
    max-height: clamp(36px, 9vw, 48px);
    max-width: min(200px, 58vw);
    object-fit: contain;
    object-position: center;
}

.fsm-header-brand-fashion {
    align-self: stretch;
    width: 100%;
    box-sizing: border-box;
    font-family: "Dancing Script", "Brush Script MT", "Segoe Script", cursive;
    font-size: clamp(20px, 5vw, 26px);
    font-weight: 600;
    letter-spacing: 0.04em;
    line-height: 1;
    color: var(--brand, #901e50);
    text-align: right;
    padding-left: 68%;
}

.fsm-close {
    width: 44px;
    height: 44px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: transparent;
    color: var(--brand);
    font-size: 22px;
    cursor: pointer;
    border-radius: var(--radius-sm);
}
.fsm-close:hover {
    color: var(--brand-dark);
}

.fsm-body.categories-modal-body {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    padding: 0 !important;
    min-height: 0;
}
.fsm-body.categories-modal-body .fsm-layout--desktop {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.fsm-empty {
    padding: 32px 20px;
    text-align: center;
    color: var(--text-muted);
    font-size: 15px;
}

.fsm-list {
    display: flex;
    flex-direction: column;
}

.fsm-item {
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

/* Same card layout at every level — only font size + indent change by depth */
.fsm-card {
    display: grid;
    grid-template-columns: 1fr minmax(100px, 38%) 28px;
    align-items: center;
    gap: 8px;
    width: 100%;
    min-height: 112px;
    padding: 20px 12px 20px 20px;
    border: none;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    text-align: left;
    text-decoration: none;
    cursor: pointer;
    transition: filter 0.2s ease;
    color: inherit;
}
.fsm-card:hover {
    filter: brightness(0.97);
}
.fsm-card--parent:not(:has(.fsm-card-media)),
.fsm-card--leaf:not(:has(.fsm-card-media)) {
    grid-template-columns: 1fr 28px;
}
.fsm-card--leaf:not(:has(.fsm-card-media)) .fsm-card-chev--spacer {
    display: none;
}

.fsm-card-text {
    min-width: 0;
    z-index: 1;
}

.fsm-card-title {
    display: block;
    font-weight: 800;
    line-height: 1.1;
    color: #1a1a1a;
    letter-spacing: -0.02em;
    margin: 0 0 8px;
}

.fsm-card--depth-0 .fsm-card-title {
    font-size: 28px;
}
.fsm-card--depth-1 .fsm-card-title {
    font-size: 24px;
}
.fsm-card--depth-2 .fsm-card-title {
    font-size: 18px;
}
.fsm-card--depth-3 .fsm-card-title,
.fsm-card--depth-4 .fsm-card-title,
.fsm-card--depth-5 .fsm-card-title {
    font-size: 15px;
    font-weight: 700;
}

.fsm-card-subtitle {
    display: block;
    font-weight: 500;
    line-height: 1.4;
    color: #4b5563;
    max-width: 220px;
}
.fsm-card--depth-0 .fsm-card-subtitle {
    font-size: 13px;
}
.fsm-card--depth-1 .fsm-card-subtitle {
    font-size: 12px;
}
.fsm-card--depth-2 .fsm-card-subtitle {
    font-size: 11px;
}
.fsm-card--depth-3 .fsm-card-subtitle,
.fsm-card--depth-4 .fsm-card-subtitle,
.fsm-card--depth-5 .fsm-card-subtitle {
    font-size: 10px;
}

.fsm-card--depth-1 {
    padding-left: 32px;
}
.fsm-card--depth-2 {
    padding-left: 44px;
}
.fsm-card--depth-3 {
    padding-left: 56px;
}
.fsm-card--depth-4 {
    padding-left: 68px;
}
.fsm-card--depth-5 {
    padding-left: 80px;
}

.fsm-card-media {
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    min-height: 72px;
    min-width: 88px;
    overflow: visible;
    flex-shrink: 0;
}
.fsm-card-media img {
    max-height: 96px;
    width: auto;
    max-width: 120px;
    object-fit: contain;
    object-position: bottom right;
}
.fsm-card-ph {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 88px;
    height: 72px;
    font-size: 28px;
    color: rgba(144, 30, 80, 0.35);
    background: rgba(255, 255, 255, 0.45);
    border-radius: 8px;
}
.fsm-card-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 72px;
    height: 72px;
    font-size: 32px;
    color: rgba(144, 30, 80, 0.4);
}
.fsm-card-icon--sm {
    width: 52px;
    height: 52px;
    font-size: 24px;
}

.fsm-card-chev {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    color: var(--brand);
    font-size: 14px;
    transition: transform 0.25s ease;
}
.fsm-item.is-open .fsm-card-chev {
    transform: rotate(180deg);
}

.fsm-card-chev--spacer {
    visibility: hidden;
    pointer-events: none;
}

.fsm-children {
    display: block;
    background: transparent;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    margin: 0;
    padding: 0;
    transition:
        max-height 0.4s cubic-bezier(0.22, 1, 0.36, 1),
        opacity 0.28s ease;
}
.fsm-children[hidden] {
    max-height: 0 !important;
    opacity: 0 !important;
    overflow: hidden !important;
}
.fsm-item.is-open .fsm-children:not([hidden]) {
    max-height: 2000px;
    opacity: 1;
}

.fsm-shop-all {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 20px;
    font-size: 14px;
    font-weight: 700;
    color: var(--brand);
    text-decoration: none;
    border-top: 1px solid var(--border);
    background: var(--bg-white);
}
.fsm-shop-all:hover {
    background: var(--bg);
}

body.fsm-menu-open,
body.uh-mobile-menu-open {
    overflow: hidden;
}

/* Mobile: bottom tab bar sits on top of full-height menu (no white gap above nav) */
@media (max-width: 767px) {
    body.fsm-menu-open,
    body.uh-mobile-menu-open {
        padding-bottom: 0 !important;
    }

    body.fsm-menu-open .mobile-bottom-nav,
    body.uh-mobile-menu-open .mobile-bottom-nav {
        display: flex !important;
        z-index: 2200;
    }

    body.fsm-menu-open .fsm-overlay.categories-modal-overlay,
    body.uh-mobile-menu-open .fsm-overlay.categories-modal-overlay {
        bottom: 0;
        top: 0;
        left: 0;
        right: 0;
        height: auto;
    }

    body.fsm-menu-open .fsm-overlay.categories-modal-overlay.active,
    body.fsm-menu-open .fsm-overlay.categories-modal-overlay[aria-hidden="false"],
    body.uh-mobile-menu-open .fsm-overlay.categories-modal-overlay.active,
    body.uh-mobile-menu-open .fsm-overlay.categories-modal-overlay[aria-hidden="false"] {
        background: var(--bg-white);
    }

    body.fsm-menu-open .fsm-overlay .fsm-panel.categories-modal,
    body.uh-mobile-menu-open .fsm-overlay .fsm-panel.categories-modal {
        width: 100%;
        max-width: 100%;
        height: 100%;
        max-height: 100%;
        box-sizing: border-box;
        padding-bottom: var(--shop-bottom-nav-h);
    }

    body.fsm-menu-open .mobile-bottom-nav [data-mbn="categories"].active,
    body.uh-mobile-menu-open .mobile-bottom-nav [data-mbn="categories"].active {
        color: var(--brand);
    }

    body.fsm-menu-open .mobile-bottom-nav [data-mbn="categories"].active .mbn-tab__label,
    body.uh-mobile-menu-open .mobile-bottom-nav [data-mbn="categories"].active .mbn-tab__label {
        color: var(--brand);
    }

    .fsm-drill-viewport {
        background: #e8e8e8;
    }

    body.fsm-menu-open .fsm-drill-panel,
    body.uh-mobile-menu-open .fsm-drill-panel {
        max-height: 100%;
    }

    .fsm-drill-panel:not(.fsm-drill-panel--sublist),
    .fsm-drill-panel--banners {
        background: #e8e8e8;
    }
}

@media (min-width: 768px) {
    .fsm-overlay.categories-modal-overlay {
        background: rgba(15, 15, 20, 0);
        backdrop-filter: blur(0);
        align-items: stretch;
        justify-content: flex-end;
    }
    .fsm-overlay.categories-modal-overlay.active,
    .fsm-overlay.categories-modal-overlay.fsm-is-open {
        background: rgba(15, 15, 20, 0.45);
        backdrop-filter: blur(4px);
    }
    .fsm-overlay .fsm-panel.categories-modal {
        max-width: 480px;
        box-shadow: none;
        transform: translate3d(100%, 0, 0);
    }
    .fsm-overlay.active .fsm-panel.categories-modal,
    .fsm-overlay.fsm-is-open .fsm-panel.categories-modal {
        transform: translate3d(0, 0, 0);
        box-shadow: var(--shadow-lg);
    }
    .fsm-overlay.fsm-is-closing .fsm-panel.categories-modal {
        transform: translate3d(100%, 0, 0);
        box-shadow: none;
    }
}

/* All breakpoints: horizontal drill + slim sub-lists (no in-place accordion) */
.fsm-layout--desktop {
    display: none !important;
}
.fsm-layout--mobile {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

.fsm-drill-back {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: transparent;
    color: var(--brand);
    font-size: 18px;
    font-weight: 700;
    padding: 8px;
    width: 40px;
    height: 40px;
    cursor: pointer;
    flex-shrink: 0;
}
.fsm-drill-back[hidden] {
    display: none !important;
}
.fsm-drill-title {
    flex: 1;
    min-width: 0;
    font-size: 15px;
    font-weight: 700;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: center;
}

.fsm-shop-all--nested {
    padding-left: 28px;
    font-size: 13px;
}

/* Drill-down — horizontal slide (right in, back slides left) */
.fsm-drill-viewport {
    overflow: hidden;
    position: relative;
    flex: 1;
    min-height: 0;
    width: 100%;
}
.fsm-drill-stack {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    width: 100%;
    height: 100%;
    transform: translate3d(0, 0, 0);
    transition: transform 0.42s cubic-bezier(0.32, 0.72, 0, 1);
    will-change: transform;
    backface-visibility: hidden;
}
.fsm-drill-stack.fsm-drill-stack--no-transition {
    transition: none !important;
}
.fsm-drill-panel {
    flex: 0 0 100%;
    width: 100%;
    min-width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    overflow-x: hidden;
    overflow-y: auto;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    max-height: 100%;
    background: var(--bg-white);
}
/* Mobile drill — same card layout as desktop, font scales by depth */
.fsm-drill-row {
    display: grid;
    grid-template-columns: 1fr minmax(100px, 38%);
    align-items: center;
    gap: 8px;
    width: 100%;
    min-height: 112px;
    padding: 20px 20px 20px 20px;
    border: none;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    text-align: left;
    text-decoration: none;
    cursor: pointer;
    color: inherit;
    background: #e8e8e8;
}
.fsm-drill-row--link {
    grid-template-columns: 1fr minmax(100px, 38%);
}
/* Root + first-drill banner panels — same height for every banner row */
.fsm-drill-panel:not(.fsm-drill-panel--sublist) > .fsm-drill-row.fsm-drill-row--depth-0,
.fsm-drill-panel--banners > .fsm-drill-row--bg-banner,
.fsm-drill-panel--banners > .fsm-drill-row--text-only {
    width: 100%;
    min-height: 0;
    aspect-ratio: 2117 / 743;
    box-sizing: border-box;
}
/* Root row without banner — text on menu_bg_color only (no placeholder column) */
.fsm-drill-row--text-only,
.fsm-drill-row--text-only.fsm-drill-row--link {
    grid-template-columns: 1fr;
    align-items: stretch;
    padding: 0;
}
.fsm-drill-row--text-only .fsm-drill-row-text {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
    padding: 20px;
    box-sizing: border-box;
    max-width: 58%;
}
/* Category banners (Kids / Women / Men) — aspect-ratio set inline per image */
.fsm-drill-row--bg-banner {
    position: relative;
    grid-template-columns: 1fr;
    align-items: stretch;
    padding: 0;
    min-height: 0;
    aspect-ratio: 2117 / 743; /* fallback */
    background-repeat: no-repeat;
    background-size: cover;
    background-position: right center;
    overflow: hidden;
}
.fsm-drill-row--bg-banner::after {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background: linear-gradient(
        90deg,
        rgba(255, 255, 255, 0.72) 0%,
        rgba(255, 255, 255, 0.35) 42%,
        transparent 68%
    );
}
.fsm-drill-row--bg-banner .fsm-drill-row-text {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
    padding: 20px;
    box-sizing: border-box;
    max-width: 58%;
}
.fsm-drill-row--bg-banner .fsm-drill-row-title,
.fsm-drill-row--bg-banner .fsm-drill-row-sub {
    text-shadow: 0 1px 8px rgba(255, 255, 255, 0.85);
}
.fsm-drill-row--bg-banner .fsm-drill-row-sub {
    color: #1a1a1a;
    font-size: 13px;
    font-weight: 600;
    margin-top: 4px;
}
.fsm-drill-row:active {
    filter: brightness(0.96);
}
.fsm-drill-row--depth-1 {
    padding-left: 32px;
}
.fsm-drill-row--depth-2 {
    padding-left: 44px;
}
.fsm-drill-row--depth-3,
.fsm-drill-row--depth-4,
.fsm-drill-row--depth-5 {
    padding-left: 56px;
}
.fsm-drill-row--depth-0 .fsm-drill-row-title {
    font-size: 28px;
}
.fsm-drill-row--depth-1 .fsm-drill-row-title {
    font-size: 24px;
}
.fsm-drill-row--depth-2 .fsm-drill-row-title {
    font-size: 18px;
}
.fsm-drill-row--depth-3 .fsm-drill-row-title,
.fsm-drill-row--depth-4 .fsm-drill-row-title,
.fsm-drill-row--depth-5 .fsm-drill-row-title {
    font-size: 15px;
}
.fsm-drill-row-title {
    display: block;
    font-weight: 800;
    line-height: 1.15;
    color: #1a1a1a;
    margin: 0 0 6px;
}
.fsm-drill-row-sub {
    display: block;
    font-size: 12px;
    color: #4b5563;
    line-height: 1.35;
}
.fsm-drill-row--depth-0 .fsm-drill-row-sub {
    font-size: 13px;
}
.fsm-drill-row--depth-1 .fsm-drill-row-sub {
    font-size: 12px;
}
.fsm-drill-row-media img {
    max-height: 96px;
    max-width: 120px;
    object-fit: contain;
    object-position: bottom right;
}
.fsm-drill-row-media--ph {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 72px;
    min-height: 72px;
    font-size: 24px;
    color: rgba(144, 30, 80, 0.4);
    background: rgba(255, 255, 255, 0.5);
    border-radius: 8px;
}
.fsm-drill-row-chev {
    color: var(--brand);
    font-size: 13px;
}

.fsm-drill-shop-all {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 18px;
    font-size: 14px;
    font-weight: 700;
    color: var(--brand);
    text-decoration: none;
    border-bottom: 1px solid var(--border);
    background: var(--bg-white);
}

/* Sub-category drill panels — slim list at every nested level (not thick .fsm-drill-row) */
.fsm-header.fsm-header--drill-sub {
    justify-content: space-between;
    border-bottom: none;
    padding-bottom: 4px;
}

.fsm-drill-panel--banners {
    background: #e8e8e8;
}

.fsm-drill-panel--sublist {
    background: var(--bg-white);
}

.fsm-drill-panel--banners .fsm-drill-row--depth-0.fsm-drill-row--bg-banner .fsm-drill-row-title {
    font-size: 28px;
}

.fsm-drill-panel--banners .fsm-drill-row--depth-1.fsm-drill-row--bg-banner .fsm-drill-row-title {
    font-size: 24px;
}

.fsm-drill-panel--banners .fsm-drill-row--depth-0.fsm-drill-row--bg-banner .fsm-drill-row-sub {
    font-size: 13px;
    font-weight: 600;
}

.fsm-drill-panel--banners .fsm-drill-row--depth-1.fsm-drill-row--bg-banner .fsm-drill-row-sub {
    font-size: 12px;
    font-weight: 600;
}

.fsm-drill-panel--banners .fsm-drill-row--bg-banner,
.fsm-drill-panel--banners .fsm-drill-row--text-only {
    padding-left: 0;
}

.fsm-drill-panel-head {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px 16px 8px;
}

.fsm-drill-panel-head__back {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.fsm-drill-panel-head .fsm-drill-back {
    margin: 0;
}

.fsm-drill-panel-heading {
    margin: 0;
    padding: 0;
    flex: 1;
    min-width: 0;
    font-size: 28px;
    font-weight: 800;
    line-height: 1.15;
    color: var(--brand, #901e50);
    letter-spacing: -0.02em;
}

.fsm-drill-back-holder {
    display: none;
}

/* Sub rows: label | thumb (no chevron) */
.fsm-drill-panel--sublist .fsm-slim-row,
.fsm-drill-panel--sublist a.fsm-slim-row,
.fsm-drill-panel--sublist button.fsm-slim-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 60px;
    align-items: center;
    column-gap: 14px;
    width: 100%;
    min-height: 64px;
    padding: 14px 20px;
    margin: 0;
    border: none;
    border-bottom: 1px solid #e8eaed;
    border-radius: 0;
    text-align: left;
    text-decoration: none;
    cursor: pointer;
    color: inherit;
    background: #fff !important;
    box-shadow: none;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    -webkit-appearance: none;
    appearance: none;
}
.fsm-drill-panel--sublist .fsm-slim-row:active,
.fsm-drill-panel--sublist a.fsm-slim-row:active,
.fsm-drill-panel--sublist button.fsm-slim-row:active {
    background: #f9fafb !important;
}

.fsm-drill-panel--sublist .fsm-slim-row__label {
    grid-column: 1;
    grid-row: 1;
    min-width: 0;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.35;
    color: #1a1a1a;
    align-self: center;
}

.fsm-drill-panel--sublist .fsm-slim-row__thumb {
    grid-column: 2;
    grid-row: 1;
    flex-shrink: 0;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    overflow: hidden;
    background: #f3f4f6;
    display: flex;
    align-items: center;
    justify-content: center;
    justify-self: end;
    align-self: center;
}
.fsm-drill-panel--sublist .fsm-slim-row__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
}
/* Fallback only when square thumb could not be generated — wide banner crop */
.fsm-drill-panel--sublist .fsm-slim-row__thumb--menu-banner img {
    object-position: 84% center;
}
/* Admin Hero (center) — subject centered in circle thumb */
.fsm-drill-panel--sublist .fsm-slim-row__thumb--hero-center img {
    object-fit: cover;
    object-position: center center;
}
.fsm-drill-panel--sublist .fsm-slim-row__thumb--ph {
    font-size: 20px;
    color: #d1d5db;
}

.fsm-drill-panel--sublist .fsm-slim-row__chev,
.fsm-drill-panel--sublist .fsm-slim-row__chev--spacer {
    display: none !important;
}

/* Discover — Nykaa-style portrait grid (root panel only, additive) */
.fsm-discover {
    padding: 8px 6px 16px;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
    background: var(--bg-white);
}
.fsm-discover__heading {
    margin: 0 0 10px;
    padding: 0 2px;
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #1a1a1a;
}
.fsm-discover__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    row-gap: 8px;
}
.fsm-discover-tile {
    position: relative;
    display: block;
    aspect-ratio: 3 / 4;
    min-height: 0;
    overflow: hidden;
    text-decoration: none;
    color: #fff;
    border-radius: 6px;
    background: #f0ebe4;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}
.fsm-discover-tile::after {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(
        to top,
        rgba(0, 0, 0, 0.78) 0%,
        rgba(0, 0, 0, 0.42) 32%,
        rgba(0, 0, 0, 0.08) 58%,
        transparent 72%
    );
    pointer-events: none;
}
.fsm-discover-tile__media {
    position: absolute;
    inset: 0;
    z-index: 0;
}
.fsm-discover-tile__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 18%;
    display: block;
    transition: transform 0.35s ease;
}
.fsm-discover-tile:hover .fsm-discover-tile__img,
.fsm-discover-tile:focus-visible .fsm-discover-tile__img {
    transform: scale(1.04);
}
.fsm-discover-tile__ph {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    font-size: 28px;
    color: rgba(144, 30, 80, 0.35);
    background: rgba(255, 255, 255, 0.45);
}
.fsm-discover-tile__label-wrap {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 2;
    width: 100%;
    padding: 14px 12px 16px;
    text-align: left;
    pointer-events: none;
}
.fsm-discover-tile__label {
    display: block;
    font-size: 13px;
    font-weight: 800;
    line-height: 1.15;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #fff;
    text-shadow: none;
}
.fsm-discover-tile__sub {
    display: block;
    margin-top: 4px;
    font-size: 10px;
    font-weight: 500;
    line-height: 1.35;
    letter-spacing: 0.03em;
    text-transform: none;
    color: rgba(255, 255, 255, 0.88);
    text-shadow: none;
}
.fsm-discover-tile--serif .fsm-discover-tile__label,
.fsm-discover-tile--serif .fsm-discover-tile__sub {
    font-family: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: none;
}
.fsm-discover-tile--serif .fsm-discover-tile__label {
    font-size: 15px;
    font-weight: 700;
    text-transform: uppercase;
}
.fsm-discover-tile--sans .fsm-discover-tile__label {
    font-family: 'DM Sans', 'Inter', system-ui, sans-serif;
}
.fsm-discover-tile--heavy .fsm-discover-tile__label {
    font-family: 'DM Sans', 'Inter', system-ui, sans-serif;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.08em;
}

/* Legacy .categories-modal rules in public-theme.css must not collapse the drill body */
.fsm-overlay.categories-modal-overlay .categories-modal.fsm-panel {
    max-height: none !important;
    overflow: hidden !important;
    overflow-y: hidden !important;
}

@media (prefers-reduced-motion: reduce) {
    .fsm-overlay.categories-modal-overlay,
    .fsm-overlay .fsm-panel.categories-modal,
    .fsm-children,
    .fsm-card-chev,
    .fsm-drill-stack,
    .fsm-discover-tile__img {
        transition-duration: 0.01ms !important;
    }
    .fsm-discover-tile:hover .fsm-discover-tile__img,
    .fsm-discover-tile:focus-visible .fsm-discover-tile__img {
        transform: none;
    }
}
