/*
 * public.css
 * Public shell, public pages, media playback, and shared public components.
 * Keep theme foundations first, then page-specific sections in cascade order.
 */

/* Ensure the HTML hidden attribute always takes effect regardless of display rules */
[hidden] {
    display: none !important;
}

/* === Variables — Light Theme (Default) === */
:root {
    --bg-primary: #f2f2f2;
    --bg-secondary: rgba(255, 255, 255, 0.85);
    --bg-tertiary: rgba(243, 202, 214, 0.15);
    --accent-purple: #7b5ba8;
    --accent-gold: #9a7bc0;
    --heading-purple-start: #9a618a;
    --heading-purple-end: #6f6aad;
    --cta-yellow-start: #e8b7c8;
    --cta-yellow-end: #b9b6d8;
    --heading-gradient: linear-gradient(
        135deg,
        var(--heading-purple-start),
        var(--heading-purple-end)
    );
    --button-gradient: linear-gradient(135deg, var(--cta-yellow-start), var(--cta-yellow-end));
    --button-foreground: #2a2a2a;
    --button-secondary-bg: rgba(255, 255, 255, 0.88);
    --button-secondary-hover: rgba(243, 202, 214, 0.32);
    --button-secondary-border: rgba(185, 182, 216, 0.5);
    --text-primary: #2a2a2a;
    --text-secondary: #6b6b6b;
    --border: rgba(185, 182, 216, 0.44);
    --glass-blur: blur(18px);
    --glass-border: 1px solid rgba(255, 255, 255, 0.62);
    --glass-shadow: 0 10px 30px rgba(186, 168, 205, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.72);
    --radius: 10px;
    --radius-lg: 18px;
    --shadow: 0 8px 24px rgba(185, 182, 216, 0.22);
    --transition: 0.2s ease;
    --scrollbar-track: rgba(185, 182, 216, 0.1);
    --scrollbar-thumb: rgba(185, 182, 216, 0.45);
    --scrollbar-thumb-hover: rgba(185, 182, 216, 0.68);
    --nav-bg: rgba(242, 242, 242, 0.92);
    --player-bg: #000;
    --button-primary-glow: rgba(185, 182, 216, 0.38);
    --card-hover-border: rgba(185, 182, 216, 0.6);
    --card-hover-shadow: 0 10px 30px rgba(186, 168, 205, 0.24), 0 2px 8px rgba(0, 0, 0, 0.04);
    --surface-card-bg: var(--bg-secondary);
    --surface-card-border: var(--glass-border);
    --surface-card-radius: var(--radius-lg);
    --surface-card-shadow: var(--glass-shadow);
    --field-bg: var(--bg-tertiary);
    --field-border: var(--glass-border);
    --danger: #e53e3e;
    --danger-bg: rgba(229, 62, 62, 0.1);
    --danger-bg-strong: rgba(229, 62, 62, 0.75);
    --danger-border: rgba(229, 62, 62, 0.3);
    --danger-border-soft: rgba(229, 62, 62, 0.2);
    --success: #15803d;
    --success-bg: rgba(34, 197, 94, 0.12);
    --success-border: rgba(34, 197, 94, 0.3);
    --warning: #ca8a04;
    --warning-bg: rgba(234, 179, 8, 0.15);
    --warning-border: rgba(234, 179, 8, 0.35);
    --info: #3b6bb6;
    --info-bg: rgba(59, 130, 246, 0.15);
    --favorite: #e05c94;
    --favorite-strong: #c93e7d;
    --favorite-on: #fff7fb;
    --favorite-bg: rgba(224, 92, 148, 0.1);
    --favorite-bg-soft: rgba(224, 92, 148, 0.08);
    --favorite-bg-medium: rgba(224, 92, 148, 0.16);
    --favorite-bg-strong: rgba(224, 92, 148, 0.2);
    --favorite-border: rgba(224, 92, 148, 0.35);
    --favorite-border-soft: rgba(224, 92, 148, 0.28);
    --favorite-border-strong: rgba(224, 92, 148, 0.5);
    --favorite-shadow: 0 10px 24px rgba(224, 92, 148, 0.22);
    --favorite-shadow-strong: 0 14px 28px rgba(224, 92, 148, 0.3);
    --muted: var(--text-secondary);
    --muted-border: rgba(148, 163, 184, 0.16);
    --muted-border-strong: rgba(148, 163, 184, 0.18);
    --shell-divider: var(--muted-border);
    --shell-active-bg: rgba(124, 58, 237, 0.07);
    --shell-active-border: rgba(124, 58, 237, 0.14);
    --media-bg: #000;
    --media-scrim: rgba(0, 0, 0, 0.55);
    --media-scrim-strong: rgba(15, 23, 42, 0.85);
    --media-overlay-bg: rgba(15, 23, 42, 0.94);
    --media-on-overlay: #fff;
    --pill-bg: var(--button-secondary-bg);
    --pill-border: var(--border);
    --pill-fg: var(--text-secondary);
    --environment-banner-bg-start: rgba(255, 236, 164, 0.95);
    --environment-banner-bg-end: rgba(244, 196, 84, 0.88);
    --environment-banner-glow: rgba(255, 250, 224, 0.72);
    --environment-banner-border: rgba(171, 122, 19, 0.24);
    --environment-banner-text: #5c4207;
}

/* === Dark Theme === */
[data-theme="dark"] {
    --bg-primary: #0b0b0f;
    --bg-secondary: rgba(22, 22, 29, 0.88);
    --bg-tertiary: rgba(42, 42, 58, 0.9);
    --accent-purple: #9d7bff;
    --accent-gold: #b29bff;
    --heading-purple-start: #b29bff;
    --heading-purple-end: #7c5cff;
    --cta-yellow-start: #7c5cff;
    --cta-yellow-end: #9d7bff;
    --heading-gradient: linear-gradient(
        135deg,
        var(--heading-purple-start),
        var(--heading-purple-end)
    );
    --button-gradient: linear-gradient(135deg, var(--cta-yellow-start), var(--cta-yellow-end));
    --button-foreground: #eaeaf2;
    --button-secondary-bg: rgba(42, 42, 58, 0.42);
    --button-secondary-hover: rgba(42, 42, 58, 0.65);
    --button-secondary-border: rgba(178, 155, 255, 0.28);
    --text-primary: #eaeaf2;
    --text-secondary: #9a9aaf;
    --border: rgba(178, 155, 255, 0.28);
    --glass-border: 1px solid rgba(178, 155, 255, 0.18);
    --glass-shadow:
        0 0 0 1px rgba(178, 155, 255, 0.18), 0 0 24px rgba(157, 123, 255, 0.14),
        0 18px 50px rgba(0, 0, 0, 0.38), inset 0 1px 0 rgba(255, 255, 255, 0.04);
    --shadow: 0 10px 28px rgba(0, 0, 0, 0.35);
    --scrollbar-track: rgba(178, 155, 255, 0.06);
    --scrollbar-thumb: rgba(124, 92, 255, 0.46);
    --scrollbar-thumb-hover: rgba(157, 123, 255, 0.65);
    --nav-bg: rgba(11, 11, 15, 0.92);
    --button-primary-glow: rgba(124, 92, 255, 0.38);
    --card-hover-border: rgba(178, 155, 255, 0.45);
    --card-hover-shadow:
        0 0 0 1px rgba(178, 155, 255, 0.2), 0 12px 32px rgba(124, 92, 255, 0.2),
        0 2px 8px rgba(0, 0, 0, 0.3);
    --danger: #f87171;
    --danger-bg: rgba(239, 68, 68, 0.15);
    --danger-bg-strong: rgba(229, 62, 62, 0.75);
    --danger-border: rgba(239, 68, 68, 0.35);
    --danger-border-soft: rgba(239, 68, 68, 0.22);
    --success: #4ade80;
    --success-bg: rgba(34, 197, 94, 0.22);
    --success-border: rgba(34, 197, 94, 0.36);
    --warning: #fbbf24;
    --warning-bg: rgba(245, 158, 11, 0.15);
    --warning-border: rgba(245, 158, 11, 0.35);
    --info: #60a5fa;
    --info-bg: rgba(59, 130, 246, 0.15);
    --favorite: #f0a0c4;
    --favorite-strong: #e05c94;
    --favorite-on: #fff7fb;
    --favorite-bg: rgba(224, 92, 148, 0.12);
    --favorite-bg-soft: rgba(224, 92, 148, 0.08);
    --favorite-bg-medium: rgba(224, 92, 148, 0.16);
    --favorite-bg-strong: rgba(224, 92, 148, 0.2);
    --favorite-border: rgba(224, 92, 148, 0.35);
    --favorite-border-soft: rgba(224, 92, 148, 0.28);
    --favorite-border-strong: rgba(224, 92, 148, 0.5);
    --favorite-shadow: 0 10px 24px rgba(224, 92, 148, 0.18);
    --favorite-shadow-strong: 0 14px 28px rgba(224, 92, 148, 0.24);
    --muted: var(--text-secondary);
    --muted-border: rgba(148, 163, 184, 0.16);
    --muted-border-strong: rgba(148, 163, 184, 0.18);
    --shell-divider: var(--muted-border);
    --shell-active-bg: rgba(124, 92, 255, 0.12);
    --shell-active-border: rgba(178, 155, 255, 0.22);
    --media-bg: #000;
    --media-scrim: rgba(0, 0, 0, 0.55);
    --media-scrim-strong: rgba(15, 23, 42, 0.85);
    --media-overlay-bg: rgba(15, 23, 42, 0.94);
    --media-on-overlay: #fff;
    --pill-bg: var(--button-secondary-bg);
    --pill-border: var(--border);
    --pill-fg: var(--text-secondary);
    --environment-banner-bg-start: rgba(168, 119, 10, 0.96);
    --environment-banner-bg-end: rgba(245, 191, 52, 0.88);
    --environment-banner-glow: rgba(255, 235, 166, 0.2);
    --environment-banner-border: rgba(255, 219, 119, 0.2);
    --environment-banner-text: #fff4cf;
}

/* === Reset === */
*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
    scrollbar-width: thin;
}

body,
* {
    scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
    scrollbar-width: thin;
}

html::-webkit-scrollbar,
body::-webkit-scrollbar,
*::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

html::-webkit-scrollbar-track,
body::-webkit-scrollbar-track,
*::-webkit-scrollbar-track {
    background: var(--scrollbar-track);
    border-radius: 999px;
}

html::-webkit-scrollbar-thumb,
body::-webkit-scrollbar-thumb,
*::-webkit-scrollbar-thumb {
    background: var(--scrollbar-thumb);
    border-radius: 999px;
    border: 2px solid var(--scrollbar-track);
}

html::-webkit-scrollbar-thumb:hover,
body::-webkit-scrollbar-thumb:hover,
*::-webkit-scrollbar-thumb:hover {
    background: var(--scrollbar-thumb-hover);
}

body {
    font-family:
        Figtree,
        -apple-system,
        BlinkMacSystemFont,
        "Segoe UI",
        sans-serif;
    font-weight: 400;
    letter-spacing: -0.01em;
    background: linear-gradient(135deg, #f2f2f2 0%, #ebe5f5 46%, #f6eef2 100%);
    background-attachment: fixed;
    color: var(--text-primary);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    line-height: 1.6;
}

[data-theme="dark"] body {
    background: linear-gradient(135deg, #0b0b0f 0%, #120f1f 48%, #0e0b18 100%);
}

h1,
h2 {
    font-family:
        Sora,
        -apple-system,
        BlinkMacSystemFont,
        "Segoe UI",
        sans-serif;
}

a {
    color: var(--accent-purple);
    text-decoration: none;
    transition: color var(--transition);
}

a:hover {
    color: var(--accent-gold);
}

img {
    max-width: 100%;
    height: auto;
}

:focus-visible {
    outline: 2px solid var(--accent-purple);
    outline-offset: 2px;
    border-radius: var(--radius);
}

/* === Glass Utility === */
.glass {
    background: var(--bg-secondary);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: var(--glass-border);
    box-shadow: var(--glass-shadow);
    border-radius: var(--radius-lg);
}

/* === Background Symbols === */
#bg-symbols {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    overflow: hidden;

    /* Fade toward top and bottom edges */
    mask-image: linear-gradient(to bottom, transparent 0%, black 12%, black 88%, transparent 100%);
    -webkit-mask-image: linear-gradient(
        to bottom,
        transparent 0%,
        black 12%,
        black 88%,
        transparent 100%
    );
}

#bg-symbols::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    background: rgba(240, 238, 242, 0.48);
}

[data-theme="dark"] #bg-symbols::after {
    background: rgba(11, 11, 15, 0.48);
}

#bg-symbols span {
    position: absolute;
    bottom: -10%;
    display: inline-block;
    pointer-events: none;
    user-select: none;
    will-change: transform, opacity;
    animation: bg-symbol-float linear infinite;
}

/* Light mode: lavender and rose against neutral background */
#bg-symbols span.sym-gold {
    color: #8c87bd;
}

#bg-symbols span.sym-white {
    color: #c897aa;
}

/* Dark mode: electric violet and soft glow */
[data-theme="dark"] #bg-symbols span.sym-gold {
    color: #7c5cff;
}

[data-theme="dark"] #bg-symbols span.sym-white {
    color: #b29bff;
}

@keyframes bg-symbol-float {
    0% {
        transform: translateY(0) translateX(0);
        opacity: 0;
    }

    8% {
        opacity: var(--sym-op);
    }

    92% {
        opacity: var(--sym-op);
    }

    100% {
        transform: translateY(var(--sym-rise)) translateX(var(--sym-drift));
        opacity: 0;
    }
}

@keyframes ui-gradient-shift {
    0% {
        background-position: 0% 50%;
    }

    50% {
        background-position: 100% 50%;
    }

    100% {
        background-position: 0% 50%;
    }
}

@keyframes ui-gradient-shift-dual {
    0% {
        background-position:
            0% 50%,
            0% 50%;
    }

    50% {
        background-position:
            100% 50%,
            100% 50%;
    }

    100% {
        background-position:
            0% 50%,
            0% 50%;
    }
}

/* === Navbar === */
.navbar {
    position: sticky;
    top: 0;
    z-index: 100;
    background: var(--nav-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border-bottom: 1px solid var(--border);
}

.environment-banner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.7rem 1.25rem;
    text-align: center;
    color: var(--environment-banner-text);
    background:
        linear-gradient(135deg, var(--environment-banner-glow), transparent 56%),
        linear-gradient(90deg, var(--environment-banner-bg-start), var(--environment-banner-bg-end));
    border-bottom: 1px solid var(--environment-banner-border);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.25),
        0 8px 18px rgba(0, 0, 0, 0.05);
}

.environment-banner strong {
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.environment-banner span {
    max-width: 62rem;
    font-size: 0.92rem;
    line-height: 1.45;
}

.environment-banner-public {
    padding-inline: 1.5rem;
}

.nav-content {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 1.5rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    height: 68px;
}

.nav-logo {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    color: var(--text-primary);
    font-family:
        Sora,
        -apple-system,
        BlinkMacSystemFont,
        "Segoe UI",
        sans-serif;
    font-weight: 700;
    font-size: 1.05rem;
    letter-spacing: -0.02em;
    flex-shrink: 0;
}

.nav-logo:hover {
    color: var(--accent-purple);
}

.nav-logo img {
    height: 34px;
    width: 34px;
}

.nav-links {
    display: flex;
    list-style: none;
    gap: 0.15rem;
    margin-left: 0;
    flex-shrink: 0;
}

.nav-links a {
    color: var(--text-secondary);
    padding: 0.45rem 0.9rem;
    border-radius: 999px;
    transition: all var(--transition);
    font-weight: 600;
    font-size: 0.9rem;
    position: relative;
}

.nav-links a:hover {
    color: var(--text-primary);
    background: var(--bg-tertiary);
}

.nav-links a.active {
    color: var(--accent-purple);
    background: rgba(185, 182, 216, 0.22);
    font-weight: 700;
}

[data-theme="dark"] .nav-links a.active {
    background: rgba(124, 92, 255, 0.12);
}

.nav-right {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.nav-search {
    position: relative;
    display: flex;
    align-items: center;
    min-width: 0;
    width: 100%;
}

.nav-search-desktop {
    margin-left: auto;
    max-width: 300px;
    width: 100%;
    min-width: 0;
}

.nav-search-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: 999px;
    color: var(--text-primary);
    cursor: pointer;
    transition: all var(--transition);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
}

.nav-search-toggle:hover,
.nav-search-toggle:focus-visible {
    border-color: var(--accent-purple);
    color: var(--accent-purple);
}

.nav-search-form {
    position: relative;
    width: 100%;
    max-width: none;
    flex: 1;
    min-width: 0;
}

.nav-search-form .search-input {
    width: 100%;
    padding-right: 1rem;
}

.nav-search-mobile-toggle {
    display: none;
}

.theme-toggle {
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: 999px;
    width: 38px;
    height: 38px;
    padding: 0;
    cursor: pointer;
    font-size: 1rem;
    line-height: 1;
    color: var(--text-secondary);
    transition: all var(--transition);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.theme-toggle:hover {
    border-color: var(--accent-purple);
    color: var(--accent-purple);
    background: var(--bg-tertiary);
}

/* Show sun in dark mode, moon in light mode */
.theme-icon-dark {
    display: block;
    vertical-align: middle;
}

.theme-icon-light {
    display: none;
    vertical-align: middle;
}

[data-theme="dark"] .theme-icon-dark {
    display: none;
}

[data-theme="dark"] .theme-icon-light {
    display: block;
}

.search-modal {
    position: fixed;
    inset: 0;
    z-index: 250;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 4.5rem 1rem 1rem;
}

.search-modal[hidden] {
    display: none;
}

.search-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.56);
}

