/* ═══════════════════════════════════════════════════════════
   🍬🍫 CANDY & CHOCOLATE KEYBOARD THEME
   Keys shaped like PC keyboard buttons · Sweet color palette
   ═══════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700;800;900&family=Lilita+One&family=Luckiest+Guy&display=swap');

:root {
    /* Chocolate board chassis */
    --bg-main:        #2a0a0a;
    --bg-panel:       #3d0f0f;
    --bg-keycap:      #5a1414;
    --bg-keycap-face: #6b1a1a;

    /* Candy accents */
    --candy-pink:     #ff6eb4;
    --candy-pink-dk:  #c0396e;
    --candy-pink-ddk: #7a0038;
    --caramel:        #d4a017;
    --caramel-dk:     #9e740a;
    --mint:           #00c9a7;
    --mint-dk:        #007a65;
    --cream:          #fff3e0;
    --cream-dim:      #f9c8d8;
    --choco-edge:     #1e0505;
    --choco-shadow:   #0f0202;

    /* Key highlights */
    --key-top:        rgba(255,255,255,0.12);
    --key-glow:       rgba(255,110,180,0.4);

    /* Text */
    --text:           #fff3e0;
    --text-dark:      #2a0a0a;
    --muted:          #f9c8d8;

    /* Feedback */
    --danger:         #ff2e63;
    --success:        #00c9a7;

    /* Fonts */
    --font-display:   'Lilita One', 'Luckiest Guy', sans-serif;
    --font-body:      'Inter', sans-serif;

    /* Radii */
    --radius-lg:   20px;
    --radius-md:   14px;
    --radius-sm:   10px;
    --radius-key:  8px;
    --radius-full: 999px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;}
img{max-width:100%;display:block;}
button{font-family:var(--font-display);cursor:pointer;border:none;}

