/* [수정] 폰트 임포트: Thin(100)과 Light(300) 굵기를 추가했습니다. */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@100;300;400;700&family=Noto+Sans+KR:wght@100;300;400;700&display=swap');/* [수정] body에 기본 폰트 적용 */
body {
    min-height: 100vh;
    margin: 0;
    box-sizing: border-box;
    background-color: #f0f0f0;
    /* [신규] 폰트 패밀리 적용 */
    font-family: 'Poppins', 'Noto Sans KR', sans-serif;
}

/* [수정] main 태그 상단 여백 조정 (제목이 커졌으므로) */
main {
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    padding: 60px 20px 20px 20px; /* 상단 여백 증가 */
    box-sizing: border-box;
}

/* [수정] h1 스타일을 명세에 맞게 변경 */
h1 {
    text-align: center;
    color: #333;
    font-size: 15vw; /* 뷰포트 너비 비례 */
    font-weight: 700; /* Bold */
    letter-spacing: 2px;
    line-height: 1;
    margin-bottom: 0.2em;
}

/* [수정] h2 스타일을 명세에 맞게 변경 */
h2 {
    text-align: center;
    color: #555;
    font-size: 5vw; /* 뷰포트 너비 비례 */
    font-weight: 400; /* Regular */
    margin-top: 10px;
    margin-bottom: 2em;
}

/* --- [신규] Phase 구분선 스타일 --- */
/* [신규] 안내 문구 스타일 */
.instruction-text {
    text-align: center;
    font-size: 0.9rem;       /* 본문보다 약간 작게 */
    color: #777;             /* 너무 튀지 않는 회색 */
    margin-top: 20px;        /* 위쪽 여백 */
    margin-bottom: -20px;    /* 아래쪽 여백 (구분선과 가깝게 하기 위해 음수 혹은 0 사용) */
    font-weight: 400;
    letter-spacing: -0.5px;
    animation-delay: 0.5s;   /* 다른 요소보다 조금 늦게 뜨도록 (선택사항) */
}

.phase-divider {
    display: flex;
    align-items: center; /* 텍스트와 선 수직 중앙 정렬 */
    width: 100%;
    margin: 40px 0 20px 0; /* 위 40px, 아래 20px 간격 */
    padding: 0 5px; /* 양옆 약간의 여백 */
    box-sizing: border-box;
}

.phase-divider span {
    font-size: 1.5rem;
    font-weight: 700;
    color: #333;
    margin-right: 15px; /* 텍스트와 선 사이 간격 */
    white-space: nowrap; /* 텍스트 줄바꿈 방지 */
}

.phase-divider::after {
    content: "";
    flex-grow: 1; /* 남은 공간을 모두 차지 */
    height: 1px; /* 선 두께 */
    background-color: #ccc; /* 선 색상 */
}
/* --- [신규] 탭 내비게이션 스타일 --- */
nav {
    display: flex;
    justify-content: center;
    gap: 2rem;
    border-bottom: 1px solid #ddd;
    margin-bottom: 2rem;
}
nav a {
    text-decoration: none;
    color: #333;
    padding: 1rem 0;
    position: relative;
    font-weight: 700; /* 500 -> 700 (Bold)로 변경 */
    cursor: pointer;
    font-family: 'Poppins', sans-serif; /* 폰트 적용 */
}
nav a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 2px;
    background: #0366d6; /* 강조 색상 */
    transform: scaleX(0);
    transition: transform 0.2s ease;
    transform-origin: bottom right;
}
nav a:hover::after,
nav a.active::after {
    transform: scaleX(1);
    transform-origin: bottom left;
}

.tab-content {
    position: relative;
    /* [수정] 높이 애니메이션을 위한 설정 추가 */
    overflow: hidden;
    transition: height 0.3s ease-in-out; /* 0.3초간 높이 변화 */
}


.tab-content > section {
    opacity: 0;
    visibility: hidden;
    position: absolute;
    width: 100%; /* 너비 고정 */
    left: 0;
    right: 0;
    transition: opacity 0.5s ease;
    /* [신규] 그림자 공간 확보를 위한 좌우 패딩 추가 */
    padding: 0 30px; /* 좌우에 30px 패딩 */
    box-sizing: border-box; /* 패딩이 너비 계산에 포함되도록 */
}
.tab-content > section.active {
    opacity: 1;
    visibility: visible;
    position: static; /* 활성화 시 문서 흐름에 포함 */
}
/* [유지] details 섹션 스타일 */
.details-box {
    background: #ffffff;
    border-radius: 10px;
    padding: 1.5em 2em;
    margin: 2em auto;
    border: 1px solid #ddd;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
}
.details-box h3 {
    margin-top: 0;
    color: #333;
}
.details-box p {
    margin: 0.5em 0;
    line-height: 1.6;
    color: #555;
}

/* [유지] 페이드인 애니메이션 스타일 */
.fade-in {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}
.fade-in.visible {
    opacity: 1;
    transform: translateY(0);
}