.search-modal-panel {
    position: relative;
    width: min(100%, 760px);
    z-index: 1;
    padding: 0.875rem;
}

.search-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.75rem;
}

.search-modal-header h2 {
    margin: 0;
    font-size: 1rem;
}

.search-modal-close {
    width: 36px;
    height: 36px;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: var(--bg-secondary);
    color: var(--text-secondary);
    cursor: pointer;
    font-size: 1.2rem;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition);
    flex-shrink: 0;
}

.search-modal-form {
    position: relative;
    width: 100%;
}

.site-dialog {
    position: fixed;
    inset: 0;
    z-index: 1200;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.site-dialog-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(12, 8, 23, 0.58);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.site-dialog-panel {
    position: relative;
    z-index: 1;
    width: min(100%, 420px);
    padding: 1.35rem 1.35rem 1.25rem;
}

.site-dialog-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.75rem;
}

.site-dialog-header h2 {
    margin: 0;
    font-size: 1.05rem;
}

.site-dialog-close {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: var(--bg-secondary);
    color: var(--text-primary);
    cursor: pointer;
    font-size: 1.4rem;
    line-height: 1;
}

.site-dialog-copy {
    color: var(--text-secondary);
    margin-bottom: 1rem;
}

.site-dialog-panel-wide {
    width: min(100%, 600px);
}

.site-dialog-body {
    color: var(--text-secondary);
    margin-bottom: 1rem;
    max-height: 60vh;
    overflow-y: auto;
}

.site-dialog-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    flex-wrap: wrap;
}

body.site-dialog-open {
    overflow: hidden;
}

.changelog-notify-entry {
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--border);
}

.changelog-notify-entry:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.changelog-notify-entry:first-child {
    padding-top: 0;
}

.changelog-notify-meta {
    font-size: 0.78rem;
    color: var(--text-secondary);
    margin-bottom: 0.2rem;
}

.changelog-notify-title {
    display: block;
    font-size: 0.97rem;
    color: var(--text-primary);
    margin-bottom: 0.4rem;
}

.changelog-notify-list {
    margin: 0;
    padding-left: 1.25rem;
    font-size: 0.88rem;
    color: var(--text-secondary);
    line-height: 1.6;
}

.error-popup-details {
    background: var(--bg-tertiary);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 0.75rem;
    font-size: 0.78rem;
    line-height: 1.5;
    white-space: pre-wrap;
    word-break: break-all;
    color: var(--text-secondary);
    margin: 0 0 1rem;
    max-height: 160px;
    overflow-y: auto;
}

.nav-toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
}

.nav-toggle span {
    display: block;
    width: 24px;
    height: 2px;
    background: var(--text-primary);
    border-radius: 2px;
    transition: all var(--transition);
}

/* === Main Content === */
.main-content {
    position: relative;
    z-index: 1;
    flex: 1;
    max-width: 1400px;
    width: 100%;
    margin: 0 auto;
    padding: 2rem 1.5rem;
}

.glass-card {
    background: var(--bg-secondary);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: var(--glass-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--glass-shadow);
    padding: 1.5rem;
    position: relative;
}

/* === Surface Primitives === */
.home-card,
.discovery-sidebar-card,
.discovery-empty,
.vod-card,
.chat-panel,
.model-card,
.model-info-card,
.model-toggles,
.karaoke-card,
.random-image-card,
.random-controls-card,
.user-nav-dropdown {
    background: var(--surface-card-bg);
    border: var(--surface-card-border);
    border-radius: var(--surface-card-radius);
    box-shadow: var(--surface-card-shadow);
}

.admin-login-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 60vh;
    padding: 2rem 1rem;
}

.admin-login-card {
    width: 100%;
    max-width: 380px;
}

.admin-login-title {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 1.25rem;
}

.admin-login-error {
    color: var(--danger);
    font-size: 0.875rem;
    margin-bottom: 1rem;
    padding: 0.5rem 0.75rem;
    background: var(--danger-bg);
    border: 1px solid var(--danger-border);
    border-radius: var(--radius);
}

.admin-login-form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.admin-form-group {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.admin-form-group label {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-secondary);
}

.admin-input {
    padding: 0.55rem 0.9rem;
    border-radius: var(--radius);
    border: var(--glass-border);
    background: var(--bg-tertiary);
    color: var(--text-primary);
    font-size: 0.95rem;
    font-family: inherit;
    outline: none;
    transition: border-color var(--transition);
}

.admin-input:focus {
    border-color: var(--accent-purple);
}

.admin-login-btn {
    margin-top: 0.25rem;
    width: 100%;
    justify-content: center;
}

.page-header {
    margin-bottom: 2rem;
}

.page-header h1,
.mobile-discovery-header h1,
.model-detail-info h1,
.home-hero h1,
.error-page h1 {
    font-size: 2.1rem;
    font-weight: 700;
    letter-spacing: -0.025em;
    background: var(--heading-gradient);
    background-size: 200% 200%;
    animation: ui-gradient-shift 14s ease-in-out infinite;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.page-subtitle {
    color: var(--text-secondary);
    margin-top: 0.25rem;
}

.back-link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    color: var(--text-secondary);
    margin-bottom: 1.25rem;
    font-size: 0.82rem;
    font-weight: 500;
    padding: 0.3rem 0.6rem 0.3rem 0.45rem;
    border-radius: 999px;
    border: 1px solid transparent;
    transition: all var(--transition);
}

.back-link svg {
    width: 0.85rem;
    height: 0.85rem;
    flex-shrink: 0;
    stroke: currentcolor;
    stroke-width: 2.2;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
}

.back-link:hover {
    color: var(--accent-purple);
    border-color: var(--border);
    background: var(--bg-secondary);
}

/* === Buttons === */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    padding: 0.52rem 1.2rem;
    border-radius: var(--radius);
    border: 1px solid var(--button-secondary-border);
    font-size: 0.88rem;
    font-weight: 600;
    letter-spacing: 0.01em;
    cursor: pointer;
    transition: all var(--transition);
    text-decoration: none;
    color: var(--text-primary);
    background: var(--button-secondary-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    box-shadow: 0 2px 8px rgba(178, 155, 255, 0.08);
    white-space: nowrap;
}

.btn:hover {
    background: var(--button-secondary-hover);
    color: var(--text-primary);
    border-color: var(--accent-purple);
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(178, 155, 255, 0.16);
}

.btn-secondary {
    background: var(--button-secondary-bg);
    border-color: var(--button-secondary-border);
}

.btn-primary {
    border: 1.5px solid transparent;
    border-radius: calc(var(--radius) + 2px);
    background:
        var(--button-gradient) padding-box,
        var(--button-gradient) border-box;
    background-size:
        200% 200%,
        200% 200%;
    animation: ui-gradient-shift-dual 8s ease-in-out infinite;
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    color: var(--button-foreground);
    text-shadow: none;
    box-shadow: 0 8px 20px var(--button-primary-glow);
}

[data-theme="dark"] .btn-primary {
    box-shadow:
        0 0 0 1px rgba(178, 155, 255, 0.25),
        0 0 12px rgba(124, 92, 255, 0.3),
        0 8px 20px rgba(0, 0, 0, 0.25);
}

.btn-primary:hover,
.btn-primary:focus {
    background:
        var(--button-gradient) padding-box,
        var(--button-gradient) border-box;
    color: var(--button-foreground);
    filter: brightness(1.08);
    border-color: transparent;
    transform: translateY(-1px);
}

.btn-sm {
    padding: 0.28rem 0.7rem;
    font-size: 0.78rem;
}

.btn-large {
    padding: 0.85rem 2.25rem;
    font-size: 1rem;
    font-weight: 700;
    border-radius: 999px;
    letter-spacing: 0.02em;
}

/* === Hero (Home) === */
.hero {
    display: flex;
    justify-content: center;
    margin-bottom: 3rem;
}

.hero-image {
    max-height: 500px;
    width: auto;
    border-radius: var(--radius-lg);
    box-shadow: var(--glass-shadow);
}

.home-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
    gap: 2rem;
    padding: 2rem;
    align-items: center;
    margin-bottom: 2rem;
}

