html {
    scroll-behavior: smooth;
}

body {
    font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

body.yhome-notify-open {
    overflow: hidden;
}

/* 공통 알림 모달 — 채널 페이지는 body의 --yhome-* 테마 변수를 그대로 사용 */
#yhomeNotifyModal .yhome-notify-backdrop {
    background: color-mix(in srgb, var(--yhome-bg, #020617) 58%, rgba(0, 0, 0, 0.82));
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
}

#yhomeNotifyModal .yhome-notify-panel {
    border: 1px solid var(--yhome-border, rgba(255, 255, 255, 0.1));
    background: var(--yhome-surface-strong, rgba(15, 23, 42, 0.94));
    color: var(--yhome-muted, #cbd5e1);
    box-shadow:
        0 24px 48px rgba(0, 0, 0, 0.42),
        0 0 0 1px color-mix(in srgb, var(--yhome-primary, #ef4444) 14%, transparent);
}

#yhomeNotifyModal .yhome-notify-icon-wrap {
    background: var(--yhome-surface-soft, rgba(255, 255, 255, 0.06));
    color: var(--yhome-primary-muted, #fecaca);
}

#yhomeNotifyModal .yhome-notify-icon-wrap[data-yhome-notify-variant="info"] {
    color: var(--yhome-accent-two, #7dd3fc);
}

#yhomeNotifyModal .yhome-notify-icon-wrap[data-yhome-notify-variant="success"] {
    color: color-mix(in srgb, var(--yhome-accent, #34d399) 55%, #4ade80);
}

#yhomeNotifyModal .yhome-notify-icon-wrap[data-yhome-notify-variant="question"] {
    color: color-mix(in srgb, var(--yhome-primary-muted, #fde68a) 72%, var(--yhome-accent-two, #fcd34d));
}

#yhomeNotifyModal .yhome-notify-icon-wrap svg {
    color: inherit;
    stroke: currentColor;
}

#yhomeNotifyModal .yhome-notify-title {
    color: var(--yhome-heading, #ffffff);
}

#yhomeNotifyModal .yhome-notify-message {
    color: var(--yhome-muted, #cbd5e1);
}

#yhomeNotifyModal .yhome-notify-cancel {
    border: 1px solid var(--yhome-border, rgba(255, 255, 255, 0.12));
    background: var(--yhome-surface-soft, rgba(255, 255, 255, 0.05));
    color: var(--yhome-text, #f1f5f9);
    --tw-ring-color: color-mix(in srgb, var(--yhome-primary, #ef4444) 28%, transparent);
    --tw-ring-offset-color: var(--yhome-surface-strong, #0f172a);
}

#yhomeNotifyModal .yhome-notify-cancel:hover {
    background: color-mix(in srgb, var(--yhome-surface-soft, rgba(255, 255, 255, 0.08)) 88%, var(--yhome-primary, #ef4444));
}

#yhomeNotifyModal .yhome-notify-ok {
    border: 1px solid color-mix(in srgb, var(--yhome-primary, #ef4444) 55%, transparent);
    background: var(--yhome-primary, #ef4444);
    color: var(--yhome-on-primary, #ffffff);
    box-shadow: 0 10px 28px color-mix(in srgb, var(--yhome-primary, #ef4444) 22%, transparent);
    --tw-ring-color: color-mix(in srgb, var(--yhome-primary, #ef4444) 35%, transparent);
    --tw-ring-offset-color: var(--yhome-surface-strong, #0f172a);
}

#yhomeNotifyModal .yhome-notify-ok:hover {
    background: var(--yhome-primary-hover, #f87171);
    color: var(--yhome-on-primary-hover, #ffffff);
}

#yhomeNotifyModal .yhome-notify-ok:focus-visible,
#yhomeNotifyModal .yhome-notify-cancel:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--yhome-primary, #ef4444) 42%, transparent);
    outline-offset: 3px;
}

/* Sticky footer: short pages still keep footer at the viewport bottom */
body.yhome-sticky-footer {
    min-height: 100vh;
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
}

body.yhome-sticky-footer.yhome-channel-page > #app {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
    width: 100%;
}

/* 채널 페이지: #app 세로 플렉스 안에서 main·직계 본문이 자손 최소 너비로 줄어들지 않도록 */
body.yhome-sticky-footer.yhome-channel-page #app > main {
    flex: 1 1 auto;
    min-height: 0;
    width: 100%;
    min-width: 0;
    align-self: stretch;
}

body.yhome-channel-page #app > main > section,
body.yhome-channel-page #app > main > div#channelPage {
    width: 100%;
    min-width: 0;
}

body.yhome-sticky-footer > main {
    flex: 1 1 auto;
    min-height: 0;
}

.yhome-site-footer {
    flex-shrink: 0;
    margin-top: auto;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(2, 6, 23, 0.94);
    padding: 0;
    font-size: 0.75rem;
    line-height: 1.5;
    color: rgb(100, 116, 139);
    box-shadow: 0 -18px 48px rgba(0, 0, 0, 0.35);
}

body.yhome-channel-page .yhome-site-footer {
    border-top-color: var(--yhome-border);
    color: var(--yhome-dim);
    background: var(--yhome-header-bg);
    box-shadow: 0 -12px 36px rgba(0, 0, 0, 0.28);
}

.yhome-site-footer-inner {
    margin-left: auto;
    margin-right: auto;
}

.yhome-footer-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.45rem 0.95rem;
    border-radius: 9999px;
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    text-decoration: none;
    color: rgb(148, 163, 184);
    background: rgba(255, 255, 255, 0.045);
    border: 1px solid rgba(255, 255, 255, 0.1);
    transition:
        color 0.18s ease,
        background 0.18s ease,
        border-color 0.18s ease,
        box-shadow 0.18s ease;
}

.yhome-footer-pill:hover {
    color: rgb(254, 202, 202);
    border-color: rgba(248, 113, 113, 0.45);
    background: rgba(239, 68, 68, 0.12);
    box-shadow: 0 0 0 1px rgba(248, 113, 113, 0.12);
}

button.yhome-footer-pill {
    margin: 0;
    cursor: pointer;
    font: inherit;
    letter-spacing: inherit;
    text-transform: inherit;
    appearance: none;
    -webkit-appearance: none;
}

body.yhome-channel-page .yhome-footer-pill {
    color: var(--yhome-dim);
    border-color: var(--yhome-border);
    background: var(--yhome-surface-soft);
}

body.yhome-channel-page .yhome-footer-pill:hover {
    color: var(--yhome-primary-muted);
    border-color: color-mix(in srgb, var(--yhome-primary) 42%, transparent);
    background: var(--yhome-primary-soft);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--yhome-primary) 18%, transparent);
}

.yhome-site-footer-meta {
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    color: rgb(100, 116, 139);
}

body.yhome-channel-page .yhome-site-footer-meta {
    border-top-color: var(--yhome-border);
    color: var(--yhome-dim);
}

.yhome-site-footer-copy {
    margin: 0;
    color: rgb(100, 116, 139);
}

body.yhome-channel-page .yhome-site-footer-copy {
    color: var(--yhome-dim);
}

body.yhome-contact-modal-open {
    overflow: hidden;
}

/* Footer contact modal (`inc_footer.php`, `assets/footer_contact.js`) */
.yhome-contact-modal {
    position: fixed;
    inset: 0;
    z-index: 105;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding: max(1rem, env(safe-area-inset-top, 0px)) max(1rem, env(safe-area-inset-right, 0px)) max(1rem, env(safe-area-inset-bottom, 0px)) max(1rem, env(safe-area-inset-left, 0px));
}

@media (min-width: 640px) {
    .yhome-contact-modal {
        align-items: center;
    }
}

.yhome-contact-modal.hidden {
    display: none;
}

.yhome-contact-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(2, 3, 10, 0.72);
    backdrop-filter: blur(6px);
}

.yhome-contact-modal-panel {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 22rem;
    max-height: min(85vh, 28rem);
    max-height: min(85dvh, 28rem);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border-radius: 1.1rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: linear-gradient(165deg, rgba(15, 23, 42, 0.96), rgba(2, 6, 23, 0.98));
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.65);
}

.yhome-contact-modal-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.85rem 1rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    flex-shrink: 0;
}

.yhome-contact-modal-title {
    margin: 0;
    font-size: 1rem;
    font-weight: 800;
    color: #f8fafc;
    letter-spacing: -0.02em;
}

.yhome-contact-modal-x {
    flex-shrink: 0;
    display: grid;
    place-items: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 0.75rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.04);
    color: #e2e8f0;
    cursor: pointer;
    transition:
        background 0.15s ease,
        color 0.15s ease;
}

.yhome-contact-modal-x:hover {
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
}

.yhome-contact-modal-body {
    padding: 0.85rem 1rem 1rem;
    overflow-y: auto;
    flex: 1;
    min-height: 0;
}

.yhome-contact-modal-dl {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.yhome-contact-modal-dl > div {
    margin: 0;
}

.yhome-contact-modal-dl dt {
    margin: 0 0 0.15rem;
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgb(100, 116, 139);
}

.yhome-contact-modal-dl dd {
    margin: 0;
    font-size: 0.8125rem;
    line-height: 1.45;
    font-weight: 600;
    color: rgb(226, 232, 240);
}

.yhome-contact-modal-mail {
    color: rgb(252, 165, 165);
    text-decoration: none;
    font-weight: 700;
    text-underline-offset: 2px;
}

.yhome-contact-modal-mail:hover {
    text-decoration: underline;
}

body.yhome-channel-page .yhome-contact-modal-panel {
    border-color: var(--yhome-border);
    background: var(--yhome-surface-strong);
}

body.yhome-channel-page .yhome-contact-modal-title {
    color: var(--yhome-heading);
}

body.yhome-channel-page .yhome-contact-modal-x {
    border-color: var(--yhome-border);
    color: var(--yhome-text);
}

body.yhome-channel-page .yhome-contact-modal-x:hover {
    background: var(--yhome-primary-soft);
    color: var(--yhome-primary-muted);
}

body.yhome-channel-page .yhome-contact-modal-dl dt {
    color: var(--yhome-dim);
}

body.yhome-channel-page .yhome-contact-modal-dl dd {
    color: var(--yhome-muted);
}

body.yhome-channel-page .yhome-contact-modal-mail {
    color: var(--yhome-primary-muted);
}

body.yhome-channel-page {
    --yhome-bg: #020617;
    --yhome-surface: rgba(15, 23, 42, 0.72);
    --yhome-surface-soft: rgba(255, 255, 255, 0.045);
    --yhome-surface-strong: rgba(15, 23, 42, 0.88);
    --yhome-border: rgba(255, 255, 255, 0.11);
    --yhome-primary: #ef4444;
    --yhome-primary-hover: #f87171;
    --yhome-primary-soft: rgba(239, 68, 68, 0.18);
    --yhome-primary-muted: #fecaca;
    --yhome-accent: #f43f5e;
    --yhome-accent-two: #38bdf8;
    --yhome-heading: #ffffff;
    --yhome-text: #ffffff;
    --yhome-muted: #cbd5e1;
    --yhome-dim: #94a3b8;
    --yhome-on-primary: #ffffff;
    --yhome-on-primary-hover: var(--yhome-on-primary);
    --yhome-hero-gradient: linear-gradient(120deg, #dc2626, #c026d3, #0ea5e9);
    --yhome-body-bg:
        radial-gradient(circle at top left, rgba(239, 68, 68, 0.24), transparent 34rem),
        radial-gradient(circle at top right, rgba(56, 189, 248, 0.16), transparent 30rem),
        #020617;
    --yhome-header-bg: rgba(2, 6, 23, 0.82);
    --yhome-glow: rgba(239, 68, 68, 0.28);
    background: var(--yhome-body-bg);
    color: var(--yhome-muted);
}

body.yhome-theme-ocean {
    --yhome-primary: #2563eb;
    --yhome-primary-hover: #60a5fa;
    --yhome-primary-soft: rgba(37, 99, 235, 0.2);
    --yhome-primary-muted: #bfdbfe;
    --yhome-accent: #06b6d4;
    --yhome-accent-two: #67e8f9;
    --yhome-hero-gradient: linear-gradient(120deg, #1d4ed8, #0891b2, #67e8f9);
    --yhome-body-bg:
        radial-gradient(circle at top left, rgba(37, 99, 235, 0.28), transparent 34rem),
        radial-gradient(circle at top right, rgba(6, 182, 212, 0.2), transparent 30rem),
        #07111f;
    --yhome-glow: rgba(37, 99, 235, 0.3);
}

body.yhome-theme-forest {
    --yhome-primary: #16a34a;
    --yhome-primary-hover: #4ade80;
    --yhome-primary-soft: rgba(22, 163, 74, 0.2);
    --yhome-primary-muted: #bbf7d0;
    --yhome-accent: #65a30d;
    --yhome-accent-two: #bef264;
    --yhome-hero-gradient: linear-gradient(120deg, #166534, #65a30d, #bef264);
    --yhome-body-bg:
        radial-gradient(circle at top left, rgba(22, 163, 74, 0.24), transparent 34rem),
        radial-gradient(circle at top right, rgba(190, 242, 100, 0.12), transparent 30rem),
        #06130d;
    --yhome-glow: rgba(22, 163, 74, 0.28);
}

body.yhome-theme-lavender {
    --yhome-bg: #fbf7ff;
    --yhome-surface: rgba(255, 255, 255, 0.76);
    --yhome-surface-soft: rgba(255, 255, 255, 0.68);
    --yhome-surface-strong: rgba(255, 255, 255, 0.92);
    --yhome-border: rgba(109, 40, 217, 0.18);
    --yhome-primary: #8b5cf6;
    --yhome-primary-hover: #7c3aed;
    --yhome-primary-soft: rgba(139, 92, 246, 0.22);
    --yhome-primary-muted: #6d28d9;
    --yhome-accent: #c084fc;
    --yhome-accent-two: #f0abfc;
    --yhome-heading: #2e1065;
    --yhome-text: #3b2765;
    --yhome-muted: #5b4b7b;
    --yhome-dim: #7c6f98;
    --yhome-on-primary: #ffffff;
    --yhome-on-primary-hover: var(--yhome-on-primary);
    --yhome-hero-gradient: linear-gradient(120deg, #6d28d9, #c084fc, #f0abfc);
    --yhome-body-bg:
        radial-gradient(circle at top left, rgba(139, 92, 246, 0.2), transparent 34rem),
        radial-gradient(circle at top right, rgba(240, 171, 252, 0.3), transparent 30rem),
        #fbf7ff;
    --yhome-header-bg: rgba(255, 255, 255, 0.78);
    --yhome-glow: rgba(139, 92, 246, 0.32);
}

body.yhome-theme-sunset {
    --yhome-primary: #f97316;
    --yhome-primary-hover: #fb923c;
    --yhome-primary-soft: rgba(249, 115, 22, 0.2);
    --yhome-primary-muted: #fed7aa;
    --yhome-accent: #fb7185;
    --yhome-accent-two: #fde68a;
    --yhome-hero-gradient: linear-gradient(120deg, #ea580c, #fb7185, #fde68a);
    --yhome-body-bg:
        radial-gradient(circle at top left, rgba(249, 115, 22, 0.25), transparent 34rem),
        radial-gradient(circle at top right, rgba(251, 113, 133, 0.16), transparent 30rem),
        #180b08;
    --yhome-glow: rgba(249, 115, 22, 0.3);
}

body.yhome-theme-honey {
    --yhome-bg: #fff7ed;
    --yhome-surface: rgba(255, 255, 255, 0.78);
    --yhome-surface-soft: rgba(255, 251, 235, 0.74);
    --yhome-surface-strong: rgba(255, 255, 255, 0.94);
    --yhome-border: rgba(180, 83, 9, 0.2);
    --yhome-primary: #f59e0b;
    --yhome-primary-hover: #d97706;
    --yhome-primary-soft: rgba(245, 158, 11, 0.19);
    --yhome-primary-muted: #92400e;
    --yhome-accent: #facc15;
    --yhome-accent-two: #fef3c7;
    --yhome-heading: #3f2208;
    --yhome-text: #4b2d0f;
    --yhome-muted: #6f4f1d;
    --yhome-dim: #9a6b1f;
    --yhome-on-primary: #2f1a05;
    --yhome-on-primary-hover: var(--yhome-on-primary);
    --yhome-hero-gradient: linear-gradient(120deg, #b45309, #f59e0b, #fde68a);
    --yhome-body-bg:
        radial-gradient(circle at top left, rgba(245, 158, 11, 0.24), transparent 34rem),
        radial-gradient(circle at top right, rgba(250, 204, 21, 0.24), transparent 30rem),
        #fff7ed;
    --yhome-header-bg: rgba(255, 251, 235, 0.78);
    --yhome-glow: rgba(245, 158, 11, 0.28);
}

body.yhome-theme-rose {
    --yhome-primary: #e11d48;
    --yhome-primary-hover: #fb7185;
    --yhome-primary-soft: rgba(225, 29, 72, 0.2);
    --yhome-primary-muted: #fecdd3;
    --yhome-accent: #fb7185;
    --yhome-accent-two: #fecdd3;
    --yhome-hero-gradient: linear-gradient(120deg, #be123c, #fb7185, #fecdd3);
    --yhome-body-bg:
        radial-gradient(circle at top left, rgba(225, 29, 72, 0.25), transparent 34rem),
        radial-gradient(circle at top right, rgba(251, 113, 133, 0.14), transparent 30rem),
        #160711;
    --yhome-glow: rgba(225, 29, 72, 0.3);
}

body.yhome-theme-mint {
    --yhome-bg: #ecfdf5;
    --yhome-surface: rgba(255, 255, 255, 0.76);
    --yhome-surface-soft: rgba(240, 253, 250, 0.74);
    --yhome-surface-strong: rgba(255, 255, 255, 0.94);
    --yhome-border: rgba(15, 118, 110, 0.18);
    --yhome-primary: #14b8a6;
    --yhome-primary-hover: #0f766e;
    --yhome-primary-soft: rgba(20, 184, 166, 0.2);
    --yhome-primary-muted: #0f766e;
    --yhome-accent: #2dd4bf;
    --yhome-accent-two: #ccfbf1;
    --yhome-heading: #042f2e;
    --yhome-text: #134e4a;
    --yhome-muted: #28635e;
    --yhome-dim: #4f807a;
    --yhome-on-primary: #042f2e;
    --yhome-on-primary-hover: var(--yhome-on-primary);
    --yhome-hero-gradient: linear-gradient(120deg, #0f766e, #2dd4bf, #ccfbf1);
    --yhome-body-bg:
        radial-gradient(circle at top left, rgba(20, 184, 166, 0.22), transparent 34rem),
        radial-gradient(circle at top right, rgba(204, 251, 241, 0.5), transparent 30rem),
        #ecfdf5;
    --yhome-header-bg: rgba(240, 253, 250, 0.78);
    --yhome-glow: rgba(20, 184, 166, 0.3);
}

body.yhome-theme-royal {
    --yhome-primary: #4f46e5;
    --yhome-primary-hover: #818cf8;
    --yhome-primary-soft: rgba(79, 70, 229, 0.22);
    --yhome-primary-muted: #c7d2fe;
    --yhome-accent: #3b82f6;
    --yhome-accent-two: #bfdbfe;
    --yhome-hero-gradient: linear-gradient(120deg, #3730a3, #3b82f6, #bfdbfe);
    --yhome-body-bg:
        radial-gradient(circle at top left, rgba(79, 70, 229, 0.27), transparent 34rem),
        radial-gradient(circle at top right, rgba(59, 130, 246, 0.14), transparent 30rem),
        #090d24;
    --yhome-glow: rgba(79, 70, 229, 0.34);
}

body.yhome-theme-mono {
    --yhome-bg: #f8fafc;
    --yhome-surface: rgba(255, 255, 255, 0.78);
    --yhome-surface-soft: rgba(248, 250, 252, 0.74);
    --yhome-surface-strong: rgba(255, 255, 255, 0.94);
    --yhome-border: rgba(51, 65, 85, 0.17);
    --yhome-primary: #64748b;
    --yhome-primary-hover: #475569;
    --yhome-primary-soft: rgba(148, 163, 184, 0.16);
    --yhome-primary-muted: #334155;
    --yhome-accent: #e2e8f0;
    --yhome-accent-two: #94a3b8;
    --yhome-heading: #0f172a;
    --yhome-text: #1e293b;
    --yhome-muted: #475569;
    --yhome-dim: #64748b;
    --yhome-on-primary: #ffffff;
    --yhome-on-primary-hover: var(--yhome-on-primary);
    --yhome-hero-gradient: linear-gradient(120deg, #0f172a, #64748b, #e2e8f0);
    --yhome-body-bg:
        radial-gradient(circle at top left, rgba(148, 163, 184, 0.22), transparent 34rem),
        radial-gradient(circle at top right, rgba(226, 232, 240, 0.52), transparent 30rem),
        #f8fafc;
    --yhome-header-bg: rgba(248, 250, 252, 0.8);
    --yhome-glow: rgba(148, 163, 184, 0.22);
}

body.yhome-channel-page header {
    border-color: var(--yhome-border);
    background: var(--yhome-header-bg);
}

body.yhome-channel-page header nav {
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    padding: 0;
    box-shadow: none;
}

body.yhome-channel-page.yhome-channel-home header nav .nav-link:hover,
body.yhome-channel-page.yhome-channel-home header nav .nav-link.is-active {
    background: transparent !important;
}

@media (max-width: 639.98px) {
    body.yhome-channel-page header nav.yhome-channel-header-nav {
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        -ms-overflow-style: none;
    }

    body.yhome-channel-page header nav.yhome-channel-header-nav::-webkit-scrollbar {
        display: none;
        width: 0;
        height: 0;
    }
}

body.yhome-channel-page header > div > a > .yhome-header-logo-img {
    border: 1px solid color-mix(in srgb, var(--yhome-primary) 42%, transparent);
    background: color-mix(in srgb, var(--yhome-primary) 10%, rgba(15, 23, 42, 0.55));
    box-shadow: 0 16px 36px var(--yhome-glow);
    transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease, filter 0.15s ease;
}

body.yhome-channel-page header > div > a:hover > .yhome-header-logo-img {
    border-color: color-mix(in srgb, var(--yhome-primary-hover) 52%, transparent);
    box-shadow: 0 18px 40px var(--yhome-glow);
    filter: brightness(1.05);
}

body.yhome-channel-page #yhomeAccountBtn,
body.yhome-channel-page #youtubeLink,
body.yhome-channel-page #refreshComments,
body.yhome-channel-page #filterForm button[type="submit"],
body.yhome-channel-page .pager-btn.is-active,
body.yhome-channel-page .pager-btn:hover:not(:disabled) {
    border-color: var(--yhome-primary);
    background: var(--yhome-primary);
    box-shadow: 0 16px 36px var(--yhome-glow);
    color: var(--yhome-on-primary);
}

body.yhome-channel-page #yhomeAccountBtn:hover,
body.yhome-channel-page #youtubeLink:hover,
body.yhome-channel-page #refreshComments:hover,
body.yhome-channel-page #filterForm button[type="submit"]:hover {
    background: var(--yhome-primary-hover);
}

body.yhome-channel-page .nav-link:hover,
body.yhome-channel-page .nav-link.is-active {
    background: var(--yhome-primary-soft);
}

body.yhome-channel-page #home,
body.yhome-channel-page .introduce-card,
body.yhome-channel-page #contentsPage > .mb-6,
body.yhome-channel-page #playlistsPage > .mb-6,
body.yhome-channel-page #communityPage > .mb-6,
body.yhome-channel-page #analysisPage > .mb-6 {
    border-color: var(--yhome-border);
    background: var(--yhome-surface-soft);
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.28);
}

body.yhome-channel-page #home {
    margin-top: -1.5rem;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

body.yhome-channel-page .home-hero-meta {
    padding-top: 1rem;
}

@media (max-width: 640px) {
    body.yhome-channel-page .home-hero-meta {
        padding-top: 0.65rem;
    }
}

body.yhome-channel-page #heroBanner,
body.yhome-channel-page #previewBanner,
body.yhome-channel-page main > section > .h-36 {
    background: var(--yhome-hero-gradient);
}

body.yhome-channel-page #heroBanner.has-channel-banner,
body.yhome-channel-page #previewBanner.has-channel-banner {
    background-image:
        linear-gradient(
            180deg,
            rgba(2, 6, 23, 0),
            rgba(2, 6, 23, 0.18) 62%,
            color-mix(in srgb, var(--yhome-bg) 78%, transparent)
        ),
        var(--yhome-hero-image);
    background-position: center;
    background-size: cover;
    box-shadow: inset 0 -1px 0 color-mix(in srgb, var(--yhome-primary) 32%, transparent);
}

body.yhome-channel-page #channelThumb {
    border-color: var(--yhome-bg);
}

body.yhome-channel-page #channelHandle,
body.yhome-channel-page #performanceMeta,
body.yhome-channel-page #introduceToggle,
body.yhome-channel-page #introduce a,
body.yhome-channel-page #introduce h2 i,
body.yhome-channel-page .analysis-panel h3 i,
body.yhome-channel-page .community-filter-info i {
    color: var(--yhome-primary-muted);
}

body.yhome-channel-page .metric-card,
body.yhome-channel-page .video-card,
body.yhome-channel-page .playlist-card,
body.yhome-channel-page .content-card,
body.yhome-channel-page .contents-table-wrap,
body.yhome-channel-page .community-stat-card,
body.yhome-channel-page .community-comment-card,
body.yhome-channel-page .analysis-panel,
body.yhome-channel-page .analysis-metric-group,
body.yhome-channel-page .analysis-metric-mini,
body.yhome-channel-page .analysis-hero-date,
body.yhome-channel-page .analysis-summary-card,
body.yhome-channel-page .analysis-grid article,
body.yhome-channel-page .content-modal-panel,
body.yhome-channel-page .performance-modal-panel,
body.yhome-channel-page .community-analysis-modal-panel {
    border-color: var(--yhome-border);
    background: var(--yhome-surface);
}

body.yhome-channel-page .video-card:hover,
body.yhome-channel-page .playlist-card:hover,
body.yhome-channel-page .content-card:hover,
body.yhome-channel-page .community-video-card:hover {
    border-color: var(--yhome-primary);
    box-shadow: 0 18px 50px rgba(0, 0, 0, 0.24);
}

body.yhome-channel-page .metric-card span,
body.yhome-channel-page .analysis-metric-mini span,
body.yhome-channel-page .analysis-hero-date span,
body.yhome-channel-page .video-card p,
body.yhome-channel-page .playlist-card p,
body.yhome-channel-page #channelUpdated,
body.yhome-channel-page #channelDescription,
body.yhome-channel-page #contentsSummary,
body.yhome-channel-page #playlistsSummary,
body.yhome-channel-page #communitySummary,
body.yhome-channel-page #analysisNote {
    color: var(--yhome-dim);
}

body.modal-open {
    overflow: hidden;
}

.channel-card {
    position: relative;
    display: block;
    min-height: 100%;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 1.5rem;
    background: rgba(255, 255, 255, 0.04);
    padding: 1rem;
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.channel-card:hover {
    transform: translateY(-3px);
    border-color: rgba(248, 113, 113, 0.5);
    background: rgba(255, 255, 255, 0.07);
}

.channel-card-link {
    display: block;
    color: inherit;
}

.channel-delete-btn {
    position: absolute;
    top: 0.85rem;
    right: 0.85rem;
    display: inline-flex;
    width: 2.25rem;
    height: 2.25rem;
    align-items: center;
    justify-content: center;
    border-radius: 9999px;
    border: 1px solid rgba(248, 113, 113, 0.26);
    background: rgba(15, 23, 42, 0.84);
    color: rgb(254, 202, 202);
    opacity: 0;
    pointer-events: none;
    transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease, opacity 0.15s ease;
}

.channel-card:hover .channel-delete-btn,
.channel-delete-btn:focus-visible,
.channel-delete-btn.is-loading {
    opacity: 1;
    pointer-events: auto;
}

.channel-delete-btn:hover {
    border-color: rgba(248, 113, 113, 0.7);
    background: rgba(220, 38, 38, 0.24);
    color: white;
}

.channel-delete-btn:disabled,
.channel-delete-btn.is-loading {
    cursor: not-allowed;
    opacity: 0.55;
}

.metric-card {
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 1.25rem;
    background: rgba(15, 23, 42, 0.76);
    padding: 1rem;
}

.metric-card span {
    display: block;
    color: rgb(148, 163, 184);
    font-size: 0.875rem;
    font-weight: 700;
}

.metric-card strong {
    display: block;
    margin-top: 0.35rem;
    color: white;
    font-size: 1.7rem;
    font-weight: 900;
}

.analysis-hero-date {
    display: inline-grid;
    min-width: 11rem;
    gap: 0.2rem;
    border: 1px solid var(--yhome-border);
    border-radius: 1.15rem;
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--yhome-primary) 16%, transparent), transparent 58%),
        var(--yhome-surface);
    padding: 0.85rem 1rem;
    box-shadow: inset 0 1px 0 color-mix(in srgb, white 10%, transparent);
}

.analysis-hero-date.hidden {
    display: none;
}

.analysis-hero-date span {
    color: var(--yhome-dim);
    font-size: 0.75rem;
    font-weight: 900;
}

.analysis-hero-date strong {
    color: var(--yhome-heading);
    font-size: 1.05rem;
    font-weight: 950;
}

#analysisGrid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 16rem), 1fr));
}

#analysisPage,
#analysisGrid,
#analysisDetails,
.analysis-panel,
.analysis-metric-group,
.analysis-kind-ratio,
.analysis-vbar-chart {
    width: 100%;
    min-width: 0;
    max-width: 100%;
}

.analysis-metric-group {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--yhome-border);
    border-radius: 1.35rem;
    background:
        radial-gradient(circle at top right, color-mix(in srgb, var(--yhome-accent-two) 14%, transparent), transparent 12rem),
        linear-gradient(145deg, color-mix(in srgb, var(--yhome-primary) 10%, transparent), transparent 54%),
        var(--yhome-surface);
    padding: 1rem;
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.18);
}

.analysis-metric-group.is-featured {
    background:
        radial-gradient(circle at top right, color-mix(in srgb, var(--yhome-accent-two) 24%, transparent), transparent 13rem),
        linear-gradient(135deg, color-mix(in srgb, var(--yhome-primary) 26%, transparent), color-mix(in srgb, var(--yhome-accent) 12%, transparent)),
        var(--yhome-surface);
}

.analysis-metric-group-head {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin-bottom: 0.9rem;
}

.analysis-metric-group-head span {
    display: grid;
    width: 2rem;
    height: 2rem;
    place-items: center;
    border-radius: 0.8rem;
    background: var(--yhome-primary-soft);
    color: var(--yhome-primary-muted);
}

.analysis-metric-group-head h2 {
    color: var(--yhome-heading);
    font-size: 1rem;
    font-weight: 950;
}

.analysis-metric-grid {
    display: grid;
    gap: 0.65rem;
}

.analysis-metric-mini {
    min-width: 0;
    border-radius: 0.95rem;
    background: color-mix(in srgb, var(--yhome-surface-soft) 82%, transparent);
    padding: 0.75rem;
}

.analysis-metric-mini span {
    display: block;
    color: var(--yhome-dim);
    font-size: 0.76rem;
    font-weight: 900;
}

.analysis-metric-mini strong {
    display: block;
    overflow: hidden;
    margin-top: 0.2rem;
    color: color-mix(in srgb, var(--yhome-accent-two) 34%, white);
    font-size: clamp(1.05rem, 2vw, 1.45rem);
    font-weight: 950;
    line-height: 1.15;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.analysis-metric-mini em {
    display: block;
    margin-top: 0.3rem;
    color: color-mix(in srgb, var(--yhome-primary-muted) 58%, var(--yhome-muted));
    font-size: 0.72rem;
    font-style: normal;
    font-weight: 900;
}

/* Channel home: compact stats bar */
body.yhome-channel-page .home-metrics {
    width: 100%;
    min-width: 0;
}

body.yhome-channel-page .home-metrics-bar {
    display: flex;
    align-items: stretch;
    min-width: 0;
    overflow: hidden;
    border: 1px solid var(--yhome-border, rgba(255, 255, 255, 0.1));
    border-radius: 1rem;
    background: color-mix(in srgb, var(--yhome-surface-soft, rgba(15, 23, 42, 0.55)) 88%, transparent);
    box-shadow: inset 0 1px 0 color-mix(in srgb, white 8%, transparent);
}

body.yhome-channel-page .home-metrics-bar--preview {
    display: block;
}

body.yhome-channel-page .home-metrics-strip {
    display: flex;
    flex: 1 1 auto;
    align-items: stretch;
    min-width: 0;
}

body.yhome-channel-page .home-metric-chip,
body.yhome-channel-page button.home-metric-chip {
    display: flex;
    flex: 1 1 0;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    min-width: 0;
    padding: 0.65rem 0.5rem;
    text-align: center;
}

body.yhome-channel-page .home-metric-chip + .home-metric-chip,
body.yhome-channel-page button.home-metric-chip + .home-metric-chip,
body.yhome-channel-page button.home-metric-chip + button.home-metric-chip {
    border-left: 1px solid color-mix(in srgb, var(--yhome-border, rgba(255, 255, 255, 0.1)) 70%, transparent);
}

body.yhome-channel-page .home-metric-icon {
    width: 0.95rem;
    height: 0.95rem;
    flex-shrink: 0;
    color: color-mix(in srgb, var(--yhome-primary-muted, #fca5a5) 72%, var(--yhome-dim, #94a3b8));
    opacity: 0.92;
}

body.yhome-channel-page .home-metric-chip-body {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.1rem;
    min-width: 0;
}

body.yhome-channel-page .home-metrics-bar strong {
    display: block;
    overflow: hidden;
    max-width: 100%;
    color: var(--yhome-heading, white);
    font-size: clamp(0.92rem, 2.4vw, 1.05rem);
    font-weight: 900;
    line-height: 1.15;
    text-overflow: ellipsis;
    white-space: nowrap;
}

body.yhome-channel-page .home-metric-label {
    display: block;
    color: var(--yhome-dim, #94a3b8);
    font-size: 0.62rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    line-height: 1.1;
    text-transform: uppercase;
}

body.yhome-channel-page button.home-metric-chip.home-metric-exact-btn {
    width: auto;
    margin: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    font: inherit;
    color: inherit;
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
    transition: background 0.15s ease;
}

body.yhome-channel-page button.home-metric-chip.home-metric-exact-btn:hover {
    background: color-mix(in srgb, var(--yhome-primary-soft, rgba(248, 113, 113, 0.12)) 55%, transparent);
}

body.yhome-channel-page button.home-metric-chip.home-metric-exact-btn:focus-visible {
    outline: 2px solid var(--yhome-primary, #f87171);
    outline-offset: -2px;
    z-index: 1;
}

body.yhome-channel-page .home-metric-about {
    display: flex;
    flex: 1 1 auto;
    align-items: center;
    gap: 0.55rem;
    min-width: 0;
    max-width: 52%;
    padding: 0.6rem 0.75rem;
    border: 0;
    border-right: 1px solid color-mix(in srgb, var(--yhome-border, rgba(255, 255, 255, 0.1)) 70%, transparent);
    border-radius: 0;
    background: transparent;
    font: inherit;
    color: inherit;
    text-align: left;
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
    transition: background 0.15s ease;
}

body.yhome-channel-page .home-metric-about:hover {
    background: color-mix(in srgb, var(--yhome-primary-soft, rgba(248, 113, 113, 0.12)) 45%, transparent);
}

body.yhome-channel-page .home-metric-about:focus-visible {
    outline: 2px solid var(--yhome-primary, #f87171);
    outline-offset: -2px;
    z-index: 1;
}

body.yhome-channel-page .home-metric-about-body {
    display: flex;
    flex-direction: column;
    gap: 0.12rem;
    min-width: 0;
    flex: 1 1 auto;
}

body.yhome-channel-page .home-metric-about-preview {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
    color: var(--yhome-muted, #cbd5e1);
    font-size: 0.72rem;
    font-weight: 600;
    line-height: 1.3;
    word-break: break-word;
}

body.yhome-channel-page .home-metric-about-chevron {
    width: 0.9rem;
    height: 0.9rem;
    flex-shrink: 0;
    color: var(--yhome-dim, #94a3b8);
    opacity: 0.75;
}

.introduce-metric-card {
    cursor: pointer;
}

button.metric-card.home-metric-exact-btn {
    display: block;
    width: 100%;
    font: inherit;
    color: inherit;
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
    transition: transform 0.15s ease, border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}

button.metric-card.home-metric-exact-btn:focus-visible {
    outline: 2px solid var(--yhome-primary, #f87171);
    outline-offset: 2px;
}

body.yhome-channel-page button.metric-card.home-metric-exact-btn:hover {
    transform: translateY(-2px);
    border-color: var(--yhome-primary);
    box-shadow: 0 18px 50px rgba(0, 0, 0, 0.24);
}

.introduce-preview {
    display: -webkit-box;
    overflow: hidden;
    margin-top: 0.45rem;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    color: var(--yhome-muted);
    font-size: 0.82rem;
    font-weight: 700;
    line-height: 1.35;
    word-break: keep-all;
}

.introduce-modal {
    position: fixed;
    inset: 0;
    z-index: 92;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.introduce-modal.hidden {
    display: none;
}

.introduce-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(2, 6, 23, 0.82);
    backdrop-filter: blur(10px);
}

.introduce-modal-panel {
    position: relative;
    z-index: 1;
    width: min(42rem, calc(100vw - 2rem));
    max-height: calc(100vh - 2rem);
    overflow-y: auto;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 1.1rem;
    background: rgb(15, 23, 42);
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.55);
}

.introduce-modal-close {
    display: inline-grid;
    width: 2.15rem;
    height: 2.15rem;
    flex: 0 0 auto;
    place-items: center;
    border-radius: 0.65rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: rgb(226, 232, 240);
    transition: background 0.15s ease, color 0.15s ease;
}

.introduce-modal-close:hover {
    background: rgba(255, 255, 255, 0.1);
    color: white;
}

body.yhome-channel-page .introduce-modal-panel {
    border-color: var(--yhome-border);
    background: var(--yhome-surface-strong);
}

body.yhome-channel-page .introduce-modal-close {
    border-color: var(--yhome-border);
    color: var(--yhome-text);
}

body.yhome-channel-page .introduce-modal-close:hover {
    background: var(--yhome-primary-soft);
    color: var(--yhome-primary-muted);
}

@media (max-width: 640px) {
    body.yhome-channel-page #home {
        margin-top: -1.5rem;
        border: 0;
        border-radius: 0;
        box-shadow: none;
        overflow: visible;
    }

    body.yhome-channel-page #previewState {
        overflow: visible;
    }

    body.yhome-channel-page #heroBanner,
    body.yhome-channel-page #previewBanner {
        margin-left: -1.25rem;
        margin-right: -1.25rem;
        width: calc(100% + 2.5rem);
        max-width: none;
        box-sizing: border-box;
    }

    body.yhome-channel-page #contentsPage > .mb-6,
    body.yhome-channel-page #playlistsPage > .mb-6,
    body.yhome-channel-page #communityPage > .mb-6,
    body.yhome-channel-page #analysisPage > .mb-6 {
        margin-top: -1.5rem;
        margin-right: -1.25rem;
        margin-left: -1.25rem;
        border: 0;
        border-radius: 0;
        box-shadow: none;
    }

    body.yhome-channel-page .home-metrics-bar:not(.home-metrics-bar--preview) {
        flex-direction: column;
    }

    body.yhome-channel-page .home-metric-about {
        max-width: none;
        border-right: 0;
        border-bottom: 1px solid color-mix(in srgb, var(--yhome-border) 70%, transparent);
        padding: 0.55rem 0.65rem;
    }

    body.yhome-channel-page .home-metrics-strip {
        width: 100%;
    }

    body.yhome-channel-page .home-metric-chip,
    body.yhome-channel-page button.home-metric-chip {
        padding: 0.55rem 0.35rem;
    }

    body.yhome-channel-page .home-metrics-bar strong {
        font-size: clamp(0.84rem, 3.6vw, 0.98rem);
    }

    .introduce-modal:not(.hidden) {
        align-items: flex-end;
        justify-content: stretch;
        padding: 0;
    }

    .introduce-modal:not(.hidden) .introduce-modal-backdrop {
        opacity: 0;
        transition: opacity 0.26s ease;
    }

    .introduce-modal:not(.hidden).introduce-modal--visible .introduce-modal-backdrop {
        opacity: 1;
    }

    .introduce-modal-panel {
        display: flex;
        width: 100%;
        max-width: none;
        max-height: 72vh;
        max-height: 72dvh;
        flex-direction: column;
        overflow: hidden;
        border-radius: 1.25rem 1.25rem 0 0;
        margin: 0;
        transform: translateY(100%);
        transition: transform 0.34s cubic-bezier(0.32, 0.72, 0, 1);
        padding-bottom: env(safe-area-inset-bottom, 0);
    }

    .introduce-modal:not(.hidden).introduce-modal--visible .introduce-modal-panel {
        transform: translateY(0);
    }

    .introduce-modal-panel > div:last-of-type {
        flex: 1 1 auto;
        min-height: 0;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }
}

@media (max-width: 640px) and (prefers-reduced-motion: reduce) {
    .introduce-modal:not(.hidden) .introduce-modal-backdrop {
        opacity: 1;
        transition: none;
    }

    .introduce-modal-panel {
        transform: none !important;
        transition: none !important;
    }
}

.nav-link {
    transition: background 0.18s ease, color 0.18s ease;
}

.nav-link:hover,
.nav-link.is-active {
    background: rgba(255, 255, 255, 0.1);
    color: white;
}

.video-card {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 1.25rem;
    background: rgba(15, 23, 42, 0.7);
}

#introduce,
#introduce > article,
#videoGrid,
.video-card > div,
.video-card h3,
.video-card p {
    min-width: 0;
}

.video-card h3,
.video-card p {
    overflow-wrap: anywhere;
    word-break: keep-all;
}

.video-card img {
    aspect-ratio: 16 / 9;
    width: 100%;
    object-fit: cover;
}

.playlist-card {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 1.35rem;
    background: rgba(15, 23, 42, 0.72);
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.playlist-card:hover {
    transform: translateY(-3px);
    border-color: rgba(248, 113, 113, 0.45);
    background: rgba(255, 255, 255, 0.07);
}

.playlist-card img {
    aspect-ratio: 16 / 9;
    width: 100%;
    object-fit: cover;
    background: rgba(255, 255, 255, 0.08);
}

.content-card {
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 1.35rem;
    background: rgba(15, 23, 42, 0.72);
    transition: transform 0.18s ease, border-color 0.18s ease;
}

.content-card:hover {
    transform: translateY(-3px);
    border-color: rgba(248, 113, 113, 0.45);
}

.content-card img {
    aspect-ratio: 16 / 9;
    width: 100%;
    object-fit: cover;
}

.content-duration {
    position: absolute;
    right: 0.65rem;
    bottom: 0.65rem;
    border-radius: 0.55rem;
    background: rgba(2, 6, 23, 0.86);
    padding: 0.25rem 0.45rem;
    color: white;
    font-size: 0.75rem;
    font-weight: 900;
}

.content-kind {
    display: inline-flex;
    align-items: center;
    border-radius: 9999px;
    padding: 0.25rem 0.6rem;
    font-size: 0.75rem;
    font-weight: 900;
}

.content-kind-long {
    background: rgba(59, 130, 246, 0.16);
    color: rgb(191, 219, 254);
}

.content-kind-shorts {
    background: rgba(244, 63, 94, 0.18);
    color: rgb(254, 205, 211);
}

.content-quality {
    display: inline-flex;
    align-items: center;
    border-radius: 9999px;
    background: rgba(255, 255, 255, 0.08);
    padding: 0.25rem 0.55rem;
    color: rgb(226, 232, 240);
    font-size: 0.75rem;
    font-weight: 900;
    text-transform: uppercase;
}

.filter-control {
    min-height: 2.25rem;
    width: 100%;
    border-radius: 0.75rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: white;
    padding: 0 0.75rem;
    color: rgb(15, 23, 42);
    font-size: 0.82rem;
    outline: none;
}

.filter-control:focus {
    box-shadow: 0 0 0 4px rgba(239, 68, 68, 0.26);
}

.account-settings-modal {
    position: fixed;
    inset: 0;
    z-index: 90;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.account-settings-modal.hidden {
    display: none;
}

.yhome-post-login-owned-list {
    display: grid;
    gap: 0.35rem;
    max-height: min(50vh, 22rem);
    overflow-y: auto;
    padding-bottom: 0.25rem;
}

.account-settings-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(2, 6, 23, 0.82);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
}

.account-settings-panel {
    position: relative;
    z-index: 1;
    width: min(34rem, calc(100vw - 2rem));
    max-height: calc(100vh - 2rem);
    overflow-y: auto;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 0.9rem;
    background: rgb(15, 23, 42);
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.55);
}

.account-settings-panel.yhome-post-login-owned-panel {
    width: min(26rem, calc(100vw - 2rem));
}

.account-theme-modal {
    z-index: 95;
}

.account-theme-panel {
    width: min(38rem, calc(100vw - 2rem));
}

.account-settings-close {
    display: inline-grid;
    width: 2.15rem;
    height: 2.15rem;
    flex: 0 0 auto;
    place-items: center;
    border-radius: 0.65rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: rgb(226, 232, 240);
    transition: background 0.15s ease, color 0.15s ease;
}

.account-settings-close:hover {
    background: rgba(255, 255, 255, 0.1);
    color: white;
}

.account-settings-card {
    display: grid;
    gap: 0.6rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    padding: 0.85rem 0;
}

.account-settings-card:last-child {
    border-bottom: 0;
}

.account-settings-card-head {
    display: flex;
    align-items: center;
    gap: 0.65rem;
}

.account-settings-channel-design-rows {
    display: grid;
    gap: 0.62rem;
    padding-top: 0.15rem;
}

.account-settings-design-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.45rem 0.75rem;
}

.account-settings-design-row + .account-settings-design-row {
    padding-top: 0.62rem;
    border-top: 1px solid rgba(255, 255, 255, 0.09);
}

.account-settings-design-row-meta {
    display: flex;
    min-width: 0;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem;
}

.account-settings-design-row-label {
    font-size: 0.82rem;
    font-weight: 850;
    letter-spacing: -0.02em;
    color: rgb(203, 213, 225);
}

.account-settings-card-icon {
    display: grid;
    width: 2rem;
    height: 2rem;
    flex: 0 0 auto;
    place-items: center;
    border-radius: 0.65rem;
    background: rgba(248, 113, 113, 0.16);
    color: rgb(254, 202, 202);
}

/* 채널 페이지 계정 설정: 밝은 테마 패널에서도 아이콘·배경 대비 유지 */
body.yhome-channel-page .account-settings-card-icon {
    background: var(--yhome-primary-soft);
    color: var(--yhome-heading);
}

body.yhome-channel-page .account-settings-card-icon svg {
    stroke: currentColor;
}

.account-settings-card h3 {
    margin: 0;
    color: white;
    font-size: 0.92rem;
    font-weight: 950;
    line-height: 1.25;
}

.account-settings-card p {
    margin-top: 0.12rem;
    color: rgb(148, 163, 184);
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1.4;
}

.account-settings-channel-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.6rem;
}

.account-settings-channel-card {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    min-width: 0;
    border-radius: 0.75rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.05);
    padding: 0.5rem 0.55rem;
    text-decoration: none;
    color: inherit;
    transition:
        background 0.15s ease,
        border-color 0.15s ease;
}

.account-settings-channel-card:hover {
    background: rgba(248, 113, 113, 0.12);
    border-color: rgba(248, 113, 113, 0.35);
}

.account-settings-channel-card:focus-visible {
    outline: 2px solid rgba(248, 113, 113, 0.65);
    outline-offset: 2px;
}

.account-settings-channel-card--static {
    cursor: default;
    opacity: 0.78;
}

.account-settings-channel-card--static:hover {
    background: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.1);
}

.account-settings-channel-card-thumb {
    display: grid;
    flex: 0 0 auto;
    place-items: center;
    width: 3.5rem;
    height: 3.5rem;
    overflow: hidden;
    border-radius: 0.55rem;
    background: rgba(2, 6, 23, 0.55);
}

.account-settings-channel-card-thumb--empty {
    color: rgb(148, 163, 184);
}

.account-settings-channel-card-img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.account-settings-channel-card-body {
    display: flex;
    min-width: 0;
    flex: 1 1 auto;
    flex-direction: column;
    gap: 0.12rem;
}

.account-settings-channel-card-handle {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: rgb(148, 163, 184);
    font-size: 0.68rem;
    font-weight: 800;
}

.account-settings-channel-card-title {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    color: white;
    font-size: 0.78rem;
    font-weight: 900;
    line-height: 1.25;
}

.account-settings-channel-card-subs {
    color: rgb(100, 116, 139);
    font-size: 0.68rem;
    font-weight: 700;
}

.account-settings-url-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: 0.5rem;
}

.account-settings-url-row input {
    min-width: 0;
    border-radius: 0.65rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(2, 6, 23, 0.76);
    padding: 0.55rem 0.65rem;
    color: rgb(226, 232, 240);
    font-size: 0.8rem;
    font-weight: 800;
    outline: none;
}

.account-settings-action-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    border-radius: 0.65rem;
    border: 0;
    background: rgba(255, 255, 255, 0.06);
    padding: 0 0.7rem;
    color: white;
    font-size: 0.78rem;
    font-weight: 900;
    transition: background 0.15s ease;
}

.account-settings-action-btn:hover {
    background: rgba(248, 113, 113, 0.16);
}

.account-settings-empty {
    border-radius: 0.65rem;
    background: rgba(255, 255, 255, 0.05);
    padding: 0.65rem 0.7rem;
    color: rgb(148, 163, 184);
    font-size: 0.8rem;
    font-weight: 800;
}

.account-settings-member-status-row {
    display: flex;
    min-width: 0;
    flex: 1 1 auto;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem 1rem;
    border-radius: 0.65rem;
    background: rgba(248, 113, 113, 0.12);
    padding: 0.55rem 0.7rem;
}

.account-settings-member-status-row h3 {
    margin: 0;
}

.account-settings-member-grade {
    flex-shrink: 0;
    color: rgb(254, 202, 202);
    font-size: 0.85rem;
    font-weight: 950;
}

.account-settings-status {
    display: inline-flex;
    border-radius: 9999px;
    background: rgba(234, 179, 8, 0.16);
    padding: 0.2rem 0.5rem;
    color: rgb(254, 240, 138);
    font-size: 0.7rem;
    font-weight: 900;
}

.account-settings-status.hidden {
    display: none;
}

.account-settings-status.is-error {
    background: rgba(239, 68, 68, 0.16);
    color: rgb(254, 202, 202);
}

.account-settings-theme-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
    gap: 0.5rem;
}

.account-settings-theme-summary {
    display: grid;
    grid-template-columns: 5.5rem minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.7rem;
    width: 100%;
    border-radius: 0.7rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.05);
    padding: 0.6rem;
    text-align: left;
    transition: background 0.15s ease, border-color 0.15s ease;
}

.account-settings-theme-summary:hover {
    border-color: rgba(248, 113, 113, 0.45);
    background: rgba(248, 113, 113, 0.12);
}

.account-settings-theme-summary strong,
.account-settings-theme-summary em {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.account-settings-theme-summary strong {
    color: white;
    font-size: 0.86rem;
    font-weight: 950;
}

.account-settings-theme-summary em {
    display: none;
    margin-top: 0.12rem;
    color: rgb(148, 163, 184);
    font-size: 0.74rem;
    font-style: normal;
    font-weight: 750;
}

.account-settings-theme-option {
    display: grid;
    gap: 0.4rem;
    min-height: 5rem;
    border-radius: 0.7rem;
    border: 1px solid rgba(255, 255, 255, 0.09);
    background: rgba(255, 255, 255, 0.045);
    padding: 0.6rem;
    text-align: left;
    transition: transform 0.15s ease, border-color 0.15s ease, background 0.15s ease;
}

.account-settings-theme-option:hover {
    transform: translateY(-1px);
    border-color: rgba(248, 113, 113, 0.55);
    background: rgba(255, 255, 255, 0.07);
}

.account-settings-theme-option.is-active,
.account-settings-theme-option[data-selected="1"] {
    position: relative;
    transform: translateY(-1px);
    border-color: rgba(248, 113, 113, 0.55);
    background: rgba(248, 113, 113, 0.12);
}

.account-settings-theme-option.is-active::after,
.account-settings-theme-option[data-selected="1"]::after {
    content: "Selected";
    position: absolute;
    right: 0.5rem;
    top: 0.5rem;
    border-radius: 9999px;
    background: rgba(15, 23, 42, 0.74);
    padding: 0.12rem 0.35rem;
    color: white;
    font-size: 0.64rem;
    font-weight: 950;
}

.account-settings-theme-grid.is-saving .account-settings-theme-option {
    cursor: progress;
}

.theme-option-swatches {
    display: flex;
    overflow: hidden;
    width: 100%;
    height: 1.75rem;
    border-radius: 0.55rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.theme-option-swatches span {
    flex: 1 1 0;
}

.theme-option-swatches--value-btn {
    height: 1.12rem;
    max-height: 100%;
    border: 0;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.account-settings-layout-value-icon.account-settings-layout-value-icon--theme {
    width: auto;
    min-width: 2.65rem;
    max-width: 3.45rem;
    padding: 0.1rem 0.2rem;
}

.account-settings-theme-option strong {
    color: white;
    font-size: 0.82rem;
    font-weight: 950;
}

.account-settings-theme-option em {
    color: rgb(148, 163, 184);
    font-size: 0.7rem;
    font-style: normal;
    font-weight: 750;
    line-height: 1.35;
}

.account-settings-option-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(8rem, 1fr));
    gap: 0.5rem;
}

.account-settings-option-grid button {
    cursor: not-allowed;
    border-radius: 0.9rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.04);
    padding: 0.7rem 0.8rem;
    color: rgb(148, 163, 184);
    font-size: 0.82rem;
    font-weight: 900;
    opacity: 0.72;
}

.account-settings-layout-value-btn {
    display: inline-flex;
    max-width: min(18rem, 62%);
    align-items: center;
    gap: 0.45rem;
    margin: 0;
    padding: 0.32rem 0.45rem 0.32rem 0.38rem;
    border-radius: 0.65rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.06);
    color: rgb(203, 213, 225);
    font: inherit;
    line-height: 1.2;
    cursor: pointer;
    text-align: left;
    transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.account-settings-layout-value-btn:hover {
    border-color: rgba(248, 113, 113, 0.45);
    background: rgba(248, 113, 113, 0.14);
    color: rgb(248, 250, 252);
}

.account-settings-layout-value-btn:focus-visible {
    outline: 2px solid rgba(248, 113, 113, 0.65);
    outline-offset: 2px;
}

.account-settings-layout-value-icon {
    display: grid;
    width: 1.85rem;
    height: 1.85rem;
    flex-shrink: 0;
    place-items: center;
    border-radius: 0.5rem;
    background: rgba(248, 113, 113, 0.16);
    color: rgb(254, 202, 202);
}

.account-settings-layout-value-text {
    min-width: 0;
    flex: 1 1 auto;
    overflow: hidden;
    font-size: 0.86rem;
    font-weight: 950;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: rgb(248, 250, 252);
}

.account-settings-layout-value-chevron {
    flex-shrink: 0;
    opacity: 0.55;
}

@media (max-width: 640px) {
    .account-settings-modal {
        align-items: stretch;
        padding: 0.35rem;
    }

    .account-settings-panel {
        width: 100%;
        max-height: calc(100vh - 0.7rem);
        border-radius: 0.75rem;
    }

    .account-settings-url-row {
        grid-template-columns: 1fr;
    }

    .account-settings-action-btn {
        min-height: 2.65rem;
    }
}

.contents-filterbar {
    display: flex;
    align-items: center;
    gap: 0.45rem;
}

body.yhome-channel-page #contentsPage > .mb-6,
body.yhome-channel-page #playlistsPage > .mb-6,
body.yhome-channel-page #communityPage > .mb-6,
body.yhome-channel-page #analysisPage > .mb-6,
body.yhome-channel-page .analysis-access-hero {
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

body.yhome-channel-page #contentsPage .contents-filterbar {
    border: 0;
    border-radius: 0;
    background: transparent;
    padding: 0.7rem;
}

body.yhome-channel-page .filter-segment-btn {
    color: var(--yhome-text);
}

body.yhome-channel-page .filter-segment-btn:hover,
body.yhome-channel-page .filter-segment-btn.is-active {
    color: var(--yhome-on-primary);
}

.filter-segment {
    display: inline-flex;
    flex: 0 0 auto;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 0.75rem;
    background: rgba(15, 23, 42, 0.72);
    padding: 0.15rem;
}

.filter-segment-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.25rem;
    border-radius: 0.6rem;
    padding: 0 0.7rem;
    color: rgb(203, 213, 225);
    font-size: 0.82rem;
    font-weight: 900;
    text-decoration: none;
    transition: background 0.15s ease, color 0.15s ease;
}

.filter-segment-btn:hover,
.filter-segment-btn.is-active {
    background: rgb(220, 38, 38);
    color: white;
}

.filter-control-compact {
    max-width: 10.5rem;
}

.filter-control-mini {
    max-width: 8.4rem;
    padding: 0 0.65rem;
    font-size: 0.82rem;
}

.filter-control-playlist {
    max-width: 15rem;
}

.contents-search {
    display: flex;
    flex: 1 1 auto;
    justify-content: flex-end;
    gap: 0.45rem;
    margin-left: auto;
}

.contents-search .filter-control {
    max-width: 22rem;
    min-height: 2.25rem;
}

.contents-search button {
    min-height: 2.25rem;
    border-radius: 0.75rem;
    padding: 0 0.8rem;
    font-size: 0.82rem;
}

@media (max-width: 900px) {
    .contents-filterbar {
        flex-wrap: wrap;
    }

    .contents-search {
        flex-basis: 100%;
    }

    .contents-search .filter-control {
        max-width: none;
    }
}

@media (max-width: 1023px) {
    #filterForm {
        margin-bottom: 1rem;
    }

    .contents-filterbar {
        display: grid;
        grid-template-columns: minmax(7.5rem, 0.85fr) minmax(0, 1.15fr);
        gap: 0.55rem;
        border: 0;
        border-radius: 0;
        background: transparent;
        padding: 0.7rem;
    }

    .filter-segment {
        display: grid;
        grid-column: 1 / -1;
        width: 100%;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        border-color: var(--yhome-border);
        background: var(--yhome-surface-strong);
    }

    .filter-segment-btn {
        min-width: 0;
        min-height: 2.45rem;
        padding: 0 0.35rem;
        color: var(--yhome-text);
        font-size: 0.82rem;
    }

    .filter-control,
    .contents-search .filter-control {
        min-height: 2.65rem;
        max-width: none;
        border-color: var(--yhome-border);
        border-radius: 0.85rem;
        background: var(--yhome-surface-strong);
        font-size: 0.88rem;
    }

    .filter-control-playlist {
        max-width: none;
    }

    .contents-search {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 0.5rem;
        margin-left: 0;
    }

    .contents-search button {
        min-height: 2.65rem;
        border-radius: 0.85rem;
        padding: 0 0.75rem;
        white-space: nowrap;
    }

    #contentsList.contents-table-wrap {
        margin-right: -1.25rem;
        margin-left: -1.25rem;
        overflow: visible;
        border: 0;
        border-radius: 0;
        background: transparent;
    }

    #contentsList .contents-table {
        display: none;
    }

    .contents-mobile-list {
        display: grid;
        gap: 0;
    }

    .contents-mobile-card {
        display: grid;
        grid-template-columns: 7.2rem minmax(0, 1fr);
        gap: 0.6rem;
        border-top: 1px solid var(--yhome-border);
        background: var(--yhome-surface);
        padding: 0.6rem 1rem;
    }

    .contents-mobile-card:first-child {
        border-top: 0;
    }

    .contents-mobile-thumb {
        position: relative;
        display: block;
        overflow: hidden;
        align-self: start;
        border-radius: 0.7rem;
    }

    .contents-mobile-thumb img {
        aspect-ratio: 16 / 9;
        width: 100%;
        object-fit: cover;
    }

    .contents-mobile-thumb .content-duration {
        position: absolute;
        right: 0.28rem;
        bottom: 0.28rem;
        padding: 0.1rem 0.3rem;
        font-size: 0.58rem;
        font-weight: 800;
        line-height: 1.15;
        border-radius: 0.32rem;
        letter-spacing: 0.02em;
    }

    .contents-mobile-body {
        display: grid;
        min-width: 0;
        gap: 0.32rem;
    }

    .contents-mobile-body .contents-meta {
        gap: 0.22rem;
        font-size: 0.62rem;
    }

    .contents-mobile-body .contents-title {
        display: block;
        overflow: hidden;
        font-size: 0.86rem;
        line-height: 1.28;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .contents-mobile-stats {
        display: flex;
        min-width: 0;
        align-items: center;
        gap: 0.35rem;
        flex-wrap: nowrap;
    }

    .contents-mobile-stats span,
    .contents-mobile-stats a {
        display: inline-flex;
        min-width: 0;
        align-items: center;
        gap: 0.18rem;
        border-radius: 0.6rem;
        background: var(--yhome-surface-soft);
        padding: 0.24rem 0.34rem;
        color: var(--yhome-muted);
        text-decoration: none;
    }

    .contents-mobile-stats svg {
        flex: 0 0 auto;
        color: var(--yhome-primary-muted);
    }

    .contents-mobile-stats strong {
        overflow: hidden;
        color: var(--yhome-heading);
        font-size: 0.72rem;
        font-weight: 950;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .contents-mobile-extra {
        display: flex;
        flex-wrap: wrap;
        gap: 0.22rem;
        color: var(--yhome-muted);
        font-size: 0.62rem;
        font-weight: 800;
    }

    .contents-mobile-extra span {
        border-radius: 9999px;
        background: var(--yhome-surface-soft);
        padding: 0.12rem 0.36rem;
    }

    .contents-mobile-extra strong {
        margin-right: 0.22em;
        color: var(--yhome-heading);
        font-weight: 900;
    }

    .contents-mobile-extra-perf {
        flex: 1 1 100%;
        min-width: 0;
        margin-top: 0.12rem;
    }

    .contents-mobile-extra-perf .performance-badge {
        min-height: 1.9rem;
        min-width: 0;
        padding: 0.22rem 0.42rem;
        font-size: 0.66rem;
        white-space: nowrap;
    }

    .contents-mobile-extra-perf .text-slate-500 {
        display: inline-flex;
        min-height: 1.9rem;
        align-items: center;
        border-radius: 9999px;
        background: var(--yhome-surface-soft);
        padding: 0.28rem 0.5rem;
        color: var(--yhome-muted);
        font-size: 0.7rem;
        font-weight: 900;
    }
}

.contents-table-wrap {
    width: 100%;
    min-width: 0;
    overflow-x: auto;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 1.25rem;
    background: rgba(15, 23, 42, 0.72);
}

/* Contents list: horizontal scrollbar (table desktop view) */
#contentsList.contents-table-wrap {
    scrollbar-gutter: stable;
    scrollbar-width: thin;
    scrollbar-color: color-mix(in srgb, var(--yhome-primary-muted, #f87171) 58%, transparent)
        color-mix(in srgb, var(--yhome-surface-soft, rgb(30 41 59)) 92%, transparent);
}

#contentsList.contents-table-wrap::-webkit-scrollbar {
    height: 11px;
}

#contentsList.contents-table-wrap::-webkit-scrollbar-track {
    margin: 0 0.65rem 0.2rem;
    border-radius: 9999px;
    background: color-mix(in srgb, var(--yhome-surface-soft, rgb(30 41 59)) 94%, transparent);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--yhome-border, rgba(255 255 255 / 0.12)) 85%, transparent);
}

