h1:focus {
    outline: none;
}

#blazor-error-ui {
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

/* --- Theme Park playtest GUI (functional placeholder styling) --- */
body { font-family: system-ui, sans-serif; margin: 0; background: #f4f5f7; color: #1d2330; }
main { max-width: 1100px; margin: 0 auto; padding: 1rem; }
.panel { background: #fff; border: 1px solid #dde1e7; border-radius: 8px; padding: 1rem 1.25rem; }
.topbar { display: flex; align-items: center; justify-content: space-between; }
h1 { font-size: 1.4rem; margin: 0.2rem 0 0.6rem; }
h2 { font-size: 1.05rem; margin: 0.2rem 0; }
.newgame { max-width: 360px; margin: 3rem auto; display: flex; flex-direction: column; gap: 0.75rem; }
.newgame label { display: flex; align-items: center; gap: 0.5rem; }
button { cursor: pointer; border: 1px solid #c2c8d2; background: #fff; border-radius: 6px; padding: 0.35rem 0.75rem; }
button.primary { background: #2f6fed; color: #fff; border-color: #2f6fed; font-weight: 600; }
.status { color: #44506a; }
.tag { background: #eef1f6; border-radius: 10px; padding: 0.05rem 0.5rem; margin-left: 0.35rem; font-size: 0.8rem; }
.tag.over { background: #ffe1e1; }
.player { border: 1px solid #e4e8ef; border-radius: 6px; padding: 0.6rem 0.8rem; margin-top: 0.6rem; }
.player.active { border-color: #2f6fed; box-shadow: 0 0 0 2px rgba(47,111,237,0.12); }
.resources { font-size: 0.95rem; margin: 0.2rem 0; }
.muted { color: #6b7689; font-size: 0.85rem; margin: 0.2rem 0; }
.card-row { display: flex; flex-wrap: wrap; gap: 0.35rem; margin-top: 0.4rem; }
.card-chip { background: #f0f3f8; border: 1px solid #d8dee8; border-radius: 5px; padding: 0.15rem 0.5rem; font-size: 0.85rem; }
.error { color: #b32121; }

/* --- Board / cards / grid --- */
h3 { font-size: 0.95rem; margin: 0.8rem 0 0.3rem; color: #44506a; }
.topbar-actions { display: flex; gap: 0.4rem; }
.actions { display: flex; gap: 0.5rem; margin: 0.6rem 0; }
.mission { margin: 0.3rem 0; }
.handoff { max-width: 460px; margin: 3rem auto; text-align: center; }
.result { font-size: 1.1rem; font-weight: 600; margin: 0.4rem 0; }
.scoreboard { margin: 0.2rem 0 0.8rem 1.2rem; }
.build-banner { display: flex; align-items: center; gap: 0.75rem; background: #eaf1ff; border: 1px solid #cfe0ff; border-radius: 6px; padding: 0.4rem 0.7rem; margin: 0.5rem 0; }

.board-grid { max-width: 420px; margin: 0.5rem 0; }
.parkgrid { width: 100%; height: auto; }
.parkgrid .cell { stroke: #c7cedb; stroke-width: 1; fill: #f7f9fc; }
.parkgrid .cell.empty { fill: #f7f9fc; }
.parkgrid .cell.entrance { fill: #ffe08a; stroke: #e0a92a; }
.parkgrid .cell.built { fill: #9ec5ff; stroke: #5b8ad6; }
.parkgrid .cell.selectable { fill: #cfeccd; stroke: #5aa854; cursor: pointer; }
.parkgrid .cell.selectable:hover { fill: #aee0a8; }
.parkgrid .cell.ghost.legal { fill: #66c25e; fill-opacity: 0.75; stroke: #3f8f39; }
.parkgrid .cell.ghost.illegal { fill: #e08585; fill-opacity: 0.7; stroke: #b35050; }
.parkgrid .cell-label { font-size: 6px; text-anchor: middle; dominant-baseline: central; fill: #1d2330; pointer-events: none; }
.parkgrid .cell-label.entrance-label { font-weight: 700; }

/* --- Card faces --- */
.card-row { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 0.4rem; align-items: flex-start; }
.cardface { width: 130px; border: 1px solid #d3d9e3; border-radius: 7px; padding: 0.4rem 0.5rem; background: #fff; cursor: pointer; box-shadow: 0 1px 2px rgba(0,0,0,0.05); }
.cardface:hover { border-color: #2f6fed; }
.cardface.disabled { opacity: 0.5; cursor: not-allowed; }
.cardface.selected { outline: 2px solid #2f6fed; }
.cardface.type-ride { border-top: 3px solid #d6618f; }
.cardface.type-food { border-top: 3px solid #d99a2b; }
.cardface.type-shop { border-top: 3px solid #4aa3a3; }
.cardface.type-facility { border-top: 3px solid #7a8a9a; }
.cardface.type-market { border-top: 3px solid #6b5bd6; }
.cf-head { display: flex; justify-content: space-between; align-items: baseline; gap: 0.3rem; }
.cf-name { font-weight: 600; font-size: 0.82rem; }
.cf-type { font-size: 0.65rem; color: #6b7689; text-transform: uppercase; }
.cf-stats { display: flex; flex-wrap: wrap; gap: 0.3rem; margin: 0.25rem 0; font-size: 0.72rem; }
.cf-tags { display: flex; flex-wrap: wrap; gap: 0.2rem; }
.cf-tag { background: #eef1f6; border-radius: 8px; padding: 0 0.35rem; font-size: 0.65rem; }
.cf-req { font-size: 0.65rem; color: #8a6d3b; margin-top: 0.2rem; }
.cf-footprint { margin-top: 0.3rem; }
.cf-footprint .fp { width: 38px; height: 28px; }
.cf-footprint .fp polygon { fill: #cdd8ea; stroke: #92a3c0; stroke-width: 0.5; }

.partner-wrap { width: 140px; }
.effect { font-size: 0.68rem; color: #44506a; margin: 0.2rem 0 0; }
.mission-pick { display: flex; flex-direction: column; align-items: flex-start; gap: 0.2rem; text-align: left; max-width: 240px; padding: 0.5rem 0.7rem; }
.discard-prompt { margin-top: 0.8rem; padding: 0.6rem; background: #fff7e6; border: 1px solid #f0dcae; border-radius: 6px; }

/* --- Card effect text (inside the face) --- */
.cf-effect { font-size: 0.68rem; color: #44506a; margin-top: 0.3rem; padding-top: 0.25rem; border-top: 1px dashed #e2e6ee; }

/* --- Board layout: grid + help side by side --- */
.board-row { display: flex; flex-wrap: wrap; gap: 1rem; align-items: flex-start; margin: 0.5rem 0; }
.board-row .board-grid { flex: 0 0 420px; max-width: 420px; margin: 0; }
.board-help { flex: 1 1 220px; min-width: 200px; background: #f7f9fc; border: 1px solid #e4e8ef; border-radius: 7px; padding: 0.6rem 0.85rem; }
.board-help h4 { margin: 0 0 0.4rem; font-size: 0.85rem; color: #44506a; text-transform: uppercase; letter-spacing: 0.03em; }
.board-help ul { margin: 0; padding-left: 1.1rem; }
.board-help li { font-size: 0.82rem; color: #3a4452; margin: 0.25rem 0; line-height: 1.35; }

/* --- End-of-season payout --- */
.season-report { max-width: 560px; margin: 2rem auto; }
.season-table { width: 100%; border-collapse: collapse; margin: 0.6rem 0 1rem; }
.season-table th, .season-table td { text-align: left; padding: 0.35rem 0.6rem; border-bottom: 1px solid #e8ebf1; font-size: 0.9rem; }
.season-table th { color: #6b7689; font-weight: 600; font-size: 0.78rem; text-transform: uppercase; }
.delta-up { color: #2f8f39; font-weight: 600; }
.delta-down { color: #b35050; font-weight: 600; }

/* --- Built tags + season-stage effect --- */
.builttags { font-size: 0.85rem; margin: 0.15rem 0 0.3rem; }
.season-effect { font-size: 0.78rem; color: #6b7689; margin-top: 0.15rem; }

.newgame .aim { font-size: 0.85rem; color: #44506a; line-height: 1.45; margin: 0; }

.cardface.static { cursor: default; box-shadow: none; }
.cardface.static:hover { border-color: #d3d9e3; }

/* --- New-game player name inputs --- */
.player-names { display: flex; flex-direction: column; gap: 0.4rem; }
.player-names label { display: flex; align-items: center; justify-content: space-between; gap: 0.6rem; font-size: 0.9rem; }
.player-names input { flex: 1; max-width: 200px; padding: 0.3rem 0.45rem; border: 1px solid #c2c8d2; border-radius: 5px; font: inherit; }
button.primary:disabled { background: #aebfe0; border-color: #aebfe0; cursor: not-allowed; }