.home-hero-copy {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.home-eyebrow {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    color: var(--accent-purple);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin-bottom: 0.4rem;
}

.home-section-kicker {
    color: var(--accent-purple);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.home-hero h1 {
    font-size: clamp(2.8rem, 6vw, 5rem);
    line-height: 1;
    letter-spacing: -0.02em;
    margin: 0 0 0.75rem;
    padding-bottom: 0.08em;
}

.home-hero-text {
    color: var(--text-secondary);
    font-size: 1.05rem;
    max-width: 42rem;
}

.home-hero-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-top: 1.5rem;
}

.home-hero-media {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
}

.home-hero-socials-badge {
    width: 100%;
    padding: 0.75rem 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.home-hero-socials-label {
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.home-hero-socials-links {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.home-hero-social-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    border: 1px solid var(--pill-border);
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0.2rem 0.65rem;
    text-decoration: none;
}

.home-hero-social-pill:hover {
    filter: brightness(1.15);
}

.home-hero-social-pill-twitch {
    background: var(--shell-active-bg);
    color: var(--accent-purple);
}

.home-hero-social-pill-youtube {
    background: var(--danger-bg);
    color: var(--danger);
}

.home-hero-social-pill-x {
    background: var(--pill-bg);
    border-color: var(--text-secondary);
    color: var(--pill-fg);
}

.home-section {
    margin-bottom: 2rem;
}

.home-section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
}

.home-section-header h2 {
    margin-top: 0.1rem;
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.home-cards {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 1.5rem;
    max-width: 1400px;
    margin: 0 auto;
}

.home-card {
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    padding: 1.75rem 1.25rem;
    text-align: center;
    color: var(--text-primary);
    transition: all var(--transition);
}

.home-card:hover {
    border-color: var(--card-hover-border);
    transform: translateY(-2px);
    box-shadow: var(--card-hover-shadow);
    color: var(--text-primary);
}

.home-card-icon {
    margin-bottom: 0.85rem;
    color: var(--accent-purple);
    display: flex;
    justify-content: center;
    opacity: 0.85;
}

.home-card-icon svg {
    width: 1.75rem;
    height: 1.75rem;
}

.home-card:hover .home-card-icon {
    opacity: 1;
}

.home-card h2 {
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: -0.015em;
    margin-bottom: 0.4rem;
}

.home-card p {
    color: var(--text-secondary);
    font-size: 0.82rem;
    line-height: 1.5;
}

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

.home-model-list,
.home-karaoke-list,
.home-random-list {
    display: grid;
    gap: 0.75rem;
}

.home-entity-card,
.home-random-card {
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr);
    gap: 0.85rem;
    align-items: center;
    padding: 0.75rem;
    border-radius: var(--radius);
    border: 1px solid var(--border);
    background: var(--bg-secondary);
    color: var(--text-primary);
}

.home-entity-card:hover,
.home-random-card:hover {
    color: var(--text-primary);
    border-color: var(--accent-purple);
}

.home-entity-card img,
.home-random-card img {
    width: 92px;
    height: 92px;
    border-radius: calc(var(--radius) + 2px);
    background: var(--bg-tertiary);
}

.home-entity-card img {
    object-fit: contain;
    padding: 0.2rem;
}

.home-random-card img {
    object-fit: cover;
}

.home-random-media {
    width: 92px;
    height: 92px;
    border-radius: calc(var(--radius) + 2px);
    background: var(--bg-tertiary);
}

.home-random-media-label {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--accent-purple);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.home-entity-copy,
.home-random-copy {
    display: grid;
    gap: 0.25rem;
}

.home-entity-copy span:last-child,
.home-random-copy span {
    color: var(--text-secondary);
    font-size: 0.88rem;
}

.home-entity-kicker {
    color: var(--accent-purple);
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.home-resume-meta {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 0.75rem;
    color: var(--text-secondary);
    font-size: 0.82rem;
    font-weight: 700;
}

.resume-progress-bar {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 5px;
    background: rgba(15, 23, 42, 0.28);
    z-index: 2;
}

.resume-progress-bar span {
    display: block;
    height: 100%;
    background: var(--button-gradient);
}

.vod-card-resume .vod-thumbnail {
    position: relative;
}

.vod-card-shell {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    min-width: 0;
    position: relative;
}

.vod-card.has-resume-state {
    border-color: rgba(185, 182, 216, 0.35);
    box-shadow: 0 16px 36px rgba(178, 155, 255, 0.1);
}

.vod-card-actions {
    display: flex;
    gap: 0.5rem;
    flex-wrap: nowrap;
    margin-top: auto;
}

.vod-card-actions .btn {
    flex: 1 1 0;
    width: 100%;
    justify-content: center;
}

.vod-card-resume-meta {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    margin-top: 0.75rem;
    color: var(--accent-purple);
    font-size: 0.8rem;
    font-weight: 700;
}

/* === VODs === */
.discovery-page-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.discovery-header-actions {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.discovery-shell {
    display: grid;
    grid-template-columns: minmax(250px, 300px) minmax(0, 1fr);
    gap: 1.5rem;
    align-items: start;
}

.discovery-sidebar {
    position: sticky;
    top: 88px;
    align-self: start;
    height: fit-content;
}

#vod-discovery-sidebar {
    position: static;
    top: auto;
}

.discovery-sidebar-card,
.discovery-empty {
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    padding: 1.1rem 1.15rem;
}

.discovery-sidebar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.discovery-sidebar-header h2,
.discovery-section h3,
.discovery-empty h2 {
    margin: 0;
    font-family:
        Figtree,
        -apple-system,
        BlinkMacSystemFont,
        "Segoe UI",
        sans-serif;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.discovery-section + .discovery-section {
    margin-top: 1.25rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--border);
}

.discovery-field,
.discovery-check {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    color: var(--text-primary);
    font-weight: 600;
}

.discovery-check {
    flex-direction: row;
    align-items: center;
    gap: 0.65rem;
    font-weight: 500;
}

.discovery-check + .discovery-check,
.discovery-field + .discovery-field {
    margin-top: 0.65rem;
}

.discovery-check input {
    width: 1rem;
    height: 1rem;
    accent-color: var(--accent-purple);
}

.discovery-field span,
.discovery-results-meta,
.discovery-empty p {
    color: var(--text-secondary);
}

.discovery-apply {
    margin-top: 0.85rem;
}

.discovery-field-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.discovery-field-row .discovery-field + .discovery-field {
    margin-top: 0;
}

.discovery-main {
    min-width: 0;
}

.discovery-main-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.discovery-main-header h1 {
    font-size: 1.8rem;
    font-weight: 700;
    letter-spacing: -0.025em;
    margin: 0 0 0.1rem;
    background: var(--heading-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.discovery-main-subtitle {
    color: var(--text-secondary);
    font-size: 0.88rem;
    margin: 0;
}

.models-page-header {
    margin-bottom: 1.25rem;
}

.models-page-header h1 {
    font-size: 1.8rem;
    font-weight: 700;
    letter-spacing: -0.025em;
    margin: 0 0 0.1rem;
    background: var(--heading-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.models-toolbar {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-bottom: 1.25rem;
}

.models-toolbar .search-field {
    flex: 1;
    min-width: 180px;
}

.models-toolbar-select {
    width: auto;
    min-width: 130px;
    flex-shrink: 0;
    height: 44px;
}

.discovery-toolbar {
    display: flex;
    align-items: center;
    gap: 1rem;
    justify-content: space-between;
    margin-bottom: 1.25rem;
}

.discovery-toolbar .search-field {
    flex: 1;
}

.discovery-results-meta {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.2rem;
    font-size: 0.9rem;
    white-space: nowrap;
}

.discovery-mobile-toggle,
.discovery-sidebar-close {
    display: none;
}

.mobile-discovery-page {
    max-width: 720px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.mobile-discovery-header {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.mobile-discovery-header h1 {
    margin: 0;
}

.mobile-discovery-form {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.mobile-discovery-actions {
    display: flex;
    gap: 0.75rem;
    justify-content: flex-end;
    flex-wrap: wrap;
    margin-top: 1.25rem;
}

.discovery-advanced {
    margin-top: 0.65rem;
}

.discovery-advanced summary {
    cursor: pointer;
    font-weight: 700;
    color: var(--text-primary);
}

.discovery-advanced .discovery-field {
    margin-top: 0.75rem;
}

.discovery-empty {
    padding: 1.5rem;
}

.discovery-select {
    cursor: pointer;
    padding-right: 2.5rem;
}

.search-field {
    position: relative;
    flex: 1;
    display: flex;
    align-items: stretch;
}

.search-input {
    flex: 1;
    width: 100%;
    padding: 0.5rem 2.75rem 0.5rem 1rem;
    height: 44px;
    min-height: 44px;
    border-radius: var(--radius);
    border: 2px solid var(--border);
    background: var(--bg-secondary);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    color: var(--text-primary);
    font: inherit;
    line-height: 1.2;
    font-size: 0.95rem;
    font-weight: 600;
    outline: none;
    transition: border-color var(--transition);
    box-sizing: border-box;
}

select,
input[type="date"],
input[type="number"] {
    font: inherit;
}

select,
.discovery-select,
.admin-field select,
.admin-log-control select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image:
        linear-gradient(45deg, transparent 50%, var(--text-secondary) 50%),
        linear-gradient(135deg, var(--text-secondary) 50%, transparent 50%);
    background-position:
        calc(100% - 1.1rem) calc(50% - 2px),
        calc(100% - 0.75rem) calc(50% - 2px);
    background-size:
        0.4rem 0.4rem,
        0.4rem 0.4rem;
    background-repeat: no-repeat;
    padding-right: 2.5rem;
    color: var(--text-primary);
}

select option {
    background: var(--bg-secondary);
    color: var(--text-primary);
}

input[type="date"] {
    appearance: none;
    -webkit-appearance: none;
    color-scheme: dark;
    padding-right: 1rem;
}

input[type="date"]::-webkit-date-and-time-value {
    text-align: left;
}

input[type="date"]::-webkit-calendar-picker-indicator {
    cursor: pointer;
    opacity: 0.75;
    filter: invert(77%) sepia(13%) saturate(401%) hue-rotate(193deg) brightness(88%) contrast(89%);
}

input[type="number"] {
    appearance: textfield;
    -moz-appearance: textfield;
}

input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

input[name="duration_min"],
input[name="duration_max"] {
    display: block;
    width: 100%;
    height: 44px !important;
    min-height: 44px !important;
    max-height: 44px;
    margin: 0;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    line-height: 1.2;
    box-sizing: border-box;
    flex: none;
}

.search-input:focus {
    border-color: var(--accent-purple);
    border-width: 2px;
    box-shadow: 0 0 0 3px rgba(185, 182, 216, 0.28);
    outline: none;
}

[data-theme="dark"] .search-input:focus {
    box-shadow: 0 0 0 3px rgba(124, 92, 255, 0.18);
}

.search-input::placeholder {
    color: var(--text-secondary);
}

.search-input::-webkit-search-cancel-button,
.search-input::-webkit-search-decoration {
    -webkit-appearance: none;
    appearance: none;
}

.search-submit {
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    width: 2.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 0;
    border-radius: 0 var(--radius) var(--radius) 0;
    transition: color var(--transition);
}

.search-submit:hover {
    color: var(--accent-purple);
}

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

.vod-card {
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    overflow: hidden;
    color: var(--text-primary);
    transition: all var(--transition);
    display: flex;
    flex-direction: column;
    height: 100%;
}

.vod-card:hover {
    border-color: var(--card-hover-border);
    transform: translateY(-1px);
    box-shadow: var(--card-hover-shadow);
    color: var(--text-primary);
}

.vod-thumbnail {
    position: relative;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: var(--bg-tertiary);
}

.vod-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.vod-thumbnail-placeholder {
    background: linear-gradient(135deg, var(--bg-tertiary), var(--bg-secondary));
}

.vod-duration-badge {
    position: absolute;
    right: 0.75rem;
    bottom: 0.75rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.2rem 0.5rem;
    border-radius: 999px;
    background: var(--media-scrim-strong);
    color: var(--media-on-overlay);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    z-index: 2;
}

.vod-card-body {
    padding: 1rem;
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 10.75rem;
}

.vod-card-header {
    display: flex;
    justify-content: space-between;
    margin-bottom: 0.5rem;
}

.vod-number {
    color: var(--accent-purple);
    font-weight: 700;
    font-size: 0.9rem;
}

.vod-date {
    color: var(--text-secondary);
    font-size: 0.85rem;
    font-weight: 600;
}

.vod-title {
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.4;
    flex: 1;
    margin: 0;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    min-height: calc(1.4em * 2);
}

.vod-title.has-overflow {
    cursor: help;
}

.vod-card-footer {
    margin-top: 0.75rem;
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.vod-card-body .vod-card-resume-meta {
    margin-bottom: 0.75rem;
}

.vod-title-tooltip {
    position: fixed;
    z-index: 50;
    max-width: min(32rem, calc(100vw - 2rem));
    padding: 0.65rem 0.8rem;
    border-radius: 0.75rem;
    background: var(--media-overlay-bg);
    color: var(--media-on-overlay);
    font-size: 0.88rem;
    line-height: 1.45;
    box-shadow: 0 18px 48px rgba(15, 23, 42, 0.28);
    pointer-events: none;
    opacity: 0;
    transform: translateY(4px);
    transition:
        opacity 0.12s ease,
        transform 0.12s ease;
}

.vod-title-tooltip.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.vod-title-tooltip[hidden] {
    display: block;
}

.vod-badge,
.model-badge,
.unified-card-pill,
.player-meta-badge {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: var(--pill-bg);
    border: 1px solid var(--pill-border);
    color: var(--pill-fg);
}

.vod-badge {
    font-size: 0.75rem;
    padding: 0.15rem 0.5rem;
}

.vod-badge-twitch {
    background: var(--shell-active-bg);
    color: var(--accent-purple);
}

.vod-badge-youtube,
.vod-badge-youtube-chat {
    background: var(--danger-bg);
    color: var(--danger);
}

.vod-badge-tags {
    background: var(--success-bg);
    color: var(--success);
}

/* Search suggestions dropdown */
.search-suggestions {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    z-index: 200;
    background: var(--bg-secondary);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--glass-shadow);
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
    transform: translateY(-4px);
    transition:
        opacity var(--transition),
        transform var(--transition);
}

.search-suggestions.is-open {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.search-suggestion {
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
    padding: 0.55rem 1rem;
    cursor: pointer;
    color: var(--text-primary);
    transition: background var(--transition);
    text-decoration: none;
    border-bottom: 1px solid var(--border);
}

.search-suggestion:last-child {
    border-bottom: none;
}

.search-suggestion:hover,
.search-suggestion.is-active {
    background: var(--bg-tertiary);
    color: var(--text-primary);
}

.search-suggestion:hover .suggestion-title,
.search-suggestion.is-active .suggestion-title {
    color: var(--accent-purple);
}

.suggestion-number {
    color: var(--accent-purple);
    font-weight: 700;
    font-size: 0.8rem;
    flex-shrink: 0;
    min-width: 2.5rem;
}

.suggestion-title {
    font-weight: 600;
    font-size: 0.9rem;
    flex: 1;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    transition: color var(--transition);
}

.suggestion-date {
    color: var(--text-secondary);
    font-size: 0.8rem;
    flex-shrink: 0;
}

.search-suggestion-group {
    padding: 0.45rem 1rem 0.3rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-secondary);
    background: var(--shell-active-bg);
}

.search-suggestion-detail {
    color: var(--text-secondary);
    font-size: 0.8rem;
    flex-shrink: 0;
}

.search-suggestions-footer {
    padding: 0.65rem 1rem;
    font-size: 0.78rem;
    color: var(--text-secondary);
    background: var(--shell-active-bg);
    border-top: 1px solid var(--border);
}

/* === Stats === */
.stats-page {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.stats-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.stats-summary-card {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    min-height: 140px;
    justify-content: center;
}

.stats-summary-label,
.stats-summary-footnote {
    color: var(--text-secondary);
    font-size: 0.88rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.stats-summary-footnote {
    text-transform: none;
    letter-spacing: 0;
    font-weight: 450;
    margin-top: 0.1rem;
}

.stats-summary-value {
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    font-weight: 800;
    line-height: 1.05;
    background: var(--heading-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.stats-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-areas:
        "storage duration"
        "growth growth"
        "records dow"
        "heatmap heatmap"
        "tags freq"
        "catalog catalog";
    grid-auto-rows: minmax(280px, auto);
    gap: 1rem;
    align-items: stretch;
}

.stats-panel {
    min-width: 0;
    min-height: 0;
    overflow: hidden;
}

.stats-panel-wide {
    grid-area: catalog;
}

.stats-panel-storage {
    grid-area: storage;
}

.stats-panel-duration {
    grid-area: duration;
}

.stats-panel-growth {
    grid-area: growth;
    display: flex;
    flex-direction: column;
}

.stats-panel-records {
    grid-area: records;
}

.stats-panel-dow {
    grid-area: dow;
}

.stats-panel-heatmap {
    grid-area: heatmap;
    grid-auto-rows: auto;
}

.stats-panel-tags {
    grid-area: tags;
}

.stats-panel-freq {
    grid-area: freq;
}

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

.stats-panel-header-row .stats-panel-header {
    margin-bottom: 0;
    flex: 1;
    min-width: 0;
}

.stats-panel-header {
    margin-bottom: 1rem;
}

.stats-panel-header h2 {
    font-size: 1.15rem;
    margin-bottom: 0.2rem;
}

.stats-panel-header p {
    color: var(--text-secondary);
    font-size: 0.92rem;
}

.stats-toggle-group {
    display: inline-flex;
    gap: 0.35rem;
    padding: 0.25rem;
    margin-bottom: 1rem;
    border-radius: 999px;
    background: var(--bg-tertiary);
    border: var(--glass-border);
}

.stats-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    border: none;
    background: transparent;
    color: var(--text-secondary);
    font: inherit;
    font-weight: 700;
    padding: 0.45rem 0.85rem;
    border-radius: 999px;
    cursor: pointer;
    transition: all var(--transition);
}

.stats-toggle:hover {
    color: var(--text-primary);
}

.stats-toggle-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
    transition: opacity var(--transition);
}

.stats-toggle:not(.is-active) {
    opacity: 0.55;
}

.stats-toggle:not(.is-active):hover {
    opacity: 0.85;
}

/* Per-metric dot colors — always visible */
[data-growth-metric="count"] .stats-toggle-dot {
    background: var(--accent-purple);
}

[data-growth-metric="duration_seconds"] .stats-toggle-dot {
    background: var(--accent-gold);
}

[data-growth-metric="bytes"] .stats-toggle-dot {
    background: #0ea5e9;
}

[data-theme="dark"] [data-growth-metric="bytes"] .stats-toggle-dot {
    background: #38bdf8;
}

/* Per-metric active button backgrounds */
.stats-toggle.is-active[data-growth-metric="count"] {
    background: var(--accent-purple);
    color: var(--media-on-overlay);
    box-shadow: 0 4px 14px rgba(124, 58, 237, 0.35);
    opacity: 1;
}

[data-theme="dark"] .stats-toggle.is-active[data-growth-metric="count"] {
    box-shadow: 0 4px 14px rgba(176, 101, 255, 0.35);
}

.stats-toggle.is-active[data-growth-metric="duration_seconds"] {
    background: var(--button-gradient);
    color: var(--button-foreground);
    box-shadow: 0 4px 14px rgba(212, 160, 23, 0.35);
    opacity: 1;
}

.stats-toggle.is-active[data-growth-metric="bytes"] {
    background: #0ea5e9;
    color: var(--media-on-overlay);
    box-shadow: 0 4px 14px rgba(14, 165, 233, 0.35);
    opacity: 1;
}

[data-theme="dark"] .stats-toggle.is-active[data-growth-metric="bytes"] {
    background: #38bdf8;
    color: #0c1a1f;
    box-shadow: 0 4px 14px rgba(56, 189, 248, 0.35);
}

/* Dot turns white/dark inside active button except for gold */
.stats-toggle.is-active[data-growth-metric="count"] .stats-toggle-dot,
.stats-toggle.is-active[data-growth-metric="bytes"] .stats-toggle-dot {
    background: rgba(255, 255, 255, 0.6);
}

.stats-toggle.is-active[data-growth-metric="duration_seconds"] .stats-toggle-dot {
    background: rgba(0, 0, 0, 0.25);
}

/* === Duration Distribution === */
.stats-pill-chart {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.stats-pill {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.stats-pill-meter {
    position: relative;
    flex: 1;
    min-height: 14px;
    overflow: hidden;
}

.stats-meter {
    width: 100%;
    height: 14px;
    appearance: none;
    -webkit-appearance: none;
    border: none;
    border-radius: 999px;
    overflow: hidden;
    background: var(--bg-tertiary);
}

.stats-meter::-webkit-progress-bar {
    background: var(--bg-tertiary);
    border-radius: 999px;
}

.stats-meter::-webkit-progress-value {
    background: var(--button-gradient);
    border-radius: 999px;
}

.stats-meter::-moz-progress-bar {
    background: var(--button-gradient);
    border-radius: 999px;
}

.stats-pill > span:first-child,
.stats-pill > strong {
    min-width: 72px;
}

/* === Archive Growth Area Chart === */
.stats-growth-chart {
    position: relative;
    overflow: hidden;
}

.stats-area-svg {
    display: block;
    max-width: 100%;

    --series-vods: var(--accent-purple);
    --series-runtime: var(--accent-gold);
    --series-storage: #0ea5e9;
}

[data-theme="dark"] .stats-area-svg {
    --series-storage: #38bdf8;
}

.stats-area-grid line {
    stroke: var(--border);
    stroke-width: 1;
    stroke-dasharray: 3 4;
}

.stats-area-label {
    font-size: 11px;
    fill: var(--text-secondary);
    font-family:
        Inter,
        -apple-system,
        BlinkMacSystemFont,
        "Segoe UI",
        sans-serif;
}

.stats-area-crosshair {
    stroke: var(--text-secondary);
    stroke-width: 1;
    stroke-dasharray: 3 4;
    opacity: 0.6;
}

.stats-area-tooltip {
    position: absolute;
    pointer-events: none;
    background: var(--bg-secondary);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: var(--glass-border);
    box-shadow: var(--glass-shadow);
    border-radius: var(--radius);
    padding: 0.6rem 0.85rem;
    font-size: 0.82rem;
    line-height: 1.5;
    z-index: 10;
    white-space: nowrap;
}

.stats-tooltip-label {
    display: block;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 0.3rem;
}

.stats-tooltip-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--text-secondary);
}

.stats-tooltip-row em {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}

/* === Longest Streams === */
.stats-record-row {
    display: flex;
    align-items: baseline;
    gap: 0.75rem;
    padding: 0.65rem 0;
    border-bottom: 1px solid var(--border);
}

.stats-record-row:last-child {
    border-bottom: none;
}

.stats-record-rank {
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--text-secondary);
    min-width: 1.8rem;
    flex-shrink: 0;
}

.stats-record-info {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    min-width: 0;
}

.stats-record-info a {
    font-weight: 600;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.stats-record-meta {
    font-size: 0.8rem;
    color: var(--text-secondary);
}

/* === Calendar Heatmap === */
.stats-heatmap {
    display: flex;
    flex-direction: column;
    gap: 4px;
    overflow-x: auto;
}

.stats-heatmap-row {
    display: grid;
    grid-template-columns: 3rem repeat(12, minmax(0, 1fr));
    gap: 4px;
    align-items: center;
}

.stats-heatmap-year {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-align: right;
    padding-right: 0.5rem;
    white-space: nowrap;
}

.stats-heatmap-month-label {
    font-size: 0.72rem;
    color: var(--text-secondary);
    text-align: center;
}

.stats-heatmap-cell {
    aspect-ratio: 1;
    border-radius: 3px;
    background: var(--bg-tertiary);
    cursor: default;
    min-width: 0;
}

.stats-heatmap-legend {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-top: 0.75rem;
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.stats-heatmap-legend .stats-heatmap-cell {
    width: 14px;
    height: 14px;
    aspect-ratio: unset;
    flex-shrink: 0;
}

/* === Streaming Habits === */
.stats-freq-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem 1.5rem;
}

.stats-freq-item {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.stats-freq-value {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.2;
}

.stats-freq-label {
    font-size: 0.8rem;
    color: var(--text-secondary);
}

/* === Tables === */
.stats-share-cell {
    color: var(--text-secondary);
    font-size: 0.85rem;
}

.stats-table-wrap {
    overflow: auto;
}

.stats-table-wrap-large {
    max-height: 620px;
}

.stats-table {
    width: 100%;
    border-collapse: collapse;
}

.stats-table th,
.stats-table td {
    padding: 0.8rem 0.65rem;
    border-bottom: 1px solid var(--border);
    text-align: left;
}

.stats-table td {
    font-size: 0.9rem;
}

.stats-table tbody tr:hover td {
    background: var(--bg-tertiary);
}

.stats-sort {
    border: none;
    background: none;
    color: var(--text-secondary);
    font: inherit;
    font-weight: 700;
    cursor: pointer;
    padding: 0;
}

.stats-sort:hover {
    color: var(--accent-purple);
}

/* === Pagination === */
.pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.5rem;
    margin-top: 2rem;
    flex-wrap: wrap;
}

.pagination-pages {
    display: flex;
    gap: 0.25rem;
    align-items: center;
}

.pagination-current {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.3rem 0.75rem;
    border-radius: var(--radius);
    background: var(--button-gradient);
    color: var(--button-foreground);
    font-size: 0.8rem;
    font-weight: 700;
}

.pagination-ellipsis {
    padding: 0 0.5rem;
    color: var(--text-secondary);
}

/* === Theater Mode === */
body.theater-mode {
    overflow: hidden;
}

body.theater-mode .navbar,
body.theater-mode .footer,
body.theater-mode .player-page-top,
body.theater-mode .player-title,
body.theater-mode .tags-section {
    display: none;
}

body.theater-mode .player-footer {
    flex-shrink: 0;
    padding: 0.35rem 0.75rem;
    margin-top: 0;
    border-top: 1px solid var(--border);
    background: var(--bg-secondary);
    justify-content: flex-end;
}

body.theater-mode .player-info-card,
body.theater-mode .up-next-panel {
    display: none;
}

body.theater-mode .player-layout {
    position: fixed;
    inset: 0;
    z-index: 50;
    background: var(--bg-primary);
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    align-items: stretch;
}

body.theater-mode .player-layout.has-chat {
    grid-template-columns: 1fr 380px;
}

body.theater-mode .player-layout .player-column {
    display: grid;
    align-items: center;
    min-height: 0;
    overflow: hidden;
    background: var(--media-bg);
}

body.theater-mode .player-layout .player-container {
    width: min(100%, calc(100vh * 16 / 9));
    height: auto;
    max-height: 100vh;
    min-height: 0;
    aspect-ratio: 16 / 9;
    align-self: center;
    border-radius: 0;
    background: var(--media-bg);
    box-shadow: none;
}

body.theater-mode .player-layout .player-container .mp-wrapper.mp-video {
    width: 100%;
    height: auto;
    max-height: 100vh;
    min-height: 0;
    aspect-ratio: 16 / 9;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--media-bg);
}

body.theater-mode .player-layout .player-container .mp-wrapper.mp-video video {
    width: 100%;
    height: 100%;
    max-height: none;
    object-fit: contain;
}

body.theater-mode .player-layout .player-sidebar {
    display: none;
}

body.theater-mode .player-layout.has-chat .player-sidebar {
    display: flex;
    min-height: 0;
    max-height: 100vh;
}

body.theater-mode .player-layout.has-chat .chat-panel {
    height: 100vh;
    max-height: 100vh;
    min-height: 0;
    border-radius: 0;
    border-left: 1px solid var(--border);
}

/* === VOD Player === */
.player-page {
    max-width: 100%;
    margin: 0 auto;
}

.player-page-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
    min-width: 0;
    flex-wrap: nowrap;
}

.player-page-top .back-link {
    margin-bottom: 0;
    min-width: 0;
    flex-shrink: 1;
    white-space: nowrap;
}

.player-page-top .player-meta-badge {
    flex-shrink: 0;
}

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

.player-column,
.player-sidebar {
    min-width: 0;
}

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

.player-footer {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    align-items: center;
    margin-top: 0.75rem;
    color: var(--text-secondary);
    font-size: 0.92rem;
}

.player-title {
    font-family:
        Sora,
        -apple-system,
        BlinkMacSystemFont,
        "Segoe UI",
        sans-serif;
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: -0.025em;
    margin-top: 0;
    line-height: 1.35;
}

.player-title-row {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
}

.player-controls-row {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.player-controls-row .btn-sm {
    min-height: 2.4rem;
    padding: 0.5rem 1rem;
    font-size: 0.85rem;
}

.player-controls-row .player-source-switch-side {
    min-width: 8rem;
    justify-content: center;
}

.player-controls-row .player-source-variant {
    min-width: 5rem;
    justify-content: center;
}

.player-controls-row .player-action-dropdown .btn {
    min-width: 7rem;
    justify-content: center;
}

.player-controls-row .favorite-toggle {
    min-width: 8rem;
    justify-content: center;
}

.player-source-group {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    flex-shrink: 0;
}

.player-controls-sep {
    display: inline-block;
    width: 1px;
    height: 1.5rem;
    background: var(--border);
    margin: 0 0.2rem;
    flex-shrink: 0;
}

.player-source-switch-wrap {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.player-source-switch {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.player-source-switch-side {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    min-width: 6.5rem;
}

.player-source-switch-side.is-active {
    background: rgba(124, 92, 255, 0.1);
    border-color: rgba(124, 92, 255, 0.36);
    color: var(--accent-purple);
    box-shadow: none;
    animation: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.player-source-switch-side.is-active:hover {
    background: rgba(124, 92, 255, 0.2);
    border-color: rgba(124, 92, 255, 0.45);
    transform: none;
    box-shadow: none;
    filter: none;
}

.player-source-switch-logo {
    width: 1rem;
    height: 1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.player-source-switch-logo svg {
    width: 100%;
    height: 100%;
}

.player-source-variants {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    flex-wrap: wrap;
}

.player-source-variant.is-active {
    background: var(--shell-active-border);
    border-color: var(--shell-active-border);
    color: var(--accent-purple);
}

.player-info-card {
    margin-top: 1rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.player-heading {
    margin-bottom: 0;
}

.player-section-separator {
    height: 1px;
    margin: 1rem 0 1.1rem;
    background: linear-gradient(90deg, transparent, var(--muted-border-strong), transparent);
}

.player-meta-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    background: var(--button-secondary-bg);
    border: 1px solid var(--button-secondary-border);
    color: var(--text-secondary);
    font-size: 0.82rem;
    font-weight: 700;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.14),
        0 16px 36px rgba(15, 23, 42, 0.12);
}

[data-theme="dark"] .player-meta-badge {
    background: var(--bg-tertiary);
}

.vod-number,
.vod-date,
.player-meta-separator {
    display: inline-flex;
    align-items: center;
    line-height: 1;
}

.player-meta-badge .vod-number {
    font-weight: 700;
    color: var(--accent-purple);
}

.player-meta-badge .vod-number,
.player-meta-badge .vod-date,
.player-meta-badge .player-meta-separator {
    font-size: 0.82rem;
    font-weight: 700;
}

.player-meta-badge .vod-date {
    color: var(--text-secondary);
}

.player-meta-separator {
    color: var(--text-secondary);
    font-weight: 700;
}

.player-resume-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.9rem 1rem;
    margin-bottom: 1rem;
    border-radius: var(--radius);
    background: linear-gradient(135deg, rgba(185, 182, 216, 0.14), rgba(186, 168, 205, 0.08));
    border: 1px solid rgba(185, 182, 216, 0.35);
}

[data-theme="dark"] .player-resume-card {
    background: linear-gradient(135deg, rgba(124, 92, 255, 0.14), rgba(157, 123, 255, 0.06));
    border-color: rgba(178, 155, 255, 0.22);
}

.player-resume-copy {
    display: grid;
    gap: 0.25rem;
}

.player-resume-kicker {
    margin: 0;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--accent-purple);
}

.player-resume-text {
    margin: 0;
    color: var(--text-primary);
    font-weight: 600;
}

.player-resume-actions {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.player-info-grid {
    display: grid;
    grid-template-columns: minmax(250px, 0.9fr) minmax(0, 1fr);
    grid-template-areas: "clip tags";
    gap: 1rem;
    align-items: start;
}

.player-info-grid-no-tags {
    grid-template-columns: minmax(0, 1fr);
    grid-template-areas: "clip";
}

.player-grid-card {
    height: auto;
}

.player-card-clip {
    grid-area: clip;
}

.player-card-shortcuts {
    grid-area: shortcuts;
}

.player-action-dropdown {
    position: relative;
    flex-shrink: 0;
}

.player-dropdown-trigger {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    white-space: nowrap;
}

.player-dropdown-menu {
    position: absolute;
    top: calc(100% + 0.4rem);
    left: 0;
    z-index: 200;
    min-width: 180px;
    background: var(--bg-secondary);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: var(--glass-border);
    border-radius: var(--radius);
    box-shadow: var(--glass-shadow);
    padding: 0.4rem;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.player-dropdown-item {
    display: block;
    width: 100%;
    text-align: left;
    padding: 0.4rem 0.65rem;
    border-radius: calc(var(--radius) - 2px);
    font-size: 0.88rem;
    color: var(--text-primary);
    background: none;
    border: none;
    cursor: pointer;
    text-decoration: none;
    transition: background var(--transition);
}

.player-dropdown-item:hover,
.player-dropdown-item:focus-visible {
    background: var(--bg-tertiary);
}

.player-dropdown-section-label {
    margin: 0.35rem 0 0.1rem;
    padding: 0 0.65rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.player-dropdown-section-label:first-child {
    margin-top: 0.1rem;
}

.player-dropdown-timestamp {
    padding: 0.3rem 0.65rem 0.4rem;
    font-size: 0.82rem;
    color: var(--text-secondary);
    margin: 0;
    border-bottom: 1px solid var(--border);
}

.player-dropdown-status {
    min-height: 1.2rem;
    font-size: 0.8rem;
    color: var(--accent-purple);
    padding: 0.2rem 0.65rem 0.1rem;
    margin: 0;
}

.player-container {
    background: var(--player-bg);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--glass-shadow);
    aspect-ratio: 16 / 9;
    position: relative;
}

.video-player {
    width: 100%;
    display: block;
    max-height: 80vh;
}

.theater-overlay-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    min-height: 2rem;
    white-space: nowrap;
}

.mp-control-bubble-theater .theater-overlay-toggle {
    background: transparent !important;
    border: none !important;
    color: var(--media-on-overlay) !important;
    box-shadow: none !important;
    padding: 0.35rem 0.55rem;
    border-radius: 999px;
    transform: none !important;
    transition:
        background var(--transition),
        color var(--transition);
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

.mp-control-bubble-theater .theater-overlay-toggle:hover,
.mp-control-bubble-theater .theater-overlay-toggle:focus-visible {
    background: rgba(255, 255, 255, 0.16) !important;
    color: var(--media-on-overlay) !important;
    box-shadow: none !important;
    transform: none !important;
}

@media (max-width: 1024px) {
    .theater-overlay-toggle {
        display: none !important;
    }
}

/* === Downloads === */
.download-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.btn-download::before {
    content: "\2193 ";
}

/* === Share / Downloads / Clip — side-by-side cards === */
.player-card {
    min-width: 0;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 24%), var(--bg-tertiary);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--muted-border);
    border-radius: var(--radius);
    padding: 1rem 1.1rem;
    box-shadow: 0 14px 36px rgba(15, 23, 42, 0.06);
}

[data-theme="dark"] .player-card,
[data-theme="dark"] .tags-section {
    background: var(--bg-tertiary);
    border-color: rgba(178, 155, 255, 0.1);
}

.player-card h3 {
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-secondary);
    margin-bottom: 0.75rem;
}

/* === Community Tags === */
.tags-section {
    display: flex;
    flex-direction: column;
    min-width: 0;
    min-height: 0;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 24%), var(--bg-tertiary);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--muted-border);
    border-radius: var(--radius);
    padding: 1rem 1.1rem;
    margin-top: 0;
    box-shadow: 0 14px 36px rgba(15, 23, 42, 0.06);
}

.tags-header {
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-secondary);
    margin-bottom: 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.tags-header-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.75rem;
}

.tags-header-row .tags-header {
    margin-bottom: 0;
}

.player-grid-tags {
    grid-area: tags;
    min-height: 0;
}

.tags-count {
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
    color: var(--text-secondary);
    opacity: 0.7;
}

.tags-list {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    scrollbar-width: thin;
}

.tags-section.is-collapsed .tags-list {
    display: none;
}

.tags-loading {
    font-size: 0.85rem;
    color: var(--text-secondary);
    padding: 0.25rem 0;
}

.tag-item {
    display: flex;
    align-items: center;
    min-width: 0;
    gap: 0.65rem;
    padding: 0.45rem 0.5rem;
    border-bottom: 1px solid rgba(128, 128, 128, 0.1);
    border-radius: 0.5rem;
    transition:
        background 0.15s,
        border-color 0.15s,
        transform 0.15s;
}

.tag-item:hover {
    background: var(--shell-active-bg);
    border-color: var(--shell-active-bg);
}

/* === Collapse sidebar when chat is hidden and no up-next === */
.player-sidebar.sidebar-hidden {
    display: none;
}

.player-layout:has(.player-sidebar.sidebar-hidden) {
    grid-template-columns: minmax(0, 1fr);
}

/* === Mobile: icon-only Share and Download trigger buttons === */
@media (max-width: 640px) {
    .player-dropdown-trigger .btn-label {
        display: none;
    }
}

/* === Mobile: reorder player layout so chat appears directly under the video === */
@media (max-width: 768px) {
    .player-layout {
        display: flex;
        flex-direction: column;
        gap: 1rem;
    }

    .player-column {
        display: contents;
    }

    .player-sidebar {
        display: contents;
    }

    .player-container {
        order: 1;
    }

    .chat-panel {
        order: 2;
    }

    .player-info-card {
        order: 3;
        margin-top: 0;
    }

    .up-next-panel {
        order: 4;
    }
}

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

.tag-active {
    border-left: none;
    padding-left: 0.5rem;
    margin-left: 0;
    background: rgba(145, 70, 255, 0.06);
    border-radius: 0.5rem;
}

.player-sidebar .chat-panel {
    height: min(62vh, 720px);
    max-height: min(62vh, 720px);
    position: static;
}

.up-next-panel {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.up-next-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
}

.up-next-header h3 {
    margin: 0;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.up-next-subtitle {
    margin: 0.2rem 0 0;
    color: var(--text-secondary);
    font-size: 0.82rem;
}

.up-next-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.up-next-card {
    display: block;
    color: var(--text-primary);
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    transition: all var(--transition);
}

.up-next-card.is-primary {
    border-color: var(--shell-active-border);
}

.up-next-card:hover {
    color: var(--text-primary);
    border-color: var(--accent-purple);
    transform: translateY(-1px);
}

.up-next-thumb {
    position: relative;
    aspect-ratio: 16 / 9;
    background: var(--bg-tertiary);
    overflow: hidden;
}

.up-next-thumb img,
.up-next-thumb .vod-thumbnail-placeholder {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.up-next-body {
    padding: 0.875rem 0.95rem 0.95rem;
}

.up-next-slot {
    display: inline-flex;
    margin-bottom: 0.45rem;
    color: var(--accent-purple);
    font-size: 0.74rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.up-next-meta {
    margin: 0 0 0.4rem;
    color: var(--text-secondary);
    font-size: 0.82rem;
    font-weight: 600;
}

.up-next-title {
    margin: 0;
    font-weight: 600;
    line-height: 1.45;
}

.up-next-countdown {
    padding: 0.75rem 0.875rem;
    border-radius: var(--radius);
    background: var(--shell-active-bg);
    border: 1px solid var(--shell-active-border);
}

.up-next-countdown p {
    margin: 0 0 0.55rem;
    font-weight: 600;
}

.up-next-actions {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.autoplay-switch {
    border: none;
    background: transparent;
    padding: 0;
    cursor: pointer;
}

.autoplay-switch-track {
    width: 46px;
    height: 26px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    padding: 2px;
    background: rgba(191, 36, 36, 0.18);
    border: 1px solid rgba(191, 36, 36, 0.28);
    transition:
        background var(--transition),
        border-color var(--transition);
}

.autoplay-switch-thumb {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--bg-primary);
    color: #b91c1c;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transform: translateX(0);
    transition:
        transform var(--transition),
        color var(--transition);
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.18);
}

.autoplay-switch.is-on .autoplay-switch-track {
    background: rgba(22, 163, 74, 0.18);
    border-color: rgba(22, 163, 74, 0.3);
}

.autoplay-switch.is-on .autoplay-switch-thumb {
    transform: translateX(20px);
    color: var(--success);
}

.autoplay-icon {
    width: 11px;
    height: 11px;
}

.autoplay-icon-pause {
    display: inline-flex;
}

.autoplay-icon-play {
    display: none;
}

.autoplay-switch.is-on .autoplay-icon-pause {
    display: none;
}

.autoplay-switch.is-on .autoplay-icon-play {
    display: inline-flex;
}

.search-results {
    display: grid;
    gap: 1rem;
}

.search-results-section {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.search-results-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}

.search-results-header h2 {
    margin: 0;
}

.search-results-header span {
    color: var(--text-secondary);
    font-size: 0.85rem;
    font-weight: 700;
}

.search-results-list {
    display: grid;
    gap: 0.75rem;
}

.search-result-card {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    padding: 1rem;
    border-radius: var(--radius);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    color: var(--text-primary);
    transition: all var(--transition);
}

.search-result-card-compact {
    padding: 0.85rem;
}

.search-result-card:hover {
    color: var(--text-primary);
    border-color: var(--accent-purple);
    transform: translateY(-1px);
}

.search-result-thumb {
    width: 160px;
    flex-shrink: 0;
    aspect-ratio: 16 / 9;
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--bg-tertiary);
}

.search-result-thumb-model {
    width: 92px;
    aspect-ratio: 1;
}

.search-result-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.search-result-thumb-model img {
    object-fit: contain;
    padding: 0.2rem;
}

.search-result-main {
    flex: 1 1 auto;
    min-width: 0;
    text-align: left;
}

.search-result-main h3,
.search-result-main p {
    margin: 0;
}

.search-result-main p {
    margin-top: 0.35rem;
    color: var(--text-secondary);
}

.search-result-type {
    display: inline-flex;
    margin-bottom: 0.55rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--accent-purple);
}

.search-result-meta {
    color: var(--text-secondary);
    font-size: 0.85rem;
    font-weight: 700;
    white-space: nowrap;
}

.search-empty-state {
    text-align: center;
}

[data-theme="dark"] .tag-active {
    background: rgba(145, 70, 255, 0.1);
}

.tag-time {
    flex-shrink: 0;
    font-family: monospace;
    font-size: 0.8rem;
    background: rgba(128, 128, 128, 0.12);
    border: none;
    border-radius: 4px;
    padding: 0.15rem 0.4rem;
    cursor: pointer;
    color: var(--accent-purple);
    transition:
        background 0.15s,
        color 0.15s;
    line-height: 1.5;
}

.tag-time:hover,
.tag-time:focus-visible {
    background: var(--accent-purple);
    color: var(--media-on-overlay);
}

.tag-copy {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-left: auto;
    width: 2rem;
    height: 2rem;
    border: none;
    border-radius: 4px;
    padding: 0;
    background: rgba(128, 128, 128, 0.12);
    color: var(--accent-purple);
    cursor: pointer;
    transition:
        background 0.15s,
        color 0.15s,
        transform 0.15s;
    line-height: 1;
}

.tag-copy svg {
    width: 0.95rem;
    height: 0.95rem;
    fill: none;
    stroke: currentcolor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.tag-copy:hover,
.tag-copy:focus-visible {
    background: var(--accent-purple);
    color: var(--media-on-overlay);
}

.tag-copy.is-copied {
    background: #16a34a;
    color: var(--media-on-overlay);
}

.tag-copy.is-copied svg {
    transform: scale(0.96);
}

.tag-labels {
    font-size: 0.85rem;
    color: var(--text-primary);
    line-height: 1.4;
    flex: 1;
    min-width: 0;
    white-space: normal;
    overflow-wrap: anywhere;
}

.tag-countdown {
    flex-shrink: 0;
    font-family: monospace;
    font-size: 0.75rem;
    color: var(--text-secondary);
    opacity: 0.7;
    padding: 0.1rem 0.35rem;
    background: rgba(128, 128, 128, 0.1);
    border-radius: 4px;
}

.share-buttons {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.share-current-time {
    margin: 0 0 0.6rem;
    color: var(--text-secondary);
    font-size: 0.82rem;
    font-weight: 600;
}

.share-current-time span {
    color: var(--accent-purple);
    font-family: monospace;
}

.share-status {
    margin-top: 0.6rem;
    font-size: 0.8rem;
    color: var(--accent-purple);
    min-height: 1.1em;
}

.clip-inputs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.75rem;
}

.clip-presets {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 0.75rem;
}

#clip-download {
    grid-column: 1 / -1;
}

.clip-field {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.clip-field label {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-secondary);
}

.clip-field input,
.clip-field .btn {
    width: 100%;
}

.clip-field .search-input {
    padding-right: 1rem;
}

.clip-status {
    margin-top: 0.75rem;
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.clip-status.error {
    color: var(--danger);
}

.player-shortcuts-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.player-shortcuts-header h3 {
    margin-bottom: 0;
}

.player-shortcuts-copy {
    margin: 0;
    color: var(--text-secondary);
    font-size: 0.88rem;
    line-height: 1.5;
}

kbd {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.75rem;
    padding: 0.16rem 0.42rem;
    border-radius: 0.45rem;
    border: 1px solid var(--border);
    background: var(--bg-tertiary);
    color: var(--text-secondary);
    font: inherit;
    font-size: 0.76rem;
    font-weight: 600;
    letter-spacing: 0.01em;
}

.shortcut-overlay {
    position: fixed;
    inset: 0;
    z-index: 40;
    display: grid;
    place-items: center;
    padding: 1.5rem;
    background: rgba(15, 23, 42, 0.55);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.shortcut-dialog {
    width: min(100%, 560px);
    padding: 1.25rem;
}

.shortcut-dialog-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.shortcut-dialog-header h2 {
    margin: 0;
    font-size: 1.1rem;
}

.shortcut-list {
    display: grid;
    gap: 0.65rem;
}

.shortcut-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.7rem 0.85rem;
    border-radius: var(--radius);
    background: var(--bg-tertiary);
}

.shortcut-row span {
    color: var(--text-secondary);
    text-align: right;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip-path: inset(50%);
    white-space: nowrap;
    border: 0;
}

/* === Chat Panel === */
.chat-panel {
    display: flex;
    flex-direction: column;
    background: var(--bg-secondary);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: var(--glass-border);
    box-shadow: var(--glass-shadow);
    border-radius: var(--radius-lg);
    overflow: hidden;
    min-height: 0;
    transition:
        height var(--transition),
        max-height var(--transition),
        box-shadow var(--transition);
}

.chat-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 1rem;
    border-bottom: 1px solid var(--border);
}

.chat-panel.is-collapsed {
    height: auto !important;
    max-height: none !important;
}

.chat-panel.is-collapsed .chat-header {
    border-bottom: none;
}

.chat-panel.is-collapsed .chat-messages,
.chat-panel.is-collapsed .chat-scroll-btn {
    display: none !important;
}

.chat-header h3 {
    font-size: 0.95rem;
    color: var(--accent-purple);
}

.chat-messages {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    padding: 0.5rem 0.75rem;
    font-size: 0.85rem;
}

.chat-messages::-webkit-scrollbar {
    width: 6px;
}

.chat-messages::-webkit-scrollbar-track {
    background: transparent;
}

.chat-messages::-webkit-scrollbar-thumb {
    background: var(--scrollbar-thumb);
    border-radius: 999px;
}

.chat-loading {
    text-align: center;
    color: var(--text-secondary);
    padding: 2rem;
}

.chat-message {
    padding: 2px 0;
    line-height: 1.4;
    overflow-wrap: anywhere;
}

.chat-username {
    font-weight: 700;
    margin-right: 0.3rem;
    font-size: 0.85rem;
}

.chat-body {
    font-size: 0.85rem;
}

.chat-emote {
    height: 1.5em;
    vertical-align: middle;
    margin: 0 1px;
}

.chat-scroll-btn {
    position: sticky;
    bottom: 0;
    display: none;
    justify-content: center;
    padding: 0.4rem;
    background: var(--button-gradient);
    color: var(--button-foreground);
    border: none;
    cursor: pointer;
    font-size: 0.8rem;
    width: 100%;
}

.chat-scroll-btn:hover {
    color: var(--media-bg);
}

[data-theme="dark"] .chat-scroll-btn:hover {
    color: white;
}

.chat-scroll-btn.visible {
    display: flex;
}

/* === Models Grid === */
.models-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 1.5rem;
}

.model-card {
    display: block;
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    overflow: hidden;
    color: var(--text-primary);
    transition: all var(--transition);
}

.model-card:hover {
    border-color: var(--card-hover-border);
    transform: translateY(-2px);
    box-shadow: var(--card-hover-shadow);
    color: var(--text-primary);
}

.model-card-image {
    aspect-ratio: 3 / 4;
    overflow: hidden;
    background: var(--bg-tertiary);
}

.model-card-image img {
    width: 100%;
    height: 100%;
    padding: 1rem;
    object-fit: contain;
    transition: transform 0.3s ease;
}

.model-card:hover .model-card-image img {
    transform: scale(1.03);
}

.model-card-info {
    padding: 1rem;
}

.model-card-info h3 {
    font-size: 1.1rem;
    margin-bottom: 0.5rem;
}

.model-card-meta {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.model-fav-badge {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--favorite);
    padding: 0.15rem 0.5rem;
    border-radius: 999px;
    background: var(--favorite-bg-soft);
    border: 1px solid var(--favorite-border-soft);
}

.model-badge {
    font-size: 0.75rem;
    padding: 0.15rem 0.6rem;
    font-weight: 700;
}

.model-badge-live2d {
    background: var(--shell-active-bg);
    color: var(--accent-purple);
}

.model-badge-3d {
    background: var(--warning-bg);
    color: var(--warning);
}

.model-date {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-secondary);
}

/* === Model Detail === */
.model-detail-top {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    margin-bottom: 3rem;
}

.model-detail-image {
    position: relative;
    padding: 1rem;
    border-radius: var(--radius-lg);
    background: var(--bg-secondary);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    cursor: pointer;
    align-self: stretch;
    display: flex;
    align-items: center;
    justify-content: center;
}

.model-detail-image::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: var(--radius-lg);
    padding: 2px;
    background: var(--heading-gradient);
    -webkit-mask:
        linear-gradient(var(--media-on-overlay) 0 0) content-box,
        linear-gradient(var(--media-on-overlay) 0 0);
    -webkit-mask-composite: xor;
    mask:
        linear-gradient(var(--media-on-overlay) 0 0) content-box,
        linear-gradient(var(--media-on-overlay) 0 0);
    mask-composite: exclude;
    pointer-events: none;
}

.model-detail-image img {
    display: block;
    width: 110%;
    height: auto;
    max-height: 100%;
    aspect-ratio: 1;
    object-fit: contain;
    border-radius: calc(var(--radius-lg) - 4px);
}

.model-detail-image-hero {
    padding: 1.25rem;
    min-height: 100%;
    background:
        radial-gradient(circle at top, rgba(185, 182, 216, 0.18), transparent 48%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.02)),
        var(--bg-tertiary);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.16);
}

[data-theme="dark"] .model-detail-image-hero {
    background:
        radial-gradient(circle at top, rgba(157, 123, 255, 0.2), transparent 48%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.01)),
        var(--bg-tertiary);
}