/* [삭제] 아코디언 관련 스타일 모두 삭제됨 */

/* --- [유지] 카드 스타일 (변경 없음) --- */
.grid-container {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    width: 100%;
    margin: 0 auto;
    perspective: 1000px;
}
.card-container {
    width: 100%;
    aspect-ratio: 1 / 1;
    position: relative;
    cursor: pointer;
}
.card-inner {
    position: relative;
    width: 100%;
    height: 100%;
    transform-style: preserve-3d;
}
.card-front, .card-back {
    position: absolute;
    width: 100%;
    height: 100%;
    backface-visibility: hidden;
    border-radius: 15px;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.2);
    overflow: hidden;
}
.card-front {
    background-size: cover;
    background-position: center;
    color: white;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 2em;
    font-weight: bold;
    text-shadow: 2px 2px 4px rgba(0,0,0,0.5);
}

.card-image-1 { background-image: url("media/image_1-1.jpg"); }
.card-image-2 { background-image: url("media/image_1-2.jpg"); }
.card-image-3 { background-image: url("media/image_1-3.jpg"); }
.card-image-4 { background-image: url("media/image_1-4.jpg"); }
.card-image-5 { background-image: url("media/image_1-5.jpg"); }
.card-image-6 { background-image: url("media/image_1-6.jpg"); }
.card-image-7 { background-image: url("media/image_1-7.jpg"); }
.card-image-8 { background-image: url("media/image_1-8.jpg"); }
.card-image-9 { background-image: url("media/image_1-9.jpg"); }
.card-image-10 { background-image: url("media/image_1-10.jpg"); }
.card-image-11 { background-image: url("media/image_2-1.jpg"); }
.card-image-12 { background-image: url("media/image_2-2.jpg"); }
.card-image-13 { background-image: url("media/image_2-3.jpg"); }
.card-image-14 { background-image: url("media/image_2-4.jpg"); }
.card-image-15 { background-image: url("media/image_2-5.jpg"); }
.card-image-16 { background-image: url("media/image_2-6.jpg"); }
.card-image-17 { background-image: url("media/image_2-7.jpg"); }
.card-image-18 { background-image: url("media/image_2-8.jpg"); }
.card-image-19 { background-image: url("media/image_2-9.jpg"); }
.card-image-20 { background-image: url("media/image_2-10.jpg"); }

.card-back {
    transform: rotateY(180deg);
    background-color: #2c2c2c;
    color: white;
    padding: 20px;
    box-sizing: border-box;

    /* [추가/수정] 텍스트 스타일 개선 */
    display: flex;
    flex-direction: column;
    justify-content: center; /* 텍스트 수직 중앙 정렬 */
    align-items: center;     /* 텍스트 수평 중앙 정렬 */
    text-align: center;      /* 줄바꿈 시 가운데 정렬 */
}

/* [신규] 카드 뒷면 내부의 p 태그 스타일 구체화 */
.card-back p {
    font-size: 1rem;       /* 글자 크기 (필요시 조정) */
    line-height: 1.8;      /* 행간 (줄 간격): 보통 1.5~1.8 추천 */
    letter-spacing: 0.05em; /* 자간 (글자 간격): 약간 넓게 */
    margin: 0;             /* 불필요한 여백 제거 */
}

.card-back h3 {
    margin-bottom: 15px;   /* 제목과 본문 사이 간격 */
    letter-spacing: 0.1em; /* 제목은 자간을 좀 더 넓게 */
}

.card-front::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;

    /* 좌상단(어두움) -> 우하단(투명) 그라데이션 */
    /* 0% 지점은 진한 검은색(0.7), 70% 지점까지 서서히 투명해짐 */
    background: linear-gradient(to bottom right, rgba(0,0,0,0.7) 0%, rgba(0,0,0,0) 70%);

    z-index: 5; /* 텍스트(z-index:10)보다는 아래, 배경 이미지보다는 위 */
    pointer-events: none; /* 마우스 클릭 통과 */
    border-radius: 15px; /* 부모와 동일한 둥근 모서리 */
}
.card-front::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    background: linear-gradient(45deg, rgba(255,255,255,0.2) 0%, rgba(255,255,255,0.05) 50%, rgba(255,255,255,0.2) 100%);
    transform: translateX(-100%) rotate(45deg);
    transition: transform 0.1s ease-out;
    pointer-events: none;
}
.card-container:hover .card-front::before {
    transform: translateX(100%) rotate(45deg);
}

/* --- [신규] 채팅 UI 스타일 --- */
.chat-window {
    width: 100%;
    height: 500px; /* 채팅창의 고정 높이 */
    background: #ffffff;
    border: 1px solid #ddd;
    border-radius: 10px;
    padding: 15px;
    box-sizing: border-box;
    overflow-y: auto; /* 메시지가 많아지면 스크롤 */
    display: flex;
    flex-direction: column; /* 메시지가 위에서 아래로 쌓임 */
    gap: 10px;
}

