:root {
    --bs-body-font-family: "Inter", sans-serif;
    --heading-font: "Playfair Display", serif;
    --ink: #111111;
    --muted: #787878;
    --gold: #C9A96E;
    --gold-dark: #B08D4F;
    --gold-light: #E8D5B0;
    --neon: #C9A96E;
    --neon-deep: #B08D4F;
    --card: #ffffff;
    --line: rgba(0, 0, 0, 0.06);
    --surface: #FAFAF8;
    --premium-radius-sm: 0.5rem;
    --premium-radius-md: 0.75rem;
    --premium-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
    --premium-shadow-hover: 0 8px 32px rgba(0, 0, 0, 0.1);
    --transition-smooth: cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

html {
    font-size: 16px;
    scroll-behavior: smooth;
}

body {
    margin: 0;
    color: var(--ink);
    background: var(--surface);
}

.site-shell {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.site-shell > main {
    flex: 1 0 auto;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--heading-font);
}

a {
    color: inherit;
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 1020;
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    background: rgba(10, 10, 10, 0.92);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    transition: background 0.4s ease, box-shadow 0.4s ease;
}

.nav-glass {
    background: rgba(10, 10, 10, 0.97);
    box-shadow: 0 1px 30px rgba(0, 0, 0, 0.15);
}

.premium-navbar {
    padding: 0.9rem 0;
}

.premium-navbar .container {
    display: flex;
    align-items: center;
}

.navbar-toggler {
    margin-left: auto;
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.14) !important;
    border-radius: 0.9rem;
    padding: 0.45rem 0.7rem;
}

.navbar-toggler i {
    font-size: 1.35rem;
}

.navbar-toggler:focus {
    box-shadow: none;
}

.navbar-brand {
    display: inline-flex;
    align-items: center;
    gap: 0;
    color: #fff;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-decoration: none;
}

.brand-logo-img {
    display: block;
    width: auto;
    max-width: 100%;
    object-fit: contain;
    background: #fff;
}

.brand-logo-img-header {
    height: 3.25rem;
    max-width: 12.5rem;
    border-radius: 0.35rem;
}

.brand-logo-img-footer {
    width: 5.75rem;
    height: auto;
    flex: 0 0 auto;
    border-radius: 0.35rem;
}

.brand-mark {
    display: inline-grid;
    place-items: center;
    width: 2.65rem;
    height: 2.65rem;
    border-radius: 0.85rem;
    background: linear-gradient(135deg, var(--gold), #efcf7f);
    color: #111;
    font-weight: 800;
    box-shadow: 0 10px 28px rgba(201, 169, 110, 0.35);
}

.brand-mark-header {
    width: 2.6rem;
    height: 2.6rem;
    border-radius: 0.65rem;
    background: linear-gradient(135deg, var(--gold), var(--gold-light));
    box-shadow: 0 4px 16px rgba(201, 169, 110, 0.25);
}

.brand-mark-header i {
    font-size: 1.1rem;
    color: #111;
}

.brand-lockup {
    display: flex;
    align-items: baseline;
    gap: 0.3rem;
    font-size: 1.5rem;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-family: var(--heading-font);
}

.brand-accent {
    color: var(--gold);
}

.brand-text {
    color: #fff;
}

.premium-nav-links {
    gap: 0.35rem;
}

.premium-nav-links .nav-item {
    position: relative;
}

.premium-nav-links .nav-item + .nav-item::before {
    content: "/";
    position: absolute;
    left: -0.15rem;
    top: 50%;
    transform: translateY(-50%);
    color: rgba(255, 255, 255, 0.34);
    font-size: 0.8rem;
}

.nav-link {
    color: rgba(255, 255, 255, 0.78);
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.84rem;
    letter-spacing: 0.08em;
    padding-inline: 1rem !important;
}

.nav-link:hover,
.nav-link:focus {
    color: #fff;
}

.header-action-row {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    margin-left: 1.25rem;
}

.header-global-search {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    min-width: 280px;
    padding: 0.35rem 0.4rem 0.35rem 0.9rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.04);
    margin: 0;
    transition: border-color 0.3s ease;
}

.header-global-search i {
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.95rem;
}

.header-global-search input {
    flex: 1 1 auto;
    min-width: 0;
    border: 0;
    outline: 0;
    background: transparent;
    color: #fff;
    font-size: 0.88rem;
    letter-spacing: 0.01em;
}

.header-global-search input::placeholder {
    color: rgba(255, 255, 255, 0.35);
}

.header-global-search-btn {
    border: 0;
    padding: 0.55rem 0.9rem;
    border-radius: 999px;
    background: var(--gold);
    color: #fff;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    white-space: nowrap;
    transition: background 0.3s ease;
}

.header-global-search-btn:hover {
    background: var(--gold-dark);
}

.header-icon-btn {
    position: relative;
    display: inline-grid;
    place-items: center;
    width: 2.8rem;
    height: 2.8rem;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: transparent;
    color: #fff;
    text-decoration: none;
    transition: transform 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.header-icon-btn:hover,
.header-icon-btn:focus {
    color: #fff;
    transform: translateY(-1px);
    border-color: rgba(201, 169, 110, 0.58);
    background: rgba(201, 169, 110, 0.08);
}

.header-icon-btn i {
    font-size: 1.05rem;
}

.header-badge {
    position: absolute;
    top: -0.15rem;
    right: -0.15rem;
    min-width: 1rem;
    height: 1rem;
    padding-inline: 0.2rem;
    border-radius: 999px;
    background: var(--gold);
    color: #fff;
    font-size: 0.6rem;
    font-weight: 700;
    display: grid;
    place-items: center;
}

.header-account-nav {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0.4rem;
    margin: 0;
}

.header-account-link,
.header-account-logout {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.7rem 0.95rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: transparent;
    color: rgba(255, 255, 255, 0.82);
    text-decoration: none;
    font-size: 0.84rem;
    font-weight: 700;
    transition: border-color 0.2s ease, color 0.2s ease, background-color 0.2s ease;
}

.header-account-link.icon-only,
.header-account-logout.icon-only {
    justify-content: center;
    width: 2.8rem;
    height: 2.8rem;
    padding: 0;
    border-radius: 50%;
}

.header-account-link.icon-only i,
.header-account-logout.icon-only i {
    font-size: 1.05rem;
}

.header-account-logout {
    cursor: pointer;
}

.header-account-menu {
    position: relative;
}

.header-account-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    min-height: 2.8rem;
    padding: 0.68rem 0.9rem;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
    font-size: 0.84rem;
    font-weight: 700;
    line-height: 1;
    cursor: pointer;
    transition: transform 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.header-account-toggle:hover,
.header-account-toggle:focus,
.header-account-toggle.show {
    color: #fff;
    transform: translateY(-1px);
    border-color: rgba(255, 255, 255, 0.34);
    background: rgba(255, 255, 255, 0.16);
}

.header-account-toggle::after {
    margin-left: 0.1rem;
}

.header-account-toggle i {
    font-size: 1rem;
}

.header-account-name {
    max-width: 7.5rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.header-account-dropdown {
    min-width: 14.5rem;
    padding: 0.45rem;
    border: 1px solid rgba(183, 44, 219, 0.16);
    border-radius: 0.5rem;
    box-shadow: 0 18px 42px rgba(24, 3, 32, 0.18);
}

.header-account-summary {
    display: grid;
    gap: 0.15rem;
    padding: 0.65rem 0.8rem 0.7rem;
    color: #5f6571;
    font-size: 0.78rem;
}

.header-account-summary strong {
    color: #15121a;
    font-size: 0.95rem;
}

.header-account-dropdown .dropdown-item {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    min-height: 2.45rem;
    border-radius: 0.42rem;
    color: #1f1b24;
    font-weight: 650;
}

.header-account-dropdown .dropdown-item i {
    color: #B72CDB;
}

.header-account-dropdown .dropdown-item:hover,
.header-account-dropdown .dropdown-item:focus {
    background: rgba(183, 44, 219, 0.08);
    color: #4d1260;
}

.header-account-logout-item {
    width: 100%;
    border: 0;
    background: transparent;
    text-align: left;
}

@media (max-width: 1599.98px) {
    .premium-navbar {
        padding: 0.7rem 0;
    }

    .premium-navbar .container {
        max-width: 100%;
        padding-inline: 1.25rem;
    }

    .brand-mark-header {
        width: 2.2rem;
        height: 2.2rem;
    }

    .brand-logo-img-header {
        height: 2.85rem;
        max-width: 10.5rem;
    }

    .brand-mark-header i {
        font-size: 0.95rem;
    }

    .brand-lockup {
        font-size: 1.28rem;
        letter-spacing: 0.09em;
    }

    .premium-nav-links {
        gap: 0.1rem;
    }

    .nav-link {
        font-size: 0.76rem;
        letter-spacing: 0.06em;
        padding-inline: 0.72rem !important;
    }

    .header-action-row {
        gap: 0.6rem;
        margin-left: 0.8rem;
    }

    .header-global-search {
        min-width: 220px;
        padding: 0.28rem 0.32rem 0.28rem 0.72rem;
    }

    .header-global-search input {
        font-size: 0.82rem;
    }

    .header-global-search-btn {
        padding: 0.5rem 0.78rem;
        font-size: 0.68rem;
    }

    .header-icon-btn,
    .header-account-link.icon-only,
    .header-account-logout.icon-only {
        width: 2.5rem;
        height: 2.5rem;
    }

    .header-account-toggle {
        min-height: 2.5rem;
        padding: 0.6rem 0.75rem;
        font-size: 0.78rem;
    }

    .header-account-link,
    .header-account-logout {
        padding: 0.62rem 0.82rem;
        font-size: 0.78rem;
    }
}

.header-account-link:hover,
.header-account-link:focus,
.header-account-logout:hover,
.header-account-logout:focus {
    color: #fff;
    border-color: rgba(255, 255, 255, 0.3);
    background: rgba(255, 255, 255, 0.04);
}

.header-account-link.admin-link {
    border-color: rgba(201, 169, 110, 0.45);
    background: rgba(201, 169, 110, 0.12);
    color: var(--neon);
    box-shadow: 0 0 0 1px rgba(201, 169, 110, 0.18), 0 14px 30px rgba(201, 169, 110, 0.14);
}

.header-account-link.admin-link:hover,
.header-account-link.admin-link:focus {
    color: #101010;
    background: linear-gradient(135deg, var(--neon), var(--gold-light));
    border-color: transparent;
}

.header-auth-trigger {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.72rem 1.15rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(255, 255, 255, 0.03);
    color: #fff;
    font-size: 0.88rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.header-auth-trigger i {
    font-size: 1rem;
}

.header-auth-trigger:hover,
.header-auth-trigger:focus {
    color: #111;
    border-color: transparent;
    background: var(--gold);
    box-shadow: 0 8px 24px rgba(201, 169, 110, 0.3);
    transform: translateY(-1px);
}

.auth-modal-dialog {
    max-width: 980px;
}

.auth-modal-content {
    border: 0;
    border-radius: 2rem;
    overflow: hidden;
    background: transparent;
    box-shadow: 0 40px 120px rgba(8, 12, 24, 0.45);
}

.auth-modal-shell {
    display: grid;
    grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1.1fr);
    min-height: 640px;
    background:
        radial-gradient(circle at top left, rgba(201, 169, 110, 0.2), transparent 28%),
        linear-gradient(135deg, #07121d 0%, #111923 100%);
}

.auth-modal-aside {
    position: relative;
    padding: 3rem 2.4rem;
    color: #fff;
    background: #111;
}

.auth-modal-aside::after {
    content: "";
    position: absolute;
    inset: 1.4rem;
    border-radius: 1.6rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    pointer-events: none;
}

.auth-kicker {
    display: inline-flex;
    padding: 0.35rem 0.8rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    color: var(--neon);
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    font-weight: 800;
}

.auth-modal-aside h2 {
    margin-top: 1.3rem;
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1.02;
}

.auth-modal-aside p {
    margin-top: 1rem;
    color: rgba(255, 255, 255, 0.72);
    font-size: 1rem;
    line-height: 1.75;
}

.auth-feature-list {
    display: grid;
    gap: 0.85rem;
    margin-top: 2.2rem;
}

.auth-feature-list div {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    padding: 0.95rem 1rem;
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.auth-feature-list i {
    display: inline-grid;
    place-items: center;
    width: 2.4rem;
    height: 2.4rem;
    border-radius: 0.9rem;
    background: rgba(201, 169, 110, 0.14);
    color: var(--neon);
}

.auth-modal-main {
    position: relative;
    padding: 2.2rem;
    background:
        radial-gradient(circle at top right, rgba(201, 169, 110, 0.1), transparent 22%),
        linear-gradient(180deg, #fff 0%, #fafaf8 100%);
}

.auth-close-btn {
    position: absolute;
    top: 1.5rem;
    right: 1.5rem;
    width: 2.9rem;
    height: 2.9rem;
    border-radius: 50%;
    border: 1px solid rgba(0, 0, 0, 0.08);
    background: #fff;
    color: var(--ink);
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.08);
}

.auth-inline-alert {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1.1rem;
    padding: 0.9rem 1rem;
    border-radius: 1rem;
    background: rgba(220, 38, 38, 0.08);
    border: 1px solid rgba(220, 38, 38, 0.18);
    color: #9e2727;
    font-weight: 600;
}

.auth-inline-alert.success {
    background: rgba(34, 197, 94, 0.1);
    border: 1px solid rgba(34, 197, 94, 0.18);
    color: #166534;
}

.auth-tab-switcher,
.auth-method-switcher {
    display: inline-flex;
    gap: 0.5rem;
    padding: 0.35rem;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.06);
}

.auth-method-switcher {
    margin-top: 1.1rem;
}

.auth-tab-btn,
.auth-method-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.85rem 1.1rem;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--muted);
    font-weight: 700;
}

.auth-tab-btn.is-active,
.auth-method-btn.is-active {
    background: #fff;
    color: var(--ink);
    box-shadow: 0 14px 28px rgba(0, 0, 0, 0.08);
}

.auth-panel {
    display: none;
    margin-top: 1.5rem;
}

.auth-panel.is-active,
.auth-method-panel.is-active {
    display: block;
}

.auth-subpanel {
    display: none;
}

.auth-subpanel.is-active {
    display: block;
}

.auth-panel-head h3 {
    margin-bottom: 0.45rem;
    font-size: 2rem;
}

.auth-panel-head p {
    color: var(--muted);
    margin-bottom: 0;
}

.auth-method-panel {
    display: none;
}

.auth-form {
    margin-top: 1.25rem;
}

.auth-field-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.auth-field-grid.single {
    grid-template-columns: minmax(0, 1fr);
}

.auth-field {
    display: grid;
    gap: 0.45rem;
}

.auth-field span {
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--ink);
}

.auth-field .form-control {
    min-height: 3.5rem;
    border-radius: 1.15rem;
    border: 1px solid rgba(0, 0, 0, 0.1);
    background: rgba(255, 255, 255, 0.88);
    box-shadow: none;
}

.auth-field .form-control:focus {
    border-color: rgba(201, 169, 110, 0.6);
    box-shadow: 0 0 0 0.25rem rgba(201, 169, 110, 0.14);
}

.auth-form-footer {
    display: grid;
    gap: 0.95rem;
    margin-top: 1.15rem;
}

.auth-form-footer.register {
    align-items: flex-end;
}

.auth-form-footer.forgot {
    flex-direction: column;
    align-items: stretch;
}

.auth-checkbox {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    color: #5d6c80;
    font-weight: 600;
    font-size: 0.98rem;
}

.auth-form-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.auth-checkbox input {
    width: 1.05rem;
    height: 1.05rem;
    accent-color: var(--gold-dark);
}

.auth-register-note,
.auth-provider-note {
    margin: 0;
    color: var(--muted);
    line-height: 1.7;
}

.auth-provider-stack {
    display: grid;
    gap: 0.8rem;
    margin-top: 1.25rem;
}

.auth-provider-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    width: 100%;
    padding: 1rem 1.2rem;
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 1.15rem;
    background: #fff;
    color: var(--ink);
    font-weight: 700;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.auth-provider-btn:hover,
.auth-provider-btn:focus {
    transform: translateY(-1px);
    border-color: rgba(201, 169, 110, 0.45);
    box-shadow: 0 16px 30px rgba(0, 0, 0, 0.08);
}

.auth-provider-btn.disabled,
.auth-provider-btn:disabled {
    opacity: 0.52;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

.checkout-shell,
.orders-shell,
.order-details-shell,
.invoice-shell,
.order-success-shell {
    padding: 4rem 0 5rem;
}

.checkout-hero,
.orders-hero,
.order-detail-hero,
.invoice-toolbar,
.order-success-card {
    padding: 2.4rem;
    border-radius: 2rem;
    background:
        radial-gradient(circle at top right, rgba(201, 169, 110, 0.12), transparent 24%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(249, 244, 236, 0.96));
    border: 1px solid rgba(0, 0, 0, 0.08);
    box-shadow: 0 28px 50px rgba(0, 0, 0, 0.08);
}

.checkout-form {
    display: grid;
    gap: 1.4rem;
}

.checkout-panel,
.checkout-summary-card,
.checkout-guest-card,
.order-card,
.invoice-card,
.order-status-strip,
.checkout-submit-bar {
    padding: 2rem;
    border-radius: 1.75rem;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(0, 0, 0, 0.08);
    box-shadow: 0 20px 45px rgba(0, 0, 0, 0.06);
}

.checkout-panel-head h2,
.checkout-summary-head h3,
.order-success-card h1,
.order-detail-hero h1,
.orders-hero h1,
.invoice-toolbar h1 {
    margin-bottom: 0.45rem;
}

.checkout-panel-head p,
.checkout-summary-head p,
.orders-hero p,
.order-detail-hero p,
.invoice-toolbar p,
.checkout-hero p {
    margin-bottom: 0;
    color: var(--muted);
}

.saved-address-grid,
.checkout-choice-grid,
.guest-benefit-grid,
.orders-grid {
    display: grid;
    gap: 1rem;
}

.saved-address-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    margin-bottom: 1rem;
}

