@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@400;500;600;700;800;900&family=Noto+Serif+TC:wght@700;900&display=swap");

@media all {
    *,
    *::before,
    *::after {
        box-sizing: border-box;
    }

    html {
        min-height: 100%;
        text-size-adjust: 100%;
        -webkit-text-size-adjust: 100%;
    }

    body {
        min-height: 100vh;
        margin: 0;
    }

    img,
    svg,
    video,
    iframe {
        max-width: 100%;
    }

    button,
    input,
    select,
    textarea {
        font: inherit;
    }

    button,
    a {
        -webkit-tap-highlight-color: transparent;
    }
}

/* Frontend UI final cascade */
@media all {
    body.bluecg-member-page .bluecg-shell.wide {
        width: min(100% - 1.5rem, 72rem);
    }

    body.bluecg-member-page .bluecg-brand.compact {
        min-height: 6.6rem;
        margin-bottom: .8rem;
        padding: 1rem 1.15rem;
        border-radius: 1.2rem;
    }

    body.bluecg-member-page .bluecg-brand.compact .bluecg-title {
        font-size: clamp(1.52rem, 2.25vw, 2.05rem);
        letter-spacing: .035em;
    }

    body.bluecg-member-page .bluecg-brand.compact .bluecg-subtitle {
        color: color-mix(in srgb, var(--bcg-muted) 86%, black);
        font-size: .88rem;
        font-weight: 800;
    }

    body.bluecg-member-page .bluecg-nav {
        gap: .35rem;
        margin-bottom: .85rem;
        padding: .42rem;
        border-radius: 1rem;
    }

    body.bluecg-member-page .bluecg-nav a {
        min-height: 2.38rem;
        padding: .42rem .78rem;
        border-radius: .72rem;
        font-size: .82rem;
    }

    body.bluecg-member-page .bluecg-nav a.active {
        background: linear-gradient(180deg, #f5cf74, #cf8526);
        color: #25170f;
    }

    body.bluecg-member-page .bluecg-panel.quest {
        border-radius: 1.15rem;
    }

    body.bluecg-member-page .bluecg-panel-inner {
        padding: clamp(.95rem, 2vw, 1.35rem);
    }

    body.bluecg-member-page .bluecg-heading,
    body.bluecg-member-page .bluecg-section-title {
        gap: .7rem;
        margin-bottom: .85rem;
    }

    body.bluecg-member-page .bluecg-heading h2,
    body.bluecg-member-page .bluecg-section-title h2 {
        margin-bottom: .15rem;
        font-size: clamp(1.12rem, 1.85vw, 1.45rem);
    }

    body.bluecg-member-page .bluecg-grid {
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
        gap: .95rem;
    }

    .bluecg-event-card {
        gap: .7rem;
        min-height: 100%;
    }

    .bluecg-card-topline {
        display: flex;
        justify-content: flex-start;
    }

    .bluecg-event-summary {
        display: -webkit-box;
        min-height: 3.2em;
        overflow: hidden;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 3;
    }

    .bluecg-event-times {
        display: grid;
        gap: .32rem;
        padding: .65rem .72rem;
        border: 1px solid var(--bcg-line);
        border-radius: .8rem;
        background: color-mix(in srgb, var(--bcg-surface-solid) 72%, transparent);
        color: var(--bcg-muted);
        font-size: .82rem;
        line-height: 1.45;
    }

    .bluecg-event-category-card .bluecg-event-text:empty {
        display: none;
    }

    .bluecg-event-text {
        padding: .9rem 1rem;
        border-radius: .9rem;
        background: linear-gradient(180deg, rgba(255, 254, 249, .86), rgba(255, 249, 237, .72));
        color: var(--bcg-ink-soft);
        font-size: .92rem;
        line-height: 1.86;
    }

    .bluecg-content-image img {
        max-height: min(34rem, 72vh);
    }

    .bluecg-showcase-grid {
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 22rem));
        justify-content: center;
        gap: 1rem;
    }

    .bluecg-vote-grid {
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 15.5rem), 18rem));
        justify-content: center;
        gap: 1rem;
    }

    .bluecg-showcase-card,
    .bluecg-vote-card {
        width: 100%;
        max-width: 22rem;
        border-radius: 1rem;
    }

    .bluecg-vote-card {
        max-width: 18rem;
    }

    .bluecg-gallery-main {
        aspect-ratio: 4 / 3;
        min-height: 8.8rem;
        max-height: 12rem;
    }

    .bluecg-vote-card .bluecg-gallery-main {
        min-height: 8rem;
        max-height: 10rem;
    }

    .bluecg-work-youtube .bluecg-content-video {
        width: 100%;
        margin: 0;
        box-shadow: none;
    }

    .bluecg-showcase-head,
    .bluecg-vote-card-head {
        align-items: start;
    }

    .bluecg-showcase-head h3,
    .bluecg-vote-card h3 {
        overflow-wrap: anywhere;
        line-height: 1.25;
    }

    .bluecg-author-line,
    .bluecg-vote-author {
        grid-template-columns: auto minmax(0, 1fr);
        margin-top: .35rem;
        line-height: 1.42;
    }

    .bluecg-author-line strong {
        min-width: 0;
        white-space: normal;
    }

    .bluecg-author-line span:last-child,
    .bluecg-vote-author span:last-child {
        grid-column: 1 / -1;
    }

    .bluecg-showcase-concept,
    .bluecg-vote-concept {
        min-height: 0;
        color: color-mix(in srgb, var(--bcg-ink-soft) 88%, black);
    }

    .bluecg-vote-actions {
        grid-template-columns: auto minmax(7rem, 1fr);
        margin-top: .2rem;
    }

    .bluecg-vote-actions .bluecg-button,
    .bluecg-vote-actions .bluecg-link-button {
        min-height: 2.35rem;
        border-radius: .75rem;
    }

    .bluecg-form .bluecg-field {
        min-width: 0;
    }

    .bluecg-field label,
    .bluecg-label {
        color: var(--bcg-ink);
        font-size: .86rem;
        font-weight: 900;
    }

    .bluecg-field input,
    .bluecg-field select,
    .bluecg-field textarea,
    .bluecg-textarea {
        border-radius: .75rem;
    }

    .bluecg-file-status li span {
        white-space: normal;
        overflow-wrap: anywhere;
    }

    .bluecg-table-wrap {
        border-radius: 1rem;
    }

    .bluecg-results-table td,
    .bluecg-results-table th {
        vertical-align: middle;
    }

    .bluecg-results-table tbody tr:nth-child(1),
    .bluecg-results-table tbody tr:nth-child(2),
    .bluecg-results-table tbody tr:nth-child(3) {
        background: color-mix(in srgb, var(--bcg-amber-2) 12%, white);
    }

    .bluecg-empty {
        grid-column: 1 / -1;
    }

    @media (max-width: 820px) {
        body.bluecg-member-page .bluecg-shell.wide {
            width: 100%;
            padding-inline: .6rem;
        }

        body.bluecg-member-page .bluecg-brand.compact {
            min-height: 0;
            padding: .85rem;
            text-align: center;
        }

        body.bluecg-member-page .bluecg-brand.compact .bluecg-logo {
            width: 8.7rem;
            height: 2.65rem;
        }

        body.bluecg-member-page .bluecg-nav {
            flex-wrap: nowrap;
            justify-content: flex-start;
            overflow-x: auto;
            scrollbar-width: none;
        }

        body.bluecg-member-page .bluecg-nav::-webkit-scrollbar {
            display: none;
        }

        body.bluecg-member-page .bluecg-nav a {
            flex: 0 0 auto;
            min-height: 2.28rem;
            font-size: .78rem;
            white-space: nowrap;
        }

        body.bluecg-member-page .bluecg-grid,
        .bluecg-showcase-grid,
        .bluecg-vote-grid {
            grid-template-columns: 1fr;
            justify-items: stretch;
        }

        .bluecg-showcase-card,
        .bluecg-vote-card {
            max-width: none;
        }

        .bluecg-gallery-main,
        .bluecg-vote-card .bluecg-gallery-main {
            aspect-ratio: 16 / 10;
            max-height: 13rem;
        }

        .bluecg-vote-actions {
            grid-template-columns: 1fr;
        }

        .bluecg-event-text {
            padding: .78rem;
            font-size: .88rem;
            line-height: 1.75;
        }
    }
}

/* Frontend UI completion pass */
@media all {
    body.bluecg-member-page .bluecg-shell.wide {
        width: min(100% - 1.5rem, 72rem);
    }

    body.bluecg-member-page .bluecg-brand.compact {
        min-height: 6.6rem;
        margin-bottom: .8rem;
        padding: 1rem 1.15rem;
        border-radius: 1.2rem;
    }

    body.bluecg-member-page .bluecg-brand.compact .bluecg-title {
        font-size: clamp(1.52rem, 2.25vw, 2.05rem);
        letter-spacing: .035em;
    }

    body.bluecg-member-page .bluecg-brand.compact .bluecg-subtitle {
        color: color-mix(in srgb, var(--bcg-muted) 86%, black);
        font-size: .88rem;
        font-weight: 800;
    }

    body.bluecg-member-page .bluecg-nav {
        gap: .35rem;
        margin-bottom: .85rem;
        padding: .42rem;
        border-radius: 1rem;
    }

    body.bluecg-member-page .bluecg-nav a {
        min-height: 2.38rem;
        padding: .42rem .78rem;
        border-radius: .72rem;
        font-size: .82rem;
    }

    body.bluecg-member-page .bluecg-nav a.active {
        background: linear-gradient(180deg, #f5cf74, #cf8526);
        color: #25170f;
    }

    body.bluecg-member-page .bluecg-panel.quest {
        border-radius: 1.15rem;
    }

    body.bluecg-member-page .bluecg-panel-inner {
        padding: clamp(.95rem, 2vw, 1.35rem);
    }

    body.bluecg-member-page .bluecg-heading,
    body.bluecg-member-page .bluecg-section-title {
        gap: .7rem;
        margin-bottom: .85rem;
    }

    body.bluecg-member-page .bluecg-heading h2,
    body.bluecg-member-page .bluecg-section-title h2 {
        margin-bottom: .15rem;
        font-size: clamp(1.12rem, 1.85vw, 1.45rem);
    }

    body.bluecg-member-page .bluecg-grid {
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
        gap: .95rem;
    }

    .bluecg-event-card {
        gap: .7rem;
        min-height: 100%;
    }

    .bluecg-card-topline {
        display: flex;
        justify-content: flex-start;
    }

    .bluecg-event-summary {
        display: -webkit-box;
        min-height: 3.2em;
        overflow: hidden;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 3;
    }

    .bluecg-event-times {
        display: grid;
        gap: .32rem;
        padding: .65rem .72rem;
        border: 1px solid var(--bcg-line);
        border-radius: .8rem;
        background: color-mix(in srgb, var(--bcg-surface-solid) 72%, transparent);
        color: var(--bcg-muted);
        font-size: .82rem;
        line-height: 1.45;
    }

    .bluecg-event-text {
        padding: .9rem 1rem;
        border-radius: .9rem;
        background: linear-gradient(180deg, rgba(255, 254, 249, .86), rgba(255, 249, 237, .72));
        color: var(--bcg-ink-soft);
        font-size: .92rem;
        line-height: 1.86;
    }

    .bluecg-content-image img {
        max-height: min(34rem, 72vh);
    }

    .bluecg-showcase-grid {
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 22rem));
        justify-content: center;
        gap: 1rem;
    }

    .bluecg-vote-grid {
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 15.5rem), 18rem));
        justify-content: center;
        gap: 1rem;
    }

    .bluecg-showcase-card,
    .bluecg-vote-card {
        width: 100%;
        max-width: 22rem;
        border-radius: 1rem;
    }

    .bluecg-vote-card {
        max-width: 18rem;
    }

    .bluecg-gallery-main {
        aspect-ratio: 4 / 3;
        min-height: 8.8rem;
        max-height: 12rem;
    }

    .bluecg-vote-card .bluecg-gallery-main {
        min-height: 8rem;
        max-height: 10rem;
    }

    .bluecg-work-youtube .bluecg-content-video {
        width: 100%;
        margin: 0;
        box-shadow: none;
    }

    .bluecg-showcase-head,
    .bluecg-vote-card-head {
        align-items: start;
    }

    .bluecg-showcase-head h3,
    .bluecg-vote-card h3 {
        overflow-wrap: anywhere;
        line-height: 1.25;
    }

    .bluecg-author-line,
    .bluecg-vote-author {
        grid-template-columns: auto minmax(0, 1fr);
        margin-top: .35rem;
        line-height: 1.42;
    }

    .bluecg-author-line strong {
        min-width: 0;
        white-space: normal;
    }

    .bluecg-author-line span:last-child,
    .bluecg-vote-author span:last-child {
        grid-column: 1 / -1;
    }

    .bluecg-showcase-concept,
    .bluecg-vote-concept {
        min-height: 0;
        color: color-mix(in srgb, var(--bcg-ink-soft) 88%, black);
    }

    .bluecg-vote-actions {
        grid-template-columns: auto minmax(7rem, 1fr);
        margin-top: .2rem;
    }

    .bluecg-vote-actions .bluecg-button,
    .bluecg-vote-actions .bluecg-link-button {
        min-height: 2.35rem;
        border-radius: .75rem;
    }

    .bluecg-form .bluecg-field {
        min-width: 0;
    }

    .bluecg-field label,
    .bluecg-label {
        color: var(--bcg-ink);
        font-size: .86rem;
        font-weight: 900;
    }

    .bluecg-field input,
    .bluecg-field select,
    .bluecg-field textarea,
    .bluecg-textarea {
        border-radius: .75rem;
    }

    .bluecg-file-status li span {
        white-space: normal;
        overflow-wrap: anywhere;
    }

    .bluecg-table-wrap {
        border-radius: 1rem;
    }

    .bluecg-results-table td,
    .bluecg-results-table th {
        vertical-align: middle;
    }

    .bluecg-results-table tbody tr:nth-child(1),
    .bluecg-results-table tbody tr:nth-child(2),
    .bluecg-results-table tbody tr:nth-child(3) {
        background: color-mix(in srgb, var(--bcg-amber-2) 12%, white);
    }

    .bluecg-empty {
        grid-column: 1 / -1;
    }

    @media (max-width: 820px) {
        body.bluecg-member-page .bluecg-shell.wide {
            width: 100%;
            padding-inline: .6rem;
        }

        body.bluecg-member-page .bluecg-brand.compact {
            min-height: 0;
            padding: .85rem;
            text-align: center;
        }

        body.bluecg-member-page .bluecg-brand.compact .bluecg-logo {
            width: 8.7rem;
            height: 2.65rem;
        }

        body.bluecg-member-page .bluecg-nav {
            flex-wrap: nowrap;
            justify-content: flex-start;
            overflow-x: auto;
            scrollbar-width: none;
        }

        body.bluecg-member-page .bluecg-nav::-webkit-scrollbar {
            display: none;
        }

        body.bluecg-member-page .bluecg-nav a {
            flex: 0 0 auto;
            min-height: 2.28rem;
            font-size: .78rem;
            white-space: nowrap;
        }

        body.bluecg-member-page .bluecg-grid,
        .bluecg-showcase-grid,
        .bluecg-vote-grid {
            grid-template-columns: 1fr;
            justify-items: stretch;
        }

        .bluecg-showcase-card,
        .bluecg-vote-card {
            max-width: none;
        }

        .bluecg-gallery-main,
        .bluecg-vote-card .bluecg-gallery-main {
            aspect-ratio: 16 / 10;
            max-height: 13rem;
        }

        .bluecg-vote-actions {
            grid-template-columns: 1fr;
        }

        .bluecg-event-text {
            padding: .78rem;
            font-size: .88rem;
            line-height: 1.75;
        }
    }
}