.model-detail-info h1 {
    font-size: 2rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    margin-bottom: 0;
}

.model-name-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.model-info-card {
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    padding: 1.75rem 2rem;
    box-sizing: border-box;
    display: grid;
    gap: 1.5rem;
}

.model-detail-hero {
    display: grid;
    grid-template-columns: minmax(340px, 420px) minmax(0, 1fr);
    align-items: stretch;
    gap: 1.5rem;
}

.model-detail-intro-wrap {
    display: grid;
    align-content: start;
    gap: 1.25rem;
}

.model-detail-kicker {
    margin: 0 0 0.5rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--accent-purple);
}

.model-detail-lede {
    margin: 0.75rem 0 0;
    color: var(--text-secondary);
    max-width: 60ch;
    line-height: 1.65;
}

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

.model-meta-card {
    padding: 1rem 1.1rem;
    border-radius: var(--radius);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.06)),
        var(--bg-tertiary);
    border: 1px solid var(--muted-border-strong);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

[data-theme="dark"] .model-meta-card {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02)),
        var(--bg-tertiary);
}

.model-meta-card strong {
    display: block;
    margin-top: 0.3rem;
    font-size: 1rem;
    line-height: 1.45;
}

.model-meta-card-credits {
    grid-column: 1 / -1;
}

