:root {
    --abc-wine: #6c1d24;
    --abc-wine-dark: #4d1015;
    --abc-gold: #bb9457;
    --abc-ivory: #f6f1ec;
    --abc-panel: #ffffff;
    --abc-line: #e7ddd5;
    --abc-text: #2f2522;
    --abc-muted: #6f635d;
    --abc-shadow: 0 20px 45px rgba(57, 25, 21, 0.08);
    --sidebar-width: 300px;
    --sidebar-collapsed-width: 96px;
    --sidebar-transition: 280ms cubic-bezier(0.22, 1, 0.36, 1);
    --sidebar-icon-size: 1rem;
    --sidebar-toggle-size: 2.5rem;
}

html.is-busy,
body.is-busy {
    overflow: hidden;
}

body {
    font-family: "Manrope", "Segoe UI", sans-serif;
    color: var(--abc-text);
    background:
        radial-gradient(circle at top left, rgba(187, 148, 87, 0.18), transparent 32%),
        linear-gradient(180deg, #fbf8f5 0%, #f3ece6 100%);
}

h1,
h2,
h3 {
    font-family: "Fraunces", Georgia, serif;
}

.busy-overlay {
    position: fixed;
    inset: 0;
    z-index: 2400;
    display: grid;
    place-items: center;
    padding: 1.5rem;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
        opacity 180ms ease,
        visibility 180ms ease;
}

.busy-overlay[data-state="visible"] {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.busy-overlay:focus {
    outline: none;
}

.busy-overlay-backdrop {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at top left, rgba(187, 148, 87, 0.2), transparent 28%),
        radial-gradient(circle at bottom right, rgba(108, 29, 36, 0.34), transparent 38%),
        rgba(37, 15, 18, 0.58);
    backdrop-filter: blur(14px);
}

.busy-overlay-dialog {
    position: relative;
    display: flex;
    align-items: center;
    gap: 1.4rem;
    width: min(100%, 36rem);
    padding: 1.45rem 1.55rem;
    border: 1px solid rgba(246, 241, 236, 0.16);
    border-radius: 1.8rem;
    background:
        linear-gradient(145deg, rgba(77, 16, 21, 0.96), rgba(108, 29, 36, 0.92)),
        linear-gradient(120deg, rgba(255, 255, 255, 0.08), transparent 52%);
    box-shadow:
        0 28px 80px rgba(38, 12, 15, 0.42),
        inset 0 1px 0 rgba(255, 255, 255, 0.12);
    color: #fff9f4;
}

.busy-overlay-media {
    position: relative;
    flex: 0 0 auto;
    width: 7rem;
    height: 7rem;
    display: grid;
    place-items: center;
}

.busy-overlay-orbit,
.busy-overlay-spark {
    position: absolute;
    border-radius: 999px;
}

.busy-overlay-orbit {
    inset: 0;
    border: 1px solid rgba(255, 255, 255, 0.16);
}

.busy-overlay-orbit-outer {
    border-top-color: rgba(255, 255, 255, 0.84);
    border-right-color: rgba(187, 148, 87, 0.9);
    animation: busy-overlay-spin 2.6s linear infinite;
}

.busy-overlay-orbit-inner {
    inset: 0.72rem;
    border-bottom-color: rgba(255, 255, 255, 0.78);
    border-left-color: rgba(187, 148, 87, 0.88);
    animation: busy-overlay-spin-reverse 1.9s linear infinite;
}

.busy-overlay-spark {
    width: 0.8rem;
    height: 0.8rem;
    background: radial-gradient(circle, rgba(255, 248, 238, 0.95) 0%, rgba(187, 148, 87, 0.86) 55%, rgba(187, 148, 87, 0) 100%);
    box-shadow: 0 0 20px rgba(187, 148, 87, 0.34);
    animation: busy-overlay-spark 1.6s ease-in-out infinite;
}

.busy-overlay-spark-a {
    top: 0.45rem;
    right: 1rem;
    animation-delay: 0s;
}

.busy-overlay-spark-b {
    bottom: 0.8rem;
    right: 0.25rem;
    animation-delay: 0.24s;
}

.busy-overlay-spark-c {
    bottom: 1rem;
    left: 0.3rem;
    animation-delay: 0.48s;
}

.busy-overlay-core {
    position: relative;
    width: 4.9rem;
    height: 4.9rem;
    display: grid;
    place-items: center;
    border-radius: 50%;
    background:
        radial-gradient(circle at 32% 28%, rgba(187, 148, 87, 0.98), rgba(108, 29, 36, 0.96) 62%),
        linear-gradient(180deg, rgba(77, 16, 21, 0.96), rgba(108, 29, 36, 0.92));
    box-shadow:
        0 18px 40px rgba(28, 8, 11, 0.35),
        inset 0 1px 0 rgba(255, 255, 255, 0.24);
    animation: busy-overlay-pulse 1.7s ease-in-out infinite;
}

.busy-overlay-logo {
    width: 3.1rem;
    height: auto;
    filter: drop-shadow(0 8px 14px rgba(0, 0, 0, 0.22));
}

.busy-overlay-copy {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    min-width: 0;
}

.busy-overlay-eyebrow {
    color: rgba(255, 242, 228, 0.76);
}

.busy-overlay-title {
    font-family: "Fraunces", Georgia, serif;
    font-size: clamp(1.45rem, 2vw, 1.8rem);
    line-height: 1.05;
    letter-spacing: 0.01em;
}

.busy-overlay-message {
    margin: 0;
    max-width: 28rem;
    color: rgba(255, 242, 228, 0.82);
}

.busy-overlay-progress {
    display: inline-flex;
    align-items: center;
    gap: 0.42rem;
    margin-top: 0.25rem;
}

.busy-overlay-progress span {
    width: 0.52rem;
    height: 0.52rem;
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(255, 247, 241, 0.96), rgba(187, 148, 87, 0.88));
    animation: busy-overlay-dot 1.2s ease-in-out infinite;
}

.busy-overlay-progress span:nth-child(2) {
    animation-delay: 0.16s;
}

.busy-overlay-progress span:nth-child(3) {
    animation-delay: 0.32s;
}

.bulk-print-panel-head {
    align-items: center;
    gap: 1rem;
}

.bulk-print-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-top: 1rem;
}

.bulk-print-overlay {
    position: fixed;
    inset: 0;
    z-index: 1080;
    display: grid;
    place-items: center;
    padding: 1.5rem;
}

.bulk-print-overlay-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(34, 28, 24, 0.42);
    backdrop-filter: blur(4px);
}

.bulk-print-overlay-dialog {
    position: relative;
    width: min(540px, calc(100vw - 2rem));
    border-radius: 8px;
    border: 1px solid rgba(108, 29, 36, 0.16);
    background: #fffaf6;
    box-shadow: 0 22px 60px rgba(47, 39, 35, 0.18);
    padding: 1.25rem 1.25rem 1.1rem;
}

.bulk-print-overlay-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.75rem;
}

.bulk-print-overlay-title {
    display: block;
    font-size: 1.1rem;
    color: #2f2723;
}

.bulk-print-overlay-message {
    color: #655b56;
}

.bulk-print-progress {
    width: 100%;
    height: 0.75rem;
    border-radius: 999px;
    background: rgba(108, 29, 36, 0.08);
    overflow: hidden;
}

.bulk-print-progress-bar {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #6c1d24 0%, #b85c38 100%);
    transition: width 0.35s ease;
}

.bulk-print-progress-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 0.75rem;
    color: #655b56;
    font-size: 0.95rem;
}

.bulk-print-current,
.bulk-print-error {
    margin-top: 0.85rem;
    padding: 0.75rem 0.85rem;
    border-radius: 8px;
    font-size: 0.95rem;
}

.bulk-print-current {
    background: rgba(108, 29, 36, 0.05);
    color: #49352f;
}

.bulk-print-error {
    background: rgba(177, 58, 47, 0.1);
    color: #8d2f27;
}

.bulk-print-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    margin-top: 1rem;
}

.eyebrow {
    display: inline-block;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    font-size: 0.74rem;
    font-weight: 700;
    color: var(--abc-gold);
}

.auth-shell {
    min-height: 100vh;
    margin: 0;
}

.auth-stage {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 1.1fr minmax(320px, 460px);
    gap: 2rem;
    align-items: stretch;
    padding: 2rem;
}

.auth-brand,
.auth-card,
.sidebar,
.panel-card,
.stat-card {
    border: 1px solid rgba(231, 221, 213, 0.9);
    box-shadow: var(--abc-shadow);
}

.auth-brand {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    padding: 4rem;
    border-radius: 2rem;
    background: linear-gradient(135deg, var(--abc-wine-dark), var(--abc-wine));
    color: #fff7f1;
}

.auth-brand-logo {
    display: block;
    width: min(180px, 42%);
    height: auto;
    margin-bottom: 1.5rem;
}

.auth-brand h1 {
    margin: 0.75rem 0 1rem;
    font-size: clamp(2.2rem, 4vw, 4rem);
    line-height: 1;
}

.auth-brand p {
    max-width: 34rem;
    color: rgba(255, 247, 241, 0.85);
}

.auth-card {
    align-self: center;
    padding: 2rem;
    border-radius: 1.75rem;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(12px);
}

.app-shell {
    margin: 0;
}

.app-grid {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    min-height: 100vh;
    align-items: start;
}

.sidebar {
    display: flex;
    flex-direction: column;
    gap: 2rem;
    width: var(--sidebar-width);
    min-width: 0;
    padding: 2rem;
    overflow: hidden;
    position: sticky;
    top: 0;
    align-self: start;
    min-height: 100vh;
    background: linear-gradient(180deg, var(--abc-wine-dark) 0%, var(--abc-wine) 100%);
    color: #fffaf7;
    transition:
        width var(--sidebar-transition),
        padding var(--sidebar-transition),
        gap var(--sidebar-transition);
}

.sidebar-top,
.sidebar-panel {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.sidebar-top {
    flex: 1 1 auto;
    min-height: 0;
}

.sidebar-panel {
    flex: 1 1 auto;
    min-height: 0;
}

.sidebar-brand {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.85rem;
}

.sidebar-brand-media {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 4.5rem;
}

.sidebar-brand-logo {
    display: block;
    width: 100%;
    height: auto;
    object-fit: contain;
}

.sidebar-user-details {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    min-width: 0;
    overflow: hidden;
    transition:
        opacity var(--sidebar-transition),
        transform var(--sidebar-transition),
        max-width var(--sidebar-transition),
        max-height var(--sidebar-transition);
    max-width: 12rem;
    max-height: 6rem;
}

.sidebar-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    width: var(--sidebar-toggle-size);
    height: var(--sidebar-toggle-size);
    padding: 0;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 0.95rem;
    background: rgba(255, 255, 255, 0.08);
    color: #fffaf7;
    transition:
        background-color var(--sidebar-transition),
        border-color var(--sidebar-transition),
        transform var(--sidebar-transition);
}

.sidebar-toggle:hover {
    background: rgba(255, 255, 255, 0.14);
    border-color: rgba(255, 255, 255, 0.28);
}

.sidebar-toggle svg {
    width: 1rem;
    height: 1rem;
    fill: currentColor;
    transition: transform var(--sidebar-transition);
}

.nav-section {
    min-width: 0;
}

.app-nav-link {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    border-radius: 0.9rem;
    padding: 0.72rem 0.9rem;
    color: rgba(255, 250, 247, 0.92);
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid transparent;
    overflow: hidden;
    transition:
        background-color var(--sidebar-transition),
        border-color var(--sidebar-transition),
        color var(--sidebar-transition),
        padding var(--sidebar-transition),
        gap var(--sidebar-transition);
}

.app-nav-link:hover {
    color: #fff;
    background: rgba(255, 255, 255, 0.12);
}

.app-nav-link.is-active {
    color: #fff;
    background: rgba(255, 255, 255, 0.16);
    border-color: rgba(255, 255, 255, 0.2);
}

.nav-section-label {
    display: block;
    margin-bottom: 0.9rem;
    font-size: 0.78rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255, 250, 247, 0.72);
    overflow: hidden;
    max-height: 2rem;
    transition:
        opacity var(--sidebar-transition),
        transform var(--sidebar-transition),
        max-height var(--sidebar-transition),
        margin-bottom var(--sidebar-transition);
}

.nav-icon,
.sidebar-user-icon,
.sidebar-logout-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 var(--sidebar-icon-size);
    width: var(--sidebar-icon-size);
    height: var(--sidebar-icon-size);
    color: rgba(255, 250, 247, 0.9);
}

.nav-icon svg,
.sidebar-user-icon svg,
.sidebar-logout-icon svg {
    width: 100%;
    height: 100%;
    fill: currentColor;
}

.nav-label,
.sidebar-logout-label {
    overflow: hidden;
    white-space: nowrap;
    transition:
        opacity var(--sidebar-transition),
        transform var(--sidebar-transition),
        max-width var(--sidebar-transition);
}

.nav-label {
    max-width: 12rem;
}

.sidebar-meta {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.sidebar-user-card {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.9rem;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.06);
    transition:
        padding var(--sidebar-transition),
        gap var(--sidebar-transition),
        background-color var(--sidebar-transition),
        border-color var(--sidebar-transition);
}

.sidebar-user-role {
    font-size: 0.9rem;
    color: rgba(255, 250, 247, 0.8);
}

.sidebar-logout-button {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.65rem;
    overflow: hidden;
    transition:
        gap var(--sidebar-transition),
        padding var(--sidebar-transition);
}

.sidebar-logout-label {
    max-width: 8rem;
}

.app-shell.is-sidebar-collapsed .sidebar {
    width: var(--sidebar-collapsed-width);
    gap: 1.5rem;
    padding: 1.5rem 1rem;
}

.app-shell.is-sidebar-collapsed .sidebar-top {
    gap: 1.25rem;
}

.app-shell.is-sidebar-collapsed .sidebar-brand {
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
}

.app-shell.is-sidebar-collapsed .sidebar-brand-media {
    width: 2.75rem;
}

.app-shell.is-sidebar-collapsed .sidebar-toggle {
    margin-top: 0.15rem;
}

.app-shell.is-sidebar-collapsed .sidebar-toggle svg {
    transform: rotate(180deg);
}

.app-shell.is-sidebar-collapsed .nav-section-label,
.app-shell.is-sidebar-collapsed .nav-label,
.app-shell.is-sidebar-collapsed .sidebar-user-details,
.app-shell.is-sidebar-collapsed .sidebar-logout-label {
    opacity: 0;
    max-width: 0;
    max-height: 0;
    transform: translateX(-0.45rem);
    pointer-events: none;
}

.app-shell.is-sidebar-collapsed .nav-section-label {
    margin-bottom: 0;
}

.app-shell.is-sidebar-collapsed .app-nav-link,
.app-shell.is-sidebar-collapsed .sidebar-user-card,
.app-shell.is-sidebar-collapsed .sidebar-logout-button {
    justify-content: center;
    gap: 0;
}

.app-shell.is-sidebar-collapsed .app-nav-link {
    padding-left: 0.8rem;
    padding-right: 0.8rem;
}

.app-shell.is-sidebar-collapsed .sidebar-user-card,
.app-shell.is-sidebar-collapsed .sidebar-logout-button {
    padding-left: 0.85rem;
    padding-right: 0.85rem;
}

.content-shell {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.topbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem 2rem;
    border-bottom: 1px solid var(--abc-line);
    background: rgba(255, 255, 255, 0.72);
    backdrop-filter: blur(14px);
}

.topbar-heading,
.topbar-actions {
    display: flex;
    align-items: center;
    gap: 0.85rem;
}

.topbar-heading {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.25rem;
}

.topbar-label {
    display: block;
    font-size: 0.78rem;
    color: var(--abc-muted);
    text-transform: uppercase;
    letter-spacing: 0.12em;
}

.topbar-title {
    margin: 0;
    font-size: clamp(1.55rem, 2vw, 2.1rem);
    line-height: 1.05;
}

.topbar-copy {
    margin: 0;
    color: var(--abc-muted);
    max-width: 48rem;
}

.content-area {
    padding: 2rem;
}

