/* =========================================
   1. 참조 CSS 변수 및 기본 설정
   ========================================= */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Noto+Sans+KR:wght@400;500;700&display=swap');

/* 브라우저 기본 스크롤을 부드럽게 설정 */
html {
    scroll-behavior: smooth;
}

:root {
  --navy-900: #0f172a;
  --navy-800: #1e3a8a;
  --primary: #2563eb; 
  --bg-color: #f8fafc;      /* 전체 페이지 배경색 */
  --text-color: #334155;
  
  /* 사이트 전체 너비 및 마진 변수화 */
  --site-width: 896px;      /* 컨테이너 최대 너비 */
  --site-margin: 0 auto 24px; /* 중앙 정렬 및 하단 여백 */

  /* 카드 색상 정의 */
  --card-bg: #ffffff;       /* 카드 본문: 흰색 */
  --header-bg: #f8fafc;     /* 카드 헤더: 은은한 회색 */
  --border-color: #e2e8f0;  /* 테두리 색상 */
  --input-bg: #f8fafc;      /* 입력창 배경: 연한 회색 */
}

body {
    background-color: var(--bg-color);
    color: var(--text-color);
    font-family: 'Inter', 'Noto Sans KR', sans-serif;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;

    /* 우측 스크롤바 숨기기 (기능은 유지됨) */
    -ms-overflow-style: none; /* IE and Edge */
    scrollbar-width: none;  /* Firefox */
}

/* Chrome, Safari, Opera용 스크롤바 숨김 */
body::-webkit-scrollbar {
    display: none;
}

/* 변수 사용으로 일괄 제어 */
.container {
    max-width: var(--site-width); 
    margin: var(--site-margin);
    padding: 0 20px;
}

.content-section {
    padding: 60px 0;
    flex: 1;
}

.header_text h2 {
    color: var(--navy-900);
}

/* =========================================
   2. 헤더 분리형 카드 디자인 (Boxy Style)
   ========================================= */

.section-card {
    max-width: var(--site-width);
    margin: var(--site-margin);
    
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    margin-bottom: 24px; 
    box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
    overflow: hidden;
}

/* 제목 부분 */
.card-header {
    background-color: var(--header-bg);
    padding: 20px 30px;
    border-bottom: 1px solid var(--border-color);
}

.card-header h3 {
    font-size: 18px;
    font-weight: 700;
    color: var(--navy-900);
    margin: 0;
    padding: 0;
    border: none;
}

/* 내용 부분 */
.card-body {
    padding: 30px;
    background-color: #ffffff;
}

/* 폼 레이아웃 */
.form-row {
    display: flex;
    gap: 20px;
    margin-bottom: 24px;
}
.form-col {
    flex: 1;
    min-width: 0;
}
.form-group {
    margin-bottom: 24px;
}

.form-group label {
    display: block;
    margin-bottom: 8px;
    font-weight: 600;
    color: var(--text-color);
    font-size: 16px;
}

.required-mark {
    color: #dc2626;
    margin-left: 2px;
    font-weight: 700;
}

.form-note {
    font-size: 13px;
    color: #64748b;
    margin-top: 6px;
}

/* 입력 필드 스타일 */
input[type="text"],
input[type="email"],
input[type="date"],
input[type="time"],
select {
    width: 100%;
    height: 48px;
    padding: 0 16px;
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    font-size: 15px;
    background-color: var(--input-bg);
    transition: all 0.2s ease-in-out;
    color: var(--navy-900);
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

/* Select 화살표 */
select {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
    background-position: right 0.75rem center;
    background-repeat: no-repeat;
    background-size: 1.25em 1.25em;
    padding-right: 2.5rem;
}

/* option을 지우고 select 태그 자체에 여백 적용 */
select.guest-count {
    padding-left: 12px !important;
    font-size: 15px;
}

input:focus, select:focus {
    border-color: var(--primary);
    background-color: #ffffff;
    outline: none;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.15);
}

/* Itinerary 박스 */
.itinerary-box {
    background-color: #f8fafc;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 24px;
    margin-bottom: 16px;
}

/* Itinerary 내부 라벨 스타일 */
.itinerary-box label {
    font-size: 12px;
    color: #64748b;
    font-weight: 700;
    text-transform: uppercase;
    display: block;
    margin-bottom: 4px;
    letter-spacing: 0.5px;
}

