/* ============================================================================
   SHARED — Cross-Component Classes
   Styles used by 3+ unrelated components that can't be scoped.
   ============================================================================ */

/* --- Animations --- */
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(12px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes fadeInBackdrop {
    to { opacity: 1; }
}

@keyframes pulse {
    0% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.4); opacity: 0.5; }
    100% { transform: scale(1); opacity: 1; }
}

@keyframes livePulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.5; transform: scale(1.3); }
}

@keyframes skeletonShimmer {
    0% { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}

@keyframes pop {
    0% { transform: scale(0.8); }
    60% { transform: scale(1.1); }
    100% { transform: scale(1); }
}

/* --- Page Entry Choreography --- */
.animate-in {
    animation: fadeInUp 400ms ease-out both;
}

.stagger-1 { animation-delay: calc(1 * 60ms); }
.stagger-2 { animation-delay: calc(2 * 60ms); }
.stagger-3 { animation-delay: calc(3 * 60ms); }
.stagger-4 { animation-delay: calc(4 * 60ms); }
.stagger-5 { animation-delay: calc(5 * 60ms); }
.stagger-6 { animation-delay: calc(6 * 60ms); }

/* --- Theme Transition --- */
.theme-transitioning,
.theme-transitioning *,
.theme-transitioning *::before,
.theme-transitioning *::after {
    transition: background-color 300ms ease, color 200ms ease,
                border-color 200ms ease, box-shadow 200ms ease !important;
}

/* --- Player Images --- */
.player-image,
img.player-image {
    border-radius: var(--radius-sm);
    object-fit: cover;
    border: 1px solid var(--border-subtle);
}

.player-image-sm,
img.player-image-sm {
    width: 32px;
    height: 32px;
    border-radius: 6px;
}

.player-image-md,
img.player-image-md {
    width: 48px;
    height: 48px;
    border-radius: var(--radius-sm);
}

.player-image-lg,
img.player-image-lg {
    width: 64px;
    height: 64px;
    border-radius: var(--radius-sm);
}

.player-image.rounded-circle,
img.player-image.rounded-circle {
    border-radius: var(--radius-sm);
}

/* Established app convention: images marked .rounded-circle render as ~8px
   rounded rectangles (not full circles), so player photos and avatars stay
   consistent app-wide. Kept global so pages using bare .rounded-circle (e.g.
   Draft, MyRankings) don't regress to circles. Bespoke player photos that
   aren't .rounded-circle can opt in via the .player-avatar helper below. */
img.rounded-circle {
    border-radius: var(--radius-sm);
}

/* Reusable helper for bespoke player photos that aren't .player-image. */
.player-avatar {
    border-radius: var(--radius-sm);
    object-fit: cover;
}

/* --- Live Indicator --- */
.live-indicator {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.6rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0;
    color: var(--accent-success);
    margin-left: 0.75rem;
    padding: 2px 8px;
    border-radius: var(--radius-sm);
    background: var(--accent-success-subtle);
}

.live-indicator::before {
    content: '';
    display: inline-block;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--accent-success);
    animation: livePulse 2s ease-in-out infinite;
}

/* --- Loading Skeletons --- */
.skeleton {
    background: linear-gradient(90deg,
        var(--surface-3) 0%,
        var(--surface-4) 50%,
        var(--surface-3) 100%);
    background-size: 200% 100%;
    animation: skeletonShimmer 1.8s ease-in-out infinite;
    border-radius: 4px;
}

.skeleton-text {
    height: 0.875rem;
    margin-bottom: 0.5rem;
}

.skeleton-text.w-75 { width: 75%; }
.skeleton-text.w-50 { width: 50%; }
.skeleton-text.w-33 { width: 33%; }

.skeleton-circle {
    border-radius: 50%;
}

.skeleton-card {
    height: 100px;
    border-radius: var(--radius-sm);
}

.loading-skeleton {
    padding: 0.75rem;
}

.loading-skeleton .skeleton-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.875rem;
}

.loading-skeleton .skeleton-avatar {
    width: 36px;
    height: 36px;
    flex-shrink: 0;
}

.loading-skeleton .skeleton-lines {
    flex: 1;
}

/* --- Stat Presentation --- */
.stat-hero {
    font-family: var(--font-mono);
    font-size: var(--text-3xl);
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.stat-trend-up {
    color: var(--accent-success);
}

.stat-trend-up::after {
    content: " \2191";
}

.stat-trend-down {
    color: var(--accent-danger);
}

.stat-trend-down::after {
    content: " \2193";
}

.stat-highlight {
    display: inline;
    padding: 2px 8px;
    border-radius: var(--radius-sm);
    background-color: var(--accent-primary-subtle);
    font-variant-numeric: tabular-nums;
}

.font-mono {
    font-variant-numeric: tabular-nums;
}

td.text-end,
td.text-center,
th.text-end,
th.text-center {
    font-variant-numeric: tabular-nums;
}

/* --- Clean List Items --- */
.clean-list-item {
    padding: var(--spacing-md);
    border-bottom: 1px solid var(--border-subtle);
    background: var(--surface-panel, var(--surface-2));
    transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease, color 0.15s ease, transform 0.15s ease;
    cursor: pointer;
}

.clean-list-item:hover {
    background: var(--surface-control-hover, var(--surface-3));
}

.clean-list-item:last-child {
    border-bottom: none;
}

.clean-list-item.selected {
    background: var(--accent-primary-subtle);
    border-left: 3px solid var(--accent-primary);
}

/* --- Dashboard Widgets --- */
.dashboard-widget {
    background: var(--surface-panel, var(--surface-2));
    border-radius: var(--panel-radius, var(--radius-sm));
    border: 1px solid var(--border-default);
    overflow: hidden;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    box-shadow: var(--shadow-sm);
}

.dashboard-widget:hover {
    border-color: var(--border-default);
}

.dashboard-widget.compact {
    overflow-y: auto;
}

.dashboard-widget.primary {
    border-color: var(--accent-primary-subtle);
}

.dashboard-widget:nth-child(1) { animation-delay: 60ms; }
.dashboard-widget:nth-child(2) { animation-delay: 120ms; }
.dashboard-widget:nth-child(3) { animation-delay: 180ms; }
.dashboard-widget:nth-child(4) { animation-delay: 240ms; }
.dashboard-widget:nth-child(5) { animation-delay: 300ms; }
.dashboard-widget:nth-child(6) { animation-delay: 360ms; }

.dashboard-widget .dashboard-card {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    margin: 0 !important;
}

.dashboard-widget .dashboard-card-header {
    padding: 14px 16px 10px !important;
    border-bottom: none !important;
    background: transparent !important;
}

.dashboard-widget .dashboard-card-title {
    font-family: var(--font-display) !important;
    font-weight: 720 !important;
    color: var(--text-secondary) !important;
}

.dashboard-widget .dashboard-icon-wrapper {
    display: none !important;
}

.dashboard-widget .dashboard-card-action {
    color: var(--accent-secondary) !important;
    text-decoration: none !important;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
}

.dashboard-widget .dashboard-card-body {
    padding: 0 !important;
}

.dashboard-widget .dashboard-card-header::after {
    display: none;
}

.dashboard-card-header {
    border-bottom: 1px solid var(--border-subtle);
    padding-bottom: 0.625rem;
    margin-bottom: 0;
}

.dashboard-card-body {
    padding-top: 0.5rem;
}

/* --- Dashboard List Styling --- */
.dashboard-widget .transaction-list,
.dashboard-widget .auction-list {
    padding: 0;
    margin: 0;
}

.dashboard-widget .transaction-item,
.dashboard-widget .auction-item {
    padding: 12px 20px;
    border-bottom: 1px solid var(--border-subtle);
    transition: background-color 0.2s ease;
}

.dashboard-widget .transaction-item:hover,
.dashboard-widget .auction-item:hover {
    background: var(--surface-3);
}

.dashboard-widget .transaction-summary {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.85rem;
    line-height: 1.4;
}

.dashboard-widget .transaction-franchise {
    font-weight: 500;
    color: var(--text-primary);
    text-decoration: none;
}

.dashboard-widget .transaction-franchise:hover {
    color: var(--accent-primary);
    text-decoration: underline;
}

.dashboard-widget .transaction-action {
    color: var(--text-tertiary);
    font-weight: 400;
}

.dashboard-widget .transaction-player {
    font-weight: 500;
    color: var(--accent-secondary);
    text-decoration: none;
}

.dashboard-widget .transaction-player:hover {
    text-decoration: underline;
}

.dashboard-widget .transaction-position {
    color: var(--text-quaternary);
    font-size: 0.75rem;
    font-weight: 400;
}

.dashboard-widget .transaction-time {
    font-size: 0.8rem;
    color: var(--text-quaternary);
    margin-top: 2px;
    font-weight: 400;
}

.dashboard-widget .transaction-avatar img {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    object-fit: cover;
}

.dashboard-widget .transaction-avatar {
    flex: 0 0 28px;
    margin-right: 12px;
}

/* --- Thread Panel --- */
.thread-panel {
    position: fixed;
    --thread-panel-top: 0px;
    top: var(--thread-panel-top);
    right: 0;
    width: min(640px, 48vw);
    height: calc(100dvh - var(--thread-panel-top));
    background: var(--surface-canvas);
    border-left: 1px solid var(--border-default);
    box-shadow: -18px 0 70px rgba(0, 0, 0, 0.42);
    z-index: -1;
    display: none;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    pointer-events: none;
}

html[data-layout="top-nav"] .thread-panel {
    --thread-panel-top: 56px;
}

html[data-layout="sidebar"] .thread-panel,
html[data-layout="vertical"] .thread-panel,
html:not([data-layout="top-nav"]) .thread-panel {
    --thread-panel-top: 44px;
}

.thread-panel.show {
    display: flex;
    z-index: 1060;
    transform: translateX(0);
    pointer-events: auto;
}

.thread-panel.show::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.2);
    z-index: -1;
    opacity: 0;
    animation: fadeInBackdrop 0.3s ease-in-out forwards;
}

.thread-panel-backdrop {
    backdrop-filter: blur(4px);
    background-color: rgba(0, 0, 0, 0.4);
}

.topic-thread-viewer {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
    max-height: calc(100dvh - var(--thread-panel-top, 0px));
    color: var(--text-primary);
    background: var(--surface-panel);
    font-family: var(--font-body);
    isolation: isolate;
}

.topic-thread-header {
    flex: 0 0 auto;
    padding: 1rem 1.25rem;
    background: color-mix(in srgb, var(--surface-1) 86%, transparent);
    border-bottom: 1px solid var(--border-default);
    box-shadow: 0 1px 0 color-mix(in srgb, var(--text-primary) 5%, transparent);
    backdrop-filter: blur(22px) saturate(1.2);
    -webkit-backdrop-filter: blur(22px) saturate(1.2);
}

.topic-thread-header-inner {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 1rem;
}

.topic-thread-title-group {
    min-width: 0;
    padding-right: 0.35rem;
}

.topic-thread-title {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    margin: 0 0 0.35rem;
    color: var(--text-primary);
    font-family: var(--font-display);
    font-size: 1.02rem;
    font-weight: 720;
    letter-spacing: 0;
    line-height: 1.2;
    overflow-wrap: anywhere;
}

.topic-thread-title i {
    color: var(--accent-primary);
    font-size: 0.95rem;
}

.topic-thread-meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.3rem;
    color: var(--text-tertiary);
    font-size: 0.78rem;
    font-weight: 560;
    line-height: 1.35;
}

.topic-thread-meta i {
    color: color-mix(in srgb, var(--text-tertiary) 72%, var(--accent-primary) 28%);
    font-size: 0.75rem;
}

.topic-thread-actions {
    display: flex;
    align-items: center;
    justify-self: end;
    gap: 0.55rem;
    flex: 0 0 auto;
}

.thread-close-button,
.thread-popout-button {
    appearance: none !important;
    -webkit-appearance: none !important;
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    width: 2.55rem;
    height: 2.55rem;
    padding: 0;
    border: 1px solid var(--border-default) !important;
    border-radius: var(--control-radius) !important;
    background: var(--surface-control) !important;
    color: var(--text-secondary) !important;
    box-shadow: inset 0 1px 0 color-mix(in srgb, var(--text-primary) 5%, transparent) !important;
    line-height: 1;
    transition: background-color var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-out);
}

.thread-close-button:hover,
.thread-close-button:focus-visible,
.thread-popout-button:hover,
.thread-popout-button:focus-visible {
    border-color: color-mix(in srgb, var(--accent-primary) 48%, var(--border-default));
    background: var(--surface-control-hover) !important;
    color: var(--text-primary) !important;
    transform: translateY(-1px);
}

.thread-popout-button {
    text-decoration: none;
}

.topic-thread-body {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-height: 0;
}

.topic-thread-messages {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    padding: 0;
    background: var(--surface-canvas);
}

.topic-message-item {
    padding: 1.05rem 1.25rem;
    border-bottom: 1px solid var(--border-subtle);
    background: transparent;
}

.topic-message-item:hover {
    background: color-mix(in srgb, var(--accent-primary-subtle) 22%, transparent);
}

.topic-message-row {
    display: flex;
    align-items: flex-start;
    gap: 0.95rem;
}

.topic-message-avatar {
    flex: 0 0 auto;
    background: transparent !important;
}

.topic-message-avatar .player-image,
.topic-message-avatar .player-image-md,
.message-avatar-fallback {
    width: 2.7rem !important;
    height: 2.7rem !important;
    border-radius: var(--radius-sm);
    border: 1px solid color-mix(in srgb, var(--accent-primary) 24%, var(--border-default));
    object-fit: cover;
    background: var(--surface-control);
    box-shadow:
        inset 0 1px 0 color-mix(in srgb, var(--text-primary) 5%, transparent),
        0 10px 24px rgba(0, 0, 0, 0.24);
}

.message-avatar-fallback {
    display: grid;
    place-items: center;
    color: var(--text-primary);
    background: var(--accent-gradient);
}

.topic-message-content {
    flex: 1 1 auto;
    min-width: 0;
}

