/* ── Wrapper ─────────────────────────────────────────────────── */
.pinguins-cart-wrapper {
    display: inline-flex; align-items: center; justify-content: center;
    position: relative; z-index: 99999;
}
.pinguins-cart-container { position: relative; }

.pinguins-cart-link {
    display: inline-flex; align-items: center; text-decoration: none;
    gap: 12px; padding: 8px 12px; border-radius: 50px;
    transition: all 0.3s cubic-bezier(0.4,0,0.2,1); color: inherit;
}

.pinguins-cart-icon-container {
    position: relative; display: inline-flex; align-items: center;
    justify-content: center; font-size: 24px; line-height: 1;
}

.pinguins-cart-badge {
    position: absolute; top: -8px; right: -10px;
    min-width: 20px; height: 20px; background: #e11d2d; color: #fff;
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
    font-size: 11px; font-weight: 700; line-height: 1; padding: 2px;
    box-shadow: 0 2px 4px rgba(0,0,0,.2); z-index: 2;
    transition: transform 0.3s cubic-bezier(0.175,0.885,0.32,1.275);
}

/* ── Dropdown ────────────────────────────────────────────────── */
.pinguins-cart-dropdown {
    position: absolute; top: 100%; right: 0; margin-top: 15px;
    width: 360px; max-width: calc(100vw - 40px);
    background: #fff; box-shadow: 0 10px 30px rgba(0,0,0,.15);
    z-index: 100000; border-radius: 8px; padding: 20px;
    display: flex; flex-direction: column;
    /* HIDDEN by default */
    opacity: 0; visibility: hidden; pointer-events: none;
    transform: translateY(10px);
    transition: opacity .3s ease, visibility .3s ease, transform .3s cubic-bezier(0.4,0,0.2,1);
}
.pinguins-glass-yes .pinguins-cart-dropdown {
    background: rgba(255,255,255,.7) !important;
    backdrop-filter: blur(15px) saturate(180%);
    -webkit-backdrop-filter: blur(15px) saturate(180%);
    border: 1px solid rgba(255,255,255,.3);
}
/* Show dropdown — only when mode is dropdown */
.pinguins-display-dropdown.pinguins-trigger-hover:hover .pinguins-cart-dropdown,
.pinguins-display-dropdown.pinguins-cart-open .pinguins-cart-dropdown {
    opacity: 1; visibility: visible; pointer-events: auto; transform: translateY(0);
}