.panel-card,
.stat-card {
    background: rgba(255, 255, 255, 0.88);
    border-radius: 1.35rem;
    padding: 1.4rem;
}

.panel-card-compact {
    padding: 1.1rem 1.25rem;
}

.panel-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1rem;
}

.panel-title {
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 1rem;
}

.panel-subtitle {
    color: var(--abc-muted);
}

.draft-delete-note {
    margin-top: 1.25rem;
    padding: 0.9rem 1rem;
    border: 1px solid rgba(108, 29, 36, 0.14);
    border-radius: 1rem;
    background: rgba(108, 29, 36, 0.05);
    color: var(--abc-wine-dark);
    font-size: 0.95rem;
}

.stat-card {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    min-height: 100%;
}

.stat-label {
    font-size: 0.78rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--abc-muted);
}

.stat-value {
    font-size: 2rem;
    line-height: 1;
    color: var(--abc-wine);
}

.stat-note {
    color: var(--abc-muted);
    font-size: 0.88rem;
}

.workflow-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 0.9rem;
}

.participant-filter-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1rem;
    align-items: end;
}

.participant-filter-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.workflow-step,
.award-group-card,
.award-catalog-entry,
.feature-card,
.dashboard-list-item,
.catalog-chip,
.award-config-row,
.award-config-section {
    border: 1px solid var(--abc-line);
    border-radius: 1rem;
    background: rgba(248, 243, 238, 0.72);
}

.workflow-step {
    padding: 1rem;
    font-weight: 600;
}

.workflow-step.is-current {
    border-color: rgba(108, 29, 36, 0.28);
    background: rgba(108, 29, 36, 0.08);
}

.workflow-step.is-complete {
    border-color: rgba(28, 122, 60, 0.2);
    background: rgba(28, 122, 60, 0.08);
}

.award-group-card {
    padding: 1rem;
    height: 100%;
}

.award-option {
    display: flex;
    gap: 0.75rem;
    align-items: flex-start;
    padding: 0.6rem 0;
    border-top: 1px solid rgba(231, 221, 213, 0.72);
    cursor: pointer;
}

.award-option:first-of-type {
    border-top: 0;
    padding-top: 0;
}

.exhibition-editor-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.7fr) minmax(280px, 320px);
    gap: 1rem;
    align-items: start;
}

.exhibition-editor-main,
.exhibition-editor-sidebar {
    display: grid;
    gap: 1.25rem;
}

.exhibition-editor-sidebar {
    position: sticky;
    top: 1rem;
}

.exhibition-editor-form-card,
.exhibition-editor-secondary-card,
.exhibition-editor-summary-card {
    box-shadow: 0 12px 28px rgba(57, 25, 21, 0.06);
}

.exhibition-editor-compact-head,
.exhibition-editor-section-head,
.exhibition-award-category-head,
.exhibition-award-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
}

.exhibition-editor-focus-meta {
    justify-content: flex-end;
}

.exhibition-editor-main-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    justify-content: flex-start;
}

.exhibition-editor-section + .exhibition-editor-section {
    margin-top: 1rem;
}

.exhibition-award-guide {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
    margin-bottom: 1rem;
}

.exhibition-award-toolbar {
    margin-bottom: 1rem;
    align-items: end;
}

.exhibition-award-search {
    flex: 1 1 auto;
}

.exhibition-award-toggle {
    padding: 0.75rem 0.95rem;
    border: 1px solid var(--abc-line);
    border-radius: 1rem;
    background: rgba(248, 243, 238, 0.72);
}

.exhibition-award-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
}

.exhibition-award-category {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.exhibition-award-category-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.45rem;
}

.exhibition-award-option {
    margin: 0;
    padding: 0.75rem 0;
}

.exhibition-award-option.is-selected {
    margin-inline: -0.5rem;
    padding-inline: 0.5rem;
    border-radius: 0.9rem;
    background: rgba(108, 29, 36, 0.08);
    border-top-color: transparent;
}

.exhibition-award-option.is-selected + .exhibition-award-option {
    border-top-color: transparent;
}

.exhibition-award-option[hidden],
.exhibition-award-category[hidden] {
    display: none !important;
}

.exhibition-award-option-body {
    display: block;
    min-width: 0;
}

.exhibition-award-empty {
    margin-top: 1rem;
    padding: 0.95rem 1rem;
    border: 1px dashed var(--abc-line);
    border-radius: 1rem;
    color: var(--abc-muted);
    text-align: center;
    background: rgba(248, 243, 238, 0.52);
}

.exhibition-editor-sidecard .info-item strong {
    display: block;
}

.exhibition-editor-side-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.exhibition-editor-side-block + .exhibition-editor-side-block {
    margin-top: 0;
}

.exhibition-editor-side-actions .btn {
    text-align: left;
}

.award-catalog-entry {
    padding: 1rem;
}

.feature-card,
.dashboard-list-item,
.catalog-chip,
.award-config-row,
.award-config-section {
    padding: 1rem;
}

.award-config-section-head {
    margin-bottom: 1rem;
}

.award-config-row {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) 120px minmax(0, 1.4fr);
    gap: 1rem;
    align-items: start;
}

.award-config-row-pair {
    grid-template-columns: 1fr;
}

.award-config-pair-head {
    margin-bottom: 0.9rem;
}

.award-config-pair-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.award-config-pair-grid-single {
    grid-template-columns: minmax(0, 1fr);
}

.award-config-pair-item {
    padding: 1rem;
    border: 1px solid rgba(108, 29, 36, 0.12);
    border-radius: 0.9rem;
    background: rgba(255, 255, 255, 0.45);
}

.award-config-main,
.award-config-sort,
.award-config-rules {
    min-width: 0;
}

.award-toggle {
    display: flex;
    gap: 0.85rem;
    align-items: flex-start;
}

.award-toggle-static {
    justify-content: space-between;
    width: 100%;
}

.award-config-rules {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.award-source-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 0.75rem;
}

.award-source-option {
    align-items: stretch;
    gap: 0.65rem;
    min-height: 100%;
    margin: 0;
    padding: 0.75rem 0.85rem;
    border: 1px solid rgba(108, 29, 36, 0.12);
    border-radius: 0.9rem;
    background: rgba(255, 255, 255, 0.62);
    transition:
        border-color 180ms ease,
        background-color 180ms ease,
        transform 180ms ease;
}

.award-source-option:hover {
    border-color: rgba(108, 29, 36, 0.22);
    background: rgba(255, 255, 255, 0.9);
    transform: translateY(-1px);
}

.award-source-option input {
    margin-top: 0.2rem;
    flex: 0 0 auto;
}

.award-source-option span {
    display: block;
    min-width: 0;
}

.award-source-option strong,
.award-source-option small {
    overflow-wrap: anywhere;
}

.award-source-option input:checked + span strong {
    color: var(--abc-wine-dark);
}

.award-config-row.is-inactive,
.award-config-pair-item.is-inactive {
    background: rgba(248, 243, 238, 0.42);
}

.award-config-readonly-note {
    margin-top: 0.75rem;
    color: var(--abc-muted);
    font-size: 0.88rem;
}

.feature-card-header,
.feature-card-meta,
.feature-card-actions {
    display: flex;
    gap: 0.9rem;
    flex-wrap: wrap;
    align-items: center;
}

.feature-card-header {
    justify-content: space-between;
    margin-bottom: 0.75rem;
}

.feature-card-meta {
    color: var(--abc-muted);
    margin-bottom: 1rem;
}

.dashboard-list-item {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    text-decoration: none;
    color: inherit;
}

.dashboard-list-item:hover {
    color: inherit;
    border-color: rgba(108, 29, 36, 0.25);
}

.empty-state {
    padding: 1.2rem;
    border: 1px dashed rgba(108, 29, 36, 0.25);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.55);
}

.catalog-show-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1rem;
}

.catalog-show-card {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
    min-height: 100%;
    padding: 1.2rem;
    border: 1px solid rgba(108, 29, 36, 0.14);
    border-radius: 1.15rem;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 243, 238, 0.92)),
        rgba(255, 255, 255, 0.88);
    color: inherit;
    text-decoration: none;
    box-shadow: 0 16px 35px rgba(57, 25, 21, 0.06);
    transition:
        transform 180ms ease,
        box-shadow 180ms ease,
        border-color 180ms ease;
}

.catalog-show-card:hover {
    color: inherit;
    transform: translateY(-2px);
    border-color: rgba(108, 29, 36, 0.24);
    box-shadow: 0 22px 45px rgba(57, 25, 21, 0.1);
}

.catalog-show-card-top,
.catalog-show-card-meta,
.catalog-show-card-footer,
.catalog-selected-show-head,
.catalog-selected-show-actions {
    display: flex;
    align-items: center;
    gap: 0.85rem;
}

.catalog-show-card-top,
.catalog-show-card-meta,
.catalog-show-card-footer,
.catalog-selected-show-head {
    justify-content: space-between;
}

.catalog-show-card-meta {
    color: var(--abc-muted);
    font-size: 0.92rem;
    flex-wrap: wrap;
}

.catalog-show-card-title {
    margin: 0;
    font-size: 1.3rem;
    line-height: 1.15;
    color: var(--abc-wine-dark);
}

.catalog-show-card-footer {
    margin-top: auto;
    padding-top: 0.95rem;
    border-top: 1px solid rgba(108, 29, 36, 0.1);
}

.catalog-show-card-count {
    font-weight: 700;
    color: var(--abc-text);
}

.catalog-show-card-action {
    font-size: 0.84rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--abc-wine);
}

.catalog-selected-show-head,
.catalog-selected-show-actions {
    flex-wrap: wrap;
}

.catalog-auto-arrange-form {
    margin: 0;
}

.catalog-dog-name {
    font-weight: 700;
    color: var(--abc-wine-dark);
}

.catalog-number-cell {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    min-width: 6.5rem;
}

.catalog-drag-handle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--abc-muted);
    cursor: grab;
    user-select: none;
    letter-spacing: -0.12em;
}

.catalog-reorder-feedback {
    margin-top: 0.75rem;
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0.4rem 0.75rem;
    border-radius: 999px;
    background: rgba(108, 29, 36, 0.08);
    color: var(--abc-muted);
    font-size: 0.92rem;
    font-weight: 600;
}

.catalog-reorder-feedback.is-success {
    background: rgba(43, 122, 72, 0.12);
    color: #1f6a3a;
}

.catalog-reorder-feedback.is-danger {
    background: rgba(170, 59, 59, 0.12);
    color: #9d2424;
}

.catalog-reorder-table tbody tr[draggable="true"] {
    cursor: move;
}

.catalog-reorder-table tbody[data-reorder-submitting="true"] tr[draggable="true"] {
    cursor: progress;
}

.catalog-reorder-table tbody tr.is-dragging {
    opacity: 0.6;
}

.catalog-reorder-table tbody tr.is-drop-target {
    box-shadow: inset 0 3px 0 rgba(108, 29, 36, 0.22);
}

.catalog-class-cell {
    min-width: 13rem;
}

.sex-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    border: 1px solid rgba(108, 29, 36, 0.12);
    background: rgba(255, 255, 255, 0.92);
}

.sex-icon svg {
    width: 1.15rem;
    height: 1.15rem;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.9;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.sex-icon-ruede {
    color: #1f5398;
    background: rgba(38, 107, 196, 0.1);
}

.sex-icon-huendin {
    color: #a03357;
    background: rgba(178, 72, 111, 0.1);
}

.table-sort-link {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    color: inherit;
    text-decoration: none;
}

.table-sort-link:hover {
    color: var(--abc-wine);
}

.table-sort-link.is-active {
    color: var(--abc-wine-dark);
}

.table-sort-link-center {
    justify-content: center;
}

.table-sort-indicator {
    font-size: 0.88rem;
    line-height: 1;
    color: var(--abc-muted);
}

.status-badge,
.metric-pill,
.role-badge,
.rule-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    border-radius: 999px;
    padding: 0.45rem 0.75rem;
    font-size: 0.78rem;
    font-weight: 700;
}

.status-badge,
.metric-pill,
.role-badge {
    border: 1px solid rgba(108, 29, 36, 0.12);
    background: rgba(255, 255, 255, 0.82);
    color: var(--abc-text);
}

.status-draft {
    background: rgba(187, 148, 87, 0.15);
}

.status-open {
    background: rgba(58, 132, 93, 0.16);
}

.status-closed {
    background: rgba(45, 87, 146, 0.14);
}

.status-started {
    background: rgba(187, 148, 87, 0.22);
}

.status-archived {
    background: rgba(106, 106, 106, 0.14);
}

.status-dropdown {
    display: inline-flex;
}

.status-dropdown-toggle {
    border: 1px solid rgba(108, 29, 36, 0.12);
    cursor: pointer;
}

.status-dropdown-toggle::after {
    margin-left: 0.55rem;
}

.status-dropdown-toggle:hover,
.status-dropdown-toggle:focus,
.status-dropdown-toggle.show {
    color: var(--abc-text);
    border-color: rgba(108, 29, 36, 0.22);
}

.status-dropdown-menu {
    min-width: 12rem;
    padding: 0.45rem;
    border: 1px solid rgba(108, 29, 36, 0.12);
    border-radius: 1rem;
    box-shadow: 0 18px 45px rgba(70, 34, 16, 0.14);
}

.status-dropdown-label {
    padding: 0.4rem 0.6rem 0.55rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--abc-muted);
}

.status-dropdown-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    width: 100%;
    border-radius: 0.75rem;
    padding: 0.65rem 0.75rem;
}

.status-dropdown-item.is-active,
.status-dropdown-item:disabled {
    color: var(--abc-wine-dark);
    background: rgba(108, 29, 36, 0.08);
    opacity: 1;
}

.status-dropdown-check {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--abc-muted);
}

.exhibitions-list-panel {
    position: relative;
}

.exhibitions-table-wrap {
    position: relative;
    overflow: visible;
}

.exhibitions-table-wrap .app-table {
    position: relative;
}

.exhibitions-table-wrap .app-table td,
.exhibitions-table-wrap .app-table th {
    vertical-align: middle;
}

.exhibitions-table-wrap .app-table tbody tr {
    position: relative;
}

.exhibitions-table-wrap .status-dropdown {
    position: relative;
}

.exhibitions-table-wrap .status-dropdown-menu {
    z-index: 30;
}

.exhibition-row-started {
    background: linear-gradient(90deg, rgba(187, 148, 87, 0.1), rgba(187, 148, 87, 0.03));
}

.exhibition-action-group {
    align-items: center;
}

.exhibition-cockpit-button {
    min-width: 9rem;
}

.exhibition-cockpit-button-live {
    position: relative;
    font-weight: 700;
    box-shadow: 0 14px 28px rgba(108, 29, 36, 0.18);
}

.exhibition-cockpit-button-live:hover,
.exhibition-cockpit-button-live:focus {
    box-shadow: 0 18px 32px rgba(108, 29, 36, 0.22);
}

.metric-pill {
    min-width: 2.35rem;
}

.app-table thead th {
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--abc-muted);
    border-bottom-color: var(--abc-line);
}

.app-table tbody tr:hover {
    background: rgba(108, 29, 36, 0.025);
}

.info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 1rem;
}

.info-item {
    padding: 0.95rem 1rem;
    border: 1px solid var(--abc-line);
    border-radius: 1rem;
    background: rgba(248, 243, 238, 0.72);
}

.info-label {
    display: block;
    margin-bottom: 0.35rem;
    font-size: 0.78rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--abc-muted);
}

.section-divider {
    height: 1px;
    background: var(--abc-line);
    margin: 1.2rem 0;
}

