/**
 * Layout Base CSS - FOUC 방지 및 레이아웃 기본 스타일
 * ====================================================
 * 충청남도교육청 단위학교 사업선택제
 *
 * 목적:
 * - 레이아웃 로딩 중 FOUC(Flash of Unstyled Content) 방지
 * - 스켈레톤 UI 표시로 사용자 경험 개선
 * - 헤더/푸터 컨테이너 기본 높이 확보
 */

/* ===================================================
   1. 레이아웃 로딩 상태 관리
   =================================================== */

/* 로딩 중 - 콘텐츠 숨김 및 스켈레톤 표시 */
body.layout-loading #header,
body.layout-loading #footer {
    min-height: 60px;
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s ease-in-out infinite;
}

/* 관리자 헤더는 더 높은 높이 */
body[data-layout="adm"].layout-loading #header {
    min-height: 100px;
}

/* KR 헤더는 2depth 포함하여 더 높게 */
body[data-layout="kr"].layout-loading #header,
body[data-layout="auto"].layout-loading #header {
    min-height: 120px;
}

/* 로딩 완료 - 정상 표시 */
body.layout-loaded #header,
body.layout-loaded #footer {
    min-height: auto;
    background: none;
    animation: none;
}

/* 스켈레톤 로딩 애니메이션 */
@keyframes skeleton-loading {
    0% {
        background-position: 200% 0;
    }
    100% {
        background-position: -200% 0;
    }
}

/* ===================================================
   2. 기본 레이아웃 구조
   =================================================== */

/* 전체 래퍼 */
#wrap {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

/* 메인 콘텐츠 영역 - 푸터 밀어내기 */
#content,
main {
    flex: 1 0 auto;
}

/* 푸터는 항상 하단에 */
#footer,
footer {
    flex-shrink: 0;
}

/* ===================================================
   3. 헤더 기본 스타일 보완
   =================================================== */

/* 헤더 컨테이너 초기 상태 */
#header {
    position: relative;
    z-index: 100;
}

/* KR 헤더 기본 배경 */
body[data-layout="kr"] #header .header,
body[data-layout="auto"] #header .header {
    background-color: #fff;
}

/* ADM 헤더 기본 배경 */
body[data-layout="adm"] #header #krds-header {
    background-color: #1a365d;
}

/* ===================================================
   4. 메뉴 활성화 상태
   =================================================== */

/* KR GNB 활성화 상태 */
.gnb .gnb-item.active {
    color: var(--krds-light-color-text-primary);
}

/* KR 2depth 활성화 상태 */
.depth-column .depth-title.active {
    font-weight:var(--krds-typo-font-weight-bold);
    color: var(--krds-light-color-text-primary);
}

.depth-column .depth-item.active {
    font-weight:var(--krds-typo-font-weight-bold);
    color: var(--krds-light-color-text-primary);
    background-color:var(--krds-color-light-primary-5);
}

/* ADM 1depth 활성화 상태 */
#mainNav .nav-item.active {
    
}

#mainNav .nav-item.active span {
    font-weight: 700;
}

/* ADM 2depth 활성화 상태 */
#subNav .sub-nav-item.active {
    font-weight: 700;
    color: var(--krds-light-color-text-primary);
    border-bottom: 2px solid #1a56db;
}

/* ===================================================
   5. 페이지네이션 기본 스타일
   =================================================== */

/* KRDS 페이지네이션 기본 스타일 (KRDS CSS 보완) */
.krds-pagination {
    display: flex;
    justify-content: center;
    margin: 20px 0;
}

.pagination-list {
    display: flex;
    align-items: center;
    gap: 4px;
    list-style: none;
    padding: 0;
    margin: 0;
}

.page-item {
    display: inline-block;
}

.page-item.disabled .page-link {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

.page-item.active .page-link {
    background-color: var(--krds-light-color-text-primary);
    color: #fff;
    border-color: var(--krds-light-color-text-primary);
}

.page-link {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    height: 32px;
    padding: 0 8px;
    border: 1px solid #d1d5db;
    border-radius: 4px;
    background-color: #fff;
    color: #374151;
    text-decoration: none;
    font-size: 14px;
    transition: all 0.2s ease;
}

.page-link:hover:not(.disabled) {
    background-color: #f3f4f6;
    border-color: #9ca3af;
}

/* ===================================================
   5-1. 비로그인 상태 유틸리티 메뉴 스타일
   =================================================== */

/* 회원가입 버튼 강조 (Primary Blue) */
.utility .utility-signup {
    color: var(--krds-light-color-text-primary);
    font-weight: 600;
    transition: all 0.2s ease;
}

.utility .utility-signup:hover {
    background-color: rgba(26, 86, 219, 0.05);
    color: var(--krds-light-color-text-primary);
}

.utility .utility-signup img {
    filter: brightness(0) saturate(100%) invert(27%) sepia(76%) saturate(2679%) hue-rotate(214deg) brightness(95%) contrast(94%);
}

/* 로그인 버튼 기본 스타일 (Gray) */
.utility .utility-login {
    color: #4b5563;
    transition: all 0.2s ease;
}

.utility .utility-login:hover {
    background-color: rgba(75, 85, 99, 0.05);
    color: #1f2937;
}

/* 아이콘 크기 통일 */
.utility .utility-item img {
    width: 20px;
    height: 20px;
    margin-right: 6px;
}

/* 반응형: 모바일에서 텍스트 숨김 */
@media (max-width: 768px) {
    .utility .utility-item span {
        display: none;
    }
    .utility .utility-item img {
        margin-right: 0;
    }
}

/* ===================================================
   6. 푸터 기본 스타일 보완
   =================================================== */

/* KR 푸터 컨테이너 */
.footer-container {
    background-color: #f8fafc;
    border-top: 1px solid #e2e8f0;
}

/* ADM 푸터 컨테이너 */
#krds-footer {
    background-color: #1a365d;
    color: #fff;
    padding: 20px 0;
    text-align: center;
}

#krds-footer .f-copy {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.7);
    margin: 0;
}

/* ===================================================
   7. 유틸리티 클래스
   =================================================== */

/* 숨김 처리 */
.layout-hidden {
    display: none !important;
}

/* 로딩 스피너 (필요시 사용) */
.layout-spinner {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 2px solid #e0e0e0;
    border-top-color: var(--krds-light-color-text-primary);
    border-radius: 50%;
    animation: spinner-rotate 0.8s linear infinite;
}

@keyframes spinner-rotate {
    to {
        transform: rotate(360deg);
    }
}

/* ===================================================
   8. 반응형 대응
   =================================================== */

@media (max-width: 768px) {
    /* 모바일에서 로딩 상태 높이 조정 */
    body.layout-loading #header {
        min-height: 56px;
    }

    body.layout-loading #footer {
        min-height: 80px;
    }

    /* 페이지네이션 간격 축소 */
    .pagination-list {
        gap: 2px;
    }

    .page-link {
        min-width: 28px;
        height: 28px;
        font-size: 12px;
    }
}