.topic-message-meta {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-bottom: 0.55rem;
    color: var(--text-tertiary);
    font-size: 0.8rem;
    line-height: 1.35;
}

.topic-message-author {
    color: var(--text-secondary);
    font-weight: 680;
}

.topic-thread-viewer .message-body {
    max-width: 100%;
    padding: 0.88rem 1rem;
    border: 1px solid var(--border-default);
    border-radius: var(--radius-sm);
    background: var(--surface-control);
    color: var(--text-primary);
    box-shadow: 0 14px 28px rgba(0, 0, 0, 0.24);
    font-size: 0.92rem;
    line-height: 1.55;
    overflow-wrap: anywhere;
    word-break: normal;
}

.topic-thread-viewer .message-body p:last-child {
    margin-bottom: 0;
}

.topic-thread-viewer .message-body a {
    color: var(--accent-primary);
    font-weight: 700;
    text-decoration: none;
}

.topic-thread-viewer .message-body a:hover {
    text-decoration: underline;
}

.topic-thread-viewer .message-body blockquote,
.topic-thread-viewer .message-body .quote {
    margin: 0.85rem 0;
    padding: 0.8rem 0.95rem;
    border-left: 3px solid var(--accent-secondary);
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    background: color-mix(in srgb, var(--accent-secondary-subtle) 45%, transparent);
    color: var(--text-secondary);
}

.topic-thread-viewer .message-body pre {
    margin: 0.85rem 0;
    padding: 0.9rem;
    overflow: auto;
    border: 1px solid var(--border-default);
    border-radius: var(--radius-sm);
    background: var(--surface-0);
    color: var(--text-secondary);
}

.topic-message-item-long .message-body {
    line-height: 1.64;
    font-size: 0.95rem;
}

.topic-thread-viewer .message-composer {
    flex: 0 0 auto;
    padding: 1rem 1.25rem 1.15rem;
    border-top: 1px solid var(--border-default);
    background: var(--surface-panel);
    box-shadow: 0 -16px 36px rgba(0, 0, 0, 0.26);
}

.topic-thread-viewer .message-input-container {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
    gap: 0.7rem;
    padding: 0.62rem;
    border: 1px solid var(--border-default);
    border-radius: var(--control-radius);
    background: var(--surface-control);
    box-shadow: inset 0 1px 0 color-mix(in srgb, var(--text-primary) 5%, transparent);
}

.topic-thread-viewer .message-input-container:focus-within {
    border-color: color-mix(in srgb, var(--accent-primary) 62%, var(--border-default));
    background: var(--surface-control-hover);
    box-shadow: var(--focus-ring);
}

.topic-thread-viewer .message-input {
    min-height: 2.4rem;
    max-height: 10rem;
    padding: 0.48rem 0.25rem;
    border: 0;
    background: transparent;
    color: var(--text-primary);
    font: inherit;
    line-height: 1.45;
    outline: none;
    resize: none;
}

.topic-thread-viewer .message-input::placeholder {
    color: var(--text-quaternary);
}

.topic-thread-viewer .message-actions {
    position: static;
    display: flex;
    gap: 0;
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
    opacity: 1;
}

.topic-thread-viewer .btn-send {
    display: inline-grid;
    place-items: center;
    width: 2.6rem;
    height: 2.6rem;
    border: 1px solid color-mix(in srgb, var(--accent-primary) 50%, var(--border-default));
    border-radius: var(--control-radius);
    background: var(--button-primary-bg);
    color: var(--button-primary-text);
    box-shadow: 0 12px 26px var(--accent-primary-glow);
}

.topic-thread-viewer .btn-send.disabled {
    filter: grayscale(0.55);
    opacity: 0.48;
    box-shadow: none;
}

.topic-thread-viewer .message-composer-hint {
    margin-top: 0.72rem;
    padding-left: 0.15rem;
    color: var(--text-tertiary);
    font-weight: 600;
}

.topic-thread-viewer .message-composer-hint small {
    color: inherit !important;
}

.topic-thread-viewer .message-composer-hint kbd {
    border: 1px solid var(--border-default);
    border-radius: 4px;
    background: var(--surface-control);
    color: var(--text-secondary);
}

.topic-thread-empty {
    display: grid;
    place-items: center;
    gap: 0.75rem;
    min-height: 16rem;
    padding: 2rem;
    color: var(--text-tertiary);
    text-align: center;
}

.topic-thread-empty i {
    color: var(--text-quaternary);
    font-size: 1.65rem;
}

.topic-thread-empty p {
    margin: 0;
    font-weight: 560;
}

/* --- Dashboard Empty State --- */
.dashboard-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: var(--spacing-xl);
    color: var(--text-tertiary);
}

.dashboard-empty-state .empty-icon {
    font-size: 1.5rem;
    margin-bottom: var(--spacing-sm);
    opacity: 0.3;
    color: var(--text-quaternary);
}

.dashboard-empty-state .empty-message {
    font-size: 0.85rem;
    max-width: 280px;
    color: var(--text-tertiary);
    font-weight: 400;
    line-height: 1.5;
}

/* --- Typing Indicator --- */
.typing-indicator {
    display: inline-flex;
    gap: 3px;
    align-items: center;
    padding: 4px 8px;
}

.typing-indicator span {
    display: inline-block;
    width: 5px;
    height: 5px;
    background-color: var(--text-tertiary);
    border-radius: 50%;
    animation: pulse 1.4s infinite;
}

.typing-indicator span:nth-child(2) { animation-delay: 0.2s; }
.typing-indicator span:nth-child(3) { animation-delay: 0.4s; }

/* --- Recency Glow --- */
.recency-glow {
    border-left: 3px solid var(--accent-primary);
    box-shadow: inset 3px 0 6px -3px var(--accent-primary-subtle);
}

/* --- Countdown Urgency --- */
.countdown-urgent .auction-timing {
    color: var(--accent-warning) !important;
    font-weight: 600;
}

.countdown-urgent .auction-timing i {
    animation: livePulse 1.5s ease-in-out infinite;
    color: var(--accent-warning);
}

/* --- Button Press Feedback --- */
.btn:active,
.dashboard-card-action:active,
.link-btn:active {
    transform: scale(0.97);
}

.badge-pop {
    animation: pop 300ms ease-out;
}

/* --- Scroll Fade --- */
.scroll-fade {
    mask-image: linear-gradient(to bottom, black 85%, transparent 100%);
    -webkit-mask-image: linear-gradient(to bottom, black 85%, transparent 100%);
}

/* --- Dashboard Layout --- */
.app-dashboard {
    min-height: calc(100vh - 140px);
    padding: var(--content-py) var(--content-px);
    background: var(--surface-canvas, var(--surface-1));
}

.app-dashboard .row > [class*="col-"] {
    padding-left: calc(var(--spacing-md) / 2);
    padding-right: calc(var(--spacing-md) / 2);
}

.home-dashboard {
    background: var(--surface-canvas, var(--surface-0));
    min-height: calc(100vh - 120px);
    font-family: var(--font-body);
    padding: 0;
}

/* Franchise stats banner — used at top of Teams page (Team page uses .team-franchise-stats) */
.franchise-stats-banner {
    padding: 1.25rem 1.5rem;
    background: var(--surface-panel, var(--surface-2));
    border: 1px solid var(--border-default);
    border-radius: var(--panel-radius, var(--radius-sm));
    margin-bottom: 1.5rem;
}

/* Compact franchise history teaser — single line with link */
.franchise-teaser {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    /* Inside .team-page the gutter var aligns the strip with the hero/stat bands. */
    padding: min(0.75rem, var(--density-card-pad, 1.5rem)) var(--team-gutter, 2.5rem);
    border-bottom: 1px solid var(--border-subtle);
    text-decoration: none;
    font-family: var(--font-body);
    font-size: 0.8125rem;
    color: var(--text-tertiary);
    transition: background 0.15s ease;
    flex-wrap: wrap;
}

.franchise-teaser:hover {
    background: var(--surface-1);
    color: var(--text-secondary);
    text-decoration: none;
}

.franchise-teaser-label {
    font-family: var(--font-body);
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0;
    text-transform: uppercase;
    color: var(--text-quaternary);
}

.franchise-teaser-sep {
    color: var(--text-quaternary);
    opacity: 0.5;
}

.franchise-teaser-stat {
    font-family: var(--font-mono);
    font-weight: 600;
    color: var(--text-primary);
    font-variant-numeric: tabular-nums;
}

.franchise-teaser-unit {
    font-family: var(--font-body);
    font-weight: 500;
    color: var(--text-tertiary);
    margin-left: 0.25rem;
}

.franchise-teaser-titles {
    font-family: var(--font-mono);
    font-weight: 700;
    color: var(--accent-warning);
}

.franchise-teaser-cta {
    margin-left: auto;
    color: var(--accent-primary);
    font-weight: 500;
    font-size: 0.75rem;
}

.franchise-teaser-loading {
    padding: min(0.75rem, var(--density-card-pad, 1.5rem)) var(--team-gutter, 2.5rem);
    border-bottom: 1px solid var(--border-subtle);
}

/* ============================================================================
   TEAM PAGE — Sleek 2026 Editorial Layout
   No bordered cards. Sections defined by dividers. Typographic hierarchy.
   ============================================================================ */

.team-page {
    /* Horizontal gutter scales with density: 2.5rem comfortable → ~1.4rem ultra. */
    --team-gutter: calc(var(--density-page-pad, 1.5rem) * 1.6667);
    padding: 0;
    background: var(--surface-0);
    min-height: calc(100vh - 60px);
}

.team-franchise-stats {
    padding: var(--density-hero-pad-y, 2rem) var(--team-gutter) 0;
}

/* --- Team Hero — minimal identity strip --- */
.team-hero {
    display: flex;
    align-items: center;
    gap: min(1.25rem, var(--density-section-gap, 1.5rem));
    padding: min(var(--density-hero-pad-y, 2rem), 1.5rem) var(--team-gutter) min(var(--density-hero-pad-y, 2rem), 1.25rem);
    border-bottom: 1px solid var(--border-subtle);
}

.team-hero-logo {
    width: var(--density-avatar-size, 56px);
    height: var(--density-avatar-size, 56px);
    border-radius: var(--radius-sm);
    object-fit: cover;
    flex-shrink: 0;
}

.team-hero-text {
    flex: 1;
    min-width: 0;
}

.team-hero-title {
    font-family: var(--font-display);
    font-size: min(var(--density-display-size, 1.875rem), 1.875rem);
    font-weight: 600;
    letter-spacing: 0;
    color: var(--text-primary);
    margin: 0 0 0.25rem;
    line-height: 1.1;
}

.team-hero-meta {
    font-family: var(--font-body);
    font-size: 0.8125rem;
    color: var(--text-tertiary);
    margin: 0;
    letter-spacing: 0;
}

.team-hero-sep {
    margin: 0 0.5rem;
    color: var(--text-quaternary);
}

/* --- Team Stat Strip — horizontal stats, no boxes --- */
.team-stat-strip {
    display: flex;
    align-items: center;
    gap: 0;
    padding: min(var(--density-hero-pad-y, 2rem), 1.5rem) var(--team-gutter);
    border-bottom: 1px solid var(--border-subtle);
}

.team-stat {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
}

.team-stat-value {
    font-family: var(--font-mono);
    font-size: min(var(--density-display-size, 1.875rem), 1.875rem);
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0;
    color: var(--text-primary);
    font-variant-numeric: tabular-nums;
}

.team-stat-success { color: var(--accent-success); }
.team-stat-primary { color: var(--accent-primary); }
.team-stat-warning { color: var(--accent-warning); }

.team-stat-label {
    font-family: var(--font-body);
    font-size: 0.625rem;
    font-weight: 500;
    letter-spacing: 0;
    text-transform: uppercase;
    color: var(--text-quaternary);
    margin-top: 0.5rem;
}

.team-stat-meta {
    font-family: var(--font-mono);
    font-size: 0.6875rem;
    color: var(--text-tertiary);
    font-variant-numeric: tabular-nums;
    margin-top: 0.125rem;
}

.team-stat-divider {
    width: 1px;
    align-self: stretch;
    background: var(--border-subtle);
    margin: 0 calc(var(--density-section-gap, 1.5rem) * 1.3333);
}

/* --- Team Section — borderless container with header --- */
.team-section {
    border-bottom: 1px solid var(--border-subtle);
}

.team-section:last-child {
    border-bottom: none;
}

.team-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--density-section-gap, 1.5rem) var(--team-gutter) min(0.875rem, var(--density-section-gap, 1.5rem));
    gap: min(1rem, var(--density-section-gap, 1.5rem));
}