#contentsList.contents-table-wrap::-webkit-scrollbar-thumb {
    border-radius: 9999px;
    border: 3px solid transparent;
    background-clip: padding-box;
    background-color: color-mix(in srgb, var(--yhome-primary, #ef4444) 45%, var(--yhome-border, rgba(148 163 184 / 0.45)));
}

#contentsList.contents-table-wrap::-webkit-scrollbar-thumb:hover {
    background-color: color-mix(in srgb, var(--yhome-primary, #ef4444) 68%, var(--yhome-heading, #f8fafc));
}

body.yhome-channel-page #playlistGrid {
    width: 100%;
    min-width: 0;
}

.contents-mobile-list {
    display: none;
}

@media (max-width: 1023px) {
    .contents-mobile-list {
        display: grid;
    }
}

.contents-table {
    min-width: 1200px;
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    color: rgb(203, 213, 225);
    font-size: 0.82rem;
}

.contents-table th,
.contents-table td {
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    padding: 0.75rem 0.8rem;
    text-align: left;
    vertical-align: middle;
    white-space: nowrap;
}

.contents-table th {
    position: sticky;
    top: 0;
    z-index: 2;
    background: rgb(15, 23, 42);
    color: rgb(226, 232, 240);
    font-weight: 900;
}

.sort-head {
    display: inline-flex;
    width: 100%;
    align-items: center;
    gap: 0.35rem;
    color: inherit;
    font: inherit;
}

.contents-table .num .sort-head {
    justify-content: flex-end;
}

.contents-table .performance-cell .sort-head {
    justify-content: center;
}

.progress-modal {
    position: fixed;
    inset: 0;
    z-index: 80;
    display: grid;
    place-items: center;
    padding: 1.25rem;
    background: rgba(2, 6, 23, 0.78);
    backdrop-filter: blur(10px);
}

.progress-modal.hidden {
    display: none;
}

.progress-panel {
    width: min(100%, 32rem);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 1.75rem;
    background: rgba(15, 23, 42, 0.96);
    padding: 1.5rem;
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.42);
}

