/* Craft Checkout Side Cart
   Integrated into Craft Checkout for WooCommerce v1.3.4 — isolated side-cart assets */
.spcsc-root,
.spcsc-trigger,
.spcsc-navbar-menu-item {
    --spcsc-clay: #8B7353;
    --spcsc-cream: #F3EEE5;
    --spcsc-ink: #2A2520;
    --spcsc-muted: #6E6256;
    --spcsc-rust: #8A3A2B;
    --spcsc-line: rgba(42, 37, 32, .12);
    --spcsc-shadow: 0 24px 70px rgba(42, 37, 32, .22);
}

html.spcsc-side-cart-open,
body.spcsc-side-cart-open {
    overflow: hidden;
}

.spcsc-trigger {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .45rem;
    min-height: 42px;
    padding: .55rem .85rem;
    border: 1px solid var(--spcsc-line);
    border-radius: 999px;
    background: rgba(243, 238, 229, .92);
    color: var(--spcsc-ink);
    font: inherit;
    line-height: 1;
    cursor: pointer;
    text-decoration: none;
    box-shadow: 0 10px 26px rgba(42, 37, 32, .08);
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
}

.spcsc-trigger:hover,
.spcsc-trigger:focus-visible {
    transform: translateY(-1px);
    background: #fff;
    border-color: rgba(139, 115, 83, .35);
    box-shadow: 0 14px 32px rgba(42, 37, 32, .14);
    color: var(--spcsc-ink);
    outline: none;
}


.spcsc-trigger--icon-only {
    width: 42px;
    height: 42px;
    min-width: 42px;
    min-height: 42px;
    padding: 0;
    gap: 0;
}

.spcsc-trigger--icon-only .spcsc-trigger__icon {
    margin: 0;
}

.spcsc-trigger--icon-only .spcsc-trigger__label,
.spcsc-trigger--icon-only .spcsc-trigger__subtotal {
    display: none !important;
}

.spcsc-trigger__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.2rem;
    height: 1.2rem;
    color: var(--spcsc-clay);
}

.spcsc-trigger__label {
    font-weight: 700;
    letter-spacing: .01em;
}

.spcsc-trigger__subtotal {
    color: var(--spcsc-muted);
    font-size: .9em;
}

.spcsc-trigger__count {
    position: absolute;
    top: -.38rem;
    right: -.38rem;
    min-width: 1.25rem;
    height: 1.25rem;
    padding: 0 .32rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: var(--spcsc-rust);
    color: #fff;
    font-size: .72rem;
    font-weight: 800;
    line-height: 1;
    box-shadow: 0 6px 14px rgba(138, 58, 43, .28);
}

.spcsc-trigger--empty .spcsc-trigger__count {
    background: var(--spcsc-muted);
}

.spcsc-floating-wrap {
    position: fixed;
    right: var(--spcsc-floating-right, 1rem);
    bottom: var(--spcsc-floating-bottom, 1rem);
    z-index: 99940;
}

.spcsc-floating-wrap--bottom-right {
    right: var(--spcsc-floating-right, 1rem);
    left: auto;
    bottom: var(--spcsc-floating-bottom, 1rem);
    top: auto;
    transform: none;
}

.spcsc-floating-wrap--middle-right {
    right: var(--spcsc-floating-right, 1rem);
    left: auto;
    top: 50%;
    bottom: auto;
    transform: translateY(-50%);
}

.spcsc-floating-wrap--top-right {
    right: var(--spcsc-floating-right, 1rem);
    left: auto;
    top: var(--spcsc-floating-top, 120px);
    bottom: auto;
    transform: none;
}

.spcsc-floating-wrap--bottom-left {
    left: var(--spcsc-floating-left, 1rem);
    right: auto;
    bottom: var(--spcsc-floating-bottom, 1rem);
    top: auto;
    transform: none;
}

.spcsc-floating-wrap--middle-left {
    left: var(--spcsc-floating-left, 1rem);
    right: auto;
    top: 50%;
    bottom: auto;
    transform: translateY(-50%);
}