.rule-chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.participant-chip-stack {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.rule-chip {
    background: rgba(108, 29, 36, 0.08);
    color: var(--abc-wine-dark);
}

.rule-chip.is-neutral {
    background: rgba(111, 99, 93, 0.08);
    color: var(--abc-muted);
}

.rule-chip-status-ok {
    background: rgba(28, 122, 60, 0.12);
    color: #1f6a3a;
}

.rule-chip-status-check {
    background: rgba(184, 124, 18, 0.14);
    color: #8c5d11;
}

.rule-chip-status-success {
    background: rgba(28, 122, 60, 0.12);
    color: #1f6a3a;
}

.rule-chip-status-progress {
    background: rgba(38, 107, 196, 0.14);
    color: #1f5398;
}

.rule-chip-status-warning {
    background: rgba(164, 39, 39, 0.12);
    color: #8f2020;
}

.rule-chip-status-invalid {
    background: rgba(164, 39, 39, 0.12);
    color: #8f2020;
}

.eligibility-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.eligibility-badge-ok {
    background: rgba(28, 122, 60, 0.12);
    color: #1f6a3a;
}

.eligibility-badge-check {
    background: rgba(184, 124, 18, 0.14);
    color: #8c5d11;
}

.eligibility-badge-invalid {
    background: rgba(164, 39, 39, 0.12);
    color: #8f2020;
}

.warning-list-compact {
    margin: 0.6rem 0 0;
    padding-left: 1rem;
    color: var(--abc-muted);
    font-size: 0.88rem;
}

.warning-list-compact li + li {
    margin-top: 0.2rem;
}

.warning-admin-list {
    display: grid;
    gap: 1rem;
}

.warning-admin-card {
    border: 1px solid var(--abc-line);
    border-radius: 1rem;
    padding: 1.1rem 1.2rem;
    background: #fff;
}

.warning-admin-head {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    margin-bottom: 1rem;
}

.warning-quick-action {
    padding-top: 0.25rem;
}

.table-action-stack {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.meta-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.8rem 1rem;
}

.meta-list div {
    padding-top: 0.75rem;
    border-top: 1px solid var(--abc-line);
}

.meta-list dt {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--abc-muted);
    margin-bottom: 0.2rem;
}

.meta-list dd {
    margin: 0;
    font-weight: 600;
}

.rule-preview {
    background: #241a19;
    color: #f8efe7;
    padding: 0.9rem;
    border-radius: 0.85rem;
    font-size: 0.78rem;
    overflow-x: auto;
}

.payment-check {
    padding: 1rem 1rem 1rem 2rem;
    border: 1px solid var(--abc-line);
    border-radius: 1rem;
    background: rgba(248, 243, 238, 0.72);
}

.workflow-page-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.workflow-page-actions,
.hero-focus-actions,
.class-card-actions,
.class-status-row,
.evaluation-actions,
.evaluation-nav-links,
.candidate-card-meta,
.dog-header-meta {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    align-items: center;
}

.class-status-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: start;
    padding: 1rem 1.1rem;
    border: 1px solid var(--abc-line);
    border-radius: 1.15rem;
    background: rgba(248, 243, 238, 0.72);
    box-shadow: 0 8px 20px rgba(57, 25, 21, 0.05);
}

.class-status-main {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    min-width: 0;
}

.class-status-heading {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    align-items: center;
}

.class-status-note {
    font-size: 0.92rem;
    color: var(--abc-muted);
}

.class-status-kpi-grid {
    grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
    margin-bottom: 0;
    max-width: 30rem;
}

.class-status-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    align-items: center;
    justify-content: flex-end;
}

.class-status-action {
    white-space: nowrap;
}

.class-warning-banner {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem 1rem;
    align-items: center;
    padding: 1rem 1.1rem;
    border: 1px solid rgba(159, 53, 53, 0.34);
    border-radius: 1.15rem;
    background: rgba(159, 53, 53, 0.14);
    color: #7b1f1f;
}

.class-warning-banner-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.38rem 0.72rem;
    border-radius: 999px;
    background: #8f2020;
    color: #fff7f1;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.class-warning-banner-copy {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.class-warning-banner-copy strong {
    font-size: 0.98rem;
}

.class-warning-banner-copy span {
    color: #7b1f1f;
}

.hero-focus-card {
    position: relative;
    overflow: hidden;
    padding: 1.25rem;
    border-color: rgba(108, 29, 36, 0.22);
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(248, 243, 238, 0.94));
    box-shadow:
        0 14px 34px rgba(47, 39, 35, 0.08),
        0 0 0 1px rgba(108, 29, 36, 0.04);
}

.hero-focus-card::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    border: 1px solid rgba(184, 92, 56, 0.14);
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.45),
        0 0 18px rgba(184, 92, 56, 0.08);
    pointer-events: none;
}

.hero-focus-card.is-current {
    box-shadow:
        0 18px 38px rgba(47, 39, 35, 0.1),
        0 0 0 1px rgba(108, 29, 36, 0.08);
}

.hero-focus-card.is-current::after {
    border-color: rgba(184, 92, 56, 0.18);
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.55),
        0 0 22px rgba(184, 92, 56, 0.1);
}

.hero-focus-main {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(20rem, 24rem);
    gap: 0.9rem;
    align-items: start;
}

.hero-focus-copy {
    min-width: 0;
    margin-bottom: 0;
}

.hero-focus-intro {
    display: inline-flex;
    align-items: center;
    margin-bottom: 0.65rem;
}

.hero-focus-inline-indicator {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.32rem 0.62rem;
    border: 1px solid rgba(108, 29, 36, 0.14);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.82);
    color: var(--abc-wine-dark);
    font-size: 0.76rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.hero-focus-inline-dot {
    width: 0.52rem;
    height: 0.52rem;
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(184, 92, 56, 0.95), rgba(108, 29, 36, 1));
    box-shadow: 0 0 0 0 rgba(108, 29, 36, 0.32);
    animation: hero-focus-pulse 2.2s ease-out infinite;
}

.hero-focus-title {
    margin: 0 0 0.2rem;
    font-size: clamp(1.2rem, 1.8vw, 1.45rem);
}

.hero-focus-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 0;
}

.hero-focus-next-dog {
    margin-top: 0.55rem;
    font-size: 0.95rem;
    color: var(--abc-muted);
}

.hero-focus-next-dog strong {
    color: var(--abc-text);
}

.hero-focus-kpi-grid {
    width: 100%;
    display: grid;
    gap: 0.5rem;
    max-width: 100%;
    align-self: start;
}

.hero-focus-kpi-grid .class-card-kpi {
    border-radius: 0.72rem;
    padding: 0.5rem 0.6rem;
}

.hero-focus-kpi-grid .class-card-kpi-tone-neutral,
.hero-focus-kpi-grid .class-card-kpi-tone-progress,
.hero-focus-kpi-grid .class-card-kpi-tone-warning,
.hero-focus-kpi-grid .class-card-kpi-tone-danger,
.hero-focus-kpi-grid .class-card-kpi-tone-success {
    border-color: rgba(163, 146, 136, 0.12);
    background: rgba(255, 255, 255, 0.62);
}

.hero-focus-kpi-grid .class-card-kpi::before {
    display: none;
}

.hero-focus-kpi-cluster {
    display: grid;
    gap: 0.4rem;
}

.hero-focus-kpi-cluster-grid {
    display: grid;
    gap: 0.45rem;
}

.hero-focus-kpi-cluster-grid-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.hero-focus-kpi-cluster-grid-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.hero-focus-kpi-item {
    position: relative;
    display: grid;
    gap: 0.14rem;
    min-width: 0;
    padding-left: 0.8rem;
}

.hero-focus-kpi-item::before {
    content: "";
    position: absolute;
    top: 0.3rem;
    left: 0;
    width: 0.38rem;
    height: 0.38rem;
    border-radius: 999px;
    background: #a89c95;
}

.hero-focus-kpi-item-label {
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: rgba(101, 91, 86, 0.92);
}

.hero-focus-kpi-item-value {
    font-size: 0.92rem;
    font-weight: 700;
    color: rgba(47, 39, 35, 0.96);
    line-height: 1.2;
}

.hero-focus-kpi-item-tone-neutral::before {
    background: #a89c95;
}

.hero-focus-kpi-item-tone-progress::before {
    background: #2f6fce;
}

.hero-focus-kpi-item-tone-warning::before {
    background: #b77916;
}

.hero-focus-kpi-item-tone-success::before {
    background: #1f7a45;
}

@media (max-width: 991.98px) {
    .hero-focus-main {
        grid-template-columns: minmax(0, 1fr);
    }

    .hero-focus-kpi-grid {
        max-width: none;
    }
}

@media (max-width: 575.98px) {
    .hero-focus-kpi-cluster-grid-2,
    .hero-focus-kpi-cluster-grid-3 {
        grid-template-columns: 1fr;
    }
}

@keyframes hero-focus-pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(108, 29, 36, 0.3);
    }

    70% {
        box-shadow: 0 0 0 0.45rem rgba(108, 29, 36, 0);
    }

    100% {
        box-shadow: 0 0 0 0 rgba(108, 29, 36, 0);
    }
}

@media (max-width: 767.98px) {
    .class-status-panel {
        grid-template-columns: minmax(0, 1fr);
    }

    .class-status-kpi-grid {
        max-width: none;
    }

    .class-status-actions {
        justify-content: flex-start;
    }
}

.cockpit-top-grid {
    display: grid;
    gap: 1rem;
    align-items: start;
}

.cockpit-hero-panel {
    grid-column: 1 / -1;
}

.cockpit-hero-panel .panel-head {
    margin-bottom: 0.9rem;
}

.cockpit-hero-panel .panel-subtitle {
    max-width: 48rem;
}

.cockpit-quick-panel {
    grid-column: 1 / -1;
}

.cockpit-quick-panel {
    padding: 1.25rem;
}

.cockpit-quick-panel-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
}

.cockpit-quick-actions-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(3.6rem, 1fr));
    gap: 0.65rem;
    align-items: start;
}

.cockpit-quick-actions-stack {
    display: flex;
    flex-wrap: nowrap;
    gap: 0.85rem;
    align-items: stretch;
    overflow-x: auto;
    padding-top: 0.15rem;
}

.cockpit-quick-group {
    position: relative;
    display: grid;
    gap: 0.6rem;
    min-width: 0;
    flex: 1 1 0;
    padding: 0.95rem 0.75rem 0.75rem;
    border: 1px solid rgba(108, 29, 36, 0.12);
    border-radius: 0.85rem;
    background: rgba(255, 255, 255, 0.34);
}

.cockpit-quick-group-label {
    position: absolute;
    top: 0;
    left: 0.7rem;
    transform: translateY(-50%);
    padding: 0 0.35rem;
    background: #f3ece6;
    border-radius: 0.35rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0;
    color: var(--abc-muted);
    line-height: 1.2;
}

.cockpit-setup-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 0.75rem;
}

.cockpit-setup-item {
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
    min-height: 100%;
    padding: 0.95rem 1rem;
    border: 1px solid var(--abc-line);
    border-radius: 1rem;
    background: rgba(248, 243, 238, 0.72);
    color: inherit;
    text-decoration: none;
    transition:
        border-color 180ms ease,
        transform 180ms ease,
        background-color 180ms ease;
}

.cockpit-setup-item:hover {
    color: inherit;
    border-color: rgba(108, 29, 36, 0.25);
    background: rgba(255, 255, 255, 0.94);
    transform: translateY(-1px);
}

.cockpit-setup-item-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.75rem;
}

.cockpit-setup-item-detail {
    color: var(--abc-muted);
    font-size: 0.88rem;
    line-height: 1.45;
}

.cockpit-warning-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
}

.cockpit-warning-card {
    min-height: 100%;
}

.cockpit-warning-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.cockpit-quick-action-link {
    display: grid;
    justify-items: center;
    align-items: center;
    gap: 0;
    min-height: 3.6rem;
    padding: 0.7rem;
    border: 1px solid var(--abc-line);
    border-radius: 0.8rem;
    background: rgba(248, 243, 238, 0.72);
    color: inherit;
    text-decoration: none;
    transition:
        border-color 180ms ease,
        transform 180ms ease,
        background-color 180ms ease;
}

.cockpit-quick-action-link:hover {
    color: inherit;
    border-color: rgba(108, 29, 36, 0.25);
    background: rgba(255, 255, 255, 0.94);
    transform: translateY(-1px);
}

.cockpit-quick-action-link.link-primary {
    border-color: var(--abc-wine);
    background: var(--abc-wine);
    color: var(--abc-panel);
}

.cockpit-quick-action-link.link-primary:hover {
    border-color: var(--abc-wine);
    background: var(--abc-wine-dark);
    color: var(--abc-panel);
}

.cockpit-quick-action-icon.icon-primary {
    color: var(--abc-panel);
}

.cockpit-quick-action-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.4rem;
    height: 1.4rem;
    color: rgb(108, 29, 36);
}

.cockpit-quick-action-icon svg {
    width: 100%;
    height: 100%;
}

.cockpit-quick-action-copy {
    display: none;
}

.cockpit-quick-action-title {
    font-size: 0.95rem;
}

.cockpit-quick-action-detail {
    color: var(--abc-muted);
    font-size: 0.84rem;
    line-height: 1.4;
}

.cockpit-quick-panel.is-expanded .cockpit-quick-actions-grid {
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 0.75rem;
}

.cockpit-quick-panel.is-expanded .cockpit-quick-actions-stack {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
    overflow: visible;
}

.cockpit-quick-panel.is-expanded .cockpit-quick-group {
    gap: 0.7rem;
    padding: 1rem;
}

.cockpit-quick-panel.is-expanded .cockpit-quick-action-link {
    justify-items: start;
    align-items: start;
    gap: 0.45rem;
    min-height: 100%;
    padding: 0.9rem 1rem;
}

.cockpit-quick-panel.is-expanded .cockpit-quick-action-copy {
    display: grid;
    gap: 0.25rem;
    width: 100%;
}

.cockpit-quick-toggle {
    flex-shrink: 0;
}

.rule-chip-link {
    color: inherit;
    text-decoration: none;
}

.rule-chip-link:hover {
    color: inherit;
    border-color: rgba(108, 29, 36, 0.22);
    background: rgba(255, 255, 255, 0.92);
}

.cockpit-summary-strip {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 0.85rem;
}

.cockpit-summary-strip .stat-card {
    padding: 1rem 1.1rem;
    border-radius: 1.15rem;
}

.cockpit-summary-strip .stat-value {
    font-size: 1.45rem;
}

.cockpit-workflow-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.cockpit-workflow-panel {
    padding: 1.25rem;
}

.cockpit-workflow-panel-male {
    background:
        linear-gradient(180deg, rgba(188, 214, 223, 0.28), rgba(255, 255, 255, 0.88));
}

.cockpit-workflow-panel-female {
    background:
        linear-gradient(180deg, rgba(236, 216, 225, 0.3), rgba(255, 255, 255, 0.88));
}

.cockpit-sex-grid {
    display: grid;
    gap: 0.85rem;
}

.workflow-status-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 0.45rem 0.85rem;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.workflow-status-open {
    background: rgba(111, 99, 93, 0.1);
    color: var(--abc-muted);
}

.workflow-status-in_progress {
    background: rgba(38, 107, 196, 0.14);
    color: #1f5398;
}

.workflow-status-running,
.workflow-status-nearly_done,
.workflow-status-rating_saved,
.workflow-status-report_saved {
    background: rgba(38, 107, 196, 0.14);
    color: #1f5398;
}

.workflow-status-warning {
    background: rgba(164, 39, 39, 0.12);
    color: #8f2020;
}

.workflow-status-finished,
.workflow-status-completed,
.workflow-status-done,
.workflow-status-printed {
    background: rgba(28, 122, 60, 0.12);
    color: #1f6a3a;
}

.task-list,
.candidate-list,
.award-selection-list {
    display: grid;
    gap: 0.9rem;
}

.task-list-item,
.candidate-card,
.award-selection-card {
    display: flex;
    gap: 0.9rem;
    align-items: flex-start;
    padding: 1rem;
    border: 1px solid var(--abc-line);
    border-radius: 1rem;
    background: rgba(248, 243, 238, 0.72);
    color: inherit;
    text-decoration: none;
}

.task-list-item:hover,
.final-award-jump:hover {
    color: inherit;
    border-color: rgba(108, 29, 36, 0.25);
}

.workflow-task-arrow {
    margin-left: auto;
    color: var(--abc-muted);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.stat-card-link {
    display: flex;
    text-decoration: none;
    color: inherit;
}

.stat-card-link:hover {
    color: inherit;
    border-color: rgba(108, 29, 36, 0.25);
}

.class-overview-grid,
.final-award-preview-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
    gap: 1rem;
}