.progress-badge {
    min-width: 4rem;
    border-radius: 9999px;
    background: rgba(239, 68, 68, 0.16);
    padding: 0.45rem 0.8rem;
    color: rgb(254, 202, 202);
    text-align: center;
    font-size: 0.875rem;
    font-weight: 900;
}

.progress-track {
    overflow: hidden;
    height: 0.75rem;
    border-radius: 9999px;
    background: rgba(255, 255, 255, 0.1);
}

.progress-bar {
    width: 0;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, rgb(220, 38, 38), rgb(244, 63, 94), rgb(14, 165, 233));
    transition: width 0.35s ease;
}

.progress-summary {
    margin-top: 0.35rem;
    color: rgb(148, 163, 184);
    font-size: 0.82rem;
    font-weight: 700;
}

.progress-steps {
    display: grid;
    gap: 0.65rem;
    margin-top: 1.25rem;
}

.progress-steps li {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    color: rgb(148, 163, 184);
    font-size: 0.875rem;
    font-weight: 700;
}

.progress-steps span {
    display: grid;
    flex: 0 0 auto;
    width: 1.55rem;
    height: 1.55rem;
    place-items: center;
    border-radius: 9999px;
    background: rgba(255, 255, 255, 0.08);
    color: rgb(203, 213, 225);
    font-size: 0.78rem;
}