/* 말풍선 공통 스타일 */
.chat-message {
    padding: 0 15px;
    border-radius: 20px;
    max-width: 75%;
    line-height: 1.5;
    word-wrap: break-word; /* 긴 텍스트 줄바꿈 */
}

/* 받은 메시지 (기본 안내) */
.chat-message.received {
    background-color: #efefef;
    color: #000;
    align-self: flex-start; /* 왼쪽 정렬 */
}

/* [수정] 보낸 메시지 (기본 틀) */
.chat-message.sent {
    /* background-color: #0095f6; <-- [삭제] (JS가 색상을 관리) */
    color: white; /* 기본 텍스트 색상 */
    align-self: flex-end; /* 오른쪽 정렬 */
}

/* [수정] 랜덤 색상 말풍선을 위한 스타일 */
.chat-message.sent.custom-color {
    /* background-color는 JS로 설정됩니다 */
    color: white; /* [수정] #222 -> white */
}

/* 입력 폼 스타일 */
.chat-form {
    display: flex;
    gap: 10px;
    margin-top: 15px;
}

#chat-input {
    flex-grow: 1; /* 입력창이 남은 공간 모두 차지 */
    border: 1px solid #ddd;
    border-radius: 20px;
    padding: 12px 18px;
    font-size: 1em;
}

/* [수정] 채팅 버튼 스타일 (회색 계열) */
.chat-form button {
    background-color: #333333; /* 검은 계열 색상 */
    color: white;
    border: none;
    border-radius: 20px;
    padding: 0 20px;
    font-size: 1em;
    font-weight: 600;
    cursor: pointer;
    transition: background-color 0.2s;
}
.chat-form button:hover {
    background-color: #1a1a1a; /* 더 어두운 검은색 */
}

.card-front-title {
    position: absolute;
    top: 25px;       /* 위에서 15px */
    left: 15px;      /* [변경] 왼쪽에서 15px (우상단 -> 좌상단) */

    font-family: 'Noto Sans KR', sans-serif;
    font-weight: 100; /* Light 굵기 유지 */
    font-size: 1.95rem; /* [변경] 크기 대폭 확대 */
    line-height: 1.1;  /* 줄 간격을 좁게 하여 큰 글씨가 뭉쳐 보이게 함 */
    color: rgba(255, 255, 255, 0.9);

    text-align: left; /* [변경] 좌측 정렬 */
    margin: 0;
    z-index: 10;
    pointer-events: none;
    text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.8);

    /* [핵심] 너비 제한 및 자동 줄바꿈 */
    max-width: 50%;       /* 카드의 40% 너비까지만 차지 */
    word-break: keep-all; /* [중요] 한글 단어 중간에서 끊기지 않도록 설정 */
    word-wrap: break-word; /* 필요한 경우 줄바꿈 */
}

@media (min-width: 768px) {
    .grid-container {
        grid-template-columns: repeat(3, 1fr);
    }

    /* [신규] 768px 이상에서 h1, h2 폰트 크기 고정 */
    h1 {
        font-size: 6rem; /* 약 96px */
    }
    h2 {
        font-size: 2rem; /* 약 32px */
    }
}

/* [수정] 기존 모바일 @media 규칙 정리 */
@media (max-width: 767px) { /* 768px 미만으로 명확히 분리 */
    .grid-container {
        grid-template-columns: repeat(2, 1fr);
    }
    main {
        padding: 20px 10px; /* 모바일 여백 */
    }
    /* vw 단위가 기본값이므로 모바일 h1, h2 별도 지정 불필요 */
}


@media (max-width: 580px) {
    /* (기존) 카드 그리드 1열 변경 코드 */
    .grid-container {
        grid-template-columns: 1fr;
        max-width: 270px; /* 좁아진 폭에 맞춰 설정 */
        margin: 0 auto;
    }

    /* [수정] 좁아진 카드 폭에 맞춰 내부 여백과 폰트 크기 축소 */
    .card-back {
        padding: 10px; /* 패딩을 15px -> 10px로 줄여 내부 공간 확보 */
    }

    .card-back h3 {
        font-size: 1.1rem; /* 제목 크기 1.3rem -> 1.1rem로 축소 */
        margin-bottom: 8px;
        word-break: keep-all; /* 단어 중간에 줄바꿈 방지 (선택사항) */
    }

    .card-back p {
        font-size: 0.85rem; /* 본문 크기 0.95rem -> 0.85rem로 축소 */
        line-height: 1.5;   /* 줄 간격도 약간 좁힘 */
    }

    /* [신규] 채팅 전송 버튼 스타일 조정 (기존 유지) */
    .chat-form button {
        font-size: 0.9rem;
        padding: 0 15px;
        white-space: nowrap;
    }
    .card-front-title {
        font-size: 1.2rem; /* 모바일에서는 1.7rem이 너무 크므로 약간 축소 */
        top: 12px;
        left: 12px;
        max-width: 50%; /* 모바일은 좁으므로 너비 제한을 조금 더 여유 있게(50%) */
    }
}