.model-meta-label {
    display: block;
    font-size: 0.76rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--text-secondary);
}

.model-meta-credits-list {
    display: grid;
    gap: 0.8rem;
    margin-top: 0.65rem;
}

.model-meta-credit {
    display: grid;
    grid-template-columns: 84px 1fr;
    gap: 0.85rem;
    align-items: start;
}

.model-meta-credit-role {
    color: var(--accent-purple);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.model-meta-credit-name {
    min-width: 0;
    font-size: 0.98rem;
    font-weight: 600;
    line-height: 1.45;
}

.model-detail-section {
    display: grid;
    gap: 1rem;
}

.model-section-separator {
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--muted-border-strong), transparent);
    margin: 0.15rem 0;
}

.model-section-heading {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
}

.model-section-heading h2 {
    margin: 0;
    font-size: 1.05rem;
}

.model-section-heading p {
    margin: 0.35rem 0 0;
    color: var(--text-secondary);
    font-size: 0.92rem;
}

.model-debut-card {
    display: grid;
    grid-template-columns: minmax(220px, 280px) 1fr;
    gap: 1rem;
    min-width: 0;
    padding: 1rem;
    border-radius: var(--radius-lg);
    color: var(--text-primary);
    border: 1px solid var(--shell-active-border);
    background:
        radial-gradient(circle at top right, rgba(245, 158, 11, 0.14), transparent 32%),
        radial-gradient(circle at top left, var(--shell-active-bg), transparent 34%),
        var(--bg-tertiary);
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.08);
    transition:
        transform var(--transition),
        border-color var(--transition),
        box-shadow var(--transition);
}

.model-debut-card:hover {
    color: var(--text-primary);
    transform: translateY(-1px);
    border-color: var(--accent-purple);
    box-shadow: 0 18px 44px var(--shell-active-bg);
}

.model-debut-thumb {
    position: relative;
    min-width: 0;
    width: 100%;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    border-radius: calc(var(--radius-lg) - 4px);
    background: var(--bg-secondary);
}

.model-debut-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.model-debut-main {
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.model-debut-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.65rem;
}

.model-debut-id {
    color: var(--text-secondary);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.04em;
}

.model-debut-main h3,
.model-debut-main p {
    margin: 0;
}

.model-debut-main h3 {
    font-size: 1.05rem;
    line-height: 1.45;
}

.model-debut-main p {
    margin-top: 0.45rem;
    color: var(--text-secondary);
}

.model-debut-badges {
    margin-top: 0.85rem;
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.model-credits {
    gap: 0.75rem;
}

.credit-entry {
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 1rem;
    padding: 0.95rem 1rem;
    border-radius: var(--radius);
    background: var(--bg-tertiary);
    border: 1px solid var(--muted-border);
}

.credit-role {
    color: var(--accent-purple);
    font-size: 0.82rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    align-self: center;
}

.credit-entry-main {
    min-width: 0;
    font-size: 0.98rem;
    font-weight: 600;
}

.model-timeline {
    gap: 0.9rem;
}

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

.model-updates .model-section-heading {
    grid-column: 1 / -1;
}

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

.timeline-entry {
    padding: 1rem 1rem 1rem 1.1rem;
    border-radius: var(--radius);
    border: 1px solid rgba(245, 158, 11, 0.18);
    background: linear-gradient(180deg, rgba(245, 158, 11, 0.08), transparent), var(--bg-tertiary);
    height: 100%;
    display: flex;
    flex-direction: column;
}

.timeline-date {
    font-size: 0.85rem;
    color: var(--accent-gold);
    font-weight: 600;
}

.timeline-entry p {
    color: var(--text-secondary);
    font-size: 0.9rem;
    margin-top: 0.25rem;
    margin-bottom: 0;
}

/* === Toggles === */
.model-toggles {
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    padding: 1.75rem 2rem 2rem;
}

.model-toggles-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.model-toggles h2 {
    font-size: 1.5rem;
    margin: 0.15rem 0 0;
}

.model-toggles-copy {
    margin: 0.55rem 0 0;
    color: var(--text-secondary);
    max-width: 58ch;
}

.model-toggles-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    justify-content: flex-end;
}