.progress-steps li.is-active {
    color: white;
}

.progress-steps li.is-active span {
    background: rgb(220, 38, 38);
    color: white;
}

.progress-steps li.is-done {
    color: rgb(187, 247, 208);
}

.progress-steps li.is-done span,
.progress-modal.is-complete .progress-badge {
    background: rgba(34, 197, 94, 0.2);
    color: rgb(187, 247, 208);
}

.progress-modal.is-error .progress-badge {
    background: rgba(248, 113, 113, 0.18);
    color: rgb(254, 202, 202);
}

.progress-error-view {
    padding: 0.35rem 0.25rem 0.75rem;
    text-align: center;
}

.progress-modal.is-error-full .progress-panel {
    width: min(100%, 26rem);
}

.progress-error-message {
    font-size: 1rem;
    font-weight: 650;
    line-height: 1.65;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
    word-break: keep-all;
}

@media (min-width: 640px) {
    .progress-error-message {
        font-size: 1.0625rem;
    }
}

.sort-head span {
    min-width: 0.8rem;
    color: rgb(248, 113, 113);
    font-size: 0.7rem;
}

.sort-head:not(.is-active) span {
    opacity: 0;
}

.sort-head:hover {
    color: white;
}

.contents-table tr:hover td {
    background: rgba(255, 255, 255, 0.04);
}

.contents-table .num {
    text-align: right;
}

.contents-comment-link {
    display: inline-flex;
    min-width: 2.25rem;
    justify-content: flex-end;
    border-radius: 9999px;
    padding: 0.2rem 0.5rem;
    color: rgb(254, 202, 202);
    font-weight: 900;
}

.contents-comment-link:hover {
    background: rgba(248, 113, 113, 0.16);
    color: white;
}

.contents-table .performance-cell {
    text-align: center;
}

.playlist-count-badge {
    display: inline-flex;
    min-width: 2.1rem;
    align-items: center;
    justify-content: center;
    border-radius: 9999px;
    background: rgba(59, 130, 246, 0.16);
    padding: 0.25rem 0.55rem;
    color: rgb(191, 219, 254);
    font-weight: 900;
}

.playlist-cell {
    position: relative;
}

.playlist-hover-layer {
    position: absolute;
    top: calc(100% - 0.25rem);
    right: 0.4rem;
    z-index: 6;
    display: none;
    min-width: 12rem;
    max-width: 18rem;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 0.9rem;
    background: rgba(15, 23, 42, 0.98);
    box-shadow: 0 1.25rem 2.5rem rgba(0, 0, 0, 0.42);
    padding: 0.45rem;
    text-align: left;
    white-space: normal;
}

.playlist-cell:hover .playlist-hover-layer {
    display: grid;
    gap: 0.25rem;
}

.playlist-layer-item,
.playlist-layer-empty {
    border-radius: 0.65rem;
    padding: 0.45rem 0.55rem;
    color: rgb(226, 232, 240);
    font-size: 0.78rem;
    font-weight: 800;
    line-height: 1.25rem;
    overflow-wrap: anywhere;
}

.playlist-layer-item {
    display: block;
    background: rgba(59, 130, 246, 0.14);
    text-decoration: none;
}

.playlist-layer-item:hover {
    background: rgba(59, 130, 246, 0.28);
    color: white;
}

.playlist-layer-empty {
    color: rgb(148, 163, 184);
}

.contents-table .contents-thumb-cell.sticky-col {
    position: sticky;
    left: 0;
    /* 가로 스크롤 시 뒤쪽 셀이 썸네일 위에 겹치지 않도록 본문·헤더 모두 앞면으로 */
    z-index: 5;
    width: 7rem;
    min-width: 7rem;
    max-width: 7rem;
    box-sizing: border-box;
    background: rgb(15, 23, 42);
    box-shadow: 4px 0 14px -8px rgba(0, 0, 0, 0.65);
}

.contents-table td.contents-content-cell {
    max-width: 15rem;
    white-space: normal;
    vertical-align: top;
}

.contents-thumb-cell {
    width: 7rem;
}

.contents-thumb-wrap {
    position: relative;
    display: block;
    width: 5.5rem;
}

.contents-thumb {
    width: 5.5rem;
    height: 3.1rem;
    border-radius: 0.55rem;
    object-fit: cover;
    background: rgba(255, 255, 255, 0.08);
}

.contents-thumb-wrap .content-duration {
    right: 0.2rem;
    bottom: 0.2rem;
    padding: 0.1rem 0.32rem;
    font-size: 0.58rem;
    font-weight: 800;
    line-height: 1.15;
    border-radius: 0.3rem;
    letter-spacing: 0.02em;
}

.contents-meta {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.35rem;
    color: rgb(148, 163, 184);
    font-size: 0.75rem;
    font-weight: 700;
}

.contents-meta .contents-source-handle {
    flex-shrink: 0;
    align-self: center;
    border-radius: 0.35rem;
    padding: 0.05rem 0.38rem;
    font-weight: 800;
    text-decoration: none;
    color: rgb(254, 202, 202);
    background: rgba(255, 255, 255, 0.06);
}

.contents-meta .contents-source-handle:hover {
    color: white;
    background: rgba(248, 113, 113, 0.18);
}

