/* 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-skipnav-bg: rgba(10, 15, 24, 0.42);
    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-skipnav-bg: rgba(255, 255, 255, 0.38);
    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,
.darkthread-home-skipnav {
    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-skipnav {
        padding: 10px 12px;
        border-radius: 14px;
    }

    .darkthread-home-skipnav ul {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 14px 20px;
        font-size: clamp(0.88rem, 3.1vw, 0.96rem);
    }

    .darkthread-home-skipnav li {
        min-width: auto;
    }

    .darkthread-home-skipnav li::before {
        display: block;
    }

    .darkthread-home-skipnav a {
        display: inline;
        padding: 0;
        border-radius: 0;
        text-align: left;
        line-height: inherit;
        background: none;
    }

    .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-skipnav {
    --dt-home-panel-bg-overlay: none;
    --dt-home-panel-bg-image-layer: none;
    --dt-home-panel-bg-color: var(--dt-home-skipnav-bg);
    padding: 14px 20px;
}

.darkthread-home-skipnav ul {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 14px 22px;
    font-size: clamp(0.92rem, 1.35vw, 1.02rem);
}

.darkthread-home-skipnav li {
    position: relative;
}

.darkthread-home-skipnav li:not(:first-child) {
    margin-left: 2px;
    padding-left: 20px;
}

.darkthread-home-skipnav li:not(:first-child)::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    width: 1px;
    height: 14px;
    transform: translateY(-50%);
    background: var(--dt-home-line);
}

.darkthread-home-skipnav a {
    color: #c7ceda;
    font-weight: 600;
    font-size: inherit;
    line-height: 1.35;
    text-decoration: none;
    padding: 4px 6px;
    border-radius: 8px;
    transition: color 0.14s ease, text-shadow 0.14s ease, background-color 0.14s ease;
}

.darkthread-home-skipnav a:hover {
    color: #e5ebf5;
    text-shadow: 0 0 10px rgba(148, 163, 184, 0.22);
}

.darkthread-home-skipnav a:focus-visible {
    color: var(--dt-fg);
    background: rgba(15, 23, 42, 0.82);
    outline: 2px solid color-mix(in srgb, var(--dt-home-accent-hover) 70%, transparent);
    outline-offset: 2px;
}

.darkthread-home-hero {
    position: relative;
    overflow: hidden;
    min-height: 360px;
    --dt-home-hero-image-position: center center;
    --dt-home-hero-image-size: cover;
}

.darkthread-home-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    opacity: 0.02;
    pointer-events: none;
    z-index: 0;
    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.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: 160px 160px;
}

.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-hero-notice-row {
    display: grid;
    gap: 20px;
    align-items: stretch;
    min-width: 0;
}

.darkthread-home-hero-notice-row > .darkthread-home-hero,
.darkthread-home-hero-notice-row > .darkthread-home-notice {
    min-width: 0;
}

/* 히어로·공지 2열 그리드 사이에 끼어 넣는 띠배너는 한 행 전체 폭 */
.darkthread-home-hero-notice-row > .darkthread-kakao-strip-ad,
.darkthread-home-hero-notice-row > .darkthread-home-strip-ad {
    grid-column: 1 / -1;
    width: 100%;
    min-width: 0;
}

/* 추천·자유게시판 2열 행 안 띠배너 — 한 칸에 갇히지 않게 전체 폭 */
.darkthread-home-row--popular > .darkthread-kakao-strip-ad,
.darkthread-home-row--popular > .darkthread-home-strip-ad {
    grid-column: 1 / -1;
    width: 100%;
    min-width: 0;
}

@media (min-width: 900px) {
    .darkthread-home-hero-notice-row {
        grid-template-columns: minmax(0, 1.55fr) minmax(0, 1fr);
        gap: clamp(16px, 2.2vw, 24px);
    }
}

@media (max-width: 899px) {
    .darkthread-home-hero-notice-row {
        grid-template-columns: 1fr;
    }
}

/* 우열 공지 카드: 행 높이에 맞춰 스와이퍼 영역이 남는 세로 공간을 채움 */
@media (min-width: 900px) {
    .darkthread-home-notice.darkthread-home-notice--hero-col .darkthread-home-notice-swiper {
        flex: 1 1 auto;
        min-height: 0;
    }
}

.darkthread-home-notice.darkthread-home-notice--hero-col {
    min-height: 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-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-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;
    }
}

/* 추천·자유게시판 행: 데스크톱 동일 고정 높이, 2열 5:5 */
.darkthread-home-row--popular {
    align-items: stretch;
}

.darkthread-home-row--popular .darkthread-home-card--stretch {
    min-height: 0;
}

@media (min-width: 900px) {
    .darkthread-home-row--popular .darkthread-home-popular,
    .darkthread-home-row--popular .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--popular:has(.darkthread-home-spotlight-free-board) {
        grid-template-columns: minmax(0, 5fr) minmax(0, 5fr);
        gap: clamp(14px, 1.8vw, 20px);
    }

    .darkthread-home-row--popular .darkthread-home-popular {
        display: flex;
        flex-direction: column;
        min-height: 0;
    }

    .darkthread-home-row--popular .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--popular .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--popular .darkthread-home-popular .darkthread-home-card-head,
    .darkthread-home-row--popular .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(248, 113, 113, 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-rankmeta,
    .darkthread-home-popular .darkthread-home-feature-meta {
        flex-wrap: wrap;
        justify-content: flex-end;
        row-gap: 0;
        min-width: 0;
        max-width: 100%;
    }

    .darkthread-home-popular .darkthread-home-rankrow {
        height: auto;
        min-height: 54px;
        max-height: none;
    }

    .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(248, 113, 113, 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: #f87171;
}

.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(248, 113, 113, 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-notice-item {
    --dt-home-chip-bg: rgba(255, 255, 255, 0.28);
    --dt-home-chip-bg-hover: rgba(255, 255, 255, 0.42);
}

html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-skipnav a:focus-visible {
    color: #111827;
    background: #e2e8f0;
    outline-color: #475569;
}

html.darkthread-board-list-v2-theme-light body.darkthread-home .darkthread-home-skipnav a,
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(185, 28, 28, 0.22);
    background: #fff1f2;
    color: #991b1b;
}



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);
}
