/* 기본 초기화 */
* { 
    box-sizing: border-box; 
    margin: 0; 
    padding: 0; 
}

html, body {
    width: 100%;
    margin: 0; /* 상하좌우 여백 제거 */
    padding: 0; /* 안쪽 여백 제거 */
    border-radius: 0;

    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; 
    line-height: 1.6; 
    color: #333;
    background-color: #fff;

    /* Footer 바닥 고정을 위한 Flex 설정 */
    display: flex;
    flex-direction: column;
    min-height: 100vh; /* 화면의 최소 높이를 꽉 채움 */
}

a { 
    text-decoration: none; 
    color: inherit;
}

ul { 
    list-style: none;
}

/* 레이아웃 공통 */
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* 헤더 스타일 */
header { padding: 1rem 0; }
.header-container { display: flex; justify-content: space-between; align-items: center; }

/* 로고 링크 설정 (이미지를 감싸는 a 태그) */
.logo a {
    display: inline-block; /* 링크 영역이 이미지 크기에 딱 맞게 설정 */
    text-decoration: none; /* 혹시 모를 밑줄 제거 */
}

/* 로고 이미지 */
.logo img {
    height: 36px;       /* 높이를 고정 */
    width: auto;        /* 너비는 비율에 맞춰 자동 조절 */
    display: block;     /* 이미지 하단의 미세한 여백 제거 */
    max-width: 100%;    /* 화면이 매우 좁을 때 삐져나감 방지 */
    margin-top: 4px;    /* 위쪽 여백 추가 */
}

/* 로고 이미지 (모바일) */
@media (max-width: 768px) {
    .logo img {
        height: 32px;   /* 모바일에서는 32px */
    }
}

/* 네비게이션 (데스크탑) */
#nav-menu { 
    display: flex; /* 메뉴 안의 아이템들을 가로로 나열 */
    align-items: center; /* 메뉴 안의 글자와 Select 박스를 세로 중앙 정렬 */
    gap: 20px; /* 아이템 사이 간격 */
}

#menu-toggle { display: none; font-size: 1.5rem; background: none; border: none; cursor: pointer; }

/* 언어 선택 (Select) 스타일 */
#lang-select {
    border: none; /* 테두리 제거 */
    background-color: transparent; /* 배경 투명 (헤더색과 통일) */
    font-size: 1rem; /* 다른 메뉴와 폰트 크기 통일 */
    font-family: inherit; /* 폰트체 상속 */
    color: #333; /* 글자색 (헤더 글자색과 통일) */
    cursor: pointer; /* 마우스 올리면 손가락 모양 */
    outline: none; /* 클릭 시 생기는 파란/검은 테두리 제거 */
    padding: 0 5px; /* 위아래는 0, 좌우는 5px */
}

/* 언어 선택에 마우스 올렸을 때 연한 회색 배경 */
#lang-select:hover {
    background-color: #f5f5f5;
    border-radius: 4px;
}

/* 모바일 반응형 (768px 이하) */
@media (max-width: 768px) {
    #menu-toggle { display: block; } /* 햄버거 버튼 보이기 */
    
    #nav-menu {
        display: none; /* 기본 숨김 */
        flex-direction: column;
        position: absolute;
        top: 60px;
        left: 0;
        width: 100%;
        background-color: white;
        border-top: 1px solid #ddd;
        border-bottom: 1px solid #ddd;
        padding: 20px;
        text-align: center;
    }

    #nav-menu.active { display: flex; } /* JS로 클릭시 보이기 */
}

/* Main 태그가 화면 너비를 꽉 채우도록 설정 */
main {
    width: 100%;     /* 줄어들지 말고 꽉 채움 */
    flex-grow: 1;    /* 내용이 적어도 남은 높이를 다 차지하게 함 */
}

/* Footer 스타일 */
footer {
    background-color: #f5f5f5; /* 연한 회색 배경 */
    color: #666;              /* 진한 회색 텍스트 */
    padding: 2rem 0;          /* 위아래 여백 */
    font-size: 0.9rem;        /* 본문보다 약간 작은 글씨 */
    border-top: 1px solid #e0e0e0; /* 상단에 아주 연한 경계선 */
    margin-top: auto;         /* 내용이 적어도 바닥에 붙게 함 */
}

.footer-container {
    display: flex;
    justify-content: space-between; /* 저작권은 왼쪽, 링크는 오른쪽 배치 */
    align-items: center;
}

.footer-links {
    display: flex;
    gap: 20px;
}

.footer-links a:hover {
    color: #333; /* 마우스 올리면 글씨가 진해짐 */
    text-decoration: underline;
}

/* 모바일 화면 (세로 배치) */
@media (max-width: 768px) {
    .footer-container {
        flex-direction: column; /* 세로로 쌓기 */
        gap: 1rem;
        text-align: center;
    }
}

/* 메인 히어로 섹션 */
.hero {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 100px 0;
}

.hero h1 {
    font-size: 2.5rem;
    margin-bottom: 1rem;
}

.hero p {
    font-size: 1.2rem;
    color: #666;
}

/* 문서 페이지 (Privacy, Terms) */
/* 1. 컨텐츠 래퍼 */
.content-wrapper {
    max-width: 900px;       /* 기본 최대 너비 */
    margin: 0 auto;         /* 중앙 정렬 */
    padding: 3rem 1rem;     /* 위아래, 좌우 여백 */
}