/* ─── BODY ───────────────────────────────────────────────── */
body {
    font-family: var(--font-body);
    background-color: var(--bg-main);
    background-image:
        radial-gradient(ellipse at 15% 20%, rgba(255,110,180,0.18) 0%, transparent 45%),
        radial-gradient(ellipse at 85% 80%, rgba(212,160,23,0.15) 0%, transparent 45%),
        linear-gradient(160deg, #3d0000 0%, #1a0505 60%, #2a0a0a 100%);
    background-attachment: fixed;
    color: var(--text);
    line-height: 1.5;
    overflow-x: hidden;
    position: relative;
    padding-bottom: 60px;
}

/* Polka-dot candy sprinkle pattern */
body::before {
    content: "";
    position: fixed; inset: 0; z-index: 0; pointer-events: none;
    background-image:
        radial-gradient(circle, rgba(255,110,180,0.07) 1.5px, transparent 1.5px),
        radial-gradient(circle, rgba(212,160,23,0.05) 1px, transparent 1px);
    background-size: 32px 32px, 60px 60px;
    background-position: 0 0, 16px 16px;
}

/* ─── LAYOUT ──────────────────────────────────────────────── */
.main-container { min-height:100vh; padding:60px 16px 80px; position:relative; z-index:1; }
.container { max-width:800px; margin:0 auto; }

/* ─── LANG SWITCHER ──────────────────────────────────────── */
.lang-switcher { position:fixed; top:16px; right:16px; z-index:9999; }

/* Keycap-style lang button */
.lang-button {
    background: linear-gradient(160deg, #8a2030 0%, #6b1a1a 60%, #5a1414 100%);
    border-top:    2px solid rgba(255,110,180,0.6);
    border-left:   2px solid rgba(255,110,180,0.5);
    border-right:  2px solid var(--choco-edge);
    border-bottom: 5px solid var(--choco-shadow);
    border-radius: var(--radius-key);
    display:flex; align-items:center; gap:6px;
    padding: 8px 18px;
    color: var(--candy-pink);
    font-size: 0.9rem; font-weight: 700;
    font-family: var(--font-display);
    letter-spacing: 0.05em;
    transition: transform 0.08s, border-bottom-width 0.08s;
    white-space: nowrap;
    text-shadow: 0 0 10px rgba(255,110,180,0.6);
    box-shadow: 0 0 16px rgba(255,110,180,0.2);
}
.lang-button:hover {
    color: #ffffff;
    background: linear-gradient(160deg, #a0253a 0%, #7f1f20 100%);
    box-shadow: 0 0 24px rgba(255,110,180,0.35);
}
.lang-button:active { transform:translateY(3px); border-bottom-width:2px; }
.lang-select { position:absolute; inset:0; opacity:0; cursor:pointer; z-index:10; }

/* ─── HERO ───────────────────────────────────────────────── */
.page-hero { text-align:center; padding:10px 0 28px; position:relative; }

.hero-logo {
    width: clamp(100px,20vw,150px);
    margin: 0 auto 18px;
    border-radius: 16px;
    border: 2px solid rgba(255,110,180,0.4);
    filter: drop-shadow(0 0 18px rgba(255,110,180,0.6)) drop-shadow(0 6px 0 rgba(0,0,0,0.5));
    animation: float-bob 4s ease-in-out infinite;
}

.hero-text { margin-bottom:18px; }

.hero-title {
    font-family: var(--font-display);
    font-size: clamp(1.8rem,5vw,3rem);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    line-height: 1.15;
    margin-bottom: 8px;
    background: linear-gradient(90deg,
        var(--candy-pink) 0%,
        #ffb6d9 30%,
        var(--caramel) 60%,
        var(--candy-pink) 100%
    );
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    animation: candy-text 5s linear infinite;
    filter: drop-shadow(0 4px 0 rgba(0,0,0,0.5));
}
@keyframes candy-text {
    from { background-position: 0% center; }
    to   { background-position: 200% center; }
}

.hero-sub {
    font-family: var(--font-display);
    font-size: 1.1rem;
    color: var(--cream);
    text-shadow: 0 2px 8px rgba(0,0,0,0.5), 0 0 20px rgba(255,110,180,0.3);
}

.social-proof {
    display:inline-flex; align-items:center; gap:8px;
    padding: 7px 18px; border-radius: var(--radius-full);
    background: rgba(255,110,180,0.08);
    border: 1px solid rgba(255,110,180,0.4);
    font-family: var(--font-display); font-size:0.9rem; color:var(--candy-pink);
    text-shadow: 0 0 10px rgba(255,110,180,0.5);
    box-shadow: 0 0 18px rgba(255,110,180,0.12);
    letter-spacing: 0.04em;
}
.social-proof .dot {
    width:8px; height:8px; border-radius:50%;
    background:var(--mint);
    animation: pulse-dot 1.5s ease-in-out infinite;
    box-shadow: 0 0 10px var(--mint);
}

/* ─── SHOP PANEL (the keyboard board) ───────────────────── */
.shop-panel {
    background: linear-gradient(160deg, #4a1010 0%, #2e0808 100%);
    border: 2px solid rgba(255,110,180,0.25);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow:
        0 0 0 1px rgba(255,110,180,0.08),
        0 10px 50px rgba(0,0,0,0.7),
        0 0 60px rgba(255,110,180,0.08);
    position: relative;
}

/* Candy stripe top bar */
.shop-panel::before {
    content: "";
    position: absolute; top:0; left:0; right:0; height:5px;
    background: repeating-linear-gradient(
        90deg,
        var(--candy-pink) 0px, var(--candy-pink) 18px,
        var(--caramel)    18px, var(--caramel)    36px,
        #ffffff           36px, #ffffff           54px,
        var(--candy-pink) 54px
    );
    background-size: 200% auto;
    animation: stripe-move 6s linear infinite;
    z-index: 2;
}
@keyframes stripe-move {
    from { background-position: 0% center; }
    to   { background-position: 200% center; }
}

/* ─── STORE BANNER ───────────────────────────────────────── */
.shop-header.store-banner {
    display:flex; align-items:center; justify-content:space-between;
    padding: 18px 20px 16px;
    background: linear-gradient(135deg, #3a0c0c 0%, #4a1010 100%);
    border-bottom: 2px solid rgba(255,110,180,0.25);
    gap:12px; flex-wrap:wrap;
}
.store-banner-left { display:flex; align-items:center; gap:10px; }
.store-logo { height:38px; width:auto; object-fit:contain; border-radius:6px; filter:drop-shadow(0 0 10px rgba(255,110,180,0.4)); }
.store-banner-tabs { display:flex; gap:8px; }

/* ─── Keycap-style tab buttons ─── */
.store-tab {
    padding: 8px 22px;
    border-radius: var(--radius-key);
    font-family: var(--font-display);
    font-size: 0.95rem; font-weight: 700;
    letter-spacing: 0.06em; text-transform: uppercase;
    background: linear-gradient(160deg, #6b1a1a 0%, #5a1414 60%, #4a1010 100%);
    border-top:    2px solid rgba(255,110,180,0.25);
    border-left:   2px solid rgba(255,110,180,0.2);
    border-right:  2px solid var(--choco-edge);
    border-bottom: 5px solid var(--choco-shadow);
    color: var(--cream-dim);
    transition: all 0.08s ease; cursor:pointer;
    position: relative;
}
.store-tab::after {
    content: "";
    position: absolute; inset: 2px; border-radius: 4px;
    background: linear-gradient(180deg, rgba(255,255,255,0.07) 0%, transparent 40%);
    pointer-events: none;
}
.store-tab.active {
    background: linear-gradient(160deg, #a0253a 0%, #7a1525 60%, #5a0f1a 100%);
    border-top-color:   var(--candy-pink);
    border-left-color:  rgba(255,110,180,0.7);
    border-right-color: var(--candy-pink-ddk);
    border-bottom-color: var(--candy-pink-ddk);
    color: #ffffff;
    text-shadow: 0 0 12px rgba(255,110,180,0.8);
    box-shadow: 0 0 20px rgba(255,110,180,0.3);
}
.store-tab:hover:not(.active) { color:#ffffff; background:linear-gradient(160deg,#7f2020 0%,#6b1a1a 100%); }
.store-tab:active { border-bottom-width:2px; transform:translateY(2px); }

/* ─── SHOP ITEMS LIST ───────────────────────────────────── */
.shop-items-list { display:flex; flex-direction:column; padding:14px; gap:10px; }

/* ─── SHOP ITEM — Big keycap card ────────────────────────── */
.shop-item {
    display: flex; align-items: center; gap: 14px;
    padding: 13px 16px;
    border-radius: var(--radius-md);

    /* Keycap face: top surface */
    background: linear-gradient(160deg,
        #7a2020 0%,   /* top-left highlight */
        #6b1a1a 35%,
        #5a1414 75%,
        #4a1010 100%
    );

    /* Keycap edges: bright top/left, dark right/bottom = 3D key look */
    border-top:    2px solid rgba(255,110,180,0.35);
    border-left:   2px solid rgba(255,110,180,0.25);
    border-right:  2px solid #1e0505;
    border-bottom: 6px solid #0f0202;

    cursor: pointer;
    transition: all 0.08s ease;
    position: relative; overflow: hidden;
}

/* Top-face inner bevel shine (like a real keycap) */
.shop-item::before {
    content: "";
    position: absolute; top:0; left:0; right:0; height: 40%;
    background: linear-gradient(180deg, rgba(255,255,255,0.08) 0%, transparent 100%);
    border-radius: var(--radius-md) var(--radius-md) 0 0;
    pointer-events: none;
}

/* Pink candy left accent stripe */
.shop-item::after {
    content: "";
    position: absolute; left:0; top:6px; bottom:6px; width:4px;
    background: linear-gradient(180deg, var(--candy-pink), var(--caramel));
    border-radius: 4px;
    opacity: 0;
    transition: opacity 0.2s ease;
    box-shadow: 0 0 12px rgba(255,110,180,0.6);
}

.shop-item:hover::after { opacity: 1; }

.shop-item:hover {
    background: linear-gradient(160deg,
        #8f2525 0%,
        #7a2020 35%,
        #6b1a1a 75%,
        #5a1414 100%
    );
    border-top-color:   var(--candy-pink);
    border-left-color:  rgba(255,110,180,0.6);
    border-right-color: #1e0505;
    border-bottom-color:#0f0202;
    box-shadow: 0 0 30px rgba(255,110,180,0.2), 0 6px 20px rgba(0,0,0,0.4);
    transform: translateY(-2px);
}

/* Press down like a real key */
.shop-item:active {
    transform: translateY(4px);
    border-bottom-width: 2px;
    border-top-color: rgba(255,110,180,0.15);
    box-shadow: none;
}

/* Item Image Box */
.shop-item-img-box {
    width: 62px; height: 62px;
    border-radius: var(--radius-key);
    background: linear-gradient(135deg, #3d0f0f, #5a1414);
    border-top:   2px solid rgba(255,110,180,0.4);
    border-left:  2px solid rgba(255,110,180,0.3);
    border-right: 2px solid #1e0505;
    border-bottom:3px solid #0f0202;
    display:flex; align-items:center; justify-content:center;
    flex-shrink:0; overflow:hidden;
    box-shadow: inset 0 2px 4px rgba(0,0,0,0.4), 0 0 10px rgba(255,110,180,0.1);
}
.shop-item-img-box img {
    width: 44px; height: 44px; object-fit:contain;
    transition: transform 0.2s ease;
    filter: drop-shadow(0 2px 6px rgba(0,0,0,0.5));
}
.shop-item:hover .shop-item-img-box img { transform: scale(1.12) rotate(5deg); }
.shop-item:hover .shop-item-img-box {
    border-top-color: var(--candy-pink);
    border-left-color: rgba(255,110,180,0.6);
    box-shadow: 0 0 18px rgba(255,110,180,0.3);
}

/* Item Info */
.shop-item-info { flex:1; min-width:0; display:flex; flex-direction:column; gap:4px; }

.shop-item-name {
    font-family: var(--font-display);
    font-size: 1.15rem; font-weight: 700;
    color: var(--cream);
    letter-spacing: 0.04em; text-transform: uppercase;
    white-space: nowrap; overflow:hidden; text-overflow:ellipsis;
    text-shadow: 0 2px 4px rgba(0,0,0,0.5);
}
.shop-item:hover .shop-item-name {
    color: var(--candy-pink);
    text-shadow: 0 0 12px rgba(255,110,180,0.6);
}
.shop-item-stock {
    font-family: var(--font-body); font-size:0.78rem; color:var(--cream-dim); font-weight:600;
}

/* ─── Rarity Badges ─────────────────────────────────────── */
.shop-item-rarity {
    display:inline-block; font-family:var(--font-display); font-size:0.72rem;
    letter-spacing:0.07em; text-transform:uppercase;
    padding: 3px 10px; border-radius: 5px; width:fit-content;
    /* badge is also a tiny keycap */
    border-bottom: 2px solid rgba(0,0,0,0.4);
    border-right:  1px solid rgba(0,0,0,0.3);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.15);
}
.rarity-mythic   { background:linear-gradient(135deg,#ff2e63,#ff6eb4); color:#fff; text-shadow:0 0 8px rgba(255,110,180,0.8); border-bottom-color:#8b0025; }
.rarity-legendary{ background:linear-gradient(135deg,#d4a017,#f5c842); color:#3d0f0f; text-shadow:none; border-bottom-color:#9e740a; }
.rarity-epic     { background:linear-gradient(135deg,#c084fc,#e879f9); color:#fff; text-shadow:0 0 8px rgba(192,132,252,0.8); border-bottom-color:#7c3aed; }
.rarity-super    { background:linear-gradient(135deg,#00c9a7,#34d399); color:#fff; text-shadow:0 0 8px rgba(0,201,167,0.8); border-bottom-color:#047857; }

/* ─── Claim Button — keycap style ──────────────────────── */
.roblox-claim-btn {
    flex-shrink: 0;
    padding: 10px 22px;
    border-radius: var(--radius-key);

    background: linear-gradient(160deg, #00e0bc 0%, #00c9a7 50%, #00a08a 100%);
    border-top:    2px solid rgba(255,255,255,0.35);
    border-left:   2px solid rgba(255,255,255,0.25);
    border-right:  2px solid #003d30;
    border-bottom: 5px solid #002920;

    color: #ffffff;
    font-family: var(--font-display);
    font-size: 1.05rem; text-transform: uppercase;
    letter-spacing: 0.05em;
    transition: all 0.08s ease;
    white-space: nowrap;
    text-shadow: 0 1px 3px rgba(0,0,0,0.4);
    box-shadow: 0 0 18px rgba(0,201,167,0.25);
    position: relative; overflow: hidden;
}
.roblox-claim-btn::after {
    content: "";
    position: absolute; top:0; left:0; right:0; height:45%;
    background: linear-gradient(180deg, rgba(255,255,255,0.18) 0%, transparent 100%);
    border-radius: var(--radius-key) var(--radius-key) 0 0;
    pointer-events: none;
}
.shop-item:hover .roblox-claim-btn {
    background: linear-gradient(160deg, #00f5d0 0%, #00d4ae 50%, #00b090 100%);
    box-shadow: 0 0 28px rgba(0,201,167,0.45);
    transform: translateY(-1px);
    border-bottom-width: 6px;
}
.roblox-claim-btn:active { transform:translateY(3px); border-bottom-width:2px; box-shadow:none; }

/* ─── iOS POPUP ──────────────────────────────────────────── */
.ios-popup { position:fixed; inset:0; z-index:2500; display:flex; align-items:center; justify-content:center; }
.ios-popup-background { position:absolute; inset:0; background:rgba(20,3,3,0.85); backdrop-filter:blur(8px); }
.ios-popup-content {
    position:relative; z-index:1;
    background: linear-gradient(160deg, #4a1010, #2e0808);
    border-top:  2px solid rgba(255,110,180,0.5);
    border-left: 2px solid rgba(255,110,180,0.4);
    border-right: 2px solid var(--choco-edge);
    border-bottom: 6px solid var(--choco-shadow);
    border-radius: var(--radius-lg);
    width:min(92vw,420px); padding:24px; text-align:center;
    box-shadow: 0 0 40px rgba(255,110,180,0.2);
}
.ios-instruction-gif { width:100%; border-radius:var(--radius-md); border:2px solid var(--candy-pink); }
.ios-instruction-text h3 { font-family:var(--font-display); color:var(--candy-pink); margin:14px 0 8px; font-size:1.4rem; text-shadow:0 0 12px rgba(255,110,180,0.6); }
.ios-instruction-text p { color:var(--cream); font-size:0.95rem; }

/* ─── FOOTER ─────────────────────────────────────────────── */
.site-footer { margin-top:40px; padding:16px 0 10px; border-top:2px solid rgba(255,110,180,0.2); }
.footer-keywords { text-align:center; font-size:0.75rem; color:var(--cream-dim); }

/* ═══════════════════════════════════════════════════════════
   GENERATOR MODAL
   ═══════════════════════════════════════════════════════════ */
.gen-modal { display:none; position:fixed; inset:0; z-index:99999; align-items:center; justify-content:center; padding:16px; }
.gen-modal.open { display:flex; }
.gen-backdrop { position:absolute; inset:0; background:rgba(15,2,2,0.8); backdrop-filter:blur(8px); }

.gen-box {
    position:relative; z-index:1;
    background: linear-gradient(160deg, #4a1010 0%, #2e0808 100%);
    border-top:    2px solid rgba(255,110,180,0.5);
    border-left:   2px solid rgba(255,110,180,0.4);
    border-right:  2px solid var(--choco-edge);
    border-bottom: 8px solid var(--choco-shadow);
    border-radius: var(--radius-lg);
    width:100%; max-width:420px;
    box-shadow: 0 0 50px rgba(255,110,180,0.25), 0 20px 0 rgba(0,0,0,0.5);
    overflow:hidden;
    animation: genSlideIn 0.25s cubic-bezier(0.34,1.56,0.64,1) both;
}
@keyframes genSlideIn { from{opacity:0;transform:translateY(30px) scale(0.95);}to{opacity:1;transform:translateY(0) scale(1);} }

.gen-header {
    display:flex; align-items:center; justify-content:space-between;
    padding:12px 16px;
    background: linear-gradient(135deg, #3a0c0c 0%, #4a1010 100%);
    border-bottom: 2px solid rgba(255,110,180,0.3);
    position: relative;
}
.gen-header::after {
    content: "";
    position: absolute; bottom:-2px; left:0; right:0; height:2px;
    background: linear-gradient(90deg, var(--candy-pink), var(--caramel), var(--candy-pink));
    background-size: 200% auto;
    animation: stripe-move 3s linear infinite;
}
.gen-logo-row { display:flex; align-items:center; gap:10px; }
.gen-logo-img { width:38px; height:38px; border-radius:6px; }
.gen-label { font-family:var(--font-display); color:var(--candy-pink); font-size:1.3rem; text-transform:uppercase; text-shadow:0 0 16px rgba(255,110,180,0.7); }

.gen-close {
    background: linear-gradient(135deg,#ff2e63,#ff6eb4);
    border-top:  2px solid rgba(255,200,200,0.3);
    border-left: 2px solid rgba(255,200,200,0.2);
    border-right:2px solid #5a0020;
    border-bottom:4px solid #3a000e;
    border-radius:6px; width:32px; height:32px;
    color:#ffffff; font-family:var(--font-display); font-size:1.1rem; cursor:pointer;
    display:flex; align-items:center; justify-content:center;
}
.gen-close:active { transform:translateY(2px); border-bottom-width:2px; }

.gen-screen { display:none; padding:20px 16px; flex-direction:column; gap:16px; }
.gen-screen.active { display:flex; }

.gen-item-preview {
    display:flex; align-items:center; gap:14px;
    background:linear-gradient(135deg,#5a1414,#3d0f0f);
    border-top:  2px solid rgba(255,110,180,0.3);
    border-left: 2px solid rgba(255,110,180,0.2);
    border-right:1px solid var(--choco-edge);
    border-bottom:3px solid var(--choco-shadow);
    border-radius:var(--radius-md); padding:12px;
}
.gen-item-thumb { width:64px; height:64px; object-fit:contain; border-radius:8px; background:#3d0f0f; border:2px solid var(--candy-pink); padding:4px; }
.gen-item-name { font-family:var(--font-display); font-size:1.2rem; color:var(--cream); }
.gen-item-badge { display:inline-block; margin-top:4px; background:linear-gradient(135deg,var(--candy-pink),#ff9de0); color:#fff; font-family:var(--font-display); font-size:0.75rem; padding:2px 8px; border-radius:4px; border-bottom:2px solid var(--candy-pink-ddk); }
.gen-desc { color:var(--cream); font-size:0.95rem; text-align:center; opacity:0.9; }

.gen-input-wrap { display:flex; align-items:center; gap:10px; border-top:2px solid rgba(255,110,180,0.6); border-left:2px solid rgba(255,110,180,0.5); border-right:2px solid #3a0000; border-bottom:4px solid #1e0000; border-radius:var(--radius-sm); padding:0 14px; background:#fff3e0; color:var(--text-dark); }
.gen-input { flex:1; border:none; background:transparent; padding:12px 0; font-size:1rem; font-family:var(--font-body); font-weight:700; color:var(--text-dark); outline:none; }
.gen-input::placeholder { color:#a0634a; }
.gen-input-icon { font-size:1.2rem; }
.gen-error-msg { color:var(--danger); font-family:var(--font-body); font-size:0.85rem; font-weight:700; min-height:16px; text-align:center; }

.gen-btn-primary {
    width:100%;
    background: linear-gradient(160deg, #ff9de0 0%, var(--candy-pink) 50%, var(--candy-pink-dk) 100%);
    border-top:    2px solid rgba(255,255,255,0.3);
    border-left:   2px solid rgba(255,255,255,0.2);
    border-right:  2px solid var(--candy-pink-ddk);
    border-bottom: 5px solid var(--candy-pink-ddk);
    border-radius: var(--radius-key);
    padding:12px; color:#ffffff;
    font-family:var(--font-display); font-size:1.2rem; text-transform:uppercase;
    transition:all 0.08s ease; text-shadow:0 1px 3px rgba(0,0,0,0.3);
    position:relative; overflow:hidden;
}
.gen-btn-primary::after { content:""; position:absolute; top:0; left:0; right:0; height:45%; background:linear-gradient(180deg,rgba(255,255,255,0.2) 0%,transparent 100%); pointer-events:none; }
.gen-btn-primary:hover { background:linear-gradient(160deg,#ffb3e6 0%,#ff7ec4 50%,var(--candy-pink-dk) 100%); transform:translateY(-1px); border-bottom-width:6px; }
.gen-btn-primary:active { transform:translateY(3px); border-bottom-width:2px; }

.gen-security-row { display:flex; align-items:center; justify-content:center; gap:6px; color:var(--cream-dim); font-size:0.8rem; font-weight:700; }
.gen-security-dot { width:8px; height:8px; border-radius:50%; background:var(--mint); box-shadow:0 0 8px var(--mint); }

.gen-progress-header { display:flex; flex-direction:column; align-items:center; gap:8px; }
.avatar-scanner-container { width:80px; height:80px; border-radius:50%; background:#3d0f0f; border-top:2px solid rgba(255,110,180,0.5); border-left:2px solid rgba(255,110,180,0.4); border-right:2px solid #1e0505; border-bottom:3px solid #0f0202; position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; box-shadow:0 0 20px rgba(255,110,180,0.3); }
.scanner-avatar-img { width:60px; height:60px; object-fit:cover; border-radius:50%; }
.scanner-laser { position:absolute; width:100%; height:3px; background:var(--candy-pink); box-shadow:0 0 12px var(--candy-pink); top:0; left:0; }
.avatar-scanner-container.scanning .scanner-laser { animation:laser-sweep 1.2s linear infinite; }
.gen-progress-label { font-family:var(--font-display); font-size:1rem; color:var(--candy-pink); text-shadow:0 0 10px rgba(255,110,180,0.5); }

.gen-steps { display:flex; flex-direction:column; gap:8px; }
.gen-step { display:flex; align-items:center; gap:12px; padding:8px 12px; border-radius:var(--radius-sm); background:linear-gradient(135deg,#5a1414,#3d0f0f); border-top:1px solid rgba(255,110,180,0.2); border-left:1px solid rgba(255,110,180,0.15); border-right:1px solid #1e0505; border-bottom:3px solid #0f0202; }
.gen-step-icon { width:24px; height:24px; border-radius:50%; background:#3d0f0f; border:2px solid rgba(255,110,180,0.4); color:var(--cream); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:0.85rem; flex-shrink:0; }
.gen-step.done .gen-step-icon { background:var(--mint); border-color:var(--mint-dk); }
.gen-step-text { flex:1; }
.gen-step-title { font-size:0.9rem; font-weight:700; color:var(--cream); }
.gen-step-sub { font-size:0.75rem; color:var(--cream-dim); }
.gen-step.done .gen-step-title { color:var(--mint); text-shadow:0 0 8px rgba(0,201,167,0.6); }

.gen-progress-bar-wrap { height:8px; background:#1e0505; border-radius:4px; overflow:hidden; border:1px solid rgba(255,110,180,0.2); }
.gen-progress-bar { height:100%; background:linear-gradient(90deg,var(--candy-pink),#ff9de0,var(--caramel)); width:0%; transition:width 0.4s ease; }

.gen-transfer-panel { display:flex; align-items:center; justify-content:center; gap:12px; padding:12px; background:linear-gradient(135deg,#5a1414,#3d0f0f); border-top:1px solid rgba(255,110,180,0.25); border-left:1px solid rgba(255,110,180,0.2); border-right:1px solid #1e0505; border-bottom:3px solid #0f0202; border-radius:var(--radius-md); }
.transfer-node { display:flex; flex-direction:column; align-items:center; gap:4px; }
.transfer-avatar-wrap,.transfer-item-wrap { position:relative; }
.transfer-avatar-img { width:54px; height:54px; border-radius:50%; border:2px solid var(--candy-pink); box-shadow:0 0 12px rgba(255,110,180,0.3); }
.transfer-item-img { width:54px; height:54px; object-fit:contain; border-radius:8px; background:#3d0f0f; border:2px solid var(--candy-pink); padding:4px; }
.transfer-status-indicator { position:absolute; bottom:0; right:0; width:12px; height:12px; border-radius:50%; border:2px solid #3d0f0f; }
.transfer-status-indicator.online { background:var(--mint); box-shadow:0 0 6px var(--mint); }
.transfer-status-indicator.pending { background:var(--caramel); box-shadow:0 0 6px var(--caramel); }
.transfer-username,.transfer-item-name { font-size:0.8rem; font-weight:700; color:var(--cream); }
.transfer-badge { font-family:var(--font-display); font-size:0.65rem; padding:1px 6px; border-radius:4px; }
.online-badge { background:var(--mint); color:#fff; }
.pending-badge { background:linear-gradient(135deg,var(--candy-pink),#ff9de0); color:#fff; }
.transfer-path { display:flex; flex-direction:column; align-items:center; gap:4px; flex:1; }
.transfer-line { width:40px; height:4px; background:var(--candy-pink); border-radius:2px; box-shadow:0 0 8px rgba(255,110,180,0.5); }
.transfer-pulse { width:10px; height:10px; border-radius:50%; background:var(--caramel); animation:pulse-dot 1.2s ease-in-out infinite; box-shadow:0 0 8px var(--caramel); }

.offer-container { display:flex; flex-direction:column; gap:8px; }
.offer-card { display:flex; align-items:center; justify-content:space-between; padding:12px; background:linear-gradient(135deg,#5a1414,#3d0f0f); border-top:1px solid rgba(255,110,180,0.2); border-left:1px solid rgba(255,110,180,0.15); border-right:1px solid #1e0505; border-bottom:4px solid #0f0202; border-radius:var(--radius-md); text-decoration:none; color:var(--cream); transition:all 0.08s ease; }
.offer-card:hover { background:linear-gradient(135deg,#6b1a1a,#5a1414); border-top-color:var(--candy-pink); border-left-color:rgba(255,110,180,0.4); transform:translateY(-1px); }
.offer-card:active { transform:translateY(2px); border-bottom-width:2px; }
.offer-left { display:flex; align-items:center; gap:10px; }
.offer-img { width:32px; height:32px; border-radius:6px; object-fit:cover; }
.offer-info { display:flex; flex-direction:column; gap:4px; flex:1; min-width:0; text-align:left; }
.offer-title { font-family:var(--font-display); font-size:1.1rem; color:var(--cream); }
.offer-desc { font-family:var(--font-body); font-size:0.85rem; color:var(--cream-dim); font-weight:600; }
.offer-action { background:linear-gradient(160deg,#f5c842,var(--caramel)); color:var(--text-dark); font-family:var(--font-display); font-size:0.9rem; padding:6px 16px; border-radius:var(--radius-key); border-top:2px solid rgba(255,255,255,0.3); border-left:2px solid rgba(255,255,255,0.2); border-right:2px solid var(--caramel-dk); border-bottom:4px solid var(--caramel-dk); font-weight:900; }

.secure-footer-line { font-family:var(--font-display); color:var(--candy-pink); }
.spinner { width:36px; height:36px; border:4px solid rgba(255,110,180,0.2); border-top-color:var(--candy-pink); border-radius:50%; animation:spin 0.8s linear infinite; margin:0 auto; }
@keyframes spin { to { transform:rotate(360deg); } }
.offers-loading { text-align:center; color:var(--cream-dim); padding:20px; font-family:var(--font-display); font-size:0.95rem; display:flex; flex-direction:column; gap:10px; align-items:center; }
.gen-expire-note { font-family:var(--font-display); font-size:0.9rem; color:var(--caramel); text-shadow:0 0 8px rgba(212,160,23,0.5); }
.status-dot { display:inline-block; width:8px; height:8px; border-radius:50%; background:var(--candy-pink); margin-right:6px; }
.status-dot.pulsing { animation:pulse-dot 1.5s ease-in-out infinite; box-shadow:0 0 8px var(--candy-pink); }

.gen-final-card { display:flex; align-items:center; gap:12px; background:linear-gradient(135deg,#5a1414,#3d0f0f); border-top:1px solid rgba(255,110,180,0.2); border-left:1px solid rgba(255,110,180,0.15); border-right:1px solid #1e0505; border-bottom:4px solid #0f0202; border-radius:var(--radius-md); padding:12px 14px; margin-top:14px; }
.gen-final-thumb { width:64px; height:64px; object-fit:contain; border-radius:8px; border:2px solid var(--candy-pink); background:#3d0f0f; padding:4px; flex-shrink:0; }
.gen-final-info { flex:1; min-width:0; text-align:left; }
.gen-final-name { font-family:var(--font-display); font-size:1.1rem; color:var(--cream); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.gen-final-tag { font-family:var(--font-body); font-size:0.8rem; color:var(--mint); font-weight:700; margin-top:2px; text-shadow:0 0 8px rgba(0,201,167,0.5); }
.success-message-box { background:rgba(0,201,167,0.1); border-top:1px solid var(--mint); border-left:1px solid var(--mint); border-right:1px solid #003d30; border-bottom:3px solid #002920; border-radius:var(--radius-md); padding:16px; text-align:center; color:var(--cream); font-size:0.95rem; font-weight:600; }

/* ─── ANIMATIONS ──────────────────────────────── */
@keyframes float-bob { 0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);} }
@keyframes pulse-dot { 0%,100%{transform:scale(1);opacity:1;}50%{transform:scale(1.35);opacity:0.8;} }
@keyframes laser-sweep { 0%{top:0%;}50%{top:calc(100% - 3px);}100%{top:0%;} }

/* ─── RESPONSIVE ──────────────────────────────── */
@media (max-width:600px) {
    .main-container{padding:30px 10px 60px;}
    .hero-title{font-size:1.6rem;}
    .shop-item{gap:10px;padding:10px;}
    .shop-item-img-box{width:52px;height:52px;}
    .shop-item-img-box img{width:38px;height:38px;}
    .shop-item-name{font-size:1rem;}
    .roblox-claim-btn{padding:8px 14px;font-size:0.9rem;}
}

.animated-background,.bg-item-img,.bg-item-img img{display:none!important;}

/* ─── LIVE COUNT TICKER ─────────────────────── */
[data-i18n="hero_live"] {
    display:inline-block;
    font-family:var(--font-display);
    font-size:0.9rem;
    color:var(--caramel);
    text-shadow:0 0 8px rgba(212,160,23,0.5);
    letter-spacing:0.04em;
    margin-top:8px;
}
