/* home.css: 홈 화면 전용 스타일 */

/* ——— 홈(아카이브형) 전용 ——— */
body.darkthread-home {
    --dt-home-bg: #030303;
    --dt-home-card: #090909;
    --dt-home-card-strong: #111;
    --dt-home-line: rgba(148, 163, 184, 0.12);
    --dt-home-line-hover: rgba(148, 163, 184, 0.24);
    color: var(--dt-home-text);
    /* 셸 내 세션 간 세로 리듬(히어로 ↔ 공지/인기 ↔ 게시판 ↔ 최근) */
    --darkthread-home-shell-section-gap: clamp(18px, 4vw, 28px);
    /* 카드·게시판·최근 기록: 제목(헤더) 아래 본문까지 간격 통일 */
    --darkthread-home-section-head-gap: 16px;
    /* 추천·자유게시판: 5건(피처+4행) 기준 동일 고정 높이(본문 폰트 확대에 맞춤) */
    --dt-home-spotlight-card-height: clamp(466px, 42.5vh, 500px);
    /* 홈 패널(히어로·공지·추천·자유게시판·게시판 카드) — 다크: 반투명 글래스 기본 */
    --dt-home-panel-radius: 20px;
    --dt-home-panel-border-color: rgba(148, 163, 184, 0.12);
    --dt-home-panel-border: 1px solid var(--dt-home-panel-border-color);
    --dt-home-panel-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.03),
        inset 0 -1px 0 rgba(255, 255, 255, 0.03);
    --dt-home-panel-backdrop: blur(10px) saturate(118%);
    --dt-home-panel-bg-color: rgba(8, 10, 14, 0.52);
    --dt-home-panel-bg-overlay: none;
    --dt-home-panel-bg-image-layer: none;
    /* 패널 내부 칩(피처·랭크·공지 행·상태 카드·최근 카드) */
    --dt-home-chip-bg: rgba(0, 0, 0, 0.22);
    --dt-home-chip-bg-hover: rgba(0, 0, 0, 0.32);
    --dt-home-chip-border-color: var(--dt-home-line);
    --dt-home-chip-border: 1px solid var(--dt-home-chip-border-color);
    /* 히어로 상태·공지·추천·자유게시판·스와이퍼 행 — 배경 비치는 글래스 칩 */
    --dt-home-glass-surface-bg: rgba(8, 10, 14, 0.28);
    --dt-home-glass-surface-bg-hover: rgba(8, 10, 14, 0.42);
    --dt-home-glass-surface-border: rgba(148, 163, 184, 0.14);
    --dt-home-glass-surface-border-hover: rgba(148, 163, 184, 0.24);
    --dt-home-hero-orb-border: rgba(255, 255, 255, 0.12);
    --dt-home-hero-orb-glow: rgba(138, 180, 210, 0.2);
    --dt-home-hero-orb-shadow: rgba(0, 0, 0, 0.72);
    overflow-x: clip;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home {
    --dt-home-bg: #ffffff;
    --dt-home-card: #ffffff;
    --dt-home-card-strong: #f8fafc;
    --dt-home-line: rgba(15, 23, 42, 0.1);
    --dt-home-line-hover: rgba(15, 23, 42, 0.2);
    --dt-home-panel-border-color: #e5e7eb;
    --dt-home-panel-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
    --dt-home-panel-backdrop: blur(12px) saturate(118%);
    --dt-home-panel-bg-color: rgba(255, 255, 255, 0.38);
    --dt-home-panel-bg-overlay: none;
    --dt-home-panel-bg-image-layer: none;
    --dt-home-chip-bg: rgba(255, 255, 255, 0.32);
    --dt-home-chip-bg-hover: rgba(255, 255, 255, 0.48);
    --dt-home-chip-border-color: rgba(15, 23, 42, 0.1);
    --dt-home-glass-surface-bg: rgba(255, 255, 255, 0.36);
    --dt-home-glass-surface-bg-hover: rgba(255, 255, 255, 0.5);
    --dt-home-glass-surface-border: rgba(15, 23, 42, 0.1);
    --dt-home-glass-surface-border-hover: rgba(15, 23, 42, 0.18);
    --dt-home-hero-orb-border: rgba(15, 23, 42, 0.06);
    --dt-home-hero-orb-glow: rgba(96, 165, 250, 0.1);
    --dt-home-hero-orb-shadow: rgba(15, 23, 42, 0.13);
    color: var(--dt-home-text);
}

html.darkthread-board-list-v2-theme-light body.darkthread-home:not(.darkthread-main-bg) {
    background: #ffffff;
}

/* 홈 패널 표면 — 외곽 카드 공통(배경은 토큰만, 컴포넌트별 !important 금지) */
.darkthread-home-hero,
.darkthread-home-card,
.darkthread-home-board-card {
    border-radius: var(--dt-home-panel-radius);
    border: var(--dt-home-panel-border);
    box-shadow: var(--dt-home-panel-shadow);
    backdrop-filter: var(--dt-home-panel-backdrop);
    -webkit-backdrop-filter: var(--dt-home-panel-backdrop);
    background:
        var(--dt-home-panel-bg-overlay),
        var(--dt-home-panel-bg-image-layer),
        var(--dt-home-panel-bg-color);
}

.darkthread-home-board-card:hover {
    --dt-home-panel-border-color: var(--dt-home-line-hover);
    --dt-home-panel-bg-color: var(--dt-home-chip-bg-hover);
}

/* 홈 패널 내부 칩 — 추천·자유게시판·공지 행·히어로 상태 카드·최근 기록 */
.darkthread-home-feature,
.darkthread-home-rankrow,
.darkthread-home-notice-item,
.darkthread-home-status-card,
.darkthread-home-recent-card {
    border: var(--dt-home-chip-border);
    background: var(--dt-home-chip-bg);
    transition:
        background 0.14s ease,
        border-color 0.14s ease,
        transform 0.14s ease,
        box-shadow 0.14s ease;
}

.darkthread-home-feature:hover,
.darkthread-home-rankrow:hover,
.darkthread-home-notice-item:hover,
.darkthread-home-status-card:hover,
.darkthread-home-recent-card:hover {
    background: var(--dt-home-chip-bg-hover);
    border-color: var(--dt-home-line-hover);
}

/* 다크 전용: 히어로·공지·추천 배경 이미지(라이트는 글래스 패널만) */
html:not(.darkthread-board-list-v2-theme-light) body.darkthread-home .darkthread-home-hero,
body.darkthread-home:not(.darkthread-board-list-v2-theme-light) .darkthread-home-hero {
    --dt-home-panel-bg-overlay: linear-gradient(180deg, rgba(5, 8, 14, 0.08) 0%, rgba(5, 8, 14, 0.2) 58%, rgba(4, 6, 11, 0.34) 100%);
    --dt-home-panel-bg-image-layer: var(--dt-home-hero-image) var(--dt-home-hero-image-position, center center) / var(--dt-home-hero-image-size, cover) no-repeat;
    --dt-home-panel-bg-color: linear-gradient(180deg, #090909 0%, #030303 48%, #050505 100%);
    --dt-home-panel-backdrop: none;
}

html:not(.darkthread-board-list-v2-theme-light) body.darkthread-home .darkthread-home-notice,
body.darkthread-home:not(.darkthread-board-list-v2-theme-light) .darkthread-home-notice {
    --dt-home-panel-bg-overlay: linear-gradient(180deg, rgba(5, 7, 12, 0.58), rgba(5, 7, 12, 0.74));
    --dt-home-panel-bg-image-layer: url("../image/bg/Notice.jpg") center / cover no-repeat;
    --dt-home-panel-backdrop: none;
}

html:not(.darkthread-board-list-v2-theme-light) body.darkthread-home .darkthread-home-popular,
body.darkthread-home:not(.darkthread-board-list-v2-theme-light) .darkthread-home-popular {
    --dt-home-panel-bg-overlay: linear-gradient(180deg, rgba(5, 7, 12, 0.56), rgba(5, 7, 12, 0.76));
    --dt-home-panel-bg-image-layer: url("../image/bg/Recommend.jpg") center / cover no-repeat;
    --dt-home-panel-backdrop: none;
}

/* 홈 스킵: «메인 소개»·«공지사항» 상단 앵커 — 고정 헤더에 가리지 않도록 */
body.darkthread-home #darkthread-home-scroll-top {
    scroll-margin-top: clamp(3.5rem, 10vh, 5.5rem);
}

body.darkthread-home #darkthread-main,
body.darkthread-home #darkthread-highlights,
body.darkthread-home #darkthread-content {
    position: relative;
    z-index: 3;
    overflow-x: clip;
}

/* V2 검색 툴바 sticky: clip 이 조상에 있으면 따라오지 않음 → board/list 와 동일 처리 */
body.darkthread-home.darkthread-home-v2-toolbar #darkthread-main,
body.darkthread-home.darkthread-home-v2-toolbar #darkthread-highlights,
body.darkthread-home.darkthread-home-v2-toolbar #darkthread-content {
    overflow-x: visible;
    overflow-y: visible;
}

/* 홈: 기본 레이아웃(main·highlights) 패딩이 셸 패딩과 겹쳐 모바일에서 과도하게 좁아지는 것 방지 */
@media (max-width: 768px) {
    body.darkthread-home {
        --darkthread-home-shell-section-gap: clamp(16px, 3.2vw, 22px);
    }

    body.darkthread-home:not(.darkthread-home-v2-toolbar) #darkthread-main {
        padding-top: 1rem;
        padding-bottom: 1rem;
        padding-left: max(0.35rem, env(safe-area-inset-left, 0px));
        padding-right: max(0.35rem, env(safe-area-inset-right, 0px));
    }

    body.darkthread-home:not(.darkthread-home-v2-toolbar) #darkthread-highlights {
        padding-left: 0;
        padding-right: 0;
    }

    body.darkthread-home #darkthread-content {
        min-width: 0;
    }

    .darkthread-home-shell {
        padding: 12px 8px;
    }

    .darkthread-home-hero {
        min-height: 0;
        border-radius: 16px;
    }

    .darkthread-home-hero-grid {
        padding: 14px 12px;
        gap: 18px;
    }

    .darkthread-home-hero-title {
        font-size: clamp(1.32rem, 5.2vw, 1.85rem);
    }

    .darkthread-home-hero-sub {
        font-size: 0.9rem;
        line-height: 1.65;
    }

    .darkthread-home-hero-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .darkthread-home-btn {
        width: 100%;
        justify-content: center;
    }
}

.darkthread-home-shell {
    position: relative;
    z-index: 4;
    box-sizing: border-box;
    width: 100%;
    /* 가로형 애드핏 728×2 + gap(20) + 좌우 padding(24×2) */
    max-width: 1540px;
    margin: 0 auto;
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: var(--darkthread-home-shell-section-gap, 28px);
    color: var(--dt-home-text);
    opacity: 1;
    visibility: visible;
    overflow-x: clip;
}