.spcsc-floating-wrap--top-left {
    left: var(--spcsc-floating-left, 1rem);
    right: auto;
    top: var(--spcsc-floating-top, 120px);
    bottom: auto;
    transform: none;
}

/* Backward compatibility for older saved settings/classes. */
.spcsc-floating-wrap--bottom {
    right: var(--spcsc-floating-right, 1rem);
    bottom: var(--spcsc-floating-bottom, 1rem);
    top: auto;
    transform: none;
}

.spcsc-floating-wrap--center {
    right: var(--spcsc-floating-right, 1rem);
    top: 50%;
    bottom: auto;
    transform: translateY(-50%);
}

.spcsc-floating-wrap--top {
    right: var(--spcsc-floating-right, 1rem);
    top: var(--spcsc-floating-top, 120px);
    bottom: auto;
    transform: none;
}

.spcsc-floating-wrap .spcsc-trigger {
    width: 58px;
    height: 58px;
    padding: 0;
    background: var(--spcsc-ink);
    color: #fff;
    border-color: rgba(255,255,255,.12);
    box-shadow: 0 18px 42px rgba(42, 37, 32, .24);
}

.spcsc-floating-wrap 
.spcsc-trigger--icon-only {
    width: 42px;
    height: 42px;
    min-width: 42px;
    min-height: 42px;
    padding: 0;
    gap: 0;
}

.spcsc-trigger--icon-only .spcsc-trigger__icon {
    margin: 0;
}

.spcsc-trigger--icon-only .spcsc-trigger__label,
.spcsc-trigger--icon-only .spcsc-trigger__subtotal {
    display: none !important;
}

.spcsc-floating-wrap .spcsc-trigger__icon {
    color: #fff;
    font-size: 1.25rem;
}

.spcsc-floating-wrap .spcsc-trigger__label,
.spcsc-floating-wrap .spcsc-trigger__subtotal {
    display: none;
}

.spcsc-drawer {
    position: fixed;
    inset: 0;
    z-index: 99950;
    pointer-events: none;
    visibility: hidden;
}

.spcsc-drawer__overlay {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
    background: rgba(42, 37, 32, .42);
    opacity: 0;
    cursor: pointer;
    transition: opacity .22s ease;
}

.spcsc-drawer__drawer {
    position: absolute;
    top: 0;
    right: 0;
    width: min(var(--spcsc-drawer-width, 430px), calc(100vw - 18px));
    height: 100%;
    display: flex;
    flex-direction: column;
    background: linear-gradient(180deg, #fff 0%, var(--spcsc-cream) 100%);
    color: var(--spcsc-ink);
    box-shadow: var(--spcsc-shadow);
    transform: translateX(105%);
    transition: transform .26s ease;
    pointer-events: auto;
}

.spcsc-drawer--right .spcsc-drawer__drawer {
    right: 0;
    left: auto;
    transform: translateX(105%);
}

.spcsc-drawer--left .spcsc-drawer__drawer {
    left: 0;
    right: auto;
    transform: translateX(-105%);
}

.spcsc-drawer--left .spcsc-drawer__drawer {
    box-shadow: 24px 0 70px rgba(42, 37, 32, .22);
}

.spcsc-drawer--active {
    pointer-events: auto;
    visibility: visible;
}

.spcsc-drawer--active .spcsc-drawer__overlay {
    opacity: 1;
}

.spcsc-drawer--active .spcsc-drawer__drawer {
    transform: translateX(0);
}

.spcsc-drawer__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.25rem 1.25rem 1rem;
    border-bottom: 1px solid var(--spcsc-line);
    background: rgba(255,255,255,.72);
    backdrop-filter: blur(10px);
}

.spcsc-drawer__eyebrow {
    margin: 0 0 .2rem;
    color: var(--spcsc-clay);
    font-size: .74rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .12em;
}

.spcsc-drawer__header h2 {
    margin: 0;
    color: var(--spcsc-ink);
    font-size: 1.35rem;
    font-weight: 800;
    line-height: 1.15;
}

.spcsc-drawer__close {
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--spcsc-line);
    border-radius: 999px;
    background: #fff;
    color: var(--spcsc-ink);
    font-size: 1.55rem;
    line-height: 1;
    cursor: pointer;
}