.saved-address-card,
.checkout-choice-card {
    position: relative;
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 1rem;
    align-items: flex-start;
    padding: 1.1rem 1.15rem;
    border-radius: 1.25rem;
    border: 1px solid rgba(0, 0, 0, 0.08);
    background: #fff;
    cursor: pointer;
    transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.saved-address-card:hover,
.checkout-choice-card:hover {
    transform: translateY(-1px);
    border-color: rgba(201, 169, 110, 0.35);
    box-shadow: 0 18px 30px rgba(0, 0, 0, 0.06);
}

.saved-address-card input,
.checkout-choice-card input {
    margin-top: 0.25rem;
}

.saved-address-card.is-selected,
.checkout-choice-card.is-selected {
    border-color: rgba(201, 169, 110, 0.52);
    box-shadow: 0 0 0 1px rgba(201, 169, 110, 0.18), 0 18px 30px rgba(201, 169, 110, 0.1);
}

.saved-address-card strong,
.checkout-choice-card strong {
    display: block;
    font-size: 1rem;
}

.saved-address-card span,
.saved-address-card small,
.checkout-choice-card span,
.checkout-choice-card small {
    display: block;
    color: var(--muted);
    line-height: 1.65;
}

.checkout-choice-card em {
    font-style: normal;
    font-weight: 800;
    color: var(--ink);
}

.checkout-choice-card.payment strong i {
    color: var(--gold-dark);
    margin-right: 0.45rem;
}

.checkout-switch {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    margin-block: 0.85rem 1rem;
    color: var(--ink);
    font-weight: 700;
}

.checkout-field-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.checkout-field {
    display: grid;
    gap: 0.45rem;
}

.checkout-field-span-2 {
    grid-column: span 2;
}

.checkout-field span {
    font-size: 0.88rem;
    font-weight: 700;
}

.checkout-field .form-control {
    min-height: 3.4rem;
    border-radius: 1.1rem;
    border: 1px solid rgba(0, 0, 0, 0.1);
    box-shadow: none;
}

.checkout-field .form-control:focus {
    border-color: rgba(201, 169, 110, 0.55);
    box-shadow: 0 0 0 0.25rem rgba(201, 169, 110, 0.14);
}

.checkout-inline-options,
.checkout-submit-bar,
.order-card-top,
.order-card-metrics,
.order-card-actions,
.order-detail-actions,
.invoice-head,
.invoice-grid,
.invoice-foot,
.order-success-grid,
.order-success-actions,
.checkout-guest-actions {
    display: flex;
    gap: 1rem;
}

.checkout-inline-options,
.checkout-submit-bar,
.order-card-metrics,
.order-success-grid {
    flex-wrap: wrap;
}

.checkout-submit-bar,
.order-detail-hero,
.invoice-toolbar,
.order-card-top,
.order-card-actions,
.invoice-head,
.invoice-foot,
.checkout-guest-actions {
    align-items: center;
    justify-content: space-between;
}

.checkout-submit-bar span,
.summary-note-card span,
.order-card p,
.address-copy,
.invoice-grid p {
    color: var(--muted);
    line-height: 1.7;
}

.checkout-summary-items,
.order-item-list {
    display: grid;
    gap: 1rem;
    margin-block: 1.4rem;
}

.checkout-summary-line,
.order-item-card {
    display: grid;
    grid-template-columns: 72px 1fr auto;
    gap: 1rem;
    align-items: center;
}

.checkout-summary-thumb,
.order-card-media,
.order-item-card img {
    overflow: hidden;
    border-radius: 1.15rem;
}

.checkout-summary-thumb img,
.order-card-media img,
.order-item-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.checkout-summary-thumb {
    width: 72px;
    height: 72px;
}

.checkout-summary-copy span,
.checkout-summary-copy small,
.order-item-card span,
.order-item-card small {
    display: block;
    color: var(--muted);
}

.checkout-coupon-chip {
    display: flex;
    gap: 0.8rem;
    align-items: flex-start;
    padding: 1rem 1.1rem;
    margin-bottom: 1rem;
    border-radius: 1.15rem;
    background: rgba(201, 169, 110, 0.1);
}

.checkout-coupon-chip i {
    color: var(--neon-deep);
    font-size: 1.2rem;
}

.checkout-coupon-chip span {
    display: block;
    color: var(--muted);
}

.checkout-total-list {
    display: grid;
    gap: 0.85rem;
}

.checkout-total-list div {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.checkout-grand-total {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 1.4rem;
    padding-top: 1.2rem;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.checkout-grand-total strong {
    font-size: 2rem;
}

.checkout-trust-stack {
    display: grid;
    gap: 0.8rem;
    margin-top: 1.4rem;
}

.checkout-trust-stack div,
.guest-benefit-grid div {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    color: var(--ink);
    font-weight: 600;
}

.checkout-inline-alert {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    padding: 1rem 1.2rem;
    border-radius: 1.2rem;
    background: rgba(220, 38, 38, 0.08);
    border: 1px solid rgba(220, 38, 38, 0.18);
    color: #a12626;
    font-weight: 700;
}

.checkout-notes {
    min-height: 140px;
    resize: vertical;
}

.checkout-guest-card h2 {
    max-width: 18ch;
}

.guest-benefit-grid {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    margin-top: 1.5rem;
}

.orders-grid {
    margin-top: 2rem;
}

.order-card {
    display: grid;
    grid-template-columns: 180px 1fr;
    gap: 1.35rem;
}

.order-card-media {
    min-height: 180px;
}

.status-pill {
    display: inline-flex;
    padding: 0.55rem 0.9rem;
    border-radius: 999px;
    background: rgba(201, 169, 110, 0.12);
    color: var(--neon-deep);
    font-weight: 800;
}

.order-card-metrics div,
.order-success-grid div,
.order-status-strip > div {
    flex: 1;
    min-width: 120px;
    padding: 1rem;
    border-radius: 1rem;
    background: rgba(0, 0, 0, 0.04);
}

.order-card-metrics span,
.order-success-grid span,
.order-status-strip span,
.invoice-label {
    display: block;
    color: var(--muted);
    font-size: 0.86rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 0.25rem;
}

.order-item-list {
    margin-top: 0.5rem;
}

.order-item-card {
    padding: 0.9rem;
    border-radius: 1.1rem;
    background: rgba(0, 0, 0, 0.04);
}

.order-item-card img {
    width: 84px;
    height: 84px;
}

.order-item-copy {
    min-width: 0;
}

.order-item-copy strong,
.order-item-metrics strong {
    display: block;
    color: var(--ink);
}

.order-item-metrics {
    text-align: right;
}

.order-status-card {
    height: 100%;
    padding: 1rem;
    border-radius: 1rem;
    background: rgba(0, 0, 0, 0.04);
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.2rem;
    min-height: 92px;
}

.address-copy {
    margin: 0;
}

.invoice-card {
    margin-top: 1.5rem;
}

.invoice-table th {
    color: var(--muted);
    text-transform: uppercase;
    font-size: 0.78rem;
    letter-spacing: 0.08em;
}

.invoice-totals {
    width: min(100%, 360px);
    margin-left: auto;
}

.invoice-totals div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.55rem 0;
}

.invoice-grand {
    margin-top: 0.65rem;
    padding-top: 0.85rem !important;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
    font-size: 1.1rem;
}

.order-success-icon {
    display: inline-grid;
    place-items: center;
    width: 4.5rem;
    height: 4.5rem;
    margin-bottom: 1rem;
    border-radius: 1.4rem;
    background: rgba(201, 169, 110, 0.14);
    color: var(--neon-deep);
    font-size: 1.8rem;
}

@media print {
    .site-header,
    .site-footer,
    .flash-shell,
    .invoice-toolbar .btn {
        display: none !important;
    }

    body {
        background: #fff;
    }

    .invoice-shell {
        padding: 0;
    }

    .invoice-card,
    .invoice-toolbar {
        box-shadow: none;
        border: 0;
    }
}

@media (max-width: 991.98px) {
    .checkout-shell,
    .orders-shell,
    .order-details-shell,
    .invoice-shell,
    .order-success-shell {
        padding: 2.5rem 0 4rem;
    }

    .auth-modal-shell {
        grid-template-columns: minmax(0, 1fr);
    }

    .auth-modal-aside,
    .auth-modal-main {
        padding: 1.6rem;
    }

    .auth-modal-main {
        padding-top: 4.5rem;
    }

    .auth-field-grid,
    .auth-field-grid.single {
        grid-template-columns: minmax(0, 1fr);
    }

    .auth-form-footer,
    .auth-form-footer.register {
        flex-direction: column;
        align-items: stretch;
    }

    .auth-provider-btn,
    .auth-form-footer .btn {
        width: 100%;
    }

    .checkout-field-grid,
    .order-card,
    .checkout-summary-line,
    .order-item-card {
        grid-template-columns: minmax(0, 1fr);
    }

    .checkout-field-span-2 {
        grid-column: auto;
    }

    .checkout-inline-options,
    .checkout-submit-bar,
    .order-card-top,
    .order-card-actions,
    .order-detail-actions,
    .invoice-head,
    .invoice-grid,
    .invoice-foot,
    .order-success-actions,
    .checkout-guest-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .order-details-page .checkout-panel,
    .order-details-page .checkout-summary-card,
    .order-details-page .order-status-strip {
        padding: 1.35rem;
        border-radius: 1.4rem;
    }

    .order-details-page .order-item-card {
        grid-template-columns: 64px minmax(0, 1fr);
    }

    .order-details-page .order-item-metrics {
        grid-column: 2;
        text-align: left;
        display: flex;
        align-items: baseline;
        justify-content: space-between;
        gap: 0.75rem;
    }
}

@media (max-width: 575.98px) {
    .header-auth-trigger {
        width: 100%;
        justify-content: center;
    }

    .auth-modal-dialog {
        margin: 0.85rem;
    }

    .auth-modal-content {
        border-radius: 1.5rem;
    }

    .auth-tab-switcher,
    .auth-method-switcher {
        width: 100%;
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .auth-tab-btn,
    .auth-method-btn {
        justify-content: center;
        width: 100%;
    }

    .order-details-page {
        overflow-x: clip;
    }

    .order-details-page .container {
        padding-inline: 0.95rem;
    }

    .order-details-page .order-detail-hero {
        padding: 1.35rem;
        border-radius: 1.5rem;
    }

    .order-details-page .order-detail-hero h1 {
        font-size: 2.05rem;
    }

    .order-details-page .order-detail-hero p {
        font-size: 0.95rem;
    }

    .order-details-page .order-detail-actions {
        gap: 0.65rem;
    }

    .order-details-page .order-detail-actions .btn {
        width: 100%;
        min-height: 2.9rem;
    }

    .order-details-page .order-status-strip,
    .order-details-page .checkout-panel,
    .order-details-page .checkout-summary-card {
        padding: 1.05rem;
        border-radius: 1.2rem;
    }

    .order-details-page .order-status-card {
        min-height: 84px;
        padding: 0.8rem 0.75rem;
        border-radius: 0.95rem;
    }

    .order-details-page .order-status-card span {
        font-size: 0.72rem;
        margin-bottom: 0.15rem;
    }

    .order-details-page .order-status-card strong {
        font-size: 0.98rem;
    }

    .order-details-page .checkout-panel-head {
        margin-bottom: 0.8rem;
    }

    .order-details-page .checkout-panel-head h2,
    .order-details-page .checkout-summary-head h3 {
        font-size: 1.15rem;
    }

    .order-details-page .order-item-list {
        gap: 0.7rem;
        margin-block: 1rem 0;
    }

    .order-details-page .order-item-card {
        grid-template-columns: 56px minmax(0, 1fr);
        gap: 0.75rem;
        padding: 0.8rem;
        align-items: start;
    }

    .order-details-page .order-item-card img {
        width: 56px;
        height: 56px;
        border-radius: 0.9rem;
    }

    .order-details-page .order-item-copy strong {
        font-size: 1rem;
        line-height: 1.2;
    }

    .order-details-page .order-item-copy span,
    .order-details-page .order-item-copy small,
    .order-details-page .order-item-metrics span {
        font-size: 0.88rem;
        line-height: 1.4;
    }

    .order-details-page .order-item-metrics {
        grid-column: 2;
        margin-top: 0.15rem;
        display: grid;
        justify-content: start;
        gap: 0.15rem;
    }

    .order-details-page .checkout-total-list div {
        font-size: 0.95rem;
    }

    .order-details-page .checkout-grand-total {
        align-items: flex-start;
        gap: 0.45rem;
        flex-direction: column;
    }

    .order-details-page .checkout-grand-total strong {
        font-size: 1.85rem;
        line-height: 1;
    }

    .order-details-page .address-copy {
        font-size: 0.96rem;
        line-height: 1.75;
    }
}

.navbar-toggler {
    color: #fff;
    font-size: 1.6rem;
    margin-left: auto;
}

.navbar-toggler:focus {
    box-shadow: none;
}

.btn-gold {
    background: linear-gradient(135deg, var(--gold), #efcf7f);
    border: 0;
    color: #111;
    font-weight: 700;
    box-shadow: 0 16px 34px rgba(201, 169, 110, 0.28);
}

.btn-gold:hover,
.btn-gold:focus {
    color: #111;
    background: linear-gradient(135deg, #d6ac5e, #f3da93);
}

.btn-neon {
    background: var(--gold);
    border: 0;
    color: #fff;
    font-weight: 600;
    letter-spacing: 0.05em;
    box-shadow: 0 4px 16px rgba(201, 169, 110, 0.3);
    transition: all 0.3s var(--transition-smooth);
}

.btn-neon:hover,
.btn-neon:focus {
    color: #fff;
    background: var(--gold-dark);
    box-shadow: 0 6px 24px rgba(201, 169, 110, 0.4);
    transform: translateY(-2px);
}

.hero-shell {
    padding: 6rem 0 5rem;
    background: linear-gradient(180deg, #0a0a0a 0%, #141414 100%);
}

.eyebrow {
    display: inline-block;
    margin-bottom: 0.75rem;
    text-transform: uppercase;
    font-size: 0.72rem;
    letter-spacing: 0.25em;
    font-weight: 600;
    color: var(--gold);
}

.hero-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.hero-metrics div {
    padding: 1rem;
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.hero-metrics strong {
    display: block;
    color: #fff;
    font-size: 1.25rem;
}

.hero-metrics span {
    color: rgba(255, 255, 255, 0.62);
    font-size: 0.92rem;
}

.premium-carousel {
    border-radius: 2rem;
}

.hero-card {
    min-height: 520px;
    border-radius: 2rem;
    overflow: hidden;
    display: flex;
    align-items: end;
    background-position: center;
    background-size: cover;
    padding: 2rem;
}

.hero-card-content {
    max-width: 28rem;
    color: #fff;
}

.hero-card-content h2 {
    font-size: 2.15rem;
    margin-bottom: 1rem;
}

.hero-card-content p {
    color: rgba(255, 255, 255, 0.78);
    margin-bottom: 1.5rem;
}

.section-heading {
    max-width: 40rem;
    margin-bottom: 2.25rem;
}

.section-heading h2 {
    font-size: clamp(2rem, 4vw, 3rem);
    margin-bottom: 0;
}

.detail-content-card > h2 {
    font-size: clamp(2rem, 4vw, 3rem);
    margin-bottom: 0.7rem;
}

.section-heading.light h2 {
    color: #fff;
}

.category-card,
.product-card,
.brand-card,
.admin-card,
.newsletter-card,
.error-card {
    position: relative;
    border-radius: 1.5rem;
    background: var(--card);
    border: 1px solid var(--line);
    box-shadow: 0 16px 45px rgba(0, 0, 0, 0.08);
}

.category-card {
    overflow: hidden;
    height: 100%;
}

.category-image {
    min-height: 240px;
    background-position: center;
    background-size: cover;
}

.category-content,
.product-body,
.admin-card,
.error-card {
    padding: 1.5rem;
}

.category-content h3,
.product-body h3 {
    margin-bottom: 0.75rem;
}

.brand-strip {
    background: #111;
}

.brand-card {
    height: 100%;
    padding: 1.5rem 1rem;
    background: rgba(255, 255, 255, 0.94);
}

.brand-logo {
    width: 3.5rem;
    height: 3.5rem;
    margin: 0 auto 1rem;
    border-radius: 1rem;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, var(--gold), #f0d489);
    font-weight: 800;
    color: #111;
}

.brand-card p,
.category-content p,
.product-body p,
.footer-copy {
    color: var(--muted);
}

.product-card {
    overflow: hidden;
}

.product-visual {
    min-height: 260px;
    background-position: center;
    background-size: cover;
}

.product-meta {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--gold-dark);
    font-weight: 700;
}

.price {
    display: inline-block;
    font-size: 1.2rem;
}

.compare-price {
    display: block;
    color: var(--muted);
    text-decoration: line-through;
    font-size: 0.9rem;
}

.newsletter-shell {
    padding: 0 0 5rem;
}

.newsletter-card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 2rem;
    padding: 2rem;
    background: linear-gradient(135deg, #f0ebe0, #f8f5f0);
}

.site-footer {
    padding: 4rem 0 2rem;
    background: #111;
    color: rgba(255, 255, 255, 0.6);
    flex-shrink: 0;
}

.footer-brand {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
}

.footer-links {
    padding: 0;
    margin: 0;
    list-style: none;
    display: grid;
    gap: 0.75rem;
}

.footer-links a {
    text-decoration: none;
    color: rgba(255, 255, 255, 0.78);
}

.footer-bottom {
    margin-top: 2rem;
    padding-top: 1.25rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.admin-card strong,
.error-code {
    font-size: 2.35rem;
    color: var(--ink);
}

.admin-card span {
    display: block;
    color: var(--muted);
    margin-bottom: 0.5rem;
}

.error-shell {
    padding: 5rem 0;
}

.error-card {
    max-width: 42rem;
    margin: 0 auto;
    text-align: center;
}

@media (max-width: 991.98px) {
    .navbar-collapse {
        margin-top: 1rem;
        padding: 1rem 0 0.5rem;
        border-top: 1px solid rgba(255, 255, 255, 0.08);
    }

    .hero-shell {
        padding-top: 3.5rem;
    }

    .hero-metrics {
        grid-template-columns: 1fr;
    }

    .newsletter-card {
        flex-direction: column;
        align-items: flex-start;
    }

    .account-password-actions {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (max-width: 767.98px) {
    .hero-card {
        min-height: 420px;
    }

    .hero-card-content h2 {
        font-size: 1.7rem;
    }

    .footer-bottom {
        flex-direction: column;
    }
}

/* Final handoff polish */
:root {
    --premium-radius-sm: 0.75rem;
    --premium-radius-md: 1rem;
    --premium-shadow: 0 18px 46px rgba(0, 0, 0, 0.08);
    --premium-shadow-hover: 0 24px 56px rgba(0, 0, 0, 0.13);
}

body {
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
}

.btn {
    border-radius: var(--premium-radius-sm);
    font-weight: 600;
    letter-spacing: 0.03em;
    transition: all 0.3s var(--transition-smooth);
}

.btn:hover,
.btn:focus {
    transform: translateY(-1px);
}

.btn-dark {
    border-color: #111;
    background: #111;
    color: #fff;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.1);
}

.btn-dark:hover,
.btn-dark:focus {
    border-color: #000;
    background: #000;
    color: #fff;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}

.btn-outline-dark {
    border-color: rgba(0, 0, 0, 0.18);
    background: rgba(255, 255, 255, 0.78);
}

.btn-outline-dark:hover,
.btn-outline-dark:focus {
    border-color: #0d1726;
    background: #0d1726;
}

.shop-product-card,
.landing-product-card,
.admin-panel,
.checkout-panel,
.checkout-summary-card,
.order-card,
.account-panel-card {
    border-radius: var(--premium-radius-md);
    box-shadow: var(--premium-shadow);
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.shop-product-card:hover,
.landing-product-card:hover,
.order-card:hover,
.account-panel-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--premium-shadow-hover);
}

.premium-product-card .shop-product-body {
    gap: 0.8rem;
}

.premium-product-card h3 {
    line-height: 1.15;
}

.premium-product-card h3 a:hover {
    color: var(--gold-dark);
}

.premium-rating {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    color: var(--ink);
}

.premium-rating.compact {
    justify-content: space-between;
    width: 100%;
}

.premium-rating-stars {
    display: inline-flex;
    gap: 0.15rem;
    color: #d7a839;
    line-height: 1;
}

.premium-rating-copy {
    display: inline-flex;
    align-items: baseline;
    gap: 0.35rem;
}

.premium-rating-copy strong {
    font-weight: 900;
}

.premium-rating-copy small {
    color: var(--muted);
    font-weight: 700;
}

.premium-detail-rating {
    align-items: center;
}

.premium-breadcrumbs {
    margin-bottom: 1.15rem;
}

.premium-breadcrumbs ol {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    align-items: center;
    list-style: none;
    margin: 0;
    padding: 0;
}

.premium-breadcrumbs li {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.84rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.product-detail-shell .premium-breadcrumbs li,
.container > .premium-breadcrumbs li {
    color: #778295;
}

.premium-breadcrumbs li:not(:last-child)::after {
    content: "/";
    opacity: 0.55;
}

.premium-breadcrumbs a {
    color: inherit;
    text-decoration: none;
}

.premium-breadcrumbs a:hover,
.premium-breadcrumbs .is-current span {
    color: var(--neon-deep);
}

.premium-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.7rem;
    margin-top: 2rem;
}

.premium-pagination .pagination-list {
    display: flex;
    gap: 0.45rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.premium-pagination .page-link {
    min-width: 2.65rem;
    min-height: 2.65rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    border-radius: 999px;
    border: 1px solid rgba(0, 0, 0, 0.1);
    background: rgba(255, 255, 255, 0.9);
    color: var(--ink);
    font-weight: 900;
    text-decoration: none;
}

.premium-pagination .page-link.active,
.premium-pagination .page-link:hover {
    border-color: transparent;
    background: #0d1726;
    color: #fff;
}

.premium-pagination .page-link.disabled {
    pointer-events: none;
    opacity: 0.45;
}

.premium-empty-state {
    display: grid;
    justify-items: center;
    gap: 0.8rem;
    padding: clamp(2rem, 5vw, 3.25rem);
    text-align: center;
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: var(--premium-radius-md);
    background: rgba(255, 255, 255, 0.94);
    box-shadow: var(--premium-shadow);
}

.premium-empty-icon {
    width: 4rem;
    height: 4rem;
    display: grid;
    place-items: center;
    border-radius: var(--premium-radius-md);
    background: linear-gradient(135deg, rgba(201, 169, 110, 0.18), rgba(255, 255, 255, 0.95));
    color: var(--gold-dark);
    font-size: 1.45rem;
}

.premium-empty-state h3 {
    margin: 0;
    font-size: clamp(1.45rem, 3vw, 2rem);
}

.premium-empty-state p {
    max-width: 34rem;
    margin: 0;
    color: var(--muted);
}

.premium-toast-area {
    position: fixed;
    z-index: 1080;
    top: 6.5rem;
    right: 1.25rem;
    display: grid;
    gap: 0.8rem;
    width: min(24rem, calc(100vw - 2rem));
}

.premium-toast {
    width: 100%;
    border: 0;
    border-radius: var(--premium-radius-md);
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 22px 60px rgba(0, 0, 0, 0.18);
    overflow: hidden;
}

.premium-toast::before {
    content: "";
    display: block;
    height: 0.25rem;
    background: var(--neon-deep);
}

.premium-toast.error::before {
    background: #dc3545;
}

.premium-toast .toast-body {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 0.8rem;
    align-items: center;
    padding: 1rem;
    color: var(--ink);
    font-weight: 800;
}

.premium-toast.success i {
    color: var(--neon-deep);
}

.premium-toast.error i {
    color: #dc3545;
}

.catalog-toolbar,
.shop-filter-card {
    border-radius: var(--premium-radius-md);
}

.header-global-search:focus-within {
    border-color: rgba(201, 169, 110, 0.56);
    box-shadow: 0 0 0 0.22rem rgba(201, 169, 110, 0.12);
}

@media (max-width: 991.98px) {
    .header-action-row {
        width: 100%;
        margin: 1rem 0 0;
        align-items: stretch;
        flex-wrap: wrap;
    }

    .header-global-search {
        flex: 1 1 100%;
        min-width: 0;
    }
}

@media (max-width: 767.98px) {
    .premium-pagination {
        flex-wrap: wrap;
    }

    .premium-pagination .nav-link {
        flex: 1 1 calc(50% - 0.5rem);
    }

    .premium-pagination .pagination-list {
        order: -1;
        width: 100%;
        justify-content: center;
        overflow-x: auto;
        padding-bottom: 0.2rem;
    }

    .premium-toast-area {
        top: 5.25rem;
        right: 0.75rem;
        width: calc(100vw - 1.5rem);
    }

    .shop-card-actions {
        grid-template-columns: 1fr;
    }
}

.catalog-hero {
    padding: 5rem 0 3rem;
    background-position: center;
    background-size: cover;
    color: #fff;
}

.catalog-hero h1 {
    font-size: clamp(2.5rem, 5vw, 4rem);
    margin-bottom: 1rem;
}

.catalog-hero p {
    max-width: 42rem;
    color: rgba(255, 255, 255, 0.78);
}

.catalog-hero-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 1.75rem;
    color: rgba(255, 255, 255, 0.68);
}

.catalog-shell,
.product-detail-shell {
    padding: 3rem 0 5rem;
}

.shop-filter-card,
.catalog-toolbar,
.product-detail-card,
.product-gallery-card,
.detail-content-card,
.shop-empty-state,
.info-card {
    border-radius: 1.6rem;
    background: #fff;
    border: 1px solid var(--line);
    box-shadow: 0 16px 50px rgba(0, 0, 0, 0.08);
}

.shop-filter-card,
.catalog-toolbar,
.product-detail-card,
.product-gallery-card,
.detail-content-card,
.shop-empty-state {
    padding: 1.5rem;
}

.filter-header p,
.catalog-toolbar p,
.shop-empty-state p {
    color: var(--muted);
}

.filter-header h3 {
    font-size: clamp(2.1rem, 3vw, 3rem);
    line-height: 0.95;
    margin-bottom: 0.9rem;
}

.shop-filter-form {
    display: grid;
    gap: 1.5rem;
}

.catalog-filter-column {
    max-width: 21rem;
}

.catalog-results-column {
    flex: 1 1 0;
}

.shop-filter-accordion {
    display: grid;
    gap: 0.95rem;
}

.shop-filter-accordion .accordion-item {
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 1.1rem;
    overflow: hidden;
    background: #fafaf8;
}

.shop-filter-accordion .accordion-button {
    background: #fafaf8;
    color: var(--ink);
    font-family: var(--heading-font);
    font-size: 1.08rem;
    font-weight: 700;
    box-shadow: none;
    padding: 1rem 1.1rem;
}

.shop-filter-accordion .accordion-button:not(.collapsed) {
    background: linear-gradient(135deg, rgba(230, 248, 214, 0.94), rgba(249, 253, 243, 0.96));
    color: var(--ink);
}

.shop-filter-accordion .accordion-button:focus {
    box-shadow: none;
    border-color: transparent;
}

.shop-filter-accordion .accordion-body {
    padding: 0.4rem 1rem 1rem;
}

.filter-block h4 {
    font-family: var(--heading-font);
    font-size: 1.15rem;
    margin-bottom: 0.85rem;
}

.filter-list {
    display: grid;
    gap: 0.75rem;
}

.filter-option,
.filter-chip {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.85rem 1rem;
    border-radius: 1rem;
    background: #f8f8f6;
    border: 1px solid rgba(0, 0, 0, 0.06);
    font-size: 0.95rem;
}

.filter-chip.active {
    background: linear-gradient(135deg, #1b2a44, #26395f);
    color: #fff;
}

.filter-option input {
    margin-right: 0.35rem;
}

.catalog-toolbar {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    margin-bottom: 1.5rem;
}

.catalog-toolbar h2 {
    margin-bottom: 0.25rem;
    font-size: clamp(2.2rem, 3vw, 3.25rem);
}

@media (min-width: 1200px) {
    .shop-filter-card {
        padding: 1.25rem;
    }

    .shop-filter-accordion .accordion-button {
        padding: 0.9rem 1rem;
        font-size: 1rem;
    }

    .shop-filter-accordion .accordion-body {
        padding: 0.35rem 0.9rem 0.9rem;
    }

    .filter-option,
    .filter-chip {
        padding: 0.75rem 0.85rem;
        font-size: 0.9rem;
    }

    .shop-product-body {
        padding: 1.2rem;
    }

    .shop-product-body h3 {
        font-size: 1.2rem;
    }

    .shop-card-actions .btn {
        min-height: 3rem;
        font-size: 0.92rem;
    }
}

.shop-product-card {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border-radius: 1.6rem;
    background: #fff;
    border: 1px solid var(--line);
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.07);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.shop-product-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 24px 56px rgba(0, 0, 0, 0.12);
}

.shop-product-media {
    position: relative;
    min-height: 280px;
    background: linear-gradient(180deg, #fafaf8, #f5f5f3);
}

.shop-product-media img {
    width: 100%;
    height: 280px;
    object-fit: cover;
}

.shop-badge-stack {
    position: absolute;
    inset: 1rem auto auto 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.shop-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.45rem 0.8rem;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--gold), #f2d48d);
    color: #111;
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.shop-badge.sale {
    background: linear-gradient(135deg, #d14b3f, #f08962);
    color: #fff;
}

.shop-badge.dark {
    background: linear-gradient(135deg, #111, #333);
    color: #fff;
}

.shop-badge.muted {
    background: linear-gradient(135deg, #6b7280, #9ca3af);
    color: #fff;
}

.shop-product-body {
    padding: 1.4rem;
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    flex: 1;
}

.shop-product-body h3 {
    font-size: 1.4rem;
    margin: 0.35rem 0 0.65rem;
}

.shop-product-body p,
.detail-content-card p {
    color: var(--muted);
}

.shop-product-body p {
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.shop-rating-row,
.detail-rating-row,
.detail-badge-row,
.shop-price-row,
.detail-price-row,
.detail-action-row,
.detail-info-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
}

.shop-rating-row {
    align-items: center;
    color: var(--gold-dark);
    font-weight: 700;
    margin-bottom: 1rem;
}

.shop-rating-row small,
.detail-rating-row span {
    color: var(--muted);
}

.shop-price-row,
.detail-price-row {
    align-items: center;
    justify-content: space-between;
}

.stock-tag,
.stock-line {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 0.45rem 0.8rem;
    font-size: 0.82rem;
    font-weight: 700;
}

.stock-tag.in,
.stock-line.in {
    background: rgba(16, 185, 129, 0.12);
    color: #047857;
}

.stock-tag.out,
.stock-line.out {
    background: rgba(220, 38, 38, 0.1);
    color: #b91c1c;
}

.shop-card-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
    margin-top: auto;
}

.shop-card-actions .btn {
    min-height: 3.2rem;
    padding-inline: 0.85rem;
    white-space: nowrap;
    font-size: 0.98rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    line-height: 1.1;
}

.shop-card-action-form,
.shop-details-btn {
    width: 100%;
}

@media (max-width: 1535.98px) {
    .catalog-shell .container-fluid,
    .product-detail-shell .container,
    .commerce-shell .container,
    .checkout-shell .container,
    .site-footer .container {
        padding-inline: 1rem !important;
    }

    .catalog-filter-column {
        max-width: 17rem;
    }

    .shop-filter-card {
        padding: 1.05rem;
    }

    .filter-header h3 {
        font-size: 1.95rem;
        margin-bottom: 0.65rem;
    }

    .filter-header p {
        font-size: 0.94rem;
        line-height: 1.55;
        margin-bottom: 0;
    }

    .catalog-toolbar {
        padding: 1.2rem 1.35rem;
        margin-bottom: 1.15rem;
    }

    .catalog-toolbar h2 {
        font-size: clamp(1.95rem, 2.4vw, 2.75rem);
    }

    .catalog-toolbar p {
        font-size: 0.95rem;
    }

    .shop-product-media,
    .shop-product-media img {
        min-height: 240px;
        height: 240px;
    }

    .shop-badge-stack {
        inset: 0.8rem auto auto 0.8rem;
        gap: 0.4rem;
    }

    .shop-badge {
        padding: 0.38rem 0.72rem;
        font-size: 0.68rem;
    }

    .shop-product-body {
        padding: 1.05rem;
        gap: 0.72rem;
    }

    .shop-product-body h3 {
        font-size: 1.12rem;
        margin: 0.2rem 0 0.35rem;
    }

    .shop-product-body p {
        font-size: 0.92rem;
    }

    .price {
        font-size: 1.05rem;
    }

    .compare-price {
        font-size: 0.82rem;
    }

    .stock-tag,
    .stock-line {
        padding: 0.36rem 0.65rem;
        font-size: 0.74rem;
    }

    .shop-card-actions .btn {
        min-height: 2.8rem;
        font-size: 0.88rem;
        padding-inline: 0.65rem;
    }
}

@media (max-width: 1199.98px) {
    .catalog-hero {
        padding: 3rem 0 2rem;
    }

    .catalog-hero h1 {
        font-size: clamp(1.9rem, 5vw, 3rem);
    }

    .catalog-shell,
    .product-detail-shell,
    .commerce-shell {
        padding: 2rem 0 3rem;
    }

    .catalog-filter-column {
        max-width: none;
    }

    .shop-filter-card,
    .catalog-toolbar,
    .product-detail-card,
    .product-gallery-card,
    .detail-content-card,
    .shop-empty-state,
    .checkout-panel,
    .order-card,
    .coupon-panel,
    .cart-line-card,
    .wishlist-card,
    .account-panel-card {
        padding: 1rem;
    }

    .shop-filter-form {
        gap: 1rem;
    }

    .shop-filter-accordion {
        gap: 0.75rem;
    }

    .filter-header h3 {
        font-size: 1.8rem;
    }

    .catalog-toolbar {
        gap: 0.75rem;
        align-items: flex-start;
    }

    .catalog-toolbar p {
        max-width: 100%;
    }

    .shop-product-media,
    .shop-product-media img {
        min-height: 220px;
        height: 220px;
    }

    .product-main-image img {
        height: 420px;
    }

    .product-detail-card h1 {
        font-size: clamp(1.85rem, 4vw, 2.8rem);
    }

    .detail-price-row strong {
        font-size: 1.7rem;
    }
}

.shop-empty-state {
    text-align: center;
    padding: 3rem 1.5rem;
}

.shop-pagination-nav {
    margin-top: 2rem;
}

.pagination .page-link {
    color: var(--ink);
    border: 1px solid rgba(0, 0, 0, 0.12);
    padding: 0.75rem 1rem;
}

.pagination .page-item.active .page-link {
    background: #101b2e;
    border-color: #101b2e;
}

.product-gallery-card {
    position: sticky;
    top: 6rem;
}

.product-main-image {
    overflow: hidden;
    border-radius: 1.4rem;
    background: linear-gradient(180deg, #fafaf8, #f5f5f3);
}

.product-main-image img {
    width: 100%;
    height: 540px;
    object-fit: cover;
}

.product-thumb-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.8rem;
    margin-top: 1rem;
}

.product-thumb {
    border: 1px solid rgba(0, 0, 0, 0.12);
    border-radius: 1rem;
    padding: 0;
    overflow: hidden;
    background: transparent;
}

.product-thumb.active {
    border-color: var(--gold);
    box-shadow: 0 10px 22px rgba(201, 169, 110, 0.22);
}

.product-thumb img {
    width: 100%;
    height: 96px;
    object-fit: cover;
}

.product-detail-card h1 {
    font-size: clamp(2.2rem, 4vw, 3.5rem);
    margin-bottom: 1rem;
}

.detail-rating-row {
    align-items: center;
    margin-bottom: 1rem;
}

.detail-badge-row,
.detail-price-row {
    margin-bottom: 1rem;
}

.detail-price-row strong {
    font-size: 2rem;
}

.detail-action-row {
    margin: 1.5rem 0;
}

.detail-info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.info-card {
    padding: 1rem;
}

.variant-group-wrap {
    display: grid;
    gap: 1.25rem;
}

.variant-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.variant-pill input {
    display: none;
}

.variant-pill span {
    display: inline-flex;
    align-items: center;
    padding: 0.85rem 1rem;
    border-radius: 999px;
    border: 1px solid rgba(0, 0, 0, 0.12);
    background: #fff;
    cursor: pointer;
}

.variant-pill input:checked + span {
    background: #101b2e;
    color: #fff;
    border-color: #101b2e;
}

.review-list {
    display: grid;
    gap: 1rem;
}

.review-card {
    padding: 1.25rem;
    border-radius: 1.2rem;
    background: #f8f8f6;
}

.review-meta {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.5rem;
}

.review-stars {
    color: var(--gold-dark);
    font-size: 1.1rem;
    letter-spacing: 0.12em;
    margin-bottom: 0.5rem;
}

.premium-accordion .accordion-item {
    border: 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.premium-accordion .accordion-button {
    background: transparent;
    font-weight: 700;
    box-shadow: none;
}

.premium-accordion .accordion-button:not(.collapsed) {
    color: var(--ink);
}

@media (max-width: 1399.98px) {
    .navbar-collapse {
        margin-top: 1rem;
        padding: 1rem 0 0.5rem;
        border-top: 1px solid rgba(255, 255, 255, 0.08);
    }

    .premium-nav-links {
        margin-top: 0.5rem;
        gap: 0;
        align-items: flex-start !important;
    }

    .premium-nav-links .nav-item + .nav-item::before {
        display: none;
    }

    .premium-nav-links .nav-link {
        padding-inline: 0 !important;
        padding-block: 0.65rem;
    }

    .header-action-row {
        flex-wrap: wrap;
        margin: 1rem 0 0;
        margin-left: 0;
        width: 100%;
        justify-content: flex-start;
    }

    .header-global-search {
        order: -1;
        width: 100%;
        min-width: 0;
    }

    .header-account-nav {
        flex-wrap: wrap;
    }

    .header-account-link,
    .header-account-logout {
        justify-content: center;
    }
}

@media (max-width: 991.98px) {
    .catalog-toolbar {
        flex-direction: column;
        align-items: flex-start;
    }

    .product-gallery-card {
        position: static;
    }

    .catalog-shell .container-fluid,
    .product-detail-shell .container,
    .commerce-shell .container,
    .checkout-shell .container {
        padding-inline: 0.9rem !important;
    }

    .shop-filter-card,
    .catalog-toolbar {
        border-radius: 1.2rem;
    }

    .catalog-toolbar h2 {
        font-size: 1.9rem;
    }

    .shop-product-media,
    .shop-product-media img {
        min-height: 260px;
        height: 260px;
    }

    .cart-line-card,
    .coupon-panel,
    .order-card,
    .wishlist-card {
        border-radius: 1.1rem;
    }
}

@media (max-width: 767.98px) {
    .brand-lockup {
        font-size: 1.55rem;
    }

    .brand-logo-img-header {
        height: 2.6rem;
        max-width: 9.5rem;
    }

    .shop-card-actions,
    .detail-action-row,
    .detail-info-grid {
        grid-template-columns: 1fr;
        flex-direction: column;
    }

    .product-main-image img {
        height: 360px;
    }

    .product-thumb-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .header-action-row {
        gap: 0.7rem;
    }

    .header-global-search {
        padding: 0.35rem 0.35rem 0.35rem 0.8rem;
    }

    .header-global-search-btn {
        padding-inline: 0.85rem;
    }

    .header-icon-btn {
        width: 2.55rem;
        height: 2.55rem;
    }

    .header-account-link.icon-only,
    .header-account-logout.icon-only {
        width: 2.55rem;
        height: 2.55rem;
    }

    .catalog-hero {
        padding: 2.2rem 0 1.6rem;
    }

    .catalog-hero h1 {
        font-size: 1.8rem;
        line-height: 1.06;
    }

    .catalog-hero p,
    .catalog-hero-meta {
        font-size: 0.92rem;
    }

    .catalog-shell,
    .product-detail-shell,
    .commerce-shell {
        padding: 1.5rem 0 2.4rem;
    }

    .filter-header h3 {
        font-size: 1.55rem;
        line-height: 1;
    }

    .catalog-toolbar {
        padding: 0.95rem 1rem;
    }

    .catalog-toolbar h2 {
        font-size: 1.7rem;
    }

    .shop-filter-accordion .accordion-button {
        font-size: 0.95rem;
        padding: 0.85rem 0.95rem;
    }

    .filter-option,
    .filter-chip {
        padding: 0.72rem 0.8rem;
        font-size: 0.88rem;
    }

    .shop-product-media,
    .shop-product-media img {
        min-height: 230px;
        height: 230px;
    }

    .shop-product-body {
        padding: 0.95rem;
    }

    .shop-product-body h3 {
        font-size: 1.05rem;
    }

    .shop-card-actions .btn {
        min-height: 2.65rem;
        font-size: 0.84rem;
    }

    .product-main-image img {
        height: 320px;
    }

    .product-detail-card h1 {
        font-size: 1.65rem;
    }

    .detail-price-row strong {
        font-size: 1.45rem;
    }
}

@media (max-width: 575.98px) {
    .premium-navbar .container,
    .catalog-shell .container-fluid,
    .product-detail-shell .container,
    .commerce-shell .container,
    .checkout-shell .container,
    .site-footer .container {
        padding-inline: 0.75rem !important;
    }

    .brand-lockup {
        font-size: 1.2rem;
        letter-spacing: 0.06em;
    }

    .brand-logo-img-header {
        height: 2.35rem;
        max-width: 8.75rem;
    }

    .catalog-toolbar h2,
    .filter-header h3 {
        font-size: 1.45rem;
    }

    .shop-product-media,
    .shop-product-media img {
        min-height: 210px;
        height: 210px;
    }

    .shop-price-row {
        align-items: flex-start;
    }

    .stock-tag {
        margin-top: 0.35rem;
    }
}
}

.landing-hero {
    position: relative;
    min-height: 100vh;
    padding: 2rem 0 5rem;
    background-position: center;
    background-size: cover;
    overflow: hidden;
}

.landing-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 28% 48%, rgba(255, 255, 255, 0.06), transparent 24%),
        radial-gradient(circle at 68% 28%, rgba(201, 169, 110, 0.08), transparent 22%),
        linear-gradient(135deg, rgba(255, 255, 255, 0.02), transparent 45%);
    pointer-events: none;
}

.landing-hero .container {
    position: relative;
    z-index: 1;
}

.landing-support-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
    align-items: center;
    margin: 1rem 0 4rem;
    color: #fff;
}

.support-item {
    min-width: 12rem;
}

.support-label {
    display: block;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--neon);
    font-weight: 800;
}

.support-item strong {
    display: block;
    font-size: 1.15rem;
}

.landing-hero-grid {
    min-height: calc(100vh - 14rem);
}

.landing-eyebrow {
    color: var(--neon);
}

.landing-title {
    display: flex;
    flex-direction: column;
    gap: 0.1em;
    margin-bottom: 1rem;
    font-size: clamp(3.4rem, 8vw, 6.6rem);
    line-height: 0.92;
    letter-spacing: -0.04em;
    color: #fff;
    text-transform: uppercase;
}

.landing-title .accent {
    color: var(--neon);
}

@media (max-width: 1599.98px) {
    .landing-hero {
        min-height: 88vh;
        padding: 1.5rem 0 3.5rem;
    }

    .landing-hero-grid {
        min-height: calc(88vh - 11rem);
    }

    .landing-support-bar {
        gap: 1.2rem;
        margin: 0.5rem 0 2rem;
    }

    .support-item {
        min-width: 9.5rem;
    }

    .support-label {
        font-size: 0.68rem;
    }

    .support-item strong {
        font-size: 0.95rem;
    }

    .landing-title {
        font-size: clamp(2.85rem, 5.3vw, 4.9rem);
        line-height: 0.95;
    }

    .landing-subtitle {
        font-size: clamp(1.05rem, 1.7vw, 1.55rem);
        margin-bottom: 1.4rem;
    }

    .landing-price {
        margin-bottom: 1.35rem;
    }

    .landing-price strong {
        font-size: clamp(1.55rem, 2.5vw, 2.35rem);
    }

    .landing-price span {
        font-size: clamp(1rem, 1.5vw, 1.35rem);
    }

    .countdown-ring {
        width: 6.75rem;
        height: 6.75rem;
    }

    .countdown-ring strong {
        font-size: 1.7rem;
    }

    .countdown-ring span {
        font-size: 0.72rem;
    }

    .landing-copy {
        font-size: 0.95rem;
        line-height: 1.6;
    }

    .landing-cta-row {
        margin-top: 1.35rem;
    }

    .landing-visual-wrap {
        min-height: 34rem;
    }

    .landing-accent-panel {
        height: 18rem;
    }

    .landing-product-shot {
        width: min(36rem, 100%);
        transform: translate(1.25rem, 0.5rem);
    }

    .landing-product-shot img {
        max-height: 31rem;
    }

    .floating-stat-card {
        transform: scale(0.92);
        transform-origin: center;
    }
}

@media (max-width: 1599.98px) {
    .catalog-hero {
        padding: 4rem 0 2.5rem;
    }

    .catalog-hero h1 {
        font-size: clamp(2rem, 3.8vw, 3.25rem);
    }

    .catalog-shell,
    .product-detail-shell {
        padding: 2.25rem 0 4rem;
    }

    .shop-filter-card,
    .catalog-toolbar,
    .product-detail-card,
    .product-gallery-card,
    .detail-content-card,
    .shop-empty-state {
        padding: 1.2rem;
    }
}

.landing-subtitle {
    max-width: 34rem;
    font-size: clamp(1.25rem, 2.4vw, 2.4rem);
    color: rgba(255, 255, 255, 0.92);
    margin-bottom: 2rem;
}

.landing-price {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 2rem;
}

.landing-price strong {
    color: #fff;
    font-size: clamp(2rem, 4vw, 3.2rem);
    font-weight: 800;
}

.landing-price span {
    color: rgba(255, 255, 255, 0.5);
    text-decoration: line-through;
    font-size: clamp(1.25rem, 2vw, 2rem);
    font-weight: 700;
}

.countdown-ring-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-bottom: 2rem;
}

.countdown-ring {
    display: grid;
    place-items: center;
    width: 8.5rem;
    height: 8.5rem;
    border-radius: 50%;
    border: 4px solid rgba(255, 255, 255, 0.14);
    background:
        radial-gradient(circle at center, rgba(255, 255, 255, 0.06), transparent 58%),
        linear-gradient(135deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.01));
}

.countdown-ring strong {
    font-size: 2.25rem;
    color: #fff;
    line-height: 1;
}

.countdown-ring span {
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.68);
}

.landing-copy {
    max-width: 38rem;
    color: rgba(255, 255, 255, 0.74);
    font-size: 1.05rem;
    line-height: 1.8;
}

.landing-cta-row {
    margin-top: 2rem;
}

.landing-pill-btn,
.landing-pill-btn-dark {
    border-radius: 999px;
    padding-inline: 1.75rem;
}

.landing-socials {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 2rem;
}

.landing-socials a {
    color: rgba(255, 255, 255, 0.76);
    text-decoration: none;
    border-bottom: 1px solid transparent;
}

.landing-socials a:hover {
    color: #fff;
    border-bottom-color: rgba(255, 255, 255, 0.44);
}

.landing-visual-wrap {
    position: relative;
    min-height: 42rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.landing-visual-shadow {
    position: absolute;
    inset: 12% 20% 12% 10%;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.05);
    filter: blur(0.4rem);
}

.landing-accent-panel {
    position: absolute;
    right: -3rem;
    top: 27%;
    width: min(48rem, 95%);
    height: 22rem;
    border-radius: 9rem 0 0 9rem;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.08), transparent 45%),
        linear-gradient(135deg, var(--neon-deep), #8ef44f);
    box-shadow: 0 24px 60px rgba(201, 169, 110, 0.2);
}

.landing-product-shot {
    position: relative;
    z-index: 2;
    width: min(44rem, 100%);
    transform: translate(2rem, 1rem);
}

.landing-product-shot img {
    width: 100%;
    max-height: 40rem;
    object-fit: contain;
    filter: drop-shadow(0 26px 34px rgba(0, 0, 0, 0.24));
}

.floating-stat-card {
    position: absolute;
    right: -1rem;
    z-index: 3;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    align-items: flex-start;
    padding: 1rem 1.15rem;
    border-radius: 1rem;
    color: #fff;
    background: rgba(22, 22, 22, 0.78);
    border: 1px solid rgba(255, 255, 255, 0.08);
    text-decoration: none;
}

.floating-stat-card strong {
    font-size: 1.45rem;
    font-weight: 800;
}

.floating-stat-card span {
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.9rem;
}

.floating-stat-card.top {
    top: 24%;
}

.floating-stat-card.cta {
    top: 39%;
    background: linear-gradient(135deg, #19a34a, #42d46d);
}

.landing-collections-strip,
.landing-featured-products,
.landing-membership-band {
    padding: 5rem 0;
}

.landing-brand-band {
    padding: 5rem 0;
    background: #111;
}

.landing-section-head {
    max-width: 48rem;
    margin-bottom: 2rem;
}

.landing-section-head h2 {
    color: #fff;
    font-size: clamp(2rem, 4vw, 3.4rem);
}

.landing-section-head.dark h2 {
    color: var(--ink);
}

.landing-category-card,
.landing-brand-card,
.landing-product-card,
.landing-membership-card {
    position: relative;
    overflow: hidden;
    border-radius: 1.8rem;
    border: 1px solid rgba(0, 0, 0, 0.08);
    background: #fff;
    box-shadow: 0 18px 46px rgba(0, 0, 0, 0.08);
}

.landing-category-card {
    min-height: 24rem;
    color: #fff;
}

.landing-category-visual {
    position: absolute;
    inset: 0;
    background-position: center;
    background-size: cover;
}

.landing-category-content {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    justify-content: end;
    min-height: 24rem;
    padding: 1.75rem;
    background: linear-gradient(180deg, transparent 20%, rgba(15, 18, 24, 0.82) 100%);
}

.landing-card-kicker {
    display: inline-block;
    margin-bottom: 0.5rem;
    color: var(--neon);
    text-transform: uppercase;
    font-size: 0.78rem;
    letter-spacing: 0.16em;
    font-weight: 800;
}

.landing-category-content p {
    color: rgba(255, 255, 255, 0.74);
}

.landing-brand-card {
    height: 100%;
    padding: 1.5rem 1rem;
    background: rgba(255, 255, 255, 0.98);
}

.landing-product-card {
    display: flex;
    flex-direction: column;
    background: linear-gradient(180deg, #ffffff, #f7f8f7);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.landing-product-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 24px 54px rgba(0, 0, 0, 0.14);
}

.landing-product-visual {
    min-height: 18rem;
    background-position: center;
    background-size: cover;
}

.landing-product-body {
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.landing-product-body p {
    margin-bottom: 0;
}

.landing-product-footer {
    margin-top: auto;
    padding-top: 1.25rem;
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
}

.landing-product-btn {
    min-width: 8.8rem;
    min-height: 3rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    white-space: nowrap;
}

.landing-membership-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
    padding: 2rem;
    background:
        linear-gradient(135deg, rgba(201, 169, 110, 0.14), rgba(201, 169, 110, 0.05)),
        linear-gradient(180deg, #ffffff, #f8faf6);
}

@media (max-width: 991.98px) {
    .landing-support-bar {
        gap: 1rem;
        margin-bottom: 2rem;
    }

    .landing-hero-grid {
        min-height: auto;
    }

    .landing-visual-wrap {
        min-height: 30rem;
    }

    .landing-accent-panel {
        right: 0;
        width: 100%;
        height: 15rem;
        top: 33%;
        border-radius: 4rem;
    }

    .landing-product-shot {
        transform: none;
    }

    .floating-stat-card {
        right: 1rem;
    }

    .landing-membership-card {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 767.98px) {
    .landing-title {
        font-size: clamp(2.8rem, 14vw, 4.2rem);
    }

    .countdown-ring-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .countdown-ring {
        width: 100%;
        height: 7.5rem;
    }

    .landing-visual-wrap {
        min-height: 24rem;
    }

    .landing-accent-panel {
        top: 30%;
        height: 12rem;
        border-radius: 2.5rem;
    }

    .floating-stat-card.top {
        top: 12%;
    }

    .floating-stat-card.cta {
        top: auto;
        bottom: 0;
    }
}

.flash-shell {
    padding-top: 1rem;
}

.flash-banner {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    padding: 1rem 1.2rem;
    border-radius: 1.2rem;
    border: 1px solid rgba(0, 0, 0, 0.08);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.07);
}

.flash-banner.success {
    background: linear-gradient(135deg, rgba(22, 163, 74, 0.14), rgba(255, 255, 255, 0.96));
    color: #166534;
}

.flash-banner.error {
    background: linear-gradient(135deg, rgba(220, 38, 38, 0.12), rgba(255, 255, 255, 0.96));
    color: #991b1b;
}

.motion-card {
    opacity: 0;
    transform: translateY(18px);
    transition: opacity 0.5s ease, transform 0.5s ease, box-shadow 0.3s ease;
}

.motion-card.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.motion-btn {
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.motion-btn:hover,
.motion-btn:focus {
    transform: translateY(-2px);
}

.shop-floating-action {
    position: absolute;
    top: 1rem;
    right: 1rem;
    z-index: 2;
}

.shop-circle-action {
    width: 2.9rem;
    height: 2.9rem;
    border: 0;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: rgba(255, 255, 255, 0.94);
    color: var(--ink);
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.12);
}

.shop-circle-action:hover,
.shop-circle-action:focus {
    background: #101b2e;
    color: #fff;
}

.commerce-shell {
    padding: 3.5rem 0 5rem;
}

.commerce-hero,
.coupon-panel,
.cart-line-card,
.cart-totals-card,
.empty-commerce-state,
.wishlist-card {
    border-radius: 1.8rem;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(0, 0, 0, 0.08);
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.08);
}

.commerce-hero {
    padding: 2.2rem;
    margin-bottom: 2rem;
    background:
        radial-gradient(circle at top right, rgba(201, 169, 110, 0.12), transparent 28%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 250, 246, 0.94));
}

.commerce-hero h1 {
    font-size: clamp(2.2rem, 4vw, 3.5rem);
    margin-bottom: 0.75rem;
}

.commerce-hero p {
    color: var(--muted);
    max-width: 48rem;
    margin-bottom: 0;
}

.commerce-list-shell {
    display: grid;
    gap: 1.25rem;
}

.cart-line-card {
    display: grid;
    grid-template-columns: 12rem minmax(0, 1fr);
    gap: 1.4rem;
    padding: 1.3rem;
}

.cart-line-media {
    border-radius: 1.4rem;
    overflow: hidden;
    background: linear-gradient(180deg, #fafaf8, #f0f0ee);
}

.cart-line-media img {
    width: 100%;
    height: 100%;
    min-height: 12rem;
    object-fit: cover;
}

.cart-line-copy {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 1rem;
}

.cart-line-top,
.cart-line-bottom,
.wishlist-price-row,
.wishlist-action-grid,
.detail-purchase-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

.cart-line-top {
    justify-content: space-between;
    align-items: flex-start;
}

.cart-line-top h3,
.wishlist-card h3 {
    font-size: 1.6rem;
    margin: 0.35rem 0 0.5rem;
}

.cart-remove-btn {
    width: 2.8rem;
    height: 2.8rem;
    border: 0;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.06);
    color: var(--ink);
}

.cart-remove-btn:hover,
.cart-remove-btn:focus {
    background: #111;
    color: #fff;
}

.cart-line-bottom {
    justify-content: space-between;
    align-items: end;
}

.cart-quantity-form {
    display: flex;
    flex-wrap: wrap;
    gap: 0.9rem;
    align-items: center;
}

.detail-purchase-form {
    margin-top: 1.5rem;
}

.detail-purchase-grid {
    align-items: center;
}

.detail-quantity-box {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.4rem;
    border-radius: 999px;
    background: #f5f5f3;
    border: 1px solid rgba(0, 0, 0, 0.08);
}

.quantity-btn {
    width: 2.5rem;
    height: 2.5rem;
    border: 0;
    border-radius: 50%;
    background: #fff;
    color: var(--ink);
    font-size: 1.2rem;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.08);
}

.quantity-input {
    width: 4.5rem;
    border: 0;
    background: transparent;
    text-align: center;
    font-weight: 800;
    color: var(--ink);
}

.quantity-input:focus {
    outline: none;
}

.cart-price-stack {
    text-align: right;
}

.cart-price-stack span,
.cart-applied-coupon p,
.shipping-progress-copy span,
.empty-commerce-state p,
.wishlist-card p,
.coupon-panel p {
    color: var(--muted);
}

.cart-price-stack strong {
    display: block;
    font-size: 1.4rem;
}

.coupon-panel {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 1.5rem;
    align-items: center;
    padding: 1.6rem;
    margin-top: 1.5rem;
}

.coupon-panel h3,
.cart-totals-head h3 {
    margin-bottom: 0.35rem;
}

.coupon-form {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    width: min(32rem, 100%);
}

.coupon-form .form-control {
    flex: 1;
    min-width: 14rem;
    border-radius: 999px;
    border-color: rgba(0, 0, 0, 0.12);
    padding-inline: 1.2rem;
}

.cart-totals-card {
    position: sticky;
    top: 6rem;
    padding: 1.6rem;
    display: grid;
    gap: 1.2rem;
}

.cart-totals-list {
    display: grid;
    gap: 0.9rem;
    margin: 0;
}

.cart-totals-list div {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
}

.cart-totals-list dt,
.cart-totals-list dd {
    margin: 0;
}

.cart-total-grand {
    display: flex;
    justify-content: space-between;
    align-items: end;
    padding-top: 1rem;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.cart-total-grand strong {
    font-size: 1.9rem;
}

.cart-applied-coupon,
.shipping-progress-card {
    display: flex;
    gap: 0.9rem;
    padding: 1rem;
    border-radius: 1.2rem;
    background: #f8f8f6;
}

.cart-applied-coupon i {
    color: #15803d;
    font-size: 1.1rem;
}

.shipping-progress-card {
    flex-direction: column;
    background: #f8f8f6;
}

.summary-note-card {
    padding: 1rem;
    border-radius: 1.2rem;
    background: linear-gradient(135deg, rgba(201, 169, 110, 0.12), rgba(255, 255, 255, 0.95));
}

.summary-note-card strong {
    display: block;
    margin-bottom: 0.2rem;
}

.summary-note-card span {
    color: var(--muted);
}

.order-details-page .order-detail-hero {
    gap: 1.25rem;
}

.order-details-page .order-detail-hero h1 {
    font-size: clamp(2rem, 4vw, 3.35rem);
    line-height: 1.02;
    overflow-wrap: anywhere;
}

.order-details-page .order-detail-actions .btn {
    min-height: 3rem;
    padding-inline: 1rem;
    border-radius: 0.95rem;
    white-space: nowrap;
}

.order-details-page .order-status-strip {
    padding: 1.25rem;
}

.order-details-page .order-status-card {
    min-width: 0;
}

.order-details-page .order-status-card strong {
    line-height: 1.2;
    overflow-wrap: anywhere;
}

.order-details-page .checkout-panel,
.order-details-page .checkout-summary-card {
    padding: 1.65rem;
}

.order-details-page .checkout-panel-head {
    margin-bottom: 1rem;
}

.order-details-page .checkout-panel-head h2,
.order-details-page .checkout-summary-head h3 {
    font-size: clamp(1.65rem, 2vw, 2.35rem);
    line-height: 1.08;
}

.order-details-page .order-item-list {
    gap: 0.85rem;
}

.order-details-page .order-item-card {
    grid-template-columns: 76px minmax(0, 1fr) auto;
    gap: 0.9rem;
    padding: 0.95rem;
}

.order-details-page .address-copy {
    line-height: 1.9;
}

.order-details-page .checkout-total-list {
    gap: 0.95rem;
}

.order-details-page .checkout-total-list div {
    gap: 1rem;
}

.order-details-page .summary-note-card,
.order-details-page .checkout-coupon-chip {
    margin-top: 1rem;
}

@media (min-width: 1200px) {
    .order-details-page .order-details-side .checkout-summary-card {
        position: sticky;
        top: 7rem;
    }
}

.order-history-page {
    background: #f5f5f5;
}

.order-workspace-container {
    width: min(100% - 2rem, 1380px);
    max-width: 1380px;
    margin-inline: auto;
    padding-inline: 0;
}

.order-history-page .row {
    --bs-gutter-x: 2rem;
}

.order-app-view {
    width: 100%;
    margin-inline: auto;
}

.order-app-view .mobile-orders-topbar {
    margin-bottom: 1rem;
}

.order-app-view .mobile-orders-topbar h1 {
    font-size: clamp(1.35rem, 2vw, 1.9rem);
}

.order-app-view .mobile-order-chip-row {
    flex-wrap: wrap;
    overflow: visible;
}

.order-app-view .mobile-order-chip {
    border: 0;
    cursor: pointer;
}

.order-app-view .mobile-order-chip:hover,
.order-app-view .mobile-order-chip:focus-visible {
    color: var(--ink);
    box-shadow: 0 0 0 3px rgba(201, 169, 110, 0.16);
    outline: 0;
}

.order-app-stack {
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 360px), 1fr));
    align-items: start;
}

.order-app-card {
    min-height: 100%;
}

.order-app-card[hidden] {
    display: none !important;
}

.order-app-card .mobile-order-gallery {
    min-height: 92px;
}

.order-app-card .mobile-order-gallery-thumb {
    width: 72px;
    height: 92px;
}

.order-app-product-list {
    display: grid;
    gap: 0.8rem;
}

.order-app-product-row {
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr) auto;
    gap: 0.9rem;
    align-items: center;
    color: inherit;
    padding: 0.7rem;
    border-radius: 1rem;
    background: rgba(0, 0, 0, 0.035);
}

.order-app-product-row:hover {
    color: inherit;
    background: rgba(0, 0, 0, 0.06);
}

.order-app-product-copy {
    min-width: 0;
    display: grid;
    gap: 0.1rem;
}

.order-app-product-copy strong {
    color: var(--ink);
    line-height: 1.25;
}

.order-app-product-copy span,
.order-app-product-copy small {
    color: var(--muted);
    line-height: 1.35;
}

.order-app-product-price {
    text-align: right;
    white-space: nowrap;
}

.order-app-count {
    color: var(--muted);
    font-family: var(--bs-body-font-family);
    font-size: 0.82rem;
    font-weight: 700;
}

.order-app-summary {
    gap: 0.2rem;
}

.order-app-summary span,
.order-app-summary small {
    color: var(--muted);
}

.order-app-summary strong {
    color: var(--ink);
    font-size: 1.05rem;
}

.order-app-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
}