@media (max-width: 520px) {
    body.darkthread-home {
        --darkthread-home-shell-section-gap: 16px;
    }

    body.darkthread-home:not(.darkthread-home-v2-toolbar) #darkthread-main {
        padding-left: max(0.25rem, env(safe-area-inset-left, 0px));
        padding-right: max(0.25rem, env(safe-area-inset-right, 0px));
    }

    .darkthread-home-shell {
        padding: 10px 6px;
    }

    .darkthread-home-card {
        padding: 16px 12px;
    }

    .darkthread-home-hero-grid {
        padding: 12px 10px;
        gap: 14px;
    }
}

.darkthread-home-shell::before {
    content: '';
    position: absolute;
    inset: -6px -8px;
    opacity: 0.04;
    pointer-events: none;
    z-index: -1;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    background-size: 180px 180px;
}

@supports not (overflow: clip) {
    body.darkthread-home #darkthread-main,
    body.darkthread-home #darkthread-highlights,
    body.darkthread-home #darkthread-content,
    .darkthread-home-shell {
        overflow-x: hidden;
    }
}

.darkthread-home-hero {
    position: relative;
    overflow: hidden;
    min-height: 360px;
    border-color: var(--dt-home-hero-orb-border);
    transform: translateZ(0);
    --dt-home-hero-image-position: center center;
    --dt-home-hero-image-size: cover;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.12),
        inset 0 -24px 46px rgba(0, 0, 0, 0.28),
        inset 18px 0 48px rgba(255, 255, 255, 0.025),
        inset -22px -18px 52px rgba(0, 0, 0, 0.24),
        0 18px 38px -18px var(--dt-home-hero-orb-shadow),
        0 42px 90px -48px var(--dt-home-hero-orb-glow);
}

.darkthread-home-hero::before {
    content: '';
    position: absolute;
    inset: 3px;
    z-index: 1;
    pointer-events: none;
    border-radius: inherit;
    background:
        radial-gradient(115% 82% at 50% -18%, rgba(255, 255, 255, 0.34) 0%, rgba(255, 255, 255, 0.12) 24%, rgba(255, 255, 255, 0.035) 48%, transparent 68%),
        radial-gradient(78% 90% at 6% 8%, rgba(255, 255, 255, 0.16) 0%, rgba(255, 255, 255, 0.055) 30%, transparent 58%),
        radial-gradient(80% 100% at 96% 94%, rgba(0, 0, 0, 0.36) 0%, rgba(0, 0, 0, 0.12) 35%, transparent 66%),
        linear-gradient(135deg, rgba(255, 255, 255, 0.12) 0%, transparent 18%, transparent 74%, rgba(255, 255, 255, 0.04) 100%);
    mix-blend-mode: screen;
    opacity: 0.48;
}

.darkthread-home-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    opacity: 0.02;
    pointer-events: none;
    z-index: 1;
    background:
        radial-gradient(70% 55% at 50% 18%, rgba(255, 255, 255, 0.1), transparent 62%),
        url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    background-size: auto, 160px 160px;
    mix-blend-mode: overlay;
}

.darkthread-home-hero-grid {
    position: relative;
    z-index: 2;
    display: grid;
    gap: 24px;
    padding: 24px;
    align-items: stretch;
}

@media (min-width: 960px) {
    .darkthread-home-hero-grid {
        grid-template-columns: minmax(0, 2.05fr) minmax(0, 1fr);
        gap: 28px;
    }
}

/* 추천·자유게시판 2열 행 안 띠배너 — 한 칸에 갇히지 않게 전체 폭 */
.darkthread-home-row--spotlight > .darkthread-kakao-strip-ad,
.darkthread-home-row--spotlight > .darkthread-home-strip-ad {
    grid-column: 1 / -1;
    width: 100%;
    min-width: 0;
}

.darkthread-home-hero-main {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 14px;
    min-height: 280px;
}

.darkthread-home-hero-label {
    margin: 0;
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--dt-home-muted);
}

.darkthread-home-hero-title {
    margin: 0;
    font-size: clamp(1.55rem, 2.4vw, 2.15rem);
    font-weight: 650;
    line-height: 1.28;
    letter-spacing: -0.03em;
    color: #eef1f6;
}

.darkthread-home-hero-sub {
    margin: 0;
    max-width: 38rem;
    font-size: 0.95rem;
    line-height: 1.75;
    color: var(--dt-home-muted);
}

.darkthread-home-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 8px;
}

.darkthread-home-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 11px 18px;
    border-radius: 12px;
    font-size: 0.88rem;
    font-weight: 600;
    text-decoration: none;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: transparent;
    backdrop-filter: blur(8px) saturate(118%);
    -webkit-backdrop-filter: blur(8px) saturate(118%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.16),
        inset 0 -1px 0 rgba(255, 255, 255, 0.03),
        0 8px 20px rgba(0, 0, 0, 0.12);
    transition:
        background-color 0.14s ease,
        border-color 0.14s ease,
        box-shadow 0.14s ease,
        color 0.14s ease,
        transform 0.14s ease;
}

.darkthread-home-btn--primary {
    border-color: rgba(138, 180, 210, 0.28);
    color: #e9f2fc;
}

.darkthread-home-btn--primary:hover {
    background: rgba(138, 180, 210, 0.07);
    border-color: rgba(166, 200, 225, 0.36);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.2),
        inset 0 -1px 0 rgba(255, 255, 255, 0.05),
        0 10px 24px rgba(0, 0, 0, 0.16);
    transform: translateY(-1px);
}

.darkthread-home-btn--secondary {
    border-color: rgba(255, 255, 255, 0.16);
    color: #d6dce5;
}

.darkthread-home-btn--secondary:hover {
    background: rgba(255, 255, 255, 0.045);
    border-color: rgba(255, 255, 255, 0.24);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.2),
        inset 0 -1px 0 rgba(255, 255, 255, 0.05),
        0 10px 24px rgba(0, 0, 0, 0.16);
    transform: translateY(-1px);
}

.darkthread-home-btn--report {
    border-color: rgba(255, 122, 143, 0.36);
    color: #ffe7ec;
    font-weight: 650;
}

.darkthread-home-btn--report:hover {
    background: rgba(135, 30, 50, 0.3);
    border-color: rgba(255, 150, 168, 0.48);
    color: #fff;
    transform: translateY(-1px);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.22),
        inset 0 -1px 0 rgba(255, 255, 255, 0.05),
        0 12px 28px rgba(123, 31, 46, 0.24);
}

.darkthread-home-btn--report:focus-visible {
    outline: 2px solid rgba(251, 191, 36, 0.85);
    outline-offset: 3px;
}

.darkthread-home-btn--login {
    position: relative;
    padding: 12px 22px;
    font-size: 0.95rem;
    font-weight: 750;
    letter-spacing: -0.02em;
    color: #07090d;
    border: 1px solid rgba(255, 255, 255, 0.42);
    background: linear-gradient(165deg, #f4f7fc 0%, #dce4f0 42%, #c8d4e8 100%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.75),
        inset 0 -1px 0 rgba(80, 100, 130, 0.12),
        0 4px 0 rgba(0, 0, 0, 0.35),
        0 14px 36px rgba(120, 160, 210, 0.28);
}

.darkthread-home-btn--login:hover {
    color: #050608;
    border-color: rgba(255, 255, 255, 0.55);
    background: linear-gradient(165deg, #ffffff 0%, #e8eef8 45%, #d2deee 100%);
    transform: translateY(-2px);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.88),
        inset 0 -1px 0 rgba(80, 100, 130, 0.1),
        0 5px 0 rgba(0, 0, 0, 0.32),
        0 18px 44px rgba(130, 175, 220, 0.38);
}

.darkthread-home-btn--login:focus-visible {
    outline: 3px solid rgba(253, 224, 71, 0.95);
    outline-offset: 3px;
}

.darkthread-home-hero-aside {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.darkthread-home-hero-aside .darkthread-home-status-card,
.darkthread-home-notice .darkthread-home-notice-item,
.darkthread-home-popular .darkthread-home-feature,
.darkthread-home-popular .darkthread-home-rankrow,
.darkthread-home-spotlight-free-board .darkthread-home-feature,
.darkthread-home-spotlight-free-board .darkthread-home-rankrow,
.darkthread-home-board-swiper .darkthread-home-board-card,
.darkthread-home-recent-swiper .darkthread-home-recent-card {
    background: var(--dt-home-glass-surface-bg);
    border-color: var(--dt-home-glass-surface-border);
    backdrop-filter: blur(10px) saturate(118%);
    -webkit-backdrop-filter: blur(10px) saturate(118%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.05),
        0 4px 16px rgba(0, 0, 0, 0.1);
}

.darkthread-home-hero-aside .darkthread-home-status-card:hover,
.darkthread-home-notice .darkthread-home-notice-item:hover,
.darkthread-home-popular .darkthread-home-feature:hover,
.darkthread-home-popular .darkthread-home-rankrow:hover,
.darkthread-home-spotlight-free-board .darkthread-home-feature:hover,
.darkthread-home-spotlight-free-board .darkthread-home-rankrow:hover,
.darkthread-home-board-swiper .darkthread-home-board-card:hover,
.darkthread-home-recent-swiper .darkthread-home-recent-card:hover {
    background: var(--dt-home-glass-surface-bg-hover);
    border-color: var(--dt-home-glass-surface-border-hover);
}

.darkthread-home-hero-aside .darkthread-home-status-card::before {
    opacity: 0.16;
}

.darkthread-home-status-card {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    border-radius: 16px;
    padding: 20px 22px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    text-decoration: none;
    color: inherit;
}

.darkthread-home-status-card::before {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    /* 18% 좌측 편향 라디얼 + 135deg 선형은 우측이 상대적으로 어두워 보임 → 상단 중심 + 수직 하이라이트 */
    background:
        radial-gradient(circle at 50% 14%, rgba(255, 255, 255, 0.16), transparent 40%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.06), transparent 56%);
    opacity: 0.24;
    z-index: 0;
}

.darkthread-home-status-card:hover {
    transform: translateY(-1px);
}

.darkthread-home-status-title {
    margin: 0;
    font-size: 0.9rem;
    font-weight: 650;
    color: #dce1e8;
}

.darkthread-home-status-desc {
    margin: 0;
    font-size: 0.8rem;
    line-height: 1.55;
    color: var(--dt-home-muted);
}

.darkthread-home-status-content {
    position: relative;
    z-index: 1;
}

.darkthread-home-status-icon {
    position: absolute;
    right: -12px;
    bottom: -10px;
    font-size: 4.1rem;
    opacity: 0.08;
    color: rgba(140, 168, 190, 0.8);
    pointer-events: none;
    z-index: 0;
    transform: rotate(-8deg);
}

.darkthread-home-list-ad {
    width: 100%;
    min-width: 0;
    margin-block: 16px;
}

.darkthread-home-list-ad--coupang-dynamic .darkthread-coupang-partners-dynamic {
    width: 100%;
    max-width: 100%;
}

.darkthread-home-row {
    display: grid;
    gap: 20px;
    align-items: stretch;
}

.darkthread-home-row--ad {
    margin-top: 2px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    min-width: 0;
}

/* 홈 PC 스폰서: 단일 슬롯 행 + 카드 중앙 정렬(728 기준) */
.darkthread-home-row--ad.darkthread-home-row--ad-center {
    grid-template-columns: minmax(0, 1fr);
    justify-items: center;
    width: 100%;
    min-width: 0;
}

.darkthread-home-row--ad.darkthread-home-row--ad-below-hero {
    margin-top: 0;
}

.darkthread-home-row--ad.darkthread-home-row--ad-footer {
    margin-top: 2px;
}

.darkthread-home-row--ad.darkthread-home-row--ad-center .darkthread-home-ad-slot {
    width: 100%;
    max-width: min(728px, 100%);
}

@media (max-width: 759px) {
    .darkthread-home-row--ad {
        grid-template-columns: 1fr;
    }
}

/* 추천·자유게시판: 각각 단독 행(1열), 데스크톱 동일 카드 높이 */
.darkthread-home-row--spotlight {
    align-items: stretch;
    grid-template-columns: minmax(0, 1fr);
}

.darkthread-home-row--spotlight .darkthread-home-card--stretch {
    min-height: 0;
}

@media (min-width: 900px) {
    .darkthread-home-row--spotlight .darkthread-home-popular,
    .darkthread-home-row--spotlight .darkthread-home-spotlight-free-board {
        height: var(--dt-home-spotlight-card-height, 452px);
        min-height: var(--dt-home-spotlight-card-height, 452px);
        max-height: var(--dt-home-spotlight-card-height, 452px);
        box-sizing: border-box;
    }

    .darkthread-home-row--spotlight .darkthread-home-popular {
        display: flex;
        flex-direction: column;
        min-height: 0;
    }

    .darkthread-home-row--spotlight .darkthread-home-popular .darkthread-home-popular-stack {
        flex: 1 1 auto;
        min-height: 0;
        overflow: visible;
        align-self: stretch;
        align-content: stretch;
        grid-template-rows: minmax(0, 1fr);
    }

    .darkthread-home-popular-stack > .darkthread-home-popular-panel.is-active {
        height: 100%;
        min-height: 0;
    }

    .darkthread-home-row--spotlight .darkthread-home-spotlight-free-board .darkthread-home-free-board-body--empty {
        flex: 1 1 auto;
        min-height: 0;
    }

    .darkthread-home-popular-panel.darkthread-home-popular-panel--empty.is-active {
        min-height: 0;
    }
}

.darkthread-home-spotlight-free-board {
    display: flex;
    flex-direction: column;
    gap: 0;
    min-height: 0;
}

.darkthread-home-free-board-body {
    display: flex;
    flex-direction: column;
    /* 피처 margin-bottom만으로 추천 패널과 동일 간격 (gap 중복 시 9px로 벌어짐) */
    gap: 0;
    min-height: 0;
    flex: 0 0 auto;
    overflow: visible;
    padding-top: 0;
}

.darkthread-home-free-board-list {
    flex: 0 0 auto;
    min-height: 0;
    gap: 6px;
}

.darkthread-home-free-board-body--empty {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px 10px;
    min-height: 160px;
    box-sizing: border-box;
}

/* 추천·자유 스포트라이트: 표시할 글이 없을 때 */
.darkthread-home-spotlight-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    width: 100%;
    max-width: 17.5rem;
    margin: 0 auto;
    padding: clamp(8px, 2vw, 16px) 10px;
    text-align: center;
    box-sizing: border-box;
}