.spcsc-drawer__content {
    flex: 1;
    overflow: auto;
    padding: 1rem;
}

.spcsc-drawer__items {
    display: grid;
    gap: .85rem;
}

.spcsc-drawer__item {
    display: grid;
    grid-template-columns: 76px minmax(0, 1fr);
    gap: .85rem;
    position: relative;
    padding: .85rem;
    border: 1px solid var(--spcsc-line);
    border-radius: 20px;
    background: rgba(255,255,255,.82);
    box-shadow: 0 10px 26px rgba(42, 37, 32, .06);
}

.spcsc-drawer__thumb {
    width: 76px;
    height: 76px;
    overflow: hidden;
    border-radius: 16px;
    background: var(--spcsc-cream);
    border: 1px solid rgba(42, 37, 32, .08);
}

.spcsc-drawer__thumb img,
.spcsc-drawer__thumb-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.spcsc-drawer__item-main {
    min-width: 0;
    padding-right: 4.4rem;
}

.spcsc-drawer__item-title {
    margin: 0 0 .3rem;
    color: var(--spcsc-ink);
    font-size: .98rem;
    font-weight: 800;
    line-height: 1.25;
}

.spcsc-drawer__item-title a {
    color: inherit;
    text-decoration: none;
}

.spcsc-drawer__item-title a:hover {
    color: var(--spcsc-rust);
}

.spcsc-drawer__meta {
    color: var(--spcsc-muted);
    font-size: .8rem;
}

.spcsc-drawer__meta dl,
.spcsc-drawer__meta p {
    margin: 0;
}

.spcsc-drawer__price {
    color: var(--spcsc-muted);
    font-size: .86rem;
    margin: .2rem 0 .55rem;
}

.spcsc-drawer__line-total {
    position: absolute;
    top: .9rem;
    right: .9rem;
    color: var(--spcsc-ink);
    font-weight: 800;
    font-size: .92rem;
}

.spcsc-drawer__qty-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .35rem;
}

.spcsc-drawer__qty-btn,
.spcsc-drawer__remove {
    border: 1px solid var(--spcsc-line);
    background: #fff;
    color: var(--spcsc-ink);
    min-width: 34px;
    height: 34px;
    border-radius: 999px;
    font-weight: 800;
    cursor: pointer;
}

.spcsc-drawer__qty-btn:hover,
.spcsc-drawer__remove:hover {
    border-color: rgba(139, 115, 83, .36);
    color: var(--spcsc-rust);
}

.spcsc-drawer__qty {
    width: 56px;
    height: 34px;
    text-align: center;
    border: 1px solid var(--spcsc-line);
    border-radius: 999px;
    background: #fff;
    color: var(--spcsc-ink);
    font-weight: 700;
}

.spcsc-drawer__remove {
    padding: 0 .75rem;
    color: var(--spcsc-rust);
    font-size: .8rem;
}

.spcsc-drawer__footer {
    padding: 1rem 1.25rem 1.25rem;
    border-top: 1px solid var(--spcsc-line);
    background: rgba(255,255,255,.82);
}

.spcsc-drawer__subtotal {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    font-size: 1rem;
    margin-bottom: .35rem;
}

.spcsc-drawer__subtotal strong {
    font-size: 1.2rem;
    color: var(--spcsc-ink);
}

.spcsc-drawer__note {
    margin: 0 0 .85rem;
    color: var(--spcsc-muted);
    font-size: .85rem;
}

.spcsc-drawer__actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .65rem;
}

.spcsc-drawer__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: .75rem 1rem;
    border-radius: 999px;
    font-weight: 800;
    text-decoration: none;
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.spcsc-drawer__btn:hover {
    transform: translateY(-1px);
    text-decoration: none;
}

.spcsc-drawer__btn--primary {
    background: var(--spcsc-ink);
    color: #fff;
    box-shadow: 0 12px 26px rgba(42, 37, 32, .18);
}

.spcsc-drawer__btn--primary:hover {
    color: #fff;
    background: #1f1a16;
}

