/* /Layout/MainLayout.razor.rz.scp.css */
/* Centered "frame" on desktop, edge-to-edge on phones. Hard black border, no shadow. */
.app-shell[b-ig77nwm32i] {
    min-height: 100vh;
    max-width: var(--shell);
    margin: 0 auto;
    position: relative;
    background: var(--paper);
}

@media (min-width: 560px) {
    .app-shell[b-ig77nwm32i] {
        border-left: 3px solid var(--ink);
        border-right: 3px solid var(--ink);
    }
}
/* /Layout/NavMenu.razor.rz.scp.css */
.navbar-toggler[b-xbcyjk6xeo] {
    background-color: rgba(255, 255, 255, 0.1);
}

.top-row[b-xbcyjk6xeo] {
    height: 3.5rem;
    background-color: rgba(0,0,0,0.4);
}

.navbar-brand[b-xbcyjk6xeo] {
    font-size: 1.1rem;
}

.bi[b-xbcyjk6xeo] {
    display: inline-block;
    position: relative;
    width: 1.25rem;
    height: 1.25rem;
    margin-right: 0.75rem;
    top: -1px;
    background-size: cover;
}

.bi-house-door-fill-nav-menu[b-xbcyjk6xeo] {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-house-door-fill' viewBox='0 0 16 16'%3E%3Cpath d='M6.5 14.5v-3.505c0-.245.25-.495.5-.495h2c.25 0 .5.25.5.5v3.5a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5v-7a.5.5 0 0 0-.146-.354L13 5.793V2.5a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5v1.293L8.354 1.146a.5.5 0 0 0-.708 0l-6 6A.5.5 0 0 0 1.5 7.5v7a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5Z'/%3E%3C/svg%3E");
}

.bi-plus-square-fill-nav-menu[b-xbcyjk6xeo] {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-plus-square-fill' viewBox='0 0 16 16'%3E%3Cpath d='M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm6.5 4.5v3h3a.5.5 0 0 1 0 1h-3v3a.5.5 0 0 1-1 0v-3h-3a.5.5 0 0 1 0-1h3v-3a.5.5 0 0 1 1 0z'/%3E%3C/svg%3E");
}

.bi-list-nested-nav-menu[b-xbcyjk6xeo] {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-list-nested' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M4.5 11.5A.5.5 0 0 1 5 11h10a.5.5 0 0 1 0 1H5a.5.5 0 0 1-.5-.5zm-2-4A.5.5 0 0 1 3 7h10a.5.5 0 0 1 0 1H3a.5.5 0 0 1-.5-.5zm-2-4A.5.5 0 0 1 1 3h10a.5.5 0 0 1 0 1H1a.5.5 0 0 1-.5-.5z'/%3E%3C/svg%3E");
}

.nav-item[b-xbcyjk6xeo] {
    font-size: 0.9rem;
    padding-bottom: 0.5rem;
}

    .nav-item:first-of-type[b-xbcyjk6xeo] {
        padding-top: 1rem;
    }

    .nav-item:last-of-type[b-xbcyjk6xeo] {
        padding-bottom: 1rem;
    }

    .nav-item[b-xbcyjk6xeo]  a {
        color: #d7d7d7;
        border-radius: 4px;
        height: 3rem;
        display: flex;
        align-items: center;
        line-height: 3rem;
    }

.nav-item[b-xbcyjk6xeo]  a.active {
    background-color: rgba(255,255,255,0.37);
    color: white;
}

.nav-item[b-xbcyjk6xeo]  a:hover {
    background-color: rgba(255,255,255,0.1);
    color: white;
}

@media (min-width: 641px) {
    .navbar-toggler[b-xbcyjk6xeo] {
        display: none;
    }

    .collapse[b-xbcyjk6xeo] {
        /* Never collapse the sidebar for wide screens */
        display: block;
    }
    
    .nav-scrollable[b-xbcyjk6xeo] {
        /* Allow sidebar to scroll for tall menus */
        height: calc(100vh - 3.5rem);
        overflow-y: auto;
    }
}
/* /Pages/Home.razor.rz.scp.css */
/* ============================================================
   MINIMALIST BRUTALIST. White paper, ink borders, monospace,
   UPPERCASE, hard offset shadows, active = inverted. No radii.
   Layout structure is unchanged from the original.
   ============================================================ */