.darkthread-home-spotlight-empty-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 46px;
    flex: 0 0 auto;
    border-radius: 50%;
    border: 1px solid var(--dt-home-line);
    background: rgba(0, 0, 0, 0.28);
    color: var(--dt-home-accent);
    font-size: 1.12rem;
    line-height: 1;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.darkthread-home-spotlight-empty-text {
    margin: 0;
    font-size: 0.93rem;
    font-weight: 500;
    line-height: 1.55;
    color: var(--dt-home-muted);
}

.darkthread-home-popular-panel.darkthread-home-popular-panel--empty.is-active {
    justify-content: center;
    align-items: center;
    min-height: 160px;
}

.darkthread-home-spotlight-free-board.darkthread-home-card {
    padding: 12px 14px 11px;
}

.darkthread-home-empty.darkthread-home-empty--tight {
    margin: 0.35rem 0;
    padding: 10px 8px;
    font-size: 0.86rem;
}

/* 추천 카드: 본문 스크롤 없이 맞춤, 조회·댓글·추천 우측 정렬 */
.darkthread-home-popular.darkthread-home-card {
    padding: 12px 14px 11px;
}

.darkthread-home-popular .darkthread-home-popular-stack {
    flex: 0 0 auto;
    min-height: 0;
    overflow: hidden;
    align-content: start;
}

.darkthread-home-popular .darkthread-home-feature,
.darkthread-home-popular .darkthread-home-rankrow {
    width: 100%;
    max-width: 100%;
    min-width: 0;
}

.darkthread-home-popular .darkthread-home-feature,
.darkthread-home-spotlight-free-board .darkthread-home-feature {
    height: 130px;
    margin-bottom: 6px;
    margin-top: 0;
    padding: 9px 11px;
    gap: 5px;
    box-sizing: border-box;
}

.darkthread-home-popular .darkthread-home-feature-cat,
.darkthread-home-spotlight-free-board .darkthread-home-feature-cat {
    font-size: 0.78rem;
}

.darkthread-home-popular .darkthread-home-feature-meta,
.darkthread-home-spotlight-free-board .darkthread-home-feature-meta {
    justify-content: flex-end;
    text-align: right;
    align-self: stretch;
    width: 100%;
    font-size: 0.78rem;
    line-height: 1.28;
}

.darkthread-home-popular .darkthread-home-feature-title,
.darkthread-home-spotlight-free-board .darkthread-home-feature-title {
    min-height: 2.1rem;
    max-height: 2.1rem;
    font-size: 0.95rem;
    line-height: 1.32;
}

.darkthread-home-popular .darkthread-home-feature-preview,
.darkthread-home-spotlight-free-board .darkthread-home-feature-preview {
    min-height: 2.2rem;
    max-height: 2.2rem;
    font-size: 0.82rem;
    line-height: 1.4;
}

.darkthread-home-popular .darkthread-home-ranklist,
.darkthread-home-spotlight-free-board .darkthread-home-ranklist {
    gap: 6px;
}

.darkthread-home-popular .darkthread-home-rankrow,
.darkthread-home-spotlight-free-board .darkthread-home-rankrow {
    box-sizing: border-box;
    height: 54px;
    min-height: 54px;
    max-height: 54px;
    padding: 5px 9px;
    gap: 3px;
}

.darkthread-home-popular .darkthread-home-rankmeta,
.darkthread-home-spotlight-free-board .darkthread-home-rankmeta {
    justify-content: flex-end;
    text-align: right;
    align-self: stretch;
    width: 100%;
    font-size: 0.69rem;
    line-height: 1.18;
}

.darkthread-home-popular .darkthread-home-ranktitle--compact,
.darkthread-home-spotlight-free-board .darkthread-home-ranktitle--compact {
    font-size: 0.82rem;
    line-height: 1.24;
}

.darkthread-home-card {
    padding: 24px;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.darkthread-home-card--stretch {
    min-height: 100%;
}

.darkthread-home-notice {
    overflow: hidden;
    position: relative;
    /*
     * 근거(번들 CSS): node_modules/swiper/swiper-bundle.css
     *   .swiper { position: relative; z-index: 1; overflow: hidden; … }
     *   .swiper-wrapper { z-index: 1; transform: translate3d(0px, 0, 0); … }
     * 공지가 5건 초과면 본문 루트에 .swiper가 붙는다. 이 카드는 .darkthread-home-card의
     * backdrop-filter와 함께 쓰이며, 합성 레이어(z-index/transform) 자식이 카드 테두리보다
     * 위에 그려져 하단 테두리가 사라진 것처럼 보이는 현상이 난다.
     * 추천 카드에는 동일 위치에 .swiper 루트가 없어 차이가 난다.
     * 해결: 실제 box border는 투명으로 두고, 자식보다 위(z-index:2)에 ::after 링으로만 테두리를 그린다.
     */
    border-color: transparent;
}

.darkthread-home-notice::after {
    content: '';
    position: absolute;
    inset: 0;
    box-sizing: border-box;
    border-radius: inherit;
    border: 1px solid var(--dt-home-panel-border-color);
    pointer-events: none;
    z-index: 2;
}

.darkthread-home-popular {
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.darkthread-home-card-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: var(--darkthread-home-section-head-gap, 16px);
}

@media (max-width: 560px) {
    .darkthread-home-card-head {
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
    }

    .darkthread-home-tabs {
        flex-wrap: wrap;
    }
}

/* 공지사항·인기글: 타이틀·전체 보기 / 탭을 중앙 정렬 (게시판·최근 기록과 통일) */
.darkthread-home-notice .darkthread-home-card-head,
.darkthread-home-popular .darkthread-home-card-head,
.darkthread-home-spotlight-free-board .darkthread-home-card-head {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 10px;
}

.darkthread-home-notice .darkthread-home-card-head .darkthread-home-section-title,
.darkthread-home-popular .darkthread-home-card-head .darkthread-home-section-title,
.darkthread-home-spotlight-free-board .darkthread-home-card-head .darkthread-home-section-title {
    width: 100%;
    text-align: center;
}

.darkthread-home-popular .darkthread-home-card-head .darkthread-home-section-title,
.darkthread-home-spotlight-free-board .darkthread-home-card-head .darkthread-home-section-title {
    font-size: 1.12rem;
}

.darkthread-home-notice .darkthread-home-card-head .darkthread-home-textlink {
    white-space: normal;
}

.darkthread-home-spotlight-free-board .darkthread-home-spotlight-subrow .darkthread-home-textlink {
    white-space: normal;
    font-size: 0.9rem;
}

/* 추천·자유 스포트라이트: 헤더와 본문 사이 간격 축소, 동일 리듬 */
.darkthread-home-popular .darkthread-home-card-head,
.darkthread-home-spotlight-free-board .darkthread-home-card-head {
    margin-bottom: 6px;
    gap: 6px;
    box-sizing: border-box;
    justify-content: flex-start;
}

@media (min-width: 900px) {
    .darkthread-home-row--spotlight .darkthread-home-popular .darkthread-home-card-head,
    .darkthread-home-row--spotlight .darkthread-home-spotlight-free-board .darkthread-home-card-head {
        min-height: 84px;
    }
}

.darkthread-home-popular .darkthread-home-tabs,
.darkthread-home-spotlight-subrow .darkthread-home-tabs {
    width: 100%;
    justify-content: center;
    flex-wrap: wrap;
}

.darkthread-home-popular .darkthread-home-tab {
    font-size: 0.86rem;
    padding: 3px 14px;
}

.darkthread-home-spotlight-subrow {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    width: 100%;
    min-height: 32px;
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body.darkthread-home .darkthread-home-shell .darkthread-home-section-title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 650;
    letter-spacing: -0.02em;
    color: #e6e9ef;
}

.darkthread-home-textlink {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--dt-home-accent);
    text-decoration: none;
    white-space: nowrap;
    transition: color 0.12s ease;
}