.spcsc-drawer__btn--ghost {
    background: #fff;
    color: var(--spcsc-ink);
    border: 1px solid var(--spcsc-line);
}

.spcsc-drawer__empty {
    min-height: 300px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 2rem;
    border: 1px dashed rgba(139, 115, 83, .35);
    border-radius: 24px;
    background: rgba(255,255,255,.62);
}

.spcsc-drawer__empty-icon {
    width: 62px;
    height: 62px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: .85rem;
    border-radius: 999px;
    background: var(--spcsc-cream);
    color: var(--spcsc-clay);
    font-size: 1.45rem;
}

.spcsc-drawer__empty h3 {
    margin: 0 0 .4rem;
    color: var(--spcsc-ink);
    font-weight: 800;
}

.spcsc-drawer__empty p {
    margin: 0;
    color: var(--spcsc-muted);
}

.spcsc-drawer__loader {
    position: absolute;
    inset: 0;
    display: none;
    background: rgba(255,255,255,.54);
    backdrop-filter: blur(2px);
}

.spcsc-drawer--loading .spcsc-drawer__loader {
    display: block;
}

.spcsc-notice {
    position: fixed;
    left: 50%;
    bottom: 1.25rem;
    transform: translateX(-50%);
    z-index: 99970;
    max-width: min(420px, calc(100vw - 2rem));
    padding: .85rem 1rem;
    border-radius: 999px;
    background: var(--spcsc-ink);
    color: #fff;
    font-size: .9rem;
    font-weight: 700;
    box-shadow: 0 14px 32px rgba(42, 37, 32, .2);
}

.spcsc-notice--error {
    background: var(--spcsc-rust);
}

.spcsc-navbar-menu-item {
    display: flex;
    align-items: center;
}

.spcsc-navbar-menu-item .spcsc-trigger {
    margin-left: .35rem;
}

@media (max-width: 575.98px) {
    .spcsc-drawer__drawer {
        width: 100vw;
    }

    .spcsc-drawer__header,
    .spcsc-drawer__footer {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .spcsc-drawer__item {
        grid-template-columns: 64px minmax(0, 1fr);
        border-radius: 18px;
    }

    .spcsc-drawer__thumb {
        width: 64px;
        height: 64px;
    }

    .spcsc-drawer__item-main {
        padding-right: 0;
    }

    .spcsc-drawer__line-total {
        position: static;
        grid-column: 2;
        margin-top: -.35rem;
    }

    .spcsc-drawer__actions {
        grid-template-columns: 1fr;
    }

    .spcsc-floating-wrap {
        right: .85rem;
        bottom: .85rem;
    }
}

/* Side cart quantity controls refinement - v1.3.1 */
.spcsc-drawer .spcsc-drawer__qty-row {
    display: flex;
    align-items: center;
    gap: .55rem;
    flex-wrap: nowrap;
    margin-top: .55rem;
}

.spcsc-drawer .spcsc-drawer__qty-control {
    display: inline-flex;
    align-items: center;
    flex: 0 0 auto;
    height: 38px;
    padding: 3px;
    gap: 2px;
    border: 1px solid var(--spcsc-line);
    border-radius: 999px;
    background: #fff;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.7);
}

.spcsc-drawer .spcsc-drawer__qty-btn {
    width: 30px !important;
    min-width: 30px !important;
    max-width: 30px !important;
    height: 30px !important;
    min-height: 30px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 999px !important;
    background: rgba(243, 238, 229, .72) !important;
    color: var(--spcsc-ink) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: .95rem !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    box-shadow: none !important;
}

.spcsc-drawer .spcsc-drawer__qty-btn:hover,
.spcsc-drawer .spcsc-drawer__qty-btn:focus {
    background: var(--spcsc-ink) !important;
    color: #fff !important;
    outline: none !important;
}

.spcsc-drawer .spcsc-drawer__qty {
    flex: 0 0 42px !important;
    width: 42px !important;
    min-width: 42px !important;
    max-width: 42px !important;
    height: 30px !important;
    min-height: 30px !important;
    margin: 0 !important;
    padding: 0 .15rem !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    color: var(--spcsc-ink) !important;
    text-align: center !important;
    font-size: .95rem !important;
    font-weight: 800 !important;
    line-height: 30px !important;
    box-shadow: none !important;
    appearance: textfield;
    -moz-appearance: textfield;
}

.spcsc-drawer .spcsc-drawer__qty::-webkit-outer-spin-button,
.spcsc-drawer .spcsc-drawer__qty::-webkit-inner-spin-button {
    margin: 0;
    -webkit-appearance: none;
}

.spcsc-drawer .spcsc-drawer__remove {
    flex: 0 0 auto;
    height: 36px !important;
    min-height: 36px !important;
    padding: 0 .82rem !important;
    border-radius: 999px !important;
    background: #fff !important;
    color: var(--spcsc-rust) !important;
    white-space: nowrap;
}

.spcsc-drawer.spcsc-drawer--loading .spcsc-drawer__qty-btn,
.spcsc-drawer.spcsc-drawer--loading .spcsc-drawer__qty,
.spcsc-drawer.spcsc-drawer--loading .spcsc-drawer__remove {
    pointer-events: none;
}

@media (max-width: 575.98px) {
    .spcsc-drawer .spcsc-drawer__qty-row {
        gap: .45rem;
        justify-content: flex-start;
    }

    .spcsc-drawer .spcsc-drawer__qty-control {
        height: 36px;
    }

    .spcsc-drawer .spcsc-drawer__qty-btn {
        width: 28px !important;
        min-width: 28px !important;
        max-width: 28px !important;
        height: 28px !important;
        min-height: 28px !important;
    }

    .spcsc-drawer .spcsc-drawer__qty {
        flex-basis: 38px !important;
        width: 38px !important;
        min-width: 38px !important;
        max-width: 38px !important;
        height: 28px !important;
        min-height: 28px !important;
        line-height: 28px !important;
    }
}

/* Side cart speed refinement - v1.3.3 */
.spcsc-drawer.spcsc-drawer--syncing .spcsc-drawer__drawer::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, transparent, var(--spcsc-clay), transparent);
    animation: spcscCartSync 1s linear infinite;
    z-index: 4;
}