.team-section-header-left {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.team-section-header-right {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.team-section-title {
    font-family: var(--font-display);
    font-size: min(var(--density-heading-size, 1.125rem), 1.125rem);
    font-weight: 500;
    color: var(--text-primary);
    margin: 0;
    letter-spacing: 0;
    display: flex;
    align-items: center;
    gap: 0.625rem;
}

.team-section-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.5rem;
    height: 1.25rem;
    padding: 0 0.4rem;
    border-radius: var(--radius-full);
    font-family: var(--font-mono);
    font-size: 0.6875rem;
    font-weight: 600;
    background: var(--surface-3);
    color: var(--text-secondary);
}

.team-section-count-danger {
    background: var(--accent-danger-subtle);
    color: var(--accent-danger);
}

.team-section-count-warning {
    background: var(--accent-warning-subtle);
    color: var(--accent-warning);
}

.team-section-deadline {
    font-family: var(--font-body);
    font-size: 0.75rem;
    color: var(--accent-danger);
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
}

/* Section count pills (for Dynasty Roster header) */
.team-section-counts {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.team-count-pill {
    display: inline-flex;
    align-items: baseline;
    gap: 0.375rem;
    padding: 0.25rem 0.625rem;
    border-radius: var(--radius-full);
    font-family: var(--font-mono);
    font-size: 0.8125rem;
    font-weight: 600;
    background: var(--surface-2);
    color: var(--text-primary);
}

.team-count-pill-label {
    font-family: var(--font-body);
    font-size: 0.6875rem;
    font-weight: 500;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0;
}

.team-count-pill-primary {
    background: var(--accent-primary-subtle);
    color: var(--accent-primary);
}

.team-count-pill-warning {
    background: var(--accent-warning-subtle);
    color: var(--accent-warning);
}

.team-count-pill-danger {
    background: var(--accent-danger-subtle);
    color: var(--accent-danger);
}

.team-count-pill-primary .team-count-pill-label,
.team-count-pill-warning .team-count-pill-label,
.team-count-pill-danger .team-count-pill-label {
    color: currentColor;
    opacity: 0.7;
}

/* RFA window status banner (RFA tab header) */
.team-rfa-window {
    display: inline-flex;
    align-items: baseline;
    gap: 0.4rem;
    padding: 0.2rem 0.625rem;
    border-radius: var(--radius-full);
    font-family: var(--font-body);
    font-size: 0.75rem;
    background: var(--surface-2);
    color: var(--text-secondary);
}

.team-rfa-window .fas {
    align-self: center;
}

.team-rfa-window-detail {
    color: var(--text-tertiary);
}

.team-rfa-window-info {
    background: var(--accent-info-subtle);
    color: var(--accent-info);
}

.team-rfa-window-danger {
    background: var(--accent-danger-subtle);
    color: var(--accent-danger);
}

.team-rfa-window-warning {
    background: var(--accent-warning-subtle);
    color: var(--accent-warning);
}

.team-rfa-window-info .team-rfa-window-detail,
.team-rfa-window-danger .team-rfa-window-detail,
.team-rfa-window-warning .team-rfa-window-detail {
    color: currentColor;
    opacity: 0.75;
}

/* RFA tab empty state */
.team-rfa-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.25rem;
    padding: 3rem 1.5rem;
    color: var(--text-tertiary);
}

.team-rfa-empty .fas {
    font-size: 1.75rem;
    margin-bottom: 0.5rem;
    color: var(--text-quaternary);
}

.team-rfa-empty-title {
    font-family: var(--font-display);
    font-size: 1.0625rem;
    font-weight: 500;
    color: var(--text-secondary);
    margin: 0;
}

.team-rfa-empty-sub {
    font-size: 0.8125rem;
    max-width: 28rem;
    margin: 0;
}

/* Section body */
.team-section-body {
    padding: 0 min(1rem, var(--density-page-pad, 1.5rem)) var(--density-section-gap, 1.5rem);
}

/* Toggle (sort by scoring) */
.team-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
    user-select: none;
}

.team-toggle input[type="checkbox"] {
    appearance: none;
    width: 32px;
    height: 18px;
    background: var(--surface-3);
    border-radius: 9999px;
    position: relative;
    transition: background 0.15s ease;
    cursor: pointer;
    margin: 0;
}

.team-toggle input[type="checkbox"]::after {
    content: '';
    position: absolute;
    top: 2px;
    left: 2px;
    width: 14px;
    height: 14px;
    background: var(--text-primary);
    border-radius: 50%;
    transition: transform 0.15s ease;
}

.team-toggle input[type="checkbox"]:checked {
    background: var(--accent-primary);
}

.team-toggle input[type="checkbox"]:checked::after {
    transform: translateX(14px);
}

.team-toggle-label {
    font-family: var(--font-body);
    font-size: 0.75rem;
    color: var(--text-tertiary);
}

@media (max-width: 768px) {
    .team-franchise-stats,
    .team-hero,
    .team-stat-strip,
    .team-section-header {
        padding-left: 1.25rem;
        padding-right: 1.25rem;
    }

    .team-stat-strip {
        gap: 0;
        flex-wrap: wrap;
    }

    .team-stat-divider {
        display: none;
    }

    .team-stat {
        min-width: 50%;
        margin-bottom: 1rem;
    }

    .team-stat-value {
        font-size: 1.5rem;
    }
}

/* On phones the .team-page wrapper has no padding, so the hero/stat bands ran
   edge-to-edge — the hero divider + dark surface read as a gutterless full-bleed
   card. Give the page a side gutter (standard mobile content padding) so the whole
   team surface is inset from the screen edges, and drop the bands' own side padding
   so their text aligns to that single gutter instead of double-indenting.
   Desktop/tablet (>575.98px) keep the editorial full-bleed layout unchanged. */
@media (max-width: 575.98px) {
    .team-page {
        padding-left: var(--spacing-md, 16px);
        padding-right: var(--spacing-md, 16px);
    }

    .team-franchise-stats,
    .team-hero,
    .team-stat-strip,
    .team-section-header,
    .team-section-body {
        padding-left: 0;
        padding-right: 0;
    }
}

/* --- Bold Dashboard Grid --- */
.dash-hero {
    padding: 2rem 2.5rem 0;
}

.dash-grid {
    display: grid;
    grid-template-columns: 1fr 380px;
    min-height: calc(100vh - 280px);
}

.dash-primary {
    border-right: 1px solid var(--border-subtle);
}

.dash-secondary {
    overflow-y: auto;
}

.dash-section {
    border-bottom: 1px solid var(--border-subtle);
}

/* Override old widget borders in new layout */
.dash-section .dashboard-card,
.dash-section .dashboard-widget {
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}

.dash-section .dashboard-card-header {
    padding: 1rem 1.5rem 0.5rem !important;
}

.dash-section .dashboard-card-body {
    padding: 0 !important;
}

.dash-section .transaction-item,
.dash-section .auction-item {
    padding: 0.625rem 1.5rem;
}

.dash-section .topic-list {
    padding: 0;
}

@media (max-width: 1024px) {
    .dash-grid {
        grid-template-columns: 1fr;
    }
    .dash-primary {
        border-right: none;
    }
    .dash-hero {
        padding: 1.5rem 1.5rem 0;
    }
    .dash-status-bar {
        padding: 0.75rem 1.5rem;
    }
}

/* --- Focus Rings --- */
.btn:focus-visible,
.nav-link:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px var(--surface-1), 0 0 0 4px var(--accent-primary);
}


/* ============================================================================
   COMPONENT STYLES — Extracted from app.css
   ============================================================================ */

/* --- Search Results --- */
.search-results {
    background: var(--surface-2);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--border-default);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-xl);
    max-height: 300px;
    overflow-y: auto;
    z-index: 1050;
}

.search-result-item {
    display: block;
    padding: 12px 16px;
    border-bottom: 1px solid var(--border-subtle);
    cursor: pointer;
    transition: background-color 0.15s ease;
    text-decoration: none;
    color: var(--text-primary);
}

.search-result-item:hover {
    background: var(--surface-3);
    color: var(--text-primary);
    text-decoration: none;
}

.search-result-item:last-child,
.search-result-item:last-of-type { border-bottom: none; }

.search-result-item .player-image-sm {
    width: 40px; height: 40px;
    border-radius: 8px;
    object-fit: cover;
    border: 2px solid var(--border-default);
}

.search-result-item .text-primary { font-weight: 600; font-size: 0.9rem; }
.search-result-item .text-muted { font-size: 0.8rem; font-weight: 500; }
.search-result-item .text-info { font-size: 0.75rem; font-weight: 600; color: var(--accent-info) !important; }
.search-result-item .text-success { font-size: 0.75rem; font-weight: 600; color: var(--accent-success) !important; }

.search-result-more {
    display: block;
    padding: 12px 16px;
    text-align: center;
    color: var(--accent-secondary);
    font-weight: 600;
    font-size: 0.85rem;
    text-decoration: none;
    border-top: 1px solid var(--border-subtle);
}

.search-result-more:hover {
    background: var(--surface-3);
    text-decoration: none;
    color: var(--accent-secondary-hover);
}

/* --- Page Headers --- */
.page-header {
    display: flex; justify-content: space-between; align-items: flex-start;
    margin-bottom: var(--spacing-lg); gap: var(--spacing-md);
}
.page-header-simple { margin-bottom: var(--spacing-lg); }
.page-title {
    font-family: var(--font-display); font-size: var(--text-3xl);
    color: var(--text-primary); margin: 0 0 var(--spacing-xs);
    display: flex; align-items: center; gap: var(--spacing-sm); font-weight: 600;
}
.page-title i { color: var(--accent-primary); }
.page-subtitle { color: var(--text-tertiary); font-size: var(--text-sm); margin: 0; }
.page-actions { display: flex; gap: var(--spacing-sm); align-items: center; flex-shrink: 0; }

/* --- Home Dashboard Overrides --- */
.home-dashboard {
    background: var(--surface-1) !important;
    min-height: calc(100vh - 120px) !important;
    padding: 0 !important;
}

.home-dashboard .card {
    background: var(--surface-2) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    border: 1px solid var(--border-default) !important;
}

.home-dashboard .badge.bg-light {
    background: var(--surface-3) !important;
    color: var(--text-tertiary) !important;
    border: 1px solid var(--border-subtle) !important;
}

.home-dashboard h1,
.home-dashboard .h2 {
    font-size: 1.5rem !important;
    font-weight: 600 !important;
    color: var(--text-primary) !important;
    margin-bottom: 0 !important;
}

.home-dashboard .card-title {
    font-size: 0.95rem !important;
    font-weight: 500 !important;
    color: var(--text-primary) !important;
    margin-bottom: 0 !important;
}

.home-dashboard .card-title i {
    font-size: 0.85rem !important;
    color: var(--text-tertiary) !important;
    margin-right: 8px !important;
}

.home-dashboard small,
.home-dashboard .small {
    font-size: 0.8rem !important;
    color: var(--text-tertiary) !important;
}

.home-dashboard .text-muted {
    color: var(--text-tertiary) !important;
    font-size: 0.85rem !important;
}

.home-dashboard .card-header { padding: var(--card-padding) !important; }
.home-dashboard .clean-list-item,
.home-dashboard .list-group-item { padding: 12px var(--card-padding) !important; }

.home-dashboard .btn { border-radius: 8px !important; font-weight: 500 !important; padding: 10px 16px !important; }
.home-dashboard .btn-primary { background: var(--accent-secondary) !important; color: var(--text-inverse) !important; }
.home-dashboard .btn-primary:hover { background: var(--accent-secondary-hover) !important; box-shadow: var(--shadow-md) !important; }

/* --- Teams Page --- */
.teams-header {
    padding: 1.5rem 1.5rem 0 1.5rem;
    background: var(--surface-1);
    border-bottom: 1px solid var(--border-subtle);
}

.teams-content { padding: 1.5rem; }

.team-card {
    background: var(--surface-2);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-default);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease, transform 0.2s ease;
    height: 100%;
    display: flex;
    flex-direction: column;
    cursor: pointer;
}

.team-card:hover { box-shadow: var(--shadow-md); }

.team-header {
    padding: 20px 24px;
    border-bottom: 1px solid var(--border-subtle);
}

.team-info { display: flex; align-items: center; gap: 16px; }
.team-logo { flex: 0 0 48px; }
.team-logo img { width: 48px; height: 48px; border-radius: 8px; object-fit: cover; box-shadow: var(--shadow-sm); }
.team-logo-placeholder {
    width: 48px; height: 48px; background: var(--surface-3);
    border-radius: 8px; display: flex; align-items: center; justify-content: center;
    color: var(--text-tertiary); font-size: 1.2rem;
}

.team-details { flex: 1; min-width: 0; }
.team-name { margin: 0 0 4px 0; font-size: 1.25rem; font-weight: 600; line-height: 1.3; }
.team-name a { color: var(--text-primary); text-decoration: none; transition: color 0.2s ease; }
.team-name a:hover { color: var(--accent-secondary); }
.team-owner { color: var(--text-tertiary); font-size: 0.9rem; font-weight: 500; }

.team-summary { padding: 20px 24px; border-bottom: 1px solid var(--border-subtle); }
.summary-grid { display: grid; gap: 16px; }
.summary-item { display: flex; flex-direction: column; gap: 6px; }
.summary-label { font-size: 0.85rem; font-weight: 500; color: var(--text-tertiary); text-transform: uppercase; letter-spacing: 0; }
.summary-value { font-size: 1.1rem; font-weight: 600; color: var(--text-primary); display: flex; align-items: baseline; gap: 4px; }
.summary-detail { font-size: 0.9rem; font-weight: 400; color: var(--text-quaternary); }
.summary-bar { height: 4px; background: var(--surface-3); border-radius: 2px; overflow: hidden; }
.summary-bar-fill { height: 100%; background: var(--accent-secondary); border-radius: 2px; transition: width 0.3s ease; }

.position-breakdown { padding: 20px 24px; border-bottom: 1px solid var(--border-subtle); }
.breakdown-title { margin: 0 0 12px 0; font-size: 1rem; font-weight: 600; color: var(--text-primary); }
.position-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px 8px; }
.position-item {
    display: flex; justify-content: space-between; align-items: center;
    padding: 8px 12px; background: var(--surface-3); border-radius: 8px;
    border: 1px solid var(--border-subtle);
}
.position-label { font-size: 0.85rem; font-weight: 600; color: var(--text-tertiary); }
.position-count { font-size: 0.9rem; font-weight: 600; color: var(--text-primary); }

/* --- Trade Center --- */
.trade-center-header {
    padding: 1.5rem 1.5rem 0 1.5rem;
    background: var(--surface-1);
    border-bottom: 1px solid var(--border-subtle);
}

.trade-center-content { padding: 1.5rem; background: var(--surface-1); min-height: calc(100vh - 120px); }
.trade-section { height: 100%; }
.trade-card { background: var(--surface-2); border-radius: var(--radius-sm); box-shadow: var(--shadow-sm); border: 1px solid var(--border-default); overflow: hidden; }
.trade-card-header { background: var(--surface-3); padding: 0.75rem 1rem; border-bottom: 1px solid var(--border-subtle); font-weight: 600; }
.trade-card-body { padding: 0.75rem; }
.trade-block-item { padding: 0.75rem; border-bottom: 1px solid var(--border-subtle); transition: background-color 0.2s ease; }
.trade-block-item:hover { background: var(--surface-3); }
.trade-block-item:last-child { border-bottom: none; }
.player-info strong { color: var(--text-primary); font-size: 0.9rem; }
.player-info small { font-size: 0.8rem; color: var(--text-secondary); }