.darkthread-home-textlink:hover {
    color: var(--dt-home-accent-hover);
}

.darkthread-home-notice-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.darkthread-home-notice-swiper {
    width: 100%;
    overflow: hidden;
    /* 마지막 슬라이드 하단이 뷰포트에 붙어 잘리지 않도록(스와이퍼 고정 높이와 맞춤) */
    padding-bottom: 3px;
}

/*
 * 홈 공지는 세로 방향 Swiper + 자동재생만 쓰고 allowTouchMove는 꺼져 있다.
 * Swiper 번들의 `.swiper-vertical { touch-action: pan-x }` 때문에 모바일에서
 * 이 영역 위에서 시작한 세로 스크롤이 무시되는 경우가 있어 페이지 스크롤을 허용한다.
 */
body.darkthread-home .darkthread-home-notice-swiper.swiper-vertical {
    touch-action: pan-y pinch-zoom;
}

.darkthread-home-notice-swiper .darkthread-home-notice-list {
    gap: 6px;
}

.darkthread-home-notice-swiper.swiper-initialized .darkthread-home-notice-list {
    gap: 0;
}

.darkthread-home-notice-swiper .swiper-wrapper {
    align-items: stretch;
}

.darkthread-home-notice-swiper.swiper-initialized .swiper-slide {
    height: auto !important;
}

.darkthread-home-notice-item {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    grid-template-rows: auto auto;
    gap: 6px 12px;
    padding: 14px 16px;
    border-radius: 14px;
    text-decoration: none;
    color: inherit;
}

.darkthread-home-notice-icon {
    grid-row: 1;
    grid-column: 1;
    align-self: start;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.45rem;
    height: 1.45rem;
    border-radius: 999px;
    border: 1px solid rgba(var(--dt-crimson-border-rgb), 0.45);
    color: #fee2e2;
    background: linear-gradient(180deg, rgba(146, 45, 45, 0.72), rgba(117, 31, 31, 0.82));
    line-height: 1;
}

.darkthread-home-notice-icon i {
    font-size: 0.72rem;
    line-height: 1;
}

.darkthread-home-notice-title {
    grid-row: 1;
    grid-column: 2;
    font-size: 0.92rem;
    font-weight: 600;
    color: #e2e6ed;
}

.darkthread-home-notice-date {
    grid-row: 1;
    grid-column: 3;
    font-size: 0.72rem;
    color: var(--dt-home-muted);
    white-space: nowrap;
}

.darkthread-home-date-today {
    color: #facc15 !important;
    font-weight: 600;
}

.darkthread-home-notice-line {
    grid-row: 2;
    grid-column: 1 / -1;
    font-size: 0.8rem;
    line-height: 1.5;
    color: var(--dt-home-muted);
}

@media (max-width: 520px) {
    .darkthread-home-notice-item {
        grid-template-columns: auto minmax(0, 1fr);
        grid-template-rows: auto;
        gap: 8px;
    }

    .darkthread-home-notice-icon {
        grid-row: 1;
        grid-column: 1;
    }

    .darkthread-home-notice-title {
        grid-row: 1;
        grid-column: 2;
    }

    .darkthread-home-notice-date {
        grid-row: 2;
        grid-column: 1 / -1;
        white-space: normal;
    }

    .darkthread-home-notice-line {
        grid-row: 3;
        grid-column: 1 / -1;
    }
}

.darkthread-home-tabs {
    display: flex;
    align-items: center;
    gap: 0;
}

.darkthread-home-tab {
    position: relative;
    overflow: visible;
    cursor: pointer;
    border: 0;
    background: transparent;
    color: var(--dt-home-muted);
    font-size: 0.78rem;
    font-weight: 600;
    padding: 2px 13px;
    border-radius: 0;
    transition:
        color 0.14s ease;
}

.darkthread-home-tab::before {
    content: '';
    position: absolute;
    left: 13px;
    bottom: -4px;
    z-index: 0;
    width: 0;
    height: 1px;
    background: rgba(255, 255, 255, 0.68);
    pointer-events: none;
}

.darkthread-home-tab + .darkthread-home-tab::after {
    content: '|';
    position: absolute;
    left: -2px;
    top: 50%;
    transform: translateY(-52%);
    color: rgba(148, 163, 184, 0.32);
    font-weight: 400;
    pointer-events: none;
}

.darkthread-home-tab > span {
    position: relative;
    z-index: 1;
}

.darkthread-home-tab:hover {
    color: var(--dt-home-text);
}

.darkthread-home-tab.is-active {
    color: #fff;
}

.darkthread-home-tab.is-active::before {
    animation: darkthread-home-tab-progress 10s linear forwards;
}

.darkthread-home-tab.is-progress-reset::before {
    animation: none;
}

@keyframes darkthread-home-tab-progress {
    from {
        width: 0;
    }

    to {
        width: calc(100% - 26px);
    }
}

.darkthread-home-popular-stack {
    display: grid;
    position: relative;
    align-content: start;
    flex: 0 1 auto;
    min-height: 120px;
    min-width: 0;
    overflow: hidden;
}

.darkthread-home-popular-stack > .darkthread-home-popular-panel {
    grid-area: 1 / 1;
    transition: opacity 0.16s ease;
    padding-top: 0;
}

/* 비활성 탭 패널이 visibility:hidden이라도 레이아웃에 남아 max(…) 높이를 밀어버림 → absolute로 플로우에서 제외 */
.darkthread-home-popular-panel:not(.is-active) {
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    z-index: 0;
    overflow: hidden;
    max-width: 100%;
}

.darkthread-home-popular-panel.is-active {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    gap: 0;
    min-width: 0;
    max-width: 100%;
}

.darkthread-home-feature {
    display: flex;
    flex-direction: column;
    gap: 8px;
    height: 168px;
    overflow: hidden;
    padding: 15px 16px;
    border-radius: 16px;
    text-decoration: none;
    color: inherit;
    margin-bottom: 14px;
}

.darkthread-home-feature:hover {
    transform: translateY(-1px);
}

.darkthread-home-feature-cat {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--dt-home-muted);
}

.darkthread-home-feature-title {
    font-size: 1.05rem;
    font-weight: 650;
    line-height: 1.35;
    color: #eef1f6;
    min-height: 2.85rem;
    max-height: 2.85rem;
    overflow: hidden;
}

.darkthread-home-feature-preview {
    font-size: 0.88rem;
    line-height: 1.6;
    color: var(--dt-home-text);
    min-height: 2.8rem;
    max-height: 2.8rem;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
}

.darkthread-home-feature-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.1rem 0.35rem;
    margin-top: auto;
    font-size: 0.75rem;
    text-align: center;
    color: var(--dt-home-muted);
}

.darkthread-home-meta-dot {
    margin: 0 0.2em;
}

.darkthread-home-ranklist {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

/* 제목 1줄 + 하단 메타(조회·댓글·추천) 한 덩어리 — 상단 피처 카드와 동일한 정보 밀도 */
.darkthread-home-rankrow {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 5px;
    height: 74px;
    overflow: hidden;
    padding: 10px 12px;
    border-radius: 12px;
    text-decoration: none;
    color: inherit;
}

.darkthread-home-rankrow:hover {
    transform: translateY(-1px);
}

.darkthread-home-ranktitle {
    min-width: 0;
    font-size: 0.86rem;
    font-weight: 600;
    line-height: 1.4;
    color: #e2e6ed;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
}

.darkthread-home-ranktitle--compact {
    display: block;
    white-space: nowrap;
    text-overflow: ellipsis;
    -webkit-line-clamp: unset;
    line-clamp: unset;
}

.darkthread-home-ranktitle--compact .darkthread-home-post-title-line {
    display: block;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    overflow-wrap: normal;
}

.darkthread-home-rankmeta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.1rem 0.25rem;
    margin-top: auto;
    font-size: 0.72rem;
    line-height: 1.45;
    text-align: center;
    color: var(--dt-home-muted);
}

.darkthread-home-rankmeta .darkthread-home-meta-dot {
    margin: 0 0.12em;
    color: rgba(148, 163, 184, 0.45);
}

@media (min-width: 768px) {
    .darkthread-home-feature-cat,
    .darkthread-home-feature-title,
    .darkthread-home-feature-preview {
        text-align: left;
    }

    .darkthread-home-rankrow {
        height: 74px;
    }

    .darkthread-home-ranktitle {
        min-width: 0;
        text-align: left;
        -webkit-line-clamp: 1;
        line-clamp: 1;
    }

    .darkthread-home-rankmeta {
        row-gap: 4px;
    }

    .darkthread-home-spotlight-free-board .darkthread-home-rankrow,
    .darkthread-home-popular .darkthread-home-rankrow {
        height: 54px;
        min-height: 54px;
        max-height: 54px;
        padding: 5px 9px;
        box-sizing: border-box;
    }
}

.darkthread-home-boards {
    width: 100%;
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
}

.darkthread-home-boards-head {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: var(--darkthread-home-section-head-gap, 16px);
}

.darkthread-home-boards-head .darkthread-home-section-title {
    width: 100%;
    text-align: center;
}