.cockpit-special-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 1rem;
}

.cockpit-special-card {
    display: flex;
    flex-direction: column;
    min-height: 100%;
}

.cockpit-special-note {
    color: var(--abc-muted);
    margin-bottom: 1rem;
}

.class-card {
    padding: 1.15rem;
    border: 1px solid var(--abc-line);
    border-radius: 1.15rem;
    background: rgba(248, 243, 238, 0.72);
    overflow: hidden;
    box-shadow: 0 8px 20px rgba(57, 25, 21, 0.05);
}

.class-card.is-current {
    border-color: rgba(108, 29, 36, 0.35);
    background: rgba(108, 29, 36, 0.05);
}

.class-card.is-finished {
    border-color: rgba(28, 122, 60, 0.24);
    background: linear-gradient(145deg, rgba(242, 250, 244, 0.98), rgba(231, 246, 235, 0.92));
}

.class-card.is-finished .class-card-head h3 {
    color: #1f6a3a;
}

.class-card-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 0.85rem;
}

.class-card-head .workflow-status-badge {
    padding: 0.34rem 0.68rem;
    font-size: 0.69rem;
    letter-spacing: 0.04em;
}

.hero-focus-head .hero-focus-status-badge {
    padding: 0.24rem 0.54rem;
    border: 1px solid rgba(108, 29, 36, 0.12);
    background: rgba(248, 243, 238, 0.88);
    color: var(--abc-muted);
    font-size: 0.67rem;
    letter-spacing: 0.03em;
}

.class-card-meta-line {
    display: inline-flex;
    flex-wrap: wrap;
}

.class-card-meta-sex {
    width: 1.6rem;
    height: 1.6rem;
}

.class-card-meta-sex svg {
    width: 0.95rem;
    height: 0.95rem;
}

.class-card-kpi-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: stretch;
    gap: 0.42rem;
    margin-bottom: 0.85rem;
}

.class-card-kpi {
    --class-kpi-dot: #b7ada7;
    position: relative;
    flex: 1 1 9rem;
    max-width: 16rem;
    min-width: 0;
    border-radius: 0.72rem;
    border: 1px solid rgba(163, 146, 136, 0.2);
    background: rgba(255, 255, 255, 0.9);
    padding: 0.4rem 0.5rem 0.45rem 0.58rem;
}

.class-card-kpi::before {
    content: "";
    position: absolute;
    top: 0.57rem;
    left: 0.42rem;
    width: 0.42rem;
    height: 0.42rem;
    border-radius: 50%;
    background: var(--class-kpi-dot);
}

.class-card-kpi-label {
    display: block;
    margin-left: 0.55rem;
    font-size: 0.61rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--abc-muted);
}

.class-card-kpi-value {
    display: block;
    margin-top: 0.16rem;
    margin-left: 0.55rem;
    font-size: 0.91rem;
    font-weight: 700;
    color: var(--abc-text);
}

.class-card-kpi-tone-neutral {
    --class-kpi-dot: #a89c95;
}

.class-card-kpi-tone-progress {
    --class-kpi-dot: #2f6fce;
    border-color: rgba(47, 111, 206, 0.28);
    background: rgba(47, 111, 206, 0.1);
}

.class-card-kpi-tone-warning {
    --class-kpi-dot: #b77916;
    border-color: rgba(183, 121, 22, 0.3);
    background: rgba(183, 121, 22, 0.11);
}

.class-card-kpi-tone-danger {
    --class-kpi-dot: #9f3535;
    border-color: rgba(159, 53, 53, 0.3);
    background: rgba(159, 53, 53, 0.1);
}

.class-card-kpi-tone-success {
    --class-kpi-dot: #1f7a45;
    border-color: rgba(31, 122, 69, 0.28);
    background: rgba(31, 122, 69, 0.1);
}

.class-card-kpi-tone-progress .class-card-kpi-value,
.class-card-kpi-tone-warning .class-card-kpi-value,
.class-card-kpi-tone-danger .class-card-kpi-value,
.class-card-kpi-tone-success .class-card-kpi-value {
    color: #2c2521;
}

.class-card-kpi-value,
.class-card-kpi-label {
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.class-card-kpi-group {
    display: grid;
    flex-basis: 13.5rem;
    gap: 0.18rem;
}

.class-card-kpi-group::before {
    display: none;
}

.class-card-kpi-group .class-card-kpi-label {
    margin-left: 0;
}

.class-card-kpi-pairs {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.28rem;
}

.class-card-kpi-pairs-compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.class-card-kpi-pair {
    display: grid;
    gap: 0.04rem;
    padding: 0.14rem 0.22rem;
    border-radius: 0.42rem;
    background: rgba(248, 243, 238, 0.7);
    min-width: 0;
}

.class-card-kpi-pair-label {
    font-size: 0.49rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: rgba(101, 91, 86, 0.88);
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.class-card-kpi-pair-value {
    font-size: 0.66rem;
    font-weight: 600;
    color: rgba(47, 39, 35, 0.9);
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.class-card-kpi-pair-tone-progress {
    background: rgba(47, 111, 206, 0.09);
}

.class-card-kpi-pair-tone-warning {
    background: rgba(183, 121, 22, 0.1);
}

.class-card-kpi-pair-tone-success {
    background: rgba(31, 122, 69, 0.09);
}

.class-card-kpi-pair-tone-neutral {
    background: rgba(248, 243, 238, 0.7);
}

.class-card-actions {
    align-items: stretch;
}

.class-card-actions .btn {
    flex: 1 1 220px;
    min-width: 0;
    white-space: normal;
}

.class-card-actions.hero-focus-actions {
    align-items: center;
    gap: 0.75rem;
    margin-top: 1rem;
}

.class-card-actions.hero-focus-actions .btn {
    flex: 0 0 auto;
    min-width: 12rem;
    white-space: nowrap;
}

.class-card-actions.hero-focus-actions .btn.btn-primary {
    min-width: 14rem;
}

.workflow-checkboxes {
    display: flex;
    gap: 0.85rem;
    flex-wrap: wrap;
    align-items: center;
    padding: 0.75rem 0;
}

.workflow-table tbody tr td {
    vertical-align: top;
}

.workflow-row-next {
    background: rgba(108, 29, 36, 0.04);
}

.class-rating-quick-form {
    display: grid;
    gap: 0.7rem;
    min-width: 260px;
}

.class-rating-quick-fields {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) 92px;
    gap: 0.6rem;
    align-items: end;
}

.class-rating-field {
    display: grid;
    gap: 0.3rem;
    min-width: 0;
}

.class-rating-field-label {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--abc-muted);
}

.class-rating-field-rank {
    width: 100%;
}

.class-ranking-hint {
    min-height: 1.15em;
    font-size: 0.68rem;
    line-height: 1.25;
}

.class-rating-quick-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.class-rating-quick-actions {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.class-rating-quick-actions .btn {
    white-space: nowrap;
}

.evaluation-action-bar {
    margin-bottom: 1rem;
}

.evaluation-action-bar-head,
.evaluation-action-bar-foot {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.evaluation-action-bar-foot {
    margin-top: 0.9rem;
    padding-top: 0.9rem;
    border-top: 1px solid var(--abc-line);
}

.evaluation-action-summary,
.evaluation-action-buttons {
    display: flex;
    gap: 0.65rem;
    flex-wrap: wrap;
    align-items: center;
}

.evaluation-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.9fr);
    gap: 1rem;
    align-items: start;
}

.evaluation-main-column,
.evaluation-side-column {
    display: grid;
    gap: 1rem;
    min-width: 0;
}

.evaluation-main-column .workflow-textarea {
    min-height: 32rem;
}

.evaluation-rating-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 120px;
    gap: 0.85rem;
    align-items: start;
}

.evaluation-subhead {
    margin-bottom: 0.75rem;
}

.evaluation-class-nav-list {
    display: grid;
    gap: 0.55rem;
    max-height: 18rem;
    overflow: auto;
    padding-right: 0.15rem;
}

.evaluation-class-nav-item {
    display: grid;
    gap: 0.35rem;
    padding: 0.8rem 0.9rem;
    border: 1px solid var(--abc-line);
    border-radius: 0.95rem;
    background: #fff;
    color: inherit;
    text-decoration: none;
    transition: border-color 160ms ease, background-color 160ms ease, box-shadow 160ms ease;
}

.evaluation-class-nav-item:hover {
    color: inherit;
    border-color: rgba(108, 29, 36, 0.22);
    box-shadow: 0 8px 18px rgba(57, 25, 21, 0.04);
}

.evaluation-class-nav-item.is-current {
    border-color: rgba(108, 29, 36, 0.32);
    background: rgba(108, 29, 36, 0.05);
}

.evaluation-class-nav-item.is-next-open:not(.is-current) {
    border-color: rgba(184, 124, 18, 0.24);
    background: rgba(184, 124, 18, 0.04);
}

.evaluation-class-nav-line {
    display: flex;
    gap: 0.55rem;
    align-items: center;
    flex-wrap: wrap;
    min-width: 0;
}

.evaluation-class-nav-line-muted {
    color: var(--abc-muted);
    font-size: 0.84rem;
}

.evaluation-class-nav-line .workflow-status-badge {
    padding: 0.28rem 0.58rem;
    font-size: 0.68rem;
}

.evaluation-class-nav-catalog {
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--abc-muted);
}

.evaluation-class-nav-name {
    min-width: 0;
    font-size: 0.96rem;
    line-height: 1.35;
}

.evaluation-meta-strip {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem;
}

.evaluation-meta-item {
    display: grid;
    gap: 0.2rem;
    min-width: 0;
    padding: 0.8rem 0.9rem;
    border: 1px solid var(--abc-line);
    border-radius: 0.9rem;
    background: rgba(248, 243, 238, 0.46);
}

.evaluation-meta-item strong {
    word-break: break-word;
}

.dog-meta-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
}

.workflow-textarea {
    height: 350px;
    resize: vertical;
}

.heart-rating-selector {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
}

.heart-rating-option {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    padding: 1rem;
    border: 1px solid var(--abc-line);
    border-radius: 1rem;
    background: rgba(248, 243, 238, 0.72);
    cursor: pointer;
    transition: border-color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

.heart-rating-option:hover {
    border-color: rgba(108, 29, 36, 0.28);
    box-shadow: 0 8px 20px rgba(57, 25, 21, 0.05);
}

.heart-rating-option input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.heart-rating-option:has(input:checked) {
    border-color: rgba(108, 29, 36, 0.45);
    background: rgba(108, 29, 36, 0.07);
    box-shadow: 0 10px 24px rgba(108, 29, 36, 0.1);
    transform: translateY(-1px);
}

.heart-rating-visual {
    font-size: 1.6rem;
    letter-spacing: 0.18rem;
    color: var(--abc-wine);
    line-height: 1;
}

.heart-rating-label {
    font-size: 0.92rem;
    color: var(--abc-muted);
}

.award-selection-card input,
.candidate-card input {
    margin-top: 0.25rem;
}

.award-selection-card.is-disabled {
    opacity: 0.72;
    background: rgba(111, 99, 93, 0.06);
}

.candidate-card.is-disabled {
    opacity: 0.76;
    background: rgba(111, 99, 93, 0.06);
}

.class-config-enable {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
}

.class-config-enable-switch {
    margin: 0;
    padding: 0;
    padding-left: 0;
    width: auto;
    max-width: 100%;
    justify-self: start;
    border: 0;
    border-radius: 0;
    background: transparent;
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
}

.class-config-enable-switch .form-check-input {
    margin-top: 0;
    margin-left: 0;
    float: none;
    flex: 0 0 auto;
}

.class-config-enable-switch .form-check-label {
    font-weight: 600;
    color: var(--abc-ink);
    line-height: 1.2;
    white-space: nowrap;
}

.config-compact-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
}

.config-inline-hints {
    justify-content: flex-end;
}

.config-overview-strip {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 0.8rem;
    margin-top: 1rem;
}

.config-overview-stat {
    display: grid;
    gap: 0.2rem;
    min-width: 0;
    padding: 0.9rem 1rem;
    border: 1px solid var(--abc-line);
    border-radius: 1rem;
    background: rgba(248, 243, 238, 0.58);
}

.config-overview-stat strong {
    font-size: 0.98rem;
    font-weight: 700;
}

.config-overview-stat span {
    color: var(--abc-muted);
    font-size: 0.86rem;
}

.config-guide-grid,
.config-class-settings,
.config-summary-grid,
.config-class-grid {
    display: grid;
    gap: 1rem;
}

.config-guide-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.config-summary-grid {
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.config-class-grid {
    grid-template-columns: 1fr;
    gap: 0.8rem;
}

.config-class-list {
    display: grid;
    gap: 0.8rem;
}

.config-class-list-head {
    display: grid;
    grid-template-columns: minmax(280px, 1.35fr) minmax(170px, 0.85fr) minmax(280px, 1.2fr) minmax(240px, 0.9fr);
    gap: 1rem;
    padding: 0 1rem;
    color: var(--abc-muted);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.config-class-card {
    display: grid;
    grid-template-columns: minmax(280px, 1.35fr) minmax(170px, 0.85fr) minmax(280px, 1.2fr) minmax(240px, 0.9fr);
    align-items: center;
    gap: 1rem;
    min-width: 0;
    padding: 0.95rem 1rem;
    border: 1px solid var(--abc-line);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.82);
    transition:
        border-color 180ms ease,
        box-shadow 180ms ease,
        transform 180ms ease,
        opacity 180ms ease;
}

.config-class-card.is-disabled {
    opacity: 0.72;
    background: rgba(111, 99, 93, 0.06);
}

.config-class-card.is-enabled {
    border-color: rgba(108, 29, 36, 0.16);
}

.config-class-card.is-dragging {
    opacity: 0.55;
    transform: scale(0.99);
}

.config-class-card.is-drop-target {
    border-color: rgba(108, 29, 36, 0.45);
    box-shadow: 0 0 0 3px rgba(108, 29, 36, 0.08);
}

.config-class-primary,
.config-class-card-title,
.config-class-preview,
.config-class-controls,
.config-class-ring-field,
.config-class-rank-field {
    min-width: 0;
}

.config-class-primary {
    display: grid;
    gap: 0.6rem;
}

.config-class-card-title {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
}

.config-class-card-heading {
    display: grid;
    gap: 0.45rem;
}

.config-class-inline-meta,
.config-class-stats {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.config-drag-handle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border: 1px dashed rgba(108, 29, 36, 0.26);
    border-radius: 0.8rem;
    background: rgba(108, 29, 36, 0.04);
    color: var(--abc-muted);
    font-weight: 800;
    letter-spacing: 0.1em;
    cursor: grab;
    user-select: none;
}

.config-class-preview {
    display: grid;
    gap: 0.3rem;
}

.config-class-preview-label {
    color: var(--abc-muted);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.config-class-award-preview {
    min-height: 1.4rem;
    color: var(--abc-ink);
    font-size: 0.95rem;
}

.config-class-award-list {
    display: grid;
    gap: 0.18rem;
    line-height: 1.3;
}

.config-class-award-list [data-class-award-chip] {
    color: var(--abc-ink);
    font-size: 0.89rem;
    font-weight: 500;
    display: block;
}

.config-class-controls {
    display: grid;
    justify-items: stretch;
    align-content: center;
    gap: 0.85rem;
}

.config-class-settings-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
    align-items: start;
}

.config-class-ring-field,
.config-class-rank-field {
    width: 100%;
}

.config-class-ring-field .form-control,
.config-class-rank-field .form-control {
    padding: 0.45rem 0.7rem;
}

.config-class-controls .btn {
    width: 100%;
}

.config-class-card.is-disabled .config-award-card-preview,
.config-class-card.is-disabled .config-class-award-preview,
.config-class-card.is-disabled .config-class-stats,
.config-class-card.is-disabled .config-class-inline-meta {
    opacity: 0.92;
}

.config-class-card.is-disabled .config-drag-handle {
    background: rgba(111, 99, 93, 0.05);
    border-color: rgba(111, 99, 93, 0.2);
}

.config-class-rank-note {
    margin-top: 0.35rem;
    line-height: 1.25;
}

.config-offcanvas {
    width: min(980px, 100vw);
}

.config-offcanvas .offcanvas-header {
    border-bottom: 1px solid var(--abc-line);
}

.config-offcanvas .offcanvas-body {
    background:
        radial-gradient(circle at top left, rgba(187, 148, 87, 0.12), transparent 28%),
        linear-gradient(180deg, #fbf8f5 0%, #f3ece6 100%);
}

.config-offcanvas-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.25rem 1.2rem;
    border-top: 1px solid var(--abc-line);
    background: rgba(251, 248, 245, 0.98);
}

.class-open-awards-trigger {
    font: inherit;
    border: 1px solid transparent;
    cursor: pointer;
    transition: border-color 0.2s ease, transform 0.2s ease, background-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.class-open-awards-trigger.is-attention {
    color: #7a3d00;
    background: linear-gradient(180deg, rgba(249, 196, 95, 0.95), rgba(236, 160, 49, 0.92));
    border-color: rgba(175, 105, 11, 0.45);
    box-shadow: 0 10px 22px rgba(175, 105, 11, 0.18);
    font-weight: 700;
}

.class-open-awards-trigger.is-subtle {
    color: #5f534f;
    background: rgba(248, 243, 238, 0.9);
    border-color: rgba(126, 106, 99, 0.24);
    box-shadow: none;
}

.class-open-awards-trigger:hover,
.class-open-awards-trigger:focus-visible {
    border-color: rgba(183, 121, 22, 0.35);
    transform: translateY(-1px);
}

.class-open-awards-trigger.is-attention:hover,
.class-open-awards-trigger.is-attention:focus-visible {
    color: #693300;
    background: linear-gradient(180deg, rgba(250, 205, 109, 1), rgba(239, 167, 57, 0.96));
    border-color: rgba(161, 94, 8, 0.48);
    box-shadow: 0 12px 24px rgba(161, 94, 8, 0.22);
}

.class-open-awards-trigger.is-subtle:hover,
.class-open-awards-trigger.is-subtle:focus-visible {
    background: rgba(255, 248, 239, 0.96);
    border-color: rgba(183, 121, 22, 0.28);
    box-shadow: 0 8px 18px rgba(97, 74, 65, 0.08);
}

.class-open-awards-trigger:disabled {
    cursor: default;
    transform: none;
    box-shadow: none;
}

.class-open-awards-offcanvas {
    --bs-offcanvas-width: min(560px, 98vw);
    width: var(--bs-offcanvas-width) !important;
    max-width: 98vw;
}


.class-open-award-card {
    border: 1px solid var(--abc-line);
    border-radius: 1rem;
    padding: 0.9rem;
    background: rgba(248, 243, 238, 0.7);
}

.class-open-award-head {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    align-items: flex-start;
    margin-bottom: 0.7rem;
}

.class-open-award-candidates {
    display: grid;
    gap: 0.55rem;
}

.internal-live-shell {
    display: grid;
    gap: 1rem;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow-x: clip;
}

.internal-live-page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.25rem 1.3rem;
    border: 1px solid rgba(108, 29, 36, 0.1);
    border-radius: 1.4rem;
    background:
        radial-gradient(circle at top right, rgba(108, 29, 36, 0.08), transparent 38%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 243, 238, 0.92));
    box-shadow: 0 16px 34px rgba(57, 25, 21, 0.08);
}