.order-app-actions .btn {
    min-height: 2.65rem;
    border-radius: 0.85rem;
    padding-inline: 1rem;
}

.order-detail-app-view {
    width: 100%;
    margin-inline: auto;
    display: grid;
    gap: 1rem;
}

.order-detail-app-view .mobile-detail-topbar {
    margin-bottom: 0;
}

.rating-star {
    border: 0;
    padding: 0;
    background: transparent;
    color: #d7b54a;
    line-height: 1;
    cursor: pointer;
}

.rating-star i {
    pointer-events: none;
}

.rating-star:hover,
.rating-star.is-selected {
    color: #d39b12;
}

.order-filter-empty {
    margin-top: 1rem;
    padding: 1.25rem;
    border-radius: 1.2rem;
    background: #fff;
    text-align: center;
    color: var(--muted);
}

.order-filter-empty strong {
    display: block;
    color: var(--ink);
    margin-bottom: 0.2rem;
}

@media (min-width: 768px) {
    .order-history-page.account-shell {
        padding-block: 2.5rem 3.5rem;
    }

    .order-details-shell.order-details-page {
        padding-block: 2.5rem 3.5rem;
        background: #f5f5f5;
    }

    .order-workspace-container {
        width: min(100% - 3rem, 1460px);
    }

    .order-history-page .col-xl-3 {
        width: 280px;
        flex: 0 0 280px;
    }

    .order-history-page .col-xl-9 {
        flex: 1 1 0;
        width: auto;
        max-width: none;
    }

    .order-app-view {
        padding: 1.35rem;
        border-radius: 1.75rem;
        background: rgba(255, 255, 255, 0.72);
        box-shadow: 0 22px 50px rgba(0, 0, 0, 0.06);
    }

    .order-app-card {
        padding: 1.2rem;
    }

    .order-history-page .mobile-orders-topbar {
        display: flex;
        align-items: center;
        justify-content: space-between;
    }

    .order-app-stack {
        grid-template-columns: minmax(0, 1fr);
        gap: 0.95rem;
    }

    .order-app-card {
        position: relative;
        grid-template-columns: minmax(420px, 1.5fr) minmax(130px, 0.38fr) minmax(210px, 0.55fr);
        column-gap: 1.4rem;
        row-gap: 0.9rem;
        align-items: center;
        min-height: 142px;
        overflow: hidden;
        transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
    }

    .order-app-card::before {
        content: "";
        position: absolute;
        inset: 0 auto 0 0;
        width: 4px;
        background: linear-gradient(180deg, var(--neon), rgba(201, 169, 110, 0));
        opacity: 0;
        transition: opacity 180ms ease;
    }

    .order-app-card:hover {
        transform: translateY(-3px);
        border-color: rgba(201, 169, 110, 0.28);
        box-shadow: 0 18px 44px rgba(0, 0, 0, 0.12);
    }

    .order-app-card:hover::before {
        opacity: 1;
    }

    .order-app-card .mobile-order-card-head {
        grid-column: 1 / -1;
        display: grid;
        grid-template-columns: max-content minmax(0, 1fr) auto;
        align-items: center;
        gap: 0.7rem;
        padding-bottom: 0.35rem;
        border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    }

    .order-app-card .mobile-order-card-head strong {
        font-family: var(--bs-body-font-family);
        font-size: 0.98rem;
        font-weight: 800;
    }

    .order-app-product-list {
        gap: 0.55rem;
    }

    .order-app-product-row {
        grid-template-columns: 64px minmax(0, 1fr) max-content;
        min-height: 74px;
        padding: 0.55rem 0.65rem;
        border: 1px solid transparent;
    }

    .order-app-card:hover .order-app-product-row {
        border-color: rgba(0, 0, 0, 0.04);
    }

    .order-app-product-row:nth-child(n + 3) {
        display: none;
    }

    .order-app-product-copy strong {
        font-size: 0.95rem;
    }

    .order-app-product-copy span,
    .order-app-product-copy small {
        font-size: 0.82rem;
    }

    .order-app-card .mobile-order-gallery-thumb {
        width: 64px;
        height: 58px;
        border-radius: 0.7rem;
    }

    .order-app-summary {
        align-self: center;
        padding-inline: 0.3rem;
    }

    .order-app-card .mobile-order-feedback {
        align-self: center;
        display: grid;
        justify-items: end;
        gap: 0.45rem;
        font-size: 0.85rem;
        font-weight: 700;
    }

    .order-app-card .mobile-order-stars {
        display: inline-flex;
        gap: 0.16rem;
    }

    .order-app-actions {
        grid-column: 3;
        justify-content: flex-end;
        align-self: start;
    }

    .order-app-actions .btn {
        min-width: 120px;
    }

    .order-detail-app-view {
        grid-template-columns: minmax(0, 1.1fr) minmax(340px, 0.9fr);
        padding: 1.35rem;
        border-radius: 1.75rem;
        background: rgba(255, 255, 255, 0.72);
        box-shadow: 0 22px 50px rgba(0, 0, 0, 0.06);
    }

    .order-detail-app-view .mobile-detail-topbar,
    .order-detail-app-view .mobile-detail-status-banner,
    .order-detail-app-view .mobile-detail-feedback-card,
    .order-detail-app-view .mobile-detail-card:first-of-type,
    .order-detail-app-view .mobile-detail-card:last-child {
        grid-column: 1 / -1;
    }

    .order-detail-app-view .mobile-detail-card {
        box-shadow: none;
    }

    .order-detail-app-view .mobile-detail-item {
        grid-template-columns: 56px minmax(0, 1fr) auto;
    }

    .order-detail-app-view .mobile-detail-item img {
        width: 56px;
        height: 68px;
    }
}

