/* ============================================
   Nasus Side Cart – Dark + Green Accent
   ============================================ */

:root {
    --nsc-bg: #0f1923;
    --nsc-bg-secondary: #0a1219;
    --nsc-bg-item: #162230;
    --nsc-text: #ffffff;
    --nsc-text-secondary: #94a3b8;
    --nsc-accent: #10b981;
    --nsc-accent-hover: #059669;
    --nsc-border: rgba(255, 255, 255, 0.1);
    --nsc-border-hover: rgba(16, 185, 129, 0.3);
    --nsc-offset-x: 20px;
    --nsc-offset-y: 20px;
    --nsc-icon-size: 22px;
    --nsc-price-size: 14px;
    --nsc-panel-w: 400px;
}

/* ─── Overlay ─── */
.nsc-overlay {
    position: fixed !important;
    inset: 0 !important;
    background: rgba(0, 0, 0, 0.7) !important;
    z-index: 2147483646 !important;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}
.nsc-overlay.nsc-open { opacity: 1; visibility: visible; }

/* ─── Side Panel ─── */
.nsc-panel {
    position: fixed !important;
    top: 0 !important;
    width: var(--nsc-panel-w) !important;
    max-width: 92vw !important;
    height: 100% !important;
    background: var(--nsc-bg) !important;
    z-index: 2147483647 !important;
    display: flex !important;
    flex-direction: column !important;
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1) !important;
    box-shadow: -4px 0 30px rgba(0, 0, 0, 0.6) !important;
    overflow: hidden !important;
    isolation: isolate !important;
    color: var(--nsc-text) !important;
}
.nsc-panel *, .nsc-panel *::before, .nsc-panel *::after { box-sizing: border-box !important; }
.nsc-panel button { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important; }
.nsc-panel img { max-width: 100% !important; height: auto !important; }
.nsc-panel a { text-decoration: none !important; }
.nsc-panel input[type="text"] { -webkit-appearance: none !important; appearance: none !important; }
.nsc-panel.nsc-slide-right { right: 0; transform: translateX(100%); }
.nsc-panel.nsc-slide-left { left: 0; transform: translateX(-100%); }
.nsc-panel.nsc-open.nsc-slide-right,
.nsc-panel.nsc-open.nsc-slide-left { transform: translateX(0); }

/* ─── Header ─── */
.nsc-panel-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 18px 20px;
    border-bottom: 1px solid var(--nsc-border);
    flex-shrink: 0;
    background: var(--nsc-bg-secondary);
}
.nsc-panel-title {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: #ffffff !important;
}
.nsc-close {
    background: none !important;
    border: none !important;
    font-size: 28px !important;
    cursor: pointer !important;
    color: var(--nsc-text-secondary) !important;
    line-height: 1 !important;
    padding: 0 4px !important;
}
.nsc-close:hover { color: #ffffff !important; }

/* ─── Body ─── */
.nsc-panel-body {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 0;
    background: var(--nsc-bg);
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,0.12) transparent;
}
.nsc-panel-body::-webkit-scrollbar { width: 5px; }
.nsc-panel-body::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.12); border-radius: 10px; }

/* ─── Empty ─── */
.nsc-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
    text-align: center;
}
.nsc-empty p {
    margin-bottom: 16px;
    font-size: 15px;
    color: var(--nsc-text-secondary) !important;
}

/* ─── Items ─── */
.nsc-items { padding: 8px 16px; }
.nsc-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 12px;
    margin-bottom: 8px;
    border-radius: 10px;
    background: var(--nsc-bg-item);
    border: 1px solid var(--nsc-border);
    position: relative;
    animation: nscFadeIn 0.25s ease;
    transition: border-color 0.2s;
}
.nsc-item:hover { border-color: var(--nsc-border-hover); }
@keyframes nscFadeIn { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:translateY(0); } }

.nsc-item-img {
    flex-shrink: 0;
    width: 60px;
    height: 60px;
    border-radius: 8px;
    overflow: hidden;
    background: rgba(255,255,255,0.05);
}
.nsc-item-img img { width: 100% !important; height: 100% !important; object-fit: cover !important; }