.contents-meta .contents-source-handle.is-external {
    max-width: 11rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    text-decoration: underline;
    text-decoration-color: rgba(248, 113, 113, 0.45);
    text-underline-offset: 0.12em;
}

.contents-meta .contents-source-handle.is-external:hover {
    text-decoration-color: rgba(255, 255, 255, 0.55);
}

.contents-table th.contents-thumb-cell.sticky-col {
    z-index: 6;
}

.contents-title {
    display: block;
    overflow: hidden;
    color: white;
    font-weight: 900;
    line-height: 1.35;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.contents-title:hover {
    color: rgb(254, 202, 202);
}

.contents-sub {
    margin-top: 0.25rem;
    color: rgb(100, 116, 139);
    font-size: 0.72rem;
}

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

.content-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(2, 6, 23, 0.82);
    backdrop-filter: blur(10px);
}

.content-modal-panel {
    position: relative;
    z-index: 1;
    width: min(96rem, calc(100vw - 1.5rem));
    max-height: calc(100vh - 2rem);
    margin: 0;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 1.5rem;
    background: rgb(15, 23, 42);
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.55);
    overflow-y: auto;
}

@supports (height: 100dvh) {
    .content-modal-panel {
        max-height: calc(100dvh - 1.5rem);
    }
}

.content-modal-panel,
.modal-scroll-hidden {
    scrollbar-width: none;
}

.content-modal-panel::-webkit-scrollbar,
.modal-scroll-hidden::-webkit-scrollbar {
    display: none;
}

.content-modal-body {
    display: grid;
    gap: 1rem;
    padding: 1rem;
}

.content-modal-stats {
    display: flex;
    flex-wrap: nowrap;
    align-items: stretch;
    width: 100%;
    box-sizing: border-box;
    gap: 0.65rem;
}

.content-modal-stats .metric-card {
    flex: 1 1 0;
    min-width: 0;
}

.content-modal-details {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
}

.content-download-actions {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
    gap: 0.75rem;
}

.content-download-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    border-radius: 1rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.06);
    padding: 0.85rem 1rem;
    color: white;
    font-weight: 900;
    transition: background 0.15s ease, border-color 0.15s ease, transform 0.15s ease;
}

.content-download-btn:hover {
    transform: translateY(-1px);
    border-color: rgba(248, 113, 113, 0.45);
    background: rgba(248, 113, 113, 0.16);
}

.content-download-btn.is-loading {
    pointer-events: none;
    opacity: 0.68;
}

.download-cache-dot {
    display: inline-block;
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 9999px;
    background: rgba(148, 163, 184, 0.45);
}

.content-download-btn.has-cache .download-cache-dot {
    background: rgb(34, 197, 94);
    box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.18);
}

.content-modal-comments {
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 0;
    background: transparent;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.modal-comments-list {
    display: flex;
    flex-direction: column;
    gap: 0;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 1rem;
    background: rgba(15, 23, 42, 0.72);
}

body.yhome-channel-page #modalCommentsList.modal-comments-list {
    border-color: var(--yhome-border);
    background: var(--yhome-surface-soft);
}

body.yhome-channel-page #contentModal #modalCommentsList .modal-comment-row {
    border-top-color: color-mix(in srgb, var(--yhome-border) 75%, transparent);
}

#contentModal #modalCommentsList .modal-comment-thread {
    gap: 0;
}

#contentModal #modalCommentsList .modal-comment-row {
    border-radius: 0;
    background: transparent;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding: 0.75rem 0.85rem;
}

#contentModal #modalCommentsList > .modal-comment-thread:first-child > .modal-comment-row:first-of-type {
    border-top: none;
}

#contentModal #modalCommentsList .modal-comment-row.is-reply {
    background: transparent;
}

#contentModal #modalCommentsList .modal-comment-children {
    margin-top: 0;
    padding-top: 0;
    gap: 0;
}

.modal-comment-row {
    display: grid;
    grid-template-columns: 2rem minmax(0, 1fr);
    gap: 0.75rem;
    border-radius: 1rem;
    background: rgba(15, 23, 42, 0.72);
    padding: 0.85rem;
}

.modal-comment-thread {
    display: grid;
    gap: 0.45rem;
}

.modal-comment-children {
    display: grid;
    gap: 0.45rem;
    margin-left: 1rem;
    border-left: 2px solid rgba(59, 130, 246, 0.28);
    padding-left: 0.75rem;
}

.modal-comment-row.is-reply {
    background: rgba(30, 41, 59, 0.78);
}

.modal-comment-avatar {
    display: grid;
    width: 2rem;
    height: 2rem;
    place-items: center;
    border-radius: 9999px;
    object-fit: cover;
    background: rgba(255, 255, 255, 0.1);
    color: white;
    font-size: 0.82rem;
    font-weight: 900;
}

.modal-comment-head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem;
    color: rgb(148, 163, 184);
    font-size: 0.78rem;
    font-weight: 800;
}

.modal-comment-head strong {
    color: white;
    font-size: 0.86rem;
    font-weight: 900;
}

.modal-comment-badge {
    border-radius: 9999px;
    padding: 0.15rem 0.45rem;
    font-size: 0.68rem;
    font-weight: 900;
}

.modal-comment-badge.is-reply {
    background: rgba(59, 130, 246, 0.16);
    color: rgb(191, 219, 254);
}

.modal-comment-badge.is-edited {
    background: rgba(234, 179, 8, 0.16);
    color: rgb(254, 240, 138);
}

.modal-comment-badge.is-deleted {
    background: rgba(100, 116, 139, 0.22);
    color: rgb(203, 213, 225);
}

.modal-comment-parent {
    margin-top: 0.35rem;
    color: rgb(147, 197, 253);
    font-size: 0.75rem;
    font-weight: 900;
}

.modal-comment-text {
    margin-top: 0.35rem;
    white-space: pre-line;
    color: rgb(226, 232, 240);
    font-size: 0.9rem;
    line-height: 1.6;
    overflow-wrap: anywhere;
}

.download-message {
    border-radius: 0.9rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 0.75rem 0.9rem;
    font-size: 0.875rem;
    font-weight: 800;
    text-align: center;
}

.download-message.hidden {
    display: none;
}

.download-message.is-info {
    border-color: rgba(96, 165, 250, 0.32);
    background: rgba(59, 130, 246, 0.12);
    color: rgb(191, 219, 254);
}

.download-message.is-success {
    border-color: rgba(34, 197, 94, 0.32);
    background: rgba(34, 197, 94, 0.12);
    color: rgb(187, 247, 208);
}

.download-message.is-error {
    border-color: rgba(248, 113, 113, 0.36);
    background: rgba(239, 68, 68, 0.13);
    color: rgb(254, 202, 202);
}

@media (max-width: 640px) {
    .content-modal {
        align-items: stretch;
        padding: 0.35rem;
    }

    .content-modal-panel {
        width: 100%;
        max-height: calc(100vh - 0.7rem);
        border-radius: 1rem;
    }

    @supports (height: 100dvh) {
        .content-modal-panel {
            max-height: calc(100dvh - 0.7rem);
        }
    }

    .content-modal-body {
        gap: 0.8rem;
        padding: 0.8rem;
    }

    .content-modal-youtube-btn {
        padding: 0.5rem 0.7rem;
        font-size: 0.78rem;
    }

    .content-modal-youtube-btn span {
        display: none;
    }

    .content-download-actions {
        gap: 0.5rem;
    }

    .content-download-btn {
        padding: 0.7rem 0.5rem;
        font-size: 0.78rem;
    }

    .content-modal-stats {
        display: flex;
        flex-wrap: nowrap;
        gap: 0;
        overflow: hidden;
        border: 1px solid var(--yhome-border);
        border-radius: 0.9rem;
        background: var(--yhome-surface-soft);
    }

    .content-modal-stats .metric-card {
        min-width: 0;
        border: 0;
        border-radius: 0;
        background: transparent;
        padding: 0.55rem 0.25rem;
        text-align: center;
    }

    .content-modal-stats .metric-card + .metric-card {
        border-left: 1px solid var(--yhome-border);
    }

    .content-modal-stats .metric-card span,
    .content-modal-stats .metric-card strong {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .content-modal-stats .metric-card span {
        color: var(--yhome-muted);
        font-size: 0.68rem;
        font-weight: 850;
        line-height: 1.15;
    }

    .content-modal-stats .metric-card strong {
        margin-top: 0.18rem;
        color: var(--yhome-heading);
        font-size: clamp(0.86rem, 3.8vw, 1.05rem);
        line-height: 1.2;
    }

    /* #contentModal: mobile bottom sheet (player modal) */
    #contentModal.content-modal:not(.hidden) {
        align-items: flex-end;
        justify-content: stretch;
        padding: 0;
    }

    #contentModal.content-modal:not(.hidden) .content-modal-backdrop {
        opacity: 0;
        transition: opacity 0.26s ease;
    }

    #contentModal.content-modal:not(.hidden).content-modal--visible .content-modal-backdrop {
        opacity: 1;
    }

    #contentModal .content-modal-panel {
        display: flex;
        width: 100%;
        max-width: none;
        max-height: 90vh;
        max-height: 90dvh;
        flex-direction: column;
        overflow: hidden;
        border-radius: 1.25rem 1.25rem 0 0;
        margin: 0;
        transform: translateY(100%);
        transition: transform 0.34s cubic-bezier(0.32, 0.72, 0, 1);
        padding-bottom: env(safe-area-inset-bottom, 0);
    }

    #contentModal.content-modal:not(.hidden).content-modal--visible .content-modal-panel {
        transform: translateY(0);
    }

    #contentModal .content-modal-panel > div:first-child {
        flex-shrink: 0;
    }

    #contentModal .content-modal-panel > .content-modal-body {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 0.8rem;
        padding: 0.8rem;
        flex: 1 1 auto;
        min-height: 0;
        min-width: 0;
        overflow-x: hidden;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        isolation: isolate;
        scrollbar-width: thin;
        scrollbar-color: rgba(148, 163, 184, 0.55) rgba(15, 23, 42, 0.55);
    }

    #contentModal .content-modal-panel > .content-modal-body::-webkit-scrollbar {
        width: 10px;
    }

    #contentModal .content-modal-panel > .content-modal-body::-webkit-scrollbar-track {
        margin: 6px 0;
        border-radius: 999px;
        background: rgba(15, 23, 42, 0.72);
    }

    #contentModal .content-modal-panel > .content-modal-body::-webkit-scrollbar-thumb {
        border-radius: 999px;
        border: 2px solid rgba(15, 23, 42, 0.72);
        background: linear-gradient(180deg, rgba(203, 213, 225, 0.45), rgba(148, 163, 184, 0.35));
    }

    #contentModal .content-modal-panel > .content-modal-body::-webkit-scrollbar-thumb:hover {
        background: linear-gradient(180deg, rgba(248, 250, 252, 0.55), rgba(203, 213, 225, 0.45));
    }

    #contentModal .content-modal-panel > .content-modal-body > .content-player-wrap {
        flex: 0 0 auto;
        align-self: stretch;
        width: 100%;
        min-width: 0;
    }

    #contentModal .content-modal-panel > .content-modal-body > #modalStats,
    #contentModal .content-modal-panel > .content-modal-body > .content-modal-details,
    #contentModal .content-modal-panel > .content-modal-body > #modalDownloadMessage,
    #contentModal .content-modal-panel > .content-modal-body > .content-download-actions,
    #contentModal .content-modal-panel > .content-modal-body > #modalCommentsSection {
        flex: 0 0 auto;
        min-width: 0;
        position: relative;
    }

    #contentModal .content-modal-details {
        display: flex;
        flex-direction: column;
        gap: 1rem;
    }

    #contentModal #modalDescription {
        scrollbar-width: thin;
        scrollbar-color: rgba(148, 163, 184, 0.5) rgba(15, 23, 42, 0.5);
    }

    #contentModal #modalDescription::-webkit-scrollbar {
        display: block;
        width: 8px;
    }

    #contentModal #modalDescription::-webkit-scrollbar-track {
        border-radius: 999px;
        background: rgba(15, 23, 42, 0.55);
    }

    #contentModal #modalDescription::-webkit-scrollbar-thumb {
        border-radius: 999px;
        border: 2px solid rgba(15, 23, 42, 0.55);
        background: linear-gradient(180deg, rgba(203, 213, 225, 0.4), rgba(148, 163, 184, 0.32));
    }

    #contentModal #modalDescription::-webkit-scrollbar-thumb:hover {
        background: linear-gradient(180deg, rgba(248, 250, 252, 0.5), rgba(203, 213, 225, 0.4));
    }
}

@media (max-width: 640px) and (max-height: 520px) {
    #contentModal .content-modal-panel > .content-modal-body > .content-player-wrap {
        max-height: min(48dvh, 56.25vw);
        width: 100%;
        margin-inline: auto;
    }
}

@media (max-width: 640px) and (prefers-reduced-motion: reduce) {
    #contentModal .content-modal-panel {
        transform: none !important;
        transition: none !important;
    }

    #contentModal.content-modal:not(.hidden) .content-modal-backdrop {
        opacity: 1;
        transition: none;
    }
}

.performance-modal-panel {
    position: relative;
    z-index: 1;
    width: min(48rem, calc(100vw - 2rem));
    max-height: calc(100vh - 2rem);
    margin: 0;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 1.5rem;
    background: rgb(15, 23, 42);
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.55);
    overflow-y: auto;
}

.performance-hero {
    display: flex;
    align-items: center;
    gap: 1.1rem;
}

.performance-ring {
    --score: 0;
    display: grid;
    width: 6.5rem;
    height: 6.5rem;
    flex: 0 0 auto;
    place-items: center;
    border-radius: 9999px;
    background: conic-gradient(rgb(248, 113, 113) calc(var(--score) * 1%), rgba(255, 255, 255, 0.08) 0);
}

.performance-ring > div {
    display: grid;
    width: 4.9rem;
    height: 4.9rem;
    place-items: center;
    border-radius: 9999px;
    background: rgb(15, 23, 42);
    line-height: 1;
}

.performance-ring strong {
    color: white;
    font-size: 1.55rem;
    font-weight: 950;
}

.performance-ring span {
    color: rgb(148, 163, 184);
    font-size: 0.75rem;
    font-weight: 900;
}

.performance-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    border-radius: 9999px;
    background: rgba(255, 255, 255, 0.07);
    padding: 0.35rem 0.65rem;
    font-size: 0.78rem;
}

.performance-chip span {
    color: rgb(148, 163, 184);
    font-weight: 800;
}

.performance-chip strong {
    color: white;
    font-weight: 900;
}

.performance-bars {
    display: grid;
    gap: 0.9rem;
}

.performance-score-row {
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.04);
    padding: 0.9rem;
}

.performance-score-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.55rem;
}

.performance-score-head strong {
    color: white;
    font-weight: 950;
}

.performance-score-head span,
.performance-score-value {
    color: rgb(148, 163, 184);
    font-size: 0.8rem;
    font-weight: 800;
}

.performance-score-track {
    overflow: hidden;
    height: 0.65rem;
    border-radius: 9999px;
    background: rgba(255, 255, 255, 0.08);
}

.performance-score-fill {
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, rgb(248, 113, 113), rgb(251, 191, 36));
}

.score-vph .performance-score-fill {
    background: linear-gradient(90deg, rgb(96, 165, 250), rgb(34, 211, 238));
}

.score-engagement .performance-score-fill {
    background: linear-gradient(90deg, rgb(52, 211, 153), rgb(163, 230, 53));
}

.performance-score-value {
    margin-top: 0.45rem;
}

.performance-level-guide {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    overflow: hidden;
    border-radius: 0.9rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: rgb(203, 213, 225);
    font-size: 0.75rem;
    font-weight: 900;
    text-align: center;
}

.performance-level-guide span {
    padding: 0.55rem 0.25rem;
    background: rgba(255, 255, 255, 0.04);
}

.performance-level-guide span + span {
    border-left: 1px solid rgba(255, 255, 255, 0.08);
}

.content-player-wrap {
    position: relative;
    overflow: hidden;
    border-radius: 1.25rem;
    background: #000;
    aspect-ratio: 16 / 9;
    width: 100%;
}

.content-player-wrap iframe {
    position: absolute;
    inset: 0;
    display: block;
    width: 100%;
    height: 100%;
    border: 0;
}

@media (max-width: 640px) {
    .content-player-wrap {
        border-radius: 0.9rem;
    }
}

.modal-pill {
    display: inline-flex;
    max-width: 100%;
    border-radius: 9999px;
    background: rgba(255, 255, 255, 0.08);
    padding: 0.35rem 0.65rem;
    color: rgb(226, 232, 240);
    font-size: 0.78rem;
    font-weight: 800;
}

.modal-extra-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border-radius: 0.9rem;
    background: rgba(255, 255, 255, 0.04);
    padding: 0.75rem 0.9rem;
}

.modal-extra-row span {
    color: rgb(148, 163, 184);
    font-weight: 700;
}