/* Premium visual pass */
@media all {
    :root {
        --bcg-ink: #181717;
        --bcg-ink-soft: #38322d;
        --bcg-muted: #695f58;
        --bcg-line: rgba(42, 35, 28, .13);
        --bcg-line-strong: rgba(42, 35, 28, .24);
        --bcg-surface: rgba(255, 254, 249, .9);
        --bcg-surface-solid: #fffefa;
        --bcg-teal: #1f7774;
        --bcg-teal-2: #35aaa4;
        --bcg-amber: #bb7925;
        --bcg-amber-2: #f4ce71;
        --bcg-rose: #a45262;
        --bcg-cobalt: #215e84;
        --bcg-shadow-sm: 0 .5rem 1.25rem rgba(31, 24, 18, .07);
        --bcg-shadow-md: 0 1rem 2.8rem rgba(31, 24, 18, .12);
        --bcg-shadow-lg: 0 1.8rem 4.6rem rgba(31, 24, 18, .18);
    }

    body.bluecg-page {
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .76), rgba(251, 244, 230, .8)),
            linear-gradient(118deg, transparent 0 19%, rgba(31, 119, 116, .08) 19% 19.55%, transparent 19.55% 100%),
            linear-gradient(62deg, transparent 0 62%, rgba(187, 121, 37, .08) 62% 62.45%, transparent 62.45% 100%),
            repeating-linear-gradient(90deg, rgba(31, 119, 116, .04) 0 1px, transparent 1px 2.1rem),
            repeating-linear-gradient(0deg, rgba(187, 121, 37, .032) 0 1px, transparent 1px 2.1rem),
            linear-gradient(180deg, #eef7f5 0%, #fcf6ea 46%, #f1eadf 100%);
    }

    body.bluecg-page::before {
        position: fixed;
        inset: 0;
        z-index: -1;
        display: block;
        content: "";
        pointer-events: none;
        background:
            linear-gradient(90deg, transparent, rgba(255, 255, 255, .28), transparent),
            repeating-linear-gradient(135deg, rgba(31, 119, 116, .045) 0 1px, transparent 1px 1.4rem);
        mask-image: linear-gradient(180deg, rgba(0, 0, 0, .9), rgba(0, 0, 0, .28));
    }

    .bluecg-brand.compact,
    .bluecg-nav,
    .bluecg-panel,
    .bluecg-card,
    .bluecg-stat,
    .bluecg-form-card,
    .bluecg-table-wrap,
    .bluecg-profile,
    .bluecg-menu-item {
        box-shadow:
            var(--bcg-shadow-sm),
            inset 0 1px 0 rgba(255, 255, 255, .75);
    }

    .bluecg-brand.compact {
        position: relative;
        overflow: clip;
        border-color: rgba(31, 119, 116, .16);
        background:
            linear-gradient(135deg, rgba(255, 254, 250, .94), rgba(244, 251, 248, .84) 48%, rgba(255, 248, 233, .86));
    }

    .bluecg-brand.compact::before {
        position: absolute;
        inset: 0 0 auto;
        height: 3px;
        content: "";
        background: linear-gradient(90deg, var(--bcg-teal), var(--bcg-amber), var(--bcg-rose));
    }

    .bluecg-logo {
        border-color: rgba(255, 255, 255, .86);
        box-shadow:
            0 .75rem 1.5rem rgba(8, 13, 18, .18),
            inset 0 0 0 1px rgba(255, 255, 255, .15);
    }

    .bluecg-kicker {
        border-color: rgba(31, 119, 116, .28);
        background:
            linear-gradient(180deg, rgba(255, 255, 255, .86), rgba(228, 248, 243, .9));
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, .8);
    }

    .bluecg-title {
        color: #161514;
        text-shadow: 0 1px 0 rgba(255, 255, 255, .74);
    }

    .bluecg-nav {
        position: relative;
        border-color: rgba(31, 119, 116, .13);
        background:
            linear-gradient(180deg, rgba(255, 254, 250, .92), rgba(248, 242, 232, .86));
    }

    .bluecg-nav a {
        color: #554b44;
        text-decoration: none;
    }

    .bluecg-nav a.active {
        box-shadow:
            0 .35rem .85rem rgba(31, 119, 116, .12),
            inset 0 1px 0 rgba(255, 255, 255, .86);
    }

    .bluecg-panel {
        border-color: rgba(31, 119, 116, .14);
        background:
            linear-gradient(180deg, rgba(255, 254, 250, .96), rgba(255, 249, 238, .9));
        box-shadow:
            var(--bcg-shadow-md),
            inset 0 1px 0 rgba(255, 255, 255, .82);
    }

    .bluecg-panel::before {
        height: 4px;
        background: linear-gradient(90deg, var(--bcg-teal), var(--bcg-amber-2), var(--bcg-rose));
    }

    .bluecg-panel::after {
        position: absolute;
        inset: 4px 0 auto;
        height: 1px;
        content: "";
        background: linear-gradient(90deg, transparent, rgba(255, 255, 255, .92), transparent);
    }

    .bluecg-heading,
    .bluecg-section-title {
        border-bottom-color: rgba(31, 119, 116, .13);
    }

    .bluecg-heading-badge {
        background:
            linear-gradient(145deg, rgba(255, 255, 255, .22), transparent 38%),
            linear-gradient(135deg, var(--bcg-teal-2), var(--bcg-cobalt));
        box-shadow:
            0 .55rem 1rem rgba(31, 119, 116, .2),
            inset 0 1px 0 rgba(255, 255, 255, .32);
    }

    .bluecg-heading-badge.gold {
        background:
            linear-gradient(145deg, rgba(255, 255, 255, .24), transparent 38%),
            linear-gradient(135deg, var(--bcg-amber-2), var(--bcg-rose));
        box-shadow:
            0 .55rem 1rem rgba(187, 121, 37, .2),
            inset 0 1px 0 rgba(255, 255, 255, .32);
    }

    .bluecg-hero {
        position: relative;
        border-color: rgba(31, 119, 116, .22);
        background:
            linear-gradient(115deg, rgba(236, 250, 246, .92), rgba(255, 249, 235, .88) 64%, rgba(255, 243, 238, .86)),
            repeating-linear-gradient(135deg, rgba(31, 119, 116, .045) 0 .35rem, transparent .35rem .7rem);
        box-shadow:
            inset .34rem 0 0 var(--bcg-teal),
            inset 0 1px 0 rgba(255, 255, 255, .84),
            0 .75rem 1.6rem rgba(31, 24, 18, .07);
    }

    .bluecg-card,
    .bluecg-form-card,
    .bluecg-menu-item,
    .bluecg-stat {
        position: relative;
        overflow: clip;
        background:
            linear-gradient(180deg, rgba(255, 254, 250, .94), rgba(255, 250, 240, .86));
    }

    .bluecg-card::before,
    .bluecg-menu-item::before,
    .bluecg-stat::before {
        position: absolute;
        inset: 0 auto 0 0;
        width: 3px;
        content: "";
        background: linear-gradient(180deg, var(--bcg-teal), var(--bcg-amber));
        opacity: .8;
    }

    .bluecg-card:hover,
    .bluecg-menu-item:hover {
        border-color: rgba(31, 119, 116, .3);
        box-shadow:
            var(--bcg-shadow-md),
            inset 0 1px 0 rgba(255, 255, 255, .82);
    }

    .bluecg-stat strong {
        color: #1d7773;
    }

    .bluecg-button,
    .bluecg-link-button {
        position: relative;
        overflow: hidden;
        background:
            linear-gradient(180deg, rgba(255, 255, 255, .18), transparent 38%),
            linear-gradient(180deg, var(--bcg-teal-2), #176461);
        box-shadow:
            0 .75rem 1.2rem rgba(31, 119, 116, .24),
            inset 0 1px 0 rgba(255, 255, 255, .34);
    }

    .bluecg-button::after,
    .bluecg-link-button::after {
        position: absolute;
        inset: 0;
        content: "";
        background: linear-gradient(110deg, transparent 0 32%, rgba(255, 255, 255, .18) 43%, transparent 54% 100%);
        opacity: 0;
        transform: translateX(-35%);
        transition: opacity .18s ease, transform .28s ease;
        pointer-events: none;
    }

    .bluecg-button:hover::after,
    .bluecg-link-button:hover::after {
        opacity: 1;
        transform: translateX(35%);
    }

    .bluecg-link-button.secondary {
        background:
            linear-gradient(180deg, rgba(255, 255, 255, .2), transparent 38%),
            linear-gradient(180deg, var(--bcg-amber-2), var(--bcg-amber));
    }

    .bluecg-mini-button,
    .bluecg-card-links a,
    .bluecg-pagination > a,
    .bluecg-pagination > span,
    .bluecg-pagination-links a {
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, .72);
    }

    .bluecg-field input,
    .bluecg-field select,
    .bluecg-field textarea,
    .bluecg-table input,
    .bluecg-table select,
    .bluecg-textarea {
        background:
            linear-gradient(180deg, #fffefa, #fffaf0);
    }

    .bluecg-table-wrap {
        border-color: rgba(31, 119, 116, .14);
    }

    .bluecg-table th {
        background:
            linear-gradient(180deg, #fffefa, #f5ead5);
        color: #342d27;
    }

    .bluecg-table td {
        background: rgba(255, 254, 250, .72);
    }

    .bluecg-work-gallery.is-empty,
    .bluecg-gallery-main,
    .bluecg-showcase-media {
        border-color: rgba(31, 119, 116, .18);
        background:
            linear-gradient(135deg, rgba(255, 255, 255, .9), rgba(255, 248, 232, .82)),
            repeating-linear-gradient(45deg, rgba(31, 119, 116, .06) 0 .42rem, transparent .42rem .84rem);
    }

    .bluecg-alert,
    .bluecg-success,
    .bluecg-notice,
    .bluecg-empty {
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, .78);
    }

    .bluecg-admin-page .bluecg-button,
    .bluecg-admin-page .bluecg-link-button {
        background:
            linear-gradient(180deg, rgba(255, 255, 255, .18), transparent 38%),
            linear-gradient(180deg, #c5757d, var(--bcg-rose));
    }
}

@media all {
    :root {
        color-scheme: light;

        --bcg-font-sans: "Noto Sans TC", "Microsoft JhengHei", "PingFang TC", system-ui, sans-serif;
        --bcg-font-display: "Noto Serif TC", "Noto Sans TC", serif;

        --bcg-ink: #211f1d;
        --bcg-ink-soft: #3f3933;
        --bcg-muted: #6f655d;
        --bcg-muted-2: #8c8178;
        --bcg-line: rgba(65, 54, 43, .14);
        --bcg-line-strong: rgba(65, 54, 43, .22);

        --bcg-bg: #f4f1ea;
        --bcg-bg-2: #eaf2ef;
        --bcg-surface: rgba(255, 253, 247, .88);
        --bcg-surface-solid: #fffdf7;
        --bcg-surface-2: #f8f0df;

        --bcg-teal: #247875;
        --bcg-teal-2: #35a39d;
        --bcg-amber: #c4872f;
        --bcg-amber-2: #f0c86b;
        --bcg-rose: #a95d63;
        --bcg-cobalt: #255f85;

        --bcg-danger: #b34242;
        --bcg-danger-bg: #fff0ed;
        --bcg-success: #257a58;
        --bcg-success-bg: #eefaf2;
        --bcg-notice: #286f8f;
        --bcg-notice-bg: #eef8fb;

        --bcg-radius-xs: .45rem;
        --bcg-radius-sm: .65rem;
        --bcg-radius-md: .9rem;
        --bcg-radius-lg: 1.15rem;
        --bcg-radius-xl: 1.45rem;

        --bcg-shadow-sm: 0 .35rem .9rem rgba(40, 31, 24, .06);
        --bcg-shadow-md: 0 .8rem 2.2rem rgba(40, 31, 24, .10);
        --bcg-shadow-lg: 0 1.35rem 3.6rem rgba(40, 31, 24, .15);

        --bcg-focus: 0 0 0 .2rem rgba(36, 120, 117, .24);
        --bcg-control-h: 2.75rem;
        --bcg-compact-control-h: 2.5rem;
        --bcg-page-max: 76rem;
    }
}

@media all {
    html {
        background:
            linear-gradient(180deg, #eef7f5 0%, #fbf4e7 46%, #f1eadf 100%);
    }

    body.bluecg-page {
        color: var(--bcg-ink);
        font-family: var(--bcg-font-sans);
        line-height: 1.6;
        letter-spacing: 0;
        background:
            linear-gradient(rgba(255, 255, 255, .72), rgba(255, 253, 247, .72)),
            repeating-linear-gradient(90deg, rgba(36, 120, 117, .045) 0 1px, transparent 1px 2rem),
            repeating-linear-gradient(0deg, rgba(196, 135, 47, .035) 0 1px, transparent 1px 2rem);
        background-attachment: fixed;
        font-synthesis-weight: none;
        overflow-x: hidden;
    }

    .bluecg-page *,
    .bluecg-page *::before,
    .bluecg-page *::after {
        letter-spacing: 0;
    }

    .bluecg-page::before,
    .bluecg-page::after {
        display: none;
    }

    .bluecg-page ::selection {
        background: rgba(36, 120, 117, .22);
        color: var(--bcg-ink);
    }

    :where(.bluecg-page a) {
        color: inherit;
    }

    :where(.bluecg-page button) {
        cursor: pointer;
    }

    :where(.bluecg-page button:disabled) {
        cursor: not-allowed;
    }

    :where(.bluecg-page :focus-visible) {
        outline: 0;
        box-shadow: var(--bcg-focus);
    }
}

@media all {
    .bluecg-shell {
        width: min(100% - 2rem, 34rem);
        margin-inline: auto;
        padding-block: max(1rem, env(safe-area-inset-top)) max(1.4rem, env(safe-area-inset-bottom));
    }

    .bluecg-shell.wide,
    .bluecg-admin-page .bluecg-shell.wide,
    .bluecg-member-page .bluecg-shell.wide,
    .bluecg-dashboard-page .bluecg-shell.wide {
        width: min(100% - 2rem, var(--bcg-page-max));
    }

    .bluecg-brand {
        margin-block-end: 1rem;
        text-align: center;
    }

    .bluecg-brand.compact {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        grid-template-areas:
            "logo kicker"
            "logo title"
            "logo subtitle";
        gap: .3rem 1rem;
        align-items: center;
        margin-inline: auto;
        margin-block-end: .9rem;
        padding: .9rem;
        border: 1px solid var(--bcg-line);
        border-radius: var(--bcg-radius-lg);
        background: var(--bcg-surface);
        box-shadow: var(--bcg-shadow-sm);
        text-align: start;
    }

    @supports (backdrop-filter: blur(12px)) {
        .bluecg-brand.compact,
        .bluecg-nav,
        .bluecg-panel,
        .bluecg-card,
        .bluecg-stat,
        .bluecg-form-card {
            backdrop-filter: blur(18px);
            -webkit-backdrop-filter: blur(18px);
        }
    }

    .bluecg-brand.compact .bluecg-logo {
        grid-area: logo;
    }

    .bluecg-brand.compact .bluecg-kicker {
        grid-area: kicker;
    }

    .bluecg-brand.compact .bluecg-title {
        grid-area: title;
    }

    .bluecg-brand.compact .bluecg-subtitle {
        grid-area: subtitle;
    }

    .bluecg-panel + .bluecg-panel,
    .bluecg-panel + section,
    section + .bluecg-panel {
        margin-top: 1rem;
    }
}

@media all {
    .bluecg-logo {
        display: block;
        inline-size: 15rem;
        block-size: 4.25rem;
        max-inline-size: 100%;
        border: 1px solid rgba(255, 255, 255, .78);
        border-radius: var(--bcg-radius-sm);
        background: #070d12 url("bluecg-logo.png") center / contain no-repeat;
        box-shadow: var(--bcg-shadow-sm), inset 0 0 0 1px rgba(255, 255, 255, .12);
        color: transparent;
        font-size: 0;
        overflow: hidden;
        transform: none;
    }

    .bluecg-logo::before,
    .bluecg-logo::after {
        display: none;
    }

    .bluecg-kicker {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: fit-content;
        min-height: 1.75rem;
        padding: .26rem .72rem;
        border: 1px solid color-mix(in srgb, var(--bcg-teal) 22%, transparent);
        border-radius: 999px;
        background: color-mix(in srgb, var(--bcg-teal) 8%, white);
        color: var(--bcg-teal);
        font-size: .78rem;
        font-weight: 800;
        line-height: 1.2;
        text-transform: uppercase;
    }

    .bluecg-title {
        margin: 0;
        color: var(--bcg-ink);
        font-family: var(--bcg-font-display);
        font-size: 2rem;
        font-weight: 900;
        line-height: 1.15;
        text-wrap: balance;
        overflow-wrap: anywhere;
    }

    .bluecg-subtitle,
    .bluecg-meta,
    .bluecg-hint {
        color: var(--bcg-muted);
    }

    .bluecg-subtitle {
        margin: 0;
        font-size: .95rem;
        font-weight: 600;
        overflow-wrap: anywhere;
        text-wrap: pretty;
    }

    .bluecg-nav {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: .42rem;
        margin-block: 0 .9rem;
        padding: .38rem;
        border: 1px solid var(--bcg-line);
        border-radius: var(--bcg-radius-lg);
        background: color-mix(in srgb, var(--bcg-surface-solid) 82%, transparent);
        box-shadow: var(--bcg-shadow-sm);
    }

    .bluecg-nav a {
        position: relative;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-height: var(--bcg-control-h);
        padding: .55rem .85rem;
        border: 1px solid transparent;
        border-radius: var(--bcg-radius-sm);
        color: var(--bcg-muted);
        font-size: .94rem;
        font-weight: 800;
        line-height: 1.2;
        text-decoration: none;
        white-space: nowrap;
        transition: background-color .18s ease, border-color .18s ease, color .18s ease, transform .18s ease;
    }

    .bluecg-nav a:hover,
    .bluecg-nav a:focus-visible,
    .bluecg-nav a.active {
        border-color: color-mix(in srgb, var(--bcg-teal) 26%, transparent);
        background: color-mix(in srgb, var(--bcg-teal) 10%, white);
        color: var(--bcg-teal);
        transform: translateY(-1px);
    }

    .bluecg-panel {
        position: relative;
        border: 1px solid var(--bcg-line);
        border-radius: var(--bcg-radius-xl);
        background: var(--bcg-surface);
        box-shadow: var(--bcg-shadow-md);
        overflow: clip;
    }

    .bluecg-panel.quest {
        background:
            linear-gradient(180deg, rgba(255, 253, 247, .94), rgba(248, 240, 223, .88));
    }

    .bluecg-panel::before {
        position: absolute;
        inset: 0 0 auto;
        block-size: 3px;
        content: "";
        background: linear-gradient(90deg, var(--bcg-teal), var(--bcg-amber), var(--bcg-rose));
    }

    .bluecg-panel-inner {
        container-type: inline-size;
        padding: 1.25rem;
    }

    .bluecg-heading,
    .bluecg-section-title {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        gap: .8rem;
        align-items: start;
        margin-block-end: 1rem;
        padding-block-end: .9rem;
        border-bottom: 1px solid var(--bcg-line);
    }

    .bluecg-section-title {
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: end;
    }

    .bluecg-heading-badge {
        display: grid;
        place-items: center;
        inline-size: 2.5rem;
        block-size: 2.5rem;
        border: 1px solid rgba(255, 255, 255, .66);
        border-radius: var(--bcg-radius-sm);
        background: linear-gradient(135deg, var(--bcg-teal), var(--bcg-cobalt));
        color: white;
        font-size: .95rem;
        font-weight: 900;
        box-shadow: var(--bcg-shadow-sm);
        transform: none;
    }

    .bluecg-heading-badge.gold {
        background: linear-gradient(135deg, var(--bcg-amber), var(--bcg-rose));
    }

    .bluecg-heading h1,
    .bluecg-heading h2,
    .bluecg-section-title h2,
    .bluecg-section-title h3 {
        margin: 0;
        color: var(--bcg-ink);
        font-family: var(--bcg-font-display);
        font-size: 1.35rem;
        font-weight: 900;
        line-height: 1.25;
        text-wrap: balance;
        overflow-wrap: anywhere;
    }

    .bluecg-heading p,
    .bluecg-section-title p {
        margin: .25rem 0 0;
        color: var(--bcg-muted);
        text-wrap: pretty;
    }

    .bluecg-hero {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 1rem;
        align-items: center;
        margin-block-end: 1rem;
        padding: 1rem;
        border: 1px solid color-mix(in srgb, var(--bcg-teal) 20%, transparent);
        border-radius: var(--bcg-radius-lg);
        background:
            linear-gradient(135deg, color-mix(in srgb, var(--bcg-teal) 10%, white), color-mix(in srgb, var(--bcg-amber) 12%, white));
        box-shadow: inset .28rem 0 0 var(--bcg-teal);
        color: var(--bcg-ink);
        overflow: clip;
    }

    .bluecg-hero::before,
    .bluecg-hero::after {
        display: none;
    }

    .bluecg-hero h2,
    .bluecg-hero-content h2 {
        margin: 0 0 .35rem;
        color: var(--bcg-ink);
        font-family: var(--bcg-font-display);
        font-size: 1.35rem;
        line-height: 1.25;
        text-wrap: balance;
    }

    .bluecg-hero p {
        margin: 0;
        color: var(--bcg-ink-soft);
    }

    .bluecg-hero-stats {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(8rem, 1fr));
        gap: .75rem;
    }

    .bluecg-ribbon,
    .bluecg-pill {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: fit-content;
        max-width: 100%;
        min-height: 2.15rem;
        padding: .35rem .7rem;
        border: 1px solid color-mix(in srgb, var(--bcg-teal) 18%, transparent);
        border-radius: 999px;
        background: color-mix(in srgb, var(--bcg-teal) 9%, white);
        color: var(--bcg-teal);
        font-size: .82rem;
        font-weight: 900;
        line-height: 1.25;
        text-align: center;
        overflow-wrap: anywhere;
    }

    .bluecg-pill.active {
        border-color: color-mix(in srgb, var(--bcg-teal) 32%, transparent);
        background: color-mix(in srgb, var(--bcg-teal) 14%, white);
    }

    .bluecg-alert,
    .bluecg-success,
    .bluecg-notice {
        display: flex;
        align-items: flex-start;
        gap: .65rem;
        margin: 0 0 1rem;
        padding: .85rem .95rem;
        border: 1px solid;
        border-radius: var(--bcg-radius-md);
        font-weight: 700;
        line-height: 1.55;
        overflow-wrap: anywhere;
    }

    .bluecg-alert {
        border-color: color-mix(in srgb, var(--bcg-danger) 28%, transparent);
        background: var(--bcg-danger-bg);
        color: var(--bcg-danger);
    }

    .bluecg-success {
        border-color: color-mix(in srgb, var(--bcg-success) 28%, transparent);
        background: var(--bcg-success-bg);
        color: var(--bcg-success);
    }

    .bluecg-notice {
        border-color: color-mix(in srgb, var(--bcg-notice) 26%, transparent);
        background: var(--bcg-notice-bg);
        color: var(--bcg-notice);
    }

    .bluecg-form {
        display: grid;
        gap: 1rem;
    }

    .bluecg-form-row {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 16rem), 1fr));
        gap: 1rem;
        align-items: start;
    }

    .bluecg-field,
    .bluecg-label {
        min-width: 0;
    }

    .bluecg-field label,
    .bluecg-label {
        display: flex;
        align-items: center;
        gap: .35rem;
        margin: 0 0 .35rem;
        color: var(--bcg-ink);
        font-size: .92rem;
        font-weight: 800;
        line-height: 1.35;
    }

    .bluecg-field input,
    .bluecg-field select,
    .bluecg-field textarea,
    .bluecg-table input,
    .bluecg-table select,
    .bluecg-textarea {
        width: 100%;
        min-height: var(--bcg-control-h);
        padding: .7rem .85rem;
        border: 1px solid var(--bcg-line-strong);
        border-radius: var(--bcg-radius-sm);
        background: var(--bcg-surface-solid);
        color: var(--bcg-ink);
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, .8);
        transition: border-color .18s ease, box-shadow .18s ease, background-color .18s ease;
    }

    .bluecg-field textarea,
    .bluecg-textarea {
        min-height: 9rem;
        resize: vertical;
        line-height: 1.62;
    }

    .bluecg-field input:hover,
    .bluecg-field select:hover,
    .bluecg-field textarea:hover,
    .bluecg-table input:hover,
    .bluecg-table select:hover {
        border-color: color-mix(in srgb, var(--bcg-teal) 34%, var(--bcg-line-strong));
    }

    .bluecg-field input:focus,
    .bluecg-field select:focus,
    .bluecg-field textarea:focus,
    .bluecg-table input:focus,
    .bluecg-table select:focus {
        outline: 0;
        border-color: var(--bcg-teal);
        box-shadow: var(--bcg-focus);
    }

    .bluecg-field input:disabled,
    .bluecg-field select:disabled,
    .bluecg-field textarea:disabled {
        background: color-mix(in srgb, var(--bcg-muted-2) 10%, white);
        color: var(--bcg-muted-2);
    }

    .bluecg-hint {
        margin: .38rem 0 0;
        font-size: .84rem;
        line-height: 1.5;
        text-wrap: pretty;
    }

    .bluecg-choice {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: .6rem;
        margin: 0;
        padding: 0;
        border: 0;
    }

    .bluecg-choice legend {
        grid-column: 1 / -1;
        margin-block-end: .15rem;
        font-weight: 800;
    }

    .bluecg-choice label {
        display: grid;
        place-items: center;
        min-height: var(--bcg-control-h);
        padding: .55rem .75rem;
        border: 1px solid var(--bcg-line-strong);
        border-radius: var(--bcg-radius-sm);
        background: var(--bcg-surface-solid);
        color: var(--bcg-muted);
        font-weight: 900;
        text-align: center;
        cursor: pointer;
    }

    .bluecg-choice input {
        position: absolute;
        opacity: 0;
        pointer-events: none;
    }

    .bluecg-choice label:hover,
    .bluecg-choice label:has(input:checked) {
        border-color: color-mix(in srgb, var(--bcg-teal) 38%, transparent);
        background: color-mix(in srgb, var(--bcg-teal) 9%, white);
        color: var(--bcg-teal);
    }

    .bluecg-checkbox {
        display: flex;
        align-items: center;
        gap: .55rem;
        min-height: var(--bcg-control-h);
        padding: .65rem .75rem;
        border: 1px solid var(--bcg-line);
        border-radius: var(--bcg-radius-sm);
        background: color-mix(in srgb, var(--bcg-surface-solid) 88%, transparent);
        color: var(--bcg-ink-soft);
        font-weight: 800;
        cursor: pointer;
    }

    .bluecg-checkbox input {
        inline-size: 1.05rem;
        block-size: 1.05rem;
        accent-color: var(--bcg-teal);
    }

    .bluecg-button,
    .bluecg-link-button,
    .bluecg-mini-button {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: .45rem;
        min-height: var(--bcg-control-h);
        padding: .62rem 1rem;
        border: 1px solid transparent;
        border-radius: var(--bcg-radius-sm);
        background: linear-gradient(180deg, var(--bcg-teal-2), var(--bcg-teal));
        color: white;
        font-size: .94rem;
        font-weight: 900;
        line-height: 1.2;
        text-align: center;
        text-decoration: none;
        box-shadow: 0 .55rem 1rem rgba(36, 120, 117, .20);
        transition: transform .18s ease, box-shadow .18s ease, background-color .18s ease, opacity .18s ease;
        user-select: none;
    }

    .bluecg-button,
    .bluecg-link-button {
        width: 100%;
    }

    .bluecg-button:hover,
    .bluecg-link-button:hover,
    .bluecg-mini-button:hover {
        color: white;
        transform: translateY(-1px);
        box-shadow: 0 .75rem 1.25rem rgba(36, 120, 117, .24);
    }

    .bluecg-button:active,
    .bluecg-link-button:active,
    .bluecg-mini-button:active {
        transform: translateY(0);
    }

    .bluecg-button:disabled,
    .bluecg-link-button[aria-disabled="true"] {
        background: #b9b2aa;
        box-shadow: none;
        opacity: .72;
    }

    .bluecg-link-button.secondary {
        background: linear-gradient(180deg, var(--bcg-amber-2), var(--bcg-amber));
        box-shadow: 0 .55rem 1rem rgba(196, 135, 47, .22);
    }

    .bluecg-mini-button {
        width: auto;
        min-height: var(--bcg-compact-control-h);
        padding-inline: .75rem;
        background: color-mix(in srgb, var(--bcg-teal) 10%, white);
        color: var(--bcg-teal);
        box-shadow: none;
    }

    .bluecg-mini-button:hover {
        background: var(--bcg-teal);
        color: white;
    }

    .bluecg-actions {
        display: grid;
        gap: .7rem;
        margin-block-start: 1rem;
    }

    .bluecg-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
        gap: 1rem;
    }

    .bluecg-card,
    .bluecg-form-card,
    .bluecg-stat,
    .bluecg-user-card,
    .bluecg-key-box {
        min-width: 0;
        border: 1px solid var(--bcg-line);
        border-radius: var(--bcg-radius-lg);
        background: color-mix(in srgb, var(--bcg-surface-solid) 86%, transparent);
        box-shadow: var(--bcg-shadow-sm);
    }

    .bluecg-card {
        display: flex;
        flex-direction: column;
        gap: .7rem;
        padding: 1rem;
        transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
    }

    .bluecg-card:hover {
        border-color: color-mix(in srgb, var(--bcg-teal) 25%, transparent);
        box-shadow: var(--bcg-shadow-md);
        transform: translateY(-2px);
    }

    .bluecg-card h3,
    .bluecg-form-card h3 {
        margin: 0;
        color: var(--bcg-ink);
        font-family: var(--bcg-font-display);
        font-size: 1.15rem;
        font-weight: 900;
        line-height: 1.3;
        overflow-wrap: anywhere;
    }

    .bluecg-card .bluecg-meta {
        flex: 1 1 auto;
        margin: 0;
    }

    .bluecg-card-links {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 7.5rem), 1fr));
        gap: .5rem;
        margin-block-start: auto;
    }

    .bluecg-card-links a {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-height: var(--bcg-compact-control-h);
        padding: .5rem .65rem;
        border: 1px solid color-mix(in srgb, var(--bcg-teal) 18%, transparent);
        border-radius: var(--bcg-radius-sm);
        background: color-mix(in srgb, var(--bcg-teal) 8%, white);
        color: var(--bcg-teal);
        font-weight: 900;
        text-decoration: none;
    }

    .bluecg-card-links a:hover {
        background: var(--bcg-teal);
        color: white;
    }

    .bluecg-statusbar,
    .bluecg-admin-strip {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 10rem), 1fr));
        gap: .75rem;
        margin-block: 1rem;
    }

    .bluecg-stat {
        display: grid;
        gap: .2rem;
        align-content: center;
        min-height: 5rem;
        padding: .9rem;
    }

    .bluecg-stat::after {
        display: none;
    }

    .bluecg-stat span {
        color: var(--bcg-muted);
        font-size: .76rem;
        font-weight: 900;
        line-height: 1.25;
        text-transform: uppercase;
    }

    .bluecg-stat strong {
        color: var(--bcg-teal);
        font-size: 1.16rem;
        font-weight: 900;
        line-height: 1.25;
        overflow-wrap: anywhere;
    }

    .bluecg-profile {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        gap: 1rem;
        align-items: center;
        padding: 1rem;
        border: 1px solid var(--bcg-line);
        border-radius: var(--bcg-radius-lg);
        background: linear-gradient(135deg, var(--bcg-surface-solid), color-mix(in srgb, var(--bcg-teal) 8%, white));
    }

    .bluecg-avatar {
        display: grid;
        place-items: center;
        inline-size: 4rem;
        block-size: 4rem;
        border-radius: var(--bcg-radius-md);
        background: linear-gradient(135deg, var(--bcg-teal), var(--bcg-amber));
        color: white;
        font-size: 1.4rem;
        font-weight: 900;
        box-shadow: var(--bcg-shadow-sm);
        transform: none;
    }

    .bluecg-profile h3 {
        margin: 0 0 .15rem;
        font-family: var(--bcg-font-display);
        font-size: 1.25rem;
        font-weight: 900;
        overflow-wrap: anywhere;
    }

    .bluecg-profile p {
        margin: 0;
        overflow-wrap: anywhere;
    }

    .bluecg-menu-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 17rem), 1fr));
        gap: 1rem;
    }

    .bluecg-menu-item {
        position: relative;
        display: grid;
        align-content: start;
        gap: .45rem;
        min-height: 8rem;
        padding: 1rem 2.4rem 1rem 1rem;
        border: 1px solid var(--bcg-line);
        border-radius: var(--bcg-radius-lg);
        background: var(--bcg-surface);
        color: var(--bcg-ink);
        text-decoration: none;
        box-shadow: var(--bcg-shadow-sm);
        transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
    }

    .bluecg-menu-item::after {
        position: absolute;
        inset-inline-end: 1rem;
        inset-block-start: 1rem;
        content: ">";
        color: var(--bcg-teal);
        font-weight: 900;
    }

    .bluecg-menu-item:hover {
        border-color: color-mix(in srgb, var(--bcg-teal) 25%, transparent);
        box-shadow: var(--bcg-shadow-md);
        transform: translateY(-2px);
    }

    .bluecg-menu-item strong {
        font-size: 1.05rem;
        font-weight: 900;
        overflow-wrap: anywhere;
    }

    .bluecg-menu-item span {
        color: var(--bcg-muted);
        font-size: .9rem;
        line-height: 1.5;
        text-wrap: pretty;
    }

    .bluecg-timeline {
        display: grid;
        gap: .8rem;
        margin-block: 1rem;
    }

    .bluecg-step {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        gap: .75rem;
        align-items: start;
        padding: .85rem;
        border: 1px solid var(--bcg-line);
        border-radius: var(--bcg-radius-md);
        background: color-mix(in srgb, var(--bcg-surface-solid) 78%, transparent);
    }

    .bluecg-step-mark {
        display: grid;
        place-items: center;
        inline-size: 2rem;
        block-size: 2rem;
        border-radius: 999px;
        background: var(--bcg-teal);
        color: white;
        font-weight: 900;
    }

    .bluecg-step h3 {
        margin: 0 0 .15rem;
        font-size: 1rem;
        font-weight: 900;
    }

    .bluecg-step p {
        margin: 0;
    }

    .bluecg-table-wrap {
        position: relative;
        margin-block: 1rem;
        overflow: auto;
        border: 1px solid var(--bcg-line);
        border-radius: var(--bcg-radius-lg);
        background: var(--bcg-surface);
        box-shadow: var(--bcg-shadow-sm);
        scrollbar-gutter: stable;
        scrollbar-color: color-mix(in srgb, var(--bcg-teal) 52%, transparent) transparent;
        -webkit-overflow-scrolling: touch;
    }

    .bluecg-table {
        width: 100%;
        min-width: 44rem;
        border-collapse: separate;
        border-spacing: 0;
        color: var(--bcg-ink-soft);
        font-size: .9rem;
    }

    .bluecg-table th,
    .bluecg-table td {
        padding: .75rem .85rem;
        border-bottom: 1px solid var(--bcg-line);
        vertical-align: top;
        overflow-wrap: anywhere;
    }

    .bluecg-table th {
        position: sticky;
        top: 0;
        z-index: 1;
        background: linear-gradient(180deg, var(--bcg-surface-solid), var(--bcg-surface-2));
        color: var(--bcg-ink);
        font-size: .78rem;
        font-weight: 900;
        line-height: 1.25;
        text-transform: uppercase;
    }

    .bluecg-table td {
        background: color-mix(in srgb, var(--bcg-surface-solid) 78%, transparent);
    }

    .bluecg-table tbody tr:nth-child(even) td {
        background: color-mix(in srgb, var(--bcg-teal) 5%, white);
    }

    .bluecg-table tbody tr:hover td,
    .bluecg-table tbody tr.bluecg-row-active td {
        background: color-mix(in srgb, var(--bcg-amber) 12%, white);
    }

    .bluecg-table .bluecg-button,
    .bluecg-table .bluecg-link-button,
    .bluecg-table .bluecg-mini-button {
        width: auto;
        min-height: var(--bcg-compact-control-h);
        padding-inline: .7rem;
        font-size: .8rem;
    }

    .bluecg-table .bluecg-textarea {
        min-height: 5.5rem;
    }

    .bluecg-link {
        color: var(--bcg-teal);
        font-weight: 900;
        text-decoration-thickness: 1px;
        text-underline-offset: .18em;
        overflow-wrap: anywhere;
    }

    .bluecg-link:hover {
        color: var(--bcg-amber);
    }

    .bluecg-empty {
        display: grid;
        place-items: center;
        min-height: 4.4rem;
        width: 100%;
        padding: 1rem;
        border: 1px dashed var(--bcg-line-strong);
        border-radius: var(--bcg-radius-md);
        background: color-mix(in srgb, var(--bcg-surface-solid) 78%, transparent);
        color: var(--bcg-muted);
        font-weight: 800;
        text-align: center;
    }

    .bluecg-pagination,
    .bluecg-pagination-links {
        display: flex;
        flex-wrap: wrap;
        gap: .45rem;
        align-items: center;
    }

    .bluecg-pagination {
        justify-content: space-between;
        margin-block-start: 1rem;
        padding: .75rem;
        border: 1px solid var(--bcg-line);
        border-radius: var(--bcg-radius-md);
        background: var(--bcg-surface);
    }

    .bluecg-pagination-info {
        color: var(--bcg-muted);
        font-size: .86rem;
        line-height: 1.35;
    }

    .bluecg-pagination > a,
    .bluecg-pagination > span,
    .bluecg-pagination-links a {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-height: var(--bcg-compact-control-h);
        padding: .45rem .7rem;
        border: 1px solid var(--bcg-line);
        border-radius: var(--bcg-radius-sm);
        background: var(--bcg-surface-solid);
        color: var(--bcg-muted);
        font-weight: 900;
        text-decoration: none;
    }

    .bluecg-pagination > span,
    .bluecg-pagination a:hover,
    .bluecg-pagination-links a:hover {
        border-color: color-mix(in srgb, var(--bcg-teal) 28%, transparent);
        background: color-mix(in srgb, var(--bcg-teal) 9%, white);
        color: var(--bcg-teal);
    }

    .bluecg-form-card,
    .bluecg-admin-upload-card,
    .bluecg-editor-preview,
    .bluecg-upload-result,
    .bluecg-admin-image-preview,
    .bluecg-file-status {
        display: grid;
        gap: .75rem;
        padding: 1rem;
        border: 1px solid var(--bcg-line);
        border-radius: var(--bcg-radius-lg);
        background: color-mix(in srgb, var(--bcg-surface-solid) 82%, transparent);
    }

    .bluecg-editor-preview {
        min-height: 4.5rem;
        overflow: auto;
        border-style: dashed;
    }

    .bluecg-admin-image-preview[hidden],
    .bluecg-field[hidden],
    .bluecg-field.is-hidden {
        display: none !important;
    }

    .bluecg-admin-image-preview img,
    .bluecg-upload-result img {
        max-height: 18rem;
        border-radius: var(--bcg-radius-md);
        object-fit: contain;
    }

    .bluecg-upload-result input {
        width: 100%;
        min-height: var(--bcg-control-h);
        padding: .65rem .75rem;
        border: 1px solid var(--bcg-line-strong);
        border-radius: var(--bcg-radius-sm);
        background: var(--bcg-surface-solid);
        color: var(--bcg-ink);
        font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace;
    }

    .bluecg-file-status {
        margin-block-start: .5rem;
        gap: .45rem;
        color: var(--bcg-muted);
        font-size: .84rem;
    }

    .bluecg-file-status.is-error {
        border-color: color-mix(in srgb, var(--bcg-danger) 28%, transparent);
        background: var(--bcg-danger-bg);
        color: var(--bcg-danger);
    }

    .bluecg-file-status ul {
        display: grid;
        gap: .35rem;
        margin: 0;
        padding: 0;
        list-style: none;
    }

    .bluecg-file-status li {
        display: flex;
        gap: .6rem;
        justify-content: space-between;
        min-width: 0;
        padding: .42rem .55rem;
        border-radius: var(--bcg-radius-xs);
        background: color-mix(in srgb, var(--bcg-amber) 8%, white);
    }

    .bluecg-file-status li span {
        min-width: 0;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .bluecg-file-status li small {
        flex: 0 0 auto;
        color: var(--bcg-muted);
    }

    .bluecg-divider {
        height: 1px;
        margin-block: 1rem;
        background: var(--bcg-line);
    }

    .bluecg-inline-form {
        display: inline-grid;
        gap: .45rem;
    }

    .bluecg-key-box {
        padding: .8rem;
        font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace;
        color: var(--bcg-ink);
        overflow-wrap: anywhere;
    }

    .bluecg-footer {
        margin-block-start: 1.25rem;
        color: var(--bcg-muted);
        font-size: .84rem;
        text-align: center;
    }

    .bluecg-turnstile {
        display: flex;
        justify-content: center;
        min-height: 4.4rem;
    }
}

@media all {
    .bluecg-event-banner {
        margin: 0 0 1rem;
    }

    .bluecg-event-banner img {
        display: block;
        width: 100%;
        max-height: 24rem;
        border: 1px solid var(--bcg-line);
        border-radius: var(--bcg-radius-lg);
        object-fit: cover;
        box-shadow: var(--bcg-shadow-sm);
    }

    .bluecg-event-text {
        line-height: 1.78;
        text-wrap: pretty;
    }

    .bluecg-content-image {
        display: grid;
        justify-items: center;
        margin: .85rem 0;
    }

    .bluecg-content-image img {
        max-width: min(100%, 48rem);
        max-height: 34rem;
        border: 1px solid var(--bcg-line);
        border-radius: var(--bcg-radius-lg);
        background: var(--bcg-surface-solid);
        object-fit: contain;
        box-shadow: var(--bcg-shadow-sm);
    }

    .bluecg-content-video {
        position: relative;
        width: min(100%, 48rem);
        margin: .85rem auto;
        overflow: hidden;
        border: 1px solid var(--bcg-line);
        border-radius: var(--bcg-radius-lg);
        background: #151210;
        aspect-ratio: 16 / 9;
        box-shadow: var(--bcg-shadow-md);
    }

    .bluecg-content-video iframe {
        width: 100%;
        height: 100%;
        border: 0;
    }

    .bluecg-content-center {
        text-align: center;
    }

    .bluecg-content-underline {
        text-decoration: underline;
        text-underline-offset: .16em;
    }

    .bluecg-showcase-panel .bluecg-category-nav,
    .bluecg-category-nav {
        justify-content: flex-start;
    }

    .bluecg-showcase-grid,
    .bluecg-vote-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 17rem), 1fr));
        gap: 1rem;
        align-items: stretch;
    }

    .bluecg-showcase-card,
    .bluecg-vote-card,
    .bluecg-work-card {
        min-width: 0;
    }

    .bluecg-showcase-card,
    .bluecg-vote-card {
        padding: .72rem;
    }

    .bluecg-showcase-body,
    .bluecg-vote-card-body {
        display: grid;
        gap: .55rem;
    }

    .bluecg-showcase-head,
    .bluecg-vote-card-head {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        gap: .6rem;
        align-items: start;
    }

    .bluecg-showcase-head h3,
    .bluecg-vote-card h3 {
        margin: 0;
        font-size: 1.02rem;
    }

    .bluecg-showcase-concept,
    .bluecg-vote-concept {
        display: -webkit-box;
        min-height: 3em;
        margin: 0;
        overflow: hidden;
        color: var(--bcg-ink-soft);
        font-size: .86rem;
        line-height: 1.55;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 3;
    }

    .bluecg-vote-concept {
        -webkit-line-clamp: 2;
    }

    .bluecg-author-line,
    .bluecg-vote-author {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr) auto;
        gap: .35rem .55rem;
        align-items: center;
        margin: .42rem 0 0;
        padding: .45rem .55rem;
        border: 1px solid var(--bcg-line);
        border-radius: var(--bcg-radius-sm);
        background: color-mix(in srgb, var(--bcg-surface-solid) 74%, transparent);
        color: var(--bcg-muted);
        font-size: .78rem;
    }

    .bluecg-author-line strong {
        color: var(--bcg-ink);
        overflow-wrap: anywhere;
    }

    .bluecg-vote-actions {
        display: grid;
        grid-template-columns: auto minmax(7rem, 1fr);
        gap: .55rem;
        align-items: center;
    }

    .bluecg-vote-actions form,
    .bluecg-vote-actions .bluecg-button,
    .bluecg-vote-actions .bluecg-link-button,
    .bluecg-vote-actions .bluecg-pill {
        width: 100%;
    }

    .bluecg-vote-card.is-voted {
        border-color: color-mix(in srgb, var(--bcg-teal) 32%, transparent);
        background: linear-gradient(180deg, color-mix(in srgb, var(--bcg-teal) 8%, white), var(--bcg-surface-solid));
    }

    .bluecg-work-thumb,
    .bluecg-work-gallery,
    .bluecg-gallery-main {
        min-width: 0;
    }

    .bluecg-work-gallery {
        display: grid;
        gap: .5rem;
    }

    .bluecg-work-gallery.is-empty,
    .bluecg-gallery-main,
    .bluecg-showcase-media {
        display: grid;
        place-items: center;
        min-height: 9rem;
        border: 1px solid var(--bcg-line);
        border-radius: var(--bcg-radius-md);
        background:
            linear-gradient(135deg, rgba(255, 255, 255, .8), rgba(248, 240, 223, .78)),
            repeating-linear-gradient(45deg, rgba(36, 120, 117, .055) 0 .4rem, transparent .4rem .8rem);
        color: var(--bcg-muted);
        font-weight: 900;
        overflow: hidden;
    }

    .bluecg-gallery-main {
        position: relative;
        width: 100%;
        padding: 0;
        cursor: zoom-in;
        aspect-ratio: 4 / 3;
    }

    .bluecg-gallery-main img,
    .bluecg-showcase-media img,
    .bluecg-work-thumb img {
        width: 100%;
        height: 100%;
        object-fit: contain;
    }

    .bluecg-gallery-counter {
        position: absolute;
        inset: .45rem .45rem auto auto;
        min-width: 2.35rem;
        padding: .15rem .45rem;
        border-radius: 999px;
        background: rgba(22, 18, 14, .72);
        color: white;
        font-size: .68rem;
        font-weight: 900;
    }

    .bluecg-gallery-controls {
        display: grid;
        grid-template-columns: 2.5rem minmax(0, 1fr) 2.5rem;
        gap: .45rem;
        align-items: center;
    }

    .bluecg-gallery-controls > button,
    .bluecg-gallery-thumbs button {
        display: grid;
        place-items: center;
        width: 2.5rem;
        height: 2.5rem;
        padding: 0;
        border: 1px solid var(--bcg-line);
        border-radius: var(--bcg-radius-sm);
        background: var(--bcg-surface-solid);
        color: var(--bcg-teal);
        font-weight: 900;
    }

    .bluecg-gallery-thumbs {
        display: flex;
        gap: .35rem;
        min-width: 0;
        overflow-x: auto;
        scrollbar-width: none;
    }

    .bluecg-gallery-thumbs::-webkit-scrollbar {
        display: none;
    }

    .bluecg-gallery-thumbs button.active {
        border-color: var(--bcg-teal);
        box-shadow: var(--bcg-focus);
    }

    .bluecg-gallery-thumbs img {
        width: 100%;
        height: 100%;
        border-radius: calc(var(--bcg-radius-sm) - .2rem);
        object-fit: cover;
    }

    .bluecg-image-modal {
        position: fixed;
        inset: 0;
        z-index: 9999;
        display: none;
        place-items: center;
        padding: 1rem;
    }

    .bluecg-image-modal.is-open {
        display: grid;
    }

    .bluecg-image-modal-backdrop {
        position: absolute;
        inset: 0;
        background: rgba(15, 12, 10, .82);
        backdrop-filter: blur(8px);
    }

    .bluecg-image-modal-frame {
        position: relative;
        z-index: 1;
        display: grid;
        place-items: center;
        width: min(100%, 72rem);
        height: min(100%, 88vh);
        padding: 3rem;
        border: 1px solid rgba(255, 255, 255, .22);
        border-radius: var(--bcg-radius-lg);
        background: rgba(23, 19, 16, .78);
        box-shadow: var(--bcg-shadow-lg);
    }

    .bluecg-image-modal-img {
        max-width: 100%;
        max-height: 100%;
        border-radius: var(--bcg-radius-sm);
        object-fit: contain;
    }

    .bluecg-image-modal-close,
    .bluecg-image-modal-arrow {
        position: absolute;
        z-index: 2;
        display: grid;
        place-items: center;
        padding: 0;
        border: 1px solid rgba(255, 255, 255, .2);
        background: rgba(255, 253, 247, .94);
        color: var(--bcg-ink);
        font-weight: 900;
    }

    .bluecg-image-modal-close {
        inset-block-start: .75rem;
        inset-inline-end: .75rem;
        width: 2.5rem;
        height: 2.5rem;
        border-radius: 999px;
        font-size: 1.35rem;
    }

    .bluecg-image-modal-arrow {
        top: 50%;
        width: 2.75rem;
        height: 3.25rem;
        border-radius: var(--bcg-radius-sm);
        font-size: 2rem;
        transform: translateY(-50%);
    }

    .bluecg-image-modal-arrow.prev {
        left: .75rem;
    }

    .bluecg-image-modal-arrow.next {
        right: .75rem;
    }

    .bluecg-image-modal-counter {
        position: absolute;
        inset-block-end: .8rem;
        left: 50%;
        color: white;
        font-size: .84rem;
        font-weight: 900;
        transform: translateX(-50%);
    }

    body.bluecg-modal-open {
        overflow: hidden;
    }
}