.internal-live-page-actions,
.internal-live-inline-actions,
.internal-live-card-actions,
.internal-live-focus-actions,
.internal-live-class-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    align-items: center;
    padding-top: 20px;
}

.internal-live-page-head,
.internal-live-focus-card,
.internal-live-section,
.internal-live-filter-form,
.internal-live-switcher,
.internal-live-workflow-panel,
.internal-live-group-summary-card,
.internal-live-metric-card,
.internal-live-class-card,
.internal-live-dog-card,
.internal-live-report-card,
.internal-live-hub-card,
.internal-live-switcher-link,
.internal-live-activity-item {
    width: 100%;
    max-width: 100%;
    min-width: 0;
}

.internal-live-page-head > *,
.internal-live-focus-head > *,
.internal-live-class-head > *,
.internal-live-dog-head > *,
.internal-live-report-head > *,
.internal-live-switcher-head > *,
.internal-live-hub-head > *,
.panel-head > * {
    min-width: 0;
}

.internal-live-focus-card,
.internal-live-section,
.internal-live-filter-form,
.internal-live-switcher {
    border: 1px solid rgba(108, 29, 36, 0.08);
    border-radius: 1.3rem;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 243, 238, 0.94));
    box-shadow: 0 14px 30px rgba(57, 25, 21, 0.07);
}

.internal-live-focus-card,
.internal-live-section,
.internal-live-switcher {
    padding: 1.15rem;
}

.internal-live-focus-card {
    background:
        radial-gradient(circle at top left, rgba(108, 29, 36, 0.09), transparent 30%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(247, 241, 237, 0.95));
}

.internal-live-focus-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(250px, 320px);
    gap: 1.1rem;
    align-items: start;
}

.internal-live-focus-main,
.internal-live-focus-aside {
    min-width: 0;
}

.internal-live-focus-main {
    display: grid;
    gap: 0.9rem;
}

.internal-live-focus-aside {
    display: grid;
    gap: 0.85rem;
    align-content: start;
}

.internal-live-focus-title-row {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 0.7rem;
}

.internal-live-focus-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    color: var(--abc-muted);
    font-size: 0.96rem;
}

.internal-live-focus-stats span {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.internal-live-focus-stats span:not(:last-child)::after {
    content: "·";
    color: rgba(108, 29, 36, 0.28);
    margin-left: 0.2rem;
}

.internal-live-focus-head,
.internal-live-class-head,
.internal-live-dog-head,
.internal-live-report-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.85rem;
}

.internal-live-focus-head {
    margin-bottom: 1rem;
}

.internal-live-focus-side,
.internal-live-panel-side,
.internal-live-class-side {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: flex-start;
    gap: 0.65rem;
}

.internal-live-progress-stack {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.65rem;
}

.internal-live-focus-progresses {
    display: grid;
    grid-template-columns: auto minmax(160px, 1fr);
    justify-content: end;
    gap: 0.85rem;
    align-items: stretch;
}

.internal-live-focus-progress-item {
    display: grid;
    justify-items: center;
    align-content: start;
    gap: 0.38rem;
    min-width: 84px;
}

.internal-live-focus-progress-panel {
    display: grid;
    align-content: start;
    gap: 0.5rem;
    min-width: min(100%, 220px);
    padding: 0.7rem 0.8rem;
    border-radius: 1rem;
    background:
        linear-gradient(180deg, rgba(108, 29, 36, 0.08), rgba(255, 255, 255, 0.94));
    box-shadow: inset 0 0 0 1px rgba(108, 29, 36, 0.08);
}

.internal-live-focus-progress-caption {
    font-size: 0.68rem;
    line-height: 1.2;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--abc-muted);
    text-align: center;
}

.internal-live-focus-progress-meta {
    font-size: 0.72rem;
    line-height: 1.2;
    color: var(--abc-muted);
    text-align: center;
}

.internal-live-focus-progress-bar {
    position: relative;
    overflow: hidden;
    min-width: 0;
    height: 56px;
    border-radius: 0.95rem;
    background: rgba(108, 29, 36, 0.12);
    box-shadow: inset 0 0 0 1px rgba(108, 29, 36, 0.08);
}

.internal-live-focus-progress-fill {
    position: absolute;
    inset: 0 auto 0 0;
    max-width: 100%;
    border-radius: inherit;
    background:
        linear-gradient(90deg, rgba(108, 29, 36, 0.9), rgba(151, 61, 68, 0.94));
}

.internal-live-focus-progress-bar-value {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    font-family: "Fraunces", serif;
    font-size: 1.15rem;
    line-height: 1;
    color: var(--abc-text);
    z-index: 1;
}

.internal-live-progress-counter {
    --progress-value: 0%;
    position: relative;
    display: grid;
    place-items: center;
    width: 72px;
    aspect-ratio: 1;
    border-radius: 999px;
    background:
        conic-gradient(var(--abc-wine) var(--progress-value), rgba(108, 29, 36, 0.14) 0);
    box-shadow: inset 0 0 0 1px rgba(108, 29, 36, 0.08);
    text-align: center;
    isolation: isolate;
}

.internal-live-progress-counter-focus {
    background:
        conic-gradient(var(--abc-wine) var(--progress-value), rgba(108, 29, 36, 0.12) 0);
}

.internal-live-progress-counter::before {
    content: "";
    position: absolute;
    inset: 7px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: inset 0 0 0 1px rgba(108, 29, 36, 0.05);
    z-index: 0;
}

.internal-live-progress-counter-lg {
    width: 82px;
}

.internal-live-progress-counter-sm {
    width: 62px;
}

.internal-live-progress-value,
.internal-live-progress-label {
    position: relative;
    z-index: 1;
}

.internal-live-progress-value {
    display: block;
    font-family: "Fraunces", serif;
    font-size: 1rem;
    line-height: 1;
    color: var(--abc-text);
}

.internal-live-progress-counter-lg .internal-live-progress-value {
    font-size: 1.1rem;
}

.internal-live-progress-counter-sm .internal-live-progress-value {
    font-size: 0.9rem;
}

.internal-live-progress-label {
    display: block;
    margin-top: 0.15rem;
    max-width: 44px;
    font-size: 0.54rem;
    line-height: 1.1;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--abc-muted);
}

.internal-live-progress-counter:not(.internal-live-progress-counter-focus):not(.internal-live-progress-counter-overall) .internal-live-progress-label {
    display: none;
}

.internal-live-focus-title {
    font-family: "Fraunces", serif;
    font-size: clamp(1.45rem, 5vw, 2rem);
    margin-bottom: 0.3rem;
}

.internal-live-metric-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.internal-live-workflow-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.internal-live-group-summary-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
}

.internal-live-workflow-panel {
    padding: 1.15rem;
    border: 1px solid rgba(108, 29, 36, 0.08);
    border-radius: 1.3rem;
    box-shadow: 0 14px 30px rgba(57, 25, 21, 0.07);
}

.internal-live-workflow-panel-male {
    background:
        linear-gradient(180deg, rgba(188, 214, 223, 0.28), rgba(255, 255, 255, 0.9));
}

.internal-live-workflow-panel-female {
    background:
        linear-gradient(180deg, rgba(236, 216, 225, 0.3), rgba(255, 255, 255, 0.9));
}

.internal-live-group-summary-card {
    padding: 1rem;
    border: 1px solid rgba(108, 29, 36, 0.08);
    border-radius: 1.15rem;
    box-shadow: 0 12px 24px rgba(57, 25, 21, 0.05);
}

.internal-live-group-summary-card-ruede {
    background:
        linear-gradient(180deg, rgba(188, 214, 223, 0.25), rgba(255, 255, 255, 0.94));
}

.internal-live-group-summary-card-huendin {
    background:
        linear-gradient(180deg, rgba(236, 216, 225, 0.28), rgba(255, 255, 255, 0.94));
}

.internal-live-group-summary-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.85rem;
}

.internal-live-switcher {
    display: grid;
    gap: 0.9rem;
    background:
        radial-gradient(circle at top right, rgba(108, 29, 36, 0.05), transparent 36%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 240, 235, 0.94));
}

.internal-live-switcher-compact {
    gap: 0.7rem;
    padding-top: 0.95rem;
    padding-bottom: 0.95rem;
}

.internal-live-switcher-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
}

.internal-live-switcher-head,
.internal-live-hub-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.85rem;
}

.internal-live-switcher-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.internal-live-switcher-link {
    display: grid;
    flex: 1 1 220px;
    gap: 0.14rem;
    padding: 0.8rem 0.9rem;
    border-radius: 0.95rem;
    border: 1px solid rgba(108, 29, 36, 0.12);
    background: rgba(255, 255, 255, 0.96);
    color: inherit;
    text-decoration: none;
    box-shadow: 0 8px 18px rgba(57, 25, 21, 0.04);
}

.internal-live-switcher-link span {
    color: var(--abc-muted);
    font-size: 0.82rem;
}

.internal-live-shell .btn,
.internal-live-shell .workflow-status-badge,
.internal-live-shell .status-badge {
    max-width: 100%;
}

.internal-live-shell h2,
.internal-live-shell h3,
.internal-live-shell h4,
.internal-live-shell strong,
.internal-live-shell p,
.internal-live-shell span,
.internal-live-shell a {
    overflow-wrap: anywhere;
}

.internal-live-switcher-link:hover {
    color: inherit;
    border-color: rgba(108, 29, 36, 0.24);
}

.internal-live-switcher-link.is-current {
    border-color: rgba(108, 29, 36, 0.26);
    background: linear-gradient(180deg, rgba(108, 29, 36, 0.07), rgba(255, 255, 255, 0.98));
}

.internal-live-metric-card {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    min-height: 110px;
    padding: 1rem;
    border-radius: 1.1rem;
    border: 1px solid rgba(108, 29, 36, 0.08);
    background: rgba(255, 255, 255, 0.96);
    color: inherit;
    text-decoration: none;
    box-shadow: 0 12px 24px rgba(57, 25, 21, 0.05);
}

.internal-live-metric-card:hover {
    color: inherit;
    border-color: rgba(108, 29, 36, 0.2);
}

.internal-live-metric-label {
    font-size: 0.78rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--abc-muted);
    font-weight: 700;
}

.internal-live-metric-value {
    font-family: "Fraunces", serif;
    font-size: 1.9rem;
    color: var(--abc-text);
}

.internal-live-class-grid,
.internal-live-dog-grid,
.internal-live-report-list,
.internal-live-activity-list,
.internal-live-section-stack,
.internal-live-hub-grid {
    display: grid;
    gap: 0.9rem;
}

.internal-live-hub-grid {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.internal-live-class-card,
.internal-live-dog-card,
.internal-live-report-card,
.internal-live-activity-item,
.internal-live-hub-card {
    border: 1px solid var(--abc-line);
    border-radius: 1.05rem;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 10px 22px rgba(57, 25, 21, 0.05);
}

.internal-live-class-card,
.internal-live-dog-card,
.internal-live-report-card,
.internal-live-hub-card {
    padding: 1rem;
}

.internal-live-activity-item {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    align-items: flex-start;
    padding: 0.9rem 1rem;
    color: inherit;
    text-decoration: none;
}

.internal-live-activity-item:hover {
    color: inherit;
    border-color: rgba(108, 29, 36, 0.2);
}

.internal-live-class-card.is-current {
    border-color: rgba(108, 29, 36, 0.26);
    background: linear-gradient(180deg, rgba(108, 29, 36, 0.06), rgba(255, 255, 255, 0.96));
}

.internal-live-hub-card.is-current {
    border-color: rgba(108, 29, 36, 0.28);
    background:
        radial-gradient(circle at top right, rgba(108, 29, 36, 0.08), transparent 40%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(247, 241, 237, 0.96));
}

.internal-live-hub-focus,
.internal-live-hub-activity {
    padding: 0.8rem 0.9rem;
    border-radius: 0.95rem;
    background: rgba(248, 243, 238, 0.78);
    margin-top: 0.85rem;
}

.internal-live-hub-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.6rem;
    margin-top: 0.85rem;
}

.internal-live-hub-metric {
    display: grid;
    gap: 0.18rem;
    padding: 0.7rem 0.8rem;
    border-radius: 0.9rem;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(108, 29, 36, 0.07);
}

.internal-live-hub-metric span {
    color: var(--abc-muted);
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.internal-live-hub-metric strong {
    font-family: "Fraunces", serif;
    font-size: 1.2rem;
}

.internal-live-class-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin: 0.8rem 0;
    color: var(--abc-muted);
    font-size: 0.9rem;
}

.internal-live-inline-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.public-live-class-dog-result-panel {
    display: grid;
    gap: 0.7rem;
    margin: 0.8rem 0 0.2rem;
    padding: 0.85rem;
    border: 1px solid rgba(108, 29, 36, 0.1);
    border-radius: 0.5rem;
    background:
        linear-gradient(180deg, rgba(251, 248, 245, 0.96), rgba(247, 241, 236, 0.92));
}