.modal-extra-row strong {
    overflow: hidden;
    color: white;
    text-align: right;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.modal-extra-row.is-multiline {
    align-items: flex-start;
}

.modal-extra-row.is-multiline strong {
    white-space: normal;
    overflow-wrap: anywhere;
}

.modal-playlist-row strong {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.4rem;
}

.modal-playlist-row a {
    border-radius: 9999px;
    background: rgba(59, 130, 246, 0.16);
    padding: 0.25rem 0.55rem;
    color: rgb(191, 219, 254);
    text-decoration: none;
}

.modal-playlist-row a:hover {
    background: rgba(59, 130, 246, 0.28);
    color: white;
}

.performance-badge {
    display: inline-flex;
    min-width: 3rem;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    border-radius: 9999px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 0.35rem 0.5rem;
    color: white;
    font-size: 0.75rem;
    font-weight: 900;
    text-align: center;
    transition: transform 0.15s ease, filter 0.15s ease;
}

.performance-badge:hover {
    transform: translateY(-1px);
    filter: brightness(1.12);
}

.performance-badge span {
    opacity: 0.82;
    font-weight: 800;
}

.performance-level-1 {
    background: rgba(100, 116, 139, 0.34);
    color: rgb(226, 232, 240);
}

.performance-level-2 {
    background: rgba(234, 179, 8, 0.18);
    color: rgb(254, 240, 138);
}

.performance-level-3 {
    background: rgba(59, 130, 246, 0.18);
    color: rgb(191, 219, 254);
}

.performance-level-4 {
    background: rgba(34, 197, 94, 0.18);
    color: rgb(187, 247, 208);
}

.performance-level-5 {
    background: rgba(244, 63, 94, 0.2);
    color: rgb(254, 205, 211);
}

.pager-btn {
    min-width: 2.25rem;
    border-radius: 9999px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    padding: 0.45rem 0.75rem;
    color: rgb(226, 232, 240);
    font-size: 0.875rem;
    font-weight: 800;
}

.pager-btn:hover,
.pager-btn.is-active {
    background: rgb(220, 38, 38);
    border-color: rgb(220, 38, 38);
    color: white;
}

.pager-btn:disabled {
    cursor: not-allowed;
    opacity: 0.38;
}

.pager-btn:disabled:hover {
    background: transparent;
    border-color: rgba(255, 255, 255, 0.12);
    color: rgb(226, 232, 240);
}

body.yhome-channel-page .pager-btn {
    border-color: var(--yhome-border);
    background: var(--yhome-surface-soft);
    color: var(--yhome-text);
}

body.yhome-channel-page .pager-btn:disabled {
    color: var(--yhome-dim);
}

body.yhome-channel-page .pager-btn:disabled:hover {
    border-color: var(--yhome-border);
    background: var(--yhome-surface-soft);
    color: var(--yhome-dim);
}

.analysis-panel {
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 1.25rem;
    background: rgba(15, 23, 42, 0.72);
    padding: 1rem;
}

.analysis-panel h3 {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: white;
    font-size: 1rem;
    font-weight: 900;
}

.analysis-rank-row {
    display: flex;
    min-width: 0;
    align-items: center;
    gap: 0.75rem;
    border-radius: 0.9rem;
    background: rgba(255, 255, 255, 0.04);
    padding: 0.7rem 0.8rem;
    color: rgb(203, 213, 225);
    font-size: 0.875rem;
}

.analysis-rank-row strong {
    flex: 0 0 auto;
    color: white;
    font-weight: 900;
}

.analysis-rank-no {
    display: grid;
    width: 1.55rem;
    height: 1.55rem;
    place-items: center;
    border-radius: 9999px;
    background: rgba(220, 38, 38, 0.25);
    color: rgb(254, 202, 202);
    font-size: 0.75rem;
    font-weight: 900;
}

.analysis-kind-ratio {
    display: grid;
    gap: 0.85rem;
}

.analysis-kind-ratio-track {
    display: flex;
    overflow: hidden;
    height: 1.05rem;
    border-radius: 9999px;
    background: color-mix(in srgb, var(--yhome-muted) 16%, transparent);
}

.analysis-kind-ratio-track span {
    display: block;
    min-width: 0;
}

.analysis-kind-ratio-track .is-shorts,
.analysis-kind-ratio-legend i.is-shorts {
    background: linear-gradient(90deg, #f43f5e, #fb7185);
}

.analysis-kind-ratio-track .is-long,
.analysis-kind-ratio-legend i.is-long {
    background: linear-gradient(90deg, #0ea5e9, #22d3ee);
}

.analysis-kind-ratio-track .is-long {
    box-shadow: inset 2px 0 0 color-mix(in srgb, var(--yhome-bg) 78%, white);
}

.analysis-kind-ratio-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
}

.analysis-kind-ratio-legend span {
    display: inline-flex;
    min-width: 0;
    max-width: 100%;
    align-items: center;
    gap: 0.4rem;
    border-radius: 9999px;
    background: var(--yhome-surface-soft);
    padding: 0.35rem 0.65rem;
    color: var(--yhome-muted);
    font-size: 0.78rem;
    font-weight: 900;
}

.analysis-kind-ratio-legend i {
    width: 0.55rem;
    height: 0.55rem;
    flex: 0 0 auto;
    border-radius: 9999px;
}

.analysis-kind-ratio-legend strong {
    overflow: hidden;
    color: var(--yhome-heading);
    font-weight: 950;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.analysis-vbar-chart {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    align-items: end;
    gap: 0.35rem;
    min-height: 11rem;
    padding: 0.15rem 0.25rem 0;
}

.analysis-vbar-item {
    display: grid;
    min-width: 0;
    height: 100%;
    grid-template-rows: auto 1fr auto;
    justify-items: center;
    gap: 0.42rem;
    text-align: center;
}

.analysis-vbar-item strong {
    overflow: hidden;
    color: var(--yhome-heading);
    font-size: 0.72rem;
    font-weight: 950;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.analysis-vbar-track {
    display: flex;
    overflow: hidden;
    align-items: end;
    justify-self: center;
    width: clamp(0.7rem, 44%, 1.15rem);
    min-height: 8.5rem;
    border-radius: 0.75rem;
    background: color-mix(in srgb, var(--yhome-muted) 11%, transparent);
}

.analysis-vbar-track span {
    display: block;
    width: 100%;
    min-height: 0.35rem;
    border-radius: inherit;
    background: linear-gradient(180deg, var(--yhome-accent-two), var(--yhome-primary));
    box-shadow: 0 0.7rem 1.35rem color-mix(in srgb, var(--yhome-primary) 22%, transparent);
}

.analysis-vbar-item em {
    color: var(--yhome-muted);
    font-size: 0.75rem;
    font-style: normal;
    font-weight: 900;
}

.analysis-pie-panel {
    display: flex;
    flex-direction: column;
}

.analysis-pie-wrap {
    display: grid;
    grid-template-columns: minmax(8rem, 0.75fr) minmax(0, 1fr);
    align-items: center;
    align-content: center;
    gap: 1rem;
    flex: 1 1 auto;
}

.analysis-pie-chart {
    position: relative;
    display: grid;
    width: min(100%, 10.5rem);
    aspect-ratio: 1;
    justify-self: center;
    place-items: center;
    border-radius: 9999px;
    background: conic-gradient(var(--pie));
    box-shadow: 0 1rem 2.5rem color-mix(in srgb, var(--yhome-primary) 16%, transparent);
}

.analysis-pie-chart::after {
    content: "";
    position: absolute;
    inset: 18%;
    border-radius: inherit;
    background: var(--yhome-surface-strong);
    box-shadow: inset 0 0 0 1px var(--yhome-border);
}

.analysis-pie-chart > div {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: baseline;
    gap: 0.16rem;
    text-align: center;
}

.analysis-pie-chart strong,
.analysis-pie-chart span {
    position: relative;
    z-index: 1;
    line-height: 1;
}

.analysis-pie-chart strong {
    color: var(--yhome-heading);
    font-size: 1.45rem;
    font-weight: 950;
}

.analysis-pie-chart span {
    color: var(--yhome-muted);
    font-size: 0.78rem;
    font-weight: 900;
}

.analysis-pie-legend {
    display: grid;
    min-width: 0;
    gap: 0.45rem;
}

.analysis-pie-legend span {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.45rem;
    min-width: 0;
    border-radius: 0.8rem;
    background: var(--yhome-surface-soft);
    padding: 0.45rem 0.6rem;
    color: var(--yhome-muted);
    font-size: 0.78rem;
    font-weight: 900;
}

.analysis-pie-legend i {
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 9999px;
}

.analysis-pie-legend strong {
    overflow: hidden;
    color: var(--yhome-heading);
    font-weight: 950;
    text-overflow: ellipsis;
    white-space: nowrap;
}

@media (max-width: 640px) {
    .analysis-pie-wrap {
        grid-template-columns: 1fr;
    }

    .analysis-pie-chart {
        width: min(72vw, 10rem);
    }
}

.message-ok {
    background: rgba(34, 197, 94, 0.12);
    color: rgb(187, 247, 208);
    border: 1px solid rgba(34, 197, 94, 0.3);
}

.message-error {
    background: rgba(239, 68, 68, 0.12);
    color: rgb(254, 202, 202);
    border: 1px solid rgba(239, 68, 68, 0.3);
}

.message-info {
    background: rgba(59, 130, 246, 0.12);
    color: rgb(191, 219, 254);
    border: 1px solid rgba(59, 130, 246, 0.35);
}

.community-filter {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
    border: 1px solid rgba(248, 113, 113, 0.24);
    border-radius: 1rem;
    background: rgba(127, 29, 29, 0.22);
    padding: 0.85rem 1rem;
    color: rgb(254, 226, 226);
    font-size: 0.9rem;
}

.community-filter-clear {
    flex: 0 0 auto;
    color: white;
    font-weight: 900;
}

.community-filter-info {
    display: flex;
    flex: 1 1 0%;
    min-width: 0;
    align-items: center;
    gap: 0.75rem;
}

.community-filter-thumb {
    width: 8rem;
    flex: 0 0 auto;
    aspect-ratio: 16 / 9;
    border-radius: 0.75rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    object-fit: cover;
    background: rgba(255, 255, 255, 0.08);
}

.community-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 11rem), 1fr));
    gap: 0.75rem;
}

.community-stat-card {
    display: flex;
    min-width: 0;
    align-items: flex-start;
    gap: 0.75rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 1rem;
    background: rgba(15, 23, 42, 0.72);
    padding: 0.9rem;
}

.community-stat-icon {
    display: grid;
    width: 2rem;
    height: 2rem;
    flex: 0 0 auto;
    place-items: center;
    border-radius: 0.8rem;
    background: rgba(248, 113, 113, 0.16);
    color: rgb(254, 202, 202);
}

.community-stat-card span {
    display: block;
    color: rgb(148, 163, 184);
    font-size: 0.75rem;
    font-weight: 900;
}

.community-stat-card strong {
    display: block;
    margin-top: 0.15rem;
    color: white;
    font-size: 1.25rem;
    font-weight: 950;
    line-height: 1.2;
}

.community-stat-card p {
    margin-top: 0.25rem;
    color: rgb(100, 116, 139);
    font-size: 0.75rem;
    font-weight: 800;
    line-height: 1.35;
}

.community-analysis-summary {
    margin-bottom: 1rem;
}

.community-analysis-summary-card {
    display: grid;
    width: 100%;
    gap: 0.35rem;
    border: 1px solid rgba(248, 113, 113, 0.22);
    border-radius: 1.2rem;
    background: linear-gradient(135deg, rgba(127, 29, 29, 0.28), rgba(15, 23, 42, 0.86));
    padding: 1rem;
    text-align: left;
}

.community-analysis-summary-head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.community-analysis-summary-card span {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    color: rgb(254, 202, 202);
    font-size: 0.82rem;
    font-weight: 950;
}

.community-analysis-summary-card strong {
    display: -webkit-box;
    overflow: hidden;
    color: white;
    font-size: 0.98rem;
    line-height: 1.5;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.community-analysis-summary-card em {
    color: rgb(148, 163, 184);
    font-size: 0.78rem;
    font-style: normal;
    font-weight: 800;
}

.community-analysis-summary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin-top: 0.75rem;
}

.community-analysis-mini-card {
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.04);
    padding: 0.75rem;
}

.community-analysis-mini-card > span {
    display: block;
    margin-bottom: 0.45rem;
    color: rgb(248, 113, 113);
    font-size: 0.75rem;
    font-weight: 950;
}

.community-analysis-mini-card p {
    display: -webkit-box;
    overflow: hidden;
    color: rgb(226, 232, 240);
    font-size: 0.86rem;
    line-height: 1.5;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
}

.community-analysis-mini-card .keyword-cloud {
    min-height: 4rem;
}

.community-analysis-mini-card .keyword-cloud-word {
    padding: 0.12rem 0.45rem;
}

@media (max-width: 900px) {
    .community-analysis-summary-grid {
        grid-template-columns: 1fr;
    }
}

.community-analysis-modal-panel {
    position: relative;
    z-index: 1;
    display: flex;
    width: min(58rem, calc(100vw - 2rem));
    max-height: calc(100vh - 2rem);
    min-height: 0;
    flex-direction: column;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 1.5rem;
    background: rgb(15, 23, 42);
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.55);
}

@supports (height: 100dvh) {
    .community-analysis-modal-panel {
        max-height: calc(100dvh - 2rem);
    }
}

.community-analysis-modal-panel > div:first-child {
    flex-shrink: 0;
}

#communityAnalysisBody {
    flex: 1 1 auto;
    min-width: 0;
    min-height: 0;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: rgba(148, 163, 184, 0.55) rgba(15, 23, 42, 0.45);
}

#communityAnalysisBody::-webkit-scrollbar {
    width: 10px;
}

#communityAnalysisBody::-webkit-scrollbar-track {
    margin: 6px 0;
    border-radius: 999px;
    background: rgba(15, 23, 42, 0.72);
}

#communityAnalysisBody::-webkit-scrollbar-thumb {
    border-radius: 999px;
    border: 2px solid rgba(15, 23, 42, 0.72);
    background: linear-gradient(180deg, rgba(203, 213, 225, 0.45), rgba(148, 163, 184, 0.35));
}

#communityAnalysisBody::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, rgba(248, 250, 252, 0.55), rgba(203, 213, 225, 0.45));
}

body.yhome-channel-page #communityAnalysisBody {
    scrollbar-color: color-mix(in srgb, var(--yhome-primary-muted) 52%, transparent)
        color-mix(in srgb, var(--yhome-surface-strong) 88%, transparent);
}

body.yhome-channel-page #communityAnalysisBody::-webkit-scrollbar-track {
    background: color-mix(in srgb, var(--yhome-surface-strong) 90%, transparent);
}

body.yhome-channel-page #communityAnalysisBody::-webkit-scrollbar-thumb {
    border-color: color-mix(in srgb, var(--yhome-surface-strong) 90%, transparent);
    background: linear-gradient(
        180deg,
        color-mix(in srgb, var(--yhome-primary-muted) 48%, transparent),
        color-mix(in srgb, var(--yhome-primary-muted) 28%, transparent)
    );
}

body.yhome-channel-page #communityAnalysisBody::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(
        180deg,
        color-mix(in srgb, var(--yhome-heading) 35%, transparent),
        color-mix(in srgb, var(--yhome-primary-muted) 42%, transparent)
    );
}

.analysis-summary-card,
.analysis-grid article {
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 1.1rem;
    background: rgba(255, 255, 255, 0.04);
    padding: 1rem;
}

.analysis-summary-card h3,
.analysis-grid h3 {
    margin-bottom: 0.65rem;
    color: white;
    font-size: 0.95rem;
    font-weight: 950;
}

.analysis-summary-card p,
.analysis-grid li {
    color: rgb(203, 213, 225);
    font-size: 0.9rem;
    line-height: 1.65;
}

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

.analysis-grid .analysis-wide {
    grid-column: 1 / -1;
}

.analysis-grid ul {
    display: grid;
    gap: 0.4rem;
    padding-left: 1rem;
    list-style: disc;
}

.sentiment-row {
    display: grid;
    grid-template-columns: 2.5rem minmax(0, 1fr) 3rem;
    align-items: center;
    gap: 0.55rem;
    margin-top: 0.55rem;
    color: rgb(203, 213, 225);
    font-size: 0.82rem;
    font-weight: 900;
}

.sentiment-row div {
    overflow: hidden;
    height: 0.55rem;
    border-radius: 9999px;
    background: rgba(255, 255, 255, 0.1);
}

.sentiment-row b {
    display: block;
    height: 100%;
    border-radius: inherit;
}

.sentiment-row b.positive {
    background: rgb(34, 197, 94);
}

.sentiment-row b.neutral {
    background: rgb(148, 163, 184);
}

.sentiment-row b.negative {
    background: rgb(248, 113, 113);
}

.keyword-cloud {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    min-height: 8rem;
}

.keyword-cloud-word {
    display: inline-flex;
    border-radius: 9999px;
    padding: 0.18rem 0.55rem;
    font-weight: 950;
    line-height: 1.4;
}

.keyword-cloud-word.tone-0 { color: rgb(254, 202, 202); background: rgba(248, 113, 113, 0.12); }
.keyword-cloud-word.tone-1 { color: rgb(191, 219, 254); background: rgba(59, 130, 246, 0.12); }
.keyword-cloud-word.tone-2 { color: rgb(187, 247, 208); background: rgba(34, 197, 94, 0.12); }
.keyword-cloud-word.tone-3 { color: rgb(254, 240, 138); background: rgba(234, 179, 8, 0.12); }
.keyword-cloud-word.tone-4 { color: rgb(221, 214, 254); background: rgba(139, 92, 246, 0.12); }

.community-comment-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 9rem;
    gap: 0.8rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 1.35rem;
    background: rgba(15, 23, 42, 0.72);
    padding: 1rem;
}

.community-comment-card.is-reply {
    border-left: 4px solid rgba(59, 130, 246, 0.75);
}

.community-comment-card.is-video-filtered {
    grid-template-columns: 1fr;
}

.community-comment-main {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.community-comment-meta {
    margin-top: 0.65rem;
    padding-top: 0.75rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.community-author-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.55rem;
    color: rgb(148, 163, 184);
    font-size: 0.82rem;
    font-weight: 800;
}

.community-author-link {
    display: inline-flex;
    min-width: 0;
    align-items: center;
    gap: 0.5rem;
    color: white;
    font-weight: 900;
}

.community-author-link:hover {
    color: rgb(254, 202, 202);
}

.community-author-img {
    display: grid;
    width: 2rem;
    height: 2rem;
    flex: 0 0 auto;
    place-items: center;
    border-radius: 9999px;
    object-fit: cover;
    background: rgba(255, 255, 255, 0.1);
    color: white;
    font-size: 0.82rem;
    font-weight: 900;
}

.community-status-badge {
    border-radius: 9999px;
    padding: 0.22rem 0.55rem;
    font-size: 0.72rem;
    font-weight: 900;
}

.community-status-badge.is-edited {
    background: rgba(234, 179, 8, 0.16);
    color: rgb(254, 240, 138);
}

.community-status-badge.is-deleted {
    background: rgba(100, 116, 139, 0.22);
    color: rgb(203, 213, 225);
}

.community-comment-date {
    color: rgb(100, 116, 139);
    font-weight: 500;
}

.modal-comment-published {
    font-weight: 500;
}

.community-comment-like {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    color: rgb(148, 163, 184);
}

.community-parent-preview {
    margin: 0 0 0.55rem 0;
    border-left: 3px solid rgba(148, 163, 184, 0.35);
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.04);
    padding: 0.5rem 0.75rem;
}