@media (min-width: 768px) and (max-width: 1199.98px) {
    .order-app-card {
        grid-template-columns: minmax(0, 1fr);
    }

    .order-app-card .mobile-order-card-head,
    .order-app-actions {
        grid-column: auto;
    }

    .order-app-card .mobile-order-feedback {
        justify-items: start;
    }
}

@media (max-width: 767.98px) {
    .order-workspace-container {
        width: 100%;
        max-width: 100%;
        padding-inline: 0.9rem;
    }

    .order-app-stack {
        grid-template-columns: minmax(0, 1fr);
    }

    .order-app-count {
        display: none;
    }

    .order-app-view .mobile-order-chip-row {
        flex-wrap: nowrap;
        overflow-x: auto;
    }

    .order-app-card .mobile-order-gallery-thumb {
        width: 56px;
        height: 72px;
    }

    .order-app-product-row {
        grid-template-columns: 56px minmax(0, 1fr) auto;
        padding: 0;
        background: transparent;
    }

    .order-app-actions {
        display: none;
    }

    .order-app-product-price {
        display: none;
    }
}

.shipping-progress.progress {
    height: 0.7rem;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.08);
}

.shipping-progress .progress-bar {
    background: linear-gradient(135deg, var(--neon), var(--gold-light));
}

.empty-commerce-state {
    padding: 3.5rem 2rem;
    text-align: center;
}

.empty-commerce-icon {
    width: 5rem;
    height: 5rem;
    margin: 0 auto 1.2rem;
    border-radius: 1.6rem;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, rgba(201, 169, 110, 0.18), rgba(201, 169, 110, 0.04));
    color: var(--ink);
    font-size: 2rem;
}

.commerce-recommend-strip {
    margin-top: 3rem;
}

.wishlist-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.5rem;
}

.wishlist-card {
    overflow: hidden;
}

.wishlist-card-media {
    min-height: 18rem;
    background: linear-gradient(180deg, #fafaf8, #f5f5f3);
}

.wishlist-card-media img {
    width: 100%;
    height: 18rem;
    object-fit: cover;
}

.wishlist-card-body {
    padding: 1.5rem;
}

.wishlist-action-grid form {
    flex: 1;
}

.detail-inline-form {
    margin-top: 1rem;
}

.detail-wishlist-btn {
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
}

.related-products-stack {
    display: grid;
    gap: 1rem;
}

.related-product-card {
    display: grid;
    grid-template-columns: 6.4rem minmax(0, 1fr);
    gap: 0.95rem;
    align-items: center;
    padding: 0.85rem;
    border-radius: 1.25rem;
    background: #fafaf8;
    border: 1px solid rgba(0, 0, 0, 0.08);
}

.related-product-media {
    display: block;
    border-radius: 1rem;
    overflow: hidden;
    background: linear-gradient(180deg, #fafaf8, #f5f5f3);
}

.related-product-media img {
    width: 100%;
    height: 6.4rem;
    object-fit: cover;
}

.related-product-copy {
    min-width: 0;
}

.related-product-copy h3 {
    margin: 0.25rem 0 0.45rem;
    font-size: 1rem;
    line-height: 1.35;
}

.related-product-copy h3 a {
    color: var(--ink);
}

.related-product-price-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    align-items: center;
    margin-bottom: 0.75rem;
}

.related-product-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
}

.related-cart-form {
    width: 100%;
}

.address-card {
    position: relative;
}

.address-card-head {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: start;
    margin-bottom: 0.9rem;
}

.address-more-btn {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(0, 0, 0, 0.1);
    background: #fff;
}

.address-dropdown-menu {
    min-width: 14rem;
    border-radius: 1rem;
    padding: 0.45rem;
    border: 1px solid rgba(0, 0, 0, 0.08);
    box-shadow: 0 18px 45px rgba(0, 0, 0, 0.14);
}

.address-dropdown-menu .dropdown-item {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    border-radius: 0.75rem;
    padding: 0.7rem 0.8rem;
    background: transparent;
    border: 0;
    width: 100%;
}

.address-dropdown-menu form {
    margin: 0;
}

.account-form-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
}

@media (max-width: 991.98px) {
    .cart-line-card {
        grid-template-columns: 1fr;
    }

    .cart-totals-card {
        position: static;
    }

    .wishlist-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .commerce-shell {
        padding-top: 2rem;
    }

    .cart-line-bottom,
    .cart-quantity-form,
    .coupon-panel,
    .detail-purchase-grid,
    .wishlist-action-grid {
        flex-direction: column;
        align-items: stretch;
    }

    .cart-price-stack {
        text-align: left;
    }

    .coupon-form {
        width: 100%;
    }

    .coupon-form .form-control {
        min-width: 100%;
    }

    .related-product-card,
    .account-form-actions {
        grid-template-columns: 1fr;
    }

    .address-card-head {
        flex-direction: column;
        align-items: stretch;
    }
}

.account-auth-shell,
.account-shell {
    padding: clamp(2.5rem, 4vw, 4.5rem) 0 5rem;
}

.account-auth-card {
    display: grid;
    grid-template-columns: 0.95fr 1.05fr;
    min-height: 42rem;
    overflow: hidden;
    border-radius: 2rem;
    background: rgba(255, 255, 255, 0.95);
    box-shadow: 0 28px 90px rgba(0, 0, 0, 0.16);
}

.account-auth-aside {
    position: relative;
    padding: clamp(2rem, 4vw, 3.5rem);
    display: flex;
    flex-direction: column;
    justify-content: end;
    gap: 1.25rem;
    color: #fff;
    background: #111;
}

.account-auth-aside::before,
.account-overview-hero::before,
.orders-hero::before {
    content: "";
    position: absolute;
    inset: auto -12% -30% auto;
    width: 18rem;
    height: 18rem;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(201, 169, 110, 0.15), transparent 68%);
    pointer-events: none;
}

.auth-kicker,
.account-sidebar-head .eyebrow {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 0.5rem 0.8rem;
    border-radius: 999px;
    background: rgba(201, 169, 110, 0.14);
    color: var(--neon-deep);
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-size: 0.72rem;
    font-weight: 800;
}

.account-auth-aside h1,
.account-overview-hero h1,
.orders-hero h1 {
    font-size: clamp(2.4rem, 5vw, 4.4rem);
    line-height: 0.98;
    margin: 0;
}

.account-auth-aside p,
.account-overview-hero p,
.orders-hero p {
    max-width: 34rem;
    margin: 0;
    color: rgba(255, 255, 255, 0.78);
    font-size: 1.02rem;
}

.account-overview-hero,
.orders-hero {
    position: relative;
    overflow: hidden;
    padding: clamp(1.75rem, 3vw, 2.4rem);
    border-radius: 1.8rem;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.97), rgba(242, 252, 233, 0.9));
    box-shadow: 0 16px 50px rgba(0, 0, 0, 0.08);
}

.account-overview-hero p,
.orders-hero p {
    color: var(--muted);
}

.account-auth-main {
    padding: clamp(1.8rem, 4vw, 3.4rem);
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 1.5rem;
}

@media (max-width: 1535.98px) {
    html {
        font-size: 15px;
    }

    .section-heading {
        margin-bottom: 1.4rem;
    }

    .section-heading h2,
    .detail-content-card > h2 {
        font-size: clamp(1.55rem, 2.4vw, 2.3rem);
        line-height: 1.02;
    }

    .eyebrow,
    .auth-kicker,
    .account-sidebar-head .eyebrow {
        font-size: 0.66rem;
        letter-spacing: 0.14em;
    }

    .product-detail-shell .row.g-5 {
        --bs-gutter-x: 1.6rem;
        --bs-gutter-y: 1.6rem;
    }

    .product-detail-card h1 {
        font-size: clamp(1.95rem, 3vw, 2.8rem);
        line-height: 1.02;
        margin-bottom: 0.7rem;
    }

    .product-detail-card .lead {
        font-size: 0.98rem;
        margin-bottom: 0.85rem;
    }

    .detail-rating-row,
    .detail-badge-row,
    .detail-price-row {
        margin-bottom: 0.75rem;
    }

    .detail-price-row strong {
        font-size: 1.55rem;
    }

    .detail-content-card,
    .product-gallery-card,
    .product-detail-card,
    .checkout-panel,
    .order-card,
    .coupon-panel,
    .cart-line-card,
    .wishlist-card,
    .account-panel-card,
    .account-auth-card,
    .account-overview-hero,
    .orders-hero {
        border-radius: 1.2rem;
    }

    .detail-content-card p,
    .review-card p,
    .order-card p,
    .account-overview-hero p,
    .orders-hero p,
    .account-auth-aside p {
        font-size: 0.95rem;
        line-height: 1.6;
    }

    .related-products-stack {
        gap: 0.8rem;
    }

    .related-product-card {
        grid-template-columns: 5.35rem minmax(0, 1fr);
        gap: 0.8rem;
        padding: 0.75rem;
    }

    .related-product-media img {
        height: 5.35rem;
    }

    .related-product-copy h3 {
        font-size: 0.92rem;
        line-height: 1.25;
    }

    .related-product-price-row {
        margin-bottom: 0.55rem;
    }

    .related-product-actions .btn {
        min-height: 2.5rem;
        font-size: 0.82rem;
        padding-inline: 0.65rem;
    }

    .review-card {
        padding: 1rem;
    }

    .checkout-panel-head h2,
    .account-panel-card h2 {
        font-size: 1.4rem;
    }

    .account-auth-aside h1,
    .account-overview-hero h1,
    .orders-hero h1 {
        font-size: clamp(1.9rem, 3.2vw, 3rem);
    }

    .account-auth-aside,
    .account-auth-main {
        padding: 1.6rem;
    }
}

@media (max-width: 1199.98px) {
    html {
        font-size: 14.5px;
    }

    .section-heading h2,
    .detail-content-card > h2 {
        font-size: 1.45rem;
    }

    .product-detail-card h1 {
        font-size: clamp(1.7rem, 4vw, 2.25rem);
    }

    .product-detail-card .lead,
    .detail-content-card p,
    .review-card p,
    .account-auth-aside p,
    .account-overview-hero p,
    .orders-hero p {
        font-size: 0.92rem;
    }

    .detail-price-row strong {
        font-size: 1.4rem;
    }

    .related-product-card {
        grid-template-columns: 4.9rem minmax(0, 1fr);
    }

    .related-product-media img {
        height: 4.9rem;
    }

    .account-auth-card {
        grid-template-columns: 1fr;
        min-height: auto;
    }
}

@media (max-width: 767.98px) {
    html {
        font-size: 14px;
    }

    .section-heading h2,
    .detail-content-card > h2 {
        font-size: 1.32rem;
    }

    .product-detail-card h1 {
        font-size: 1.55rem;
    }

    .detail-content-card,
    .product-gallery-card,
    .product-detail-card,
    .checkout-panel,
    .order-card,
    .coupon-panel,
    .cart-line-card,
    .wishlist-card,
    .account-panel-card,
    .account-auth-card,
    .account-overview-hero,
    .orders-hero {
        border-radius: 1rem;
    }

    .related-product-card {
        grid-template-columns: 4.5rem minmax(0, 1fr);
        padding: 0.65rem;
    }

    .related-product-media img {
        height: 4.5rem;
    }

    .related-product-copy h3 {
        font-size: 0.88rem;
    }

    .related-product-actions .btn {
        min-height: 2.3rem;
        font-size: 0.78rem;
    }

    .account-auth-aside h1,
    .account-overview-hero h1,
    .orders-hero h1 {
        font-size: 1.65rem;
    }
}

.account-auth-head {
    display: grid;
    gap: 0.55rem;
}

.account-auth-head h2 {
    margin: 0;
    font-size: clamp(1.8rem, 3vw, 2.4rem);
}

.account-auth-head p,
.account-auth-foot,
.account-panel-copy,
.address-copy {
    color: var(--muted);
}

.account-auth-form {
    display: grid;
    gap: 1rem;
}

.account-auth-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.account-password-actions,
.auth-footer-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    align-items: center;
    justify-content: space-between;
}

.account-password-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: stretch;
}

.account-password-actions .btn {
    width: 100%;
    min-height: 3.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    white-space: normal;
    line-height: 1.25;
    padding-inline: 0.9rem;
    font-size: 0.98rem;
}

.auth-primary-btn {
    width: 100%;
    min-height: 3.75rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    border-radius: 0.75rem;
    color: #fff !important;
    background: #111 !important;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
    border: 0;
}

.auth-primary-btn:hover,
.auth-primary-btn:focus {
    background: linear-gradient(135deg, #000, #222) !important;
    color: #fff !important;
    box-shadow: 0 18px 38px rgba(22, 139, 132, 0.3);
}

.auth-center-link {
    font-size: 0.96rem;
    color: #5b6678;
}

.auth-center-link:hover {
    color: var(--neon-deep);
}

.auth-inline-btn {
    border: 0;
    background: transparent;
    color: var(--gold-dark);
    font-weight: 700;
    padding: 0;
}

.auth-inline-btn:hover {
    color: #0e6761;
}

.auth-forgot-link {
    font-size: 0.98rem;
}

.account-inline-button {
    border: 0;
    background: transparent;
    padding: 0;
    font: inherit;
    cursor: pointer;
}

.account-inline-link {
    color: var(--ink);
    font-weight: 700;
    text-decoration: none;
}

.account-inline-link:hover {
    color: var(--neon-deep);
}

.auth-provider-stack {
    display: grid;
    gap: 0.85rem;
}

.auth-provider-btn {
    width: 100%;
    border: 1px solid rgba(24, 113, 108, 0.16);
    background: #fff;
    border-radius: 1.1rem;
    padding: 1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    font-weight: 700;
    color: #53657d;
    box-shadow: 0 10px 24px rgba(16, 24, 40, 0.04);
    transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.auth-provider-btn:hover:not(:disabled) {
    transform: translateY(-2px);
    border-color: rgba(22, 139, 132, 0.28);
    box-shadow: 0 14px 28px rgba(22, 139, 132, 0.09);
}

.auth-provider-btn.disabled {
    opacity: 0.55;
}

.account-sidebar {
    position: sticky;
    top: 6.2rem;
    padding: 1.4rem;
    border-radius: 1.6rem;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 14px 40px rgba(0, 0, 0, 0.08);
}

.account-sidebar-head {
    display: grid;
    gap: 0.45rem;
    margin-bottom: 1.15rem;
}

.account-sidebar-head h3 {
    margin: 0;
    font-size: 1.55rem;
}

.account-nav {
    display: grid;
    gap: 0.7rem;
}

.account-nav-link {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    padding: 0.95rem 1rem;
    border-radius: 1rem;
    color: var(--ink);
    text-decoration: none;
    background: rgba(247, 249, 251, 0.95);
    border: 1px solid transparent;
    transition: transform 180ms ease, border-color 180ms ease, background 180ms ease, color 180ms ease;
}

.account-nav-link:hover,
.account-nav-link.is-active {
    transform: translateX(4px);
    color: var(--ink);
    border-color: rgba(201, 169, 110, 0.42);
    background: linear-gradient(135deg, rgba(201, 169, 110, 0.16), rgba(255, 255, 255, 0.98));
}

.account-stat-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin: 1.2rem 0 1.4rem;
}

.account-stat-card {
    padding: 1.2rem 1.3rem;
    border-radius: 1.4rem;
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.06);
}

.account-stat-card span,
.order-card-metrics span,
.saved-address-grid .status-pill {
    color: var(--muted);
}

.account-stat-card strong {
    display: block;
    margin-top: 0.45rem;
    font-size: 2rem;
}

.saved-address-grid,
.account-orders-grid,
.account-wishlist-grid {
    display: grid;
    gap: 1.1rem;
}

.saved-address-grid {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.saved-address-grid .checkout-panel,
.account-orders-grid .order-card,
.account-wishlist-grid .wishlist-card {
    margin: 0;
}

.account-address-form {
    gap: 1.15rem;
}

.account-address-switches {
    display: flex;
    flex-wrap: wrap;
    gap: 1.25rem;
}

.account-form-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
}

.account-form-actions .btn {
    width: 100%;
    min-height: 3.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.order-card-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.9rem;
    margin: 1rem 0;
    padding: 0.95rem 1rem;
    border-radius: 1rem;
    background: rgba(247, 249, 251, 0.92);
}

.order-card-metrics strong {
    display: block;
    margin-top: 0.28rem;
}

.wishlist-price-row {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    margin: 0.8rem 0 1.2rem;
}

.wishlist-price-row .price {
    font-size: 1.35rem;
}

.wishlist-price-row .compare-price {
    text-decoration: line-through;
    color: var(--muted);
}

.validation-summary-errors ul {
    margin: 0;
    padding-left: 1rem;
}

.account-panel-card {
    padding: 1.4rem;
    border-radius: 1.4rem;
    background: rgba(255, 255, 255, 0.95);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.06);
}

.account-message-shell {
    padding: 4rem 0 5rem;
}

.account-message-card {
    max-width: 42rem;
    margin: 0 auto;
    padding: clamp(2rem, 5vw, 3rem);
    border-radius: 2rem;
    text-align: center;
    background: rgba(255, 255, 255, 0.95);
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.1);
}

.account-message-icon {
    width: 4.8rem;
    height: 4.8rem;
    margin: 0 auto 1.25rem;
    border-radius: 1.5rem;
    display: grid;
    place-items: center;
    font-size: 1.7rem;
    color: var(--ink);
    background: linear-gradient(135deg, rgba(201, 169, 110, 0.22), rgba(255, 255, 255, 0.96));
}

@media (max-width: 1199.98px) {
    .account-auth-card {
        grid-template-columns: 1fr;
    }

    .account-sidebar {
        position: static;
    }
}

@media (max-width: 991.98px) {
    .account-stat-grid,
    .order-card-metrics {
        grid-template-columns: 1fr;
    }

    .account-form-actions {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .account-auth-row {
        flex-direction: column;
        align-items: flex-start;
    }

    .account-password-actions,
    .auth-footer-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .related-product-actions {
        grid-template-columns: 1fr;
    }

    .account-auth-main,
    .account-auth-aside,
    .account-overview-hero,
    .orders-hero {
        padding: 1.4rem;
    }

    .account-shell,
    .account-auth-shell {
        padding-top: 1.75rem;
    }

    .landing-product-footer {
        flex-direction: column;
        align-items: stretch;
    }

    .landing-product-btn {
        width: 100%;
    }
}

.mobile-orders-topbar,
.mobile-detail-topbar {
    display: grid;
    gap: 0.2rem;
    margin-bottom: 1rem;
}

.mobile-orders-topbar h1,
.mobile-detail-topbar h1 {
    margin: 0;
    font-size: 1.4rem;
    font-weight: 800;
}

.mobile-orders-topbar p,
.mobile-detail-topbar p {
    margin: 0;
    color: var(--muted);
    font-size: 0.92rem;
}

.mobile-order-chip-row {
    display: flex;
    gap: 0.6rem;
    overflow-x: auto;
    padding-bottom: 0.2rem;
    margin-bottom: 1rem;
    scrollbar-width: none;
}

.mobile-order-chip-row::-webkit-scrollbar {
    display: none;
}

.mobile-order-chip {
    flex: 0 0 auto;
    padding: 0.6rem 0.95rem;
    border-radius: 999px;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.08);
    color: var(--muted);
    font-size: 0.82rem;
    font-weight: 700;
}

.mobile-order-chip.active {
    background: rgba(0, 0, 0, 0.08);
    color: var(--ink);
}

.mobile-orders-stack,
.mobile-detail-item-list,
.mobile-detail-actions {
    display: grid;
    gap: 0.9rem;
}

.mobile-order-card,
.mobile-detail-card {
    display: grid;
    gap: 0.9rem;
    padding: 1rem;
    border-radius: 1.35rem;
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid rgba(0, 0, 0, 0.06);
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.06);
    color: inherit;
}

.mobile-order-card-head,
.mobile-detail-status-head,
.mobile-detail-card-head,
.mobile-detail-list div,
.mobile-order-product,
.mobile-detail-item {
    display: flex;
    gap: 0.8rem;
    justify-content: space-between;
    align-items: flex-start;
}

.mobile-order-card-head strong,
.mobile-detail-status-head strong,
.mobile-detail-card-head h2 {
    margin: 0;
}

.mobile-order-card-head div,
.mobile-order-copy,
.mobile-detail-item-copy {
    min-width: 0;
    display: grid;
    gap: 0.15rem;
}

.mobile-order-card-head span,
.mobile-order-copy span,
.mobile-order-copy small,
.mobile-detail-item-copy span,
.mobile-detail-item-copy small,
.mobile-detail-note span,
.mobile-detail-status span {
    color: var(--muted);
}

.mobile-order-pill {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    background: rgba(201, 169, 110, 0.12);
    color: var(--neon-deep);
    font-size: 0.74rem;
    font-weight: 800;
    white-space: nowrap;
}

.mobile-order-thumb,
.mobile-detail-item img {
    width: 64px;
    height: 64px;
    border-radius: 1rem;
    overflow: hidden;
    flex: 0 0 auto;
    background: rgba(0, 0, 0, 0.04);
}

.mobile-order-thumb img,
.mobile-detail-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mobile-order-copy strong,
.mobile-detail-item-copy strong,
.mobile-detail-address strong {
    color: var(--ink);
}

.mobile-order-total,
.mobile-detail-item-price {
    text-align: right;
    display: grid;
    gap: 0.2rem;
    flex: 0 0 auto;
}

.mobile-order-total span {
    color: var(--muted);
    font-size: 0.82rem;
    font-weight: 700;
}

.mobile-detail-address {
    margin: 0;
    color: var(--muted);
    line-height: 1.75;
}

.mobile-detail-list {
    display: grid;
    gap: 0;
    margin: 0;
}

.mobile-detail-list div {
    padding: 0.8rem 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.mobile-detail-list div:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.mobile-detail-list dt,
.mobile-detail-list dd {
    margin: 0;
}

.mobile-detail-list dt {
    color: var(--muted);
}

.mobile-detail-list dd {
    color: var(--ink);
    font-weight: 700;
    text-align: right;
}

.mobile-detail-list-price .total dt,
.mobile-detail-list-price .total dd {
    font-size: 1.02rem;
    font-weight: 800;
}

.mobile-detail-note {
    display: grid;
    gap: 0.15rem;
    padding: 0.85rem 0.95rem;
    border-radius: 1rem;
    background: linear-gradient(135deg, rgba(201, 169, 110, 0.12), rgba(255, 255, 255, 0.95));
}

.mobile-detail-actions .btn {
    min-height: 2.9rem;
    border-radius: 0.95rem;
}

@media (max-width: 767.98px) {
    .order-history-page,
    .order-details-page {
        background: #f5f5f5;
    }

    .order-history-page .container,
    .order-details-page .container {
        max-width: 100%;
        padding-inline: 0.9rem;
    }

    .orders-shell.order-history-page,
    .order-details-shell.order-details-page {
        padding: 1.15rem 0 2rem;
    }

    .mobile-order-card-head strong,
    .mobile-detail-status-head strong,
    .mobile-detail-card-head h2 {
        font-size: 1rem;
    }

    .mobile-order-card-head span,
    .mobile-order-copy span,
    .mobile-order-copy small,
    .mobile-detail-item-copy span,
    .mobile-detail-item-copy small,
    .mobile-detail-address,
    .mobile-detail-list dt,
    .mobile-detail-list dd,
    .mobile-detail-note span {
        font-size: 0.86rem;
    }

    .mobile-order-total strong,
    .mobile-detail-item-price strong {
        font-size: 0.96rem;
    }

    .mobile-orders-view,
    .mobile-order-details-view {
        padding-top: 0.2rem;
    }

    .mobile-orders-topbar h1,
    .mobile-detail-topbar h1 {
        font-size: 1.3rem;
        font-weight: 700;
    }

    .mobile-order-card,
    .mobile-detail-card {
        gap: 0.85rem;
        padding: 0.95rem;
        border-radius: 1.2rem;
        box-shadow: none;
    }

    .mobile-order-card-head {
        align-items: center;
    }

    .mobile-order-card-head strong {
        font-size: 1rem;
        font-weight: 700;
    }

    .mobile-order-gallery {
        display: flex;
        gap: 0.55rem;
        overflow-x: auto;
        scrollbar-width: none;
    }

    .mobile-order-gallery::-webkit-scrollbar {
        display: none;
    }

    .mobile-order-gallery-thumb {
        width: 56px;
        height: 72px;
        border-radius: 0.7rem;
        overflow: hidden;
        flex: 0 0 auto;
        background: #fff;
        border: 1px solid rgba(0, 0, 0, 0.06);
    }

    .mobile-order-gallery-thumb img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .mobile-order-feedback {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.8rem;
        font-size: 0.85rem;
        font-weight: 600;
    }

    .mobile-order-stars {
        display: inline-flex;
        align-items: center;
        gap: 0.2rem;
        color: #e1b63f;
        font-size: 0.92rem;
        flex: 0 0 auto;
    }

    .mobile-detail-status-banner strong {
        color: var(--gold-dark);
        font-size: 1.02rem;
    }

    .mobile-detail-feedback-card {
        grid-template-columns: auto 1fr;
        align-items: center;
        gap: 0.8rem;
    }

    .mobile-detail-feedback-icon {
        width: 2.9rem;
        height: 2.9rem;
        border-radius: 0.9rem;
        background: rgba(13, 163, 255, 0.1);
        color: #2d99d4;
        display: grid;
        place-items: center;
        font-size: 1.1rem;
        flex: 0 0 auto;
    }

    .mobile-detail-feedback-copy {
        display: grid;
        gap: 0.35rem;
        min-width: 0;
    }

    .mobile-detail-card-head {
        align-items: center;
    }

    .mobile-detail-card-head h2 {
        font-size: 0.98rem;
        font-weight: 700;
    }

    .mobile-detail-card-head i {
        color: var(--muted);
        font-size: 0.95rem;
    }

    .mobile-detail-item {
        display: grid;
        grid-template-columns: 44px minmax(0, 1fr) auto;
        gap: 0.7rem;
        align-items: start;
    }

    .mobile-detail-item img {
        width: 44px;
        height: 56px;
        border-radius: 0.55rem;
        border: 1px solid rgba(0, 0, 0, 0.06);
    }

    .mobile-detail-item-copy strong {
        font-size: 0.9rem;
        line-height: 1.3;
        font-weight: 600;
    }

    .mobile-detail-item-copy span,
    .mobile-detail-item-copy small {
        font-size: 0.76rem;
        line-height: 1.35;
    }

    .mobile-detail-item-price {
        gap: 0.05rem;
        min-width: 3.6rem;
    }

    .mobile-detail-item-price strong {
        font-size: 0.88rem;
        font-weight: 700;
    }

    .mobile-detail-item-price span {
        color: var(--muted);
        font-size: 0.72rem;
    }

    .mobile-detail-address {
        font-size: 0.84rem;
        line-height: 1.7;
    }

    .mobile-detail-list div {
        padding: 0.72rem 0;
        gap: 0.8rem;
    }

    .mobile-detail-list dt,
    .mobile-detail-list dd {
        font-size: 0.82rem;
    }

    .mobile-detail-download {
        min-height: 3rem;
        border-radius: 0.95rem;
        border-style: dashed;
        color: #0f8ec7;
        border-color: rgba(15, 142, 199, 0.45);
        background: #fff;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-weight: 700;
    }
}

/* ─── LUXURY POLISH LAYER ─── */

::selection {
    background: rgba(201, 169, 110, 0.25);
    color: #111;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--heading-font);
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.1;
}

.form-control:focus {
    border-color: rgba(201, 169, 110, 0.5) !important;
    box-shadow: 0 0 0 0.2rem rgba(201, 169, 110, 0.1) !important;
}

.checkout-switch input:checked + span::before {
    background: var(--gold) !important;
}

.shop-product-card {
    transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94),
                box-shadow 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.shop-product-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.08);
}

.shop-product-media img {
    transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.shop-product-card:hover .shop-product-media img {
    transform: scale(1.05);
}

.product-card:hover,
.category-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
}

.landing-category-card {
    transition: transform 0.4s ease, box-shadow 0.4s ease;
}

.landing-category-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.12);
}

.account-nav-link:hover,
.account-nav-link.is-active {
    border-color: rgba(201, 169, 110, 0.4);
    background: linear-gradient(135deg, rgba(201, 169, 110, 0.08), rgba(255, 255, 255, 0.98));
}

.mobile-order-pill {
    background: rgba(201, 169, 110, 0.12);
    color: var(--gold-dark);
}

.status-pill {
    background: rgba(201, 169, 110, 0.12);
    color: var(--gold-dark);
}

.order-app-card:hover {
    border-color: rgba(201, 169, 110, 0.2);
}