.public-live-class-dog-result-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.public-live-class-dog-result-badge {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0.35rem 0.68rem;
    border-radius: 999px;
    font-size: 0.82rem;
    font-weight: 700;
    line-height: 1;
}

.public-live-class-dog-result-badge.is-rank {
    background: rgba(108, 29, 36, 0.12);
    color: var(--abc-wine-dark);
}

.public-live-class-dog-honor-row {
    display: grid;
    gap: 0.4rem;
}

.public-live-class-dog-honor-label {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--abc-muted);
}

.public-live-class-dog-honor-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.public-live-class-dog-honor-chip {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    max-width: 100%;
    padding: 0.38rem 0.62rem;
    border-radius: 0.5rem;
    font-size: 0.84rem;
    font-weight: 700;
    line-height: 1.2;
    overflow-wrap: anywhere;
}

.public-live-class-dog-honor-chip.is-title {
    background: rgba(108, 29, 36, 0.1);
    color: var(--abc-wine-dark);
}

.public-live-class-dog-honor-chip.is-award {
    background: rgba(187, 148, 87, 0.14);
    color: #7f5722;
}

.internal-live-dog-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.7rem;
    margin: 0.85rem 0 1rem;
}

.internal-live-dog-meta div {
    min-width: 0;
}

.internal-live-dog-meta dt {
    font-size: 0.72rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--abc-muted);
    margin-bottom: 0.18rem;
}

.internal-live-dog-meta dd {
    margin: 0;
    font-weight: 600;
}

.internal-live-heart-pair {
    display: inline-flex;
    align-items: center;
    gap: 0.1rem;
    margin-right: 0.45rem;
    color: var(--abc-wine);
    font-size: 1rem;
    line-height: 1;
    vertical-align: middle;
}

.internal-live-heart-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.internal-live-heart-icon-empty {
    opacity: 0.38;
}

.internal-live-heart-label {
    display: inline-flex;
    align-items: center;
    color: var(--abc-muted);
    font-size: 0.84rem;
    font-weight: 600;
    vertical-align: middle;
}

.internal-live-detail-grid {
    display: grid;
    gap: 1rem;
}

.internal-live-report-preview {
    display: grid;
    gap: 0.85rem;
}

.internal-live-report-text {
    font-size: 0.98rem;
    line-height: 1.7;
    color: var(--abc-text);
}

.internal-live-filter-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
    align-items: end;
}

.internal-live-filter-actions {
    display: flex;
    justify-content: flex-start;
    align-items: end;
}

.class-open-award-candidate {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    align-items: center;
    border: 1px solid rgba(163, 146, 136, 0.22);
    border-radius: 0.8rem;
    background: rgba(255, 255, 255, 0.85);
    padding: 0.6rem 0.7rem;
}

.class-open-award-candidate-main {
    min-width: 0;
}

.class-open-award-candidate-actions {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    flex-wrap: wrap;
}

.class-open-award-assign-form {
    display: inline-flex;
}

.class-open-award-feedback {
    min-height: 1.1em;
    margin-top: 0.5rem;
}

.class-open-award-candidate-main strong,
.class-open-award-candidate-main .small {
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.public-live-shell {
    gap: 1.25rem;
}

.public-live-page-head {
    margin-bottom: 0.25rem;
}

.public-live-class-groups {
    display: grid;
    gap: 0.85rem;
}

.public-live-metric-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.public-live-metric-card {
    display: grid;
    gap: 0.45rem;
    min-height: 8.6rem;
    padding: 0.9rem;
    border: 1px solid rgba(108, 29, 36, 0.08);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 10px 22px rgba(57, 25, 21, 0.05);
}

.public-live-metric-card-primary {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(249, 244, 239, 0.96));
}

.public-live-metric-card-success {
    background:
        linear-gradient(180deg, rgba(246, 250, 247, 0.96), rgba(239, 247, 242, 0.96));
}

.public-live-metric-card-neutral {
    background:
        linear-gradient(180deg, rgba(246, 249, 251, 0.96), rgba(239, 245, 248, 0.96));
}

.public-live-metric-card-highlight {
    background:
        linear-gradient(180deg, rgba(251, 247, 241, 0.96), rgba(248, 241, 231, 0.96));
}

.public-live-metric-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.6rem;
}

.public-live-inline-icon-lg {
    width: 1.1rem;
    height: 1.1rem;
    flex-basis: 1.1rem;
}

.public-live-metric-value {
    display: block;
    font-family: "Fraunces", Georgia, serif;
    font-size: clamp(2rem, 7vw, 3rem);
    line-height: 0.9;
    color: var(--abc-text);
}

.public-live-metric-subtitle {
    margin-top: auto;
    color: var(--abc-muted);
    font-size: 0.8rem;
    line-height: 1.35;
}

.public-live-class-group {
    border: 1px solid rgba(108, 29, 36, 0.08);
    border-radius: 0.5rem;
    background: rgba(255, 255, 255, 0.95);
    box-shadow: 0 10px 22px rgba(57, 25, 21, 0.05);
    padding: 0.85rem;
}

.public-live-class-group-male {
    background:
        linear-gradient(180deg, rgba(188, 214, 223, 0.2), rgba(255, 255, 255, 0.96));
}

.public-live-class-group-female {
    background:
        linear-gradient(180deg, rgba(236, 216, 225, 0.22), rgba(255, 255, 255, 0.96));
}

.public-live-class-group-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.75rem;
}

.public-live-class-group-side {
    display: flex;
    align-items: flex-start;
    justify-content: flex-end;
}

.public-live-class-group .panel-subtitle {
    display: none;
}

.public-live-class-accordion {
    display: grid;
    gap: 0.55rem;
    margin-top: 0.75rem;
}

.public-live-class-item {
    border: 1px solid rgba(108, 29, 36, 0.12);
    border-radius: 0.5rem;
    background: rgba(255, 255, 255, 0.96);
    overflow: hidden;
}

.public-live-class-item.is-current {
    border-color: rgba(108, 29, 36, 0.24);
}

.public-live-class-item.is-current {
    background: linear-gradient(180deg, rgba(108, 29, 36, 0.05), rgba(255, 255, 255, 0.97));
}

.public-live-class-summary {
    list-style: none;
    display: flex;
    gap: 0.7rem;
    align-items: flex-start;
    padding: 0.8rem;
    cursor: default;
}

.public-live-class-summary::-webkit-details-marker {
    display: none;
}

.public-live-class-summary::marker {
    content: "";
    display: none;
}

.public-live-class-summary::after {
    content: none;
}

.public-live-class-summary-main {
    display: grid;
    gap: 0.55rem;
    flex: 1 1 auto;
    min-width: 0;
}

.public-live-class-summary-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.6rem;
}

.public-live-class-summary-side {
    display: flex;
    align-items: flex-start;
    justify-content: flex-end;
    flex: 0 0 auto;
}

.public-live-class-summary .workflow-status-badge {
    flex: 0 0 auto;
}

.public-live-class-stats,
.public-live-preview-strip,
.public-live-preview-tags,
.public-live-class-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.public-live-stat-pill,
.public-live-preview-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    min-width: 0;
    padding: 0.34rem 0.52rem;
    border-radius: 0.5rem;
    background: rgba(248, 243, 238, 0.9);
    color: var(--abc-muted);
    font-size: 0.82rem;
    line-height: 1.2;
}

.public-live-preview-chip {
    max-width: 100%;
    color: var(--abc-text);
    align-items: flex-start;
}

.public-live-preview-chip.is-next,
.public-live-preview-item.is-next {
    background: rgba(108, 29, 36, 0.08);
}

.public-live-preview-chip-copy {
    display: grid;
    gap: 0.12rem;
    min-width: 0;
    flex: 1 1 auto;
}

.public-live-preview-chip-title,
.public-live-preview-chip-meta {
    display: block;
    min-width: 0;
    overflow-wrap: anywhere;
}

.public-live-preview-chip-title {
    font-weight: 700;
    line-height: 1.28;
}

.public-live-preview-chip-meta {
    color: var(--abc-muted);
    font-size: 0.76rem;
    line-height: 1.3;
}

.public-live-inline-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 0.95rem;
    height: 0.95rem;
    flex: 0 0 0.95rem;
    color: var(--abc-wine);
}

.public-live-inline-icon-muted {
    color: rgba(111, 99, 93, 0.78);
    font-weight: 700;
    font-size: 0.95rem;
}

.public-live-inline-icon svg {
    width: 100%;
    height: 100%;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.public-live-class-body {
    display: grid;
    gap: 0.7rem;
    padding: 0 0.8rem 0.8rem;
    border-top: 1px solid rgba(108, 29, 36, 0.08);
}

.public-live-class-timing {
    padding-top: 0.1rem;
}

.public-live-preview-list {
    display: grid;
    gap: 0.5rem;
}

.public-live-preview-item {
    display: grid;
    gap: 0.35rem;
    padding: 0.7rem;
    border: 1px solid rgba(108, 29, 36, 0.08);
    border-radius: 0.5rem;
    background: rgba(255, 255, 255, 0.92);
}

.public-live-preview-item-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.6rem;
}

.public-live-preview-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    color: var(--abc-muted);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.public-live-preview-copy {
    color: var(--abc-muted);
    font-size: 0.9rem;
    line-height: 1.35;
}

.public-live-award-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 0.95rem;
}

.public-live-award-card {
    border: 1px solid rgba(122, 34, 43, 0.12);
    border-radius: 1.1rem;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 18px 40px rgba(122, 34, 43, 0.08);
    padding: 1rem 1.05rem;
    display: grid;
    gap: 0.8rem;
    min-width: 0;
}

.public-live-award-head {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    align-items: flex-start;
}

.public-live-winner-list {
    display: grid;
    gap: 0.55rem;
}

.public-live-winner-item {
    border-radius: 0.8rem;
    background: rgba(247, 242, 240, 0.86);
    padding: 0.7rem 0.78rem;
    display: grid;
    gap: 0.2rem;
}

.public-live-winner-item strong,
.public-live-winner-item span {
    min-width: 0;
    overflow-wrap: anywhere;
}

.public-live-winner-item span {
    color: var(--abc-muted);
    font-size: 0.9rem;
}

.public-live-award-inline {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-top: 0.8rem;
}

.public-live-class-actions-inline {
    padding: 0 0.8rem 0.8rem;
}

.public-live-class-canvas {
    --bs-offcanvas-width: min(100vw, 42rem);
    border-left: 1px solid rgba(108, 29, 36, 0.12);
    background:
        linear-gradient(180deg, rgba(251, 248, 245, 0.98), rgba(243, 236, 230, 0.98));
    z-index: 1310;
}

.public-live-class-canvas-head {
    align-items: flex-start;
    gap: 0.75rem;
    padding: 1rem;
    border-bottom: 1px solid rgba(108, 29, 36, 0.08);
    background: rgba(251, 248, 245, 0.92);
    backdrop-filter: blur(14px);
    position: sticky;
    top: 0;
    z-index: 2;
}

.public-live-class-canvas-titlewrap {
    min-width: 0;
}

.public-live-class-canvas-titlewrap .offcanvas-title {
    overflow-wrap: anywhere;
}

.public-live-class-canvas-body {
    display: grid;
    gap: 1rem;
    padding: 1rem;
    padding-bottom: calc(1rem + env(safe-area-inset-bottom, 0px));
    overscroll-behavior: contain;
}

.public-live-class-canvas-loading {
    display: grid;
    place-items: center;
    min-height: min(60dvh, 32rem);
}

.public-live-class-canvas-loading-card {
    width: min(100%, 34rem);
}

.public-live-class-canvas-loading-card .busy-overlay-media {
    width: 6rem;
    height: 6rem;
}

.public-live-class-canvas-loading-card .busy-overlay-core {
    width: 4.35rem;
    height: 4.35rem;
}

.public-live-class-canvas-loading-card .busy-overlay-logo {
    width: 2.8rem;
}

.public-live-class-canvas-content {
    display: grid;
    gap: 1rem;
}

.public-live-class-canvas-meta-card {
    display: grid;
    gap: 0.8rem;
    padding: 0.9rem;
    border: 1px solid rgba(108, 29, 36, 0.1);
    border-radius: 0.5rem;
    background: rgba(255, 255, 255, 0.88);
    box-shadow: 0 10px 22px rgba(57, 25, 21, 0.05);
}

.public-live-class-canvas-meta-copy {
    display: grid;
    gap: 0.25rem;
}

.public-live-class-canvas-meta-actions,
.public-live-class-canvas-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.public-live-class-canvas-filters {
    position: sticky;
    top: 0;
    z-index: 2;
    padding: 0.2rem;
    border: 1px solid rgba(108, 29, 36, 0.08);
    border-radius: 8px;
    background: rgba(251, 248, 245, 0.94);
    backdrop-filter: blur(12px);
}

.public-shell .offcanvas-backdrop.show {
    z-index: 1300;
    background: rgba(34, 17, 17, 0.48);
    backdrop-filter: blur(4px);
}

.public-shell.is-public-class-canvas-open .public-shell-topbar {
    opacity: 0;
    transform: translateY(-110%);
    pointer-events: none;
}

.config-category-block + .config-category-block {
    margin-top: 1.25rem;
}

.config-category-head {
    margin-bottom: 0.85rem;
}

.config-category-title {
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
}

.class-award-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1rem;
}

.class-award-grid > [data-award-group-card] {
    min-width: 0;
}

.class-award-grid > .config-award-group-shell-pair,
.class-award-grid > .config-award-group-shell-bundle {
    grid-column: 1 / -1;
}

.class-award-card {
    padding: 1rem;
    border: 1px solid var(--abc-line);
    border-radius: 1rem;
    background: rgba(248, 243, 238, 0.72);
}

.config-award-card.is-selected {
    border-color: rgba(108, 29, 36, 0.28);
    background: rgba(108, 29, 36, 0.05);
}

.config-award-pair-shell {
    padding: 1rem;
    height: 100%;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(244, 236, 229, 0.92));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

.config-award-pair-head {
    margin-bottom: 0.9rem;
}

.config-award-pair-head-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.85rem;
    margin-bottom: 0.35rem;
}

.config-award-pair-master-toggle {
    display: flex;
    align-items: flex-start;
    gap: 0.7rem;
    padding: 0.75rem 0.85rem;
    border: 1px solid rgba(108, 29, 36, 0.12);
    border-radius: 0.8rem;
    background: rgba(255, 255, 255, 0.66);
}

.config-award-pair-master-toggle .form-check-input {
    margin-top: 0.15rem;
}

.config-award-pair-master-toggle .form-check-label {
    margin: 0;
}

.config-award-pair-master-toggle small {
    line-height: 1.35;
}

.config-award-pair-master-stage {
    display: grid;
    gap: 0.2rem;
}

.config-award-pair-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 0.9rem;
}

.config-award-pair-card {
    display: grid;
    gap: 0.8rem;
    align-content: start;
    padding: 1rem 1rem 1.05rem;
    background: rgba(255, 255, 255, 0.82);
}

.config-award-sex-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
}

.config-award-pair-toggle {
    align-items: flex-start;
}

.config-award-pair-toggle-body {
    display: grid;
    gap: 0.18rem;
}

.config-award-pair-toggle-body strong {
    font-size: 1rem;
}

.config-award-pair-toggle-body small {
    line-height: 1.35;
}

.class-award-card.is-disabled {
    opacity: 0.68;
    background: rgba(111, 99, 93, 0.06);
}

.workflow-warning-box {
    padding: 1rem;
    border: 1px solid rgba(184, 124, 18, 0.24);
    border-radius: 1rem;
    background: rgba(184, 124, 18, 0.08);
}

.evaluation-actions form,
.table-action-stack form {
    margin: 0;
}

.evaluation-nav-links {
    margin-top: 1rem;
}

.candidate-card-body {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    flex: 1;
}

.special-dog-checklist {
    display: grid;
    gap: 0.75rem;
    max-height: 24rem;
    overflow: auto;
    padding-right: 0.25rem;
}

.special-competition-sidecard {
    background: rgba(248, 243, 238, 0.48);
    border-style: dashed;
}

.pair-builder-grid {
    display: grid;
    gap: 1rem;
}