@media all {
    .bluecg-login-page {
        display: grid;
        min-height: 100vh;
    }

    .bluecg-login-shell {
        display: grid;
        align-items: center;
        width: min(100% - 2rem, 29rem);
        min-height: 100vh;
    }

    .bluecg-login-panel {
        width: 100%;
    }

    .bluecg-login-panel .bluecg-panel-inner {
        padding: 1.2rem;
    }

    .bluecg-login-brand {
        display: grid;
        justify-items: center;
        gap: .7rem;
        margin-block-end: 1rem;
        text-align: center;
    }

    .bluecg-login-brand .bluecg-logo {
        inline-size: min(100%, 16rem);
        block-size: 4.45rem;
    }

    .bluecg-login-head {
        display: grid;
        gap: .35rem;
        margin-block-end: 1rem;
        text-align: center;
    }

    .bluecg-login-copy {
        display: grid;
        gap: .18rem;
        margin: 0;
        color: var(--bcg-muted);
        font-weight: 700;
    }

    .bluecg-login-copy span {
        color: var(--bcg-ink);
        font-size: 1rem;
        font-weight: 900;
    }

    .bluecg-login-tabs {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .bluecg-dashboard-menu .bluecg-menu-item[data-kind="admin"] {
        border-color: color-mix(in srgb, var(--bcg-rose) 26%, transparent);
    }

    .bluecg-admin-page .bluecg-brand.compact,
    .bluecg-member-page .bluecg-brand.compact,
    .bluecg-dashboard-page .bluecg-brand.compact {
        width: 100%;
    }

    .bluecg-admin-page .bluecg-kicker {
        border-color: color-mix(in srgb, var(--bcg-rose) 24%, transparent);
        background: color-mix(in srgb, var(--bcg-rose) 8%, white);
        color: var(--bcg-rose);
    }

    .bluecg-admin-page .bluecg-nav a:hover,
    .bluecg-admin-page .bluecg-nav a.active {
        border-color: color-mix(in srgb, var(--bcg-rose) 28%, transparent);
        background: color-mix(in srgb, var(--bcg-rose) 8%, white);
        color: var(--bcg-rose);
    }

    .bluecg-admin-page .bluecg-button,
    .bluecg-admin-page .bluecg-link-button {
        background: linear-gradient(180deg, #b96f77, var(--bcg-rose));
        box-shadow: 0 .55rem 1rem rgba(169, 93, 99, .20);
    }
}

@media all {
    .bluecg-meta {
        margin: 0;
        font-size: .9rem;
        line-height: 1.55;
        text-wrap: pretty;
    }

    .bluecg-user-card {
        padding: 1rem;
        text-align: center;
    }

    .bluecg-user-card strong {
        display: block;
        color: var(--bcg-teal);
        font-size: 1.15rem;
        font-weight: 900;
    }

    code {
        padding: .08rem .3rem;
        border-radius: .35rem;
        background: color-mix(in srgb, var(--bcg-ink) 8%, white);
        color: var(--bcg-ink);
        font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace;
    }

    @media (min-width: 821px) {
        .bluecg-nav {
            position: sticky;
            top: .75rem;
            z-index: 20;
        }

        .bluecg-login-page .bluecg-nav {
            position: static;
        }
    }

    @media (max-width: 820px) {
        .bluecg-shell,
        .bluecg-shell.wide,
        .bluecg-admin-page .bluecg-shell.wide,
        .bluecg-member-page .bluecg-shell.wide,
        .bluecg-dashboard-page .bluecg-shell.wide {
            width: 100%;
            padding-inline: .75rem;
        }

        .bluecg-brand.compact {
            grid-template-columns: 1fr;
            grid-template-areas:
                "logo"
                "kicker"
                "title"
                "subtitle";
            justify-items: center;
            text-align: center;
        }

        .bluecg-logo {
            inline-size: min(100%, 14.5rem);
            block-size: 4.05rem;
        }

        .bluecg-title {
            font-size: 1.55rem;
        }

        .bluecg-nav {
            flex-wrap: nowrap;
            justify-content: flex-start;
            overflow-x: auto;
            overscroll-behavior-inline: contain;
            scrollbar-width: none;
            scroll-snap-type: x proximity;
            -webkit-overflow-scrolling: touch;
        }

        .bluecg-nav::-webkit-scrollbar {
            display: none;
        }

        .bluecg-nav a {
            flex: 0 0 auto;
            min-height: var(--bcg-control-h);
            scroll-snap-align: start;
        }

        .bluecg-panel-inner {
            padding: .9rem;
        }

        .bluecg-heading,
        .bluecg-section-title {
            grid-template-columns: auto minmax(0, 1fr);
            gap: .65rem;
        }

        .bluecg-section-title {
            align-items: start;
        }

        .bluecg-hero {
            grid-template-columns: 1fr;
            padding: .95rem;
        }

        .bluecg-hero h2,
        .bluecg-hero-content h2 {
            font-size: 1.18rem;
        }

        .bluecg-profile {
            grid-template-columns: 1fr;
            justify-items: center;
            text-align: center;
        }

        .bluecg-menu-item {
            min-height: auto;
        }

        .bluecg-table {
            min-width: 38rem;
        }

        .bluecg-vote-grid,
        .bluecg-showcase-grid {
            grid-template-columns: minmax(0, 1fr);
        }

        .bluecg-vote-actions,
        .bluecg-showcase-head,
        .bluecg-vote-card-head {
            grid-template-columns: 1fr;
        }

        .bluecg-author-line,
        .bluecg-vote-author {
            grid-template-columns: auto minmax(0, 1fr);
        }

        .bluecg-author-line span:last-child,
        .bluecg-vote-author span:last-child {
            grid-column: 1 / -1;
        }

        .bluecg-image-modal-frame {
            height: min(100%, 84vh);
            padding: 3rem .8rem 2.3rem;
        }

        .bluecg-image-modal-arrow {
            top: auto;
            bottom: .7rem;
            width: 2.5rem;
            height: 2.5rem;
            font-size: 1.55rem;
            transform: none;
        }

        .bluecg-login-shell {
            width: min(100% - 1.25rem, 29rem);
            align-items: start;
            min-height: auto;
        }
    }

    @media (max-width: 430px) {
        .bluecg-shell,
        .bluecg-shell.wide,
        .bluecg-admin-page .bluecg-shell.wide,
        .bluecg-member-page .bluecg-shell.wide,
        .bluecg-dashboard-page .bluecg-shell.wide {
            padding-inline: .55rem;
        }

        .bluecg-title {
            font-size: 1.38rem;
        }

        .bluecg-panel-inner,
        .bluecg-login-panel .bluecg-panel-inner {
            padding: .75rem;
        }

        .bluecg-heading-badge {
            inline-size: 2.25rem;
            block-size: 2.25rem;
            font-size: .85rem;
        }

        .bluecg-table {
            min-width: 34rem;
        }

        .bluecg-choice {
            grid-template-columns: 1fr;
        }
    }

    @container (max-width: 34rem) {
        .bluecg-form-row,
        .bluecg-hero,
        .bluecg-section-title {
            grid-template-columns: 1fr;
        }
    }

    @media (prefers-reduced-motion: reduce) {
        *,
        *::before,
        *::after {
            animation-duration: .01ms !important;
            animation-iteration-count: 1 !important;
            scroll-behavior: auto !important;
            transition-duration: .01ms !important;
        }
    }
}

/* Local artwork final cascade */
@media all {
    :root {
        --bcg-art-page: url("bluecg-art-page-20260523.webp");
        --bcg-art-hero: url("bluecg-art-hero-20260523.webp");
        --bcg-art-hero-mobile: url("bluecg-art-hero-mobile-20260523.webp");
        --bcg-art-login: url("bluecg-art-login-20260523.webp");
        --bcg-art-ui: url("bluecg-art-ui-20260523.webp");
    }

    body.bluecg-page {
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .78), rgba(255, 249, 238, .92) 52%, rgba(239, 232, 221, .96)),
            radial-gradient(circle at 12% 4%, rgba(53, 163, 157, .18), transparent 27rem),
            radial-gradient(circle at 86% 8%, rgba(240, 200, 107, .2), transparent 24rem),
            var(--bcg-art-page) top center / min(1800px, 150vw) auto no-repeat,
            linear-gradient(180deg, #eef7f5 0%, #fcf6ea 48%, #f1eadf 100%);
    }

    body.bluecg-page::before {
        position: fixed;
        inset: 0;
        z-index: -1;
        display: block;
        content: "";
        pointer-events: none;
        background:
            linear-gradient(180deg, rgba(255, 255, 255, .24), rgba(255, 255, 255, .72) 58%, rgba(255, 255, 255, .86)),
            repeating-linear-gradient(90deg, rgba(36, 120, 117, .04) 0 1px, transparent 1px 2.2rem),
            repeating-linear-gradient(0deg, rgba(196, 135, 47, .032) 0 1px, transparent 1px 2.2rem);
        mask-image: linear-gradient(180deg, rgba(0, 0, 0, .88), rgba(0, 0, 0, .3) 62%, transparent);
    }

    .bluecg-brand.compact {
        position: relative;
        isolation: isolate;
        min-height: 7.25rem;
        overflow: clip;
        border-color: rgba(36, 120, 117, .18);
        background:
            linear-gradient(90deg, rgba(255, 254, 249, .95) 0 34%, rgba(255, 254, 249, .55) 56%, rgba(255, 250, 240, .08)),
            var(--bcg-art-hero) center 30% / cover no-repeat;
        box-shadow:
            0 1.25rem 3rem rgba(40, 31, 24, .12),
            inset 0 1px 0 rgba(255, 255, 255, .82);
    }

    .bluecg-brand.compact::after {
        position: absolute;
        inset: auto 0 0 auto;
        z-index: -1;
        display: block;
        width: min(42%, 22rem);
        height: 100%;
        content: "";
        pointer-events: none;
        background:
            linear-gradient(90deg, rgba(255, 254, 249, .86), rgba(255, 254, 249, .08)),
            radial-gradient(circle at 56% 44%, rgba(255, 255, 255, .34), transparent 52%);
        opacity: .72;
    }

    .bluecg-brand.compact > * {
        position: relative;
        z-index: 1;
    }

    .bluecg-brand.compact .bluecg-kicker,
    .bluecg-brand.compact .bluecg-title,
    .bluecg-brand.compact .bluecg-subtitle {
        max-width: 48rem;
    }

    .bluecg-brand.compact .bluecg-logo {
        background-color: rgba(7, 13, 18, .9);
        box-shadow:
            0 1rem 2rem rgba(8, 13, 18, .2),
            inset 0 0 0 1px rgba(255, 255, 255, .18);
    }

    .bluecg-nav,
    .bluecg-panel,
    .bluecg-card,
    .bluecg-form-card,
    .bluecg-stat,
    .bluecg-table-wrap,
    .bluecg-profile,
    .bluecg-menu-item {
        border-color: rgba(44, 92, 90, .15);
        box-shadow:
            0 1rem 2.4rem rgba(40, 31, 24, .1),
            inset 0 1px 0 rgba(255, 255, 255, .82);
    }

    .bluecg-panel.quest {
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .95), rgba(255, 249, 238, .9)),
            radial-gradient(circle at 100% 0, rgba(53, 163, 157, .12), transparent 18rem);
    }

    .bluecg-hero {
        position: relative;
        isolation: isolate;
        min-height: 11.5rem;
        align-items: end;
        padding: 1.15rem;
        border-color: rgba(36, 120, 117, .24);
        background:
            linear-gradient(90deg, rgba(255, 254, 249, .92) 0 34%, rgba(255, 254, 249, .42) 58%, rgba(255, 254, 249, .06)),
            linear-gradient(180deg, rgba(255, 255, 255, .12), rgba(20, 35, 43, .16)),
            var(--bcg-art-hero) center 30% / cover no-repeat;
        box-shadow:
            inset .34rem 0 0 var(--bcg-teal),
            inset 0 1px 0 rgba(255, 255, 255, .84),
            0 1rem 2.4rem rgba(31, 24, 18, .1);
    }

    .bluecg-hero::before {
        position: absolute;
        inset: 0;
        z-index: -1;
        display: block;
        content: "";
        pointer-events: none;
        background:
            radial-gradient(circle at 20% 22%, rgba(255, 255, 255, .72), transparent 16rem),
            linear-gradient(115deg, rgba(36, 120, 117, .08), transparent 54%, rgba(196, 135, 47, .12));
    }

    .bluecg-hero::after {
        position: absolute;
        inset: auto 1rem 1rem auto;
        z-index: -1;
        display: block;
        width: clamp(6rem, 16vw, 12rem);
        height: clamp(6rem, 16vw, 12rem);
        content: "";
        pointer-events: none;
        background: radial-gradient(circle, rgba(255, 255, 255, .28), transparent 68%);
    }

    .bluecg-hero > * {
        position: relative;
        z-index: 1;
    }

    .bluecg-login-page {
        min-height: 100vh;
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .74), rgba(244, 241, 234, .9)),
            var(--bcg-art-page) center / cover fixed no-repeat,
            linear-gradient(180deg, #edf8f5, #f8efe2);
    }

    .bluecg-login-panel {
        isolation: isolate;
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .96), rgba(255, 249, 238, .92)),
            radial-gradient(circle at 18% 0, rgba(53, 163, 157, .14), transparent 16rem);
    }

    .bluecg-panel.quest.bluecg-login-panel {
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .96), rgba(255, 249, 238, .92)),
            radial-gradient(circle at 18% 0, rgba(53, 163, 157, .14), transparent 16rem);
    }

    .bluecg-login-panel .bluecg-panel-inner {
        position: relative;
        z-index: 1;
    }

    .bluecg-login-brand {
        width: 100%;
    }

    .bluecg-login-brand .bluecg-logo {
        inline-size: min(100%, 16rem);
        min-inline-size: min(14rem, 100%);
    }

    @media (min-width: 920px) {
        .bluecg-login-shell {
            width: min(100% - 2rem, 66rem);
        }

        .bluecg-login-panel {
            display: grid;
            grid-template-columns: minmax(22rem, .92fr) minmax(25rem, 1fr);
            min-height: 43rem;
            background:
                linear-gradient(90deg, rgba(11, 35, 44, .1), rgba(255, 254, 249, .96) 46%),
                var(--bcg-art-login) 20% center / cover no-repeat;
        }

        .bluecg-panel.quest.bluecg-login-panel {
            background:
                linear-gradient(90deg, rgba(11, 35, 44, .1), rgba(255, 254, 249, .96) 46%),
                var(--bcg-art-login) 20% center / cover no-repeat;
        }

        .bluecg-login-panel::after {
            position: relative;
            inset: auto;
            grid-column: 1;
            grid-row: 1;
            display: block;
            height: auto;
            min-height: 100%;
            content: "";
            pointer-events: none;
            background:
                linear-gradient(90deg, rgba(7, 22, 28, .08), rgba(255, 254, 249, .16) 68%, rgba(255, 254, 249, .76)),
                linear-gradient(180deg, rgba(255, 255, 255, .08), rgba(13, 34, 42, .18));
        }

        .bluecg-login-panel .bluecg-panel-inner {
            grid-column: 2;
            grid-row: 1;
            align-self: stretch;
            display: grid;
            align-content: center;
            margin: .72rem;
            padding: clamp(1.35rem, 2.8vw, 2rem);
            border: 1px solid rgba(255, 255, 255, .72);
            border-radius: calc(var(--bcg-radius-xl) - .35rem);
            background: rgba(255, 254, 249, .88);
            box-shadow:
                0 1.1rem 2.6rem rgba(31, 24, 18, .13),
                inset 0 1px 0 rgba(255, 255, 255, .88);
        }
    }

    @media (max-width: 820px) {
        body.bluecg-page {
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .88), rgba(255, 249, 238, .96) 58%, rgba(239, 232, 221, .98)),
                var(--bcg-art-hero-mobile) top center / 100% auto no-repeat,
                linear-gradient(180deg, #eef7f5 0%, #fcf6ea 48%, #f1eadf 100%);
        }

        .bluecg-brand.compact,
        .bluecg-hero {
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .86), rgba(255, 250, 240, .52)),
                var(--bcg-art-hero-mobile) center top / cover no-repeat;
        }

        .bluecg-brand.compact {
            min-height: auto;
        }

        .bluecg-hero {
            align-items: start;
            min-height: 10.5rem;
        }

        .bluecg-login-page {
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .78), rgba(255, 249, 238, .95)),
                var(--bcg-art-hero-mobile) top center / 100% auto no-repeat,
                linear-gradient(180deg, #eef7f5, #f8efe2);
        }
    }
}

@media all {
    .bluecg-brand.compact.bluecg-login-brand {
        grid-template-columns: minmax(0, 1fr);
        grid-template-areas:
            "logo"
            "kicker"
            "title"
            "subtitle";
        justify-items: center;
        text-align: center;
    }

    .bluecg-brand.compact.bluecg-login-brand .bluecg-logo {
        inline-size: min(100%, 16rem);
        width: min(100%, 16rem);
        min-inline-size: 0;
        max-inline-size: 16rem;
    }
}

/* Login composition corrective pass */
@media all {
    body.bluecg-login-page {
        display: grid;
        min-height: 100svh;
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .72), rgba(255, 250, 240, .94) 48%, rgba(238, 231, 222, .98)),
            radial-gradient(circle at 50% -8rem, rgba(53, 163, 157, .22), transparent 28rem),
            var(--bcg-art-hero) top center / min(1800px, 150vw) auto no-repeat,
            linear-gradient(180deg, #eef7f5, #f6efe2);
        background-attachment: scroll;
    }

    body.bluecg-login-page::before {
        position: fixed;
        inset: 0;
        z-index: -1;
        display: block;
        content: "";
        pointer-events: none;
        background:
            linear-gradient(180deg, rgba(255, 255, 255, .42), rgba(255, 255, 255, .82) 42%, rgba(255, 255, 255, .92)),
            repeating-linear-gradient(90deg, rgba(36, 120, 117, .035) 0 1px, transparent 1px 2.35rem);
        mask-image: linear-gradient(180deg, rgba(0, 0, 0, .82), rgba(0, 0, 0, .28) 68%, transparent);
    }

    .bluecg-login-shell {
        width: min(100% - 2rem, 44rem);
        min-height: 100svh;
        padding-block: clamp(.75rem, 2vh, 1.2rem);
        align-items: center;
    }

    .bluecg-login-panel,
    .bluecg-panel.quest.bluecg-login-panel {
        display: block;
        width: 100%;
        min-height: 0;
        border-color: rgba(36, 120, 117, .18);
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .94), rgba(255, 250, 240, .9));
        backdrop-filter: blur(18px) saturate(1.08);
        box-shadow:
            0 1.4rem 3.4rem rgba(40, 31, 24, .16),
            inset 0 1px 0 rgba(255, 255, 255, .88);
    }

    .bluecg-login-panel::after {
        display: none;
    }

    .bluecg-login-panel .bluecg-panel-inner {
        display: block;
        margin: 0;
        padding: clamp(1rem, 2vw, 1.2rem);
        border: 0;
        border-radius: 0;
        background: transparent;
        box-shadow: none;
    }

    .bluecg-brand.compact.bluecg-login-brand,
    .bluecg-login-brand {
        display: grid;
        grid-template-columns: minmax(0, 1fr);
        grid-template-areas:
            "logo"
            "kicker";
        justify-items: center;
        gap: .55rem;
        width: 100%;
        min-height: clamp(7.15rem, 14vw, 8rem);
        margin-block-end: .78rem;
        padding: clamp(.72rem, 2vw, .9rem);
        border: 1px solid rgba(36, 120, 117, .2);
        border-radius: var(--bcg-radius-lg);
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .2), rgba(255, 249, 236, .74)),
            linear-gradient(90deg, rgba(255, 254, 249, .66), rgba(255, 254, 249, .04) 34%, rgba(255, 250, 240, .36)),
            var(--bcg-art-hero) center 31% / cover no-repeat;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .72),
            0 .9rem 1.8rem rgba(31, 24, 18, .1);
        text-align: center;
    }

    .bluecg-brand.compact.bluecg-login-brand::before {
        height: 3px;
    }

    .bluecg-brand.compact.bluecg-login-brand::after {
        display: none;
    }

    .bluecg-brand.compact.bluecg-login-brand .bluecg-logo,
    .bluecg-login-brand .bluecg-logo {
        grid-area: logo;
        inline-size: min(100%, 15.5rem);
        width: min(100%, 15.5rem);
        block-size: 3.75rem;
        min-inline-size: 0;
        max-inline-size: 15.5rem;
        border-color: rgba(255, 255, 255, .82);
        background-color: rgba(7, 13, 18, .9);
        box-shadow:
            0 .85rem 1.6rem rgba(8, 13, 18, .2),
            inset 0 0 0 1px rgba(255, 255, 255, .16);
    }

    .bluecg-brand.compact.bluecg-login-brand .bluecg-kicker,
    .bluecg-login-brand .bluecg-kicker {
        grid-area: kicker;
        max-width: 100%;
        min-height: 1.72rem;
        padding-inline: .78rem;
        background: rgba(239, 250, 247, .92);
        box-shadow:
            0 .45rem .9rem rgba(31, 119, 116, .09),
            inset 0 1px 0 rgba(255, 255, 255, .8);
    }

    .bluecg-login-head {
        margin-block-end: .78rem;
    }

    .bluecg-login-copy {
        gap: .12rem;
        color: var(--bcg-muted);
        font-size: .9rem;
    }

    .bluecg-login-copy span {
        font-size: 1rem;
        line-height: 1.28;
    }

    .bluecg-login-form {
        gap: .68rem .78rem;
    }

    .bluecg-login-form .bluecg-field {
        gap: .34rem;
    }

    .bluecg-login-form label,
    .bluecg-login-form .bluecg-label,
    .bluecg-login-tabs legend {
        font-size: .95rem;
        line-height: 1.35;
    }

    .bluecg-login-tabs {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: .55rem;
        margin-block-end: .1rem;
    }

    .bluecg-login-tabs label {
        min-height: 2.6rem;
        padding: .5rem .65rem;
        font-size: .98rem;
        line-height: 1.2;
    }

    .bluecg-login-form input,
    .bluecg-login-form select {
        min-height: 2.65rem;
    }

    .bluecg-login-form .bluecg-button {
        margin-block-start: .12rem;
        min-height: 2.85rem;
    }

    .bluecg-turnstile {
        display: flex;
        justify-content: center;
    }

    .bluecg-turnstile-preview {
        display: grid;
        place-items: center;
        width: min(100%, 19rem);
        min-height: 4.2rem;
        border: 1px solid rgba(65, 54, 43, .18);
        border-radius: .35rem;
        background: rgba(255, 255, 255, .72);
        color: var(--bcg-muted);
        font-size: .86rem;
        font-weight: 800;
    }

    @media (min-width: 920px) {
        .bluecg-login-shell {
            width: min(100% - 2rem, 44rem);
        }

        .bluecg-login-panel,
        .bluecg-panel.quest.bluecg-login-panel {
            display: block;
            min-height: 0;
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .94), rgba(255, 250, 240, .9));
        }

        .bluecg-login-panel .bluecg-panel-inner {
            display: block;
            margin: 0;
            padding: 1.1rem 1.2rem 1.15rem;
            border: 0;
            border-radius: 0;
            background: transparent;
            box-shadow: none;
        }

        .bluecg-login-form {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            align-items: end;
        }

        .bluecg-login-form > input[type="hidden"],
        .bluecg-login-tabs {
            grid-column: 1 / -1;
        }

        .bluecg-login-form > div:has(.bluecg-turnstile) {
            grid-column: 1;
        }

        .bluecg-login-form > .bluecg-button {
            grid-column: 2;
            align-self: end;
            margin-block-start: 1.58rem;
        }

        .bluecg-turnstile {
            justify-content: flex-start;
        }
    }

    @media (max-width: 820px) {
        body.bluecg-login-page {
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .82), rgba(255, 250, 240, .96) 48%, rgba(238, 231, 222, .98)),
                var(--bcg-art-hero-mobile) top center / 100% auto no-repeat,
                linear-gradient(180deg, #eef7f5, #f6efe2);
        }

        .bluecg-login-shell {
            width: min(100% - 1.1rem, 34rem);
            min-height: 100svh;
            padding-block: .8rem;
        }

        .bluecg-login-form {
            display: grid;
            grid-template-columns: minmax(0, 1fr);
        }

        .bluecg-login-form > .bluecg-button,
        .bluecg-login-form > div:has(.bluecg-turnstile) {
            grid-column: 1;
        }

        .bluecg-turnstile {
            justify-content: center;
        }

        .bluecg-brand.compact.bluecg-login-brand,
        .bluecg-login-brand {
            min-height: 7.7rem;
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .18), rgba(255, 249, 236, .76)),
                linear-gradient(90deg, rgba(255, 254, 249, .46), rgba(255, 254, 249, .02) 45%, rgba(255, 250, 240, .36)),
                var(--bcg-art-hero-mobile) center 15% / cover no-repeat;
        }
    }

    @media (max-width: 430px) {
        .bluecg-login-panel .bluecg-panel-inner {
            padding: .78rem;
        }

        .bluecg-brand.compact.bluecg-login-brand,
        .bluecg-login-brand {
            min-height: 7.6rem;
            padding: .72rem;
        }

        .bluecg-brand.compact.bluecg-login-brand .bluecg-logo,
        .bluecg-login-brand .bluecg-logo {
            inline-size: min(100%, 14rem);
            width: min(100%, 14rem);
            block-size: 3.85rem;
        }
    }
}