/* ---- Masthead (the newspaper nameplate) ---- */
.masthead[b-h6ap1zw5h5] {
    background: var(--paper);
    padding: 0.5rem 0.9rem 0;
    text-align: center;
}
.masthead-top[b-h6ap1zw5h5] {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    font-size: 0.6rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--dim);
    padding-bottom: 0.4rem;
}
.masthead-title[b-h6ap1zw5h5] {
    font-weight: 700;
    font-size: 2rem;
    line-height: 1.05;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    padding: 0.5rem 0 0.55rem;
    border-top: 4px double var(--ink);
    border-bottom: 4px double var(--ink);
}
.dateline[b-h6ap1zw5h5] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.62rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 0.45rem 0.1rem 0.55rem;
}
.dateline .coins[b-h6ap1zw5h5] {
    font-variant-numeric: tabular-nums;
    font-weight: 700;
    border: 2px solid var(--ink);
    padding: 0.1rem 0.5rem;
    letter-spacing: 0.04em;
}

/* ---- Action banner: the pinned front-page bulletin ---- */
.action-banner[b-h6ap1zw5h5] {
    position: sticky;
    top: 0;
    z-index: 9;
    background: var(--paper);
    padding: 0.55rem 0.9rem 0.75rem;
    border-top: 2px solid var(--ink);
    border-bottom: 2px solid var(--ink);
}
.banner-kicker[b-h6ap1zw5h5] {
    font-size: 0.58rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ink);
    margin-bottom: 0.4rem;
}
/* Newspaper byline under the bulletin: small italic dateline, set off by a hairline. */
.byline[b-h6ap1zw5h5] {
    margin-top: 0.5rem;
    padding-top: 0.4rem;
    border-top: 1px solid var(--ink);
    font-size: 0.6rem;
    font-style: italic;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--dim);
}
.banner-line[b-h6ap1zw5h5] { font-size: 0.85rem; margin-bottom: 0.4rem; display: flex; align-items: center; gap: 0.4rem; text-transform: uppercase; letter-spacing: 0.03em; }

/* Combat HP/swing rows: label · bar · numeric, so the fight reads at a glance. */
.hprow[b-h6ap1zw5h5] { display: flex; align-items: center; gap: 0.5rem; margin: 0.25rem 0; }
.hprow .bar[b-h6ap1zw5h5] { flex: 1; margin: 0; }
.hplabel[b-h6ap1zw5h5] { font-size: 0.6rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; width: 3.2rem; }
.hpnum[b-h6ap1zw5h5] { font-size: 0.72rem; font-weight: 700; font-variant-numeric: tabular-nums; width: 3.6rem; text-align: right; }

/* Live combat feed (newspaper "dispatch wire"): newest blow first. */
.feed[b-h6ap1zw5h5] { display: flex; flex-direction: column; gap: 1px; margin-top: 0.45rem; padding-top: 0.4rem; border-top: 1px solid var(--ink); }
.feed span[b-h6ap1zw5h5] { font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.04em; }
.feed .ev-miss[b-h6ap1zw5h5] { color: var(--dim); }
.feed .ev-dmg[b-h6ap1zw5h5]  { color: var(--red); }
.feed .ev-kill[b-h6ap1zw5h5] { font-weight: 700; }
.feed .ev-eat[b-h6ap1zw5h5]  { font-style: italic; }
.banner-line b[b-h6ap1zw5h5] { font-weight: 700; }
.banner-sub[b-h6ap1zw5h5] { font-size: 0.72rem; color: var(--dim); margin-top: 0.35rem; text-transform: uppercase; letter-spacing: 0.04em; }
.banner-line.muted[b-h6ap1zw5h5] { color: var(--dim); }

/* ---- Content column ---- */
.content[b-h6ap1zw5h5] {
    padding: 0.9rem 0.85rem 6rem;
}
/* Section front: a small kicker label over a big headline, bracketed by rules. */
.content h2[b-h6ap1zw5h5] {
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin: 0.1rem 0 0.85rem;
    padding-bottom: 0.3rem;
    border-top: 2px solid var(--ink);
    border-bottom: 4px solid var(--ink);
    position: relative;
}
.content h2[b-h6ap1zw5h5]::before {
    content: attr(data-kicker);
    display: block;
    font-size: 0.6rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    color: var(--dim);
    padding: 0.3rem 0 0.35rem;
    margin-bottom: 0.3rem;
    border-bottom: 1px solid var(--ink);
}

/* ---- Panels (cards): flat, hard border ---- */
.card[b-h6ap1zw5h5] {
    background: var(--paper);
    border: 2px solid var(--ink);
    padding: 0.8rem;
    margin-bottom: 0.8rem;
}