.negotiation-item, .proposal-item {
    padding: 1rem; border: 1px solid var(--border-default); border-radius: var(--radius-sm);
    margin-bottom: 0.75rem; cursor: pointer; transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease, transform 0.2s ease; background: var(--surface-2);
}
.proposal-item:hover { box-shadow: var(--shadow-md); border-color: var(--accent-secondary); }
.proposal-item.selected { border-color: var(--accent-secondary); box-shadow: 0 0 0 3px var(--accent-secondary-subtle); background: var(--accent-secondary-subtle); }
.proposal-info strong { color: var(--text-primary); font-size: 0.95rem; }

.trade-asset-item { padding: 0.5rem 0.75rem; background: var(--surface-3); border-radius: var(--radius-sm); margin-bottom: 0.5rem; }
.trade-asset-item:last-child { margin-bottom: 0; }
.trade-asset-item strong { color: var(--text-primary); font-size: 0.9rem; }
.trade-asset-item small { color: var(--text-secondary); font-size: 0.8rem; display: block; margin-top: 0.25rem; }

.trade-chat-messages { background: var(--surface-3); border-radius: var(--radius-sm); padding: 1rem; }
.chat-message { margin-bottom: 1rem; max-width: 80%; }
.chat-message:last-child { margin-bottom: 0; }
.chat-message.own-message { margin-left: auto; text-align: right; }
.chat-message.other-message { margin-right: auto; text-align: left; }
.message-body { background: var(--surface-2); padding: 0.75rem; border-radius: var(--radius-sm); box-shadow: var(--shadow-xs); font-size: 0.9rem; color: var(--text-primary); }
.own-message .message-body { background: var(--accent-secondary); color: var(--text-inverse); }
.other-message .message-body { background: var(--surface-2); color: var(--text-primary); }

/* --- Dashboard Layout --- */
.left-sidebar { display: flex; flex-direction: column; height: 100%; overflow-y: auto; }
.main-content { display: flex; flex-direction: column; height: 100%; overflow-y: auto; }

/* --- Thread List --- */
.thread-list { display: flex; flex-direction: column; padding: 0; margin: 0; }
.thread-item { display: flex; align-items: flex-start; padding: 12px 20px; border-bottom: 1px solid var(--border-subtle); cursor: pointer; transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease, transform 0.2s ease; position: relative; }
.thread-item:hover { background: var(--surface-3); }
.thread-item.active { background: var(--accent-primary-subtle); }
.thread-item.active::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--accent-secondary); border-radius: 0 2px 2px 0; }
.thread-avatar { flex: 0 0 36px; margin-right: 14px; }
.thread-avatar img { width: 36px; height: 36px; border-radius: 8px; object-fit: cover; box-shadow: var(--shadow-xs); }
.avatar-placeholder { width: 36px; height: 36px; background: var(--surface-3); border-radius: 8px; display: flex; align-items: center; justify-content: center; color: var(--text-tertiary); font-size: 0.9rem; }
.thread-content { flex: 1; min-width: 0; }
.thread-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
.franchise-name { font-weight: 500; color: var(--text-primary); font-size: 0.9rem; letter-spacing: 0; }
.thread-time { font-size: 0.8rem; color: var(--text-tertiary); font-weight: 500; }
.thread-subject { font-weight: 500; color: var(--text-primary); font-size: 0.96rem; margin-bottom: 6px; line-height: 1.4; }
.thread-preview { font-size: 0.82rem; color: var(--text-tertiary); line-height: 1.3; }
.reply-count { color: var(--accent-secondary); font-weight: 500; font-size: 0.8rem; }

/* --- Dashboard Card System --- */
.dashboard-card {
    background: var(--surface-2);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border-default);
    overflow: hidden;
    transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease, transform 0.2s ease;
    display: flex; flex-direction: column; height: 100%;
    margin-bottom: 1.5rem;
}

.dashboard-card:hover { box-shadow: var(--shadow-md); border-color: var(--border-strong); }
.dashboard-card-compact { }

.dashboard-card-header {
    padding: 14px 16px;
    border-bottom: 1px solid var(--border-subtle);
    display: flex; align-items: center; justify-content: space-between;
    background: var(--surface-3);
}

.dashboard-card-title { font-size: 0.95rem; font-weight: 600; color: var(--text-primary); letter-spacing: 0; }
.dashboard-icon-wrapper { width: 24px; height: 24px; display: flex; align-items: center; justify-content: center; color: var(--accent-secondary); font-size: 1.1rem; flex-shrink: 0; }
.dashboard-card-action { font-size: 0.8125rem; color: var(--accent-secondary); text-decoration: none; font-weight: 500; }
.dashboard-card-action:hover { color: var(--accent-secondary-hover); }
.dashboard-card-body { padding: 0 0.25rem; flex: 1; overflow: hidden; display: flex; flex-direction: column; }
.dashboard-loading { display: flex; justify-content: center; align-items: center; padding: 3rem 1.5rem; }
.dashboard-loading .spinner-border { color: var(--accent-secondary); width: 2rem; height: 2rem; }
.dashboard-notice { background: var(--accent-primary-subtle); color: var(--text-secondary); padding: 1rem 1.5rem; border-left: 3px solid var(--accent-primary); margin: 1rem 1.5rem; border-radius: 0 6px 6px 0; font-size: 0.875rem; }
.dashboard-empty-icon { width: 36px; height: 36px; border-radius: 8px; background: var(--surface-3); display: flex; align-items: center; justify-content: center; margin-bottom: 0.75rem; color: var(--text-quaternary); opacity: 0.5; }
.dashboard-empty-text { margin: 0; font-size: 0.8rem; font-weight: 400; color: var(--text-tertiary); }

.auction-dashboard-card-dormant {
    height: auto;
}

.auction-dashboard-card-dormant .dashboard-card-body {
    flex: 0 0 auto;
    min-height: 0;
    padding: 0;
    overflow: visible;
}