.community-parent-preview span {
    color: rgb(147, 197, 253);
    font-size: 0.75rem;
    font-weight: 900;
}

.community-parent-preview p {
    display: -webkit-box;
    overflow: hidden;
    margin-top: 0.25rem;
    color: rgb(148, 163, 184);
    font-size: 0.82rem;
    line-height: 1.45;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.community-comment-text {
    margin: 0 0 0.35rem 0;
    white-space: pre-line;
    color: rgb(226, 232, 240);
    font-size: 0.95rem;
    line-height: 1.7;
    overflow-wrap: anywhere;
}

.community-video-card {
    display: block;
    align-self: center;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 0.85rem;
    background: rgba(255, 255, 255, 0.04);
}

.community-video-card:hover {
    border-color: rgba(248, 113, 113, 0.45);
    background: rgba(255, 255, 255, 0.07);
}

.community-video-card img {
    aspect-ratio: 16 / 9;
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
    background: rgba(255, 255, 255, 0.08);
}

@media (max-width: 900px) {
    .community-comment-card {
        grid-template-columns: 1fr;
    }

    .community-video-card {
        width: 9rem;
        max-width: 45vw;
    }

    .community-filter {
        align-items: flex-start;
        flex-direction: column;
    }

    .community-filter-info {
        align-items: flex-start;
        align-self: stretch;
        width: 100%;
    }

    .community-filter-thumb {
        width: 6rem;
    }
}

body.yhome-channel-page .text-red-100,
body.yhome-channel-page .text-red-200,
body.yhome-channel-page .text-red-300,
body.yhome-channel-page .text-red-400,
body.yhome-channel-page .contents-comment-link,
body.yhome-channel-page .contents-meta .contents-source-handle,
body.yhome-channel-page .sort-head span,
body.yhome-channel-page .modal-playlist-row a,
body.yhome-channel-page .community-analysis-summary-card span,
body.yhome-channel-page .community-analysis-mini-card > span,
body.yhome-channel-page .account-settings-member-grade,
body.yhome-channel-page .account-settings-status,
body.yhome-channel-page .download-message.is-error,
body.yhome-channel-page .modal-comment-parent,
body.yhome-channel-page .community-parent-preview span {
    color: var(--yhome-primary-muted);
}

body.yhome-channel-page .community-comment-meta {
    border-top-color: var(--yhome-border, rgba(255, 255, 255, 0.1));
}

body.yhome-channel-page .bg-red-500,
body.yhome-channel-page .bg-red-600,
body.yhome-channel-page #refreshChannel,
body.yhome-channel-page #modalYoutubeLink,
body.yhome-channel-page #reanalyzeComments,
body.yhome-channel-page .filter-segment-btn:hover,
body.yhome-channel-page .filter-segment-btn.is-active,
body.yhome-channel-page .progress-steps li.is-active span,
body.yhome-channel-page .analysis-rank-no,
body.yhome-channel-page .sentiment-row b.positive {
    background: var(--yhome-primary);
    color: white;
}

body.yhome-channel-page .hover\:bg-red-500:hover,
body.yhome-channel-page #refreshChannel:hover,
body.yhome-channel-page #modalYoutubeLink:hover,
body.yhome-channel-page #reanalyzeComments:hover {
    background: var(--yhome-primary-hover);
}

body.yhome-channel-page .border-red-300\/30,
body.yhome-channel-page .account-settings-card,
body.yhome-channel-page .account-settings-url-row input,
body.yhome-channel-page .account-settings-layout-value-btn,
body.yhome-channel-page .account-settings-theme-option,
body.yhome-channel-page .theme-option-swatches,
body.yhome-channel-page .download-message.is-error,
body.yhome-channel-page #analyzeComments {
    border-color: color-mix(in srgb, var(--yhome-primary-muted) 34%, transparent);
}

body.yhome-channel-page .bg-red-500\/15,
body.yhome-channel-page .content-kind-long,
body.yhome-channel-page .content-kind-shorts,
body.yhome-channel-page .performance-level-3,
body.yhome-channel-page .performance-level-5,
body.yhome-channel-page .keyword-cloud-word,
body.yhome-channel-page .download-message.is-error,
body.yhome-channel-page .modal-comment-badge.is-reply,
body.yhome-channel-page .community-stat-icon,
body.yhome-channel-page .playlist-count-badge,
body.yhome-channel-page .contents-comment-link:hover,
body.yhome-channel-page .contents-meta .contents-source-handle:hover,
body.yhome-channel-page .community-filter,
body.yhome-channel-page .community-analysis-mini-card,
body.yhome-channel-page .community-analysis-summary-card,
body.yhome-channel-page .modal-playlist-row a,
body.yhome-channel-page #analyzeComments,
body.yhome-channel-page .account-settings-member-status-row,
body.yhome-channel-page .account-settings-theme-option.is-active,
body.yhome-channel-page .account-settings-theme-option[data-selected="1"] {
    background: var(--yhome-primary-soft);
}

body.yhome-channel-page .account-settings-theme-option:hover:not(.is-active):not([data-selected="1"]) {
    background: color-mix(in srgb, var(--yhome-primary) 8%, rgba(255, 255, 255, 0.045));
}

body.yhome-channel-page .bg-gradient-to-r,
body.yhome-channel-page .bg-gradient-to-br {
    background-image: var(--yhome-hero-gradient);
}

body.yhome-channel-page .filter-segment,
body.yhome-channel-page .filter-control,
body.yhome-channel-page .contents-table th,
body.yhome-channel-page .contents-table .sticky-col,
body.yhome-channel-page .performance-ring > div,
body.yhome-channel-page .content-duration,
body.yhome-channel-page .playlist-hover-layer,
body.yhome-channel-page .progress-panel,
body.yhome-channel-page .content-modal-panel,
body.yhome-channel-page .performance-modal-panel,
body.yhome-channel-page .community-analysis-modal-panel {
    background: var(--yhome-surface-strong);
}

/* 계정 드롭다운·계정/채널 설정 패널 본문: 테마 대비용 불투명 배경(딤은 .account-settings-backdrop) */
body.yhome-channel-page .account-settings-panel,
body.yhome-channel-page #yhomeAccountPanel {
    background: var(--yhome-bg);
}

/* 밝은 채널 테마: 계정 패널 배경이 밝아질 때 amber-100 글자가 묻히지 않도록 */
body.yhome-channel-page #yhomeAccountPanel .yhome-account-panel-admin {
    color: var(--yhome-heading);
    border-color: color-mix(in srgb, var(--yhome-primary) 38%, transparent);
    background: color-mix(in srgb, var(--yhome-primary) 14%, transparent);
}
body.yhome-channel-page #yhomeAccountPanel .yhome-account-panel-admin:hover {
    color: var(--yhome-heading);
    border-color: color-mix(in srgb, var(--yhome-primary) 48%, transparent);
    background: color-mix(in srgb, var(--yhome-primary) 22%, transparent);
}

body.yhome-channel-page .filter-control {
    color: var(--yhome-text);
}

body.yhome-channel-page .filter-control::placeholder {
    color: var(--yhome-dim);
}

body.yhome-channel-page .filter-control:focus {
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--yhome-primary) 28%, transparent);
}

body.yhome-channel-page .shadow-red-950\/25,
body.yhome-channel-page .shadow-red-950\/30 {
    --tw-shadow-color: var(--yhome-glow);
    --tw-shadow: var(--tw-shadow-colored);
}

body.yhome-channel-page .ring-red-500\/30 {
    --tw-ring-color: color-mix(in srgb, var(--yhome-primary) 30%, transparent);
}

body.yhome-channel-page .contents-table th,
body.yhome-channel-page .contents-table td,
body.yhome-channel-page .contents-table-wrap,
body.yhome-channel-page .playlist-card,
body.yhome-channel-page .video-card,
body.yhome-channel-page .metric-card,
body.yhome-channel-page .analysis-metric-group,
body.yhome-channel-page .analysis-metric-mini,
body.yhome-channel-page .analysis-hero-date,
body.yhome-channel-page .content-card,
body.yhome-channel-page .community-stat-card,
body.yhome-channel-page .community-comment-card,
body.yhome-channel-page .community-video-card,
body.yhome-channel-page .analysis-panel,
body.yhome-channel-page .analysis-summary-card,
body.yhome-channel-page .analysis-grid article,
body.yhome-channel-page .download-message,
body.yhome-channel-page .modal-comment-row,
body.yhome-channel-page .performance-score-row,
body.yhome-channel-page .community-filter,
body.yhome-channel-page .community-analysis-summary-card,
body.yhome-channel-page .content-modal-panel,
body.yhome-channel-page .performance-modal-panel,
body.yhome-channel-page .community-analysis-modal-panel {
    border-color: var(--yhome-border);
}

body.yhome-channel-page .progress-bar,
body.yhome-channel-page .performance-score-fill,
body.yhome-channel-page .score-vph .performance-score-fill,
body.yhome-channel-page .score-engagement .performance-score-fill,
body.yhome-channel-page .sentiment-row b.neutral {
    background: linear-gradient(90deg, var(--yhome-primary), var(--yhome-accent), var(--yhome-accent-two));
}

body.yhome-channel-page .performance-ring {
    background: conic-gradient(var(--yhome-primary) calc(var(--score) * 1%), rgba(255, 255, 255, 0.08) 0);
}

body.yhome-channel-page .sentiment-row b.negative {
    background: var(--yhome-accent);
}

body.yhome-channel-page .content-kind-long,
body.yhome-channel-page .content-kind-shorts,
body.yhome-channel-page .playlist-count-badge,
body.yhome-channel-page .modal-comment-badge.is-reply,
body.yhome-channel-page .performance-level-3,
body.yhome-channel-page .performance-level-5,
body.yhome-channel-page .keyword-cloud-word,
body.yhome-channel-page .download-message.is-info,
body.yhome-channel-page .download-message.is-success {
    color: var(--yhome-primary-muted);
}

body.yhome-channel-page .download-message.is-info,
body.yhome-channel-page .download-message.is-success,
body.yhome-channel-page .performance-level-4 {
    background: color-mix(in srgb, var(--yhome-accent-two) 16%, transparent);
    border-color: color-mix(in srgb, var(--yhome-accent-two) 28%, transparent);
    color: var(--yhome-primary-muted);
}

body.yhome-channel-page #yhomeAccountBtn,
body.yhome-channel-page #youtubeLink,
body.yhome-channel-page #refreshComments,
body.yhome-channel-page #filterForm button[type="submit"],
body.yhome-channel-page #modalYoutubeLink,
body.yhome-channel-page #reanalyzeComments {
    background: var(--yhome-primary);
    color: var(--yhome-on-primary);
    transition: transform 0.15s ease, box-shadow 0.15s ease, filter 0.15s ease;
}

body.yhome-channel-page #yhomeAccountBtn:hover,
body.yhome-channel-page #youtubeLink:hover,
body.yhome-channel-page #refreshComments:hover,
body.yhome-channel-page #filterForm button[type="submit"]:hover,
body.yhome-channel-page #modalYoutubeLink:hover,
body.yhome-channel-page #reanalyzeComments:hover {
    background: var(--yhome-primary-hover);
    color: var(--yhome-on-primary-hover);
    filter: none;
}

body.yhome-channel-page #channelTitle,
body.yhome-channel-page #performanceTitle,
body.yhome-channel-page #modalTitle,
body.yhome-channel-page #yhomeAccountSettingsTitle,
body.yhome-channel-page main h1,
body.yhome-channel-page main h2,
body.yhome-channel-page main h3,
body.yhome-channel-page .account-settings-card h3,
body.yhome-channel-page .analysis-panel h3,
body.yhome-channel-page .analysis-summary-card h3,
body.yhome-channel-page .analysis-grid h3 {
    color: var(--yhome-heading);
    text-shadow: 0 0 28px color-mix(in srgb, var(--yhome-primary) 24%, transparent);
}

body.yhome-channel-page .video-card,
body.yhome-channel-page .playlist-card,
body.yhome-channel-page .content-card,
body.yhome-channel-page .contents-table-wrap,
body.yhome-channel-page .community-comment-card,
body.yhome-channel-page .analysis-panel,
body.yhome-channel-page .analysis-metric-group,
body.yhome-channel-page .metric-card {
    background:
        linear-gradient(145deg, color-mix(in srgb, var(--yhome-primary) 10%, transparent), transparent 48%),
        var(--yhome-surface);
}

body.yhome-channel-page .metric-card strong,
body.yhome-channel-page .analysis-metric-mini strong,
body.yhome-channel-page .analysis-hero-date strong,
body.yhome-channel-page .analysis-rank-row strong {
    color: color-mix(in srgb, var(--yhome-accent-two) 34%, white);
}

body.yhome-channel-page .nav-link.is-active,
body.yhome-channel-page .filter-segment-btn.is-active {
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--yhome-primary-muted) 28%, transparent), 0 10px 28px var(--yhome-glow);
}

body.yhome-channel-page .content-quality,
body.yhome-channel-page .performance-chip,
body.yhome-channel-page .modal-pill {
    background: color-mix(in srgb, var(--yhome-accent) 14%, rgba(255, 255, 255, 0.06));
    color: color-mix(in srgb, var(--yhome-primary-muted) 42%, white);
}

body.yhome-channel-page .contents-table tr:hover td,
body.yhome-channel-page .analysis-rank-row:hover,
body.yhome-channel-page .modal-comment-row:hover {
    background: color-mix(in srgb, var(--yhome-primary) 9%, transparent);
}

body.yhome-channel-page .text-white,
body.yhome-channel-page .text-slate-50,
body.yhome-channel-page .contents-table th,
body.yhome-channel-page .contents-table th.sticky-col,
body.yhome-channel-page .sort-head,
body.yhome-channel-page .metric-card strong,
body.yhome-channel-page .community-stat-card strong,
body.yhome-channel-page .performance-ring strong,
body.yhome-channel-page .modal-comment-head strong,
body.yhome-channel-page .modal-extra-row strong,
body.yhome-channel-page .account-settings-card h3,
body.yhome-channel-page .account-settings-layout-value-text,
body.yhome-channel-page .account-settings-theme-option strong,
body.yhome-channel-page .playlist-card h2,
body.yhome-channel-page .video-card h3,
body.yhome-channel-page .content-card h3,
body.yhome-channel-page .contents-title {
    color: var(--yhome-heading);
}

body.yhome-channel-page .text-slate-100,
body.yhome-channel-page .text-slate-200,
body.yhome-channel-page .text-slate-300,
body.yhome-channel-page .contents-table,
body.yhome-channel-page .contents-table td,
body.yhome-channel-page .analysis-rank-row,
body.yhome-channel-page .modal-comment-text,
body.yhome-channel-page .community-comment-text,
body.yhome-channel-page .performance-score-head strong,
body.yhome-channel-page .download-message,
body.yhome-channel-page .playlist-layer-item {
    color: var(--yhome-text);
}

body.yhome-channel-page .text-slate-400,
body.yhome-channel-page .text-slate-500,
body.yhome-channel-page .text-slate-600,
body.yhome-channel-page .metric-card span,
body.yhome-channel-page .analysis-metric-mini span,
body.yhome-channel-page .analysis-hero-date span,
body.yhome-channel-page .video-card p,
body.yhome-channel-page .playlist-card p,
body.yhome-channel-page .account-settings-theme-option em,
body.yhome-channel-page .performance-score-head span,
body.yhome-channel-page .performance-score-value,
body.yhome-channel-page .performance-chip span,
body.yhome-channel-page .progress-summary,
body.yhome-channel-page .progress-steps li,
body.yhome-channel-page .modal-extra-row span,
body.yhome-channel-page .modal-comment-head,
body.yhome-channel-page .community-author-row,
body.yhome-channel-page .community-comment-date,
body.yhome-channel-page .community-comment-like,
body.yhome-channel-page .community-stat-card p,
body.yhome-channel-page .contents-meta,
body.yhome-channel-page .contents-sub {
    color: var(--yhome-muted);
}

body.yhome-channel-page .text-red-100,
body.yhome-channel-page .text-red-200,
body.yhome-channel-page .text-red-300,
body.yhome-channel-page .text-red-400,
body.yhome-channel-page .hover\:text-red-100:hover,
body.yhome-channel-page .contents-comment-link,
body.yhome-channel-page .contents-meta .contents-source-handle,
body.yhome-channel-page #channelHandle,
body.yhome-channel-page #modalMeta,
body.yhome-channel-page #performanceMeta,
body.yhome-channel-page #apiProgressEyebrow,
body.yhome-channel-page .community-analysis-summary-card span {
    color: var(--yhome-primary-muted);
}

/* 커뮤니티 분위기 요약 카드: 밝은 테마에서 고정 밝은색 글자가 배경과 겹치지 않도록 */
body.yhome-channel-page .community-analysis-mini-card p {
    color: var(--yhome-text);
}

body.yhome-channel-page .community-analysis-summary-card .sentiment-row {
    color: var(--yhome-muted);
}

body.yhome-channel-page .community-analysis-summary-card .sentiment-row strong {
    color: var(--yhome-heading);
}

body.yhome-channel-page .community-analysis-summary-card em {
    color: var(--yhome-dim);
}

body.yhome-channel-page .community-analysis-summary-card .sentiment-row div {
    background: color-mix(in srgb, var(--yhome-heading) 12%, transparent);
}

body.yhome-channel-page .community-analysis-modal-panel .sentiment-row {
    color: var(--yhome-muted);
}

body.yhome-channel-page .community-analysis-modal-panel .sentiment-row strong {
    color: var(--yhome-heading);
}

body.yhome-channel-page .community-analysis-modal-panel .sentiment-row div {
    background: color-mix(in srgb, var(--yhome-heading) 12%, transparent);
}

/* 커뮤니티 통계 카드: 밝은 테마에서 숫자·아이콘 대비 */
body.yhome-channel-page .community-stat-icon {
    color: var(--yhome-primary);
}