/* 게시판 둘러보기: 내용 높이 기반 카드 + 가변 열(모바일 2·넓은 화면 3) */
.darkthread-home-board-grid {
    display: grid;
    width: 100%;
    min-width: 0;
    align-items: start;
    gap: clamp(10px, 2vw, 14px);
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (min-width: 520px) {
    .darkthread-home-board-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

/* Swiper 12 번들: .swiper overflow:hidden + .swiper-wrapper/slide height:100% 조합이
   가로 슬라이더에서 높이 체인을 깨뜨려 카드 하단(테두리·기록 n건)이 잘리는 경우가 있음 */
.darkthread-home-board-swiper.swiper {
    width: 100%;
    min-width: 0;
    max-width: 100%;
    height: auto !important;
    padding: 4px 2px 10px;
    overflow-x: hidden;
    overflow-y: visible;
}

.darkthread-home-swiper-shell {
    position: relative;
    width: 100%;
    min-width: 0;
    max-width: 100%;
    --dt-home-swiper-pagination-space: 40px;
    padding-bottom: var(--dt-home-swiper-pagination-space);
    overflow-x: clip;
}

.darkthread-home-swiper-shell--board {
    /* 카드 하단·페이지네이션 사이 여유 (슬라이더 하단 잘림 완화) */
    --dt-home-swiper-pagination-space: 58px;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
}

.darkthread-home-board-swiper .swiper-wrapper {
    height: auto !important;
    align-items: stretch;
}

.darkthread-home-board-swiper .swiper-slide {
    display: flex;
    height: auto !important;
    align-self: stretch;
    box-sizing: border-box;
}

.darkthread-home-board-swiper .darkthread-home-board-card {
    height: auto;
    align-self: stretch;
    min-height: min-content;
    /* 하단 테두리·통계 행이 부모 overflow에 잘리지 않도록(줄 클램프는 자식에서 처리) */
    overflow: visible;
}

.darkthread-home-board-name-row {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
}

.darkthread-home-board-icon {
    width: 1.05rem;
    flex: 0 0 1.05rem;
    text-align: center;
    font-size: 0.8rem;
    color: rgba(136, 167, 190, 0.95);
}

/* PC: 카드가 뷰포트 전체 너비만큼 커지지 않도록 그리드 폭 제한 */
@media (min-width: 900px) {
    .darkthread-home-board-grid {
        max-width: min(960px, 100%);
        margin-left: auto;
        margin-right: auto;
        gap: 14px;
    }
}

.darkthread-home-board-card {
    --dt-home-panel-radius: 16px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    width: 100%;
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
    min-height: 0;
    padding: 10px 12px;
    text-decoration: none;
    color: inherit;
    overflow: hidden;
}

@media (min-width: 640px) {
    .darkthread-home-board-card {
        gap: 5px;
        padding: 12px 14px;
    }
}

@media (min-width: 900px) {
    .darkthread-home-board-card {
        padding: 12px 14px;
    }
}

.darkthread-home-board-name {
    min-width: 0;
    flex-shrink: 0;
    font-size: clamp(0.8rem, 2.2vw, 0.9rem);
    font-weight: 650;
    line-height: 1.25;
    color: #e8ecf1;
}

.darkthread-home-board-desc {
    flex-shrink: 0;
    font-size: clamp(0.68rem, 1.9vw, 0.78rem);
    line-height: 1.38;
    color: var(--dt-home-muted);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.darkthread-home-board-latest {
    flex-shrink: 0;
    margin-top: 4px;
    font-size: clamp(0.68rem, 1.9vw, 0.78rem);
    line-height: 1.4;
    color: var(--dt-home-text);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.darkthread-home-board-latest--muted {
    color: var(--dt-home-muted);
}

.darkthread-home-board-stat {
    flex-shrink: 0;
    margin-top: 6px;
    padding-top: 6px;
    border-top: 1px solid rgba(148, 163, 184, 0.12);
    font-size: clamp(0.65rem, 1.7vw, 0.72rem);
    color: var(--dt-home-muted);
}

.darkthread-home-recent {
    width: 100%;
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
}

.darkthread-home-recent-head {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    text-align: center;
    gap: 6px;
    width: 100%;
    min-width: 0;
    margin-bottom: var(--darkthread-home-section-head-gap, 16px);
}

.darkthread-home-recent-head .darkthread-home-section-title {
    width: 100%;
    text-align: center;
}

.darkthread-home-recent-head .darkthread-home-textlink {
    white-space: normal;
}

.darkthread-home-recent-swiper {
    width: 100%;
    min-width: 0;
    max-width: 100%;
    padding: 2px;
    overflow: hidden;
}

.darkthread-home-board-swiper .swiper-wrapper,
.darkthread-home-recent-swiper .swiper-wrapper,
.darkthread-home-board-swiper .swiper-slide,
.darkthread-home-recent-swiper .swiper-slide {
    min-width: 0;
    max-width: 100%;
}

.darkthread-home-recent-swiper .swiper-wrapper {
    align-items: stretch;
}

.darkthread-home-recent-swiper .swiper-slide {
    display: flex;
    height: auto;
}

.darkthread-home-recent-swiper .darkthread-home-recent-card {
    height: 100%;
}

.darkthread-home-recent-swiper-btn {
    position: absolute;
    top: calc((100% - var(--dt-home-swiper-pagination-space)) / 2 - 18px);
    z-index: 90;
    width: 36px;
    height: 36px;
    border: 1px solid var(--dt-home-line);
    border-radius: 999px;
    background: rgba(9, 9, 9, 0.9);
    background: color-mix(in srgb, var(--dt-home-card) 88%, transparent);
    color: var(--dt-home-accent);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.05),
        0 2px 10px rgba(0, 0, 0, 0.35);
    backdrop-filter: blur(8px) saturate(118%);
    -webkit-backdrop-filter: blur(8px) saturate(118%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.35rem;
    line-height: 1;
    cursor: pointer;
    transition:
        transform 0.14s ease,
        background-color 0.14s ease,
        border-color 0.14s ease,
        color 0.14s ease,
        box-shadow 0.14s ease,
        opacity 0.14s ease;
}

.darkthread-home-recent-swiper-btn:hover {
    transform: translateY(-1px);
    background: rgba(17, 17, 17, 0.94);
    background: color-mix(in srgb, var(--dt-home-card-strong) 92%, transparent);
    border-color: rgba(154, 154, 154, 0.22);
    border-color: color-mix(in srgb, var(--dt-home-accent) 32%, var(--dt-home-line));
    color: var(--dt-home-accent-hover);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.07),
        0 3px 14px rgba(0, 0, 0, 0.45);
}

.darkthread-home-recent-swiper-btn:focus-visible {
    outline: 2px solid rgba(182, 182, 182, 0.55);
    outline: 2px solid color-mix(in srgb, var(--dt-home-accent-hover) 75%, transparent);
    outline-offset: 2px;
}

.darkthread-home-recent-swiper-btn i {
    font-size: 0.82rem;
    line-height: 1;
    color: inherit;
}

.darkthread-home-recent-swiper-btn:disabled,
.darkthread-home-recent-swiper-btn.swiper-button-disabled {
    opacity: 0;
    pointer-events: none;
}

.darkthread-home-recent-swiper-btn--prev {
    left: 8px;
}

.darkthread-home-recent-swiper-btn--next {
    right: 8px;
}

.darkthread-home-recent-swiper-pagination {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    text-align: center;
}

.darkthread-home-recent-swiper-pagination .swiper-pagination-bullet {
    background: var(--dt-home-muted);
    opacity: 0.38;
}

.darkthread-home-recent-swiper-pagination .swiper-pagination-bullet-active {
    background: var(--dt-home-accent-hover);
    opacity: 1;
}

@media (max-width: 560px) {
    .darkthread-home-swiper-shell {
        --dt-home-swiper-pagination-space: 40px;
    }

    .darkthread-home-recent-swiper-btn {
        width: 32px;
        height: 32px;
        top: calc((100% - var(--dt-home-swiper-pagination-space)) / 2 - 16px);
    }

    .darkthread-home-recent-swiper-btn--prev {
        left: 4px;
    }

    .darkthread-home-recent-swiper-btn--next {
        right: 4px;
    }
}

@media (min-width: 1200px) {
    .darkthread-home-recent-swiper-btn--prev {
        left: 12px;
    }

    .darkthread-home-recent-swiper-btn--next {
        right: 12px;
    }
}

.darkthread-home-recent-card {
    display: flex;
    flex-direction: column;
    gap: 8px;
    width: 100%;
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
    padding: 22px;
    border-radius: 20px;
    text-decoration: none;
    color: inherit;
    min-height: 158px;
}

.darkthread-home-recent-cat {
    font-size: 0.68rem;
    font-weight: 650;
    letter-spacing: 0.06em;
    color: var(--dt-home-muted);
}

.darkthread-home-recent-title {
    min-width: 0;
    font-size: 0.95rem;
    font-weight: 650;
    line-height: 1.35;
    color: #eef1f6;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    overflow-wrap: anywhere;
}

/* 홈 게시글 제목: board/list 과 동일한 # 강조 + 파이프/해시 분리 태그 칩(SSR) */
.darkthread-home-post-title-root {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
}

.darkthread-home-post-title-root .darkthread-home-post-title-line {
    width: 100%;
    min-width: 0;
    overflow-wrap: anywhere;
}

body.darkthread-home .darkthread-table-title-main {
    color: inherit;
    font-weight: inherit;
}

body.darkthread-home .darkthread-table-title-tag {
    color: #b8a36a;
    font-size: 0.92em;
    font-weight: 600;
}

body.darkthread-home .darkthread-mobile-post-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem 0.45rem;
    max-width: 100%;
    color: #b8a36a;
    font-size: 0.78rem;
    font-weight: 600;
    line-height: 1.25;
}

body.darkthread-home .darkthread-mobile-post-tags > span {
    white-space: nowrap;
}

body.darkthread-home .darkthread-mobile-post-tag-more {
    color: #d3c08a;
}

.darkthread-home-feature-title.darkthread-home-post-title-root .darkthread-home-post-title-line {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    line-clamp: 4;
}

.darkthread-home-ranktitle.darkthread-home-post-title-root {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    -webkit-line-clamp: unset;
    line-clamp: unset;
}

.darkthread-home-ranktitle.darkthread-home-post-title-root .darkthread-home-post-title-line {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
}

/* 추천 하위 행: compact 의도(1줄 말줄임)가 post-title-root flex·2줄 clamp 에 덮이지 않도록 */
.darkthread-home-popular .darkthread-home-ranktitle--compact.darkthread-home-post-title-root,
.darkthread-home-spotlight-free-board .darkthread-home-ranktitle--compact.darkthread-home-post-title-root {
    display: block;
    flex: 1 1 auto;
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
}

.darkthread-home-popular .darkthread-home-ranktitle--compact.darkthread-home-post-title-root .darkthread-home-post-title-line,
.darkthread-home-spotlight-free-board .darkthread-home-ranktitle--compact.darkthread-home-post-title-root .darkthread-home-post-title-line {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    -webkit-line-clamp: unset;
    line-clamp: unset;
    -webkit-box-orient: unset;
}

body.darkthread-home .darkthread-home-popular .darkthread-mobile-post-tags,
body.darkthread-home .darkthread-home-spotlight-free-board .darkthread-mobile-post-tags {
    max-width: 100%;
    min-width: 0;
    overflow: hidden;
}

.darkthread-home-popular .darkthread-home-feature-title.darkthread-home-post-title-root,
.darkthread-home-spotlight-free-board .darkthread-home-feature-title.darkthread-home-post-title-root {
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
}

@media (max-width: 767px) {
    .darkthread-home-popular.darkthread-home-card {
        padding: 14px 14px 15px;
    }

    .darkthread-home-popular .darkthread-home-popular-stack {
        overflow: visible;
    }

    .darkthread-home-popular .darkthread-home-feature {
        height: auto;
        min-height: 188px;
        max-height: none;
        margin-bottom: 11px;
        padding: 12px 12px 11px;
        gap: 7px;
    }

    .darkthread-home-popular .darkthread-home-feature-title {
        min-height: 0;
        max-height: none;
        line-height: 1.38;
    }

    .darkthread-home-popular .darkthread-home-feature-title.darkthread-home-post-title-root .darkthread-home-post-title-line {
        -webkit-line-clamp: 2;
        line-clamp: 2;
    }

    .darkthread-home-popular .darkthread-home-feature-preview {
        min-height: 0;
        max-height: none;
        padding-top: 7px;
        border-top: 1px solid rgba(148, 163, 184, 0.1);
        line-height: 1.5;
        -webkit-line-clamp: 3;
        line-clamp: 3;
    }

    .darkthread-home-popular .darkthread-home-rankmeta,
    .darkthread-home-popular .darkthread-home-feature-meta {
        flex-wrap: wrap;
        justify-content: flex-end;
        row-gap: 2px;
        min-width: 0;
        max-width: 100%;
    }

    .darkthread-home-popular .darkthread-home-feature-meta {
        padding-top: 7px;
        border-top: 1px solid rgba(148, 163, 184, 0.1);
    }

    .darkthread-home-popular .darkthread-home-ranklist {
        gap: 9px;
    }

    .darkthread-home-popular .darkthread-home-rankrow {
        height: auto;
        min-height: 62px;
        max-height: none;
        padding: 8px 10px;
        gap: 7px;
    }

    .darkthread-home-popular .darkthread-home-ranktitle--compact.darkthread-home-post-title-root {
        flex: 0 1 auto;
    }
}

.darkthread-home-recent-title.darkthread-home-post-title-root {
    display: flex;
    flex-direction: column;
    -webkit-line-clamp: unset;
    line-clamp: unset;
    overflow: visible;
}

.darkthread-home-recent-title.darkthread-home-post-title-root .darkthread-home-post-title-line {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
}

.darkthread-home-board-latest.darkthread-home-post-title-root {
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    -webkit-line-clamp: unset;
    line-clamp: unset;
}

.darkthread-home-board-latest.darkthread-home-post-title-root .darkthread-home-post-title-line {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
}

.darkthread-home-recent-preview {
    min-width: 0;
    font-size: 0.82rem;
    line-height: 1.55;
    color: var(--dt-home-text);
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    white-space: normal;
    overflow-wrap: anywhere;
}

.darkthread-home-recent-foot {
    margin-top: auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    font-size: 0.74rem;
    color: var(--dt-home-muted);
}

.darkthread-home-empty {
    margin: 0;
    padding: 16px;
    font-size: 0.86rem;
    color: var(--dt-home-muted);
}

.darkthread-home-empty--wide {
    grid-column: 1 / -1;
}

.darkthread-home-recent-swiper > .darkthread-home-empty--wide {
    border-radius: 14px;
    border: 1px dashed rgba(148, 163, 184, 0.2);
    background: rgba(10, 15, 24, 0.45);
}

body.darkthread-home a.darkthread-home-feature:focus-visible,
body.darkthread-home a.darkthread-home-rankrow:focus-visible,
body.darkthread-home a.darkthread-home-board-card:focus-visible,
body.darkthread-home a.darkthread-home-recent-card:focus-visible,
body.darkthread-home a.darkthread-home-notice-item:focus-visible,
body.darkthread-home .darkthread-home-tab:focus-visible {
    outline: 2px solid rgba(120, 150, 175, 0.55);
    outline-offset: 2px;
}

body.darkthread-home a.darkthread-home-story:focus-visible,
body.darkthread-home a.darkthread-home-pill:focus-visible {
    outline: 2px solid rgba(var(--dt-crimson-border-rgb), 0.55);
    outline-offset: 2px;
}

body.darkthread-home #home-recent a:focus-visible {
    outline: 2px solid rgba(120, 150, 175, 0.55);
    outline-offset: 2px;
}

.darkthread-home-kicker {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: var(--dt-fg-soft);
}

.darkthread-home-eyebrow {
    font-size: 0.9rem;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #8b3a3a;
}

.darkthread-home-title {
    max-width: 48rem;
    text-wrap: balance;
    font-size: clamp(2.4rem, 5vw, 4.8rem);
    line-height: 0.98;
    font-weight: 700;
    letter-spacing: -0.06em;
    color: #fff;
}

.darkthread-home-description {
    max-width: 46rem;
    font-size: 1rem;
    line-height: 1.85;
    color: var(--dt-fg-muted);
}

.darkthread-home-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    border-radius: 9999px;
    border: 1px solid rgba(148, 163, 184, 0.14);
    background: rgba(18, 18, 18, 0.92);
    padding: 0.45rem 0.8rem;
    color: #e5e7eb;
    font-size: 0.875rem;
    line-height: 1;
}