@keyframes spcscCartSync {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(100%); }
}

.spcsc-drawer__subtotal--syncing strong::after {
    content: ' syncing';
    margin-left: .35rem;
    color: var(--spcsc-muted);
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.spcsc-drawer__item--pending-remove {
    opacity: .45;
    transform: scale(.99);
    pointer-events: none;
}

/* Admin-configurable sidebar checkout options */
.spcsc-root,
.spcsc-trigger,
.spcsc-navbar-menu-item {
    --spcsc-button-bg: #2A2520;
    --spcsc-button-text: #ffffff;
    --spcsc-floating-right: 16px;
    --spcsc-floating-top: 120px;
    --spcsc-floating-bottom: 16px;
    --spcsc-drawer-width: 430px;
}

.spcsc-trigger--hide-when-empty.spcsc-trigger--empty {
    display: none !important;
}

.spcsc-floating-wrap {
    right: var(--spcsc-floating-right);
    bottom: var(--spcsc-floating-bottom);
}

.spcsc-floating-wrap--top {
    top: var(--spcsc-floating-top);
    bottom: auto;
}

.spcsc-floating-wrap--center {
    top: 50%;
    bottom: auto;
    transform: translateY(-50%);
}

.spcsc-floating-wrap--bottom {
    bottom: var(--spcsc-floating-bottom);
}

.spcsc-floating-wrap .spcsc-trigger {
    background: var(--spcsc-button-bg);
    color: var(--spcsc-button-text);
}

.spcsc-floating-wrap .spcsc-trigger__icon {
    color: var(--spcsc-button-text);
}

.spcsc-drawer__drawer {
    width: min(var(--spcsc-drawer-width), calc(100vw - 18px));
}

.spcsc-drawer__btn--primary {
    background: var(--spcsc-button-bg);
    color: var(--spcsc-button-text);
}

.spcsc-drawer__btn--primary:hover {
    color: var(--spcsc-button-text);
    filter: brightness(.92);
}

@media (max-width: 767.98px) {
    .spcsc-floating-wrap--hide-mobile {
        display: none !important;
    }
}

/* Craft Checkout 1.2.0 side cart value features */
.spcsc-drawer__footer .spc-free-shipping-bar{margin:0 0 14px;padding:12px;border-radius:16px}.spcsc-upsells{display:grid;gap:10px;margin:0 0 14px}.spcsc-upsells h3{margin:0;color:var(--spcsc-text,#2A2520);font-size:14px}.spcsc-upsell{display:grid;grid-template-columns:48px minmax(0,1fr);gap:10px;align-items:center;padding:10px;border:1px solid rgba(42,37,32,.12);border-radius:14px;background:#fff;text-decoration:none}.spcsc-upsell__img img{width:48px;height:48px;object-fit:cover;border-radius:10px}.spcsc-upsell__copy strong{display:block;color:var(--spcsc-text,#2A2520);font-size:13px;line-height:1.25}.spcsc-upsell__copy em{display:block;margin-top:3px;color:var(--spcsc-accent,#8B7353);font-style:normal;font-weight:800;font-size:12px}

/* Theme-safe icons. These use inline SVG so the plugin works even when Font Awesome is not loaded. */
.spc-theme-icon{display:inline-flex;width:1em;height:1em;align-items:center;justify-content:center;line-height:1;vertical-align:-.125em;flex:0 0 auto}
.spc-theme-icon svg{width:1em;height:1em;display:block;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}


/* =========================================================
   v1.2.21 Side cart premium UI polish
   Visual-only. Existing drawer, quantity, remove, subtotal, and AJAX logic unchanged.
   ========================================================= */

.spcsc-root,
.spcsc-trigger,
.spcsc-navbar-menu-item {
    --spcsc-premium-surface: #fffaf3;
    --spcsc-premium-card: #ffffff;
    --spcsc-premium-line: rgba(42,37,32,.105);
    --spcsc-premium-shadow: 0 28px 80px rgba(42,37,32,.24);
}

.spcsc-floating-wrap .spcsc-trigger {
    width: 62px;
    height: 62px;
    border: 1px solid rgba(255,255,255,.16);
    background: linear-gradient(135deg, var(--spcsc-ink), #171310);
    box-shadow: 0 18px 44px rgba(42,37,32,.26);
}

.spcsc-floating-wrap .spcsc-trigger:hover,
.spcsc-floating-wrap .spcsc-trigger:focus-visible {
    transform: translateY(-2px) scale(1.02);
    box-shadow: 0 24px 54px rgba(42,37,32,.30);
}

.spcsc-trigger__count {
    top: -.42rem;
    right: -.42rem;
    min-width: 1.42rem;
    height: 1.42rem;
    border: 2px solid #fff;
    font-size: .72rem;
}

.spcsc-drawer__overlay {
    background: rgba(23,19,16,.54);
    backdrop-filter: blur(2px);
}

.spcsc-drawer__drawer {
    width: min(var(--spcsc-drawer-width, 450px), calc(100vw - 14px));
    background:
        radial-gradient(circle at top left, rgba(139,115,83,.12), transparent 34%),
        linear-gradient(180deg, #fff 0%, var(--spcsc-premium-surface) 100%);
    box-shadow: var(--spcsc-premium-shadow);
}

.spcsc-drawer__header {
    padding: 1.35rem 1.35rem 1.1rem;
    background: rgba(255,255,255,.88);
    border-bottom: 1px solid var(--spcsc-premium-line);
}

.spcsc-drawer__eyebrow {
    color: var(--spcsc-rust);
    font-size: .72rem;
    font-weight: 950;
}

.spcsc-drawer__header h2 {
    font-size: clamp(1.35rem, 3vw, 1.7rem);
    font-weight: 950;
    letter-spacing: -.035em;
}

.spcsc-drawer__close {
    width: 44px;
    height: 44px;
    background: #fff;
    box-shadow: 0 10px 24px rgba(42,37,32,.08);
    transition: transform .16s ease, border-color .16s ease, color .16s ease;
}

.spcsc-drawer__close:hover,
.spcsc-drawer__close:focus-visible {
    transform: rotate(5deg) scale(1.02);
    border-color: rgba(138,58,43,.28);
    color: var(--spcsc-rust);
}

.spcsc-drawer__content {
    padding: 1.05rem;
}

.spcsc-drawer__items {
    gap: .95rem;
}

.spcsc-drawer__item {
    grid-template-columns: 82px minmax(0, 1fr);
    gap: .95rem;
    padding: .95rem;
    border-radius: 24px;
    background: rgba(255,255,255,.84);
    border-color: var(--spcsc-premium-line);
    box-shadow: 0 12px 28px rgba(42,37,32,.055);
    transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.spcsc-drawer__item:hover {
    transform: translateY(-1px);
    border-color: rgba(139,115,83,.22);
    box-shadow: 0 18px 38px rgba(42,37,32,.09);
}

.spcsc-drawer__thumb {
    width: 82px;
    height: 82px;
    border-radius: 18px;
    background: #f3eee5;
    box-shadow: 0 8px 18px rgba(42,37,32,.055);
}

.spcsc-drawer__item-title {
    font-size: 1rem;
    font-weight: 950;
    letter-spacing: -.012em;
}

.spcsc-drawer__price {
    font-weight: 750;
}

.spcsc-drawer__line-total {
    top: .95rem;
    right: .95rem;
    padding: 4px 8px;
    border-radius: 999px;
    background: rgba(138,58,43,.07);
    color: var(--spcsc-rust);
    font-weight: 950;
}

.spcsc-drawer .spcsc-drawer__qty-control {
    border-radius: 999px;
    background: #fff;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
}

.spcsc-drawer .spcsc-drawer__qty-btn,
.spcsc-drawer__remove {
    transition: transform .14s ease, color .14s ease, border-color .14s ease, background-color .14s ease;
}

.spcsc-drawer .spcsc-drawer__qty-btn:hover,
.spcsc-drawer .spcsc-drawer__qty-btn:focus-visible,
.spcsc-drawer__remove:hover,
.spcsc-drawer__remove:focus-visible {
    transform: translateY(-1px);
}

.spcsc-drawer__footer {
    padding: 1.1rem 1.35rem 1.35rem;
    background: rgba(255,255,255,.9);
    border-top: 1px solid var(--spcsc-premium-line);
    box-shadow: 0 -12px 30px rgba(42,37,32,.05);
}

.spcsc-drawer__subtotal {
    margin-bottom: .55rem;
    font-weight: 850;
}

.spcsc-drawer__subtotal strong {
    font-size: 1.32rem;
    font-weight: 950;
    color: var(--spcsc-rust);
}

.spcsc-drawer__note {
    margin-bottom: 1rem;
    line-height: 1.45;
}

.spcsc-drawer__btn {
    min-height: 48px;
    border-radius: 999px;
    font-weight: 950;
}

.spcsc-drawer__btn--primary {
    background: linear-gradient(135deg, var(--spcsc-ink), #171310);
    box-shadow: 0 16px 30px rgba(42,37,32,.2);
}

.spcsc-drawer__btn--ghost {
    background: #fff;
    border: 1px solid rgba(42,37,32,.11);
}

.spcsc-drawer__empty {
    min-height: 58vh;
    display: grid;
    align-content: center;
    justify-items: center;
    padding: 2rem 1.25rem;
}

.spcsc-drawer__empty-icon {
    box-shadow: 0 16px 34px rgba(42,37,32,.11);
}

@media (max-width: 520px) {
    .spcsc-floating-wrap .spcsc-trigger {
        width: 56px;
        height: 56px;
    }

    .spcsc-drawer__drawer {
        width: min(100vw, 430px) !important;
    }

    .spcsc-drawer__item {
        grid-template-columns: 72px minmax(0, 1fr);
        border-radius: 20px;
    }

    .spcsc-drawer__thumb {
        width: 72px;
        height: 72px;
    }

    .spcsc-drawer__actions {
        grid-template-columns: 1fr;
    }
}