/* 데스크탑 화면 (화면 너비가 1024px 이상일 때) */
@media (min-width: 1024px) {
    .content-wrapper {
        max-width: 1200px;  /* 영역의 최대 너비 */
    }
}

/* 2. 메인 제목 */
.page-title {
    font-size: 2rem;
    font-weight: 600;
    color: #111827;         /* gray-900 */
    margin-bottom: 3rem;    /* mb-12 */
    padding-bottom: 0.5rem; /* pb-2 */
    border-bottom: 1px solid #e5e7eb; /* 연한 회색 줄 */
}

/* 3. 본문 텍스트 */
.text-body {
    color: #4b5563;         /* gray-600 */
    margin-bottom: 1rem;
    line-height: 1.7;       /* 가독성을 위해 줄간격 추가 */
}

/* 4. 목차 박스 */
.toc-box {
    background-color: #f9fafb; /* gray-50 (아주 연한 회색) */
    padding: 1.5rem;
    border-radius: 0.5rem;     /* 둥근 모서리 */
    margin-bottom: 2rem;
}

.toc-title {
    font-size: 1.25rem;     /* text-xl */
    font-weight: 600;
    color: #1f2937;         /* gray-800 */
    margin-bottom: 0.75rem;
}

.toc-list {
    list-style-type: decimal; /* 숫자 리스트 */
    list-style-position: inside;
    color: #4b5563;
    margin-left: 0.5rem;
}

.toc-list li {
    margin-bottom: 0.25rem; /* space-y-1 */
}

.toc-list a:hover {
    color: #1d4ed8;         /* blue hover 효과 */
    text-decoration: underline;
}

/* 5. 섹션 제목 (h2) */
.section-title {
    font-size: 1.5rem;      /* text-xl~2xl */
    font-weight: 600;
    color: #1f2937;         /* gray-800 */
    margin-top: 2.5rem;     /* mt-6 보다 조금 더 넉넉하게 */
    margin-bottom: 1rem;
}

/* 6. 소제목 (h3) */
.sub-title {
    font-size: 1.1rem;      /* text-l */
    font-weight: 600;
    color: #374151;         /* gray-700 */
    margin-top: 1.5rem;
    margin-bottom: 0.75rem;
}

/* 7. 본문 리스트 (ul) */
.content-list {
    list-style-type: disc;  /* 점 리스트 */
    list-style-position: inside;
    color: #4b5563;
    margin-left: 1rem;
    margin-bottom: 1rem;
}

/* 404 에러 페이지 스타일 */

/* 메인 컨테이너 */
.error-page-main {
    flex-grow: 1;           /* Footer를 바닥으로 밀어냄 */
    width: 100%;
    padding: 1rem;          /* 모바일 여백 */
    display: flex;
    align-items: center;    /* 세로 중앙 정렬 효과 */
    justify-content: center;
}

/* 컨텐츠 박스 */
.error-content {
    text-align: center;
    padding-top: 5rem;
    padding-bottom: 5rem;
    width: 100%;
    max-width: 100%;        /* 넘침 방지 */
}

/* 404 숫자 */
.error-code {
    font-size: 2.25rem;     /* 기본(모바일) 크기 */
    font-weight: 700;
    color: #111827;         /* Gray 900 */
    line-height: 1.25;
    margin-bottom: 2rem;    /* mb-8 */
    max-width: 56rem;       /* max-w-4xl */
    margin-left: auto;
    margin-right: auto;
    padding: 0 1rem;
}

/* Page Not Found 텍스트 */
.error-title {
    font-size: 1.25rem;     /* 기본(모바일) 크기 */
    color: #4b5563;         /* Gray 600 */
    margin-bottom: 2rem;    /* mb-8 */
    max-width: 42rem;       /* max-w-2xl */
    margin-left: auto;
    margin-right: auto;
    padding: 0 1rem;
}

/* 설명 텍스트 */
.error-desc {
    color: #6b7280;         /* Gray 500 */
    max-width: 32rem;       /* max-w-lg */
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 0;       /* 기본 여백 없음 */
}

/* 아래쪽 여백이 큰 설명 텍스트 */
.error-desc.mb-large {
    margin-bottom: 2.5rem;
}

/* 홈 버튼 스타일 */
.home-button {
    display: inline-block;
    padding: 0.75rem 1.5rem; /* px-6 py-3 */
    background-color: #1d4ed8; /* Blue 700 */
    color: white;
    font-weight: 500;       /* Medium */
    border-radius: 0.5rem;  /* rounded-lg */
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1); /* shadow-md */
    text-decoration: none;
    transition: background-color 0.15s ease-in-out;
}

/* 버튼 마우스 오버 효과 */
.home-button:hover {
    background-color: #2563eb; /* Blue 600 (조금 더 밝게) */
}

/* =========================
   반응형 미디어 쿼리
   ========================= */
@media (min-width: 640px) {
    /* 화면이 640px 이상일 때 폰트 키우기 */
    .error-code {
        font-size: 3.75rem; /* text-6xl */
    }
    
    .error-title {
        font-size: 1.5rem;  /* text-2xl */
    }
}