.darkthread-home-stat {
    border: 1px solid rgba(148, 163, 184, 0.12);
    border-radius: 1.2rem;
    background: rgba(255, 255, 255, 0.04);
    padding: 1rem 1rem 0.95rem;
}

.darkthread-home-stat-value {
    margin-top: 0.4rem;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: -0.04em;
    color: #fff;
}

.darkthread-home-stat-label {
    font-size: 0.8rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--dt-fg-soft);
}

.darkthread-home-stat-note {
    margin-top: 0.35rem;
    font-size: 0.875rem;
    line-height: 1.55;
    color: var(--dt-fg-muted);
}

.darkthread-home-story {
    display: grid;
    gap: 0.75rem;
    border-radius: 1.35rem;
    border: 1px solid rgba(148, 163, 184, 0.12);
    background: rgba(255, 255, 255, 0.035);
    padding: 1rem 1.05rem;
    transition: transform 0.16s ease, border-color 0.16s ease, background-color 0.16s ease;
}

.darkthread-home-story:hover {
    transform: translateY(-1px);
    border-color: rgba(var(--dt-crimson-border-rgb), 0.26);
    background: rgba(255, 255, 255, 0.055);
}

.darkthread-home-story-title {
    font-size: 0.98rem;
    font-weight: 600;
    line-height: 1.55;
    color: var(--dt-fg);
}

.darkthread-home-story-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem 0.65rem;
    font-size: 0.8rem;
    color: var(--dt-fg-muted);
}

.darkthread-home-story-excerpt {
    font-size: 0.9rem;
    line-height: 1.7;
    color: var(--dt-fg-muted);
}