/* Admin and member surface correction */
@media all {
    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact {
        position: relative;
        isolation: isolate;
        min-height: 0;
        padding: .85rem 1rem;
        border-color: rgba(36, 120, 117, .16);
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .96), rgba(252, 247, 237, .9)),
            linear-gradient(90deg, rgba(36, 120, 117, .08), transparent 38%, rgba(196, 135, 47, .08));
        box-shadow:
            0 .9rem 2rem rgba(40, 31, 24, .1),
            inset 0 1px 0 rgba(255, 255, 255, .86);
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact::after {
        position: absolute;
        inset: 0 0 0 auto;
        z-index: 0;
        display: block;
        width: min(42%, 34rem);
        height: auto;
        content: "";
        pointer-events: none;
        background:
            linear-gradient(90deg, rgba(255, 254, 249, .98), rgba(255, 254, 249, .64) 22%, rgba(255, 254, 249, .06)),
            var(--bcg-art-hero) center 33% / cover no-repeat;
        opacity: .42;
        mask-image: linear-gradient(90deg, transparent, #000 28%);
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact > * {
        position: relative;
        z-index: 1;
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact .bluecg-logo {
        inline-size: clamp(11.5rem, 16vw, 13.5rem);
        block-size: clamp(3.2rem, 4.4vw, 3.75rem);
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact .bluecg-title {
        font-size: clamp(1.55rem, 2.4vw, 2.15rem);
        line-height: 1.12;
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact .bluecg-kicker {
        min-height: 1.65rem;
        padding: .22rem .7rem;
        font-size: .76rem;
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact .bluecg-subtitle {
        font-size: .9rem;
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-nav {
        justify-content: center;
        gap: .28rem;
        width: fit-content;
        max-width: 100%;
        margin-inline: auto;
        margin-block-end: .85rem;
        padding: .28rem;
        border-radius: var(--bcg-radius-md);
        background: rgba(255, 254, 249, .86);
        box-shadow:
            0 .7rem 1.6rem rgba(40, 31, 24, .08),
            inset 0 1px 0 rgba(255, 255, 255, .86);
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-nav a {
        min-height: 2.65rem;
        padding: .5rem .85rem;
        border-radius: .75rem;
        font-size: .88rem;
    }

    a.bluecg-card,
    a.bluecg-card:hover,
    a.bluecg-card:focus-visible {
        color: inherit;
        text-decoration: none;
    }

    a.bluecg-card h3,
    a.bluecg-card .bluecg-meta,
    a.bluecg-card * {
        text-decoration: none;
    }

    .bluecg-admin-strip {
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 12.25rem), 1fr));
        gap: .85rem;
    }

    .bluecg-admin-strip .bluecg-card {
        min-height: 7rem;
        padding: .95rem 1rem;
        border-radius: var(--bcg-radius-md);
    }

    @media (max-width: 820px) {
        body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact {
            padding: .9rem;
        }

        body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact::after {
            inset: 0;
            width: 100%;
            opacity: .18;
            mask-image: linear-gradient(180deg, #000, transparent 78%);
        }

        body.bluecg-page:not(.bluecg-login-page) .bluecg-nav {
            width: 100%;
            justify-content: flex-start;
            margin-inline: 0;
        }
    }
}

/* Artwork de-duplication for content surfaces */
@media all {
    body.bluecg-page:not(.bluecg-login-page) {
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .66), rgba(255, 250, 240, .86) 54%, rgba(239, 232, 221, .92)),
            radial-gradient(circle at 10% 0, rgba(53, 163, 157, .13), transparent 24rem),
            radial-gradient(circle at 88% 0, rgba(240, 200, 107, .16), transparent 25rem),
            repeating-linear-gradient(90deg, rgba(36, 120, 117, .035) 0 1px, transparent 1px 2.35rem),
            var(--bcg-art-ui) top center / min(1800px, 150vw) auto no-repeat,
            linear-gradient(180deg, #eef6f3 0%, #fbf5ea 46%, #f0e8dc 100%);
    }

    body.bluecg-page:not(.bluecg-login-page)::before {
        background:
            linear-gradient(180deg, rgba(255, 255, 255, .34), rgba(255, 255, 255, .78) 58%, rgba(255, 255, 255, .9)),
            repeating-linear-gradient(0deg, rgba(196, 135, 47, .026) 0 1px, transparent 1px 2.2rem);
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact::after {
        width: min(34%, 28rem);
        opacity: .3;
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-hero {
        position: relative;
        isolation: isolate;
        min-height: 0;
        align-items: center;
        padding: 1rem 1.1rem;
        border-color: rgba(36, 120, 117, .18);
        background:
            linear-gradient(135deg, rgba(239, 250, 247, .92), rgba(255, 250, 236, .9)),
            repeating-linear-gradient(135deg, rgba(36, 120, 117, .055) 0 .45rem, transparent .45rem .9rem);
        box-shadow:
            inset .32rem 0 0 var(--bcg-teal),
            inset 0 1px 0 rgba(255, 255, 255, .86),
            0 .8rem 1.8rem rgba(31, 24, 18, .08);
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-hero::before {
        position: absolute;
        inset: 0;
        z-index: -1;
        display: block;
        content: "";
        pointer-events: none;
        background:
            radial-gradient(circle at 8% 16%, rgba(255, 255, 255, .72), transparent 13rem),
            radial-gradient(circle at 100% 0, rgba(53, 163, 157, .13), transparent 14rem),
            linear-gradient(90deg, rgba(255, 255, 255, .74), rgba(255, 255, 255, .22));
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-hero::after {
        display: none;
    }

    @media (max-width: 820px) {
        body.bluecg-page:not(.bluecg-login-page) {
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .78), rgba(255, 250, 240, .9) 52%, rgba(239, 232, 221, .95)),
                radial-gradient(circle at 18% -4rem, rgba(53, 163, 157, .14), transparent 18rem),
                radial-gradient(circle at 92% -3rem, rgba(240, 200, 107, .14), transparent 17rem),
                var(--bcg-art-ui) top center / auto 28rem no-repeat,
                linear-gradient(180deg, #eef6f3 0%, #fbf5ea 52%, #f0e8dc 100%);
        }

        body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact::after {
            opacity: .12;
        }

        body.bluecg-page:not(.bluecg-login-page) .bluecg-hero {
            align-items: start;
            min-height: 0;
            background:
                linear-gradient(135deg, rgba(239, 250, 247, .94), rgba(255, 250, 236, .92)),
                repeating-linear-gradient(135deg, rgba(36, 120, 117, .05) 0 .42rem, transparent .42rem .84rem);
        }
    }
}

/* Frontend UI final override layer */
@media all {
    body.bluecg-member-page .bluecg-shell.wide {
        width: min(100% - 1.5rem, 72rem);
    }

    body.bluecg-member-page .bluecg-brand.compact {
        min-height: 6.6rem;
        margin-bottom: .8rem;
        padding: 1rem 1.15rem;
        border-radius: 1.2rem;
    }

    body.bluecg-member-page .bluecg-brand.compact .bluecg-title {
        font-size: clamp(1.52rem, 2.25vw, 2.05rem);
        letter-spacing: .035em;
    }

    body.bluecg-member-page .bluecg-nav {
        gap: .35rem;
        margin-bottom: .85rem;
        padding: .42rem;
        border-radius: 1rem;
    }

    body.bluecg-member-page .bluecg-nav a {
        min-height: 2.38rem;
        padding: .42rem .78rem;
        border-radius: .72rem;
        font-size: .82rem;
    }

    body.bluecg-member-page .bluecg-nav a.active {
        background: linear-gradient(180deg, #f5cf74, #cf8526);
        color: #25170f;
    }

    body.bluecg-member-page .bluecg-panel-inner {
        padding: clamp(.95rem, 2vw, 1.35rem);
    }

    body.bluecg-member-page .bluecg-grid {
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
        gap: .95rem;
    }

    .bluecg-event-card {
        gap: .7rem;
        min-height: 100%;
    }

    .bluecg-event-summary {
        display: -webkit-box;
        min-height: 3.2em;
        overflow: hidden;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 3;
    }

    .bluecg-event-times {
        display: grid;
        gap: .32rem;
        padding: .65rem .72rem;
        border: 1px solid var(--bcg-line);
        border-radius: .8rem;
        background: color-mix(in srgb, var(--bcg-surface-solid) 72%, transparent);
        color: var(--bcg-muted);
        font-size: .82rem;
        line-height: 1.45;
    }

    .bluecg-event-category-card .bluecg-event-text:empty {
        display: none;
    }

    .bluecg-event-text {
        padding: .9rem 1rem;
        border-radius: .9rem;
        background: linear-gradient(180deg, rgba(255, 254, 249, .86), rgba(255, 249, 237, .72));
        color: var(--bcg-ink-soft);
        font-size: .92rem;
        line-height: 1.86;
    }

    .bluecg-showcase-grid {
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 22rem));
        justify-content: center;
        gap: 1rem;
    }

    .bluecg-vote-grid {
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 15.5rem), 18rem));
        justify-content: center;
        gap: 1rem;
    }

    .bluecg-showcase-card,
    .bluecg-vote-card {
        width: 100%;
        max-width: 22rem;
        border-radius: 1rem;
    }

    .bluecg-vote-card {
        max-width: 18rem;
    }

    .bluecg-gallery-main {
        aspect-ratio: 4 / 3;
        min-height: 8.8rem;
        max-height: 12rem;
    }

    .bluecg-vote-card .bluecg-gallery-main {
        min-height: 8rem;
        max-height: 10rem;
    }

    .bluecg-work-youtube .bluecg-content-video {
        width: 100%;
        margin: 0;
        box-shadow: none;
    }

    .bluecg-author-line,
    .bluecg-vote-author {
        grid-template-columns: auto minmax(0, 1fr);
        margin-top: .35rem;
        line-height: 1.42;
    }

    .bluecg-author-line span:last-child,
    .bluecg-vote-author span:last-child {
        grid-column: 1 / -1;
    }

    .bluecg-file-status li span {
        white-space: normal;
        overflow-wrap: anywhere;
    }

    .bluecg-status-pill {
        justify-content: center;
        min-width: 4.5rem;
    }

    .bluecg-status-pending {
        border-color: color-mix(in srgb, var(--bcg-amber) 28%, transparent);
        background: color-mix(in srgb, var(--bcg-amber-2) 22%, white);
    }

    .bluecg-status-approved {
        border-color: color-mix(in srgb, var(--bcg-teal) 28%, transparent);
        background: color-mix(in srgb, var(--bcg-teal) 14%, white);
    }

    .bluecg-status-rejected,
    .bluecg-status-disqualified {
        border-color: color-mix(in srgb, var(--bcg-rose) 28%, transparent);
        background: color-mix(in srgb, var(--bcg-rose) 12%, white);
    }

    .bluecg-results-table td,
    .bluecg-results-table th {
        vertical-align: middle;
    }

    .bluecg-results-table {
        min-width: 42rem;
    }

    .bluecg-results-table td:first-child {
        font-weight: 900;
        color: var(--bcg-amber);
        white-space: nowrap;
    }

    @media (max-width: 820px) {
        body.bluecg-member-page .bluecg-shell.wide {
            width: 100%;
            padding-inline: .6rem;
        }

        body.bluecg-member-page .bluecg-brand.compact {
            min-height: 0;
            padding: .85rem;
            text-align: center;
        }

        body.bluecg-member-page .bluecg-nav {
            flex-wrap: nowrap;
            justify-content: flex-start;
            overflow-x: auto;
            scrollbar-width: none;
        }

        body.bluecg-member-page .bluecg-nav::-webkit-scrollbar {
            display: none;
        }

        body.bluecg-member-page .bluecg-nav a {
            flex: 0 0 auto;
            min-height: 2.28rem;
            font-size: .78rem;
            white-space: nowrap;
        }

        body.bluecg-member-page .bluecg-grid,
        .bluecg-showcase-grid,
        .bluecg-vote-grid {
            grid-template-columns: 1fr;
            justify-items: stretch;
        }

        .bluecg-showcase-card,
        .bluecg-vote-card {
            max-width: none;
        }

        .bluecg-gallery-main,
        .bluecg-vote-card .bluecg-gallery-main {
            aspect-ratio: 16 / 10;
            max-height: 13rem;
        }

        .bluecg-vote-actions {
            grid-template-columns: 1fr;
        }

        .bluecg-event-text {
            padding: .78rem;
            font-size: .88rem;
            line-height: 1.75;
        }

        .bluecg-results-table {
            min-width: 36rem;
            font-size: .82rem;
        }
    }
}

/* Login UI polish active override */
@media all {
    body.bluecg-login-page {
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .7), rgba(255, 250, 240, .92) 48%, rgba(236, 226, 212, .98)),
            radial-gradient(circle at 50% -6rem, rgba(36, 120, 117, .2), transparent 26rem),
            var(--bcg-art-hero) top center / min(1900px, 155vw) auto no-repeat,
            linear-gradient(180deg, #edf7f4, #f7eddf);
    }

    body.bluecg-login-page .bluecg-login-shell {
        width: min(100% - 1.5rem, 41rem);
        padding-block: clamp(1rem, 3vh, 1.8rem);
    }

    body.bluecg-login-page .bluecg-login-panel,
    body.bluecg-login-page .bluecg-panel.quest.bluecg-login-panel {
        overflow: hidden;
        border: 1px solid rgba(63, 97, 87, .18);
        border-radius: 1.45rem;
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .96), rgba(255, 249, 238, .93));
        box-shadow:
            0 1.2rem 2.6rem rgba(40, 31, 24, .12),
            inset 0 1px 0 rgba(255, 255, 255, .92);
    }

    body.bluecg-login-page .bluecg-login-panel .bluecg-panel-inner {
        padding: clamp(.9rem, 2vw, 1.1rem);
    }

    body.bluecg-login-page .bluecg-login-brand,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand {
        position: relative;
        isolation: isolate;
        min-height: clamp(8rem, 18vw, 9.6rem);
        margin-block-end: .9rem;
        padding: 1rem;
        border: 1px solid rgba(36, 120, 117, .18);
        border-radius: 1.2rem;
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .14), rgba(255, 249, 236, .74) 72%, rgba(255, 249, 236, .9)),
            linear-gradient(90deg, rgba(255, 254, 249, .9), rgba(255, 254, 249, .16) 34%, rgba(255, 250, 240, .72)),
            var(--bcg-art-hero) center 26% / cover no-repeat;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .76),
            0 .75rem 1.4rem rgba(31, 24, 18, .08);
    }

    body.bluecg-login-page .bluecg-login-brand .bluecg-logo,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-logo {
        display: none;
    }

    body.bluecg-login-page .bluecg-login-brand .bluecg-kicker,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-kicker {
        position: absolute;
        right: 50%;
        bottom: .85rem;
        margin: 0;
        min-height: 2.25rem;
        padding: .48rem 1.1rem;
        border-color: rgba(36, 120, 117, .18);
        background:
            linear-gradient(180deg, rgba(255, 255, 255, .94), rgba(232, 249, 245, .92));
        color: #226c6a;
        font-size: clamp(.98rem, 2vw, 1.12rem);
        line-height: 1.15;
        transform: translateX(50%);
        white-space: nowrap;
    }

    body.bluecg-login-page .bluecg-login-head {
        margin-block: .1rem .85rem;
        text-align: center;
    }

    body.bluecg-login-page .bluecg-login-copy {
        margin: 0;
        color: #5f554e;
    }

    body.bluecg-login-page .bluecg-login-copy span {
        color: #29231f;
        font-size: 1.02rem;
        font-weight: 900;
    }

    body.bluecg-login-page .bluecg-login-copy small {
        color: #7b7068;
        font-size: .82rem;
        font-weight: 700;
    }

    body.bluecg-login-page .bluecg-login-form {
        gap: .72rem .78rem;
    }

    body.bluecg-login-page .bluecg-login-tabs {
        padding: .42rem;
        border-radius: 1rem;
        background: rgba(245, 237, 221, .7);
    }

    body.bluecg-login-page .bluecg-login-tabs label {
        min-height: 2.55rem;
        border-radius: .78rem;
        background: rgba(255, 254, 249, .75);
    }

    body.bluecg-login-page .bluecg-login-form input,
    body.bluecg-login-page .bluecg-login-form select {
        min-height: 2.65rem;
        border-radius: .78rem;
        background: rgba(255, 255, 255, .88);
    }

    body.bluecg-login-page .bluecg-login-form .bluecg-button {
        min-height: 2.85rem;
        border-radius: .9rem;
        letter-spacing: .08em;
    }

    @media (max-width: 820px) {
        body.bluecg-login-page {
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .78), rgba(255, 250, 240, .94) 42%, rgba(236, 226, 212, .98)),
                var(--bcg-art-hero-mobile) top center / 100% auto no-repeat,
                linear-gradient(180deg, #edf7f4, #f7eddf);
        }

        body.bluecg-login-page .bluecg-login-shell {
            width: min(100% - 1rem, 34rem);
            min-height: 100svh;
            padding-block: .75rem;
        }

        body.bluecg-login-page .bluecg-login-brand,
        body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand {
            min-height: 7.3rem;
            margin-bottom: .72rem;
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .1), rgba(255, 249, 236, .72) 70%, rgba(255, 249, 236, .9)),
                var(--bcg-art-hero-mobile) center 16% / cover no-repeat;
        }

        body.bluecg-login-page .bluecg-login-brand .bluecg-kicker,
        body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-kicker {
            bottom: .72rem;
            min-height: 2.1rem;
            padding: .42rem .95rem;
            font-size: .96rem;
        }
    }
}

/* Login header badge final override */
@media all {
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand,
    body.bluecg-login-page .bluecg-login-brand {
        min-height: 8.8rem;
        place-items: center;
        padding: 1.15rem;
        overflow: hidden;
    }

    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-logo,
    body.bluecg-login-page .bluecg-login-brand .bluecg-logo {
        display: none;
    }

    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-kicker,
    body.bluecg-login-page .bluecg-login-brand .bluecg-kicker {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-height: 2.35rem;
        margin-top: 2.9rem;
        padding: .52rem 1.25rem;
        border: 1px solid rgba(36, 120, 117, .2);
        border-radius: 999px;
        background:
            linear-gradient(180deg, rgba(255, 255, 255, .92), rgba(231, 248, 244, .9));
        color: #23706e;
        font-size: clamp(1rem, 2.2vw, 1.18rem);
        font-weight: 900;
        letter-spacing: .035em;
        box-shadow:
            0 .55rem 1rem rgba(31, 24, 18, .08),
            inset 0 1px 0 rgba(255, 255, 255, .9);
    }

    @media (max-width: 820px) {
        body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand,
        body.bluecg-login-page .bluecg-login-brand {
            min-height: 7.4rem;
        }

        body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-kicker,
        body.bluecg-login-page .bluecg-login-brand .bluecg-kicker {
            margin-top: 2.2rem;
            font-size: .98rem;
        }
    }
}

/* Game data center UX polish final override */
@media all {
    body.bluecg-game-page {
        scroll-behavior: smooth;
    }

    body.bluecg-game-page .bluecg-game-jump {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(14.6rem, 1fr));
        gap: .62rem;
        margin-top: .92rem;
        overflow: hidden;
        padding: .68rem;
        border: 1px solid rgba(109, 88, 66, .16);
        border-radius: 1.05rem;
        background:
            linear-gradient(135deg, rgba(35, 132, 127, .16), rgba(214, 154, 54, .12), rgba(109, 88, 66, .08)),
            rgba(255, 255, 250, .58);
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .86),
            0 .6rem 1.4rem rgba(69, 50, 28, .06);
    }

    body.bluecg-game-page .bluecg-form-row {
        align-items: end;
        gap: .72rem;
        margin-top: .82rem;
        padding: .72rem;
        border: 1px solid rgba(116, 93, 67, .12);
        border-radius: .92rem;
        background: rgba(255, 255, 252, .62);
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, .82);
    }

    body.bluecg-game-page .bluecg-form-row > .bluecg-button,
    body.bluecg-game-page .bluecg-form-row > .bluecg-link-button {
        align-self: end;
        min-height: var(--bcg-control-h);
        margin-top: 0;
    }

    body.bluecg-game-page .bluecg-game-jump a {
        position: relative;
        display: grid;
        grid-template-columns: 2.28rem minmax(0, 1fr) auto;
        grid-template-rows: auto auto;
        align-items: center;
        column-gap: .68rem;
        row-gap: .18rem;
        min-width: 0;
        min-height: 4.35rem;
        padding: .72rem .78rem .68rem .68rem;
        border: 1px solid rgba(116, 93, 67, .13);
        border-radius: .92rem;
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .98), rgba(250, 247, 241, .94));
        color: #433127;
        text-decoration: none;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .92);
        transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease, background-color .18s ease;
    }

    body.bluecg-game-page .bluecg-game-jump a::after {
        position: absolute;
        inset-block: 0;
        inset-inline-start: 0;
        width: .26rem;
        border-radius: .92rem 0 0 .92rem;
        background: transparent;
        content: "";
    }

    body.bluecg-game-page .bluecg-game-jump a::before {
        display: grid;
        grid-row: 1 / 3;
        grid-column: 1;
        place-items: center;
        inline-size: 2.28rem;
        block-size: 2.28rem;
        border-radius: .72rem;
        background:
            linear-gradient(180deg, rgba(237, 250, 247, .98), rgba(251, 243, 227, .94));
        color: #237c76;
        font-size: .86rem;
        font-weight: 950;
        line-height: 1;
        box-shadow: inset 0 0 0 1px rgba(35, 124, 118, .12);
        content: attr(data-nav);
    }

    body.bluecg-game-page .bluecg-game-jump strong {
        grid-column: 2;
        grid-row: 1;
        min-width: 0;
        overflow: hidden;
        color: inherit;
        font-size: .9rem;
        font-weight: 950;
        line-height: 1.18;
        letter-spacing: 0;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-game-page .bluecg-game-jump em {
        grid-column: 2 / 4;
        grid-row: 2;
        min-width: 0;
        overflow: hidden;
        color: #7a7065;
        font-size: .72rem;
        font-style: normal;
        font-weight: 720;
        line-height: 1.2;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-game-page .bluecg-game-jump a:hover,
    body.bluecg-game-page .bluecg-game-jump a:focus-visible {
        border-color: rgba(159, 113, 48, .34);
        background:
            linear-gradient(180deg, rgba(255, 250, 238, .96), rgba(248, 241, 225, .9));
        color: #704915;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .9),
            0 .5rem 1rem rgba(58, 43, 28, .08);
        transform: translateY(-2px);
    }

    body.bluecg-game-page .bluecg-game-jump a.active {
        border-color: rgba(35, 132, 127, .45);
        background:
            linear-gradient(180deg, rgba(235, 251, 248, .98), rgba(255, 249, 234, .94));
        color: #1e7771;
        box-shadow:
            0 .78rem 1.45rem rgba(42, 104, 99, .14),
            inset 0 1px 0 rgba(255, 255, 255, .9);
    }

    body.bluecg-game-page .bluecg-game-jump a.active::after {
        background: linear-gradient(180deg, #2ca59b, #d69a36);
    }

    body.bluecg-game-page .bluecg-game-jump a.active::before {
        background: linear-gradient(180deg, #35a79d, #247d77);
        color: #fff;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .24),
            0 .26rem .58rem rgba(36, 120, 117, .18);
    }

    body.bluecg-game-page .bluecg-game-jump span {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex: 0 0 auto;
        grid-column: 3;
        grid-row: 1;
        justify-self: end;
        min-height: 1.2rem;
        min-width: 1.95rem;
        padding: .12rem .42rem;
        border-radius: 999px;
        background: rgba(88, 118, 98, .12);
        color: #586357;
        font-size: .68rem;
        font-weight: 800;
        line-height: 1;
        white-space: nowrap;
    }

    body.bluecg-game-page .bluecg-game-jump a.active span {
        background: rgba(35, 132, 127, .13);
        color: #1f7771;
    }

    body.bluecg-game-page .bluecg-record-tabs {
        display: flex;
        flex-wrap: wrap;
        gap: .42rem;
        margin: .85rem 0 .75rem;
    }

    body.bluecg-game-page .bluecg-record-tabs a {
        display: inline-flex;
        align-items: center;
        min-height: 2rem;
        padding: .34rem .68rem;
        border: 1px solid rgba(116, 93, 67, .18);
        border-radius: 999px;
        background: rgba(255, 255, 252, .76);
        color: #5b4635;
        font-size: .8rem;
        font-weight: 850;
        text-decoration: none;
    }

    body.bluecg-game-page .bluecg-record-tabs a:hover,
    body.bluecg-game-page .bluecg-record-tabs a:focus-visible,
    body.bluecg-game-page .bluecg-record-tabs a.active {
        border-color: rgba(35, 132, 127, .38);
        background: linear-gradient(180deg, rgba(231, 250, 247, .92), rgba(255, 247, 228, .86));
        color: #1f7771;
        box-shadow: 0 .45rem 1rem rgba(42, 104, 99, .1);
    }

    body.bluecg-game-page .bluecg-support-actions {
        display: flex;
        flex-wrap: wrap;
        gap: .6rem;
        margin: .8rem 0 .35rem;
    }

    body.bluecg-game-page .bluecg-game-result-note {
        margin: .45rem 0 .65rem;
        padding: .46rem .65rem;
        border: 1px solid rgba(85, 116, 92, .16);
        border-radius: .8rem;
        background: rgba(247, 251, 241, .82);
        color: #546150;
        font-size: .82rem;
        font-weight: 750;
    }

    body.bluecg-game-page .bluecg-table-wrap {
        margin-top: .65rem;
        border-color: rgba(116, 93, 67, .14);
        border-radius: 1rem;
        background:
            linear-gradient(180deg, rgba(255, 255, 252, .98), rgba(249, 246, 239, .92));
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .92),
            0 .65rem 1.45rem rgba(45, 35, 24, .06);
    }

    body.bluecg-game-page .bluecg-table {
        min-width: 52rem;
    }

    body.bluecg-game-page .bluecg-table th {
        white-space: nowrap;
        background:
            linear-gradient(180deg, rgba(255, 252, 244, .98), rgba(244, 238, 224, .96));
    }

    body.bluecg-game-page .bluecg-table td {
        vertical-align: middle;
    }

    body.bluecg-game-page .bluecg-table :is(th, td):first-child {
        position: sticky;
        left: 0;
        z-index: 2;
        box-shadow: .55rem 0 1rem rgba(50, 39, 28, .045);
    }

    body.bluecg-game-page .bluecg-table th:first-child {
        z-index: 4;
    }

    body.bluecg-game-page .bluecg-table td:first-child {
        background:
            linear-gradient(180deg, rgba(255, 255, 252, .99), rgba(250, 247, 241, .96));
    }

    body.bluecg-game-page .bluecg-table tbody tr:nth-child(even) td:first-child {
        background:
            linear-gradient(180deg, rgba(249, 255, 253, .98), rgba(243, 250, 247, .95));
    }

    body.bluecg-game-page .bluecg-table tbody tr:hover td:first-child,
    body.bluecg-game-page .bluecg-table tbody tr.bluecg-row-active td:first-child {
        background:
            linear-gradient(180deg, rgba(255, 249, 234, .99), rgba(251, 239, 213, .96));
    }

    body.bluecg-game-page .bluecg-game-overview-extra {
        display: grid;
        gap: .9rem;
        margin-top: .95rem;
    }

    body.bluecg-game-page .bluecg-game-overview-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 14rem), 1fr));
        gap: .72rem;
    }

    body.bluecg-game-page .bluecg-game-overview-card,
    body.bluecg-game-page .bluecg-game-rank-card,
    body.bluecg-game-page .bluecg-game-guild-card,
    body.bluecg-game-page .bluecg-game-mini-card {
        border: 1px solid rgba(109, 88, 66, .14);
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .97), rgba(250, 247, 240, .91));
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .9),
            0 .45rem 1rem rgba(44, 34, 24, .05);
    }

    body.bluecg-game-page .bluecg-game-overview-card {
        display: grid;
        align-content: start;
        gap: .18rem;
        min-height: 6.35rem;
        padding: .84rem .92rem;
        border-radius: .84rem;
    }

    body.bluecg-game-page .bluecg-game-overview-card span {
        color: #756a60;
        font-size: .78rem;
        font-weight: 850;
    }

    body.bluecg-game-page .bluecg-game-overview-card strong {
        min-width: 0;
        overflow-wrap: anywhere;
        color: #2f251f;
        font-size: 1.16rem;
        font-weight: 950;
        line-height: 1.22;
        letter-spacing: 0;
    }

    body.bluecg-game-page .bluecg-game-overview-card small {
        color: #6f665d;
        font-size: .78rem;
        font-weight: 720;
        line-height: 1.38;
    }

    body.bluecg-game-page .bluecg-game-rank-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
        gap: .72rem;
    }

    body.bluecg-game-page .bluecg-game-rank-card,
    body.bluecg-game-page .bluecg-game-guild-card {
        min-width: 0;
        padding: .82rem;
        border-radius: .84rem;
    }

    body.bluecg-game-page .bluecg-game-rank-card h3,
    body.bluecg-game-page .bluecg-game-guild-card h3 {
        margin: 0 0 .58rem;
        color: #2f251f;
        font-size: .96rem;
        font-weight: 950;
        letter-spacing: 0;
    }

    body.bluecg-game-page .bluecg-game-rank-row,
    body.bluecg-game-page .bluecg-game-mini-card {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr) auto;
        gap: .58rem;
        align-items: center;
        min-width: 0;
        padding: .46rem .2rem;
        border-top: 1px solid rgba(109, 88, 66, .1);
    }

    body.bluecg-game-page .bluecg-game-rank-row:first-of-type {
        border-top: 0;
        padding-top: .1rem;
    }

    body.bluecg-game-page .bluecg-game-rank-row > div,
    body.bluecg-game-page .bluecg-game-mini-card > div {
        min-width: 0;
    }

    body.bluecg-game-page .bluecg-game-rank-row strong,
    body.bluecg-game-page .bluecg-game-mini-card strong {
        display: block;
        min-width: 0;
        overflow: hidden;
        color: #3b2e25;
        font-size: .86rem;
        font-weight: 900;
        line-height: 1.25;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-game-page .bluecg-game-rank-row small,
    body.bluecg-game-page .bluecg-game-mini-card small,
    body.bluecg-game-page .bluecg-game-media-text small {
        display: block;
        min-width: 0;
        overflow: hidden;
        color: #766b61;
        font-size: .72rem;
        font-weight: 720;
        line-height: 1.25;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
        white-space: normal;
    }

    body.bluecg-game-page .bluecg-table .bluecg-game-media-text small {
        max-width: min(36rem, 70vw);
        overflow: visible;
        text-overflow: clip;
        white-space: normal;
    }

    body.bluecg-game-page .bluecg-game-rank-row b {
        justify-self: end;
        color: #237872;
        font-size: .78rem;
        font-weight: 950;
        line-height: 1.2;
        text-align: right;
        white-space: nowrap;
    }

    body.bluecg-game-page .bluecg-game-guild-layout {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: .9rem;
        margin-top: .9rem;
    }

    body.bluecg-game-page .bluecg-game-guild-card.wide {
        grid-column: 1 / -1;
    }

    body.bluecg-game-page .bluecg-game-card-list {
        display: grid;
        gap: .48rem;
        max-height: 25rem;
        overflow: auto;
        padding-right: .1rem;
    }

    body.bluecg-game-page .bluecg-game-mini-card {
        grid-template-columns: auto minmax(0, 1fr);
        min-height: 3.5rem;
        padding: .52rem .58rem;
        border-radius: .72rem;
    }

    body.bluecg-game-page .bluecg-game-group-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 20rem), 1fr));
        gap: .78rem;
        margin-top: .8rem;
    }

    body.bluecg-game-page .bluecg-game-group-card {
        display: grid;
        grid-template-columns: 5.2rem minmax(0, 1fr);
        gap: .85rem;
        align-items: start;
        min-width: 0;
        min-height: 8rem;
        padding: .78rem;
        overflow: hidden;
        border: 1px solid rgba(109, 88, 66, .14);
        border-radius: .9rem;
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .98), rgba(239, 250, 247, .9));
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .9),
            0 .45rem 1rem rgba(44, 34, 24, .05);
    }

    body.bluecg-game-page .bluecg-game-group-card img,
    body.bluecg-game-page .bluecg-game-group-fallback {
        inline-size: 5.2rem;
        block-size: 5.2rem;
        border: 1px solid rgba(35, 120, 114, .16);
        border-radius: .82rem;
        background: linear-gradient(180deg, rgba(237, 250, 247, .98), rgba(255, 247, 228, .92));
        object-fit: cover;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, .9);
    }

    body.bluecg-game-page .bluecg-game-group-fallback {
        display: grid;
        place-items: center;
        color: #237872;
        font-size: 1.45rem;
        font-weight: 950;
    }

    body.bluecg-game-page .bluecg-game-group-card > div {
        display: grid;
        gap: .28rem;
        min-width: 0;
    }

    body.bluecg-game-page .bluecg-game-group-card span {
        justify-self: start;
        padding: .1rem .46rem;
        border-radius: 999px;
        background: rgba(35, 132, 127, .1);
        color: #237872;
        font-size: .7rem;
        font-weight: 900;
    }

    body.bluecg-game-page .bluecg-game-group-card h3 {
        margin: 0;
        overflow: hidden;
        color: #2f251f;
        font-size: 1rem;
        font-weight: 950;
        line-height: 1.25;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-game-page .bluecg-game-group-card p {
        display: -webkit-box;
        min-height: 2.8em;
        margin: 0;
        overflow: hidden;
        color: #62584f;
        font-size: .82rem;
        font-weight: 720;
        line-height: 1.4;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
    }

    body.bluecg-game-page .bluecg-game-group-card small,
    body.bluecg-game-page .bluecg-game-group-card em {
        display: block;
        min-width: 0;
        overflow: hidden;
        color: #756a60;
        font-size: .74rem;
        font-style: normal;
        font-weight: 720;
        line-height: 1.3;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-game-page .bluecg-game-group-card .bluecg-link-button {
        justify-self: start;
        min-height: 2rem;
        margin-top: .12rem;
        padding: .25rem .68rem;
        font-size: .78rem;
    }

    body.bluecg-game-page .bluecg-game-media {
        display: inline-flex;
        align-items: center;
        gap: .62rem;
        min-width: 0;
    }

    body.bluecg-game-page .bluecg-game-media-text {
        display: inline-flex;
        flex-direction: column;
        min-width: 0;
        line-height: 1.35;
    }

    body.bluecg-game-page .bluecg-game-icon-link {
        display: inline-flex;
        flex: 0 0 auto;
        color: inherit;
        text-decoration: none;
    }

    body.bluecg-game-page .bluecg-game-icon-frame {
        position: relative;
        display: inline-grid;
        place-items: center;
        inline-size: 2.35rem;
        block-size: 2.35rem;
        flex: 0 0 auto;
        border: 1px solid rgba(39, 120, 116, .16);
        border-radius: .75rem;
        background: linear-gradient(180deg, rgba(255, 254, 248, .96), rgba(238, 248, 245, .86));
        box-shadow: 0 .38rem .9rem rgba(47, 72, 66, .1), inset 0 1px 0 rgba(255, 255, 255, .9);
        transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease;
    }

    body.bluecg-game-page .bluecg-game-icon-link:hover .bluecg-game-icon-frame,
    body.bluecg-game-page .bluecg-game-icon-link:focus-visible .bluecg-game-icon-frame {
        border-color: rgba(31, 119, 113, .42);
        box-shadow: 0 .58rem 1.05rem rgba(47, 72, 66, .16), inset 0 1px 0 rgba(255, 255, 255, .94);
        transform: translateY(-1px);
    }

    body.bluecg-game-page .bluecg-game-icon-frame.face {
        inline-size: 2.75rem;
        block-size: 2.75rem;
        border-radius: 50%;
    }

    body.bluecg-game-page .bluecg-game-icon {
        inline-size: 100%;
        block-size: 100%;
        object-fit: contain;
        border-radius: inherit;
    }

    body.bluecg-game-page .bluecg-game-icon-frame.is-missing::after {
        content: "#" attr(data-id);
        color: #54706d;
        font-size: .68rem;
        font-weight: 900;
        letter-spacing: 0;
    }

    body.bluecg-game-page .bluecg-game-asset-modal .bluecg-image-modal-frame {
        width: min(100%, 28rem);
        height: min(100%, 28rem);
        padding: 3.2rem 2.2rem 3rem;
    }

    body.bluecg-game-page .bluecg-game-asset-modal .bluecg-image-modal-img {
        max-width: min(100%, 14rem);
        max-height: min(100%, 14rem);
        image-rendering: auto;
    }

    body.bluecg-game-page .bluecg-world-message {
        min-width: 22rem;
        max-width: 48rem;
        line-height: 1.65;
        white-space: normal;
    }

    body.bluecg-game-page .bluecg-game-detail {
        margin-top: 1rem;
        padding-top: 1rem;
        border-top: 1px solid rgba(119, 91, 57, .16);
    }

    body.bluecg-game-page .bluecg-game-detail-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: .9rem;
        margin-top: .75rem;
    }

    body.bluecg-game-page .bluecg-game-detail-grid > .wide {
        grid-column: 1 / -1;
    }

    body.bluecg-game-page .bluecg-game-character-summary {
        display: grid;
        grid-template-columns: minmax(14rem, .45fr) minmax(0, 1fr);
        gap: .9rem;
        align-items: stretch;
        margin-top: .85rem;
    }

    body.bluecg-game-page .bluecg-game-character-portrait,
    body.bluecg-game-page .bluecg-game-fact-grid span {
        border: 1px solid rgba(116, 91, 63, .14);
        background:
            linear-gradient(180deg, rgba(255, 255, 252, .98), rgba(239, 250, 247, .88));
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .9),
            0 .42rem 1.1rem rgba(45, 35, 27, .055);
    }

    body.bluecg-game-page .bluecg-game-character-portrait {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        gap: .82rem;
        align-items: center;
        min-width: 0;
        padding: .82rem;
        border-radius: .95rem;
    }

    body.bluecg-game-page .bluecg-game-character-portrait .bluecg-game-icon-frame.face {
        inline-size: 4.2rem;
        block-size: 4.2rem;
    }

    body.bluecg-game-page .bluecg-game-character-portrait strong,
    body.bluecg-game-page .bluecg-game-character-portrait small {
        display: block;
        min-width: 0;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-game-page .bluecg-game-character-portrait strong {
        color: #2e251f;
        font-size: 1.02rem;
        font-weight: 950;
        line-height: 1.25;
    }

    body.bluecg-game-page .bluecg-game-character-portrait small {
        margin-top: .2rem;
        color: #766a60;
        font-size: .76rem;
        font-weight: 760;
    }

    body.bluecg-game-page .bluecg-game-fact-grid {
        display: grid;
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: .58rem;
        min-width: 0;
    }

    body.bluecg-game-page .bluecg-game-fact-grid span {
        display: grid;
        gap: .22rem;
        min-width: 0;
        min-height: 4.25rem;
        padding: .62rem .68rem;
        border-radius: .82rem;
        border-left: .22rem solid rgba(35, 132, 127, .32);
    }

    body.bluecg-game-page .bluecg-game-fact-grid b,
    body.bluecg-game-page .bluecg-game-fact-grid em {
        display: block;
        min-width: 0;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-game-page .bluecg-game-fact-grid b {
        color: #786b60;
        font-size: .68rem;
        font-weight: 900;
        line-height: 1.15;
    }

    body.bluecg-game-page .bluecg-game-fact-grid em {
        align-self: end;
        color: #2f261f;
        font-size: .86rem;
        font-style: normal;
        font-weight: 880;
        line-height: 1.25;
    }

    body.bluecg-game-page .bluecg-game-character-note {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: .62rem;
        margin-top: .68rem;
    }

    body.bluecg-game-page .bluecg-game-character-note span {
        display: grid;
        gap: .22rem;
        min-width: 0;
        padding: .72rem .82rem;
        border: 1px solid rgba(38, 139, 132, .18);
        border-radius: .86rem;
        background:
            linear-gradient(135deg, rgba(239, 250, 247, .92), rgba(255, 252, 242, .95));
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .9),
            0 .46rem 1.2rem rgba(42, 34, 26, .055);
    }

    body.bluecg-game-page .bluecg-game-character-note b,
    body.bluecg-game-page .bluecg-game-character-note em {
        min-width: 0;
        overflow-wrap: anywhere;
    }

    body.bluecg-game-page .bluecg-game-character-note b {
        color: #277a75;
        font-size: .72rem;
        font-weight: 950;
        line-height: 1.15;
    }

    body.bluecg-game-page .bluecg-game-character-note em {
        color: #312820;
        font-size: .88rem;
        font-style: normal;
        font-weight: 850;
        line-height: 1.45;
    }

    body.bluecg-game-page .bluecg-game-character-status {
        display: grid;
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: .62rem;
        margin-top: .68rem;
    }

    body.bluecg-game-page .bluecg-game-character-status span {
        display: grid;
        align-content: start;
        gap: .2rem;
        min-width: 0;
        min-height: 5.5rem;
        padding: .72rem .76rem;
        border: 1px solid rgba(190, 151, 78, .18);
        border-radius: .86rem;
        background:
            linear-gradient(180deg, rgba(255, 255, 252, .96), rgba(252, 244, 224, .84));
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .92),
            0 .42rem 1rem rgba(42, 34, 26, .05);
    }

    body.bluecg-game-page .bluecg-game-character-status span:nth-child(4n + 1) {
        border-color: rgba(38, 139, 132, .22);
        background:
            linear-gradient(180deg, rgba(248, 255, 253, .98), rgba(232, 248, 244, .88));
    }

    body.bluecg-game-page .bluecg-game-character-status span:nth-child(4n + 2) {
        border-color: rgba(197, 139, 45, .22);
    }

    body.bluecg-game-page .bluecg-game-character-status span:nth-child(4n + 3) {
        border-color: rgba(139, 104, 164, .2);
        background:
            linear-gradient(180deg, rgba(255, 253, 250, .98), rgba(246, 240, 250, .82));
    }

    body.bluecg-game-page .bluecg-game-character-status span:nth-child(4n) {
        border-color: rgba(160, 92, 77, .2);
        background:
            linear-gradient(180deg, rgba(255, 253, 250, .98), rgba(252, 239, 232, .82));
    }

    body.bluecg-game-page .bluecg-game-character-status b,
    body.bluecg-game-page .bluecg-game-character-status em,
    body.bluecg-game-page .bluecg-game-character-status small {
        min-width: 0;
        overflow-wrap: anywhere;
    }

    body.bluecg-game-page .bluecg-game-character-status b {
        color: #8f5f35;
        font-size: .7rem;
        font-weight: 950;
        line-height: 1.15;
    }

    body.bluecg-game-page .bluecg-game-character-status em {
        color: #2f261f;
        font-size: .93rem;
        font-style: normal;
        font-weight: 920;
        line-height: 1.25;
    }

    body.bluecg-game-page .bluecg-game-character-status small {
        color: #766a60;
        font-size: .68rem;
        font-weight: 720;
        line-height: 1.35;
    }

    body.bluecg-game-page .bluecg-game-detail h3 {
        margin: 0 0 .45rem;
        color: #2e251f;
        font-size: 1rem;
        font-weight: 900;
    }

    body.bluecg-game-page section[id] {
        scroll-margin-top: 1rem;
    }

    @media (max-width: 820px) {
        body.bluecg-game-page .bluecg-game-jump {
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: .5rem;
            padding: .55rem;
        }

        body.bluecg-game-page .bluecg-game-jump::-webkit-scrollbar {
            display: none;
        }

        body.bluecg-game-page .bluecg-game-jump a {
            grid-template-columns: 2rem minmax(0, 1fr) auto;
            min-height: 4.05rem;
            padding: .62rem .62rem .6rem .58rem;
            font-size: .8rem;
        }

        body.bluecg-game-page .bluecg-game-jump a::before {
            inline-size: 2rem;
            block-size: 2rem;
        }

        body.bluecg-game-page .bluecg-game-jump span {
            grid-column: auto;
            justify-self: end;
            margin-top: 0;
        }

        body.bluecg-game-page .bluecg-form-row > .bluecg-button,
        body.bluecg-game-page .bluecg-form-row > .bluecg-link-button {
            margin-top: 0;
        }

        body.bluecg-game-page .bluecg-record-tabs {
            flex-wrap: nowrap;
            overflow-x: auto;
            padding-bottom: .2rem;
            scrollbar-width: none;
        }

        body.bluecg-game-page .bluecg-record-tabs::-webkit-scrollbar {
            display: none;
        }

        body.bluecg-game-page .bluecg-record-tabs a {
            flex: 0 0 auto;
            white-space: nowrap;
        }

        body.bluecg-game-page .bluecg-game-detail-grid {
            grid-template-columns: 1fr;
        }

        body.bluecg-game-page .bluecg-game-character-summary {
            grid-template-columns: 1fr;
        }

        body.bluecg-game-page .bluecg-game-fact-grid {
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }

        body.bluecg-game-page .bluecg-game-character-note {
            grid-template-columns: 1fr;
        }

        body.bluecg-game-page .bluecg-game-character-status {
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }

        body.bluecg-game-page .bluecg-game-guild-layout {
            grid-template-columns: 1fr;
        }

        body.bluecg-game-page .bluecg-game-rank-row {
            grid-template-columns: auto minmax(0, 1fr);
        }

        body.bluecg-game-page .bluecg-game-rank-row b {
            grid-column: 2;
            justify-self: start;
        }

        body.bluecg-game-page .bluecg-game-group-card {
            grid-template-columns: 4.4rem minmax(0, 1fr);
        }

        body.bluecg-game-page .bluecg-game-group-card img,
        body.bluecg-game-page .bluecg-game-group-fallback {
            inline-size: 4.4rem;
            block-size: 4.4rem;
        }
    }

    @media (max-width: 540px) {
        body.bluecg-game-page .bluecg-game-jump {
            grid-template-columns: 1fr;
        }

        body.bluecg-game-page .bluecg-game-fact-grid {
            grid-template-columns: 1fr;
        }

        body.bluecg-game-page .bluecg-game-character-portrait {
            grid-template-columns: 3.5rem minmax(0, 1fr);
        }

        body.bluecg-game-page .bluecg-game-character-portrait .bluecg-game-icon-frame.face {
            inline-size: 3.5rem;
            block-size: 3.5rem;
        }

        body.bluecg-game-page .bluecg-game-character-status {
            grid-template-columns: 1fr;
        }
    }
}