.model-toggles-summary span {
    display: inline-flex;
    align-items: center;
    padding: 0.4rem 0.75rem;
    border-radius: 999px;
    background: var(--bg-tertiary);
    border: 1px solid var(--muted-border);
    color: var(--text-secondary);
    font-size: 0.82rem;
    font-weight: 700;
}

.toggle-tabs {
    display: flex;
    gap: 0.6rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}

.toggle-tab {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.75rem 1rem;
    border-radius: 999px;
    background: var(--bg-tertiary);
    border: 1px solid var(--muted-border-strong);
    color: var(--text-primary);
}

.toggle-tab small {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.7rem;
    height: 1.7rem;
    padding: 0 0.4rem;
    border-radius: 999px;
    background: var(--muted-border);
    color: var(--text-secondary);
    font-size: 0.74rem;
    font-weight: 700;
}

.toggle-tab.active {
    border: 2px solid transparent;
    background:
        var(--button-gradient) padding-box,
        var(--button-gradient) border-box;
    color: var(--button-foreground);
}

.toggle-tab.active small {
    background: rgba(255, 255, 255, 0.22);
    color: var(--button-foreground);
}

.toggle-tab.active:hover {
    color: var(--button-foreground);
    filter: brightness(1.1);
}

.toggle-gallery {
    display: none;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.15rem;
}

.toggle-gallery.active {
    display: grid;
}

.toggle-gallery-header {
    grid-column: 1 / -1;
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.25rem;
}

.toggle-gallery-header h3 {
    margin: 0;
    font-size: 1.05rem;
}

.toggle-gallery-header p {
    margin: 0.35rem 0 0;
    color: var(--text-secondary);
    font-size: 0.9rem;
}

.toggle-item {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 24%), var(--bg-tertiary);
    border: 1px solid var(--muted-border);
    border-radius: var(--radius-lg);
    cursor: pointer;
    transition: all var(--transition);
    overflow: hidden;
    box-shadow: 0 14px 36px rgba(15, 23, 42, 0.06);
}

.toggle-item:hover {
    border-color: var(--card-hover-border);
    transform: translateY(-1px);
    box-shadow: var(--card-hover-shadow);
}

.toggle-item-media {
    position: relative;
    padding: 0.9rem 0.9rem 0;
    background: radial-gradient(circle at top, rgba(178, 155, 255, 0.08), transparent 52%);
}

.toggle-item img {
    width: 100%;
    aspect-ratio: 1;
    object-fit: contain;
    border-radius: calc(var(--radius-lg) - 8px);
    background: rgba(255, 255, 255, 0.32);
}

[data-theme="dark"] .toggle-item img {
    background: rgba(15, 23, 42, 0.42);
}

.toggle-item-body {
    display: grid;
    gap: 0.2rem;
    padding: 0.95rem 1rem 1rem;
}

.toggle-label {
    display: block;
    padding: 0;
    font-size: 0.98rem;
    font-weight: 600;
    color: var(--text-primary);
    text-align: left;
    white-space: normal;
    overflow-wrap: anywhere;
}

.toggle-caption {
    color: var(--text-secondary);
    font-size: 0.82rem;
    font-weight: 600;
}

/* === Lightbox === */
.lightbox {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 200;
    background: rgba(0, 0, 0, 0.9);
    justify-content: center;
    align-items: center;
    cursor: pointer;
}

.lightbox.active {
    display: flex;
}

.lightbox-image {
    max-width: 90vw;
    max-height: 90vh;
    border-radius: var(--radius);
}

.lightbox-close {
    position: absolute;
    top: 1rem;
    right: 1.5rem;
    background: none;
    border: none;
    color: white;
    font-size: 2rem;
    cursor: pointer;
    padding: 0.5rem;
    line-height: 1;
}

.karaoke-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(380px, 100%), 1fr));
    gap: 1.5rem;
}

.karaoke-card {
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    padding: 1.25rem;
}

.karaoke-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
}

.karaoke-card-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-shrink: 0;
}

.karaoke-share-wrap {
    position: relative;
    flex-shrink: 0;
}

.karaoke-share-popup {
    position: absolute;
    right: 0;
    bottom: calc(100% + 0.55rem);
    max-width: 220px;
    padding: 0.45rem 0.65rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--bg-primary) 84%, black 16%);
    border: 1px solid rgba(255, 255, 255, 0.14);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.24);
    color: var(--text-primary);
    font-size: 0.78rem;
    line-height: 1.2;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transform: translateY(6px);
    transition:
        opacity 160ms ease,
        transform 160ms ease;
}

.karaoke-share-popup.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.karaoke-share-popup::after {
    content: "";
    position: absolute;
    right: 0.9rem;
    top: 100%;
    border-width: 6px 6px 0;
    border-style: solid;
    border-color: color-mix(in srgb, var(--bg-primary) 84%, black 16%) transparent transparent;
}

.karaoke-info h3 {
    font-size: 1.1rem;
    margin-bottom: 0.25rem;
}

.karaoke-artist {
    color: var(--text-secondary);
    margin-bottom: 0.75rem;
    font-size: 0.9rem;
}

.karaoke-players {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.karaoke-player h4 {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin-bottom: 0.35rem;
}

.karaoke-player video {
    width: 100%;
    border-radius: var(--radius);
}

.karaoke-player audio {
    width: 100%;
}

.karaoke-player-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.35rem;
}

/* === Random === */
.random-layout {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 1.5rem;
    align-items: start;
}

.random-image-card {
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    padding: 1.5rem;
    min-height: 300px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.random-image-container {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.random-placeholder {
    color: var(--text-secondary);
    text-align: center;
    padding: 2rem;
}

.random-image {
    max-width: 100%;
    max-height: 70vh;
    border-radius: var(--radius);
    transition: opacity 0.3s ease;
}

.random-image.loading {
    opacity: 0.3;
}

.random-controls-card {
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    padding: 1.5rem;
}

.random-controls-card h3 {
    font-size: 1.25rem;
    margin-bottom: 0.5rem;
}

.random-controls-desc {
    color: var(--text-secondary);
    font-size: 0.9rem;
    margin-bottom: 1.5rem;
}

.random-buttons {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

/* === 404 === */
.error-page {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    min-height: 60vh;
    gap: 1rem;
}

.error-image {
    max-width: 400px;
    border-radius: var(--radius-lg);
}

.error-page h1 {
    font-size: 3rem;
}

.error-page p {
    color: var(--text-secondary);
    font-size: 1.1rem;
}

/* === Custom Media Player === */
.mp-wrapper {
    position: relative;
    width: 100%;
}

.mp-wrapper.mp-video {
    background: var(--player-bg);
    border-radius: var(--radius-lg);
    overflow: hidden;
    line-height: 0;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
    user-select: none;
    -webkit-user-select: none;
}

.mp-wrapper.mp-video.mp-pending-metadata {
    aspect-ratio: 16 / 9;
}

/* Wrapper inside .player-container already has its own border-radius */
.player-container .mp-wrapper.mp-video {
    border-radius: 0;
    height: 100%;
}

body:not(.theater-mode) .player-container .mp-wrapper.mp-video video {
    width: 100%;
    height: 100%;
    max-height: none;
    object-fit: contain;
    position: absolute;
    inset: 0;
}

/* Keep the actual video/audio element full width */
.mp-wrapper video,
.mp-wrapper audio {
    width: 100%;
    display: block;
}

.mp-wrapper.mp-video video {
    max-height: 80vh;
    -webkit-tap-highlight-color: transparent;
}

.mp-wrapper.mp-video.mp-pending-metadata video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    max-height: none;
    object-fit: contain;
}

/* Fullscreen: video fills the entire screen */
.mp-wrapper.mp-video:fullscreen,
.mp-wrapper.mp-video:-webkit-full-screen {
    width: 100vw;
    height: 100vh;
    border-radius: 0;
    display: flex;
    flex-direction: column;
}

.mp-wrapper.mp-video:fullscreen video,
.mp-wrapper.mp-video:-webkit-full-screen video {
    flex: 1;
    width: 100%;
    height: 0; /* flex sizes it to fill remaining space */
    max-height: none;
    object-fit: contain;
}

/* --- Overlay (video only): big play icon when paused --- */
.mp-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    pointer-events: auto;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
}

.mp-overlay-icon {
    width: 64px;
    height: 64px;
    background: var(--media-scrim);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.2s ease;
    pointer-events: none;
}

.mp-video.mp-paused .mp-overlay-icon {
    opacity: 1;
}

.mp-overlay-icon svg {
    width: 30px;
    height: 30px;
    color: var(--media-on-overlay);
    margin-left: 3px; /* optical centering for play triangle */
}

/* --- Loading spinner (video only) --- */
.mp-spinner {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 48px;
    height: 48px;
    border: 3px solid rgba(255, 255, 255, 0.2);
    border-top-color: var(--accent-gold);
    border-radius: 50%;
    opacity: 0;
    pointer-events: none;
    z-index: 5;
    animation: mp-spin 0.8s linear infinite;
    transition: opacity 0.2s ease;
}

.mp-spinner.mp-spinner-visible {
    opacity: 1;
}

/* Hide spinner when paused — overlay play icon takes precedence */
.mp-video.mp-paused .mp-spinner {
    opacity: 0;
}

@keyframes mp-spin {
    to {
        transform: translate(-50%, -50%) rotate(360deg);
    }
}

/* --- Controls bar --- */
.mp-controls {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    line-height: 1;
}

/* Video: absolute overlay at bottom, fades in on hover/pause */
.mp-video .mp-controls {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.5rem;
    background: transparent;
    padding: 0.85rem 0.9rem 0.8rem;
    opacity: 0;
    transform: translateY(8px);
    transition:
        opacity 0.24s ease,
        transform 0.24s ease;
    will-change: opacity, transform;
    pointer-events: none;
}

.mp-status-top {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    display: flex;
    align-items: stretch;
    padding: 0.85rem 0.9rem 0.6rem;
    opacity: 0;
    transform: translateY(-8px);
    transition:
        opacity 0.24s ease,
        transform 0.24s ease;
    will-change: opacity, transform;
    pointer-events: none;
}

.mp-status-top::before {
    content: "";
    position: absolute;
    inset: 0 0 -78px;
    background: linear-gradient(
        to bottom,
        rgba(0, 0, 0, 0.7) 0%,
        rgba(0, 0, 0, 0.5) 34%,
        rgba(0, 0, 0, 0.24) 66%,
        rgba(0, 0, 0, 0.06) 90%,
        rgba(0, 0, 0, 0) 100%
    );
    pointer-events: none;
    z-index: 0;
    opacity: 1;
}

.mp-status-top > * {
    position: relative;
    z-index: 1;
}

.mp-video .mp-controls::before {
    content: "";
    position: absolute;
    inset: -78px 0 0;
    background: linear-gradient(
        to top,
        rgba(0, 0, 0, 0.7) 0%,
        rgba(0, 0, 0, 0.5) 34%,
        rgba(0, 0, 0, 0.24) 66%,
        rgba(0, 0, 0, 0.06) 90%,
        rgba(0, 0, 0, 0) 100%
    );
    pointer-events: none;
    z-index: 0;
    opacity: 1;
}

.mp-video .mp-controls > * {
    position: relative;
    z-index: 1;
}

.mp-skip-hints {
    display: none;
}

.mp-controls-top {
    display: flex;
    align-items: center;
    width: 100%;
}

.mp-controls-bottom {
    display: flex;
    align-items: center;
    gap: 6px;
    width: 100%;
    min-width: 0;
}

.mp-control-bubble {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 0.22rem;
    min-height: 2.35rem;
    padding: 0.2rem 0.28rem;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.58);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.mp-audio .mp-control-bubble {
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.mp-control-bubble-play {
    padding-inline: 0.24rem;
}

.mp-control-bubble-transport {
    gap: 0.08rem;
    padding-inline: 0.24rem;
}

.mp-control-bubble-volume {
    padding-inline: 0.24rem 0.45rem;
    overflow: visible;
}

.mp-control-bubble-theater {
    margin-left: auto;
    padding-inline: 0.24rem;
}

.mp-control-bubble-actions {
    padding-inline: 0.24rem;
}

.mp-tag-status {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.5rem;
    width: 100%;
}

.mp-status-top .mp-tag-status-item {
    background: var(--media-scrim);
    border-color: rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.mp-tag-status-item {
    position: relative;
    display: grid;
    align-content: center;
    gap: 0.28rem;
    min-width: 0;
    min-height: 3.05rem;
    padding: 0.56rem 0.65rem;
    border-radius: 0.7rem;
    overflow: hidden;
    background: rgba(0, 0, 0, 0.52);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: none;
}

.mp-tag-status-button {
    appearance: none;
    text-align: left;
    color: inherit;
    cursor: pointer;
    transition:
        background var(--transition),
        border-color var(--transition),
        transform var(--transition);
}

.mp-tag-status-button:hover,
.mp-tag-status-button:focus-visible {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.18);
    transform: translateY(-1px);
}

.mp-tag-status-button:disabled {
    cursor: default;
}

.mp-tag-status-button:disabled:hover,
.mp-tag-status-button:disabled:focus-visible {
    background: rgba(0, 0, 0, 0.52);
    border-color: rgba(255, 255, 255, 0.08);
    transform: none;
}

.mp-tag-status-label {
    font-size: 0.63rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.62);
    line-height: 1;
}

.mp-tag-status-value {
    min-width: 0;
    font-size: 0.77rem;
    font-weight: 600;
    line-height: 1.28;
    color: rgba(255, 255, 255, 0.96);
    white-space: normal;
    overflow: hidden;
    text-overflow: ellipsis;
    overflow-wrap: anywhere;
}

.mp-control-bubble-actions .mp-btn,
.mp-control-bubble-theater .theater-overlay-toggle {
    min-height: 2.1rem;
}

.mp-video:not(.mp-paused, .mp-controls-visible),
.mp-video:not(.mp-paused, .mp-controls-visible) * {
    cursor: none;
}

.mp-video.mp-paused .mp-status-top,
.mp-video.mp-controls-visible .mp-status-top,
.mp-video.mp-paused .mp-controls,
.mp-video.mp-controls-visible .mp-controls {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

/* Audio: static bar with glassmorphism */
.mp-audio .mp-controls {
    background: var(--bg-tertiary);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: var(--glass-border);
    border-radius: var(--radius);
    box-shadow: var(--glass-shadow);
    margin-top: 6px;
}

/* --- Buttons --- */
.mp-btn {
    background: none;
    border: none;
    color: var(--media-on-overlay);
    cursor: pointer;
    padding: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
    transition: background var(--transition);
    flex-shrink: 0;
    line-height: 0;
}

.mp-control-bubble .mp-btn {
    border-radius: 999px;
}

.mp-skip-back-btn,
.mp-skip-fwd-btn {
    gap: 0.22rem;
    min-width: 2.35rem;
    padding: 0.18rem 0.4rem;
    line-height: 1;
}

.mp-btn:hover {
    background: rgba(255, 255, 255, 0.16);
}

.mp-btn svg {
    width: 18px;
    height: 18px;
}

.mp-skip-back-btn svg,
.mp-skip-fwd-btn svg {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
}

.mp-skip-label {
    display: inline-flex;
    align-items: center;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    line-height: 1;
}

.mp-audio .mp-btn {
    color: var(--text-primary);
}

.mp-audio .mp-btn:hover {
    background: var(--bg-secondary);
}

/* --- Seek bar --- */
.mp-seek-group {
    flex: 1;
    display: flex;
    align-items: center;
    min-width: 0;
    width: 100%;
    padding: 0;
}

.mp-seek-bar {
    flex: 1;
    height: 20px; /* tall hitbox, visually transparent */
    background: transparent;
    position: relative;
    cursor: pointer;
}

/* Visual track lives in ::before so height can animate independently */
.mp-seek-bar::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    height: 4px;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 2px;
    transition: height 0.15s ease;
    pointer-events: none;
}

.mp-audio .mp-seek-bar::before {
    background: var(--border);
}

.mp-seek-bar:hover::before,
.mp-wrapper.mp-dragging .mp-seek-bar::before {
    height: 6px;
}

.mp-seek-fill {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    height: 4px;
    border-radius: 2px;
    pointer-events: none;
    transition: height 0.15s ease;
}

.mp-seek-bar:hover .mp-seek-fill,
.mp-wrapper.mp-dragging .mp-seek-fill {
    height: 6px;
}

.mp-seek-buffered {
    background: rgba(255, 255, 255, 0.25);
    width: 0;
}

.mp-audio .mp-seek-buffered {
    background: var(--shell-active-border);
}

.mp-seek-progress {
    background: var(--accent-gold);
    width: 0;
    z-index: 1;
}

.mp-seek-thumb {
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--accent-gold);
    opacity: 0;
    transition: opacity 0.15s;
    pointer-events: none;
    z-index: 2;
    left: 0;
}