.nsc-item-info { flex: 1; min-width: 0; }
.nsc-item-title {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #ffffff !important;
    line-height: 1.3;
    margin-bottom: 4px;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.nsc-item-price {
    font-size: 13px !important;
    color: var(--nsc-accent) !important;
    margin-bottom: 4px;
    font-weight: 600 !important;
}
.nsc-item-price del {
    opacity: 0.5;
    color: var(--nsc-text-secondary) !important;
    font-weight: 400 !important;
}
.nsc-item-price ins {
    text-decoration: none !important;
    font-weight: 700 !important;
    color: #ffffff !important;
}

/* ─── Stars ─── */
.nsc-item-rating { display: flex; align-items: center; gap: 1px; margin-bottom: 6px; }
.nsc-star { display: inline-block; width: 14px; height: 14px; position: relative; }
.nsc-star::before {
    content: '';
    position: absolute;
    inset: 0;
    background-color: rgba(255,255,255,0.12);
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z'/%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z'/%3E%3C/svg%3E");
    -webkit-mask-size: contain; mask-size: contain;
    -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat;
}
.nsc-star-full::before { background-color: #f59e0b; }
.nsc-star-half::before { background: linear-gradient(90deg, #f59e0b 50%, rgba(255,255,255,.12) 50%); }
.nsc-star-empty::before { background-color: rgba(255,255,255,0.12); }
.nsc-rating-num { font-size: 11px; color: var(--nsc-text-secondary); margin-left: 4px; font-weight: 500; }

/* ─── Quantity — fully hardened ─── */
.nsc-item-qty {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0 !important;
    border: 1px solid var(--nsc-accent) !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
    box-shadow: none !important;
    background: transparent !important;
}
.nsc-panel .nsc-qty-btn,
.nsc-panel .nsc-qty-btn:hover,
.nsc-panel .nsc-qty-btn:focus,
.nsc-panel .nsc-qty-btn:active {
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    min-height: 32px !important;
    max-width: 32px !important;
    max-height: 32px !important;
    background: var(--nsc-accent) !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 0 !important;
    cursor: pointer !important;
    font-size: 18px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    margin: 0 !important;
    box-shadow: none !important;
    outline: none !important;
    text-decoration: none !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    transition: opacity 0.2s !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    float: none !important;
    position: static !important;
}
.nsc-panel .nsc-qty-btn:hover { opacity: 0.8 !important; }
.nsc-qty-val {
    width: 36px !important;
    min-width: 36px !important;
    text-align: center !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    line-height: 32px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* ─── Remove ─── */
.nsc-panel .nsc-item-remove,
.nsc-panel .nsc-item-remove:hover,
.nsc-panel .nsc-item-remove:focus {
    position: absolute !important;
    top: 10px !important;
    right: 8px !important;
    background: none !important;
    border: none !important;
    font-size: 18px !important;
    color: rgba(255,255,255,0.35) !important;
    cursor: pointer !important;
    padding: 2px 4px !important;
    line-height: 1 !important;
    width: auto !important;
    height: auto !important;
    min-width: 0 !important;
    min-height: 0 !important;
    box-shadow: none !important;
    text-transform: none !important;
    transition: color 0.2s !important;
}
.nsc-panel .nsc-item-remove:hover { color: #ef4444 !important; }

/* ─── Suggested ─── */
.nsc-suggested { padding: 16px; border-top: 1px solid var(--nsc-border); }
.nsc-suggested-title {
    font-size: 13px;
    font-weight: 700;
    color: var(--nsc-accent) !important;
    margin: 0 0 12px 0;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.nsc-suggested-list { display: flex; flex-direction: column; gap: 10px; }
.nsc-suggested-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px;
    border-radius: 8px;
    background: var(--nsc-bg-item);
    border: 1px solid var(--nsc-border);
}
.nsc-suggested-img { width: 44px; height: 44px; border-radius: 6px; overflow: hidden; flex-shrink: 0; background: rgba(255,255,255,.05); }
.nsc-suggested-img img { width: 100%; height: 100%; object-fit: cover; }
.nsc-suggested-info { flex: 1; min-width: 0; }
.nsc-suggested-name { display: block; font-size: 13px; font-weight: 500; color: #ffffff !important; line-height: 1.3; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; text-decoration: none !important; }
.nsc-suggested-name:hover { color: var(--nsc-accent) !important; }

/* Points badge */
.nsc-suggested-points {
    display: inline-block;
    font-size: 10px !important;
    font-weight: 600 !important;
    color: #fbbf24 !important;
    background: rgba(251, 191, 36, 0.12) !important;
    padding: 2px 6px !important;
    border-radius: 4px !important;
    margin-top: 2px;
}

/* Steam 3x2 promo banner */
.nsc-promo-banner {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 8px 16px;
    padding: 12px 14px;
    border-radius: 10px;
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.15), rgba(16, 185, 129, 0.05)) !important;
    border: 1px solid rgba(16, 185, 129, 0.3) !important;
    animation: nscPulse 2s ease-in-out infinite;
}
@keyframes nscPulse {
    0%, 100% { border-color: rgba(16, 185, 129, 0.3); }
    50% { border-color: rgba(16, 185, 129, 0.6); }
}
.nsc-promo-icon {
    font-size: 28px;
    flex-shrink: 0;
    line-height: 1;
}
.nsc-promo-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.nsc-promo-text strong {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: var(--nsc-accent) !important;
}
.nsc-promo-text span {
    font-size: 12px !important;
    color: var(--nsc-text-secondary) !important;
    line-height: 1.3;
}
.nsc-suggested-price { font-size: 12px; color: var(--nsc-text-secondary) !important; }

/* Botón link para "Ver" en sugeridos */
.nsc-panel a.nsc-btn-link,
.nsc-panel a.nsc-btn-link:hover,
.nsc-panel a.nsc-btn-link:visited {
    padding: 7px 14px !important;
    border-radius: 6px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    background: rgba(255,255,255,0.08) !important;
    color: #ffffff !important;
    border: 1px solid var(--nsc-border) !important;
    cursor: pointer !important;
    text-decoration: none !important;
    flex-shrink: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    pointer-events: auto !important;
    position: relative !important;
    z-index: 5 !important;
    transition: all 0.2s !important;
}
.nsc-panel a.nsc-btn-link:hover {
    background: rgba(255,255,255,0.15) !important;
    border-color: var(--nsc-accent) !important;
    color: var(--nsc-accent) !important;
}

/* Botón Añadir en sugeridos */
.nsc-add-suggested {
    white-space: nowrap !important;
    min-width: 65px !important;
    min-height: 36px !important;
    -webkit-tap-highlight-color: rgba(16, 185, 129, 0.3) !important;
    touch-action: manipulation !important;
    user-select: none !important;
    -webkit-user-select: none !important;
}
.nsc-add-suggested:active {
    opacity: 0.7 !important;
    transform: scale(0.95) !important;
}
@media (max-width: 768px) {
    .nsc-add-suggested {
        min-height: 44px !important;
        min-width: 70px !important;
        padding: 10px 14px !important;
        font-size: 14px !important;
    }
}

/* ─── Coupon ─── */
.nsc-coupon {
    display: flex;
    gap: 8px;
    padding: 14px 16px;
    border-top: 1px solid var(--nsc-border);
}
.nsc-coupon-input {
    flex: 1 !important;
    padding: 10px 14px !important;
    border: 1px solid var(--nsc-border) !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    outline: none !important;
    background: var(--nsc-bg-item) !important;
    color: #ffffff !important;
    transition: border-color 0.2s !important;
}
.nsc-coupon-input::placeholder { color: var(--nsc-text-secondary) !important; }
.nsc-coupon-input:focus { border-color: var(--nsc-accent) !important; }

/* ─── Totals ─── */
.nsc-totals {
    padding: 16px;
    border-top: 1px solid var(--nsc-border);
    background: var(--nsc-bg-secondary);
}
.nsc-total-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 14px !important;
    color: var(--nsc-text-secondary) !important;
    margin-bottom: 8px;
}
.nsc-total-row span:last-child {
    color: #ffffff !important;
    font-weight: 500 !important;
}
.nsc-total-row:last-child { margin-bottom: 0; }
.nsc-total-final {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    padding-top: 10px;
    border-top: 1px solid var(--nsc-border);
}
.nsc-total-final span:last-child {
    color: var(--nsc-accent) !important;
    font-weight: 700 !important;
}
.nsc-discount span:last-child { color: var(--nsc-accent) !important; }

/* ─── Panel Footer (fixed at bottom, outside scroll) ─── */
.nsc-panel-footer {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    padding: 16px !important;
    border-top: 1px solid var(--nsc-border) !important;
    flex-shrink: 0 !important;
    background: var(--nsc-bg-secondary) !important;
    position: relative !important;
    z-index: 20 !important;
}
.nsc-panel-footer a,
.nsc-panel-footer a:hover,
.nsc-panel-footer a:active,
.nsc-panel-footer a:focus,
.nsc-panel-footer a:visited {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 13px 20px !important;
    border-radius: 10px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    cursor: pointer !important;
    pointer-events: auto !important;
    position: relative !important;
    z-index: 21 !important;
    text-align: center !important;
    transition: all 0.2s !important;
}
.nsc-panel-footer a.nsc-btn-primary,
.nsc-panel-footer a.nsc-btn-primary:visited {
    background: var(--nsc-accent) !important;
    color: #ffffff !important;
    border: none !important;
}
.nsc-panel-footer a.nsc-btn-primary:hover {
    background: var(--nsc-accent-hover) !important;
    color: #ffffff !important;
}
.nsc-panel-footer a.nsc-btn-secondary,
.nsc-panel-footer a.nsc-btn-secondary:visited {
    background: transparent !important;
    color: #ffffff !important;
    border: 1px solid var(--nsc-border) !important;
}
.nsc-panel-footer a.nsc-btn-secondary:hover {
    background: rgba(255,255,255,0.06) !important;
    color: #ffffff !important;
    border-color: var(--nsc-border-hover) !important;
}

/* ─── Buttons (inside panel body — for backwards compat) ─── */
.nsc-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 16px;
    border-top: 1px solid var(--nsc-border);
    flex-shrink: 0;
    background: var(--nsc-bg-secondary);
}
.nsc-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 13px 20px !important;
    border-radius: 10px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
    border: none !important;
    text-align: center !important;
}
.nsc-btn-primary {
    background: var(--nsc-accent) !important;
    color: #ffffff !important;
}
.nsc-btn-primary:hover {
    background: var(--nsc-accent-hover) !important;
    color: #ffffff !important;
}
.nsc-btn-secondary {
    background: transparent !important;
    color: #ffffff !important;
    border: 1px solid var(--nsc-border) !important;
}
.nsc-btn-secondary:hover {
    background: rgba(255,255,255,0.06) !important;
    color: #ffffff !important;
    border-color: var(--nsc-border-hover) !important;
}
.nsc-btn-sm {
    padding: 7px 14px !important;
    border-radius: 6px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    background: var(--nsc-accent) !important;
    color: #ffffff !important;
    border: none !important;
    cursor: pointer !important;
    transition: background 0.2s !important;
    flex-shrink: 0 !important;
}
.nsc-btn-sm:hover { background: var(--nsc-accent-hover) !important; }

/* ─── Float ─── */
.nsc-float {
    position: fixed !important;
    bottom: var(--nsc-offset-y) !important;
    width: 56px !important;
    height: 56px !important;
    border-radius: 50% !important;
    background: var(--nsc-accent) !important;
    color: #fff !important;
    border: none !important;
    cursor: pointer !important;
    z-index: 2147483647 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-shadow: 0 4px 20px rgba(16, 185, 129, 0.35) !important;
    transition: transform 0.2s, box-shadow 0.2s !important;
}
.nsc-float:hover {
    transform: scale(1.08);
    box-shadow: 0 6px 28px rgba(16, 185, 129, 0.45) !important;
}
.nsc-float-right { right: var(--nsc-offset-x) !important; }
.nsc-float-left { left: var(--nsc-offset-x) !important; }
.nsc-cart-svg { width: 24px; height: 24px; }
.nsc-float-count {
    position: absolute;
    top: -4px;
    right: -4px;
    background: #ef4444;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    box-shadow: 0 2px 8px rgba(0,0,0,0.3);
}

/* ─── Menu ─── */
.nsc-menu-icon { display: inline-flex; align-items: center; gap: 6px; cursor: pointer; position: relative; color: inherit; }
.nsc-menu-count { position: absolute; top: -6px; right: -8px; background: var(--nsc-accent); color: #fff; font-size: 10px; font-weight: 700; width: 18px; height: 18px; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.nsc-menu-total { font-weight: 600; color: inherit; }

/* ─── Loading ─── */
.nsc-loading { opacity: 0.5; pointer-events: none; }
.nsc-loading .nsc-actions { pointer-events: auto !important; opacity: 1 !important; }
.nsc-loading .nsc-actions a { pointer-events: auto !important; }

/* ─── Hide currency switchers when cart panel is open ─── */
body.nsc-panel-active .woocommerce-currency-switcher-form,
body.nsc-panel-active .curcy-currency-switcher,
body.nsc-panel-active #curcy-currency-switcher,
body.nsc-panel-active .wcsm-switcher,
body.nsc-panel-active .woocs_auto_switcher,
body.nsc-panel-active #woocs_widjet_exchanger,
body.nsc-panel-active .woocs-auto-switcher,
body.nsc-panel-active .curcy-flag-switcher,
body.nsc-panel-active .villatheme-currency-switcher,
body.nsc-panel-active [class*="curcy-"],
body.nsc-panel-active [id*="curcy-"] {
    visibility: hidden !important;
    pointer-events: none !important;
    opacity: 0 !important;
}

/* ─── Ensure action links are clickable ─── */
.nsc-panel .nsc-actions {
    position: relative !important;
    z-index: 10 !important;
}
.nsc-panel .nsc-actions a,
.nsc-panel .nsc-actions a:hover,
.nsc-panel .nsc-actions a:focus {
    pointer-events: auto !important;
    cursor: pointer !important;
    position: relative !important;
    z-index: 11 !important;
}

/* ─── Responsive ─── */
@media (max-width: 480px) {
    .nsc-panel { --nsc-panel-w: 100vw !important; }
    .nsc-float { width: 50px !important; height: 50px !important; }
    .nsc-cart-svg { width: 20px; height: 20px; }
}

/* ─── Mobile touch fixes ─── */
@media (max-width: 768px) {
    /* Bigger touch targets */
    .nsc-panel .nsc-qty-btn,
    .nsc-panel .nsc-qty-btn:hover,
    .nsc-panel .nsc-qty-btn:focus,
    .nsc-panel .nsc-qty-btn:active {
        width: 40px !important;
        height: 40px !important;
        min-width: 40px !important;
        min-height: 40px !important;
        max-width: 40px !important;
        max-height: 40px !important;
        font-size: 20px !important;
    }
    .nsc-qty-val {
        width: 40px !important;
        min-width: 40px !important;
        font-size: 16px !important;
        line-height: 40px !important;
    }
    .nsc-panel .nsc-item-remove,
    .nsc-panel .nsc-item-remove:hover {
        font-size: 24px !important;
        padding: 8px !important;
        top: 6px !important;
        right: 4px !important;
    }
    .nsc-close {
        font-size: 34px !important;
        padding: 4px 8px !important;
    }
    .nsc-btn-sm,
    .nsc-panel .nsc-btn-sm {
        padding: 10px 16px !important;
        font-size: 13px !important;
        min-height: 40px !important;
    }
    .nsc-panel a.nsc-btn-link,
    .nsc-panel a.nsc-btn-link:hover {
        padding: 10px 16px !important;
        font-size: 13px !important;
        min-height: 40px !important;
    }
    .nsc-coupon-input {
        min-height: 44px !important;
        font-size: 16px !important; /* prevents iOS zoom */
    }
    .nsc-panel-footer a,
    .nsc-panel-footer a:hover {
        padding: 15px 20px !important;
        font-size: 15px !important;
        min-height: 48px !important;
    }
    .nsc-item {
        padding: 14px 12px !important;
        gap: 10px !important;
    }
    .nsc-promo-banner {
        margin: 8px 12px !important;
    }
    .nsc-suggested {
        padding: 16px 12px !important;
    }
}

/* ─── iOS scroll fix ─── */
.nsc-panel-body {
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior: contain !important;
}

/* iOS body lock */
body.nsc-panel-active {
    overflow: hidden !important;
    position: fixed !important;
    width: 100% !important;
    height: 100% !important;
}

/* All interactive elements need explicit touch-action */
.nsc-panel button,
.nsc-panel a,
.nsc-panel input {
    touch-action: manipulation !important;
    -webkit-tap-highlight-color: rgba(16, 185, 129, 0.15) !important;
    cursor: pointer !important;
}