/* Login page corrective layout override 2026-05-25 */
@media all {
    body.bluecg-login-page {
        position: relative;
        display: grid;
        place-items: center;
        min-height: 100svh;
        padding: clamp(1rem, 3vw, 2.4rem);
        overflow-x: hidden;
        isolation: isolate;
        background:
            radial-gradient(circle at 15% 12%, rgba(53, 163, 157, .17), transparent 25rem),
            radial-gradient(circle at 86% 10%, rgba(218, 151, 64, .18), transparent 24rem),
            linear-gradient(135deg, #edf8f5 0%, #fffaf0 48%, #f4eadf 100%);
    }

    body.bluecg-login-page::before {
        position: fixed;
        inset: 0;
        z-index: -1;
        display: block;
        content: "";
        pointer-events: none;
        background:
            linear-gradient(90deg, rgba(255, 255, 255, .88), rgba(255, 255, 255, .58)),
            var(--bcg-art-section) center top / cover no-repeat;
        opacity: .12;
        filter: saturate(.82) blur(1px);
        transform: scale(1.02);
    }

    body.bluecg-login-page .bluecg-login-shell {
        width: min(100%, 80rem);
        min-height: 0;
        margin: 0 auto;
        padding: 0;
        align-items: center;
    }

    body.bluecg-login-page .bluecg-login-panel,
    body.bluecg-login-page .bluecg-panel.quest.bluecg-login-panel {
        position: relative;
        display: grid;
        width: 100%;
        min-height: 0;
        overflow: hidden;
        border: 1px solid rgba(45, 129, 125, .2);
        border-radius: 1.45rem;
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .98), rgba(255, 249, 238, .94));
        box-shadow:
            0 1.4rem 3rem rgba(50, 38, 25, .14),
            inset 0 1px 0 rgba(255, 255, 255, .94);
        backdrop-filter: blur(18px) saturate(1.06);
    }

    body.bluecg-login-page .bluecg-login-panel::before {
        display: none;
    }

    body.bluecg-login-page .bluecg-login-panel .bluecg-panel-inner {
        position: relative;
        z-index: 1;
        display: grid;
        align-content: center;
        width: min(100%, 39rem);
        padding: clamp(1.15rem, 2.3vw, 2rem);
        justify-self: center;
    }

    body.bluecg-login-page .bluecg-login-brand,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand {
        display: grid;
        grid-template-columns: 1fr;
        grid-template-areas: "logo";
        place-items: center;
        min-height: clamp(6.6rem, 8vw, 7.7rem);
        margin: 0 0 1rem;
        padding: .75rem 1rem;
        overflow: hidden;
        border: 1px solid rgba(45, 129, 125, .17);
        border-radius: 1rem;
        background:
            linear-gradient(90deg, rgba(255, 254, 249, .92) 0 34%, rgba(255, 254, 249, .56) 62%, rgba(255, 250, 240, .28)),
            linear-gradient(180deg, rgba(255, 255, 255, .22), rgba(255, 249, 236, .72)),
            var(--bcg-art-login) center 27% / cover no-repeat;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .86),
            0 .65rem 1.2rem rgba(37, 29, 20, .07);
        text-align: center;
    }

    body.bluecg-login-page .bluecg-login-brand .bluecg-logo,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-logo {
        grid-area: logo;
        display: block;
        width: min(100%, 24rem);
        inline-size: min(100%, 24rem);
        max-inline-size: 24rem;
        height: clamp(5.1rem, 7vw, 6.15rem);
        block-size: clamp(5.1rem, 7vw, 6.15rem);
        align-self: center;
        background-color: transparent;
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain;
        box-shadow: none;
        filter:
            drop-shadow(0 .5rem .75rem rgba(20, 83, 92, .2))
            drop-shadow(0 0 .38rem rgba(255, 255, 255, .88));
    }

    body.bluecg-login-page .bluecg-login-brand .bluecg-kicker,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-kicker {
        display: none;
    }

    body.bluecg-login-page .bluecg-login-head {
        margin: 0 0 .85rem;
        text-align: center;
    }

    body.bluecg-login-page .bluecg-login-copy {
        gap: .22rem;
        margin: 0;
    }

    body.bluecg-login-page .bluecg-login-copy span {
        color: #231f1b;
        font-family: var(--bcg-font-display);
        font-size: clamp(1.32rem, 2.5vw, 1.72rem);
        font-weight: 950;
        line-height: 1.12;
    }

    body.bluecg-login-page .bluecg-login-copy small {
        color: #70655d;
        font-size: clamp(.92rem, 1.35vw, 1rem);
        font-weight: 780;
        line-height: 1.35;
    }

    body.bluecg-login-page .bluecg-login-form {
        gap: .78rem 1rem;
        padding: clamp(.85rem, 1.8vw, 1.15rem);
        border: 1px solid rgba(45, 129, 125, .12);
        border-radius: 1rem;
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .82), rgba(255, 249, 238, .58));
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, .75);
    }

    body.bluecg-login-page .bluecg-login-tabs {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: .45rem;
        padding: .42rem;
        border: 1px solid rgba(45, 129, 125, .14);
        border-radius: .95rem;
        background: rgba(246, 239, 225, .66);
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .82),
            0 .32rem .8rem rgba(50, 38, 25, .045);
    }

    body.bluecg-login-page .bluecg-login-tabs legend {
        margin-bottom: .18rem;
        color: #1f1b17;
        font-size: clamp(1.18rem, 2vw, 1.42rem);
        font-weight: 950;
        line-height: 1.18;
    }

    body.bluecg-login-page .bluecg-login-tabs label {
        min-height: 2.95rem;
        padding: .58rem .62rem;
        border-radius: .78rem;
        color: #62584f;
        font-size: .94rem;
        font-weight: 920;
        line-height: 1.18;
        text-align: center;
        white-space: normal;
    }

    body.bluecg-login-page .bluecg-login-tabs label:has(input:checked) {
        border-color: rgba(36, 120, 117, .4);
        background:
            linear-gradient(180deg, rgba(232, 251, 247, .98), rgba(255, 255, 253, .92));
        color: #247872;
        box-shadow: 0 .45rem .9rem rgba(36, 120, 117, .12);
    }

    body.bluecg-login-page .bluecg-login-form label,
    body.bluecg-login-page .bluecg-login-form .bluecg-label {
        margin-bottom: .32rem;
        color: #24211d;
        font-size: .9rem;
        font-weight: 900;
        line-height: 1.32;
        text-wrap: balance;
    }

    body.bluecg-login-page .bluecg-login-form input,
    body.bluecg-login-page .bluecg-login-form select {
        min-height: 3rem;
        border-color: rgba(78, 68, 57, .22);
        border-radius: .82rem;
        background: rgba(255, 255, 255, .94);
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .9),
            0 .25rem .7rem rgba(50, 38, 25, .04);
    }

    body.bluecg-login-page .bluecg-login-form input:focus,
    body.bluecg-login-page .bluecg-login-form select:focus {
        border-color: rgba(36, 120, 117, .58);
        box-shadow:
            0 0 0 .22rem rgba(36, 120, 117, .14),
            inset 0 1px 0 rgba(255, 255, 255, .9);
    }

    body.bluecg-login-page .bluecg-login-form > div:has(.bluecg-turnstile) {
        display: grid;
        justify-items: start;
        gap: .35rem;
    }

    body.bluecg-login-page .bluecg-turnstile {
        max-width: 100%;
        overflow: hidden;
    }

    body.bluecg-login-page .bluecg-login-form .bluecg-button {
        min-height: 3.2rem;
        margin-top: .15rem;
        border-radius: .9rem;
        background: linear-gradient(180deg, #35aaa2, #247872);
        font-size: 1rem;
        font-weight: 950;
        box-shadow:
            0 .85rem 1.45rem rgba(36, 120, 117, .24),
            inset 0 1px 0 rgba(255, 255, 255, .26);
    }

    @media (min-width: 980px) {
        body.bluecg-login-page .bluecg-login-panel,
        body.bluecg-login-page .bluecg-panel.quest.bluecg-login-panel {
            grid-template-columns: minmax(27rem, .92fr) minmax(31rem, 1.08fr);
        }

        body.bluecg-login-page .bluecg-login-panel::after {
            position: relative;
            inset: auto;
            display: block;
            grid-column: 1;
            grid-row: 1;
            min-height: clamp(39rem, 76svh, 45rem);
            border-radius: 1.35rem 0 0 1.35rem;
            background:
                linear-gradient(90deg, rgba(255, 254, 249, .03) 0%, rgba(255, 252, 246, .2) 54%, rgba(255, 250, 240, .84) 100%),
                linear-gradient(180deg, rgba(255, 255, 255, 0) 43%, rgba(255, 255, 255, .72) 84%, rgba(255, 250, 240, .96) 100%),
                var(--bcg-art-login) 42% center / cover no-repeat;
            content: "";
        }

        body.bluecg-login-page .bluecg-login-panel .bluecg-panel-inner {
            grid-column: 2;
            grid-row: 1;
        }

        body.bluecg-login-page .bluecg-login-form {
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }

        body.bluecg-login-page .bluecg-login-form > input[type="hidden"],
        body.bluecg-login-page .bluecg-login-tabs,
        body.bluecg-login-page .bluecg-login-form > div:has(.bluecg-turnstile),
        body.bluecg-login-page .bluecg-login-form > .bluecg-button {
            grid-column: 1 / -1;
        }
    }

    @media (max-width: 979px) {
        body.bluecg-login-page {
            padding: clamp(.7rem, 3vw, 1.4rem);
        }

        body.bluecg-login-page .bluecg-login-shell {
            width: min(100%, 35rem);
        }

        body.bluecg-login-page .bluecg-login-panel,
        body.bluecg-login-page .bluecg-panel.quest.bluecg-login-panel {
            display: block;
        }

        body.bluecg-login-page .bluecg-login-panel::after {
            display: none;
        }
    }

    @media (max-width: 540px) {
        body.bluecg-login-page .bluecg-login-panel .bluecg-panel-inner {
            padding: .9rem;
        }

        body.bluecg-login-page .bluecg-login-brand,
        body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand {
            min-height: 6.25rem;
            padding: .6rem .7rem;
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .22), rgba(255, 249, 236, .8)),
                var(--bcg-art-login-mobile) center 16% / cover no-repeat;
        }

        body.bluecg-login-page .bluecg-login-brand .bluecg-logo,
        body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-logo {
            width: min(100%, 17rem);
            inline-size: min(100%, 17rem);
            height: 4.55rem;
            block-size: 4.55rem;
        }

        body.bluecg-login-page .bluecg-login-form {
            padding: .75rem;
        }

        body.bluecg-login-page .bluecg-login-tabs {
            grid-template-columns: 1fr;
        }
    }
}

/* Login page final corrective layout override 2026-05-25 */
@media all {
    body.bluecg-login-page {
        position: relative;
        display: grid;
        place-items: center;
        min-height: 100svh;
        padding: clamp(1rem, 3vw, 2.4rem);
        overflow-x: hidden;
        isolation: isolate;
        background:
            radial-gradient(circle at 15% 12%, rgba(53, 163, 157, .17), transparent 25rem),
            radial-gradient(circle at 86% 10%, rgba(218, 151, 64, .18), transparent 24rem),
            linear-gradient(135deg, #edf8f5 0%, #fffaf0 48%, #f4eadf 100%);
    }

    body.bluecg-login-page::before {
        position: fixed;
        inset: 0;
        z-index: -1;
        display: block;
        content: "";
        pointer-events: none;
        background:
            linear-gradient(90deg, rgba(255, 255, 255, .88), rgba(255, 255, 255, .58)),
            var(--bcg-art-section) center top / cover no-repeat;
        opacity: .12;
        filter: saturate(.82) blur(1px);
        transform: scale(1.02);
    }

    body.bluecg-login-page .bluecg-login-shell {
        width: min(100%, 80rem);
        min-height: 0;
        margin: 0 auto;
        padding: 0;
        align-items: center;
    }

    body.bluecg-login-page .bluecg-login-panel,
    body.bluecg-login-page .bluecg-panel.quest.bluecg-login-panel {
        position: relative;
        display: grid;
        width: 100%;
        min-height: 0;
        overflow: hidden;
        border: 1px solid rgba(45, 129, 125, .2);
        border-radius: 1.45rem;
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .98), rgba(255, 249, 238, .94));
        box-shadow:
            0 1.4rem 3rem rgba(50, 38, 25, .14),
            inset 0 1px 0 rgba(255, 255, 255, .94);
        backdrop-filter: blur(18px) saturate(1.06);
    }

    body.bluecg-login-page .bluecg-login-panel::before {
        display: none;
    }

    body.bluecg-login-page .bluecg-login-panel .bluecg-panel-inner {
        position: relative;
        z-index: 1;
        display: grid;
        align-content: center;
        width: min(100%, 39rem);
        padding: clamp(1.15rem, 2.3vw, 2rem);
        justify-self: center;
    }

    body.bluecg-login-page .bluecg-login-brand,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand {
        display: grid;
        grid-template-columns: 1fr;
        grid-template-areas: "logo";
        place-items: center;
        min-height: clamp(6.6rem, 8vw, 7.7rem);
        margin: 0 0 1rem;
        padding: .75rem 1rem;
        overflow: hidden;
        border: 1px solid rgba(45, 129, 125, .17);
        border-radius: 1rem;
        background:
            linear-gradient(90deg, rgba(255, 254, 249, .92) 0 34%, rgba(255, 254, 249, .56) 62%, rgba(255, 250, 240, .28)),
            linear-gradient(180deg, rgba(255, 255, 255, .22), rgba(255, 249, 236, .72)),
            var(--bcg-art-login) center 27% / cover no-repeat;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .86),
            0 .65rem 1.2rem rgba(37, 29, 20, .07);
        text-align: center;
    }

    body.bluecg-login-page .bluecg-login-brand .bluecg-logo,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-logo {
        grid-area: logo;
        display: block;
        width: min(100%, 24rem);
        inline-size: min(100%, 24rem);
        max-inline-size: 24rem;
        height: clamp(5.1rem, 7vw, 6.15rem);
        block-size: clamp(5.1rem, 7vw, 6.15rem);
        align-self: center;
        background-color: transparent;
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain;
        box-shadow: none;
        filter:
            drop-shadow(0 .5rem .75rem rgba(20, 83, 92, .2))
            drop-shadow(0 0 .38rem rgba(255, 255, 255, .88));
    }

    body.bluecg-login-page .bluecg-login-brand .bluecg-kicker,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-kicker {
        display: none;
    }

    body.bluecg-login-page .bluecg-login-head {
        margin: 0 0 .85rem;
        text-align: center;
    }

    body.bluecg-login-page .bluecg-login-copy {
        gap: .22rem;
        margin: 0;
    }

    body.bluecg-login-page .bluecg-login-copy span {
        color: #231f1b;
        font-family: var(--bcg-font-display);
        font-size: clamp(1.32rem, 2.5vw, 1.72rem);
        font-weight: 950;
        line-height: 1.12;
    }

    body.bluecg-login-page .bluecg-login-copy small {
        color: #70655d;
        font-size: clamp(.92rem, 1.35vw, 1rem);
        font-weight: 780;
        line-height: 1.35;
    }

    body.bluecg-login-page .bluecg-login-form {
        gap: .78rem 1rem;
        padding: clamp(.85rem, 1.8vw, 1.15rem);
        border: 1px solid rgba(45, 129, 125, .12);
        border-radius: 1rem;
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .82), rgba(255, 249, 238, .58));
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, .75);
    }

    body.bluecg-login-page .bluecg-login-tabs {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: .45rem;
        padding: .42rem;
        border: 1px solid rgba(45, 129, 125, .14);
        border-radius: .95rem;
        background: rgba(246, 239, 225, .66);
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .82),
            0 .32rem .8rem rgba(50, 38, 25, .045);
    }

    body.bluecg-login-page .bluecg-login-tabs legend {
        margin-bottom: .18rem;
        color: #1f1b17;
        font-size: clamp(1.18rem, 2vw, 1.42rem);
        font-weight: 950;
        line-height: 1.18;
    }

    body.bluecg-login-page .bluecg-login-tabs label {
        min-height: 2.95rem;
        padding: .58rem .62rem;
        border-radius: .78rem;
        color: #62584f;
        font-size: .94rem;
        font-weight: 920;
        line-height: 1.18;
        text-align: center;
        white-space: normal;
    }

    body.bluecg-login-page .bluecg-login-tabs label:has(input:checked) {
        border-color: rgba(36, 120, 117, .4);
        background:
            linear-gradient(180deg, rgba(232, 251, 247, .98), rgba(255, 255, 253, .92));
        color: #247872;
        box-shadow: 0 .45rem .9rem rgba(36, 120, 117, .12);
    }

    body.bluecg-login-page .bluecg-login-form label,
    body.bluecg-login-page .bluecg-login-form .bluecg-label {
        margin-bottom: .32rem;
        color: #24211d;
        font-size: .9rem;
        font-weight: 900;
        line-height: 1.32;
        text-wrap: balance;
    }

    body.bluecg-login-page .bluecg-login-form input,
    body.bluecg-login-page .bluecg-login-form select {
        min-height: 3rem;
        border-color: rgba(78, 68, 57, .22);
        border-radius: .82rem;
        background: rgba(255, 255, 255, .94);
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .9),
            0 .25rem .7rem rgba(50, 38, 25, .04);
    }

    body.bluecg-login-page .bluecg-login-form input:focus,
    body.bluecg-login-page .bluecg-login-form select:focus {
        border-color: rgba(36, 120, 117, .58);
        box-shadow:
            0 0 0 .22rem rgba(36, 120, 117, .14),
            inset 0 1px 0 rgba(255, 255, 255, .9);
    }

    body.bluecg-login-page .bluecg-login-form > div:has(.bluecg-turnstile) {
        display: grid;
        justify-items: start;
        gap: .35rem;
    }

    body.bluecg-login-page .bluecg-turnstile {
        max-width: 100%;
        overflow: hidden;
    }

    body.bluecg-login-page .bluecg-login-form .bluecg-button {
        min-height: 3.2rem;
        margin-top: .15rem;
        border-radius: .9rem;
        background: linear-gradient(180deg, #35aaa2, #247872);
        font-size: 1rem;
        font-weight: 950;
        box-shadow:
            0 .85rem 1.45rem rgba(36, 120, 117, .24),
            inset 0 1px 0 rgba(255, 255, 255, .26);
    }

    @media (min-width: 980px) {
        body.bluecg-login-page .bluecg-login-panel,
        body.bluecg-login-page .bluecg-panel.quest.bluecg-login-panel {
            grid-template-columns: minmax(27rem, .92fr) minmax(31rem, 1.08fr);
        }

        body.bluecg-login-page .bluecg-login-panel::after {
            position: relative;
            inset: auto;
            display: block;
            grid-column: 1;
            grid-row: 1;
            min-height: clamp(39rem, 76svh, 45rem);
            border-radius: 1.35rem 0 0 1.35rem;
            background:
                linear-gradient(90deg, rgba(255, 254, 249, .03) 0%, rgba(255, 252, 246, .2) 54%, rgba(255, 250, 240, .84) 100%),
                linear-gradient(180deg, rgba(255, 255, 255, 0) 43%, rgba(255, 255, 255, .72) 84%, rgba(255, 250, 240, .96) 100%),
                var(--bcg-art-login) 42% center / cover no-repeat;
            content: "";
        }

        body.bluecg-login-page .bluecg-login-panel .bluecg-panel-inner {
            grid-column: 2;
            grid-row: 1;
        }

        body.bluecg-login-page .bluecg-login-form {
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }

        body.bluecg-login-page .bluecg-login-form > input[type="hidden"],
        body.bluecg-login-page .bluecg-login-tabs,
        body.bluecg-login-page .bluecg-login-form > div:has(.bluecg-turnstile),
        body.bluecg-login-page .bluecg-login-form > .bluecg-button {
            grid-column: 1 / -1;
        }
    }

    @media (max-width: 979px) {
        body.bluecg-login-page {
            padding: clamp(.7rem, 3vw, 1.4rem);
        }

        body.bluecg-login-page .bluecg-login-shell {
            width: min(100%, 35rem);
        }

        body.bluecg-login-page .bluecg-login-panel,
        body.bluecg-login-page .bluecg-panel.quest.bluecg-login-panel {
            display: block;
        }

        body.bluecg-login-page .bluecg-login-panel::after {
            display: none;
        }
    }

    @media (max-width: 540px) {
        body.bluecg-login-page .bluecg-login-panel .bluecg-panel-inner {
            padding: .9rem;
        }

        body.bluecg-login-page .bluecg-login-brand,
        body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand {
            min-height: 6.25rem;
            padding: .6rem .7rem;
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .22), rgba(255, 249, 236, .8)),
                var(--bcg-art-login-mobile) center 16% / cover no-repeat;
        }

        body.bluecg-login-page .bluecg-login-brand .bluecg-logo,
        body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-logo {
            width: min(100%, 17rem);
            inline-size: min(100%, 17rem);
            height: 4.55rem;
            block-size: 4.55rem;
        }

        body.bluecg-login-page .bluecg-login-form {
            padding: .75rem;
        }

        body.bluecg-login-page .bluecg-login-tabs {
            grid-template-columns: 1fr;
        }
    }
}

