        /* HOME PAGE
           - 헤더 아래 메인 배너
           - 배너 아래 카테고리 메뉴
           - 클래스 목록 / 하단 배너
           - 모바일 대응 오버라이드
        */
        body.home-page {
            background:
                radial-gradient(circle at 12% 0%, rgba(120, 149, 255, 0.16), transparent 28%),
                radial-gradient(circle at 88% 12%, rgba(93, 225, 198, 0.12), transparent 24%),
                linear-gradient(180deg, #05070b 0%, #070a10 40%, #05070b 100%);
        }

        body.home-page .main-content {
            display: flex;
            flex-direction: column;
            gap: clamp(1.1rem, 2.2vw, 2rem);
            padding-bottom: 1.5rem;
        }


        body.home-page .hero-inner {
            width: min(calc(100vw - 0.75rem), 1880px);
            max-width: none;
            margin: 0 auto;
            display: grid;
            grid-template-columns: 1fr;
            gap: 1rem;
            align-items: stretch;
            padding: 0 0.35rem;
        }

        /* 메인 배너 / 카테고리 / 하단 배너 공통 유리 질감 */
        body.home-page .main-ad-banner.home-main-banner,
        body.home-page .home-category-panel,
        body.home-page .bottom-banner-section .banner-inner {
            background: linear-gradient(180deg, rgba(18, 22, 31, 0.96), rgba(10, 12, 18, 0.92));
            border: 1px solid rgba(255, 255, 255, 0.08);
            box-shadow: 0 24px 60px rgba(0, 0, 0, 0.28);
            backdrop-filter: blur(24px);
            -webkit-backdrop-filter: blur(24px);
        }

        /* 메인 배너: 실제 이미지가 들어가는 스테이지 */
        body.home-page .main-ad-banner.home-main-banner {
            border-radius: 30px;
            padding: clamp(0.48rem, 0.8vw, 0.7rem);
            overflow: hidden;
            position: relative;
            min-height: auto;
            display: flex;
            flex-direction: column;
            gap: 0.45rem;
        }

        body.home-page .main-ad-banner.home-main-banner::before {
            content: "";
            position: absolute;
            inset: 0;
            background:
                radial-gradient(circle at top right, rgba(94, 140, 255, 0.22), transparent 32%),
                radial-gradient(circle at bottom left, rgba(93, 225, 198, 0.12), transparent 34%);
            pointer-events: none;
        }

        body.home-page .home-banner-stage {
            position: relative;
            width: 100%;
            aspect-ratio: 16 / 5;
            min-height: 500px;
            border-radius: 28px;
            overflow: hidden;
            background: #090c12;
            border: 1px solid rgba(255, 255, 255, 0.08);
        }

        body.home-page .home-banner-stage::before {
            content: "";
            position: absolute;
            inset: 0;
            background:
                linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent 24%),
                linear-gradient(180deg, transparent 55%, rgba(4, 6, 10, 0.22) 100%);
            pointer-events: none;
            z-index: 1;
        }

        body.home-page .home-banner-stage::after {
            content: "";
            position: absolute;
            inset: auto 0 0;
            height: clamp(120px, 16vw, 220px);
            background: linear-gradient(180deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.82));
            pointer-events: none;
            z-index: 2;
        }

        body.home-page .home-banner-track {
            position: absolute;
            inset: 0;
        }

        body.home-page .home-banner-slide {
            position: absolute;
            inset: 0;
            opacity: 0;
            transform: scale(1.015);
            transition: opacity 640ms ease, transform 760ms ease;
            will-change: opacity, transform;
        }

        body.home-page .home-banner-slide.is-active {
            opacity: 1;
            transform: scale(1);
            z-index: 1;
        }

        body.home-page .home-banner-slide a,
        body.home-page .home-banner-slide div {
            display: block;
            width: 100%;
            height: 100%;
        }

        body.home-page .home-banner-slide img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            object-position: center;
            background: #0a0d12;
        }

        body.home-page .home-banner-empty {
            display: grid;
            place-items: center;
            padding: 1.5rem;
            text-align: center;
            color: rgba(236, 242, 255, 0.75);
            font-weight: 700;
            letter-spacing: -0.03em;
            background:
                radial-gradient(circle at top left, rgba(142, 165, 255, 0.16), transparent 28%),
                radial-gradient(circle at bottom right, rgba(93, 225, 198, 0.12), transparent 30%);
        }

        body.home-page .hero-eyebrow,
        body.home-page .home-category-panel .hero-eyebrow,
        body.home-page .banner-eyebrow {
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            width: fit-content;
            padding: 0.42rem 0.78rem;
            border-radius: 999px;
            background: rgba(255, 255, 255, 0.08);
            border: 1px solid rgba(255, 255, 255, 0.08);
            color: #d9e6ff;
            font-size: 0.8rem;
            font-weight: 700;
            letter-spacing: 0.04em;
            text-transform: uppercase;
        }

        body.home-page .banner-link:focus-visible,
        body.home-page .home-category-item:focus-visible,
        body.home-page .class-card-link:focus-visible {
            outline: 2px solid rgba(142, 165, 255, 0.95);
            outline-offset: 3px;
        }

        /* 카테고리 패널: 배너 아래 아이콘 메뉴 */
        body.home-page .home-category-panel {
            display: flex;
            flex-direction: column;
            gap: 0.9rem;
            border-radius: 30px;
            padding: clamp(1rem, 1.8vw, 1.3rem);
            min-height: 0;
        }

        body.home-page .home-category-panel h2 {
            margin: 0;
            font-size: clamp(1.2rem, 2.4vw, 1.45rem);
            line-height: 1.15;
            letter-spacing: -0.04em;
            word-break: keep-all;
        }

        body.home-page .home-category-panel p {
            margin: 0;
            color: rgba(236, 242, 255, 0.7);
            line-height: 1.7;
            font-size: 0.95rem;
        }

        /* JS가 카테고리 카드를 주입하는 래퍼 */
        body.home-page .home-category-shell {
            height: 100%;
            display: flex;
            flex-direction: column;
            gap: 0.7rem;
        }

        body.home-page .home-category-grid {
            display: grid;
            gap: 0.55rem;
            align-content: start;
        }

        body.home-page .home-category-grid-primary {
            grid-template-columns: repeat(6, minmax(0, 1fr));
        }

        body.home-page .home-category-grid-extra {
            grid-template-columns: repeat(6, minmax(0, 1fr));
        }

        /* 카테고리 카드 */
        body.home-page .home-category-item {
            display: flex;
            flex-direction: column;
            justify-content: space-between;
            gap: 0.4rem;
            min-height: 100px;
            padding: 0.68rem 0.42rem;
            border-radius: 18px;
            background: rgba(255, 255, 255, 0.045);
            border: 1px solid rgba(255, 255, 255, 0.08);
            color: #eef4ff;
            text-align: center;
        }

        body.home-page .home-category-item:hover,
        body.home-page .home-category-item.is-active {
            transform: translateY(-2px);
            background: rgba(255, 255, 255, 0.08);
            border-color: rgba(142, 165, 255, 0.3);
            box-shadow: 0 18px 36px rgba(0, 0, 0, 0.16);
        }

        body.home-page .home-category-icon {
            width: clamp(36px, 4vw, 44px);
            height: clamp(36px, 4vw, 44px);
            border-radius: 14px;
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
        }

        body.home-page .home-category-name,
        body.home-page .home-category-label {
            font-size: 0.8rem;
            font-weight: 700;
            line-height: 1.25;
            word-break: keep-all;
            text-align: center;
        }

        body.home-page .home-category-count {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-width: 1.9rem;
            padding: 0.16rem 0.42rem;
            border-radius: 999px;
            background: rgba(255, 255, 255, 0.08);
            color: rgba(255, 255, 255, 0.8);
            font-size: 0.68rem;
            font-weight: 700;
        }

        /* 더보기 / 접기 */
        body.home-page .home-category-toggle-row {
            display: flex;
            justify-content: center;
            padding-top: 0.1rem;
        }

        body.home-page .home-category-toggle {
            width: clamp(120px, 16vw, 160px);
            min-height: 92px;
            padding: 0.82rem 0.95rem;
            border-radius: 20px;
            background: rgba(255, 255, 255, 0.06);
            border: 1px solid rgba(255, 255, 255, 0.08);
            color: #eef4ff;
            font-weight: 700;
            letter-spacing: -0.02em;
        }

        body.home-page .home-category-toggle:hover {
            background: rgba(255, 255, 255, 0.1);
            transform: translateY(-1px);
        }

        body.home-page .home-category-extra[hidden] {
            display: none !important;
        }

/* __HOME_PAGE_CSS__ */