.darkthread-home-section-header {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.darkthread-home-section-kicker {
    font-size: 11px;
    letter-spacing: 0.34em;
    text-transform: uppercase;
    color: var(--dt-fg-soft);
}

.darkthread-home-section-header .darkthread-home-section-title {
    margin-top: 0.35rem;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: -0.04em;
    color: #fff;
}

.darkthread-home-section-copy {
    max-width: 36rem;
    font-size: 0.95rem;
    line-height: 1.75;
    color: var(--dt-fg-muted);
}

/* 전역 v2 라이트 테마: 홈 */
html.darkthread-board-list-v2-theme-light body.darkthread-home.darkthread-main-bg::before,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-blood-layer,
html.darkthread-board-list-v2-theme-light body.darkthread-home .noise::before {
    opacity: 0 !important;
}

/* 모바일 탭 바 */
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-mobile-tab-bar {
    background: #ffffff !important;
    border-color: #e5e7eb !important;
    box-shadow: 0 -1px 0 #e5e7eb !important;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-mobile-tab-bar__item {
    color: var(--dt-fg-soft) !important;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-mobile-tab-bar__item:hover,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-mobile-tab-bar__item.is-active {
    color: #111827 !important;
    background: #f1f5f9 !important;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-shell {
    color: var(--dt-fg);
}

html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-shell::before {
    opacity: 0;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-hero-title,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-status-title,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-feature-title,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-ranktitle,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-board-name,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-board-latest,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-recent-title,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-notice-title,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-shell .darkthread-home-section-title {
    color: #111827 !important;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-hero-label,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-hero-sub,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-status-desc,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-feature-cat,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-feature-preview,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-feature-meta,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-rankmeta,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-board-desc,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-board-stat,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-recent-cat,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-recent-preview,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-recent-foot,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-notice-date,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-empty {
    color: var(--dt-fg-soft) !important;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-textlink {
    color: #475569;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-btn {
    border-color: #e5e7eb;
    background: rgba(255, 255, 255, 0.82);
    color: var(--dt-fg);
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-btn--primary,
html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-btn--login {
    border-color: #111827;
    background: #111827;
    color: #ffffff;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-btn--report {
    border-color: rgba(var(--dt-crimson-rgb), 0.22);
    background: #fff1f2;
    color: #632323;
}



html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-recent-swiper-btn {
    border-color: #e5e7eb;
    background: rgba(255, 255, 255, 0.94);
    color: #475569;
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.1);
}

html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-spotlight-empty-icon {
    background: #f8fafc;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-tab.is-active {
    color: #111827;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-tab::before {
    background: rgba(17, 24, 39, 0.7);
}

html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-tab + .darkthread-home-tab::after {
    color: rgba(15, 23, 42, 0.2);
}

/* ——— 홈 좌측 프로필 레일 (board/view dt-v2-view-rail 동형) ——— */
body.darkthread-home.darkthread-home-v2-profile {
    /* board-view-v2.css .darkthread-board-view-v2 토큰과 동일 (우측 광고 열 제외) */
    --dt-v2-home-rail-width: var(--dt-v2-profile-rail-width, calc(250px / 1.5));
    --dt-v2-home-center-max: var(--dt-v2-profile-center-max, calc(680px + 250px - 250px / 1.5));
    --dt-v2-home-column-gap: 48px;
    --dt-v2-home-shell-padding-inline: 24px;
    --dt-v2-home-shell-max: calc(
        var(--dt-v2-home-rail-width) + var(--dt-v2-home-column-gap) + var(--dt-v2-home-center-max)
    );
    /* board/view 좌·우 레일과 동일한 sticky 기준 */
    --dt-v2-home-sticky-top: calc(
        var(--dt-v2-toolbar-top, var(--dt-v2-chrome-top, 0px)) + var(--dt-v2-toolbar-offset-height, 52px) + 10px
    );
    --dt-v2-text: var(--dt-home-text, #f5f5f5);
    --dt-v2-muted: rgba(148, 163, 184, 0.82);
    --dt-v2-soft: rgba(148, 163, 184, 0.62);
}

html.darkthread-board-list-v2-theme-light body.darkthread-home.darkthread-home-v2-profile {
    --dt-v2-text: #111827;
    --dt-v2-muted: #64748b;
    --dt-v2-soft: #94a3b8;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-view-rail__label {
    color: #475569;
    font-weight: 800;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-view-rail__name,
html.darkthread-board-list-v2-theme-light body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-view-rail__name .darkthread-author-profile-link {
    color: #0f172a;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-view-rail__bio {
    color: #172033;
    font-weight: 750;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-view-rail__link {
    color: #111827 !important;
    font-weight: 800;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-shell:has(.dt-v2-home-rail-recent--rail) .dt-v2-home-profile-recent-divider {
    border-top-color: rgba(51, 65, 85, 0.24);
}

html.darkthread-board-list-v2-theme-light body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-home-rail-recent__title,
html.darkthread-board-list-v2-theme-light body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-home-rail-recent__link-title {
    color: #0b1220;
    font-weight: 850;
    letter-spacing: 0;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-home-rail-recent__meta,
html.darkthread-board-list-v2-theme-light body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-home-rail-recent__empty {
    color: #334155;
    font-weight: 750;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-home-rail-recent__link {
    border-radius: 8px;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-home-rail-recent__link:hover {
    background: rgba(255, 255, 255, 0.28);
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-wrap {
    width: 100%;
    min-width: 0;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-shell.dt-v2-view-shell {
    box-sizing: border-box;
    width: min(100%, var(--dt-v2-view-shell-max));
    max-width: 100%;
    margin: 0 auto;
}

/* 최근 읽은 글: 좌측 열 폭은 우측 사이드(250px)와 동일, 프로필만 좁은 레일 폭 유지 */
body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-shell.dt-v2-view-shell:has(.dt-v2-home-rail-recent--rail) {
    --dt-v2-home-left-column-width: var(--dt-v2-view-side-width, var(--dt-v2-profile-rail-width-base, 250px));
    grid-template-columns: var(--dt-v2-home-left-column-width) minmax(0, var(--dt-v2-view-center-max)) var(--dt-v2-view-side-width);
    --dt-v2-view-shell-max: calc(
        var(--dt-v2-home-left-column-width) + var(--dt-v2-view-side-width) + (var(--dt-v2-view-column-gap) * 2) +
            var(--dt-v2-view-center-max)
    );
    width: min(100%, var(--dt-v2-view-shell-max));
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-shell--no-side {
    grid-template-columns: var(--dt-v2-view-rail-width) minmax(0, var(--dt-v2-view-center-max));
    width: min(
        100%,
        calc(var(--dt-v2-view-rail-width) + var(--dt-v2-view-column-gap) + var(--dt-v2-view-center-max))
    );
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail.dt-v2-view-rail {
    position: sticky;
    top: var(--dt-v2-view-sticky-top, var(--dt-v2-home-sticky-top));
    align-self: start;
    display: flex;
    flex-direction: column;
    gap: var(--dt-v2-view-side-stack-gap, 24px);
    box-sizing: border-box;
    width: 100%;
    max-width: var(--dt-v2-view-left-column-width, var(--dt-v2-view-rail-width, var(--dt-v2-home-rail-width)));
    min-width: 0;
    overflow: visible;
    z-index: 4;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-view-rail__inner {
    box-sizing: border-box;
    width: 100%;
    max-width: none;
    max-height: calc(100dvh - var(--dt-v2-home-sticky-top) - 24px);
    padding:
        var(--dt-v2-view-rail-padding-block, 24px) var(--dt-v2-view-rail-padding-inline, 22px)
        calc(var(--dt-v2-view-rail-padding-block, 24px) + 2px);
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-shell.dt-v2-view-shell:has(.dt-v2-home-rail-recent--rail) .dt-v2-home-profile-rail.dt-v2-view-rail {
    width: 100%;
    max-width: 100%;
    min-width: 0;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-shell:has(.dt-v2-home-rail-recent--rail) .dt-v2-home-profile-rail .dt-v2-view-rail__inner {
    width: 100%;
    max-width: none;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-side.dt-v2-view-side {
    top: var(--dt-v2-view-sticky-top, var(--dt-v2-home-sticky-top));
    min-width: 0;
    max-width: 100%;
    overflow-x: clip;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-side .dt-v2-view-side__inner {
    gap: 8px;
    padding-top: 0;
    padding-bottom: 12px;
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    max-height: none;
    overflow-x: clip;
    overflow-y: visible;
    overscroll-behavior: auto;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-side .dt-v2-home-profile-side__divider {
    --dt-v2-home-side-divider-gap: 6px;
    flex-shrink: 0;
    width: 100%;
    margin: var(--dt-v2-home-side-divider-gap) 0;
    border: 0;
    border-top: 1px solid var(--dt-v2-border);
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-side .dt-v2-home-side-topics {
    position: relative;
    z-index: 0;
    box-sizing: border-box;
    min-width: 0;
    max-width: 100%;
    width: 100%;
    padding: 12px var(--dt-v2-view-rail-padding-inline, 22px) 22px;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-side .dt-v2-home-side-topics h2 {
    margin-bottom: 12px;
    font-size: 14px;
    font-weight: 800;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-side .dt-v2-topic-cloud a {
    max-width: 100%;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-side .dt-v2-topic-cloud__label {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-side .dt-v2-view-side__inner > .kakao_ad_area {
    box-sizing: border-box;
    position: relative;
    z-index: 0;
    width: 100%;
    max-width: 100%;
    margin-top: 0;
    padding: var(--dt-v2-view-side-section-padding, 20px 22px 22px);
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-side .dt-v2-view-side__inner > .darkthread-home-coupang-sidebar {
    box-sizing: border-box;
    position: relative;
    z-index: 0;
    display: flex;
    justify-content: center;
    width: 100%;
    max-width: 100%;
    margin-top: 0;
    padding: var(--dt-v2-view-side-section-padding, 20px 22px 22px);
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-rail-recent {
    display: grid;
    gap: 10px;
    min-width: 0;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-shell:has(.dt-v2-home-rail-recent--rail) .dt-v2-home-profile-recent-divider {
    --dt-v2-home-profile-recent-divider-gap: 16px;
    flex-shrink: 0;
    align-self: stretch;
    width: 100%;
    max-width: 100%;
    margin: var(--dt-v2-home-profile-recent-divider-gap) 0;
    border: 0;
    border-top: 1px solid var(--dt-v2-border, rgba(255, 255, 255, 0.1));
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-shell:has(.dt-v2-home-rail-recent--rail) .dt-v2-home-rail-recent--rail {
    position: relative;
    z-index: 0;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
    padding: var(--dt-v2-view-side-section-padding, 20px 22px 22px);
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-rail-recent__title {
    margin: 0;
    color: var(--dt-v2-text, var(--dt-home-text, #f5f5f5));
    font-size: 13px;
    font-weight: 800;
    line-height: 1.35;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-rail-recent__list {
    display: grid;
    gap: 12px;
    margin: 0;
    padding: 0;
    list-style: none;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-rail-recent__link {
    display: grid;
    gap: 3px;
    color: inherit;
    text-decoration: none;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-rail-recent__link:hover .dt-v2-home-rail-recent__link-title {
    text-decoration: underline;
    text-underline-offset: 3px;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-rail-recent__link-title {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    color: var(--dt-v2-text, var(--dt-home-text, #f5f5f5));
    font-size: 13px;
    font-weight: 750;
    line-height: 1.45;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-rail-recent__meta,
body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-rail-recent__empty {
    margin: 0;
    color: var(--dt-v2-muted, var(--dt-home-muted));
    font-size: 11px;
    line-height: 1.4;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-rail-recent--mobile {
    display: none;
    margin: 0 0 20px;
    padding: 16px;
    border-radius: 16px;
    border: 1px solid var(--dt-home-panel-border-color, rgba(255, 255, 255, 0.1));
    background: var(--dt-home-panel-bg, rgba(12, 13, 16, 0.72));
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side {
    position: relative;
    z-index: 0;
    box-sizing: border-box;
    margin: 0;
    /* 좌측 dt-v2-view-rail__inner 과 첫 카드(글래스) 상단선 동일 */
    padding:
        var(--dt-v2-view-rail-padding-block, 24px) var(--dt-v2-view-rail-padding-inline, 22px)
        12px;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    min-width: 0;
    max-width: 100%;
    width: 100%;
    overflow: visible;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side::after {
    display: none;
}

/* 공지 헤더·더보기 버튼 → asset/css/home-notice-side.css (#home-notice, FA/tailwind 간섭 차단) */

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side__title {
    color: var(--dt-v2-text, var(--dt-home-text, #f5f5f5));
    font-size: 14px;
    font-weight: 800;
    line-height: 1.35;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side__empty {
    margin: 0;
    color: var(--dt-v2-muted, var(--dt-home-muted));
    font-size: 12px;
    line-height: 1.45;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side__viewport {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side--static .darkthread-home-notice--side__viewport {
    height: auto;
    overflow: visible;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side--static .darkthread-home-notice-swiper {
    height: auto;
    overflow: visible;
    padding: 0;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side--static .darkthread-home-notice-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side--carousel .darkthread-home-notice--side__viewport {
    overflow: hidden;
    box-sizing: border-box;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side--carousel .darkthread-home-notice-swiper {
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    height: 100%;
    padding: 0;
    border-radius: 0;
    overflow: hidden;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side--carousel .darkthread-home-notice-swiper.swiper-initialized .swiper-slide {
    height: auto !important;
    box-sizing: border-box;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side--carousel .darkthread-home-notice-swiper.swiper-initialized .swiper-wrapper {
    align-items: stretch;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side--carousel .darkthread-home-notice-swiper.swiper-initialized .darkthread-home-notice-list,
body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side--carousel .darkthread-home-notice-swiper.swiper-initialized .swiper-wrapper {
    min-width: 0;
    max-width: 100%;
    gap: 0;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side--carousel .darkthread-home-notice-swiper .swiper-slide {
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side .darkthread-home-notice-item {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    grid-template-rows: auto;
    gap: 8px 10px;
    align-items: start;
    margin: 0;
    padding: 10px 12px;
    border-radius: 12px;
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
    color: inherit;
    text-decoration: none;
    overflow-wrap: anywhere;
    background: var(--dt-home-glass-surface-bg);
    border: var(--dt-home-chip-border, 1px solid var(--dt-home-glass-surface-border));
    border-color: var(--dt-home-glass-surface-border);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow: none;
    transition:
        background 0.14s ease,
        border-color 0.14s ease,
        box-shadow 0.14s ease;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side .darkthread-home-notice-item:hover {
    background: var(--dt-home-glass-surface-bg-hover);
    border-color: var(--dt-home-glass-surface-border-hover);
    transform: none;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side .darkthread-home-notice-icon {
    grid-row: 1;
    grid-column: 1;
    width: 1.35rem;
    height: 1.35rem;
    flex-shrink: 0;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side .darkthread-home-notice-icon i {
    font-size: 0.68rem;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-home-notice--side .darkthread-home-notice-title {
    grid-row: 1;
    grid-column: 2;
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    margin: 0;
    min-width: 0;
    max-width: 100%;
    align-self: center;
    font-size: 0.82rem;
    font-weight: 600;
    line-height: 1.4;
    color: #e2e6ed;
    overflow-wrap: anywhere;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-side .kakao_ad_area,
body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-side ins.kakao_ad_area iframe,
body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-side .darkthread-home-coupang-sidebar iframe {
    border-radius: 0 !important;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-side ins.kakao_ad_area iframe {
    border: 0;
    overflow: hidden;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-side .darkthread-home-coupang-sidebar iframe {
    border: 0;
    overflow: hidden;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-main {
    min-width: 0;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-main > .darkthread-home-shell {
    box-sizing: border-box;
    width: 100%;
    max-width: none;
    margin: 0;
    padding: 0;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-comment-avatar-shell {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    flex-shrink: 0;
    overflow: visible;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-comment-avatar-frame {
    position: relative;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    overflow: hidden;
    border-radius: 999px;
    border: 1px solid rgba(148, 163, 184, 0.28);
    background: #090909;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-comment-avatar-image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-comment-avatar-image.hidden,
body.darkthread-home.darkthread-home-v2-profile .darkthread-comment-avatar-fallback.hidden {
    display: none;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-comment-avatar-fallback {
    color: var(--dt-home-text, #f5f5f5);
    font-size: 0.92rem;
    font-weight: 800;
    line-height: 1;
    text-transform: uppercase;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-comment-avatar-shell.is-master::before {
    content: "";
    position: absolute;
    inset: -0.75rem;
    border-radius: 48% 52% 46% 54% / 58% 44% 56% 42%;
    background:
        radial-gradient(circle at 35% 30%, rgba(var(--dt-crimson-border-rgb), 0.65) 0 12%, transparent 30%),
        radial-gradient(circle at 68% 72%, rgba(var(--dt-crimson-rgb), 0.9) 0 18%, transparent 36%),
        conic-gradient(from 24deg, rgba(20, 0, 0, 0) 0deg, rgba(var(--dt-crimson-rgb), 0.92) 58deg, rgba(10, 0, 0, 0.36) 104deg, rgba(var(--dt-crimson-rgb), 0.8) 158deg, rgba(7, 0, 0, 0.15) 214deg, rgba(var(--dt-crimson-rgb), 0.78) 292deg, rgba(20, 0, 0, 0) 360deg);
    filter: blur(10px) saturate(1.35);
    opacity: 0.92;
    pointer-events: none;
    z-index: 0;
    animation: darkthread-home-profile-aura-writhe 4.8s ease-in-out infinite;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-comment-avatar-shell.is-master::after,
body.darkthread-home.darkthread-home-v2-profile .darkthread-comment-avatar-shell.is-admin::after {
    content: "";
    position: absolute;
    inset: -0.18rem;
    border-radius: 43% 57% 52% 48% / 50% 42% 58% 50%;
    pointer-events: none;
    z-index: 1;
    animation: darkthread-home-profile-aura-ripple 3.2s ease-in-out infinite;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-comment-avatar-shell.is-master::after {
    box-shadow:
        0 0 0 1px rgba(var(--dt-crimson-rgb), 0.9),
        0 0 10px rgba(var(--dt-crimson-rgb), 0.86),
        0 0 24px rgba(var(--dt-crimson-rgb), 0.56),
        inset 0 0 8px rgba(15, 0, 0, 0.86);
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-comment-avatar-shell.is-admin::before {
    content: "";
    position: absolute;
    inset: -0.75rem;
    border-radius: 48% 52% 46% 54% / 58% 44% 56% 42%;
    background:
        radial-gradient(circle at 35% 30%, rgba(196, 181, 253, 0.72) 0 12%, transparent 30%),
        radial-gradient(circle at 68% 72%, rgba(46, 16, 101, 0.92) 0 18%, transparent 36%),
        conic-gradient(from 24deg, rgba(15, 0, 30, 0) 0deg, rgba(91, 33, 182, 0.92) 58deg, rgba(15, 0, 30, 0.36) 104deg, rgba(139, 92, 246, 0.82) 158deg, rgba(15, 0, 30, 0.15) 214deg, rgba(109, 40, 217, 0.78) 292deg, rgba(15, 0, 30, 0) 360deg);
    filter: blur(10px) saturate(1.25);
    opacity: 0.92;
    pointer-events: none;
    z-index: 0;
    animation: darkthread-home-profile-aura-writhe 4.8s ease-in-out infinite;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-comment-avatar-shell.is-admin::after {
    box-shadow:
        0 0 0 1px rgba(76, 29, 149, 0.9),
        0 0 10px rgba(109, 40, 217, 0.86),
        0 0 24px rgba(139, 92, 246, 0.56),
        inset 0 0 8px rgba(15, 0, 30, 0.86);
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-comment-avatar-shell.is-guest::before {
    content: "";
    position: absolute;
    inset: -0.55rem;
    border-radius: 999px;
    background:
        radial-gradient(circle, rgba(239, 68, 68, 0.58) 0%, rgba(var(--dt-crimson-rgb), 0.32) 34%, rgba(var(--dt-crimson-rgb), 0.18) 54%, rgba(var(--dt-crimson-rgb), 0) 76%);
    filter: blur(9px);
    opacity: 0.95;
    pointer-events: none;
    z-index: 0;
}

body.darkthread-home.darkthread-home-v2-profile .darkthread-comment-avatar-shell.is-guest::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 999px;
    box-shadow:
        0 0 0 1px rgba(var(--dt-crimson-border-rgb), 0.42),
        0 0 16px rgba(var(--dt-crimson-rgb), 0.42);
    pointer-events: none;
    z-index: 1;
}

@keyframes darkthread-home-profile-aura-writhe {
    0% {
        border-radius: 48% 52% 46% 54% / 58% 44% 56% 42%;
        transform: rotate(0deg) scale(0.96);
        opacity: 0.72;
    }
    38% {
        border-radius: 42% 58% 61% 39% / 45% 61% 39% 55%;
        transform: rotate(128deg) scale(1.06);
        opacity: 0.98;
    }
    68% {
        border-radius: 60% 40% 48% 52% / 38% 57% 43% 62%;
        transform: rotate(238deg) scale(1.01);
        opacity: 0.82;
    }
    100% {
        border-radius: 48% 52% 46% 54% / 58% 44% 56% 42%;
        transform: rotate(360deg) scale(0.96);
        opacity: 0.72;
    }
}

@keyframes darkthread-home-profile-aura-ripple {
    0%,
    100% {
        transform: scale(0.98);
        opacity: 0.78;
    }
    50% {
        transform: scale(1.08);
        opacity: 1;
    }
}

@media (prefers-reduced-motion: reduce) {
    body.darkthread-home.darkthread-home-v2-profile .darkthread-comment-avatar-shell.is-master::before,
    body.darkthread-home.darkthread-home-v2-profile .darkthread-comment-avatar-shell.is-master::after,
    body.darkthread-home.darkthread-home-v2-profile .darkthread-comment-avatar-shell.is-admin::before,
    body.darkthread-home.darkthread-home-v2-profile .darkthread-comment-avatar-shell.is-admin::after {
        animation: none;
    }
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-view-rail__avatar-slot .darkthread-comment-avatar-shell {
    display: inline-flex;
    margin: 0;
    overflow: visible;
    vertical-align: top;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-view-rail__avatar-slot .darkthread-comment-avatar-shell.is-master::before,
body.darkthread-home.darkthread-home-v2-profile .dt-v2-view-rail__avatar-slot .darkthread-comment-avatar-shell.is-admin::before {
    inset: -0.85rem -0.5rem -0.6rem -1rem;
    z-index: 0;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-view-rail__avatar-slot .darkthread-comment-avatar-shell.is-guest::before {
    inset: -0.65rem -0.45rem -0.5rem -0.85rem;
    z-index: 0;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-view-rail__avatar-slot .darkthread-comment-avatar-shell.is-master::after,
body.darkthread-home.darkthread-home-v2-profile .dt-v2-view-rail__avatar-slot .darkthread-comment-avatar-shell.is-admin::after,
body.darkthread-home.darkthread-home-v2-profile .dt-v2-view-rail__avatar-slot .darkthread-comment-avatar-shell.is-guest::after {
    z-index: 1;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-view-rail__avatar-slot .darkthread-comment-avatar-frame {
    position: relative;
    z-index: 2;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-view-rail__avatar-slot .dt-v2-view-rail__avatar-shell {
    width: 3.75rem;
    height: 3.75rem;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-view-rail__avatar-slot .darkthread-comment-avatar-fallback {
    font-size: 22.5px;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-view-rail__link:has(.dt-v2-view-rail__link-icon) {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.35;
    text-decoration: none;
    text-underline-offset: 3px;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-view-rail__link:has(.dt-v2-view-rail__link-icon):hover,
body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-view-rail__link:has(.dt-v2-view-rail__link-icon):focus-visible {
    text-decoration: none;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-view-rail__link-text {
    text-decoration: none;
    text-underline-offset: 3px;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-view-rail__link:hover .dt-v2-view-rail__link-text,
body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-view-rail__link:focus-visible .dt-v2-view-rail__link-text {
    text-decoration: underline;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-view-rail__link:not(:has(.dt-v2-view-rail__link-icon)) {
    font-size: 13px;
    font-weight: 700;
    text-decoration: none;
    text-underline-offset: 3px;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-view-rail__link:not(:has(.dt-v2-view-rail__link-icon)):hover,
body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-view-rail__link:not(:has(.dt-v2-view-rail__link-icon)):focus-visible {
    text-decoration: underline;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail .dt-v2-view-rail__link-icon {
    flex-shrink: 0;
    width: 1em;
    font-size: 0.95em;
    text-decoration: none;
}

@media (max-width: 1180px) {
    body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-shell.dt-v2-view-shell {
        display: flex;
        flex-direction: column;
        width: 100%;
        max-width: none;
        gap: 20px;
    }

    body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-rail.dt-v2-view-rail {
        display: none;
    }

    body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-rail-recent--rail {
        display: none;
    }

    body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-rail-recent--mobile {
        display: none;
    }

    body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-side.dt-v2-view-side {
        display: none;
    }

    body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-main {
        order: 0;
        width: 100%;
    }

    body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-main > .darkthread-home-shell {
        margin: 0 auto;
    }

}

@media (max-width: 760px) {
    body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-shell {
        padding: 24px 16px 24px;
    }
}

@media (max-width: 520px) {
    body.darkthread-home.darkthread-home-v2-profile .dt-v2-home-profile-shell {
        padding-left: 6px;
        padding-right: 6px;
    }
}

/* 홈 프로필 레일: 왕관 반듯·노란색 (마스터/관리자 공통) */
body.darkthread-home.darkthread-home-v2-profile .dt-v2-view-rail__name .darkthread-comment-admin-crown {
    transform: none;
}

body.darkthread-home.darkthread-home-v2-profile .dt-v2-view-rail__name .darkthread-comment-admin-crown.is-master-tier,
body.darkthread-home.darkthread-home-v2-profile .dt-v2-view-rail__name .darkthread-comment-admin-crown.is-admin-tier {
    color: #facc15;
    text-shadow: 0 0 6px rgba(250, 204, 21, 0.55);
    filter: none;
}