/* System visual polish pass 2026-05-25 */
@media all {
    body.bluecg-page {
        color: var(--bcg-ink);
        font-family: var(--bcg-font-sans);
        -webkit-font-smoothing: antialiased;
        text-rendering: optimizeLegibility;
    }

    body.bluecg-member-page .bluecg-shell.wide {
        width: min(100% - 2rem, 92rem);
    }

    .bluecg-logo {
        border-color: rgba(36, 120, 117, .16);
        background-color: transparent;
        box-shadow:
            0 .75rem 1.6rem rgba(31, 24, 18, .08),
            inset 0 1px 0 rgba(255, 255, 255, .72);
    }

    .bluecg-brand.compact {
        border-color: rgba(36, 120, 117, .15);
        background:
            linear-gradient(90deg, rgba(255, 254, 249, .96), rgba(255, 249, 238, .87)),
            var(--bcg-art-hero) right center / auto 120% no-repeat;
    }

    .bluecg-title,
    .bluecg-heading h1,
    .bluecg-heading h2,
    .bluecg-section-title h2,
    .bluecg-card h3,
    .bluecg-form-card h3 {
        letter-spacing: 0;
    }

    .bluecg-panel,
    .bluecg-nav,
    .bluecg-card,
    .bluecg-menu-item,
    .bluecg-table-wrap {
        box-shadow:
            0 1rem 2.6rem rgba(37, 29, 21, .075),
            inset 0 1px 0 rgba(255, 255, 255, .76);
    }

    .bluecg-panel.quest {
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .97), rgba(255, 249, 238, .92)),
            radial-gradient(circle at 100% 0, rgba(36, 120, 117, .08), transparent 18rem);
    }

    .bluecg-heading,
    .bluecg-section-title {
        align-items: center;
    }

    .bluecg-heading h2,
    .bluecg-section-title h2 {
        font-family: var(--bcg-font-display);
        font-size: clamp(1.22rem, 1.55vw, 1.62rem);
    }

    .bluecg-heading p,
    .bluecg-section-title p,
    .bluecg-meta,
    .bluecg-hint {
        line-height: 1.72;
    }

    .bluecg-statusbar {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 8.8rem), 1fr));
        gap: .72rem;
    }

    .bluecg-stat {
        min-height: 5.15rem;
        padding: .8rem .9rem;
        border-color: rgba(36, 120, 117, .14);
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .98), rgba(249, 245, 236, .91));
    }

    .bluecg-stat span {
        color: color-mix(in srgb, var(--bcg-muted) 88%, black);
        font-weight: 850;
    }

    .bluecg-stat strong {
        font-size: clamp(1.12rem, 1.9vw, 1.52rem);
        line-height: 1.15;
    }

    .bluecg-dashboard-card,
    .bluecg-menu-item {
        border: 1px solid rgba(36, 120, 117, .14);
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .98), rgba(250, 246, 239, .9));
    }

    .bluecg-dashboard-card {
        min-height: 8.2rem;
        padding: .95rem;
        border-radius: 1rem;
        box-shadow: 0 .85rem 1.8rem rgba(37, 29, 21, .065);
        text-decoration: none;
    }

    .bluecg-dashboard-card strong,
    .bluecg-menu-item strong {
        color: var(--bcg-ink);
        line-height: 1.28;
    }

    .bluecg-dashboard-card small,
    .bluecg-menu-item span {
        color: var(--bcg-muted);
        line-height: 1.5;
    }

    .bluecg-form-row {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 16rem), 1fr));
        gap: .8rem 1rem;
        align-items: end;
    }

    .bluecg-form-row .bluecg-button {
        min-height: var(--bcg-control-h);
    }

    .bluecg-field input,
    .bluecg-field select,
    .bluecg-field textarea,
    .bluecg-table input,
    .bluecg-table select,
    .bluecg-textarea {
        border-color: rgba(82, 67, 51, .2);
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .98), rgba(255, 251, 244, .94));
    }

    .bluecg-table-wrap {
        border-color: rgba(36, 120, 117, .13);
        background: rgba(255, 254, 249, .78);
    }

    .bluecg-table {
        border-spacing: 0;
    }

    .bluecg-table th {
        background:
            linear-gradient(180deg, #fffefa, #f4ead7);
        color: #2c2722;
        font-size: .86rem;
        font-weight: 950;
        white-space: nowrap;
    }

    .bluecg-table td {
        color: var(--bcg-ink-soft);
        vertical-align: middle;
    }

    .bluecg-table tbody tr:hover td {
        background: color-mix(in srgb, var(--bcg-teal) 7%, #fffefa);
    }

    .bluecg-content-image {
        display: grid;
        place-items: center;
        overflow: hidden;
        border: 1px solid rgba(36, 120, 117, .13);
        border-radius: 1rem;
        background: linear-gradient(180deg, rgba(255, 254, 249, .95), rgba(250, 246, 238, .9));
    }

    .bluecg-content-image img {
        display: block;
        width: 100%;
        max-height: min(30rem, 68vh);
        object-fit: contain;
    }
}

@media all {
    body.bluecg-game-page .bluecg-game-jump {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 13rem), 1fr));
        gap: .72rem;
        margin: 1rem 0;
        padding: .85rem;
        border: 1px solid rgba(83, 70, 55, .13);
        border-radius: 1.1rem;
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .92), rgba(249, 244, 235, .78));
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, .82);
    }

    body.bluecg-game-page .bluecg-game-jump a {
        position: relative;
        display: grid;
        grid-template-columns: 2.35rem minmax(0, 1fr) auto;
        grid-template-areas:
            "icon title count"
            "icon hint count";
        gap: .08rem .7rem;
        align-items: center;
        min-height: 4.2rem;
        padding: .7rem .75rem;
        overflow: hidden;
        border: 1px solid rgba(83, 70, 55, .13);
        border-radius: .95rem;
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .98), rgba(250, 246, 238, .9));
        color: var(--bcg-ink);
        text-decoration: none;
        box-shadow: 0 .55rem 1.2rem rgba(37, 29, 21, .055);
        transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease, background .18s ease;
    }

    body.bluecg-game-page .bluecg-game-jump a::before {
        grid-area: icon;
        display: grid;
        place-items: center;
        width: 2.35rem;
        height: 2.35rem;
        border-radius: .82rem;
        background:
            linear-gradient(135deg, rgba(53, 163, 157, .95), rgba(37, 95, 133, .95));
        color: white;
        content: attr(data-nav);
        font-weight: 950;
        box-shadow:
            0 .55rem 1rem rgba(36, 120, 117, .18),
            inset 0 1px 0 rgba(255, 255, 255, .28);
    }

    body.bluecg-game-page .bluecg-game-jump a strong {
        grid-area: title;
        min-width: 0;
        overflow: hidden;
        color: var(--bcg-ink);
        font-size: .95rem;
        font-weight: 950;
        line-height: 1.22;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-game-page .bluecg-game-jump a em {
        grid-area: hint;
        min-width: 0;
        overflow: hidden;
        color: var(--bcg-muted);
        font-size: .76rem;
        font-style: normal;
        font-weight: 720;
        line-height: 1.3;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-game-page .bluecg-game-jump a span {
        grid-area: count;
        align-self: center;
        justify-self: end;
        max-width: 4.8rem;
        min-height: 1.65rem;
        padding: .2rem .48rem;
        overflow: hidden;
        border-radius: 999px;
        background: rgba(91, 112, 99, .11);
        color: #617064;
        font-size: .72rem;
        font-weight: 900;
        line-height: 1.2;
        text-align: center;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-game-page .bluecg-game-jump a:hover,
    body.bluecg-game-page .bluecg-game-jump a:focus-visible,
    body.bluecg-game-page .bluecg-game-jump a.active {
        border-color: rgba(36, 120, 117, .34);
        background:
            linear-gradient(180deg, rgba(239, 251, 248, .98), rgba(255, 250, 238, .94));
        box-shadow:
            0 .9rem 1.9rem rgba(36, 120, 117, .12),
            inset 0 1px 0 rgba(255, 255, 255, .86);
        transform: translateY(-1px);
    }

    body.bluecg-game-page .bluecg-game-jump a.active::before {
        background:
            linear-gradient(135deg, rgba(240, 200, 107, .98), rgba(169, 93, 99, .96));
    }

    body.bluecg-game-page .bluecg-game-jump a.active span {
        background: rgba(36, 120, 117, .13);
        color: var(--bcg-teal);
    }

    body.bluecg-game-page .bluecg-record-tabs {
        display: flex;
        flex-wrap: wrap;
        gap: .55rem;
    }

    body.bluecg-game-page .bluecg-record-tabs a {
        min-height: 2.45rem;
        padding: .5rem .82rem;
        border-radius: 999px;
        font-weight: 900;
    }

    body.bluecg-game-page .bluecg-game-result-note {
        margin: .85rem 0;
        padding: .72rem .85rem;
        border: 1px solid rgba(36, 120, 117, .14);
        border-radius: .85rem;
        background: rgba(239, 251, 248, .7);
        color: color-mix(in srgb, var(--bcg-muted) 88%, black);
        font-weight: 780;
        line-height: 1.55;
    }

    body.bluecg-game-page .bluecg-game-character-summary,
    body.bluecg-game-page .bluecg-game-character-note,
    body.bluecg-game-page .bluecg-game-fact-grid span {
        border-color: rgba(36, 120, 117, .13);
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .98), rgba(250, 246, 238, .9));
    }
}

@media all {
    body.bluecg-login-page .bluecg-login-shell {
        width: min(100% - 1.5rem, 74rem);
    }

    body.bluecg-login-page .bluecg-login-panel,
    body.bluecg-login-page .bluecg-panel.quest.bluecg-login-panel {
        border-radius: 1.25rem;
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .98), rgba(255, 249, 238, .94));
    }

    body.bluecg-login-page .bluecg-login-brand .bluecg-logo,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-logo {
        block-size: 4rem;
        border-color: transparent;
        background-color: transparent;
        box-shadow: none;
    }

    body.bluecg-login-page .bluecg-login-copy span {
        font-family: var(--bcg-font-display);
        font-size: 1.12rem;
    }

    body.bluecg-login-page .bluecg-login-form {
        gap: .75rem;
    }

    body.bluecg-login-page .bluecg-login-tabs {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        padding: .35rem;
        border: 1px solid rgba(36, 120, 117, .13);
        border-radius: 1rem;
        background: rgba(255, 254, 249, .76);
    }

    body.bluecg-login-page .bluecg-login-tabs label {
        min-height: 2.75rem;
        border-radius: .8rem;
    }

    body.bluecg-login-page .bluecg-login-powered {
        margin-top: .85rem;
        color: var(--bcg-muted);
        font-size: .76rem;
        font-weight: 850;
        letter-spacing: 0;
        text-align: center;
    }

    @media (min-width: 980px) {
        body.bluecg-login-page .bluecg-login-panel,
        body.bluecg-login-page .bluecg-panel.quest.bluecg-login-panel {
            display: grid;
            grid-template-columns: minmax(22rem, .95fr) minmax(26rem, 1fr);
            min-height: 43rem;
            overflow: hidden;
        }

        body.bluecg-login-page .bluecg-login-panel::after {
            position: relative;
            inset: auto;
            display: block;
            grid-column: 1;
            grid-row: 1;
            min-height: 100%;
            border-radius: 1.1rem 0 0 1.1rem;
            background:
                linear-gradient(90deg, rgba(255, 254, 249, .08), rgba(255, 254, 249, .78) 92%),
                var(--bcg-art-login) center / cover no-repeat;
            content: "";
        }

        body.bluecg-login-page .bluecg-login-panel .bluecg-panel-inner {
            display: grid;
            grid-column: 2;
            grid-row: 1;
            align-content: center;
            padding: clamp(1.25rem, 2.6vw, 2rem);
        }
    }
}

@media (max-width: 720px) {
    body.bluecg-member-page .bluecg-shell.wide,
    body.bluecg-login-page .bluecg-login-shell {
        width: min(100% - 1rem, 100%);
    }

    .bluecg-brand.compact {
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .96), rgba(255, 249, 238, .92)),
            var(--bcg-art-hero-mobile) top right / auto 130% no-repeat;
    }

    .bluecg-heading,
    .bluecg-section-title {
        grid-template-columns: 2.75rem minmax(0, 1fr);
    }

    .bluecg-dashboard-card {
        min-height: 0;
    }

    body.bluecg-game-page .bluecg-game-jump {
        grid-template-columns: 1fr;
        padding: .65rem;
    }

    body.bluecg-game-page .bluecg-game-jump a {
        min-height: 3.9rem;
    }

    body.bluecg-login-page .bluecg-login-tabs {
        grid-template-columns: 1fr;
    }
}

/* Overall page polish */
@media all {
    body.bluecg-page {
        text-rendering: optimizeLegibility;
    }

    body.bluecg-page .bluecg-shell.wide {
        width: min(100% - clamp(1rem, 3vw, 2.4rem), 82rem);
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact,
    body.bluecg-page .bluecg-panel.quest,
    body.bluecg-page .bluecg-card,
    body.bluecg-page .bluecg-form-card,
    body.bluecg-page .bluecg-table-wrap,
    body.bluecg-page .bluecg-nav {
        border-color: rgba(67, 55, 42, .13);
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .74),
            0 .7rem 1.75rem rgba(36, 28, 20, .075);
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact {
        min-height: 8.75rem;
        padding: clamp(.85rem, 1.6vw, 1.15rem);
        border-radius: 1.25rem;
        background:
            linear-gradient(90deg, rgba(255, 253, 247, .94), rgba(255, 253, 247, .62) 47%, rgba(255, 241, 208, .72)),
            var(--bcg-art-hero, url("bluecg-art-hero-20260523.webp")) right 34% center / auto 150% no-repeat;
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact .bluecg-logo {
        inline-size: clamp(8.75rem, 18vw, 13.5rem);
        block-size: clamp(2.85rem, 6vw, 3.7rem);
        border: 0;
        background-color: transparent;
        box-shadow: none;
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact .bluecg-title {
        font-size: clamp(1.45rem, 3vw, 2.35rem);
        line-height: 1.08;
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact .bluecg-subtitle {
        max-width: 38rem;
        font-size: clamp(.88rem, 1.4vw, 1rem);
        line-height: 1.52;
    }

    body.bluecg-page .bluecg-nav {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 7.75rem), 1fr));
        gap: .5rem;
        padding: .5rem;
        overflow: visible;
        border-radius: 1.05rem;
        background: rgba(255, 253, 247, .86);
    }

    body.bluecg-page .bluecg-nav a {
        min-width: 0;
        min-height: 2.55rem;
        padding: .58rem .68rem;
        border-radius: .78rem;
        background: rgba(255, 255, 252, .58);
        color: #5f554d;
        font-size: .88rem;
        font-weight: 900;
        white-space: normal;
        text-align: center;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, .72);
    }

    body.bluecg-page .bluecg-nav a:hover,
    body.bluecg-page .bluecg-nav a:focus-visible,
    body.bluecg-page .bluecg-nav a.active {
        border-color: rgba(36, 120, 117, .26);
        background:
            linear-gradient(180deg, rgba(239, 251, 248, .96), rgba(255, 251, 240, .92));
        color: #1f7774;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .8),
            0 .45rem 1rem rgba(36, 120, 117, .12);
    }

    body.bluecg-page .bluecg-panel.quest {
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .94), rgba(249, 243, 231, .9));
    }

    body.bluecg-page .bluecg-panel-inner {
        padding: clamp(1rem, 2vw, 1.45rem);
    }

    body.bluecg-page .bluecg-heading,
    body.bluecg-page .bluecg-section-title {
        gap: .7rem;
        margin-block-end: 1.05rem;
    }

    body.bluecg-page .bluecg-heading-badge {
        inline-size: 2.65rem;
        block-size: 2.65rem;
        border-radius: .82rem;
        box-shadow: 0 .65rem 1.1rem rgba(36, 120, 117, .16);
    }

    body.bluecg-page .bluecg-card,
    body.bluecg-page .bluecg-dashboard-card,
    body.bluecg-page .bluecg-menu-item {
        border-radius: 1rem;
    }

    body.bluecg-page .bluecg-card:hover,
    body.bluecg-page .bluecg-dashboard-card:hover,
    body.bluecg-page .bluecg-menu-item:hover {
        transform: translateY(-1px);
    }

    body.bluecg-page .bluecg-field input,
    body.bluecg-page .bluecg-field select,
    body.bluecg-page .bluecg-field textarea,
    body.bluecg-page .bluecg-table input,
    body.bluecg-page .bluecg-table select {
        min-height: 2.85rem;
        border-radius: .82rem;
        background: rgba(255, 255, 252, .86);
    }

    body.bluecg-page .bluecg-button,
    body.bluecg-page .bluecg-link-button {
        min-height: 2.95rem;
        border-radius: .82rem;
    }

    body.bluecg-page .bluecg-mini-button {
        border-radius: .78rem;
        font-size: .86rem;
    }

    body.bluecg-page .bluecg-table-wrap {
        border-radius: 1rem;
        background: rgba(255, 254, 249, .82);
    }

    body.bluecg-page .bluecg-table {
        border-collapse: separate;
        border-spacing: 0;
    }

    body.bluecg-page .bluecg-table th {
        position: sticky;
        top: 0;
        z-index: 2;
        background:
            linear-gradient(180deg, rgba(255, 251, 240, .98), rgba(246, 238, 222, .96));
    }

    body.bluecg-page .bluecg-table td {
        vertical-align: middle;
    }

    body.bluecg-game-register-page .bluecg-register-layout {
        grid-template-columns: minmax(0, 1fr) minmax(19rem, 25rem);
    }

    body.bluecg-game-register-page .bluecg-register-steps {
        background:
            linear-gradient(135deg, rgba(236, 250, 247, .92), rgba(255, 247, 228, .88));
    }

    body.bluecg-game-register-page .bluecg-register-step-list {
        display: grid;
        gap: .65rem;
        margin: 0;
        padding: 0;
        list-style: none;
    }

    body.bluecg-game-register-page .bluecg-register-step-list li {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        gap: .08rem .65rem;
        align-items: center;
        padding: .65rem;
        border: 1px solid rgba(64, 52, 42, .1);
        border-radius: .85rem;
        background: rgba(255, 255, 253, .7);
    }

    body.bluecg-game-register-page .bluecg-register-step-list span {
        grid-row: 1 / 3;
        display: grid;
        place-items: center;
        inline-size: 2rem;
        block-size: 2rem;
        border-radius: 999px;
        background: #247875;
        color: white;
        font-size: .82rem;
        font-weight: 950;
    }

    body.bluecg-game-register-page .bluecg-register-step-list strong,
    body.bluecg-game-register-page .bluecg-register-step-list small {
        min-width: 0;
    }

    body.bluecg-game-register-page .bluecg-register-step-list strong {
        color: #211f1d;
        font-weight: 950;
        line-height: 1.25;
    }

    body.bluecg-game-register-page .bluecg-register-step-list small {
        color: #6f655d;
        font-size: .78rem;
        font-weight: 720;
        line-height: 1.35;
    }

    body.bluecg-game-register-page .bluecg-register-show-password {
        justify-self: start;
        min-height: 2.35rem;
        padding-block: .42rem;
    }

    body.bluecg-game-register-page .bluecg-register-blocked {
        margin: 0;
    }

    body.bluecg-login-page .bluecg-login-panel {
        border-radius: 1.25rem;
    }

    body.bluecg-login-page .bluecg-login-form input,
    body.bluecg-login-page .bluecg-login-form select {
        min-height: 2.95rem;
    }

    @media (max-width: 820px) {
        body.bluecg-page .bluecg-shell.wide,
        body.bluecg-page .bluecg-shell {
            width: min(100% - 1rem, 82rem);
        }

        body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact {
            min-height: 7.25rem;
            grid-template-columns: auto minmax(0, 1fr);
            background:
                linear-gradient(90deg, rgba(255, 253, 247, .96), rgba(255, 253, 247, .82)),
                var(--bcg-art-hero-mobile, url("bluecg-art-hero-mobile.webp")) center 18% / cover no-repeat;
        }

        body.bluecg-page .bluecg-nav {
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: .42rem;
        }

        body.bluecg-page .bluecg-nav a {
            min-height: 2.65rem;
            font-size: .84rem;
        }

        body.bluecg-page .bluecg-table th {
            position: static;
        }

        body.bluecg-game-register-page .bluecg-register-layout {
            grid-template-columns: 1fr;
        }
    }

    @media (max-width: 430px) {
        body.bluecg-page .bluecg-nav {
            grid-template-columns: 1fr;
        }

        body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact {
            grid-template-columns: 1fr;
            text-align: start;
        }

        body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact .bluecg-logo {
            inline-size: 10.5rem;
        }
    }
}

/* Game account registration */
@media all {
    body.bluecg-game-register-page .bluecg-register-hero .bluecg-panel-inner {
        display: grid;
        grid-template-columns: minmax(0, 1fr) minmax(17rem, .82fr);
        gap: 1rem;
        align-items: stretch;
        background:
            linear-gradient(90deg, rgba(255, 253, 247, .96), rgba(255, 253, 247, .72) 42%, rgba(255, 244, 216, .76)),
            var(--bcg-art-section, url("bluecg-art-section-quest-20260523.jpg")) right 34% center / auto 170% no-repeat;
    }

    body.bluecg-game-register-page .bluecg-register-hero-copy {
        display: grid;
        align-content: center;
        gap: .55rem;
        min-height: 10.5rem;
        max-width: 44rem;
    }

    body.bluecg-game-register-page .bluecg-register-hero-copy h2 {
        margin: 0;
        color: #211f1d;
        font-family: var(--bcg-font-display);
        font-size: clamp(1.75rem, 3.5vw, 3rem);
        font-weight: 950;
        line-height: 1.08;
        text-wrap: balance;
    }

    body.bluecg-game-register-page .bluecg-register-hero-copy p {
        max-width: 35rem;
        margin: 0;
        color: #514842;
        font-size: 1rem;
        font-weight: 720;
        line-height: 1.65;
        text-wrap: pretty;
    }

    body.bluecg-game-register-page .bluecg-register-profile-grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: .65rem;
        align-content: center;
    }

    body.bluecg-game-register-page .bluecg-register-profile-grid article,
    body.bluecg-game-register-page .bluecg-register-account-list article {
        min-width: 0;
        border: 1px solid rgba(64, 52, 42, .13);
        border-radius: .95rem;
        background: rgba(255, 255, 251, .74);
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, .85);
    }

    body.bluecg-game-register-page .bluecg-register-profile-grid article {
        display: grid;
        grid-template-columns: minmax(5.5rem, auto) minmax(0, 1fr);
        gap: .18rem .7rem;
        align-items: center;
        padding: .74rem .82rem;
    }

    body.bluecg-game-register-page .bluecg-register-profile-grid span {
        grid-row: 1 / 3;
        color: #247872;
        font-size: .75rem;
        font-weight: 950;
        text-transform: uppercase;
    }

    body.bluecg-game-register-page .bluecg-register-profile-grid strong,
    body.bluecg-game-register-page .bluecg-register-profile-grid small,
    body.bluecg-game-register-page .bluecg-register-account-list strong,
    body.bluecg-game-register-page .bluecg-register-account-list small {
        min-width: 0;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-game-register-page .bluecg-register-profile-grid strong {
        color: #211f1d;
        font-size: .98rem;
        font-weight: 950;
    }

    body.bluecg-game-register-page .bluecg-register-profile-grid small {
        color: #756b62;
        font-size: .78rem;
        font-weight: 760;
    }

    body.bluecg-game-register-page .bluecg-register-layout {
        display: grid;
        grid-template-columns: minmax(0, 1fr) minmax(18rem, 24rem);
        gap: 1rem;
        align-items: start;
        margin-top: 1rem;
    }

    body.bluecg-game-register-page .bluecg-register-form .bluecg-field input {
        font-weight: 780;
    }

    body.bluecg-game-register-page .bluecg-register-form .bluecg-button {
        min-height: 3.05rem;
        font-size: 1rem;
    }

    body.bluecg-game-register-page .bluecg-register-terms {
        align-items: flex-start;
        line-height: 1.5;
    }

    body.bluecg-game-register-page .bluecg-register-meter {
        position: relative;
        height: .45rem;
        margin-top: .5rem;
        overflow: hidden;
        border-radius: 999px;
        background: rgba(64, 52, 42, .1);
    }

    body.bluecg-game-register-page .bluecg-register-meter span {
        display: block;
        inline-size: 0;
        block-size: 100%;
        border-radius: inherit;
        background: linear-gradient(90deg, #c56b62, #c4872f, #247875);
        transition: inline-size .2s ease;
    }

    body.bluecg-game-register-page #password-match-hint[data-state="ok"] {
        color: #257a58;
    }

    body.bluecg-game-register-page #password-match-hint[data-state="bad"] {
        color: #b34242;
    }

    body.bluecg-game-register-page .bluecg-register-sidebar {
        display: grid;
        gap: 1rem;
    }

    body.bluecg-game-register-page .bluecg-register-rules ul {
        display: grid;
        gap: .55rem;
        margin: 0;
        padding-left: 1.15rem;
        color: #514842;
        font-weight: 720;
        line-height: 1.55;
    }

    body.bluecg-game-register-page .bluecg-register-existing {
        gap: .85rem;
    }

    body.bluecg-game-register-page .bluecg-register-account-list {
        display: grid;
        gap: .52rem;
    }

    body.bluecg-game-register-page .bluecg-register-account-list article {
        display: grid;
        gap: .12rem;
        padding: .72rem .78rem;
    }

    body.bluecg-game-register-page .bluecg-register-account-list strong {
        color: #211f1d;
        font-size: .96rem;
        font-weight: 950;
    }

    body.bluecg-game-register-page .bluecg-register-account-list small {
        color: #776d64;
        font-size: .76rem;
        font-weight: 720;
    }

    body.bluecg-game-register-page .bluecg-register-success {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        align-items: center;
    }

    body.bluecg-game-register-page .bluecg-register-success strong {
        font-family: var(--bcg-font-display);
        font-size: 1.05rem;
        font-weight: 950;
    }

    @media (max-width: 980px) {
        body.bluecg-game-register-page .bluecg-register-hero .bluecg-panel-inner,
        body.bluecg-game-register-page .bluecg-register-layout {
            grid-template-columns: 1fr;
        }

        body.bluecg-game-register-page .bluecg-register-profile-grid {
            grid-template-columns: repeat(3, minmax(0, 1fr));
        }
    }

    @media (max-width: 720px) {
        body.bluecg-game-register-page .bluecg-register-hero .bluecg-panel-inner {
            background:
                linear-gradient(180deg, rgba(255, 253, 247, .97), rgba(255, 253, 247, .82)),
                var(--bcg-art-hero-mobile, url("bluecg-art-hero-mobile-20260523.webp")) top center / 100% auto no-repeat;
        }

        body.bluecg-game-register-page .bluecg-register-hero-copy {
            min-height: 8.5rem;
        }

        body.bluecg-game-register-page .bluecg-register-profile-grid {
            grid-template-columns: 1fr;
        }

        body.bluecg-game-register-page .bluecg-register-profile-grid article {
            grid-template-columns: minmax(4.8rem, auto) minmax(0, 1fr);
        }
    }
}

/* Member dashboard final layout */
@media all {
    body.bluecg-dashboard-page .bluecg-dashboard-home {
        margin-bottom: 1rem;
    }

    body.bluecg-dashboard-page .bluecg-dashboard-hero {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 1rem;
        align-items: center;
    }

    body.bluecg-dashboard-page .bluecg-profile.compact {
        margin: 0;
        padding: 0;
        border: 0;
        background: transparent;
        box-shadow: none;
    }

    body.bluecg-dashboard-page .bluecg-profile.compact h2 {
        margin: .12rem 0 .2rem;
        color: var(--bcg-ink);
        font-size: clamp(1.35rem, 2.2vw, 1.8rem);
        font-weight: 950;
        letter-spacing: 0;
    }

    body.bluecg-dashboard-page .bluecg-profile.compact p {
        margin: 0;
        color: #6d6258;
        font-weight: 760;
        line-height: 1.55;
    }

    body.bluecg-dashboard-page .bluecg-dashboard-actions {
        display: flex;
        flex-wrap: wrap;
        gap: .45rem;
        justify-content: flex-end;
        min-width: min(100%, 24rem);
    }

    body.bluecg-dashboard-page .bluecg-dashboard-actions .bluecg-mini-button {
        min-height: 2.35rem;
        padding-inline: .86rem;
        border: 1px solid rgba(36, 120, 117, .18);
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .95), rgba(235, 249, 246, .86));
        color: #237872;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, .9);
    }

    body.bluecg-dashboard-page .bluecg-dashboard-stats {
        margin-top: 1rem;
    }

    body.bluecg-dashboard-page .bluecg-dashboard-layout {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1rem;
    }

    body.bluecg-dashboard-page .bluecg-dashboard-wide {
        grid-column: 1 / -1;
    }

    body.bluecg-dashboard-page .bluecg-dashboard-list {
        display: grid;
        gap: .55rem;
    }

    body.bluecg-dashboard-page .bluecg-dashboard-card-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 14.5rem), 1fr));
        gap: .72rem;
    }

    body.bluecg-dashboard-page .bluecg-dashboard-card {
        position: relative;
        display: grid;
        align-content: start;
        gap: .38rem;
        min-height: 8.1rem;
        padding: .82rem .9rem .9rem;
        overflow: hidden;
        border: 1px solid rgba(109, 88, 66, .14);
        border-radius: .82rem;
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .97), rgba(250, 246, 238, .9));
        color: #3d3028;
        text-decoration: none;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .9),
            0 .45rem 1rem rgba(44, 34, 24, .06);
    }

    body.bluecg-dashboard-page .bluecg-dashboard-card::before {
        position: absolute;
        inset: 0 0 auto;
        height: .22rem;
        background: linear-gradient(90deg, #2a918a, #d69a36);
        opacity: .75;
        content: "";
    }

    body.bluecg-dashboard-page .bluecg-dashboard-card:hover,
    body.bluecg-dashboard-page .bluecg-dashboard-card:focus-visible {
        border-color: rgba(36, 120, 117, .34);
        color: #1f7771;
        transform: translateY(-2px);
        box-shadow:
            0 .72rem 1.4rem rgba(47, 72, 66, .12),
            inset 0 1px 0 rgba(255, 255, 255, .92);
    }

    body.bluecg-dashboard-page .bluecg-dashboard-card .bluecg-pill {
        justify-self: start;
        margin-bottom: .08rem;
    }

    body.bluecg-dashboard-page .bluecg-dashboard-card strong {
        display: -webkit-box;
        min-height: 2.25em;
        overflow: hidden;
        color: inherit;
        font-size: 1rem;
        font-weight: 950;
        line-height: 1.25;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
    }

    body.bluecg-dashboard-page .bluecg-dashboard-card small {
        display: block;
        min-width: 0;
        overflow: hidden;
        color: #756a60;
        font-size: .78rem;
        font-weight: 720;
        line-height: 1.32;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-dashboard-page .bluecg-dashboard-event-card {
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .98), rgba(239, 250, 247, .9));
    }

    body.bluecg-dashboard-page .bluecg-dashboard-submission-card {
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .98), rgba(255, 249, 235, .9));
    }

    body.bluecg-dashboard-page .bluecg-dashboard-reward-card {
        min-height: 7.4rem;
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .98), rgba(249, 242, 252, .9));
    }

    body.bluecg-dashboard-page .bluecg-dashboard-card-grid.rewards {
        margin-top: .9rem;
    }

    body.bluecg-dashboard-page .bluecg-dashboard-row {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        gap: .16rem .65rem;
        align-items: center;
        min-height: 3.45rem;
        padding: .62rem .72rem;
        border: 1px solid rgba(109, 88, 66, .14);
        border-radius: .72rem;
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .96), rgba(250, 246, 238, .9));
        color: #3d3028;
        text-decoration: none;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, .86);
    }

    body.bluecg-dashboard-page .bluecg-dashboard-row:hover,
    body.bluecg-dashboard-page .bluecg-dashboard-row:focus-visible {
        border-color: rgba(36, 120, 117, .34);
        color: #1f7771;
        transform: translateY(-1px);
        box-shadow:
            0 .45rem 1rem rgba(47, 72, 66, .1),
            inset 0 1px 0 rgba(255, 255, 255, .9);
    }

    body.bluecg-dashboard-page .bluecg-dashboard-row .bluecg-pill {
        grid-row: 1 / 3;
        min-width: 4.4rem;
        justify-content: center;
        text-align: center;
    }

    body.bluecg-dashboard-page .bluecg-dashboard-row strong {
        min-width: 0;
        overflow: hidden;
        color: inherit;
        font-size: .95rem;
        font-weight: 930;
        line-height: 1.24;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-dashboard-page .bluecg-dashboard-row small {
        min-width: 0;
        overflow: hidden;
        color: #756a60;
        font-size: .78rem;
        font-weight: 720;
        line-height: 1.25;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-dashboard-page .bluecg-dashboard-resource-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 14rem), 1fr));
        gap: .7rem;
        margin-bottom: .9rem;
    }

    body.bluecg-dashboard-page .bluecg-phase-open {
        background: rgba(35, 132, 127, .13);
        color: #1f7771;
    }

    body.bluecg-dashboard-page .bluecg-phase-vote {
        background: rgba(201, 137, 38, .15);
        color: #8a5d1b;
    }

    body.bluecg-dashboard-page .bluecg-phase-soon {
        background: rgba(77, 108, 167, .13);
        color: #405e92;
    }

    body.bluecg-dashboard-page .bluecg-phase-closed {
        background: rgba(103, 96, 89, .13);
        color: #635a52;
    }

    @media (max-width: 860px) {
        body.bluecg-dashboard-page .bluecg-dashboard-hero,
        body.bluecg-dashboard-page .bluecg-dashboard-layout {
            grid-template-columns: 1fr;
        }

        body.bluecg-dashboard-page .bluecg-dashboard-actions {
            justify-content: stretch;
            min-width: 0;
        }

        body.bluecg-dashboard-page .bluecg-dashboard-actions .bluecg-mini-button {
            flex: 1 1 9rem;
        }
    }

    @media (max-width: 520px) {
        body.bluecg-dashboard-page .bluecg-dashboard-row {
            grid-template-columns: 1fr;
            gap: .34rem;
        }

        body.bluecg-dashboard-page .bluecg-dashboard-row .bluecg-pill {
            grid-row: auto;
            justify-self: start;
        }

        body.bluecg-dashboard-page .bluecg-dashboard-row strong,
        body.bluecg-dashboard-page .bluecg-dashboard-row small,
        body.bluecg-dashboard-page .bluecg-dashboard-card small {
            white-space: normal;
        }
    }
}