.mp-seek-bar:hover .mp-seek-thumb,
.mp-wrapper.mp-dragging .mp-seek-thumb {
    opacity: 1;
}

.mp-seek-tooltip {
    position: absolute;
    bottom: calc(100% + 10px);
    transform: translateX(-50%);
    background: rgba(0, 0, 0, 0.82);
    color: var(--media-on-overlay);
    font-size: 0.72rem;
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
    padding: 3px 7px;
    border-radius: 4px;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.1s ease;
    z-index: 10;
}

.mp-seek-tooltip-visible {
    opacity: 1;
}

.mp-audio .mp-seek-tooltip {
    background: var(--bg-primary);
    color: var(--text-primary);
    border: var(--glass-border);
    box-shadow: var(--shadow);
}

/* --- Time display --- */
.mp-time {
    font-size: 0.72rem;
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
    flex-shrink: 0;
    color: rgba(255, 255, 255, 0.9);
}

.mp-video .mp-time {
    flex: 0 0 auto;
    min-width: max-content;
    text-align: center;
    padding: 0 0.28rem;
}

.mp-audio .mp-time {
    color: var(--text-secondary);
}

/* --- Volume group --- */
.mp-volume-group {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
}

.mp-volume-slider-wrap {
    width: 72px;
}

.mp-vol-slider {
    height: 20px; /* tall hitbox, visually transparent */
    background: transparent;
    position: relative;
    cursor: pointer;
}

.mp-vol-slider::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    height: 4px;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 2px;
    transition: height 0.15s ease;
    pointer-events: none;
}

.mp-audio .mp-vol-slider::before {
    background: var(--border);
}

.mp-vol-slider:hover::before {
    height: 6px;
}

.mp-vol-slider:hover .mp-seek-fill {
    height: 6px;
}

.mp-vol-level {
    background: var(--accent-purple);
    width: 100%;
}

.mp-vol-thumb {
    position: absolute;
    top: 50%;
    left: 100%;
    transform: translate(-50%, -50%);
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--accent-purple);
    opacity: 0;
    transition: opacity 0.15s;
    pointer-events: none;
    z-index: 2;
}

.mp-vol-slider:hover .mp-vol-thumb {
    opacity: 1;
}

.mp-sleeping-btn.is-active {
    background: rgba(255, 255, 255, 0.16);
    color: var(--accent-gold);
}

.mp-audio .mp-sleeping-btn.is-active {
    color: var(--accent-gold);
    background: var(--bg-tertiary);
}

.mp-sleeping-btn:disabled {
    cursor: not-allowed;
    opacity: 0.45;
}

/* Karaoke card player overrides */
.karaoke-player .mp-audio .mp-controls {
    margin-top: 4px;
}

.karaoke-player .mp-video .mp-controls-bottom {
    justify-content: flex-start;
}

.karaoke-player .mp-video .mp-control-bubble-actions {
    margin-left: auto;
    padding-inline: 0.24rem;
}

.karaoke-player .mp-skip-hints,
.karaoke-player .mp-skip-back-btn,
.karaoke-player .mp-skip-fwd-btn {
    display: none !important;
}

/* === Footer === */
.footer {
    position: relative;
    z-index: 1;
    text-align: center;
    padding: 1.5rem 1.5rem 2rem;
    border-top: 1px solid var(--border);
    color: var(--text-secondary);
    font-size: 0.8rem;
    margin-top: 2rem;
    letter-spacing: 0.01em;
}

/* === Responsive === */
@media (max-width: 1024px) {
    .home-hero,
    .home-discovery-grid {
        grid-template-columns: 1fr;
    }

    body:not(.theater-mode) .player-page {
        width: calc(100% + 1.5rem);
        max-width: none;
        margin-left: -0.75rem;
        margin-right: -0.75rem;
    }

    body:not(.theater-mode) .player-page-top {
        padding-left: 0.75rem;
        padding-right: 0.75rem;
    }

    body:not(.theater-mode) .player-layout {
        display: flex;
        flex-direction: column;
        width: 100%;
    }

    body:not(.theater-mode) .player-sidebar {
        order: 2;
        width: 100%;
        align-self: stretch;
    }

    body:not(.theater-mode) .player-column,
    body:not(.theater-mode) .player-container,
    body:not(.theater-mode) .player-info-card {
        width: 100%;
        max-width: none;
    }

    body:not(.theater-mode) .player-sidebar > .chat-panel,
    body:not(.theater-mode) .player-sidebar > .up-next-panel {
        width: 100%;
    }

    body:not(.theater-mode) .player-sidebar > .chat-panel {
        height: 400px;
        max-height: 400px;
    }

    .player-info-grid,
    .player-info-grid-no-tags {
        grid-template-columns: 1fr;
    }

    .player-info-grid {
        grid-template-areas:
            "tags"
            "clip"
            "downloads"
            "share";
    }

    .tags-section {
        height: auto;
    }

    .tags-list {
        flex: 0 1 auto;
        max-height: 480px;
    }

    .player-info-grid-no-tags {
        grid-template-areas:
            "clip"
            "downloads"
            "share";
    }

    .player-card-shortcuts {
        display: none;
    }

    .player-page-top {
        gap: 0.75rem;
    }

    .player-page-top .back-link {
        font-size: 0.84rem;
    }

    .player-page-top .player-meta-badge {
        padding: 0.32rem 0.6rem;
        font-size: 0.76rem;
    }

    .player-title-row {
        flex-direction: column;
        align-items: stretch;
    }

    .player-source-switch-wrap {
        justify-content: flex-start;
    }

    .mp-tag-status {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0.35rem;
    }

    .mp-controls-bottom {
        flex-wrap: nowrap;
        gap: 4px;
        justify-content: flex-start;
    }

    .mp-control-bubble-actions {
        margin-left: 0;
        flex: 0 0 auto;
        min-width: max-content;
    }

    .mp-control-bubble-theater {
        margin-left: auto;
        flex: 0 0 auto;
        min-width: max-content;
        width: auto;
    }

    .mp-video .mp-time {
        margin-right: 0;
    }

    .mp-control-bubble-play,
    .mp-control-bubble-transport,
    .mp-control-bubble-volume {
        flex: 0 0 auto;
    }

    .mp-control-bubble-theater .theater-overlay-toggle {
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        gap: 0.35rem;
        flex-shrink: 0;
        min-width: max-content;
        width: auto;
        min-height: 2rem;
        padding: 0.35rem 0.55rem;
        white-space: nowrap;
    }
}

@media (max-width: 720px) {
    body:not(.theater-mode) .player-page {
        width: calc(100% + 1rem);
        margin-left: -0.5rem;
        margin-right: -0.5rem;
    }

    .player-page-top {
        gap: 0.55rem;
        padding-left: 0.5rem;
        padding-right: 0.5rem;
    }

    .player-page-top .back-link {
        font-size: 0.78rem;
    }

    .player-page-top .player-meta-badge,
    .player-page-top .player-meta-badge .vod-number,
    .player-page-top .player-meta-badge .vod-date,
    .player-page-top .player-meta-badge .player-meta-separator {
        font-size: 0.72rem;
    }

    .player-page-top .player-meta-badge {
        padding: 0.28rem 0.5rem;
    }

    .mp-tag-status {
        gap: 0.3rem;
    }

    .mp-tag-status-item {
        min-height: 2.7rem;
        padding: 0.45rem 0.5rem;
    }

    .mp-tag-status-label {
        font-size: 0.56rem;
    }

    .mp-tag-status-value {
        font-size: 0.69rem;
    }

    .mp-control-bubble-theater .theater-overlay-toggle {
        padding: 0.32rem 0.48rem;
        font-size: 0;
        gap: 0;
    }

    .mp-controls-bottom {
        flex-wrap: wrap;
        row-gap: 0.4rem;
    }

    .mp-control-bubble-play,
    .mp-control-bubble-transport,
    .mp-control-bubble-volume {
        order: 1;
    }

    .mp-control-bubble-theater {
        order: 2;
        margin-left: auto;
    }

    .mp-control-bubble-actions {
        order: 3;
    }

    .home-entity-card,
    .home-random-card {
        grid-template-columns: 72px minmax(0, 1fr);
    }

    .home-entity-card img,
    .home-random-card img,
    .home-random-media,
    .search-result-thumb,
    .search-result-thumb-model {
        width: 72px;
        height: 72px;
        aspect-ratio: 1;
    }

    .search-result-card {
        flex-direction: row;
        align-items: stretch;
    }

    .vod-card-actions,
    .player-resume-card,
    .player-shortcuts-header,
    .shortcut-row {
        flex-direction: column;
        align-items: stretch;
    }

    .vod-card-resume-meta,
    .player-resume-actions {
        flex-direction: column;
    }

    .clip-inputs {
        grid-template-columns: 1fr;
    }

    .player-source-switch {
        min-width: 0;
        width: 100%;
    }

    .player-source-switch-side {
        min-height: 42px;
        padding: 0.7rem 0.85rem;
    }
}

@media (max-width: 640px) {
    .mp-skip-back-btn,
    .mp-skip-fwd-btn {
        display: none;
        min-width: 2rem;
        padding: 0.15rem 0.28rem;
    }

    .mp-controls-bottom {
        gap: 0.35rem;
    }

    .mp-control-bubble {
        min-height: 2.15rem;
        padding: 0.16rem 0.22rem;
    }

    .mp-control-bubble-transport {
        gap: 0.05rem;
        padding-inline: 0.18rem;
    }

    .mp-control-bubble-volume,
    .mp-control-bubble-actions,
    .mp-control-bubble-theater {
        padding-inline: 0.18rem;
    }

    .mp-skip-label {
        font-size: 0.72rem;
    }

    .home-hero {
        padding: 1.25rem;
    }

    .discovery-page-header {
        flex-flow: row wrap;
        align-items: center;
        gap: 0.5rem;
    }

    .discovery-page-header h1 {
        font-size: 1.35rem;
        margin-bottom: 0;
    }

    .discovery-page-header .page-subtitle {
        display: none;
    }

    .discovery-toolbar {
        flex-direction: column;
        align-items: stretch;
        gap: 0.75rem;
        margin-bottom: 1rem;
    }

    .discovery-toolbar .search-field {
        width: 100%;
    }

    .discovery-toolbar-actions {
        display: flex;
        align-items: center;
        gap: 0.75rem;
    }

    .discovery-toolbar-actions .discovery-mobile-toggle {
        flex: 1;
    }

    .discovery-toolbar-actions .discovery-results-meta {
        flex-direction: column;
        align-items: flex-end;
        white-space: nowrap;
        font-size: 0.82rem;
    }

    .search-result-card {
        gap: 0.75rem;
    }

    .search-result-meta {
        white-space: normal;
    }

    .mobile-discovery-actions {
        flex-direction: column;
    }

    .mobile-discovery-actions .btn {
        width: 100%;
        justify-content: center;
    }
}

@media (max-width: 1024px) and (hover: none) and (pointer: coarse) {
    .tag-item {
        padding-top: 0.4rem;
        padding-bottom: 0.4rem;
    }

    .tag-labels {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        overflow-wrap: normal;
        word-break: normal;
    }

    .mp-tag-status-item {
        min-height: 2.45rem;
    }

    .mp-tag-status-value {
        white-space: nowrap;
        text-overflow: ellipsis;
        overflow-wrap: normal;
        word-break: normal;
        line-height: 1.15;
    }

    .mp-skip-hints {
        display: block;
        opacity: 0;
        visibility: hidden;
        transition: opacity var(--transition);
    }

    .mp-skip-hint {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        display: grid;
        justify-items: center;
        gap: 0.2rem;
        width: min(34%, 8.5rem);
        padding: 0.5rem 0.35rem;
        border-radius: 0.9rem;
        background: rgba(0, 0, 0, 0.26);
        color: rgba(255, 255, 255, 0.92);
        text-align: center;
        pointer-events: none;
        opacity: 1;
        transition: transform var(--transition);
        z-index: 1;
    }

    .mp-skip-hint-left {
        left: 0.85rem;
    }

    .mp-skip-hint-right {
        right: 0.85rem;
    }

    .mp-skip-hint-text {
        font-size: 0.62rem;
        font-weight: 700;
        letter-spacing: 0.04em;
        text-transform: uppercase;
        line-height: 1.1;
    }

    .mp-skip-hint-value {
        font-size: 0.82rem;
        font-weight: 800;
        line-height: 1;
    }

    .mp-video.mp-paused .mp-skip-hints,
    .mp-video.mp-controls-visible .mp-skip-hints {
        opacity: 1;
        visibility: visible;
    }

    .mp-controls-bottom {
        flex-wrap: wrap;
        row-gap: 0.4rem;
    }

    .mp-control-bubble-play,
    .mp-control-bubble-transport,
    .mp-control-bubble-volume {
        order: 1;
    }

    .mp-control-bubble-theater {
        order: 2;
        margin-left: auto;
    }

    .mp-control-bubble-actions {
        order: 3;
    }

    .mp-skip-back-btn,
    .mp-skip-fwd-btn {
        display: none;
    }

    .mp-control-bubble-actions .mp-btn,
    .mp-control-bubble-theater .theater-overlay-toggle {
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        width: 2.1rem;
        min-width: 2.1rem;
        height: 2.1rem;
        min-height: 2.1rem;
        padding: 0;
        border-radius: 999px;
        flex-shrink: 0;
    }

    .mp-control-bubble-theater .theater-overlay-toggle {
        font-size: 0;
        gap: 0;
    }
}

@media (max-width: 1024px) and (hover: none) and (pointer: coarse) and (orientation: landscape) {
    body.theater-mode .player-layout.has-chat {
        grid-template-columns: minmax(0, 1fr) minmax(180px, 30vw);
    }
}

.karaoke-player .mp-video .mp-control-bubble-actions .mp-btn {
    width: auto;
    min-width: 0;
    height: auto;
    min-height: 0;
    padding: 4px;
}

@media (max-width: 768px) {
    .random-layout {
        grid-template-columns: 1fr;
    }

    .environment-banner {
        flex-direction: column;
        gap: 0.15rem;
        padding: 0.7rem 1rem;
    }

    .environment-banner strong {
        font-size: 0.76rem;
    }

    .environment-banner span {
        font-size: 0.86rem;
    }

    .nav-toggle {
        display: flex;
    }

    .nav-search-desktop {
        display: none;
    }

    .nav-search-mobile-toggle {
        display: inline-flex;
    }

    .nav-right {
        margin-left: auto;
    }

    .nav-links {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background: var(--nav-bg);
        backdrop-filter: var(--glass-blur);
        -webkit-backdrop-filter: var(--glass-blur);
        flex-direction: column;
        padding: 1rem;
        border-bottom: 1px solid var(--border);
    }

    .nav-links.open {
        display: flex;
    }

    .nav-links a {
        padding: 0.75rem 1rem;
    }

    .discovery-mobile-toggle {
        display: inline-flex;
    }

    .discovery-sidebar {
        display: none;
    }

    .discovery-field-row {
        grid-template-columns: 1fr;
    }

    .model-detail-top {
        grid-template-columns: 1fr;
    }

    .model-detail-image {
        max-width: none;
    }

    .model-toggles-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .model-detail-hero,
    .model-meta-grid,
    .model-debut-card,
    .model-timeline-grid {
        grid-template-columns: 1fr;
    }

    .model-debut-thumb {
        min-height: 180px;
    }

    .credit-entry {
        grid-template-columns: 1fr;
        gap: 0.5rem;
    }

    .model-meta-credit {
        grid-template-columns: 1fr;
        gap: 0.25rem;
    }

    .discovery-shell {
        grid-template-columns: 1fr;
    }

    .vods-grid {
        grid-template-columns: 1fr;
    }

    .hero-image {
        max-height: 300px;
    }

    .home-cards {
        grid-template-columns: repeat(2, 1fr);
    }

    .toggle-gallery {
        grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    }

    .clip-inputs {
        grid-template-columns: 1fr;
    }

    .tags-list {
        max-height: 250px;
    }

    .download-buttons {
        flex-direction: column;
    }

    .mp-volume-slider-wrap {
        display: none;
    }

    .mp-btn svg {
        width: 16px;
        height: 16px;
    }

    .mp-time {
        font-size: 0.65rem;
    }

    .search-result-card,
    .stats-summary-grid,
    .stats-grid {
        flex-direction: column;
    }

    .up-next-header {
        flex-flow: row nowrap;
        align-items: center;
    }

    .up-next-header > :first-child {
        min-width: 0;
        flex: 1 1 auto;
    }

    .up-next-header .autoplay-switch {
        flex: 0 0 auto;
    }

    .stats-summary-grid,
    .stats-grid {
        display: flex;
    }

    .stats-panel-growth {
        grid-area: auto;
        grid-column: auto;
        grid-row: auto;
    }
}

