/**
 * Voidlust — store modal + shop page visuals only
 * Loaded on index.html (site overlay) and shop.html
 */

/* ── Goddess premium card (site shop modal) ── */
.site-shop-overlay .site-goddess-card--premium {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    padding: 24px 20px 22px;
    border-radius: 18px;
    border: 1px solid rgba(180, 0, 0, 0.48);
    background:
        radial-gradient(ellipse 90% 70% at 50% 0%, rgba(120, 0, 0, 0.22), transparent 58%),
        linear-gradient(180deg, rgba(18, 10, 12, 0.92), rgba(8, 5, 8, 0.88));
    text-align: center;
    animation: vlShopVipGlow 3.2s ease-in-out infinite;
}

@keyframes vlShopVipGlow {
    0%, 100% { box-shadow: 0 0 22px rgba(120, 0, 0, 0.32), inset 0 0 0 1px rgba(255, 80, 80, 0.06); }
    50% { box-shadow: 0 0 46px rgba(200, 20, 20, 0.52), 0 0 80px rgba(80, 0, 0, 0.25), inset 0 0 0 1px rgba(255, 120, 120, 0.12); }
}

.site-shop-overlay .site-goddess-card__art {
    width: 118px;
    height: 118px;
    margin: 0 auto 14px;
    border-radius: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    background:
        radial-gradient(circle at 50% 42%, rgba(179, 0, 0, 0.28), rgba(8, 4, 6, 0.92) 68%);
    border: 1px solid rgba(179, 0, 0, 0.38);
    box-shadow: 0 0 28px rgba(120, 0, 0, 0.28), inset 0 1px 0 rgba(255, 200, 160, 0.06);
}

.site-shop-overlay .site-goddess-emblem {
    width: 86px;
    height: 86px;
    object-fit: contain;
    margin: 0;
    filter: drop-shadow(0 0 18px rgba(179, 0, 0, 0.55));
}

.site-shop-overlay .site-goddess-sub {
    display: block;
    font-size: 0.88rem;
    color: rgba(201, 167, 106, 0.78);
    margin: -4px 0 16px;
    letter-spacing: 0.06em;
}

.site-shop-overlay .site-goddess-features {
    text-align: left;
    margin-bottom: 18px;
}

.site-shop-overlay .site-goddess-features li {
    display: flex;
    align-items: flex-start;
    gap: 8px;
}

.site-shop-overlay .site-goddess-features li::before {
    content: '✓';
    color: rgba(201, 167, 106, 0.82);
    flex-shrink: 0;
}

/* ── Crystal packs (site shop modal) ── */
.site-shop-overlay .site-crystal-card {
    padding: 18px 14px 16px;
    min-height: 172px;
    border: 1px solid rgba(201, 167, 106, 0.52);
    background:
        radial-gradient(ellipse 80% 55% at 50% 0%, rgba(179, 0, 0, 0.1), transparent 60%),
        linear-gradient(165deg, rgba(16, 10, 10, 0.88), rgba(8, 6, 8, 0.94));
    box-shadow: 0 0 18px rgba(255, 210, 120, 0.1), inset 0 1px 0 rgba(255, 240, 200, 0.05);
    animation: vlShopPackGlow 2.8s ease-in-out infinite;
    gap: 6px;
}

@keyframes vlShopPackGlow {
    0%, 100% { box-shadow: 0 0 16px rgba(255, 210, 120, 0.12), inset 0 1px 0 rgba(255, 240, 200, 0.05); }
    50% { box-shadow: 0 0 28px rgba(255, 220, 120, 0.28), 0 0 44px rgba(200, 150, 50, 0.12), inset 0 1px 0 rgba(255, 250, 220, 0.08); }
}

.site-shop-overlay .site-crystal-card:hover {
    transform: translateY(-3px);
    border-color: rgba(255, 220, 160, 0.82);
    box-shadow: 0 0 32px rgba(255, 220, 140, 0.42), 0 0 48px rgba(200, 140, 40, 0.18);
}

