/**
 * 프리미엄 AI 사주 분석 - 스타일
 * Getin.kr
 */

/* 컨테이너 */
.premium-container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 1rem;
}

/* 2컬럼 레이아웃 (입력 폼 + 사이드바) */
.form-layout {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 1.5rem;
    align-items: start;
}

@media (max-width: 900px) {
    .form-layout {
        grid-template-columns: 1fr;
    }
    .form-sidebar {
        order: -1;
    }
}

.form-main {
    min-width: 0;
}

/* 사이드바 */
.form-sidebar {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    position: sticky;
    top: 1rem;
}

@media (max-width: 900px) {
    .form-sidebar {
        position: static;
    }
}

.sidebar-card {
    background: linear-gradient(145deg, #f8f7ff, #f3f0ff);
    border: 1px solid rgba(139, 92, 246, 0.2);
    border-radius: 1rem;
    padding: 1.25rem;
    box-shadow: 0 4px 15px rgba(139, 92, 246, 0.1);
}

.dark .sidebar-card {
    background: linear-gradient(145deg, #1a1333, #0f0a1e);
    border-color: rgba(139, 92, 246, 0.25);
}

.sidebar-icon {
    font-size: 2rem;
    text-align: center;
    margin-bottom: 0.75rem;
}

.sidebar-title {
    font-size: 1rem;
    font-weight: 700;
    color: #4c1d95;
    margin-bottom: 0.75rem;
    text-align: center;
}

.dark .sidebar-title {
    color: #c4b5fd;
}

.sidebar-card p {
    font-size: 0.85rem;
    color: #4b5563;
    line-height: 1.5;
    margin: 0 0 0.5rem 0;
    text-align: center;
}

.dark .sidebar-card p {
    color: #cbd5e1;
}

.sidebar-donate-btn {
    display: block;
    width: 100%;
    padding: 0.75rem 1rem;
    background: #fee500;
    color: #000;
    font-weight: 700;
    font-size: 0.9rem;
    text-align: center;
    text-decoration: none;
    border-radius: 0.5rem;
    margin-top: 0.75rem;
    transition: all 0.2s;
}

.sidebar-donate-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(254, 229, 0, 0.4);
}

.sidebar-items {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.25rem 0.5rem;
}

.sidebar-items li {
    font-size: 0.75rem;
    color: #4b5563;
    padding: 0.2rem 0;
}

.dark .sidebar-items li {
    color: #9ca3af;
}

.sidebar-bonus {
    margin-top: 0.75rem !important;
    padding: 0.5rem;
    background: rgba(139, 92, 246, 0.1);
    border-radius: 0.5rem;
    color: #7c3aed !important;
    font-weight: 600;
}

.dark .sidebar-bonus {
    background: rgba(139, 92, 246, 0.15);
    color: #a78bfa !important;
}

/* 후원 사이드바 강조 */
.donation-sidebar {
    background: linear-gradient(145deg, #fef3ff, #fae8ff);
    border-color: rgba(168, 85, 247, 0.25);
}

.dark .donation-sidebar {
    background: linear-gradient(145deg, #2d1a4a, #1a0f2e);
}

/* 헤더 */
.premium-header {
    text-align: center;
    margin-bottom: 2rem;
}

.premium-badge {
    display: inline-block;
    padding: 0.25rem 1rem;
    background: linear-gradient(135deg, #8b5cf6, #6366f1);
    color: white;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 2rem;
    margin-bottom: 1rem;
}

.premium-title {
    font-size: 2rem;
    font-weight: 700;
    background: linear-gradient(135deg, #8b5cf6, #d4af37);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin: 0 0 0.5rem 0;
}

.premium-subtitle {
    color: #6b7280;
    font-size: 1rem;
    margin: 0;
}

.dark .premium-subtitle {
    color: #9ca3af;
}

/* 카드 */
.premium-card {
    background: white;
    border-radius: 1rem;
    padding: 1.5rem;
    margin-bottom: 1rem;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    border: 1px solid rgba(139, 92, 246, 0.1);
}

.dark .premium-card {
    background: #1f2937;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    border-color: rgba(139, 92, 246, 0.2);
}

/* 폼 */
.form-section {
    margin-bottom: 1.5rem;
}

.form-label {
    display: block;
    font-weight: 600;
    color: #374151;
    margin-bottom: 0.5rem;
}

.dark .form-label {
    color: #e5e7eb;
}

.form-label .required {
    color: #8b5cf6;
    font-weight: 500;
    font-size: 0.8rem;
}

.form-input,
.form-select {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1px solid #d1d5db;
    border-radius: 0.5rem;
    font-size: 1rem;
    color: #1f2937;
    background: white;
    transition: border-color 0.2s;
}

.dark .form-input,
.dark .form-select {
    background: #374151;
    border-color: #4b5563;
    color: #f3f4f6;
}

.form-input:focus,
.form-select:focus {
    outline: none;
    border-color: #8b5cf6;
}

.form-hint {
    font-size: 0.8rem;
    color: #9ca3af;
    margin-top: 0.25rem;
}

.date-inputs {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 0.5rem;
}

.calendar-type {
    display: flex;
    gap: 1.5rem;
    margin-top: 0.75rem;
}

.radio-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
    color: #4b5563;
    font-size: 0.9rem;
}

.dark .radio-label {
    color: #9ca3af;
}

/* 성별 버튼 */
.gender-buttons {
    display: flex;
    gap: 1rem;
}

.gender-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 1rem;
    border: 2px solid #e5e7eb;
    border-radius: 0.75rem;
    background: white;
    cursor: pointer;
    transition: all 0.2s;
    font-size: 1rem;
    color: #4b5563;
}

.dark .gender-btn {
    background: #374151;
    border-color: #4b5563;
    color: #9ca3af;
}

.gender-btn:hover {
    border-color: #8b5cf6;
}

.gender-btn.active {
    border-color: #8b5cf6;
    background: rgba(139, 92, 246, 0.1);
    color: #7c3aed;
}

.gender-icon {
    font-size: 1.5rem;
}

/* 분석 항목 미리보기 */
.analysis-preview {
    background: linear-gradient(135deg, #f5f3ff, #ede9fe);
    border-radius: 0.75rem;
    padding: 1rem;
    margin-bottom: 1.5rem;
}

.dark .analysis-preview {
    background: linear-gradient(135deg, #2e1065, #1e1b4b);
}

.preview-title {
    font-weight: 600;
    color: #6d28d9;
    margin-bottom: 0.75rem;
}

.dark .preview-title {
    color: #a78bfa;
}

.preview-items {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.preview-item {
    font-size: 0.8rem;
    color: #5b21b6;
    background: white;
    padding: 0.25rem 0.75rem;
    border-radius: 1rem;
}

.dark .preview-item {
    background: rgba(139, 92, 246, 0.2);
    color: #c4b5fd;
}

/* 분석 버튼 */
.analyze-btn {
    width: 100%;
    padding: 1rem;
    background: linear-gradient(135deg, #8b5cf6, #6366f1);
    color: white;
    border: none;
    border-radius: 0.75rem;
    font-size: 1.1rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s;
}

.analyze-btn:hover:not(:disabled) {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(139, 92, 246, 0.4);
}

.analyze-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.analysis-note {
    text-align: center;
    font-size: 0.8rem;
    color: #9ca3af;
    margin-top: 1rem;
}

/* 분석 진행 중 */
.analyzing-section {
    text-align: center;
    padding: 2rem 0;
}

.analyzing-icon {
    font-size: 4rem;
    animation: pulse 2s ease-in-out infinite;
    margin-bottom: 1rem;
}

@keyframes pulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.1); }
}

.analyzing-title {
    font-size: 1.25rem;
    font-weight: 600;
    color: #374151;
    margin: 0 0 0.5rem 0;
}

.dark .analyzing-title {
    color: #f3f4f6;
}

.analyzing-name {
    color: #8b5cf6;
    font-weight: 500;
    margin-bottom: 2rem;
}

/* 진행 단계 */
.progress-steps {
    max-width: 400px;
    margin: 0 auto 2rem;
    text-align: left;
}

.progress-step {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid #e5e7eb;
}

.dark .progress-step {
    border-bottom-color: #374151;
}

.progress-step:last-child {
    border-bottom: none;
}

.step-icon {
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
    font-weight: 600;
    background: #e5e7eb;
    color: #6b7280;
}

.dark .step-icon {
    background: #374151;
    color: #9ca3af;
}

.progress-step.active .step-icon {
    background: #8b5cf6;
    color: white;
}

.progress-step.completed .step-icon {
    background: #10b981;
    color: white;
}

.step-spinner {
    width: 1rem;
    height: 1rem;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top-color: white;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

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

.step-info {
    flex: 1;
}

.step-name {
    font-weight: 500;
    color: #374151;
    font-size: 0.9rem;
}

.dark .step-name {
    color: #e5e7eb;
}

.progress-step.pending .step-name {
    color: #9ca3af;
}

.step-desc {
    font-size: 0.75rem;
    color: #9ca3af;
}

/* 진행률 바 */
.progress-bar-container {
    height: 8px;
    background: #e5e7eb;
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 0.5rem;
}

.dark .progress-bar-container {
    background: #374151;
}

.progress-bar {
    height: 100%;
    background: linear-gradient(90deg, #8b5cf6, #6366f1);
    border-radius: 4px;
    transition: width 0.5s ease;
}

.progress-text {
    font-size: 0.9rem;
    color: #8b5cf6;
    font-weight: 500;
}

/* 결과 섹션 */
.result-section {
    /* 결과 전체 래퍼 */
}

.result-header {
    background: linear-gradient(135deg, #8b5cf6, #6366f1);
    border-radius: 1rem;
    padding: 1.5rem;
    margin-bottom: 1rem;
    color: white;
}

.result-user {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.result-zodiac {
    font-size: 3rem;
}

.result-name {
    font-size: 1.25rem;
    font-weight: 600;
}

.result-birth {
    opacity: 0.9;
    font-size: 0.9rem;
}

/* 사주팔자 카드 */
.saju-card {
    background: linear-gradient(135deg, #fef3c7, #fde68a);
}

.dark .saju-card {
    background: linear-gradient(135deg, #78350f, #92400e);
}

.card-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #92400e;
    margin: 0 0 1rem 0;
}

.dark .card-title {
    color: #fde68a;
}

.saju-pillars {
    display: flex;
    justify-content: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.pillar {
    text-align: center;
    padding: 1rem;
    background: white;
    border-radius: 0.75rem;
    min-width: 70px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.dark .pillar {
    background: rgba(0, 0, 0, 0.2);
}

.pillar-label {
    font-size: 0.75rem;
    color: #92400e;
    margin-bottom: 0.25rem;
}

.dark .pillar-label {
    color: #fcd34d;
}

.pillar-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: #78350f;
}

.dark .pillar-value {
    color: #fef3c7;
}

.pillar-korean {
    font-size: 0.7rem;
    color: #a16207;
}

.dark .pillar-korean {
    color: #fbbf24;
}

/* 오행 분포 */
.ohang-section {
    padding-top: 1rem;
    border-top: 1px solid rgba(146, 64, 14, 0.2);
}

.subsection-title {
    font-size: 0.9rem;
    font-weight: 600;
    color: #92400e;
    margin: 0 0 0.75rem 0;
}

.dark .subsection-title {
    color: #fcd34d;
}

.ohang-bars {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.ohang-bar-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.ohang-label {
    width: 50px;
    font-size: 0.8rem;
    color: #78350f;
}

.dark .ohang-label {
    color: #fef3c7;
}

.ohang-bar {
    flex: 1;
    height: 12px;
    background: rgba(255, 255, 255, 0.5);
    border-radius: 6px;
    overflow: hidden;
}

.ohang-bar-fill {
    height: 100%;
    border-radius: 6px;
    transition: width 0.5s ease;
}

.ohang-bar-fill.ohang-wood { background: #22c55e; }
.ohang-bar-fill.ohang-fire { background: #ef4444; }
.ohang-bar-fill.ohang-earth { background: #eab308; }
.ohang-bar-fill.ohang-metal { background: #9ca3af; }
.ohang-bar-fill.ohang-water { background: #3b82f6; }

.ohang-count {
    width: 35px;
    font-size: 0.75rem;
    color: #92400e;
    text-align: right;
}

.dark .ohang-count {
    color: #fcd34d;
}

/* 결과 탭 */
.result-tabs {
    display: flex;
    gap: 0.25rem;
    overflow-x: auto;
    padding-bottom: 0.5rem;
    margin-bottom: 1rem;
}

.result-tab {
    flex: 1;
    min-width: max-content;
    padding: 0.75rem 0.5rem;
    border: none;
    border-radius: 0.5rem;
    background: #f3f4f6;
    color: #6b7280;
    font-size: 0.8rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
    white-space: nowrap;
}

.dark .result-tab {
    background: #374151;
    color: #9ca3af;
}

.result-tab:hover {
    background: #e5e7eb;
}

.dark .result-tab:hover {
    background: #4b5563;
}

.result-tab.active {
    background: #8b5cf6;
    color: white;
}

/* 탭 콘텐츠 */
.tab-content {
    min-height: 300px;
}

/* 결과 섹션 박스 */
.result-section-box {
    padding: 1rem;
    background: #f9fafb;
    border-radius: 0.75rem;
    margin-bottom: 1rem;
    border-left: 3px solid #8b5cf6;
}

.dark .result-section-box {
    background: rgba(139, 92, 246, 0.08);
}

.section-title {
    font-size: 1rem;
    font-weight: 600;
    color: #374151;
    margin: 0 0 0.75rem 0;
}

.dark .section-title {
    color: #e5e7eb;
}

.section-content {
    font-size: 0.9rem;
    color: #4b5563;
    line-height: 1.7;
    margin: 0;
}

.dark .section-content {
    color: #d1d5db;
}

/* 일간 정보 */
.ilgan-info {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 0.75rem;
}

.ilgan-name {
    font-size: 1.25rem;
    font-weight: 700;
    color: #8b5cf6;
}

.ilgan-element {
    font-size: 0.9rem;
    color: #6b7280;
}

/* 격국 */
.gyeokguk-name {
    font-size: 1.1rem;
    font-weight: 600;
    color: #6d28d9;
    margin-bottom: 0.5rem;
}

/* 신강/신약 배지 */
.strength-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.5rem 1rem;
    border-radius: 2rem;
    font-weight: 600;
    margin-bottom: 0.75rem;
}

.strength-badge.strong {
    background: #dcfce7;
    color: #166534;
}

.strength-badge.weak {
    background: #fef3c7;
    color: #92400e;
}

/* 용신/기신 그리드 */
.yongsin-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.yongsin-box {
    border-left-color: #10b981;
}

.gisin-box {
    border-left-color: #f59e0b;
}

.yongsin-element {
    font-size: 1.5rem;
    font-weight: 700;
    color: #10b981;
    margin-bottom: 0.5rem;
}

.gisin-element {
    font-size: 1.5rem;
    font-weight: 700;
    color: #f59e0b;
    margin-bottom: 0.5rem;
}

.lucky-info {
    display: flex;
    gap: 1rem;
    margin-top: 0.75rem;
    font-size: 0.85rem;
    color: #059669;
}

/* 성격/재능 */
.highlight-text {
    font-size: 1.1rem;
    font-weight: 600;
    color: #6d28d9;
    margin-bottom: 1.5rem;
    padding: 1rem;
    background: linear-gradient(135deg, #f5f3ff, #ede9fe);
    border-radius: 0.75rem;
}

.dark .highlight-text {
    background: rgba(139, 92, 246, 0.15);
    color: #a78bfa;
}

.trait-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-top: 1rem;
}

.trait-box {
    padding: 1rem;
    border-radius: 0.75rem;
}

.trait-box.strengths {
    background: #dcfce7;
}

.trait-box.weaknesses {
    background: #fef3c7;
}

.dark .trait-box.strengths {
    background: rgba(16, 185, 129, 0.15);
}

.dark .trait-box.weaknesses {
    background: rgba(245, 158, 11, 0.15);
}

.trait-box h5 {
    font-size: 0.9rem;
    font-weight: 600;
    margin: 0 0 0.5rem 0;
}

.trait-box ul {
    margin: 0;
    padding-left: 1.25rem;
    font-size: 0.85rem;
    color: #4b5563;
}

.dark .trait-box ul {
    color: #d1d5db;
}

.trait-box li {
    margin-bottom: 0.25rem;
}

.advice-text {
    margin-top: 0.75rem;
    padding: 0.75rem;
    background: #f0fdf4;
    border-radius: 0.5rem;
    color: #166534;
    font-size: 0.9rem;
}

.dark .advice-text {
    background: rgba(16, 185, 129, 0.1);
    color: #86efac;
}

.talent-list {
    margin: 0;
    padding-left: 1.25rem;
}

.talent-list li {
    margin-bottom: 0.5rem;
    line-height: 1.6;
}

.career-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.career-tag {
    padding: 0.5rem 1rem;
    background: #ede9fe;
    color: #6d28d9;
    border-radius: 2rem;
    font-size: 0.85rem;
}

.dark .career-tag {
    background: rgba(139, 92, 246, 0.2);
    color: #c4b5fd;
}

/* 재물운 */
.level-badge {
    display: inline-block;
    padding: 0.5rem 1.5rem;
    background: linear-gradient(135deg, #fbbf24, #f59e0b);
    color: white;
    font-weight: 700;
    border-radius: 2rem;
    margin-bottom: 0.75rem;
}

.method-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-top: 1rem;
}

.good-methods {
    padding: 0.75rem;
    background: #dcfce7;
    border-radius: 0.5rem;
}

.avoid-methods {
    padding: 0.75rem;
    background: #fee2e2;
    border-radius: 0.5rem;
}

.dark .good-methods {
    background: rgba(16, 185, 129, 0.15);
}

.dark .avoid-methods {
    background: rgba(239, 68, 68, 0.15);
}

.method-list strong {
    display: block;
    font-size: 0.85rem;
    margin-bottom: 0.5rem;
}

.method-list ul {
    margin: 0;
    padding-left: 1rem;
    font-size: 0.8rem;
}

.warning-text {
    margin-top: 0.75rem;
    padding: 0.75rem;
    background: #fef3c7;
    border-radius: 0.5rem;
    color: #92400e;
    font-size: 0.9rem;
}

.dark .warning-text {
    background: rgba(245, 158, 11, 0.15);
    color: #fcd34d;
}

.business-fields {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.75rem;
}

.field-tag {
    padding: 0.25rem 0.75rem;
    background: #e0e7ff;
    color: #4338ca;
    border-radius: 1rem;
    font-size: 0.8rem;
}

.good-period {
    color: #166534;
    margin-bottom: 0.5rem;
}

.caution-period {
    color: #92400e;
}

/* 연애/결혼 */
.small-text {
    font-size: 0.85rem;
    color: #6b7280;
    margin-top: 0.5rem;
}

.spouse-info {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    margin-top: 0.75rem;
    font-size: 0.85rem;
    color: #6b7280;
}

.caution-text {
    color: #dc2626;
}

.advice-box {
    padding: 1rem;
    background: #f0fdf4;
    border-radius: 0.75rem;
    margin-top: 1rem;
}

.advice-box p {
    margin: 0 0 0.5rem 0;
    font-size: 0.9rem;
    color: #166534;
}

.advice-box p:last-child {
    margin-bottom: 0;
}

.dark .advice-box {
    background: rgba(16, 185, 129, 0.1);
}

.dark .advice-box p {
    color: #86efac;
}

/* 건강 */
.constitution-type {
    font-size: 1.1rem;
    font-weight: 600;
    color: #059669;
    margin-bottom: 0.5rem;
}

.vulnerability-item {
    padding: 0.75rem;
    background: #fef2f2;
    border-radius: 0.5rem;
    margin-bottom: 0.5rem;
}

.dark .vulnerability-item {
    background: rgba(239, 68, 68, 0.1);
}

.vulnerability-item strong {
    color: #dc2626;
}

.vulnerability-item p {
    font-size: 0.85rem;
    color: #6b7280;
    margin: 0.25rem 0 0 0;
}

.prevention {
    color: #059669 !important;
}

/* 대운/세운 */
.daeun-header,
.year-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 0.75rem;
}

.daeun-period,
.year-name {
    font-size: 1.1rem;
    font-weight: 600;
    color: #374151;
}

.dark .daeun-period,
.dark .year-name {
    color: #e5e7eb;
}

.daeun-ganzi {
    font-size: 1.25rem;
    font-weight: 700;
    color: #8b5cf6;
}

.year-rating {
    padding: 0.25rem 0.75rem;
    background: #8b5cf6;
    color: white;
    border-radius: 1rem;
    font-size: 0.8rem;
    font-weight: 600;
}

.daeun-details {
    margin-top: 0.75rem;
}

.opportunity {
    color: #059669;
    margin-bottom: 0.25rem;
}

.challenge {
    color: #d97706;
}

.year-theme {
    padding: 0.5rem;
    background: #ede9fe;
    border-radius: 0.5rem;
    color: #6d28d9;
    font-weight: 500;
    margin-bottom: 0.75rem;
}

.monthly-item {
    display: flex;
    gap: 1rem;
    padding: 0.5rem 0;
    border-bottom: 1px solid #e5e7eb;
}

.dark .monthly-item {
    border-bottom-color: #374151;
}

.monthly-item:last-child {
    border-bottom: none;
}

.monthly-item strong {
    min-width: 80px;
    color: #8b5cf6;
}

/* 종합 총평 */
.conclusion-card {
    border: 2px solid #8b5cf6;
}

.keywords-section {
    text-align: center;
    margin-bottom: 1.5rem;
}

.keywords-section h4 {
    font-size: 1rem;
    color: #6d28d9;
    margin: 0 0 0.75rem 0;
}

.keyword-tags {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.keyword-tag {
    padding: 0.5rem 1.5rem;
    background: linear-gradient(135deg, #8b5cf6, #6366f1);
    color: white;
    font-weight: 600;
    border-radius: 2rem;
}

.mission-box {
    border-left-color: #f59e0b;
    background: linear-gradient(135deg, #fef3c7, #fde68a);
}

.dark .mission-box {
    background: rgba(245, 158, 11, 0.15);
}

.mission-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: #92400e;
    margin-bottom: 0.5rem;
}

.dark .mission-title {
    color: #fcd34d;
}

.core-advice {
    font-size: 1rem;
    font-weight: 500;
    color: #374151;
    line-height: 1.8;
    margin-bottom: 1rem;
}

.dark .core-advice {
    color: #e5e7eb;
}

.practical-advice {
    margin: 0;
    padding-left: 1.25rem;
}

.practical-advice li {
    margin-bottom: 0.5rem;
    line-height: 1.6;
}

.warning-box {
    border-left-color: #ef4444;
    background: #fef2f2;
}

.dark .warning-box {
    background: rgba(239, 68, 68, 0.1);
}

.warning-box h4 {
    color: #dc2626;
}

.warning-box ul {
    margin: 0;
    padding-left: 1.25rem;
}

.warning-box li {
    margin-bottom: 0.5rem;
    color: #991b1b;
}

.dark .warning-box li {
    color: #fca5a5;
}

.encouragement-box {
    text-align: center;
    padding: 1.5rem;
    background: linear-gradient(135deg, #f0fdf4, #dcfce7);
    border-radius: 0.75rem;
    margin-top: 1rem;
}

.dark .encouragement-box {
    background: rgba(16, 185, 129, 0.15);
}

.encouragement-text {
    font-size: 1rem;
    color: #166534;
    line-height: 1.8;
    margin: 0 0 1rem 0;
}

.dark .encouragement-text {
    color: #86efac;
}

.final-word {
    font-size: 1.1rem;
    font-weight: 600;
    color: #059669;
    margin: 0;
}

.dark .final-word {
    color: #34d399;
}

/* 신살 */
.sinsal-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.sinsal-item {
    padding: 0.75rem 1rem;
    border-radius: 0.5rem;
    background: #f3f4f6;
}

.dark .sinsal-item {
    background: #374151;
}

.sinsal-item.대길 {
    background: #dcfce7;
}

.sinsal-item.길 {
    background: #dbeafe;
}

.sinsal-item.흉 {
    background: #fee2e2;
}

.sinsal-name {
    font-weight: 600;
    color: #374151;
    margin-bottom: 0.25rem;
}

.dark .sinsal-name {
    color: #e5e7eb;
}

.sinsal-hanja {
    font-weight: normal;
    color: #6b7280;
}

.sinsal-desc {
    font-size: 0.85rem;
    color: #4b5563;
    margin: 0;
}

.dark .sinsal-desc {
    color: #d1d5db;
}

/* 행운 요소 */
.lucky-card {
    background: linear-gradient(135deg, #a855f7, #8b5cf6);
    color: white;
}

.lucky-card .card-title {
    color: white;
}

.lucky-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

.lucky-item {
    text-align: center;
    padding: 1rem;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 0.75rem;
}

.lucky-label {
    display: block;
    font-size: 0.75rem;
    opacity: 0.9;
    margin-bottom: 0.25rem;
}

.lucky-value {
    font-size: 1.1rem;
    font-weight: 600;
}

/* 후원 안내 (분석 전) */
.donation-notice {
    display: flex;
    gap: 0.75rem;
    align-items: flex-start;
    padding: 1rem;
    background: linear-gradient(135deg, rgba(139, 92, 246, 0.08), rgba(168, 85, 247, 0.05));
    border: 1px solid rgba(139, 92, 246, 0.2);
    border-radius: 0.75rem;
    margin-bottom: 1.5rem;
}

.donation-notice-icon {
    font-size: 1.5rem;
    flex-shrink: 0;
}

.donation-notice-text {
    font-size: 0.9rem;
    color: #4b5563;
    line-height: 1.5;
}

.donation-notice-text p {
    margin: 0 0 0.25rem 0;
}

.donation-notice-text p:last-child {
    margin-bottom: 0;
}

.donation-notice-text a {
    color: #7c3aed;
    font-weight: 600;
    text-decoration: underline;
}

.dark .donation-notice {
    background: linear-gradient(135deg, rgba(139, 92, 246, 0.12), rgba(168, 85, 247, 0.08));
}

.dark .donation-notice-text {
    color: #cbd5e1;
}

.dark .donation-notice-text a {
    color: #a78bfa;
}

/* 후원 카드 (결과 후) */
.donation-card {
    text-align: center;
}

.donation-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #6d28d9;
    margin-bottom: 0.75rem;
}

.dark .donation-title {
    color: #a78bfa;
}

.donation-content p {
    color: #6b7280;
    font-size: 0.9rem;
    margin-bottom: 0.5rem;
}

.dark .donation-content p {
    color: #9ca3af;
}

.donation-btn {
    display: inline-block;
    padding: 0.75rem 2rem;
    background: #fee500;
    color: #000;
    font-weight: bold;
    border-radius: 0.5rem;
    text-decoration: none;
    margin: 1rem 0;
    transition: transform 0.2s;
}

.donation-btn:hover {
    transform: translateY(-2px);
}

.donation-note {
    font-size: 0.8rem !important;
    color: #9ca3af !important;
}

/* 액션 버튼 */
.action-buttons {
    display: flex;
    gap: 1rem;
    margin-top: 1rem;
}

.reset-btn,
.pdf-btn {
    flex: 1;
    padding: 1rem;
    border-radius: 0.75rem;
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
}

.reset-btn {
    background: #f3f4f6;
    border: 1px solid #e5e7eb;
    color: #4b5563;
}

.dark .reset-btn {
    background: #374151;
    border-color: #4b5563;
    color: #d1d5db;
}

.pdf-btn {
    background: #3b82f6;
    border: none;
    color: white;
}

.pdf-btn:hover {
    background: #2563eb;
}

.pdf-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* 에러 메시지 */
.error-message {
    position: fixed;
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%);
    background: #ef4444;
    color: white;
    padding: 1rem 1.5rem;
    border-radius: 0.75rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
    z-index: 1000;
}

.error-close {
    background: none;
    border: none;
    color: white;
    font-size: 1.25rem;
    cursor: pointer;
}

/* 반응형 */
@media (max-width: 640px) {
    .premium-title {
        font-size: 1.5rem;
    }

    .date-inputs {
        grid-template-columns: 1fr;
    }

    .gender-buttons {
        flex-direction: column;
    }

    .saju-pillars {
        flex-wrap: wrap;
    }

    .result-tabs {
        flex-wrap: nowrap;
    }

    .result-tab {
        font-size: 0.7rem;
        padding: 0.5rem 0.25rem;
    }

    .trait-grid,
    .yongsin-grid,
    .method-list {
        grid-template-columns: 1fr;
    }

    .lucky-grid {
        grid-template-columns: 1fr;
    }

    .action-buttons {
        flex-direction: column;
    }

    .name-display {
        flex-direction: column;
        gap: 0.25rem;
    }

    .char-analysis {
        padding: 0.75rem;
    }

    .harmony-score {
        flex-direction: column;
        gap: 0.25rem;
    }

    .name-effects {
        grid-template-columns: 1fr;
    }
}

/* 성명학 분석 섹션 */
.name-display {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    padding: 1.5rem;
    background: linear-gradient(135deg, #ede9fe, #ddd6fe);
    border-radius: 1rem;
    margin-bottom: 1.5rem;
}

.dark .name-display {
    background: linear-gradient(135deg, #4c1d95, #5b21b6);
}

.name-hanja {
    font-size: 2rem;
    font-weight: 700;
    color: #5b21b6;
}

.dark .name-hanja {
    color: #e9d5ff;
}

.name-korean {
    font-size: 1.1rem;
    color: #7c3aed;
}

.dark .name-korean {
    color: #c4b5fd;
}

.stroke-count {
    font-size: 1.75rem;
    font-weight: 700;
    color: #8b5cf6;
    margin-bottom: 0.5rem;
}

.char-analysis {
    padding: 1rem;
    background: #f5f3ff;
    border-radius: 0.75rem;
    margin-bottom: 0.75rem;
}

.dark .char-analysis {
    background: rgba(139, 92, 246, 0.1);
}

.char-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 0.5rem;
}

.char-hanja {
    font-size: 1.5rem;
    font-weight: 700;
    color: #6d28d9;
    min-width: 2rem;
    text-align: center;
}

.dark .char-hanja {
    color: #c4b5fd;
}

.char-info {
    font-size: 0.85rem;
    color: #7c3aed;
}

.dark .char-info {
    color: #a78bfa;
}

.char-desc {
    font-size: 0.9rem;
    color: #4b5563;
    margin: 0;
    padding-left: 3rem;
}

.dark .char-desc {
    color: #d1d5db;
}

.harmony-score {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    background: linear-gradient(135deg, #fef3c7, #fde68a);
    border-radius: 0.75rem;
    margin-bottom: 0.75rem;
}

.dark .harmony-score {
    background: linear-gradient(135deg, #78350f, #92400e);
}

.harmony-label {
    font-size: 0.9rem;
    color: #92400e;
}

.dark .harmony-label {
    color: #fcd34d;
}

.harmony-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: #78350f;
}

.dark .harmony-value {
    color: #fef3c7;
}

.harmony-grade {
    padding: 0.25rem 0.75rem;
    background: #92400e;
    color: white;
    border-radius: 1rem;
    font-size: 0.85rem;
    font-weight: 600;
}

.dark .harmony-grade {
    background: #fbbf24;
    color: #78350f;
}

.name-effects {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.effect-item {
    padding: 0.75rem;
    border-radius: 0.5rem;
}

.effect-item.positive {
    background: #dcfce7;
}

.effect-item.negative {
    background: #fef3c7;
}

.dark .effect-item.positive {
    background: rgba(16, 185, 129, 0.15);
}

.dark .effect-item.negative {
    background: rgba(245, 158, 11, 0.15);
}

.effect-item strong {
    display: block;
    font-size: 0.85rem;
    margin-bottom: 0.5rem;
    color: #374151;
}

.dark .effect-item strong {
    color: #e5e7eb;
}

.effect-item ul {
    margin: 0;
    padding-left: 1rem;
    font-size: 0.8rem;
}

.effect-item ul li {
    margin-bottom: 0.25rem;
}

/* 오행 균형 섹션 */
.ohang-balance-section {
    border: 2px solid #c4b5fd;
    background: linear-gradient(135deg, rgba(237, 233, 254, 0.5), rgba(221, 214, 254, 0.5));
}

.dark .ohang-balance-section {
    border-color: #7c3aed;
    background: linear-gradient(135deg, rgba(139, 92, 246, 0.1), rgba(124, 58, 237, 0.1));
}

.ohang-balance-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

@media (max-width: 640px) {
    .ohang-balance-grid {
        grid-template-columns: 1fr;
    }
}

.balance-item {
    padding: 1rem;
    border-radius: 0.75rem;
}

.balance-item.excess {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.3);
}

.balance-item.lacking {
    background: rgba(59, 130, 246, 0.1);
    border: 1px solid rgba(59, 130, 246, 0.3);
}

.dark .balance-item.excess {
    background: rgba(239, 68, 68, 0.15);
    border-color: rgba(239, 68, 68, 0.4);
}

.dark .balance-item.lacking {
    background: rgba(59, 130, 246, 0.15);
    border-color: rgba(59, 130, 246, 0.4);
}

.balance-label {
    font-weight: 600;
    font-size: 0.9rem;
    margin-bottom: 0.5rem;
    color: #374151;
}

.dark .balance-label {
    color: #e5e7eb;
}

.balance-item p {
    font-size: 0.85rem;
    color: #4b5563;
    line-height: 1.5;
    margin: 0;
}

.dark .balance-item p {
    color: #d1d5db;
}

/* 보너스 탭 스타일 */
.bonus-tab {
    background: linear-gradient(135deg, #ede9fe, #ddd6fe);
    color: #7c3aed;
}

.bonus-tab.active {
    background: linear-gradient(135deg, #8b5cf6, #7c3aed);
    color: white;
}

.dark .bonus-tab {
    background: rgba(139, 92, 246, 0.2);
    color: #c4b5fd;
}

.dark .bonus-tab.active {
    background: linear-gradient(135deg, #8b5cf6, #7c3aed);
    color: white;
}

/* ================================
   월운 (12개월 운세) 섹션
   ================================ */
.monthly-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.75rem;
    margin-top: 1rem;
}

@media (max-width: 768px) {
    .monthly-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .monthly-grid {
        grid-template-columns: 1fr;
    }
}

.monthly-card {
    padding: 0.75rem;
    border-radius: 0.75rem;
    background: #f8fafc;
    border-left: 4px solid #9ca3af;
}

.dark .monthly-card {
    background: #1e293b;
}

.monthly-card.rating-상 {
    border-left-color: #22c55e;
    background: linear-gradient(135deg, #f0fdf4, #dcfce7);
}

.monthly-card.rating-중 {
    border-left-color: #eab308;
    background: linear-gradient(135deg, #fefce8, #fef9c3);
}

.monthly-card.rating-하 {
    border-left-color: #ef4444;
    background: linear-gradient(135deg, #fef2f2, #fee2e2);
}

.dark .monthly-card.rating-상 {
    background: rgba(34, 197, 94, 0.1);
}

.dark .monthly-card.rating-중 {
    background: rgba(234, 179, 8, 0.1);
}

.dark .monthly-card.rating-하 {
    background: rgba(239, 68, 68, 0.1);
}

.monthly-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.5rem;
}

.monthly-name {
    font-weight: 700;
    color: #1f2937;
}

.dark .monthly-name {
    color: #f1f5f9;
}

.monthly-rating {
    font-size: 0.75rem;
    padding: 0.125rem 0.5rem;
    border-radius: 1rem;
    background: rgba(0, 0, 0, 0.1);
}

.monthly-theme {
    font-size: 0.85rem;
    font-weight: 600;
    color: #6366f1;
    margin-bottom: 0.5rem;
}

.dark .monthly-theme {
    color: #a5b4fc;
}

.monthly-details {
    font-size: 0.8rem;
    margin-bottom: 0.5rem;
}

.monthly-opp {
    color: #166534;
    margin: 0.25rem 0;
}

.monthly-warn {
    color: #dc2626;
    margin: 0.25rem 0;
}

.dark .monthly-opp {
    color: #86efac;
}

.dark .monthly-warn {
    color: #fca5a5;
}

.monthly-advice {
    font-size: 0.75rem;
    color: #6b7280;
    margin: 0;
    font-style: italic;
}

.monthly-summary {
    display: flex;
    gap: 1rem;
    margin-top: 1rem;
    padding: 1rem;
    background: #f3f4f6;
    border-radius: 0.75rem;
}

.dark .monthly-summary {
    background: #1e293b;
}

.best-months, .caution-months {
    flex: 1;
    text-align: center;
}

.best-months strong {
    color: #22c55e;
}

.caution-months strong {
    color: #f59e0b;
}

/* ================================
   자녀운, 학업운, 귀인운 추가 스타일
   ================================ */
.aptitude-type {
    font-size: 1.25rem;
    font-weight: 700;
    color: #6366f1;
    margin-bottom: 0.5rem;
}

.dark .aptitude-type {
    color: #a5b4fc;
}

.benefactor-type {
    padding: 0.75rem;
    background: #f8fafc;
    border-radius: 0.5rem;
    margin-bottom: 0.75rem;
    border-left: 3px solid #8b5cf6;
}

.dark .benefactor-type {
    background: #1e293b;
}

.benefactor-name {
    font-weight: 600;
    color: #7c3aed;
    margin-bottom: 0.25rem;
}

.dark .benefactor-name {
    color: #c4b5fd;
}

.benefactor-traits {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.5rem;
}

.benefactor-traits p {
    margin: 0;
    font-size: 0.9rem;
}

.career-tag.recommended {
    background: linear-gradient(135deg, #8b5cf6, #6366f1);
    color: white;
}

/* ================================
   12운성 스타일
   ================================ */
.card-desc {
    font-size: 0.85rem;
    color: #6b7280;
    margin: 0 0 1rem 0;
}

.dark .card-desc {
    color: #9ca3af;
}

.woonsung-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.75rem;
}

@media (max-width: 640px) {
    .woonsung-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

.woonsung-item {
    padding: 1rem;
    background: linear-gradient(135deg, #ede9fe, #ddd6fe);
    border-radius: 0.75rem;
    text-align: center;
}

.dark .woonsung-item {
    background: linear-gradient(135deg, #4c1d95, #5b21b6);
}

.woonsung-position {
    font-size: 0.75rem;
    color: #7c3aed;
    margin-bottom: 0.25rem;
}

.dark .woonsung-position {
    color: #c4b5fd;
}

.woonsung-name {
    font-size: 1.25rem;
    font-weight: 700;
    color: #5b21b6;
}

.dark .woonsung-name {
    color: #e9d5ff;
}

.woonsung-hanja {
    font-size: 0.85rem;
    color: #7c3aed;
    margin-bottom: 0.5rem;
}

.dark .woonsung-hanja {
    color: #c4b5fd;
}

.woonsung-meaning {
    font-size: 0.75rem;
    color: #6b7280;
    margin: 0;
    line-height: 1.4;
}

.dark .woonsung-meaning {
    color: #d1d5db;
}

/* ================================
   합충형파해 스타일
   ================================ */
.hapchung-section {
    margin-bottom: 1rem;
}

.hapchung-section:last-child {
    margin-bottom: 0;
}

.hapchung-title {
    font-size: 0.9rem;
    font-weight: 600;
    color: #374151;
    margin: 0 0 0.5rem 0;
}

.dark .hapchung-title {
    color: #e5e7eb;
}

.hapchung-item {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    border-radius: 0.5rem;
    margin-bottom: 0.5rem;
    align-items: center;
}

.hapchung-item.good {
    background: #dcfce7;
}

.hapchung-item.perfect {
    background: linear-gradient(135deg, #bbf7d0, #86efac);
}

.hapchung-item.partial {
    background: #fef3c7;
}

.hapchung-item.bad {
    background: #fee2e2;
}

.hapchung-item.warning {
    background: #fef3c7;
}

.dark .hapchung-item.good {
    background: rgba(34, 197, 94, 0.15);
}

.dark .hapchung-item.perfect {
    background: rgba(34, 197, 94, 0.25);
}

.dark .hapchung-item.partial {
    background: rgba(234, 179, 8, 0.15);
}

.dark .hapchung-item.bad {
    background: rgba(239, 68, 68, 0.15);
}

.dark .hapchung-item.warning {
    background: rgba(234, 179, 8, 0.15);
}

.hapchung-name {
    font-weight: 600;
    color: #1f2937;
    min-width: 80px;
}

.dark .hapchung-name {
    color: #f1f5f9;
}

.hapchung-desc {
    flex: 1;
    font-size: 0.85rem;
    color: #4b5563;
}

.dark .hapchung-desc {
    color: #d1d5db;
}

.hapchung-position {
    font-size: 0.75rem;
    color: #6b7280;
    background: rgba(0, 0, 0, 0.05);
    padding: 0.125rem 0.5rem;
    border-radius: 1rem;
}

.dark .hapchung-position {
    background: rgba(255, 255, 255, 0.1);
}

.no-data {
    text-align: center;
    color: #6b7280;
    font-size: 0.9rem;
    padding: 1rem;
}

.no-data.good {
    color: #22c55e;
}

.dark .no-data {
    color: #9ca3af;
}

.dark .no-data.good {
    color: #86efac;
}

/* ================================
   공망 스타일
   ================================ */
.gongmang-info {
    display: flex;
    justify-content: center;
    margin-bottom: 1rem;
}

.gongmang-jiji {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1.5rem;
    background: #f3f4f6;
    border-radius: 2rem;
}

.dark .gongmang-jiji {
    background: #1e293b;
}

.gongmang-label {
    font-size: 0.85rem;
    color: #6b7280;
}

.gongmang-value {
    font-size: 1.25rem;
    font-weight: 700;
    color: #6366f1;
}

.dark .gongmang-value {
    color: #a5b4fc;
}

.gongmang-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.75rem;
}

@media (max-width: 640px) {
    .gongmang-list {
        grid-template-columns: 1fr;
    }
}

.gongmang-item {
    padding: 0.75rem;
    background: #fef3c7;
    border-radius: 0.5rem;
    border-left: 3px solid #f59e0b;
}

.dark .gongmang-item {
    background: rgba(245, 158, 11, 0.15);
}

.gongmang-position {
    font-weight: 600;
    color: #92400e;
    margin-bottom: 0.25rem;
}

.dark .gongmang-position {
    color: #fcd34d;
}

.gongmang-meaning {
    font-size: 0.85rem;
    color: #78350f;
    margin: 0;
}

.dark .gongmang-meaning {
    color: #fef3c7;
}

/* ================================
   도구 정보 섹션 (소개/사용법/꿀팁/FAQ)
   - 프리미엄 사주 카드 스타일과 통일
   ================================ */
.tool-info-section {
    max-width: 800px;
    margin: 3rem auto 0;
    padding: 0 1rem;
}

.info-card {
    background: linear-gradient(145deg, #f8f7ff, #f3f0ff);
    border: 1px solid rgba(139, 92, 246, 0.15);
    border-radius: 1rem;
    padding: 1.5rem;
    margin-bottom: 1.5rem;
    box-shadow: 0 4px 20px rgba(139, 92, 246, 0.08);
}

.dark .info-card {
    background: linear-gradient(145deg, #1a1333, #0f0a1e);
    border-color: rgba(139, 92, 246, 0.2);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}

.info-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: #4c1d95;
    margin: 0 0 1rem 0;
    padding-bottom: 0.75rem;
    border-bottom: 2px solid rgba(139, 92, 246, 0.2);
}

.dark .info-title {
    color: #c4b5fd;
    border-bottom-color: rgba(139, 92, 246, 0.3);
}

.info-content {
    color: #4b5563;
    line-height: 1.7;
}

.dark .info-content {
    color: #cbd5e1;
}

.info-content p {
    margin: 0 0 1rem 0;
}

.info-content p:last-child {
    margin-bottom: 0;
}

.feature-list {
    list-style: none;
    padding: 0;
    margin: 1rem 0 0 0;
}

.feature-list li {
    padding: 0.5rem 0;
    border-bottom: 1px solid rgba(139, 92, 246, 0.1);
}

.feature-list li:last-child {
    border-bottom: none;
}

.dark .feature-list li {
    border-bottom-color: rgba(139, 92, 246, 0.15);
}

/* 사용법 단계 */
.step-guide {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.step-item {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
}

.step-number {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    min-width: 32px;
    background: linear-gradient(135deg, #8b5cf6, #6366f1);
    color: white;
    font-weight: 700;
    border-radius: 50%;
    font-size: 0.9rem;
}

.step-text strong {
    display: block;
    color: #4c1d95;
    margin-bottom: 0.25rem;
}

.dark .step-text strong {
    color: #c4b5fd;
}

.step-text p {
    margin: 0;
    font-size: 0.9rem;
    color: #6b7280;
}

.dark .step-text p {
    color: #9ca3af;
}

/* 꿀팁 그리드 */
.tip-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

@media (max-width: 640px) {
    .tip-grid {
        grid-template-columns: 1fr;
    }
}

.tip-item {
    display: flex;
    gap: 0.75rem;
    padding: 1rem;
    background: rgba(139, 92, 246, 0.05);
    border: 1px solid rgba(139, 92, 246, 0.1);
    border-radius: 0.75rem;
    transition: all 0.2s;
}

.tip-item:hover {
    background: rgba(139, 92, 246, 0.08);
    border-color: rgba(139, 92, 246, 0.2);
}

.dark .tip-item {
    background: rgba(139, 92, 246, 0.08);
    border-color: rgba(139, 92, 246, 0.15);
}

.dark .tip-item:hover {
    background: rgba(139, 92, 246, 0.12);
}

.tip-icon {
    font-size: 1.5rem;
    min-width: 2rem;
}

.tip-text strong {
    display: block;
    color: #4c1d95;
    font-size: 0.95rem;
    margin-bottom: 0.25rem;
}

.dark .tip-text strong {
    color: #c4b5fd;
}

.tip-text p {
    margin: 0;
    font-size: 0.85rem;
    color: #6b7280;
    line-height: 1.5;
}

.dark .tip-text p {
    color: #9ca3af;
}

/* FAQ 리스트 */
.faq-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.faq-item {
    border: 1px solid rgba(139, 92, 246, 0.15);
    border-radius: 0.75rem;
    overflow: hidden;
    transition: all 0.2s;
}

.faq-item:hover {
    border-color: rgba(139, 92, 246, 0.3);
    box-shadow: 0 2px 8px rgba(139, 92, 246, 0.1);
}

.dark .faq-item {
    border-color: rgba(139, 92, 246, 0.2);
}

.faq-question {
    padding: 1rem;
    background: rgba(139, 92, 246, 0.05);
    font-weight: 600;
    color: #4c1d95;
    font-size: 0.95rem;
}

.dark .faq-question {
    background: rgba(139, 92, 246, 0.1);
    color: #c4b5fd;
}

.faq-answer {
    padding: 1rem;
    font-size: 0.9rem;
    color: #4b5563;
    line-height: 1.6;
    border-top: 1px solid rgba(139, 92, 246, 0.1);
    background: rgba(255, 255, 255, 0.5);
}

.dark .faq-answer {
    color: #cbd5e1;
    border-top-color: rgba(139, 92, 246, 0.15);
    background: rgba(0, 0, 0, 0.2);
}

/* ============================================
   통일된 PDF 스타일 (ai-fortune 기준)
   ============================================ */

.pdf-content {
    background: #ffffff;
    color: #1f2937;
    padding: 2rem;
    font-family: 'Pretendard', sans-serif;
    max-width: 600px;
    line-height: 1.6;
}

.pdf-header {
    text-align: center;
    margin-bottom: 2rem;
    padding-bottom: 1rem;
    border-bottom: 2px solid #8b5cf6;
}

.pdf-title {
    font-size: 1.5rem;
    font-weight: bold;
    color: #8b5cf6;
    margin-bottom: 0.5rem;
}

.pdf-info {
    color: #6b7280;
    font-size: 0.9rem;
}

.pdf-section {
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid #e5e7eb;
}

.pdf-section:last-of-type {
    border-bottom: none;
}

.pdf-section-title {
    font-size: 1.1rem;
    font-weight: bold;
    color: #374151;
    margin-bottom: 0.75rem;
}

.pdf-pillars {
    display: flex;
    justify-content: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.pdf-pillar {
    text-align: center;
    padding: 0.75rem 1rem;
    background: #f3f0ff;
    border-radius: 0.5rem;
    min-width: 60px;
}

.pdf-pillar-label {
    font-size: 0.75rem;
    color: #6b7280;
    margin-bottom: 0.25rem;
}

.pdf-pillar-value {
    font-size: 1.25rem;
    color: #92400e;
    font-weight: bold;
}

.pdf-pillar-korean {
    font-size: 0.7rem;
    color: #9ca3af;
}

.pdf-summary {
    background: #fef3c7;
    color: #92400e;
    padding: 0.75rem;
    border-radius: 0.5rem;
    font-weight: 500;
    margin-bottom: 0.75rem;
}

.pdf-analysis {
    color: #4b5563;
    line-height: 1.7;
    font-size: 0.9rem;
}

.pdf-analysis p {
    margin-bottom: 0.5rem;
}

.pdf-subsections {
    margin: 0.75rem 0;
}

.pdf-subsection {
    margin-bottom: 0.75rem;
    padding: 0.75rem;
    background: #f9fafb;
    border-radius: 0.5rem;
    border-left: 3px solid #8b5cf6;
}

.pdf-subsection-title {
    font-size: 0.85rem;
    font-weight: 600;
    color: #4c1d95;
    margin-bottom: 0.5rem;
}

.pdf-subsection-content {
    font-size: 0.8rem;
    line-height: 1.6;
    color: #4b5563;
}

.pdf-advice {
    margin: 0.75rem 0;
    padding: 0.75rem;
    background: #fef3c7;
    border-radius: 0.5rem;
    font-size: 0.85rem;
    color: #92400e;
}

.pdf-grid {
    display: flex;
    gap: 1rem;
    margin-top: 1rem;
}

.pdf-box {
    flex: 1;
    padding: 0.75rem;
    background: #f9fafb;
    border-radius: 0.5rem;
}

.pdf-box-title {
    font-size: 0.85rem;
    font-weight: 500;
    margin-bottom: 0.5rem;
    color: #374151;
}

.pdf-box ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.pdf-box li {
    font-size: 0.8rem;
    color: #6b7280;
    padding: 0.15rem 0;
}

.pdf-lucky,
.pdf-compat {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    font-size: 0.9rem;
    color: #4b5563;
}

.pdf-lucky strong,
.pdf-compat strong {
    color: #7c3aed;
}

.pdf-footer {
    text-align: center;
    font-size: 0.75rem;
    color: #9ca3af;
    margin-top: 2rem;
    padding-top: 1rem;
    border-top: 1px solid #e5e7eb;
}

/* ===================================
   서비스 마감 안내
=================================== */
.service-closed-card {
    max-width: 600px;
    margin: 2rem auto;
    padding: 3rem 2rem;
    background: linear-gradient(145deg, #fef3ff, #fae8ff);
    border: 2px solid #d8b4fe;
    border-radius: 1.5rem;
    text-align: center;
    box-shadow: 0 10px 40px rgba(139, 92, 246, 0.15);
}

.closed-icon {
    font-size: 4rem;
    margin-bottom: 1rem;
}

.closed-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: #7c3aed;
    margin-bottom: 1rem;
}

.closed-message {
    font-size: 1rem;
    color: #6b7280;
    line-height: 1.8;
    margin-bottom: 2rem;
    white-space: pre-line;
}

.closed-donation {
    background: rgba(255, 255, 255, 0.7);
    padding: 1.5rem;
    border-radius: 1rem;
    margin-bottom: 2rem;
}

.closed-donation p {
    font-size: 0.9rem;
    color: #6b7280;
    margin-bottom: 0.5rem;
}

.closed-donate-btn {
    display: inline-block;
    margin-top: 1rem;
    padding: 0.875rem 2rem;
    background: linear-gradient(135deg, #a855f7, #7c3aed);
    color: white;
    font-weight: 600;
    font-size: 1rem;
    border-radius: 0.75rem;
    text-decoration: none;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(168, 85, 247, 0.4);
}

.closed-donate-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(168, 85, 247, 0.5);
}

.closed-alternatives {
    padding-top: 1.5rem;
    border-top: 1px solid #d8b4fe;
}

.closed-alternatives p {
    font-size: 0.9rem;
    color: #6b7280;
    margin-bottom: 1rem;
}

.closed-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem;
}

.closed-link {
    padding: 0.625rem 1rem;
    background: white;
    color: #7c3aed;
    font-weight: 500;
    font-size: 0.875rem;
    border-radius: 0.5rem;
    text-decoration: none;
    border: 1px solid #d8b4fe;
    transition: all 0.2s ease;
}

.closed-link:hover {
    background: #f3e8ff;
    border-color: #a855f7;
}

@media (max-width: 640px) {
    .service-closed-card {
        margin: 1rem;
        padding: 2rem 1.5rem;
    }

    .closed-icon {
        font-size: 3rem;
    }

    .closed-title {
        font-size: 1.25rem;
    }

    .closed-links {
        flex-direction: column;
    }
}
