/* /Layout/MainLayout.razor.rz.scp.css */
main[b-bz1983ss58] { display: block; }


/* ===== universal ZSS nav bar (uniform across all ZSS sites) ===== */
.zbar[b-bz1983ss58] {
    display: flex; align-items: center; justify-content: space-between; gap: 0.5rem;
    padding: 0.4rem 0.9rem;
    background: #100208;
    border-bottom: 1px solid rgba(122,19,32,0.6);
}
.zbar-brand[b-bz1983ss58] { font-weight: 800; font-size: 1.05rem; color: #e8d9c0; text-decoration: none; white-space: nowrap; }
.zbar-brand span[b-bz1983ss58] { color: #d2384a; text-shadow: 0 0 12px rgba(210,40,50,0.6); }
.zbar-right[b-bz1983ss58] { display: flex; align-items: center; gap: 0.35rem; flex-wrap: nowrap; }
.zchip[b-bz1983ss58] {
    display: inline-flex; align-items: center; gap: 0.2rem;
    border: 1px solid rgba(122,19,32,0.7);
    background: rgba(30,8,14,0.8);
    color: #d8c8ad;
    border-radius: 999px;
    padding: 0.26rem 0.7rem;
    font-weight: 700; font-size: 0.82rem;
    text-decoration: none; cursor: pointer; white-space: nowrap;
    box-shadow: 0 2px 8px rgba(0,0,0,0.6);
}
.zchip:hover[b-bz1983ss58] { border-color: #d2384a; box-shadow: 0 0 12px rgba(210,40,50,0.4); }
.zchip.primary[b-bz1983ss58] {
    background: linear-gradient(180deg, #b3263a, #7a1320); border-color: #d2384a; color: #fff;
    max-width: 11rem; overflow: hidden; text-overflow: ellipsis;
}
.zchip.primary:hover[b-bz1983ss58] { filter: brightness(1.08); }

.zbar-overlay[b-bz1983ss58] { position: fixed; inset: 0; z-index: 60; }
.zbar-drop[b-bz1983ss58] {
    position: fixed; top: 3.1rem; right: 0.6rem; z-index: 70;
    display: flex; flex-direction: column; gap: 0.25rem;
    min-width: 230px; padding: 0.55rem;
    background: #14040a;
    border: 1px solid rgba(122,19,32,0.7);
    border-radius: 14px;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.5);
}
.zbar-drop a[b-bz1983ss58], .zd-btn[b-bz1983ss58] {
    padding: 0.45rem 0.6rem;
    border: none; border-radius: 8px;
    background: transparent;
    color: #d8c8ad; font-weight: 700; font-size: 0.88rem;
    text-decoration: none; text-align: left; cursor: pointer;
}
.zbar-drop a:hover[b-bz1983ss58], .zd-btn:hover[b-bz1983ss58] { background: rgba(122,19,32,0.4); color: #fff; }
.zd-note[b-bz1983ss58] { font-size: 0.78rem; color: #a8916f; padding: 0.2rem 0.6rem; }
.zd-btn.danger[b-bz1983ss58] { color: #ffb9c0; background: rgba(214, 69, 80, 0.2); }
.zd-btn.danger:hover[b-bz1983ss58] { background: rgba(214, 69, 80, 0.4); }

/* ===== friends popup ===== */
.zm-ov[b-bz1983ss58] {
    position: fixed; inset: 0; z-index: 80;
    background: rgba(15, 17, 23, 0.7);
    display: grid; place-items: center;
    padding: 1rem;
}
.zm[b-bz1983ss58] {
    width: 100%; max-width: 420px;
    background: #14040a;
    border: 1px solid rgba(122,19,32,0.7);
    border-radius: 16px;
    padding: 1rem 1.1rem;
    box-shadow: 0 16px 44px rgba(0, 0, 0, 0.55);
    color: #eef1f8;
}
.zm h3[b-bz1983ss58] { margin: 0 0 0.25rem; text-align: center; }
.zm-note[b-bz1983ss58] { margin: 0 0 0.7rem; font-size: 0.82rem; color: #a8916f; text-align: center; }
.zm-add[b-bz1983ss58] { display: flex; gap: 0.4rem; margin-bottom: 0.5rem; }
.zm-add input[b-bz1983ss58] {
    flex: 1; min-width: 0;
    padding: 0.45rem 0.7rem;
    border-radius: 10px;
    border: 1px solid rgba(122,19,32,0.7);
    background: #08040a;
    color: #eef1f8; font-size: 0.9rem;
}
.zm-add button[b-bz1983ss58] {
    padding: 0.45rem 0.95rem;
    border: 1px solid #d2384a; border-radius: 10px;
    background: linear-gradient(180deg, #b3263a, #7a1320);
    color: #fff; font-weight: 800; cursor: pointer;
}
.zm-err[b-bz1983ss58] { margin: 0 0 0.4rem; color: #ffb9c0; font-size: 0.85rem; }
.zm-empty[b-bz1983ss58] { margin: 0.4rem 0; color: #a8916f; font-size: 0.88rem; text-align: center; }
.zm-list[b-bz1983ss58] { display: flex; flex-direction: column; gap: 0.3rem; max-height: 45vh; overflow-y: auto; }
.zm-row[b-bz1983ss58] {
    display: flex; align-items: center; gap: 0.5rem;
    background: rgba(30,8,14,0.7);
    border: 1px solid rgba(122,19,32,0.5);
    border-radius: 10px;
    padding: 0.4rem 0.6rem;
}
.zm-name[b-bz1983ss58] { flex: 1; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.zm-links[b-bz1983ss58] { display: flex; align-items: center; gap: 0.25rem; }
.zm-go[b-bz1983ss58] {
    display: grid; place-items: center;
    width: 1.9rem; height: 1.9rem;
    border-radius: 8px;
    background: rgba(122,19,32,0.4);
    text-decoration: none; font-size: 0.95rem;
}
.zm-go:hover[b-bz1983ss58] { background: rgba(210,40,50,0.5); }
.zm-x[b-bz1983ss58] {
    width: 1.9rem; height: 1.9rem;
    border: none; border-radius: 8px;
    background: rgba(214, 69, 80, 0.2);
    color: #ffb9c0; font-weight: 800; cursor: pointer;
}
.zm-x:hover[b-bz1983ss58] { background: rgba(214, 69, 80, 0.4); }
.zm-close[b-bz1983ss58] {
    width: 100%; margin-top: 0.7rem;
    padding: 0.5rem;
    border: 1px solid rgba(122,19,32,0.7); border-radius: 10px;
    background: transparent; color: #d8c8ad; font-weight: 700; cursor: pointer;
}
.zm-close:hover[b-bz1983ss58] { background: rgba(122,19,32,0.4); }

/* download chip — wide screens only (mobile keeps the bar slim) */
@media (max-width: 620px) {
    .zchip.dl-chip[b-bz1983ss58] { display: none; }
}

/* mobile: emoji-only chips, one slim row */
@media (max-width: 620px) {
    .zbar[b-bz1983ss58] { padding: 0.3rem 0.6rem; }
    .zbar-brand[b-bz1983ss58] { font-size: 0.95rem; }
    .zchip[b-bz1983ss58] { padding: 0.24rem 0.55rem; }
    .zchip .lbl[b-bz1983ss58] { display: none; }
}

/* ZSS score chip in the header */
.zscore[b-bz1983ss58] {
    display: inline-flex; align-items: center; gap: 0.25rem;
    padding: 0.26rem 0.6rem; border-radius: 999px;
    background: rgba(139,92,246,0.14); border: 1px solid rgba(167,139,250,0.5);
    color: #c9b8ff; font-size: 0.78rem; white-space: nowrap;
}
.zscore b[b-bz1983ss58] { color: #e8ddff; font-family: 'Cinzel', serif; }

/* achievements modal */
.ach-modal[b-bz1983ss58] { max-width: 400px; }
.ach-list[b-bz1983ss58] { display: grid; gap: 0.4rem; max-height: 56vh; overflow-y: auto; margin-bottom: 0.8rem; }
.ach-row[b-bz1983ss58] { display: flex; align-items: center; gap: 0.7rem; padding: 0.5rem 0.7rem; border-radius: 10px; background: rgba(30,8,14,0.6); border: 1px solid rgba(122,19,32,0.4); }
.ach-row.locked[b-bz1983ss58] { opacity: 0.5; }
.ach-row.got[b-bz1983ss58] { border-color: rgba(230,201,90,0.5); background: rgba(230,201,90,0.08); }
.ach-ic[b-bz1983ss58] { font-size: 1.4rem; width: 2rem; text-align: center; }
.ach-body[b-bz1983ss58] { display: flex; flex-direction: column; }
.ach-name[b-bz1983ss58] { font-weight: 700; color: #f0e2c8; font-size: 0.9rem; }
.ach-row.got .ach-name[b-bz1983ss58] { color: #e6c95a; }
.ach-desc[b-bz1983ss58] { font-size: 0.78rem; color: #a8916f; }

/* ---- mobile: tidy the header so it flows ---- */
@media (max-width: 620px) {
    .zbar[b-bz1983ss58] { padding: 0.3rem 0.5rem; flex-wrap: nowrap; }
    .zbar-brand[b-bz1983ss58] { font-size: 1.4rem; }
    .zbar-brand span[b-bz1983ss58] { display: none; }     /* just the 😈 on small screens */
    .zbar-right[b-bz1983ss58] { gap: 0.28rem; flex-wrap: wrap; justify-content: flex-end; }
    .zscore[b-bz1983ss58] { padding: 0.24rem 0.5rem; font-size: 0.72rem; }
}

/* ZSS score popup (matches the Trade-Up cross-game display) */
.zscore[b-bz1983ss58] { cursor: pointer; font: inherit; }
.zss-modal[b-bz1983ss58] { max-width: 320px; text-align: center; }
.zss-big[b-bz1983ss58] { margin: 0.2rem 0 0.6rem; font-family: 'Cinzel', serif; font-size: 2.6rem; font-weight: 900; color: #c9b8ff; text-shadow: 0 0 22px rgba(167,139,250,0.5); }
.zss-actions[b-bz1983ss58] { display: flex; gap: 0.5rem; justify-content: center; margin-top: 0.9rem; }
.zss-go[b-bz1983ss58] { display: inline-flex; align-items: center; padding: 0.5rem 1rem; border-radius: 10px; background: linear-gradient(180deg, #a78bfa, #7c3aed); color: #fff; font-weight: 700; text-decoration: none; }
/* /Pages/Landing.razor.rz.scp.css */
.land[b-76zlzc7kls] {
    min-height: calc(100vh - 43px);
    background:
        radial-gradient(ellipse at 50% -5%, #3a0810 0%, #12060c 45%, #05030a 100%);
    color: #e8d9c0;
    font-family: 'Cinzel', Georgia, serif;
    position: relative;
    overflow-x: hidden;
}
.land-embers[b-76zlzc7kls] { position: fixed; inset: 43px 0 0; pointer-events: none; z-index: 0; }
.land-embers span[b-76zlzc7kls] {
    position: absolute; bottom: -6%; color: #ff5a2c; opacity: 0;
    filter: drop-shadow(0 0 8px rgba(255,90,44,0.8));
    animation: landrise-b-76zlzc7kls linear infinite;
}
@keyframes landrise-b-76zlzc7kls {
    0% { transform: translateY(0) rotate(0); opacity: 0; }
    12% { opacity: 0.7; } 88% { opacity: 0.6; }
    100% { transform: translateY(-105vh) rotate(200deg); opacity: 0; }
}
.land > section[b-76zlzc7kls], .land > footer[b-76zlzc7kls] { position: relative; z-index: 1; }

/* ---- hero ---- */
.hero[b-76zlzc7kls] { text-align: center; padding: 3.5rem 1.25rem 2.5rem; max-width: 760px; margin: 0 auto; }
.hero-sigil[b-76zlzc7kls] { font-size: 4.5rem; color: rgba(210,40,50,0.55); text-shadow: 0 0 40px rgba(210,40,50,0.7); animation: breath-b-76zlzc7kls 4s ease-in-out infinite; }
@keyframes breath-b-76zlzc7kls { 0%,100% { opacity: 0.6; transform: scale(1); } 50% { opacity: 1; transform: scale(1.06); } }
.hero h1[b-76zlzc7kls] {
    font-family: 'UnifrakturMaguntia', serif; font-size: clamp(2.6rem, 11vw, 5rem); margin: 0.3rem 0 0;
    color: #f0e2c8; text-shadow: 0 0 30px rgba(210,40,50,0.7), 0 0 6px rgba(255,90,44,0.5); line-height: 1;
}
.hero-tag[b-76zlzc7kls] { font-size: clamp(1rem, 3.6vw, 1.35rem); color: #b9a487; margin: 0.8rem 0 1.6rem; }
.hero-tag em[b-76zlzc7kls] { color: #d2384a; font-style: italic; }
.hero-cta[b-76zlzc7kls] { display: flex; gap: 0.8rem; justify-content: center; flex-wrap: wrap; }
.cta-primary[b-76zlzc7kls], .cta-ghost[b-76zlzc7kls] {
    font-family: 'Cinzel'; font-weight: 700; font-size: 1rem; letter-spacing: 0.04em;
    padding: 0.8rem 1.7rem; border-radius: 12px; text-decoration: none; transition: 0.15s;
}
.cta-primary[b-76zlzc7kls] { background: linear-gradient(180deg, #b3263a, #7a1320); color: #fff; border: 1px solid #d2384a; box-shadow: 0 0 24px rgba(210,40,50,0.5); }
.cta-primary:hover[b-76zlzc7kls] { filter: brightness(1.12); box-shadow: 0 0 34px rgba(210,40,50,0.8); transform: translateY(-2px); }
.cta-ghost[b-76zlzc7kls] { background: transparent; color: #d8c8ad; border: 1px solid rgba(122,19,32,0.7); }
.cta-ghost:hover[b-76zlzc7kls] { border-color: #d2384a; color: #fff; }

.hero-stats[b-76zlzc7kls] { display: flex; gap: 0.5rem; flex-wrap: wrap; justify-content: center; margin: 1.6rem 0 0; }
.hero-stats span[b-76zlzc7kls] {
    font-size: 0.85rem; color: #a8916f; padding: 0.35rem 0.8rem;
    background: rgba(20,8,12,0.6); border: 1px solid rgba(122,19,32,0.5); border-radius: 999px;
}
.hero-stats b[b-76zlzc7kls] { color: #f0e2c8; }
.hero-firsttime[b-76zlzc7kls] { margin: 1.6rem 0 0; color: #8a7257; font-style: italic; }
.scroll-hint[b-76zlzc7kls] { margin-top: 2.2rem; color: #7a1320; font-family: 'Cinzel'; letter-spacing: 0.15em; font-size: 0.8rem; animation: nudge-b-76zlzc7kls 1.8s ease-in-out infinite; }
@keyframes nudge-b-76zlzc7kls { 0%,100% { opacity: 0.55; transform: translateY(0); } 50% { opacity: 1; transform: translateY(6px); } }

/* ---- sections ---- */
.seven[b-76zlzc7kls], .how[b-76zlzc7kls] { max-width: 900px; margin: 0 auto; padding: 2.5rem 1.25rem; }
.sect[b-76zlzc7kls] { font-family: 'Cinzel'; color: #d2384a; font-size: 1.4rem; letter-spacing: 0.08em; border-left: 4px solid #7a1320; padding-left: 0.7rem; text-shadow: 0 0 14px rgba(210,40,50,0.4); }
.sect-lede[b-76zlzc7kls] { color: #b9a487; line-height: 1.6; margin: 0.6rem 0 1.4rem; }
.sect-lede strong[b-76zlzc7kls] { color: #e6c95a; }

.sin-grid[b-76zlzc7kls] { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 0.7rem; }
.sin-card[b-76zlzc7kls] {
    display: flex; flex-direction: column; align-items: center; gap: 0.12rem; text-align: center;
    padding: 1rem 0.6rem; border-radius: 14px;
    background: linear-gradient(160deg, rgba(20,8,12,0.92), rgba(8,4,10,0.92));
    border: 1px solid rgba(122,19,32,0.5); transition: 0.15s;
}
.sin-card:hover[b-76zlzc7kls] { border-color: #d2384a; transform: translateY(-3px); box-shadow: 0 6px 20px rgba(210,40,50,0.3); }
.sc-ic[b-76zlzc7kls] { width: 50px; height: 50px; display: grid; place-items: center; font-size: 1.6rem; border-radius: 14px; background: linear-gradient(150deg, var(--g1), var(--g2)); box-shadow: inset 0 1px 2px rgba(255,255,255,0.18); margin-bottom: 0.35rem; }
.sc-name[b-76zlzc7kls] { font-weight: 700; color: #f0e2c8; }
.sc-latin[b-76zlzc7kls] { font-style: italic; color: #8a7257; font-size: 0.78rem; }
.sc-need[b-76zlzc7kls] { color: #d2384a; font-size: 0.8rem; font-weight: 700; margin-top: 0.2rem; }

.steps[b-76zlzc7kls] { display: grid; gap: 0.7rem; }
.step[b-76zlzc7kls] { display: flex; gap: 1rem; align-items: flex-start; background: rgba(255,255,255,0.03); border-left: 3px solid #7a1320; border-radius: 0 12px 12px 0; padding: 0.9rem 1.1rem; }
.step-n[b-76zlzc7kls] { font-size: 1.8rem; flex: 0 0 auto; }
.step strong[b-76zlzc7kls] { color: #e6c95a; font-size: 1.05rem; }
.step p[b-76zlzc7kls] { margin: 0.2rem 0 0; color: #b9a487; font-size: 0.92rem; line-height: 1.55; }
.how-cta[b-76zlzc7kls] { text-align: center; margin-top: 1.6rem; }

/* ---- footer ---- */
.land-foot[b-76zlzc7kls] { text-align: center; padding: 2.5rem 1.25rem 3.5rem; border-top: 1px dashed rgba(122,19,32,0.4); color: #8a7257; }
.foot-logo[b-76zlzc7kls] { font-family: 'UnifrakturMaguntia', serif; font-size: 1.8rem; color: #d2384a; margin: 0 0 0.4rem; }
.land-foot a[b-76zlzc7kls] { color: #d2384a; text-decoration: none; }
.land-foot a:hover[b-76zlzc7kls] { color: #f0e2c8; }
.foot-note[b-76zlzc7kls] { font-style: italic; color: #7a1320; margin-top: 0.6rem; }

@media (max-width: 620px) {
    .hero[b-76zlzc7kls] { padding-top: 2.2rem; }
    .sin-grid[b-76zlzc7kls] { grid-template-columns: repeat(3, 1fr); }
}
/* /Pages/Learn.razor.rz.scp.css */
.learn[b-rzx4d3za9s] {
    min-height: calc(100vh - 43px);
    background: radial-gradient(ellipse at 50% -10%, #2a0810 0%, #0c0408 55%, #05030a 100%);
    color: #e8d9c0;
    padding: 2.5rem 1.25rem 4rem;
    font-family: 'Cinzel', Georgia, serif;
}
.learn-inner[b-rzx4d3za9s] { max-width: 760px; margin: 0 auto; }
.learn h1[b-rzx4d3za9s] { font-family: 'UnifrakturMaguntia', serif; font-size: clamp(2.2rem, 7vw, 3.4rem); margin: 0; color: #d2384a; text-shadow: 0 0 24px rgba(210,40,50,0.6); text-align: center; }
.tag[b-rzx4d3za9s] { text-align: center; color: #a8916f; font-style: italic; margin: 0.3rem 0 2rem; }
.learn section[b-rzx4d3za9s] { margin-bottom: 2rem; }
.learn h2[b-rzx4d3za9s] { color: #e6c95a; font-size: 1.3rem; margin: 0 0 0.6rem; }
.learn p[b-rzx4d3za9s], .learn li[b-rzx4d3za9s] { color: #cbb596; line-height: 1.7; }
.learn b[b-rzx4d3za9s] { color: #f0e2c8; }
.learn em[b-rzx4d3za9s] { color: #d2384a; font-style: italic; }
.learn ol[b-rzx4d3za9s] { padding-left: 1.3rem; display: grid; gap: 0.5rem; }
.note[b-rzx4d3za9s] { font-style: italic; color: #a8916f; border-left: 2px solid #d2384a; padding-left: 0.8rem; }

.sins[b-rzx4d3za9s] { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 0.7rem; margin: 1rem 0; }
.sin[b-rzx4d3za9s] {
    display: flex; flex-direction: column; align-items: center; gap: 0.15rem; text-align: center;
    padding: 0.9rem 0.6rem; border-radius: 14px;
    background: linear-gradient(160deg, rgba(20,8,12,0.9), rgba(8,4,10,0.9));
    border: 1px solid rgba(122,19,32,0.5);
}
.s-ic[b-rzx4d3za9s] {
    width: 48px; height: 48px; display: grid; place-items: center; font-size: 1.5rem; border-radius: 13px;
    background: linear-gradient(150deg, var(--g1), var(--g2)); box-shadow: inset 0 1px 2px rgba(255,255,255,0.16); margin-bottom: 0.3rem;
}
.s-name[b-rzx4d3za9s] { font-weight: 700; color: #f0e2c8; }
.s-latin[b-rzx4d3za9s] { font-style: italic; color: #8a7257; font-size: 0.8rem; }
.s-need[b-rzx4d3za9s] { color: #d2384a; font-size: 0.8rem; font-weight: 700; margin-top: 0.2rem; }

.back[b-rzx4d3za9s] { display: inline-block; margin-top: 1rem; color: #d2384a; text-decoration: none; font-weight: 700; }
.back:hover[b-rzx4d3za9s] { color: #f0e2c8; text-shadow: 0 0 10px rgba(210,40,50,0.6); }
/* /Pages/Play.razor.rz.scp.css */
/* ====================== infernal backdrop ====================== */
.hell[b-jldlkfrwkd] {
    position: relative;            /* in flow so the page scrolls when content is tall */
    min-height: calc(100vh - 43px);
    background:
        radial-gradient(ellipse at 50% 120%, #5a0a12 0%, #1a0408 38%, #05030a 72%),
        repeating-linear-gradient(115deg, rgba(122,19,32,0.05) 0 2px, transparent 2px 26px);
    background-attachment: fixed;  /* anchored to the viewport while scrolling */
    color: #e8d9c0;
}
.hell[b-jldlkfrwkd]::before {
    content: ""; position: fixed; inset: 43px 0 0; pointer-events: none; z-index: 0;
    background: radial-gradient(circle at 50% 60%, transparent 40%, rgba(0,0,0,0.7) 100%);
    box-shadow: inset 0 0 220px 40px rgba(122,19,32,0.45);
    animation: breathe-b-jldlkfrwkd 7s ease-in-out infinite;
}
@keyframes breathe-b-jldlkfrwkd { 0%,100% { opacity: 0.7; } 50% { opacity: 1; } }

.pentagram[b-jldlkfrwkd] {
    position: fixed; left: 50%; top: 52%;
    width: 78vh; height: 78vh; transform: translate(-50%, -50%);
    background: radial-gradient(circle, transparent 47%, rgba(180,30,40,0.18) 48%, rgba(180,30,40,0.18) 49.4%, transparent 50%);
    filter: drop-shadow(0 0 30px rgba(180,30,40,0.4));
    animation: spin-b-jldlkfrwkd 90s linear infinite; pointer-events: none; opacity: 0.5; z-index: 0;
}
.pentagram[b-jldlkfrwkd]::after {
    content: "⛤"; position: absolute; inset: 0; display: grid; place-items: center;
    font-size: 66vh; line-height: 1; color: rgba(180,30,40,0.12);
    text-shadow: 0 0 40px rgba(210,40,50,0.5);
}
@keyframes spin-b-jldlkfrwkd { to { transform: translate(-50%, -50%) rotate(360deg); } }

.embers[b-jldlkfrwkd] { position: fixed; inset: 43px 0 0; pointer-events: none; z-index: 0; }
.embers span[b-jldlkfrwkd] {
    position: absolute; bottom: -8%; opacity: 0; color: #ff5a2c;
    filter: drop-shadow(0 0 8px rgba(255,90,44,0.8));
    animation-name: rise-b-jldlkfrwkd; animation-timing-function: linear; animation-iteration-count: infinite;
}
@keyframes rise-b-jldlkfrwkd {
    0% { transform: translateY(0) rotate(0); opacity: 0; }
    12% { opacity: 0.8; } 88% { opacity: 0.7; }
    100% { transform: translateY(-100vh) rotate(220deg); opacity: 0; }
}

/* ====================== three-column stage ====================== */
.stage[b-jldlkfrwkd] {
    position: relative; z-index: 2;
    min-height: calc(100vh - 43px);
    display: grid; grid-template-columns: 1fr auto 1fr;
    align-items: center; gap: 2rem; padding: 1rem 3vw; box-sizing: border-box;
}
.side[b-jldlkfrwkd] { max-width: 340px; }
.side.left[b-jldlkfrwkd] { justify-self: end; text-align: right; }
.side.right[b-jldlkfrwkd] { justify-self: start; }
.side-h[b-jldlkfrwkd] {
    font-family: 'UnifrakturMaguntia', 'Cinzel', serif; font-size: 1.9rem; margin: 0 0 0.8rem;
    color: #d2384a; text-shadow: 0 0 18px rgba(210,40,50,0.6);
}
.lede[b-jldlkfrwkd] { color: #b9a487; font-size: 0.98rem; line-height: 1.6; margin: 0 0 1.2rem; }
.hint-sm[b-jldlkfrwkd] { color: #8a7257; font-size: 0.8rem; font-style: italic; line-height: 1.5; margin: 0.8rem 0 0; }
.hint-sm b[b-jldlkfrwkd] { color: #d2384a; }

.meta[b-jldlkfrwkd], .ledger[b-jldlkfrwkd] { display: grid; gap: 0.5rem; }
.meta-row[b-jldlkfrwkd], .led-row[b-jldlkfrwkd] {
    display: flex; justify-content: space-between; align-items: center;
    padding: 0.45rem 0.7rem; border: 1px solid rgba(122,19,32,0.45);
    border-radius: 9px; background: rgba(20,8,12,0.5); font-size: 0.9rem; color: #b9a487;
}
.meta-row b[b-jldlkfrwkd], .led-row b[b-jldlkfrwkd] { color: #f0e2c8; font-size: 1.05rem; }
.led-row span[b-jldlkfrwkd] { text-transform: uppercase; letter-spacing: 0.1em; font-size: 0.72rem; color: #8a7257; }

.relic-h[b-jldlkfrwkd] { font-family: 'Cinzel'; color: #d2384a; font-size: 1rem; margin: 1.2rem 0 0.5rem; letter-spacing: 0.05em; }
.relics[b-jldlkfrwkd] { display: grid; gap: 0.35rem; }
.relic[b-jldlkfrwkd] {
    display: flex; align-items: center; gap: 0.5rem; font-size: 0.82rem; color: #d8c8ad;
    padding: 0.35rem 0.6rem; border-left: 2px solid #d2384a; background: rgba(122,19,32,0.18);
    border-radius: 0 7px 7px 0;
}

/* right column temptations */
.temptations[b-jldlkfrwkd] { list-style: none; padding: 0; margin: 0 0 0.5rem; display: grid; gap: 0.45rem; }
.temptations li[b-jldlkfrwkd] {
    display: flex; align-items: center; gap: 0.7rem; padding: 0.5rem 0.7rem;
    background: rgba(20,8,12,0.6); border: 1px solid rgba(122,19,32,0.45); border-radius: 10px;
    transition: 0.2s;
}
.temptations li.sealed[b-jldlkfrwkd] { opacity: 0.55; border-color: rgba(122,19,32,0.25); }
.t-icon[b-jldlkfrwkd] {
    width: 32px; height: 32px; flex: 0 0 auto; display: grid; place-items: center;
    border-radius: 8px; font-size: 1.1rem; background: linear-gradient(150deg, var(--g1), var(--g2));
    box-shadow: inset 0 0 6px rgba(0,0,0,0.5);
}
.t-body[b-jldlkfrwkd] { flex: 1; min-width: 0; }
.t-name[b-jldlkfrwkd] { display: block; font-weight: 700; color: #e8d9c0; font-size: 0.85rem; }
.t-name em[b-jldlkfrwkd] { color: #8a7257; font-weight: 400; font-style: italic; font-size: 0.78rem; }
.t-track[b-jldlkfrwkd] { display: block; height: 6px; margin-top: 0.3rem; border-radius: 999px; background: rgba(0,0,0,0.5); overflow: hidden; }
.t-fill[b-jldlkfrwkd] { display: block; height: 100%; transition: width 0.4s ease; }
.t-fill.calm[b-jldlkfrwkd] { background: linear-gradient(90deg, #6b7280, #9aa0ae); }
.t-fill.warn[b-jldlkfrwkd] { background: linear-gradient(90deg, #c79a3b, #e6b35a); }
.t-fill.danger[b-jldlkfrwkd] { background: linear-gradient(90deg, #7a1320, #d2452b); }
.t-pip[b-jldlkfrwkd] { font-family: 'Cinzel'; color: #d2384a; font-weight: 700; font-size: 0.9rem; min-width: 1.6rem; text-align: right; }

/* ====================== the phone ====================== */
.phone-wrap[b-jldlkfrwkd] { display: flex; flex-direction: column; align-items: center; gap: 0.9rem; }
.phone[b-jldlkfrwkd] {
    position: relative; width: 312px; height: 642px; border-radius: 46px;
    background: linear-gradient(160deg, #1c1c22, #0a0a0d); padding: 11px;
    box-shadow: 0 0 0 2px #2a2a30, 0 0 60px rgba(210,40,50,0.45), 0 30px 70px rgba(0,0,0,0.8);
}
.notch[b-jldlkfrwkd] { position: absolute; top: 11px; left: 50%; transform: translateX(-50%); width: 148px; height: 25px; background: #0a0a0d; border-radius: 0 0 18px 18px; z-index: 5; }
.screen[b-jldlkfrwkd] {
    position: relative; width: 100%; height: 100%; border-radius: 36px; overflow: hidden;
    background: radial-gradient(ellipse at 50% 0%, #2a0810 0%, #12060c 45%, #08040a 100%);
    display: flex; flex-direction: column;
}
.home-bar[b-jldlkfrwkd] { position: absolute; bottom: 8px; left: 50%; transform: translateX(-50%); width: 118px; height: 5px; border-radius: 3px; background: rgba(232,217,192,0.5); z-index: 6; }

.status-bar[b-jldlkfrwkd] { display: flex; justify-content: space-between; align-items: center; padding: 0.55rem 1.3rem 0.15rem; font-size: 0.72rem; color: #cbb596; letter-spacing: 0.05em; }
.carrier[b-jldlkfrwkd] { font-family: 'UnifrakturMaguntia', serif; font-size: 0.95rem; color: #d2384a; }

.lock-head[b-jldlkfrwkd] { text-align: center; padding: 0.5rem 0 0.6rem; }
.clock[b-jldlkfrwkd] { font-family: 'Cinzel'; font-weight: 900; font-size: 3rem; line-height: 1; color: #f0e2c8; text-shadow: 0 0 22px rgba(210,40,50,0.6); }
.date[b-jldlkfrwkd] { color: #a8916f; font-size: 0.82rem; letter-spacing: 0.06em; margin-top: 0.2rem; }
.lock-body[b-jldlkfrwkd] { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1rem; padding: 0 1.5rem 2rem; }
.lock-tag[b-jldlkfrwkd] { font-style: italic; color: #a8916f; margin: 0; }
.begin[b-jldlkfrwkd] {
    font-family: 'Cinzel'; font-weight: 700; font-size: 0.95rem; letter-spacing: 0.05em;
    padding: 0.7rem 1.5rem; border: 1px solid #d2384a; border-radius: 12px; cursor: pointer;
    background: linear-gradient(180deg, #b3263a, #7a1320); color: #fff;
    box-shadow: 0 0 22px rgba(210,40,50,0.5); transition: 0.15s;
}
.begin:hover[b-jldlkfrwkd] { filter: brightness(1.12); box-shadow: 0 0 30px rgba(210,40,50,0.8); }

/* in-run HUD */
.ghud[b-jldlkfrwkd] {
    display: flex; justify-content: space-around; align-items: center;
    padding: 0.45rem 0.6rem; margin: 0.2rem 0.9rem 0.4rem;
    background: rgba(40,16,22,0.5); border: 1px solid rgba(122,19,32,0.5); border-radius: 12px;
    font-family: 'Cinzel'; font-size: 0.74rem; color: #d8c8ad; letter-spacing: 0.04em;
}

/* sin app grid */
.apps[b-jldlkfrwkd] { flex: 1; display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.35rem 0.2rem; align-content: start; padding: 0.3rem 0.8rem; overflow-y: auto; }
.app[b-jldlkfrwkd] { display: flex; flex-direction: column; align-items: center; gap: 0.25rem; background: none; border: none; cursor: pointer; padding: 0.25rem 0; color: #e8d9c0; }
.app:disabled[b-jldlkfrwkd] { cursor: default; }
.app .icon[b-jldlkfrwkd] {
    position: relative; width: 56px; height: 56px; display: grid; place-items: center;
    border-radius: 16px; font-size: 1.6rem; background: linear-gradient(150deg, var(--g1), var(--g2));
    box-shadow: 0 4px 12px rgba(0,0,0,0.5), inset 0 1px 2px rgba(255,255,255,0.16); transition: transform 0.12s, box-shadow 0.12s;
}
.app.ready .icon[b-jldlkfrwkd] { box-shadow: 0 0 0 2px #f0e2c8, 0 0 18px rgba(240,226,200,0.6); animation: pulse-b-jldlkfrwkd 1.3s ease-in-out infinite; }
@keyframes pulse-b-jldlkfrwkd { 0%,100% { box-shadow: 0 0 0 2px #f0e2c8, 0 0 14px rgba(240,226,200,0.5); } 50% { box-shadow: 0 0 0 2px #fff, 0 0 26px rgba(240,226,200,0.9); } }
.app.ready:hover .icon[b-jldlkfrwkd] { transform: translateY(-3px) scale(1.05); }
.app.ready:active .icon[b-jldlkfrwkd] { transform: scale(0.94); }
.app.sealed .icon[b-jldlkfrwkd] { filter: grayscale(0.7) brightness(0.6); }
.corr[b-jldlkfrwkd] {
    position: absolute; bottom: -5px; right: -5px; min-width: 20px; height: 20px; padding: 0 3px;
    display: grid; place-items: center; border-radius: 10px; font-size: 0.62rem; font-weight: 800;
    background: #08040a; color: #f0e2c8; border: 1.5px solid rgba(210,40,50,0.7);
    box-shadow: 0 0 8px rgba(0,0,0,0.6);
}
.seal[b-jldlkfrwkd] { position: absolute; inset: 0; display: grid; place-items: center; font-size: 1.7rem; color: #d2384a; text-shadow: 0 0 12px rgba(210,40,50,0.9); }
.app-name[b-jldlkfrwkd] { font-size: 0.68rem; letter-spacing: 0.02em; color: #d8c8ad; }
.app-need[b-jldlkfrwkd] { font-size: 0.6rem; color: #8a7257; font-style: italic; }

/* dice tray */
.tray[b-jldlkfrwkd] { margin: auto 0.7rem 1.3rem; padding: 0.55rem; background: rgba(40,16,22,0.55); border: 1px solid rgba(122,19,32,0.55); border-radius: 18px; }
.dice[b-jldlkfrwkd] { display: flex; flex-wrap: wrap; gap: 0.35rem; justify-content: center; margin-bottom: 0.5rem; }
.die[b-jldlkfrwkd] {
    width: 38px; height: 38px; display: grid; place-items: center; font-size: 1.8rem; line-height: 1;
    border-radius: 9px; background: #f0e2c8; color: #1a0408;
    box-shadow: 0 2px 6px rgba(0,0,0,0.6), inset 0 -2px 4px rgba(0,0,0,0.2);
    animation: tumble-b-jldlkfrwkd 0.3s ease-out;
}
.die.spent[b-jldlkfrwkd] { opacity: 0.28; transform: scale(0.88); }
@keyframes tumble-b-jldlkfrwkd { from { transform: rotate(-90deg) scale(0.5); opacity: 0; } to { transform: none; opacity: 1; } }
.tray-btns[b-jldlkfrwkd] { display: flex; gap: 0.35rem; }
.tb[b-jldlkfrwkd] { flex: 1; padding: 0.45rem 0.3rem; border-radius: 10px; border: 1px solid rgba(122,19,32,0.6); background: rgba(20,8,12,0.8); color: #d8c8ad; font-size: 0.72rem; font-weight: 700; cursor: pointer; transition: 0.12s; }
.tb:hover:not(:disabled)[b-jldlkfrwkd] { border-color: #d2384a; color: #fff; }
.tb:disabled[b-jldlkfrwkd] { opacity: 0.4; cursor: default; }
.tb.endday[b-jldlkfrwkd] { background: linear-gradient(180deg, #b3263a, #7a1320); color: #fff; border-color: #d2384a; }
.tb.wild[b-jldlkfrwkd] { background: rgba(240,226,200,0.15); }

/* game over / win */
.over[b-jldlkfrwkd] { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 0.5rem; padding: 0 1.5rem 2rem; text-align: center; }
.over-big[b-jldlkfrwkd] { font-size: 4rem; animation: breathe-b-jldlkfrwkd 3s ease-in-out infinite; }
.over h3[b-jldlkfrwkd] { font-family: 'UnifrakturMaguntia', serif; font-size: 2.4rem; margin: 0; color: #f0e2c8; text-shadow: 0 0 20px rgba(210,40,50,0.6); }
.over.won h3[b-jldlkfrwkd] { color: #e6c95a; text-shadow: 0 0 22px rgba(230,201,90,0.7); }
.over-sub[b-jldlkfrwkd] { color: #a8916f; font-style: italic; margin: 0 0 0.6rem; }
.over-stats[b-jldlkfrwkd] { display: flex; gap: 1.2rem; margin-bottom: 1rem; }
.over-stats div[b-jldlkfrwkd] { display: flex; flex-direction: column; }
.over-stats b[b-jldlkfrwkd] { font-family: 'Cinzel'; font-size: 1.5rem; color: #d2384a; }
.over-stats span[b-jldlkfrwkd] { font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.12em; color: #8a7257; }

.phone-cap[b-jldlkfrwkd] { font-style: italic; color: #8a7257; letter-spacing: 0.08em; margin: 0; text-align: center; max-width: 320px; }
.phone-cap.toast[b-jldlkfrwkd] { color: #e6c95a; text-shadow: 0 0 12px rgba(230,201,90,0.5); font-style: normal; font-weight: 700; }

/* ====================== auth modal ====================== */
.auth-ov[b-jldlkfrwkd] { position: fixed; inset: 0; z-index: 100; background: rgba(5,2,8,0.8); display: grid; place-items: center; padding: 1rem; }
.auth[b-jldlkfrwkd] { width: 100%; max-width: 360px; background: #14040a; border: 1px solid rgba(122,19,32,0.7); border-radius: 16px; padding: 1.2rem; box-shadow: 0 0 50px rgba(210,40,50,0.4); }
.auth h3[b-jldlkfrwkd] { margin: 0 0 0.8rem; text-align: center; color: #f0e2c8; font-family: 'Cinzel'; font-size: 1.05rem; }
.auth-tabs[b-jldlkfrwkd] { display: flex; gap: 0.3rem; margin-bottom: 0.7rem; }
.auth-tabs button[b-jldlkfrwkd] { flex: 1; padding: 0.45rem; border: 1px solid rgba(122,19,32,0.6); background: rgba(20,8,12,0.8); color: #a8916f; border-radius: 9px; font-weight: 700; font-size: 0.82rem; cursor: pointer; }
.auth-tabs button.on[b-jldlkfrwkd] { background: linear-gradient(180deg, #b3263a, #7a1320); color: #fff; border-color: #d2384a; }
.auth-in[b-jldlkfrwkd] { width: 100%; box-sizing: border-box; margin-bottom: 0.5rem; padding: 0.6rem 0.8rem; border-radius: 10px; border: 1px solid rgba(122,19,32,0.6); background: #08040a; color: #e8d9c0; font-size: 0.92rem; }
.auth-err[b-jldlkfrwkd] { color: #ff8a8a; font-size: 0.85rem; margin: 0 0 0.5rem; }
.auth-go[b-jldlkfrwkd] { width: 100%; padding: 0.65rem; border: none; border-radius: 10px; background: linear-gradient(180deg, #b3263a, #7a1320); color: #fff; font-weight: 800; cursor: pointer; margin-bottom: 0.4rem; }
.auth-x[b-jldlkfrwkd] { width: 100%; padding: 0.5rem; border: 1px solid rgba(122,19,32,0.5); border-radius: 10px; background: transparent; color: #a8916f; cursor: pointer; }

/* ====================== responsive ====================== */
@media (max-width: 1080px) {
    .stage[b-jldlkfrwkd] { grid-template-columns: 1fr; justify-items: center; gap: 1rem; overflow-y: auto; padding: 1.5rem 1rem; height: auto; min-height: calc(100vh - 43px); }
    .side[b-jldlkfrwkd] { display: none; }
}

/* ====================== full-screen 3D dice arena ====================== */
.arena[b-jldlkfrwkd] {
    position: fixed; inset: 0; z-index: 200;
    background: radial-gradient(ellipse at 50% 45%, rgba(60,8,18,0.97), rgba(6,2,10,0.99) 75%);
    perspective: 1100px; perspective-origin: 50% 42%;
    display: grid; place-items: center; cursor: pointer;
    animation: arenaIn-b-jldlkfrwkd 0.3s ease;
    overflow: hidden;
}
@keyframes arenaIn-b-jldlkfrwkd { from { opacity: 0; } to { opacity: 1; } }
.arena[b-jldlkfrwkd]::before {
    content: "⛤"; position: absolute; left: 50%; top: 44%; transform: translate(-50%, -50%);
    font-size: 90vh; line-height: 1; color: rgba(180,30,40,0.07);
    text-shadow: 0 0 60px rgba(210,40,50,0.4); pointer-events: none;
    animation: spin-b-jldlkfrwkd 60s linear infinite;
}
.arena-floor[b-jldlkfrwkd] {
    position: absolute; left: 50%; bottom: 8%; transform: translateX(-50%);
    width: 70vw; height: 26vh; border-radius: 50%;
    background: radial-gradient(ellipse, rgba(210,40,50,0.22), transparent 70%);
    filter: blur(8px); pointer-events: none;
}
.arena-stage[b-jldlkfrwkd] { position: relative; width: 1px; height: 1px; transform-style: preserve-3d; }

.die3d[b-jldlkfrwkd] {
    position: absolute; left: 0; top: 0; width: 72px; height: 72px; margin: -36px;
    transform-style: preserve-3d;
    transition: transform 1.5s cubic-bezier(0.16, 0.7, 0.18, 1);
}
.face[b-jldlkfrwkd] {
    position: absolute; width: 72px; height: 72px; box-sizing: border-box; padding: 9px;
    display: grid; grid-template: repeat(3, 1fr) / repeat(3, 1fr);
    background: linear-gradient(135deg, #f7eed9 0%, #e6d2ac 60%, #cdb487 100%);
    border-radius: 6px;
    box-shadow: inset 0 0 10px rgba(122,19,32,0.25), inset 0 2px 4px rgba(255,255,255,0.5);
    backface-visibility: hidden;
}
.f1[b-jldlkfrwkd] { transform: rotateY(0deg)    translateZ(36px); }
.f6[b-jldlkfrwkd] { transform: rotateY(180deg)  translateZ(36px); }
.f3[b-jldlkfrwkd] { transform: rotateY(90deg)   translateZ(36px); }
.f4[b-jldlkfrwkd] { transform: rotateY(-90deg)  translateZ(36px); }
.f2[b-jldlkfrwkd] { transform: rotateX(90deg)   translateZ(36px); }
.f5[b-jldlkfrwkd] { transform: rotateX(-90deg)  translateZ(36px); }
.cell[b-jldlkfrwkd] { display: grid; place-items: center; }
.cell.on[b-jldlkfrwkd]::after {
    content: ""; width: 12px; height: 12px; border-radius: 50%;
    background: radial-gradient(circle at 34% 30%, #a8323e, #4a0a14 70%, #2a0408);
    box-shadow: 0 1px 2px rgba(0,0,0,0.55), inset 0 1px 1px rgba(255,255,255,0.25);
}

/* while resting, the dice hover with a slow ominous bob */
.arena:not(.rolled) .die3d[b-jldlkfrwkd] { animation: hover-b-jldlkfrwkd 2.4s ease-in-out infinite; }
@keyframes hover-b-jldlkfrwkd { 0%,100% { margin-top: -36px; } 50% { margin-top: -48px; } }

.arena-prompt[b-jldlkfrwkd] {
    position: absolute; bottom: 11%; left: 50%; transform: translateX(-50%);
    text-align: center; display: flex; flex-direction: column; align-items: center; gap: 0.15rem;
    pointer-events: none;
}
.ap-sigil[b-jldlkfrwkd] { font-size: 2rem; color: #d2384a; text-shadow: 0 0 20px rgba(210,40,50,0.8); animation: breathe-b-jldlkfrwkd 2s ease-in-out infinite; }
.ap-text[b-jldlkfrwkd] {
    font-family: 'UnifrakturMaguntia', serif; font-size: 1.8rem; color: #f0e2c8;
    text-shadow: 0 0 18px rgba(210,40,50,0.6); letter-spacing: 0.04em;
    animation: nudge-b-jldlkfrwkd 1.6s ease-in-out infinite;
}
.ap-sub[b-jldlkfrwkd] { font-family: 'Cinzel'; font-size: 0.8rem; color: #a8916f; letter-spacing: 0.15em; text-transform: uppercase; }
@keyframes nudge-b-jldlkfrwkd { 0%,100% { opacity: 0.65; transform: translateY(0); } 50% { opacity: 1; transform: translateY(-4px); } }

.arena-fate[b-jldlkfrwkd] {
    position: absolute; bottom: 12%; left: 50%; transform: translateX(-50%);
    font-family: 'UnifrakturMaguntia', serif; font-size: 1.5rem; color: #d2384a;
    text-shadow: 0 0 18px rgba(210,40,50,0.6); pointer-events: none;
    animation: fadePulse-b-jldlkfrwkd 1.5s ease-in-out;
}
@keyframes fadePulse-b-jldlkfrwkd { 0% { opacity: 0; } 30% { opacity: 1; } 100% { opacity: 0.5; } }

/* ====================== flares (primary temptation) ====================== */
.app.flared .icon[b-jldlkfrwkd] {
    box-shadow: 0 0 0 2px #ff5a2c, 0 0 22px rgba(255,90,44,0.9);
    animation: flarePulse-b-jldlkfrwkd 0.9s ease-in-out infinite;
}
@keyframes flarePulse-b-jldlkfrwkd {
    0%,100% { box-shadow: 0 0 0 2px #ff5a2c, 0 0 14px rgba(255,90,44,0.7); }
    50% { box-shadow: 0 0 0 3px #ffae3c, 0 0 30px rgba(255,140,44,1); }
}
.flare[b-jldlkfrwkd] { position: absolute; top: -8px; left: -6px; font-size: 1rem; animation: flicker-b-jldlkfrwkd 0.5s steps(2) infinite; filter: drop-shadow(0 0 4px rgba(255,90,44,0.9)); }
@keyframes flicker-b-jldlkfrwkd { 0%,100% { transform: rotate(-8deg) scale(1); } 50% { transform: rotate(8deg) scale(1.15); } }
.corr.hot[b-jldlkfrwkd] { border-color: #ff5a2c; color: #ffd0a0; box-shadow: 0 0 10px rgba(255,90,44,0.8); }
.app-need.primary[b-jldlkfrwkd] { color: #ff7a3c; font-weight: 800; font-style: normal; }

.temptations li.flared[b-jldlkfrwkd] { border-color: #ff5a2c; background: rgba(255,90,44,0.14); box-shadow: 0 0 14px rgba(255,90,44,0.3); }
.temptations li.flared .t-icon[b-jldlkfrwkd] { background: radial-gradient(circle, #ff7a3c, #7a1320); animation: flicker-b-jldlkfrwkd 0.5s steps(2) infinite; }

/* ====================== relic detail popup ====================== */
.relic-hint[b-jldlkfrwkd] { font-size: 0.62rem; color: #8a7257; font-weight: 400; letter-spacing: 0; }
.relic[b-jldlkfrwkd] { font: inherit; text-align: left; width: 100%; cursor: pointer; }
.relic:hover[b-jldlkfrwkd] { background: rgba(122,19,32,0.34); border-left-color: #ff5a2c; }
.relic-pop-ov[b-jldlkfrwkd] { position: fixed; inset: 0; z-index: 210; background: rgba(5,2,8,0.82); display: grid; place-items: center; padding: 1rem; }
.relic-pop[b-jldlkfrwkd] {
    width: 100%; max-width: 300px; text-align: center;
    background: #14040a; border: 1px solid rgba(210,40,50,0.6); border-radius: 16px;
    padding: 1.5rem 1.3rem; box-shadow: 0 0 50px rgba(210,40,50,0.45);
}
.rp-icon[b-jldlkfrwkd] { font-size: 2.6rem; margin-bottom: 0.3rem; }
.relic-pop h3[b-jldlkfrwkd] { margin: 0 0 0.4rem; color: #f0e2c8; font-family: 'Cinzel'; }
.relic-pop p[b-jldlkfrwkd] { color: #cbb596; line-height: 1.6; margin: 0 0 1rem; }
.rp-x[b-jldlkfrwkd] { padding: 0.5rem 1.4rem; border: 1px solid rgba(122,19,32,0.6); border-radius: 10px; background: linear-gradient(180deg, #b3263a, #7a1320); color: #fff; font-weight: 700; cursor: pointer; }

/* ====================== mobile: info on top, collapsible temptations ====================== */
.caret[b-jldlkfrwkd] { display: none; }
@media (max-width: 1080px) {
    .stage[b-jldlkfrwkd] { grid-template-columns: 1fr; justify-items: stretch; gap: 0.9rem; overflow-y: auto; padding: 1rem 1rem 2rem; height: auto; min-height: calc(100vh - 43px); }

    /* left ledger → a compact strip across the top */
    .side[b-jldlkfrwkd] { display: block; max-width: none; width: 100%; text-align: left; }
    .side.left[b-jldlkfrwkd] { order: -1; }
    .side.left .lede[b-jldlkfrwkd] { display: none; }
    .side-h[b-jldlkfrwkd] { font-size: 1.3rem; margin-bottom: 0.5rem; }
    .meta[b-jldlkfrwkd], .ledger[b-jldlkfrwkd] { grid-auto-flow: column; grid-template-columns: none; justify-content: start; gap: 0.4rem; overflow-x: auto; padding-bottom: 0.2rem; }
    .meta-row[b-jldlkfrwkd], .led-row[b-jldlkfrwkd] { flex-direction: column; align-items: flex-start; gap: 0.1rem; min-width: max-content; padding: 0.4rem 0.7rem; }
    .relics[b-jldlkfrwkd] { grid-auto-flow: column; justify-content: start; overflow-x: auto; }
    .relic[b-jldlkfrwkd] { white-space: nowrap; }

    /* phone in the middle */
    .phone-wrap[b-jldlkfrwkd] { order: 1; }

    /* temptations → collapsible card */
    .side.right[b-jldlkfrwkd] { order: 2; }
    .tempt-toggle[b-jldlkfrwkd] { cursor: pointer; display: flex; align-items: center; justify-content: space-between; background: rgba(20,8,12,0.6); border: 1px solid rgba(122,19,32,0.5); border-radius: 10px; padding: 0.5rem 0.8rem; }
    .caret[b-jldlkfrwkd] { display: inline; color: #d2384a; font-size: 1.1rem; }
    .temptations[b-jldlkfrwkd] { display: none; margin-top: 0.5rem; }
    .temptations.open[b-jldlkfrwkd] { display: grid; }
    .side.right .hint-sm[b-jldlkfrwkd] { display: none; }
}

/* freshly-unlocked achievements on the game-over screen */
.over-unlocks[b-jldlkfrwkd] { display: flex; flex-wrap: wrap; gap: 0.3rem; justify-content: center; margin-bottom: 0.9rem; max-width: 260px; }
.ou-h[b-jldlkfrwkd] { width: 100%; font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.14em; color: #e6c95a; }
.ou-chip[b-jldlkfrwkd] { font-size: 0.72rem; font-weight: 700; color: #1a0408; background: linear-gradient(180deg, #f0d878, #e6b35a); border-radius: 999px; padding: 0.16rem 0.55rem; }

/* dice stay a mystery until cast — no spoiling the roll at rest */
.face .myst[b-jldlkfrwkd] { grid-column: 1 / -1; place-self: center; font-size: 1.7rem; color: #7a1320; text-shadow: 0 0 8px rgba(122,19,32,0.6); }
.die3d.mystery .face[b-jldlkfrwkd] { background: linear-gradient(135deg, #2a1016 0%, #160810 70%, #0c0408 100%); box-shadow: inset 0 0 12px rgba(122,19,32,0.5); }

/* combined ZSS total on the game-over screen */
.over-zss[b-jldlkfrwkd] { margin-bottom: 0.9rem; font-size: 0.85rem; color: #c9b8ff; letter-spacing: 0.04em; }
.over-zss b[b-jldlkfrwkd] { font-family: 'Cinzel', serif; color: #e8ddff; }

/* ---- score cards in the left ledger (reflow to top on mobile) ---- */
.scores[b-jldlkfrwkd] { display: grid; gap: 0.5rem; margin-bottom: 0.5rem; }
.score-card[b-jldlkfrwkd] {
    display: flex; align-items: center; justify-content: space-between; gap: 0.6rem;
    box-sizing: border-box; text-align: left; font: inherit;
    padding: 0.45rem 0.7rem; border-radius: 9px;
    background: rgba(20,8,12,0.5); border: 1px solid rgba(122,19,32,0.45); color: #b9a487;
}
.score-card.zss[b-jldlkfrwkd] { cursor: pointer; background: rgba(139,92,246,0.12); border-color: rgba(167,139,250,0.45); }
.score-card.zss:hover[b-jldlkfrwkd] { background: rgba(139,92,246,0.22); }
.sc-k[b-jldlkfrwkd] { font-size: 0.9rem; }
.sc-v[b-jldlkfrwkd] { font-family: 'Cinzel', serif; font-weight: 800; font-size: 1.05rem; color: #f0e2c8; }
.score-card.zss .sc-v[b-jldlkfrwkd] { color: #c9b8ff; }

/* ---- ZSS popup ---- */
.zsc[b-jldlkfrwkd] { width: 100%; max-width: 320px; text-align: center; background: #14040a; border: 1px solid rgba(167,139,250,0.5); border-radius: 16px; padding: 1.3rem; box-shadow: 0 0 50px rgba(139,92,246,0.4); }
.zsc h3[b-jldlkfrwkd] { margin: 0 0 0.3rem; color: #f0e2c8; font-family: 'Cinzel'; }
.zsc-big[b-jldlkfrwkd] { margin: 0.2rem 0 0.6rem; font-family: 'Cinzel', serif; font-size: 2.6rem; font-weight: 900; color: #c9b8ff; text-shadow: 0 0 22px rgba(167,139,250,0.5); }
.zsc-note[b-jldlkfrwkd] { color: #b9a487; line-height: 1.6; font-size: 0.88rem; margin: 0 0 1rem; }

/* ---- temptation border meter (mobile only) ---- */
.tempt-frame[b-jldlkfrwkd] { display: none; }
.tf[b-jldlkfrwkd] { position: fixed; z-index: 60; pointer-events: none; --c: #6b7280; background: var(--c); box-shadow: 0 0 10px var(--c); }
.tempt-frame.warn .tf[b-jldlkfrwkd] { --c: #e6b35a; }
.tempt-frame.danger .tf[b-jldlkfrwkd] { --c: #ff4530; }
.tf.top[b-jldlkfrwkd] { top: 0; left: 0; height: 4px; }
.tf.right[b-jldlkfrwkd] { top: 0; right: 0; width: 4px; }
.tf.bottom[b-jldlkfrwkd] { bottom: 0; right: 0; height: 4px; }
.tf.left[b-jldlkfrwkd] { bottom: 0; left: 0; width: 4px; }
.tf-label[b-jldlkfrwkd] {
    position: fixed; top: 48px; left: 50%; transform: translateX(-50%); z-index: 61;
    font-family: 'Cinzel'; font-size: 0.7rem; font-weight: 800; letter-spacing: 0.1em;
    color: #ffd0a0; background: rgba(8,4,10,0.75); padding: 0.1rem 0.6rem; border-radius: 999px;
    pointer-events: none;
}
@media (max-width: 1080px) {
    .tempt-frame[b-jldlkfrwkd] { display: block; }
}
@media (min-width: 1081px) {
    .tf-label[b-jldlkfrwkd] { display: none; }
}

@media (max-width: 1080px) {
    .scores[b-jldlkfrwkd] { grid-auto-flow: column; justify-content: start; overflow-x: auto; }
    .score-card[b-jldlkfrwkd] { min-width: max-content; }
}

/* ---- difficulty picker on the lock screen ---- */
.diffs[b-jldlkfrwkd] { display: flex; gap: 0.4rem; width: 100%; justify-content: center; }
.diff[b-jldlkfrwkd] {
    flex: 1; max-width: 5.6rem;
    display: flex; flex-direction: column; align-items: center; gap: 0.1rem;
    padding: 0.5rem 0.3rem; cursor: pointer;
    background: rgba(20,8,12,0.7); border: 1px solid rgba(122,19,32,0.5);
    border-radius: 12px; color: #d8c8ad; transition: 0.15s;
}
.diff:hover:not(:disabled)[b-jldlkfrwkd] { border-color: #d2384a; }
.diff.on[b-jldlkfrwkd] { border-color: #e6c95a; background: rgba(230,201,90,0.12); box-shadow: 0 0 14px rgba(230,201,90,0.3); }
.diff.locked[b-jldlkfrwkd] { opacity: 0.5; cursor: not-allowed; }
.diff-ic[b-jldlkfrwkd] { font-size: 1.4rem; }
.diff-name[b-jldlkfrwkd] { font-family: 'Cinzel'; font-weight: 700; font-size: 0.8rem; color: #f0e2c8; }
.diff-mult[b-jldlkfrwkd] { font-size: 0.64rem; color: #a8916f; letter-spacing: 0.02em; }
.diff-lock[b-jldlkfrwkd] { font-size: 0.6rem; color: #8a7257; }

/* ---- lock-screen altar / heat / daily ---- */
.shard-bal[b-jldlkfrwkd] { color: #c9b8ff; font-weight: 800; }
.heat[b-jldlkfrwkd] { display: flex; align-items: center; justify-content: center; gap: 0.5rem; margin: 0.2rem 0; }
.heat-k[b-jldlkfrwkd] { font-family: 'Cinzel'; font-size: 0.8rem; color: #ff9a5c; letter-spacing: 0.08em; }
.heat-btn[b-jldlkfrwkd] { width: 1.6rem; height: 1.6rem; border: 1px solid rgba(122,19,32,0.6); border-radius: 8px; background: rgba(20,8,12,0.7); color: #e8d9c0; font-weight: 800; cursor: pointer; }
.heat-btn:disabled[b-jldlkfrwkd] { opacity: 0.35; cursor: default; }
.heat-v[b-jldlkfrwkd] { font-family: 'Cinzel'; font-weight: 900; color: #ff7a3c; min-width: 1rem; text-align: center; }
.altar[b-jldlkfrwkd] { display: grid; gap: 0.3rem; width: 100%; margin: 0.2rem 0 0.4rem; }
.altar-item[b-jldlkfrwkd] {
    display: flex; justify-content: space-between; align-items: center; gap: 0.5rem;
    padding: 0.4rem 0.7rem; border-radius: 9px; cursor: pointer; font-size: 0.78rem;
    background: rgba(20,8,12,0.6); border: 1px solid rgba(122,19,32,0.45); color: #d8c8ad;
}
.altar-item:hover:not(:disabled)[b-jldlkfrwkd] { border-color: #d2384a; }
.altar-item.owned[b-jldlkfrwkd] { border-color: #e6c95a; background: rgba(230,201,90,0.12); color: #f0e2c8; }
.altar-item.broke[b-jldlkfrwkd] { opacity: 0.45; cursor: not-allowed; }
.altar-cost[b-jldlkfrwkd] { color: #c9b8ff; font-weight: 800; white-space: nowrap; }
.daily[b-jldlkfrwkd] { margin-top: 0.5rem; padding: 0.45rem 1rem; border: 1px dashed rgba(167,139,250,0.6); border-radius: 10px; background: rgba(139,92,246,0.12); color: #c9b8ff; font-weight: 700; font-size: 0.85rem; cursor: pointer; }
.daily:hover[b-jldlkfrwkd] { background: rgba(139,92,246,0.24); }

/* ---- relic draft ---- */
.draft[b-jldlkfrwkd] { width: 100%; max-width: 440px; text-align: center; background: #14040a; border: 1px solid rgba(210,40,50,0.5); border-radius: 16px; padding: 1.3rem 1.1rem; box-shadow: 0 0 50px rgba(210,40,50,0.4); }
.draft h3[b-jldlkfrwkd] { margin: 0; color: #e6c95a; font-family: 'Cinzel'; }
.draft-sub[b-jldlkfrwkd] { margin: 0.2rem 0 1rem; color: #a8916f; font-style: italic; font-size: 0.85rem; }
.draft-cards[b-jldlkfrwkd] { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.5rem; }
.draft-card[b-jldlkfrwkd] { display: flex; flex-direction: column; align-items: center; gap: 0.25rem; padding: 0.8rem 0.4rem; border-radius: 12px; cursor: pointer; background: rgba(30,8,14,0.8); border: 1px solid rgba(122,19,32,0.6); color: #e8d9c0; transition: 0.13s; }
.draft-card:hover[b-jldlkfrwkd] { border-color: #e6c95a; transform: translateY(-3px); box-shadow: 0 6px 18px rgba(230,201,90,0.25); }
.dc-ic[b-jldlkfrwkd] { font-size: 1.8rem; }
.dc-name[b-jldlkfrwkd] { font-weight: 800; font-size: 0.82rem; color: #f0e2c8; }
.dc-desc[b-jldlkfrwkd] { font-size: 0.68rem; color: #a8916f; line-height: 1.35; }

/* ---- nightfall event ---- */
.event[b-jldlkfrwkd] { width: 100%; max-width: 360px; text-align: center; background: #14040a; border: 1px solid rgba(210,40,50,0.5); border-radius: 16px; padding: 1.5rem 1.2rem; box-shadow: 0 0 50px rgba(210,40,50,0.4); }
.ev-ic[b-jldlkfrwkd] { font-size: 3rem; }
.event h3[b-jldlkfrwkd] { margin: 0.2rem 0; color: #f0e2c8; font-family: 'UnifrakturMaguntia', serif; font-size: 1.8rem; }
.ev-desc[b-jldlkfrwkd] { color: #cbb596; font-style: italic; margin: 0 0 1rem; }
.ev-opt[b-jldlkfrwkd] { display: block; width: 100%; margin-bottom: 0.5rem; padding: 0.6rem; border-radius: 10px; border: 1px solid #d2384a; background: linear-gradient(180deg, #b3263a, #7a1320); color: #fff; font-weight: 700; cursor: pointer; }
.ev-opt.b[b-jldlkfrwkd] { background: transparent; color: #d8c8ad; border-color: rgba(122,19,32,0.6); }
.ev-opt:hover[b-jldlkfrwkd] { filter: brightness(1.1); }

/* ---- daily board on the over screen ---- */
.daily-board[b-jldlkfrwkd] { width: 100%; max-width: 220px; margin: 0 0 0.8rem; }
.db-h[b-jldlkfrwkd] { display: block; font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.14em; color: #c9b8ff; margin-bottom: 0.3rem; }
.db-row[b-jldlkfrwkd] { display: flex; justify-content: space-between; font-size: 0.8rem; color: #cbb596; padding: 0.12rem 0; }
.db-row b[b-jldlkfrwkd] { color: #f0e2c8; }

/* ---- confirm altar purchase ---- */
.confirm-buy[b-jldlkfrwkd] { width: 100%; max-width: 300px; text-align: center; background: #14040a; border: 1px solid rgba(167,139,250,0.5); border-radius: 16px; padding: 1.4rem 1.2rem; box-shadow: 0 0 50px rgba(139,92,246,0.4); }
.cb-ic[b-jldlkfrwkd] { font-size: 2.6rem; }
.confirm-buy h3[b-jldlkfrwkd] { margin: 0.2rem 0 0.4rem; color: #f0e2c8; font-family: 'Cinzel'; }
.cb-desc[b-jldlkfrwkd] { color: #cbb596; line-height: 1.5; margin: 0 0 0.4rem; }
.cb-desc b[b-jldlkfrwkd] { color: #c9b8ff; }
.cb-bal[b-jldlkfrwkd] { font-size: 0.78rem; color: #a8916f; margin-bottom: 1rem; }
.cb-btns[b-jldlkfrwkd] { display: flex; gap: 0.5rem; }
.cb-yes[b-jldlkfrwkd] { flex: 1; padding: 0.55rem; border: none; border-radius: 10px; background: linear-gradient(180deg, #a78bfa, #7c3aed); color: #fff; font-weight: 800; cursor: pointer; }
.cb-no[b-jldlkfrwkd] { flex: 1; padding: 0.55rem; border: 1px solid rgba(122,19,32,0.6); border-radius: 10px; background: transparent; color: #a8916f; cursor: pointer; }

/* game-over button row */
.over-btns[b-jldlkfrwkd] { display: flex; gap: 0.5rem; }
.begin.ghost[b-jldlkfrwkd] { background: transparent; color: #d8c8ad; box-shadow: none; }
.begin.ghost:hover[b-jldlkfrwkd] { background: rgba(122,19,32,0.3); box-shadow: none; }

/* lock-screen secondary links row */
.lock-links[b-jldlkfrwkd] { display: flex; gap: 0.5rem; margin-top: 0.5rem; }
.lock-links .daily[b-jldlkfrwkd] { margin-top: 0; text-decoration: none; display: inline-block; }

/* ---- sin card collection on the lock screen ---- */
.cards[b-jldlkfrwkd] { width: 100%; }
.cards-h[b-jldlkfrwkd] { display: block; font-size: 0.72rem; color: #a8916f; letter-spacing: 0.04em; margin-bottom: 0.35rem; text-align: center; }
.card-row[b-jldlkfrwkd] { display: flex; gap: 0.4rem; flex-wrap: wrap; justify-content: center; }
.scard[b-jldlkfrwkd] {
    display: flex; flex-direction: column; align-items: center; gap: 0.1rem;
    width: 3rem; padding: 0.4rem 0.2rem; border-radius: 10px; cursor: pointer;
    background: linear-gradient(160deg, rgba(20,8,12,0.9), rgba(8,4,10,0.9));
    border: 1px solid rgba(122,19,32,0.5); color: #e8d9c0;
}
.scard.on[b-jldlkfrwkd] { border-color: #e6c95a; box-shadow: 0 0 14px rgba(230,201,90,0.4); }
.scard-ic[b-jldlkfrwkd] { width: 30px; height: 30px; display: grid; place-items: center; border-radius: 8px; font-size: 1.05rem; background: linear-gradient(150deg, var(--g1), var(--g2)); }
.scard-lv[b-jldlkfrwkd] { font-size: 0.6rem; font-weight: 800; color: #c9b8ff; }
.cast-btn:disabled[b-jldlkfrwkd] { opacity: 0.4; cursor: default; }

/* ---- cast the lots overlay ---- */
.cast-ov[b-jldlkfrwkd] { position: fixed; inset: 0; z-index: 200; background: radial-gradient(ellipse at 50% 45%, rgba(60,8,18,0.97), rgba(5,2,10,0.99) 75%); display: grid; place-items: center; padding: 1rem; animation: arenaIn-b-jldlkfrwkd 0.3s ease; }
.cast-inner[b-jldlkfrwkd] { text-align: center; max-width: 420px; width: 100%; }
.cast-title[b-jldlkfrwkd] { font-family: 'UnifrakturMaguntia', serif; font-size: 2rem; color: #d2384a; text-shadow: 0 0 20px rgba(210,40,50,0.7); margin: 0 0 0.8rem; }
.cast-prizes[b-jldlkfrwkd] { display: flex; gap: 0.5rem; justify-content: center; margin-bottom: 1.2rem; }
.cprize[b-jldlkfrwkd] { flex: 1; max-width: 7rem; padding: 0.5rem 0.3rem; border-radius: 10px; background: rgba(20,8,12,0.6); border: 1px solid rgba(122,19,32,0.45); display: flex; flex-direction: column; gap: 0.15rem; }
.cprize b[b-jldlkfrwkd] { font-family: 'Cinzel'; font-size: 0.9rem; }
.cprize span[b-jldlkfrwkd] { font-size: 0.68rem; color: #a8916f; }
.cprize.wrath[b-jldlkfrwkd] { border-color: rgba(214,69,43,0.6); } .cprize.wrath b[b-jldlkfrwkd] { color: #ff6a3c; }
.cprize.pair b[b-jldlkfrwkd] { color: #e6c95a; }
.cprize.pts b[b-jldlkfrwkd] { color: #c9b8ff; }

.cast-dice[b-jldlkfrwkd] { perspective: 1000px; perspective-origin: 50% 45%; height: 130px; display: grid; place-items: center; margin-bottom: 0.8rem; }
.cast-stage[b-jldlkfrwkd] { position: relative; width: 1px; height: 1px; transform-style: preserve-3d; }
.cast-dice.rolling[b-jldlkfrwkd] { animation: castShake-b-jldlkfrwkd 0.18s linear infinite; }
@keyframes castShake-b-jldlkfrwkd { 0%,100% { transform: translateX(0); } 25% { transform: translateX(-3px); } 75% { transform: translateX(3px); } }

.cast-sub[b-jldlkfrwkd] { color: #a8916f; font-style: italic; margin: 0 0 0.8rem; }
.cast-sub.fate[b-jldlkfrwkd] { color: #e6c95a; font-family: 'UnifrakturMaguntia', serif; font-size: 1.3rem; animation: breathe-b-jldlkfrwkd 1.2s ease-in-out infinite; }
.cast-btns[b-jldlkfrwkd] { display: flex; gap: 0.5rem; justify-content: center; }
.cast-btns .cb-yes[b-jldlkfrwkd] { padding: 0.55rem 1.4rem; border: none; border-radius: 10px; background: linear-gradient(180deg, #b3263a, #7a1320); color: #fff; font-weight: 800; cursor: pointer; }
.cast-btns .cb-yes:disabled[b-jldlkfrwkd] { opacity: 0.4; cursor: default; }
.cast-btns .cb-no[b-jldlkfrwkd] { padding: 0.55rem 1.2rem; border: 1px solid rgba(122,19,32,0.6); border-radius: 10px; background: transparent; color: #a8916f; cursor: pointer; }

.cast-result[b-jldlkfrwkd] { margin-bottom: 1rem; animation: castReveal-b-jldlkfrwkd 0.6s cubic-bezier(.2,.9,.3,1); }
.cr-icon[b-jldlkfrwkd] { font-size: 3.2rem; }
.cr-text[b-jldlkfrwkd] { font-family: 'Cinzel'; font-weight: 800; font-size: 1.2rem; color: #f0e2c8; }
.cast-result.jackpot .cr-text[b-jldlkfrwkd] { color: #ff6a3c; text-shadow: 0 0 18px rgba(255,106,60,0.8); }
.cast-result.jackpot[b-jldlkfrwkd] { animation: jackpot-b-jldlkfrwkd 0.7s ease-in-out 2; }
.cast-result.card .cr-text[b-jldlkfrwkd] { color: #e6c95a; text-shadow: 0 0 14px rgba(230,201,90,0.6); }
.cast-result.pts .cr-text[b-jldlkfrwkd] { color: #c9b8ff; }
@keyframes castReveal-b-jldlkfrwkd { from { opacity: 0; transform: scale(0.6); } to { opacity: 1; transform: scale(1); } }
@keyframes jackpot-b-jldlkfrwkd { 0%,100% { transform: scale(1); } 50% { transform: scale(1.12); } }

/* ---- game-mode buttons: stacked wide, utilities in a row ---- */
.daily-wide[b-jldlkfrwkd] { width: 100%; box-sizing: border-box; margin-top: 0.5rem;
    background: linear-gradient(180deg, #4a3a7a, #2a1f52); border-color: rgba(167,139,250,0.6); box-shadow: 0 0 18px rgba(139,92,246,0.35); }
.daily-wide:hover[b-jldlkfrwkd] { box-shadow: 0 0 26px rgba(139,92,246,0.6); }
.lock-links[b-jldlkfrwkd] { display: flex; gap: 0.5rem; margin-top: 0.6rem; justify-content: center; flex-wrap: wrap; }
.lock-links .daily[b-jldlkfrwkd] { margin-top: 0; text-decoration: none; display: inline-block; }

/* ---- collection viewer ---- */
.coll[b-jldlkfrwkd] { width: 100%; max-width: 420px; text-align: center; background: #14040a; border: 1px solid rgba(122,19,32,0.7); border-radius: 16px; padding: 1.2rem; box-shadow: 0 0 50px rgba(210,40,50,0.4); }
.coll h3[b-jldlkfrwkd] { margin: 0 0 0.2rem; color: #f0e2c8; font-family: 'Cinzel'; }
.coll-sub[b-jldlkfrwkd] { color: #a8916f; font-size: 0.82rem; margin: 0 0 1rem; }
.coll-grid[b-jldlkfrwkd] { display: grid; grid-template-columns: repeat(auto-fit, minmax(92px, 1fr)); gap: 0.5rem; margin-bottom: 1rem; }
.ccard[b-jldlkfrwkd] { display: flex; flex-direction: column; align-items: center; gap: 0.15rem; padding: 0.7rem 0.4rem; border-radius: 12px; background: rgba(20,8,12,0.6); border: 1px solid rgba(122,19,32,0.4); }
.ccard.locked[b-jldlkfrwkd] { opacity: 0.5; }
.ccard.owned[b-jldlkfrwkd] { border-color: rgba(230,201,90,0.45); }
.ccard.rare.owned[b-jldlkfrwkd] { border-color: rgba(255,106,60,0.6); box-shadow: 0 0 12px rgba(255,106,60,0.3); }
.cc-ic[b-jldlkfrwkd] { width: 40px; height: 40px; display: grid; place-items: center; font-size: 1.4rem; border-radius: 11px; background: linear-gradient(150deg, var(--g1), var(--g2)); }
.ccard.locked .cc-ic[b-jldlkfrwkd] { background: rgba(40,30,40,0.6); }
.cc-name[b-jldlkfrwkd] { font-weight: 700; font-size: 0.82rem; color: #f0e2c8; }
.cc-lv[b-jldlkfrwkd] { font-size: 0.7rem; font-weight: 800; color: #e6c95a; }
.cc-eff[b-jldlkfrwkd] { font-size: 0.62rem; color: #a8916f; }

/* ---- the market (shop modal) ---- */
.shop[b-jldlkfrwkd] { width: 100%; max-width: 380px; text-align: center; background: #14040a; border: 1px solid rgba(122,19,32,0.7); border-radius: 16px; padding: 1.3rem 1.2rem; box-shadow: 0 0 50px rgba(210,40,50,0.4); }
.shop h3[b-jldlkfrwkd] { margin: 0 0 0.15rem; color: #f0e2c8; font-family: 'Cinzel'; }
.shop-bal[b-jldlkfrwkd] { color: #e6c95a; font-size: 0.82rem; margin: 0 0 1rem; font-weight: 700; }
.shop-sec[b-jldlkfrwkd] { display: block; text-align: left; color: #d2384a; font-weight: 800; font-size: 0.82rem; letter-spacing: 0.04em; margin: 0.9rem 0 0.5rem; }
.shop-sec em[b-jldlkfrwkd] { color: #8a7257; font-weight: 400; font-style: italic; }
.shop .altar[b-jldlkfrwkd] { margin: 0; }
.shop-cast[b-jldlkfrwkd] { width: 100%; box-sizing: border-box; padding: 0.7rem; border-radius: 11px; cursor: pointer; font-weight: 800; font-family: 'Cinzel'; color: #1a0408; background: linear-gradient(180deg, #e6c95a, #b8902e); border: 1px solid rgba(230,201,90,0.7); box-shadow: 0 0 16px rgba(230,201,90,0.35); }
.shop-cast:hover:not(:disabled)[b-jldlkfrwkd] { box-shadow: 0 0 26px rgba(230,201,90,0.6); }
.shop-cast:disabled[b-jldlkfrwkd] { opacity: 0.4; cursor: default; filter: grayscale(0.6); }
.shop-hint[b-jldlkfrwkd] { color: #8a7257; font-size: 0.68rem; margin: 0.5rem 0 1rem; line-height: 1.4; }

/* ---- lock-screen extras ---- */
.offer-note[b-jldlkfrwkd] { color: #e6c95a; font-size: 0.74rem; margin: 0.6rem 0 0; text-align: center; }
.daily-wide.locked[b-jldlkfrwkd] { background: linear-gradient(180deg, #2a2230, #1a1622); border-color: rgba(120,100,140,0.4); box-shadow: none; opacity: 0.7; cursor: default; color: #9a8caf; }
.shop-btn[b-jldlkfrwkd] { color: #e6c95a !important; border-color: rgba(230,201,90,0.4) !important; }

/* ---- daily win reward banner ---- */
.over-reward[b-jldlkfrwkd] { margin: 0.6rem auto 0; max-width: 280px; padding: 0.45rem 0.7rem; border-radius: 9px; font-size: 0.78rem; color: #e6c95a; background: rgba(230,201,90,0.1); border: 1px solid rgba(230,201,90,0.35); }
.over-reward b[b-jldlkfrwkd] { color: #f0e2c8; }

.daily-wide .dw-sub[b-jldlkfrwkd] { display: block; font-family: 'Inter', sans-serif; font-weight: 500; font-size: 0.62rem; letter-spacing: 0.02em; opacity: 0.8; margin-top: 0.15rem; text-transform: none; }
/* /Pages/Stats.razor.rz.scp.css */
/* /Pages/StatsView.razor.rz.scp.css */
.stats[b-8jbbior0y9] {
    min-height: calc(100vh - 43px);
    background: radial-gradient(ellipse at 50% -10%, #2a0810 0%, #0c0408 55%, #05030a 100%);
    color: #e8d9c0; font-family: 'Cinzel', Georgia, serif;
    padding: 2.2rem 1.25rem 4rem;
}
.stats-inner[b-8jbbior0y9] { max-width: 720px; margin: 0 auto; }
.stats h1[b-8jbbior0y9] { font-family: 'UnifrakturMaguntia', serif; font-size: clamp(2rem, 7vw, 3rem); margin: 0; color: #d2384a; text-shadow: 0 0 24px rgba(210,40,50,0.6); text-align: center; }
.st-sub[b-8jbbior0y9] { text-align: center; color: #a8916f; font-style: italic; margin: 0.2rem 0 1.8rem; }
.st-h[b-8jbbior0y9] { color: #e6c95a; font-size: 1.2rem; margin: 1.8rem 0 0.7rem; border-left: 3px solid #7a1320; padding-left: 0.6rem; }

.st-grid[b-8jbbior0y9] { display: grid; grid-template-columns: repeat(auto-fit, minmax(110px, 1fr)); gap: 0.6rem; }
.st-card[b-8jbbior0y9] {
    display: flex; flex-direction: column; align-items: center; gap: 0.15rem;
    padding: 0.9rem 0.5rem; border-radius: 12px;
    background: rgba(20,8,12,0.6); border: 1px solid rgba(122,19,32,0.45);
}
.st-card.hl[b-8jbbior0y9] { border-color: rgba(230,201,90,0.5); background: rgba(230,201,90,0.08); }
.st-v[b-8jbbior0y9] { font-family: 'Cinzel'; font-weight: 900; font-size: 1.5rem; color: #f0e2c8; }
.st-card.hl .st-v[b-8jbbior0y9] { color: #e6c95a; }
.st-k[b-8jbbior0y9] { font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.08em; color: #8a7257; text-align: center; }

.st-rows[b-8jbbior0y9] { display: grid; gap: 0.4rem; }
.st-row[b-8jbbior0y9] { display: flex; justify-content: space-between; align-items: center; padding: 0.5rem 0.8rem; border-radius: 9px; background: rgba(20,8,12,0.5); border: 1px solid rgba(122,19,32,0.4); color: #b9a487; font-size: 0.92rem; }
.st-row b[b-8jbbior0y9] { color: #f0e2c8; }

.st-bars[b-8jbbior0y9] { display: grid; gap: 0.4rem; }
.st-bar[b-8jbbior0y9] { display: flex; align-items: center; gap: 0.6rem; }
.sb-ic[b-8jbbior0y9] { width: 30px; height: 30px; flex: 0 0 auto; display: grid; place-items: center; border-radius: 8px; font-size: 1.05rem; background: linear-gradient(150deg, var(--g1), var(--g2)); box-shadow: inset 0 0 6px rgba(0,0,0,0.5); }
.sb-name[b-8jbbior0y9] { width: 84px; flex: 0 0 auto; font-size: 0.85rem; color: #d8c8ad; }
.sb-track[b-8jbbior0y9] { flex: 1; height: 12px; border-radius: 999px; background: rgba(0,0,0,0.5); border: 1px solid rgba(122,19,32,0.4); overflow: hidden; }
.sb-fill[b-8jbbior0y9] { display: block; height: 100%; transition: width 0.5s ease; }
.sb-fill.death[b-8jbbior0y9] { background: linear-gradient(90deg, #4a0a14, #d2452b); }
.sb-n[b-8jbbior0y9] { width: 2rem; text-align: right; font-family: 'Cinzel'; font-weight: 700; color: #d2384a; }

.st-back[b-8jbbior0y9] { display: inline-block; margin-top: 1.6rem; color: #d2384a; text-decoration: none; font-weight: 700; }
.st-back:hover[b-8jbbior0y9] { color: #f0e2c8; text-shadow: 0 0 10px rgba(210,40,50,0.6); }
/* /Pages/Visit.razor.rz.scp.css */
.visit[b-b8p7rmuui0] {
    min-height: calc(100vh - 43px);
    background: radial-gradient(ellipse at 50% -10%, #2a0810 0%, #0c0408 55%, #05030a 100%);
    color: #e8d9c0; font-family: 'Cinzel', Georgia, serif;
    padding: 2.4rem 1rem 4rem;
}
.v-msg[b-b8p7rmuui0] { text-align: center; color: #a8916f; font-weight: 700; font-style: italic; }
.v-card[b-b8p7rmuui0] {
    max-width: 460px; margin: 0 auto; text-align: center;
    background: #14040a;
    border: 1px solid rgba(122,19,32,0.7);
    border-radius: 18px;
    padding: 1.8rem 1.4rem;
    box-shadow: 0 0 50px rgba(210,40,50,0.35);
}
.v-emoji[b-b8p7rmuui0] { font-size: 3rem; }
.v-card h1[b-b8p7rmuui0] { margin: 0.4rem 0 0.8rem; font-family: 'UnifrakturMaguntia', serif; font-size: 1.8rem; color: #d2384a; text-shadow: 0 0 20px rgba(210,40,50,0.5); }
.v-btn[b-b8p7rmuui0] {
    display: inline-block;
    padding: 0.55rem 1.1rem;
    border: 1px solid rgba(122,19,32,0.7);
    border-radius: 999px;
    background: linear-gradient(180deg, #7a1320, #4a0a14);
    color: #f0e2c8; font-weight: 700; font-size: 0.86rem; font-family: 'Cinzel';
    text-decoration: none;
    box-shadow: 0 0 14px rgba(210,40,50,0.25);
}
.v-btn:hover[b-b8p7rmuui0] { box-shadow: 0 0 22px rgba(210,40,50,0.5); }