/* ---- Progress bars: bordered box, solid ink fill ---- */
.bar[b-h6ap1zw5h5] {
    background: var(--paper);
    border: 2px solid var(--ink);
    height: 16px;
    overflow: hidden;
    margin: 0.45rem 0;
}
.bar.small[b-h6ap1zw5h5] { height: 12px; margin: 0.3rem 0; }
.fill[b-h6ap1zw5h5] {
    height: 100%;
    background: var(--ink);
    transition: width 0.12s linear;
}
.fill.snap[b-h6ap1zw5h5] { transition: none; } /* instant empty on cycle completion (no backward animation) */
.fill.xp[b-h6ap1zw5h5] { background: var(--ink); }
.fill.hp[b-h6ap1zw5h5] { background: var(--ink); }
/* Enemy bar uses a hatch so player vs enemy read apart with zero color. */
.fill.enemy[b-h6ap1zw5h5] {
    background: repeating-linear-gradient(45deg, var(--ink) 0 5px, var(--paper) 5px 10px);
}

/* ---- Skills as a single ruled "listings" ledger (newspaper box-score feel) ---- */
.ledger[b-h6ap1zw5h5] { border: 2px solid var(--ink); margin-bottom: 0.85rem; background: var(--paper); }
.ledger .skill-card[b-h6ap1zw5h5] {
    border: 0;
    border-bottom: 1px solid var(--ink);  /* hairline divider between listings */
    margin: 0;
    padding: 0.65rem 0.75rem;
}
.ledger .skill-card:last-child[b-h6ap1zw5h5] { border-bottom: 0; }

/* Broadsheet: skills flow into two ruled columns on wide screens. */
@media (min-width: 760px) {
    .ledger[b-h6ap1zw5h5] { display: grid; grid-template-columns: 1fr 1fr; }
    .ledger .skill-card[b-h6ap1zw5h5] { border-bottom: 1px solid var(--ink); }
    .ledger .skill-card:nth-child(odd)[b-h6ap1zw5h5] { border-right: 1px solid var(--ink); }
    .ledger .skill-card:last-child[b-h6ap1zw5h5] { border-bottom: 1px solid var(--ink); }
}

/* ---- Skill cards ---- */
.skill-head[b-h6ap1zw5h5] { display: flex; justify-content: space-between; align-items: center; cursor: pointer; }
.skill-name[b-h6ap1zw5h5] { font-weight: 700; text-transform: uppercase; letter-spacing: 0.03em; font-size: 0.95rem; }
.skill-lvl[b-h6ap1zw5h5] {
    font-weight: 700;
    font-size: 0.8rem;
    background: var(--ink);
    color: var(--paper);
    padding: 0.12rem 0.5rem;
    letter-spacing: 0.05em;
}

.activities[b-h6ap1zw5h5] { margin-top: 0.6rem; display: flex; flex-direction: column; gap: 0.5rem; }
.act[b-h6ap1zw5h5] {
    display: flex; justify-content: space-between; align-items: center;
    border: 2px solid var(--ink); color: var(--ink);
    background: var(--paper);
    padding: 0.6rem 0.7rem; font-size: 0.9rem; cursor: pointer; width: 100%;
    text-transform: uppercase; letter-spacing: 0.02em;
    box-shadow: 3px 3px 0 var(--ink);
    transition: transform 0.04s, box-shadow 0.04s;
    font-family: inherit;
}
.act:active[b-h6ap1zw5h5] { transform: translate(3px, 3px); box-shadow: 0 0 0 var(--ink); }
.act .meta[b-h6ap1zw5h5] { color: var(--dim); font-size: 0.78rem; text-transform: none; }
.act.running[b-h6ap1zw5h5] { background: var(--ink); color: var(--paper); box-shadow: 3px 3px 0 var(--dim); }
.act.running .meta[b-h6ap1zw5h5] { color: #cfcfcf; }
.act.locked[b-h6ap1zw5h5] { opacity: 1; color: var(--dim); border-color: var(--dim); cursor: not-allowed; box-shadow: none; }
.act.locked .meta[b-h6ap1zw5h5] { color: var(--dim); }

/* ---- Combat ---- */
.stat-grid[b-h6ap1zw5h5] { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 0; border: 2px solid var(--ink); }
.stat-grid > div[b-h6ap1zw5h5] {
    display: flex; flex-direction: column; gap: 2px;
    padding: 0.5rem 0.55rem;
    border-right: 2px solid var(--ink);
    border-bottom: 2px solid var(--ink);
}
.stat-grid > div:nth-child(3n)[b-h6ap1zw5h5] { border-right: none; }
.stat-grid > div:nth-child(n+4)[b-h6ap1zw5h5] { border-bottom: none; } /* last row (assumes 6 cells) */
.stat-grid .muted[b-h6ap1zw5h5] { font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--dim); }
.stat-grid b[b-h6ap1zw5h5] { font-size: 1.1rem; font-weight: 700; }