.itinerary-title {
    color: var(--navy-800);
    font-weight: 700;
    font-size: 14px;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.itinerary-title svg {
    color: var(--primary);
}

.radio-group, .checkbox-group {
    display: flex;
    gap: 24px;
    align-items: center;
    margin-top: 8px;
}
.radio-label, .checkbox-label {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    font-size: 15px;
    color: var(--text-color);
}

input[type="radio"], input[type="checkbox"] {
    accent-color: var(--navy-800);
    width: 18px;
    height: 18px;
    cursor: pointer;
    margin: 0;
}

/* 제출 버튼 스타일 */
.submit-btn {
    display: block;           
    width: auto;              
    min-width: 280px;         
    margin: 0 auto;           
    background: var(--primary);
    color: white;
    padding: 16px 40px;       
    font-size: 18px;
    font-weight: 700;
    border: none;
    border-radius: 9999px;
    cursor: pointer;
    transition: background-color 0.2s, transform 0.1s;
    box-shadow: 0 4px 6px -1px rgba(37, 99, 235, 0.2);
}
.submit-btn:hover {
    background-color: var(--navy-800);
}
.submit-btn:active {
    transform: translateY(1px);
}

.error-msg {
    color: #dc2626;
    font-size: 13px;
    margin-top: 6px;
    display: none;
    font-weight: 500;
}

/* 성공 메시지 디자인 */
.success-box {
    background-color: #ffffff;
    border-radius: 20px;
    padding: 50px 40px;
    margin: 50px auto;
    max-width: 550px;
    text-align: center;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
    border: 1px solid #e2e8f0;
    border-top: 6px solid #10b981;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
    animation: slideUpFade 0.7s cubic-bezier(0.16, 1, 0.3, 1) forwards;
    opacity: 0;
    transform: translateY(30px);
}

.success-icon {
    color: #10b981;
    font-size: 64px;
    line-height: 1;
    animation: popIn 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275) 0.2s forwards;
    opacity: 0;
    transform: scale(0.5);
}

.success-content h3 {
    color: #0f172a;
    font-size: 26px;
    margin: 0 0 10px 0;
    font-weight: 800;
    letter-spacing: -0.5px;
}

.success-content p {
    color: #475569;
    font-size: 16px;
    line-height: 1.6;
    margin: 0;
    word-break: keep-all;
}

@keyframes slideUpFade {
    to { opacity: 1; transform: translateY(0); }
}

@keyframes popIn {
    to { opacity: 1; transform: scale(1); }
}

/* 하단 안내 문구 박스 스타일 */
.updates-box {
    max-width: var(--site-width);
    margin: var(--site-margin);
    margin-top: 60px;
    background-color: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 40px;
    text-align: center;
    color: #475569;
    font-size: 14px;
    line-height: 1.6;
}
.updates-box h4 {
    font-size: 14px;
    font-weight: 700;
    color: #1e293b;
    text-transform: uppercase;
    margin-bottom: 20px;
    letter-spacing: 0.5px;
}
.updates-box a {
    color: var(--primary);
    text-decoration: underline;
    font-weight: 600;
}
.updates-box .email-box {
    background-color: #ffffff; 
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    padding: 20px;
    margin: 24px auto;
    max-width: 600px;
}
.updates-box .email-links {
    font-weight: 700;
    color: #0f172a;
    font-size: 15px;
    margin-top: 5px;
}
.updates-box .email-links a {
    color: #0f172a;
    text-decoration: none;
}
.updates-box .email-links a:hover {
    color: var(--primary);
}
.updates-box .sep {
    margin: 0 10px;
    color: #cbd5e1;
}

/* =========================================
   [통합 완료] 모바일 반응형 디자인 (Media Queries)
   화면 폭이 900px 이하(태블릿/모바일)일 때 적용
   ========================================= */
@media (max-width: 900px) {
    
    /* 1. 고정 너비 해제 및 화면 꽉 차게 */
    :root {
        --site-width: 100%;
        --site-margin: 0 auto;
    }

    /* 2. 컨테이너 좌우 여백 */
    .container {
        padding: 0 16px;
        width: 100%;
        box-sizing: border-box;
    }

    /* 3. 그리드 및 폼 배치 변경 (가로 -> 세로) */
    .grid, .grid-cols-2, .grid-cols-12 {
        display: block !important;
    }
    
    .form-row {
        flex-direction: column; /* 위아래로 배치 */
        gap: 16px;
    }
    
    .form-group, .itinerary-box { 
        margin-bottom: 20px; 
    }

    /* 4. 체크박스/라디오 버튼 줄바꿈 허용 */
    .radio-group, .checkbox-group { 
        flex-wrap: wrap; 
        gap: 16px; 
    }

    /* 5. 카드 및 박스 여백 최적화 */
    .section-card {
        margin-bottom: 20px;
        border-radius: 8px;
    }
    .card-body {
        padding: 20px 16px;
    }
    
    .updates-box { 
        padding: 24px; 
    }
    
    /* 6. 이메일 링크 세로 배치 (기존 코드 통합) */
    .email-links { 
        display: flex; 
        flex-direction: column; 
        gap: 8px; 
    }
    .updates-box .sep { 
        display: none; /* 구분선 숨김 */
    }

    /* 7. 폰트 크기 최적화 */
    h1, .text-4xl, .text-5xl {
        font-size: 28px !important; 
        line-height: 1.3;
    }
    h2, .text-2xl {
        font-size: 22px !important;
    }
    p, .text-lg {
        font-size: 15px !important;
        line-height: 1.6;
    }

    /* 8. 입력창 및 버튼 최적화 */
    input[type="text"], 
    input[type="email"], 
    select {
        font-size: 16px; /* 모바일 확대 방지 */
        height: 44px;
    }

    .submit-btn {
        width: 100%;
        min-width: 0;
    }

    /* 9. 이미지 반응형 */
    img {
        max-width: 100%;
        height: auto;
    }
}