.order-app-card::before {
    background: linear-gradient(180deg, var(--gold), rgba(201, 169, 110, 0)) !important;
}

.shipping-progress .progress-bar {
    background: linear-gradient(135deg, var(--gold), var(--gold-light)) !important;
}

/* Smooth page transition overlay */
.page-transition {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: #111;
    transform: scaleY(0);
    transform-origin: bottom;
    pointer-events: none;
}

/* Luxury loading shimmer */
@keyframes shimmer {
    0% { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}

.skeleton-loader {
    background: linear-gradient(90deg, #f0f0ee 25%, #e8e8e6 50%, #f0f0ee 75%);
    background-size: 200% 100%;
    animation: shimmer 1.5s ease-in-out infinite;
    border-radius: var(--premium-radius-sm);
}

/* 2026-05 responsive compact cleanup */
.editorial-page,
.support-page,
.cms-page,
.status-page {
    padding-top: clamp(1.75rem, 4vw, 3rem) !important;
    padding-bottom: clamp(2.25rem, 5vw, 4rem) !important;
}

.editorial-page h1,
.support-page h1,
.cms-page h1,
.status-page h1,
.admin-panel h1,
.checkout-panel h1,
.empty-commerce-state h2,
.order-success-card h1,
.order-detail-hero h1,
.mobile-orders-topbar h1,
.mobile-detail-topbar h1 {
    font-size: clamp(1.85rem, 3.2vw, 2.95rem);
    line-height: 1.04;
}

.editorial-page h2,
.support-page h2,
.cms-page h2,
.status-page h2,
.checkout-panel h2,
.cart-totals-card h3,
.coupon-panel h3,
.admin-panel-header h3,
.account-auth-head h2,
.mobile-detail-card-head h2 {
    font-size: clamp(1.3rem, 2.2vw, 2rem);
    line-height: 1.12;
}

.editorial-page h3,
.support-page h3,
.cms-page h3,
.status-page h3,
.landing-product-card h3,
.wishlist-card h3,
.order-card h3,
.cart-line-copy h3,
.related-product-copy h3 {
    font-size: clamp(1.05rem, 1.65vw, 1.45rem);
    line-height: 1.18;
}

.lead,
.editorial-page .lead,
.cms-page .lead,
.status-page .lead,
.support-page .lead,
.product-detail-card .lead,
.commerce-hero p,
.checkout-hero p,
.orders-hero p,
.account-overview-hero p,
.account-auth-aside p {
    font-size: clamp(0.98rem, 1.45vw, 1.18rem);
    line-height: 1.6;
}

.cms-content,
.cms-content p,
.review-card p,
.checkout-panel p,
.order-card p,
.wishlist-card p,
.cart-line-copy p,
.stack-item small,
.support-page .text-muted,
.editorial-page .text-muted,
.cms-page .text-muted,
.status-page .text-muted {
    font-size: 0.96rem;
    line-height: 1.65;
}

.cms-content h2,
.cms-content h3,
.cms-content h4 {
    line-height: 1.15;
}

.cms-content h2 {
    font-size: clamp(1.35rem, 2vw, 1.9rem);
}

.cms-content h3 {
    font-size: clamp(1.15rem, 1.6vw, 1.45rem);
}

.btn-lg,
.shop-card-actions .btn,
.detail-action-row .btn,
.order-success-actions .btn,
.account-password-actions .btn {
    min-height: 2.9rem;
    padding: 0.72rem 1.1rem;
    font-size: 0.92rem;
}

.form-control-lg,
.form-select-lg {
    min-height: calc(2.85rem + 2px);
    padding: 0.72rem 0.95rem;
    font-size: 0.96rem;
}

.checkout-panel,
.checkout-summary-card,
.checkout-guest-card,
.order-card,
.invoice-card,
.order-status-strip,
.checkout-submit-bar,
.cart-totals-card,
.coupon-panel,
.cart-line-card,
.wishlist-card,
.account-panel-card,
.admin-panel,
.order-success-card,
.empty-commerce-state {
    border-radius: 1.35rem;
}

.commerce-hero,
.checkout-hero,
.orders-hero,
.order-detail-hero,
.invoice-toolbar,
.account-overview-hero {
    padding: 1.7rem;
}

.commerce-hero h1,
.checkout-hero h1,
.orders-hero h1 {
    font-size: clamp(1.85rem, 3vw, 2.7rem);
}

.section-heading {
    margin-bottom: 1.35rem;
}

.section-heading h2,
.detail-content-card > h2 {
    font-size: clamp(1.45rem, 2.6vw, 2.2rem);
    line-height: 1.06;
}

.detail-content-card,
.product-detail-card,
.product-gallery-card {
    padding: 1.2rem;
}

.product-main-image img {
    height: 460px;
}

.product-thumb img {
    height: 82px;
}

.product-detail-card h1 {
    font-size: clamp(1.95rem, 3.2vw, 2.9rem);
    margin-bottom: 0.8rem;
}

.detail-price-row strong {
    font-size: 1.7rem;
}

.detail-action-row,
.detail-purchase-grid {
    gap: 0.75rem;
}

.detail-quantity-box {
    min-height: 2.9rem;
}

.related-products-stack {
    gap: 0.85rem;
}

.related-product-card {
    grid-template-columns: 7rem minmax(0, 1fr);
    gap: 0.9rem;
    padding: 0.9rem;
}

.related-product-media img {
    height: 7rem;
}

.related-product-copy .price {
    font-size: 1.1rem;
}

.related-product-actions {
    gap: 0.55rem;
}

.related-product-actions .btn {
    min-height: 2.55rem;
    font-size: 0.84rem;
    padding-inline: 0.85rem;
}

.cart-line-card {
    grid-template-columns: 10.5rem minmax(0, 1fr);
    gap: 1.1rem;
    padding: 1.05rem;
}

.cart-line-copy h3,
.wishlist-card h3,
.order-card h3 {
    margin-bottom: 0.35rem;
}

.cart-line-media,
.wishlist-card-media,
.order-card-media {
    border-radius: 1rem;
}

.wishlist-card-media,
.wishlist-card-media img {
    min-height: 15rem;
    height: 15rem;
}

.wishlist-card-body {
    padding: 1.1rem;
}

.checkout-panel-head h2,
.checkout-summary-head h3 {
    margin-bottom: 0.3rem;
}

.checkout-field-grid {
    gap: 0.85rem;
}

.saved-address-card,
.shipping-method-card,
.payment-option-card,
.address-card {
    padding: 0.95rem;
    border-radius: 1rem;
}

.account-stat-grid {
    gap: 0.9rem;
}

.account-stat-card {
    padding: 1rem 1.1rem;
}

.account-stat-card strong {
    font-size: clamp(1.35rem, 2.2vw, 2rem);
}

.account-shell .checkout-panel,
.orders-shell .order-card,
.commerce-shell .cart-line-card,
.commerce-shell .coupon-panel {
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.06);
}

.auth-modal-dialog {
    max-width: min(62rem, calc(100vw - 2rem));
}

.auth-modal-aside,
.auth-modal-main {
    padding: 1.6rem;
}

.auth-modal-aside h2 {
    font-size: clamp(1.6rem, 2.4vw, 2.3rem);
    line-height: 1.08;
}

.auth-panel-head h3 {
    font-size: 1.3rem;
}

.auth-panel-head p,
.auth-register-note,
.auth-provider-note {
    font-size: 0.95rem;
}

.landing-hero {
    min-height: 82vh;
    padding: 1.25rem 0 3rem;
}

.landing-hero .container {
    max-width: min(1180px, calc(100% - 1.5rem));
}

.hero-content {
    max-width: 50rem;
}

.hero-title {
    font-size: clamp(2.3rem, 4.8vw, 4.7rem) !important;
    line-height: 0.98 !important;
}

.hero-desc {
    font-size: clamp(0.98rem, 1.5vw, 1.18rem) !important;
    line-height: 1.55;
    margin-bottom: 2rem !important;
}

.hero-btn {
    padding: 0.8rem 1.5rem !important;
}

.py-6 {
    padding-top: clamp(3rem, 6vw, 5rem) !important;
    padding-bottom: clamp(3rem, 6vw, 5rem) !important;
}

.editorial-page form.d-flex.gap-2 {
    flex-wrap: wrap;
}

.editorial-page .form-control,
.support-page .form-control,
.status-page .form-control {
    min-height: 2.75rem;
}

@media (max-width: 1535.98px) {
    .landing-hero {
        min-height: 76vh;
    }

    .hero-title {
        font-size: clamp(2.05rem, 4.2vw, 3.85rem) !important;
    }

    .hero-desc {
        font-size: 1rem !important;
        max-width: 34rem !important;
    }

    .display-3,
    .display-4 {
        font-size: clamp(2.2rem, 4vw, 3.35rem);
    }

    .display-5,
    .display-6 {
        font-size: clamp(1.75rem, 3vw, 2.55rem);
    }

    .landing-product-visual {
        min-height: 15rem;
    }

    .support-page .admin-panel,
    .cms-page .admin-panel,
    .editorial-page .admin-panel,
    .status-page .admin-panel {
        padding: 1.2rem !important;
    }
}

@media (max-width: 1199.98px) {
    .product-main-image img {
        height: 380px;
    }

    .product-detail-card h1 {
        font-size: clamp(1.75rem, 3.6vw, 2.45rem);
    }

    .section-heading h2,
    .detail-content-card > h2 {
        font-size: clamp(1.3rem, 2.3vw, 1.85rem);
    }

    .cart-line-card {
        grid-template-columns: 8.25rem minmax(0, 1fr);
    }

    .wishlist-card-media,
    .wishlist-card-media img {
        min-height: 13rem;
        height: 13rem;
    }

    .commerce-hero,
    .checkout-hero,
    .orders-hero,
    .account-overview-hero {
        padding: 1.35rem;
    }

    .commerce-hero h1,
    .checkout-hero h1,
    .orders-hero h1,
    .account-overview-hero h1 {
        font-size: clamp(1.65rem, 3.1vw, 2.3rem);
    }

    .account-auth-aside h1 {
        font-size: clamp(1.7rem, 3.3vw, 2.45rem);
    }

    .landing-title,
    .display-3,
    .display-4 {
        font-size: clamp(1.95rem, 4vw, 2.9rem);
    }

    .display-5,
    .display-6 {
        font-size: clamp(1.5rem, 3vw, 2rem);
    }

    .py-6 {
        padding-top: clamp(2.5rem, 5vw, 4rem) !important;
        padding-bottom: clamp(2.5rem, 5vw, 4rem) !important;
    }
}

@media (max-width: 991.98px) {
    .cart-line-card {
        grid-template-columns: 1fr;
    }

    .cart-line-media img {
        width: 100%;
        height: 14rem;
        object-fit: cover;
    }

    .detail-content-card,
    .product-detail-card,
    .product-gallery-card,
    .admin-panel,
    .checkout-panel,
    .order-card,
    .wishlist-card,
    .coupon-panel,
    .cart-totals-card {
        padding: 1rem;
    }

    .related-product-card {
        grid-template-columns: 6rem minmax(0, 1fr);
    }

    .related-product-media img {
        height: 6rem;
    }

    .editorial-page .row.g-5,
    .support-page .row.g-4,
    .cms-page .row.g-5 {
        --bs-gutter-y: 1.25rem;
    }

    .auth-modal-dialog {
        max-width: calc(100vw - 1rem);
        margin: 0.5rem auto;
    }
}

@media (max-width: 767.98px) {
    .editorial-page,
    .support-page,
    .cms-page,
    .status-page {
        padding-top: 1.25rem !important;
        padding-bottom: 2rem !important;
    }

    .hero-title,
    .display-3,
    .display-4 {
        font-size: clamp(1.75rem, 8vw, 2.4rem) !important;
    }

    .display-5,
    .display-6,
    .section-heading h2,
    .detail-content-card > h2,
    .commerce-hero h1,
    .checkout-hero h1,
    .orders-hero h1,
    .account-overview-hero h1,
    .product-detail-card h1 {
        font-size: clamp(1.35rem, 6vw, 1.9rem) !important;
    }

    .lead,
    .hero-desc,
    .product-detail-card .lead {
        font-size: 0.96rem !important;
    }

    .btn-lg,
    .shop-card-actions .btn,
    .detail-action-row .btn,
    .related-product-actions .btn {
        min-height: 2.6rem;
        font-size: 0.84rem;
        padding: 0.62rem 0.85rem;
    }

    .form-control-lg,
    .form-select-lg {
        min-height: calc(2.65rem + 2px);
        font-size: 0.92rem;
        padding: 0.62rem 0.8rem;
    }

    .product-main-image img {
        height: 300px;
    }

    .product-thumb img {
        height: 74px;
    }

    .wishlist-card-media,
    .wishlist-card-media img {
        min-height: 12rem;
        height: 12rem;
    }

    .account-stat-grid,
    .order-success-actions,
    .account-password-actions {
        gap: 0.7rem;
    }

    .order-success-actions .btn,
    .account-password-actions .btn {
        width: 100%;
    }

    .auth-modal-aside,
    .auth-modal-main {
        padding: 1rem;
    }

    .auth-modal-aside h2 {
        font-size: 1.45rem;
    }
}

@media (max-width: 575.98px) {
    .editorial-page .d-flex.justify-content-between,
    .support-page .admin-panel-header,
    .status-page .order-success-actions {
        gap: 0.75rem;
    }

    .related-product-card {
        grid-template-columns: 1fr;
    }

    .related-product-media img {
        width: 100%;
        height: 11rem;
    }

    .cart-line-media img {
        height: 12rem;
    }

    .wishlist-card-media,
    .wishlist-card-media img,
    .landing-product-visual {
        min-height: 11rem;
        height: 11rem;
    }

.hero-btn,
.order-success-actions .btn,
.support-page .btn-lg,
.status-page .btn-lg {
    width: 100%;
}
}

/* Compact auth popup */
.auth-modal-dialog {
    max-width: min(44rem, calc(100vw - 2rem));
}

.auth-modal-content {
    border-radius: 1.2rem;
}

.auth-modal-shell {
    grid-template-columns: minmax(190px, 0.56fr) minmax(0, 1fr);
    min-height: 470px;
}

.auth-modal-aside {
    padding: 1.3rem 1rem;
}

.auth-modal-aside::after {
    inset: 0.7rem;
    border-radius: 0.95rem;
}

.auth-kicker {
    font-size: 0.72rem;
    letter-spacing: 0.16em;
}

.auth-modal-aside h2 {
    margin-top: 0.7rem;
    font-size: clamp(1.18rem, 1.8vw, 1.65rem);
    line-height: 1.06;
}

.auth-modal-aside p {
    margin-top: 0.55rem;
    font-size: 0.82rem;
    line-height: 1.45;
}

.auth-feature-list {
    gap: 0.5rem;
    margin-top: 1rem;
}

.auth-feature-list div {
    gap: 0.55rem;
    padding: 0.55rem 0.65rem;
    border-radius: 0.75rem;
}

.auth-feature-list i {
    width: 1.7rem;
    height: 1.7rem;
    border-radius: 0.6rem;
    font-size: 0.8rem;
}

.auth-feature-list span {
    font-size: 0.8rem;
}

.auth-modal-main {
    padding: 1rem;
}

.auth-close-btn {
    top: 0.8rem;
    right: 0.8rem;
    width: 2.2rem;
    height: 2.2rem;
}

.auth-tab-switcher,
.auth-method-switcher {
    gap: 0.25rem;
    padding: 0.22rem;
}

.auth-tab-btn,
.auth-method-btn {
    padding: 0.55rem 0.8rem;
    font-size: 0.86rem;
}

.auth-panel {
    margin-top: 0.8rem;
}

.auth-panel-head h3 {
    margin-bottom: 0.25rem;
    font-size: 1rem;
}

.auth-panel-head p,
.auth-register-note,
.auth-provider-note {
    font-size: 0.8rem;
    line-height: 1.4;
}

.auth-form {
    margin-top: 0.7rem;
}

.auth-field-grid {
    gap: 0.65rem;
}

.auth-field span {
    font-size: 0.76rem;
}

.auth-field .form-control {
    min-height: 2.6rem;
    border-radius: 0.85rem;
    padding: 0.6rem 0.75rem;
    font-size: 0.88rem;
}

.auth-form-footer {
    gap: 0.55rem;
    margin-top: 0.7rem;
}

.auth-checkbox,
.auth-forgot-link {
    font-size: 0.79rem;
}

.auth-primary-btn,
.auth-form .btn-lg {
    min-height: 2.55rem;
    padding: 0.62rem 0.9rem;
    font-size: 0.84rem;
}

.auth-provider-stack {
    gap: 0.5rem;
    margin-top: 0.7rem;
}

.auth-provider-btn {
    padding: 0.65rem 0.85rem;
    border-radius: 0.85rem;
    font-size: 0.82rem;
}

@media (max-width: 1199.98px) {
    .auth-modal-dialog {
        max-width: min(40rem, calc(100vw - 1.25rem));
    }

    .auth-modal-shell {
        grid-template-columns: minmax(170px, 0.5fr) minmax(0, 1fr);
        min-height: 430px;
    }

    .auth-modal-aside {
        padding: 1rem 0.85rem;
    }

    .auth-modal-main {
        padding: 0.9rem;
    }

    .auth-modal-aside h2 {
        font-size: 1.1rem;
    }

    .auth-feature-list span {
        font-size: 0.76rem;
    }
}

@media (max-width: 991.98px) {
    .auth-modal-dialog {
        max-width: min(31rem, calc(100vw - 0.9rem));
    }

    .auth-modal-shell {
        grid-template-columns: 1fr;
        min-height: auto;
    }

    .auth-modal-aside {
        display: none;
    }

    .auth-modal-main {
        padding: 1rem;
    }
}

/* Home category strip compact fix */
.home-category-card {
    border-radius: var(--premium-radius-md);
    min-height: 21rem;
    background: #111;
}

.home-category-bg {
    min-height: 21rem;
    background-size: cover;
    background-position: center;
    transition: transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.home-category-overlay {
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    pointer-events: none;
    background: linear-gradient(180deg, rgba(10, 10, 10, 0.04) 0%, rgba(10, 10, 10, 0.22) 44%, rgba(10, 10, 10, 0.84) 100%);
}

.home-category-content {
    padding: 1.35rem;
}

.home-category-content h3 {
    font-family: var(--heading-font);
    font-size: clamp(1.6rem, 2.2vw, 2.3rem);
    line-height: 1.04;
}

.home-category-content p {
    max-width: 30rem;
    font-size: 0.98rem;
    line-height: 1.45;
}

.home-category-content .explore-text {
    font-size: 0.74rem;
    letter-spacing: 0.1em;
    transform: translateY(8px);
    transition: all 0.4s ease;
}

@media (max-width: 1535.98px) {
    .home-category-card,
    .home-category-bg {
        min-height: 18rem;
    }

    .home-category-content {
        padding: 1.1rem;
    }

    .home-category-content h3 {
        font-size: clamp(1.35rem, 2vw, 1.9rem);
    }

    .home-category-content p {
        font-size: 0.9rem;
    }
}

@media (max-width: 1199.98px) {
    .home-category-card,
    .home-category-bg {
        min-height: 16rem;
    }

    .home-category-content h3 {
        font-size: 1.45rem;
    }
}

@media (max-width: 767.98px) {
    .home-category-card,
    .home-category-bg {
        min-height: 14rem;
    }

    .home-category-content {
        padding: 0.95rem;
    }

    .home-category-content h3 {
        font-size: 1.2rem;
    }

    .home-category-content p {
        font-size: 0.84rem;
    }
}

/* ─── Festival season welcome banner ─── */
body.festival-season-banner-open {
    overflow: hidden;
}

.festival-season-banner {
    position: fixed;
    inset: 0;
    z-index: 1090;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    pointer-events: none;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.4s ease, visibility 0.4s;
}

.festival-season-banner.is-visible {
    pointer-events: auto;
    opacity: 1;
    visibility: visible;
}

.festival-season-banner.is-dismissed {
    display: none;
}

.festival-season-banner__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(10, 8, 6, 0.72);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    cursor: pointer;
}

.festival-season-banner__panel {
    position: relative;
    z-index: 1;
    max-width: 28rem;
    width: 100%;
    padding: 2.25rem 2rem 2rem;
    background: linear-gradient(155deg, #1f1410 0%, #12100e 45%, #1a120c 100%);
    border: 1px solid rgba(201, 169, 110, 0.35);
    border-radius: 0.35rem;
    box-shadow:
        0 28px 80px rgba(0, 0, 0, 0.55),
        0 0 0 1px rgba(255, 255, 255, 0.04) inset;
    color: #f5f0e8;
    text-align: center;
    transform: translateY(14px) scale(0.97);
    opacity: 0;
    transition:
        transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94),
        opacity 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.festival-season-banner.is-visible .festival-season-banner__panel {
    transform: translateY(0) scale(1);
    opacity: 1;
}

.festival-season-banner__close {
    position: absolute;
    top: 0.65rem;
    right: 0.65rem;
    width: 2.25rem;
    height: 2.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    border-radius: 0.25rem;
    background: rgba(255, 255, 255, 0.06);
    color: rgba(245, 240, 232, 0.85);
    font-size: 1.35rem;
    line-height: 1;
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease;
}

.festival-season-banner__close:hover {
    background: rgba(201, 169, 110, 0.25);
    color: #fff;
}

.festival-season-banner__eyebrow {
    font-family: var(--heading-font, "Playfair Display", serif);
    font-size: 0.68rem;
    letter-spacing: 0.38em;
    text-transform: uppercase;
    color: var(--gold, #c9a96e);
    margin: 0 0 0.85rem;
}

.festival-season-banner__title {
    font-family: var(--heading-font, "Playfair Display", serif);
    font-size: clamp(1.55rem, 4vw, 2rem);
    font-weight: 600;
    line-height: 1.2;
    margin: 0 0 1rem;
    color: #faf6ef;
}

.festival-season-banner__text {
    font-size: 0.95rem;
    line-height: 1.65;
    color: rgba(245, 240, 232, 0.78);
    margin: 0 0 1.5rem;
}

.festival-season-banner__text strong {
    color: var(--gold-light, #e8d5b0);
    font-weight: 600;
}

.festival-season-banner__actions {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    align-items: stretch;
}

@media (min-width: 480px) {
    .festival-season-banner__actions {
        flex-direction: row;
        justify-content: center;
        align-items: center;
    }
}

.festival-season-banner__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.72rem 1.35rem;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    text-decoration: none;
    border-radius: 0.25rem;
    cursor: pointer;
    border: 1px solid transparent;
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
    font-family: var(--bs-body-font-family, "Inter", sans-serif);
}

.festival-season-banner__btn--primary {
    background: linear-gradient(180deg, #d4b878 0%, #c9a96e 50%, #b08d4f 100%);
    color: #1a1208;
    border-color: rgba(255, 255, 255, 0.12);
}

.festival-season-banner__btn--primary:hover {
    background: linear-gradient(180deg, #e8d5b0 0%, #d4b878 100%);
    color: #120a04;
}

.festival-season-banner__btn--ghost {
    background: transparent;
    color: rgba(245, 240, 232, 0.88);
    border-color: rgba(201, 169, 110, 0.35);
}

.festival-season-banner__btn--ghost:hover {
    background: rgba(201, 169, 110, 0.12);
    border-color: rgba(201, 169, 110, 0.55);
    color: #fff;
}

/* Flipkart-inspired customer account experience */
.flip-account-dropdown {
    min-width: 21rem;
    padding: 0.7rem;
    border: 1px solid rgba(15, 23, 42, 0.12);
    border-radius: 0.5rem;
    box-shadow: 0 20px 48px rgba(15, 23, 42, 0.18);
}

.flip-account-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.8rem 0.9rem 0.95rem;
    border-bottom: 1px solid rgba(15, 23, 42, 0.1);
    margin-bottom: 0.35rem;
}

.flip-account-avatar {
    width: 2.8rem;
    height: 2.8rem;
    display: grid;
    place-items: center;
    border-radius: 50%;
    color: #B72CDB;
    background: rgba(183, 44, 219, 0.08);
    border: 1px solid rgba(183, 44, 219, 0.24);
}

.flip-account-dropdown .dropdown-item {
    min-height: 2.55rem;
    gap: 0.85rem;
    font-weight: 500;
}

.header-more-menu {
    min-width: 13.5rem;
    border-radius: 0.25rem;
    border: 1px solid rgba(15, 23, 42, 0.1);
    box-shadow: 0 16px 36px rgba(15, 23, 42, 0.16);
}

.header-more-menu .dropdown-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-height: 2.6rem;
    font-size: 0.86rem;
}

.header-more-menu .dropdown-item i {
    color: #2874f0;
}

.flip-profile-shell,
.flip-orders-shell {
    background: #f1f3f6;
    padding: 1.4rem 0 4rem;
}

.flip-profile-shell .container,
.flip-orders-shell .order-workspace-container {
    max-width: 1260px;
}

.flip-account-sidebar {
    position: sticky;
    top: 6rem;
    padding: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.flip-account-user-card,
.flip-account-nav-group,
.flip-account-main-link,
.flip-account-visited {
    background: #fff;
    border: 1px solid #e0e0e0;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

.flip-account-user-card {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    min-height: 4.6rem;
    padding: 0.85rem 1rem;
    margin-bottom: 0.75rem;
}

.flip-account-user-card span:not(.flip-account-user-avatar) {
    display: block;
    color: #6b7280;
    font-size: 0.78rem;
}

.flip-account-user-card strong {
    color: #111827;
    font-size: 0.95rem;
}

.flip-account-user-avatar {
    width: 2.7rem;
    height: 2.7rem;
    border-radius: 50%;
    display: grid;
    place-items: center;
    flex: 0 0 auto;
    color: #fff;
    font-weight: 800;
    background: linear-gradient(135deg, #facc15, #38bdf8);
}

.flip-account-sidebar .account-nav {
    gap: 0;
}

.flip-account-main-link {
    min-height: 3.9rem;
    display: grid;
    grid-template-columns: 1.5rem minmax(0, 1fr) auto;
    align-items: center;
    gap: 1rem;
    padding: 0 1.15rem;
    margin-bottom: -1px;
    color: #4b5563;
    font-weight: 700;
    text-decoration: none;
}

.flip-account-main-link i:first-child,
.flip-account-nav-heading i {
    color: #2874f0;
    font-size: 1.1rem;
}

.flip-account-main-link.is-active,
.flip-account-main-link:hover {
    color: #2874f0;
}

.flip-account-nav-group {
    padding: 0.95rem 0 0.8rem;
    margin-bottom: -1px;
}

.flip-account-nav-heading {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0 1.15rem 0.85rem;
    color: #71717a;
    font-size: 0.83rem;
    font-weight: 800;
}

.flip-account-sidebar .account-nav-link {
    display: flex;
    justify-content: space-between;
    padding: 0.68rem 1.15rem 0.68rem 3.65rem;
    border: 0;
    border-radius: 0;
    color: #111827;
    background: transparent;
    font-size: 0.88rem;
    font-weight: 500;
    text-decoration: none;
    box-shadow: none;
}

.flip-account-sidebar .account-nav-link:hover,
.flip-account-sidebar .account-nav-link.is-active {
    transform: none;
    color: #2874f0;
    background: #f5faff;
}

.flip-green {
    color: #16a34a;
    font-weight: 700;
}

.flip-account-logout-form {
    margin: 0;
}

.flip-account-main-link.flip-logout {
    width: 100%;
    border: 1px solid #e0e0e0;
    color: #71717a;
    text-align: left;
}

.flip-account-visited {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem 0.8rem;
    padding: 0.9rem 1rem;
    margin-top: 0.75rem;
    font-size: 0.75rem;
}

.flip-account-visited strong {
    width: 100%;
    color: #111827;
}

.flip-account-visited a {
    color: #6b7280;
    text-decoration: none;
}

.flip-profile-panel {
    min-height: 44rem;
    padding: 1.55rem 2rem;
    background: #fff;
    border: 1px solid #e0e0e0;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

.flip-profile-section {
    max-width: 54rem;
    margin-bottom: 2rem;
}

.flip-section-title {
    display: flex;
    align-items: baseline;
    gap: 1rem;
    margin-bottom: 1.15rem;
}

.flip-section-title h1,
.flip-section-title h2,
.flip-profile-section h2 {
    margin: 0;
    color: #111827;
    font-size: 1.08rem;
    font-weight: 700;
}

.flip-section-title h1 {
    font-size: 1.15rem;
}

.flip-edit-link {
    border: 0;
    background: transparent;
    color: #2874f0;
    font-weight: 700;
    padding: 0;
}

.flip-field-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
    max-width: 30rem;
}

.flip-profile-form .form-control,
.flip-password-form .form-control {
    max-width: 30rem;
    min-height: 3rem;
    border-radius: 0;
    border-color: #d7d7d7;
    background: #fafafa;
    color: #374151;
    font-size: 0.9rem;
}

.flip-profile-form .form-control:not([readonly]) {
    background: #fff;
    border-color: #2874f0;
}

.flip-single-input {
    max-width: 15rem !important;
}

.flip-gender-block {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1.25rem;
    max-width: 22rem;
    margin-top: 1.3rem;
    color: #6b7280;
    font-size: 0.86rem;
}

.flip-gender-block > span {
    width: 100%;
    flex-basis: 100%;
    color: #111827;
    font-size: 0.82rem;
}

.flip-profile-actions,
.flip-password-form,
.flip-faq-list {
    display: grid;
    gap: 0.8rem;
}

.flip-profile-actions {
    grid-template-columns: max-content max-content;
    margin-top: 1rem;
}

.flip-quick-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
    max-width: 32rem;
}

.flip-quick-stats a {
    display: grid;
    gap: 0.25rem;
    padding: 0.9rem 1rem;
    color: #111827;
    text-decoration: none;
    background: #f8fafc;
    border: 1px solid #e5e7eb;
}

.flip-quick-stats span {
    color: #6b7280;
    font-size: 0.78rem;
}

.flip-quick-stats strong {
    font-size: 1.35rem;
}

.flip-faq-list {
    margin: 1rem 0 1.2rem;
}

.flip-faq-list strong {
    display: block;
    color: #111827;
    font-size: 0.84rem;
    margin-bottom: 0.45rem;
}

.flip-faq-list p {
    margin: 0;
    color: #374151;
    font-size: 0.84rem;
    line-height: 1.55;
}

.flip-blue-link,
.flip-red-link {
    display: block;
    width: fit-content;
    margin-top: 1rem;
    padding: 0;
    border: 0;
    background: transparent;
    text-decoration: none;
    font-size: 0.85rem;
}

.flip-link-form {
    width: fit-content;
}

.flip-blue-link {
    color: #2874f0;
}

.flip-red-link {
    color: #e11d48;
}

.flip-orders-layout {
    display: grid;
    grid-template-columns: 15rem minmax(0, 1fr);
    gap: 1rem;
    align-items: start;
}

.flip-order-filter,
.flip-order-search,
.flip-order-row {
    background: #fff;
    border: 1px solid #e0e0e0;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

.flip-order-filter {
    position: sticky;
    top: 6rem;
}

.flip-order-filter h2 {
    margin: 0;
    padding: 0.9rem 1rem;
    color: #111827;
    font-size: 1.1rem;
    font-weight: 800;
    border-bottom: 1px solid #f0f0f0;
}

.flip-filter-group {
    display: grid;
    gap: 0.75rem;
    padding: 0.95rem 1rem;
    border-bottom: 1px solid #f0f0f0;
}

.flip-filter-group strong {
    color: #111827;
    font-size: 0.78rem;
}

.flip-filter-group label {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    color: #111827;
    font-size: 0.84rem;
}

.flip-order-content {
    display: grid;
    gap: 0.75rem;
}

.flip-order-search {
    display: grid;
    grid-template-columns: minmax(0, 1fr) max-content;
    min-height: 3rem;
}

.flip-order-search input {
    border: 0;
    padding: 0 1rem;
    outline: 0;
    font-size: 0.9rem;
}

.flip-order-search .btn {
    border-radius: 0;
    padding-inline: 1.25rem;
    font-weight: 700;
}

.flip-order-list {
    display: grid;
    gap: 0.5rem;
}

.flip-order-row {
    display: grid;
    grid-template-columns: minmax(20rem, 1fr) 9rem minmax(16rem, 0.65fr);
    gap: 1.2rem;
    align-items: start;
    min-height: 6rem;
    padding: 1rem 1.2rem;
    transition: box-shadow 0.2s ease;
}

.flip-order-row:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

.flip-order-product {
    display: grid;
    grid-template-columns: 4.5rem minmax(0, 1fr);
    gap: 1rem;
    color: #111827;
    text-decoration: none;
}

.flip-order-thumb {
    width: 4.5rem;
    height: 4.5rem;
    display: grid;
    place-items: center;
    background: #f8fafc;
}

.flip-order-thumb img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.flip-order-copy {
    display: grid;
    align-content: start;
    gap: 0.35rem;
    min-width: 0;
}

.flip-order-copy strong {
    color: #111827;
    font-size: 0.9rem;
    font-weight: 600;
    line-height: 1.35;
}

.flip-order-copy small,
.flip-order-status small {
    color: #71717a;
    font-size: 0.78rem;
}

.flip-order-price strong {
    color: #111827;
    font-size: 0.9rem;
}

.flip-order-status {
    display: grid;
    gap: 0.45rem;
}

.flip-order-status strong {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: #111827;
    font-size: 0.88rem;
}

.flip-order-status strong span {
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 50%;
    background: #26a541;
}

.flip-order-status a {
    color: #2874f0;
    font-size: 0.82rem;
    font-weight: 600;
    text-decoration: none;
}

.flip-order-status a i {
    margin-right: 0.35rem;
}

.flip-account-page-panel {
    min-height: 29rem;
    padding: 1.55rem 1.8rem;
    background: #fff;
    border: 1px solid #e0e0e0;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

.flip-account-page-panel h1 {
    margin: 0 0 1.25rem;
    color: #111827;
    font-size: 1.1rem;
    font-weight: 800;
}

.flip-account-page-panel h2 {
    color: #111827;
    font-size: 1rem;
    font-weight: 800;
}

.flip-pan-form {
    display: grid;
    gap: 0.75rem;
    max-width: 43rem;
}

.flip-pan-form > .form-control,
.flip-file-field {
    width: 17rem;
    min-height: 2.85rem;
    border-radius: 0;
    border: 1px solid #cfd8e3;
    font-size: 0.84rem;
}

.flip-file-field {
    display: grid;
    align-content: center;
    padding: 0.45rem 0.65rem;
}

.flip-file-field span {
    color: #71717a;
    font-size: 0.72rem;
}

.flip-declaration {
    display: grid;
    grid-template-columns: max-content minmax(0, 1fr);
    gap: 0.65rem;
    max-width: 45rem;
    margin-top: 0.55rem;
    color: #111827;
    font-size: 0.86rem;
    line-height: 1.55;
}

.flip-pan-form .btn-primary {
    width: 5.2rem;
    margin-top: 0.75rem;
    border-radius: 0.1rem;
    font-size: 0.8rem;
    font-weight: 800;
}

.flip-gift-head,
.flip-gift-buy-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.flip-gift-head div {
    display: flex;
    gap: 1.4rem;
}

.flip-gift-head a,
.flip-gift-buy-head a,
.flip-gift-head a,
.flip-inline-link,
.flip-help-note a {
    color: #005bea;
    text-decoration: none;
    font-weight: 700;
    font-size: 0.84rem;
}

.flip-add-gift {
    width: 100%;
    min-height: 3.4rem;
    display: flex;
    align-items: center;
    gap: 1.1rem;
    margin: 0.75rem 0 3rem;
    padding: 0 1.2rem;
    border: 1px solid #d7d7d7;
    background: #fff;
    color: #005bea;
    font-weight: 800;
    text-align: left;
}

.flip-gift-buy-head {
    margin-bottom: 0.9rem;
}

.flip-gift-buy-head span {
    color: #71717a;
    font-size: 0.75rem;
    font-style: italic;
}

.flip-gift-box {
    border: 1px solid #d7d7d7;
    background: #eff6fd;
}

.flip-gift-tabs {
    display: flex;
    background: #fff;
    border-bottom: 1px solid #d7d7d7;
}

.flip-gift-tabs a {
    padding: 0.85rem 1.2rem;
    color: #374151;
    text-decoration: none;
    font-weight: 700;
    border-bottom: 3px solid transparent;
}

.flip-gift-tabs a.is-active {
    color: #2874f0;
    border-bottom-color: #2874f0;
}

.flip-gift-personal {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 23rem;
    gap: 1rem;
    padding: 0.9rem 1rem 1.2rem;
}

.flip-gift-fields,
.flip-corporate-form {
    display: grid;
    gap: 0.9rem;
}

.flip-gift-fields .form-control,
.flip-gift-fields .form-select,
.flip-corporate-form .form-control,
.flip-corporate-form .form-select,
.flip-gift-modal .form-control {
    min-height: 2.85rem;
    border-radius: 0;
    border-color: #d7d7d7;
    font-size: 0.86rem;
}

.flip-card-select-row,
.flip-corporate-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem;
}

.flip-gift-fields textarea {
    min-height: 5.3rem;
    resize: none;
}

.flip-inline-link {
    width: fit-content;
    border: 0;
    background: transparent;
    padding: 0;
}

.flip-gift-preview {
    position: relative;
    min-height: 15.5rem;
    padding: 1.8rem;
    color: #fff;
    overflow: hidden;
    border-radius: 0.35rem;
    background: #2874f0;
}

.flip-gift-preview span,
.flip-gift-preview em {
    display: block;
    font-weight: 800;
}

.flip-gift-preview strong {
    display: block;
    font-size: 2.2rem;
}

.flip-gift-preview em {
    position: absolute;
    top: 1.6rem;
    right: 1.7rem;
    font-style: normal;
    font-size: 1.3rem;
}

.flip-gift-packages {
    position: absolute;
    inset: auto 1.5rem 1rem 1.5rem;
    display: flex;
    justify-content: space-around;
    color: #facc15;
    font-size: 2rem;
}

.flip-orange-btn {
    width: fit-content;
    min-width: 11rem;
    margin-top: 0.9rem;
    border: 0;
    border-radius: 0.12rem;
    background: #fb641b;
    color: #fff;
    font-weight: 800;
}

.flip-orange-btn:hover {
    background: #e85b18;
    color: #fff;
}

.flip-corporate-form {
    padding: 1.4rem;
}

.flip-help-note {
    display: grid;
    gap: 0.25rem;
    font-size: 0.78rem;
}

.flip-gift-summary,
.flip-add-payment-form,
.flip-submitted-reviews,
.flip-persisted-note {
    display: grid;
    gap: 0.7rem;
    margin: 1rem 0 1.4rem;
}

.flip-gift-summary {
    grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
}

.flip-gift-summary div,
.flip-persisted-note,
.flip-submitted-reviews article {
    padding: 0.85rem 1rem;
    border: 1px solid #d7d7d7;
    background: #f8fafc;
}

.flip-gift-summary strong,
.flip-gift-summary span,
.flip-persisted-note strong,
.flip-persisted-note span {
    display: block;
    font-size: 0.84rem;
}

.flip-gift-summary span,
.flip-persisted-note span,
.flip-muted {
    color: #71717a;
}

.flip-page-faq {
    display: grid;
    gap: 0.7rem;
    max-width: 46rem;
    margin-top: 2.6rem;
}

.flip-page-faq p {
    margin: 0 0 0.4rem;
    color: #111827;
    font-size: 0.84rem;
    line-height: 1.55;
}

.flip-gift-modal .modal-content {
    width: 24rem;
    margin: 0 auto;
    padding: 2rem 2.25rem;
    border: 0;
    border-radius: 0.15rem;
}

.flip-gift-modal .btn-close {
    position: absolute;
    top: 0.15rem;
    right: -2.4rem;
    filter: invert(1);
    opacity: 1;
}

.flip-gift-modal form {
    display: grid;
    gap: 0.9rem;
}

.flip-gift-modal h2,
.flip-gift-modal p {
    margin: 0;
}

.flip-saved-payment-row,
.flip-card-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    max-width: 46rem;
    min-height: 5.4rem;
    padding: 1.05rem 1.35rem;
    border: 1px solid #d7d7d7;
}

.flip-saved-payment-row div,
.flip-card-row div {
    display: grid;
    gap: 0.9rem;
}

.flip-saved-payment-row span,
.flip-card-row span {
    color: #111827;
    font-size: 0.9rem;
}

.flip-saved-payment-row b {
    color: #2874f0;
    font-size: 0.7rem;
    margin-right: 1.2rem;
}

.flip-saved-payment-row button,
.flip-card-row button,
.flip-wishlist-row button {
    border: 0;
    background: transparent;
    color: #b9b9b9;
}

.flip-add-payment-form {
    max-width: 28rem;
    margin-top: 1.2rem;
}

.flip-add-payment-form .form-control,
.flip-review-form .form-control,
.flip-review-form .form-select,
.flip-review-form textarea {
    min-height: 2.65rem;
    border-radius: 0;
    border-color: #d7d7d7;
    font-size: 0.85rem;
}

.flip-add-payment-form .btn,
.flip-pref-save {
    width: fit-content;
    border-radius: 0.12rem;
    font-weight: 800;
}

.flip-checkbox-line {
    display: flex;
    gap: 0.55rem;
    align-items: center;
    font-size: 0.84rem;
}

.flip-card-list {
    max-width: 46rem;
    border: 1px solid #d7d7d7;
}

.flip-card-row {
    max-width: none;
    border: 0;
    border-bottom: 1px solid #d7d7d7;
}

.flip-card-row:last-child {
    border-bottom: 0;
}

.flip-card-row a {
    margin-left: 1.2rem;
    color: #005bea;
    text-decoration: none;
    font-size: 0.78rem;
    font-weight: 800;
}

.flip-coupon-panel {
    max-width: 47rem;
    padding-inline: 1.55rem;
}

.flip-coupon-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 10rem;
    gap: 1rem;
    padding: 1.2rem 1rem;
    border-top: 1px solid #d7d7d7;
}

.flip-coupon-row strong {
    color: #16a34a;
    font-size: 0.92rem;
}

.flip-coupon-row p,
.flip-coupon-row span,
.flip-coupon-row a {
    margin: 0.75rem 0 0;
    color: #111827;
    font-size: 0.8rem;
}

.flip-coupon-row a {
    display: block;
    color: #005bea;
    text-decoration: none;
    font-weight: 700;
    text-align: right;
}

.flip-empty-large {
    min-height: 30rem;
    display: grid;
    place-items: center;
    align-content: center;
    text-align: center;
    background: #fff;
    border: 1px solid #e0e0e0;
}

.flip-empty-illustration {
    width: 8.5rem;
    height: 5.5rem;
    display: grid;
    place-items: center;
    margin-bottom: 1.3rem;
    color: #ef4444;
    font-size: 2rem;
    background: linear-gradient(135deg, transparent 40%, #facc15 40% 55%, #2874f0 55%);
}

.flip-empty-large h1 {
    margin: 0 0 0.55rem;
    color: #111827;
    font-size: 1.1rem;
    font-weight: 800;
}

.flip-empty-large p {
    margin: 0;
    color: #111827;
    font-size: 0.82rem;
}

.flip-review-strip {
    margin-top: 0.85rem;
    padding: 1.35rem 1.6rem;
    background: #fff;
    border: 1px solid #e0e0e0;
}

.flip-review-strip h2 {
    font-size: 1rem;
    margin-bottom: 1.2rem;
}

.flip-review-row {
    display: grid;
    grid-template-columns: 4rem minmax(0, 1fr);
    gap: 1rem;
    align-items: center;
}

.flip-review-row img {
    width: 4rem;
    height: 4rem;
    object-fit: contain;
}

.flip-review-row div {
    display: grid;
    gap: 0.3rem;
}

.flip-review-form {
    display: grid;
    gap: 0.55rem;
    max-width: 30rem;
    margin-top: 0.65rem;
}

.flip-review-form textarea {
    min-height: 4.5rem;
    resize: vertical;
}

.flip-submitted-reviews {
    margin-top: 1.4rem;
}

.flip-submitted-reviews h2 {
    font-size: 1rem;
}

.flip-submitted-reviews article strong,
.flip-submitted-reviews article span {
    display: block;
}

.flip-submitted-reviews article p {
    margin: 0.35rem 0 0;
}

.flip-stars {
    color: #d1d5db;
    font-size: 1.2rem;
}

.flip-review-row a {
    color: #005bea;
    text-decoration: none;
    font-weight: 700;
}

.flip-wishlist-panel {
    padding: 0;
}

.flip-wishlist-panel h1 {
    padding: 1rem 1.5rem;
    margin: 0;
    border-bottom: 1px solid #d7d7d7;
}

.flip-wishlist-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    min-height: 7.8rem;
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid #d7d7d7;
}

.flip-wishlist-product {
    display: grid;
    grid-template-columns: 5rem minmax(0, 1fr);
    gap: 1.4rem;
    color: #111827;
    text-decoration: none;
}

.flip-wishlist-product span {
    display: grid;
    place-items: center;
    width: 5rem;
    height: 5rem;
}

.flip-wishlist-product img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.flip-wishlist-product strong {
    display: block;
    max-width: 38rem;
    margin-bottom: 0.75rem;
    font-weight: 500;
}

.flip-wishlist-price {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.flip-wishlist-price b {
    color: #111827;
    font-size: 1.15rem;
}

.flip-wishlist-price del {
    color: #8b8f98;
}

.flip-wishlist-price em {
    color: #16a34a;
    font-style: normal;
    font-size: 0.82rem;
}

.flip-empty-inline {
    padding: 3rem 1.5rem;
}

.flip-pref-shell,
.flip-help-shell,
.flip-deals-shell {
    background: #f1f3f6;
    padding: 1.35rem 0 4rem;
}

.flip-pref-layout {
    display: grid;
    grid-template-columns: 18rem minmax(0, 1fr);
    gap: 0.8rem;
    max-width: 980px;
    margin: 0 auto;
}

.flip-pref-sidebar,
.flip-pref-panel {
    background: #fff;
    border: 1px solid #e0e0e0;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

.flip-pref-sidebar {
    min-height: 16rem;
    padding: 1.1rem 0;
}

.flip-pref-title {
    display: flex;
    gap: 0.9rem;
    align-items: center;
    padding: 0 1.6rem 1rem;
    color: #71717a;
    font-size: 0.82rem;
    font-weight: 800;
}

.flip-pref-title i {
    color: #2874f0;
}

.flip-pref-sidebar a {
    display: block;
    padding: 0.85rem 3.5rem;
    color: #111827;
    text-decoration: none;
    font-size: 0.84rem;
}

.flip-pref-sidebar a.is-active,
.flip-pref-sidebar a:hover {
    color: #2874f0;
    background: #f5faff;
}

.flip-pref-panel {
    min-height: 35rem;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 17rem;
    gap: 2rem;
    padding: 1.55rem 1.65rem;
}

.flip-pref-list h1 {
    margin: 0 0 0.4rem;
    font-size: 1.05rem;
}

.flip-pref-list > p {
    color: #71717a;
    font-size: 0.82rem;
}

.flip-pref-row {
    display: grid;
    grid-template-columns: max-content minmax(0, 1fr) max-content;
    gap: 0.9rem;
    align-items: center;
    max-width: 20rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid #e5e7eb;
}

.flip-pref-row span {
    display: grid;
    gap: 0.15rem;
}

.flip-pref-row strong {
    color: #4b5563;
    font-weight: 500;
}

.flip-pref-row small {
    color: #9ca3af;
}

.flip-pref-art {
    display: grid;
    align-content: center;
    justify-items: center;
    gap: 1rem;
    text-align: center;
    color: #ef4444;
}

.flip-pref-art > div {
    width: 4.4rem;
    height: 4.4rem;
    display: grid;
    place-items: center;
    border-radius: 50%;
    color: #fff;
    background: #2874f0;
    font-size: 2rem;
}

.flip-pref-art.is-muted > div {
    background: #ef4444;
}

.flip-pref-art strong,
.flip-pref-art span {
    max-width: 14rem;
    font-size: 0.76rem;
}

.flip-pref-art span {
    color: #111827;
}

.flip-pref-save {
    margin-top: 1rem;
}

.flip-help-shell .container {
    max-width: 1220px;
}

.flip-help-shell h1 {
    font-size: 1.1rem;
    margin-bottom: 0.6rem;
}

.flip-help-intro {
    color: #71717a;
    font-size: 0.78rem;
    line-height: 1.5;
}

.flip-help-layout {
    display: grid;
    grid-template-columns: 20rem minmax(0, 1fr);
    gap: 1rem;
}

.flip-help-sidebar,
.flip-help-card {
    background: #fff;
    border: 1px solid #e0e0e0;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

.flip-help-sidebar {
    max-height: 28rem;
    overflow-y: auto;
    padding: 1rem 0;
}

.flip-help-sidebar strong {
    display: block;
    padding: 0.6rem 1.6rem;
    font-size: 0.75rem;
}

.flip-help-sidebar a {
    display: block;
    padding: 0.8rem 2.4rem;
    color: #111827;
    text-decoration: none;
    font-size: 0.85rem;
}

.flip-help-sidebar a.is-active,
.flip-help-sidebar a:hover {
    color: #2874f0;
    background: #f5faff;
}

.flip-help-main {
    display: grid;
    gap: 0.6rem;
}

.flip-help-card {
    padding: 1.1rem;
}

.flip-help-card h2 {
    font-size: 1.05rem;
    margin-bottom: 1rem;
}

.flip-gst-card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.95rem 1rem;
    border-radius: 0.75rem;
    background: #eaf5ff;
}

.flip-gst-card a,
.flip-view-more,
.flip-postal-note a {
    color: #005bea;
    text-decoration: none;
    font-weight: 700;
}

.flip-help-order,
.flip-help-issue,
.flip-help-question {
    display: grid;
    grid-template-columns: 5rem minmax(0, 1fr);
    gap: 1.3rem;
    align-items: center;
    padding: 0.85rem;
    color: #111827;
    text-decoration: none;
    border-bottom: 1px solid #e5e7eb;
}

.flip-help-order img {
    width: 4rem;
    height: 4rem;
    object-fit: contain;
}

.flip-help-order span,
.flip-help-issue span {
    display: grid;
    gap: 0.25rem;
}

.flip-help-order small,
.flip-help-issue small {
    color: #71717a;
}

.flip-help-order small i {
    display: inline-block;
    width: 0.45rem;
    height: 0.45rem;
    margin-right: 0.4rem;
    border-radius: 50%;
    background: #16a34a;
}

.flip-view-more {
    display: block;
    padding-top: 0.8rem;
    text-align: center;
}

.flip-help-issue {
    grid-template-columns: minmax(0, 1fr) max-content;
}

.flip-help-question {
    display: block;
    padding: 0.75rem 0;
}

.flip-postal-note {
    margin: 0.8rem 1rem;
    color: #71717a;
    font-size: 0.78rem;
}

.flip-deals-panel {
    max-width: 1330px;
    margin: 0 auto;
    background: #fff;
}

.flip-deals-panel header {
    min-height: 7rem;
    display: grid;
    place-items: center;
    align-content: center;
    border-bottom: 1px solid #e5e7eb;
}

.flip-deals-panel h1 {
    margin: 0;
    font-size: 1.35rem;
    font-weight: 800;
}

.flip-deals-panel header span {
    color: #9ca3af;
}

.flip-deals-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 2.6rem 2rem;
    padding: 2rem 3rem;
}

.flip-deal-card {
    display: grid;
    justify-items: center;
    gap: 0.45rem;
    color: #111827;
    text-align: center;
    text-decoration: none;
}

.flip-deal-card span {
    width: 11rem;
    height: 11rem;
    display: grid;
    place-items: center;
}

.flip-deal-card img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.flip-deal-card strong {
    font-size: 0.88rem;
}

.flip-deal-card em {
    color: #16a34a;
    font-style: normal;
    font-size: 0.84rem;
}

.flip-deal-card small {
    color: #8b8f98;
}

@media (max-width: 1199.98px) {
    .flip-account-sidebar {
        position: static;
    }

    .flip-orders-layout {
        grid-template-columns: minmax(0, 1fr);
    }

    .flip-order-filter {
        position: static;
    }

    .flip-pref-layout,
    .flip-help-layout {
        grid-template-columns: minmax(0, 1fr);
    }

    .flip-deals-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .flip-profile-panel {
        padding: 1.2rem;
    }

    .flip-field-row,
    .flip-quick-stats,
    .flip-order-search,
    .flip-order-row {
        grid-template-columns: minmax(0, 1fr);
    }

    .flip-order-row {
        gap: 0.8rem;
    }

    .flip-profile-actions {
        grid-template-columns: minmax(0, 1fr);
    }

    .flip-account-dropdown {
        min-width: 18rem;
    }

    .flip-gift-head,
    .flip-gift-buy-head,
    .flip-gift-personal,
    .flip-card-select-row,
    .flip-corporate-grid,
    .flip-coupon-row,
    .flip-pref-panel,
    .flip-deals-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .flip-gift-head,
    .flip-gift-buy-head {
        display: grid;
    }

    .flip-gift-preview {
        min-height: 12rem;
    }

    .flip-pref-panel {
        display: grid;
    }

    .flip-wishlist-row,
    .flip-saved-payment-row,
    .flip-card-row {
        align-items: flex-start;
    }

    .flip-deals-grid {
        padding: 1.5rem;
    }
}
.flip-order-detail-page,
.flip-support-chat-page {
    background: #f1f3f6;
    min-height: calc(100vh - 150px);
    padding: 24px 0 40px;
}

.flip-order-breadcrumb,
.flip-order-detail-grid {
    width: min(1460px, calc(100% - 48px));
    margin: 0 auto;
}

.flip-order-breadcrumb {
    color: #777;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    margin-bottom: 12px;
}

.flip-order-breadcrumb a {
    color: #777;
    text-decoration: none;
}

.flip-order-detail-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 420px;
    gap: 30px;
}

.flip-order-detail-main,
.flip-order-detail-side {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.flip-order-product-panel,
.flip-order-timeline-card,
.flip-chat-strip,
.flip-rate-panel,
.flip-order-copy-id,
.flip-side-panel {
    background: #fff;
    border: 1px solid #e0e0e0;
}

.flip-order-product-panel {
    min-height: 136px;
    display: flex;
    justify-content: space-between;
    gap: 24px;
    padding: 22px 24px;
}

.flip-order-product-panel h1 {
    font-size: 20px;
    line-height: 1.35;
    margin: 0 0 10px;
}

.flip-order-product-panel p {
    color: #777;
    margin: 0 0 8px;
}

.flip-order-product-panel strong {
    display: block;
    font-size: 19px;
}

.flip-order-product-panel strong span {
    color: #008c00;
    font-size: 13px;
    margin-left: 6px;
}

.flip-order-product-panel img {
    width: 92px;
    height: 112px;
    object-fit: contain;
}

.flip-order-timeline-card {
    padding: 22px 24px;
}

.flip-order-mini-timeline {
    border-left: 2px solid #16a34a;
    margin-left: 13px;
}

.flip-order-mini-timeline div {
    position: relative;
    min-height: 48px;
    padding: 0 0 18px 28px;
    display: flex;
    align-items: flex-start;
}

.flip-order-mini-timeline div:last-child {
    padding-bottom: 4px;
}

.flip-order-mini-timeline span {
    position: absolute;
    left: -13px;
    top: -2px;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: #16a34a;
    color: #fff;
    display: grid;
    place-items: center;
    font-size: 13px;
}

.flip-link-button {
    border: 0;
    background: transparent;
    color: #0b5cff;
    font-weight: 600;
    padding: 8px 0 0;
}

.flip-chat-strip {
    height: 56px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    color: #111;
    font-weight: 700;
    text-decoration: none;
}

.flip-rate-panel {
    padding: 22px 24px 18px;
}

.flip-rate-panel h2,
.flip-side-panel h2 {
    font-size: 18px;
    margin: 0 0 16px;
}

.flip-rate-box {
    background: #fafafa;
    border-radius: 10px;
    padding: 16px 18px;
    display: grid;
    gap: 12px;
}

.flip-order-stars {
    background: #fff;
    min-height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
}

.flip-order-stars button {
    border: 0;
    background: transparent;
    color: #d6d6d6;
    font-size: 26px;
}

.flip-order-stars button.is-active,
.flip-order-stars button:hover,
.flip-order-stars button:hover ~ button {
    color: #168a38;
}

.flip-order-copy-id {
    padding: 10px 18px;
    color: #777;
    display: flex;
    gap: 8px;
    align-items: center;
}

.flip-order-copy-id button {
    border: 0;
    background: transparent;
    color: #0b5cff;
}

.flip-side-panel {
    padding: 22px 18px;
}

.flip-delivery-box,
.flip-price-box {
    border-radius: 12px;
    background: #fafafa;
    padding: 14px;
}

.flip-delivery-box p {
    margin: 0;
    padding: 12px 0;
    display: flex;
    gap: 10px;
    border-bottom: 1px solid #eee;
}

.flip-delivery-box p:last-child {
    border-bottom: 0;
}

.flip-price-box > div {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    padding: 8px 0;
}

.flip-price-box .muted {
    color: #777;
    font-size: 13px;
}

.flip-price-box .total {
    border-top: 1px dashed #aaa;
    margin-top: 8px;
    padding-top: 14px;
    font-weight: 700;
}

.flip-paid-by {
    border: 1px solid #eee;
    border-radius: 8px;
    margin: 10px 0;
    padding: 12px !important;
}

.flip-invoice-btn {
    height: 48px;
    border: 1px solid #e5e5e5;
    border-radius: 10px;
    color: #111;
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-size: 17px;
}

.flip-offer-row {
    color: #111;
    text-decoration: none;
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 0;
    border-top: 1px solid #eee;
    font-size: 13px;
}

.flip-update-modal[hidden] {
    display: none;
}

.flip-update-modal {
    position: fixed;
    inset: 0;
    z-index: 1055;
}

.flip-update-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, .62);
}

.flip-update-dialog {
    position: relative;
    width: min(420px, calc(100% - 36px));
    max-height: min(76vh, 560px);
    overflow: auto;
    background: #fff;
    margin: 14vh auto 0;
    padding: 18px 10px 18px 38px;
}

.flip-update-close {
    position: fixed;
    margin-left: calc(min(420px, calc(100% - 36px)) + 14px);
    margin-top: -8px;
    border: 0;
    background: transparent;
    color: #fff;
    font-size: 30px;
}

.flip-update-timeline {
    border-left: 2px solid #16a34a;
}

.flip-update-timeline article {
    position: relative;
    padding: 0 18px 18px 24px;
}

.flip-update-timeline article > span {
    position: absolute;
    left: -7px;
    top: 2px;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: #bdbdbd;
}

.flip-update-timeline article.is-complete > span {
    background: #16a34a;
}

.flip-update-timeline h3 {
    font-size: 15px;
    margin: 0 0 8px;
}

.flip-update-timeline h3 small {
    color: #777;
    font-weight: 400;
}

.flip-update-timeline p,
.flip-update-timeline small {
    margin: 0 0 6px;
    color: #555;
    font-size: 13px;
}

.flip-chat-shell {
    width: min(1860px, calc(100% - 48px));
    height: calc(100vh - 190px);
    min-height: 620px;
    margin: 0 auto;
    background: #fff;
    border: 1px solid #ddd;
    display: grid;
    grid-template-rows: 64px 1fr 54px;
}

.flip-chat-header {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 0 18px;
    border-bottom: 1px solid #eee;
    font-size: 18px;
}

.flip-chat-logo {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: #ffe000;
    color: #2874f0;
    display: grid;
    place-items: center;
    font-weight: 800;
}

.flip-chat-body {
    overflow: auto;
    padding: 10px 46px 28px;
    background-color: #f7fbff;
    background-image: radial-gradient(circle at 1px 1px, #e2edf8 1px, transparent 0);
    background-size: 16px 16px;
}

.flip-chat-disclaimer {
    text-align: center;
    color: #8a97a3;
    font-size: 13px;
}

.flip-chat-date {
    display: block;
    width: max-content;
    margin: 34px auto;
    background: #fff;
    border-radius: 999px;
    padding: 6px 18px;
    color: #777;
    font-size: 12px;
}

.flip-chat-bubble,
.flip-chat-options,
.flip-chat-product {
    width: max-content;
    max-width: min(420px, 78%);
    background: #fff;
    border-radius: 8px;
    padding: 12px 14px;
    margin: 14px 0;
    box-shadow: 0 1px 2px rgba(0,0,0,.08);
}

.flip-chat-bubble.is-customer {
    margin-left: auto;
    background: #e8f1ff;
}

.flip-chat-bubble p,
.flip-chat-options strong {
    margin: 0 0 6px;
}

.flip-chat-bubble small {
    color: #777;
    display: block;
    text-align: right;
    font-size: 11px;
}

.flip-chat-product {
    display: grid;
    gap: 10px;
}

.flip-chat-product img {
    width: 145px;
    height: 160px;
    object-fit: contain;
}

.flip-chat-product strong {
    max-width: 145px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 12px;
}

.flip-chat-options form {
    display: grid;
    gap: 0;
}

.flip-chat-options button {
    border: 0;
    border-top: 1px solid #eee;
    background: #fff;
    color: #0b5cff;
    padding: 12px 10px;
}

.flip-chat-compose {
    display: grid;
    grid-template-columns: 1fr 54px;
    border-top: 1px solid #eee;
}

.flip-chat-compose input {
    border: 0;
    padding: 0 18px;
    font-size: 16px;
}

.flip-chat-compose button {
    border: 0;
    background: #fff;
    color: #c8c8c8;
    font-size: 28px;
}

@media (max-width: 980px) {
    .flip-order-detail-grid {
        grid-template-columns: 1fr;
    }

    .flip-order-breadcrumb,
    .flip-order-detail-grid,
    .flip-chat-shell {
        width: calc(100% - 24px);
    }

    .flip-order-product-panel {
        padding: 18px;
    }
}

body.dark-mode {
    --flip-dark-page: #0f172a;
    --flip-dark-panel: #111c32;
    --flip-dark-panel-2: #15223b;
    --flip-dark-soft: #1b2a46;
    --flip-dark-line: rgba(180, 197, 232, 0.16);
    --flip-dark-text: #edf3ff;
    --flip-dark-muted: #aebbd3;
    --flip-dark-faint: #7f8da8;
    --flip-dark-link: #8db3ff;
}

body.dark-mode .flip-profile-shell,
body.dark-mode .flip-orders-shell,
body.dark-mode .flip-order-detail-page,
body.dark-mode .flip-support-chat-page,
body.dark-mode .flip-help-shell,
body.dark-mode .flip-deals-shell,
body.dark-mode .flip-pref-shell {
    background: var(--flip-dark-page);
    color: var(--flip-dark-text);
}

body.dark-mode .flip-account-user-card,
body.dark-mode .flip-account-sidebar,
body.dark-mode .flip-account-visited,
body.dark-mode .flip-account-page-panel,
body.dark-mode .flip-profile-panel,
body.dark-mode .flip-order-product-panel,
body.dark-mode .flip-order-timeline-card,
body.dark-mode .flip-chat-strip,
body.dark-mode .flip-rate-panel,
body.dark-mode .flip-order-copy-id,
body.dark-mode .flip-side-panel,
body.dark-mode .flip-coupon-panel,
body.dark-mode .flip-wishlist-panel,
body.dark-mode .flip-help-sidebar,
body.dark-mode .flip-help-main,
body.dark-mode .flip-help-card,
body.dark-mode .flip-deals-panel,
body.dark-mode .flip-pref-sidebar,
body.dark-mode .flip-pref-panel,
body.dark-mode .flip-gift-personal,
body.dark-mode .flip-gift-summary,
body.dark-mode .flip-pan-form,
body.dark-mode .flip-card-row,
body.dark-mode .flip-saved-payment-row,
body.dark-mode .flip-review-strip,
body.dark-mode .flip-submitted-reviews {
    background: var(--flip-dark-panel);
    border-color: var(--flip-dark-line);
    color: var(--flip-dark-text);
    box-shadow: none;
}

body.dark-mode .flip-account-main-link,
body.dark-mode .flip-account-nav-heading,
body.dark-mode .flip-order-product-panel p,
body.dark-mode .flip-order-copy,
body.dark-mode .flip-muted,
body.dark-mode .flip-faq-list p,
body.dark-mode .flip-help-intro,
body.dark-mode .flip-help-note,
body.dark-mode .flip-pref-title span,
body.dark-mode .flip-pref-row small,
body.dark-mode .flip-price-box .muted,
body.dark-mode .flip-update-timeline p,
body.dark-mode .flip-update-timeline small,
body.dark-mode .flip-chat-disclaimer {
    color: var(--flip-dark-muted);
}

body.dark-mode .flip-order-breadcrumb,
body.dark-mode .flip-order-breadcrumb a,
body.dark-mode .flip-account-visited a,
body.dark-mode .flip-blue-link,
body.dark-mode .flip-inline-link,
body.dark-mode .flip-link-button,
body.dark-mode .flip-view-more,
body.dark-mode .flip-help-issue,
body.dark-mode .flip-offer-row,
body.dark-mode .flip-invoice-btn,
body.dark-mode .flip-chat-strip {
    color: var(--flip-dark-link);
}

body.dark-mode .flip-account-main-link.is-active,
body.dark-mode .flip-account-nav-group .is-active,
body.dark-mode .flip-gift-tabs .is-active,
body.dark-mode .flip-pref-sidebar .is-active {
    background: rgba(141, 179, 255, 0.12);
    color: #d9e7ff;
}

body.dark-mode .flip-delivery-box,
body.dark-mode .flip-price-box,
body.dark-mode .flip-rate-box,
body.dark-mode .flip-gift-box,
body.dark-mode .flip-gift-preview,
body.dark-mode .flip-persisted-note,
body.dark-mode .flip-review-form,
body.dark-mode .flip-empty-large,
body.dark-mode .flip-empty-inline,
body.dark-mode .flip-gst-card,
body.dark-mode .flip-help-order,
body.dark-mode .flip-help-question,
body.dark-mode .flip-card-list,
body.dark-mode .flip-add-payment-form,
body.dark-mode .flip-declaration {
    background: var(--flip-dark-panel-2);
    border-color: var(--flip-dark-line);
    color: var(--flip-dark-text);
}

body.dark-mode .flip-delivery-box p,
body.dark-mode .flip-price-box .total,
body.dark-mode .flip-paid-by,
body.dark-mode .flip-invoice-btn,
body.dark-mode .flip-offer-row,
body.dark-mode .flip-coupon-row,
body.dark-mode .flip-wishlist-row,
body.dark-mode .flip-review-row,
body.dark-mode .flip-pref-row,
body.dark-mode .flip-card-row,
body.dark-mode .flip-saved-payment-row,
body.dark-mode .flip-gift-tabs,
body.dark-mode .flip-gift-head,
body.dark-mode .flip-gift-buy-head {
    border-color: var(--flip-dark-line);
}

body.dark-mode .flip-order-search input,
body.dark-mode .flip-profile-form input,
body.dark-mode .flip-profile-form select,
body.dark-mode .flip-password-form input,
body.dark-mode .flip-pan-form input,
body.dark-mode .flip-pan-form select,
body.dark-mode .flip-pan-form textarea,
body.dark-mode .flip-gift-fields input,
body.dark-mode .flip-gift-fields select,
body.dark-mode .flip-gift-fields textarea,
body.dark-mode .flip-corporate-grid input,
body.dark-mode .flip-corporate-grid select,
body.dark-mode .flip-add-payment-form input,
body.dark-mode .flip-review-form input,
body.dark-mode .flip-review-form textarea,
body.dark-mode .flip-single-input,
body.dark-mode .flip-file-field {
    background: #0c1426;
    border-color: var(--flip-dark-line);
    color: var(--flip-dark-text);
}

body.dark-mode .flip-order-search input::placeholder,
body.dark-mode .flip-profile-form input::placeholder,
body.dark-mode .flip-pan-form input::placeholder,
body.dark-mode .flip-gift-fields input::placeholder,
body.dark-mode .flip-gift-fields textarea::placeholder,
body.dark-mode .flip-corporate-grid input::placeholder,
body.dark-mode .flip-add-payment-form input::placeholder,
body.dark-mode .flip-review-form textarea::placeholder,
body.dark-mode .flip-chat-compose input::placeholder {
    color: var(--flip-dark-faint);
}

body.dark-mode .flip-order-filter,
body.dark-mode .flip-order-row,
body.dark-mode .flip-order-search,
body.dark-mode .flip-orders-layout {
    background: var(--flip-dark-panel);
    border-color: var(--flip-dark-line);
    color: var(--flip-dark-text);
}

body.dark-mode .flip-order-row:hover,
body.dark-mode .flip-wishlist-row:hover,
body.dark-mode .flip-card-row:hover,
body.dark-mode .flip-saved-payment-row:hover {
    background: var(--flip-dark-soft);
}

body.dark-mode .flip-order-thumb,
body.dark-mode .flip-wishlist-product img,
body.dark-mode .flip-order-product-panel img,
body.dark-mode .flip-chat-product img {
    background: #fff;
    border-radius: 4px;
}

body.dark-mode .flip-order-stars,
body.dark-mode .flip-rate-box .flip-order-stars {
    background: #0c1426;
}

body.dark-mode .flip-order-stars button,
body.dark-mode .flip-stars {
    color: #66738f;
}

body.dark-mode .flip-order-stars button.is-active,
body.dark-mode .flip-order-stars button:hover {
    color: #21c45d;
}

body.dark-mode .flip-update-dialog {
    background: var(--flip-dark-panel);
    color: var(--flip-dark-text);
    border: 1px solid var(--flip-dark-line);
}

body.dark-mode .flip-update-timeline h3 small {
    color: var(--flip-dark-muted);
}

body.dark-mode .flip-chat-shell {
    background: var(--flip-dark-panel);
    border-color: var(--flip-dark-line);
    color: var(--flip-dark-text);
}

body.dark-mode .flip-chat-header,
body.dark-mode .flip-chat-compose {
    background: #101b31;
    border-color: var(--flip-dark-line);
}

body.dark-mode .flip-chat-body {
    background-color: #0d172a;
    background-image: radial-gradient(circle at 1px 1px, rgba(141, 179, 255, 0.12) 1px, transparent 0);
}

body.dark-mode .flip-chat-date,
body.dark-mode .flip-chat-bubble,
body.dark-mode .flip-chat-options,
body.dark-mode .flip-chat-product,
body.dark-mode .flip-chat-options button,
body.dark-mode .flip-chat-compose input,
body.dark-mode .flip-chat-compose button {
    background: var(--flip-dark-panel-2);
    color: var(--flip-dark-text);
    border-color: var(--flip-dark-line);
}

body.dark-mode .flip-chat-bubble.is-customer {
    background: #1d3560;
}

body.dark-mode .flip-chat-bubble small {
    color: var(--flip-dark-muted);
}

body.dark-mode .flip-account-sidebar {
    background: transparent;
    border: 0;
}

body.dark-mode .flip-account-user-card,
body.dark-mode .flip-account-nav-group,
body.dark-mode .flip-account-main-link,
body.dark-mode .flip-account-main-link.flip-logout,
body.dark-mode .flip-account-visited {
    background: #111c32;
    border: 1px solid rgba(141, 179, 255, 0.18);
    color: #edf3ff;
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.18);
}

body.dark-mode .flip-account-user-card {
    background: linear-gradient(135deg, #15223b, #101a2f);
    border-bottom-color: rgba(141, 179, 255, 0.28);
}

body.dark-mode .flip-account-user-card span:not(.flip-account-user-avatar),
body.dark-mode .flip-account-nav-heading {
    color: #9fb0cf;
}

body.dark-mode .flip-account-user-card strong,
body.dark-mode .flip-account-visited strong {
    color: #f5f8ff;
}

body.dark-mode .flip-account-nav-group {
    margin-bottom: 10px;
    padding: 0.85rem 0;
}

body.dark-mode .flip-account-main-link {
    margin-bottom: 10px;
    border-radius: 0;
    color: #dce8ff;
}

body.dark-mode .flip-account-main-link i:first-child,
body.dark-mode .flip-account-nav-heading i {
    color: #8db3ff;
}

body.dark-mode .flip-account-sidebar .account-nav-link {
    color: #c9d7f0;
    background: transparent;
    border-left: 3px solid transparent;
    padding-top: 0.74rem;
    padding-bottom: 0.74rem;
}

body.dark-mode .flip-account-sidebar .account-nav-link:hover {
    background: rgba(141, 179, 255, 0.10);
    color: #ffffff;
    border-left-color: rgba(141, 179, 255, 0.55);
}

body.dark-mode .flip-account-sidebar .account-nav-link.is-active,
body.dark-mode .flip-account-main-link.is-active {
    background: linear-gradient(90deg, rgba(141, 179, 255, 0.22), rgba(183, 44, 219, 0.08));
    color: #ffffff;
    border-left: 3px solid #8db3ff;
}

body.dark-mode .flip-account-main-link.is-active {
    border-color: rgba(141, 179, 255, 0.42);
}

body.dark-mode .flip-account-main-link.flip-logout {
    color: #bac8e4;
    margin-bottom: 0;
}

body.dark-mode .flip-account-main-link.flip-logout:hover {
    color: #ffffff;
    background: rgba(248, 113, 113, 0.10);
    border-color: rgba(248, 113, 113, 0.32);
}

body.dark-mode .flip-account-visited {
    background: #0d172a;
}

body.dark-mode .flip-account-visited a {
    color: #8db3ff;
}

.premium-bank-offers {
    background: #151515;
    color: #fff;
    padding: clamp(2rem, 4vw, 3.5rem) 0;
    overflow: hidden;
}

.premium-bank-offers-head {
    width: min(1680px, calc(100% - 48px));
    margin: 0 auto 1.4rem;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
}

.premium-bank-offers-head span {
    display: block;
    color: #ff8a3d;
    font-weight: 800;
    font-size: 0.78rem;
    text-transform: uppercase;
}

.premium-bank-offers-head h2 {
    margin: 0.25rem 0 0;
    color: #fff;
    font-family: "Inter", sans-serif;
    font-size: clamp(1.4rem, 2.4vw, 2.25rem);
    font-weight: 800;
    letter-spacing: 0;
}

.premium-bank-offers-head a {
    color: #d7e5ff;
    text-decoration: none;
    font-weight: 700;
    white-space: nowrap;
}

.premium-bank-marquee {
    width: 100%;
    overflow: hidden;
    mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}

.premium-bank-track {
    display: flex;
    width: max-content;
    gap: 1rem;
    padding: 0 1rem;
    animation: premiumBankMarquee 34s linear infinite;
}

.premium-bank-marquee:hover .premium-bank-track {
    animation-play-state: paused;
}

.premium-bank-card {
    position: relative;
    width: clamp(300px, 30vw, 520px);
    min-height: 132px;
    border-radius: 1rem;
    padding: 1.35rem 1.5rem;
    display: grid;
    grid-template-columns: 132px minmax(0, 1fr);
    align-items: center;
    gap: 1.35rem;
    color: #111;
    text-decoration: none;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.18);
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.24);
}

.premium-bank-card::before {
    content: "";
    position: absolute;
    inset: -45%;
    background: radial-gradient(circle, rgba(255,255,255,0.32), transparent 42%);
    transform: translateX(-35%);
    transition: transform 0.45s ease;
}

.premium-bank-card:hover::before {
    transform: translateX(20%);
}

.premium-bank-logo,
.premium-bank-copy,
.premium-bank-card em {
    position: relative;
    z-index: 1;
}

.premium-bank-logo {
    min-height: 56px;
    border-radius: 0.55rem;
    display: grid;
    place-items: center;
    padding: 0.65rem;
    color: #fff;
    font-weight: 900;
    text-align: center;
    letter-spacing: 0;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.18);
}

.premium-bank-logo span {
    line-height: 1.1;
}

.premium-bank-copy strong {
    display: block;
    font-size: clamp(1rem, 1.6vw, 1.55rem);
    line-height: 1.2;
    font-weight: 850;
}

.premium-bank-copy small {
    display: block;
    margin-top: 0.45rem;
    color: rgba(17, 17, 17, 0.72);
    font-weight: 650;
}

.premium-bank-card em {
    position: absolute;
    right: 1.2rem;
    bottom: 0.8rem;
    color: rgba(17, 17, 17, 0.55);
    font-style: italic;
    font-size: 0.72rem;
    font-weight: 700;
}

.premium-bank-blue { background: linear-gradient(135deg, #e8f3ff, #2380e8); }
.premium-bank-blue .premium-bank-logo { background: #0957a8; }
.premium-bank-orange { background: linear-gradient(135deg, #fff4e2, #ff9a3c); }
.premium-bank-orange .premium-bank-logo { background: #c85d12; }
.premium-bank-navy { background: linear-gradient(135deg, #eef5ff, #b4d1ff); }
.premium-bank-navy .premium-bank-logo { background: #123c9c; }
.premium-bank-burgundy { background: linear-gradient(135deg, #fff1f6, #b02a5b); }
.premium-bank-burgundy .premium-bank-logo { background: #7a123a; }
.premium-bank-red { background: linear-gradient(135deg, #fff2f2, #e43838); }
.premium-bank-red .premium-bank-logo { background: #b71924; }
.premium-bank-teal { background: linear-gradient(135deg, #eafffb, #18b5a4); }
.premium-bank-teal .premium-bank-logo { background: #08766c; }

.premium-bank-wine {
    background: linear-gradient(135deg, #b21d2b, #7c121e);
    color: #fff;
}

.premium-bank-wine .premium-bank-logo,
.premium-bank-black .premium-bank-logo {
    background: rgba(255,255,255,0.12);
}

.premium-bank-wine .premium-bank-copy small,
.premium-bank-wine em,
.premium-bank-black .premium-bank-copy small,
.premium-bank-black em {
    color: rgba(255,255,255,0.78);
}

.premium-bank-black {
    background: linear-gradient(135deg, #f4f4f4, #1d1d1d);
    color: #fff;
}

body.dark-mode .premium-bank-offers {
    background: #0b1020;
}

.premium-quick-view-btn {
    position: absolute;
    left: 1rem;
    right: auto;
    top: auto;
    bottom: 1rem;
    z-index: 3;
}

.product-detail-shell .detail-content-card > .row {
    align-items: stretch;
}

.product-detail-shell .detail-content-card > .row > .col-xl-3 {
    flex: 0 0 50%;
    max-width: 50%;
}

.product-detail-shell .detail-content-card .shop-product-card {
    min-width: 0;
}

.product-detail-shell .detail-content-card .shop-card-actions {
    grid-template-columns: repeat(2, minmax(7.25rem, 1fr));
}

.product-detail-shell .detail-content-card .shop-card-actions .btn {
    overflow: hidden;
    text-overflow: ellipsis;
}

.premium-commerce-shell {
    position: relative;
    z-index: 4000;
}

.premium-layer-open {
    overflow: hidden;
}

.premium-layer-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(5, 10, 24, 0.58);
    backdrop-filter: blur(14px);
}

.premium-quick-modal[hidden],
.premium-cart-drawer[hidden],
.premium-commerce-toast[hidden],
.premium-search-panel[hidden] {
    display: none;
}

.premium-quick-modal,
.premium-cart-drawer {
    position: fixed;
    inset: 0;
    z-index: 4100;
}

.premium-quick-dialog {
    position: relative;
    width: min(980px, calc(100% - 32px));
    max-height: min(84vh, 720px);
    overflow: auto;
    margin: 7vh auto 0;
    border: 1px solid rgba(255,255,255,0.32);
    border-radius: 22px;
    background: linear-gradient(135deg, rgba(255,255,255,0.88), rgba(255,255,255,0.72));
    box-shadow: 0 30px 80px rgba(0,0,0,0.28);
    backdrop-filter: blur(24px) saturate(140%);
}

.premium-layer-close {
    position: absolute;
    top: 16px;
    right: 16px;
    z-index: 3;
    width: 40px;
    height: 40px;
    border: 1px solid rgba(0,0,0,0.10);
    border-radius: 50%;
    background: rgba(255,255,255,0.72);
}

.premium-qv-grid {
    display: grid;
    grid-template-columns: minmax(280px, 420px) 1fr;
    gap: 32px;
    padding: 34px;
}

.premium-qv-media {
    border-radius: 18px;
    background: radial-gradient(circle at 25% 20%, rgba(183,44,219,0.16), transparent 32%), #fff;
    display: grid;
    place-items: center;
    min-height: 430px;
    overflow: hidden;
}

.premium-qv-media img {
    width: 88%;
    height: 88%;
    object-fit: contain;
}

.premium-qv-copy > span {
    color: #7c3aed;
    font-weight: 800;
    font-size: 0.8rem;
    text-transform: uppercase;
}

.premium-qv-copy h2 {
    margin: 8px 48px 10px 0;
    font-family: "Inter", sans-serif;
    font-weight: 850;
    font-size: clamp(1.5rem, 3vw, 2.35rem);
}

.premium-qv-copy p {
    color: #596174;
    line-height: 1.65;
}

.premium-qv-rating {
    width: max-content;
    border-radius: 999px;
    background: #0f9f4a;
    color: #fff;
    padding: 6px 12px;
    font-weight: 800;
    margin: 14px 0;
}

.premium-qv-rating small {
    color: rgba(255,255,255,0.78);
}

.premium-qv-price {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin: 18px 0;
}

.premium-qv-price strong {
    font-size: 2rem;
}

.premium-qv-price del {
    color: #858b99;
}

.premium-qv-price em {
    color: #0f9f4a;
    font-style: normal;
    font-weight: 850;
}

.premium-qv-offers {
    list-style: none;
    padding: 0;
    margin: 0 0 18px;
    display: grid;
    gap: 9px;
}

.premium-qv-offers li {
    display: flex;
    gap: 9px;
    color: #263247;
    font-weight: 650;
}

.premium-qv-offers i {
    color: #2874f0;
}

.premium-qv-variants {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 14px;
}

.premium-qv-variants label {
    border: 1px solid rgba(40,116,240,0.22);
    background: rgba(40,116,240,0.08);
    border-radius: 999px;
    padding: 8px 12px;
    font-weight: 700;
}

.premium-qv-variants input {
    margin-right: 6px;
}

.premium-qv-actions button,
.premium-qv-actions a,
.premium-cart-actions a,
.premium-cart-empty a {
    height: 48px;
    border: 0;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 0 18px;
    font-weight: 850;
    text-decoration: none;
}

.premium-qv-actions button {
    background: linear-gradient(135deg, #2874f0, #b72cdb);
    color: #fff;
    min-width: 180px;
}

.premium-qv-actions a {
    color: #182237;
    border: 1px solid rgba(24,34,55,0.14);
    background: rgba(255,255,255,0.62);
}

.premium-cart-panel {
    position: fixed;
    top: 0;
    right: 0;
    width: min(430px, 100%);
    height: 100%;
    background: linear-gradient(180deg, rgba(255,255,255,0.95), rgba(246,248,255,0.92));
    border-left: 1px solid rgba(255,255,255,0.48);
    box-shadow: -24px 0 70px rgba(0,0,0,0.28);
    backdrop-filter: blur(22px) saturate(150%);
    display: grid;
    grid-template-rows: auto auto 1fr auto;
}

.premium-cart-panel header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 22px;
}

.premium-cart-panel header span,
.premium-search-head span {
    color: #7c3aed;
    font-size: 0.75rem;
    text-transform: uppercase;
    font-weight: 850;
}

.premium-cart-panel header strong {
    display: block;
    font-size: 1.35rem;
}

.premium-cart-panel header button {
    border: 0;
    border-radius: 50%;
    width: 38px;
    height: 38px;
    background: rgba(15,23,42,0.08);
}

.premium-cart-progress {
    padding: 0 22px 16px;
}

.premium-cart-free {
    color: #334155;
    font-weight: 750;
    margin-bottom: 8px;
}

.premium-cart-free.is-unlocked {
    color: #0f9f4a;
}

.premium-cart-progress span {
    display: block;
    height: 8px;
    border-radius: 999px;
    background: rgba(15,23,42,0.10);
    overflow: hidden;
}

.premium-cart-progress i {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #2874f0, #0f9f4a);
}

.premium-cart-items {
    overflow: auto;
    padding: 0 18px;
}

.premium-cart-item {
    display: grid;
    grid-template-columns: 76px 1fr;
    gap: 14px;
    padding: 14px;
    margin-bottom: 12px;
    border: 1px solid rgba(15,23,42,0.08);
    border-radius: 16px;
    background: rgba(255,255,255,0.72);
}

.premium-cart-item img {
    width: 76px;
    height: 82px;
    object-fit: contain;
    border-radius: 12px;
    background: #fff;
}

.premium-cart-item a {
    color: #0f172a;
    text-decoration: none;
    font-weight: 800;
}

.premium-cart-item span {
    display: block;
    color: #64748b;
    font-size: 0.82rem;
    margin: 4px 0;
}

.premium-cart-panel footer {
    padding: 18px 22px 22px;
    border-top: 1px solid rgba(15,23,42,0.08);
}

.premium-cart-total,
.premium-cart-grand {
    display: flex;
    justify-content: space-between;
    padding: 5px 0;
}

.premium-cart-grand {
    font-size: 1.15rem;
    font-weight: 850;
}

.premium-cart-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-top: 14px;
}

.premium-cart-actions a {
    color: #0f172a;
    border: 1px solid rgba(15,23,42,0.12);
    background: rgba(255,255,255,0.62);
}

.premium-cart-actions a.is-primary {
    color: #fff;
    border: 0;
    background: linear-gradient(135deg, #2874f0, #b72cdb);
}

.premium-cart-empty {
    min-height: 320px;
    display: grid;
    place-items: center;
    align-content: center;
    gap: 10px;
    text-align: center;
    color: #475569;
}

.premium-cart-empty i {
    font-size: 2.6rem;
    color: #2874f0;
}

.premium-commerce-toast {
    position: fixed;
    left: 50%;
    bottom: 26px;
    z-index: 4300;
    transform: translateX(-50%);
    background: rgba(15, 23, 42, 0.92);
    color: #fff;
    border: 1px solid rgba(255,255,255,0.18);
    border-radius: 999px;
    padding: 12px 18px;
    box-shadow: 0 18px 42px rgba(0,0,0,0.26);
    backdrop-filter: blur(16px);
    font-weight: 750;
}

.premium-commerce-toast.is-error {
    background: rgba(127, 29, 29, 0.94);
}

.cart-drawer,
.cart-drawer-overlay,
.cart-countdown-banner,
.social-proof-toast {
    z-index: 1;
}

body .premium-commerce-shell ~ .cart-drawer,
body .premium-commerce-shell ~ .cart-drawer-overlay,
body .premium-commerce-shell ~ .cart-countdown-banner,
body .premium-commerce-shell ~ .social-proof-toast {
    display: none !important;
}

.header-global-search {
    position: relative;
}

.premium-search-panel {
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    right: 0;
    z-index: 2600;
    min-width: min(560px, 92vw);
    border: 1px solid rgba(255,255,255,0.42);
    border-radius: 18px;
    background: rgba(255,255,255,0.9);
    box-shadow: 0 24px 60px rgba(0,0,0,0.20);
    backdrop-filter: blur(22px) saturate(140%);
    padding: 10px;
}

.premium-search-head {
    display: flex;
    justify-content: space-between;
    padding: 8px 10px 10px;
}

.premium-search-head a {
    color: #2874f0;
    font-weight: 800;
    text-decoration: none;
}

.premium-search-item {
    display: grid;
    grid-template-columns: 48px 1fr auto;
    gap: 12px;
    align-items: center;
    padding: 10px;
    border-radius: 14px;
    color: #0f172a;
    text-decoration: none;
}

.premium-search-item:hover {
    background: rgba(40,116,240,0.08);
}

.premium-search-item img {
    width: 48px;
    height: 48px;
    object-fit: contain;
    border-radius: 10px;
    background: #fff;
}

.premium-search-item strong,
.premium-search-item small {
    display: block;
}

.premium-search-item small {
    color: #64748b;
}

.premium-search-item em {
    font-style: normal;
    font-weight: 850;
}

.premium-search-cats {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    padding: 8px 10px 4px;
}

.premium-search-cats a {
    border-radius: 999px;
    background: rgba(183,44,219,0.10);
    color: #741b8e;
    padding: 6px 10px;
    text-decoration: none;
    font-weight: 750;
    font-size: 0.82rem;
}

.premium-qv-skeleton {
    min-height: 420px;
    display: grid;
    gap: 14px;
    padding: 34px;
}

.premium-qv-skeleton span {
    border-radius: 18px;
    background: linear-gradient(90deg, rgba(15,23,42,0.08), rgba(255,255,255,0.42), rgba(15,23,42,0.08));
    background-size: 200% 100%;
    animation: premiumSkeleton 1.1s infinite;
}

@keyframes premiumSkeleton {
    to {
        background-position-x: -200%;
    }
}

body.dark-mode .premium-quick-dialog,
body.dark-mode .premium-cart-panel,
body.dark-mode .premium-search-panel {
    background: linear-gradient(135deg, rgba(17,28,50,0.94), rgba(13,23,42,0.90));
    border-color: rgba(141,179,255,0.22);
    color: #edf3ff;
}

body.dark-mode .premium-qv-media,
body.dark-mode .premium-cart-item,
body.dark-mode .premium-qv-actions a,
body.dark-mode .premium-search-item:hover {
    background: rgba(141,179,255,0.10);
}

body.dark-mode .premium-qv-copy p,
body.dark-mode .premium-qv-offers li,
body.dark-mode .premium-cart-free,
body.dark-mode .premium-cart-item span,
body.dark-mode .premium-search-item small {
    color: #aebbd3;
}

body.dark-mode .premium-qv-actions a,
body.dark-mode .premium-cart-item a,
body.dark-mode .premium-search-item,
body.dark-mode .premium-cart-actions a {
    color: #edf3ff;
}

.premium-cart-page {
    min-height: 70vh;
    padding: 2.6rem 0 4rem;
    background:
        radial-gradient(circle at 12% 8%, rgba(183,44,219,0.08), transparent 30%),
        linear-gradient(180deg, rgba(246,248,255,0.72), rgba(240,242,247,0.94));
}

.premium-cart-wrap {
    width: min(1460px, calc(100% - 36px));
    margin: 0 auto;
}

.premium-cart-main {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
    gap: 1.2rem;
    align-items: start;
}

.premium-cart-left {
    display: grid;
    gap: 0.75rem;
}

.premium-cart-tabs,
.premium-cart-address-strip,
.premium-cart-row,
.premium-cart-coupon,
.premium-price-card,
.premium-cart-trust,
.premium-cart-empty-page,
.premium-address-panel,
.premium-address-form-panel {
    border: 1px solid rgba(15,23,42,0.08);
    background: rgba(255,255,255,0.88);
    box-shadow: 0 18px 42px rgba(15,23,42,0.08);
    backdrop-filter: blur(18px) saturate(135%);
}

.premium-cart-tabs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 58px;
}

.premium-cart-tabs button {
    border: 0;
    background: transparent;
    color: #475569;
    font-weight: 800;
}

.premium-cart-tabs button.is-active {
    color: #2874f0;
    box-shadow: inset 0 -3px 0 #2874f0;
}

.premium-cart-address-strip {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.2rem;
}

.premium-cart-address-strip span,
.premium-cart-coupon span,
.premium-price-card header span,
.premium-address-head span,
.premium-address-form-head span {
    display: block;
    color: #7c3aed;
    font-size: 0.76rem;
    font-weight: 900;
    text-transform: uppercase;
}

.premium-cart-address-strip strong {
    display: block;
    margin-top: 0.16rem;
}

.premium-cart-address-strip a,
.premium-cart-continue,
.premium-address-head a,
.premium-address-actions a {
    border: 1px solid rgba(40,116,240,0.18);
    background: rgba(40,116,240,0.06);
    color: #155bd6;
    text-decoration: none;
    font-weight: 850;
    padding: 0.72rem 1rem;
    border-radius: 0.55rem;
    white-space: nowrap;
}

.premium-cart-list {
    display: grid;
    gap: 0.75rem;
}

.premium-cart-row {
    display: grid;
    gap: 1rem;
    padding: 1rem;
}

.premium-cart-product {
    display: grid;
    grid-template-columns: 112px minmax(0, 1fr);
    gap: 1rem;
}

.premium-cart-media {
    display: grid;
    place-items: center;
    width: 112px;
    height: 112px;
    border: 1px solid rgba(15,23,42,0.06);
    border-radius: 0.55rem;
    background: #f8fafc;
    overflow: hidden;
}

.premium-cart-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.premium-cart-title {
    color: #0f172a;
    text-decoration: none;
    font-size: 1.02rem;
    font-weight: 850;
    line-height: 1.35;
}

.premium-cart-copy p {
    margin: 0.3rem 0;
    color: #64748b;
    font-size: 0.9rem;
}

.premium-cart-rating,
.premium-cart-price-line,
.premium-cart-perks,
.premium-cart-row-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.65rem;
}

.premium-cart-rating span {
    color: #0f9f4a;
    font-weight: 900;
}

.premium-cart-rating small {
    color: #64748b;
}

.premium-cart-rating em {
    color: #155bd6;
    font-style: normal;
    font-weight: 800;
}

.premium-cart-price-line span {
    color: #0f9f4a;
    font-weight: 900;
}

.premium-cart-price-line del {
    color: #94a3b8;
}

.premium-cart-price-line strong {
    color: #0f172a;
    font-size: 1.25rem;
}

.premium-cart-perks {
    margin-top: 0.45rem;
    color: #475569;
    font-size: 0.88rem;
}

.premium-cart-perks i {
    color: #0f9f4a;
}

.premium-cart-row-actions {
    border-top: 1px solid rgba(15,23,42,0.08);
    padding-top: 0.9rem;
    justify-content: space-between;
}

.premium-cart-row-actions a,
.premium-cart-row-actions button {
    border: 0;
    background: transparent;
    color: #64748b;
    text-decoration: none;
    font-weight: 850;
    padding: 0.45rem 0.65rem;
}

.premium-cart-row-actions a:hover,
.premium-cart-row-actions button:hover {
    color: #2874f0;
}

.premium-cart-coupon {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(300px, 430px);
    gap: 1rem;
    align-items: center;
    padding: 1.2rem;
}

.premium-cart-coupon h2 {
    margin: 0.2rem 0;
    font-size: 1.65rem;
}

.premium-cart-coupon p {
    margin: 0;
    color: #64748b;
}

.premium-cart-coupon form {
    display: flex;
    gap: 0.55rem;
}

.premium-cart-coupon input,
.premium-address-form input,
.premium-address-form select {
    width: 100%;
    min-height: 46px;
    border: 1px solid rgba(15,23,42,0.12);
    border-radius: 0.5rem;
    background: rgba(255,255,255,0.82);
    color: #0f172a;
    padding: 0 0.85rem;
}

.premium-cart-coupon button,
.premium-cart-primary,
.premium-cart-place,
.premium-address-actions button {
    border: 0;
    border-radius: 0.5rem;
    background: linear-gradient(135deg, #ffb000, #ff7a00);
    color: #111827;
    font-weight: 900;
    text-decoration: none;
    min-height: 46px;
    padding: 0 1.2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
}

.premium-price-card {
    position: sticky;
    top: 6.25rem;
    display: grid;
    gap: 1rem;
    padding: 1rem;
}

.premium-price-card header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid rgba(15,23,42,0.08);
    padding-bottom: 0.8rem;
}

.premium-price-card dl {
    display: grid;
    gap: 0.75rem;
    margin: 0;
}

.premium-price-card dl div,
.premium-price-grand {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
}

.premium-price-card dt,
.premium-price-card dd {
    margin: 0;
}

.premium-price-card dd {
    font-weight: 800;
}

.premium-price-card .is-green,
.premium-price-save,
.premium-price-coupon {
    color: #0f9f4a;
}

.premium-price-progress,
.premium-price-coupon,
.premium-price-save,
.premium-cart-trust {
    border-radius: 0.55rem;
    background: rgba(15,159,74,0.08);
    padding: 0.75rem;
    font-weight: 800;
}

.premium-price-progress span {
    display: block;
    height: 8px;
    margin-top: 0.55rem;
    border-radius: 999px;
    background: rgba(15,23,42,0.1);
    overflow: hidden;
}

.premium-price-progress i {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #2874f0, #0f9f4a);
}

.premium-price-grand {
    border-top: 1px dashed rgba(15,23,42,0.2);
    padding-top: 0.85rem;
    align-items: end;
    font-weight: 900;
}

.premium-price-grand strong {
    font-size: 1.35rem;
}

.premium-cart-place {
    width: 100%;
}

.premium-cart-continue {
    text-align: center;
}

.premium-cart-trust {
    display: flex;
    gap: 0.7rem;
    margin-top: 1rem;
    color: #475569;
    background: rgba(255,255,255,0.62);
}

.premium-cart-trust i {
    color: #64748b;
    font-size: 1.5rem;
}

.premium-cart-empty-page {
    max-width: 720px;
    margin: 3rem auto;
    padding: 3rem;
    text-align: center;
    border-radius: 1rem;
}

.premium-cart-empty-icon,
.premium-address-empty i {
    width: 70px;
    height: 70px;
    border-radius: 50%;
    display: inline-grid;
    place-items: center;
    color: #7c3aed;
    background: rgba(183,44,219,0.1);
    font-size: 2rem;
}

.premium-cart-recommend {
    margin-top: 2rem;
}

.premium-address-page {
    background:
        radial-gradient(circle at 8% 12%, rgba(183,44,219,0.08), transparent 28%),
        linear-gradient(180deg, rgba(246,248,255,0.78), rgba(240,242,247,0.92));
}

.premium-checkout-page {
    min-height: 72vh;
    padding: 0 0 4rem;
    background:
        radial-gradient(circle at 12% 8%, rgba(40,116,240,0.08), transparent 28%),
        linear-gradient(180deg, #eef2f7, #f6f7fb);
}

.premium-checkout-wrap {
    width: min(1460px, calc(100% - 36px));
    margin: 0 auto;
}

.premium-checkout-main,
.premium-checkout-login {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 430px);
    gap: 1rem;
    align-items: start;
}

.premium-checkout-left {
    display: grid;
    gap: 0.7rem;
}

.premium-checkout-steps,
.premium-checkout-section,
.premium-checkout-summary,
.premium-checkout-login > div {
    border: 1px solid rgba(15,23,42,0.08);
    background: rgba(255,255,255,0.9);
    box-shadow: 0 18px 42px rgba(15,23,42,0.07);
    backdrop-filter: blur(18px) saturate(135%);
}

.premium-checkout-steps {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    min-height: 74px;
    align-items: center;
    text-align: center;
}

.premium-checkout-steps div {
    position: relative;
    display: grid;
    gap: 0.25rem;
    justify-items: center;
    color: #94a3b8;
    font-weight: 850;
}

.premium-checkout-steps div::after {
    content: "";
    position: absolute;
    top: 16px;
    left: calc(50% + 20px);
    width: calc(100% - 40px);
    height: 2px;
    background: #dbe4f0;
}

.premium-checkout-steps div:last-child::after {
    display: none;
}

.premium-checkout-steps i {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    border: 2px solid currentColor;
    font-style: normal;
    font-size: 0.82rem;
}

.premium-checkout-steps .is-active,
.premium-checkout-steps .is-complete {
    color: #2874f0;
}

.premium-checkout-section {
    padding: 1rem;
}

.premium-checkout-section header {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
}

.premium-checkout-section header span,
.premium-checkout-section-title span,
.premium-checkout-login span {
    color: #7c3aed;
    font-size: 0.76rem;
    font-weight: 900;
    text-transform: uppercase;
}

.premium-checkout-section h2,
.premium-checkout-section-title h2,
.premium-checkout-login h1 {
    margin: 0.2rem 0;
    font-size: clamp(1.15rem, 2vw, 1.6rem);
}

.premium-checkout-section em {
    border-radius: 0.28rem;
    background: #edf2f7;
    color: #64748b;
    padding: 0.18rem 0.4rem;
    font-style: normal;
    font-size: 0.72rem;
}

.premium-checkout-section p,
.premium-checkout-section small,
.premium-checkout-login p,
.premium-checkout-terms {
    color: #64748b;
}

.premium-checkout-section header a {
    align-self: start;
    border: 1px solid rgba(15,23,42,0.12);
    border-radius: 0.42rem;
    color: #155bd6;
    text-decoration: none;
    font-weight: 850;
    padding: 0.55rem 0.95rem;
}

.premium-checkout-section-title {
    margin-bottom: 0.85rem;
}

.premium-checkout-address-grid,
.premium-checkout-choice-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: 0.75rem;
}

.premium-checkout-address,
.premium-checkout-choice {
    position: relative;
    display: grid;
    gap: 0.35rem;
    border: 1px solid rgba(15,23,42,0.1);
    border-radius: 0.65rem;
    background: rgba(248,250,252,0.8);
    padding: 0.85rem 0.9rem;
    cursor: pointer;
}

.premium-checkout-address input,
.premium-checkout-choice input {
    position: absolute;
    opacity: 0;
}

.premium-checkout-address.is-selected,
.premium-checkout-choice.is-selected,
.premium-checkout-address:has(input:checked),
.premium-checkout-choice:has(input:checked) {
    border-color: #2874f0;
    box-shadow: inset 0 0 0 1px rgba(40,116,240,0.25);
}

.premium-checkout-address strong,
.premium-checkout-choice strong {
    color: #0f172a;
}

.premium-checkout-address span,
.premium-checkout-address p,
.premium-checkout-choice span {
    margin: 0;
    color: #64748b;
    line-height: 1.5;
}

.premium-checkout-toggle-row,
.premium-checkout-single-toggle,
.premium-checkout-gst {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    margin-top: 0.9rem;
}

.premium-checkout-toggle-row label,
.premium-checkout-single-toggle,
.premium-checkout-gst {
    align-items: center;
    gap: 0.45rem;
    font-weight: 800;
    color: #334155;
}

.premium-checkout-address-form {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.8rem;
    margin-top: 0.9rem;
    border-top: 1px dashed rgba(15,23,42,0.16);
    padding-top: 0.9rem;
}

.premium-checkout-address-form label,
.premium-checkout-notes {
    display: grid;
    gap: 0.35rem;
    color: #334155;
    font-weight: 850;
}

.premium-checkout-address-form .is-wide,
.premium-checkout-toggle-row.is-wide {
    grid-column: 1 / -1;
}

.premium-checkout-address-form input,
.premium-checkout-address-form select,
.premium-checkout-notes textarea {
    width: 100%;
    min-height: 44px;
    border: 1px solid rgba(15,23,42,0.12);
    border-radius: 0.45rem;
    background: rgba(255,255,255,0.86);
    color: #0f172a;
    padding: 0 0.75rem;
}

.premium-checkout-items {
    display: grid;
    gap: 0.75rem;
}

.premium-checkout-item {
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr) auto;
    gap: 0.9rem;
    align-items: start;
    border-bottom: 1px solid rgba(15,23,42,0.08);
    padding-bottom: 0.85rem;
}

.premium-checkout-item img {
    width: 92px;
    height: 92px;
    object-fit: cover;
    border-radius: 0.5rem;
    background: #f8fafc;
}

.premium-checkout-item h3 {
    margin: 0 0 0.25rem;
    color: #0f172a;
    font-size: 1rem;
}

.premium-checkout-item p {
    margin: 0 0 0.25rem;
}

.premium-open-box {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.9rem;
    align-items: start;
}

.premium-open-box i {
    color: #ffb000;
    font-size: 1.6rem;
}

.premium-checkout-notes {
    margin-top: 1rem;
}

.premium-checkout-notes textarea {
    min-height: 86px;
    padding-block: 0.7rem;
}

.premium-checkout-terms {
    padding: 1rem;
    font-size: 0.82rem;
}

.premium-checkout-right {
    position: sticky;
    top: 6rem;
}

.premium-checkout-summary {
    padding: 0.8rem;
}

.premium-black-offer {
    display: grid;
    grid-template-columns: 62px minmax(0, 1fr) auto;
    gap: 0.8rem;
    align-items: center;
    border-radius: 0.75rem;
    background: linear-gradient(135deg, #edf4ff, #f8fbff);
    padding: 0.75rem;
}

.premium-black-logo {
    border-radius: 0.45rem;
    background: #142032;
    color: #fff;
    font-weight: 950;
    font-size: 0.68rem;
    text-align: center;
    padding: 0.65rem 0.35rem;
}

.premium-black-offer strong,
.premium-black-offer span {
    display: block;
}

.premium-black-offer span {
    color: #475569;
    font-size: 0.82rem;
}

.premium-black-offer button,
.premium-checkout-continue,
.premium-checkout-login button {
    border: 0;
    border-radius: 0.45rem;
    background: #2874f0;
    color: #fff;
    font-weight: 900;
    min-height: 38px;
    padding: 0 1rem;
}

.premium-checkout-price {
    margin-top: 0.7rem;
    padding: 0.9rem;
    border-radius: 0.6rem;
    background: rgba(255,255,255,0.72);
}

.premium-checkout-price dl {
    display: grid;
    gap: 0.78rem;
    margin: 0;
}

.premium-checkout-price dl div,
.premium-checkout-total,
.premium-checkout-mini-total {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
}

.premium-checkout-price dt,
.premium-checkout-price dd {
    margin: 0;
}

.premium-checkout-price dd {
    font-weight: 850;
}

.premium-checkout-price .is-green {
    color: #0f9f4a;
}

.premium-checkout-total {
    border-top: 1px dashed rgba(15,23,42,0.2);
    margin-top: 0.9rem;
    padding-top: 0.85rem;
    align-items: end;
}

.premium-checkout-total strong {
    font-size: 1.25rem;
}

.premium-checkout-mini-total {
    margin-top: 0.7rem;
    align-items: center;
    color: #0f172a;
}

.premium-checkout-mini-total span {
    font-size: 1.2rem;
    font-weight: 900;
}

.premium-checkout-continue {
    width: 100%;
    min-height: 46px;
    margin-top: 0.75rem;
    background: linear-gradient(135deg, #ffb000, #ff7a00);
    color: #111827;
}

.premium-checkout-login {
    padding-top: 2rem;
}

.premium-checkout-login > div {
    padding: 2rem;
}

.premium-checkout-login a {
    display: inline-flex;
    margin-left: 0.6rem;
    color: #155bd6;
    font-weight: 850;
    text-decoration: none;
}

body.dark-mode .premium-checkout-page {
    background:
        radial-gradient(circle at 10% 8%, rgba(40,116,240,0.14), transparent 32%),
        linear-gradient(180deg, #0d172a, #0b1020);
}

body.dark-mode .premium-checkout-steps,
body.dark-mode .premium-checkout-section,
body.dark-mode .premium-checkout-summary,
body.dark-mode .premium-checkout-login > div,
body.dark-mode .premium-checkout-address,
body.dark-mode .premium-checkout-choice,
body.dark-mode .premium-checkout-price {
    background: rgba(17,28,50,0.88);
    border-color: rgba(141,179,255,0.18);
    color: #edf3ff;
}

body.dark-mode .premium-checkout-address strong,
body.dark-mode .premium-checkout-choice strong,
body.dark-mode .premium-checkout-item h3,
body.dark-mode .premium-checkout-mini-total,
body.dark-mode .premium-checkout-address-form label,
body.dark-mode .premium-checkout-notes,
body.dark-mode .premium-checkout-toggle-row label,
body.dark-mode .premium-checkout-single-toggle,
body.dark-mode .premium-checkout-gst {
    color: #edf3ff;
}

body.dark-mode .premium-checkout-section p,
body.dark-mode .premium-checkout-section small,
body.dark-mode .premium-checkout-address span,
body.dark-mode .premium-checkout-address p,
body.dark-mode .premium-checkout-choice span,
body.dark-mode .premium-black-offer span {
    color: #aebbd3;
}

body.dark-mode .premium-checkout-address-form input,
body.dark-mode .premium-checkout-address-form select,
body.dark-mode .premium-checkout-notes textarea,
body.dark-mode .premium-checkout-item img {
    background: rgba(141,179,255,0.08);
    border-color: rgba(141,179,255,0.18);
    color: #edf3ff;
}

body.dark-mode .premium-black-offer {
    background: rgba(141,179,255,0.08);
}

.premium-address-panel,
.premium-address-form-panel {
    padding: 1.4rem;
    margin-bottom: 1rem;
}

.premium-address-head,
.premium-address-form-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.2rem;
}

.premium-address-head h1,
.premium-address-form-head h2 {
    margin: 0.25rem 0;
    font-size: clamp(1.35rem, 2.2vw, 2rem);
}

.premium-address-head p {
    color: #64748b;
    margin: 0;
}

.premium-address-list {
    display: grid;
    gap: 0.9rem;
}

.premium-address-card,
.premium-address-empty {
    border: 1px solid rgba(15,23,42,0.08);
    border-radius: 0.65rem;
    background: rgba(248,250,252,0.76);
    padding: 1rem;
}

.premium-address-card-top,
.premium-address-name,
.premium-address-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    align-items: center;
}

.premium-address-card-top {
    justify-content: space-between;
}

.premium-address-card-top button {
    border: 0;
    background: transparent;
    color: #64748b;
}

.premium-address-label,
.premium-address-badges span {
    border-radius: 0.35rem;
    background: rgba(40,116,240,0.08);
    color: #155bd6;
    padding: 0.35rem 0.55rem;
    font-size: 0.76rem;
    font-weight: 900;
    text-transform: uppercase;
}

.premium-address-name {
    margin-top: 0.65rem;
}

.premium-address-name strong {
    color: #0f172a;
}

.premium-address-name span,
.premium-address-card p {
    color: #475569;
}

.premium-address-card p {
    margin: 0.7rem 0 0;
    line-height: 1.6;
}

.premium-address-badges {
    margin-top: 0.8rem;
}

.premium-address-badges span {
    background: rgba(15,159,74,0.1);
    color: #0f8f43;
}

.premium-address-empty {
    display: grid;
    place-items: center;
    gap: 0.5rem;
    text-align: center;
    min-height: 180px;
    color: #64748b;
}

.premium-address-empty strong {
    color: #0f172a;
}

.premium-address-form {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
}

.premium-address-form label {
    display: grid;
    gap: 0.35rem;
    font-weight: 850;
    color: #334155;
}

.premium-address-form label.is-wide,
.premium-address-validations,
.premium-address-switches,
.premium-address-actions {
    grid-column: 1 / -1;
}

.premium-address-validations {
    display: grid;
    gap: 0.25rem;
}

.premium-address-switches,
.premium-address-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    align-items: center;
}

.premium-address-switches label {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    border: 1px solid rgba(15,23,42,0.1);
    border-radius: 999px;
    padding: 0.6rem 0.8rem;
    background: rgba(255,255,255,0.64);
}

.premium-address-switches input {
    width: auto;
    min-height: auto;
}

body.dark-mode .premium-cart-page,
body.dark-mode .premium-address-page {
    background:
        radial-gradient(circle at 10% 8%, rgba(183,44,219,0.15), transparent 32%),
        linear-gradient(180deg, #0d172a, #0b1020);
}

body.dark-mode .premium-cart-tabs,
body.dark-mode .premium-cart-address-strip,
body.dark-mode .premium-cart-row,
body.dark-mode .premium-cart-coupon,
body.dark-mode .premium-price-card,
body.dark-mode .premium-cart-trust,
body.dark-mode .premium-cart-empty-page,
body.dark-mode .premium-address-panel,
body.dark-mode .premium-address-form-panel,
body.dark-mode .premium-address-card,
body.dark-mode .premium-address-empty {
    background: rgba(17,28,50,0.86);
    border-color: rgba(141,179,255,0.18);
    color: #edf3ff;
}

body.dark-mode .premium-cart-title,
body.dark-mode .premium-cart-price-line strong,
body.dark-mode .premium-address-name strong,
body.dark-mode .premium-address-empty strong {
    color: #edf3ff;
}

body.dark-mode .premium-cart-copy p,
body.dark-mode .premium-cart-rating small,
body.dark-mode .premium-cart-perks,
body.dark-mode .premium-cart-coupon p,
body.dark-mode .premium-cart-trust,
body.dark-mode .premium-address-head p,
body.dark-mode .premium-address-name span,
body.dark-mode .premium-address-card p,
body.dark-mode .premium-address-form label {
    color: #aebbd3;
}

body.dark-mode .premium-cart-media,
body.dark-mode .premium-address-switches label,
body.dark-mode .premium-cart-coupon input,
body.dark-mode .premium-address-form input,
body.dark-mode .premium-address-form select {
    background: rgba(141,179,255,0.08);
    border-color: rgba(141,179,255,0.18);
    color: #edf3ff;
}

@media (max-width: 1100px) {
    .premium-cart-main,
    .premium-checkout-main,
    .premium-checkout-login {
        grid-template-columns: 1fr;
    }

    .premium-price-card,
    .premium-checkout-right {
        position: static;
    }
}

@media (max-width: 760px) {
    .premium-cart-wrap {
        width: min(100% - 22px, 1460px);
    }

    .premium-cart-product,
    .premium-cart-coupon,
    .premium-address-form,
    .premium-checkout-address-form,
    .premium-checkout-item {
        grid-template-columns: 1fr;
    }

    .premium-cart-media {
        width: 100%;
        height: 220px;
    }

    .premium-cart-row-actions,
    .premium-cart-address-strip,
    .premium-address-head,
    .premium-address-form-head,
    .premium-checkout-section header,
    .premium-black-offer {
        align-items: stretch;
        flex-direction: column;
    }

    .premium-checkout-steps {
        font-size: 0.78rem;
    }
}

@media (max-width: 760px) {
    .premium-qv-grid {
        grid-template-columns: 1fr;
        padding: 22px;
    }

    .premium-qv-media {
        min-height: 280px;
    }

    .product-detail-shell .detail-content-card > .row > .col-xl-3 {
        flex: 0 0 100%;
        max-width: 100%;
    }

    .product-detail-shell .detail-content-card .shop-card-actions {
        grid-template-columns: 1fr;
    }
}

@keyframes premiumBankMarquee {
    from {
        transform: translateX(0);
    }
    to {
        transform: translateX(-50%);
    }
}

@media (max-width: 768px) {
    .premium-bank-offers-head {
        align-items: flex-start;
        flex-direction: column;
        width: calc(100% - 28px);
    }

    .premium-bank-card {
        width: 320px;
        grid-template-columns: 1fr;
        align-items: start;
        gap: 0.9rem;
    }

    .premium-bank-logo {
        width: 132px;
    }
}