.row-label[b-h6ap1zw5h5] { font-size: 0.68rem; color: var(--ink); margin: 0.6rem 0 0.4rem; text-transform: uppercase; letter-spacing: 0.08em; font-weight: 700; }
.chips[b-h6ap1zw5h5] { display: flex; flex-wrap: wrap; gap: 0.45rem; }
.chip[b-h6ap1zw5h5] {
    border: 2px solid var(--ink); color: var(--ink);
    background: var(--paper);
    padding: 0.35rem 0.7rem; font-size: 0.8rem; cursor: pointer;
    text-transform: uppercase; letter-spacing: 0.03em; font-family: inherit; font-weight: 700;
}
.chip.active[b-h6ap1zw5h5] { background: var(--ink); color: var(--paper); }

.monster-head[b-h6ap1zw5h5] { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.55rem; }
.monster-name[b-h6ap1zw5h5] { font-weight: 700; text-transform: uppercase; letter-spacing: 0.03em; }
.meta[b-h6ap1zw5h5] { color: var(--dim); font-size: 0.78rem; }

/* ---- Buttons ---- */
.btn[b-h6ap1zw5h5] {
    border: 2px solid var(--ink); color: var(--ink);
    background: var(--paper);
    padding: 0.6rem 0.85rem; font-size: 0.85rem; cursor: pointer;
    text-transform: uppercase; letter-spacing: 0.04em; font-weight: 700; font-family: inherit;
    box-shadow: 3px 3px 0 var(--ink);
    transition: transform 0.04s, box-shadow 0.04s;
}
.btn:active[b-h6ap1zw5h5] { transform: translate(3px, 3px); box-shadow: 0 0 0 var(--ink); }
.btn.full[b-h6ap1zw5h5] { width: 100%; margin-bottom: 0.5rem; text-align: left; display: flex; justify-content: space-between; align-items: center; }
.btn.active[b-h6ap1zw5h5] { background: var(--ink); color: var(--paper); }
.btn.danger[b-h6ap1zw5h5] { border-color: var(--red); color: var(--red); box-shadow: 3px 3px 0 var(--red); }
.btn.danger:active[b-h6ap1zw5h5] { box-shadow: 0 0 0 var(--red); }
.btn.reset[b-h6ap1zw5h5] { margin-top: 0.6rem; text-align: center; justify-content: center; }

/* ---- Bank ---- */
.bank-grid[b-h6ap1zw5h5] { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border: 2px solid var(--ink); }
.bank-item[b-h6ap1zw5h5] {
    display: flex; justify-content: space-between; align-items: center;
    padding: 0.55rem 0.6rem;
    border-right: 2px solid var(--ink);
    border-bottom: 2px solid var(--ink);
}
.bank-item:nth-child(2n)[b-h6ap1zw5h5] { border-right: none; }
.bank-name[b-h6ap1zw5h5] { font-size: 0.78rem; text-transform: uppercase; }
.bank-amt[b-h6ap1zw5h5] { font-weight: 700; font-variant-numeric: tabular-nums; }

.slot-row[b-h6ap1zw5h5] { display: flex; justify-content: space-between; padding: 0.5rem 0; border-bottom: 2px solid var(--ink); text-transform: uppercase; letter-spacing: 0.02em; font-size: 0.85rem; }
.slot-row:last-child[b-h6ap1zw5h5] { border-bottom: none; }
.muted[b-h6ap1zw5h5] { color: var(--dim); text-transform: uppercase; letter-spacing: 0.03em; font-size: 0.82rem; }

/* ---- Bottom tab bar ---- */
.tabbar[b-h6ap1zw5h5] {
    position: fixed;
    bottom: 0; left: 50%; transform: translateX(-50%);
    width: 100%; max-width: var(--shell);
    z-index: 20;
    display: flex;
    background: var(--paper);
    border-top: 3px solid var(--ink);
    padding-bottom: env(safe-area-inset-bottom);
}
.tab[b-h6ap1zw5h5] {
    flex: 1;
    display: flex; flex-direction: column; align-items: center; gap: 3px;
    background: var(--paper); border: none; cursor: pointer;
    padding: 0.5rem 0 0.6rem; font-size: 1.15rem; color: var(--ink);
    border-right: 2px solid var(--ink);
    font-family: inherit;
}
.tab:last-child[b-h6ap1zw5h5] { border-right: none; }
.tab span[b-h6ap1zw5h5] { font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.06em; font-weight: 700; }
.tab.active[b-h6ap1zw5h5] { background: var(--ink); color: var(--paper); }

/* Desaturate emoji glyphs so they fit the monochrome theme (applied only where icons live, so the
   red danger accent elsewhere is untouched). */
.masthead[b-h6ap1zw5h5], .dateline[b-h6ap1zw5h5], .banner-line[b-h6ap1zw5h5], .skill-name[b-h6ap1zw5h5], .monster-name[b-h6ap1zw5h5], .tab[b-h6ap1zw5h5], .act[b-h6ap1zw5h5], .chip[b-h6ap1zw5h5] {
    filter: grayscale(1);
}