.pair-builder-column {
    display: grid;
    gap: 0.75rem;
    min-height: 0;
}

.pair-builder-toolbar {
    display: grid;
    gap: 0.75rem;
}

.pair-builder-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    color: var(--abc-muted);
    font-size: 0.92rem;
}

.pair-builder-summary {
    padding: 1rem;
}

.pair-groups-stage {
    padding: 1rem;
    border: 1px solid var(--abc-line);
    border-radius: 1rem;
    background: rgba(248, 243, 238, 0.58);
}

.group-builder-section {
    display: grid;
    gap: 0.55rem;
}

.pair-partner-sections {
    align-content: start;
}

.pair-partner-section {
    display: grid;
    gap: 0.55rem;
}

.pair-partner-section-label {
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--abc-muted);
}

.pair-partner-card-stack {
    display: grid;
    gap: 0.75rem;
}

.special-dog-card-body {
    display: grid;
    gap: 0.35rem;
    min-width: 0;
    width: 100%;
}

.special-dog-card-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.75rem;
}

.special-dog-card-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    justify-content: flex-end;
    align-items: center;
}

.special-dog-card-badges .sex-icon {
    width: 1.7rem;
    height: 1.7rem;
}

.special-dog-card-badges .sex-icon svg {
    width: 1rem;
    height: 1rem;
}

.special-dog-catalog {
    font-size: 1.45rem;
    font-weight: 700;
    line-height: 1;
    color: var(--abc-ink);
    letter-spacing: 0;
}

.special-dog-name {
    font-size: 0.98rem;
    line-height: 1.2;
    font-weight: 600;
}

.special-dog-card-note {
    margin-top: 0.1rem;
}

.award-selection-card.is-prioritized {
    border-color: rgba(108, 29, 36, 0.28);
    background: rgba(248, 243, 238, 0.92);
}

.award-selection-card.is-deemphasized {
    opacity: 0.72;
    background: rgba(111, 99, 93, 0.06);
}

.award-selection-card.is-deemphasized input {
    opacity: 1;
}

.candidate-card.is-highlighted {
    border-color: rgba(108, 29, 36, 0.38);
    box-shadow: 0 0 0 0.2rem rgba(108, 29, 36, 0.08);
}

.pair-smart-overlay {
    position: fixed;
    right: 1.25rem;
    bottom: 1.25rem;
    width: min(22rem, calc(100vw - 2rem));
    padding: 0.85rem;
    border: 1px solid rgba(108, 29, 36, 0.18);
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 16px 36px rgba(33, 26, 24, 0.14);
    opacity: 0;
    transform: translateY(0.8rem);
    pointer-events: none;
    transition: opacity 180ms ease, transform 180ms ease;
    z-index: 40;
}