.auction-dormant-summary {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.875rem;
    padding: 0.95rem 1rem;
    background:
        linear-gradient(90deg, color-mix(in srgb, var(--accent-primary, #31c7f3) 10%, transparent), transparent 54%),
        color-mix(in srgb, var(--surface-3, #101820) 72%, transparent);
}

.auction-dormant-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border: 1px solid color-mix(in srgb, var(--accent-secondary, #d6b463) 26%, var(--border-default, transparent));
    border-radius: var(--control-radius, 8px);
    color: var(--accent-secondary);
    background: color-mix(in srgb, var(--accent-secondary, #d6b463) 8%, var(--surface-2, #0f151b));
    box-shadow: inset 0 1px 0 color-mix(in srgb, var(--text-primary, #fff) 8%, transparent);
}

.auction-dormant-copy {
    display: grid;
    gap: 0.12rem;
    min-width: 0;
}

.auction-dormant-copy strong {
    color: var(--text-primary);
    font-size: 0.9rem;
    line-height: 1.15;
}

.auction-dormant-copy span {
    color: var(--text-tertiary);
    font-size: 0.78rem;
    font-weight: 650;
    line-height: 1.2;
}

.auction-dormant-link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    color: var(--accent-secondary);
    font-size: 0.78rem;
    font-weight: 800;
    text-decoration: none;
    white-space: nowrap;
}

.auction-dormant-link:hover {
    color: var(--accent-secondary-hover);
}

/* --- Discussion Component --- */
.discussion-list { padding: 0; }
.discussion-item { display: flex; align-items: flex-start; padding: 1.25rem 1.5rem; border-bottom: 1px solid var(--border-subtle); cursor: pointer; transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease, color 0.15s ease, transform 0.15s ease; position: relative; }
.discussion-item:last-child { border-bottom: none; }
.discussion-item:hover { background: var(--surface-3); }
.discussion-item.selected { background: var(--accent-primary-subtle); border-left: 3px solid var(--accent-primary); }
.discussion-item.selected .discussion-title { color: var(--accent-secondary); }
.discussion-avatar { width: 42px; height: 42px; border-radius: var(--radius-sm); overflow: hidden; flex-shrink: 0; margin-right: 0.875rem; border: 2px solid var(--border-default); }
.discussion-avatar img { width: 100%; height: 100%; object-fit: cover; }
.discussion-avatar-placeholder { width: 100%; height: 100%; background: var(--surface-4); display: flex; align-items: center; justify-content: center; color: var(--text-primary); font-size: 0.875rem; }
.discussion-content { flex: 1; min-width: 0; }
.discussion-meta { display: flex; align-items: center; justify-content: space-between; margin-bottom: 0.375rem; }
.discussion-author { font-size: 0.8125rem; font-weight: 600; color: var(--text-secondary); }
.discussion-stats { display: flex; align-items: center; gap: 0.5rem; }
.discussion-time { font-size: 0.75rem; color: var(--text-quaternary); font-weight: 500; }
.discussion-count { background: var(--accent-info-subtle); color: var(--accent-info); font-size: 0.6875rem; font-weight: 600; padding: 0.125rem 0.375rem; border-radius: 4px; min-width: 1.25rem; text-align: center; }
.discussion-title { font-size: 0.9375rem; font-weight: 600; color: var(--text-primary); margin: 0 0 0.25rem 0; line-height: 1.4; }
.discussion-summary { font-size: 0.75rem; color: var(--text-quaternary); font-weight: 500; }

/* --- Auction Component --- */
.auction-list { padding: 0; }
.auction-item { display: flex; align-items: center; justify-content: space-between; padding: 1.25rem 1.5rem; border-bottom: 1px solid var(--border-subtle); transition: background-color 0.15s ease; }
.auction-item:last-child { border-bottom: none; }
.auction-item:hover { background: var(--surface-3); }
.auction-player { display: flex; align-items: center; flex: 1; min-width: 0; }
.auction-avatar { width: 48px !important; height: 48px !important; border-radius: var(--radius-sm); overflow: hidden; margin-right: 1rem; position: relative; border: 2px solid var(--border-default); flex-shrink: 0; }
.auction-avatar img { width: 100% !important; height: 100% !important; object-fit: cover !important; }
.auction-badge { position: absolute; top: -4px; right: -4px; background: var(--accent-warning); color: var(--text-inverse); font-size: 0.625rem; font-weight: 700; padding: 0.125rem 0.375rem; border-radius: 4px; border: 2px solid var(--surface-2); }
.auction-info { flex: 1; min-width: 0; }
.auction-player-name { display: flex; align-items: baseline; gap: 0.5rem; margin-bottom: 0.25rem; flex-wrap: wrap; }
.auction-position { background: var(--surface-5); color: var(--text-primary); font-size: 0.6875rem; font-weight: 700; padding: 0.125rem 0.375rem; border-radius: 4px; text-transform: uppercase; }
.auction-name-link { font-size: 0.9375rem; font-weight: 600; color: var(--text-primary); text-decoration: none; }
.auction-name-link:hover { color: var(--accent-secondary); }
.auction-team { font-size: 0.8125rem; color: var(--text-quaternary); font-weight: 500; }
.auction-timing { display: flex; align-items: center; gap: 0.25rem; color: var(--text-quaternary); font-size: 0.75rem; }
.auction-bid { display: flex; align-items: center; gap: 0.75rem; flex-shrink: 0; }
.auction-bid-info { text-align: right; }
.auction-bid-amount { font-size: 1rem; font-weight: 700; color: var(--accent-success); line-height: 1.2; }
.auction-bid-term { font-size: 0.75rem; color: var(--text-quaternary); font-weight: 500; }
.auction-bidder img { width: 36px; height: 36px; border-radius: 8px; object-fit: cover; border: 2px solid var(--border-default); }
.auction-no-bids { font-size: 0.8125rem; color: var(--text-quaternary); font-weight: 500; }
.auction-extras { padding: 0.75rem 1.5rem 0; border-top: 1px solid var(--border-subtle); background: var(--surface-3); }
.auction-picks, .auction-comment { color: var(--text-tertiary); font-size: 0.75rem; }
.auction-comment { font-style: italic; }

/* --- Transaction Component --- */
.transaction-list { padding: 0; }
.transaction-item { display: flex; align-items: center; padding: 1rem 1.5rem; border-bottom: 1px solid var(--border-subtle); transition: background-color 0.15s ease; }
.transaction-item:last-child { border-bottom: none; }
.transaction-item:hover { background: var(--surface-3); }
.transaction-avatar { width: 36px; height: 36px; border-radius: 8px; overflow: hidden; margin-right: 0.875rem; border: 2px solid var(--border-default); flex-shrink: 0; }
.transaction-avatar img { width: 100%; height: 100%; object-fit: cover; }
.transaction-content { flex: 1; min-width: 0; }
.transaction-summary { display: flex; align-items: baseline; gap: 0.375rem; margin-bottom: 0.25rem; flex-wrap: wrap; font-size: 0.8125rem; line-height: 1.4; }
.transaction-position { background: var(--surface-5); color: var(--text-primary); font-size: 0.625rem; font-weight: 700; padding: 0.125rem 0.3125rem; border-radius: 3px; text-transform: uppercase; }
.transaction-player { font-weight: 600; color: var(--text-primary); text-decoration: none; }
.transaction-player:hover { color: var(--accent-secondary); }
.transaction-action { color: var(--text-tertiary); }
.transaction-franchise { font-weight: 600; color: var(--accent-secondary); text-decoration: none; }
.transaction-franchise:hover { color: var(--accent-secondary-hover); }
.transaction-time { font-size: 0.6875rem; color: var(--text-quaternary); font-weight: 500; }

/* Compact transactions */
.transaction-item-compact { display: flex; align-items: flex-start; padding: 0.75rem 1rem; border-bottom: 1px solid var(--border-subtle); }
.transaction-item-compact:last-child { border-bottom: none; }
.transaction-item-compact:hover { background: var(--surface-3); }
.transaction-avatar-small { width: 2em !important; height: 2em !important; border-radius: 4px; overflow: hidden; margin-right: 0.75rem; border: 1px solid var(--border-default); flex-shrink: 0; }
.transaction-avatar-small img { width: 100% !important; height: 100% !important; object-fit: cover !important; }
.transaction-content-two-line { display: flex; flex-direction: column; gap: 0.125rem; font-size: 0.75rem; line-height: 1.2; min-width: 0; flex: 1; }
.transaction-top-line, .transaction-bottom-line { display: flex; align-items: center; gap: 0.375rem; white-space: nowrap; overflow: hidden; }
.transaction-franchise-compact { font-weight: 600; color: var(--accent-secondary); text-decoration: none; }
.transaction-franchise-compact:hover { text-decoration: underline; }
.transaction-action-compact { color: var(--text-tertiary); }
.transaction-player-compact { font-weight: 500; color: var(--text-primary); text-decoration: none; }
.transaction-player-compact:hover { text-decoration: underline; }
.transaction-position-compact { background: var(--surface-5); color: var(--text-primary); font-size: 0.5rem; font-weight: 700; padding: 0.0625rem 0.25rem; border-radius: 2px; text-transform: uppercase; }
.transaction-time-compact { color: var(--text-quaternary); font-size: 0.6875rem; margin-left: auto; }

/* --- Message Composer --- */
.message-composer { background: var(--surface-2); border-top: 1px solid var(--border-subtle); padding: 1rem; }
.message-input-container { display: flex; align-items: flex-end; gap: 0.75rem; background: var(--surface-3); border: 2px solid var(--border-default); border-radius: 8px; padding: 0.5rem; transition: border-color 0.15s ease; }
.message-input-container:focus-within { border-color: var(--accent-secondary); background: var(--surface-2); }
.message-input { flex: 1; border: none; background: transparent; resize: none; font-size: 0.9rem; line-height: 1.4; padding: 0.375rem 0; min-height: 20px; max-height: 120px; overflow-y: auto; outline: none; font-family: inherit; color: var(--text-primary); }
.message-input::placeholder { color: var(--text-quaternary); }
.message-actions { display: flex; align-items: center; gap: 0.5rem; }
.btn-send { display: flex; align-items: center; justify-content: center; width: 32px; height: 32px; border: none; border-radius: 6px; background: var(--accent-secondary); color: var(--text-inverse); cursor: pointer; transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease, color 0.15s ease, transform 0.15s ease; font-size: 0.8rem; }
.btn-send:hover:not(.disabled) { background: var(--accent-secondary-hover); transform: scale(1.05); }
.btn-send.disabled { background: var(--surface-4); cursor: not-allowed; transform: none; }
.message-composer-hint { margin-top: 0.5rem; padding-left: 0.5rem; }
.message-composer-hint kbd { background: var(--surface-3); border: 1px solid var(--border-subtle); border-radius: 3px; padding: 0.125rem 0.25rem; font-size: 0.75rem; font-family: ui-monospace, monospace; color: var(--text-secondary); }

/* --- Roster Management --- */
.modern-roster-grid, .dynasty-roster-grid { border: none !important; background: transparent !important; }
.modern-roster-grid .rz-datatable, .dynasty-roster-grid .rz-datatable { border: none !important; box-shadow: none !important; background: transparent !important; }
.modern-roster-grid .rz-data-row, .dynasty-roster-grid .rz-data-row,
.modern-roster-grid .rz-datatable-data tr, .dynasty-roster-grid .rz-datatable-data tr { background: transparent !important; }
.modern-roster-grid .rz-datatable-header, .dynasty-roster-grid .rz-datatable-header { background: var(--surface-3) !important; border: none !important; font-weight: 600 !important; text-transform: uppercase !important; font-size: 0.75rem !important; letter-spacing: 0 !important; color: var(--text-tertiary) !important; }
.modern-roster-grid .rz-datatable-data, .dynasty-roster-grid .rz-datatable-data { border: none !important; }
.modern-roster-grid .rz-datatable-data td, .dynasty-roster-grid .rz-datatable-data td { border: none !important; border-bottom: 1px solid var(--border-subtle) !important; padding: var(--density-table-pad-y, 0.875rem) var(--density-table-pad-x, 0.75rem) !important; vertical-align: middle !important; }
.modern-roster-grid .rz-datatable-data tr:hover, .dynasty-roster-grid .rz-datatable-data tr:hover { background-color: var(--surface-3) !important; }
.modern-roster-grid .rz-datatable-data tr:last-child td { border-bottom: none !important; }
.modern-roster-grid .player-image { width: 48px; height: 48px; border-radius: var(--radius-sm); object-fit: cover; border: 2px solid var(--border-default); }
.modern-roster-grid .player-image:hover { border-color: var(--accent-secondary); }

.modern-roster-grid .action-buttons { display: flex; gap: 0.25rem; justify-content: center; }
.modern-roster-grid .action-buttons .rz-button { min-width: 32px; height: 32px; padding: 0; border-radius: 6px; display: flex; align-items: center; justify-content: center; }
.modern-roster-grid .rz-datatable-footer, .dynasty-roster-grid .rz-datatable-footer { background: var(--surface-3) !important; border: none !important; border-top: 2px solid var(--border-default) !important; font-weight: 600 !important; padding: calc(var(--density-table-pad-y, 0.875rem) + 0.125rem) var(--density-table-pad-x, 0.75rem) !important; }
.team-stats-card { transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out; }
.team-stats-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.team-stats-number { font-family: var(--font-mono); font-weight: 700; line-height: 1.2; }

/* Taxi squad */
.dynasty-roster-grid .taxi-squad-row { background-color: var(--accent-warning-subtle) !important; border-left: 3px solid var(--accent-warning) !important; }
.dynasty-roster-grid .taxi-squad-row:hover { background-color: var(--accent-warning-subtle) !important; }

/* Position headers */
.dynasty-roster-grid .position-header-row { background: var(--accent-secondary) !important; border: none !important; }
.dynasty-roster-grid .position-header-row td { padding: 0.75rem 1rem !important; border: none !important; }
.dynasty-roster-grid .position-header-row:hover { background: var(--accent-secondary) !important; }
.position-header-text { color: var(--text-inverse) !important; font-weight: 600 !important; text-transform: uppercase !important; letter-spacing: 0 !important; font-size: 0.9rem !important; }

.dynasty-roster-grid .player-name-cell { min-width: 200px; }

/* Player-name columns must show the full name. Radzen's default `.rz-cell-data`
   applies `overflow:hidden; text-overflow:ellipsis; white-space:nowrap`, which
   clips long surnames ("McCaffrey" -> "McCa"). Let the name cells wrap/expand. */
.dynasty-roster-grid .player-name-cell .rz-cell-data,
.dynasty-roster-grid .rfa-name-cell .rz-cell-data {
    overflow: visible;
    text-overflow: clip;
    white-space: normal;
}
.dynasty-roster-grid .player-name-cell a,
.dynasty-roster-grid .rfa-name-cell a,
.dynasty-roster-grid .player-name-cell .roster-mobile-meta { white-space: normal; word-break: normal; overflow-wrap: anywhere; }

/* Horizontal-scroll safety net: even with fixed columns, nothing should clip
   off the side of the grid wrapper on very narrow phones. */
.dynasty-roster-grid .rz-data-grid-data,
.dynasty-roster-grid .rz-datatable-tablewrapper { overflow-x: auto; }
.status-badges-compact { display: flex; flex-wrap: wrap; gap: 0.25rem; justify-content: center; }
.status-badge { display: inline-flex; align-items: center; padding: 0.125rem 0.375rem; border-radius: 4px; font-size: 0.625rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0; line-height: 1; }
.status-badge.status-taxi { background: var(--accent-warning-subtle); color: var(--accent-warning); border: 1px solid var(--accent-warning); }
.status-badge.status-franchise { background: var(--accent-success-subtle); color: var(--accent-success); border: 1px solid var(--accent-success); }
.status-badge.status-orc { background: var(--accent-info-subtle); color: var(--accent-info); border: 1px solid var(--accent-info); }
.status-badge.status-ir, .status-badge.status-rfa { background: var(--accent-danger-subtle); color: var(--accent-danger); border: 1px solid var(--accent-danger); }
.status-badge.status-retired { background: var(--surface-3); color: var(--text-tertiary); border: 1px solid var(--border-strong); }

.dynasty-actions { display: flex; flex-wrap: wrap; gap: 0.375rem; justify-content: flex-start; align-items: center; }
.dynasty-actions .btn { font-size: 0.75rem; padding: 0.25rem 0.5rem; border-radius: 4px; font-weight: 600; white-space: nowrap; min-width: auto; height: auto; line-height: 1.2; }
.dynasty-actions .btn i { font-size: 0.6875rem; margin-right: 0.25rem; }
.dynasty-actions .btn-sm { padding: 0.25rem 0.5rem !important; font-size: 0.75rem !important; }

/* Status indicators */
.status-indicator { display: inline-flex; align-items: center; gap: 0.25rem; padding: 0.25rem 0.5rem; border-radius: var(--radius-sm); font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0; }
.status-franchise { background: var(--accent-success-subtle); color: var(--accent-success); }
.status-taxi { background: var(--accent-warning-subtle); color: var(--accent-warning); }
.status-ir, .status-rfa { background: var(--accent-danger-subtle); color: var(--accent-danger); }
.status-orc { background: var(--accent-info-subtle); color: var(--accent-info); }

/* Roster cards */
.roster-card { border: none; box-shadow: var(--shadow-sm); }
.roster-card:hover { box-shadow: var(--shadow-md); }
.roster-card .card-header { background: var(--surface-3); border-bottom: 1px solid var(--border-default); }
.position-group-header { background: var(--accent-secondary); color: var(--text-inverse); font-weight: 600; text-transform: uppercase; letter-spacing: 0; padding: 0.75rem 1rem; }
.roster-loading { display: flex; justify-content: center; align-items: center; min-height: 200px; flex-direction: column; }

/* --- Auctions Page --- */
.auctions-page { padding: 0; }
.auctions-header {
    padding: min(calc(var(--density-hero-pad-y) * 0.75), clamp(1rem, 2vw, 1.5rem)) clamp(1rem, 2.2vw, 1.5rem) min(calc(var(--density-hero-pad-y) * 0.5), 1rem);
    background: var(--surface-1);
    border-bottom: 1px solid var(--border-subtle);
}
.auctions-page .auctions-content { padding: var(--density-page-pad); }
.auctions-page .mb-5 { margin-bottom: calc(var(--density-section-gap) * 2) !important; }
.auction-page-title-row,
.auction-history-header,
.auction-empty-compact {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}
.auction-page-title-row h1,
.auction-history-header h2 {
    margin: 0;
    color: var(--text-primary);
    letter-spacing: 0;
}
.auction-page-title-row h1 { font-size: min(var(--density-display-size), 2.5rem); }
.auction-history-header h2 { font-size: var(--density-heading-size); }
.auction-page-eyebrow {
    margin: 0 0 0.3rem;
    color: var(--accent-primary);
    font-size: 0.72rem;
    font-weight: 850;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.auction-loading {
    display: grid;
    min-height: calc(var(--density-empty-state-pad) * 6);
    place-items: center;
}
.auction-empty-compact,
.auction-history-shell {
    border: 1px solid var(--border-default);
    border-radius: var(--panel-radius, 8px);
    background: var(--surface-panel, var(--surface-2));
    box-shadow: var(--shadow-sm);
}
.auction-empty-compact {
    padding: 0.95rem 1rem;
    margin-bottom: 1rem;
    border-left: 3px solid var(--accent-primary);
}
.auction-empty-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.35rem;
    height: 2.35rem;
    flex: 0 0 auto;
    border-radius: var(--control-radius, 8px);
    color: var(--accent-secondary);
    background: color-mix(in srgb, var(--accent-secondary, #d6b463) 10%, var(--surface-3, #101820));
}
.auction-empty-copy {
    display: grid;
    gap: 0.1rem;
    min-width: 0;
    margin-right: auto;
}
.auction-empty-copy strong {
    color: var(--text-primary);
    font-size: 0.95rem;
}
.auction-empty-copy span,
.auction-history-count {
    color: var(--text-tertiary);
    font-size: 0.82rem;
    font-weight: 650;
}
.auction-empty-action {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    color: var(--accent-secondary);
    font-size: 0.82rem;
    font-weight: 800;
    text-decoration: none;
    white-space: nowrap;
}
.auction-empty-action:hover { color: var(--accent-secondary-hover); }
.auction-history-shell {
    overflow: hidden;
}
.auction-history-header {
    padding: 1rem 1.1rem;
    border-bottom: 1px solid var(--border-subtle);
    background: color-mix(in srgb, var(--surface-3, #101820) 64%, transparent);
}
.auction-history-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}
.auction-season-select {
    width: auto;
    min-width: 9rem;
}
.auction-grid-shell {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.auction-grid-shell .rz-data-grid,
.auction-grid-shell .rz-datatable,
.auction-grid-shell .rz-grid-table {
    min-width: 680px;
}
.auction-grid-shell .rz-data-grid {
    border: 0 !important;
    box-shadow: none !important;
}
.auction-card-list-mobile {
    display: none;
}
.auction-mobile-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.8rem;
    align-items: center;
    padding: 0.9rem 1rem;
    border-top: 1px solid var(--border-subtle);
    background: color-mix(in srgb, var(--surface-2, #0f151b) 84%, transparent);
}
.auction-mobile-card-active {
    border-left: 3px solid var(--accent-success, #22c55e);
}
.auction-mobile-card-main,
.auction-mobile-card-side {
    display: grid;
    min-width: 0;
}
.auction-mobile-card-main {
    gap: 0.14rem;
}
.auction-mobile-card-side {
    justify-items: end;
    gap: 0.1rem;
}
.auction-mobile-status {
    color: var(--text-tertiary);
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
}
.auction-mobile-player {
    color: var(--accent-primary);
    font-weight: 850;
    text-decoration: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.auction-mobile-meta,
.auction-mobile-card-side span {
    color: var(--text-tertiary);
    font-size: 0.78rem;
    font-weight: 650;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.auction-mobile-card-side strong {
    color: var(--text-primary);
    font-size: 0.95rem;
    white-space: nowrap;
}
.auction-mobile-action {
    grid-column: 1 / -1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.35rem;
    color: var(--accent-secondary);
    border: 1px solid color-mix(in srgb, var(--accent-secondary, #d6b463) 28%, var(--border-default));
    border-radius: var(--control-radius, 8px);
    font-size: 0.82rem;
    font-weight: 850;
    text-decoration: none;
}
.auction-mobile-action:hover {
    color: var(--accent-secondary-hover);
    border-color: var(--accent-secondary-hover);
}
.auction-history-empty {
    display: grid;
    place-items: center;
    gap: 0.5rem;
    min-height: calc(var(--density-empty-state-pad) * 4);
    padding: calc(var(--density-empty-state-pad) * 0.66);
    text-align: center;
}

@media (max-width: 960px) {
    .auction-grid-shell-desktop {
        display: none;
    }

    .auction-card-list-mobile {
        display: grid;
    }
}

@media (max-width: 768px) {
    .auctions-page .auctions-content {
        padding: 1rem;
    }

    .auction-page-title-row,
    .auction-history-header,
    .auction-empty-compact {
        align-items: flex-start;
        flex-direction: column;
    }

    .auction-empty-copy {
        margin-right: 0;
    }

    .auction-empty-action,
    .auction-history-actions,
    .auction-history-actions .btn {
        width: 100%;
    }

    .auction-history-actions .btn,
    .auction-empty-action {
        justify-content: center;
    }

}

.admin-header { padding: 1.5rem 1.5rem 0 1.5rem; background: var(--surface-1); border-bottom: 1px solid var(--border-subtle); }
.player-header { padding: 1.5rem 1.5rem 0 1.5rem; background: var(--surface-1); border-bottom: 1px solid var(--border-subtle); }
.player-content { padding: 1.5rem; }
.admin-page .admin-content { padding: 1.5rem; }

/* --- Player Details --- */
.player-scoring-trend {
    padding: 1rem 1.125rem 1.05rem;
    border-bottom: 1px solid var(--line-faint, var(--border-subtle));
    background: color-mix(in srgb, var(--surface-module-strong, var(--surface-2)) 72%, transparent);
}

.player-scoring-trend-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.85rem;
}

.player-scoring-kicker,
.player-scoring-meta {
    color: var(--text-tertiary);
    font-size: 0.72rem;
    font-weight: 760;
    letter-spacing: 0;
    text-transform: uppercase;
}

.player-scoring-latest {
    display: flex;
    align-items: baseline;
    gap: 0.45rem;
    margin-top: 0.2rem;
    color: var(--text-primary);
    font-family: var(--font-display);
    font-size: clamp(1.95rem, 5vw, 2.55rem);
    font-weight: 780;
    line-height: 0.95;
}

.player-scoring-latest span {
    color: var(--text-secondary);
    font-family: var(--font-body);
    font-size: 0.78rem;
    font-weight: 720;
}

.player-scoring-meta {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.25rem;
    padding-top: 0.2rem;
}

.player-scoring-visual {
    position: relative;
    min-height: 6.15rem;
    overflow: hidden;
    border: 1px solid var(--line-faint, var(--border-subtle));
    border-radius: var(--panel-radius, var(--radius-sm));
    background:
        linear-gradient(color-mix(in srgb, var(--text-primary) 6%, transparent) 1px, transparent 1px),
        color-mix(in srgb, var(--surface-sheet, var(--surface-2)) 86%, transparent);
    background-size: 100% 33.333%, 100% 100%;
}

.player-scoring-sparkline {
    position: absolute;
    inset: 0.7rem 0.9rem 2.05rem;
    z-index: 2;
    width: calc(100% - 1.8rem);
    height: 3.25rem;
    overflow: visible;
}

.player-scoring-sparkline polyline {
    fill: none;
    stroke: var(--accent-primary);
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2.4;
    vector-effect: non-scaling-stroke;
    filter: drop-shadow(0 0 8px color-mix(in srgb, var(--accent-primary) 34%, transparent));
}

.player-scoring-sparkbars {
    position: absolute;
    inset: 0.75rem 0.9rem 0.55rem;
    display: grid;
    grid-auto-columns: minmax(1.7rem, 1fr);
    grid-auto-flow: column;
    gap: 0.55rem;
    align-items: end;
}

.player-scoring-sparkbar-item {
    display: flex;
    min-width: 0;
    height: 100%;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    gap: 0.38rem;
    color: var(--text-tertiary);
    font-family: var(--font-mono);
    font-size: 0.64rem;
    font-weight: 680;
    line-height: 1;
}

.player-scoring-sparkbar {
    display: block;
    width: 100%;
    max-width: 2.15rem;
    min-height: 0.45rem;
    border: 1px solid color-mix(in srgb, var(--accent-primary) 40%, transparent);
    border-radius: 999px 999px 5px 5px;
    background: color-mix(in srgb, var(--accent-primary) 68%, var(--surface-sheet, var(--surface-1)));
    opacity: 0.42;
}

.player-scoring-sparkbar-label {
    overflow: hidden;
    max-width: 100%;
    text-overflow: ellipsis;
}

.player-weekly-scoring {
    display: grid;
    grid-template-columns: minmax(8rem, 0.42fr) minmax(0, 1fr);
    gap: 1rem;
    align-items: stretch;
    margin-top: 0.85rem;
    padding: 0.85rem;
    border: 1px solid var(--line-faint, var(--border-subtle));
    border-radius: var(--panel-radius, var(--radius-sm));
    background: color-mix(in srgb, var(--surface-sheet, var(--surface-2)) 72%, transparent);
}

.player-weekly-copy {
    display: flex;
    min-width: 0;
    flex-direction: column;
    justify-content: center;
}

.player-weekly-metric {
    display: flex;
    align-items: baseline;
    gap: 0.4rem;
    margin-top: 0.18rem;
    color: var(--text-primary);
    font-family: var(--font-display);
    font-size: clamp(1.35rem, 3.3vw, 1.85rem);
    font-weight: 780;
    line-height: 1;
}

.player-weekly-metric span {
    color: var(--text-secondary);
    font-family: var(--font-mono);
    font-size: 0.72rem;
    font-weight: 720;
}

.player-weekly-chart {
    position: relative;
    min-height: 4.85rem;
    overflow: hidden;
    border-radius: calc(var(--panel-radius, var(--radius-sm)) - 2px);
    background:
        linear-gradient(color-mix(in srgb, var(--text-primary) 5%, transparent) 1px, transparent 1px),
        color-mix(in srgb, var(--surface-control, var(--surface-1)) 76%, transparent);
    background-size: 100% 50%, 100% 100%;
}

.player-weekly-sparkline {
    position: absolute;
    inset: 0.55rem 0.75rem 1.5rem;
    width: calc(100% - 1.5rem);
    height: 2.65rem;
    overflow: visible;
}

.player-weekly-sparkline polyline {
    fill: none;
    stroke: var(--accent-secondary, var(--accent-primary));
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2.2;
    vector-effect: non-scaling-stroke;
}

.player-weekly-axis {
    position: absolute;
    inset: auto 0.75rem 0.55rem;
    display: flex;
    justify-content: space-between;
    gap: 0.45rem;
    color: var(--text-tertiary);
    font-family: var(--font-mono);
    font-size: 0.6rem;
    font-weight: 680;
    line-height: 1;
    white-space: nowrap;
}

/* --- Auction Details --- */
.auction-details-page { padding: 1.5rem; background: var(--surface-1); min-height: calc(100vh - 60px); }
.auction-details-page .card { border: none; box-shadow: var(--shadow-md); border-radius: var(--radius-sm); }
.auction-details-page .card-header { background: var(--surface-3); border-bottom: 1px solid var(--border-subtle); border-radius: var(--radius-sm) 12px 0 0 !important; padding: 1rem 1.25rem; }
.auction-details-page .bid-history-container { max-height: 500px; overflow-y: auto; }
.auction-details-page .bid-history-table { display: table; width: 100%; border-collapse: collapse; }
.auction-details-page .bid-table-header { display: table-row; background: var(--surface-3); font-weight: 600; font-size: 0.875rem; color: var(--text-secondary); border-bottom: 2px solid var(--border-default); }
.auction-details-page .bid-table-header > div { display: table-cell; padding: 0.75rem 1rem; vertical-align: middle; border-right: 1px solid var(--border-subtle); }
.auction-details-page .bid-table-row { display: table-row; border-bottom: 1px solid var(--border-subtle); transition: background-color 0.2s ease; }
.auction-details-page .bid-table-row:hover { background-color: var(--surface-3); }
.auction-details-page .bid-table-row > div { display: table-cell; padding: 0.75rem 1rem; vertical-align: middle; border-right: 1px solid var(--border-subtle); }
.auction-details-page .bid-col-rank { width: 80px; text-align: center; }
.auction-details-page .bid-col-franchise { width: 25%; }
.auction-details-page .bid-col-total { width: 120px; text-align: right; }
.auction-details-page .bid-col-salary { width: 100px; text-align: right; }
.auction-details-page .bid-col-years { width: 60px; text-align: center; }
.auction-details-page .bid-col-time { width: auto; }
.auction-details-page .franchise-logo { width: 24px; height: 24px; border-radius: 4px; object-fit: cover; }
.auction-details-page .bid-winning { background: var(--accent-success-subtle); border-left: 4px solid var(--accent-success); }
.auction-details-page .quick-bid-row { background: var(--surface-3); border-left: 4px dashed var(--border-default); }
.auction-details-page .quick-bid-row:hover { background: var(--accent-info-subtle); border-left-color: var(--accent-info); }
.auction-details-page .badge-xs { font-size: 0.6rem; padding: 0.2rem 0.4rem; }
.auction-details-page .quick-bid-btn { background: var(--accent-secondary); border: none; box-shadow: var(--shadow-sm); }
.auction-details-page .quick-bid-btn:hover { background: var(--accent-secondary-hover); box-shadow: var(--shadow-md); }

@media (max-width: 768px) {
    /* Collapse bid-history table into stacked cards on mobile */
    .auction-details-page .bid-history-table { display: block; }
    .auction-details-page .bid-table-header { display: none; }
    .auction-details-page .bid-table-row {
        display: flex;
        flex-direction: column;
        padding: 0.75rem 1rem;
        border-bottom: 1px solid var(--border-subtle);
        gap: 0.25rem;
    }
    .auction-details-page .bid-table-row > div {
        display: block;
        padding: 0;
        border-right: none;
    }
    /* Hide annual/years/time as separate cells; surfaced inline via meta row */
    .auction-details-page .bid-col-rank,
    .auction-details-page .bid-col-total { display: inline-block; }
    /* Top line: rank badge + team + total bid */
    .auction-details-page .bid-table-row .bid-col-rank { float: left; margin-right: 0.5rem; }
    .auction-details-page .bid-table-row .bid-col-franchise { margin-left: 0; }
    .auction-details-page .bid-table-row .bid-col-total {
        font-size: 1rem;
        font-weight: 700;
        margin-top: 0.25rem;
    }
    /* Meta row: annual · years · time — collapsed into one line */
    .auction-details-page .bid-col-salary,
    .auction-details-page .bid-col-years { display: inline; font-size: 0.8rem; color: var(--text-tertiary); }
    .auction-details-page .bid-col-salary::after { content: " · "; }
    .auction-details-page .bid-col-time { font-size: 0.8rem; color: var(--text-tertiary); }
    /* Remove border-left accent — use subtle top border instead */
    .auction-details-page .bid-winning { border-left: none; border-top: 3px solid var(--accent-success); }
    .auction-details-page .quick-bid-row { border-left: none; border-top: 3px dashed var(--border-default); }
}

/* --- Trade Block Dialog --- */
.trade-block-dialog .form-label { font-weight: 600; color: var(--text-secondary); margin-bottom: 0.5rem; }
.trade-block-dialog .form-control, .trade-block-dialog .form-select { border: 2px solid var(--border-default); border-radius: 8px; padding: 0.75rem; font-size: 0.9rem; }
.trade-block-dialog .form-control:focus, .trade-block-dialog .form-select:focus { border-color: var(--accent-secondary); box-shadow: 0 0 0 0.2rem var(--accent-secondary-subtle); }
.trade-block-preferences { background: var(--surface-3); border-radius: 8px; padding: 1rem; margin-top: 1rem; }
.trade-block-preferences h6 { color: var(--text-secondary); font-weight: 600; margin-bottom: 0.75rem; }
.preference-chips { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.preference-chip { background: var(--surface-2); border: 2px solid var(--border-default); color: var(--text-secondary); padding: 0.375rem 0.75rem; border-radius: var(--radius-sm); font-size: 0.8125rem; font-weight: 500; cursor: pointer; }
.preference-chip:hover { border-color: var(--accent-secondary); background: var(--accent-secondary-subtle); }
.preference-chip.selected { background: var(--accent-secondary); border-color: var(--accent-secondary); color: var(--text-inverse); }

/* --- Dynasty Summary --- */
.dynasty-summary { display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem; padding: 1rem; background: var(--surface-3); border-radius: 8px; }
.dynasty-summary-item { display: flex; flex-direction: column; align-items: center; text-align: center; }
.dynasty-summary-label { font-size: 0.75rem; color: var(--text-tertiary); font-weight: 600; text-transform: uppercase; letter-spacing: 0; margin-bottom: 0.25rem; }
.dynasty-summary-value { font-size: 1.125rem; font-weight: 700; color: var(--text-primary); }

/* --- Brand Accent --- */
.brand-accent { color: var(--accent-secondary) !important; }
h1.brand-accent, h2.brand-accent { color: var(--accent-secondary) !important; font-weight: 600 !important; }

/* --- Loading Bar (router <Navigating> slot) --- */
.page-loading-bar { position: fixed; top: 0; left: 0; width: 100%; height: 3px; background: transparent; z-index: 9999; overflow: hidden; }
.page-loading-bar::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(to right, var(--accent-primary) 0%, var(--accent-secondary) 50%, var(--accent-primary-hover) 100%); animation: loading-bar 1.5s cubic-bezier(0.4, 0.0, 0.2, 1) infinite; transform-origin: left; }
@keyframes loading-bar { 0% { transform: translateX(-100%) scaleX(0.5); } 50% { transform: translateX(0%) scaleX(0.8); } 100% { transform: translateX(100%) scaleX(0.5); } }

/* --- Global Navigation Progress Bar ---
   Thin top bar driven by js/nav-progress.js. It hooks Blazor enhanced
   navigation (enhancedload) + circuit reconnection so any nav/reconnect
   surfaces a lightweight indicator regardless of which page is active. */
.nav-progress { position: fixed; top: 0; left: 0; height: 3px; width: 0; z-index: 10001;
    background: linear-gradient(to right, var(--accent-primary), var(--accent-secondary), var(--accent-primary-hover));
    box-shadow: 0 0 8px var(--accent-primary-glow);
    opacity: 0; transition: width 180ms var(--ease-out), opacity 200ms var(--ease-out); pointer-events: none; }
.nav-progress.is-active { opacity: 1; }
.nav-progress.is-done { opacity: 0; transition: width 120ms var(--ease-out), opacity 260ms var(--ease-out) 80ms; }

/* --- Skeleton / Shimmer Placeholders ---
   Theme-aware loading placeholders rendered by Components/Shared/Skeleton.razor.
   Base color comes from --surface-2/3 so the shimmer reads on every theme. */
.skeleton-group { display: flex; flex-direction: column; gap: 0.6rem; width: 100%; }
.skeleton-shimmer {
    position: relative; overflow: hidden; display: block;
    background: color-mix(in srgb, var(--surface-3) 70%, var(--surface-2) 30%);
    border-radius: var(--radius-sm);
}
.skeleton-shimmer::after {
    content: ''; position: absolute; inset: 0; transform: translateX(-100%);
    background: linear-gradient(90deg,
        transparent 0,
        color-mix(in srgb, var(--text-primary) 8%, transparent) 50%,
        transparent 100%);
    animation: skeleton-sweep 1.4s ease-in-out infinite;
}
@keyframes skeleton-sweep { 100% { transform: translateX(100%); } }

.skeleton-text { height: 0.85rem; width: 100%; border-radius: var(--radius-xs); }
.skeleton-rect { height: 120px; width: 100%; border-radius: var(--radius-md); }
.skeleton-circle { border-radius: var(--radius-full); width: 40px; height: 40px; flex: 0 0 auto; }

.skeleton-card { display: flex; align-items: center; gap: 0.85rem; padding: 0.85rem 1rem;
    background: var(--surface-2); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); }
.skeleton-card-avatar { width: 44px; height: 44px; }
.skeleton-card-lines { display: flex; flex-direction: column; gap: 0.5rem; flex: 1 1 auto; }

.skeleton-row { display: flex; align-items: center; gap: 0.85rem; padding: 0.6rem 0.25rem;
    border-bottom: 1px solid var(--border-subtle); }
.skeleton-row-avatar { width: 32px; height: 32px; }
.skeleton-row-grow { flex: 1 1 auto; height: 0.8rem; }
.skeleton-row-end { flex: 0 0 64px; height: 0.8rem; }

/* --- Circuit Reconnect Overlay ---
   Styling for Blazor Server's reconnection modal (id="components-reconnect-modal").
   Blazor toggles the components-reconnect-* classes on the element; we make the
   default modal theme-aware and add a thin reconnect bar via nav-progress. */
#components-reconnect-modal { position: fixed; inset: 0; z-index: 10000;
    display: none; align-items: center; justify-content: center;
    background: color-mix(in srgb, var(--surface-0) 72%, transparent);
    backdrop-filter: blur(3px); }
#components-reconnect-modal.components-reconnect-show,
#components-reconnect-modal.components-reconnect-failed,
#components-reconnect-modal.components-reconnect-rejected { display: flex; }
.reconnect-card { background: var(--surface-2); border: 1px solid var(--border-default);
    border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); padding: 1.5rem 1.75rem;
    max-width: 360px; text-align: center; color: var(--text-primary); font-family: var(--font-body); }
.reconnect-card .reconnect-spinner { width: 28px; height: 28px; margin: 0 auto 0.85rem;
    border: 3px solid var(--border-strong); border-top-color: var(--accent-primary);
    border-radius: var(--radius-full); animation: skeleton-sweep 0s, reconnect-spin 0.8s linear infinite; }
@keyframes reconnect-spin { to { transform: rotate(360deg); } }
.reconnect-card h3 { font-size: var(--text-lg); font-weight: 600; margin: 0 0 0.35rem; }
.reconnect-card p { font-size: var(--text-sm); color: var(--text-secondary); margin: 0; }
.reconnect-card .reconnect-retry { display: none; margin-top: 1rem; }
#components-reconnect-modal.components-reconnect-failed .reconnect-retry,
#components-reconnect-modal.components-reconnect-rejected .reconnect-retry { display: inline-flex; }
#components-reconnect-modal.components-reconnect-failed .reconnect-progress,
#components-reconnect-modal.components-reconnect-rejected .reconnect-progress { display: none; }

@media (prefers-reduced-motion: reduce) {
    .skeleton-shimmer::after { animation: none; }
    .page-loading-bar::before { animation: none; opacity: 0.6; }
    .nav-progress { transition: opacity 120ms linear; }
    .reconnect-card .reconnect-spinner { animation: none; border-top-color: var(--accent-primary); }
    /* Kill the busy/skeleton PULSE too, not just the shimmer sweep — a pulsing
       opacity loop is motion and should stop under reduced-motion. Keep a steady
       dimmed state so the loading affordance is still visible. */
    .loading,
    [aria-busy="true"],
    .skeleton { animation: none; opacity: 0.7; }
}

/* --- Micro-Animations --- */

@keyframes scaleIn { from { opacity: 0; transform: scale(0.9); } to { opacity: 1; transform: scale(1); } }
/* Badge entry animation removed — the scale-in "zoom" fired on every render/load and
   read as a distracting loading animation. The top nav-progress bar is the loading cue. */

.loading, [aria-busy="true"] { animation: pulse 1.5s ease-in-out infinite; }

.table tbody tr { transition: background-color var(--duration-fast) var(--ease-out); }

@keyframes slideIn { from { opacity: 0; transform: translateX(-8px); } to { opacity: 1; transform: translateX(0); } }
.list-group-item { animation: slideIn 0.25s var(--ease-out) both; }
.list-group-item:nth-child(1) { animation-delay: 0ms; }
.list-group-item:nth-child(2) { animation-delay: 30ms; }
.list-group-item:nth-child(3) { animation-delay: 60ms; }
.list-group-item:nth-child(4) { animation-delay: 90ms; }
.list-group-item:nth-child(5) { animation-delay: 120ms; }

/* --- Responsive Media Queries --- */
@media (max-width: 1200px) { .thread-panel { width: 400px; } }
@media (max-width: 992px) {
    .app-dashboard .col-4, .app-dashboard .col-8 { flex: 0 0 100%; max-width: 100%; }
    .app-dashboard .row { flex-direction: column; }
    .left-sidebar { flex-direction: row; overflow-x: auto; overflow-y: hidden; gap: 16px; }
    .left-sidebar .dashboard-widget { flex: 0 0 300px; }
    .thread-panel { width: 100vw; }
}

@media (max-width: 768px) {
    .thread-panel {
        --thread-panel-top: calc(4.6rem + 3.35rem);
        left: 0;
        right: 0;
        width: 100vw;
        max-width: 100vw;
        height: calc(100svh - var(--thread-panel-top));
        border-left: 0;
        border-top: 1px solid var(--border-default);
        box-shadow: none;
    }

    .thread-panel.show::before {
        display: none;
    }

    .topic-thread-viewer {
        height: 100%;
        max-height: none;
    }

    .topic-thread-header {
        padding: 0.85rem 1rem;
    }

    .topic-thread-header-inner {
        gap: 0.75rem;
    }

    .topic-thread-title {
        font-size: 0.96rem;
        line-height: 1.25;
    }

    .topic-thread-actions {
        gap: 0.4rem;
    }

    .thread-close-button,
    .thread-popout-button {
        width: 2.35rem;
        height: 2.35rem;
    }

    .topic-message-item {
        padding: 0.9rem 1rem;
    }

    .topic-message-row {
        gap: 0.72rem;
    }

    .topic-message-avatar .player-image,
    .topic-message-avatar .player-image-md,
    .message-avatar-fallback {
        width: 2.3rem !important;
        height: 2.3rem !important;
    }

    .topic-thread-viewer .message-body {
        padding: 0.78rem 0.86rem;
        font-size: 0.9rem;
        line-height: 1.52;
        box-shadow: none;
    }

    .topic-thread-viewer .message-composer {
        padding: 0.8rem 1rem max(0.9rem, env(safe-area-inset-bottom));
        box-shadow: 0 -10px 26px rgba(0, 0, 0, 0.2);
    }

    .topic-thread-viewer .message-input {
        min-height: 2.25rem;
        max-height: 7.5rem;
    }

    .topic-thread-viewer .message-composer-hint {
        display: none;
    }

    .home-dashboard .card-header { padding: var(--spacing-md); }
    .home-dashboard .card-title { font-size: 1rem; }
    .player-scoring-trend { padding: 0.9rem; }
    .player-scoring-trend-header { flex-direction: column; gap: 0.45rem; }
    .player-scoring-meta { align-items: flex-start; flex-direction: row; flex-wrap: wrap; }
    .player-scoring-visual { min-height: 5.7rem; }
    .player-scoring-sparkbars { gap: 0.35rem; }
    .player-scoring-sparkbar-item { font-size: 0.58rem; }
    .player-weekly-scoring { grid-template-columns: 1fr; gap: 0.75rem; }
    .player-weekly-chart { min-height: 4.5rem; }
    .player-weekly-axis { font-size: 0.56rem; }
    .main-header-bar { padding: var(--spacing-md); }
    .clean-list-item, .home-dashboard .list-group-item { padding: var(--spacing-sm) var(--spacing-md); }
    .modern-roster-grid .rz-datatable-data td { padding: 0.75rem 0.5rem !important; font-size: 0.9rem; }
    .modern-roster-grid .player-image { width: 40px; height: 40px; }
    .modern-roster-grid .action-buttons .rz-button { min-width: 28px; height: 28px; }
    .search-results { width: min(300px, calc(100vw - 1.5rem)) !important; right: 0 !important; }
    .search-result-item { padding: 10px 12px; }
    .search-result-item .player-image-sm { width: 36px; height: 36px; }
    .trade-center .col-4, .trade-center .col-8 { flex: 0 0 100%; max-width: 100%; }
    .trade-section { margin-bottom: 2rem; }
    .chat-message { max-width: 95%; }
    .nav-dropdown-content { margin-left: 0.5rem; padding-left: 0.5rem; }
    .sidebar .nav-link-sub { font-size: 0.8rem !important; padding: 6px 12px !important; }
    .header-search-input { min-width: 120px !important; max-width: 180px !important; }
    .header-nav-item { font-size: 0.8rem; padding: 6px 10px; }
    .brand-logo { font-size: 1.25rem !important; }
    .dynasty-actions { flex-direction: column; gap: 0.25rem; align-items: stretch; }
    .dynasty-actions .btn { font-size: 0.6875rem; padding: 0.1875rem 0.375rem; text-align: center; }
    .status-badges-compact { flex-direction: column; gap: 0.125rem; }
    .status-badge { font-size: 0.6875rem; padding: 0.125rem 0.3rem; }
    .dynasty-roster-grid .rz-datatable-data td { padding: 0.5rem 0.25rem !important; font-size: 0.8125rem; }
}

/* ============================================================================
   FULL THEME SURFACE PASS
   Shared page language for legacy and beta routes beyond the login screen.
   ============================================================================ */

article.content > .container-fluid.py-4,
.dynasty-page,
.team-page,
.trade-center-content,
.auctions-page,
.auction-details-page,
.player-content,
.admin-page .admin-content {
    background: transparent !important;
    padding: clamp(1rem, 2.2vw, 2rem) !important;
}

article.content > .container-fluid.py-4,
.dynasty-page {
    max-width: min(1720px, 100%);
    margin-inline: auto;
}

article.content > .container-fluid.py-4 > .page-header:first-child,
.dynasty-page > .page-header:first-child,
.dynasty-page > .d-flex.justify-content-between:first-child {
    align-items: flex-end;
    padding: 0 0 1rem;
    border-bottom: 1px solid var(--line-faint);
}

.page-title,
article.content > .container-fluid.py-4 h1,
article.content > .container-fluid.py-4 h2 {
    font-family: var(--font-display) !important;
    font-weight: 760 !important;
    letter-spacing: 0 !important;
}

.page-title i,
article.content > .container-fluid.py-4 h1 i,
article.content > .container-fluid.py-4 h2 i {
    color: var(--accent-primary) !important;
}

.dashboard-card,
.dashboard-widget,
.dash-section,
.history-panel,
.history-hero,
.thread-page-shell,
.rankings-card,
.summary-card,
.matchup-card,
.live-matchup-card,
.franchise-stats-banner,
.team-card,
.trade-card,
.admin-content .card {
    background: color-mix(in srgb, var(--surface-module) 88%, transparent) !important;
    border: 1px solid var(--line-default) !important;
    border-radius: var(--panel-radius) !important;
    box-shadow: var(--shadow-card) !important;
    backdrop-filter: blur(18px) saturate(1.14) !important;
    -webkit-backdrop-filter: blur(18px) saturate(1.14) !important;
}

.dash-section {
    overflow: hidden;
    margin-bottom: 1rem;
}

.dash-grid {
    gap: 1rem;
    grid-template-columns: minmax(0, 1fr) minmax(320px, var(--dash-secondary-width));
    padding: 0 clamp(1rem, 2vw, 2rem) clamp(1rem, 2vw, 2rem);
}

/* ============================================================================
   HOME DASHBOARD FLUID SURFACE CONTRACT
   Keep the landing dashboard edge-to-edge within the content pane: one gutter,
   one gap token, no decorative canvas, and no hidden max-width cap.
   ============================================================================ */

html[data-theme] article.content:has(.home-dashboard) {
    padding: 0 !important;
    overflow-x: hidden;
    background: var(--surface-canvas) !important;
}

html[data-theme] article.content:has(.home-dashboard),
html[data-theme] article.content:has(.home-dashboard) .home-dashboard,
html[data-theme] article.content:has(.home-dashboard) .app-dashboard {
    background-image: none !important;
}

.home-dashboard {
    --home-dashboard-gutter: clamp(1rem, 1.45vw, 1.5rem);
    --home-dashboard-gap: clamp(0.875rem, 1.2vw, 1.25rem);
    --home-card-x: clamp(1rem, 1.35vw, 1.35rem);
    --home-card-y: clamp(0.8rem, 1vw, 1rem);
    width: 100%;
    min-height: calc(100svh - var(--header-height, 56px));
    padding: 0 !important;
    background: var(--surface-canvas) !important;
}

.home-dashboard .app-dashboard {
    min-height: calc(100svh - var(--header-height, 56px));
    padding: var(--home-dashboard-gutter) !important;
    background: transparent !important;
}

.home-dashboard .dash-grid {
    gap: var(--home-dashboard-gap);
    grid-template-columns: minmax(0, 1.45fr) minmax(22rem, 0.95fr);
    width: 100%;
    max-width: none;
    padding: 0 !important;
    align-items: start;
}

.home-dashboard .dash-primary,
.home-dashboard .dash-secondary {
    display: grid;
    align-content: start;
    gap: var(--home-dashboard-gap);
    min-width: 0;
    overflow: visible;
    background: transparent !important;
}

.home-dashboard .dash-secondary {
    background: transparent !important;
}

.home-dashboard .dash-section {
    margin: 0;
    overflow: hidden;
}

.home-dashboard .dash-section .dashboard-card-header {
    padding: var(--home-card-y) var(--home-card-x) !important;
}

.home-dashboard .dash-section .dashboard-card-body {
    padding: 0 !important;
}

.home-dashboard .auction-dormant-summary {
    padding: var(--home-card-y) var(--home-card-x);
    background: var(--surface-row);
    border-top: 1px solid var(--line-faint);
}

.home-dashboard .transaction-item-compact,
.home-dashboard .topic-list-item {
    padding: 0.75rem var(--home-card-x);
}

.home-dashboard .calendar-events {
    gap: 0.45rem;
    padding: 0 var(--home-card-x) var(--home-card-y);
}

.home-dashboard .calendar-row {
    padding: 0.45rem 0.55rem;
}

.home-dashboard .transaction-content-two-line {
    gap: 0.16rem;
    font-size: 0.8125rem;
    line-height: 1.32;
}

.home-dashboard .transaction-player-compact {
    font-size: 0.875rem;
    font-weight: 650;
    line-height: 1.2;
}

.home-dashboard .transaction-position-compact {
    font-size: 0.625rem;
    padding: 0.06rem 0.32rem;
}

.home-dashboard .transaction-action-compact {
    color: var(--text-secondary) !important;
}

.home-dashboard .transaction-time-compact,
.home-dashboard .calendar-when,
.home-dashboard .last-activity {
    color: var(--text-tertiary) !important;
}

.dash-primary,
.dash-secondary {
    border: 0 !important;
    min-width: 0;
}

.dashboard-card-header,
.history-panel-header,
.summary-header,
.matchup-footer,
.team-section-header {
    background: color-mix(in srgb, var(--surface-module-strong) 78%, transparent) !important;
    border-color: var(--line-faint) !important;
}

.dashboard-card-title,
.history-panel h2,
.summary-header h5 {
    color: var(--text-primary) !important;
    font-weight: 720 !important;
    letter-spacing: 0 !important;
}

.transaction-item,
.auction-item,
.discussion-item,
.thread-item,
.topic-list-item,
.player-score-row,
.matchup-team {
    background: transparent !important;
    border-color: var(--line-faint) !important;
}

.transaction-item:hover,
.auction-item:hover,
.discussion-item:hover,
.thread-item:hover,
.topic-list-item:hover,
.player-score-row:hover,
.matchup-team:hover {
    background: var(--surface-row-hover) !important;
}

.discussion-item.selected,
.thread-item.active,
.topic-list-item.selected {
    background: var(--surface-selected) !important;
    border-left-color: var(--accent-primary) !important;
}

.message-composer,
.topic-thread-viewer .message-composer,
.thread-page-composer {
    background: color-mix(in srgb, var(--surface-module) 92%, transparent) !important;
    border-color: var(--line-default) !important;
}

.message-input-container,
.topic-thread-viewer .message-input-container,
.thread-page-input-shell {
    background: color-mix(in srgb, var(--surface-control) 88%, transparent) !important;
    border-color: var(--line-default) !important;
    border-radius: var(--control-radius) !important;
}

.message-body,
.topic-message-content,
.thread-body.message-content,
.thread-page-message-body {
    background: color-mix(in srgb, var(--surface-sheet) 92%, transparent) !important;
    color: var(--text-primary) !important;
    border: 1px solid var(--line-faint) !important;
    border-radius: var(--panel-radius) !important;
    box-shadow: var(--shadow-xs) !important;
}

.own-message .message-body {
    background: color-mix(in srgb, var(--accent-primary) 26%, var(--surface-sheet) 74%) !important;
    color: var(--text-primary) !important;
    border-color: color-mix(in srgb, var(--accent-primary) 34%, var(--line-faint)) !important;
}

/* Inline images pasted/dropped into the composer. Defined globally (not scoped) because
   message bodies are rendered via MarkupString and carry no scoped-CSS attribute. */
.mrkdwn-image-link {
    display: inline-block;
    margin: 0.35rem 0;
    max-width: 100%;
}

.mrkdwn-image {
    display: block;
    max-width: min(100%, 420px);
    max-height: 420px;
    height: auto;
    width: auto;
    border: 1px solid var(--line-default);
    border-radius: var(--radius-sm);
    background: var(--surface-2);
}

.topic-thread-viewer,
.thread-panel,
.thread-page,
.forums-shell-container {
    background: transparent !important;
}

.topic-thread-header,
.thread-page-header,
.forums-sidebar-light,
.topics-panel,
.messages-panel,
.forums-shell-sidebar,
.forums-shell-topics,
.forums-shell-messages {
    background: color-mix(in srgb, var(--surface-module-soft) 88%, transparent) !important;
    border-color: var(--line-default) !important;
}

.topic-item,
.thread-message,
.thread-page-message {
    border-color: var(--line-faint) !important;
}

.topic-item:hover,
.thread-message:hover,
.thread-page-message:hover {
    background: var(--surface-row-hover) !important;
}

.topic-item.selected {
    background: var(--surface-selected) !important;
}

.archive-table-wrap,
.rankings-card,
.summary-card {
    overflow: hidden;
}

.archive-table thead th,
.rankings-table thead,
.standings-archive-table thead th,
.franchise-archive-table thead th {
    background: color-mix(in srgb, var(--surface-module-strong) 88%, transparent) !important;
    border-color: var(--line-faint) !important;
}

.archive-table tbody tr:hover,
.rankings-table tbody tr:hover {
    background: var(--surface-row-hover) !important;
}

.rankings-stat-card {
    min-height: 6.5rem;
}

.rankings-stat-card h4,
.stat-card h3,
.summary-value,
.team-stats-number {
    font-family: var(--font-mono) !important;
    font-variant-numeric: tabular-nums;
    letter-spacing: 0 !important;
}

.rankings-stat-card small,
.stat-card small,
.stat-label,
.team-stat-label {
    letter-spacing: 0 !important;
}

@media (max-width: 1024px) {
    .dash-grid,
    .home-dashboard .dash-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    article.content > .container-fluid.py-4,
    .dynasty-page,
    .app-dashboard,
    .home-dashboard {
        padding: 0 !important;
    }

    .home-dashboard .app-dashboard {
        padding: 1rem !important;
    }

    article.content > .container-fluid.py-4 > .page-header:first-child,
    .dynasty-page > .page-header:first-child,
    .dynasty-page > .d-flex.justify-content-between:first-child {
        align-items: flex-start;
        gap: 0.875rem;
    }
}

/* Mobile-only roster meta — surfaces contract year/salary/status in the Name
   cell on phones where the dedicated columns are hidden (<768px). */
.roster-mobile-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.3rem;
    margin-top: 0.2rem;
    font-size: 0.78rem;
    color: var(--text-secondary);
}
.roster-mobile-meta .rmm-yr { font-weight: 700; color: var(--text-secondary); }
.roster-mobile-meta .rmm-sal { font-variant-numeric: tabular-nums; }
.roster-mobile-meta .rmm-sep { opacity: 0.5; }
.roster-mobile-meta .status-badge { font-size: 0.68rem; padding: 0.1rem 0.35rem; }

/* Team subtext under the player name (NFL team) — lift from tertiary to
   secondary so it clears WCAG contrast on the darker themes. */
.dynasty-roster-grid .player-name-cell small.text-muted { color: var(--text-secondary) !important; }

/* ===== Mobile dashboard polish (phones) ===== */
@media (max-width: 480px) {
    /* Transaction rows: let the bottom line wrap instead of hard-clipping the
       franchise name + time (the most useful info). */
    .transaction-bottom-line { flex-wrap: wrap; white-space: normal; }
    .transaction-time-compact { margin-left: 0; }
    .transaction-franchise-compact { min-width: 0; overflow: hidden; text-overflow: ellipsis; }
    /* Tighter auction rows so the bid block isn't squeezed. */
    .dash-section .auction-item { padding: 0.625rem 1rem; }
    .auction-avatar { width: 40px !important; height: 40px !important; margin-right: 0.625rem; }
}

/* Real tap area for widget header action links ("View All" / "View History"). */
.dashboard-card-action,
.auction-dormant-link {
    display: inline-flex;
    align-items: center;
    min-height: 40px;
    padding: 0.25rem 0.5rem;
    margin: -0.25rem -0.5rem;
}

/* ===== Mobile pass wave 2: tables, headers, roster actions ===== */
/* Bid history table can be wide — allow horizontal scroll on phones. */
.auction-details-page .bid-history-container { overflow-x: auto; -webkit-overflow-scrolling: touch; }

@media (max-width: 640px) {
    /* Auction header: stack image above name instead of a cramped row. */
    .auction-header-card .d-flex.flex-row { flex-wrap: wrap; }
    .auction-header-card .img-round-badge { width: 56px !important; height: 56px !important; }
    .auction-header-card h1 { font-size: 1.4rem; }

    /* Player detail header: stack photo over name. */
    .player-header .d-flex.align-items-start { flex-direction: column; align-items: center !important; text-align: center; }
    .player-header .player-photo { margin-right: 0 !important; margin-bottom: 0.75rem; max-width: 96px; }
}

/* Roster action buttons: keep a usable tap height even when compacted. */
@media (max-width: 768px) {
    .dynasty-actions .btn { min-height: 36px; }
}

/* ===========================================================================
   Compact mode — hide player photos (per-device preference)
   ---------------------------------------------------------------------------
   theme.js sets html[data-photos="hidden"] from the `ddb-photos` localStorage
   key (default "shown"). When hidden, the player-headshot column on every
   roster grid and the author avatars in chat collapse so names/density win.
   This is the only place the preference is wired into layout — no per-page
   Razor edits. All tokens below are verified-real in css/tokens.css.
   =========================================================================== */

/* --- Roster / penalty grids: collapse the leading photo column ---
   Every roster grid (main, RFA, unsigned-rookie) and the penalties grid
   renders the headshot as the first column: a <td> wrapping
   .img-round-badge-inline with an empty-title header. Collapsing both the
   photo <td> and its matching header <th> keeps the table aligned while
   freeing horizontal space for the name column. */
html[data-photos="hidden"] .dynasty-roster-grid .rz-datatable-data td:has(.img-round-badge-inline),
html[data-photos="hidden"] .penalties-grid .rz-datatable-data td:has(.img-round-badge-inline) {
    display: none !important;
}

/* Header for the photo column (always the leading column, empty title) is
   collapsed to keep the table aligned with the hidden photo cells. */
html[data-photos="hidden"] .dynasty-roster-grid .rz-datatable-header th:first-child,
html[data-photos="hidden"] .penalties-grid .rz-datatable-header th:first-child {
    display: none !important;
}

/* Belt-and-suspenders: hide the bare headshot itself in case a grid variant
   renders the photo without the .img-round-badge-inline wrapper. */
html[data-photos="hidden"] .dynasty-roster-grid img.player-avatar,
html[data-photos="hidden"] .penalties-grid img.player-avatar {
    display: none !important;
}

/* --- Chat: drop the message author avatar, give the text the space --- */
html[data-photos="hidden"] .topic-message-avatar {
    display: none !important;
}

html[data-photos="hidden"] .topic-message-row {
    gap: 0;
}

/* --- Mobile default: hide player photos + chat avatars for everyone ---
   On phones the headshots cost more horizontal space than they're worth, so
   we collapse them UNCONDITIONALLY (no toggle required) — names get the room.
   These mirror the html[data-photos="hidden"] selectors above exactly, minus
   the attribute gate, and keep the same header-cell + row-gap collapses so the
   tables and chat rows stay aligned. The #78 desktop opt-in rules above remain
   intact; this block only adds the mobile-default behavior. */
@media (max-width: 767.98px) {
    /* Roster / penalty grids: collapse the leading photo column + its header. */
    .dynasty-roster-grid .rz-datatable-data td:has(.img-round-badge-inline),
    .penalties-grid .rz-datatable-data td:has(.img-round-badge-inline) {
        display: none !important;
    }

    .dynasty-roster-grid .rz-datatable-header th:first-child,
    .penalties-grid .rz-datatable-header th:first-child {
        display: none !important;
    }

    /* Belt-and-suspenders: hide the bare headshot for grid variants without
       the .img-round-badge-inline wrapper. */
    .dynasty-roster-grid img.player-avatar,
    .penalties-grid img.player-avatar {
        display: none !important;
    }

    /* Chat: drop the message author avatar and close the row gap. */
    .topic-message-avatar {
        display: none !important;
    }

    .topic-message-row {
        gap: 0;
    }
}