/* System-wide data comfort final override */
@media all {
    body.bluecg-page {
        accent-color: var(--bcg-teal);
    }

    body.bluecg-page :where(.bluecg-nav a, .bluecg-button, .bluecg-link-button, .bluecg-mini-button, button, input, select, textarea) {
        touch-action: manipulation;
    }

    body.bluecg-page .bluecg-nav {
        scrollbar-width: thin;
        scrollbar-color: rgba(36, 120, 117, .36) transparent;
    }

    body.bluecg-page .bluecg-field label,
    body.bluecg-page .bluecg-label {
        min-height: 1.25rem;
    }

    body.bluecg-page .bluecg-field input,
    body.bluecg-page .bluecg-field select,
    body.bluecg-page .bluecg-field textarea,
    body.bluecg-page .bluecg-table input,
    body.bluecg-page .bluecg-table select {
        line-height: 1.35;
    }

    body.bluecg-page .bluecg-table-wrap {
        border-color: rgba(109, 88, 66, .16);
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .98), rgba(249, 245, 237, .94));
        box-shadow:
            0 .65rem 1.35rem rgba(44, 34, 24, .07),
            inset 0 1px 0 rgba(255, 255, 255, .9);
        scrollbar-width: thin;
    }

    body.bluecg-page .bluecg-table {
        font-variant-numeric: tabular-nums;
    }

    body.bluecg-page .bluecg-table th,
    body.bluecg-page .bluecg-table td {
        line-height: 1.5;
    }

    body.bluecg-page .bluecg-table th {
        backdrop-filter: blur(8px);
        box-shadow: inset 0 -1px 0 rgba(109, 88, 66, .12);
    }

    body.bluecg-page .bluecg-table :is(th, td):first-child {
        padding-left: 1rem;
    }

    body.bluecg-page .bluecg-table :is(th, td):last-child {
        padding-right: 1rem;
    }

    body.bluecg-page .bluecg-table tbody tr:last-child td {
        border-bottom: 0;
    }

    body.bluecg-page .bluecg-table tbody tr:hover td {
        color: #282018;
    }

    body.bluecg-page .bluecg-empty {
        min-height: 3.8rem;
        border-style: solid;
        background:
            linear-gradient(180deg, rgba(255, 255, 252, .86), rgba(239, 250, 247, .62));
        color: color-mix(in srgb, var(--bcg-muted) 88%, black);
    }

    body.bluecg-page .bluecg-panel.quest {
        overflow: hidden;
    }

    @media (max-width: 720px) {
        body.bluecg-page .bluecg-form-row {
            gap: .75rem;
        }

        body.bluecg-page .bluecg-table-wrap {
            margin-block: .75rem;
            border-radius: .85rem;
        }

        body.bluecg-page .bluecg-table-wrap::before {
            position: sticky;
            left: .5rem;
            z-index: 3;
            display: inline-flex;
            align-items: center;
            min-height: 1.75rem;
            margin: .5rem .5rem 0;
            padding: .2rem .55rem;
            border: 1px solid rgba(36, 120, 117, .16);
            border-radius: 999px;
            background: rgba(255, 255, 252, .92);
            color: #53665d;
            font-size: .72rem;
            font-weight: 850;
            line-height: 1;
            box-shadow: 0 .28rem .65rem rgba(49, 38, 27, .08);
            content: "左右滑動查看更多";
            pointer-events: none;
        }

        body.bluecg-page .bluecg-table {
            min-width: 40rem;
            font-size: .82rem;
        }

        body.bluecg-page .bluecg-table th,
        body.bluecg-page .bluecg-table td {
            padding: .62rem .68rem;
        }

        body.bluecg-page .bluecg-table .bluecg-button,
        body.bluecg-page .bluecg-table .bluecg-link-button,
        body.bluecg-page .bluecg-table .bluecg-mini-button {
            min-height: 2.15rem;
            padding-inline: .65rem;
        }
    }

    @media (prefers-reduced-motion: reduce) {
        body.bluecg-page,
        body.bluecg-page * {
            scroll-behavior: auto !important;
        }

        body.bluecg-page *,
        body.bluecg-page *::before,
        body.bluecg-page *::after {
            animation-duration: .01ms !important;
            animation-iteration-count: 1 !important;
            transition-duration: .01ms !important;
        }
    }
}

/* Admin mobile navigation final override */
@media (max-width: 820px) {
    body.bluecg-admin-page .bluecg-nav {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        width: 100%;
        max-width: 100%;
        justify-content: stretch;
        gap: .42rem;
        overflow: visible;
        padding: .42rem;
        scroll-snap-type: none;
    }

    body.bluecg-admin-page .bluecg-nav a {
        inline-size: 100%;
        min-width: 0;
        min-height: 2.7rem;
        padding: .48rem .55rem;
        white-space: normal;
        text-align: center;
        line-height: 1.22;
        scroll-snap-align: none;
    }
}

/* Login powered badge final override */
@media all {
    body.bluecg-login-page .bluecg-login-powered {
        display: flex;
        align-items: center;
        justify-content: center;
        width: fit-content;
        max-width: 100%;
        min-height: 2rem;
        margin: .85rem auto 0;
        padding: .38rem .95rem;
        border: 1px solid rgba(36, 120, 117, .18);
        border-radius: 999px;
        background:
            linear-gradient(180deg, rgba(255, 255, 255, .9), rgba(246, 239, 225, .82));
        color: #5f554e;
        font-size: .78rem;
        font-weight: 850;
        letter-spacing: .08em;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .9),
            0 .45rem .9rem rgba(40, 31, 24, .06);
    }
}

/* Artwork visibility final override */
@media all {
    :root {
        --bcg-art-page: url("bluecg-art-page-20260523.webp");
        --bcg-art-hero: url("bluecg-art-hero-20260523.webp");
        --bcg-art-hero-mobile: url("bluecg-art-hero-mobile-20260523.webp");
        --bcg-art-login: url("bluecg-art-login-20260523.webp");
        --bcg-art-ui: url("bluecg-art-ui-20260523.webp");
    }

    body.bluecg-page:not(.bluecg-login-page) {
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .62), rgba(255, 249, 238, .82) 54%, rgba(239, 232, 221, .9)),
            radial-gradient(circle at 12% 4%, rgba(53, 163, 157, .16), transparent 27rem),
            radial-gradient(circle at 86% 8%, rgba(240, 200, 107, .18), transparent 24rem),
            var(--bcg-art-ui) top center / min(1800px, 150vw) auto no-repeat,
            linear-gradient(180deg, #eef7f5 0%, #fcf6ea 48%, #f1eadf 100%);
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact {
        background:
            linear-gradient(90deg, rgba(255, 254, 249, .86) 0 30%, rgba(255, 254, 249, .38) 56%, rgba(255, 250, 240, .08)),
            var(--bcg-art-hero) center 32% / cover no-repeat;
    }

    body.bluecg-login-page {
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .48), rgba(255, 250, 240, .78) 46%, rgba(236, 226, 212, .92)),
            radial-gradient(circle at 50% -6rem, rgba(36, 120, 117, .18), transparent 26rem),
            var(--bcg-art-hero) top center / min(1900px, 155vw) auto no-repeat,
            linear-gradient(180deg, #edf7f4, #f7eddf);
    }

    body.bluecg-login-page .bluecg-login-brand,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand {
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .05), rgba(255, 249, 236, .48) 68%, rgba(255, 249, 236, .78)),
            linear-gradient(90deg, rgba(255, 254, 249, .72), rgba(255, 254, 249, .05) 42%, rgba(255, 250, 240, .34)),
            var(--bcg-art-hero) center 28% / cover no-repeat;
    }

    @media (max-width: 820px) {
        body.bluecg-page:not(.bluecg-login-page) {
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .68), rgba(255, 249, 238, .88) 42%, rgba(239, 232, 221, .94)),
                var(--bcg-art-ui) top center / auto 28rem no-repeat,
                linear-gradient(180deg, #edf7f4, #f7eddf);
        }

        body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact,
        body.bluecg-login-page .bluecg-login-brand,
        body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand {
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .06), rgba(255, 249, 236, .48) 68%, rgba(255, 249, 236, .82)),
                var(--bcg-art-hero-mobile) center 18% / cover no-repeat;
        }

        body.bluecg-login-page {
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .58), rgba(255, 250, 240, .86) 42%, rgba(236, 226, 212, .96)),
                var(--bcg-art-hero-mobile) top center / 100% auto no-repeat,
                linear-gradient(180deg, #edf7f4, #f7eddf);
        }
    }
}

/* Frontend artwork polish final override */
@media all {
    body.bluecg-page:not(.bluecg-login-page) {
        background:
            radial-gradient(ellipse at 50% -8rem, rgba(255, 255, 255, .72), transparent 34rem),
            linear-gradient(180deg, rgba(255, 254, 249, .54), rgba(255, 248, 235, .82) 48%, rgba(232, 220, 202, .92)),
            var(--bcg-art-ui) top center / min(1700px, 145vw) auto no-repeat,
            linear-gradient(135deg, #e8f3ef 0%, #fbf3e5 44%, #e9decf 100%);
    }

    body.bluecg-page:not(.bluecg-login-page)::before {
        background:
            linear-gradient(180deg, rgba(255, 255, 255, .18), rgba(255, 255, 255, .56) 58%, rgba(255, 255, 255, .84)),
            radial-gradient(circle at 8% 12%, rgba(45, 129, 125, .12), transparent 20rem),
            radial-gradient(circle at 92% 8%, rgba(199, 126, 58, .14), transparent 22rem),
            repeating-linear-gradient(90deg, rgba(94, 73, 50, .026) 0 1px, transparent 1px 2.45rem),
            repeating-linear-gradient(0deg, rgba(94, 73, 50, .022) 0 1px, transparent 1px 2.45rem);
        opacity: .82;
        mask-image: linear-gradient(180deg, #000 0%, rgba(0, 0, 0, .68) 62%, transparent 100%);
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact {
        overflow: hidden;
        border-color: rgba(119, 72, 45, .2);
        background:
            linear-gradient(90deg, rgba(255, 254, 249, .94) 0 24%, rgba(255, 254, 249, .7) 43%, rgba(255, 250, 240, .16) 72%),
            linear-gradient(180deg, rgba(255, 254, 249, .16), rgba(255, 249, 236, .66)),
            var(--bcg-art-hero) right 34% center / auto 155% no-repeat,
            linear-gradient(180deg, rgba(255, 250, 240, .95), rgba(244, 232, 212, .9));
        box-shadow:
            0 1.1rem 2.2rem rgba(64, 43, 27, .12),
            inset 0 1px 0 rgba(255, 255, 255, .88),
            inset 0 -.08rem 0 rgba(151, 84, 69, .26);
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact::before {
        position: absolute;
        inset: 0 0 auto 0;
        display: block;
        height: .22rem;
        content: "";
        background: linear-gradient(90deg, #2f8a82, #d1a350 55%, #a75b68);
        opacity: .9;
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact::after {
        inset: 0 0 0 auto;
        width: min(46%, 28rem);
        height: 100%;
        background:
            radial-gradient(circle at 62% 36%, rgba(255, 255, 255, .38), transparent 34%),
            linear-gradient(90deg, rgba(255, 254, 249, .78), rgba(255, 254, 249, .1) 54%, rgba(255, 254, 249, .18));
        opacity: .72;
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-panel.quest,
    body.bluecg-page:not(.bluecg-login-page) .bluecg-card,
    body.bluecg-page:not(.bluecg-login-page) .bluecg-form-card {
        border-color: rgba(126, 82, 48, .18);
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .94), rgba(255, 249, 238, .9)),
            radial-gradient(circle at 92% 0%, rgba(219, 171, 85, .12), transparent 16rem);
        box-shadow:
            0 .85rem 1.9rem rgba(64, 43, 27, .09),
            inset 0 1px 0 rgba(255, 255, 255, .88);
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-nav {
        border-color: rgba(126, 82, 48, .16);
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .92), rgba(246, 235, 216, .84));
        box-shadow:
            0 .55rem 1.1rem rgba(64, 43, 27, .08),
            inset 0 1px 0 rgba(255, 255, 255, .9);
    }

    @media (max-width: 820px) {
        body.bluecg-page:not(.bluecg-login-page) {
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .64), rgba(255, 249, 238, .88) 44%, rgba(232, 220, 202, .94)),
                var(--bcg-art-ui) top center / auto 24rem no-repeat,
                linear-gradient(180deg, #eef7f4, #f7eddf);
        }

        body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact {
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .12), rgba(255, 249, 236, .62) 64%, rgba(255, 249, 236, .9)),
                var(--bcg-art-hero-mobile) center 18% / cover no-repeat;
        }
    }
}

/* Widescreen artwork scale final override */
@media (min-width: 821px) {
    body.bluecg-page:not(.bluecg-login-page) {
        background:
            radial-gradient(ellipse at 50% -8rem, rgba(255, 255, 255, .62), transparent 32rem),
            linear-gradient(180deg, rgba(255, 254, 249, .46), rgba(255, 248, 235, .78) 48%, rgba(232, 220, 202, .9)),
            var(--bcg-art-ui) top center / max(1900px, 160vw) auto no-repeat,
            linear-gradient(135deg, #e8f3ef 0%, #fbf3e5 44%, #e9decf 100%);
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact {
        min-height: clamp(7.8rem, 8.4vw, 9.6rem);
        background:
            linear-gradient(90deg, rgba(255, 254, 249, .93) 0 20%, rgba(255, 254, 249, .62) 38%, rgba(255, 250, 240, .08) 64%),
            linear-gradient(180deg, rgba(255, 254, 249, .08), rgba(255, 249, 236, .52)),
            var(--bcg-art-hero) center 36% / cover no-repeat,
            linear-gradient(180deg, rgba(255, 250, 240, .95), rgba(244, 232, 212, .9));
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact::after {
        width: min(62%, 42rem);
        background:
            radial-gradient(circle at 58% 36%, rgba(255, 255, 255, .22), transparent 30%),
            linear-gradient(90deg, rgba(255, 254, 249, .56), rgba(255, 254, 249, .05) 44%, rgba(255, 254, 249, .1));
        opacity: .58;
    }
}

/* Logo surface override for transparent logo art. */
@media all {
    body.bluecg-page .bluecg-logo {
        border-color: transparent;
        border-radius: 0;
        background-color: transparent;
        background-image: var(--bcg-logo-art, url("bluecg-logo-transparent-20260524.png"));
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain;
        box-shadow: none;
        filter:
            drop-shadow(0 .42rem .62rem rgba(20, 83, 92, .22))
            drop-shadow(0 0 .42rem rgba(255, 255, 255, .8));
        overflow: visible;
    }

    body.bluecg-login-page .bluecg-login-brand .bluecg-logo,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-logo {
        width: min(100%, 21rem);
        inline-size: min(100%, 21rem);
        max-inline-size: 21rem;
        height: clamp(4.9rem, 7.5vw, 5.75rem);
        block-size: clamp(4.9rem, 7.5vw, 5.75rem);
        background-color: transparent;
        box-shadow: none;
    }
}

/* Transparent logo refresh: no dark plate, tuned for the bright artwork backgrounds. */
@media all {
    :root {
        --bcg-logo-art: url("bluecg-logo-transparent-20260524.png");
    }

    body.bluecg-page .bluecg-logo {
        border: 0;
        border-radius: 0;
        background-color: transparent;
        background-image: var(--bcg-logo-art);
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain;
        box-shadow: none;
        filter:
            drop-shadow(0 .42rem .62rem rgba(20, 83, 92, .22))
            drop-shadow(0 0 .42rem rgba(255, 255, 255, .8));
        overflow: visible;
    }

    body.bluecg-login-page .bluecg-login-brand .bluecg-logo,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-logo {
        width: min(100%, 21rem);
        inline-size: min(100%, 21rem);
        max-inline-size: 21rem;
        height: clamp(4.9rem, 7.5vw, 5.75rem);
        block-size: clamp(4.9rem, 7.5vw, 5.75rem);
        background-color: transparent;
        box-shadow: none;
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact .bluecg-logo {
        width: min(16rem, 25vw);
        inline-size: min(16rem, 25vw);
        height: clamp(4.05rem, 6vw, 5rem);
        block-size: clamp(4.05rem, 6vw, 5rem);
        background-color: transparent;
        box-shadow: none;
    }

    @media (max-width: 820px) {
        body.bluecg-login-page .bluecg-login-brand .bluecg-logo,
        body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-logo {
            width: min(16rem, 100%);
            inline-size: min(16rem, 100%);
            max-inline-size: 16rem;
            height: 4.65rem;
            block-size: 4.65rem;
        }

        body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact .bluecg-logo {
            width: min(14.5rem, 72vw);
            inline-size: min(14.5rem, 72vw);
            height: 4.5rem;
            block-size: 4.5rem;
        }
    }
}

/* Event detail uploaded banner: preserve the whole image instead of cropping it as a hero cover. */
@media all {
    body.bluecg-member-page .bluecg-event-banner {
        display: flex;
        align-items: center;
        justify-content: center;
        width: min(100%, 64rem);
        margin: 1rem auto 1.15rem;
        padding: clamp(.45rem, 1.1vw, .7rem);
        overflow: hidden;
        border: 1px solid rgba(45, 129, 125, .2);
        border-radius: 1.05rem;
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .78), rgba(255, 249, 238, .58)),
            radial-gradient(circle at 50% 0%, rgba(210, 163, 80, .12), transparent 18rem);
        line-height: 0;
        box-shadow:
            0 .85rem 1.7rem rgba(50, 38, 25, .08),
            inset 0 1px 0 rgba(255, 255, 255, .84);
    }

    body.bluecg-member-page .bluecg-event-banner img {
        display: block;
        width: auto;
        max-width: 100%;
        height: auto;
        max-height: min(44vh, 24rem);
        border: 0;
        border-radius: .78rem;
        background: transparent;
        object-fit: contain;
        box-shadow: none;
    }

    @media (max-width: 760px) {
        body.bluecg-member-page .bluecg-event-banner {
            width: 100%;
            margin-block: .8rem 1rem;
            padding: .36rem;
            border-radius: .85rem;
        }

        body.bluecg-member-page .bluecg-event-banner img {
            max-height: min(40vh, 16rem);
            border-radius: .65rem;
        }
    }
}

/* Comfort polish: typography, focus states, and repeated-use controls */
@media all {
    :root {
        --bcg-font-sans: "Noto Sans TC", "Noto Sans HK", "Microsoft JhengHei UI", "Segoe UI", system-ui, sans-serif;
        --bcg-font-display: "Noto Sans TC Black", "Noto Sans TC", "Microsoft JhengHei UI", "Segoe UI Variable Display", system-ui, sans-serif;
        --bcg-focus-ring: 0 0 0 .22rem rgba(36, 120, 117, .18);
    }

    html {
        text-size-adjust: 100%;
        -webkit-text-size-adjust: 100%;
    }

    body.bluecg-page,
    body.bluecg-page input,
    body.bluecg-page select,
    body.bluecg-page textarea,
    body.bluecg-page button {
        font-family: var(--bcg-font-sans);
        letter-spacing: 0;
        text-rendering: optimizeLegibility;
    }

    body.bluecg-page .bluecg-title,
    body.bluecg-page .bluecg-hero h2,
    body.bluecg-page .bluecg-hero-content h2,
    body.bluecg-page .bluecg-card h3,
    body.bluecg-login-page .bluecg-login-copy span,
    body.bluecg-login-page .bluecg-login-tabs legend {
        font-family: var(--bcg-font-display);
        letter-spacing: 0;
    }

    body.bluecg-page ::selection {
        background: rgba(52, 170, 162, .24);
        color: #16120f;
    }

    body.bluecg-page a,
    body.bluecg-page button,
    body.bluecg-page input,
    body.bluecg-page select,
    body.bluecg-page textarea {
        transition:
            border-color .16s ease,
            box-shadow .16s ease,
            background-color .16s ease,
            color .16s ease,
            transform .16s ease;
    }

    body.bluecg-page a:focus-visible,
    body.bluecg-page button:focus-visible,
    body.bluecg-page input:focus-visible,
    body.bluecg-page select:focus-visible,
    body.bluecg-page textarea:focus-visible,
    body.bluecg-page .bluecg-choice label:has(input:focus-visible) {
        outline: none;
        box-shadow: var(--bcg-focus-ring);
    }

    body.bluecg-page .bluecg-logo {
        background-size: contain;
        background-repeat: no-repeat;
        background-position: center;
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact .bluecg-logo {
        width: min(15rem, 24vw);
        height: clamp(4rem, 6vw, 5.1rem);
    }

    body.bluecg-login-page .bluecg-login-panel,
    body.bluecg-page:not(.bluecg-login-page) .bluecg-panel.quest {
        box-shadow:
            0 1.15rem 2.5rem rgba(48, 37, 24, .12),
            inset 0 1px 0 rgba(255, 255, 255, .92);
    }

    body.bluecg-login-page .bluecg-login-brand,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand {
        background:
            linear-gradient(90deg, rgba(255, 254, 249, .9) 0 25%, rgba(255, 254, 249, .5) 50%, rgba(255, 250, 240, .18) 100%),
            linear-gradient(180deg, rgba(255, 254, 249, .1), rgba(255, 249, 236, .7) 80%),
            var(--bcg-art-login) center 25% / cover no-repeat;
    }

    body.bluecg-login-page .bluecg-login-tabs {
        padding: .54rem;
        border-radius: 1.05rem;
    }

    body.bluecg-page .bluecg-choice label {
        position: relative;
        min-height: 2.8rem;
        overflow: hidden;
    }

    body.bluecg-page .bluecg-choice label:has(input:checked) {
        border-color: rgba(36, 120, 117, .45);
        background:
            linear-gradient(180deg, rgba(236, 250, 247, .95), rgba(222, 244, 239, .9));
        color: #1f7772;
        box-shadow:
            inset 0 0 0 1px rgba(255, 255, 255, .82),
            0 .4rem .9rem rgba(36, 120, 117, .08);
    }

    body.bluecg-page .bluecg-choice label:has(input:checked)::after {
        position: absolute;
        top: .62rem;
        right: .72rem;
        width: .48rem;
        height: .48rem;
        border-radius: 50%;
        background: #2a918a;
        box-shadow: 0 0 0 .22rem rgba(42, 145, 138, .13);
        content: "";
    }

    body.bluecg-page input,
    body.bluecg-page select,
    body.bluecg-page textarea {
        color: #24211d;
        caret-color: #247872;
    }

    body.bluecg-page input::placeholder,
    body.bluecg-page textarea::placeholder {
        color: rgba(64, 57, 50, .48);
    }

    body.bluecg-page input:hover,
    body.bluecg-page select:hover,
    body.bluecg-page textarea:hover {
        border-color: rgba(36, 120, 117, .34);
    }

    body.bluecg-page .bluecg-button {
        border-radius: .85rem;
        color: #ffffff;
        text-shadow: 0 1px 0 rgba(0, 0, 0, .22);
        text-wrap: balance;
    }

    body.bluecg-page .bluecg-button:hover {
        color: #ffffff;
        transform: translateY(-1px);
        box-shadow:
            0 .85rem 1.55rem rgba(36, 120, 117, .22),
            inset 0 1px 0 rgba(255, 255, 255, .24);
    }

    body.bluecg-page .bluecg-button:active {
        transform: translateY(0);
    }

    body.bluecg-page .bluecg-nav a {
        min-height: 2.75rem;
        border-radius: .9rem;
    }

    body.bluecg-page .bluecg-nav a:hover,
    body.bluecg-page .bluecg-nav a:focus-visible,
    body.bluecg-page .bluecg-nav a.active {
        background:
            linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(239, 250, 247, .9));
        color: #247872;
        box-shadow:
            inset 0 0 0 1px rgba(36, 120, 117, .16),
            0 .45rem .9rem rgba(44, 35, 26, .07);
    }

    body.bluecg-page .bluecg-card {
        transition:
            transform .16s ease,
            box-shadow .16s ease,
            border-color .16s ease,
            background-color .16s ease;
    }

    body.bluecg-page .bluecg-card:hover {
        border-color: rgba(36, 120, 117, .28);
        transform: translateY(-1px);
        box-shadow:
            0 .8rem 1.45rem rgba(48, 37, 24, .1),
            inset 0 1px 0 rgba(255, 255, 255, .88);
    }

    body.bluecg-page .bluecg-table {
        border-collapse: separate;
        border-spacing: 0;
    }

    body.bluecg-page .bluecg-table th {
        color: #29241f;
        font-weight: 950;
    }

    body.bluecg-page .bluecg-table td {
        vertical-align: middle;
    }

    body.bluecg-page .bluecg-table tbody tr {
        transition: background-color .16s ease;
    }

    body.bluecg-page .bluecg-table tbody tr:hover {
        background: rgba(239, 250, 247, .54);
    }

    @media (max-width: 820px) {
        body.bluecg-page:not(.bluecg-login-page) .bluecg-brand.compact .bluecg-logo {
            width: min(14rem, 100%);
            height: 4.05rem;
        }

        body.bluecg-login-page .bluecg-login-brand,
        body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand {
            min-height: 8.6rem;
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .12), rgba(255, 249, 236, .72) 74%, rgba(255, 249, 236, .94)),
                var(--bcg-art-login-mobile) center 15% / cover no-repeat;
        }

        body.bluecg-page .bluecg-choice label:has(input:checked)::after {
            top: .58rem;
            right: .62rem;
        }
    }

    @media (prefers-reduced-motion: reduce) {
        body.bluecg-page *,
        body.bluecg-page *::before,
        body.bluecg-page *::after {
            transition-duration: .01ms !important;
            animation-duration: .01ms !important;
            animation-iteration-count: 1 !important;
            scroll-behavior: auto !important;
        }
    }
}

/* Artwork assignment refresh: separate login, admin, activity, and page texture art */
@media all {
    :root {
        --bcg-art-page: url("bluecg-art-section-quest-20260523.jpg");
        --bcg-art-hero: url("bluecg-art-admin-hero-20260523.jpg");
        --bcg-art-hero-mobile: url("bluecg-art-admin-hero-mobile-20260523.jpg");
        --bcg-art-login: url("bluecg-art-login-v2-20260524.jpg");
        --bcg-art-login-mobile: url("bluecg-art-login-v2-mobile-20260524.jpg");
        --bcg-art-section: url("bluecg-art-section-quest-20260523.jpg");
        --bcg-art-ui: url("bluecg-art-ui-soft-20260523.jpg");
    }

    body.bluecg-login-page {
        background:
            radial-gradient(ellipse at 50% -7rem, rgba(255, 255, 255, .46), transparent 34rem),
            linear-gradient(180deg, rgba(255, 254, 249, .2), rgba(255, 250, 240, .62) 48%, rgba(236, 226, 212, .9)),
            var(--bcg-art-login) top center / min(1900px, 155vw) auto no-repeat,
            linear-gradient(135deg, #e8f6f5 0%, #f9f0df 56%, #e8ded1 100%);
    }

    body.bluecg-login-page .bluecg-login-shell {
        width: min(100% - 1.25rem, 52rem);
        padding-block: clamp(.85rem, 2.5vh, 1.6rem);
    }

    body.bluecg-login-page .bluecg-login-panel,
    body.bluecg-login-page .bluecg-panel.quest.bluecg-login-panel {
        border-color: rgba(45, 129, 125, .2);
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .92), rgba(255, 248, 235, .9)),
            radial-gradient(circle at 82% 0%, rgba(210, 163, 80, .12), transparent 16rem);
        box-shadow:
            0 1.35rem 2.7rem rgba(50, 38, 25, .14),
            inset 0 1px 0 rgba(255, 255, 255, .9);
        backdrop-filter: blur(18px) saturate(1.08);
    }

    body.bluecg-login-page .bluecg-login-panel .bluecg-panel-inner {
        padding: clamp(1rem, 2.1vw, 1.35rem);
    }

    body.bluecg-login-page .bluecg-login-brand,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand {
        display: grid;
        grid-template-columns: minmax(17rem, 21rem) minmax(0, 1fr);
        grid-template-areas: "logo kicker";
        gap: clamp(.75rem, 2vw, 1.2rem);
        align-items: end;
        min-height: clamp(6.75rem, 9.4vw, 7.85rem);
        padding: clamp(.62rem, 1.35vw, .82rem);
        overflow: hidden;
        border-color: rgba(45, 129, 125, .18);
        background:
            linear-gradient(90deg, rgba(255, 254, 249, .88) 0 24%, rgba(255, 254, 249, .42) 49%, rgba(255, 250, 240, .12) 100%),
            linear-gradient(180deg, rgba(255, 254, 249, .04), rgba(255, 249, 236, .64) 78%),
            var(--bcg-art-login) center 24% / cover no-repeat;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .86),
            0 .8rem 1.35rem rgba(37, 29, 20, .08);
    }

    body.bluecg-login-page .bluecg-login-brand .bluecg-logo,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-logo {
        display: block;
        width: min(100%, 21rem);
        inline-size: min(100%, 21rem);
        max-inline-size: 21rem;
        height: clamp(4.9rem, 7.5vw, 5.75rem);
        block-size: clamp(4.9rem, 7.5vw, 5.75rem);
        align-self: end;
        border-radius: 0;
        background-color: transparent;
        box-shadow: none;
    }

    body.bluecg-login-page .bluecg-login-brand .bluecg-kicker,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-kicker {
        position: static;
        justify-self: start;
        align-self: end;
        margin: 0 0 .08rem;
        padding: .45rem .85rem;
        border: 1px solid rgba(45, 129, 125, .22);
        border-radius: 999px;
        background:
            linear-gradient(180deg, rgba(255, 255, 255, .94), rgba(233, 247, 244, .9));
        color: #247872;
        font-size: clamp(.82rem, 1.7vw, .95rem);
        font-weight: 900;
        line-height: 1.2;
        transform: none;
        box-shadow: 0 .35rem .8rem rgba(36, 120, 117, .1);
    }

    body.bluecg-login-page .bluecg-login-copy {
        gap: .18rem;
        min-height: 0;
        margin-block: .72rem .78rem;
        padding: 0;
    }

    body.bluecg-login-page .bluecg-login-copy span {
        color: #24211d;
        font-size: clamp(1.05rem, 2vw, 1.28rem);
        font-weight: 950;
    }

    body.bluecg-login-page .bluecg-login-copy small {
        color: #70655d;
        font-size: .94rem;
        font-weight: 760;
    }

    body.bluecg-login-page .bluecg-login-tabs {
        background: rgba(245, 237, 221, .64);
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .78),
            0 .35rem .9rem rgba(50, 38, 25, .05);
    }

    body.bluecg-login-page .bluecg-login-tabs legend {
        color: #181614;
        font-size: clamp(1.2rem, 2.3vw, 1.5rem);
        font-weight: 950;
    }

    body.bluecg-login-page .bluecg-login-form label,
    body.bluecg-login-page .bluecg-login-form .bluecg-label {
        color: #221f1c;
        font-size: .93rem;
        font-weight: 900;
    }

    body.bluecg-login-page .bluecg-login-form {
        gap: .68rem 1rem;
    }

    body.bluecg-login-page .bluecg-login-form input,
    body.bluecg-login-page .bluecg-login-form select {
        min-height: 2.85rem;
        border-color: rgba(78, 68, 57, .24);
        background: rgba(255, 255, 255, .92);
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .9),
            0 .25rem .75rem rgba(50, 38, 25, .04);
    }

    body.bluecg-login-page .bluecg-login-form input:focus,
    body.bluecg-login-page .bluecg-login-form select:focus {
        border-color: rgba(36, 120, 117, .55);
        box-shadow:
            0 0 0 .22rem rgba(36, 120, 117, .14),
            inset 0 1px 0 rgba(255, 255, 255, .9);
    }

    body.bluecg-login-page .bluecg-login-form .bluecg-button {
        min-height: 3.05rem;
        background: linear-gradient(180deg, #34aaa2, #247872);
        font-weight: 950;
        box-shadow:
            0 .75rem 1.35rem rgba(36, 120, 117, .24),
            inset 0 1px 0 rgba(255, 255, 255, .22);
    }

    body.bluecg-page:not(.bluecg-login-page) {
        background:
            radial-gradient(ellipse at 50% -8rem, rgba(255, 255, 255, .58), transparent 33rem),
            linear-gradient(180deg, rgba(255, 254, 249, .6), rgba(255, 248, 235, .84) 50%, rgba(232, 220, 202, .92)),
            var(--bcg-art-ui) top center / max(1900px, 150vw) auto no-repeat,
            linear-gradient(135deg, #e8f3ef 0%, #fbf3e5 44%, #e9decf 100%);
    }

    body.bluecg-admin-page .bluecg-brand.compact {
        background:
            linear-gradient(90deg, rgba(255, 254, 249, .95) 0 23%, rgba(255, 254, 249, .68) 42%, rgba(255, 250, 240, .08) 66%),
            linear-gradient(180deg, rgba(255, 254, 249, .08), rgba(255, 249, 236, .5)),
            var(--bcg-art-hero) center 31% / cover no-repeat,
            linear-gradient(180deg, rgba(255, 250, 240, .95), rgba(244, 232, 212, .9));
    }

    body.bluecg-member-page .bluecg-brand.compact,
    body.bluecg-dashboard-page .bluecg-brand.compact {
        background:
            linear-gradient(90deg, rgba(255, 254, 249, .95) 0 23%, rgba(255, 254, 249, .66) 42%, rgba(255, 250, 240, .08) 68%),
            linear-gradient(180deg, rgba(255, 254, 249, .06), rgba(255, 249, 236, .52)),
            var(--bcg-art-section) center 34% / cover no-repeat,
            linear-gradient(180deg, rgba(255, 250, 240, .95), rgba(244, 232, 212, .9));
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-hero {
        overflow: hidden;
        border-color: rgba(45, 129, 125, .2);
        background:
            linear-gradient(90deg, rgba(255, 254, 249, .96) 0 34%, rgba(255, 254, 249, .72) 52%, rgba(255, 250, 240, .22) 100%),
            linear-gradient(180deg, rgba(239, 250, 247, .38), rgba(255, 250, 236, .72)),
            var(--bcg-art-section) right 35% center / auto 150% no-repeat,
            linear-gradient(135deg, rgba(239, 250, 247, .92), rgba(255, 250, 236, .9));
        box-shadow:
            inset .32rem 0 0 var(--bcg-teal),
            inset 0 1px 0 rgba(255, 255, 255, .86),
            0 .8rem 1.8rem rgba(31, 24, 18, .08);
    }

    body.bluecg-page:not(.bluecg-login-page) .bluecg-hero::before {
        background:
            radial-gradient(circle at 8% 16%, rgba(255, 255, 255, .72), transparent 13rem),
            linear-gradient(90deg, rgba(255, 255, 255, .7), rgba(255, 255, 255, .08));
    }

    @media (min-width: 920px) {
        body.bluecg-login-page .bluecg-login-form {
            grid-template-columns: repeat(2, minmax(0, 1fr));
            column-gap: 1rem;
        }

        body.bluecg-login-page .bluecg-login-form > input[type="hidden"],
        body.bluecg-login-page .bluecg-login-tabs {
            grid-column: 1 / -1;
        }

        body.bluecg-login-page .bluecg-login-form > div:has(.bluecg-turnstile),
        body.bluecg-login-page .bluecg-login-form > .bluecg-button {
            grid-column: 1 / -1;
        }
    }

    @media (max-width: 820px) {
        body.bluecg-login-page {
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .34), rgba(255, 250, 240, .76) 42%, rgba(236, 226, 212, .94)),
                var(--bcg-art-login-mobile) top center / 100% auto no-repeat,
                linear-gradient(180deg, #edf7f4, #f7eddf);
        }

        body.bluecg-login-page .bluecg-login-shell {
            width: min(100% - .8rem, 32rem);
            padding-block: .55rem 1rem;
        }

        body.bluecg-login-page .bluecg-login-brand,
        body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand {
            grid-template-columns: 1fr;
            grid-template-areas:
                "logo"
                "kicker";
            justify-items: center;
            min-height: 8.2rem;
            text-align: center;
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .1), rgba(255, 249, 236, .66) 74%, rgba(255, 249, 236, .9)),
                var(--bcg-art-login-mobile) center 14% / cover no-repeat;
        }

        body.bluecg-login-page .bluecg-login-brand .bluecg-logo,
        body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-logo {
            width: min(16rem, 100%);
            inline-size: min(16rem, 100%);
            max-inline-size: 16rem;
            height: 4.65rem;
            block-size: 4.65rem;
        }

        body.bluecg-login-page .bluecg-login-brand .bluecg-kicker,
        body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-kicker {
            justify-self: center;
        }

        body.bluecg-page:not(.bluecg-login-page) {
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .68), rgba(255, 249, 238, .9) 46%, rgba(232, 220, 202, .94)),
                var(--bcg-art-ui) top center / auto 24rem no-repeat,
                linear-gradient(180deg, #eef7f4, #f7eddf);
        }

        body.bluecg-admin-page .bluecg-brand.compact {
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .12), rgba(255, 249, 236, .66) 68%, rgba(255, 249, 236, .92)),
                var(--bcg-art-hero-mobile) center 18% / cover no-repeat;
        }

        body.bluecg-member-page .bluecg-brand.compact,
        body.bluecg-dashboard-page .bluecg-brand.compact,
        body.bluecg-page:not(.bluecg-login-page) .bluecg-hero {
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .16), rgba(255, 249, 236, .72) 68%, rgba(255, 249, 236, .94)),
                var(--bcg-art-section) center 24% / cover no-repeat;
        }

        body.bluecg-page:not(.bluecg-login-page) .bluecg-hero {
            min-height: 7rem;
        }
    }

    body.bluecg-login-page .bluecg-login-tabs {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    body.bluecg-login-page .bluecg-login-tabs label {
        min-width: 0;
        padding-inline: .5rem;
        font-size: .92rem;
        text-align: center;
    }

    @media (max-width: 420px) {
        body.bluecg-login-page .bluecg-login-tabs {
            grid-template-columns: 1fr;
        }
    }
}