@media (max-width: 480px) {
    .home-cards {
        grid-template-columns: 1fr;
    }

    .page-header h1 {
        font-size: 1.5rem;
    }
}

/* === Footer Links === */
.footer-links {
    margin-top: 0.6rem;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 0.15rem 0.1rem;
}

.footer-links a {
    color: var(--text-secondary);
    text-decoration: none;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    transition: all var(--transition);
    font-weight: 500;
}

.footer-links a:hover {
    color: var(--accent-purple);
    background: var(--bg-tertiary);
}

.footer-links-sep {
    color: var(--border);
    font-size: 0.7rem;
    pointer-events: none;
    user-select: none;
}

/* === Changelog Page === */
.changelog-list {
    max-width: 800px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    padding: 0 1.5rem 3rem;
}

.changelog-entry {
    padding: 1.5rem;
}

.changelog-entry-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.changelog-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--text-primary);
}

.changelog-date {
    font-size: 0.8rem;
    color: var(--text-secondary);
    flex-shrink: 0;
}

.changelog-changes {
    margin: 0;
    padding-left: 1.5rem;
    color: var(--text-secondary);
    line-height: 1.7;
}

.changelog-changes li + li {
    margin-top: 0.25rem;
}

/* === About Page === */
.about-sections {
    max-width: 800px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    padding: 0 1.5rem 3rem;
}

.about-section {
    padding: 1.5rem;
}

.about-section h2 {
    font-size: 1.1rem;
    font-weight: 600;
    margin: 0 0 0.75rem;
    color: var(--text-primary);
}

.about-section p {
    color: var(--text-secondary);
    line-height: 1.7;
    margin: 0 0 0.5rem;
}

.about-section p:last-child {
    margin-bottom: 0;
}

.about-list {
    margin: 0;
    padding-left: 1.5rem;
    color: var(--text-secondary);
    line-height: 1.7;
}

.about-list li + li {
    margin-top: 0.25rem;
}

.about-list a {
    color: var(--accent-purple);
    text-decoration: none;
}

.about-list a:hover {
    text-decoration: underline;
}

/* === CSP helper classes (replacing inline styles) === */
.admin-inline {
    display: inline;
}

.admin-list-label--flush {
    margin: 0;
}

/* === User Nav Menu (logged-in dropdown + sign-in button) === */

.user-nav-menu {
    position: relative;
}

.user-nav-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    padding: 0;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: 999px;
    color: var(--text-secondary);
    cursor: pointer;
    transition:
        background var(--transition),
        border-color var(--transition),
        color var(--transition);
}

.user-nav-toggle:hover {
    background: var(--bg-tertiary);
    border-color: var(--accent-purple);
    color: var(--accent-purple);
}

.user-nav-chevron {
    transition: transform var(--transition);
    flex-shrink: 0;
}

.user-nav-toggle[aria-expanded="true"] .user-nav-chevron {
    transform: rotate(180deg);
}

.user-nav-username,
.user-nav-chevron {
    display: none;
}

.user-nav-dropdown {
    position: absolute;
    top: calc(100% + 0.5rem);
    right: 0;
    min-width: 168px;
    background: var(--bg-secondary);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: var(--glass-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--glass-shadow);
    z-index: 200;
    overflow: hidden;
    padding: 0.3rem;
}

.user-nav-item {
    display: block;
    width: 100%;
    padding: 0.5rem 0.75rem;
    font-size: 0.84rem;
    font-weight: 500;
    color: var(--text-primary);
    text-decoration: none;
    text-align: left;
    background: none;
    border: none;
    cursor: pointer;
    transition: all var(--transition);
    border-radius: calc(var(--radius-lg) - 4px);
}

.user-nav-item:hover {
    background: var(--bg-tertiary);
    color: var(--accent-purple);
}

.user-nav-divider {
    height: 1px;
    background: var(--border);
    margin: 0.25rem 0;
}

.user-nav-signout-form {
    margin: 0;
    padding: 0;
}

.user-nav-signout {
    color: var(--text-secondary);
}

.user-nav-signout:hover {
    color: var(--danger);
    background: var(--danger-bg);
}

/* Sign-in button (logged-out state) */
.user-nav-login-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    padding: 0;
    color: var(--accent-purple);
    border: 1px solid var(--border);
    background: var(--bg-secondary);
    border-radius: 999px;
    text-decoration: none;
    transition: all var(--transition);
}

.user-nav-login-btn:hover {
    background: var(--accent-purple);
    border-color: var(--accent-purple);
    color: var(--media-on-overlay);
}

.user-nav-login-label {
    display: none;
}

/* === Account Auth Pages (register / login) === */

.account-auth-wrap {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding: 3rem 1rem 4rem;
    min-height: 60vh;
}

.account-auth-card {
    width: 100%;
    max-width: 480px;
    padding: 2rem 2.5rem;
}

.account-auth-title {
    font-size: 1.6rem;
    font-weight: 700;
    margin-bottom: 1.25rem;
    background: var(--heading-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.account-auth-notice {
    background: var(--bg-tertiary);
    border: var(--glass-border);
    border-radius: var(--radius);
    padding: 1rem 1.25rem;
    margin-bottom: 1.5rem;
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.account-auth-notice p {
    margin: 0 0 0.5rem;
}

.account-auth-notice p:last-child {
    margin-bottom: 0;
}

.account-auth-notice ul {
    margin: 0.5rem 0 0 1.25rem;
    padding: 0;
}

.account-auth-notice li {
    margin-bottom: 0.25rem;
}

.account-auth-notice strong {
    color: var(--text-primary);
}

.account-auth-error {
    color: var(--danger);
    font-size: 0.9rem;
    margin-bottom: 1rem;
    padding: 0.6rem 0.75rem;
    background: var(--danger-bg);
    border-radius: var(--radius);
    border: 1px solid var(--danger-border);
}

.account-auth-success {
    color: #2f855a;
    font-size: 0.9rem;
    margin-bottom: 1rem;
    padding: 0.6rem 0.75rem;
    background: rgba(47, 133, 90, 0.08);
    border-radius: var(--radius);
    border: 1px solid rgba(47, 133, 90, 0.25);
}

.account-auth-form {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.account-auth-btn {
    margin-top: 0.5rem;
    width: 100%;
}

.account-auth-hint {
    display: block;
    font-size: 0.78rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
}

.account-auth-alt {
    margin-top: 1.25rem;
    text-align: center;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.account-auth-alt a {
    color: var(--accent-purple);
    text-decoration: none;
}

.account-auth-alt a:hover {
    text-decoration: underline;
}

/* === Favorite Toggle Button (VOD player + cards) === */

.favorite-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    padding: 0;
    background: var(--bg-secondary);
    border: var(--glass-border);
    border-radius: var(--radius);
    cursor: pointer;
    color: var(--text-secondary);
    transition:
        color var(--transition),
        background var(--transition),
        border-color var(--transition),
        transform 0.15s;
    flex-shrink: 0;
}

html:not([data-theme="dark"]) .favorite-toggle {
    background: var(--favorite-bg-medium);
    border: 1px solid var(--favorite-border-strong);
    color: var(--favorite-strong);
    box-shadow: var(--favorite-shadow);
}

html:not([data-theme="dark"]) #favorite-toggle {
    background: var(--favorite-bg-medium);
    border: 1px solid var(--favorite-border-strong);
    color: var(--favorite-strong);
    box-shadow: var(--favorite-shadow);
}

.favorite-toggle:hover {
    color: var(--favorite);
    border-color: var(--favorite-border);
    background: var(--favorite-bg-soft);
    transform: scale(1.08);
}

.favorite-toggle.is-favorite {
    color: var(--favorite);
    background: var(--favorite-bg);
    border-color: var(--favorite-border);
}

.favorite-toggle.is-favorite svg {
    fill: var(--favorite);
}

.favorite-toggle svg {
    width: 15px;
    height: 15px;
    fill: none;
    stroke: currentcolor;
    transition: fill var(--transition);
}

.favorite-toggle-card {
    position: absolute;
    top: 0.65rem;
    right: 0.65rem;
    z-index: 3;
    background: rgba(17, 24, 39, 0.8);
    border-color: rgba(255, 255, 255, 0.12);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

html:not([data-theme="dark"]) .favorite-toggle-card {
    background: rgba(255, 244, 249, 0.96);
    border-color: var(--favorite-border);
}

html:not([data-theme="dark"]) .favorite-toggle:hover,
html:not([data-theme="dark"]) #favorite-toggle:hover,
html:not([data-theme="dark"]) .favorite-toggle:focus-visible,
html:not([data-theme="dark"]) #favorite-toggle:focus-visible,
html:not([data-theme="dark"]) .favorite-toggle.is-favorite,
html:not([data-theme="dark"]) #favorite-toggle.is-favorite {
    background: var(--favorite);
    border-color: var(--favorite);
    color: var(--favorite-on);
    box-shadow: var(--favorite-shadow-strong);
}

html:not([data-theme="dark"]) .favorite-toggle.is-favorite svg,
html:not([data-theme="dark"]) #favorite-toggle.is-favorite svg,
html:not([data-theme="dark"]) .favorite-toggle:hover svg,
html:not([data-theme="dark"]) #favorite-toggle:hover svg,
html:not([data-theme="dark"]) .favorite-toggle:focus-visible svg,
html:not([data-theme="dark"]) #favorite-toggle:focus-visible svg {
    fill: currentcolor;
}

/* === Favorite Text Button (VOD player controls row) === */

.favorite-toggle-text {
    width: auto;
    height: auto;
    padding: 0.3rem 0.65rem;
    gap: 0.4rem;
    font-size: 0.85rem;
    font-weight: 600;
    background: var(--favorite-bg);
    border: 1px solid var(--favorite-border);
    color: var(--favorite-strong);
    border-radius: var(--radius);
}

[data-theme="dark"] .favorite-toggle-text {
    background: var(--favorite-bg);
    border-color: var(--favorite-border-soft);
    color: var(--favorite);
}

.favorite-toggle-text svg {
    width: 14px;
    height: 14px;
}

.favorite-toggle-text:hover {
    background: var(--favorite-bg-strong);
    border-color: var(--favorite-border-strong);
    transform: none;
}

.favorite-toggle-text.is-favorite {
    background: var(--favorite-bg-medium);
    border-color: var(--favorite-border-strong);
    box-shadow: 0 0 12px var(--favorite-border);
}

.favorite-toggle-text.is-favorite svg {
    fill: currentcolor;
}

/* Favorite heart overlay on VOD cards */
.vod-card-favorite-indicator {
    position: absolute;
    top: 0.4rem;
    right: 0.4rem;
    width: 1.6rem;
    height: 1.6rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--media-scrim);
    border-radius: calc(var(--radius) - 2px);
    pointer-events: none;
}

.vod-card-favorite-indicator svg {
    width: 12px;
    height: 12px;
    fill: var(--favorite);
    stroke: var(--favorite);
}

/* === Favorite count badge (inside favorite-toggle-text buttons) === */

.fav-count-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.25em;
    padding: 0.05rem 0.3rem;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.15);
    font-size: 0.78em;
    font-weight: 700;
    line-height: 1.4;
    white-space: nowrap;
}

/* === Unified VOD Card === */

.unified-card-group {
    padding: 0.85rem;
}

.unified-card-group-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
    gap: 0.85rem;
}

/* === Shell === */
.unified-card-shell {
    position: relative;
    display: flex;
    flex-direction: column;
    z-index: 0;
}

.unified-card-shell:hover {
    z-index: 1;
}

/* === Card link === */
.unified-card {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: var(--text-primary);
    border-radius: var(--radius);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.08);
    transition:
        transform 0.18s ease,
        box-shadow 0.18s ease,
        border-color 0.18s ease;
}

.unified-card:hover,
.unified-card:focus-visible {
    transform: translateY(-2px);
    box-shadow: var(--card-hover-shadow);
    border-color: var(--card-hover-border);
    outline: none;
}

/* === Thumbnail === */
.unified-card-thumb {
    position: relative;
    flex-shrink: 0;
    padding: 0.75rem 0.75rem 0;
    background: radial-gradient(circle at top, rgba(178, 155, 255, 0.08), transparent 52%);
}

.unified-card-thumb img {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    display: block;
    border-radius: calc(var(--radius) - 2px);
}

.unified-card-thumb .vod-thumbnail-placeholder {
    width: 100%;
    aspect-ratio: 16 / 9;
    border-radius: calc(var(--radius) - 2px);
    background: var(--bg-tertiary);
}

/* === Progress bar (injected by watch-progress.js) === */
.unified-card-thumb .resume-progress-bar {
    position: absolute;
    left: 0.75rem;
    right: 0.75rem;
    bottom: 0;
    height: 4px;
    background: rgba(15, 23, 42, 0.35);
    z-index: 3;
    border-radius: 0 0 calc(var(--radius) - 2px) calc(var(--radius) - 2px);
}

.unified-card-thumb .resume-progress-bar span {
    display: block;
    height: 100%;
    background: var(--button-gradient);
}

/* === Duration badge === */
.unified-duration-badge {
    position: absolute;
    right: 1.1rem;
    bottom: 0.5rem;
    z-index: 2;
    padding: 0.15rem 0.45rem;
    border-radius: 999px;
    background: rgba(12, 8, 23, 0.82);
    color: var(--media-on-overlay);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    line-height: 1.4;
    white-space: nowrap;
}

/* When progress bar is present, shift badge up slightly */
.unified-card-thumb:has(.resume-progress-bar) .unified-duration-badge {
    bottom: 0.75rem;
}

/* === Card body === */
.unified-card-body {
    display: flex;
    flex-direction: column;
    padding: 0.65rem 0.8rem 0.6rem;
    gap: 0.4rem;
    flex: 1;
    min-width: 0;
}

/* === Slot label (e.g. "Autoplay next" in up-next sidebar) === */
.unified-slot-label {
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: var(--accent-purple);
}

/* === Title === */
.unified-card-title {
    margin: 0;
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1.4;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    color: var(--text-primary);
    min-height: 0;
    flex: none;
    letter-spacing: -0.005em;
}

/* === Meta row === */
.unified-card-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.4rem;
    margin-top: auto;
    min-width: 0;
}

/* === Number + date pill === */
.unified-card-pill {
    gap: 0.3rem;
    padding: 0.18rem 0.5rem;
    font-size: 0.72rem;
    font-weight: 700;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
    min-width: 0;
}

.unified-pill-number {
    color: var(--accent-purple);
}

.unified-pill-sep {
    color: var(--text-secondary);
}

.unified-meta-left {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    min-width: 0;
    overflow: hidden;
}

.unified-fav-pill {
    color: var(--favorite);
    border-color: var(--favorite-border-soft);
    background: var(--favorite-bg-soft);
    gap: 0.2rem;
    flex-shrink: 0;
}

/* === Colored dots === */
.unified-dots {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    flex-shrink: 0;
    overflow: visible;
    position: relative;
    cursor: default;
    font-size: 0.72rem;
}

.unified-dots[data-tip]::after {
    content: attr(data-tip);
    position: absolute;
    bottom: calc(100% + 6px);
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap;
    background: rgba(12, 8, 23, 0.88);
    color: var(--media-on-overlay);
    font-size: 0.68rem;
    font-weight: 600;
    padding: 0.2rem 0.45rem;
    border-radius: 4px;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.15s ease;
    z-index: 10;
}

.unified-dots[data-tip]:hover::after {
    opacity: 1;
}

@media (hover: none) {
    .unified-dots[data-tip]::after {
        display: none;
    }
}

.unified-dot {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
}

.unified-dot-twitch {
    background: #7c5cff;
}

.unified-dot-youtube {
    background: var(--danger);
}

.unified-dot-yt-chat {
    background: #fc8181;
}

.unified-dot-tags {
    background: #38a169;
}

/* === Remove button (favorites page) === */
.unified-card-remove {
    position: absolute;
    top: 0.4rem;
    right: 0.4rem;
    z-index: 4;
    width: 1.6rem;
    height: 1.6rem;
    border-radius: 50%;
    background: rgba(12, 8, 23, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.15);
    color: var(--media-on-overlay);
    font-size: 1rem;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--transition);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.unified-card-remove:hover {
    background: var(--danger-bg-strong);
}

/* === Narrow context (up-next sidebar) === */
.up-next-unified {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

/* === Responsive === */
@media (max-width: 640px) {
    .unified-card-group-grid {
        grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    }
}