.pair-smart-overlay.is-visible {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.pair-smart-overlay-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.pair-smart-overlay-list {
    display: grid;
    gap: 0.45rem;
}

.pair-smart-item {
    display: grid;
    gap: 0.15rem;
    padding: 0.55rem 0.7rem;
    border: 1px solid rgba(231, 221, 213, 0.92);
    border-radius: 0.6rem;
    background: rgba(248, 243, 238, 0.72);
    color: inherit;
    text-decoration: none;
}

.pair-smart-item.is-current {
    border-color: rgba(108, 29, 36, 0.26);
    background: rgba(108, 29, 36, 0.06);
}

.pair-smart-catalogs {
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.15;
}

.pair-smart-meta {
    font-size: 0.84rem;
    color: var(--abc-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.btn-primary {
    --bs-btn-bg: var(--abc-wine);
    --bs-btn-border-color: var(--abc-wine);
    --bs-btn-hover-bg: var(--abc-wine-dark);
    --bs-btn-hover-border-color: var(--abc-wine-dark);
    --bs-btn-active-bg: var(--abc-wine-dark);
    --bs-btn-active-border-color: var(--abc-wine-dark);
}

.form-control,
.form-select {
    border-color: var(--abc-line);
    border-radius: 0.9rem;
    padding: 0.75rem 0.95rem;
}

.table > :not(caption) > * > * {
    padding-top: 0.95rem;
    padding-bottom: 0.95rem;
}

@media (max-width: 1399.98px) {
    .exhibition-editor-shell {
        grid-template-columns: 1fr;
    }

    .exhibition-editor-sidebar {
        position: static;
    }

    .evaluation-layout {
        grid-template-columns: 1fr;
    }

    .evaluation-class-nav-list {
        grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
        max-height: none;
    }

    .config-class-list-head {
        display: none;
    }

    .config-class-card {
        grid-template-columns: minmax(0, 1fr) minmax(220px, 260px);
        align-items: start;
    }

    .config-class-primary,
    .config-class-stats,
    .config-class-preview {
        grid-column: 1;
    }

    .config-class-controls {
        grid-column: 2;
        grid-row: 1 / span 3;
        justify-content: center;
        align-items: stretch;
    }

    .config-class-ring-field,
    .config-class-rank-field {
        width: 100%;
    }
}

@media (min-width: 1200px) {
    .pair-builder-grid {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    }
}

@media (max-width: 991.98px) {
    .special-dog-card-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .special-dog-card-badges {
        justify-content: flex-start;
    }

    .exhibitions-table-wrap {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .exhibition-action-group {
        min-width: max-content;
    }

    .auth-stage,
    .app-grid {
        grid-template-columns: 1fr;
    }

    .auth-brand {
        min-height: 280px;
        padding: 2rem;
    }

    .app-shell {
        background:
            radial-gradient(circle at top left, rgba(187, 148, 87, 0.18), transparent 32%),
            linear-gradient(180deg, #fbf8f5 0%, #f3ece6 100%);
    }

    .sidebar,
    .app-shell.is-sidebar-collapsed .sidebar {
        width: auto;
        gap: 0.85rem;
        padding: 1rem;
        padding-bottom: 1rem;
        min-height: 0;
        height: auto;
        overflow: visible;
        position: sticky;
        top: 0;
        align-self: stretch;
        z-index: 1030;
        border-radius: 0 0 1.4rem 1.4rem;
        border-top: 0;
        box-shadow: 0 16px 30px rgba(57, 25, 21, 0.14);
    }

    .sidebar-top,
    .app-shell.is-sidebar-collapsed .sidebar-top {
        gap: 0;
    }

    .sidebar-panel {
        gap: 1rem;
        overflow: hidden;
        max-height: 75vh;
        opacity: 1;
        transition:
            max-height var(--sidebar-transition),
            opacity var(--sidebar-transition),
            margin-top var(--sidebar-transition);
    }

    .app-shell.is-sidebar-collapsed .sidebar-panel {
        max-height: 0;
        opacity: 0;
        margin-top: 0;
        pointer-events: none;
    }

    .sidebar-brand,
    .app-shell.is-sidebar-collapsed .sidebar-brand {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }

    .sidebar-brand-media,
    .app-shell.is-sidebar-collapsed .sidebar-brand-media {
        width: 3.5rem;
    }

    .sidebar-toggle,
    .app-shell.is-sidebar-collapsed .sidebar-toggle {
        margin-top: 0;
    }

    .nav-section {
        padding-top: 0.95rem;
        border-top: 1px solid rgba(255, 255, 255, 0.18);
    }

    .sidebar-meta {
        gap: 0.85rem;
        padding-top: 0.95rem;
        border-top: 1px solid rgba(255, 255, 255, 0.14);
    }

    .app-shell.is-sidebar-collapsed .nav-section-label,
    .app-shell.is-sidebar-collapsed .nav-label,
    .app-shell.is-sidebar-collapsed .sidebar-user-details,
    .app-shell.is-sidebar-collapsed .sidebar-logout-label {
        opacity: 1;
        max-width: none;
        max-height: none;
        transform: none;
        pointer-events: auto;
    }

    .app-shell.is-sidebar-collapsed .sidebar-toggle svg,
    .sidebar-toggle svg {
        transform: rotate(-90deg);
    }

    .app-shell:not(.is-sidebar-collapsed) .sidebar-toggle svg {
        transform: rotate(90deg);
    }

    .app-shell.is-sidebar-collapsed .app-nav-link,
    .app-shell.is-sidebar-collapsed .sidebar-user-card,
    .app-shell.is-sidebar-collapsed .sidebar-logout-button {
        justify-content: flex-start;
        gap: 0.85rem;
    }

    .topbar {
        gap: 0.75rem;
        padding: 1rem 1rem 1.15rem;
        background: transparent;
        backdrop-filter: none;
    }

    .topbar,
    .panel-head,
    .dashboard-list-item,
    .feature-card-header,
    .award-config-row,
    .exhibition-editor-compact-head,
    .exhibition-editor-section-head,
    .exhibition-award-category-head,
    .exhibition-award-toolbar,
    .workflow-page-header,
    .class-card-head,
    .candidate-card-body {
        flex-direction: column;
        align-items: flex-start;
    }

    .topbar-actions {
        width: 100%;
        justify-content: space-between;
    }

    .topbar-copy {
        max-width: none;
    }

    .content-area {
        padding: 1rem;
    }

    .meta-list {
        grid-template-columns: 1fr;
    }

    .award-config-row {
        display: flex;
    }

    .exhibition-award-guide,
    .exhibition-award-grid,
    .exhibition-editor-side-grid {
        grid-template-columns: 1fr;
    }

    .exhibition-editor-main-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .award-config-pair-grid,
    .config-award-pair-grid {
        grid-template-columns: 1fr;
    }

    .config-offcanvas-footer {
        flex-direction: column;
        align-items: flex-start;
    }

    .dog-meta-grid,
    .evaluation-rating-grid,
    .evaluation-meta-strip,
    .evaluation-class-nav-list {
        grid-template-columns: 1fr;
    }

    .class-card-kpi-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .class-open-award-head,
    .class-open-award-candidate {
        flex-direction: column;
        align-items: flex-start;
    }

    .class-open-award-candidate-actions {
        width: 100%;
    }

    .evaluation-action-bar-head,
    .evaluation-action-bar-foot {
        flex-direction: column;
        align-items: flex-start;
    }

    .heart-rating-selector {
        grid-template-columns: 1fr;
    }

    .class-rating-quick-fields {
        grid-template-columns: 1fr;
    }

    .cockpit-top-grid,
    .cockpit-workflow-grid,
    .cockpit-summary-strip {
        grid-template-columns: 1fr;
    }

    .cockpit-hero-panel,
    .cockpit-quick-panel {
        grid-column: auto;
    }

    .cockpit-quick-panel-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .config-compact-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .config-inline-hints {
        justify-content: flex-start;
    }

    .config-class-list-head {
        display: none;
    }

    .config-class-card {
        grid-template-columns: 1fr;
        gap: 0.8rem;
    }

    .config-class-controls {
        grid-column: auto;
        grid-row: auto;
        align-items: stretch;
        justify-content: flex-start;
    }

    .class-config-enable-switch {
        justify-self: start;
    }

    .config-class-card-title,
    .config-class-card-heading,
    .config-class-ring-field,
    .config-class-rank-field {
        width: 100%;
    }

    .config-class-stats,
    .config-class-inline-meta {
        gap: 0.45rem;
    }

    .config-class-settings-grid {
        grid-template-columns: 1fr;
    }

    .class-overview-grid,
    .final-award-preview-grid,
    .cockpit-special-grid {
        grid-template-columns: 1fr;
    }

    .cockpit-quick-panel:not(.is-expanded) .cockpit-quick-actions-grid {
        grid-template-columns: repeat(auto-fit, minmax(3.6rem, 1fr));
    }

    .cockpit-quick-actions-stack {
        flex-wrap: wrap;
        overflow: visible;
    }

    .cockpit-quick-group {
        flex-basis: 100%;
    }

    .cockpit-quick-panel.is-expanded .cockpit-quick-actions-grid {
        grid-template-columns: 1fr;
    }

    .internal-live-page-head,
    .internal-live-focus-head,
    .internal-live-dog-head,
    .internal-live-report-head,
    .internal-live-activity-item {
        flex-direction: column;
        align-items: flex-start;
    }

    .internal-live-metric-grid,
    .internal-live-group-summary-grid,
    .internal-live-workflow-grid,
    .internal-live-filter-grid,
    .internal-live-dog-meta {
        grid-template-columns: 1fr;
    }

    .internal-live-focus-side,
    .internal-live-panel-side,
    .internal-live-class-side,
    .internal-live-progress-stack,
    .internal-live-focus-progresses {
        justify-content: flex-start;
    }

    .internal-live-focus-progresses {
        grid-template-columns: 1fr;
    }

    .internal-live-focus-progress-item {
        justify-items: start;
    }

    .internal-live-focus-progress-caption {
        text-align: left;
    }

    .internal-live-focus-progress-meta {
        text-align: left;
    }

    .internal-live-focus-progress-panel {
        min-width: 100%;
    }

    .internal-live-focus-layout {
        grid-template-columns: 1fr;
    }

    .internal-live-switcher-toolbar {
        align-items: flex-start;
    }

    .internal-live-page-head,
    .internal-live-focus-card,
    .internal-live-section,
    .internal-live-filter-form,
    .internal-live-switcher,
    .internal-live-workflow-panel,
    .internal-live-group-summary-card,
    .internal-live-class-card,
    .internal-live-dog-card,
    .internal-live-report-card,
    .internal-live-hub-card,
    .internal-live-metric-card {
        padding-left: 0.95rem;
        padding-right: 0.95rem;
    }

    .internal-live-shell .btn {
        white-space: normal;
    }

    .public-live-award-grid {
        grid-template-columns: 1fr;
    }

    .public-live-award-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .public-live-class-summary,
    .public-live-preview-item-head,
    .public-live-class-group-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .public-live-class-summary {
        position: relative;
    }

    .public-live-class-summary-side {
        display: none;
    }

    .public-live-class-actions .btn {
        width: 100%;
        justify-content: center;
    }

    .public-live-class-canvas {
        --bs-offcanvas-width: 100vw;
        inset: 0;
        height: 100dvh;
        border-left: 0;
        border-radius: 0;
    }

    .offcanvas-end.public-live-class-canvas {
        transform: translateY(100%);
    }

    .public-live-class-canvas-head,
    .public-live-class-canvas-body {
        padding-left: 0.85rem;
        padding-right: 0.85rem;
    }

    .public-live-class-canvas-head {
        padding-top: calc(0.75rem + env(safe-area-inset-top, 0px));
    }

    .public-live-class-canvas-body {
        gap: 0.85rem;
    }

    .public-live-class-canvas-loading {
        min-height: min(54dvh, 26rem);
    }

    .public-live-class-canvas-loading-card {
        width: 100%;
        padding: 1.2rem 1rem;
    }

    .public-live-class-canvas-filters {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        top: -0.1rem;
    }

    .public-live-class-canvas-filters .btn,
    .public-live-class-canvas-meta-actions .btn {
        width: 100%;
        justify-content: center;
    }

    .public-live-class-canvas-meta-card {
        gap: 0.7rem;
        padding: 0.85rem;
    }

    .catalog-show-card-top,
    .catalog-show-card-footer,
    .catalog-selected-show-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .catalog-selected-show-actions {
        width: 100%;
        justify-content: flex-start;
    }

    .evaluation-main-column .workflow-textarea {
        min-height: 22rem;
    }
}

@media (min-width: 768px) {
    .public-live-class-group .panel-subtitle {
        display: block;
    }
}

@media (min-width: 992px) {
    .public-live-class-groups {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .sidebar,
    .app-shell.is-sidebar-collapsed .sidebar {
        padding: 0.85rem;
        border-radius: 0 0 1.15rem 1.15rem;
    }

    .sidebar-brand-media,
    .app-shell.is-sidebar-collapsed .sidebar-brand-media {
        width: 3rem;
    }

    .topbar {
        padding: 0.9rem 0.85rem 1rem;
    }

    .topbar-title {
        font-size: 1.4rem;
    }

    .topbar-copy {
        font-size: 0.92rem;
    }

    .content-area {
        padding: 0.85rem;
    }

    .catalog-show-grid {
        grid-template-columns: 1fr;
    }
}

.public-shell {
    min-height: 100vh;
    margin: 0;
    background:
        radial-gradient(circle at top left, rgba(187, 148, 87, 0.18), transparent 24%),
        radial-gradient(circle at bottom right, rgba(108, 29, 36, 0.16), transparent 24%),
        linear-gradient(180deg, #f3ebe4 0%, #fbf8f5 100%);
    scroll-padding-top: 5.5rem;
}

.public-shell-topbar {
    position: fixed;
    inset: 0 0 auto 0;
    z-index: 1200;
    padding: 0.6rem 0.85rem 0;
    opacity: 0;
    transform: translateY(-110%);
    pointer-events: none;
    transition:
        opacity 220ms ease,
        transform 220ms ease;
}

.public-shell.is-public-shell-scrolled .public-shell-topbar {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.public-shell-topbar-inner {
    width: min(1180px, calc(100% - 0.5rem));
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.65rem 0.8rem;
    border: 1px solid rgba(108, 29, 36, 0.12);
    border-radius: 8px;
    background: rgba(255, 250, 247, 0.92);
    backdrop-filter: blur(14px);
    box-shadow: 0 18px 36px rgba(57, 25, 21, 0.12);
}

.public-shell-topbar-brand {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    min-width: 0;
    color: inherit;
    text-decoration: none;
}

.public-shell-topbar-logo {
    width: 2.5rem;
    height: 2.5rem;
    object-fit: contain;
    flex: 0 0 2.5rem;
}

.public-shell-topbar-copy {
    display: grid;
    gap: 0.1rem;
    min-width: 0;
}

.public-shell-topbar-copy .eyebrow {
    color: var(--abc-muted);
}

.public-shell-topbar-copy strong {
    display: block;
    font-family: "Fraunces", Georgia, serif;
    font-size: 1rem;
    line-height: 1;
    color: var(--abc-text);
}

.public-shell-topbar-nav {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.public-shell-menu {
    display: none;
    position: relative;
}

.public-shell-menu-toggle {
    list-style: none;
    display: grid;
    gap: 0.22rem;
    padding: 0.62rem;
    border: 1px solid rgba(108, 29, 36, 0.14);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.96);
    cursor: pointer;
}

.public-shell-menu-toggle::-webkit-details-marker {
    display: none;
}

.public-shell-menu-toggle::marker {
    content: "";
    display: none;
}

.public-shell-menu-toggle span {
    display: block;
    width: 1.05rem;
    height: 1.5px;
    border-radius: 999px;
    background: var(--abc-wine);
}

.public-shell-menu-panel {
    position: absolute;
    top: calc(100% + 0.5rem);
    right: 0;
    min-width: 15rem;
    display: grid;
    gap: 0.25rem;
    padding: 0.45rem;
    border: 1px solid rgba(108, 29, 36, 0.12);
    border-radius: 8px;
    background: rgba(255, 251, 248, 0.98);
    box-shadow: 0 18px 40px rgba(57, 25, 21, 0.14);
}

.public-shell-menu-link {
    display: block;
    padding: 0.7rem 0.75rem;
    border-radius: 8px;
    color: var(--abc-text);
    text-decoration: none;
    font-weight: 600;
}

.public-shell-menu-link:hover {
    background: rgba(108, 29, 36, 0.06);
    color: var(--abc-wine-dark);
}

.public-stage {
    width: min(1180px, calc(100% - 2rem));
    margin: 0 auto;
    padding: 1.25rem 0 3rem;
}

.public-hero,
.public-card,
.public-exhibition-card,
.public-empty-state {
    border: 1px solid rgba(231, 221, 213, 0.9);
    box-shadow: var(--abc-shadow);
}

.public-hero {
    position: relative;
    display: grid;
    gap: 1.25rem;
    overflow: hidden;
    padding: 1rem 1rem 4rem;
    border-radius: 8px;
    background:
        linear-gradient(160deg, rgba(57, 12, 17, 0.97), rgba(108, 29, 36, 0.94) 52%, rgba(129, 63, 39, 0.88) 100%);
    color: #fff8f3;
}

.public-hero-backdrop {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 18% 18%, rgba(187, 148, 87, 0.28), transparent 28%),
        radial-gradient(circle at 82% 22%, rgba(255, 255, 255, 0.12), transparent 24%),
        radial-gradient(circle at 70% 82%, rgba(187, 148, 87, 0.22), transparent 26%),
        linear-gradient(120deg, rgba(255, 255, 255, 0.04), transparent 48%);
    opacity: 0.95;
    pointer-events: none;
}

.public-hero > * {
    position: relative;
    z-index: 1;
}

.public-hero h1 {
    margin: 0;
    font-size: clamp(2.35rem, 8vw, 4.4rem);
    line-height: 0.92;
    max-width: 11ch;
}

.public-hero p {
    max-width: 34rem;
    margin: 0;
    font-size: 1rem;
    line-height: 1.5;
    color: rgba(255, 248, 243, 0.84);
}

.public-hero-brand,
.public-hero-actions,
.public-section-header,
.public-form-actions,
.public-exhibition-card-top,
.public-exhibition-card-actions {
    display: flex;
    align-items: center;
    gap: 0.9rem;
}

.public-hero-brand {
    justify-content: space-between;
    align-items: flex-start;
}

.public-hero-brand-lockup {
    display: inline-flex;
    align-items: center;
    gap: 0.8rem;
    min-width: 0;
}

.public-hero-brand-copy {
    display: grid;
    gap: 0.12rem;
}

.public-hero-brand-copy strong {
    font-family: "Fraunces", Georgia, serif;
    font-size: 1.12rem;
    line-height: 1;
}

.public-hero-crest-row {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.public-hero-crest {
    width: 2.1rem;
    height: 2.1rem;
    padding: 0.28rem;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.14);
    object-fit: contain;
}

.public-hero-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(280px, 0.85fr);
    gap: 1.2rem;
    align-items: end;
}

.public-hero-copy {
    display: grid;
    gap: 1rem;
    align-content: start;
}

.public-hero-logo {
    width: min(68px, 18vw);
    height: auto;
}

.public-hero-actions {
    flex-wrap: wrap;
    gap: 0.6rem;
}

.public-hero-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
}

.public-hero-metric {
    display: grid;
    gap: 0.18rem;
    padding: 0.8rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(8px);
}

.public-hero-metric span {
    font-size: 0.72rem;
    line-height: 1.1;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: rgba(255, 248, 243, 0.72);
}

.public-hero-metric strong {
    font-family: "Fraunces", Georgia, serif;
    font-size: 1rem;
    line-height: 1.05;
    color: #fff8f3;
}

.public-hero-visual {
    position: relative;
    display: grid;
    gap: 0.75rem;
    min-height: 100%;
    align-content: end;
}

.public-hero-showmark,
.public-hero-highlight-card {
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(10px);
}

.public-hero-showmark {
    display: grid;
    place-items: center;
    padding: 1rem;
    min-height: 15rem;
}

.public-hero-showmark-image {
    width: min(100%, 17rem);
    height: auto;
    object-fit: contain;
    filter: drop-shadow(0 18px 36px rgba(18, 4, 6, 0.3));
}

.public-hero-highlight-card {
    display: grid;
    gap: 0.45rem;
    padding: 0.95rem 1rem;
}

.public-hero-highlight-card strong {
    font-family: "Fraunces", Georgia, serif;
    font-size: 1.2rem;
    line-height: 1.02;
}

.public-hero-highlight-card p {
    font-size: 0.93rem;
    color: rgba(255, 248, 243, 0.76);
}

.public-hero-watermark {
    position: absolute;
    right: -1rem;
    bottom: -1.5rem;
    width: min(11rem, 42%);
    opacity: 0.14;
    pointer-events: none;
}

.public-card {
    position: relative;
    z-index: 2;
    margin-top: -2.5rem;
    padding: 1.5rem;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(12px);
}

.public-section-header {
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.public-empty-state {
    padding: 2rem;
    border-radius: 8px;
    background: #fff;
    color: var(--abc-muted);
}

.public-exhibition-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
    gap: 1rem;
}

.public-exhibition-card {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    min-height: 100%;
    padding: 1.35rem;
    border-radius: 8px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(247, 241, 236, 0.96)),
        linear-gradient(135deg, rgba(187, 148, 87, 0.12), transparent 55%);
}

.public-exhibition-card h3 {
    margin: 0;
    font-size: 1.4rem;
}

.public-exhibition-card-top,
.public-exhibition-card-actions {
    justify-content: space-between;
}

.public-exhibition-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
    margin: 0;
}

.public-exhibition-meta dt {
    margin-bottom: 0.2rem;
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--abc-muted);
}

.public-exhibition-meta dd {
    margin: 0;
    font-weight: 600;
    color: var(--abc-text);
}

.public-registration-form {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.public-lookup-status {
    margin-bottom: 1rem;
    padding: 0.9rem 1rem;
    border-radius: 1rem;
    font-weight: 600;
}

.public-lookup-status[data-state="loading"] {
    background: rgba(187, 148, 87, 0.12);
    color: #8b5e22;
}

.public-lookup-status[data-state="success"] {
    background: rgba(71, 124, 84, 0.12);
    color: #2f6d43;
}

.public-lookup-status[data-state="warning"] {
    background: rgba(108, 29, 36, 0.12);
    color: var(--abc-wine-dark);
}

.public-lookup-status[data-state="idle"] {
    background: rgba(111, 99, 93, 0.08);
    color: var(--abc-muted);
}

.public-check-grid {
    display: grid;
    gap: 0.9rem;
}

.public-form-actions {
    justify-content: flex-start;
    flex-wrap: wrap;
}

.public-catalog-lock {
    display: grid;
    gap: 1.5rem;
}

.public-catalog-lock-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(231, 221, 213, 0.9);
}

.public-catalog-lock-copy {
    max-width: 44rem;
    margin: 0;
    font-size: 1.04rem;
    color: var(--abc-muted);
}

.public-catalog-lock-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem 1rem;
    color: var(--abc-muted);
}

.public-catalog-lock-meta strong {
    display: block;
    color: var(--abc-text);
    font-size: 1rem;
}

.public-catalog-lock-meta span {
    display: block;
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.public-catalog-lock-note {
    padding: 1rem 1.1rem;
    border-left: 4px solid rgba(187, 148, 87, 0.88);
    background: rgba(187, 148, 87, 0.12);
    color: #6f4f22;
    font-weight: 600;
}

.public-catalog-lock-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

@media (max-width: 991.98px) {
    .public-stage {
        width: min(100% - 1.25rem, 1180px);
        padding-top: 0.85rem;
    }

    .public-card,
    .public-hero {
        padding: 1.25rem;
    }

    .public-hero-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .bulk-print-panel-head,
    .bulk-print-progress-meta,
    .bulk-print-overlay-head {
        flex-direction: column;
        align-items: stretch;
    }

    .bulk-print-overlay-dialog {
        width: min(100vw - 1rem, 540px);
        padding: 1rem;
    }

    .public-section-header,
    .public-hero-brand,
    .public-exhibition-card-top,
    .public-exhibition-card-actions,
    .public-form-actions,
    .public-catalog-lock-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .public-shell-topbar {
        padding: 0.45rem 0.45rem 0;
    }

    .public-shell-topbar-inner {
        width: calc(100% - 0.1rem);
        padding: 0.55rem 0.6rem;
    }

    .public-shell-topbar-nav {
        display: none;
    }

    .public-shell-menu {
        display: block;
    }

    .public-hero {
        padding: 0.95rem 0.95rem 3.2rem;
    }

    .public-hero h1 {
        max-width: 9ch;
        font-size: clamp(2.1rem, 10vw, 3rem);
    }

    .public-hero-brand-copy strong {
        font-size: 1rem;
    }

    .public-hero-actions {
        display: grid;
        grid-template-columns: 1fr;
        width: 100%;
    }

    .public-hero-actions .btn {
        width: 100%;
    }

    .public-live-metric-card {
        min-height: 7.25rem;
    }

    .public-hero-metrics {
        grid-template-columns: 1fr;
    }

    .public-hero-showmark {
        min-height: 11.5rem;
    }

    .public-card {
        margin-top: -1.8rem;
    }

    .public-exhibition-meta {
        grid-template-columns: 1fr;
    }
}

@media (min-width: 992px) {
    .public-live-metric-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .busy-overlay {
        padding: 1rem;
    }

    .busy-overlay-dialog {
        flex-direction: column;
        align-items: flex-start;
        width: min(100%, 26rem);
        padding: 1.25rem;
    }

    .busy-overlay-media {
        width: 6.2rem;
        height: 6.2rem;
    }

    .busy-overlay-core {
        width: 4.25rem;
        height: 4.25rem;
    }

    .busy-overlay-logo {
        width: 2.7rem;
    }

    .public-shell-topbar-copy .eyebrow {
        display: none;
    }

    .public-shell-topbar-copy strong {
        font-size: 0.92rem;
    }

    .public-shell-topbar-logo {
        width: 2.2rem;
        height: 2.2rem;
        flex-basis: 2.2rem;
    }

    .public-shell-menu-panel {
        position: fixed;
        top: 4.6rem;
        left: 0.6rem;
        right: 0.6rem;
        min-width: 0;
        gap: 0.35rem;
        padding: 0.55rem;
        border-radius: 8px;
        z-index: 1250;
    }

    .public-hero-brand-lockup {
        align-items: flex-start;
    }

    .public-hero-crest-row {
        width: 100%;
    }

    .public-hero-crest {
        width: 1.95rem;
        height: 1.95rem;
    }
}

@keyframes busy-overlay-spin {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

@keyframes busy-overlay-spin-reverse {
    from {
        transform: rotate(360deg);
    }

    to {
        transform: rotate(0deg);
    }
}

@keyframes busy-overlay-pulse {
    0%,
    100% {
        transform: scale(0.98);
        box-shadow:
            0 18px 40px rgba(28, 8, 11, 0.35),
            inset 0 1px 0 rgba(255, 255, 255, 0.24);
    }

    50% {
        transform: scale(1.03);
        box-shadow:
            0 22px 46px rgba(28, 8, 11, 0.42),
            inset 0 1px 0 rgba(255, 255, 255, 0.28);
    }
}

@keyframes busy-overlay-spark {
    0%,
    100% {
        transform: scale(0.7);
        opacity: 0.38;
    }

    50% {
        transform: scale(1.15);
        opacity: 1;
    }
}

@keyframes busy-overlay-dot {
    0%,
    100% {
        transform: translateY(0);
        opacity: 0.35;
    }

    50% {
        transform: translateY(-0.28rem);
        opacity: 1;
    }
}

.cockpit-header-actions {
    align-items: center;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.cockpit-runtime-panel {
    border: 1px solid rgba(108, 29, 36, 0.12);
    background: linear-gradient(180deg, rgba(255, 250, 246, 0.96), rgba(255, 255, 255, 0.98));
}

.cockpit-runtime-head-actions {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.75rem;
}

.cockpit-runtime-controls {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.65rem;
}

.cockpit-runtime-control {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.cockpit-runtime-control-icon {
    display: inline-flex;
    width: 1rem;
    height: 1rem;
    flex: 0 0 1rem;
}

.cockpit-runtime-control-icon svg {
    width: 100%;
    height: 100%;
}

.cockpit-runtime-metric-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 0.85rem;
}

.cockpit-runtime-history {
    margin-top: 1.1rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(108, 29, 36, 0.1);
}

.cockpit-runtime-history-title {
    display: block;
    margin-bottom: 0.7rem;
}

.cockpit-runtime-history-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 0.65rem;
}

.cockpit-runtime-history-item {
    padding: 0.8rem 0.9rem;
    border: 1px solid rgba(108, 29, 36, 0.08);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.82);
}

.cockpit-runtime-history-label {
    display: block;
    font-weight: 700;
}

.cockpit-runtime-history-meta,
.cockpit-class-runtime-note {
    display: block;
    margin-top: 0.18rem;
    color: var(--abc-muted);
    font-size: 0.92rem;
}

@media (max-width: 1200px) {
    .cockpit-runtime-metric-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .cockpit-runtime-head-actions,
    .cockpit-runtime-controls {
        width: 100%;
        align-items: stretch;
        justify-content: flex-start;
    }

    .cockpit-runtime-metric-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