/* Game leaderboard transfer */
@media all {
    body.bluecg-game-page .bluecg-game-leaderboard-summary {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: .72rem;
        margin: .85rem 0 .9rem;
    }

    body.bluecg-game-page .bluecg-game-leaderboard-summary article,
    body.bluecg-game-page .bluecg-game-leaderboard-block {
        border: 1px solid rgba(109, 88, 66, .14);
        border-radius: 1rem;
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .96), rgba(250, 246, 238, .9));
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .9),
            0 .52rem 1.15rem rgba(44, 34, 24, .055);
    }

    body.bluecg-game-page .bluecg-game-leaderboard-summary article {
        display: grid;
        gap: .2rem;
        min-height: 5.25rem;
        padding: .82rem .92rem;
    }

    body.bluecg-game-page .bluecg-game-leaderboard-summary span {
        color: #247872;
        font-size: .75rem;
        font-weight: 900;
    }

    body.bluecg-game-page .bluecg-game-leaderboard-summary strong {
        min-width: 0;
        overflow: hidden;
        color: #28211d;
        font-size: 1.05rem;
        font-weight: 950;
        line-height: 1.22;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-game-page .bluecg-game-leaderboard-summary small {
        color: #74685d;
        font-size: .78rem;
        font-weight: 720;
        line-height: 1.32;
    }

    body.bluecg-game-page .bluecg-game-leaderboard-layout {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: .9rem;
        align-items: start;
    }

    body.bluecg-game-page .bluecg-game-leaderboard-block {
        padding: .9rem;
        overflow: hidden;
    }

    body.bluecg-game-page .bluecg-game-leaderboard-block.daily {
        margin-top: .9rem;
    }

    body.bluecg-game-page .bluecg-game-leaderboard-title {
        display: flex;
        gap: .75rem;
        align-items: start;
        justify-content: space-between;
        padding-bottom: .64rem;
        border-bottom: 1px solid rgba(109, 88, 66, .12);
    }

    body.bluecg-game-page .bluecg-game-leaderboard-title h3 {
        margin: 0;
        color: #24201c;
        font-size: 1.05rem;
        font-weight: 950;
        line-height: 1.22;
    }

    body.bluecg-game-page .bluecg-game-leaderboard-title p {
        margin: .18rem 0 0;
        color: #70655d;
        font-size: .82rem;
        font-weight: 720;
        line-height: 1.45;
    }

    body.bluecg-game-page .bluecg-game-rank-tabs a {
        gap: .32rem;
        padding-inline: .74rem .58rem;
    }

    body.bluecg-game-page .bluecg-game-rank-tabs a small {
        display: inline-flex;
        align-items: center;
        min-height: 1.25rem;
        padding: .1rem .38rem;
        border-radius: 999px;
        background: rgba(88, 118, 98, .12);
        color: #607064;
        font-size: .66rem;
        font-weight: 850;
        line-height: 1;
    }

    body.bluecg-game-page .bluecg-game-rank-tabs a.active small {
        background: rgba(35, 132, 127, .14);
        color: #1f7771;
    }

    body.bluecg-game-page .bluecg-game-podium {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: .55rem;
        margin: .35rem 0 .75rem;
    }

    body.bluecg-game-page .bluecg-game-podium article {
        position: relative;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        gap: .42rem .58rem;
        align-items: center;
        min-height: 6.2rem;
        padding: .7rem;
        overflow: hidden;
        border: 1px solid rgba(35, 132, 127, .17);
        border-radius: .92rem;
        background:
            linear-gradient(135deg, rgba(236, 250, 247, .94), rgba(255, 247, 228, .88));
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, .84);
    }

    body.bluecg-game-page .bluecg-game-podium article:first-child {
        background:
            linear-gradient(135deg, rgba(255, 247, 224, .98), rgba(237, 250, 247, .9));
        border-color: rgba(205, 150, 54, .28);
    }

    body.bluecg-game-page .bluecg-game-podium article > span {
        position: absolute;
        top: .55rem;
        right: .62rem;
        color: rgba(36, 120, 117, .82);
        font-size: .76rem;
        font-weight: 950;
    }

    body.bluecg-game-page .bluecg-game-podium .bluecg-game-icon-link {
        grid-row: 1 / 3;
    }

    body.bluecg-game-page .bluecg-game-podium .bluecg-game-icon-frame {
        inline-size: 3rem;
        block-size: 3rem;
    }

    body.bluecg-game-page .bluecg-game-podium strong,
    body.bluecg-game-page .bluecg-game-podium small {
        display: block;
        min-width: 0;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-game-page .bluecg-game-podium strong {
        color: #24201c;
        font-size: .92rem;
        font-weight: 950;
    }

    body.bluecg-game-page .bluecg-game-podium small {
        color: #71675d;
        font-size: .72rem;
        font-weight: 720;
    }

    body.bluecg-game-page .bluecg-game-podium b {
        justify-self: start;
        padding: .16rem .48rem;
        border-radius: 999px;
        background: rgba(255, 255, 255, .72);
        color: #247872;
        font-size: .78rem;
        font-weight: 950;
        line-height: 1.15;
    }

    body.bluecg-game-page .bluecg-rank-number {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 2.5rem;
        min-height: 1.8rem;
        padding: .12rem .44rem;
        border-radius: 999px;
        background: rgba(36, 120, 117, .11);
        color: #237872;
        font-weight: 950;
    }

    body.bluecg-game-page .bluecg-game-leaderboard-table {
        min-width: 43rem;
    }

    body.bluecg-game-page .bluecg-game-leaderboard-table.compact {
        min-width: 32rem;
    }

    body.bluecg-game-page .bluecg-game-leaderboard-columns {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: .8rem;
    }

    @media (max-width: 980px) {
        body.bluecg-game-page .bluecg-game-leaderboard-layout,
        body.bluecg-game-page .bluecg-game-leaderboard-columns {
            grid-template-columns: 1fr;
        }
    }

    @media (max-width: 720px) {
        body.bluecg-game-page .bluecg-game-leaderboard-summary,
        body.bluecg-game-page .bluecg-game-podium {
            grid-template-columns: 1fr;
        }

        body.bluecg-game-page .bluecg-game-podium article {
            min-height: 5.1rem;
        }

        body.bluecg-game-page .bluecg-game-rank-tabs a small {
            display: none;
        }
    }
}

/* Final priority visual override 2026-05-25 */
@media all {
    body.bluecg-page {
        color: var(--bcg-ink);
        font-family: var(--bcg-font-sans);
        -webkit-font-smoothing: antialiased;
        text-rendering: optimizeLegibility;
    }

    body.bluecg-member-page .bluecg-shell.wide {
        width: min(100% - 2rem, 92rem);
    }

    .bluecg-logo,
    body.bluecg-login-page .bluecg-login-brand .bluecg-logo,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-logo {
        border-color: transparent;
        background-color: transparent;
        box-shadow: none;
    }

    .bluecg-brand.compact {
        border-color: rgba(36, 120, 117, .15);
        background:
            linear-gradient(90deg, rgba(255, 254, 249, .96), rgba(255, 249, 238, .88)),
            var(--bcg-art-hero) right center / auto 120% no-repeat;
    }

    .bluecg-panel,
    .bluecg-card,
    .bluecg-menu-item,
    .bluecg-table-wrap,
    .bluecg-stat {
        box-shadow:
            0 1rem 2.6rem rgba(37, 29, 21, .075),
            inset 0 1px 0 rgba(255, 255, 255, .76);
    }

    .bluecg-panel.quest {
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .97), rgba(255, 249, 238, .92)),
            radial-gradient(circle at 100% 0, rgba(36, 120, 117, .08), transparent 18rem);
    }

    .bluecg-dashboard-card,
    .bluecg-menu-item {
        border: 1px solid rgba(36, 120, 117, .14);
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .98), rgba(250, 246, 239, .9));
    }

    .bluecg-dashboard-card {
        min-height: 8.2rem;
        padding: .95rem;
        border-radius: 1rem;
        text-decoration: none;
    }

    .bluecg-table th {
        background: linear-gradient(180deg, #fffefa, #f4ead7);
        color: #2c2722;
        font-size: .86rem;
        font-weight: 950;
        white-space: nowrap;
    }

    .bluecg-table td {
        color: var(--bcg-ink-soft);
        vertical-align: middle;
    }

    .bluecg-table tbody tr:hover td {
        background: color-mix(in srgb, var(--bcg-teal) 7%, #fffefa);
    }

    .bluecg-content-image {
        display: grid;
        place-items: center;
        overflow: hidden;
        border: 1px solid rgba(36, 120, 117, .13);
        border-radius: 1rem;
        background: linear-gradient(180deg, rgba(255, 254, 249, .95), rgba(250, 246, 238, .9));
    }

    .bluecg-content-image img {
        display: block;
        width: 100%;
        max-height: min(30rem, 68vh);
        object-fit: contain;
    }

    body.bluecg-game-page .bluecg-game-jump {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 13rem), 1fr));
        gap: .72rem;
        margin: 1rem 0;
        padding: .85rem;
        border: 1px solid rgba(83, 70, 55, .13);
        border-radius: 1.1rem;
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .92), rgba(249, 244, 235, .78));
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, .82);
    }

    body.bluecg-game-page .bluecg-game-jump a {
        position: relative;
        display: grid;
        grid-template-columns: 2.35rem minmax(0, 1fr) auto;
        grid-template-areas:
            "icon title count"
            "icon hint count";
        gap: .08rem .7rem;
        align-items: center;
        min-height: 4.2rem;
        padding: .7rem .75rem;
        overflow: hidden;
        border: 1px solid rgba(83, 70, 55, .13);
        border-radius: .95rem;
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .98), rgba(250, 246, 238, .9));
        color: var(--bcg-ink);
        text-decoration: none;
        box-shadow: 0 .55rem 1.2rem rgba(37, 29, 21, .055);
    }

    body.bluecg-game-page .bluecg-game-jump a::before {
        grid-area: icon;
        display: grid;
        place-items: center;
        width: 2.35rem;
        height: 2.35rem;
        border-radius: .82rem;
        background: linear-gradient(135deg, rgba(53, 163, 157, .95), rgba(37, 95, 133, .95));
        color: white;
        content: attr(data-nav);
        font-weight: 950;
    }

    body.bluecg-game-page .bluecg-game-jump a strong {
        grid-area: title;
        min-width: 0;
        overflow: hidden;
        color: var(--bcg-ink);
        font-size: .95rem;
        font-weight: 950;
        line-height: 1.22;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-game-page .bluecg-game-jump a em {
        grid-area: hint;
        min-width: 0;
        overflow: hidden;
        color: var(--bcg-muted);
        font-size: .76rem;
        font-style: normal;
        font-weight: 720;
        line-height: 1.3;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-game-page .bluecg-game-jump a span {
        grid-area: count;
        align-self: center;
        justify-self: end;
        max-width: 4.8rem;
        min-height: 1.65rem;
        padding: .2rem .48rem;
        overflow: hidden;
        border-radius: 999px;
        background: rgba(91, 112, 99, .11);
        color: #617064;
        font-size: .72rem;
        font-weight: 900;
        line-height: 1.2;
        text-align: center;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.bluecg-game-page .bluecg-game-jump a:hover,
    body.bluecg-game-page .bluecg-game-jump a:focus-visible,
    body.bluecg-game-page .bluecg-game-jump a.active {
        border-color: rgba(36, 120, 117, .34);
        background:
            linear-gradient(180deg, rgba(239, 251, 248, .98), rgba(255, 250, 238, .94));
        box-shadow:
            0 .9rem 1.9rem rgba(36, 120, 117, .12),
            inset 0 1px 0 rgba(255, 255, 255, .86);
        transform: translateY(-1px);
    }

    body.bluecg-game-page .bluecg-game-jump a.active::before {
        background: linear-gradient(135deg, rgba(240, 200, 107, .98), rgba(169, 93, 99, .96));
    }

    body.bluecg-game-page .bluecg-game-result-note {
        margin: .85rem 0;
        padding: .72rem .85rem;
        border: 1px solid rgba(36, 120, 117, .14);
        border-radius: .85rem;
        background: rgba(239, 251, 248, .7);
        color: color-mix(in srgb, var(--bcg-muted) 88%, black);
        font-weight: 780;
        line-height: 1.55;
    }

    body.bluecg-admin-page .bluecg-settings-dashboard {
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 13rem), 1fr));
    }

    body.bluecg-admin-page .bluecg-settings-dashboard .bluecg-stat {
        min-height: 5.4rem;
        border-color: rgba(36, 120, 117, .16);
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .98), rgba(250, 246, 239, .9)),
            radial-gradient(circle at 100% 0, rgba(53, 170, 164, .14), transparent 8rem);
    }

    body.bluecg-admin-page .bluecg-settings-form {
        gap: 1rem;
    }

    body.bluecg-admin-page .bluecg-settings-form .bluecg-form-card {
        padding: 1rem;
        border-color: rgba(83, 70, 55, .13);
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .96), rgba(251, 247, 239, .86));
    }

    body.bluecg-admin-page .bluecg-settings-form .bluecg-form-card .bluecg-form-row {
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
        align-items: stretch;
    }

    body.bluecg-admin-page .bluecg-settings-form .bluecg-field:has(.bluecg-checkbox) {
        display: grid;
        align-content: start;
        gap: .45rem;
        padding: .72rem;
        border: 1px solid rgba(83, 70, 55, .12);
        border-radius: .95rem;
        background: rgba(255, 254, 249, .72);
    }

    body.bluecg-admin-page .bluecg-settings-form .bluecg-checkbox {
        min-height: 3rem;
        border-color: rgba(36, 120, 117, .18);
        background:
            linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(240, 250, 247, .86));
        color: #2d2621;
    }

    body.bluecg-admin-page .bluecg-settings-form .bluecg-checkbox:has(input:checked) {
        border-color: rgba(36, 120, 117, .34);
        background:
            linear-gradient(180deg, rgba(232, 251, 247, .98), rgba(255, 249, 237, .9));
        color: var(--bcg-teal);
        box-shadow: 0 .55rem 1.1rem rgba(36, 120, 117, .08);
    }

    body.bluecg-login-page .bluecg-login-shell {
        width: min(100% - 1.5rem, 74rem);
    }

    body.bluecg-login-page .bluecg-login-tabs {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        padding: .35rem;
        border: 1px solid rgba(36, 120, 117, .13);
        border-radius: 1rem;
        background: rgba(255, 254, 249, .76);
    }

    body.bluecg-login-page .bluecg-login-tabs label {
        min-height: 2.75rem;
        border-radius: .8rem;
    }

    @media (min-width: 980px) {
        body.bluecg-login-page .bluecg-login-panel,
        body.bluecg-login-page .bluecg-panel.quest.bluecg-login-panel {
            display: grid;
            grid-template-columns: minmax(22rem, .95fr) minmax(26rem, 1fr);
            min-height: 43rem;
            overflow: hidden;
        }

        body.bluecg-login-page .bluecg-login-panel::after {
            position: relative;
            inset: auto;
            display: block;
            grid-column: 1;
            grid-row: 1;
            min-height: 100%;
            border-radius: 1.1rem 0 0 1.1rem;
            background:
                linear-gradient(90deg, rgba(255, 254, 249, .08), rgba(255, 254, 249, .78) 92%),
                var(--bcg-art-login) center / cover no-repeat;
            content: "";
        }

        body.bluecg-login-page .bluecg-login-panel .bluecg-panel-inner {
            display: grid;
            grid-column: 2;
            grid-row: 1;
            align-content: center;
            padding: clamp(1.25rem, 2.6vw, 2rem);
        }
    }

    @media (max-width: 720px) {
        body.bluecg-member-page .bluecg-shell.wide,
        body.bluecg-login-page .bluecg-login-shell {
            width: min(100% - 1rem, 100%);
        }

        .bluecg-brand.compact {
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .96), rgba(255, 249, 238, .92)),
                var(--bcg-art-hero-mobile) top right / auto 130% no-repeat;
        }

        body.bluecg-game-page .bluecg-game-jump {
            grid-template-columns: 1fr;
            padding: .65rem;
        }

        body.bluecg-game-page .bluecg-game-jump a {
            min-height: 3.9rem;
        }

        body.bluecg-login-page .bluecg-login-tabs {
            grid-template-columns: 1fr;
        }
    }
}

/* Login page true final override 2026-05-25 */
@media all {
    body.bluecg-login-page {
        position: relative;
        display: grid;
        place-items: center;
        min-height: 100svh;
        padding: clamp(1rem, 3vw, 2.4rem);
        overflow-x: hidden;
        isolation: isolate;
        background:
            radial-gradient(circle at 15% 12%, rgba(53, 163, 157, .17), transparent 25rem),
            radial-gradient(circle at 86% 10%, rgba(218, 151, 64, .18), transparent 24rem),
            linear-gradient(135deg, #edf8f5 0%, #fffaf0 48%, #f4eadf 100%);
    }

    body.bluecg-login-page::before {
        position: fixed;
        inset: 0;
        z-index: -1;
        display: block;
        content: "";
        pointer-events: none;
        background:
            linear-gradient(90deg, rgba(255, 255, 255, .88), rgba(255, 255, 255, .58)),
            var(--bcg-art-section) center top / cover no-repeat;
        opacity: .12;
        filter: saturate(.82) blur(1px);
        transform: scale(1.02);
    }

    body.bluecg-login-page .bluecg-login-shell {
        width: min(100%, 80rem);
        min-height: 0;
        margin: 0 auto;
        padding: 0;
        align-items: center;
    }

    body.bluecg-login-page .bluecg-login-panel,
    body.bluecg-login-page .bluecg-panel.quest.bluecg-login-panel {
        position: relative;
        display: grid;
        width: 100%;
        min-height: 0;
        overflow: hidden;
        border: 1px solid rgba(45, 129, 125, .2);
        border-radius: 1.45rem;
        background:
            linear-gradient(180deg, rgba(255, 254, 249, .98), rgba(255, 249, 238, .94));
        box-shadow:
            0 1.4rem 3rem rgba(50, 38, 25, .14),
            inset 0 1px 0 rgba(255, 255, 255, .94);
        backdrop-filter: blur(18px) saturate(1.06);
    }

    body.bluecg-login-page .bluecg-login-panel::before {
        display: none;
    }

    body.bluecg-login-page .bluecg-login-panel .bluecg-panel-inner {
        position: relative;
        z-index: 1;
        display: grid;
        align-content: center;
        width: min(100%, 39rem);
        padding: clamp(1.15rem, 2.3vw, 2rem);
        justify-self: center;
    }

    body.bluecg-login-page .bluecg-login-brand,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand {
        display: grid;
        grid-template-columns: 1fr;
        grid-template-areas: "logo";
        place-items: center;
        min-height: clamp(6.6rem, 8vw, 7.7rem);
        margin: 0 0 1rem;
        padding: .75rem 1rem;
        overflow: hidden;
        border: 1px solid rgba(45, 129, 125, .17);
        border-radius: 1rem;
        background:
            linear-gradient(90deg, rgba(255, 254, 249, .92) 0 34%, rgba(255, 254, 249, .56) 62%, rgba(255, 250, 240, .28)),
            linear-gradient(180deg, rgba(255, 255, 255, .22), rgba(255, 249, 236, .72)),
            var(--bcg-art-login) center 27% / cover no-repeat;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .86),
            0 .65rem 1.2rem rgba(37, 29, 20, .07);
        text-align: center;
    }

    body.bluecg-login-page .bluecg-login-brand .bluecg-logo,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-logo {
        grid-area: logo;
        display: block;
        width: min(100%, 24rem);
        inline-size: min(100%, 24rem);
        max-inline-size: 24rem;
        height: clamp(5.1rem, 7vw, 6.15rem);
        block-size: clamp(5.1rem, 7vw, 6.15rem);
        align-self: center;
        background-color: transparent;
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain;
        box-shadow: none;
        filter:
            drop-shadow(0 .5rem .75rem rgba(20, 83, 92, .2))
            drop-shadow(0 0 .38rem rgba(255, 255, 255, .88));
    }

    body.bluecg-login-page .bluecg-login-brand .bluecg-kicker,
    body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-kicker {
        display: none;
    }

    body.bluecg-login-page .bluecg-login-head {
        margin: 0 0 .85rem;
        text-align: center;
    }

    body.bluecg-login-page .bluecg-login-copy {
        gap: .22rem;
        margin: 0;
    }

    body.bluecg-login-page .bluecg-login-copy span {
        color: #231f1b;
        font-family: var(--bcg-font-display);
        font-size: clamp(1.32rem, 2.5vw, 1.72rem);
        font-weight: 950;
        line-height: 1.12;
    }

    body.bluecg-login-page .bluecg-login-copy small {
        color: #70655d;
        font-size: clamp(.92rem, 1.35vw, 1rem);
        font-weight: 780;
        line-height: 1.35;
    }

    body.bluecg-login-page .bluecg-login-form {
        gap: .78rem 1rem;
        padding: clamp(.85rem, 1.8vw, 1.15rem);
        border: 1px solid rgba(45, 129, 125, .12);
        border-radius: 1rem;
        background:
            linear-gradient(180deg, rgba(255, 255, 253, .82), rgba(255, 249, 238, .58));
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, .75);
    }

    body.bluecg-login-page .bluecg-login-tabs {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: .45rem;
        padding: .42rem;
        border: 1px solid rgba(45, 129, 125, .14);
        border-radius: .95rem;
        background: rgba(246, 239, 225, .66);
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .82),
            0 .32rem .8rem rgba(50, 38, 25, .045);
    }

    body.bluecg-login-page .bluecg-login-tabs legend {
        margin-bottom: .18rem;
        color: #1f1b17;
        font-size: clamp(1.18rem, 2vw, 1.42rem);
        font-weight: 950;
        line-height: 1.18;
    }

    body.bluecg-login-page .bluecg-login-tabs label {
        min-height: 2.95rem;
        padding: .58rem .62rem;
        border-radius: .78rem;
        color: #62584f;
        font-size: .94rem;
        font-weight: 920;
        line-height: 1.18;
        text-align: center;
        white-space: normal;
    }

    body.bluecg-login-page .bluecg-login-tabs label:has(input:checked) {
        border-color: rgba(36, 120, 117, .4);
        background:
            linear-gradient(180deg, rgba(232, 251, 247, .98), rgba(255, 255, 253, .92));
        color: #247872;
        box-shadow: 0 .45rem .9rem rgba(36, 120, 117, .12);
    }

    body.bluecg-login-page .bluecg-login-form label,
    body.bluecg-login-page .bluecg-login-form .bluecg-label {
        margin-bottom: .32rem;
        color: #24211d;
        font-size: .9rem;
        font-weight: 900;
        line-height: 1.32;
        text-wrap: balance;
    }

    body.bluecg-login-page .bluecg-login-form input,
    body.bluecg-login-page .bluecg-login-form select {
        min-height: 3rem;
        border-color: rgba(78, 68, 57, .22);
        border-radius: .82rem;
        background: rgba(255, 255, 255, .94);
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .9),
            0 .25rem .7rem rgba(50, 38, 25, .04);
    }

    body.bluecg-login-page .bluecg-login-form input:focus,
    body.bluecg-login-page .bluecg-login-form select:focus {
        border-color: rgba(36, 120, 117, .58);
        box-shadow:
            0 0 0 .22rem rgba(36, 120, 117, .14),
            inset 0 1px 0 rgba(255, 255, 255, .9);
    }

    body.bluecg-login-page .bluecg-login-form > div:has(.bluecg-turnstile) {
        display: grid;
        justify-items: start;
        gap: .35rem;
    }

    body.bluecg-login-page .bluecg-turnstile {
        max-width: 100%;
        overflow: hidden;
    }

    body.bluecg-login-page .bluecg-login-form .bluecg-button {
        min-height: 3.2rem;
        margin-top: .15rem;
        border-radius: .9rem;
        background: linear-gradient(180deg, #35aaa2, #247872);
        font-size: 1rem;
        font-weight: 950;
        box-shadow:
            0 .85rem 1.45rem rgba(36, 120, 117, .24),
            inset 0 1px 0 rgba(255, 255, 255, .26);
    }

    @media (min-width: 980px) {
        body.bluecg-login-page .bluecg-login-panel,
        body.bluecg-login-page .bluecg-panel.quest.bluecg-login-panel {
            grid-template-columns: minmax(27rem, .92fr) minmax(31rem, 1.08fr);
        }

        body.bluecg-login-page .bluecg-login-panel::after {
            position: relative;
            inset: auto;
            display: block;
            grid-column: 1;
            grid-row: 1;
            min-height: clamp(39rem, 76svh, 45rem);
            border-radius: 1.35rem 0 0 1.35rem;
            background:
                linear-gradient(90deg, rgba(255, 254, 249, .03) 0%, rgba(255, 252, 246, .2) 54%, rgba(255, 250, 240, .84) 100%),
                linear-gradient(180deg, rgba(255, 255, 255, 0) 43%, rgba(255, 255, 255, .72) 84%, rgba(255, 250, 240, .96) 100%),
                var(--bcg-art-login) 42% center / cover no-repeat;
            content: "";
        }

        body.bluecg-login-page .bluecg-login-panel .bluecg-panel-inner {
            grid-column: 2;
            grid-row: 1;
        }

        body.bluecg-login-page .bluecg-login-form {
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }

        body.bluecg-login-page .bluecg-login-form > input[type="hidden"],
        body.bluecg-login-page .bluecg-login-tabs,
        body.bluecg-login-page .bluecg-login-form > div:has(.bluecg-turnstile),
        body.bluecg-login-page .bluecg-login-form > .bluecg-button {
            grid-column: 1 / -1;
        }
    }

    @media (max-width: 979px) {
        body.bluecg-login-page {
            padding: clamp(.7rem, 3vw, 1.4rem);
        }

        body.bluecg-login-page .bluecg-login-shell {
            width: min(100%, 35rem);
        }

        body.bluecg-login-page .bluecg-login-panel,
        body.bluecg-login-page .bluecg-panel.quest.bluecg-login-panel {
            display: block;
        }

        body.bluecg-login-page .bluecg-login-panel::after {
            display: none;
        }
    }

    @media (max-width: 540px) {
        body.bluecg-login-page .bluecg-login-panel .bluecg-panel-inner {
            padding: .9rem;
        }

        body.bluecg-login-page .bluecg-login-brand,
        body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand {
            min-height: 6.25rem;
            padding: .6rem .7rem;
            background:
                linear-gradient(180deg, rgba(255, 254, 249, .22), rgba(255, 249, 236, .8)),
                var(--bcg-art-login-mobile) center 16% / cover no-repeat;
        }

        body.bluecg-login-page .bluecg-login-brand .bluecg-logo,
        body.bluecg-login-page .bluecg-brand.compact.bluecg-login-brand .bluecg-logo {
            width: min(100%, 17rem);
            inline-size: min(100%, 17rem);
            height: 4.55rem;
            block-size: 4.55rem;
        }

        body.bluecg-login-page .bluecg-login-form {
            padding: .75rem;
        }

        body.bluecg-login-page .bluecg-login-tabs {
            grid-template-columns: 1fr;
        }
    }
}