/* ── Panel header ────────────────────────────────────────────── */
.pinguins-cart-popup-header {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 20px; padding-bottom: 15px;
    border-bottom: 1px solid #eee; flex-shrink: 0;
}
.pinguins-cart-popup-header h3 { margin: 0; font-family: inherit; color: #333; }
.pinguins-cart-close {
    background: none;
    border: none;
    font-size: 24px;
    cursor: pointer !important;
    line-height: 1;
    padding: 0;
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    flex-shrink: 0;
    transition: all .2s ease;
    color: inherit;
}
.pinguins-cart-close:hover { opacity: .6; transform: scale(1.1); }

/* ── Teleported overlay ──────────────────────────────────────── */
.pinguins-cart-overlay-teleport {
    position: fixed; inset: 0; background: rgba(0,0,0,.5);
    z-index: 999988; opacity: 0; visibility: hidden; pointer-events: none;
    transition: opacity .3s ease, visibility .3s ease; cursor: pointer !important;
}
.pinguins-cart-overlay-teleport.pinguins-cart-open {
    opacity: 1 !important; visibility: visible !important; pointer-events: auto !important;
}

/* ── Teleported popup ────────────────────────────────────────── */
.pinguins-cart-popup.pinguins-teleported {
    position: fixed; top: 50%; left: 50%;
    transform: translate(-50%, -46%);
    width: 420px; max-width: calc(100vw - 40px);
    max-height: 90vh;
    background: #fff; box-shadow: 0 20px 50px rgba(0,0,0,.3);
    border-radius: 12px; padding: 30px; z-index: 999999;
    display: flex; flex-direction: column;
    /* HIDDEN */
    opacity: 0; visibility: hidden; pointer-events: none;
    transition: opacity .3s ease, visibility .3s ease, transform .4s cubic-bezier(0.175,0.885,0.32,1.275);
}
.pinguins-cart-popup.pinguins-teleported.pinguins-cart-open {
    opacity: 1; visibility: visible; pointer-events: auto;
    transform: translate(-50%, -50%);
}
.pinguins-cart-popup.pinguins-teleported.pinguins-glass-yes {
    background: rgba(255,255,255,.7) !important;
    backdrop-filter: blur(15px) saturate(180%);
    -webkit-backdrop-filter: blur(15px) saturate(180%);
    border: 1px solid rgba(255,255,255,.3);
}
/* Animations */
.pinguins-anim-zoom.pinguins-cart-popup.pinguins-teleported           { transform: translate(-50%,-50%) scale(.85); }
.pinguins-anim-zoom.pinguins-cart-popup.pinguins-teleported.pinguins-cart-open { transform: translate(-50%,-50%) scale(1); }
.pinguins-anim-slide.pinguins-cart-popup.pinguins-teleported          { transform: translate(-50%,-38%); }
.pinguins-anim-slide.pinguins-cart-popup.pinguins-teleported.pinguins-cart-open { transform: translate(-50%,-50%); }
@keyframes pinguinsBounce {
    0%   { transform: translate(-50%,-50%) scale(.5); opacity: 0; }
    100% { transform: translate(-50%,-50%) scale(1);  opacity: 1; }
}
.pinguins-anim-bounce.pinguins-cart-popup.pinguins-teleported.pinguins-cart-open {
    animation: pinguinsBounce .6s cubic-bezier(0.68,-0.55,0.265,1.55) forwards;
}

/* ── Teleported sidecart ─────────────────────────────────────── */
.pinguins-cart-sidecart.pinguins-teleported {
    position: fixed; top: 0; height: 100vh;
    width: 400px; max-width: 85vw;
    background: #fff; box-shadow: 0 0 50px rgba(0,0,0,.15);
    z-index: 999999; display: flex; flex-direction: column;
    padding: 30px; overflow: hidden;
    transition: transform .4s cubic-bezier(0.4,0,0.2,1);
    /* HIDDEN — default right */
    right: 0; left: auto; transform: translateX(105%);
}
.pinguins-cart-sidecart.pinguins-teleported.pinguins-side-left {
    left: 0; right: auto; transform: translateX(-105%);
}
.pinguins-cart-sidecart.pinguins-teleported.pinguins-cart-open {
    transform: translateX(0) !important;
}
.pinguins-cart-sidecart.pinguins-teleported.pinguins-glass-yes {
    background: rgba(255,255,255,.7) !important;
    backdrop-filter: blur(15px) saturate(180%);
    -webkit-backdrop-filter: blur(15px) saturate(180%);
}
.pinguins-cart-sidecart.pinguins-teleported:not(.pinguins-side-left).pinguins-glass-yes { border-left: 1px solid rgba(255,255,255,.3); }
.pinguins-cart-sidecart.pinguins-teleported.pinguins-side-left.pinguins-glass-yes       { border-right: 1px solid rgba(255,255,255,.3); }

/* ── Inline popup/sidecart (non-teleported) ──────────────────
   Hidden on FRONTEND always. */
.pinguins-cart-popup:not(.pinguins-teleported),
.pinguins-cart-sidecart:not(.pinguins-teleported),
.pinguins-cart-overlay:not(.pinguins-teleported) {
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
}

/* ── EDITOR: position per mode ───────────────────────────── */

/* Shared Editor base */
.elementor-editor-active .elementor-element-editable .pinguins-cart-dropdown,
.elementor-editor-active .elementor-element-editable .pinguins-cart-popup:not(.pinguins-teleported),
.elementor-editor-active .elementor-element-editable .pinguins-cart-sidecart:not(.pinguins-teleported) {
    display: flex !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    background: #fff;
    box-shadow: 0 15px 50px rgba(0,0,0,0.3);
    border: 2px solid #71d7f7 !important;
    z-index: 999999 !important;
}

/* 1. Dropdown in Editor: below icon */
.elementor-editor-active .pinguins-display-dropdown .pinguins-cart-dropdown {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    transform: translateY(10px) !important;
    width: 350px !important;
}

/* 2. Popup in Editor: fixed center */
.elementor-editor-active .pinguins-display-popup .pinguins-cart-popup:not(.pinguins-teleported) {
    position: fixed !important;
    top: 50% !important; left: 50% !important;
    transform: translate(-50%, -50%) !important;
    width: 450px !important;
}

/* 3. Sidecart in Editor: fixed on side */
.elementor-editor-active .pinguins-display-sidecart .pinguins-cart-sidecart:not(.pinguins-teleported) {
    position: fixed !important;
    top: 0 !important; height: 100vh !important;
    width: 380px !important;
}
.elementor-editor-active .pinguins-side-right .pinguins-cart-sidecart:not(.pinguins-teleported) { right: 0 !important; left: auto !important; }
.elementor-editor-active .pinguins-side-left .pinguins-cart-sidecart:not(.pinguins-teleported) { left: 0 !important; right: auto !important; }

/* Overlay in editor: hidden to allow clicking other things */
.elementor-editor-active .pinguins-cart-overlay {
    display: none !important;
}

/* Glassmorphism in editor */
.elementor-editor-active .pinguins-glass-yes .pinguins-cart-popup,
.elementor-editor-active .pinguins-glass-yes .pinguins-cart-sidecart,
.elementor-editor-active .pinguins-glass-yes .pinguins-cart-dropdown {
    background: rgba(255,255,255,0.9) !important;
    backdrop-filter: blur(15px) saturate(180%);
}

/* Force open for teleported panels too (if any) */
.pinguins-force-open .pinguins-cart-popup.pinguins-teleported,
.pinguins-force-open .pinguins-cart-sidecart.pinguins-teleported,
.pinguins-force-open .pinguins-cart-overlay-teleport {
    opacity: 1 !important; visibility: visible !important; pointer-events: auto !important;
    transform: none !important;
}

/* Overlay: always hidden in editor */
.elementor-editor-active .pinguins-cart-overlay:not(.pinguins-teleported) {
    display: none !important;
}

/* Glassmorphism in editor */
.elementor-editor-active .pinguins-glass-yes .pinguins-cart-popup,
.elementor-editor-active .pinguins-glass-yes .pinguins-cart-sidecart {
    background: rgba(255,255,255,.7) !important;
    backdrop-filter: blur(15px) saturate(180%);
    -webkit-backdrop-filter: blur(15px) saturate(180%);
    border: 1px solid rgba(255,255,255,.3);
}

/* ── Body lock ───────────────────────────────────────────────── */
body.pinguins-cart-body-lock { overflow: hidden !important; }

/* ── Update animation ────────────────────────────────────────── */
.pinguins-cart-updating .pinguins-cart-badge { transform: scale(1.3); }

/* Processing / Loading state */
.pinguins-cart-processing .pinguins-minicart-items {
    opacity: 0.6;
    filter: blur(1px);
}
.pinguins-cart-processing .pinguins-minicart-item.removing {
    opacity: 0.3;
    background: #fff5f5;
}

/* ── Cart items ──────────────────────────────────────────────── */
.pinguins-minicart-body {
    display: flex; flex-direction: column; flex: 1; min-height: 0; overflow: hidden;
}
.pinguins-minicart-empty { text-align: center; padding: 30px 0; color: #999; font-size: 14px; margin: 0; }

.pinguins-minicart-items {
    list-style: none; margin: 0; padding: 0;
    overflow-y: auto; flex: 1; max-height: 340px;
}
.pinguins-cart-popup.pinguins-teleported .pinguins-minicart-items,
.pinguins-cart-sidecart.pinguins-teleported .pinguins-minicart-items {
    max-height: none; flex: 1;
}

.pinguins-minicart-item {
    display: flex; align-items: flex-start; gap: 12px;
    padding: 14px 0; border-bottom: 1px solid rgba(0,0,0,.06);
}
.pinguins-minicart-item:last-child { border-bottom: none; }

.pinguins-item-thumb-link {
    flex-shrink: 0; display: block; width: 64px; height: 64px;
    border-radius: 6px; overflow: hidden; background: #f5f5f5;
}
.pinguins-item-thumb-link img.pinguins-item-thumb {
    width: 64px; height: 64px; object-fit: cover; display: block;
}

.pinguins-item-details {
    flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 3px;
}
.pinguins-item-name {
    font-size: 14px; font-weight: 600; line-height: 1.3; color: inherit;
    text-decoration: none; white-space: nowrap; overflow: hidden;
    text-overflow: ellipsis; display: block;
}
.pinguins-item-name:hover { opacity: .75; }

.pinguins-item-price-row { display: flex; align-items: center; gap: 5px; font-size: 14px; margin-top: 2px; }
.pinguins-item-qty  { color: #888; font-size: 13px; }
.pinguins-item-price { font-weight: 700; }

.pinguins-item-variations, .pinguins-item-addons {
    list-style: none; margin: 4px 0 0; padding: 0;
    display: flex; flex-direction: column; gap: 2px;
}
.pinguins-item-variations li, .pinguins-item-addons li { font-size: 12px; color: #666; line-height: 1.4; }
.pinguins-variation-name, .pinguins-addon-group-name { font-weight: 600; color: #444; }
.pinguins-addon-price { color: #e11d2d; font-weight: 600; }

.pinguins-item-remove {
    flex-shrink: 0; width: 22px; height: 22px; display: flex;
    align-items: center; justify-content: center; font-size: 16px; line-height: 1;
    color: #aaa; text-decoration: none !important; border: 1px solid #ddd;
    border-radius: 50%; transition: all .2s ease; margin-top: 2px;
}
.pinguins-item-remove:hover { color: #e11d2d; border-color: #e11d2d; background: rgba(225,29,45,.06); }

.pinguins-minicart-footer {
    padding-top: 16px; margin-top: 4px;
    border-top: 2px solid rgba(0,0,0,.07); flex-shrink: 0;
}
.pinguins-minicart-total {
    display: flex; justify-content: space-between; align-items: center;
    font-size: 15px; font-weight: 600; margin-bottom: 14px;
}
.pinguins-minicart-buttons { display: flex; gap: 10px; }

.pinguins-btn {
    flex: 1; display: block; text-align: center; padding: 12px 10px;
    font-size: 12px; font-weight: 700; text-transform: uppercase;
    letter-spacing: .5px; text-decoration: none; border-radius: 4px;
    transition: all .25s ease; line-height: 1.4;
}
.pinguins-btn-cart     { background: #f0f0f0; color: #333; }
.pinguins-btn-cart:hover { background: #e0e0e0; color: #111; }
.pinguins-btn-checkout  { background: #e11d2d; color: #fff; }
.pinguins-btn-checkout:hover { background: #c01020; color: #fff; }

.pinguins-show-cart-no     .pinguins-btn-cart     { display: none !important; }
.pinguins-show-checkout-no .pinguins-btn-checkout { display: none !important; }
.pinguins-btn-full { flex: 1 1 100% !important; }

/* Default padding for panels (overridden by Elementor control) */
.pinguins-cart-dropdown,
.pinguins-cart-popup.pinguins-teleported,
.pinguins-cart-sidecart.pinguins-teleported {
    padding: 24px;
}
/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 767px) {
    .pinguins-cart-sidecart.pinguins-teleported {
        width: 100% !important;
        max-width: 100% !important;
        padding: 20px !important;
    }
    
    .pinguins-cart-popup.pinguins-teleported {
        width: calc(100% - 30px) !important;
        padding: 20px !important;
    }

    .pinguins-minicart-footer {
        padding-bottom: 20px;
    }
    
    .pinguins-item-name {
        white-space: normal;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        max-height: 3.2em;
    }
}