.site-shop-overlay .site-pack-crystal-hero {
    width: 52px;
    height: 60px;
    object-fit: contain;
    margin: 2px 0 6px;
    filter: drop-shadow(0 0 14px rgba(179, 0, 0, 0.48));
}

.site-shop-overlay .site-crystal-val {
    flex-direction: column;
    gap: 2px;
    font-size: 0.92rem;
}

.site-shop-overlay .site-crystal-count {
    font-size: 1.15rem;
    font-weight: 700;
    color: #f0ebe4;
    letter-spacing: 0.04em;
}

.site-shop-overlay .site-crystal-count-label {
    font-size: 0.72rem;
    font-weight: 500;
    color: rgba(200, 196, 196, 0.62);
    letter-spacing: 0.04em;
}

.site-shop-overlay .vl-crystal-ico--inline {
    display: none;
}

.site-shop-overlay .site-shop-row {
    align-items: stretch;
}

.site-shop-overlay .site-shop-vip {
    flex: 0 0 min(300px, 36%);
}

.site-shop-overlay .site-shop-panel {
    max-width: 900px;
}

.site-shop-overlay .site-shop-footer {
    margin-top: 20px;
}

/* ── Shop page (site + PWA shared pack hero) ── */
.shop-page .shop-pack-crystal-hero,
.shop-container .shop-pack-crystal-hero {
    width: 52px;
    height: 60px;
    object-fit: contain;
    filter: drop-shadow(0 0 14px rgba(179, 0, 0, 0.45));
}

.shop-page .shop-pack-visual,
.shop-container .shop-pack-visual {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 64px;
    margin-bottom: 4px;
}

.shop-page .shop-pack-visual .shop-pack-crystal-img,
.shop-container .shop-pack-visual .shop-pack-crystal-img {
    width: 52px;
    height: 60px;
}

/* Site shop page — goddess art visible */
body.crave-site-mode:not(.crave-pwa-mode).shop-page .shop-goddess-art {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 16px;
    width: 120px;
    height: 120px;
    border-radius: 20px;
    background: radial-gradient(circle at 50% 42%, rgba(179, 0, 0, 0.28), rgba(8, 4, 6, 0.92) 68%);
    border: 1px solid rgba(179, 0, 0, 0.38);
    box-shadow: 0 0 28px rgba(120, 0, 0, 0.28);
}

body.crave-site-mode:not(.crave-pwa-mode).shop-page .shop-goddess-art__emblem {
    width: 86px;
    height: 86px;
    object-fit: contain;
    filter: drop-shadow(0 0 16px rgba(179, 0, 0, 0.5));
}

body.crave-site-mode:not(.crave-pwa-mode).shop-page .shop-goddess-sub--site {
    display: block;
    color: rgba(201, 167, 106, 0.78);
    font-size: 0.95rem;
    margin: -4px 0 18px;
}

body.crave-site-mode:not(.crave-pwa-mode).shop-page .shop-crystal-value .vl-crystal-ico {
    width: 18px;
    height: 22px;
}

body.crave-pwa-mode.shop-page .shop-pack-crystal-hero {
    display: none;
}

body.crave-pwa-mode.shop-page .shop-goddess-art {
    display: flex !important;
}

body.crave-site-mode:not(.crave-pwa-mode).shop-page .shop-goddess-sub.pwa-only {
    display: none !important;
}

body.crave-pwa-mode.shop-page .shop-goddess-sub--site {
    display: none !important;
}

/* Desktop site shop page layout */
body.crave-site-mode:not(.crave-pwa-mode).shop-page .shop-main-stack {
    display: grid;
    grid-template-columns: minmax(280px, 340px) 1fr;
    grid-template-rows: auto 1fr;
    gap: 20px 22px;
    align-items: start;
}

body.crave-site-mode:not(.crave-pwa-mode).shop-page .shop-main-title {
    grid-column: 1 / -1;
}

body.crave-site-mode:not(.crave-pwa-mode).shop-page .shop-goddess-block {
    grid-row: 2;
    grid-column: 1;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

body.crave-site-mode:not(.crave-pwa-mode).shop-page .shop-crystal-grid {
    grid-row: 2;
    grid-column: 2;
}