body.yhome-channel-page .bg-white\/\[0\.04\],
body.yhome-channel-page .bg-white\/\[0\.05\],
body.yhome-channel-page .bg-white\/\[0\.06\],
body.yhome-channel-page .bg-white\/\[0\.08\],
body.yhome-channel-page .bg-slate-950\/55,
body.yhome-channel-page .modal-comment-row,
body.yhome-channel-page .performance-score-row,
body.yhome-channel-page .analysis-summary-card,
body.yhome-channel-page .analysis-grid article {
    background: var(--yhome-surface-soft);
}

body.yhome-channel-page .border-white\/10,
body.yhome-channel-page .border-white\/15,
body.yhome-channel-page .border-white\/20,
body.yhome-channel-page .contents-table th,
body.yhome-channel-page .contents-table td {
    border-color: var(--yhome-border);
}

body.yhome-channel-page .bg-red-500,
body.yhome-channel-page .bg-red-600,
body.yhome-channel-page .filter-segment-btn.is-active,
body.yhome-channel-page .pager-btn.is-active,
body.yhome-channel-page .pager-btn:hover:not(:disabled),
body.yhome-channel-page #youtubeLink,
body.yhome-channel-page #refreshComments,
body.yhome-channel-page #filterForm button[type="submit"],
body.yhome-channel-page #modalYoutubeLink,
body.yhome-channel-page #reanalyzeComments,
body.yhome-channel-page #yhomeAccountBtn {
    color: var(--yhome-on-primary);
}

body.yhome-channel-page .content-quality,
body.yhome-channel-page .content-kind,
body.yhome-channel-page .content-kind-long,
body.yhome-channel-page .content-kind-shorts,
body.yhome-channel-page .content-duration,
body.yhome-channel-page .performance-badge,
body.yhome-channel-page .playlist-count-badge,
body.yhome-channel-page .modal-pill,
body.yhome-channel-page .keyword-cloud-word {
    color: color-mix(in srgb, var(--yhome-primary-muted) 58%, var(--yhome-heading));
}

body.yhome-channel-page .hover\:text-white:hover,
body.yhome-channel-page .hover\:text-red-100:hover,
body.yhome-channel-page .contents-title:hover,
body.yhome-channel-page .community-author-link:hover,
body.yhome-channel-page .modal-playlist-row a:hover,
body.yhome-channel-page .contents-comment-link:hover,
body.yhome-channel-page .contents-meta .contents-source-handle:hover,
body.yhome-channel-page #introduce a:hover,
body.yhome-channel-page #modalCommentsLink:hover {
    color: var(--yhome-primary-muted);
}

body.yhome-channel-page .hover\:bg-white\/10:hover,
body.yhome-channel-page .hover\:bg-slate-950\/75:hover,
body.yhome-channel-page #modalClose:hover,
body.yhome-channel-page #performanceClose:hover,
body.yhome-channel-page button[data-close-analysis]:hover,
body.yhome-channel-page .account-settings-close:hover,
body.yhome-channel-page #yhomeAccountSettingsOpen:hover,
body.yhome-channel-page #yhomeHeaderLogout:hover {
    background: color-mix(in srgb, var(--yhome-primary) 12%, transparent);
    color: var(--yhome-heading);
}

body.yhome-channel-page .bg-red-500:hover,
body.yhome-channel-page .bg-red-600:hover,
body.yhome-channel-page .hover\:bg-red-500:hover,
body.yhome-channel-page #youtubeLink:hover,
body.yhome-channel-page #refreshComments:hover,
body.yhome-channel-page #filterForm button[type="submit"]:hover,
body.yhome-channel-page #modalYoutubeLink:hover,
body.yhome-channel-page #reanalyzeComments:hover,
body.yhome-channel-page #yhomeAccountBtn:hover {
    color: var(--yhome-on-primary);
}

body.yhome-channel-page #refreshChannel {
    background: var(--yhome-primary);
    color: var(--yhome-on-primary);
    border-color: color-mix(in srgb, var(--yhome-on-primary) 35%, transparent);
}

body.yhome-channel-page #refreshChannel:hover {
    background: var(--yhome-primary-hover);
    color: var(--yhome-on-primary-hover);
}

body.yhome-channel-page #favoriteChannel.is-favorite,
body.yhome-channel-page #favoriteChannel.is-owner {
    background: var(--yhome-primary);
    color: var(--yhome-on-primary);
    border-color: color-mix(in srgb, var(--yhome-on-primary) 35%, transparent);
}

body.yhome-channel-page #favoriteChannel.is-favorite:hover,
body.yhome-channel-page #favoriteChannel.is-owner:hover {
    background: var(--yhome-primary-hover);
    color: var(--yhome-on-primary-hover);
}

/* Lucide가 <i>를 <svg>로 바꾸므로, 토글 시 별은 CSS로 채움 */
body.yhome-channel-page #favoriteChannel svg {
    color: currentColor;
    stroke: currentColor;
    fill: none;
    stroke-width: 2.25;
}

body.yhome-channel-page #favoriteChannel.is-favorite svg,
body.yhome-channel-page #favoriteChannel.is-favorite svg path,
body.yhome-channel-page #favoriteChannel.is-owner svg,
body.yhome-channel-page #favoriteChannel.is-owner svg path {
    fill: currentColor;
    stroke: none;
}

body.yhome-channel-page #refreshChannel svg {
    color: currentColor;
    stroke: currentColor;
    fill: none;
    stroke-width: 2.25;
}

body.yhome-channel-page .content-modal-youtube-btn svg,
body.yhome-channel-page #youtubeLink svg,
body.yhome-channel-page #refreshComments svg,
body.yhome-channel-page #filterForm button[type="submit"] svg,
body.yhome-channel-page #reanalyzeComments svg {
    color: currentColor;
    fill: currentColor;
}

body.yhome-channel-page #modalClose svg,
body.yhome-channel-page #performanceClose svg,
body.yhome-channel-page [data-close-analysis] svg,
body.yhome-channel-page .account-settings-close svg,
body.yhome-channel-page #yhomeAccountSettingsOpen svg,
body.yhome-channel-page #yhomeHeaderLogout svg {
    color: currentColor;
}

body.yhome-channel-page button svg,
body.yhome-channel-page a svg {
    pointer-events: none;
    transition: none;
}

body.yhome-channel-page #yhomeAccountBtn *,
body.yhome-channel-page #youtubeLink *,
body.yhome-channel-page #refreshComments *,
body.yhome-channel-page #filterForm button[type="submit"] *,
body.yhome-channel-page #modalYoutubeLink *,
body.yhome-channel-page #reanalyzeComments * {
    color: inherit;
    transition: none;
}

body.yhome-channel-page #yhomeAccountBtn svg,
body.yhome-channel-page #youtubeLink svg,
body.yhome-channel-page #refreshComments svg,
body.yhome-channel-page #filterForm button[type="submit"] svg,
body.yhome-channel-page #modalYoutubeLink svg,
body.yhome-channel-page #reanalyzeComments svg {
    color: inherit;
    fill: none;
    stroke: currentColor;
}

body.yhome-channel-page #youtubeLink svg.fill-white {
    fill: currentColor;
}

body.yhome-channel-page header > div > a {
    color: var(--yhome-heading);
}

body.yhome-channel-page .nav-link,
body.yhome-channel-page .contents-table,
body.yhome-channel-page .contents-table td,
body.yhome-channel-page .analysis-summary-card p,
body.yhome-channel-page .analysis-grid li,
body.yhome-channel-page .community-comment-text,
body.yhome-channel-page .modal-comment-text,
body.yhome-channel-page .modal-extra-row strong,
body.yhome-channel-page .contents-title,
body.yhome-channel-page .community-author-link,
body.yhome-channel-page .account-settings-panel .text-white,
body.yhome-channel-page .content-modal-panel .text-white,
body.yhome-channel-page .performance-modal-panel .text-white,
body.yhome-channel-page .community-analysis-modal-panel .text-white {
    color: var(--yhome-text);
}

body.yhome-channel-page .text-slate-300,
body.yhome-channel-page .text-slate-400,
body.yhome-channel-page .text-slate-500,
body.yhome-channel-page .text-slate-600,
body.yhome-channel-page .contents-meta,
body.yhome-channel-page .contents-sub,
body.yhome-channel-page .modal-extra-row span,
body.yhome-channel-page .modal-comment-head,
body.yhome-channel-page .community-author-row,
body.yhome-channel-page .community-comment-date,
body.yhome-channel-page .community-comment-like,
body.yhome-channel-page .community-parent-preview p,
body.yhome-channel-page .account-settings-card p,
body.yhome-channel-page .account-settings-design-row-label,
body.yhome-channel-page .account-settings-theme-option em,
body.yhome-channel-page .progress-summary,
body.yhome-channel-page .progress-steps li {
    color: var(--yhome-muted);
}

body.yhome-channel-page .metric-card span,
body.yhome-channel-page .analysis-metric-mini span,
body.yhome-channel-page .analysis-hero-date span,
body.yhome-channel-page .community-stat-card span,
body.yhome-channel-page .community-stat-card p,
body.yhome-channel-page .performance-ring span,
body.yhome-channel-page .performance-score-head span,
body.yhome-channel-page .performance-score-value,
body.yhome-channel-page .performance-chip span {
    color: var(--yhome-dim);
}

body.yhome-channel-page .bg-red-500,
body.yhome-channel-page .bg-red-600,
body.yhome-channel-page #refreshChannel,
body.yhome-channel-page #modalYoutubeLink,
body.yhome-channel-page #reanalyzeComments,
body.yhome-channel-page #youtubeLink,
body.yhome-channel-page #refreshComments,
body.yhome-channel-page #filterForm button[type="submit"],
body.yhome-channel-page .filter-segment-btn.is-active,
body.yhome-channel-page .pager-btn.is-active,
body.yhome-channel-page .pager-btn:hover:not(:disabled) {
    color: var(--yhome-on-primary);
}

body.yhome-channel-page #filterTypeGroup.filter-segment {
    gap: 0.2rem;
    border-color: color-mix(in srgb, var(--yhome-primary-muted) 22%, transparent);
    border-radius: 9999px;
    background: color-mix(in srgb, var(--yhome-primary) 7%, var(--yhome-surface-soft));
    padding: 0.2rem;
    box-shadow: inset 0 1px 0 color-mix(in srgb, white 12%, transparent);
}

body.yhome-channel-page #filterTypeGroup .filter-segment-btn {
    min-height: 2.25rem;
    border-radius: 9999px;
    color: var(--yhome-muted);
    font-weight: 950;
    letter-spacing: -0.01em;
    transition: background 0.16s ease, color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease;
}

body.yhome-channel-page #filterTypeGroup .filter-segment-btn:hover:not(.is-active) {
    background: color-mix(in srgb, var(--yhome-primary) 12%, transparent);
    color: var(--yhome-heading);
}

body.yhome-channel-page #filterTypeGroup .filter-segment-btn.is-active {
    background: var(--yhome-primary);
    color: var(--yhome-on-primary);
    box-shadow: 0 0.55rem 1.25rem color-mix(in srgb, var(--yhome-primary) 22%, transparent);
}

@media (max-width: 1023px) {
    body.yhome-channel-page #filterTypeGroup.filter-segment {
        gap: 0.18rem;
        padding: 0.18rem;
    }

    body.yhome-channel-page #filterTypeGroup .filter-segment-btn {
        min-height: 2.35rem;
        font-size: 0.84rem;
    }
}

body.yhome-channel-page .analysis-metric-mini strong,
body.yhome-channel-page .analysis-hero-date strong {
    color: color-mix(in srgb, var(--yhome-primary-muted) 46%, var(--yhome-heading));
    text-shadow: none;
}

/* 계정 설정·테마·레이아웃 팝업: 밝은 채널 테마에서 고정 밝은색 글자/버튼 대비 */
body.yhome-channel-page .account-settings-close {
    border-color: var(--yhome-border);
    color: var(--yhome-muted);
}

body.yhome-channel-page .account-settings-action-btn {
    background: var(--yhome-surface-soft);
    color: var(--yhome-heading);
}

body.yhome-channel-page .account-settings-action-btn:hover {
    background: var(--yhome-primary-soft);
    color: var(--yhome-heading);
}

body.yhome-channel-page .account-settings-empty {
    background: color-mix(in srgb, var(--yhome-heading) 6%, transparent);
    color: var(--yhome-muted);
}

body.yhome-channel-page .account-settings-channel-card {
    border-color: var(--yhome-border);
    background: var(--yhome-surface-soft);
}

body.yhome-channel-page .account-settings-channel-card:hover {
    border-color: color-mix(in srgb, var(--yhome-primary) 44%, transparent);
    background: var(--yhome-primary-soft);
}

body.yhome-channel-page .account-settings-channel-card--static:hover {
    border-color: var(--yhome-border);
    background: var(--yhome-surface-soft);
}

body.yhome-channel-page .account-settings-channel-card-thumb {
    background: color-mix(in srgb, var(--yhome-heading) 8%, var(--yhome-border));
}

body.yhome-channel-page .account-settings-channel-card-thumb--empty {
    color: var(--yhome-muted);
}

body.yhome-channel-page .account-settings-channel-card-title {
    color: var(--yhome-heading);
}

body.yhome-channel-page .account-settings-channel-card-handle {
    color: var(--yhome-muted);
}

body.yhome-channel-page .account-settings-channel-card-subs {
    color: var(--yhome-muted);
}

body.yhome-channel-page .account-settings-url-row input {
    border-color: var(--yhome-border);
    background: var(--yhome-surface-soft);
    color: var(--yhome-text);
}

body.yhome-channel-page .account-settings-layout-value-btn {
    border-color: color-mix(in srgb, var(--yhome-primary-muted) 34%, transparent);
    background: var(--yhome-surface-soft);
    color: var(--yhome-muted);
}

body.yhome-channel-page .account-settings-layout-value-btn:hover {
    border-color: color-mix(in srgb, var(--yhome-primary) 44%, transparent);
    background: var(--yhome-primary-soft);
    color: var(--yhome-heading);
}

body.yhome-channel-page .account-settings-layout-value-icon {
    background: var(--yhome-primary-soft);
    color: var(--yhome-primary-muted);
}

body.yhome-channel-page .theme-option-swatches--value-btn {
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--yhome-primary-muted) 28%, transparent);
}

body.yhome-channel-page .account-settings-design-row + .account-settings-design-row {
    border-top: 1px solid var(--yhome-border);
}

/* 진행 팝업: 밝은 테마에서 트랙·퍼센트 배지·단계 번호 대비 (일부 규칙은 파일 하단에 두어 기존 .progress-steps li 색 덮어씀) */
body.yhome-channel-page .progress-modal {
    background: color-mix(in srgb, var(--yhome-bg) 58%, rgba(15, 23, 42, 0.62));
}

body.yhome-channel-page .progress-track {
    background: color-mix(in srgb, var(--yhome-heading) 7%, var(--yhome-border));
}

body.yhome-channel-page .progress-badge {
    background: color-mix(in srgb, var(--yhome-primary) 20%, var(--yhome-surface-soft));
    color: var(--yhome-primary);
}

body.yhome-channel-page .progress-steps span {
    background: color-mix(in srgb, var(--yhome-primary) 14%, var(--yhome-surface-soft));
    color: var(--yhome-heading);
}

body.yhome-channel-page .progress-steps li.is-active {
    color: var(--yhome-heading);
    font-weight: 800;
}

body.yhome-channel-page .progress-steps li.is-active span {
    color: var(--yhome-on-primary);
}

body.yhome-channel-page .progress-steps li.is-done {
    color: var(--yhome-muted);
}

body.yhome-channel-page.yhome-theme-lavender .progress-steps li.is-done span,
body.yhome-channel-page.yhome-theme-lavender .progress-modal.is-complete .progress-badge,
body.yhome-channel-page.yhome-theme-honey .progress-steps li.is-done span,
body.yhome-channel-page.yhome-theme-honey .progress-modal.is-complete .progress-badge,
body.yhome-channel-page.yhome-theme-mint .progress-steps li.is-done span,
body.yhome-channel-page.yhome-theme-mint .progress-modal.is-complete .progress-badge,
body.yhome-channel-page.yhome-theme-mono .progress-steps li.is-done span,
body.yhome-channel-page.yhome-theme-mono .progress-modal.is-complete .progress-badge {
    background: color-mix(in srgb, rgb(34, 197, 94) 26%, var(--yhome-surface-soft));
    color: rgb(20, 83, 45);
}

body.yhome-channel-page .progress-modal.is-error .progress-badge {
    background: color-mix(in srgb, var(--yhome-primary) 24%, var(--yhome-surface-soft));
    color: var(--yhome-primary-hover);
}

/* Channel home hero: YouTube CTA uses brand red (not channel theme) */
body.yhome-channel-page.yhome-channel-home #youtubeLink {
    border: 1px solid rgba(0, 0, 0, 0.2);
    background: #ff0000;
    color: #fff;
    box-shadow: 0 10px 28px rgba(180, 0, 0, 0.55);
}

body.yhome-channel-page.yhome-channel-home #youtubeLink:hover {
    background: #e62117;
    color: #fff;
    border-color: rgba(0, 0, 0, 0.28);
    filter: none;
}

body.yhome-channel-page.yhome-channel-home #youtubeLink *,
body.yhome-channel-page.yhome-channel-home #youtubeLink:hover * {
    color: #fff;
}

body.yhome-channel-page.yhome-channel-home #youtubeLink .home-youtube-cta-icon {
    background: rgba(255, 255, 255, 0.22);
}

body.yhome-channel-page.yhome-channel-home #youtubeLink svg {
    color: #fff;
    stroke: #fff;
    fill: currentColor;
}

/* 채널 홈·커뮤니티: 자동 백그라운드 동기화 하단 레이어 */
#yhomeHomeSyncLayer .yhome-home-sync-track,
#yhomeCommunitySyncLayer .yhome-home-sync-track {
    height: 0.35rem;
    margin-top: 0.4rem;
}

#yhomeHomeSyncLayer .progress-track,
#yhomeCommunitySyncLayer .progress-track {
    background: color-mix(in srgb, var(--yhome-heading) 7%, var(--yhome-border));
}

/* Cookie consent slide-up (`inc_cookie_consent.php`, `assets/cookie_consent.js`) */
@media (prefers-reduced-motion: reduce) {
    #yhomeCookieConsent {
        transition-duration: 0.01ms !important;
    }
}
