/*
 * 파일명: faq_layouts.css
 * 위치: /wp-content/plugins/wp-auto-posting/assets/css/layouts/
 * 기능: FAQ 레이아웃 전용 스타일 (레이아웃 1~10)
 * 작성일: 2025-06-20
 * 수정일: 2025-09-08
 */

/* ===================================
 * FAQ 레이아웃 공통 스타일
 * =================================== */

/* ======== FAQ 섹션 기본 구조 ======== */
.wpap-faq-section {
    margin-bottom: 1.5rem !important;
    clear: both !important;
}

.wpap-faq-container {
    position: relative !important;
    z-index: 1 !important;
}

/* ======== FAQ 제목 공통 스타일 ======== */
.wpap-faq-title.wpap-section-title {
    font-size: 1.5rem !important;
    margin-top: 0 !important;
    margin-bottom: 20px !important;
    color: #333 !important;
    font-weight: 600 !important;
    line-height: 1.2 !important;
    text-align: left !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
    display: block !important;
    box-sizing: border-box !important;
}

/* ===================================
 * FAQ 레이아웃 1: 클래식 박스 스타일 (테마 색상 적용)
 * =================================== */

/* ======== 레이아웃 1: 컨테이너 스타일 ======== */
[class*="wpap-faq-classic-"] {
    background-color: #ffffff !important;
    border: 2px solid var(--theme-primary, #0073aa) !important;
    border-radius: 10px !important;
    padding: 25px !important;
    box-shadow: 0 4px 15px var(--theme-shadow, rgba(0, 115, 170, 0.1)) !important;
}

/* ---- 클래식 항목들 래퍼 ---- */
[class*="wpap-faq-classic-"] .wpap-faq-items.wpap-classic-wrapper {
    display: flex !important;
    flex-direction: column !important;
    gap: 20px !important;
}

/* ---- 개별 클래식 항목 ---- */
[class*="wpap-faq-classic-"] .wpap-faq-item.wpap-classic-item {
    border: 1px solid var(--theme-primary-light, #e3f2fd) !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    background-color: #ffffff !important;
}

/* ======== 레이아웃 1: 질문 영역 스타일 ======== */
[class*="wpap-faq-classic-"] .wpap-faq-question.wpap-classic-question {
    background: var(--theme-primary, #0073aa) !important;
    color: white !important;
    padding: 15px 20px !important;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
}

/* ---- 질문 번호 뱃지 ---- */
[class*="wpap-faq-classic-"] .wpap-question-number {
    background-color: rgba(255, 255, 255, 0.2) !important;
    color: white !important;
    padding: 4px 8px !important;
    border-radius: 50% !important;
    font-weight: 700 !important;
    font-size: 0.9rem !important;
    min-width: 30px !important;
    text-align: center !important;
}

/* ---- 질문 텍스트 ---- */
[class*="wpap-faq-classic-"] .wpap-question-text {
    flex: 1 !important;
    font-weight: 600 !important;
    font-size: 1.1rem !important;
}

/* ======== 레이아웃 1: 답변 영역 스타일 ======== */
[class*="wpap-faq-classic-"] .wpap-faq-answer.wpap-classic-answer {
    padding: 20px !important;
    background-color: #ffffff !important;
}

/* ---- 답변 내용 ---- */
[class*="wpap-faq-classic-"] .wpap-faq-answer-content.wpap-classic-content {
    color: var(--theme-text, #333) !important;
    line-height: 1.6 !important;
    border-left: 4px solid var(--theme-primary-light, #e3f2fd) !important;
    padding-left: 15px !important;
}

/* ===================================
 * FAQ 레이아웃 2: 목록 스타일
 * =================================== */

/* ======== 레이아웃 2: 컨테이너 스타일 ======== */
[class*="wpap-faq-list-"] {
    background-color: #fff !important;
    border: 1px solid #e9ecef !important;
    border-radius: 8px !important;
    padding: 25px !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05) !important;
}

/* ---- 목록 항목들 래퍼 ---- */
[class*="wpap-faq-list-"] .wpap-faq-items.wpap-list-wrapper {
    display: flex !important;
    flex-direction: column !important;
    gap: 25px !important;
}

/* ---- 개별 목록 항목 ---- */
[class*="wpap-faq-list-"] .wpap-faq-item.wpap-list-item {
    padding-bottom: 20px !important;
    border-bottom: 1px solid #f1f1f1 !important;
}

[class*="wpap-faq-list-"] .wpap-faq-item.wpap-list-item:last-child {
    border-bottom: none !important;
    padding-bottom: 0 !important;
}

/* ======== 레이아웃 2: 질문 및 답변 스타일 ======== */
[class*="wpap-faq-list-"] .wpap-faq-question.wpap-list-question {
    margin: 0 0 10px 0 !important;
    font-size: 1.1rem !important;
    color: #4a6ea9 !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
}

[class*="wpap-faq-list-"] .wpap-faq-answer-content.wpap-list-content {
    padding-left: 20px !important;
    border-left: 3px solid #f1f1f1 !important;
    color: #555 !important;
    line-height: 1.6 !important;
}

/* ===================================
 * FAQ 레이아웃 3: 평범한 박스 스타일
 * =================================== */

/* ======== 레이아웃 3: 컨테이너 스타일 ======== */
[class*="wpap-faq-simple-"] {
    background-color: #f8f9fa !important;
    border-radius: 8px !important;
    padding: 25px !important;
    border: 1px solid #e9ecef !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05) !important;
}

/* ---- 개별 박스 항목 ---- */
[class*="wpap-faq-simple-"] .wpap-faq-item.wpap-simple-item {
    background-color: #ffffff !important;
    margin-bottom: 20px !important;
    border-radius: 8px !important;
    border: 1px solid #dee2e6 !important;
    overflow: hidden !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05) !important;
}

[class*="wpap-faq-simple-"] .wpap-faq-item.wpap-simple-item:last-child {
    margin-bottom: 0 !important;
}

/* ======== 레이아웃 3: 질문 영역 (Q 박스) ======== */
[class*="wpap-faq-simple-"] .wpap-faq-question.wpap-simple-question {
    background-color: #4a6fc0 !important;
    color: white !important;
    padding: 15px 20px !important;
    display: flex !important;
    align-items: center !important;
}

/* ---- 질문 번호 라벨 ---- */
[class*="wpap-faq-simple-"] .wpap-question-number {
    background-color: rgba(255, 255, 255, 0.2) !important;
    color: white !important;
    padding: 4px 8px !important;
    border-radius: 4px !important;
    font-weight: 600 !important;
    font-size: 0.9rem !important;
    margin-right: 12px !important;
    flex-shrink: 0 !important;
}

/* ---- 질문 텍스트 ---- */
[class*="wpap-faq-simple-"] .wpap-question-text {
    flex: 1 !important;
    font-weight: 500 !important;
    font-size: 1rem !important;
    line-height: 1.4 !important;
}

/* ======== 레이아웃 3: 답변 영역 (A 박스) ======== */
[class*="wpap-faq-simple-"] .wpap-faq-answer.wpap-simple-answer {
    padding: 20px !important;
    background-color: #ffffff !important;
    display: flex !important;
    align-items: flex-start !important;
}

/* ---- 답변 라벨 ---- */
[class*="wpap-faq-simple-"] .wpap-answer-label {
    background-color: #28a745 !important;
    color: white !important;
    padding: 4px 8px !important;
    border-radius: 4px !important;
    font-weight: 600 !important;
    font-size: 0.9rem !important;
    margin-right: 15px !important;
    flex-shrink: 0 !important;
    margin-top: 2px !important;
}

/* ---- 답변 내용 ---- */
[class*="wpap-faq-simple-"] .wpap-answer-content {
    flex: 1 !important;
    color: #555 !important;
    line-height: 1.6 !important;
}

/* ===================================
 * FAQ 레이아웃 4: 대화형 버블 스타일
 * =================================== */

/* ======== 레이아웃 4: 컨테이너 스타일 ======== */
[class*="wpap-faq-bubble-"] {
    background-color: #f8f9fa;
    padding: 25px;
    border-radius: 12px;
    border: 1px solid #e9ecef;
}

/* ---- 채팅 컨테이너 ---- */
[class*="wpap-faq-bubble-"] .wpap-chat-container {
    max-width: 700px;
    margin: 0 auto;
}

/* ---- 대화 항목 간격 ---- */
[class*="wpap-faq-bubble-"] .wpap-conversation-item {
    margin-bottom: 25px;
}

[class*="wpap-faq-bubble-"] .wpap-conversation-item:last-child {
    margin-bottom: 0;
}

/* ======== 레이아웃 4: 질문 버블 (오른쪽 정렬) ======== */
[class*="wpap-faq-bubble-"] .wpap-question-bubble.wpap-user-bubble {
    display: flex;
    justify-content: flex-end;
    align-items: flex-start;
    margin-bottom: 15px;
    gap: 12px;
}

/* ---- 사용자 버블 내용 ---- */
[class*="wpap-faq-bubble-"] .wpap-user-bubble .wpap-bubble-content {
    background-color: #4a6fc0;
    color: white;
    padding: 12px 18px;
    border-radius: 20px 20px 5px 20px;
    max-width: 70%;
    font-weight: 500;
    box-shadow: 0 2px 8px rgba(74, 111, 192, 0.2);
}

/* ---- 사용자 아바타 ---- */
[class*="wpap-faq-bubble-"] .wpap-user-avatar {
    width: 35px;
    height: 35px;
    background-color: #4a6fc0;
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    font-size: 0.9rem;
    flex-shrink: 0;
}

/* ======== 레이아웃 4: 답변 버블 (왼쪽 정렬) ======== */
[class*="wpap-faq-bubble-"] .wpap-answer-bubble.wpap-bot-bubble {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 12px;
}

/* ---- 봇 버블 내용 ---- */
[class*="wpap-faq-bubble-"] .wpap-bot-bubble .wpap-bubble-content {
    background-color: #ffffff;
    color: #333;
    padding: 12px 18px;
    border-radius: 20px 20px 20px 5px;
    max-width: 70%;
    border: 1px solid #e9ecef;
    line-height: 1.6;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

/* ---- 봇 아바타 ---- */
[class*="wpap-faq-bubble-"] .wpap-bot-avatar {
    width: 35px;
    height: 35px;
    background-color: #28a745;
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    font-size: 0.9rem;
    flex-shrink: 0;
}

/* ===================================
 * FAQ 레이아웃 5: 모던 그라데이션 카드 스타일 (테마 색상 적용)
 * =================================== */

/* ======== 레이아웃 5: 컨테이너 스타일 ======== */
[class*="wpap-faq-modern-"] {
    background: var(--theme-gradient-light, linear-gradient(135deg, #f0f7ff, #e8f4f8)) !important;
    border-radius: 15px !important;
    padding: 30px !important;
    box-shadow: 0 8px 25px var(--theme-shadow, rgba(102, 126, 234, 0.2)) !important;
}

/* ---- 모던 항목들 래퍼 ---- */
[class*="wpap-faq-modern-"] .wpap-faq-items.wpap-modern-wrapper {
    display: flex !important;
    flex-direction: column !important;
    gap: 15px !important;
}

/* ---- 개별 모던 항목 ---- */
[class*="wpap-faq-modern-"] .wpap-faq-item.wpap-modern-item {
    background-color: rgba(255, 255, 255, 0.9) !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    backdrop-filter: blur(10px) !important;
    border: 1px solid rgba(255, 255, 255, 0.3) !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1) !important;
}

/* ======== 레이아웃 5: 질문 영역 스타일 ======== */
[class*="wpap-faq-modern-"] .wpap-faq-question.wpap-modern-question {
    background: var(--theme-gradient, linear-gradient(135deg, #667eea, #764ba2)) !important;
    color: white !important;
    padding: 18px 25px !important;
    display: flex !important;
    align-items: center !important;
    gap: 15px !important;
}

/* ---- 질문 아이콘 ---- */
[class*="wpap-faq-modern-"] .wpap-question-icon {
    font-size: 1.5rem !important;
    flex-shrink: 0 !important;
}

/* ---- 질문 텍스트 ---- */
[class*="wpap-faq-modern-"] .wpap-question-text {
    flex: 1 !important;
    font-weight: 600 !important;
    font-size: 1.1rem !important;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1) !important;
}

/* ======== 레이아웃 5: 답변 영역 스타일 ======== */
[class*="wpap-faq-modern-"] .wpap-faq-answer.wpap-modern-answer {
    padding: 25px !important;
    background: linear-gradient(145deg, #ffffff, #f8f9ff) !important;
}

/* ---- 답변 내용 ---- */
[class*="wpap-faq-modern-"] .wpap-faq-answer-content.wpap-modern-content {
    color: #444 !important;
    line-height: 1.7 !important;
    font-size: 1rem !important;
    position: relative !important;
}


/* ===================================
 * FAQ 레이아웃 6: 심플 아코디언 스타일
 * =================================== */

/* ======== 레이아웃 6: 컨테이너 스타일 ======== */
[class*="wpap-faq-simple-accordion-"] {
    background-color: #ffffff;
    padding: 25px;
    border-radius: 8px;
    border: 1px solid #e9ecef;
}

/* ---- 심플 아코디언 항목 ---- */
[class*="wpap-faq-simple-accordion-"] .wpap-faq-item.wpap-simple-accordion-item {
    margin-bottom: 15px;
    border: 1px solid #f0f0f0;
    border-radius: 6px;
    overflow: hidden;
}

[class*="wpap-faq-simple-accordion-"] .wpap-faq-item.wpap-simple-accordion-item:last-child {
    margin-bottom: 0;
}

/* ======== 레이아웃 6: 질문 및 답변 영역 ======== */
[class*="wpap-faq-simple-accordion-"] .wpap-faq-question.wpap-simple-question {
    background-color: #f8f9fa;
    padding: 15px;
    margin: 0;
    font-weight: 600;
    color: #333;
    border-bottom: 1px solid #e9ecef;
}

[class*="wpap-faq-simple-accordion-"] .wpap-faq-answer.wpap-simple-answer {
    padding: 15px;
    background-color: #ffffff;
    color: #555;
    line-height: 1.6;
}

/* ===================================
 * FAQ 레이아웃 7: 번호형 리스트 스타일
 * =================================== */

/* ======== 레이아웃 7: 컨테이너 스타일 ======== */
[class*="wpap-faq-numbered-"] {
    background-color: #ffffff;
    padding: 25px;
    border-radius: 8px;
    border: 1px solid #e9ecef;
}

/* ---- 번호형 항목 레이아웃 ---- */
[class*="wpap-faq-numbered-"] .wpap-faq-item.wpap-numbered-item {
    display: flex;
    margin-bottom: 25px;
    align-items: flex-start;
}

[class*="wpap-faq-numbered-"] .wpap-faq-item.wpap-numbered-item:last-child {
    margin-bottom: 0;
}

/* ======== 레이아웃 7: 번호 뱃지 및 내용 ======== */
/* ---- 번호 뱃지 (원형) ---- */
[class*="wpap-faq-numbered-"] .wpap-number-badge {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    background-color: #4a6fc0;
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    margin-right: 20px;
    margin-top: 5px;
}

/* ---- 내용 래퍼 ---- */
[class*="wpap-faq-numbered-"] .wpap-content-wrapper {
    flex: 1;
}

/* ---- 번호형 질문 ---- */
[class*="wpap-faq-numbered-"] .wpap-faq-question.wpap-numbered-question {
    font-weight: 600;
    color: #333;
    margin-bottom: 10px;
    font-size: 1.1rem;
}

/* ---- 번호형 답변 ---- */
[class*="wpap-faq-numbered-"] .wpap-faq-answer.wpap-numbered-answer {
    color: #555;
    line-height: 1.6;
}

/* ===================================
 * FAQ 레이아웃 8: 카드형 FAQ
 * =================================== */

/* ======== 레이아웃 8: 컨테이너 스타일 ======== */
[class*="wpap-faq-card-grid-"] {
    background-color: #f8f9fa;
    padding: 25px;
    border-radius: 8px;
}

/* ---- 카드 그리드 레이아웃 ---- */
[class*="wpap-faq-card-grid-"] .wpap-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 20px;
}

/* ---- 개별 FAQ 카드 ---- */
[class*="wpap-faq-card-grid-"] .wpap-faq-card {
    background-color: #ffffff;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    border: 1px solid #e9ecef;
}

/* ======== 레이아웃 8: 카드 헤더 및 바디 ======== */
/* ---- 카드 헤더 (질문 영역) ---- */
[class*="wpap-faq-card-grid-"] .wpap-card-header {
    background-color: #4a6fc0;
    padding: 15px;
}

[class*="wpap-faq-card-grid-"] .wpap-faq-question.wpap-card-question {
    color: white;
    font-weight: 600;
    margin: 0;
    line-height: 1.4;
}

/* ---- 카드 바디 (답변 영역) ---- */
[class*="wpap-faq-card-grid-"] .wpap-card-body {
    padding: 15px;
}

[class*="wpap-faq-card-grid-"] .wpap-faq-answer.wpap-card-answer {
    color: #555;
    line-height: 1.6;
}

/* ===================================
 * FAQ 레이아웃 9: 구분선 목록 스타일
 * =================================== */

/* ======== 레이아웃 9: 컨테이너 스타일 ======== */
[class*="wpap-faq-divider-"] {
    background-color: #ffffff !important;
    border: 2px solid #e3f2fd !important;
    border-radius: 12px !important;
    padding: 30px !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08) !important;
}

/* ---- 구분선 항목들 래퍼 ---- */
[class*="wpap-faq-divider-"] .wpap-faq-items.wpap-divider-wrapper {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
}

/* ---- 개별 구분선 항목 ---- */
[class*="wpap-faq-divider-"] .wpap-faq-item.wpap-divider-item {
    padding: 25px 0 !important;
    border-bottom: 2px solid #f5f5f5 !important;
    position: relative !important;
}

[class*="wpap-faq-divider-"] .wpap-faq-item.wpap-divider-item:last-child {
    border-bottom: none !important;
    padding-bottom: 0 !important;
}

[class*="wpap-faq-divider-"] .wpap-faq-item.wpap-divider-item:first-child {
    padding-top: 0 !important;
}

/* ======== 레이아웃 9: 질문 영역 (Q 라벨) ======== */
[class*="wpap-faq-divider-"] .wpap-faq-question.wpap-divider-question {
    margin: 0 0 15px 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
}

/* ---- 질문 번호 라벨 (그라데이션) ---- */
[class*="wpap-faq-divider-"] .wpap-question-number {
    background: linear-gradient(135deg, #2196f3, #1976d2) !important;
    color: white !important;
    padding: 8px 12px !important;
    border-radius: 20px !important;
    font-weight: 700 !important;
    font-size: 0.9rem !important;
    flex-shrink: 0 !important;
    min-width: 45px !important;
    text-align: center !important;
    box-shadow: 0 2px 6px rgba(33, 150, 243, 0.3) !important;
}

/* ---- 질문 텍스트 ---- */
[class*="wpap-faq-divider-"] .wpap-question-text {
    font-size: 1.15rem !important;
    color: #1565c0 !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
    flex: 1 !important;
}

/* ======== 레이아웃 9: 답변 영역 (A 라벨) ======== */
[class*="wpap-faq-divider-"] .wpap-faq-answer.wpap-divider-answer {
    display: flex !important;
    align-items: flex-start !important;
    gap: 12px !important;
    margin-left: 57px !important;
}

/* ---- 답변 라벨 (그라데이션) ---- */
[class*="wpap-faq-divider-"] .wpap-answer-label {
    background: linear-gradient(135deg, #4caf50, #388e3c) !important;
    color: white !important;
    padding: 8px 12px !important;
    border-radius: 20px !important;
    font-weight: 700 !important;
    font-size: 0.9rem !important;
    flex-shrink: 0 !important;
    min-width: 35px !important;
    text-align: center !important;
    box-shadow: 0 2px 6px rgba(76, 175, 80, 0.3) !important;
    margin-top: 2px !important;
}

/* ---- 답변 내용 (배경 박스) ---- */
[class*="wpap-faq-divider-"] .wpap-faq-answer-content.wpap-divider-content {
    flex: 1 !important;
    color: #424242 !important;
    line-height: 1.7 !important;
    font-size: 1rem !important;
    background-color: #fafafa !important;
    padding: 15px 20px !important;
    border-radius: 8px !important;
    border-left: 4px solid #e8f5e8 !important;
}

/* ===================================
 * FAQ 레이아웃 10: 타임라인 스타일
 * =================================== */

/* ======== 레이아웃 10: 컨테이너 스타일 ======== */
[class*="wpap-faq-timeline-"] {
    background-color: #ffffff;
    padding: 25px;
    border-radius: 8px;
    border: 1px solid #e9ecef;
}

/* ---- 타임라인 컨테이너 ---- */
[class*="wpap-faq-timeline-"] .wpap-timeline-container {
    position: relative;
    padding-left: 30px;
}

/* ---- 타임라인 세로선 ---- */
[class*="wpap-faq-timeline-"] .wpap-timeline-container::before {
    content: '';
    position: absolute;
    left: 15px;
    top: 20px;
    bottom: 20px;
    width: 2px;
    background-color: #e9ecef;
}

/* ---- 개별 타임라인 항목 ---- */
[class*="wpap-faq-timeline-"] .wpap-timeline-item {
    position: relative;
    margin-bottom: 30px;
}

[class*="wpap-faq-timeline-"] .wpap-timeline-item:last-child {
    margin-bottom: 0;
}

/* ======== 레이아웃 10: 타임라인 마커 및 내용 ======== */
/* ---- 타임라인 마커 (원형 점) ---- */
[class*="wpap-faq-timeline-"] .wpap-timeline-marker {
    position: absolute;
    left: -23px;
    top: 10px;
    width: 16px;
    height: 16px;
    background-color: #4a6fc0;
    border-radius: 50%;
    border: 3px solid #ffffff;
    box-shadow: 0 0 0 2px #4a6fc0;
}

/* ---- 타임라인 내용 박스 ---- */
[class*="wpap-faq-timeline-"] .wpap-timeline-content {
    background-color: #f8f9fa;
    padding: 20px;
    border-radius: 8px;
    border: 1px solid #e9ecef;
}

/* ---- 타임라인 질문 ---- */
[class*="wpap-faq-timeline-"] .wpap-faq-question.wpap-timeline-question {
    font-weight: 600;
    color: #333;
    margin-bottom: 10px;
    font-size: 1.1rem;
}

/* ---- 타임라인 답변 ---- */
[class*="wpap-faq-timeline-"] .wpap-faq-answer.wpap-timeline-answer {
    color: #555;
    line-height: 1.6;
}

/* ===================================
 * 반응형 스타일 - 태블릿 (768px 이하)
 * =================================== */

@media (max-width: 768px) {
    /* ======== 레이아웃 1: 클래식 박스 반응형 ======== */
    /* ---- 클래식 컨테이너 패딩 축소 ---- */
    [class*="wpap-faq-classic-"] {
        padding: 20px !important;
    }
    
    /* ---- 클래식 항목 간격 축소 ---- */
    [class*="wpap-faq-classic-"] .wpap-faq-items.wpap-classic-wrapper {
        gap: 15px !important;
    }
    
    /* ---- 클래식 질문 영역 패딩 축소 ---- */
    [class*="wpap-faq-classic-"] .wpap-faq-question.wpap-classic-question {
        padding: 12px 15px !important;
        gap: 10px !important;
    }
    
    /* ---- 클래식 답변 영역 패딩 축소 ---- */
    [class*="wpap-faq-classic-"] .wpap-faq-answer.wpap-classic-answer {
        padding: 15px !important;
    }
    
    /* ======== 레이아웃 2: 목록 스타일 반응형 ======== */
    /* ---- 목록 스타일 패딩 축소 ---- */
    [class*="wpap-faq-list-"] {
        padding: 20px !important;
    }
    
    /* ======== 레이아웃 3: 박스 스타일 반응형 ======== */
    /* ---- 박스 스타일 세로 배치 ---- */
    [class*="wpap-faq-simple-"] {
        padding: 20px !important;
    }
    
    [class*="wpap-faq-simple-"] .wpap-faq-question.wpap-simple-question {
        padding: 12px 15px !important;
        flex-direction: column !important;
        align-items: flex-start !important;
    }
    
    [class*="wpap-faq-simple-"] .wpap-question-number {
        margin-right: 0 !important;
        margin-bottom: 8px !important;
    }
    
    [class*="wpap-faq-simple-"] .wpap-faq-answer.wpap-simple-answer {
        padding: 15px !important;
        flex-direction: column !important;
    }
    
    [class*="wpap-faq-simple-"] .wpap-answer-label {
        margin-right: 0 !important;
        margin-bottom: 10px !important;
        margin-top: 0 !important;
        align-self: flex-start !important;
    }
    
    /* ======== 레이아웃 4: 버블 스타일 반응형 ======== */
    /* ---- 버블 스타일 패딩 축소 ---- */
    [class*="wpap-faq-bubble-"] {
        padding: 20px;
    }
    
    [class*="wpap-faq-bubble-"] .wpap-user-bubble .wpap-bubble-content,
    [class*="wpap-faq-bubble-"] .wpap-bot-bubble .wpap-bubble-content {
        max-width: 85%;
        padding: 10px 15px;
        font-size: 0.9rem;
    }
    
    [class*="wpap-faq-bubble-"] .wpap-user-avatar,
    [class*="wpap-faq-bubble-"] .wpap-bot-avatar {
        width: 30px;
        height: 30px;
        font-size: 0.8rem;
    }
    
    /* ======== 레이아웃 5: 모던 그라데이션 반응형 ======== */
    /* ---- 모던 컨테이너 패딩 축소 ---- */
    [class*="wpap-faq-modern-"] {
        padding: 25px 20px !important;
    }
    
    /* ---- 모던 질문 영역 패딩 축소 ---- */
    [class*="wpap-faq-modern-"] .wpap-faq-question.wpap-modern-question {
        padding: 15px 20px !important;
        gap: 12px !important;
    }
    
    /* ---- 모던 답변 영역 패딩 축소 ---- */
    [class*="wpap-faq-modern-"] .wpap-faq-answer.wpap-modern-answer {
        padding: 20px !important;
    }
    
    /* ======== 레이아웃 6: 심플 아코디언 반응형 ======== */
    /* ---- 심플 아코디언 패딩 축소 ---- */
    [class*="wpap-faq-simple-accordion-"] {
        padding: 20px;
    }
    
    [class*="wpap-faq-simple-accordion-"] .wpap-faq-question.wpap-simple-question,
    [class*="wpap-faq-simple-accordion-"] .wpap-faq-answer.wpap-simple-answer {
        padding: 12px;
    }
    
    /* ======== 레이아웃 7: 번호형 리스트 반응형 ======== */
    /* ---- 번호형 리스트 세로 배치 ---- */
    [class*="wpap-faq-numbered-"] {
        padding: 20px;
    }
    
    [class*="wpap-faq-numbered-"] .wpap-faq-item.wpap-numbered-item {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }
    
    [class*="wpap-faq-numbered-"] .wpap-number-badge {
        margin-right: 0;
        margin-bottom: 15px;
        margin-top: 0;
    }
    
    /* ======== 레이아웃 8: 카드형 반응형 ======== */
    /* ---- 카드형 1열 배치 ---- */
    [class*="wpap-faq-card-grid-"] {
        padding: 20px;
    }
    
    [class*="wpap-faq-card-grid-"] .wpap-card-grid {
        grid-template-columns: 1fr;
        gap: 15px;
    }
    
    /* ======== 레이아웃 9: 구분선 목록 반응형 ======== */
    /* ---- 구분선 목록 반응형 ---- */
    [class*="wpap-faq-divider-"] {
        padding: 25px 20px !important;
    }
    
    [class*="wpap-faq-divider-"] .wpap-faq-item.wpap-divider-item {
        padding: 20px 0 !important;
    }
    
    [class*="wpap-faq-divider-"] .wpap-faq-question.wpap-divider-question {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 10px !important;
    }
    
    [class*="wpap-faq-divider-"] .wpap-faq-answer.wpap-divider-answer {
        flex-direction: column !important;
        margin-left: 0 !important;
        gap: 10px !important;
    }
    
    [class*="wpap-faq-divider-"] .wpap-answer-label {
        align-self: flex-start !important;
        margin-top: 0 !important;
    }
    
    /* ======== 레이아웃 10: 타임라인 반응형 ======== */
    /* ---- 타임라인 패딩 축소 ---- */
    [class*="wpap-faq-timeline-"] {
        padding: 20px;
    }
    
    [class*="wpap-faq-timeline-"] .wpap-timeline-container {
        padding-left: 25px;
    }
    
    [class*="wpap-faq-timeline-"] .wpap-timeline-content {
        padding: 15px;
    }
    
    /* ======== FAQ 공통 반응형 ======== */
    /* ---- FAQ 공통 제목 크기 조정 ---- */
    .wpap-faq-title.wpap-section-title {
        font-size: 1.3rem !important;
    }
}

/* ===================================
 * 반응형 스타일 - 모바일 (576px 이하)
 * =================================== */

@media (max-width: 576px) {
    /* ======== 레이아웃 1: 클래식 박스 모바일 ======== */
    /* ---- 클래식 더 작은 패딩 ---- */
    [class*="wpap-faq-classic-"] {
        padding: 15px !important;
    }
    
    /* ---- 클래식 질문 텍스트 크기 조정 ---- */
    [class*="wpap-faq-classic-"] .wpap-question-text {
        font-size: 1rem !important;
    }
    
    /* ---- 클래식 답변 내용 크기 조정 ---- */
    [class*="wpap-faq-classic-"] .wpap-faq-answer-content.wpap-classic-content {
        font-size: 0.9rem !important;
        padding-left: 12px !important;
    }
    
    /* ======== 레이아웃 2: 목록 스타일 모바일 ======== */
    /* ---- 목록 더 작은 패딩 ---- */
    [class*="wpap-faq-list-"] {
        padding: 15px !important;
    }
    
    [class*="wpap-faq-list-"] .wpap-faq-question.wpap-list-question {
        font-size: 1rem !important;
        margin-bottom: 8px !important;
    }
    
    [class*="wpap-faq-list-"] .wpap-faq-answer-content.wpap-list-content {
        padding-left: 15px !important;
        font-size: 0.9rem !important;
    }
    
    /* ======== 레이아웃 3: 박스 스타일 모바일 ======== */
    /* ---- 박스 더 작은 패딩 ---- */
    [class*="wpap-faq-simple-"] {
        padding: 15px !important;
    }
    
    [class*="wpap-faq-simple-"] .wpap-faq-question.wpap-simple-question {
        padding: 10px 12px !important;
    }
    
    [class*="wpap-faq-simple-"] .wpap-question-text {
        font-size: 0.95rem !important;
    }
    
    [class*="wpap-faq-simple-"] .wpap-faq-answer.wpap-simple-answer {
        padding: 12px !important;
    }
    
    [class*="wpap-faq-simple-"] .wpap-answer-content {
        font-size: 0.9rem !important;
    }
    
    /* ======== 레이아웃 4: 버블 스타일 모바일 ======== */
    /* ---- 버블 더 작은 패딩 ---- */
    [class*="wpap-faq-bubble-"] {
        padding: 15px;
    }
    
    [class*="wpap-faq-bubble-"] .wpap-user-bubble .wpap-bubble-content,
    [class*="wpap-faq-bubble-"] .wpap-bot-bubble .wpap-bubble-content {
        max-width: 90%;
        padding: 8px 12px;
        font-size: 0.85rem;
    }
    
    [class*="wpap-faq-bubble-"] .wpap-conversation-item {
        margin-bottom: 20px;
    }
    
    /* ======== 레이아웃 5: 모던 그라데이션 모바일 ======== */
    /* ---- 모던 더 작은 패딩 ---- */
    [class*="wpap-faq-modern-"] {
        padding: 20px 15px !important;
    }
    
    /* ---- 모던 질문 아이콘 크기 축소 ---- */
    [class*="wpap-faq-modern-"] .wpap-question-icon {
        font-size: 1.3rem !important;
    }
    
    /* ---- 모던 질문 텍스트 크기 조정 ---- */
    [class*="wpap-faq-modern-"] .wpap-question-text {
        font-size: 1rem !important;
    }
    
    /* ---- 모던 답변 내용 크기 조정 ---- */
    [class*="wpap-faq-modern-"] .wpap-faq-answer-content.wpap-modern-content {
        font-size: 0.9rem !important;
    }
    
    /* ======== 레이아웃 6~10: 새로운 레이아웃 모바일 ======== */
    /* ---- 모든 새 레이아웃 더 작은 패딩 ---- */
    [class*="wpap-faq-simple-accordion-"],
    [class*="wpap-faq-numbered-"],
    [class*="wpap-faq-card-grid-"],
    [class*="wpap-faq-timeline-"] {
        padding: 15px;
    }
    
    /* ---- 번호형 뱃지 크기 축소 ---- */
    [class*="wpap-faq-numbered-"] .wpap-number-badge {
        width: 35px;
        height: 35px;
        font-size: 0.9rem;
    }
    
    /* ---- 구분선 목록 모바일 최적화 ---- */
    [class*="wpap-faq-divider-"] {
        padding: 20px 15px !important;
    }
    
    [class*="wpap-faq-divider-"] .wpap-question-text {
        font-size: 1.05rem !important;
    }
    
    [class*="wpap-faq-divider-"] .wpap-faq-answer-content.wpap-divider-content {
        padding: 12px 15px !important;
        font-size: 0.95rem !important;
    }
    
    /* ---- 타임라인 마커 조정 ---- */
    [class*="wpap-faq-timeline-"] .wpap-timeline-container {
        padding-left: 20px;
    }
    
    [class*="wpap-faq-timeline-"] .wpap-timeline-marker {
        left: -20px;
        width: 14px;
        height: 14px;
        border-width: 2px;
    }
    
    /* ======== FAQ 공통 모바일 ======== */
    /* ---- FAQ 공통 제목 더 작게 ---- */
    .wpap-faq-title.wpap-section-title {
        font-size: 1.2rem !important;
        margin-bottom: 15px !important;
    }
}

/* ===================================
 * 인쇄용 스타일 (선택사항)
 * =================================== */

@media print {
    /* ======== 모든 FAQ 레이아웃 인쇄 최적화 ======== */
    /* ---- 인쇄용 배경 및 테두리 단순화 ---- */
    [class*="wpap-faq-"] {
        background-color: white !important;
        border: 1px solid #000 !important;
        box-shadow: none !important;
        page-break-inside: avoid;
    }
    
    /* ---- 인터랙티브 요소 숨김 ---- */
    [class*="wpap-faq-"] .wpap-accordion-icon,
    [class*="wpap-faq-"] .wpap-toggle-icon,
    [class*="wpap-faq-"] .wpap-tab-navigation {
        display: none !important;
    }
    
    /* ---- 모든 FAQ 항목 표시 ---- */
    [class*="wpap-faq-"] .wpap-faq-answer-content,
    [class*="wpap-faq-"] .wpap-toggle-content {
        display: block !important;
    }
}